add pulic floder
BIN
public/Data/china/国界线.dbf
Normal file
1
public/Data/china/国界线.prj
Normal file
@ -0,0 +1 @@
|
|||||||
|
PROJCS["China_Lambert_Conformal_Conic",GEOGCS["GCS_Beijing_1954",DATUM["D_Beijing_1954",SPHEROID["Krasovsky_1940",6378245.0,298.3]],PRIMEM["Greenwich",0.0],UNIT["Degree",0.0174532925199433]],PROJECTION["Lambert_Conformal_Conic"],PARAMETER["False_Easting",0.0],PARAMETER["False_Northing",0.0],PARAMETER["Central_Meridian",105.0],PARAMETER["Standard_Parallel_1",30.0],PARAMETER["Standard_Parallel_2",62.0],PARAMETER["Latitude_Of_Origin",0.0],UNIT["Meter",1.0]]
|
BIN
public/Data/china/国界线.shp
Normal file
50754
public/Data/data.txt
Normal file
1
public/Data/data_text.txt
Normal file
@ -0,0 +1 @@
|
|||||||
|
回传设备组ID,回传设备ID,GPS类型,当前GPS的HZ数,UTC时间,UTC日,UTC月,UTC年,导航模式,DGPS,Fix,Gps Fix Valid,Spare,卫星数量,纬度GPS,经度GPS,高度GPS,速度东,速度北,速度上,帧标志,帧序号,故障字标志,硬复位故障,程序飞,记录器接收数据校验和不为零,EEPROM编程错误,采样定时错误,未用,HDLC通信错误,变量非法,接收记录器应答超时,模拟量板错误,同步器板或429板错误,采集器FIFO溢出,记录器响应错,记录器通讯错,记录器记录错,指示空速,升降速率,主油量,主油量补偿,副油量,副油量补偿,横滚角,无线电高度,升降舵角位移,法向加速度,电源电压,发动机超温节油,起落架手柄放下位置信号,无线电发话按钮按下,左主轮着地信号,直发断电信号,滑油压降告警,燃油切断告警,燃油泵故障,副翼角位移,气压高度,航向角,油门杆角位移,方向舵角位移,俯仰角,后舱座椅弹射,纵向加速度,应急系统压力,马赫数,可靠性电压,火警,侧向加速度,攻角,前舱座椅弹射,低压转子转速,高压转子转速,座舱盖未上锁,前起落架放下,主液压压力降,WS11起动按钮按下,DF22起动指示灯,DF22起动按钮按下,右起落架放下,左起落架放下,襟翼放下35度,涡轮后温度,大气总温,全机剩余油量Gt0,高程高度
|
0
public/Data/data_text1.txt
Normal file
1
public/Data/population909500.json
Normal file
152256
public/Data/test_data.json
Normal file
3
public/config/componentUrl.js
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
var dataInterfaceURL="http://139.159.228.85:8080/"
|
||||||
|
var ImgURL = "http://localhost:9876/mapdata/Img/"
|
||||||
|
var paramsType = 1 //1为测试参数传参状态 2为真实参数传参状态
|
168
public/config/config.json
Normal file
@ -0,0 +1,168 @@
|
|||||||
|
{
|
||||||
|
|
||||||
|
"serverURL": "http://localhost:5237/mapdata",
|
||||||
|
"xj3d": {
|
||||||
|
"homeButton": false,
|
||||||
|
"sceneModePicker": false,
|
||||||
|
"navigationHelpButton": false,
|
||||||
|
"animation": false,
|
||||||
|
"timeline": false,
|
||||||
|
"infoBox": false,
|
||||||
|
"vrButton": false,
|
||||||
|
"fullscreenButton": false,
|
||||||
|
"geocoder": false,
|
||||||
|
"showRenderLoopErrors": false,
|
||||||
|
"center":{"y":11.862015,"x":100.491438,"z":14350334.7,"heading":0,"pitch":-89,"roll":0},
|
||||||
|
"minzoom": 1,
|
||||||
|
"maxzoom": 50000000,
|
||||||
|
"style": { "atmosphere": false, "lighting": false, "fog": false, "testTerrain": false },
|
||||||
|
"contextmenu":true,
|
||||||
|
"mouseZoom": false,
|
||||||
|
"location": {
|
||||||
|
"fps":true,
|
||||||
|
"format":"<div>经度:{x}</div> <div>纬度:{y}</div> <div>海拔:{z}米</div> <div>方向:{heading}度</div> <div>俯仰角:{pitch}度</div> <div>视高:{height}米</div>",
|
||||||
|
"crs":"degrese"
|
||||||
|
},
|
||||||
|
"navigation": {
|
||||||
|
"legend": { "left": "0px", "bottom": "-1px"},
|
||||||
|
"compass": { "bottom": "0px", "right": "0px","display": "none"}
|
||||||
|
},
|
||||||
|
"terrain": {
|
||||||
|
"url": "http://data.marsgis.cn/terrain",
|
||||||
|
"visible": true
|
||||||
|
},
|
||||||
|
"basemaps": [
|
||||||
|
{
|
||||||
|
"id": 10,
|
||||||
|
"name": "地图底图",
|
||||||
|
"type": "group"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 10,
|
||||||
|
"name": "地图底图",
|
||||||
|
"type": "group"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"pid": 10,
|
||||||
|
"name": "谷歌卫星",
|
||||||
|
"icon": "img/basemaps/google_img.png",
|
||||||
|
"type": "www_google",
|
||||||
|
"crs": "wgs84",
|
||||||
|
"layer": "img_d",
|
||||||
|
"visible": false
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"pid": 10,
|
||||||
|
"name": "ArcGIS卫星",
|
||||||
|
"icon": "img/basemaps/esriWorldImagery.png",
|
||||||
|
"type": "arcgis",
|
||||||
|
"url": "https://services.arcgisonline.com/ArcGIS/rest/services/World_Imagery/MapServer",
|
||||||
|
"enablePickFeatures": false
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"pid": 10,
|
||||||
|
"name": "微软卫星",
|
||||||
|
"icon": "img/basemaps/bingAerial.png",
|
||||||
|
"type": "www_bing",
|
||||||
|
"layer": "Aerial"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"pid": 10,
|
||||||
|
"name": "天地图卫星",
|
||||||
|
"icon": "img/basemaps/tdt_img.png",
|
||||||
|
"type": "www_tdt",
|
||||||
|
"layer": "img_d",
|
||||||
|
"key": [
|
||||||
|
"313cd4b28ed520472e8b43de00b2de56",
|
||||||
|
"83b36ded6b43b9bc81fbf617c40b83b5",
|
||||||
|
"0ebd57f93a114d146a954da4ecae1e67",
|
||||||
|
"6c99c7793f41fccc4bd595b03711913e",
|
||||||
|
"56b81006f361f6406d0e940d2f89a39c"
|
||||||
|
],
|
||||||
|
"visible": true
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"pid": 10,
|
||||||
|
"name": "天地图电子",
|
||||||
|
"icon": "img/basemaps/tdt_vec.png",
|
||||||
|
"type": "group",
|
||||||
|
"layers": [
|
||||||
|
{ "name": "底图", "type": "www_tdt", "layer": "vec_d", "key": ["313cd4b28ed520472e8b43de00b2de56" ] },
|
||||||
|
{ "name": "注记", "type": "www_tdt", "layer": "vec_z", "key": [ "83b36ded6b43b9bc81fbf617c40b83b5" ] }
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"pid": 10,
|
||||||
|
"name": "OSM地图",
|
||||||
|
"type": "xyz",
|
||||||
|
"icon": "img/basemaps/osm.png",
|
||||||
|
"url": "http://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png",
|
||||||
|
"subdomains": "abc"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"pid": 10,
|
||||||
|
"name": "离线地图",
|
||||||
|
"type": "group",
|
||||||
|
"icon": "img/basemaps/google_img.png",
|
||||||
|
"visible": false,
|
||||||
|
"layers": [
|
||||||
|
{
|
||||||
|
"name": "世界影像",
|
||||||
|
"type": "tms",
|
||||||
|
"url": "$serverURL$/worldimage/tiles/"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"operationallayers": [
|
||||||
|
{
|
||||||
|
"name": "行政区划界线",
|
||||||
|
"type": "xyz",
|
||||||
|
"url": "https://t{s}.tianditu.gov.cn/DataServer?T=ibo_w&x={x}&y={y}&l={z}&tk=56b81006f361f6406d0e940d2f89a39c",
|
||||||
|
"subdomains": "01234567",
|
||||||
|
"maximumLevel": 10,
|
||||||
|
"visible": true
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"pid": 10,
|
||||||
|
"name": "天地图注记",
|
||||||
|
"type": "www_tdt",
|
||||||
|
"layer": "img_z",
|
||||||
|
"key": [
|
||||||
|
"313cd4b28ed520472e8b43de00b2de56",
|
||||||
|
"83b36ded6b43b9bc81fbf617c40b83b5",
|
||||||
|
"0ebd57f93a114d146a954da4ecae1e67",
|
||||||
|
"6c99c7793f41fccc4bd595b03711913e",
|
||||||
|
"56b81006f361f6406d0e940d2f89a39c"
|
||||||
|
],
|
||||||
|
"proxy": "http://data.marsgis.cn/proxy/",
|
||||||
|
"visible": false
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 60,
|
||||||
|
"name": "地形",
|
||||||
|
"type": "group"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"pid": 60,
|
||||||
|
"type": "terrain",
|
||||||
|
"name": "地形数据",
|
||||||
|
"terrain": {
|
||||||
|
"type": "default",
|
||||||
|
"url": "$serverURL$/terrain/terrain1"
|
||||||
|
},
|
||||||
|
"radio":false
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"pid": 60,
|
||||||
|
"type": "terrain",
|
||||||
|
"name": "无地形",
|
||||||
|
"terrain": {
|
||||||
|
"type": "ellipsoid"
|
||||||
|
},
|
||||||
|
"radio":false
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
317
public/config/widget.json
Normal file
@ -0,0 +1,317 @@
|
|||||||
|
{
|
||||||
|
"debugger": false,
|
||||||
|
"version": "20200510",
|
||||||
|
"defaultOptions": {
|
||||||
|
"style": "dark",
|
||||||
|
"windowOptions": {
|
||||||
|
"skin": "layer-mars-dialog animation-scale-up",
|
||||||
|
"position": {
|
||||||
|
"top": 50,
|
||||||
|
"right": 10
|
||||||
|
},
|
||||||
|
"maxmin": false,
|
||||||
|
"resize": true
|
||||||
|
},
|
||||||
|
"autoReset":false,
|
||||||
|
"autoDisable": true,
|
||||||
|
"disableOther": true
|
||||||
|
},
|
||||||
|
"widgetsAtStart": [
|
||||||
|
{
|
||||||
|
"name": "右上角工具栏",
|
||||||
|
"uri": "widgets/toolBarRight/widget.js",
|
||||||
|
"css":{
|
||||||
|
"top": "10px",
|
||||||
|
"left": "auto",
|
||||||
|
"right": "10px"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "放大缩小工具按钮",
|
||||||
|
"uri": "widgets/toolbtn-zoom/widget.js"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "poi查询",
|
||||||
|
"uri": "widgets/queryBaiduPOI/widget.js"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"widgets": [
|
||||||
|
{
|
||||||
|
"name": "模板",
|
||||||
|
"type": "group",
|
||||||
|
"children": [
|
||||||
|
{
|
||||||
|
"name": "iframe弹窗模板",
|
||||||
|
"uri": "widgets/_example/widget.js",
|
||||||
|
"windowOptions": {
|
||||||
|
"width": 300,
|
||||||
|
"height": 400,
|
||||||
|
"position": {
|
||||||
|
"bottom": 10,
|
||||||
|
"right": 10
|
||||||
|
},
|
||||||
|
"maxmin": true,
|
||||||
|
"resize": true
|
||||||
|
},
|
||||||
|
"openAtStart": false
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "div弹窗模板",
|
||||||
|
"uri": "widgets/_example_divwin/widget.js"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "append模板",
|
||||||
|
"uri": "widgets/_example_append/widget.js"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "地图工具",
|
||||||
|
"type": "group",
|
||||||
|
"children": [
|
||||||
|
{
|
||||||
|
"id": "manageBasemaps",
|
||||||
|
"name": "地图切换",
|
||||||
|
"uri": "widgets/manageBasemaps/widget.js",
|
||||||
|
"group": "forlayer",
|
||||||
|
"autoDisable": false,
|
||||||
|
"disableOther": false
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "图层管理",
|
||||||
|
"uri": "widgets/manageLayers/widget.js",
|
||||||
|
"group": "forlayer",
|
||||||
|
"autoCenter": true,
|
||||||
|
"windowOptions": {
|
||||||
|
"position": {
|
||||||
|
"top": 50,
|
||||||
|
"bottom": 30,
|
||||||
|
"right": 10
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"css":{
|
||||||
|
"max-width":"300px"
|
||||||
|
},
|
||||||
|
"autoDisable": false,
|
||||||
|
"disableOther": false
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "图上量算",
|
||||||
|
"uri": "widgets/measure/widget.js"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "空间分析",
|
||||||
|
"uri": "widgets/analysis/widget.js"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "剖面分析图表",
|
||||||
|
"uri": "widgets/measureChars/widget.js",
|
||||||
|
"windowOptions": {
|
||||||
|
"noTitle": true,
|
||||||
|
"position": {
|
||||||
|
"bottom": 30,
|
||||||
|
"left": 30,
|
||||||
|
"right": 60
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"disableOther": false
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "视角书签",
|
||||||
|
"uri": "widgets/bookmark/widget.js",
|
||||||
|
"windowOptions": {
|
||||||
|
"position": {
|
||||||
|
"top": 50,
|
||||||
|
"bottom": 30,
|
||||||
|
"right": 10
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "坐标定位",
|
||||||
|
"uri": "widgets/centerXY/widget.js"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "标记",
|
||||||
|
"uri": "widgets/addmarker/widget.js"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "地区导航",
|
||||||
|
"uri": "widgets/navXZQH/widget.js"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "漫游路线设置",
|
||||||
|
"uri": "widgets/roamLine/widget.js",
|
||||||
|
"windowOptions": {
|
||||||
|
"position": {
|
||||||
|
"top": 45,
|
||||||
|
"bottom": 30,
|
||||||
|
"right": 5
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "漫游路线",
|
||||||
|
"uri": "widgets/roamFly/widget.js",
|
||||||
|
"windowOptions": {
|
||||||
|
"position": {
|
||||||
|
"bottom": 60,
|
||||||
|
"right": 5
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "路线剖面",
|
||||||
|
"uri": "widgets/roamChars/widget.js",
|
||||||
|
"windowOptions": {
|
||||||
|
"noTitle": true,
|
||||||
|
"position": {
|
||||||
|
"top": 10,
|
||||||
|
"left": 10,
|
||||||
|
"right": 10
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"disableOther": false
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "双屏对比",
|
||||||
|
"uri": "widgets/mapCompare/widget.js",
|
||||||
|
"autoDisable": false,
|
||||||
|
"disableOther": false,
|
||||||
|
"group": "mapCompare",
|
||||||
|
"windowOptions": {
|
||||||
|
"position": {
|
||||||
|
"top": 160,
|
||||||
|
"bottom": 40,
|
||||||
|
"left": 10
|
||||||
|
},
|
||||||
|
"maxmin": true
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "卷帘对比",
|
||||||
|
"uri": "widgets/mapSwipe/widget.js",
|
||||||
|
"group": "mapCompare",
|
||||||
|
"autoDisable": false,
|
||||||
|
"disableOther": false
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "标绘",
|
||||||
|
"uri": "widgets/plot/widget.js",
|
||||||
|
"windowOptions": {
|
||||||
|
"position": {
|
||||||
|
"top": 45,
|
||||||
|
"bottom": 30,
|
||||||
|
"right": 5
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"openAtStart": false
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "模型库",
|
||||||
|
"uri": "widgets/plot-model/widget.js",
|
||||||
|
"windowOptions": {
|
||||||
|
"position": {
|
||||||
|
"top": 45,
|
||||||
|
"bottom": 30,
|
||||||
|
"right": 5
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "属性编辑",
|
||||||
|
"uri": "widgets/plotAttr/widget.js",
|
||||||
|
"windowOptions": {
|
||||||
|
"position": {
|
||||||
|
"top": 60,
|
||||||
|
"bottom": 30,
|
||||||
|
"left": 10
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"disableOther": false
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "Socket通信设置",
|
||||||
|
"uri": "widgets/plotSocket/widget.js",
|
||||||
|
"windowOptions": {
|
||||||
|
"position": {
|
||||||
|
"top": 10
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"disableOther": false
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "路线导航",
|
||||||
|
"uri": "widgets/queryRoute/widget.js",
|
||||||
|
"windowOptions": {
|
||||||
|
"position": {
|
||||||
|
"top": 45,
|
||||||
|
"bottom": 30,
|
||||||
|
"right": 5
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
"name": "打印",
|
||||||
|
"uri": "widgets/print/widget.js",
|
||||||
|
"autoDisable": false,
|
||||||
|
"disableOther": false
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "分享当前地图位置",
|
||||||
|
"uri": "widgets/shareUrl/widget.js",
|
||||||
|
"windowOptions": {
|
||||||
|
"position": {
|
||||||
|
"top": 1
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "参数设置",
|
||||||
|
"uri": "widgets/setting/widget.js"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "业务演示功能",
|
||||||
|
"type": "group",
|
||||||
|
"children": [
|
||||||
|
{
|
||||||
|
"name": "企业-地图点",
|
||||||
|
"uri": "widgetsTS/qyPoint/widget.js",
|
||||||
|
"autoDisable": false,
|
||||||
|
"disableOther": false
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "企业详情",
|
||||||
|
"uri": "widgetsTS/qyDetailsView/widget.js",
|
||||||
|
"windowOptions": {
|
||||||
|
"skin": "layer-mars-dialog2",
|
||||||
|
"position": {
|
||||||
|
"top": 50,
|
||||||
|
"bottom": 50,
|
||||||
|
"left": 120,
|
||||||
|
"right": 120
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"disableOther": false
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "企业视频监控",
|
||||||
|
"uri": "widgetsTS/qyVideo/widget.js",
|
||||||
|
"windowOptions": {
|
||||||
|
"skin": "layer-mars-dialog2",
|
||||||
|
"position": {
|
||||||
|
"top": 50,
|
||||||
|
"bottom": 50,
|
||||||
|
"left": 120,
|
||||||
|
"right": 120
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"disableOther": false
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
11
public/config/xjsdkUrl.js
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
//涉及mars的在线服务地址统一配置入口
|
||||||
|
//除了该文件,地图图层的配置在 \config\config.json文件中。
|
||||||
|
|
||||||
|
var serverURL = "http://data.marsgis.cn";
|
||||||
|
|
||||||
|
//gltf小模型服务主目录
|
||||||
|
var serverURL_gltf = "http://data.marsgis.cn/gltf";
|
||||||
|
|
||||||
|
//geojson等一些文件主目录
|
||||||
|
var serverURL_file = "http://data.marsgis.cn/file";
|
||||||
|
|
460
public/css/style.css
Normal file
@ -0,0 +1,460 @@
|
|||||||
|
/* 2019-7-14 09:06:53 | 修改 木遥(微信: http://marsgis.cn/weixin.html ) */
|
||||||
|
* {
|
||||||
|
-webkit-box-sizing: border-box;
|
||||||
|
-moz-box-sizing: border-box;
|
||||||
|
box-sizing: border-box;
|
||||||
|
}
|
||||||
|
|
||||||
|
*:before,
|
||||||
|
*:after {
|
||||||
|
-webkit-box-sizing: border-box;
|
||||||
|
-moz-box-sizing: border-box;
|
||||||
|
box-sizing: border-box;
|
||||||
|
}
|
||||||
|
|
||||||
|
html,
|
||||||
|
body {
|
||||||
|
height: 100%;
|
||||||
|
width: 100%;
|
||||||
|
margin: 0;
|
||||||
|
padding: 0;
|
||||||
|
border: none;
|
||||||
|
overflow: hidden;
|
||||||
|
overflow-x: hidden;
|
||||||
|
overflow-y: hidden;
|
||||||
|
font-family: "Helvetica Neue", Helvetica, Tahoma, Arial, "Microsoft Yahei", "Hiragino Sans GB", "WenQuanYi Micro Hei", sans-serif;
|
||||||
|
font-size: 14px;
|
||||||
|
background:#000;
|
||||||
|
-webkit-overflow-scrolling: touch;
|
||||||
|
}
|
||||||
|
|
||||||
|
body {
|
||||||
|
position: relative;
|
||||||
|
}
|
||||||
|
|
||||||
|
input,
|
||||||
|
button,
|
||||||
|
select,
|
||||||
|
textarea {
|
||||||
|
font-family: inherit;
|
||||||
|
font-size: inherit;
|
||||||
|
line-height: inherit;
|
||||||
|
}
|
||||||
|
|
||||||
|
a {
|
||||||
|
color: #62a8ea;
|
||||||
|
text-decoration: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
a:hover,
|
||||||
|
a:focus {
|
||||||
|
color: #89bceb;
|
||||||
|
text-decoration: underline;
|
||||||
|
}
|
||||||
|
|
||||||
|
a:focus {
|
||||||
|
outline: thin dotted;
|
||||||
|
outline: 5px auto -webkit-focus-ring-color;
|
||||||
|
outline: none;
|
||||||
|
outline-offset: -2px;
|
||||||
|
}
|
||||||
|
|
||||||
|
ul,
|
||||||
|
li {
|
||||||
|
list-style: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
#centerDiv {
|
||||||
|
height: 100%;
|
||||||
|
width: 100%;
|
||||||
|
margin: 0;
|
||||||
|
padding: 0;
|
||||||
|
border: none;
|
||||||
|
overflow: hidden;
|
||||||
|
position: relative;
|
||||||
|
}
|
||||||
|
|
||||||
|
.signmask {
|
||||||
|
height: 100%;
|
||||||
|
width: 100%;
|
||||||
|
background: rgba(0, 0, 0, .5);
|
||||||
|
filter: alpha(opacity=50);
|
||||||
|
position: fixed;
|
||||||
|
display: block;
|
||||||
|
z-index: 20180910;
|
||||||
|
top: 0;
|
||||||
|
left: 0;
|
||||||
|
background: rgba(0, 0, 0, .5) url("../img/icon-operate.png") center no-repeat;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*dark样式*/
|
||||||
|
.dark {
|
||||||
|
color: #ffffff;
|
||||||
|
}
|
||||||
|
|
||||||
|
.dark a {
|
||||||
|
color: #ffffff;
|
||||||
|
text-decoration: none;
|
||||||
|
margin-top: 1px;
|
||||||
|
margin-right: 2px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.dark a:hover {
|
||||||
|
color: #CC3300;
|
||||||
|
text-decoration: underline;
|
||||||
|
}
|
||||||
|
|
||||||
|
.dark .content {
|
||||||
|
overflow: auto;
|
||||||
|
position: relative;
|
||||||
|
background: transparent;
|
||||||
|
height: 400px;
|
||||||
|
-webkit-box-sizing: border-box;
|
||||||
|
-moz-box-sizing: border-box;
|
||||||
|
box-sizing: border-box;
|
||||||
|
}
|
||||||
|
|
||||||
|
.dark .form-control,
|
||||||
|
.dark .input-group-addon,
|
||||||
|
.dark .btn-default,
|
||||||
|
.dark input,
|
||||||
|
.dark .dropdown-menu {
|
||||||
|
color: #ffffff;
|
||||||
|
background-color: rgba(63, 72, 84, 0.7);
|
||||||
|
border: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.dark .btn-info {
|
||||||
|
background-color: rgba(119, 214, 225, 0.2);
|
||||||
|
}
|
||||||
|
|
||||||
|
.dark .btn-primary {
|
||||||
|
background-color: rgba(32, 160, 255, 0.2);
|
||||||
|
}
|
||||||
|
|
||||||
|
.dark .btn-danger {
|
||||||
|
background-color: rgba(255, 109, 109, 0.2);
|
||||||
|
}
|
||||||
|
|
||||||
|
.dark .btn-warning {
|
||||||
|
background-color: rgba(244, 176, 102, 0.2);
|
||||||
|
}
|
||||||
|
|
||||||
|
.dark .table-hover>tbody>tr:hover {
|
||||||
|
background-color: rgba(63, 72, 84, 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
.dark .dropdown-menu>li>a {
|
||||||
|
color: #ffffff;
|
||||||
|
}
|
||||||
|
|
||||||
|
.dark .dropdown-menu>li>a:hover,
|
||||||
|
.dark .dropdown-menu>li>a:focus {
|
||||||
|
background-color: #4db3ff;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
.dark .mars3d-popup-color {
|
||||||
|
color: #ffffff;
|
||||||
|
}
|
||||||
|
|
||||||
|
.dark .mars3d-popup-background {
|
||||||
|
background: rgba(63, 72, 84, 0.9);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/**cesium按钮背景色*/
|
||||||
|
.cesium-button {
|
||||||
|
background-color: #3f4854;
|
||||||
|
color: #e6e6e6;
|
||||||
|
fill: #e6e6e6;
|
||||||
|
box-shadow: 0 1px 4px rgba(0, 0, 0, 0.3);
|
||||||
|
line-height: 32px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.cesium-viewer-geocoderContainer .cesium-geocoder-input {
|
||||||
|
background-color: rgba(63, 72, 84, 0.7);
|
||||||
|
}
|
||||||
|
|
||||||
|
.cesium-viewer-geocoderContainer .cesium-geocoder-input:focus {
|
||||||
|
background-color: rgba(63, 72, 84, 0.9);
|
||||||
|
}
|
||||||
|
|
||||||
|
.cesium-viewer-geocoderContainer .search-results {
|
||||||
|
background-color: #3f4854;
|
||||||
|
}
|
||||||
|
|
||||||
|
.cesium-geocoder-searchButton {
|
||||||
|
background-color: #3f4854;
|
||||||
|
}
|
||||||
|
|
||||||
|
.cesium-infoBox-title {
|
||||||
|
background-color: #3f4854;
|
||||||
|
}
|
||||||
|
|
||||||
|
.cesium-infoBox {
|
||||||
|
background: rgba(63, 72, 84, 0.9);
|
||||||
|
}
|
||||||
|
.cesium-toolbar-button img{
|
||||||
|
height:100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.cesium-performanceDisplay-defaultContainer {
|
||||||
|
top: auto;
|
||||||
|
bottom: 35px;
|
||||||
|
right: 50px;
|
||||||
|
}
|
||||||
|
.cesium-performanceDisplay-ms,.cesium-performanceDisplay-fps{
|
||||||
|
color: #fff;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**cesium工具栏位置*/
|
||||||
|
.cesium-viewer-toolbar {
|
||||||
|
top: auto;
|
||||||
|
left: auto;
|
||||||
|
right: 12px;
|
||||||
|
bottom: 35px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.cesium-viewer-toolbar>.cesium-toolbar-button,
|
||||||
|
.cesium-navigationHelpButton-wrapper,
|
||||||
|
.cesium-viewer-geocoderContainer {
|
||||||
|
margin-bottom: 5px;
|
||||||
|
float: right;
|
||||||
|
clear: both;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.cesium-baseLayerPicker-dropDown {
|
||||||
|
bottom: 0;
|
||||||
|
right: 40px;
|
||||||
|
max-height: 700px;
|
||||||
|
margin-bottom: 5px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.cesium-navigation-help {
|
||||||
|
top: auto;
|
||||||
|
bottom: 0;
|
||||||
|
right: 40px;
|
||||||
|
transform-origin: right bottom;
|
||||||
|
}
|
||||||
|
|
||||||
|
.cesium-sceneModePicker-wrapper {
|
||||||
|
width: auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
.cesium-sceneModePicker-wrapper .cesium-sceneModePicker-dropDown-icon {
|
||||||
|
float: left;
|
||||||
|
margin: 0 3px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.cesium-viewer-geocoderContainer .search-results {
|
||||||
|
left: 0;
|
||||||
|
right: 40px;
|
||||||
|
width: auto;
|
||||||
|
z-index: 9999;
|
||||||
|
}
|
||||||
|
|
||||||
|
.cesium-infoBox-title {
|
||||||
|
background-color: #3f4854;
|
||||||
|
}
|
||||||
|
|
||||||
|
.cesium-infoBox {
|
||||||
|
top: 50px;
|
||||||
|
background: rgba(63, 72, 84, 0.9);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**左下工具栏菜单*/
|
||||||
|
.toolbar-dropdown-menu-div {
|
||||||
|
background: rgba(43, 44, 47, 0.8);
|
||||||
|
border: 1px solid #2b2c2f;
|
||||||
|
|
||||||
|
z-index: 991;
|
||||||
|
position: absolute;
|
||||||
|
right: 60px;
|
||||||
|
bottom: 40px;
|
||||||
|
display:none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.toolbar-dropdown-menu {
|
||||||
|
min-width: 110px;
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
.toolbar-dropdown-menu > li {
|
||||||
|
padding: 0 3px;
|
||||||
|
margin: 2px 0;
|
||||||
|
}
|
||||||
|
.toolbar-dropdown-menu > li > a {
|
||||||
|
color: #edffff;
|
||||||
|
display: block;
|
||||||
|
padding: 4px 10px;
|
||||||
|
clear: both;
|
||||||
|
font-weight: normal;
|
||||||
|
line-height: 1.6;
|
||||||
|
white-space: nowrap;
|
||||||
|
text-decoration: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.toolbar-dropdown-menu > li > a:hover, .dropdown-menu > li > a:focus {
|
||||||
|
color: #fff;
|
||||||
|
background-color: #444d59;
|
||||||
|
}
|
||||||
|
|
||||||
|
.toolbar-dropdown-menu > .active > a, .dropdown-menu > .active > a:hover, .dropdown-menu > .active > a:focus {
|
||||||
|
color: #fff;
|
||||||
|
background-color: #444d59;
|
||||||
|
}
|
||||||
|
|
||||||
|
.toolbar-dropdown-menu i {
|
||||||
|
padding-right: 5px;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**infoview浮动面板*/
|
||||||
|
.infoview {
|
||||||
|
position: absolute;
|
||||||
|
top: 10px;
|
||||||
|
left: 10px;
|
||||||
|
padding: 10px 15px;
|
||||||
|
border-radius: 4px;
|
||||||
|
border: 1px solid rgba(128, 128, 128, 0.5);
|
||||||
|
color: #ffffff;
|
||||||
|
background: rgba(0, 0, 0, 0.4);
|
||||||
|
box-shadow: 0 3px 14px rgba(128, 128, 128, 0.5);
|
||||||
|
z-index: 999;
|
||||||
|
}
|
||||||
|
|
||||||
|
.infoview input,
|
||||||
|
.infoview select,
|
||||||
|
.infoview textarea {
|
||||||
|
color: #ffffff;
|
||||||
|
background-color: rgba(32, 160, 255, 0.2);
|
||||||
|
border: 1px solid #e4eaec;
|
||||||
|
font-size: 14px;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
.info-tips {
|
||||||
|
top: auto;
|
||||||
|
bottom: 70px;
|
||||||
|
left: 2px;
|
||||||
|
color: #cad1d1;
|
||||||
|
}
|
||||||
|
|
||||||
|
.rightbottom {
|
||||||
|
top: auto;
|
||||||
|
bottom: 60px;
|
||||||
|
left: auto;
|
||||||
|
right: 50px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.loadingIndicator {
|
||||||
|
display: block;
|
||||||
|
position: absolute;
|
||||||
|
top: 50%;
|
||||||
|
left: 50%;
|
||||||
|
margin-top: -33px;
|
||||||
|
margin-left: -33px;
|
||||||
|
width: 66px;
|
||||||
|
height: 66px;
|
||||||
|
background-position: center;
|
||||||
|
background-repeat: no-repeat;
|
||||||
|
background-image: url(../img/loader.gif);
|
||||||
|
}
|
||||||
|
|
||||||
|
.mars-table {
|
||||||
|
width: 100%;
|
||||||
|
border-collapse: collapse;
|
||||||
|
border-spacing: 0;
|
||||||
|
margin-top: 5px;
|
||||||
|
margin-bottom: 5px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mars-table tr td {
|
||||||
|
padding: 5px 10px;
|
||||||
|
text-align: left;
|
||||||
|
white-space: nowrap;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mars-table tr td:first-child {
|
||||||
|
border-left: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mars-table .nametd {
|
||||||
|
padding: 5px 20px 5px 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
.tb-border {
|
||||||
|
border: #cde1de 1px solid;
|
||||||
|
}
|
||||||
|
|
||||||
|
.tb-border tr td {
|
||||||
|
border: #cde1de 1px solid;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/*滚动条*/
|
||||||
|
body,
|
||||||
|
html {
|
||||||
|
scrollbar-base-color: #f4f7fc;
|
||||||
|
scrollbar-track-color: #f4f7fc;
|
||||||
|
scrollbar-face-color: #797979;
|
||||||
|
scrollbar-arrow-color: #f4f7fc;
|
||||||
|
scrollbar-shadow-color: #f4f7fc;
|
||||||
|
scrollbar-3dlight-color: #f4f7fc;
|
||||||
|
scrollbar-highlight-color: #f4f7fc;
|
||||||
|
scrollbar-darkshadow-color: #f4f7fc;
|
||||||
|
}
|
||||||
|
|
||||||
|
::-webkit-scrollbar-button {
|
||||||
|
height: 0;
|
||||||
|
width: 0;
|
||||||
|
display: none
|
||||||
|
}
|
||||||
|
|
||||||
|
::-webkit-scrollbar-track {
|
||||||
|
background: transparent
|
||||||
|
}
|
||||||
|
|
||||||
|
::-webkit-scrollbar-track,
|
||||||
|
::-webkit-scrollbar-thumb {
|
||||||
|
border: 0
|
||||||
|
}
|
||||||
|
|
||||||
|
::-webkit-scrollbar {
|
||||||
|
height: 10px;
|
||||||
|
width: 10px;
|
||||||
|
background: transparent;
|
||||||
|
border-radius: 5px
|
||||||
|
}
|
||||||
|
|
||||||
|
::-webkit-scrollbar-thumb {
|
||||||
|
padding-top: 100px;
|
||||||
|
-webkit-box-shadow: inset 1px 1px 0 rgba(0, 0, 0, .1), inset -1px -1px 0 rgba(0, 0, 0, .07);
|
||||||
|
background-color: #797979;
|
||||||
|
min-height: 28px;
|
||||||
|
border-radius: 4px;
|
||||||
|
background-clip: padding-box
|
||||||
|
}
|
||||||
|
|
||||||
|
::-webkit-scrollbar-track,
|
||||||
|
::-webkit-scrollbar-thumb {
|
||||||
|
border: 0
|
||||||
|
}
|
||||||
|
|
||||||
|
::-webkit-scrollbar-thumb:hover {
|
||||||
|
-webkit-box-shadow: inset 1px 1px 1px rgba(0, 0, 0, .25);
|
||||||
|
background-color: rgba(0, 0, 0, .4)
|
||||||
|
}
|
||||||
|
|
||||||
|
::-webkit-scrollbar-thumb:active {
|
||||||
|
-webkit-box-shadow: inset 1px 1px 3px rgba(0, 0, 0, .35);
|
||||||
|
background-color: rgba(0, 0, 0, .5)
|
||||||
|
}
|
139
public/css/widget-win.css
Normal file
@ -0,0 +1,139 @@
|
|||||||
|
@charset "utf-8";
|
||||||
|
/* widget view公共css
|
||||||
|
* 2019-6-3 09:02:24 | 修改 木遥(微信: http://marsgis.cn/weixin.html )
|
||||||
|
*/
|
||||||
|
* {
|
||||||
|
-webkit-box-sizing: border-box;
|
||||||
|
-moz-box-sizing: border-box;
|
||||||
|
box-sizing: border-box;
|
||||||
|
}
|
||||||
|
|
||||||
|
*:before, *:after {
|
||||||
|
-webkit-box-sizing: border-box;
|
||||||
|
-moz-box-sizing: border-box;
|
||||||
|
box-sizing: border-box;
|
||||||
|
}
|
||||||
|
html, body {
|
||||||
|
height: 100%;
|
||||||
|
width: 100%;
|
||||||
|
margin: 0;
|
||||||
|
padding: 0;
|
||||||
|
border: none;
|
||||||
|
overflow: hidden;
|
||||||
|
font-family: "Helvetica Neue", Helvetica, Tahoma, Arial, "Microsoft Yahei", "Hiragino Sans GB", "WenQuanYi Micro Hei", sans-serif;
|
||||||
|
font-size: 14px;
|
||||||
|
background-color:transparent!important;
|
||||||
|
}
|
||||||
|
body {
|
||||||
|
padding:1px;
|
||||||
|
}
|
||||||
|
input, button, select, textarea {
|
||||||
|
font-family: inherit;
|
||||||
|
font-size: inherit;
|
||||||
|
line-height: inherit;
|
||||||
|
}
|
||||||
|
a { color: #62a8ea;text-decoration: none;}
|
||||||
|
|
||||||
|
a:hover, a:focus {
|
||||||
|
color: #89bceb;
|
||||||
|
text-decoration: underline;
|
||||||
|
}
|
||||||
|
|
||||||
|
a:focus {
|
||||||
|
outline: thin dotted;
|
||||||
|
outline: 5px auto -webkit-focus-ring-color;
|
||||||
|
outline: none;
|
||||||
|
outline-offset: -2px;
|
||||||
|
}
|
||||||
|
ul, li {list-style: none;}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
.dark { color: #ffffff; }
|
||||||
|
.dark a{color:#ffffff;text-decoration: none;}
|
||||||
|
.dark a:hover {color:#CC3300;text-decoration:underline;}
|
||||||
|
.dark .content{
|
||||||
|
overflow: auto;
|
||||||
|
position: relative;
|
||||||
|
background: transparent;
|
||||||
|
height: 400px;
|
||||||
|
-webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box;
|
||||||
|
}
|
||||||
|
.dark .form-control,.dark .input-group-addon,.dark .btn-default,.dark input ,.dark .dropdown-menu {
|
||||||
|
color: #ffffff;
|
||||||
|
background-color: rgba(63, 72, 84, 0.6);
|
||||||
|
}
|
||||||
|
|
||||||
|
.input-group{
|
||||||
|
width:100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
.dark .btn-primary {
|
||||||
|
background-color: rgba(32, 160, 255, 0.2);
|
||||||
|
}
|
||||||
|
.dark .btn-danger {
|
||||||
|
background-color: rgba(255, 109, 109, 0.2);
|
||||||
|
}
|
||||||
|
.dark .btn-warning {
|
||||||
|
background-color: rgba(196, 188, 181, 0.2);
|
||||||
|
}
|
||||||
|
.dark .table-hover > tbody > tr:hover {
|
||||||
|
background-color: rgba(63, 72, 84, 1);
|
||||||
|
}
|
||||||
|
.dark .dropdown-menu > li > a {
|
||||||
|
color: #ffffff;
|
||||||
|
}
|
||||||
|
.dark .dropdown-menu > li > a:hover,.dark .dropdown-menu > li > a:focus {
|
||||||
|
background-color: #4db3ff;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*滚动条*/
|
||||||
|
body, html {
|
||||||
|
scrollbar-base-color:#f4f7fc;
|
||||||
|
scrollbar-track-color:#f4f7fc;
|
||||||
|
scrollbar-face-color:#797979;
|
||||||
|
scrollbar-arrow-color:#f4f7fc;
|
||||||
|
scrollbar-shadow-color:#f4f7fc;
|
||||||
|
scrollbar-3dlight-color:#f4f7fc;
|
||||||
|
scrollbar-highlight-color:#f4f7fc;
|
||||||
|
scrollbar-darkshadow-color:#f4f7fc;
|
||||||
|
}
|
||||||
|
::-webkit-scrollbar-button {
|
||||||
|
height: 0;
|
||||||
|
width: 0;
|
||||||
|
display: none
|
||||||
|
}
|
||||||
|
::-webkit-scrollbar-track {
|
||||||
|
background: transparent
|
||||||
|
}
|
||||||
|
::-webkit-scrollbar-track, ::-webkit-scrollbar-thumb {
|
||||||
|
border: 0
|
||||||
|
}
|
||||||
|
::-webkit-scrollbar {
|
||||||
|
height: 10px;
|
||||||
|
width: 10px;
|
||||||
|
background: transparent;
|
||||||
|
border-radius: 5px
|
||||||
|
}
|
||||||
|
::-webkit-scrollbar-thumb {
|
||||||
|
padding-top: 100px;
|
||||||
|
-webkit-box-shadow: inset 1px 1px 0 rgba(0, 0, 0, .1), inset -1px -1px 0 rgba(0, 0, 0, .07);
|
||||||
|
background-color: #797979;
|
||||||
|
min-height: 28px;
|
||||||
|
border-radius: 4px;
|
||||||
|
background-clip:
|
||||||
|
padding-box
|
||||||
|
}
|
||||||
|
::-webkit-scrollbar-track, ::-webkit-scrollbar-thumb {
|
||||||
|
border: 0
|
||||||
|
}
|
||||||
|
::-webkit-scrollbar-thumb:hover {
|
||||||
|
-webkit-box-shadow:inset 1px 1px 1px rgba(0, 0, 0, .25);
|
||||||
|
background-color:rgba(0, 0, 0, .4)
|
||||||
|
}
|
||||||
|
::-webkit-scrollbar-thumb:active {
|
||||||
|
-webkit-box-shadow:inset 1px 1px 3px rgba(0, 0, 0, .35);
|
||||||
|
background-color:rgba(0, 0, 0, .5)
|
||||||
|
}
|
BIN
public/img/basemaps/TerrainEllipsoid.png
Normal file
After Width: | Height: | Size: 6.2 KiB |
BIN
public/img/basemaps/TerrainSTK.png
Normal file
After Width: | Height: | Size: 11 KiB |
BIN
public/img/basemaps/arcgis.png
Normal file
After Width: | Height: | Size: 9.9 KiB |
BIN
public/img/basemaps/bd-c-bluish.png
Normal file
After Width: | Height: | Size: 12 KiB |
BIN
public/img/basemaps/bd-c-dark.png
Normal file
After Width: | Height: | Size: 9.9 KiB |
BIN
public/img/basemaps/bd-c-darkgreen.png
Normal file
After Width: | Height: | Size: 12 KiB |
BIN
public/img/basemaps/bd-c-googlelite.png
Normal file
After Width: | Height: | Size: 11 KiB |
BIN
public/img/basemaps/bd-c-grassgreen.png
Normal file
After Width: | Height: | Size: 12 KiB |
BIN
public/img/basemaps/bd-c-grayscale.png
Normal file
After Width: | Height: | Size: 6.3 KiB |
BIN
public/img/basemaps/bd-c-hardedge.png
Normal file
After Width: | Height: | Size: 12 KiB |
BIN
public/img/basemaps/bd-c-light.png
Normal file
After Width: | Height: | Size: 11 KiB |
BIN
public/img/basemaps/bd-c-midnight.png
Normal file
After Width: | Height: | Size: 12 KiB |
BIN
public/img/basemaps/bd-c-pink.png
Normal file
After Width: | Height: | Size: 11 KiB |
BIN
public/img/basemaps/bd-c-redalert.png
Normal file
After Width: | Height: | Size: 12 KiB |
BIN
public/img/basemaps/bd-img.png
Normal file
After Width: | Height: | Size: 13 KiB |
BIN
public/img/basemaps/bd-vec.png
Normal file
After Width: | Height: | Size: 7.9 KiB |
BIN
public/img/basemaps/bingAerial.png
Normal file
After Width: | Height: | Size: 12 KiB |
BIN
public/img/basemaps/bingAerialLabels.png
Normal file
After Width: | Height: | Size: 13 KiB |
BIN
public/img/basemaps/bingRoads.png
Normal file
After Width: | Height: | Size: 11 KiB |
BIN
public/img/basemaps/bingimage.png
Normal file
After Width: | Height: | Size: 12 KiB |
BIN
public/img/basemaps/bingmap.png
Normal file
After Width: | Height: | Size: 6.6 KiB |
BIN
public/img/basemaps/blackMarble.png
Normal file
After Width: | Height: | Size: 6.3 KiB |
BIN
public/img/basemaps/esriNationalGeographic.png
Normal file
After Width: | Height: | Size: 13 KiB |
BIN
public/img/basemaps/esriWorldImagery.png
Normal file
After Width: | Height: | Size: 12 KiB |
BIN
public/img/basemaps/esriWorldStreetMap.png
Normal file
After Width: | Height: | Size: 9.2 KiB |
BIN
public/img/basemaps/gaode_img.png
Normal file
After Width: | Height: | Size: 9.0 KiB |
BIN
public/img/basemaps/gaode_vec.png
Normal file
After Width: | Height: | Size: 8.4 KiB |
BIN
public/img/basemaps/google_img.png
Normal file
After Width: | Height: | Size: 9.4 KiB |
BIN
public/img/basemaps/google_ter.png
Normal file
After Width: | Height: | Size: 9.8 KiB |
BIN
public/img/basemaps/google_vec.png
Normal file
After Width: | Height: | Size: 8.2 KiB |
BIN
public/img/basemaps/mapQuestOpenStreetMap.png
Normal file
After Width: | Height: | Size: 13 KiB |
BIN
public/img/basemaps/mapboxSatellite.png
Normal file
After Width: | Height: | Size: 11 KiB |
BIN
public/img/basemaps/mapboxStreets.png
Normal file
After Width: | Height: | Size: 9.4 KiB |
BIN
public/img/basemaps/mapboxTerrain.png
Normal file
After Width: | Height: | Size: 11 KiB |
BIN
public/img/basemaps/naturalEarthII.png
Normal file
After Width: | Height: | Size: 9.0 KiB |
BIN
public/img/basemaps/offline.png
Normal file
After Width: | Height: | Size: 11 KiB |
BIN
public/img/basemaps/osm.png
Normal file
After Width: | Height: | Size: 3.0 KiB |
BIN
public/img/basemaps/sea.png
Normal file
After Width: | Height: | Size: 11 KiB |
BIN
public/img/basemaps/stamenToner.png
Normal file
After Width: | Height: | Size: 5.3 KiB |
BIN
public/img/basemaps/stamenWatercolor.png
Normal file
After Width: | Height: | Size: 12 KiB |
BIN
public/img/basemaps/tdt_img.png
Normal file
After Width: | Height: | Size: 12 KiB |
BIN
public/img/basemaps/tdt_ter.png
Normal file
After Width: | Height: | Size: 9.0 KiB |
BIN
public/img/basemaps/tdt_vec.png
Normal file
After Width: | Height: | Size: 8.7 KiB |
BIN
public/img/favicon/app-icon72x72@2x.png
Normal file
After Width: | Height: | Size: 3.0 KiB |
BIN
public/img/favicon/apple-touch-icon.png
Normal file
After Width: | Height: | Size: 1.8 KiB |
BIN
public/img/favicon/favicon.ico
Normal file
After Width: | Height: | Size: 9.4 KiB |
BIN
public/img/favicon/favicon.png
Normal file
After Width: | Height: | Size: 1.8 KiB |
BIN
public/img/friendly_icon.png
Normal file
After Width: | Height: | Size: 2.6 KiB |
BIN
public/img/icon-operate.png
Normal file
After Width: | Height: | Size: 5.5 KiB |
BIN
public/img/marker/mark1.png
Normal file
After Width: | Height: | Size: 1.7 KiB |
BIN
public/img/marker/mark2.png
Normal file
After Width: | Height: | Size: 1.5 KiB |
BIN
public/img/marker/mark3.png
Normal file
After Width: | Height: | Size: 2.2 KiB |
BIN
public/img/marker/mark4.png
Normal file
After Width: | Height: | Size: 1.6 KiB |
BIN
public/img/target_icon.png
Normal file
After Width: | Height: | Size: 9.0 KiB |
BIN
public/img/textures/LinkPulse.png
Normal file
After Width: | Height: | Size: 29 KiB |
BIN
public/img/textures/arrow.png
Normal file
After Width: | Height: | Size: 8.4 KiB |
BIN
public/img/textures/excavate_bottom_min.jpg
Normal file
After Width: | Height: | Size: 521 KiB |
BIN
public/img/textures/fence.png
Normal file
After Width: | Height: | Size: 40 KiB |
BIN
public/img/textures/lineClr.png
Normal file
After Width: | Height: | Size: 1.8 KiB |
BIN
public/img/textures/tanhao.png
Normal file
After Width: | Height: | Size: 9.5 KiB |
BIN
public/img/tietu/BlackMarble.jpg
Normal file
After Width: | Height: | Size: 132 KiB |
BIN
public/img/tietu/gugong.jpg
Normal file
After Width: | Height: | Size: 760 KiB |
BIN
public/img/tietu/leida.jpg
Normal file
After Width: | Height: | Size: 354 KiB |
BIN
public/img/tietu/world.jpg
Normal file
After Width: | Height: | Size: 242 KiB |
201
public/jmmap/JmMap.js
Normal file
9969
public/lib/admui/css/index.css
Normal file
14063
public/lib/admui/css/site.css
Normal file
137
public/lib/admui/js/app.js
Normal file
@ -0,0 +1,137 @@
|
|||||||
|
/**
|
||||||
|
* UI v1.1.0
|
||||||
|
* Copyright 2017-2018 Muyao
|
||||||
|
* Licensed under the Muyao License 1.0
|
||||||
|
*/
|
||||||
|
(function (window, document, $) {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
// 父级dom节点
|
||||||
|
$.parentFrame = $(window.parent.document);
|
||||||
|
|
||||||
|
// 父级方法&属性
|
||||||
|
var parentFrame = window.parentFrame = window.parent;
|
||||||
|
|
||||||
|
// 项目名称
|
||||||
|
$.ctx = parentFrame.$.ctx;
|
||||||
|
|
||||||
|
// 配置颜色获取方法
|
||||||
|
$.colors = parentFrame.$.colors;
|
||||||
|
|
||||||
|
// 注册组件默认配置参数获取方法
|
||||||
|
$.po = parentFrame.$.po;
|
||||||
|
|
||||||
|
// 本地存储对象操作
|
||||||
|
$.storage = parentFrame.$.storage;
|
||||||
|
$.sessionStorage = parentFrame.$.sessionStorage;
|
||||||
|
|
||||||
|
// 网址基础设置对象
|
||||||
|
$.site = parentFrame.$.site;
|
||||||
|
if ($.site && $.site.contentTabs)
|
||||||
|
$.site.contentTabs.ifameTabs(document);
|
||||||
|
|
||||||
|
// 配置信息存储管理
|
||||||
|
$.configs = parentFrame.$.configs;
|
||||||
|
|
||||||
|
// 注册组件初始化
|
||||||
|
if (parentFrame.$.components)
|
||||||
|
parentFrame.$.components.init(document, window);
|
||||||
|
|
||||||
|
// 公用对象
|
||||||
|
window.Breakpoints = parentFrame.Breakpoints;
|
||||||
|
window.toastr = parentFrame.toastr;
|
||||||
|
window.layer = parentFrame.layer;
|
||||||
|
window.haoutil = parentFrame.haoutil;
|
||||||
|
window.notifyFn = parentFrame.$.notifyFn;
|
||||||
|
|
||||||
|
// 自定义扩展对象
|
||||||
|
var _objExtend = _objExtend || {};
|
||||||
|
|
||||||
|
$.extend(_objExtend, {
|
||||||
|
_queue: {
|
||||||
|
prepare: [],
|
||||||
|
run: [],
|
||||||
|
complete: []
|
||||||
|
},
|
||||||
|
run: function () {
|
||||||
|
var self = this;
|
||||||
|
this._dequeue('prepare', function () {
|
||||||
|
self._trigger('before.run', self);
|
||||||
|
});
|
||||||
|
|
||||||
|
this._dequeue('run', function () {
|
||||||
|
self._dequeue('complete', function () {
|
||||||
|
self._trigger('after.run', self);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
},
|
||||||
|
_dequeue: function (name, done) { // 队列当前状态离队,进行下一步操作
|
||||||
|
var self = this,
|
||||||
|
queue = this._getQueue(name),
|
||||||
|
fn = queue.shift(),
|
||||||
|
next = function () {
|
||||||
|
self._dequeue(name, done);
|
||||||
|
};
|
||||||
|
|
||||||
|
if (fn) {
|
||||||
|
fn.call(this, next);
|
||||||
|
} else if ($.isFunction(done)) {
|
||||||
|
done.call(this);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
_getQueue: function (name) { // 获取队列状态信息
|
||||||
|
if (!$.isArray(this._queue[name])) {
|
||||||
|
this._queue[name] = [];
|
||||||
|
}
|
||||||
|
|
||||||
|
return this._queue[name];
|
||||||
|
},
|
||||||
|
extend: function (obj) { // 公用模块对象扩展方法
|
||||||
|
$.each(this._queue, function (name, queue) {
|
||||||
|
if ($.isFunction(obj[name])) {
|
||||||
|
queue.unshift(obj[name]);
|
||||||
|
|
||||||
|
delete obj[name];
|
||||||
|
}
|
||||||
|
});
|
||||||
|
$.extend(this, obj);
|
||||||
|
return this;
|
||||||
|
},
|
||||||
|
_trigger: function (name, data, $el) { // 离队状态执行动作
|
||||||
|
|
||||||
|
if (typeof name === 'undefined') {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (typeof $el === 'undefined') {
|
||||||
|
$el = $("#admui-pageContent");
|
||||||
|
}
|
||||||
|
|
||||||
|
$el.trigger(name + '.app', data);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// 通用功能对象(可配置增加,也可扩展)
|
||||||
|
var _app = {
|
||||||
|
pageAside: function () { // 小屏幕下侧边栏(展开&收起)操作
|
||||||
|
var pageAside = $(".page-aside"),
|
||||||
|
isOpen = pageAside.hasClass('open');
|
||||||
|
|
||||||
|
pageAside.toggleClass('open', !isOpen);
|
||||||
|
},
|
||||||
|
run: function (next) {
|
||||||
|
var self = this;
|
||||||
|
|
||||||
|
// 侧边栏开关
|
||||||
|
$(document).on('click', '.page-aside-switch', function (e) {
|
||||||
|
self.pageAside();
|
||||||
|
e.stopPropagation();
|
||||||
|
});
|
||||||
|
|
||||||
|
next();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
window.App = $.extend({}, _objExtend);
|
||||||
|
App.extend(_app);
|
||||||
|
|
||||||
|
})(window, document, jQuery);
|
2117
public/lib/admui/js/global/components.js
Normal file
174
public/lib/admui/js/global/configs/site-configs.js
Normal file
@ -0,0 +1,174 @@
|
|||||||
|
/**
|
||||||
|
* UI v1.1.0
|
||||||
|
* Copyright 2017-2018 Muyao
|
||||||
|
* Licensed under the Muyao License 1.0
|
||||||
|
*/
|
||||||
|
(function (window, $) {
|
||||||
|
"use strict";
|
||||||
|
|
||||||
|
/* global layer */
|
||||||
|
|
||||||
|
$.configs.set('site', {
|
||||||
|
fontFamily: '"Helvetica Neue", Helvetica, Tahoma, Arial, "Microsoft Yahei", "Hiragino Sans GB", "WenQuanYi Micro Hei", sans-serif'
|
||||||
|
});
|
||||||
|
|
||||||
|
$.configs.colors = {
|
||||||
|
"red": {
|
||||||
|
"100": "#ffeaea",
|
||||||
|
"200": "#fad3d3",
|
||||||
|
"300": "#fab4b4",
|
||||||
|
"400": "#fa9898",
|
||||||
|
"500": "#fa7a7a",
|
||||||
|
"600": "#f96868",
|
||||||
|
"700": "#e9595b",
|
||||||
|
"800": "#d6494b"
|
||||||
|
},
|
||||||
|
"pink": {
|
||||||
|
"100": "#fce4ec",
|
||||||
|
"200": "#ffccde",
|
||||||
|
"300": "#fba9c6",
|
||||||
|
"400": "#fb8db4",
|
||||||
|
"500": "#f978a6",
|
||||||
|
"600": "#f96197",
|
||||||
|
"700": "#f44c87",
|
||||||
|
"800": "#e53b75"
|
||||||
|
},
|
||||||
|
"purple": {
|
||||||
|
"100": "#f6f2ff",
|
||||||
|
"200": "#e3dbf4",
|
||||||
|
"300": "#d2c5ec",
|
||||||
|
"400": "#bba7e4",
|
||||||
|
"500": "#a58add",
|
||||||
|
"600": "#926dde",
|
||||||
|
"700": "#7c51d1",
|
||||||
|
"800": "#6d45bc"
|
||||||
|
},
|
||||||
|
"indigo": {
|
||||||
|
"100": "#edeff9",
|
||||||
|
"200": "#dadef5",
|
||||||
|
"300": "#bcc5f4",
|
||||||
|
"400": "#9daaf3",
|
||||||
|
"500": "#8897ec",
|
||||||
|
"600": "#677ae4",
|
||||||
|
"700": "#5166d6",
|
||||||
|
"800": "#465bd4"
|
||||||
|
},
|
||||||
|
"blue": {
|
||||||
|
"100": "#e8f1f8",
|
||||||
|
"200": "#d5e4f1",
|
||||||
|
"300": "#bcd8f1",
|
||||||
|
"400": "#a2caee",
|
||||||
|
"500": "#89bceb",
|
||||||
|
"600": "#62a8ea",
|
||||||
|
"700": "#4e97d9",
|
||||||
|
"800": "#3583ca"
|
||||||
|
},
|
||||||
|
"cyan": {
|
||||||
|
"100": "#ecf9fa",
|
||||||
|
"200": "#d3eff2",
|
||||||
|
"300": "#baeaef",
|
||||||
|
"400": "#9ae1e9",
|
||||||
|
"500": "#77d6e1",
|
||||||
|
"600": "#57c7d4",
|
||||||
|
"700": "#47b8c6",
|
||||||
|
"800": "#37a9b7"
|
||||||
|
},
|
||||||
|
"teal": {
|
||||||
|
"100": "#ecfdfc",
|
||||||
|
"200": "#cdf4f1",
|
||||||
|
"300": "#99e1da",
|
||||||
|
"400": "#79d1c9",
|
||||||
|
"500": "#56bfb5",
|
||||||
|
"600": "#3aa99e",
|
||||||
|
"700": "#269b8f",
|
||||||
|
"800": "#178d81"
|
||||||
|
},
|
||||||
|
"green": {
|
||||||
|
"100": "#e7faf2",
|
||||||
|
"200": "#bfedd8",
|
||||||
|
"300": "#9fe5c5",
|
||||||
|
"400": "#7dd3ae",
|
||||||
|
"500": "#5cd29d",
|
||||||
|
"600": "#46be8a",
|
||||||
|
"700": "#36ab7a",
|
||||||
|
"800": "#279566"
|
||||||
|
},
|
||||||
|
"light-green": {
|
||||||
|
"100": "#f1f7ea",
|
||||||
|
"200": "#e0ecd1",
|
||||||
|
"300": "#cadfb1",
|
||||||
|
"400": "#bad896",
|
||||||
|
"500": "#acd57c",
|
||||||
|
"600": "#9ece67",
|
||||||
|
"700": "#83b944",
|
||||||
|
"800": "#70a532"
|
||||||
|
},
|
||||||
|
"yellow": {
|
||||||
|
"100": "#fffae7",
|
||||||
|
"200": "#f9eec1",
|
||||||
|
"300": "#f6e7a9",
|
||||||
|
"400": "#f8e59b",
|
||||||
|
"500": "#f7e083",
|
||||||
|
"600": "#f7da64",
|
||||||
|
"700": "#f9cd48",
|
||||||
|
"800": "#fbc02d"
|
||||||
|
},
|
||||||
|
"orange": {
|
||||||
|
"100": "#fff3e6",
|
||||||
|
"200": "#ffddb9",
|
||||||
|
"300": "#fbce9d",
|
||||||
|
"400": "#f6be80",
|
||||||
|
"500": "#f4b066",
|
||||||
|
"600": "#f2a654",
|
||||||
|
"700": "#ec9940",
|
||||||
|
"800": "#e98f2e"
|
||||||
|
},
|
||||||
|
"brown": {
|
||||||
|
"100": "#fae6df",
|
||||||
|
"200": "#e2bdaf",
|
||||||
|
"300": "#d3aa9c",
|
||||||
|
"400": "#b98e7e",
|
||||||
|
"500": "#a17768",
|
||||||
|
"600": "#8d6658",
|
||||||
|
"700": "#7d5b4f",
|
||||||
|
"800": "#715146"
|
||||||
|
},
|
||||||
|
"grey": {
|
||||||
|
"100": "#fafafa",
|
||||||
|
"200": "#eeeeee",
|
||||||
|
"300": "#e0e0e0",
|
||||||
|
"400": "#bdbdbd",
|
||||||
|
"500": "#9e9e9e",
|
||||||
|
"600": "#757575",
|
||||||
|
"700": "#616161",
|
||||||
|
"800": "#424242"
|
||||||
|
},
|
||||||
|
"blue-grey": {
|
||||||
|
"100": "#f3f7f9",
|
||||||
|
"200": "#e4eaec",
|
||||||
|
"300": "#ccd5db",
|
||||||
|
"400": "#a3afb7",
|
||||||
|
"500": "#76838f",
|
||||||
|
"600": "#526069",
|
||||||
|
"700": "#37474f",
|
||||||
|
"800": "#263238"
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// 检查IE,在IE环境下设置ajax禁止缓存
|
||||||
|
var isIE = (function () {
|
||||||
|
return !!window.ActiveXObject || "ActiveXObject" in window;
|
||||||
|
});
|
||||||
|
|
||||||
|
if(isIE){
|
||||||
|
$.ajaxSetup({cache: false});
|
||||||
|
}
|
||||||
|
|
||||||
|
//// layer 弹层组件配置
|
||||||
|
//if(typeof layer !== 'undefined'){
|
||||||
|
// layer.config({
|
||||||
|
// extend: '../retina.css'
|
||||||
|
// });
|
||||||
|
//}
|
||||||
|
|
||||||
|
})(window, $);
|
359
public/lib/admui/js/global/core.js
Normal file
@ -0,0 +1,359 @@
|
|||||||
|
/**
|
||||||
|
* UI v1.1.0
|
||||||
|
* Copyright 2017-2018 Muyao
|
||||||
|
* Licensed under the Muyao License 1.0
|
||||||
|
*/
|
||||||
|
(function (window, document, $) {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
// 项目名称
|
||||||
|
$.ctx = location.pathname.substring(0,location.pathname.lastIndexOf("/")+1);
|
||||||
|
|
||||||
|
|
||||||
|
// 获取颜色配置信息
|
||||||
|
$.colors = function (name, level) {
|
||||||
|
if (!$.configs.colors && typeof $.configs.colors[name] === 'undefined') {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (level && typeof $.configs.colors[name][level] !== 'undefined') {
|
||||||
|
return $.configs.colors[name][level];
|
||||||
|
} else {
|
||||||
|
return $.configs.colors[name];
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// 3rd调用参数
|
||||||
|
$.po = function (name, options) {
|
||||||
|
var defaults = $.components.getDefaults(name);
|
||||||
|
return $.extend(true, {}, defaults, options);
|
||||||
|
};
|
||||||
|
|
||||||
|
// 配置信息存储管理
|
||||||
|
$.configs = $.configs || {};
|
||||||
|
|
||||||
|
$.extend($.configs, {
|
||||||
|
_data: {},
|
||||||
|
get: function () {
|
||||||
|
var data = this._data, name,
|
||||||
|
_argLen = arguments.length;
|
||||||
|
|
||||||
|
if (_argLen === 0) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
for (var i = 0; i < _argLen; i++) {
|
||||||
|
name = arguments[i];
|
||||||
|
|
||||||
|
data = data[name];
|
||||||
|
}
|
||||||
|
|
||||||
|
return data;
|
||||||
|
},
|
||||||
|
set: function (name, value) {
|
||||||
|
if (this.get(name)) {
|
||||||
|
console.error('configs:' + name + '对象已经存在了');
|
||||||
|
} else {
|
||||||
|
this._data[name] = value;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
extend: function (name, options) {
|
||||||
|
return $.extend(true, this.get(name), options);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// 实现插件的提前检测和调用
|
||||||
|
$.components = $.components || {};
|
||||||
|
|
||||||
|
$.extend($.components, {
|
||||||
|
_components: {},
|
||||||
|
register: function (name, obj) {
|
||||||
|
this._components[name] = obj;
|
||||||
|
},
|
||||||
|
init: function (context, iframe, name, args) {
|
||||||
|
var self = this, obj;
|
||||||
|
args = args || true;
|
||||||
|
|
||||||
|
if (typeof name === 'undefined') {
|
||||||
|
$.each(this._components, function (name) {
|
||||||
|
self.init(context, iframe, name, args);
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
context = context || document;
|
||||||
|
|
||||||
|
obj = this.get(name);
|
||||||
|
|
||||||
|
if (!obj) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (obj.mode) {
|
||||||
|
case 'default':
|
||||||
|
return this._initDefault(name, context, iframe);
|
||||||
|
case 'init':
|
||||||
|
return this._initComponent(obj, context, iframe);
|
||||||
|
case 'api':
|
||||||
|
return this._initApi(obj, context, args, iframe);
|
||||||
|
default:
|
||||||
|
this._initApi(obj, context, args, iframe);
|
||||||
|
this._initComponent(obj, context, iframe);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
_initDefault: function (name, context, iframe) { // jquery 3rd的基本用法
|
||||||
|
var iframe$ = iframe ? iframe.$ : $, defaults;
|
||||||
|
|
||||||
|
if (!iframe$.fn[name]) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
defaults = this.getDefaults(name);
|
||||||
|
|
||||||
|
$('[data-plugin=' + name + ']', context).each(function () {
|
||||||
|
var $this = iframe$(this),
|
||||||
|
options = $.extend(true, {}, defaults, $this.data());
|
||||||
|
|
||||||
|
$this[name](options);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
_initComponent: function (obj, context, iframe) { // jquery 3rd的高级用法
|
||||||
|
if ($.isFunction(obj.init)) {
|
||||||
|
obj.init.call(obj, context, iframe);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
_initApi: function (obj, context, args, iframe) { // 其他处理
|
||||||
|
if (args && $.isFunction(obj.api)) {
|
||||||
|
obj.api.call(obj, context, iframe);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
getDefaults: function (name) {
|
||||||
|
var component = this.get(name);
|
||||||
|
|
||||||
|
return component && typeof component.defaults !== "undefined" ? component.defaults : {};
|
||||||
|
},
|
||||||
|
get: function (name) {
|
||||||
|
if (typeof this._components[name] !== "undefined") {
|
||||||
|
return this._components[name];
|
||||||
|
} else {
|
||||||
|
console.error('component:' + name + ' 脚本文件没有注册任何信息!');
|
||||||
|
return undefined;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// 本地存储对象操作 localStorage
|
||||||
|
$.storage = $.storage || {};
|
||||||
|
|
||||||
|
$.extend($.storage, {
|
||||||
|
set: function (key, value, time) { //存入缓存
|
||||||
|
var cacheExpireDate, cacheVal;
|
||||||
|
|
||||||
|
if (!localStorage) {
|
||||||
|
console.error('该浏览器不支持localStorage对象');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!key || !value) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 定时情况
|
||||||
|
if (!time || isNaN(time)) {
|
||||||
|
cacheExpireDate = null;
|
||||||
|
} else {
|
||||||
|
cacheExpireDate = (new Date() - 1) + time * 1000 * 60;
|
||||||
|
}
|
||||||
|
|
||||||
|
cacheVal = {val: value, exp: cacheExpireDate};
|
||||||
|
|
||||||
|
if (typeof value === "object") {
|
||||||
|
cacheVal = JSON.stringify(cacheVal);
|
||||||
|
}
|
||||||
|
|
||||||
|
localStorage.setItem(key, cacheVal);
|
||||||
|
},
|
||||||
|
get: function (key) { // 获取存储内容
|
||||||
|
var value, now, exp;
|
||||||
|
|
||||||
|
if (!localStorage) {
|
||||||
|
console.error('该浏览器不支持localStorage对象');
|
||||||
|
}
|
||||||
|
|
||||||
|
value = localStorage.getItem(key);
|
||||||
|
|
||||||
|
if (!value) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (typeof value === 'string') {
|
||||||
|
value = JSON.parse(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
now = new Date() - 1;
|
||||||
|
exp = value.exp;
|
||||||
|
|
||||||
|
if (exp && now > exp) { // 缓存内容已过期
|
||||||
|
this.remove(key);
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
return value.val;
|
||||||
|
},
|
||||||
|
remove: function (key) { // 删除指定缓存
|
||||||
|
if (!localStorage) {
|
||||||
|
console.error('该浏览器不支持localStorage对象');
|
||||||
|
}
|
||||||
|
|
||||||
|
localStorage.removeItem(key);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// 本地存储对象操作 sessionStorage
|
||||||
|
$.sessionStorage = $.sessionStorage || {};
|
||||||
|
|
||||||
|
$.extend($.sessionStorage, {
|
||||||
|
set: function (key, value) { //存入缓存
|
||||||
|
if (!sessionStorage) {
|
||||||
|
console.error('该浏览器不支持sessionStorage对象');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!key || !value) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (typeof value === "object") {
|
||||||
|
value = JSON.stringify(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
sessionStorage.setItem(key, value);
|
||||||
|
},
|
||||||
|
get: function (key) { // 获取存储内容
|
||||||
|
var value;
|
||||||
|
|
||||||
|
if (!sessionStorage) {
|
||||||
|
console.error('该浏览器不支持sessionStorage对象');
|
||||||
|
}
|
||||||
|
|
||||||
|
value = sessionStorage.getItem(key);
|
||||||
|
|
||||||
|
if (!value) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (typeof value === 'string') {
|
||||||
|
value = JSON.parse(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
return value;
|
||||||
|
},
|
||||||
|
remove: function (key) { // 删除指定缓存
|
||||||
|
if (!sessionStorage) {
|
||||||
|
console.error('该浏览器不支持sessionStorage对象');
|
||||||
|
}
|
||||||
|
|
||||||
|
sessionStorage.removeItem(key);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// 网站基础设置
|
||||||
|
$.site = $.site || {};
|
||||||
|
|
||||||
|
function dataAttr(elem, key, data, iJquery) {
|
||||||
|
var rbrace = /^(?:\{[\w\W]*\}|\[[\w\W]*\])$/,
|
||||||
|
rmultiDash = /([A-Z])/g;
|
||||||
|
|
||||||
|
// If nothing was found internally, try to fetch any
|
||||||
|
// data from the HTML5 data-* attribute
|
||||||
|
if (data === undefined && elem.nodeType === 1) {
|
||||||
|
|
||||||
|
var name = "data-" + key.replace(rmultiDash, "-$1").toLowerCase();
|
||||||
|
|
||||||
|
data = elem.getAttribute(name);
|
||||||
|
|
||||||
|
if (typeof data === "string") {
|
||||||
|
try {
|
||||||
|
data = data === "true" ? true :
|
||||||
|
data === "false" ? false :
|
||||||
|
data === "null" ? null :
|
||||||
|
|
||||||
|
// Only convert to a number if it doesn't change the string
|
||||||
|
+data + "" === data ? +data :
|
||||||
|
rbrace.test(data) ? $.parseJSON(data) :
|
||||||
|
data;
|
||||||
|
} catch (e) {
|
||||||
|
}
|
||||||
|
|
||||||
|
// Make sure we set the data so it isn't changed later
|
||||||
|
iJquery.data(elem, key, data);
|
||||||
|
|
||||||
|
} else {
|
||||||
|
data = undefined;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return data;
|
||||||
|
}
|
||||||
|
|
||||||
|
$.fn.extend({
|
||||||
|
data: function (key, value, iJquery) {
|
||||||
|
var i, name, data,
|
||||||
|
elem = this[0],
|
||||||
|
attrs = elem && elem.attributes;
|
||||||
|
|
||||||
|
// Special expections of .data basically thwart jQuery.access,
|
||||||
|
// so implement the relevant behavior ourselves
|
||||||
|
|
||||||
|
// Gets all values
|
||||||
|
if (key === undefined || $.isFunction(key)) {
|
||||||
|
iJquery = key || $;
|
||||||
|
|
||||||
|
if (this.length) {
|
||||||
|
data = iJquery.data(elem);
|
||||||
|
|
||||||
|
if (elem.nodeType === 1 && !iJquery._data(elem, "parsedAttrs")) {
|
||||||
|
i = attrs.length;
|
||||||
|
while (i--) {
|
||||||
|
|
||||||
|
// Support: IE11+
|
||||||
|
// The attrs elements can be null (#14894)
|
||||||
|
if (attrs[i]) {
|
||||||
|
name = attrs[i].name;
|
||||||
|
if (name.indexOf("data-") === 0) {
|
||||||
|
name = iJquery.camelCase(name.slice(5));
|
||||||
|
dataAttr(elem, name, data[name], iJquery);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
iJquery._data(elem, "parsedAttrs", true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return data;
|
||||||
|
}
|
||||||
|
|
||||||
|
if($.isFunction(value) && value.fn.jquery){
|
||||||
|
return elem ? dataAttr(elem, key, value.data(elem, key), value) : undefined;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Sets multiple values
|
||||||
|
if (typeof key === "object") {
|
||||||
|
return this.each(function () {
|
||||||
|
value && value.data(this, key);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
iJquery = iJquery || $;
|
||||||
|
|
||||||
|
return arguments.length > 1 ?
|
||||||
|
|
||||||
|
// Sets one value
|
||||||
|
this.each(function () {
|
||||||
|
iJquery.data(this, key, value);
|
||||||
|
}) :
|
||||||
|
|
||||||
|
// Gets one value
|
||||||
|
// Try to fetch any internally stored data first
|
||||||
|
elem ? dataAttr(elem, key, iJquery.data(elem, key), iJquery) : undefined;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
})(window, document, jQuery);
|
359
public/lib/admui/js/index.js
Normal file
@ -0,0 +1,359 @@
|
|||||||
|
/**
|
||||||
|
* UI v1.1.0
|
||||||
|
* Copyright 2017-2018 Muyao
|
||||||
|
* Licensed under the Muyao License 1.0
|
||||||
|
*/
|
||||||
|
(function (docuemnt, window, $) {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
/* globals Breakpoints, screenfull*/
|
||||||
|
|
||||||
|
$.extend($.site, {
|
||||||
|
theme: function () { // 主题渲染
|
||||||
|
var $body = $('body'),
|
||||||
|
settingsName = 'admui.base.skinTools',
|
||||||
|
$parentLink = $('#admui-siteStyle', $('head')),
|
||||||
|
settings = localStorage.getItem(settingsName),
|
||||||
|
parentEtx = $parentLink.prop('href').indexOf('?v=') === -1 ? '' : '.min', themeColor, sidebar, navbar,
|
||||||
|
menuDisplay, menuTxtIcon;
|
||||||
|
|
||||||
|
if (!settings) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
settings = JSON.parse(settings).val;
|
||||||
|
themeColor = this.themeColor = settings.themeColor;
|
||||||
|
sidebar = settings.sidebar;
|
||||||
|
navbar = settings.navbar;
|
||||||
|
menuDisplay = settings.menuDisplay;
|
||||||
|
menuTxtIcon = settings.menuTxtIcon;
|
||||||
|
|
||||||
|
// 在前端渲染主题不是最优雅体验最好的,建议通过后端渲染
|
||||||
|
if (themeColor && themeColor !== 'primary') {
|
||||||
|
setTimeout(function () {
|
||||||
|
$parentLink.attr('href', 'lib/admui/skins/' + themeColor + '/index' + parentEtx + '.css');
|
||||||
|
}, 130);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (sidebar && sidebar === 'site-menubar-light') {
|
||||||
|
$('#admui-siteMenubar').addClass('site-menubar-light');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (navbar && navbar !== '') {
|
||||||
|
$('.site-navbar').addClass(navbar);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (settings.navbarInverse === '') {
|
||||||
|
$('.site-navbar').removeClass('navbar-inverse');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (menuDisplay && menuDisplay === 'site-menubar-fold') {
|
||||||
|
$.site.menubar.fold();
|
||||||
|
|
||||||
|
if (menuTxtIcon && menuTxtIcon === 'site-menubar-keep') {
|
||||||
|
$body.addClass('site-menubar-keep');
|
||||||
|
} else {
|
||||||
|
$body.addClass('site-menubar-fold-alt');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (settings.tabFlag === '') {
|
||||||
|
$body.removeClass('site-contabs-open');
|
||||||
|
}
|
||||||
|
|
||||||
|
},
|
||||||
|
iframeTheme: function () { // 子框架主体内容部分主题
|
||||||
|
var $iframeLink = $('#admui-siteStyle', this.iframeDocument),
|
||||||
|
iframeEtx = $iframeLink.prop('href').indexOf('?v=') === -1 ? '' : '.min',
|
||||||
|
themeColor = this.themeColor;
|
||||||
|
|
||||||
|
if (themeColor && themeColor !== 'primary') {
|
||||||
|
$iframeLink.attr('href', 'lib/admui/skins/' + this.themeColor + '/site' + iframeEtx + '.css');
|
||||||
|
}
|
||||||
|
},
|
||||||
|
_tabsDraw: function () { // 标签页重绘
|
||||||
|
var self = this,
|
||||||
|
settingsName = 'admui.base.contentTabs',
|
||||||
|
settings = $.sessionStorage.get(settingsName),
|
||||||
|
tab, checkedTabId, checkedTabUrl, tabTpl, tabUrl, tabName, tabIframe,
|
||||||
|
locationUrl = location.hash.substring(2),
|
||||||
|
$conTabs = $('.con-tabs'),
|
||||||
|
contentTabs = $.site.contentTabs,
|
||||||
|
callback = function (key, tabId, url) {
|
||||||
|
var $firstIframe = self.$content.find('iframe:first');
|
||||||
|
|
||||||
|
if (key === tabId || !locationUrl) {
|
||||||
|
checkedTabUrl = url;
|
||||||
|
|
||||||
|
$conTabs.find('li:first').addClass('active');
|
||||||
|
$firstIframe.attr('src', url);
|
||||||
|
self.iframeEvents($firstIframe);
|
||||||
|
}else{
|
||||||
|
$firstIframe.removeClass('active');
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
checkedTabId = settings.checked;
|
||||||
|
|
||||||
|
for (var key in settings) {
|
||||||
|
tab = settings[key];
|
||||||
|
|
||||||
|
if (key === 'checked' || key === 'tabId') {
|
||||||
|
continue;
|
||||||
|
} else if (key === 'iframe-0') {
|
||||||
|
callback(key, checkedTabId, tab.url);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
tabUrl = tab.url;
|
||||||
|
tabName = tab.name;
|
||||||
|
tabTpl = '<a href="' + tabUrl + '" ' + 'target="' + key + '"' +
|
||||||
|
'" title="' + tabName + '' + '" rel="contents"><span>' + tabName + '</span><i class="icon' +
|
||||||
|
' wb-close-mini">' + '</i></a></li>';
|
||||||
|
|
||||||
|
if (key === checkedTabId && locationUrl) {
|
||||||
|
checkedTabUrl = tabUrl;
|
||||||
|
tabTpl = '<li class="active">' + tabTpl;
|
||||||
|
tabIframe = '<iframe src="' + tabUrl + '" frameborder="0" name="' + key + '" class="page-frame animation-fade active"></iframe>';
|
||||||
|
} else {
|
||||||
|
tabTpl = '<li>' + tabTpl;
|
||||||
|
tabIframe = '<iframe src="" frameborder="0" name="' + key + '" class="page-frame animation-fade"></iframe>';
|
||||||
|
}
|
||||||
|
|
||||||
|
$conTabs.append(tabTpl);
|
||||||
|
self.$content.append(tabIframe);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (locationUrl !== checkedTabUrl && locationUrl) {
|
||||||
|
this._urlRequest(locationUrl);
|
||||||
|
}
|
||||||
|
|
||||||
|
contentTabs.enable($conTabs.find('.active'));
|
||||||
|
|
||||||
|
if (Object.keys(settings).length >= 19) {
|
||||||
|
contentTabs.tabSize();
|
||||||
|
contentTabs.tabEvent($conTabs, 'media');
|
||||||
|
}
|
||||||
|
},
|
||||||
|
_urlRequest: function (url) { // 处理存储信息中没有的页面访问(创建新的标签页)
|
||||||
|
var title = '未知页面';
|
||||||
|
|
||||||
|
$('.site-menu a').each(function () {
|
||||||
|
var $item = $(this);
|
||||||
|
|
||||||
|
if ($item.attr('href') === url) {
|
||||||
|
title = $.trim($item.attr('title') || $item.text());
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
$.site.contentTabs.buildTab({name: title, url: url});
|
||||||
|
},
|
||||||
|
_hideNavbar: function () { // 隐藏导航条
|
||||||
|
var $body = $('body');
|
||||||
|
|
||||||
|
$body.addClass('site-navbar-collapsing');
|
||||||
|
$('#admui-navbarCollapse').collapse('hide');
|
||||||
|
|
||||||
|
setTimeout(function () {
|
||||||
|
$body.removeClass('site-navbar-collapsing');
|
||||||
|
}, 10);
|
||||||
|
|
||||||
|
$body.removeClass('site-navbar-collapse-show');
|
||||||
|
},
|
||||||
|
iframeEvents: function ($el) { // 子框架主体内容事件处理
|
||||||
|
var self = this, _callback = function (obj) {
|
||||||
|
$('#admui-siteStyle', obj).load(function () {
|
||||||
|
self.iframeTheme();
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
* 菜单收起
|
||||||
|
* 导航条收起
|
||||||
|
* */
|
||||||
|
$el.load(function () {
|
||||||
|
var iframeDocument = self.iframeDocument = $.content.document();
|
||||||
|
|
||||||
|
$(iframeDocument).on('click', function () {
|
||||||
|
// 小屏下收起顶部导航条和左侧菜单
|
||||||
|
if (Breakpoints.is('xs') && $('body').hasClass('site-menubar-open')) {
|
||||||
|
$.site.menubar.hide();
|
||||||
|
|
||||||
|
self._hideNavbar();
|
||||||
|
}
|
||||||
|
|
||||||
|
// 核心框架中下拉菜单切换操作
|
||||||
|
$('[data-toggle="dropdown"]').parent().removeClass('open');
|
||||||
|
});
|
||||||
|
|
||||||
|
_callback(iframeDocument);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
run: function () {
|
||||||
|
var self = this,
|
||||||
|
$content = this.$content = $('#admui-pageContent');
|
||||||
|
|
||||||
|
// 获取iframe框架中变量&方法
|
||||||
|
$.content = $.content || {};
|
||||||
|
|
||||||
|
$.extend($.content, {
|
||||||
|
window: function () {
|
||||||
|
var name = $content.find('iframe.active').attr('name');
|
||||||
|
return window.frames[name];
|
||||||
|
},
|
||||||
|
document: function () { // 获取iframe框架中document
|
||||||
|
var name = $content.find('iframe.active').attr('name');
|
||||||
|
return window.frames[name].document;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// 当前iframe框架document
|
||||||
|
this.iframeDocument = null;
|
||||||
|
|
||||||
|
// 项目名称获取
|
||||||
|
$.ctx = $('#admui-signOut').data('ctx') || $.ctx;
|
||||||
|
|
||||||
|
if (typeof $.site.menu !== 'undefined') {
|
||||||
|
$.site.menu.init();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (typeof $.site.contentTabs !== 'undefined') {
|
||||||
|
$.site.contentTabs.init();
|
||||||
|
}
|
||||||
|
|
||||||
|
// 导航条响应式
|
||||||
|
$('#admui-navbar').responsiveHorizontalTabs({
|
||||||
|
tabParentSelector: '#admui-navTabs',
|
||||||
|
fnCallback: function (el) {
|
||||||
|
if ($('#admui-navbar').is(':visible')) {
|
||||||
|
el.removeClass('is-load');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// 导航条&菜单的响应式工作
|
||||||
|
if (typeof $.site.menubar !== 'undefined') {
|
||||||
|
$('#admui-siteMenubar').on('changing.site.menubar', function () {
|
||||||
|
var $menubar = $('[data-toggle="menubar"]');
|
||||||
|
|
||||||
|
$menubar.toggleClass('hided', !$.site.menubar.opened);
|
||||||
|
$menubar.toggleClass('unfolded', !$.site.menubar.folded);
|
||||||
|
});
|
||||||
|
|
||||||
|
$.site.menubar.init();
|
||||||
|
|
||||||
|
Breakpoints.on('change', function () {
|
||||||
|
$.site.menubar.change();
|
||||||
|
});
|
||||||
|
|
||||||
|
/*
|
||||||
|
* 小屏幕下导航条展开 | 收起按钮
|
||||||
|
* 搜索按钮(href)
|
||||||
|
* */
|
||||||
|
$(document).on('click', '[data-toggle="collapse"]', function (e) {
|
||||||
|
var $trigger = $(e.target),
|
||||||
|
href, target, $target;
|
||||||
|
|
||||||
|
if (!$trigger.is('[data-toggle="collapse"]')) {
|
||||||
|
$trigger = $trigger.parents('[data-toggle="collapse"]');
|
||||||
|
}
|
||||||
|
|
||||||
|
target = $trigger.attr('data-target') || (href = $trigger.attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '');
|
||||||
|
$target = $(target);
|
||||||
|
|
||||||
|
if ($target.hasClass('navbar-search-overlap')) {
|
||||||
|
$target.find('input').focus();
|
||||||
|
|
||||||
|
e.preventDefault();
|
||||||
|
} else if ($target.attr('id') === 'admui-navbarCollapse') {
|
||||||
|
var isOpen = !$trigger.hasClass('collapsed'),
|
||||||
|
$body = $(document.body);
|
||||||
|
|
||||||
|
$body.addClass('site-navbar-collapsing');
|
||||||
|
$body.toggleClass('site-navbar-collapse-show', isOpen);
|
||||||
|
|
||||||
|
$('#admui-navbar').responsiveHorizontalTabs({
|
||||||
|
tabParentSelector: '#admui-navTabs',
|
||||||
|
fnCallback: function (el) {
|
||||||
|
el.removeClass('is-load');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
setTimeout(function () {
|
||||||
|
$body.removeClass('site-navbar-collapsing');
|
||||||
|
}, 350);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
$(document).on('click', '[data-toggle="menubar"]', function () { // 菜单展开|收起控制按钮
|
||||||
|
if (Breakpoints.is('xs') && $('body').hasClass('site-menubar-open')) {
|
||||||
|
self._hideNavbar();
|
||||||
|
}
|
||||||
|
|
||||||
|
$.site.menubar.toggle();
|
||||||
|
});
|
||||||
|
|
||||||
|
// 图标对应菜单展开
|
||||||
|
$('#admui-navbar >.nav-tabs >li:not(.no-menu)').on('click', function (e) {
|
||||||
|
if ($(e.target).closest('li').is('.dropdown')) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (Breakpoints.is('xs')) {
|
||||||
|
$.site.menubar.open();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// 全屏模式操作
|
||||||
|
if (typeof screenfull !== 'undefined') {
|
||||||
|
$(document).on('click', '[data-toggle="fullscreen"]', function () {
|
||||||
|
if (screenfull.enabled) {
|
||||||
|
screenfull.toggle();
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
});
|
||||||
|
|
||||||
|
if (screenfull.enabled) {
|
||||||
|
document.addEventListener(screenfull.raw.fullscreenchange, function () {
|
||||||
|
$('[data-toggle="fullscreen"]').toggleClass('active', screenfull.isFullscreen);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// 对下拉列表的其他功能
|
||||||
|
$(document).on('show.bs.dropdown', function (e) {
|
||||||
|
var $target = $(e.target), $menu,
|
||||||
|
$trigger = e.relatedTarget ? $(e.relatedTarget) : $target.children('[data-toggle="dropdown"]'),
|
||||||
|
animation = $trigger.data('animation');
|
||||||
|
|
||||||
|
if (animation) {
|
||||||
|
$menu = $target.children('.dropdown-menu');
|
||||||
|
|
||||||
|
$menu.addClass('animation-' + animation);
|
||||||
|
|
||||||
|
$menu.one('webkitAnimationEnd mozAnimationEnd MSAnimationEnd oanimationend animationend', function () {
|
||||||
|
$menu.removeClass('animation-' + animation);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// 父框架工具提示和弹框初始化
|
||||||
|
$('[data-toggle="tooltip"]').tooltip({trigger: 'hover'});
|
||||||
|
$('[data-toggle="popover"]').popover();
|
||||||
|
|
||||||
|
if (window.localStorage) {
|
||||||
|
this.theme();
|
||||||
|
this._tabsDraw();
|
||||||
|
}
|
||||||
|
|
||||||
|
$.components.init();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
$.site.run();
|
||||||
|
|
||||||
|
})(document, window, jQuery);
|
490
public/lib/admui/js/sections/content-tabs.js
Normal file
@ -0,0 +1,490 @@
|
|||||||
|
/**
|
||||||
|
* UI v1.1.0
|
||||||
|
* Copyright 2017-2018 Muyao
|
||||||
|
* Licensed under the Muyao License 1.0
|
||||||
|
*/
|
||||||
|
(function (window, document, $) {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
$.site.contentTabs = {
|
||||||
|
$instance: $('#admui-navTabs .site-menu'),
|
||||||
|
$content: $('#admui-pageContent'),
|
||||||
|
storageKey: 'admui.base.contentTabs',
|
||||||
|
tabId: 0,
|
||||||
|
relative: 0,
|
||||||
|
tabTimeout: 30,
|
||||||
|
init: function () {
|
||||||
|
this.bind();
|
||||||
|
this._defaultTab();
|
||||||
|
},
|
||||||
|
bind: function () {
|
||||||
|
var self = this,
|
||||||
|
$navContabs = $("#admui-siteConTabs"),
|
||||||
|
$navContent = $navContabs.find("ul.con-tabs");
|
||||||
|
|
||||||
|
this.tabWidth = $navContent.find("li").width();
|
||||||
|
this.view = $navContabs.find(".contabs-scroll").width();
|
||||||
|
|
||||||
|
this.ifameTabs();
|
||||||
|
|
||||||
|
// 标签页的左右移动 && 关闭单个标签页 && 切换标签页
|
||||||
|
$navContabs
|
||||||
|
.on('click.site.contabs', 'button.pull-left', function () {
|
||||||
|
self.tabPosition($navContent, self.tabWidth, "right");
|
||||||
|
})
|
||||||
|
.on('click.site.contabs', '.pull-right>.btn-icon', function () {
|
||||||
|
var content = $navContent.width();
|
||||||
|
|
||||||
|
self.tabPosition($navContent, self.tabWidth, "left", self.view, content);
|
||||||
|
})
|
||||||
|
.on('click.site.contabs', 'ul.con-tabs>li', function (e) {
|
||||||
|
var $target = $(e.target), $item = $(this);
|
||||||
|
|
||||||
|
if ($target.is("i.wb-close-mini")) { // 关闭
|
||||||
|
self.closeTab($item);
|
||||||
|
} else if (!$item.is(".active")) { // 切换
|
||||||
|
$item.siblings("li").removeClass("active");
|
||||||
|
$item.addClass("active");
|
||||||
|
|
||||||
|
self._checkoutTab($item.find('a'));
|
||||||
|
self.enable($item);
|
||||||
|
}
|
||||||
|
e.preventDefault();
|
||||||
|
});
|
||||||
|
|
||||||
|
// 刷新当前页 && 关闭其他 && 所有标签页
|
||||||
|
$navContabs
|
||||||
|
.on('click.site.contabs', '.pull-right li.reload-page', function () {
|
||||||
|
var $navLi = $navContabs.find('ul.con-tabs>li.active>a'),
|
||||||
|
tabUrl = $navLi.attr('href');
|
||||||
|
|
||||||
|
// 刷新当前页
|
||||||
|
self.$content.children('[src="' + tabUrl + '"]').attr('src', tabUrl);
|
||||||
|
|
||||||
|
})
|
||||||
|
.on('click.site.contabs', '.pull-right li.close-other', function () {
|
||||||
|
var $navLis = $navContabs.find('ul.con-tabs>li');
|
||||||
|
|
||||||
|
$navLis.each(function () {
|
||||||
|
var $that = $(this), tabId;
|
||||||
|
|
||||||
|
if (!$that.is('.active') && $that.index() !== 0) {
|
||||||
|
tabId = $that.find('a').attr('target');
|
||||||
|
$that.remove();
|
||||||
|
self.$content.children('[name="' + tabId + '"]').remove();
|
||||||
|
self._updateSetting(tabId);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
$navContent.animate({left: 0}, 100);
|
||||||
|
|
||||||
|
self.btnView('hide');
|
||||||
|
})
|
||||||
|
.on('click.site.contabs', '.pull-right li.close-all', function () {
|
||||||
|
var $tabs = $navContabs.find('ul.con-tabs>li'),
|
||||||
|
$checked = $tabs.eq(0);
|
||||||
|
|
||||||
|
$tabs.each(function () {
|
||||||
|
var $that = $(this), tabId;
|
||||||
|
|
||||||
|
if ($that.index() !== 0) {
|
||||||
|
tabId = $that.find('a').attr('target');
|
||||||
|
$that.remove();
|
||||||
|
self._updateSetting(tabId);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
$navContent.animate({left: 0}, 100);
|
||||||
|
|
||||||
|
self.btnView('hide');
|
||||||
|
|
||||||
|
$checked.addClass('active');
|
||||||
|
self.enable($tabs.eq(0));
|
||||||
|
self._checkoutTab($checked.find('a'));
|
||||||
|
|
||||||
|
// 关闭所有
|
||||||
|
self.$content.children(':not(:first)').remove();
|
||||||
|
|
||||||
|
self.tabSize();
|
||||||
|
});
|
||||||
|
|
||||||
|
// 登出清楚标签页缓存
|
||||||
|
$(document).on('click', '#admui-signOut', function () {
|
||||||
|
$.sessionStorage.remove(self.storageKey);
|
||||||
|
});
|
||||||
|
|
||||||
|
// 浏览器窗口大小改变,标签页的对应状态
|
||||||
|
$(window).on('resize', this.resize);
|
||||||
|
},
|
||||||
|
ifameTabs: function (el) { // 为当前doc对象中的a[data-iframe]标签绑定创建标签页功能
|
||||||
|
var self = this,
|
||||||
|
doc = el === undefined ? document : el;
|
||||||
|
|
||||||
|
// 新建标签页
|
||||||
|
$(doc).on('click', 'a[data-iframe]', function (e) {
|
||||||
|
var $item = $(this), urlResult,
|
||||||
|
url = $item.attr('href'),
|
||||||
|
title = $.trim($item.text()) || $.trim($item.attr('title')),
|
||||||
|
iframeContent = $item.data('iframe') || '#admui-pageContent',
|
||||||
|
tabResult = $item.is('[target="_blank"]');
|
||||||
|
|
||||||
|
urlResult = new RegExp(/^([a-zA-z]+:|#|javascript|www\.)/); // 不执行新建标签页操作的地址
|
||||||
|
|
||||||
|
if (urlResult.test(url)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (tabResult && iframeContent === '#admui-pageContent') {
|
||||||
|
window.history.replaceState(null, '', '#!' + url);
|
||||||
|
self.tabType = true;
|
||||||
|
self.buildTab({name: title, url: url});
|
||||||
|
|
||||||
|
if (!self.$instance.find($item).length) {
|
||||||
|
self.enable($item.parent());
|
||||||
|
}
|
||||||
|
} else if (!tabResult) {
|
||||||
|
$(iframeContent).find('iframe.active').attr('src', url);
|
||||||
|
}
|
||||||
|
|
||||||
|
e.preventDefault();
|
||||||
|
});
|
||||||
|
},
|
||||||
|
_checkoutTab: function (tab) { // 标签页的切换
|
||||||
|
var $content = this.$content,
|
||||||
|
tabId = tab.attr('target'),
|
||||||
|
tabTitle = $.trim(tab.attr('title')),
|
||||||
|
tabUrl = tab.attr('href'),
|
||||||
|
$checkedTab = $content.children('iframe[name="' + tabId + '"]');
|
||||||
|
|
||||||
|
$('title').text(tabTitle);
|
||||||
|
|
||||||
|
if (!this.tabType) {
|
||||||
|
window.history.replaceState(null, '', '#!' + tabUrl);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!$checkedTab.attr('src')) {
|
||||||
|
$checkedTab.attr('src', tabUrl);
|
||||||
|
}
|
||||||
|
|
||||||
|
$content.children('.active').removeClass('active');
|
||||||
|
$checkedTab.addClass('active');
|
||||||
|
|
||||||
|
$.site.iframeEvents($checkedTab);
|
||||||
|
this._updateSetting('checked', tabId);
|
||||||
|
this.tabType = false;
|
||||||
|
},
|
||||||
|
_defaultTab: function () { // 存储默认标签的信息
|
||||||
|
var $defaultTab = $('#admui-siteConTabs').find('li:first > a'), settings;
|
||||||
|
|
||||||
|
settings = this.settings = $.sessionStorage.get(this.storageKey);
|
||||||
|
|
||||||
|
if (settings === null) {
|
||||||
|
settings = $.extend(true, {}, {
|
||||||
|
'iframe-0': {
|
||||||
|
'url': $defaultTab.attr('href'),
|
||||||
|
'name': $defaultTab.text()
|
||||||
|
},
|
||||||
|
'checked': $defaultTab.attr('target'),
|
||||||
|
'tabId': this.tabId
|
||||||
|
});
|
||||||
|
|
||||||
|
this._updateSetting(settings);
|
||||||
|
} else {
|
||||||
|
this.tabId = settings.tabId;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
_updateSetting: function (item, value) {
|
||||||
|
var settings = $.sessionStorage.get(this.storageKey);
|
||||||
|
settings = settings ? settings : {};
|
||||||
|
|
||||||
|
if (typeof item === 'object') {
|
||||||
|
$.extend(true, settings, item);
|
||||||
|
} else if (!value) {
|
||||||
|
delete settings[item];
|
||||||
|
} else {
|
||||||
|
settings[item] = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
$.sessionStorage.set(this.storageKey, settings, this.tabTimeout);
|
||||||
|
},
|
||||||
|
resize: function () {
|
||||||
|
var self = $.site.contentTabs,
|
||||||
|
$navContabs = $(".site-contabs"),
|
||||||
|
$navContent = $navContabs.find("ul.con-tabs");
|
||||||
|
|
||||||
|
self._throttle(function () {
|
||||||
|
self.view = $navContabs.find(".contabs-scroll").width();
|
||||||
|
self.tabEvent($navContent, 'media');
|
||||||
|
}, 200)();
|
||||||
|
},
|
||||||
|
enable: function ($el) { // 左侧菜单定位
|
||||||
|
var $instance = this.$instance,
|
||||||
|
href = $.trim($el.find('a').attr('href')),
|
||||||
|
_result = href.indexOf('#'),
|
||||||
|
tabUrl = _result > 0 ? href.substring(0, _result) : href,
|
||||||
|
$current = $instance.find('a[href="' + tabUrl + '"]'),
|
||||||
|
$currentParents, $currentLi, $currentHasSub, $instanceLi, checkedId, currentId;
|
||||||
|
|
||||||
|
if ($current.length === 0) {
|
||||||
|
$.site.menu.refresh();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
checkedId = $.trim($instance.closest('div.tab-pane.active').attr('id'));
|
||||||
|
currentId = $.trim($current.closest('div.tab-pane').attr('id'));
|
||||||
|
|
||||||
|
if (checkedId !== currentId) {
|
||||||
|
$('#admui-navbar a[href="#' + currentId + '"]').tab('show');
|
||||||
|
}
|
||||||
|
|
||||||
|
$currentLi = $current.closest('li').siblings('li.open');
|
||||||
|
$currentParents = $current.parents('li.has-sub');
|
||||||
|
$currentHasSub = $current.closest('li.has-sub').siblings('li.open');
|
||||||
|
$instanceLi = $instance.find('li.open');
|
||||||
|
|
||||||
|
$instance.find('li.active').trigger('deactive.site.menu');
|
||||||
|
$current.closest('li').trigger('active.site.menu');
|
||||||
|
|
||||||
|
if ($currentLi.length) {
|
||||||
|
$currentLi.trigger('close.site.menu');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!$current.closest('li.has-sub').hasClass('open')) {
|
||||||
|
if ($currentHasSub.length) {
|
||||||
|
$currentHasSub.trigger('close.site.menu');
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($instanceLi.length) {
|
||||||
|
$instanceLi.not($currentParents).trigger('close.site.menu');
|
||||||
|
}
|
||||||
|
|
||||||
|
$currentParents.trigger('open.site.menu');
|
||||||
|
}
|
||||||
|
},
|
||||||
|
buildTab: function (opt) { // 新建标签页
|
||||||
|
var $tabNav = $(".con-tabs"), tabName, obj = {}, tabId,
|
||||||
|
_url = opt.url,
|
||||||
|
_result = _url.indexOf('#'),
|
||||||
|
tabUrl = _result > 0 ? _url.substring(0, _result) : _url;
|
||||||
|
|
||||||
|
if (this._checkTabs($tabNav, tabUrl)) { // 标签查重
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
tabId = ++this.tabId;
|
||||||
|
tabName = 'iframe-' + tabId;
|
||||||
|
|
||||||
|
// 修改当前选中的标签页
|
||||||
|
$tabNav.find("li.active").removeClass("active");
|
||||||
|
$tabNav.append('<li class="active"><a href="' + tabUrl + '" target="' + tabName +
|
||||||
|
'" title="' + opt.name + '' + '" rel="contents"><span>' + opt.name + '</span><i class="icon' +
|
||||||
|
' wb-close-mini">' + '</i></a></li>');
|
||||||
|
|
||||||
|
obj[tabName] = {
|
||||||
|
'url': tabUrl,
|
||||||
|
'name': opt.name
|
||||||
|
};
|
||||||
|
|
||||||
|
$.extend(obj, {
|
||||||
|
'checked': tabName,
|
||||||
|
'tabId': tabId
|
||||||
|
});
|
||||||
|
|
||||||
|
this._updateSetting(obj);
|
||||||
|
|
||||||
|
// 修改页面标题
|
||||||
|
opt.name = opt.name === '' ? '无标题' : opt.name;
|
||||||
|
$('title').text($.trim(opt.name));
|
||||||
|
|
||||||
|
this.buildIframe(_url);
|
||||||
|
this.tabSize();
|
||||||
|
this.tabEvent($tabNav, 'media');
|
||||||
|
this.tabType = false;
|
||||||
|
},
|
||||||
|
_checkTabs: function (doc, url) { // 标签查重
|
||||||
|
var x, prevAll, nextAll, contentW,
|
||||||
|
_view = this.view, _tab = this.tabWidth,
|
||||||
|
$currenttab = doc.find("a[href='" + url + "']").closest('li');
|
||||||
|
|
||||||
|
if ($currenttab.hasClass('active')) { // 标签存在&已选中
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($currenttab.size() <= 0) { // 标签不存在
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 标签存在未选中
|
||||||
|
doc.find("li.active").removeClass("active");
|
||||||
|
$currenttab.addClass("active");
|
||||||
|
|
||||||
|
// 切换标签页
|
||||||
|
this._checkoutTab($currenttab.find('a'));
|
||||||
|
|
||||||
|
// 标签位移到可视界面显示
|
||||||
|
x = doc.position().left;
|
||||||
|
contentW = doc.width();
|
||||||
|
prevAll = $currenttab.prevAll('li').size() * _tab;
|
||||||
|
nextAll = $currenttab.nextAll('li').size() * _tab;
|
||||||
|
|
||||||
|
if (-prevAll < x) {
|
||||||
|
if (prevAll + x < _view) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
x = -(prevAll - _view + _tab);
|
||||||
|
} else {
|
||||||
|
if (-x < contentW - nextAll) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
x = -(contentW - nextAll - _tab);
|
||||||
|
}
|
||||||
|
|
||||||
|
doc.animate({
|
||||||
|
left: x
|
||||||
|
}, 100);
|
||||||
|
|
||||||
|
return true;
|
||||||
|
},
|
||||||
|
buildIframe: function (url) { // 创建iframe窗口
|
||||||
|
var $content = this.$content,
|
||||||
|
iframeName = 'iframe-' + this.tabId, $checkedIframe;
|
||||||
|
|
||||||
|
$content.children('.active').removeClass('active');
|
||||||
|
$content.append('<iframe src="' + url + '" frameborder="0" name="' + iframeName + '" class="page-frame animation-fade active"></iframe>');
|
||||||
|
|
||||||
|
$checkedIframe = $content.find('iframe[name="' + iframeName + '"]');
|
||||||
|
|
||||||
|
$.site.iframeEvents($checkedIframe);
|
||||||
|
},
|
||||||
|
tabSize: function () { // 修改标签页盒子尺寸
|
||||||
|
var content, $tabNav = $(".con-tabs"),
|
||||||
|
_num = $tabNav.find("li").size();
|
||||||
|
|
||||||
|
content = this.tabWidth * _num;
|
||||||
|
$tabNav.css("width", content);
|
||||||
|
},
|
||||||
|
tabEvent: function (doc, media) { // 增删标签页的对应状态
|
||||||
|
var content = $(".con-tabs").width(),
|
||||||
|
_view = this.view, _tab = this.tabWidth;
|
||||||
|
|
||||||
|
if (content > this.view) {
|
||||||
|
this.tabPosition(doc, _tab, "left", _view, content, media);
|
||||||
|
this.btnView('visible');
|
||||||
|
} else {
|
||||||
|
this.btnView('hide');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this.currentView < _view || this.currentContent > content) {
|
||||||
|
this.tabPosition(doc, _tab, "right", _view, content, media);
|
||||||
|
}
|
||||||
|
this.currentView = _view;
|
||||||
|
this.currentContent = content;
|
||||||
|
},
|
||||||
|
tabPosition: function (doc, width, dir, view, content, media) { // 标签页的位移
|
||||||
|
var self = this,
|
||||||
|
x = doc.position().left,
|
||||||
|
callback = function (x) {
|
||||||
|
var flag = x + width;
|
||||||
|
|
||||||
|
if (flag > 0) {
|
||||||
|
self.relative = x;
|
||||||
|
return 0;
|
||||||
|
} else {
|
||||||
|
return x;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
if (dir === "left") {
|
||||||
|
if (x <= view - content) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (typeof media !== 'undefined') {
|
||||||
|
x = view - content;
|
||||||
|
} else {
|
||||||
|
x = this.relative !== 0 ? x - width + this.relative : x - width;
|
||||||
|
this.relative = 0;
|
||||||
|
}
|
||||||
|
} else if (dir === "right") {
|
||||||
|
if (x === 0) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (typeof media !== 'undefined') {
|
||||||
|
x = content <= view ? 0 : view - content;
|
||||||
|
} else {
|
||||||
|
x = callback(x + width);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
doc.animate({
|
||||||
|
left: x
|
||||||
|
}, 100);
|
||||||
|
},
|
||||||
|
_throttle: function (fn, interval) { // 函数节流操作
|
||||||
|
var _fn = fn,
|
||||||
|
timer,
|
||||||
|
firstTime = true;
|
||||||
|
return function () {
|
||||||
|
var args = arguments,
|
||||||
|
self = this;
|
||||||
|
|
||||||
|
if (firstTime) {
|
||||||
|
_fn.apply(self, args);
|
||||||
|
firstTime = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (timer) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
timer = setTimeout(function () {
|
||||||
|
clearTimeout(timer);
|
||||||
|
timer = null;
|
||||||
|
_fn.apply(self, args);
|
||||||
|
}, interval || 500);
|
||||||
|
};
|
||||||
|
},
|
||||||
|
closeTab: function ($item) {
|
||||||
|
var checkedTabId = $item.children('a').attr('target'), $checked = '',
|
||||||
|
$nextLi = $item.next('li'),
|
||||||
|
$content = this.$content;
|
||||||
|
|
||||||
|
if ($item.is('.active')) { // 关闭选中标签
|
||||||
|
if ($nextLi.size() > 0) {
|
||||||
|
$checked = $nextLi;
|
||||||
|
} else {
|
||||||
|
$checked = $item.prev('li');
|
||||||
|
}
|
||||||
|
|
||||||
|
$checked.addClass("active");
|
||||||
|
|
||||||
|
this.enable($checked);
|
||||||
|
this._checkoutTab($checked.find('a'));
|
||||||
|
}
|
||||||
|
|
||||||
|
$item.remove();
|
||||||
|
$content.children('[name="' + checkedTabId + '"]').remove();
|
||||||
|
this._updateSetting(checkedTabId);
|
||||||
|
|
||||||
|
this.tabSize();
|
||||||
|
this.tabEvent($(".con-tabs"), 'media');
|
||||||
|
|
||||||
|
},
|
||||||
|
btnView: function (status) { // 标签页左右移动按钮状态
|
||||||
|
var $siteContabs = $('.site-contabs'),
|
||||||
|
$contabsLeftBtn = $siteContabs.children('button.pull-left'),
|
||||||
|
$contabsRightBtn = $siteContabs.find('.pull-right > button.btn-icon');
|
||||||
|
|
||||||
|
if (status === 'visible') {
|
||||||
|
$contabsLeftBtn.removeClass('hide');
|
||||||
|
$contabsRightBtn.removeClass('hide');
|
||||||
|
} else if (status === 'hide') {
|
||||||
|
$contabsLeftBtn.addClass('hide');
|
||||||
|
$contabsRightBtn.addClass('hide');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
})(window, document, jQuery);
|
304
public/lib/admui/js/sections/media-menu.js
Normal file
@ -0,0 +1,304 @@
|
|||||||
|
/**
|
||||||
|
* UI v1.1.0
|
||||||
|
* Copyright 2017-2018 Muyao
|
||||||
|
* Licensed under the Muyao License 1.0
|
||||||
|
*/
|
||||||
|
(function (window, document, $) {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
/***
|
||||||
|
* 左侧菜单响应式操作
|
||||||
|
*
|
||||||
|
* **/
|
||||||
|
|
||||||
|
$.site.menubar = {
|
||||||
|
opened: null,
|
||||||
|
folded: null,
|
||||||
|
top: false,
|
||||||
|
foldAlt: false,
|
||||||
|
auto: true,
|
||||||
|
init: function () {
|
||||||
|
var self = this,
|
||||||
|
$body = this.$body = $('body'),
|
||||||
|
$html = this.$html = $('html'),
|
||||||
|
$instance = this.$instance = $("#admui-navTabs");
|
||||||
|
|
||||||
|
$html.removeClass('css-menubar').addClass('js-menubar');
|
||||||
|
|
||||||
|
this.tabId = $('#admui-navbar').find('li.active > a').attr('href');
|
||||||
|
|
||||||
|
if (this.tabId === '#') {
|
||||||
|
this.tabId = $('.nav-tabs li.active').find('ul>li.active>a').attr('href');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!$instance.length) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 鼠标经过左侧菜单显示图标
|
||||||
|
if ($body.is('.site-menubar-fold-alt')) {
|
||||||
|
this.foldAlt = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 鼠标经过左侧菜单显示文字
|
||||||
|
if ($body.is('.site-menubar-keep')) {
|
||||||
|
if ($body.hasClass('site-menubar-fold')) { // 收起
|
||||||
|
this.auto = 'fold';
|
||||||
|
} else if ($body.hasClass('site-menubar-unfold')) { //展开
|
||||||
|
this.auto = 'unfold';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$instance.on('changed.site.menubar', function () {
|
||||||
|
self.update();
|
||||||
|
});
|
||||||
|
|
||||||
|
$('.nav-tabs li:not(.no-menu)').on('shown.bs.tab', function (event) {
|
||||||
|
var tabId = self.tabId = $(event.target).attr('href');
|
||||||
|
|
||||||
|
if ($body.hasClass('site-menubar-fold')) {
|
||||||
|
self.hoverscroll.enable(tabId);
|
||||||
|
} else if ($body.hasClass('site-menubar-unfold')) {
|
||||||
|
self.slimScroll.enable();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
this.change();
|
||||||
|
},
|
||||||
|
change: function () {
|
||||||
|
var breakpoint = Breakpoints.current();
|
||||||
|
|
||||||
|
if (this.auto !== true) {
|
||||||
|
switch (this.auto) {
|
||||||
|
case 'fold':
|
||||||
|
this.reset();
|
||||||
|
if (breakpoint.name === 'xs') {
|
||||||
|
this.hide();
|
||||||
|
} else {
|
||||||
|
this.fold();
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
case 'unfold':
|
||||||
|
this.reset();
|
||||||
|
if (breakpoint.name === 'xs') {
|
||||||
|
this.hide();
|
||||||
|
} else {
|
||||||
|
this.unfold();
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
this.reset();
|
||||||
|
|
||||||
|
if (breakpoint) {
|
||||||
|
switch (breakpoint.name) {
|
||||||
|
case 'lg':
|
||||||
|
this.unfold();
|
||||||
|
break;
|
||||||
|
case 'md':
|
||||||
|
case 'sm':
|
||||||
|
this.fold();
|
||||||
|
break;
|
||||||
|
case 'xs':
|
||||||
|
this.hide();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Breakpoints.on('xs', 'leave', function () {
|
||||||
|
$('#admui-navbar').responsiveHorizontalTabs({
|
||||||
|
tabParentSelector: '#admui-navTabs',
|
||||||
|
fnCallback: function (el) {
|
||||||
|
if ($('#admui-navbar').is(':visible')) {
|
||||||
|
el.removeClass('is-load');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
},
|
||||||
|
animate: function (doing, callback) {
|
||||||
|
var self = this,
|
||||||
|
$body = self.$body;
|
||||||
|
|
||||||
|
$body.addClass('site-menubar-changing');
|
||||||
|
|
||||||
|
doing.call(self);
|
||||||
|
this.$instance.trigger('changing.site.menubar');
|
||||||
|
|
||||||
|
callback.call(self);
|
||||||
|
$body.removeClass('site-menubar-changing');
|
||||||
|
|
||||||
|
self.$instance.trigger('changed.site.menubar');
|
||||||
|
},
|
||||||
|
reset: function () {
|
||||||
|
this.opened = null;
|
||||||
|
this.folded = null;
|
||||||
|
this.$body.removeClass('site-menubar-hide site-menubar-open site-menubar-fold site-menubar-unfold');
|
||||||
|
this.$html.removeClass('disable-scrolling');
|
||||||
|
},
|
||||||
|
open: function () {
|
||||||
|
if (this.opened !== true) {
|
||||||
|
this.animate(function () {
|
||||||
|
this.$body.removeClass('site-menubar-hide').addClass('site-menubar-open site-menubar-unfold');
|
||||||
|
this.opened = true;
|
||||||
|
|
||||||
|
this.$html.addClass('disable-scrolling');
|
||||||
|
|
||||||
|
}, function () {
|
||||||
|
this.slimScroll.enable();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
},
|
||||||
|
hide: function () {
|
||||||
|
this.hoverscroll.disable();
|
||||||
|
|
||||||
|
if (this.opened !== false) {
|
||||||
|
this.animate(function () {
|
||||||
|
|
||||||
|
this.$html.removeClass('disable-scrolling');
|
||||||
|
this.$body.removeClass('site-menubar-open').addClass('site-menubar-hide site-menubar-unfold');
|
||||||
|
this.opened = false;
|
||||||
|
|
||||||
|
}, function () {
|
||||||
|
this.slimScroll.enable();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
},
|
||||||
|
unfold: function () {
|
||||||
|
this.hoverscroll.disable();
|
||||||
|
|
||||||
|
if (this.folded !== false) {
|
||||||
|
this.animate(function () {
|
||||||
|
this.$body.removeClass('site-menubar-fold').addClass('site-menubar-unfold');
|
||||||
|
this.folded = false;
|
||||||
|
|
||||||
|
}, function () {
|
||||||
|
this.slimScroll.enable();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
},
|
||||||
|
fold: function () {
|
||||||
|
this.slimScroll.destroy();
|
||||||
|
|
||||||
|
if (this.folded !== true) {
|
||||||
|
this.animate(function () {
|
||||||
|
this.$body.removeClass('site-menubar-unfold').addClass('site-menubar-fold');
|
||||||
|
this.folded = true;
|
||||||
|
|
||||||
|
}, function () {
|
||||||
|
this.hoverscroll.enable(this.tabId);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
},
|
||||||
|
toggle: function () {
|
||||||
|
var breakpoint = Breakpoints.current(),
|
||||||
|
folded = this.folded,
|
||||||
|
opened = this.opened;
|
||||||
|
|
||||||
|
switch (breakpoint.name) {
|
||||||
|
case 'lg':
|
||||||
|
if (folded === null || folded === false) {
|
||||||
|
this.fold();
|
||||||
|
} else {
|
||||||
|
this.unfold();
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 'md':
|
||||||
|
case 'sm':
|
||||||
|
if (folded === null || folded === true) {
|
||||||
|
this.unfold();
|
||||||
|
} else {
|
||||||
|
this.fold();
|
||||||
|
}
|
||||||
|
|
||||||
|
$('#admui-navbar').responsiveHorizontalTabs({
|
||||||
|
tabParentSelector: '#admui-navTabs'
|
||||||
|
});
|
||||||
|
break;
|
||||||
|
case 'xs':
|
||||||
|
if (opened === null || opened === false) {
|
||||||
|
this.open();
|
||||||
|
} else {
|
||||||
|
this.hide();
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
update: function () {
|
||||||
|
this.hoverscroll.update();
|
||||||
|
},
|
||||||
|
slimScroll: {
|
||||||
|
api: null,
|
||||||
|
native: false,
|
||||||
|
init: function () {
|
||||||
|
// if (/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent)) {
|
||||||
|
// this.native = true;
|
||||||
|
// $body.addClass('site-menubar-native');
|
||||||
|
// return;
|
||||||
|
// }
|
||||||
|
|
||||||
|
if ($('body').is('.site-menubar-native')) {
|
||||||
|
this.native = true;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$.site.menubar.$instance.slimScroll($.po('slimScroll'));
|
||||||
|
},
|
||||||
|
enable: function () {
|
||||||
|
if (this.native) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
this.init();
|
||||||
|
},
|
||||||
|
destroy: function () {
|
||||||
|
$.site.menubar.$instance.slimScroll({destroy: true});
|
||||||
|
$.site.menubar.$instance.removeAttr('style');
|
||||||
|
}
|
||||||
|
},
|
||||||
|
hoverscroll: {
|
||||||
|
api: null,
|
||||||
|
init: function (tabId) {
|
||||||
|
$.site.menubar.$instance.find(tabId).children('div').attr('style', '');
|
||||||
|
|
||||||
|
this.api = $.site.menubar.$instance.find(tabId).asHoverScroll({
|
||||||
|
namespace: 'hoverscorll',
|
||||||
|
direction: 'vertical',
|
||||||
|
list: '.site-menu',
|
||||||
|
item: '> li',
|
||||||
|
exception: '.site-menu-sub',
|
||||||
|
fixed: false,
|
||||||
|
boundary: 100,
|
||||||
|
onEnter: function () {
|
||||||
|
//$(this).siblings().removeClass('hover');
|
||||||
|
//$(this).addClass('hover');
|
||||||
|
},
|
||||||
|
onLeave: function () {
|
||||||
|
//$(this).removeClass('hover');
|
||||||
|
}
|
||||||
|
}).data('asHoverScroll');
|
||||||
|
},
|
||||||
|
|
||||||
|
update: function () {
|
||||||
|
if (this.api) {
|
||||||
|
this.api.update();
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
enable: function (tabId) {
|
||||||
|
if (tabId !== this.tabId) {
|
||||||
|
this.tabId = tabId;
|
||||||
|
this.init(tabId);
|
||||||
|
} else {
|
||||||
|
this.api.enable();
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
disable: function () {
|
||||||
|
if (this.api) {
|
||||||
|
this.api.disable();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
})(window, document, jQuery);
|
191
public/lib/admui/js/sections/menu.js
Normal file
@ -0,0 +1,191 @@
|
|||||||
|
/**
|
||||||
|
* UI v1.1.0
|
||||||
|
* Copyright 2017-2018 Muyao
|
||||||
|
* Licensed under the Muyao License 1.0
|
||||||
|
*/
|
||||||
|
(function (window, document, $) {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
/***
|
||||||
|
* 左侧菜单相关事件功能(默认为折叠效果)
|
||||||
|
*
|
||||||
|
* 提供了多个可触发事件:
|
||||||
|
* deactive.site.menu : 取消菜单选中项
|
||||||
|
* active.site.menu : 设置菜单选中项
|
||||||
|
* open.site.menu : 展开子菜单
|
||||||
|
* close.site.menu : 收起子菜单
|
||||||
|
*
|
||||||
|
* 可自定义事件:
|
||||||
|
* expanded.site.menu : 子菜单展开后动作
|
||||||
|
* collapsed.site.menu : 子菜单收起后动作
|
||||||
|
* **/
|
||||||
|
|
||||||
|
$.site.menu = {
|
||||||
|
speed: 250,
|
||||||
|
accordion: true, // 手风琴效果标识
|
||||||
|
init: function () {
|
||||||
|
var $siteMenubar = this.$siteMenubar = $('#admui-navTabs .site-menu');
|
||||||
|
|
||||||
|
if (!$siteMenubar.length) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
this._bind();
|
||||||
|
},
|
||||||
|
_bind: function () {
|
||||||
|
var self = this,
|
||||||
|
$body = $('body'),
|
||||||
|
$siteMenubar = this.$siteMenubar;
|
||||||
|
|
||||||
|
$siteMenubar
|
||||||
|
.on('mouseenter.site.menu', '.site-menu-item', function () {
|
||||||
|
var $item = $(this),
|
||||||
|
folded = $body.hasClass('site-menubar-fold');
|
||||||
|
|
||||||
|
if (folded === true && $item.is('.has-sub') && $item.parent('.site-menu').length) {
|
||||||
|
self.position($item, $item.children('.site-menu-sub'));
|
||||||
|
}
|
||||||
|
|
||||||
|
$item.addClass('hover');
|
||||||
|
})
|
||||||
|
.on('mouseleave.site.menu', '.site-menu-item', function () {
|
||||||
|
var $item = $(this),
|
||||||
|
folded = $body.hasClass('site-menubar-fold');
|
||||||
|
|
||||||
|
if (folded === true && $item.is('.has-sub') && $item.parent('.site-menu').length) {
|
||||||
|
$item.children('.site-menu-sub').css("max-height", "");
|
||||||
|
}
|
||||||
|
|
||||||
|
$item.removeClass('hover');
|
||||||
|
})
|
||||||
|
.on('deactive.site.menu', '.site-menu-item.active', function () {
|
||||||
|
$(this).removeClass('active');
|
||||||
|
})
|
||||||
|
.on('active.site.menu', '.site-menu-item', function () {
|
||||||
|
$(this).addClass('active');
|
||||||
|
})
|
||||||
|
.on('open.site.menu', '.site-menu-item', function (e) {
|
||||||
|
var $item = $(this);
|
||||||
|
|
||||||
|
self._expand($item, function () {
|
||||||
|
$item.addClass('open');
|
||||||
|
});
|
||||||
|
|
||||||
|
if (self.accordion && $item.closest('li.has-sub').length <= 1) {
|
||||||
|
$item.siblings('.open').trigger('close.site.menu');
|
||||||
|
}
|
||||||
|
|
||||||
|
e.stopPropagation();
|
||||||
|
})
|
||||||
|
.on('close.site.menu', '.site-menu-item.open', function (e) {
|
||||||
|
var $item = $(this);
|
||||||
|
|
||||||
|
self._collapse($item, function () {
|
||||||
|
$item.removeClass('open');
|
||||||
|
});
|
||||||
|
|
||||||
|
e.stopPropagation();
|
||||||
|
})
|
||||||
|
.on('click.site.menu ', '.site-menu-item > a', function () {
|
||||||
|
var $item = $(this),
|
||||||
|
$parent = $item.parent();
|
||||||
|
|
||||||
|
if ($parent.is('.has-sub')) {
|
||||||
|
if ($parent.is('.open')) {
|
||||||
|
$parent.trigger('close.site.menu');
|
||||||
|
} else {
|
||||||
|
$parent.trigger('open.site.menu');
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
$item.closest('li').siblings('.open').trigger('close.site.menu');
|
||||||
|
$item.closest('li.has-sub').siblings('.open').trigger('close.site.menu');
|
||||||
|
$item.parents('div.tab-pane').siblings().find('li.open').trigger('close.site.menu');
|
||||||
|
|
||||||
|
$siteMenubar.find('li.active').trigger('deactive.site.menu');
|
||||||
|
$parent.trigger('active.site.menu');
|
||||||
|
}
|
||||||
|
})
|
||||||
|
//.on('tap.site.menu', '> .site-menu-item > a', function () { // 左侧菜单在移动设备下事件操作
|
||||||
|
/*var link = $(this).attr('href');
|
||||||
|
|
||||||
|
if (link) {
|
||||||
|
window.location = link;
|
||||||
|
}*/
|
||||||
|
// })
|
||||||
|
.on('touchend.site.menu', '> .site-menu-item > a', function () {
|
||||||
|
var $item = $(this).parent('.site-menu-item'),
|
||||||
|
folded = $body.hasClass('site-menubar-fold');
|
||||||
|
|
||||||
|
if (!folded) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($item.is('.has-sub') && $item.parent('.site-menu').length) {
|
||||||
|
$item.siblings('.hover').removeClass('hover');
|
||||||
|
|
||||||
|
if ($item.is('.hover')) {
|
||||||
|
$item.removeClass('hover');
|
||||||
|
} else {
|
||||||
|
$item.addClass('hover');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.on('scroll.site.menu', '.site-menu-sub', function (e) {
|
||||||
|
e.stopPropagation();
|
||||||
|
});
|
||||||
|
},
|
||||||
|
_collapse: function ($item, callback) { // 子菜单的收起动作
|
||||||
|
var self = this;
|
||||||
|
|
||||||
|
$item.children('.site-menu-sub').slideUp(self.speed, function () {
|
||||||
|
if (callback) {
|
||||||
|
callback();
|
||||||
|
}
|
||||||
|
|
||||||
|
// 触发该元素上绑定的'collapsed.site.menu'事件
|
||||||
|
self.$siteMenubar.trigger('collapsed.site.menu');
|
||||||
|
});
|
||||||
|
},
|
||||||
|
_expand: function ($item, callback) { // 子菜单的展开动作
|
||||||
|
var self = this;
|
||||||
|
|
||||||
|
$item.children('.site-menu-sub').slideDown(self.speed, function () {
|
||||||
|
if (callback) {
|
||||||
|
callback();
|
||||||
|
}
|
||||||
|
|
||||||
|
// 触发该元素上绑定的'expanded.site.menu'事件
|
||||||
|
self.$siteMenubar.trigger('expanded.site.menu');
|
||||||
|
});
|
||||||
|
},
|
||||||
|
refresh: function () { // 重置左侧菜单状态
|
||||||
|
var $siteMenubar = this.$siteMenubar;
|
||||||
|
|
||||||
|
$siteMenubar.find('li.open').trigger('close.site.menu');
|
||||||
|
$siteMenubar.find('li.active').trigger('deactive.site.menu');
|
||||||
|
},
|
||||||
|
position: function ($item, $dropdown) { // 窗口 | 在小屏幕设备上,左侧系统菜单的下拉列表的位置操作功能
|
||||||
|
var offsetTop = $item.position().top,
|
||||||
|
menubarHeight = $("#admui-navTabs").outerHeight(),
|
||||||
|
itemHeight = $item.find("> a").outerHeight();
|
||||||
|
|
||||||
|
$dropdown.removeClass('site-menu-sub-up').css('max-height', "");
|
||||||
|
|
||||||
|
if (offsetTop > menubarHeight / 2) {
|
||||||
|
$dropdown.addClass('site-menu-sub-up');
|
||||||
|
|
||||||
|
if ($.site.menubar.foldAlt) {
|
||||||
|
offsetTop = offsetTop - itemHeight;
|
||||||
|
}
|
||||||
|
$dropdown.css('max-height', offsetTop + itemHeight);
|
||||||
|
} else {
|
||||||
|
if ($.site.menubar.foldAlt) {
|
||||||
|
offsetTop = offsetTop + itemHeight;
|
||||||
|
}
|
||||||
|
$dropdown.removeClass('site-menu-sub-up');
|
||||||
|
$dropdown.css('max-height', menubarHeight - offsetTop);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
})(window, document, jQuery);
|
14
public/lib/bootstrap/README.md
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
#bootstrap
|
||||||
|
是目前最流行的 HTML, CSS 和 JavaScript 框架,用于开发响应式,移动端先行的 web 项目。
|
||||||
|
|
||||||
|
github地址:https://github.com/twbs/bootstrap
|
||||||
|
中文文档:http://www.bootcss.com/
|
||||||
|
|
||||||
|
本地版本: 3.3.7
|
||||||
|
更新日期:
|
||||||
|
|
||||||
|
介绍:
|
||||||
|
Bootstrap,来自 Twitter,是目前最受欢迎的前端框架。Bootstrap 是基于 HTML、CSS、JAVASCRIPT 的,它简洁灵活,使得 Web 开发更加快捷。
|
||||||
|
|
||||||
|
|
||||||
|
基于bootstrop的插件放在当前目录下面
|
@ -0,0 +1,327 @@
|
|||||||
|
.checkbox {
|
||||||
|
padding-left: 20px;
|
||||||
|
}
|
||||||
|
.checkbox label {
|
||||||
|
display: inline-block;
|
||||||
|
vertical-align: middle;
|
||||||
|
position: relative;
|
||||||
|
padding-left: 5px;
|
||||||
|
}
|
||||||
|
.checkbox label::before {
|
||||||
|
content: "";
|
||||||
|
display: inline-block;
|
||||||
|
position: absolute;
|
||||||
|
width: 17px;
|
||||||
|
height: 17px;
|
||||||
|
left: 0;
|
||||||
|
margin-left: -20px;
|
||||||
|
border: 1px solid #cccccc;
|
||||||
|
border-radius: 3px;
|
||||||
|
background-color: #fff;
|
||||||
|
-webkit-transition: border 0.15s ease-in-out, color 0.15s ease-in-out;
|
||||||
|
-o-transition: border 0.15s ease-in-out, color 0.15s ease-in-out;
|
||||||
|
transition: border 0.15s ease-in-out, color 0.15s ease-in-out;
|
||||||
|
}
|
||||||
|
.checkbox label::after {
|
||||||
|
display: inline-block;
|
||||||
|
position: absolute;
|
||||||
|
width: 16px;
|
||||||
|
height: 16px;
|
||||||
|
left: 0;
|
||||||
|
top: 0;
|
||||||
|
margin-left: -20px;
|
||||||
|
padding-left: 3px;
|
||||||
|
padding-top: 1px;
|
||||||
|
font-size: 11px;
|
||||||
|
color: #555555;
|
||||||
|
line-height: 1.4;
|
||||||
|
}
|
||||||
|
.checkbox input[type="checkbox"],
|
||||||
|
.checkbox input[type="radio"] {
|
||||||
|
opacity: 0;
|
||||||
|
z-index: 1;
|
||||||
|
cursor: pointer;
|
||||||
|
}
|
||||||
|
.checkbox input[type="checkbox"]:focus + label::before,
|
||||||
|
.checkbox input[type="radio"]:focus + label::before {
|
||||||
|
outline: thin dotted;
|
||||||
|
outline: 5px auto -webkit-focus-ring-color;
|
||||||
|
outline-offset: -2px;
|
||||||
|
}
|
||||||
|
.checkbox input[type="checkbox"]:checked + label::after,
|
||||||
|
.checkbox input[type="radio"]:checked + label::after {
|
||||||
|
font-family: "FontAwesome";
|
||||||
|
content: "\f00c";
|
||||||
|
}
|
||||||
|
.checkbox input[type="checkbox"]:indeterminate + label::after,
|
||||||
|
.checkbox input[type="radio"]:indeterminate + label::after {
|
||||||
|
display: block;
|
||||||
|
content: "";
|
||||||
|
width: 10px;
|
||||||
|
height: 3px;
|
||||||
|
background-color: #555555;
|
||||||
|
border-radius: 2px;
|
||||||
|
margin-left: -16.5px;
|
||||||
|
margin-top: 7px;
|
||||||
|
}
|
||||||
|
.checkbox input[type="checkbox"]:disabled,
|
||||||
|
.checkbox input[type="radio"]:disabled {
|
||||||
|
cursor: not-allowed;
|
||||||
|
}
|
||||||
|
.checkbox input[type="checkbox"]:disabled + label,
|
||||||
|
.checkbox input[type="radio"]:disabled + label {
|
||||||
|
opacity: 0.65;
|
||||||
|
}
|
||||||
|
.checkbox input[type="checkbox"]:disabled + label::before,
|
||||||
|
.checkbox input[type="radio"]:disabled + label::before {
|
||||||
|
background-color: #eeeeee;
|
||||||
|
cursor: not-allowed;
|
||||||
|
}
|
||||||
|
.checkbox.checkbox-circle label::before {
|
||||||
|
border-radius: 50%;
|
||||||
|
}
|
||||||
|
.checkbox.checkbox-inline {
|
||||||
|
margin-top: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.checkbox-primary input[type="checkbox"]:checked + label::before,
|
||||||
|
.checkbox-primary input[type="radio"]:checked + label::before {
|
||||||
|
background-color: #337ab7;
|
||||||
|
border-color: #337ab7;
|
||||||
|
}
|
||||||
|
.checkbox-primary input[type="checkbox"]:checked + label::after,
|
||||||
|
.checkbox-primary input[type="radio"]:checked + label::after {
|
||||||
|
color: #fff;
|
||||||
|
}
|
||||||
|
|
||||||
|
.checkbox-danger input[type="checkbox"]:checked + label::before,
|
||||||
|
.checkbox-danger input[type="radio"]:checked + label::before {
|
||||||
|
background-color: #d9534f;
|
||||||
|
border-color: #d9534f;
|
||||||
|
}
|
||||||
|
.checkbox-danger input[type="checkbox"]:checked + label::after,
|
||||||
|
.checkbox-danger input[type="radio"]:checked + label::after {
|
||||||
|
color: #fff;
|
||||||
|
}
|
||||||
|
|
||||||
|
.checkbox-info input[type="checkbox"]:checked + label::before,
|
||||||
|
.checkbox-info input[type="radio"]:checked + label::before {
|
||||||
|
background-color: #5bc0de;
|
||||||
|
border-color: #5bc0de;
|
||||||
|
}
|
||||||
|
.checkbox-info input[type="checkbox"]:checked + label::after,
|
||||||
|
.checkbox-info input[type="radio"]:checked + label::after {
|
||||||
|
color: #fff;
|
||||||
|
}
|
||||||
|
|
||||||
|
.checkbox-warning input[type="checkbox"]:checked + label::before,
|
||||||
|
.checkbox-warning input[type="radio"]:checked + label::before {
|
||||||
|
background-color: #f0ad4e;
|
||||||
|
border-color: #f0ad4e;
|
||||||
|
}
|
||||||
|
.checkbox-warning input[type="checkbox"]:checked + label::after,
|
||||||
|
.checkbox-warning input[type="radio"]:checked + label::after {
|
||||||
|
color: #fff;
|
||||||
|
}
|
||||||
|
|
||||||
|
.checkbox-success input[type="checkbox"]:checked + label::before,
|
||||||
|
.checkbox-success input[type="radio"]:checked + label::before {
|
||||||
|
background-color: #5cb85c;
|
||||||
|
border-color: #5cb85c;
|
||||||
|
}
|
||||||
|
.checkbox-success input[type="checkbox"]:checked + label::after,
|
||||||
|
.checkbox-success input[type="radio"]:checked + label::after {
|
||||||
|
color: #fff;
|
||||||
|
}
|
||||||
|
|
||||||
|
.checkbox-primary input[type="checkbox"]:indeterminate + label::before,
|
||||||
|
.checkbox-primary input[type="radio"]:indeterminate + label::before {
|
||||||
|
background-color: #337ab7;
|
||||||
|
border-color: #337ab7;
|
||||||
|
}
|
||||||
|
|
||||||
|
.checkbox-primary input[type="checkbox"]:indeterminate + label::after,
|
||||||
|
.checkbox-primary input[type="radio"]:indeterminate + label::after {
|
||||||
|
background-color: #fff;
|
||||||
|
}
|
||||||
|
|
||||||
|
.checkbox-danger input[type="checkbox"]:indeterminate + label::before,
|
||||||
|
.checkbox-danger input[type="radio"]:indeterminate + label::before {
|
||||||
|
background-color: #d9534f;
|
||||||
|
border-color: #d9534f;
|
||||||
|
}
|
||||||
|
|
||||||
|
.checkbox-danger input[type="checkbox"]:indeterminate + label::after,
|
||||||
|
.checkbox-danger input[type="radio"]:indeterminate + label::after {
|
||||||
|
background-color: #fff;
|
||||||
|
}
|
||||||
|
|
||||||
|
.checkbox-info input[type="checkbox"]:indeterminate + label::before,
|
||||||
|
.checkbox-info input[type="radio"]:indeterminate + label::before {
|
||||||
|
background-color: #5bc0de;
|
||||||
|
border-color: #5bc0de;
|
||||||
|
}
|
||||||
|
|
||||||
|
.checkbox-info input[type="checkbox"]:indeterminate + label::after,
|
||||||
|
.checkbox-info input[type="radio"]:indeterminate + label::after {
|
||||||
|
background-color: #fff;
|
||||||
|
}
|
||||||
|
|
||||||
|
.checkbox-warning input[type="checkbox"]:indeterminate + label::before,
|
||||||
|
.checkbox-warning input[type="radio"]:indeterminate + label::before {
|
||||||
|
background-color: #f0ad4e;
|
||||||
|
border-color: #f0ad4e;
|
||||||
|
}
|
||||||
|
|
||||||
|
.checkbox-warning input[type="checkbox"]:indeterminate + label::after,
|
||||||
|
.checkbox-warning input[type="radio"]:indeterminate + label::after {
|
||||||
|
background-color: #fff;
|
||||||
|
}
|
||||||
|
|
||||||
|
.checkbox-success input[type="checkbox"]:indeterminate + label::before,
|
||||||
|
.checkbox-success input[type="radio"]:indeterminate + label::before {
|
||||||
|
background-color: #5cb85c;
|
||||||
|
border-color: #5cb85c;
|
||||||
|
}
|
||||||
|
|
||||||
|
.checkbox-success input[type="checkbox"]:indeterminate + label::after,
|
||||||
|
.checkbox-success input[type="radio"]:indeterminate + label::after {
|
||||||
|
background-color: #fff;
|
||||||
|
}
|
||||||
|
|
||||||
|
.radio {
|
||||||
|
padding-left: 20px;
|
||||||
|
}
|
||||||
|
.radio label {
|
||||||
|
display: inline-block;
|
||||||
|
vertical-align: middle;
|
||||||
|
position: relative;
|
||||||
|
padding-left: 5px;
|
||||||
|
}
|
||||||
|
.radio label::before {
|
||||||
|
content: "";
|
||||||
|
display: inline-block;
|
||||||
|
position: absolute;
|
||||||
|
width: 17px;
|
||||||
|
height: 17px;
|
||||||
|
left: 0;
|
||||||
|
margin-left: -20px;
|
||||||
|
border: 1px solid #cccccc;
|
||||||
|
border-radius: 50%;
|
||||||
|
background-color: #fff;
|
||||||
|
-webkit-transition: border 0.15s ease-in-out;
|
||||||
|
-o-transition: border 0.15s ease-in-out;
|
||||||
|
transition: border 0.15s ease-in-out;
|
||||||
|
}
|
||||||
|
.radio label::after {
|
||||||
|
display: inline-block;
|
||||||
|
position: absolute;
|
||||||
|
content: " ";
|
||||||
|
width: 11px;
|
||||||
|
height: 11px;
|
||||||
|
left: 3px;
|
||||||
|
top: 3px;
|
||||||
|
margin-left: -20px;
|
||||||
|
border-radius: 50%;
|
||||||
|
background-color: #555555;
|
||||||
|
-webkit-transform: scale(0, 0);
|
||||||
|
-ms-transform: scale(0, 0);
|
||||||
|
-o-transform: scale(0, 0);
|
||||||
|
transform: scale(0, 0);
|
||||||
|
-webkit-transition: -webkit-transform 0.1s cubic-bezier(0.8, -0.33, 0.2, 1.33);
|
||||||
|
-moz-transition: -moz-transform 0.1s cubic-bezier(0.8, -0.33, 0.2, 1.33);
|
||||||
|
-o-transition: -o-transform 0.1s cubic-bezier(0.8, -0.33, 0.2, 1.33);
|
||||||
|
transition: transform 0.1s cubic-bezier(0.8, -0.33, 0.2, 1.33);
|
||||||
|
}
|
||||||
|
.radio input[type="radio"] {
|
||||||
|
opacity: 0;
|
||||||
|
z-index: 1;
|
||||||
|
cursor: pointer;
|
||||||
|
}
|
||||||
|
.radio input[type="radio"]:focus + label::before {
|
||||||
|
outline: thin dotted;
|
||||||
|
outline: 5px auto -webkit-focus-ring-color;
|
||||||
|
outline-offset: -2px;
|
||||||
|
}
|
||||||
|
.radio input[type="radio"]:checked + label::after {
|
||||||
|
-webkit-transform: scale(1, 1);
|
||||||
|
-ms-transform: scale(1, 1);
|
||||||
|
-o-transform: scale(1, 1);
|
||||||
|
transform: scale(1, 1);
|
||||||
|
}
|
||||||
|
.radio input[type="radio"]:disabled {
|
||||||
|
cursor: not-allowed;
|
||||||
|
}
|
||||||
|
.radio input[type="radio"]:disabled + label {
|
||||||
|
opacity: 0.65;
|
||||||
|
}
|
||||||
|
.radio input[type="radio"]:disabled + label::before {
|
||||||
|
cursor: not-allowed;
|
||||||
|
}
|
||||||
|
.radio.radio-inline {
|
||||||
|
margin-top: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.radio-primary input[type="radio"] + label::after {
|
||||||
|
background-color: #337ab7;
|
||||||
|
}
|
||||||
|
.radio-primary input[type="radio"]:checked + label::before {
|
||||||
|
border-color: #337ab7;
|
||||||
|
}
|
||||||
|
.radio-primary input[type="radio"]:checked + label::after {
|
||||||
|
background-color: #337ab7;
|
||||||
|
}
|
||||||
|
|
||||||
|
.radio-danger input[type="radio"] + label::after {
|
||||||
|
background-color: #d9534f;
|
||||||
|
}
|
||||||
|
.radio-danger input[type="radio"]:checked + label::before {
|
||||||
|
border-color: #d9534f;
|
||||||
|
}
|
||||||
|
.radio-danger input[type="radio"]:checked + label::after {
|
||||||
|
background-color: #d9534f;
|
||||||
|
}
|
||||||
|
|
||||||
|
.radio-info input[type="radio"] + label::after {
|
||||||
|
background-color: #5bc0de;
|
||||||
|
}
|
||||||
|
.radio-info input[type="radio"]:checked + label::before {
|
||||||
|
border-color: #5bc0de;
|
||||||
|
}
|
||||||
|
.radio-info input[type="radio"]:checked + label::after {
|
||||||
|
background-color: #5bc0de;
|
||||||
|
}
|
||||||
|
|
||||||
|
.radio-warning input[type="radio"] + label::after {
|
||||||
|
background-color: #f0ad4e;
|
||||||
|
}
|
||||||
|
.radio-warning input[type="radio"]:checked + label::before {
|
||||||
|
border-color: #f0ad4e;
|
||||||
|
}
|
||||||
|
.radio-warning input[type="radio"]:checked + label::after {
|
||||||
|
background-color: #f0ad4e;
|
||||||
|
}
|
||||||
|
|
||||||
|
.radio-success input[type="radio"] + label::after {
|
||||||
|
background-color: #5cb85c;
|
||||||
|
}
|
||||||
|
.radio-success input[type="radio"]:checked + label::before {
|
||||||
|
border-color: #5cb85c;
|
||||||
|
}
|
||||||
|
.radio-success input[type="radio"]:checked + label::after {
|
||||||
|
background-color: #5cb85c;
|
||||||
|
}
|
||||||
|
|
||||||
|
input[type="checkbox"].styled:checked + label:after,
|
||||||
|
input[type="radio"].styled:checked + label:after {
|
||||||
|
font-family: 'FontAwesome';
|
||||||
|
content: "\f00c";
|
||||||
|
}
|
||||||
|
input[type="checkbox"] .styled:checked + label::before,
|
||||||
|
input[type="radio"] .styled:checked + label::before {
|
||||||
|
color: #fff;
|
||||||
|
}
|
||||||
|
input[type="checkbox"] .styled:checked + label::after,
|
||||||
|
input[type="radio"] .styled:checked + label::after {
|
||||||
|
color: #fff;
|
||||||
|
}
|
263
public/lib/bootstrap/bootstrap-checkbox/demo/index.html
Normal file
@ -0,0 +1,263 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html>
|
||||||
|
<head lang="en">
|
||||||
|
<meta charset="UTF-8">
|
||||||
|
<title>awesome bootstrap checkbox demo</title>
|
||||||
|
|
||||||
|
<link href="../../bootstrap.css" rel="stylesheet" />
|
||||||
|
<link href="../../../fonts/font-awesome/css/font-awesome.min.css" rel="stylesheet" />
|
||||||
|
<link href="../awesome-bootstrap-checkbox.css" rel="stylesheet" />
|
||||||
|
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<div class="container">
|
||||||
|
<h2>Checkboxes</h2>
|
||||||
|
<form role="form">
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-md-4">
|
||||||
|
<fieldset>
|
||||||
|
<legend>
|
||||||
|
Basic
|
||||||
|
</legend>
|
||||||
|
<p>
|
||||||
|
Supports bootstrap brand colors: <code>.checkbox-primary</code>, <code>.checkbox-info</code> etc.
|
||||||
|
</p>
|
||||||
|
<div class="checkbox">
|
||||||
|
<input id="checkbox1" class="styled" type="checkbox">
|
||||||
|
<label for="checkbox1">
|
||||||
|
Default
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
<div class="checkbox checkbox-primary">
|
||||||
|
<input id="checkbox2" class="styled" type="checkbox" checked>
|
||||||
|
<label for="checkbox2">
|
||||||
|
Primary
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
<div class="checkbox checkbox-success">
|
||||||
|
<input id="checkbox3" class="styled" type="checkbox">
|
||||||
|
<label for="checkbox3">
|
||||||
|
Success
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
<div class="checkbox checkbox-info">
|
||||||
|
<input id="checkbox4" class="styled" type="checkbox">
|
||||||
|
<label for="checkbox4">
|
||||||
|
Info
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
<div class="checkbox checkbox-warning">
|
||||||
|
<input id="checkbox5" type="checkbox" class="styled" checked>
|
||||||
|
<label for="checkbox5">
|
||||||
|
Warning
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
<div class="checkbox checkbox-danger">
|
||||||
|
<input id="checkbox6" type="checkbox" class="styled" checked>
|
||||||
|
<label for="checkbox6">
|
||||||
|
Check me out
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
<p>Checkboxes without label text</p>
|
||||||
|
<div class="checkbox">
|
||||||
|
<input type="checkbox" class="styled" id="singleCheckbox1" value="option1" aria-label="Single checkbox One">
|
||||||
|
<label></label>
|
||||||
|
</div>
|
||||||
|
<div class="checkbox checkbox-primary">
|
||||||
|
<input type="checkbox" class="styled styled-primary" id="singleCheckbox2" value="option2" checked aria-label="Single checkbox Two">
|
||||||
|
<label></label>
|
||||||
|
</div>
|
||||||
|
<p>Checkboxes with indeterminate state</p>
|
||||||
|
<div class="checkbox checkbox-primary">
|
||||||
|
<input id="indeterminateCheckbox" class="styled" type="checkbox" onclick="changeState(this)">
|
||||||
|
<label></label>
|
||||||
|
</div>
|
||||||
|
<p>Inline checkboxes</p>
|
||||||
|
<div class="checkbox checkbox-inline">
|
||||||
|
<input type="checkbox" class="styled" id="inlineCheckbox1" value="option1">
|
||||||
|
<label for="inlineCheckbox1"> Inline One </label>
|
||||||
|
</div>
|
||||||
|
<div class="checkbox checkbox-success checkbox-inline">
|
||||||
|
<input type="checkbox" class="styled" id="inlineCheckbox2" value="option1" checked>
|
||||||
|
<label for="inlineCheckbox2"> Inline Two </label>
|
||||||
|
</div>
|
||||||
|
<div class="checkbox checkbox-inline">
|
||||||
|
<input type="checkbox" class="styled" id="inlineCheckbox3" value="option1">
|
||||||
|
<label for="inlineCheckbox3"> Inline Three </label>
|
||||||
|
</div>
|
||||||
|
</fieldset>
|
||||||
|
</div>
|
||||||
|
<div class="col-md-4">
|
||||||
|
<fieldset>
|
||||||
|
<legend>
|
||||||
|
Circled
|
||||||
|
</legend>
|
||||||
|
<p>
|
||||||
|
<code>.checkbox-circle</code> for roundness.
|
||||||
|
</p>
|
||||||
|
<div class="checkbox checkbox-circle">
|
||||||
|
<input id="checkbox7" class="styled" type="checkbox">
|
||||||
|
<label for="checkbox7">
|
||||||
|
Simply Rounded
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
<div class="checkbox checkbox-info checkbox-circle">
|
||||||
|
<input id="checkbox8" class="styled" type="checkbox" checked>
|
||||||
|
<label for="checkbox8">
|
||||||
|
Me too
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</fieldset>
|
||||||
|
</div>
|
||||||
|
<div class="col-md-4">
|
||||||
|
<fieldset>
|
||||||
|
<legend>
|
||||||
|
Disabled
|
||||||
|
</legend>
|
||||||
|
<p>
|
||||||
|
Disabled state also supported.
|
||||||
|
</p>
|
||||||
|
<div class="checkbox">
|
||||||
|
<input class="styled" id="checkbox9" type="checkbox" disabled>
|
||||||
|
<label for="checkbox9">
|
||||||
|
Can't check this
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
<div class="checkbox checkbox-success">
|
||||||
|
<input class="styled styled" id="checkbox10" type="checkbox" disabled checked>
|
||||||
|
<label for="checkbox10">
|
||||||
|
This too
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
<div class="checkbox checkbox-warning checkbox-circle">
|
||||||
|
<input class="styled" id="checkbox11" type="checkbox" disabled checked>
|
||||||
|
<label for="checkbox11">
|
||||||
|
And this
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</fieldset>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
<h2>Radios</h2>
|
||||||
|
<form role="form">
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-md-4">
|
||||||
|
<fieldset>
|
||||||
|
<legend>
|
||||||
|
Basic
|
||||||
|
</legend>
|
||||||
|
<p>
|
||||||
|
Supports bootstrap brand colors: <code>.radio-primary</code>, <code>.radio-danger</code> etc.
|
||||||
|
</p>
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-sm-6">
|
||||||
|
<div class="radio">
|
||||||
|
<input type="radio" name="radio1" id="radio1" value="option1" checked>
|
||||||
|
<label for="radio1">
|
||||||
|
Small
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
<div class="radio">
|
||||||
|
<input type="radio" name="radio1" id="radio2" value="option2">
|
||||||
|
<label for="radio2">
|
||||||
|
Big
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="col-sm-6">
|
||||||
|
<div class="radio radio-danger">
|
||||||
|
<input type="radio" name="radio2" id="radio3" value="option1">
|
||||||
|
<label for="radio3">
|
||||||
|
Next
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
<div class="radio radio-danger">
|
||||||
|
<input type="radio" name="radio2" id="radio4" value="option2" checked>
|
||||||
|
<label for="radio4">
|
||||||
|
One
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<p>Radios without label text</p>
|
||||||
|
<div class="radio">
|
||||||
|
<input type="radio" id="singleRadio1" value="option1" name="radioSingle1" aria-label="Single radio One">
|
||||||
|
<label></label>
|
||||||
|
</div>
|
||||||
|
<div class="radio radio-success">
|
||||||
|
<input type="radio" id="singleRadio2" value="option2" name="radioSingle1" checked aria-label="Single radio Two">
|
||||||
|
<label></label>
|
||||||
|
</div>
|
||||||
|
<p>Inline radios</p>
|
||||||
|
<div class="radio radio-info radio-inline">
|
||||||
|
<input type="radio" id="inlineRadio1" value="option1" name="radioInline" checked>
|
||||||
|
<label for="inlineRadio1"> Inline One </label>
|
||||||
|
</div>
|
||||||
|
<div class="radio radio-inline">
|
||||||
|
<input type="radio" id="inlineRadio2" value="option2" name="radioInline">
|
||||||
|
<label for="inlineRadio2"> Inline Two </label>
|
||||||
|
</div>
|
||||||
|
</fieldset>
|
||||||
|
</div>
|
||||||
|
<div class="col-md-4">
|
||||||
|
<fieldset>
|
||||||
|
<legend>
|
||||||
|
Disabled
|
||||||
|
</legend>
|
||||||
|
<p>
|
||||||
|
Disabled state also supported.
|
||||||
|
</p>
|
||||||
|
<div class="radio radio-danger">
|
||||||
|
<input type="radio" name="radio3" id="radio5" value="option1" disabled>
|
||||||
|
<label for="radio5">
|
||||||
|
Next
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
<div class="radio">
|
||||||
|
<input type="radio" name="radio3" id="radio6" value="option2" checked disabled>
|
||||||
|
<label for="radio6">
|
||||||
|
One
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</fieldset>
|
||||||
|
</div>
|
||||||
|
<div class="col-md-4">
|
||||||
|
<fieldset>
|
||||||
|
<legend>
|
||||||
|
As Checkboxes
|
||||||
|
</legend>
|
||||||
|
<p>
|
||||||
|
Radios can be made to look like checkboxes.
|
||||||
|
</p>
|
||||||
|
<div class="checkbox checkbox">
|
||||||
|
<input type="radio" name="radio4" id="radio7" value="option1" checked>
|
||||||
|
<label for="radio7">
|
||||||
|
Default
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
<div class="checkbox checkbox-success">
|
||||||
|
<input type="radio" name="radio4" id="radio8" value="option2">
|
||||||
|
<label for="radio8">
|
||||||
|
Success
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
<div class="checkbox checkbox-danger">
|
||||||
|
<input type="radio" name="radio4" id="radio9" value="option3">
|
||||||
|
<label for="radio9">
|
||||||
|
Danger
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</fieldset>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
<script type="text/javascript">
|
||||||
|
function changeState(el) {
|
||||||
|
if (el.readOnly) el.checked=el.readOnly=false;
|
||||||
|
else if (!el.checked) el.readOnly=el.indeterminate=true;
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
</body>
|
||||||
|
</html>
|
300
public/lib/bootstrap/bootstrap-select/bootstrap-select.css
vendored
Normal file
@ -0,0 +1,300 @@
|
|||||||
|
/**
|
||||||
|
* Admui-iframe v1.0.0
|
||||||
|
* Copyright 2015-2017 Admui Team
|
||||||
|
* Licensed under the Muyao License 1.0
|
||||||
|
*/
|
||||||
|
.btn-select {
|
||||||
|
height: 32px;
|
||||||
|
padding: 4px 12px;
|
||||||
|
font-size: 14px;
|
||||||
|
line-height: 1.6;
|
||||||
|
color: #76838f;
|
||||||
|
background-color: #fff;
|
||||||
|
background-image: none;
|
||||||
|
border: 1px solid #e4eaec;
|
||||||
|
border-radius: 3px;
|
||||||
|
}
|
||||||
|
.btn-group.open .btn-select, .btn-select:focus {
|
||||||
|
border-color: #62a8ea !important;
|
||||||
|
-webkit-box-shadow: none;
|
||||||
|
box-shadow: none;
|
||||||
|
}
|
||||||
|
select.bs-select-hidden, select.selectpicker {
|
||||||
|
display: none !important;
|
||||||
|
}
|
||||||
|
.bootstrap-select {
|
||||||
|
z-index:19910501;
|
||||||
|
width: 220px;
|
||||||
|
}
|
||||||
|
.bootstrap-select > .dropdown-toggle {
|
||||||
|
z-index: 1;
|
||||||
|
width: 100%;
|
||||||
|
padding-right: 25px;
|
||||||
|
}
|
||||||
|
.bootstrap-select > .dropdown-toggle.bs-placeholder, .bootstrap-select > .dropdown-toggle.bs-placeholder:hover, .bootstrap-select > .dropdown-toggle.bs-placeholder:focus, .bootstrap-select > .dropdown-toggle.bs-placeholder:active {
|
||||||
|
color: #a3afb7;
|
||||||
|
}
|
||||||
|
.bootstrap-select > select {
|
||||||
|
position: absolute;
|
||||||
|
bottom: 0;
|
||||||
|
left: 50%;
|
||||||
|
display: block !important;
|
||||||
|
width: .5px !important;
|
||||||
|
height: 100% !important;
|
||||||
|
padding: 0 !important;
|
||||||
|
border: none;
|
||||||
|
opacity: 0 !important;
|
||||||
|
}
|
||||||
|
.bootstrap-select > select.mobile-device {
|
||||||
|
position: absolute !important;
|
||||||
|
top: 0;
|
||||||
|
left: 0;
|
||||||
|
z-index: 2;
|
||||||
|
display: block !important;
|
||||||
|
width: 100%;
|
||||||
|
height: 100% !important;
|
||||||
|
opacity: 0;
|
||||||
|
}
|
||||||
|
.bootstrap-select .icon {
|
||||||
|
width: 1em;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
.has-error .bootstrap-select .dropdown-toggle, .error .bootstrap-select .dropdown-toggle {
|
||||||
|
border-color: #f85974 !important;
|
||||||
|
}
|
||||||
|
.has-success .bootstrap-select .dropdown-toggle {
|
||||||
|
border-color: #3dae6a;
|
||||||
|
}
|
||||||
|
.bootstrap-select.fit-width {
|
||||||
|
width: auto !important;
|
||||||
|
}
|
||||||
|
.bootstrap-select:not([class*="col-"]):not([class*="form-control"]):not(.input-group-btn) {
|
||||||
|
width: 220px;
|
||||||
|
}
|
||||||
|
.bootstrap-select.form-control {
|
||||||
|
padding: 0;
|
||||||
|
margin-bottom: 0;
|
||||||
|
border: none;
|
||||||
|
}
|
||||||
|
.bootstrap-select.form-control:not([class*="col-"]) {
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
.bootstrap-select.form-control.input-group-btn {
|
||||||
|
z-index: auto;
|
||||||
|
}
|
||||||
|
.bootstrap-select.btn-group:not(.input-group-btn), .bootstrap-select.btn-group[class*="col-"] {
|
||||||
|
display: inline-block;
|
||||||
|
float: none;
|
||||||
|
margin-left: 0;
|
||||||
|
}
|
||||||
|
.bootstrap-select.btn-group.dropdown-menu-right, .bootstrap-select.btn-group[class*="col-"].dropdown-menu-right, .row .bootstrap-select.btn-group[class*="col-"].dropdown-menu-right {
|
||||||
|
float: right;
|
||||||
|
}
|
||||||
|
.form-inline .bootstrap-select.btn-group, .form-horizontal .bootstrap-select.btn-group, .form-group .bootstrap-select.btn-group {
|
||||||
|
margin-bottom: 0;
|
||||||
|
}
|
||||||
|
.form-group-lg .bootstrap-select.btn-group.form-control, .form-group-sm .bootstrap-select.btn-group.form-control {
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
.form-inline .bootstrap-select.btn-group .form-control {
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
.bootstrap-select.btn-group.disabled, .bootstrap-select.btn-group > .disabled {
|
||||||
|
cursor: not-allowed;
|
||||||
|
}
|
||||||
|
.bootstrap-select.btn-group.disabled:focus, .bootstrap-select.btn-group > .disabled:focus {
|
||||||
|
outline: none !important;
|
||||||
|
}
|
||||||
|
.bootstrap-select.btn-group.bs-container {
|
||||||
|
position: absolute;
|
||||||
|
}
|
||||||
|
.bootstrap-select.btn-group.bs-container .dropdown-menu {
|
||||||
|
z-index: 1450;
|
||||||
|
}
|
||||||
|
.bootstrap-select.btn-group .dropdown-toggle .filter-option {
|
||||||
|
display: inline-block;
|
||||||
|
width: 100%;
|
||||||
|
overflow: hidden;
|
||||||
|
text-align: left;
|
||||||
|
}
|
||||||
|
.bootstrap-select.btn-group .dropdown-toggle .filter-option > .icon {
|
||||||
|
margin-right: .3em;
|
||||||
|
}
|
||||||
|
.bootstrap-select.btn-group .dropdown-toggle .caret {
|
||||||
|
position: absolute;
|
||||||
|
top: 50%;
|
||||||
|
right: 12px;
|
||||||
|
margin-top: -2px;
|
||||||
|
vertical-align: middle;
|
||||||
|
}
|
||||||
|
.bootstrap-select.btn-group[class*="col-"] .dropdown-toggle {
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
.bootstrap-select.btn-group .dropdown-menu {
|
||||||
|
min-width: 100%;
|
||||||
|
-webkit-box-sizing: border-box;
|
||||||
|
-moz-box-sizing: border-box;
|
||||||
|
box-sizing: border-box;
|
||||||
|
}
|
||||||
|
.bootstrap-select.btn-group .dropdown-menu.inner {
|
||||||
|
position: static;
|
||||||
|
float: none;
|
||||||
|
padding: 0;
|
||||||
|
margin: 0;
|
||||||
|
border: 0;
|
||||||
|
border-radius: 0;
|
||||||
|
-webkit-box-shadow: none;
|
||||||
|
box-shadow: none;
|
||||||
|
}
|
||||||
|
.bootstrap-select.btn-group .dropdown-menu li {
|
||||||
|
position: relative;
|
||||||
|
}
|
||||||
|
.bootstrap-select.btn-group .dropdown-menu li.active small {
|
||||||
|
color: #fff;
|
||||||
|
}
|
||||||
|
.bootstrap-select.btn-group .dropdown-menu li.disabled a {
|
||||||
|
cursor: not-allowed;
|
||||||
|
}
|
||||||
|
.bootstrap-select.btn-group .dropdown-menu li a {
|
||||||
|
cursor: pointer;
|
||||||
|
-webkit-user-select: none;
|
||||||
|
-moz-user-select: none;
|
||||||
|
-ms-user-select: none;
|
||||||
|
user-select: none;
|
||||||
|
}
|
||||||
|
.bootstrap-select.btn-group .dropdown-menu li a > .icon {
|
||||||
|
margin-right: .3em;
|
||||||
|
}
|
||||||
|
.bootstrap-select.btn-group .dropdown-menu li a.opt {
|
||||||
|
position: relative;
|
||||||
|
padding-left: 2.25em;
|
||||||
|
}
|
||||||
|
.bootstrap-select.btn-group .dropdown-menu li a span.check-mark {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
.bootstrap-select.btn-group .dropdown-menu li a span.text {
|
||||||
|
display: inline-block;
|
||||||
|
}
|
||||||
|
.bootstrap-select.btn-group .dropdown-menu li small {
|
||||||
|
padding-left: .5em;
|
||||||
|
}
|
||||||
|
.bootstrap-select.btn-group .dropdown-menu .notify {
|
||||||
|
position: absolute;
|
||||||
|
bottom: 6px;
|
||||||
|
width: 94%;
|
||||||
|
min-height: 26px;
|
||||||
|
-webkit-box-sizing: border-box;
|
||||||
|
-moz-box-sizing: border-box;
|
||||||
|
box-sizing: border-box;
|
||||||
|
padding: 3px 5px;
|
||||||
|
margin: 0 3%;
|
||||||
|
color: #76838f;
|
||||||
|
pointer-events: none;
|
||||||
|
background-color: #f3f7f9;
|
||||||
|
border: 1px solid #e4eaec;
|
||||||
|
border-radius: 3px;
|
||||||
|
-webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, .05);
|
||||||
|
box-shadow: inset 0 1px 1px rgba(0, 0, 0, .05);
|
||||||
|
opacity: .9;
|
||||||
|
}
|
||||||
|
.bootstrap-select.btn-group .no-results {
|
||||||
|
padding: 5px 10px;
|
||||||
|
margin: 0 8px 3px;
|
||||||
|
color: #76838f;
|
||||||
|
white-space: nowrap;
|
||||||
|
background-color: #f3f7f9;
|
||||||
|
border-radius: 3px;
|
||||||
|
}
|
||||||
|
.bootstrap-select.btn-group.fit-width .dropdown-toggle .filter-option {
|
||||||
|
position: static;
|
||||||
|
}
|
||||||
|
.bootstrap-select.btn-group.fit-width .dropdown-toggle .caret {
|
||||||
|
position: static;
|
||||||
|
top: auto;
|
||||||
|
margin-top: -1px;
|
||||||
|
}
|
||||||
|
.bootstrap-select.btn-group.show-tick .dropdown-menu li.selected a span.check-mark {
|
||||||
|
position: absolute;
|
||||||
|
right: 15px;
|
||||||
|
display: inline-block;
|
||||||
|
margin-top: 5px;
|
||||||
|
}
|
||||||
|
.bootstrap-select.btn-group.show-tick .dropdown-menu li a span.text {
|
||||||
|
margin-right: 34px;
|
||||||
|
}
|
||||||
|
.bootstrap-select.show-menu-arrow.open > .dropdown-toggle {
|
||||||
|
z-index: 1451;
|
||||||
|
}
|
||||||
|
.bootstrap-select.show-menu-arrow .dropdown-toggle:before {
|
||||||
|
position: absolute;
|
||||||
|
bottom: -9px;
|
||||||
|
left: 9px;
|
||||||
|
display: none;
|
||||||
|
content: "";
|
||||||
|
border-right: 8px solid transparent;
|
||||||
|
border-bottom: 8px solid #e4eaec;
|
||||||
|
border-left: 8px solid transparent;
|
||||||
|
}
|
||||||
|
.bootstrap-select.show-menu-arrow .dropdown-toggle:after {
|
||||||
|
position: absolute;
|
||||||
|
bottom: -9px;
|
||||||
|
left: 10px;
|
||||||
|
display: none;
|
||||||
|
content: "";
|
||||||
|
border-right: 7px solid transparent;
|
||||||
|
border-bottom: 7px solid white;
|
||||||
|
border-left: 7px solid transparent;
|
||||||
|
}
|
||||||
|
.bootstrap-select.show-menu-arrow.dropup .dropdown-toggle:before {
|
||||||
|
top: -8px;
|
||||||
|
bottom: auto;
|
||||||
|
border-top: 8px solid #e4eaec;
|
||||||
|
border-bottom: 0;
|
||||||
|
}
|
||||||
|
.bootstrap-select.show-menu-arrow.dropup .dropdown-toggle:after {
|
||||||
|
top: -8px;
|
||||||
|
bottom: auto;
|
||||||
|
border-top: 7px solid white;
|
||||||
|
border-bottom: 0;
|
||||||
|
}
|
||||||
|
.bootstrap-select.show-menu-arrow.pull-right .dropdown-toggle:before {
|
||||||
|
right: 12px;
|
||||||
|
left: auto;
|
||||||
|
}
|
||||||
|
.bootstrap-select.show-menu-arrow.pull-right .dropdown-toggle:after {
|
||||||
|
right: 13px;
|
||||||
|
left: auto;
|
||||||
|
}
|
||||||
|
.bootstrap-select.show-menu-arrow.open > .dropdown-toggle:before, .bootstrap-select.show-menu-arrow.open > .dropdown-toggle:after {
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
.bs-searchbox, .bs-actionsbox, .bs-donebutton {
|
||||||
|
padding: 4px 8px;
|
||||||
|
}
|
||||||
|
.bs-actionsbox {
|
||||||
|
width: 100%;
|
||||||
|
-webkit-box-sizing: border-box;
|
||||||
|
-moz-box-sizing: border-box;
|
||||||
|
box-sizing: border-box;
|
||||||
|
}
|
||||||
|
.bs-actionsbox .btn-group button {
|
||||||
|
width: 50%;
|
||||||
|
}
|
||||||
|
.bs-donebutton {
|
||||||
|
float: left;
|
||||||
|
width: 100%;
|
||||||
|
-webkit-box-sizing: border-box;
|
||||||
|
-moz-box-sizing: border-box;
|
||||||
|
box-sizing: border-box;
|
||||||
|
}
|
||||||
|
.bs-donebutton .btn-group button {
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
.bs-searchbox + .bs-actionsbox {
|
||||||
|
padding: 0 8px 4px;
|
||||||
|
}
|
||||||
|
.bs-searchbox input.form-control {
|
||||||
|
float: none;
|
||||||
|
width: 100%;
|
||||||
|
margin-bottom: 0;
|
||||||
|
}
|
1829
public/lib/bootstrap/bootstrap-select/bootstrap-select.js
vendored
Normal file
9
public/lib/bootstrap/bootstrap-select/bootstrap-select.min.js
vendored
Normal file
4
public/lib/bootstrap/bootstrap-table/README.md
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
#bootstrap-table
|
||||||
|
|
||||||
|
API文档:https://bootstrap-table.com/docs/api/table-options/
|
||||||
|
|
319
public/lib/bootstrap/bootstrap-table/bootstrap-table.css
vendored
Normal file
@ -0,0 +1,319 @@
|
|||||||
|
/**
|
||||||
|
* @author zhixin wen <wenzhixin2010@gmail.com>
|
||||||
|
* version: 1.12.1
|
||||||
|
* https://github.com/wenzhixin/bootstrap-table/
|
||||||
|
*/
|
||||||
|
|
||||||
|
.bootstrap-table .table {
|
||||||
|
margin-bottom: 0 !important;
|
||||||
|
border-bottom: 1px solid #dddddd;
|
||||||
|
border-collapse: collapse !important;
|
||||||
|
border-radius: 1px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.bootstrap-table .table:not(.table-condensed),
|
||||||
|
.bootstrap-table .table:not(.table-condensed) > tbody > tr > th,
|
||||||
|
.bootstrap-table .table:not(.table-condensed) > tfoot > tr > th,
|
||||||
|
.bootstrap-table .table:not(.table-condensed) > thead > tr > td,
|
||||||
|
.bootstrap-table .table:not(.table-condensed) > tbody > tr > td,
|
||||||
|
.bootstrap-table .table:not(.table-condensed) > tfoot > tr > td {
|
||||||
|
padding: 8px;
|
||||||
|
word-break: break-word;
|
||||||
|
}
|
||||||
|
|
||||||
|
.bootstrap-table .table.table-no-bordered > thead > tr > th,
|
||||||
|
.bootstrap-table .table.table-no-bordered > tbody > tr > td {
|
||||||
|
border-right: 2px solid transparent;
|
||||||
|
}
|
||||||
|
|
||||||
|
.bootstrap-table .table.table-no-bordered > tbody > tr > td:last-child {
|
||||||
|
border-right: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-container {
|
||||||
|
position: relative;
|
||||||
|
clear: both;
|
||||||
|
border: 1px solid #dddddd;
|
||||||
|
border-radius: 4px;
|
||||||
|
-webkit-border-radius: 4px;
|
||||||
|
-moz-border-radius: 4px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-container.table-no-bordered {
|
||||||
|
border: 1px solid transparent;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-footer,
|
||||||
|
.fixed-table-header {
|
||||||
|
overflow: hidden;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-footer {
|
||||||
|
border-top: 1px solid #dddddd;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-body {
|
||||||
|
overflow-x: auto;
|
||||||
|
overflow-y: auto;
|
||||||
|
height: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-container table {
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-container thead th {
|
||||||
|
height: 0;
|
||||||
|
padding: 0;
|
||||||
|
margin: 0;
|
||||||
|
border-left: 1px solid #dddddd;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-container thead th:focus {
|
||||||
|
outline: 0 solid transparent;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-container thead th:first-child:not([data-not-first-th]) {
|
||||||
|
border-left: none;
|
||||||
|
border-top-left-radius: 4px;
|
||||||
|
-webkit-border-top-left-radius: 4px;
|
||||||
|
-moz-border-radius-topleft: 4px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-container thead th .th-inner,
|
||||||
|
.fixed-table-container tbody td .th-inner {
|
||||||
|
padding: 8px;
|
||||||
|
line-height: 24px;
|
||||||
|
vertical-align: top;
|
||||||
|
overflow: hidden;
|
||||||
|
text-overflow: ellipsis;
|
||||||
|
white-space: nowrap;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-container thead th .sortable {
|
||||||
|
cursor: pointer;
|
||||||
|
background-position: right;
|
||||||
|
background-repeat: no-repeat;
|
||||||
|
padding-right: 30px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-container thead th .both {
|
||||||
|
background-image: url(' QMQ5AQBCF4dWQSJxC5wwax1Cq1e7BAdxD5SL+Tq/QCM1oNiJidwox0355mXnG/DrEtIQ6azioNZQxI0ykPhTQIwhCR+BmBYtlK7kLJYwWCcJA9M4qdrZrd8pPjZWPtOqdRQy320YSV17OatFC4euts6z39GYMKRPCTKY9UnPQ6P+GtMRfGtPnBCiqhAeJPmkqAAAAAElFTkSuQmCC');
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-container thead th .asc {
|
||||||
|
background-image: url('');
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-container thead th .desc {
|
||||||
|
background-image: url(' ');
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-container th.detail {
|
||||||
|
width: 30px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-container tbody td {
|
||||||
|
border-left: 1px solid #dddddd;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-container tbody tr:first-child td {
|
||||||
|
border-top: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-container tbody td:first-child {
|
||||||
|
border-left: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* the same color with .active */
|
||||||
|
.fixed-table-container tbody .selected td {
|
||||||
|
background-color: #f5f5f5;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-container .bs-checkbox {
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-container input[type="radio"],
|
||||||
|
.fixed-table-container input[type="checkbox"] {
|
||||||
|
margin: 0 auto !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-container .no-records-found {
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-pagination div.pagination,
|
||||||
|
.fixed-table-pagination .pagination-detail {
|
||||||
|
margin-top: 3px;
|
||||||
|
margin-bottom: 3px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-pagination div.pagination .pagination {
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-pagination .pagination a {
|
||||||
|
padding: 6px 12px;
|
||||||
|
line-height: 1.428571429;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-pagination .pagination-info {
|
||||||
|
/*line-height: 34px;*/
|
||||||
|
margin-right: 5px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-pagination .btn-group {
|
||||||
|
position: relative;
|
||||||
|
display: inline-block;
|
||||||
|
vertical-align: middle;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-pagination .dropup .dropdown-menu {
|
||||||
|
margin-bottom: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-pagination .page-list {
|
||||||
|
display: inline-block;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-toolbar .columns-left {
|
||||||
|
margin-right: 5px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-toolbar .columns-right {
|
||||||
|
margin-left: 5px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-toolbar .columns label {
|
||||||
|
display: block;
|
||||||
|
padding: 3px 20px;
|
||||||
|
clear: both;
|
||||||
|
font-weight: normal;
|
||||||
|
line-height: 1.428571429;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-toolbar .bs-bars,
|
||||||
|
.fixed-table-toolbar .search,
|
||||||
|
.fixed-table-toolbar .columns {
|
||||||
|
position: relative;
|
||||||
|
margin-top: 3px;
|
||||||
|
margin-bottom: 3px;
|
||||||
|
line-height: 34px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-pagination li.disabled a {
|
||||||
|
pointer-events: none;
|
||||||
|
cursor: default;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-loading {
|
||||||
|
display: none;
|
||||||
|
position: absolute;
|
||||||
|
top: 42px;
|
||||||
|
right: 0;
|
||||||
|
bottom: 0;
|
||||||
|
left: 0;
|
||||||
|
z-index: 99;
|
||||||
|
background-color: rgba(63, 72, 84, 1);
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-body .card-view .title {
|
||||||
|
font-weight: bold;
|
||||||
|
display: inline-block;
|
||||||
|
min-width: 30%;
|
||||||
|
text-align: left !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* support bootstrap 2 */
|
||||||
|
.fixed-table-body thead th .th-inner {
|
||||||
|
box-sizing: border-box;
|
||||||
|
}
|
||||||
|
|
||||||
|
.table th, .table td {
|
||||||
|
vertical-align: middle;
|
||||||
|
box-sizing: border-box;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-toolbar .dropdown-menu {
|
||||||
|
text-align: left;
|
||||||
|
max-height: 300px;
|
||||||
|
overflow: auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-toolbar .btn-group > .btn-group {
|
||||||
|
display: inline-block;
|
||||||
|
margin-left: -1px !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-toolbar .btn-group > .btn-group > .btn {
|
||||||
|
border-radius: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-toolbar .btn-group > .btn-group:first-child > .btn {
|
||||||
|
border-top-left-radius: 4px;
|
||||||
|
border-bottom-left-radius: 4px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fixed-table-toolbar .btn-group > .btn-group:last-child > .btn {
|
||||||
|
border-top-right-radius: 4px;
|
||||||
|
border-bottom-right-radius: 4px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.bootstrap-table .table > thead > tr > th {
|
||||||
|
vertical-align: bottom;
|
||||||
|
border-bottom: 1px solid #ddd;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* support bootstrap 3 */
|
||||||
|
.bootstrap-table .table thead > tr > th {
|
||||||
|
padding: 0;
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.bootstrap-table .fixed-table-footer tbody > tr > td {
|
||||||
|
padding: 0 !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.bootstrap-table .fixed-table-footer .table {
|
||||||
|
border-bottom: none;
|
||||||
|
border-radius: 0;
|
||||||
|
padding: 0 !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.bootstrap-table .pull-right .dropdown-menu {
|
||||||
|
right: 0;
|
||||||
|
left: auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* calculate scrollbar width */
|
||||||
|
p.fixed-table-scroll-inner {
|
||||||
|
width: 100%;
|
||||||
|
height: 200px;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.fixed-table-scroll-outer {
|
||||||
|
top: 0;
|
||||||
|
left: 0;
|
||||||
|
visibility: hidden;
|
||||||
|
width: 200px;
|
||||||
|
height: 150px;
|
||||||
|
overflow: hidden;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* for get correct heights */
|
||||||
|
.fixed-table-toolbar:after, .fixed-table-pagination:after {
|
||||||
|
content: "";
|
||||||
|
display: block;
|
||||||
|
clear: both;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fullscreen {
|
||||||
|
position: fixed;
|
||||||
|
top: 0;
|
||||||
|
left: 0;
|
||||||
|
z-index: 1050;
|
||||||
|
width: 100%!important;
|
||||||
|
background: #FFF;
|
||||||
|
}
|
3295
public/lib/bootstrap/bootstrap-table/bootstrap-table.js
vendored
Normal file
9
public/lib/bootstrap/bootstrap-table/bootstrap-table.min.js
vendored
Normal file
179
public/lib/bootstrap/bootstrap-table/extensions/export/bootstrap-table-export.js
vendored
Normal file
@ -0,0 +1,179 @@
|
|||||||
|
/**
|
||||||
|
* @author zhixin wen <wenzhixin2010@gmail.com>
|
||||||
|
* extensions: https://github.com/kayalshri/tableExport.jquery.plugin
|
||||||
|
*/
|
||||||
|
|
||||||
|
(function ($) {
|
||||||
|
'use strict';
|
||||||
|
var sprintf = $.fn.bootstrapTable.utils.sprintf;
|
||||||
|
|
||||||
|
var TYPE_NAME = {
|
||||||
|
json: 'JSON',
|
||||||
|
xml: 'XML',
|
||||||
|
png: 'PNG',
|
||||||
|
csv: 'CSV',
|
||||||
|
txt: 'TXT',
|
||||||
|
sql: 'SQL',
|
||||||
|
doc: 'Word文档',
|
||||||
|
excel: 'Excel文档',
|
||||||
|
xlsx: 'MS-Excel (OpenXML)',
|
||||||
|
powerpoint: 'MS-Powerpoint',
|
||||||
|
pdf: 'PDF'
|
||||||
|
};
|
||||||
|
|
||||||
|
$.extend($.fn.bootstrapTable.defaults, {
|
||||||
|
showExport: false,
|
||||||
|
exportDataType: 'basic', // basic, all, selected
|
||||||
|
// 'json', 'xml', 'png', 'csv', 'txt', 'sql', 'doc', 'excel', 'powerpoint', 'pdf'
|
||||||
|
exportTypes: ['json', 'xml', 'csv', 'txt', 'sql', 'excel'],
|
||||||
|
exportOptions: {}
|
||||||
|
});
|
||||||
|
|
||||||
|
$.extend($.fn.bootstrapTable.defaults.icons, {
|
||||||
|
export: ' fa-download icon-share'
|
||||||
|
});
|
||||||
|
|
||||||
|
$.extend($.fn.bootstrapTable.locales, {
|
||||||
|
formatExport: function () {
|
||||||
|
return '导出数据';
|
||||||
|
}
|
||||||
|
});
|
||||||
|
$.extend($.fn.bootstrapTable.defaults, $.fn.bootstrapTable.locales);
|
||||||
|
|
||||||
|
var BootstrapTable = $.fn.bootstrapTable.Constructor,
|
||||||
|
_initToolbar = BootstrapTable.prototype.initToolbar;
|
||||||
|
|
||||||
|
BootstrapTable.prototype.initToolbar = function () {
|
||||||
|
this.showToolbar = this.showToolbar || this.options.showExport;
|
||||||
|
|
||||||
|
_initToolbar.apply(this, Array.prototype.slice.apply(arguments));
|
||||||
|
|
||||||
|
if (this.options.showExport) {
|
||||||
|
var that = this,
|
||||||
|
$btnGroup = this.$toolbar.find('>.btn-group'),
|
||||||
|
$export = $btnGroup.find('div.export');
|
||||||
|
|
||||||
|
if (!$export.length) {
|
||||||
|
$export = $([
|
||||||
|
'<div class="export btn-group">',
|
||||||
|
'<button class="btn' +
|
||||||
|
sprintf(' btn-%s', this.options.buttonsClass) +
|
||||||
|
sprintf(' btn-%s', this.options.iconSize) +
|
||||||
|
' dropdown-toggle" aria-label="export type" ' +
|
||||||
|
'title="' + this.options.formatExport() + '" ' +
|
||||||
|
'data-toggle="dropdown" type="button">',
|
||||||
|
sprintf('<i class="%s %s"></i> 导出', this.options.iconsPrefix, this.options.icons.export),
|
||||||
|
'<span class="caret"></span>',
|
||||||
|
'</button>',
|
||||||
|
'<ul class="dropdown-menu" role="menu">',
|
||||||
|
'</ul>',
|
||||||
|
'</div>'].join('')).appendTo($btnGroup);
|
||||||
|
|
||||||
|
var $menu = $export.find('.dropdown-menu'),
|
||||||
|
exportTypes = this.options.exportTypes;
|
||||||
|
|
||||||
|
if (typeof this.options.exportTypes === 'string') {
|
||||||
|
var types = this.options.exportTypes.slice(1, -1).replace(/ /g, '').split(',');
|
||||||
|
|
||||||
|
exportTypes = [];
|
||||||
|
$.each(types, function (i, value) {
|
||||||
|
exportTypes.push(value.slice(1, -1));
|
||||||
|
});
|
||||||
|
}
|
||||||
|
$.each(exportTypes, function (i, type) {
|
||||||
|
if (TYPE_NAME.hasOwnProperty(type)) {
|
||||||
|
$menu.append(['<li role="menuitem" data-type="' + type + '">',
|
||||||
|
'<a href="javascript:void(0)">',
|
||||||
|
TYPE_NAME[type],
|
||||||
|
'</a>',
|
||||||
|
'</li>'].join(''));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
$menu.find('li').click(function () {
|
||||||
|
var type = $(this).data('type'),
|
||||||
|
doExport = function () {
|
||||||
|
|
||||||
|
if (!!that.options.exportFooter) {
|
||||||
|
var data = that.getData();
|
||||||
|
var $footerRow = that.$tableFooter.find("tr").first();
|
||||||
|
|
||||||
|
var footerData = { };
|
||||||
|
var footerHtml = [];
|
||||||
|
|
||||||
|
$.each($footerRow.children(), function (index, footerCell) {
|
||||||
|
|
||||||
|
var footerCellHtml = $(footerCell).children(".th-inner").first().html();
|
||||||
|
footerData[that.columns[index].field] = footerCellHtml == ' ' ? null : footerCellHtml;
|
||||||
|
|
||||||
|
// grab footer cell text into cell index-based array
|
||||||
|
footerHtml.push(footerCellHtml);
|
||||||
|
});
|
||||||
|
|
||||||
|
that.append(footerData);
|
||||||
|
|
||||||
|
var $lastTableRow = that.$body.children().last();
|
||||||
|
|
||||||
|
$.each($lastTableRow.children(), function (index, lastTableRowCell) {
|
||||||
|
|
||||||
|
$(lastTableRowCell).html(footerHtml[index]);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
that.$el.tableExport($.extend({}, that.options.exportOptions, {
|
||||||
|
type: type,
|
||||||
|
escape: false
|
||||||
|
}));
|
||||||
|
|
||||||
|
if (!!that.options.exportFooter) {
|
||||||
|
that.load(data);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var stateField = that.header.stateField;
|
||||||
|
|
||||||
|
if (that.options.exportDataType === 'all' && that.options.pagination) {
|
||||||
|
that.$el.one(that.options.sidePagination === 'server' ? 'post-body.bs.table' : 'page-change.bs.table', function () {
|
||||||
|
if (stateField) {
|
||||||
|
that.hideColumn(stateField);
|
||||||
|
}
|
||||||
|
doExport();
|
||||||
|
that.togglePagination();
|
||||||
|
});
|
||||||
|
that.togglePagination();
|
||||||
|
} else if (that.options.exportDataType === 'selected') {
|
||||||
|
var data = that.getData(),
|
||||||
|
selectedData = that.getSelections();
|
||||||
|
if (!selectedData.length) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (that.options.sidePagination === 'server') {
|
||||||
|
var dataServer = {total: that.options.totalRows};
|
||||||
|
dataServer[that.options.dataField] = data;
|
||||||
|
data = dataServer;
|
||||||
|
var selectedDataServer = {total: selectedData.length};
|
||||||
|
selectedDataServer[that.options.dataField] = selectedData;
|
||||||
|
selectedData = selectedDataServer;
|
||||||
|
}
|
||||||
|
|
||||||
|
that.load(selectedData);
|
||||||
|
if (stateField) {
|
||||||
|
that.hideColumn(stateField);
|
||||||
|
}
|
||||||
|
doExport();
|
||||||
|
that.load(data);
|
||||||
|
} else {
|
||||||
|
if (stateField) {
|
||||||
|
that.hideColumn(stateField);
|
||||||
|
}
|
||||||
|
doExport();
|
||||||
|
}
|
||||||
|
if (stateField) {
|
||||||
|
that.showColumn(stateField);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
})(jQuery);
|