新增依赖,添加超图网格绘制

This commit is contained in:
wanggeng 2021-12-21 23:31:26 +08:00
parent 8b6f1bdbf1
commit 4495a8262d
27 changed files with 4839 additions and 10 deletions

View File

@ -0,0 +1,30 @@
package ink.wgink.properties.map;
/**
* @ClassName: MapProperties
* @Description: 地图配置
* @Author: wanggeng
* @Date: 2021/12/19 11:18 AM
* @Version: 1.0
*/
public class MapProperties {
private String centerLng;
private String centerLat;
public String getCenterLng() {
return centerLng == null ? "" : centerLng.trim();
}
public void setCenterLng(String centerLng) {
this.centerLng = centerLng;
}
public String getCenterLat() {
return centerLat == null ? "" : centerLat.trim();
}
public void setCenterLat(String centerLat) {
this.centerLat = centerLat;
}
}

View File

@ -0,0 +1,26 @@
package ink.wgink.properties.map;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;
/**
* @ClassName: SuperMapProperties
* @Description: 超图配置
* @Author: wanggeng
* @Date: 2021/12/19 5:25 PM
* @Version: 1.0
*/
@Component
@ConfigurationProperties(prefix = "map.super-map")
public class SuperMapProperties extends MapProperties {
private String baseMapUrl;
public String getBaseMapUrl() {
return baseMapUrl == null ? "" : baseMapUrl.trim();
}
public void setBaseMapUrl(String baseMapUrl) {
this.baseMapUrl = baseMapUrl;
}
}

View File

@ -69,10 +69,12 @@
</dependency>
<!-- durid end -->
<!-- <dependency>-->
<!-- <groupId>mysql</groupId>-->
<!-- <artifactId>mysql-connector-java</artifactId>-->
<!-- </dependency>-->
<!-- gson start -->
<dependency>
<groupId>com.google.code.gson</groupId>
<artifactId>gson</artifactId>
</dependency>
<!-- gson end -->
</dependencies>

View File

@ -21,27 +21,27 @@ public class GridRouteController {
@GetMapping("save")
public ModelAndView save() {
return new ModelAndView("grid/grid/save");
return new ModelAndView("grid/grid/default/save");
}
@GetMapping("update")
public ModelAndView update() {
return new ModelAndView("grid/grid/update");
return new ModelAndView("grid/grid/default/update");
}
@GetMapping("get")
public ModelAndView get() {
return new ModelAndView("grid/grid/get");
return new ModelAndView("grid/grid/default/get");
}
@GetMapping("list")
public ModelAndView list() {
return new ModelAndView("grid/grid/list");
return new ModelAndView("grid/grid/default/list");
}
@GetMapping("list-select")
public ModelAndView listSelect() {
return new ModelAndView("grid/grid/list-select");
return new ModelAndView("grid/grid/default/list-select");
}
}

View File

@ -0,0 +1,58 @@
package ink.wgink.module.map.controller.route.grid;
import ink.wgink.interfaces.consts.ISystemConstant;
import ink.wgink.properties.map.SuperMapProperties;
import io.swagger.annotations.Api;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.servlet.ModelAndView;
/**
* @ClassName: GridRouteController
* @Description: 网格路由
* @Author: wanggeng
* @Date: 2021/10/20 9:33 上午
* @Version: 1.0
*/
@Api(tags = ISystemConstant.ROUTE_TAGS_PREFIX + "网格")
@Controller
@RequestMapping(ISystemConstant.ROUTE_PREFIX + "/grid/super-map")
public class GridSuperMapRouteController {
@Autowired
private SuperMapProperties superMapProperties;
@GetMapping("save")
public ModelAndView save() {
ModelAndView mv = new ModelAndView("grid/grid/super-map/save");
mv.addObject("superMapProperties", superMapProperties);
return mv;
}
@GetMapping("update")
public ModelAndView update() {
ModelAndView mv = new ModelAndView("grid/grid/super-map/update");
mv.addObject("superMapProperties", superMapProperties);
return mv;
}
@GetMapping("get")
public ModelAndView get() {
ModelAndView mv = new ModelAndView("grid/grid/super-map/get");
mv.addObject("superMapProperties", superMapProperties);
return mv;
}
@GetMapping("list")
public ModelAndView list() {
return new ModelAndView("grid/grid/super-map/list");
}
@GetMapping("list-select")
public ModelAndView listSelect() {
return new ModelAndView("grid/grid/super-map/list-select");
}
}

View File

@ -0,0 +1,27 @@
package ink.wgink.module.map.controller.route.grid;
import ink.wgink.interfaces.consts.ISystemConstant;
import io.swagger.annotations.Api;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.servlet.ModelAndView;
/**
* @ClassName: GridUserRouteController
* @Description: 网格用户路由
* @Author: wanggeng
* @Date: 2021/10/20 5:44 下午
* @Version: 1.0
*/
@Api(tags = ISystemConstant.ROUTE_TAGS_PREFIX + "网格用户")
@Controller
@RequestMapping(ISystemConstant.ROUTE_PREFIX + "/grid/super-map/user")
public class GridSuperMapUserRouteController {
@GetMapping("list")
public ModelAndView list() {
return new ModelAndView("grid/grid/super-map/user/list");
}
}

View File

@ -21,7 +21,7 @@ public class GridUserRouteController {
@GetMapping("list")
public ModelAndView list() {
return new ModelAndView("grid/grid/user/list");
return new ModelAndView("grid/grid/default/user/list");
}
}

View File

@ -0,0 +1,37 @@
package ink.wgink.module.map.controller.staticfile;
import ink.wgink.util.ResourceUtil;
import ink.wgink.util.request.StaticResourceRequestUtil;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.InputStream;
/**
* @ClassName: SuperMapStaticController
* @Description: 超图静态资源
* @Author: wanggeng
* @Date: 2021/12/18 10:16 PM
* @Version: 1.0
*/
@Controller
@RequestMapping("static/super-map")
public class SuperMapStaticController {
@GetMapping("css/{fileName}")
public void css(HttpServletResponse httpServletResponse, @PathVariable("fileName") String fileName) throws IOException {
InputStream inputStream = ResourceUtil.getJarResourceInputStream("static/super-map/css/" + fileName);
StaticResourceRequestUtil.download(httpServletResponse, inputStream, fileName);
}
@GetMapping("js/{fileName}")
public void js(HttpServletResponse httpServletResponse, @PathVariable("fileName") String fileName) throws IOException {
InputStream inputStream = ResourceUtil.getJarResourceInputStream("static/super-map/js/" + fileName);
StaticResourceRequestUtil.download(httpServletResponse, inputStream, fileName);
}
}

View File

@ -0,0 +1,245 @@
.marker-icon,
.marker-icon:focus {
background-color: #ffffff;
border: 1px solid #3388ff;
border-radius: 50%;
margin: -8px 0 0 -8px !important;
width: 14px !important;
height: 14px !important;
outline: 0;
transition: opacity ease 0.3s;
}
.marker-icon-middle,
.marker-icon-middle:focus {
opacity: 0.7;
margin: -6px 0 0 -6px !important;
width: 10px !important;
height: 10px !important;
}
.leaflet-pm-draggable {
cursor: move !important;
}
.cursor-marker {
cursor: crosshair;
pointer-events: none;
display: none;
}
.cursor-marker.visible {
display: block !important;
}
.leaflet-pm-invalid {
stroke: red;
transition: fill ease 0s, stroke ease 0s;
}
.rect-style-marker,
.rect-start-marker {
opacity: 0;
}
.rect-style-marker.visible,
.rect-start-marker.visible {
opacity: 1 !important;
}
.hidden {
display: none;
}
.vertexmarker-disabled {
opacity: 0.7;
}
.leaflet-pm-toolbar {
}
.leaflet-pm-toolbar .leaflet-buttons-control-button {
padding: 5px;
box-sizing: border-box;
position: relative;
z-index: 3;
}
.leaflet-pm-toolbar
.leaflet-pm-actions-container
a.leaflet-pm-action:first-child:not(.pos-right),
.leaflet-pm-toolbar
.leaflet-pm-actions-container
a.leaflet-pm-action:last-child.pos-right {
border-radius: 0;
}
.leaflet-pm-toolbar .button-container a.leaflet-buttons-control-button {
border-radius: 0;
}
.leaflet-pm-toolbar
.button-container:last-child
a.leaflet-buttons-control-button {
border-radius: 0 0 2px 2px;
}
.leaflet-pm-toolbar
.button-container:first-child
a.leaflet-buttons-control-button {
border-radius: 2px 2px 0 0;
}
.leaflet-pm-toolbar
.button-container:last-child
a.leaflet-buttons-control-button {
border-bottom: none;
}
.leaflet-pm-toolbar .control-fa-icon {
font-size: 19px;
line-height: 24px;
}
.leaflet-pm-toolbar .control-icon {
width: 100%;
height: 100%;
box-sizing: border-box;
background-size: contain;
background-repeat: no-repeat;
background-position: center center;
}
.leaflet-pm-toolbar .leaflet-pm-icon-marker {
background-image: url();
}
.leaflet-pm-toolbar .leaflet-pm-icon-polygon {
background-image: url();
}
.leaflet-pm-toolbar .leaflet-pm-icon-polyline {
background-image: url();
}
.leaflet-pm-toolbar .leaflet-pm-icon-circle {
background-image: url();
}
.leaflet-pm-toolbar .leaflet-pm-icon-circle-marker {
background-image: url();
}
.leaflet-pm-toolbar .leaflet-pm-icon-rectangle {
background-image: url();
}
.leaflet-pm-toolbar .leaflet-pm-icon-delete {
background-image: url();
}
.leaflet-pm-toolbar .leaflet-pm-icon-edit {
background-image: url();
}
.leaflet-pm-toolbar .leaflet-pm-icon-drag {
background-image: url();
}
.leaflet-pm-toolbar .leaflet-pm-icon-cut {
background-image: url();
}
.leaflet-pm-toolbar .leaflet-pm-icon-snapping {
background-image: url();
}
.leaflet-pm-toolbar .leaflet-pm-icon-rotate {
background-image: url();
}
.leaflet-buttons-control-button:hover,
.leaflet-buttons-control-button:focus {
cursor: pointer;
background-color: #f4f4f4;
}
.active .leaflet-buttons-control-button {
box-shadow: inset 0 -1px 5px 2px rgba(81, 77, 77, 0.31);
}
.leaflet-buttons-control-text-hide {
display: none;
}
.button-container {
position: relative;
}
.button-container .leaflet-pm-actions-container {
z-index: 2;
position: absolute;
top: 0;
left: 100%;
display: none;
white-space: nowrap;
direction: ltr;
}
.leaflet-right
.leaflet-pm-toolbar
.button-container
.leaflet-pm-actions-container {
right: 100%;
left: auto;
}
.button-container.active .leaflet-pm-actions-container {
display: block;
}
.button-container
.leaflet-pm-actions-container:not(.pos-right)
a.leaflet-pm-action:last-child {
border-radius: 0 3px 3px 0;
border-right: 0;
}
.button-container
.leaflet-pm-actions-container.pos-right
a.leaflet-pm-action:first-child {
border-radius: 3px 0 0 3px;
}
.button-container
.leaflet-pm-actions-container.pos-right
a.leaflet-pm-action:last-child {
border-right: 0;
}
.button-container .leaflet-pm-actions-container .leaflet-pm-action {
padding: 0 10px;
background-color: #666;
color: #fff;
display: inline-block;
width: auto;
border-right: 1px solid #eee;
user-select: none;
border-bottom: none;
height: 29px;
line-height: 29px;
}
.leaflet-pm-toolbar
.button-container:first-child.pos-right.active
a.leaflet-buttons-control-button {
border-top-left-radius: 0;
}
.leaflet-pm-toolbar
.button-container:first-child.active:not(.pos-right)
a.leaflet-buttons-control-button {
border-top-right-radius: 0;
}
.button-container .leaflet-pm-actions-container .leaflet-pm-action:hover,
.button-container .leaflet-pm-actions-container .leaflet-pm-action:focus {
cursor: pointer;
background-color: #777;
}
/* That the active control is always over the other controls */
.leaflet-pm-toolbar.activeChild {
z-index: 801;
}
.leaflet-buttons-control-button.pm-disabled {
background-color: #f4f4f4;
}
.control-icon.pm-disabled {
filter: opacity(0.6);
}

View File

@ -0,0 +1,624 @@
/* required styles */
.leaflet-pane,
.leaflet-tile,
.leaflet-marker-icon,
.leaflet-marker-shadow,
.leaflet-tile-container,
.leaflet-pane > svg,
.leaflet-pane > canvas,
.leaflet-zoom-box,
.leaflet-image-layer,
.leaflet-layer {
position: absolute;
left: 0;
top: 0;
}
.leaflet-container {
overflow: hidden;
}
.leaflet-tile,
.leaflet-marker-icon,
.leaflet-marker-shadow {
-webkit-user-select: none;
-moz-user-select: none;
user-select: none;
-webkit-user-drag: none;
}
/* Safari renders non-retina tile on retina better with this, but Chrome is worse */
.leaflet-safari .leaflet-tile {
image-rendering: -webkit-optimize-contrast;
}
/* hack that prevents hw layers "stretching" when loading new tiles */
.leaflet-safari .leaflet-tile-container {
width: 1600px;
height: 1600px;
-webkit-transform-origin: 0 0;
}
.leaflet-marker-icon,
.leaflet-marker-shadow {
display: block;
}
/* .leaflet-container svg: reset svg max-width decleration shipped in Joomla! (joomla.org) 3.x */
/* .leaflet-container img: map is broken in FF if you have max-width: 100% on tiles */
.leaflet-container .leaflet-overlay-pane svg,
.leaflet-container .leaflet-marker-pane img,
.leaflet-container .leaflet-shadow-pane img,
.leaflet-container .leaflet-tile-pane img,
.leaflet-container img.leaflet-image-layer {
max-width: none !important;
}
.leaflet-container.leaflet-touch-zoom {
-ms-touch-action: pan-x pan-y;
touch-action: pan-x pan-y;
}
.leaflet-container.leaflet-touch-drag {
-ms-touch-action: pinch-zoom;
}
.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom {
-ms-touch-action: none;
touch-action: none;
}
.leaflet-tile {
filter: inherit;
visibility: hidden;
}
.leaflet-tile-loaded {
visibility: inherit;
}
.leaflet-zoom-box {
width: 0;
height: 0;
-moz-box-sizing: border-box;
box-sizing: border-box;
z-index: 800;
}
/* workaround for https://bugzilla.mozilla.org/show_bug.cgi?id=888319 */
.leaflet-overlay-pane svg {
-moz-user-select: none;
}
.leaflet-pane { z-index: 400; }
.leaflet-tile-pane { z-index: 200; }
.leaflet-overlay-pane { z-index: 400; }
.leaflet-shadow-pane { z-index: 500; }
.leaflet-marker-pane { z-index: 600; }
.leaflet-tooltip-pane { z-index: 650; }
.leaflet-popup-pane { z-index: 700; }
.leaflet-map-pane canvas { z-index: 100; }
.leaflet-map-pane svg { z-index: 200; }
.leaflet-vml-shape {
width: 1px;
height: 1px;
}
.lvml {
behavior: url(#default#VML);
display: inline-block;
position: absolute;
}
/* control positioning */
.leaflet-control {
position: relative;
z-index: 800;
pointer-events: visiblePainted; /* IE 9-10 doesn't have auto */
pointer-events: auto;
}
.leaflet-top,
.leaflet-bottom {
position: absolute;
z-index: 1000;
pointer-events: none;
}
.leaflet-top {
top: 0;
}
.leaflet-right {
right: 0;
}
.leaflet-bottom {
bottom: 0;
}
.leaflet-left {
left: 0;
}
.leaflet-control {
float: left;
clear: both;
}
.leaflet-right .leaflet-control {
float: right;
}
.leaflet-top .leaflet-control {
margin-top: 10px;
}
.leaflet-bottom .leaflet-control {
margin-bottom: 10px;
}
.leaflet-left .leaflet-control {
margin-left: 10px;
}
.leaflet-right .leaflet-control {
margin-right: 10px;
}
/* zoom and fade animations */
.leaflet-fade-anim .leaflet-tile {
will-change: opacity;
}
.leaflet-fade-anim .leaflet-popup {
opacity: 0;
-webkit-transition: opacity 0.2s linear;
-moz-transition: opacity 0.2s linear;
-o-transition: opacity 0.2s linear;
transition: opacity 0.2s linear;
}
.leaflet-fade-anim .leaflet-map-pane .leaflet-popup {
opacity: 1;
}
.leaflet-zoom-animated {
-webkit-transform-origin: 0 0;
-ms-transform-origin: 0 0;
transform-origin: 0 0;
}
.leaflet-zoom-anim .leaflet-zoom-animated {
will-change: transform;
}
.leaflet-zoom-anim .leaflet-zoom-animated {
-webkit-transition: -webkit-transform 0.25s cubic-bezier(0,0,0.25,1);
-moz-transition: -moz-transform 0.25s cubic-bezier(0,0,0.25,1);
-o-transition: -o-transform 0.25s cubic-bezier(0,0,0.25,1);
transition: transform 0.25s cubic-bezier(0,0,0.25,1);
}
.leaflet-zoom-anim .leaflet-tile,
.leaflet-pan-anim .leaflet-tile {
-webkit-transition: none;
-moz-transition: none;
-o-transition: none;
transition: none;
}
.leaflet-zoom-anim .leaflet-zoom-hide {
visibility: hidden;
}
/* cursors */
.leaflet-interactive {
cursor: pointer;
}
.leaflet-grab {
cursor: -webkit-grab;
cursor: -moz-grab;
}
.leaflet-crosshair,
.leaflet-crosshair .leaflet-interactive {
cursor: crosshair;
}
.leaflet-popup-pane,
.leaflet-control {
cursor: auto;
}
.leaflet-dragging .leaflet-grab,
.leaflet-dragging .leaflet-grab .leaflet-interactive,
.leaflet-dragging .leaflet-marker-draggable {
cursor: move;
cursor: -webkit-grabbing;
cursor: -moz-grabbing;
}
/* marker & overlays interactivity */
.leaflet-marker-icon,
.leaflet-marker-shadow,
.leaflet-image-layer,
.leaflet-pane > svg path,
.leaflet-tile-container {
pointer-events: none;
}
.leaflet-marker-icon.leaflet-interactive,
.leaflet-image-layer.leaflet-interactive,
.leaflet-pane > svg path.leaflet-interactive {
pointer-events: visiblePainted; /* IE 9-10 doesn't have auto */
pointer-events: auto;
}
/* visual tweaks */
.leaflet-container {
background: #ddd;
outline: 0;
}
.leaflet-container a {
color: #0078A8;
}
.leaflet-container a.leaflet-active {
outline: 2px solid orange;
}
.leaflet-zoom-box {
border: 2px dotted #38f;
background: rgba(255,255,255,0.5);
}
/* general typography */
.leaflet-container {
font: 12px/1.5 "Helvetica Neue", Arial, Helvetica, sans-serif;
}
/* general toolbar styles */
.leaflet-bar {
box-shadow: 0 1px 5px rgba(0,0,0,0.65);
border-radius: 4px;
}
.leaflet-bar a,
.leaflet-bar a:hover {
background-color: #fff;
border-bottom: 1px solid #ccc;
width: 26px;
height: 26px;
line-height: 26px;
display: block;
text-align: center;
text-decoration: none;
color: black;
}
.leaflet-bar a,
.leaflet-control-layers-toggle {
background-position: 50% 50%;
background-repeat: no-repeat;
display: block;
}
.leaflet-bar a:hover {
background-color: #f4f4f4;
}
.leaflet-bar a:first-child {
border-top-left-radius: 4px;
border-top-right-radius: 4px;
}
.leaflet-bar a:last-child {
border-bottom-left-radius: 4px;
border-bottom-right-radius: 4px;
border-bottom: none;
}
.leaflet-bar a.leaflet-disabled {
cursor: default;
background-color: #f4f4f4;
color: #bbb;
}
.leaflet-touch .leaflet-bar a {
width: 30px;
height: 30px;
line-height: 30px;
}
/* zoom control */
.leaflet-control-zoom-in,
.leaflet-control-zoom-out {
font: bold 18px 'Lucida Console', Monaco, monospace;
text-indent: 1px;
}
.leaflet-control-zoom-out {
font-size: 20px;
}
.leaflet-touch .leaflet-control-zoom-in {
font-size: 22px;
}
.leaflet-touch .leaflet-control-zoom-out {
font-size: 24px;
}
/* layers control */
.leaflet-control-layers {
box-shadow: 0 1px 5px rgba(0,0,0,0.4);
background: #fff;
border-radius: 5px;
}
.leaflet-control-layers-toggle {
background-image: url(images/layers.png);
width: 36px;
height: 36px;
}
.leaflet-retina .leaflet-control-layers-toggle {
background-image: url(images/layers-2x.png);
background-size: 26px 26px;
}
.leaflet-touch .leaflet-control-layers-toggle {
width: 44px;
height: 44px;
}
.leaflet-control-layers .leaflet-control-layers-list,
.leaflet-control-layers-expanded .leaflet-control-layers-toggle {
display: none;
}
.leaflet-control-layers-expanded .leaflet-control-layers-list {
display: block;
position: relative;
}
.leaflet-control-layers-expanded {
padding: 6px 10px 6px 6px;
color: #333;
background: #fff;
}
.leaflet-control-layers-scrollbar {
overflow-y: scroll;
padding-right: 5px;
}
.leaflet-control-layers-selector {
margin-top: 2px;
position: relative;
top: 1px;
}
.leaflet-control-layers label {
display: block;
}
.leaflet-control-layers-separator {
height: 0;
border-top: 1px solid #ddd;
margin: 5px -10px 5px -6px;
}
/* Default icon URLs */
.leaflet-default-icon-path {
background-image: url(images/marker-icon.png);
}
/* attribution and scale controls */
.leaflet-container .leaflet-control-attribution {
background: #fff;
background: rgba(255, 255, 255, 0.7);
margin: 0;
}
.leaflet-control-attribution,
.leaflet-control-scale-line {
padding: 0 5px;
color: #333;
}
.leaflet-control-attribution a {
text-decoration: none;
}
.leaflet-control-attribution a:hover {
text-decoration: underline;
}
.leaflet-container .leaflet-control-attribution,
.leaflet-container .leaflet-control-scale {
font-size: 11px;
}
.leaflet-left .leaflet-control-scale {
margin-left: 5px;
}
.leaflet-bottom .leaflet-control-scale {
margin-bottom: 5px;
}
.leaflet-control-scale-line {
border: 2px solid #777;
border-top: none;
line-height: 1.1;
padding: 2px 5px 1px;
font-size: 11px;
white-space: nowrap;
overflow: hidden;
-moz-box-sizing: border-box;
box-sizing: border-box;
background: #fff;
background: rgba(255, 255, 255, 0.5);
}
.leaflet-control-scale-line:not(:first-child) {
border-top: 2px solid #777;
border-bottom: none;
margin-top: -2px;
}
.leaflet-control-scale-line:not(:first-child):not(:last-child) {
border-bottom: 2px solid #777;
}
.leaflet-touch .leaflet-control-attribution,
.leaflet-touch .leaflet-control-layers,
.leaflet-touch .leaflet-bar {
box-shadow: none;
}
.leaflet-touch .leaflet-control-layers,
.leaflet-touch .leaflet-bar {
border: 2px solid rgba(0,0,0,0.2);
background-clip: padding-box;
}
/* popup */
.leaflet-popup {
position: absolute;
text-align: center;
margin-bottom: 20px;
}
.leaflet-popup-content-wrapper {
padding: 1px;
text-align: left;
border-radius: 12px;
}
.leaflet-popup-content {
margin: 13px 19px;
line-height: 1.4;
}
.leaflet-popup-content p {
margin: 18px 0;
}
.leaflet-popup-tip-container {
width: 40px;
height: 20px;
position: absolute;
left: 50%;
margin-left: -20px;
overflow: hidden;
pointer-events: none;
}
.leaflet-popup-tip {
width: 17px;
height: 17px;
padding: 1px;
margin: -10px auto 0;
-webkit-transform: rotate(45deg);
-moz-transform: rotate(45deg);
-ms-transform: rotate(45deg);
-o-transform: rotate(45deg);
transform: rotate(45deg);
}
.leaflet-popup-content-wrapper,
.leaflet-popup-tip {
background: white;
color: #333;
box-shadow: 0 3px 14px rgba(0,0,0,0.4);
}
.leaflet-container a.leaflet-popup-close-button {
position: absolute;
top: 0;
right: 0;
padding: 4px 4px 0 0;
border: none;
text-align: center;
width: 18px;
height: 14px;
font: 16px/14px Tahoma, Verdana, sans-serif;
color: #c3c3c3;
text-decoration: none;
font-weight: bold;
background: transparent;
}
.leaflet-container a.leaflet-popup-close-button:hover {
color: #999;
}
.leaflet-popup-scrolled {
overflow: auto;
border-bottom: 1px solid #ddd;
border-top: 1px solid #ddd;
}
.leaflet-oldie .leaflet-popup-content-wrapper {
zoom: 1;
}
.leaflet-oldie .leaflet-popup-tip {
width: 24px;
margin: 0 auto;
-ms-filter: "progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";
filter: progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678);
}
.leaflet-oldie .leaflet-popup-tip-container {
margin-top: -1px;
}
.leaflet-oldie .leaflet-control-zoom,
.leaflet-oldie .leaflet-control-layers,
.leaflet-oldie .leaflet-popup-content-wrapper,
.leaflet-oldie .leaflet-popup-tip {
border: 1px solid #999;
}
/* div icon */
.leaflet-div-icon {
background: #fff;
border: 1px solid #666;
}
/* Tooltip */
/* Base styles for the element that has a tooltip */
.leaflet-tooltip {
position: absolute;
padding: 6px;
background-color: #fff;
border: 1px solid #fff;
border-radius: 3px;
color: #222;
white-space: nowrap;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
pointer-events: none;
box-shadow: 0 1px 3px rgba(0,0,0,0.4);
}
.leaflet-tooltip.leaflet-clickable {
cursor: pointer;
pointer-events: auto;
}
.leaflet-tooltip-top:before,
.leaflet-tooltip-bottom:before,
.leaflet-tooltip-left:before,
.leaflet-tooltip-right:before {
position: absolute;
pointer-events: none;
border: 6px solid transparent;
background: transparent;
content: "";
}
/* Directions */
.leaflet-tooltip-bottom {
margin-top: 6px;
}
.leaflet-tooltip-top {
margin-top: -6px;
}
.leaflet-tooltip-bottom:before,
.leaflet-tooltip-top:before {
left: 50%;
margin-left: -6px;
}
.leaflet-tooltip-top:before {
bottom: 0;
margin-bottom: -12px;
border-top-color: #fff;
}
.leaflet-tooltip-bottom:before {
top: 0;
margin-top: -12px;
margin-left: -6px;
border-bottom-color: #fff;
}
.leaflet-tooltip-left {
margin-left: -6px;
}
.leaflet-tooltip-right {
margin-left: 6px;
}
.leaflet-tooltip-left:before,
.leaflet-tooltip-right:before {
top: 50%;
margin-top: -6px;
}
.leaflet-tooltip-left:before {
right: 0;
margin-right: -12px;
border-left-color: #fff;
}
.leaflet-tooltip-right:before {
left: 0;
margin-left: -12px;
border-right-color: #fff;
}

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

View File

@ -0,0 +1,399 @@
(function () {
function SuperMap(mapContainerId, mapBox, options) {
this.mapBox = mapBox;
this.map = L.map(mapContainerId, {
crs: options.crs ? options.crs : L.CRS.EPSG3857,
center: options.center ? options.center : {lat: 0, lon: 0},
maxZoom: options.maxZoom ? options.maxZoom : 18,
zoom: options.zoom ? options.zoom : 6,
boxZoom: options.boxZoom ? options.boxZoom : false,
scrollWheelZoom: options.scrollWheelZoom ? options.scrollWheelZoom : true,
dragging: options.dragging ? options.dragging : true,
doubleClickZoom: options.doubleClickZoom ? options.doubleClickZoom : false,
zoomControl: options.zoomControl ? options.zoomControl : false
});
this.gridLayer = null;
this.gridBGLayer = null;
this.gridColor = '#000000';
this.colorOption = {
isEditColor: false,
edit: {r: 0, g: 0, b: 0},
const: {
COLOR_BOX_ID: 'B_COLOR_BOX',
COLOR_SHOW_BOX_ID: 'B_SHOW_COLOR_BOX',
COLOR_R: 'B_COLOR_R',
COLOR_G: 'B_COLOR_G',
COLOR_B: 'B_COLOR_B',
}
};
}
/**
* 初始化
* @param baseLayerUrl
*/
SuperMap.prototype.init = function (baseLayerUrl) {
var map = this.map;
L.control.zoom().addTo(map);
L.control.scale().addTo(map);
L.supermap.tiledMapLayer(baseLayerUrl, {noWrap: true}).addTo(map);
}
/**
* 初始化绘制面
*/
SuperMap.prototype.initDrawPolygon = function () {
var self = this;
self.gridLayer = L.featureGroup([]).addTo(self.map);
self.gridBGLayer = L.layerGroup([]).addTo(self.map);
self.map.pm.setLang('zh');
self.map.pm.addControls({
positions: {
draw: 'topleft',
edit: 'topleft',
custom: '',
options: ''
},
drawCircle: false,
drawMarker: false,
drawCircleMarker: false,
drawPolyline: false,
drawRectangle: false,
drawPolygon: true,
editMode: true,
dragMode: true,
cutPolygon: false,
removalMode: true,
rotateMode: true,
// 工具栏是否一个块
oneBlock: false,
drawControls: true,
editControls: false,
customControls: false,
optionsControls: false,
pinningOption: false,
snappingOption: false,
splitMode: true,
scaleMode: true
});
self.map.pm.Toolbar.createCustomControl({
name: '修改颜色',
block: 'custom',
title: '修改颜色',
className: '',
onClick: function (e) {
var colorBox = document.getElementById(self.colorOption.const.COLOR_BOX_ID);
colorBox.style.left = '50px';
colorBox.style.top = '225px';
if (!self.colorOption.isEditColor) {
colorBox.style.display = 'block';
} else {
colorBox.style.display = 'none';
}
self.colorOption.isEditColor = !self.colorOption.isEditColor;
},
toggle: true
});
self.map.pm.setPathOptions({
color: '#000000',
fillColor: '#000000',
fillOpacity: 0.4,
});
self.map.on('pm:create', function (e) {
self.map.pm.addControls({
drawControls: false,
editControls: true,
customControls: true
});
self.gridLayer.addLayer(e.layer);
e.layer.on('pm:edit', function (e) {
});
});
self.map.on('pm:remove', function (e) {
self.map.pm.addControls({
drawControls: true,
editControls: false,
customControls: false
});
})
}
/**
* 初始化网格背景
* @param gridArray
*/
SuperMap.prototype.initGridBG = function (gridArray) {
for (var i = 0, item; item = gridArray[i++];) {
this.gridBGLayer.addLayer(this.drawPolygon(item.pointArray, item.fillColor, null));
}
}
/**
* 初始化网格
* @param polygonArray
* @param color
* @param popup
*/
SuperMap.prototype.initEditGrid = function (gridArray) {
for (var i = 0, item; item = gridArray[i++];) {
var pointArray = [];
for (var j = 0, jItem; jItem = item.pointArray[j++];) {
pointArray.push([jItem.lat, jItem.lng]);
}
this.gridLayer.addLayer(this.drawPolygon(pointArray, item.fillColor, null));
}
if (gridArray.length == 0) {
return;
}
// 标记编辑
this.map.pm.addControls({
drawControls: false,
editControls: true,
customControls: true
});
}
/**
* 获取编辑网格层
* @returns 网格点数组
*/
SuperMap.prototype.getEditGridLayer = function () {
return this.gridLayer.getLayers();
}
/**
* 设置编辑网格颜色
* @param color
*/
SuperMap.prototype.setEditGridLayerColor = function (color) {
this.gridColor = color;
var layers = this.getEditGridLayer();
for (var i = 0, layer; layer = layers[i++];) {
layer.setStyle({
color: color,
fillColor: color,
});
}
}
/**
* 获取编辑网格颜色
* @returns {string}
*/
SuperMap.prototype.getGridColor = function () {
return this.gridColor;
}
/**
* 清空网格背景
*/
SuperMap.prototype.removeGridBG = function () {
this.gridBGLayer.clearLayers();
}
/**
* 获取map
* @returns {*}
*/
SuperMap.prototype.getMap = function () {
return this.map;
}
/**
* 绘制面
* @param polygonArray [{lat, lng}]
* @param color 颜色
* @param popup 点击显示内容
* @returns polygonLayer
*/
SuperMap.prototype.drawPolygon = function (polygonArray, color, popup) {
if (!popup) {
return L.polygon([polygonArray], {color: color}).addTo(this.map);
}
return L.polygon([polygonArray], {color: color}).bindPopup(popup).addTo(this.map);
}
/**
* 绘制标记
* @param point {lat, lng}
* @param popup 点击显示内容
* @returns markerLayer
*/
SuperMap.prototype.drawMarker = function (point, popup) {
if (!popup) {
return L.marker([point]).addTo(this.map);
}
return L.marker([point]).bindPopup(popup).addTo(this.map);
}
/**
* 绘制图标标记
* @param point {lat, lng}
* @param icon {url, width, height}
* @param popup 点击显示内容
* @returns markerLayer
*/
SuperMap.prototype.drawIconMarker = function (point, icon, popup) {
var iconWidth = icon.width ? icon.width : 64;
var iconHeight = icon.height ? icon.height : 64;
var icon = L.icon({
iconUrl: icon.url,
iconSize: [iconWidth, iconHeight],
iconAnchor: [iconWidth / 2, iconHeight],
popupAnchor: [0, -iconHeight],
});
if (!popup) {
return L.marker([point], {icon: icon}).addTo(this.map);
}
return L.marker([point], {icon: icon}).bindPopup(popup).addTo(this.map);
}
/**
* 绘制线
* @param pointArray 轨迹数组
* @param color 颜色
* @returns polylineLayer
*/
SuperMap.prototype.drawPolyline = function (pointArray, color) {
return L.polyline(pointArray, {color: color}).addTo(this.map);
}
/**
* 颜色RGB转16进制
* @param r
* @param g
* @param b
* @returns {string}
*/
SuperMap.prototype.colorRGBToHex = function (r, g, b) {
var red = parseInt(r, 10).toString(16);
red = red.length < 2 ? '0' + red : red;
var green = parseInt(g, 10).toString(16);
green = green.length < 2 ? '0' + green : green;
var blue = parseInt(b, 10).toString(16);
blue = blue.length < 2 ? '0' + blue : blue;
return "#" + red + green + blue;
}
/**
* 颜色16进制转RGB
* @param hex
* @returns {{r: number, b: number, g: number}}
*/
SuperMap.prototype.colorHexToRGB = function (hex) {
if (!hex) {
return {r: 0, g: 0, b: 0};
}
if (hex.indexOf('#') == 0) {
hex = hex.substring(1);
}
return {
r: parseInt(hex.substring(0, 2), 16),
g: parseInt(hex.substring(2, 4), 16),
b: parseInt(hex.substring(4, 6), 16)
}
}
// 颜色选择器
SuperMap.prototype.setShowColor = function () {
var self = this;
var colorShowBox = document.getElementById(self.colorOption.const.COLOR_SHOW_BOX_ID);
var hexColor = self.colorRGBToHex(self.colorOption.edit.r, self.colorOption.edit.g, self.colorOption.edit.b);
colorShowBox.style.backgroundColor = hexColor;
self.setEditGridLayerColor(hexColor);
}
// 设置颜色Input值
SuperMap.prototype.setColorInputValue = function (color) {
var self = this;
self.colorOption.edit = self.colorHexToRGB(color);
document.getElementById(self.colorOption.const.COLOR_R).value = self.colorOption.edit.r;
document.getElementById(self.colorOption.const.COLOR_G).value = self.colorOption.edit.g;
document.getElementById(self.colorOption.const.COLOR_B).value = self.colorOption.edit.b;
var colorShowBox = document.getElementById(self.colorOption.const.COLOR_SHOW_BOX_ID);
colorShowBox.style.backgroundColor = color;
}
/**
* 初始化颜色选择
*/
SuperMap.prototype.initColorOption = function () {
var self = this;
// 获取颜色选择器
function getColorInput(inputId, title, value) {
var colorInput = document.createElement('div');
colorInput.style.width = '100%';
colorInput.style.textAlign = 'center';
var colorInputInput = document.createElement('input');
colorInputInput.setAttribute('id', inputId);
colorInputInput.setAttribute('type', 'range');
colorInputInput.setAttribute('min', 0);
colorInputInput.setAttribute('max', 255);
colorInputInput.setAttribute('value', value);
colorInputInput.style.width = '100px';
colorInputInput.addEventListener('mousemove', function (event) {
self.colorOption.edit = {
r: document.getElementById(self.colorOption.const.COLOR_R).value,
g: document.getElementById(self.colorOption.const.COLOR_G).value,
b: document.getElementById(self.colorOption.const.COLOR_B).value
}
// 修改区域颜色
self.setShowColor();
});
var titleSpan = document.createElement('span');
titleSpan.appendChild(document.createTextNode(title));
colorInput.appendChild(titleSpan);
colorInput.appendChild(colorInputInput);
return colorInput;
}
// 颜色选BOX
function getColorInputBox() {
var colorInputBox = document.createElement('div');
colorInputBox.style.display = 'inline-block';
colorInputBox.style.width = '124px';
colorInputBox.style.verticalAlign = 'top';
var firstColorInput = getColorInput(self.colorOption.const.COLOR_R, '红', self.colorOption.edit.r);
firstColorInput.style.marginTop = '2px';
colorInputBox.appendChild(firstColorInput);
colorInputBox.appendChild(getColorInput(self.colorOption.const.COLOR_G, '绿', self.colorOption.edit.g));
colorInputBox.appendChild(getColorInput(self.colorOption.const.COLOR_B, '蓝', self.colorOption.edit.b));
return colorInputBox;
}
// 颜色BOX
function getColorBox(colorOptionBox) {
var colorBox = document.createElement('div');
colorBox.setAttribute('id', self.colorOption.const.COLOR_SHOW_BOX_ID);
colorBox.style.display = 'inline-block';
colorBox.style.width = '70px';
colorBox.style.height = '100%';
colorBox.style.borderRight = '1px solid silver';
colorBox.style.backgroundColor = self.colorRGBToHex(self.colorOption.edit.r, self.colorOption.edit.g, self.colorOption.edit.b);
return colorBox;
}
var colorOptionBox = document.createElement('div');
colorOptionBox.setAttribute('id', self.colorOption.const.COLOR_BOX_ID);
colorOptionBox.style.backgroundColor = '#FFFFFF';
colorOptionBox.style.display = 'none';
colorOptionBox.style.width = '210px';
colorOptionBox.style.height = '70px';
colorOptionBox.style.border = '1px solid silver';
colorOptionBox.style.position = 'absolute';
colorOptionBox.style.top = '0';
colorOptionBox.style.left = '0';
colorOptionBox.style.zIndex = 1000;
colorOptionBox.appendChild(getColorBox());
colorOptionBox.appendChild(getColorInputBox());
var mapContainer = document.getElementById(this.mapBox);
mapContainer.appendChild(colorOptionBox);
}
window.SuperMap = SuperMap;
})();

View File

@ -0,0 +1,153 @@
<!doctype html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
<base th:href="${#request.getContextPath() + '/'}">
<meta charset="utf-8">
<meta name="renderer" content="webkit">
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
<meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=0">
<link rel="stylesheet" href="assets/fonts/font-awesome/css/font-awesome.css"/>
<link rel="stylesheet" href="assets/layuiadmin/layui/css/layui.css" media="all">
<link rel="stylesheet" href="assets/layuiadmin/style/admin.css" media="all">
<link rel="stylesheet" href="static/super-map/css/leaflet.css">
<link rel="stylesheet" href="static/super-map/css/leaflet-geoman.css">
<style>
.layui-form-label-up {width: 100% !important; height: 30px !important; line-height: 30px !important; border: none !important; padding: 0px !important; font-size: 15px; background-color: transparent !important; text-align: left !important;}
.layui-input-block-down {margin: 0px !important; left: 0px !important;}
.layui-input-block-down .layui-form-select .layui-edge {top: 74%;}
</style>
</head>
<body>
<div class="layui-anim layui-anim-fadein">
<div class="layui-card">
<div class="layui-card-body" style="padding: 15px;">
<form class="layui-form layui-form-pane" lay-filter="dataForm">
<div id="mapBox">
<div id="superMapContainer"></div>
</div>
</form>
</div>
</div>
</div>
<script type="text/javascript" src="static/super-map/js/leaflet.min.js"></script>
<script type="text/javascript" src="static/super-map/js/iclient-leaflet.min.js"></script>
<script type="text/javascript" src="static/super-map/js/leaflet-geoman.min.js"></script>
<script type="text/javascript" src="static/super-map/js/super-map-1.0.0.min.js"></script>
<script src="assets/layuiadmin/layui/layui.js"></script>
<script th:inline="javascript">
layui.config({
base: 'assets/layuiadmin/' //静态资源所在路径
}).extend({
index: 'lib/index' //主入口模块
}).use(['index', 'form', 'laydate', 'laytpl'], function(){
var $ = layui.$;
var $win = $(window);
var form = layui.form;
var laytpl = layui.laytpl;
var laydate = layui.laydate;
var queryParams = top.restAjax.params(window.location.href);
var gridId = queryParams.gridId;
var centerPoint = {
lng: [[${superMapProperties.centerLng}]],
lat: [[${superMapProperties.centerLat}]]
}
var baiduMap = null;
var gridMember = {
users: [],
gridArray: []
}
function closeBox() {
parent.layer.close(parent.layer.getFrameIndex(window.name));
}
// 初始化网格背景
function initGridBG(areaCode, callback) {
var layIndex;
top.restAjax.get(top.restAjax.path('api/grid/list/except/{gridId}', [gridId]), {
areaCode: areaCode
}, null, function(code, data) {
var gridArray = [];
for(var i = 0, item; item = data[i++];) {
var pointArray = [];
for(var j = 0, jItem; jItem = item.pointArray[j++];) {
pointArray.push(new BaiduMap.Point(jItem.lng, jItem.lat));
}
gridArray.push({
id: item.gridId,
label: item.gridName,
fillColor: '#ffffff',
pointArray: pointArray
})
}
baiduMap.initBackgroundGrid({
gridArray: gridArray
});
callback ? callback() : '';
}, function(code, data) {
top.dialog.msg(data.msg);
}, function () {
layIndex = top.dialog.msg(top.dataMessage.loading, {icon: 16, time: 0, shade: 0.3});
}, function () {
top.dialog.close(layIndex);
});
}
function initMap(callback) {
$('#baiduMapContainer').css({
width: '100%',
height: ($win.height() - 30) +'px'
});
baiduMap = new BaiduMap('baiduMapContainer', {
single: true,
onGridStartEdit: function(baiduMap) {
$('#confirmBtn').hide();
},
onGridStopEdit: function(gridArray) {
gridMember.gridArray = gridArray;
$('#confirmBtn').show();
}
});
baiduMap.setCenterAndZoom(centerPoint, 14);
var mapTypeControl = new BMap.MapTypeControl({
mapTypes: [BMAP_NORMAL_MAP, BMAP_SATELLITE_MAP, BMAP_HYBRID_MAP],
});
baiduMap.getMap().addControl(mapTypeControl);
baiduMap.setDefaultConfig();
baiduMap.initGridOptionEvent();
baiduMap.initColorOption();
callback ? callback() : '';
}
// 初始化内容
function initData() {
top.restAjax.get(top.restAjax.path('api/grid/get/{gridId}', [gridId]), {}, null, function(code, data) {
initMap(function() {
// 背景层
initGridBG(data.areaCode, function() {
// 网格层
var grid = new BaiduMap.Grid(data.gridId, data.pointArray);
grid.setFillColor(data.fillColor);
baiduMap.setGridArray([grid]);
});
});
}, function (code, data) {
top.dialog.msg(data.msg);
}, function() {
loadLayerIndex = top.dialog.msg(top.dataMessage.loading, {icon: 16, time: 0, shade: 0.3});
}, function() {
top.dialog.close(loadLayerIndex);
});
}
initData();
// 校验
form.verify({
});
});
</script>
</body>
</html>

View File

@ -0,0 +1,318 @@
<!doctype html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
<base th:href="${#request.getContextPath() + '/'}">
<meta charset="utf-8">
<meta name="renderer" content="webkit">
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
<meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=0">
<link rel="stylesheet" href="assets/fonts/font-awesome/css/font-awesome.css"/>
<link rel="stylesheet" href="assets/layuiadmin/layui/css/layui.css" media="all">
<link rel="stylesheet" href="assets/layuiadmin/style/admin.css" media="all">
</head>
<body>
<div class="layui-anim layui-anim-fadein">
<div class="layui-row">
<div class="layui-col-md12">
<div class="layui-card">
<div class="layui-card-body">
<div class="test-table-reload-btn" style="margin-bottom: 10px;">
<div class="layui-inline">
<input type="text" id="keywords" class="layui-input search-item search-item-width-100" placeholder="输入关键字">
</div>
<button type="button" id="search" class="layui-btn layui-btn-sm">
<i class="fa fa-lg fa-search"></i> 搜索
</button>
<button type="button" id="confirm" class="layui-btn layui-btn-normal layui-btn-sm" style="float: right;">确定</button>
</div>
<table class="layui-hide" id="dataTable" lay-filter="dataTable"></table>
</div>
</div>
</div>
</div>
</div>
<script src="assets/layuiadmin/layui/layui.js"></script>
<script>
layui.config({
base: 'assets/layuiadmin/'
}).extend({
index: 'lib/index'
}).use(['index', 'table', 'laydate', 'common'], function() {
var $ = layui.$;
var $win = $(window);
var table = layui.table;
var admin = layui.admin;
var laydate = layui.laydate;
var common = layui.common;
var resizeTimeout = null;
var queryParams = top.restAjax.params(window.location.href);
var selectType = queryParams.selectType;
selectType = selectType ? selectType : 'radio'
var areaCode = queryParams.areaCode;
var oldSelectedGridList = top.dialog.dialogData.oldSelectedGridList ? top.dialog.dialogData.oldSelectedGridList : [];
// 清空上次选择
top.dialog.dialogData.newSelectedGridList = [];
var newSelectedGridList = [];
var tableData = [];
var tableUrl = 'api/grid/listpage/area-code/{areaCode}';
// 初始化选择列表
function initNewSelectedGridList() {
for(var i = 0, item; item = oldSelectedGridList[i++];) {
newSelectedGridList.push(item);
}
}
initNewSelectedGridList();
// 初始化表格
function initTable() {
$.extend(table, {config: {checkName: 'checked'}});
table.render({
elem: '#dataTable',
id: 'dataTable',
url: top.restAjax.path(tableUrl, [areaCode]),
width: admin.screen() > 1 ? '100%' : '',
height: $win.height() - 90,
limit: 20,
limits: [20, 40, 60, 80, 100, 200],
toolbar: '#headerToolBar',
request: {
pageName: 'page',
limitName: 'rows'
},
cols: [
[
{type: selectType, fixed: 'left'},
{field:'rowNum', width:80, title: '序号', fixed: 'left', align:'center', templet: '<span>{{d.LAY_INDEX}}</span>'},
{field: 'gridName', width: 120, title: '网格名称', align:'center',
templet: function(row) {
var rowData = row[this.field];
if(typeof(rowData) === 'undefined' || rowData == null || rowData == '') {
return '-';
}
return rowData;
}
},
{field: 'gridDuty', width: 120, title: '职责', align:'center',
templet: function(row) {
var rowData = row[this.field];
if(typeof(rowData) === 'undefined' || rowData == null || rowData == '') {
return '-';
}
return rowData;
}
},
{field: 'gridSummary', width: 180, title: '描述', align:'center',
templet: function(row) {
var rowData = row[this.field];
if(typeof(rowData) === 'undefined' || rowData == null || rowData == '') {
return '-';
}
return rowData;
}
},
{field: 'gridCode', width: 180, title: '网格编码', align:'center',
templet: function(row) {
var rowData = row[this.field];
if(typeof(rowData) === 'undefined' || rowData == null || rowData == '') {
return '-';
}
return rowData;
}
},
{field: 'areaName', width: 180, title: '地区名称', align:'center',
templet: function(row) {
var rowData = row[this.field];
if(typeof(rowData) === 'undefined' || rowData == null || rowData == '') {
return '-';
}
return rowData;
}
},
{field: 'areaCode', width: 180, title: '地区编码', align:'center',
templet: function(row) {
var rowData = row[this.field];
if(typeof(rowData) === 'undefined' || rowData == null || rowData == '') {
return '-';
}
return rowData;
}
},
{field: 'gridSquare', width: 180, title: '单元网格面积', align:'center',
templet: function(row) {
var rowData = row[this.field];
if(typeof(rowData) === 'undefined' || rowData == null || rowData == '') {
return '-';
}
return rowData + ' ㎡';
}
},
{field: 'gmtCreate', width: 180, title: '创建时间', align:'center',
templet: function(row) {
var rowData = row[this.field];
if(typeof(rowData) === 'undefined' || rowData == null || rowData == '') {
return '-';
}
return rowData;
}
},
{field: 'gmtModified', width: 180, title: '修改时间', align:'center',
templet: function(row) {
var rowData = row[this.field];
if(typeof(rowData) === 'undefined' || rowData == null || rowData == '') {
return '-';
}
return rowData;
}
},
{field: 'operation', width: 90, title: '操作', align:'center', fixed: 'right',
templet: function(row) {
return '<div class="layui-btn-group">' +
'<button class="layui-btn layui-btn-xs" lay-event="gridEvent">查看网格</button>' +
'</div>';
}
}
]
],
page: true,
parseData: function(data) {
for(var i = 0, item; item = data.rows[i++];) {
if(!newSelectedGridList) {
item.checked = false;
continue;
}
var isSelected = false;
for(var j = 0, jItem; jItem = newSelectedGridList[j++];) {
if(item.gridId === jItem.gridId) {
isSelected = true;
break;
}
}
if(isSelected) {
item.checked = true;
} else {
item.checked = false;
}
}
tableData = data.rows;
return {
'code': 0,
'msg': '',
'count': data.total,
'data': data.rows
};
}
});
}
// 重载表格
function reloadTable(currentPage) {
table.reload('dataTable', {
url: top.restAjax.path(tableUrl, [areaCode]),
where: {
keywords: $('#keywords').val(),
startTime: $('#startTime').val(),
endTime: $('#endTime').val()
},
page: {
curr: currentPage
},
height: $win.height() - 90,
});
}
initTable();
// 事件 - 页面变化
$win.on('resize', function() {
clearTimeout(resizeTimeout);
resizeTimeout = setTimeout(function() {
reloadTable();
}, 500);
});
// 事件 - 搜索
$(document).on('click', '#search', function() {
reloadTable(1);
});
function isGridSelected(gridId) {
for(var i = 0, item; item = newSelectedGridList[i++];) {
if(gridId == item.gridId) {
return true;
}
}
return false;
}
function addGridSelected(gridItem) {
if(isGridSelected(gridItem.gridId)) {
return;
}
newSelectedGridList.push({
gridId: gridItem.gridId,
gridName: gridItem.gridName,
gridCode: gridItem.gridCode
})
}
function removeGridSelected(gridItem) {
for(var i = 0, item; item = newSelectedGridList[i++];) {
if(gridItem.gridId == item.gridId) {
newSelectedGridList.splice(--i, 1);
i--;
return;
}
}
}
table.on('checkbox(dataTable)', function(obj) {
if(obj.type === 'all') {
if(obj.checked) {
// 添加全部
for(var i = 0, item; item = tableData[i++];) {
addGridSelected(item);
}
} else {
// 删除全部
for(var i = 0, item; item = tableData[i++];) {
removeGridSelected(item);
}
}
} else {
if(obj.checked) {
addGridSelected(obj.data);
} else {
removeGridSelected(obj.data);
}
}
});
table.on('radio(dataTable)', function(obj) {
newSelectedGridList.splice(0, newSelectedGridList.length);
addGridSelected(obj.data);
});
$(document).on('click', '#search', function() {
reloadTable(1);
});
$(document).on('click', '#confirm', function() {
top.dialog.dialogData.newSelectedGridList = newSelectedGridList;
top.dialog.closeBox();
});
table.on('tool(dataTable)', function(obj) {
var data = obj.data;
var layEvent = obj.event;
if(layEvent === 'gridEvent') {
top.dialog.open({
url: top.restAjax.path('route/grid/get?gridId={gridId}', [data.gridId]),
title: '【'+ data.gridName +'】网格',
width: '80%',
height: '80%',
onClose: function() {}
});
}
})
});
</script>
</body>
</html>

View File

@ -0,0 +1,322 @@
<!doctype html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
<base th:href="${#request.getContextPath() + '/'}">
<meta charset="utf-8">
<meta name="renderer" content="webkit">
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
<meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=0">
<link rel="stylesheet" href="assets/fonts/font-awesome/css/font-awesome.css"/>
<link rel="stylesheet" href="assets/layuiadmin/layui/css/layui.css" media="all">
<link rel="stylesheet" href="assets/layuiadmin/style/admin.css" media="all">
</head>
<body>
<div class="layui-fluid layui-anim layui-anim-fadein">
<div class="layui-row">
<div class="layui-col-md12">
<div class="layui-card">
<div class="layui-card-body">
<div class="test-table-reload-btn" style="margin-bottom: 10px;">
<div class="layui-inline">
<input type="text" id="keywords" class="layui-input search-item search-item-width-100" placeholder="输入关键字">
</div>
<button type="button" id="search" class="layui-btn layui-btn-sm">
<i class="fa fa-lg fa-search"></i> 搜索
</button>
</div>
<table class="layui-hide" id="dataTable" lay-filter="dataTable"></table>
<!-- 表头按钮组 -->
<script type="text/html" id="headerToolBar">
<div class="layui-btn-group">
<button type="button" class="layui-btn layui-btn-sm" lay-event="saveEvent">
<i class="fa fa-lg fa-plus"></i> 网格绘制
</button>
<button type="button" class="layui-btn layui-btn-normal layui-btn-sm" lay-event="updateEvent">
<i class="fa fa-lg fa-edit"></i> 网格修改
</button>
<button type="button" class="layui-btn layui-btn-danger layui-btn-sm" lay-event="removeEvent">
<i class="fa fa-lg fa-trash"></i> 删除
</button>
</div>
</script>
</div>
</div>
</div>
</div>
</div>
<script src="assets/layuiadmin/layui/layui.js"></script>
<script>
layui.config({
base: 'assets/layuiadmin/'
}).extend({
index: 'lib/index'
}).use(['index', 'table', 'laydate', 'common'], function() {
var $ = layui.$;
var $win = $(window);
var table = layui.table;
var admin = layui.admin;
var laydate = layui.laydate;
var common = layui.common;
var resizeTimeout = null;
var tableUrl = 'api/grid/listpage';
// 初始化表格
function initTable() {
table.render({
elem: '#dataTable',
id: 'dataTable',
url: top.restAjax.path(tableUrl, []),
width: admin.screen() > 1 ? '100%' : '',
height: $win.height() - 90,
limit: 20,
limits: [20, 40, 60, 80, 100, 200],
toolbar: '#headerToolBar',
request: {
pageName: 'page',
limitName: 'rows'
},
cols: [
[
{type:'checkbox', fixed: 'left'},
{field:'rowNum', width:80, title: '序号', fixed: 'left', align:'center', templet: '<span>{{d.LAY_INDEX}}</span>'},
{field: 'gridName', width: 120, title: '网格名称', align:'center',
templet: function(row) {
var rowData = row[this.field];
if(typeof(rowData) === 'undefined' || rowData == null || rowData == '') {
return '-';
}
return rowData;
}
},
{field: 'gridDuty', width: 120, title: '职责', align:'center',
templet: function(row) {
var rowData = row[this.field];
if(typeof(rowData) === 'undefined' || rowData == null || rowData == '') {
return '-';
}
return rowData;
}
},
{field: 'gridSummary', width: 180, title: '描述', align:'center',
templet: function(row) {
var rowData = row[this.field];
if(typeof(rowData) === 'undefined' || rowData == null || rowData == '') {
return '-';
}
return rowData;
}
},
{field: 'gridCode', width: 180, title: '网格编码', align:'center',
templet: function(row) {
var rowData = row[this.field];
if(typeof(rowData) === 'undefined' || rowData == null || rowData == '') {
return '-';
}
return rowData;
}
},
{field: 'areaName', width: 180, title: '地区名称', align:'center',
templet: function(row) {
var rowData = row[this.field];
if(typeof(rowData) === 'undefined' || rowData == null || rowData == '') {
return '-';
}
return rowData;
}
},
{field: 'areaCode', width: 180, title: '地区编码', align:'center',
templet: function(row) {
var rowData = row[this.field];
if(typeof(rowData) === 'undefined' || rowData == null || rowData == '') {
return '-';
}
return rowData;
}
},
{field: 'gridSquare', width: 180, title: '单元网格面积', align:'center',
templet: function(row) {
var rowData = row[this.field];
if(typeof(rowData) === 'undefined' || rowData == null || rowData == '') {
return '-';
}
return rowData + ' ㎡';
}
},
{field: 'gmtCreate', width: 180, title: '创建时间', align:'center',
templet: function(row) {
var rowData = row[this.field];
if(typeof(rowData) === 'undefined' || rowData == null || rowData == '') {
return '-';
}
return rowData;
}
},
{field: 'gmtModified', width: 180, title: '修改时间', align:'center',
templet: function(row) {
var rowData = row[this.field];
if(typeof(rowData) === 'undefined' || rowData == null || rowData == '') {
return '-';
}
return rowData;
}
},
{field: 'operation', width: 150, title: '操作', align:'center', fixed: 'right',
templet: function(row) {
return '<div class="layui-btn-group">' +
'<button class="layui-btn layui-btn-xs" lay-event="gridEvent">查看网格</button>' +
'<button class="layui-btn layui-btn-primary layui-btn-xs" lay-event="userEvent">网格人员</button>' +
'</div>';
}
}
]
],
page: true,
parseData: function(data) {
return {
'code': 0,
'msg': '',
'count': data.total,
'data': data.rows
};
}
});
}
// 重载表格
function reloadTable(currentPage) {
table.reload('dataTable', {
url: top.restAjax.path(tableUrl, []),
where: {
keywords: $('#keywords').val(),
startTime: $('#startTime').val(),
endTime: $('#endTime').val()
},
page: {
curr: currentPage
},
height: $win.height() - 90,
});
}
// 初始化日期
function initDate() {
// 日期选择
laydate.render({
elem: '#startTime',
format: 'yyyy-MM-dd'
});
laydate.render({
elem: '#endTime',
format: 'yyyy-MM-dd'
});
}
// 删除
function removeData(ids) {
top.dialog.msg(top.dataMessage.delete, {
time: 0,
btn: [top.dataMessage.button.yes, top.dataMessage.button.no],
shade: 0.3,
yes: function (index) {
top.dialog.close(index);
var layIndex;
top.restAjax.delete(top.restAjax.path('api/grid/remove/{ids}', [ids]), {}, null, function (code, data) {
top.dialog.msg(top.dataMessage.deleteSuccess, {time: 1000});
reloadTable();
}, function (code, data) {
top.dialog.msg(data.msg);
}, function () {
layIndex = top.dialog.msg(top.dataMessage.deleting, {icon: 16, time: 0, shade: 0.3});
}, function () {
top.dialog.close(layIndex);
});
}
});
}
initTable();
initDate();
// 事件 - 页面变化
$win.on('resize', function() {
clearTimeout(resizeTimeout);
resizeTimeout = setTimeout(function() {
reloadTable();
}, 500);
});
// 事件 - 搜索
$(document).on('click', '#search', function() {
reloadTable(1);
});
// 事件 - 增删改
table.on('toolbar(dataTable)', function(obj) {
var layEvent = obj.event;
var checkStatus = table.checkStatus('dataTable');
var checkDatas = checkStatus.data;
if(layEvent === 'saveEvent') {
layer.open({
type: 2,
title: false,
closeBtn: 0,
area: ['100%', '100%'],
shadeClose: true,
anim: 2,
content: top.restAjax.path('route/grid/super-map/save', []),
end: function() {
reloadTable();
}
});
} else if(layEvent === 'updateEvent') {
if(checkDatas.length === 0) {
top.dialog.msg(top.dataMessage.table.selectEdit);
} else if(checkDatas.length > 1) {
top.dialog.msg(top.dataMessage.table.selectOneEdit);
} else {
layer.open({
type: 2,
title: false,
closeBtn: 0,
area: ['100%', '100%'],
shadeClose: true,
anim: 2,
content: top.restAjax.path('route/grid/super-map/update?gridId={gridId}', [checkDatas[0].gridId]),
end: function () {
reloadTable();
}
});
}
} else if(layEvent === 'removeEvent') {
if(checkDatas.length === 0) {
top.dialog.msg(top.dataMessage.table.selectDelete);
} else {
var ids = '';
for(var i = 0, item; item = checkDatas[i++];) {
if(i > 1) {
ids += '_';
}
ids += item['gridId'];
}
removeData(ids);
}
}
});
table.on('tool(dataTable)', function(obj) {
var data = obj.data;
var layEvent = obj.event;
if(layEvent === 'gridEvent') {
top.dialog.open({
url: top.restAjax.path('route/grid/super-map/get?gridId={gridId}', [data.gridId]),
title: '【'+ data.gridName +'】网格',
width: '80%',
height: '80%',
onClose: function() {}
});
} else if(layEvent === 'userEvent') {
top.dialog.open({
url: top.restAjax.path('route/grid/super-map/user/list?gridId={gridId}', [data.gridId]),
title: '【'+ data.gridName +'】网格的用户列表',
width: '800px',
height: '500px',
onClose: function() {}
});
}
})
});
</script>
</body>
</html>

View File

@ -0,0 +1,355 @@
<!doctype html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
<base th:href="${#request.getContextPath() + '/'}">
<meta charset="utf-8">
<meta name="renderer" content="webkit">
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
<meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=0">
<link rel="stylesheet" href="assets/fonts/font-awesome/css/font-awesome.css"/>
<link rel="stylesheet" href="assets/layuiadmin/layui/css/layui.css" media="all">
<link rel="stylesheet" href="assets/layuiadmin/style/admin.css" media="all">
<link rel="stylesheet" href="static/super-map/css/leaflet.css">
<link rel="stylesheet" href="static/super-map/css/leaflet-geoman.css">
<style>
.layui-form-label-up {width: 100% !important; height: 30px !important; line-height: 30px !important; border: none !important; padding: 0px !important; font-size: 15px; background-color: transparent !important; text-align: left !important;}
.layui-input-block-down {margin: 0px !important; left: 0px !important;}
.layui-input-block-down .layui-form-select .layui-edge {top: 74%;}
</style>
</head>
<body>
<div class="layui-fluid layui-anim layui-anim-fadein">
<div class="layui-card">
<div class="layui-card-header">
<span class="layui-breadcrumb" lay-filter="breadcrumb" style="visibility: visible;">
<a class="close" href="javascript:void(0);">上级列表</a><span lay-separator="">/</span>
<a href="javascript:void(0);"><cite>新增内容</cite></a>
</span>
</div>
<div class="layui-card-body" style="padding: 15px; position: relative; overflow: hidden;">
<form class="layui-form layui-form-pane" lay-filter="dataForm">
<div class="layui-row layui-col-space15">
<div id="formContainer" class="layui-col-xs2">
<div class="layui-form-item">
<label class="layui-form-label layui-form-label-up">网格组</label>
<div class="layui-input-block layui-input-block-down layui-form" id="gridGroupIdTemplateBox" lay-filter="gridGroupIdTemplateBox"></div>
<script id="gridGroupIdTemplate" type="text/html">
<select id="gridGroupId" name="gridGroupId" lay-filter="gridGroupId">
<option value="">选择网格组</option>
{{# for(var i = 0, item; item = d[i++];) { }}
<option value="{{item.gridGroupId}}">{{item.gridGroupName}}</option>
{{# } }}
</select>
</script>
</div>
<div class="layui-form-item">
<label class="layui-form-label layui-form-label-up">网格名称</label>
<div class="layui-input-block layui-input-block-down">
<input type="text" id="gridName" name="gridName" class="layui-input" value="" placeholder="请输入网格名称" maxlength="255" lay-verify="required">
</div>
</div>
<div class="layui-form-item">
<label class="layui-form-label layui-form-label-up">网格描述</label>
<div class="layui-input-block layui-input-block-down">
<input type="text" id="gridSummary" name="gridSummary" class="layui-input" value="" placeholder="请输入网格描述" maxlength="255" lay-verify="required">
</div>
</div>
<div class="layui-form-item">
<label class="layui-form-label layui-form-label-up">网格职责</label>
<div class="layui-input-block layui-input-block-down">
<input type="text" id="gridDuty" name="gridDuty" class="layui-input" value="" placeholder="请输入网格职责" maxlength="255" lay-verify="required">
</div>
</div>
<div class="layui-form-item">
<label class="layui-form-label layui-form-label-up">选择地区</label>
<div class="layui-input-block layui-input-block-down">
<input type="hidden" id="areaCode" name="areaCode">
<input type="text" id="areaName" name="areaName" class="layui-input" value="" placeholder="请选择地区" maxlength="255" readonly lay-verify="required">
</div>
</div>
<div class="layui-form-item">
<label class="layui-form-label layui-form-label-up">添加人员</label>
<div class="layui-input-block layui-input-block-down">
<input type="hidden" id="userIds" name="userIds">
<input type="text" id="userNames" name="userNames" class="layui-input" value="" placeholder="选择人员" maxlength="255" readonly>
</div>
</div>
<div class="layui-form-item layui-layout-admin">
<div class="layui-input-block">
<div class="layui-footer" style="left: 0;">
<button id="confirmBtn" type="button" class="layui-btn" lay-submit lay-filter="submitForm">提交编辑</button>
<button type="button" class="layui-btn layui-btn-primary close">返回上级</button>
</div>
</div>
</div>
</div>
<div id="mapBox" class="layui-col-xs10">
<div id="superMapContainer"></div>
</div>
</div>
</form>
</div>
</div>
</div>
<script type="text/javascript" src="static/super-map/js/leaflet.min.js"></script>
<script type="text/javascript" src="static/super-map/js/iclient-leaflet.min.js"></script>
<script type="text/javascript" src="static/super-map/js/leaflet-geoman.min.js"></script>
<script type="text/javascript" src="static/super-map/js/super-map-1.0.0.min.js"></script>
<script src="assets/layuiadmin/layui/layui.js"></script>
<script th:inline="javascript">
layui.config({
base: 'assets/layuiadmin/' //静态资源所在路径
}).extend({
index: 'lib/index' //主入口模块
}).use(['index', 'form', 'laydate', 'laytpl'], function(){
var $ = layui.$;
var $win = $(window);
var form = layui.form;
var laytpl = layui.laytpl;
var laydate = layui.laydate;
var centerPoint = {
lng: [[${superMapProperties.centerLng}]],
lat: [[${superMapProperties.centerLat}]]
}
var superMap = null;
var gridMember = {
users: [],
gridArray: []
}
function closeBox() {
parent.layer.close(parent.layer.getFrameIndex(window.name));
}
function initSelectRadioCheckboxTemplate(templateId, templateBoxId, data, callback) {
laytpl(document.getElementById(templateId).innerHTML).render(data, function(html) {
document.getElementById(templateBoxId).innerHTML = html;
});
form.render('select', templateBoxId);
if(callback) {
callback();
}
}
// 初始化网格组下拉选择
function initGridGroupSelect(selectValue) {
top.restAjax.get(top.restAjax.path('api/grid-group/list', []), {
}, null, function(code, data, args) {
initSelectRadioCheckboxTemplate('gridGroupIdTemplate', 'gridGroupIdTemplateBox', data, function() {
var selectObj = {};
selectObj['gridGroupId'] = selectValue;
form.val('dataForm', selectObj);
});
}, function(code, data) {
top.dialog.msg(data.msg);
});
}
function initMap() {
$('#formContainer').css({
height: ($win.height() - 145) +'px',
overflow: 'auto'
})
$('#superMapContainer').css({
width: '100%',
height: ($win.height() - 145) +'px'
});
superMap = new SuperMap('superMapContainer', 'mapBox', {
center: centerPoint
});
superMap.init([[${superMapProperties.baseMapUrl}]]);
superMap.initDrawPolygon();
superMap.initColorOption();
}
// 初始化内容
function initData() {
initGridGroupSelect();
initMap();
}
initData();
// 初始化网格背景
function initGridBG(areaCode) {
superMap.removeGridBG();
var layIndex;
top.restAjax.get(top.restAjax.path('api/grid/list', []), {
areaCode: areaCode
}, null, function(code, data) {
var gridArray = [];
for(var i = 0, item; item = data[i++];) {
var pointArray = [];
for(var j = 0, jItem; jItem = item.pointArray[j++];) {
pointArray.push([jItem.lat, jItem.lng]);
}
gridArray.push({
id: item.gridId,
label: item.gridName,
fillColor: item.fillColor,
pointArray: pointArray
})
}
superMap.initGridBG(gridArray);
}, function(code, data) {
top.dialog.msg(data.msg);
}, function () {
layIndex = top.dialog.msg(top.dataMessage.loading, {icon: 16, time: 0, shade: 0.3});
}, function () {
top.dialog.close(layIndex);
});
}
// 初始化编辑网格
function initEditGrid(areaCode, userIds) {
superMap.clearMap();
var layIndex;
top.restAjax.get(top.restAjax.path('api/grid/list', []), {
areaCode: areaCode,
userIds: userIds ? userIds : ''
}, null, function(code, data) {
var grids = [];
for(var i = 0, item; item = data[i++];) {
grids.push(item.grid);
}
// 设置编辑网格
superMap.setGridArray(grids);
}, function(code, data) {
top.dialog.msg(data.msg);
}, function () {
layIndex = top.dialog.msg(top.dataMessage.loading, {icon: 16, time: 0, shade: 0.3});
}, function () {
top.dialog.close(layIndex);
});
}
$('#areaName').on('click', function() {
top.dialog.open({
title: '选择地区',
url: top.restAjax.path('route/area/get-select?areaName={areaName}', [encodeURI($('#areaName').val())]),
width: '600px',
height: '225px',
onClose: function() {
var selectedAreaArray = top.dialog.dialogData.selectedAreaArray;
var areaCode = '';
var areaName = '';
if(selectedAreaArray.length > 0) {
areaCode = selectedAreaArray[selectedAreaArray.length - 1].areaCode;
for(var i = 0, item; item = selectedAreaArray[i++];) {
if(areaName) {
areaName += '/';
}
areaName += item.areaName;
}
initGridBG(areaCode);
}
$('#areaCode').val(areaCode);
$('#areaName').val(areaName);
}
})
});
$('#userNames').on('click', function() {
top.dialog.dialogData.selectedUserIds = $('#userIds').val();
top.dialog.open({
url: top.restAjax.path('route/department/user/select-user', []),
title: '选择用户',
width: '500px',
height: '500px',
onClose: function() {
var selectedUsers = top.dialog.dialogData.selectedDepartmentUsers;
// 这里写处理逻辑
var userIds = '';
var userNames = '';
if(selectedUsers && selectedUsers.length > 0) {
var relationArray = [];
for(var i = 0, item; item = selectedUsers[i++];) {
if(userIds) {
userIds += '_';
}
if(userNames) {
userNames += ',';
}
userIds += item.userId;
userNames += item.userName;
relationArray.push({
id: item.userId,
name: item.userName
});
}
gridMember.users = relationArray;
}
$('#userIds').val(userIds);
$('#userNames').val(userNames);
}
})
});
// 提交表单
form.on('submit(submitForm)', function(formData) {
var gridLayers = superMap.getEditGridLayer();
var grid;
if(gridLayers.length == 0) {
top.dialog.msg('请添加网格');
}
var latLngs = gridLayers[0].getLatLngs();
if(latLngs.length == 0) {
top.dialog.msg('请添加网格');
}
var pointArray = [];
for(var j = 0, jItem; jItem = latLngs[0][j++];) {
pointArray.push({
lng: jItem.lng,
lat: jItem.lat
});
}
var relationIdArray = [];
for(var i = 0, item; item = gridMember.users[i++];) {
relationIdArray.push(item.id);
}
grid = {
id: new Date().getTime(),
fillColor: superMap.getGridColor(),
relationIdArray: relationIdArray,
pointArray: pointArray
}
formData.field.grid = grid;
top.dialog.confirm(top.dataMessage.commit, function(index) {
top.dialog.close(index);
var loadLayerIndex;
top.restAjax.post(top.restAjax.path('api/grid/save', []), formData.field, null, function(code, data) {
var layerIndex = top.dialog.msg(top.dataMessage.commitSuccess, {
time: 0,
btn: [top.dataMessage.button.yes, top.dataMessage.button.no],
shade: 0.3,
yes: function(index) {
top.dialog.close(index);
window.location.reload();
},
btn2: function() {
closeBox();
}
});
}, function(code, data) {
top.dialog.msg(data.msg);
}, function() {
loadLayerIndex = top.dialog.msg(top.dataMessage.committing, {icon: 16, time: 0, shade: 0.3});
}, function() {
top.dialog.close(loadLayerIndex);
});
});
return false;
});
$('.close').on('click', function() {
closeBox();
});
// 校验
form.verify({
});
});
</script>
</body>
</html>

View File

@ -0,0 +1,308 @@
<!doctype html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
<base th:href="${#request.getContextPath() + '/'}">
<meta charset="utf-8">
<meta name="renderer" content="webkit">
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
<meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=0">
<link rel="stylesheet" href="assets/fonts/font-awesome/css/font-awesome.css"/>
<link rel="stylesheet" href="assets/layuiadmin/layui/css/layui.css" media="all">
<link rel="stylesheet" href="assets/layuiadmin/style/admin.css" media="all">
<link rel="stylesheet" href="static/super-map/css/leaflet.css">
<link rel="stylesheet" href="static/super-map/css/leaflet-geoman.css">
<style>
.layui-form-label-up {width: 100% !important; height: 30px !important; line-height: 30px !important; border: none !important; padding: 0px !important; font-size: 15px; background-color: transparent !important; text-align: left !important;}
.layui-input-block-down {margin: 0px !important; left: 0px !important;}
.layui-input-block-down .layui-form-select .layui-edge {top: 74%;}
</style>
</head>
<body>
<div class="layui-fluid layui-anim layui-anim-fadein">
<div class="layui-card">
<div class="layui-card-header">
<span class="layui-breadcrumb" lay-filter="breadcrumb" style="visibility: visible;">
<a class="close" href="javascript:void(0);">上级列表</a><span lay-separator="">/</span>
<a href="javascript:void(0);"><cite>编辑内容</cite></a>
</span>
</div>
<div class="layui-card-body" style="padding: 15px;">
<form class="layui-form layui-form-pane" lay-filter="dataForm">
<div class="layui-row layui-col-space15">
<div id="formContainer" class="layui-col-xs2">
<div class="layui-form-item">
<label class="layui-form-label layui-form-label-up">网格组</label>
<div class="layui-input-block layui-input-block-down layui-form" id="gridGroupIdTemplateBox" lay-filter="gridGroupIdTemplateBox"></div>
<script id="gridGroupIdTemplate" type="text/html">
<select id="gridGroupId" name="gridGroupId" lay-filter="gridGroupId">
<option value="">选择网格组</option>
{{# for(var i = 0, item; item = d[i++];) { }}
<option value="{{item.gridGroupId}}">{{item.gridGroupName}}</option>
{{# } }}
</select>
</script>
</div>
<div class="layui-form-item">
<label class="layui-form-label layui-form-label-up">网格名称</label>
<div class="layui-input-block layui-input-block-down">
<input type="text" id="gridName" name="gridName" class="layui-input" value="" placeholder="请输入网格名称" maxlength="255" lay-verify="required">
</div>
</div>
<div class="layui-form-item">
<label class="layui-form-label layui-form-label-up">网格描述</label>
<div class="layui-input-block layui-input-block-down">
<input type="text" id="gridSummary" name="gridSummary" class="layui-input" value="" placeholder="请输入网格描述" maxlength="255" lay-verify="required">
</div>
</div>
<div class="layui-form-item">
<label class="layui-form-label layui-form-label-up">网格职责</label>
<div class="layui-input-block layui-input-block-down">
<input type="text" id="gridDuty" name="gridDuty" class="layui-input" value="" placeholder="请输入网格职责" maxlength="255" lay-verify="required">
</div>
</div>
<div class="layui-form-item layui-layout-admin">
<div class="layui-input-block">
<div class="layui-footer" style="left: 0;">
<button id="confirmBtn" type="button" class="layui-btn" lay-submit lay-filter="submitForm">提交编辑</button>
<button type="button" class="layui-btn layui-btn-primary close">返回上级</button>
</div>
</div>
</div>
</div>
<div id="mapBox" class="layui-col-xs10">
<div id="superMapContainer"></div>
</div>
</div>
</form>
</div>
</div>
</div>
<script type="text/javascript" src="static/super-map/js/leaflet.min.js"></script>
<script type="text/javascript" src="static/super-map/js/iclient-leaflet.min.js"></script>
<script type="text/javascript" src="static/super-map/js/leaflet-geoman.min.js"></script>
<script type="text/javascript" src="static/super-map/js/super-map-1.0.0.min.js"></script>
<script src="assets/layuiadmin/layui/layui.js"></script>
<script th:inline="javascript">
layui.config({
base: 'assets/layuiadmin/' //静态资源所在路径
}).extend({
index: 'lib/index' //主入口模块
}).use(['index', 'form', 'laydate', 'laytpl'], function(){
var $ = layui.$;
var $win = $(window);
var form = layui.form;
var laytpl = layui.laytpl;
var laydate = layui.laydate;
var queryParams = top.restAjax.params(window.location.href);
var gridId = queryParams.gridId;
var centerPoint = {
lng: [[${superMapProperties.centerLng}]],
lat: [[${superMapProperties.centerLat}]]
}
var superMap = null;
var gridMember = {
users: [],
gridArray: []
}
function closeBox() {
parent.layer.close(parent.layer.getFrameIndex(window.name));
}
function initSelectRadioCheckboxTemplate(templateId, templateBoxId, data, callback) {
laytpl(document.getElementById(templateId).innerHTML).render(data, function(html) {
document.getElementById(templateBoxId).innerHTML = html;
});
form.render('select', templateBoxId);
if(callback) {
callback();
}
}
// 初始化网格组下拉选择
function initGridGroupSelect(selectValue) {
top.restAjax.get(top.restAjax.path('api/grid-group/list', []), {
}, null, function(code, data, args) {
initSelectRadioCheckboxTemplate('gridGroupIdTemplate', 'gridGroupIdTemplateBox', data, function() {
var selectObj = {};
selectObj['gridGroupId'] = selectValue;
form.val('dataForm', selectObj);
});
}, function(code, data) {
top.dialog.msg(data.msg);
});
}
// 初始化网格背景
function initGridBG(areaCode, callback) {
var layIndex;
top.restAjax.get(top.restAjax.path('api/grid/list/except/{gridId}', [gridId]), {
areaCode: areaCode
}, null, function(code, data) {
var gridArray = [];
for(var i = 0, item; item = data[i++];) {
var pointArray = [];
for(var j = 0, jItem; jItem = item.pointArray[j++];) {
pointArray.push([jItem.lat, jItem.lng]);
}
gridArray.push({
id: item.gridId,
label: item.gridName,
fillColor: '#ffffff',
pointArray: pointArray
})
}
superMap.initGridBG(gridArray);
callback ? callback() : '';
}, function(code, data) {
top.dialog.msg(data.msg);
}, function () {
layIndex = top.dialog.msg(top.dataMessage.loading, {icon: 16, time: 0, shade: 0.3});
}, function () {
top.dialog.close(layIndex);
});
}
function initMap(callback) {
$('#formContainer').css({
height: ($win.height() - 145) +'px',
overflow: 'auto'
})
$('#superMapContainer').css({
width: '100%',
height: ($win.height() - 145) +'px'
});
superMap = new SuperMap('superMapContainer', 'mapBox', {
center: centerPoint
});
superMap.init([[${superMapProperties.baseMapUrl}]]);
superMap.initDrawPolygon();
superMap.initColorOption();
callback ? callback() : '';
}
// 初始化内容
function initData() {
top.restAjax.get(top.restAjax.path('api/grid/get/{gridId}', [gridId]), {}, null, function(code, data) {
var dataFormData = {};
for(var i in data) {
dataFormData[i] = data[i] +'';
}
form.val('dataForm', dataFormData);
form.render(null, 'dataForm');
gridMember.gridArray = [{
id: data.gridId,
fillColor: data.fillColor,
pointArray: data.pointArray
}];
initGridGroupSelect(data.gridGroupId);
initMap(function() {
// 背景层
initGridBG(data.areaCode, function() {
superMap.initEditGrid(gridMember.gridArray);
superMap.setColorInputValue(data.fillColor);
});
});
}, function (code, data) {
top.dialog.msg(data.msg);
}, function() {
loadLayerIndex = top.dialog.msg(top.dataMessage.loading, {icon: 16, time: 0, shade: 0.3});
}, function() {
top.dialog.close(loadLayerIndex);
});
}
initData();
$('#areaName').on('click', function() {
top.dialog.open({
title: '选择地区',
url: top.restAjax.path('route/area/get-select?areaName={areaName}', [encodeURI($('#areaName').val())]),
width: '600px',
height: '225px',
onClose: function() {
var selectedAreaArray = top.dialog.dialogData.selectedAreaArray;
var areaCode = '';
var areaName = '';
if(selectedAreaArray.length > 0) {
areaCode = selectedAreaArray[selectedAreaArray.length - 1].areaCode;
for(var i = 0, item; item = selectedAreaArray[i++];) {
if(areaName) {
areaName += '/';
}
areaName += item.areaName;
}
initGridBG(areaCode);
}
$('#areaCode').val(areaCode);
$('#areaName').val(areaName);
}
})
});
// 提交表单
form.on('submit(submitForm)', function(formData) {
var gridLayers = superMap.getEditGridLayer();
var grid;
if(gridLayers.length == 0) {
top.dialog.msg('请添加网格');
}
var latLngs = gridLayers[0].getLatLngs();
if(latLngs.length == 0) {
top.dialog.msg('请添加网格');
}
var pointArray = [];
for(var j = 0, jItem; jItem = latLngs[0][j++];) {
pointArray.push({
lng: jItem.lng,
lat: jItem.lat
});
}
grid = {
id: gridMember.gridArray[0].id,
fillColor: superMap.getGridColor(),
pointArray: pointArray
}
formData.field.grid = grid;
top.dialog.confirm(top.dataMessage.commit, function(index) {
top.dialog.close(index);
var loadLayerIndex;
top.restAjax.put(top.restAjax.path('api/grid/update/{gridId}', [gridId]), formData.field, null, function(code, data) {
var layerIndex = top.dialog.msg(top.dataMessage.commitSuccess, {
time: 0,
btn: [top.dataMessage.button.yes, top.dataMessage.button.no],
shade: 0.3,
yes: function(index) {
top.dialog.close(index);
window.location.reload();
},
btn2: function() {
closeBox();
}
});
}, function(code, data) {
top.dialog.msg(data.msg);
}, function() {
loadLayerIndex = top.dialog.msg(top.dataMessage.committing, {icon: 16, time: 0, shade: 0.3});
}, function() {
top.dialog.close(loadLayerIndex);
});
});
return false;
});
$('.close').on('click', function() {
closeBox();
});
// 校验
form.verify({
});
});
</script>
</body>
</html>

View File

@ -0,0 +1,241 @@
<!doctype html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
<base th:href="${#request.getContextPath() + '/'}">
<meta charset="utf-8">
<meta name="renderer" content="webkit">
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
<meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=0">
<link rel="stylesheet" href="assets/fonts/font-awesome/css/font-awesome.css"/>
<link rel="stylesheet" type="text/css" href="assets/js/vendor/viewer/viewer.min.css">
<link rel="stylesheet" href="assets/layuiadmin/layui/css/layui.css" media="all">
<link rel="stylesheet" href="assets/layuiadmin/style/admin.css" media="all">
</head>
<body>
<div class="layui-fluid layui-anim layui-anim-fadein" style="padding: 0;">
<div class="layui-row">
<div class="layui-col-md12">
<div class="layui-card">
<div class="layui-card-body">
<table class="layui-hide" id="dataTable" lay-filter="dataTable"></table>
<!-- 表头按钮组 -->
<script type="text/html" id="headerToolBar">
<div class="layui-btn-group">
<button type="button" class="layui-btn layui-btn-sm" lay-event="saveEvent">
<i class="fa fa-lg fa-plus"></i> 新增
</button>
<button type="button" class="layui-btn layui-btn-danger layui-btn-sm" lay-event="removeEvent">
<i class="fa fa-lg fa-trash"></i> 删除
</button>
</div>
</script>
</div>
</div>
</div>
</div>
</div>
<input id="selectedUserIds" type="hidden"/>
<script src="assets/layuiadmin/layui/layui.js"></script>
<script>
layui.config({
base: 'assets/layuiadmin/'
}).extend({
index: 'lib/index'
}).use(['index', 'table', 'common'], function() {
var $ = layui.$;
var $win = $(window);
var table = layui.table;
var admin = layui.admin;
var common = layui.common;
var gridId = top.restAjax.params(window.location.href).gridId;
var resizeTimeout = null;
var tableUrl = 'api/grid/user/listpage/{gridId}';
// 初始化表格
function initTable() {
table.render({
elem: '#dataTable',
id: 'dataTable',
url: top.restAjax.path(tableUrl, [gridId]),
width: admin.screen() > 1 ? '100%' : '',
height: $win.height() - 20,
limit: 20,
limits: [20, 40, 60, 80, 100, 200],
toolbar: '#headerToolBar',
request: {
pageName: 'page',
limitName: 'rows'
},
cols: [
[
{type:'checkbox', fixed: 'left'},
{field:'rowNum', width:80, title: '序号', align:'center', templet: '<span>{{d.LAY_INDEX}}</span>'},
{field:'userUsername', width:140, title: '用户名', align:'center'},
{field:'userName', width:140, title: '昵称', align:'center'},
{field:'userPhone', width:140, title: '手机', align:'center',
templet: function(item) {
if(!item.userPhone) {
return '-';
}
return item.userPhone;
}
},
{field:'gmtCreate', width:180, title: '添加时间', align:'center',
templet: function(item) {
if(!item.gmtCreate) {
return '-';
}
return item.gmtCreate;
}
}
]
],
page: true,
parseData: function(data) {
return {
'code': 0,
'msg': '',
'count': data.total,
'data': data.rows
};
}
});
}
// 重载表格
function reloadTable(currentPage) {
table.reload('dataTable', {
url: top.restAjax.path(tableUrl, [gridId]),
where: {
keywords: $('#keywords').val(),
},
page: {
curr: currentPage
},
});
}
// 删除
function removeData(ids) {
top.dialog.msg(top.dataMessage.delete, {
time: 0,
btn: [top.dataMessage.button.yes, top.dataMessage.button.no],
shade: 0.3,
yes: function(index) {
top.dialog.close(index);
var layIndex;
top.restAjax.delete(top.restAjax.path('api/grid/user/delete/{gridId}/{ids}', [gridId, ids]), {}, null, function(code, data) {
top.dialog.msg(top.dataMessage.deleteSuccess);
var deleteUserIds = ids.split('_');
var selectedUserIds = $('#selectedUserIds').val().split('_');
var tempIds = common.resultIdsOfDeleteIds(deleteUserIds, selectedUserIds);
$('#selectedUserIds').val(tempIds);
reloadTable();
}, function(code, data) {
top.dialog.msg(data.msg);
}, function() {
layIndex = top.dialog.msg(top.dataMessage.deleting, {icon: 16, time: 0, shade: 0.3});
}, function() {
top.dialog.close(layIndex);
});
}
});
}
// 初始化职位用户ID列表
function initSelectUserIds() {
var layIndex;
top.restAjax.get(top.restAjax.path('api/grid/user/list-user-id/{gridId}', [gridId]), {}, null, function(code, data) {
var selectedUserIds = '';
for(var i = 0, item; item = data[i++]; ) {
if('' != selectedUserIds) {
selectedUserIds += '_';
}
selectedUserIds += item;
}
$('#selectedUserIds').val(selectedUserIds);
initTable();
}, function(code, data) {
top.dialog.msg(data.msg);
}, function() {
layIndex = top.dialog.msg(top.dataMessage.loading, {icon: 16, time: 0, shade: 0.3});
}, function() {
top.dialog.close(layIndex);
});
}
initSelectUserIds();
// 事件 - 页面变化
$win.on('resize', function() {
clearTimeout(resizeTimeout);
resizeTimeout = setTimeout(function() {
reloadTable();
}, 500);
});
// 事件 - 搜索
$(document).on('click', '#search', function() {
reloadTable(1);
});
// 事件 - 增删
table.on('toolbar(dataTable)', function(obj) {
var layEvent = obj.event;
var checkStatus = table.checkStatus('dataTable');
var checkDatas = checkStatus.data;
if(layEvent === 'saveEvent') {
top.dialog.dialogData.selectedUserIds = $('#selectedUserIds').val();
top.dialog.open({
url: top.restAjax.path('route/department/user/select-user', []),
title: '选择用户',
width: '500px',
height: '500px',
closeBtn: 0,
onClose: function() {
var selectedUsers = top.dialog.dialogData.selectedDepartmentUsers;
if(selectedUsers != null && selectedUsers.length > 0) {
var ids = [];
for (var i = 0, item; item = selectedUsers[i++];) {
ids.push(item.userId);
}
top.dialog.msg(top.dataMessage.update, {
time: 0,
btn: [top.dataMessage.button.yes, top.dataMessage.button.no],
yes: function (index) {
top.dialog.close(index);
var loadLayerIndex;
top.restAjax.put(top.restAjax.path('api/grid/user/update/{gridId}', [gridId]), {
ids: ids
}, null, function (code, data) {
top.dialog.msg(top.dataMessage.updated);
initSelectUserIds();
}, function (code, data) {
top.dialog.msg(data.msg);
}, function () {
loadLayerIndex = top.dialog.msg(top.dataMessage.updating, {
icon: 16,
time: 0,
shade: 0.3
});
}, function () {
top.dialog.close(loadLayerIndex);
});
},
});
}
}
})
} else if(layEvent === 'removeEvent') {
if(checkDatas.length === 0) {
top.dialog.msg(top.dataMessage.table.selectDelete);
} else {
var ids = '';
for(var i = 0, item; item = checkDatas[i++];) {
if(i > 1) {
ids += '_';
}
ids += item.userId;
}
removeData(ids);
}
}
});
});
</script>
</body>
</html>

View File

@ -96,6 +96,7 @@
<mongo.version>3.2.5</mongo.version>
<redis.version>2.5.5</redis.version>
<freemarker.version>2.3.31</freemarker.version>
<gson.version>2.8.5</gson.version>
</properties>
<dependencyManagement>
@ -545,6 +546,13 @@
</dependency>
<!-- freemarker end -->
<!-- gson start -->
<dependency>
<groupId>com.google.code.gson</groupId>
<artifactId>gson</artifactId>
<version>${gson.version}</version>
</dependency>
<!-- gson end -->
</dependencies>
</dependencyManagement>