diff --git a/Digitalgovernment/city b/Digitalgovernment/city
deleted file mode 160000
index 33cf97d..0000000
--- a/Digitalgovernment/city
+++ /dev/null
@@ -1 +0,0 @@
-Subproject commit 33cf97dd0f7f25518e85bf63caf19b8e3d45d4e7
diff --git a/Digitalgovernment/totalData_h5 b/Digitalgovernment/totalData_h5
deleted file mode 160000
index 5a4c0d8..0000000
--- a/Digitalgovernment/totalData_h5
+++ /dev/null
@@ -1 +0,0 @@
-Subproject commit 5a4c0d86aa13699b285ff30ccf5bde1a29e8baf0
diff --git a/Digitalgovernment/town/h5 b/Digitalgovernment/town/h5
deleted file mode 160000
index 33cf97d..0000000
--- a/Digitalgovernment/town/h5
+++ /dev/null
@@ -1 +0,0 @@
-Subproject commit 33cf97dd0f7f25518e85bf63caf19b8e3d45d4e7
diff --git a/h5 b/h5
deleted file mode 160000
index cc92348..0000000
--- a/h5
+++ /dev/null
@@ -1 +0,0 @@
-Subproject commit cc92348d529336d4987018d9c45811bc047999ed
diff --git a/portal/Digitalgovernment/city/5063.png b/portal/Digitalgovernment/city/5063.png
new file mode 100644
index 0000000..039eb68
Binary files /dev/null and b/portal/Digitalgovernment/city/5063.png differ
diff --git a/portal/Digitalgovernment/city/5167.png b/portal/Digitalgovernment/city/5167.png
new file mode 100644
index 0000000..a698df7
Binary files /dev/null and b/portal/Digitalgovernment/city/5167.png differ
diff --git a/portal/Digitalgovernment/city/README.en.md b/portal/Digitalgovernment/city/README.en.md
new file mode 100644
index 0000000..2331bf7
--- /dev/null
+++ b/portal/Digitalgovernment/city/README.en.md
@@ -0,0 +1,36 @@
+# 住建局数字化改革门户页面
+
+#### Description
+住建局数字化改革页面,echart,js,布局,定位,适配,轮播图,按钮显示切换,
+
+#### Software Architecture
+Software architecture description
+
+#### Installation
+
+1. xxxx
+2. xxxx
+3. xxxx
+
+#### Instructions
+
+1. xxxx
+2. xxxx
+3. xxxx
+
+#### Contribution
+
+1. Fork the repository
+2. Create Feat_xxx branch
+3. Commit your code
+4. Create Pull Request
+
+
+#### Gitee Feature
+
+1. You can use Readme\_XXX.md to support different languages, such as Readme\_en.md, Readme\_zh.md
+2. Gitee blog [blog.gitee.com](https://blog.gitee.com)
+3. Explore open source project [https://gitee.com/explore](https://gitee.com/explore)
+4. The most valuable open source project [GVP](https://gitee.com/gvp)
+5. The manual of Gitee [https://gitee.com/help](https://gitee.com/help)
+6. The most popular members [https://gitee.com/gitee-stars/](https://gitee.com/gitee-stars/)
diff --git a/portal/Digitalgovernment/city/README.md b/portal/Digitalgovernment/city/README.md
new file mode 100644
index 0000000..d6bca6f
--- /dev/null
+++ b/portal/Digitalgovernment/city/README.md
@@ -0,0 +1,37 @@
+# 住建局数字化改革门户页面
+
+#### 介绍
+住建局数字化改革页面,echart,js,布局,定位,适配,轮播图,按钮显示切换,
+
+#### 软件架构
+软件架构说明
+
+
+#### 安装教程
+
+1. xxxx
+2. xxxx
+3. xxxx
+
+#### 使用说明
+
+1. xxxx
+2. xxxx
+3. xxxx
+
+#### 参与贡献
+
+1. Fork 本仓库
+2. 新建 Feat_xxx 分支
+3. 提交代码
+4. 新建 Pull Request
+
+
+#### 特技
+
+1. 使用 Readme\_XXX.md 来支持不同的语言,例如 Readme\_en.md, Readme\_zh.md
+2. Gitee 官方博客 [blog.gitee.com](https://blog.gitee.com)
+3. 你可以 [https://gitee.com/explore](https://gitee.com/explore) 这个地址来了解 Gitee 上的优秀开源项目
+4. [GVP](https://gitee.com/gvp) 全称是 Gitee 最有价值开源项目,是综合评定出的优秀开源项目
+5. Gitee 官方提供的使用手册 [https://gitee.com/help](https://gitee.com/help)
+6. Gitee 封面人物是一档用来展示 Gitee 会员风采的栏目 [https://gitee.com/gitee-stars/](https://gitee.com/gitee-stars/)
diff --git a/portal/Digitalgovernment/city/home.html b/portal/Digitalgovernment/city/home.html
new file mode 100644
index 0000000..e98707f
--- /dev/null
+++ b/portal/Digitalgovernment/city/home.html
@@ -0,0 +1,207 @@
+
+
+
+
+
+
+
+ 城市建设
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
绿道建设累计完成公里
+
今年新建绿道指标完成率(%)
+
58
+
+
+
+
+
+
新建绿道 完成:km 目标: km
+
+
+
+
+
+
+
+
+
+ 中心城区建成面积
+ 万㎡
+
+
+ 县(市)建成面积
+ 万㎡
+
+
+
+
+
+
+
+
+
+
+
+
2021年老旧小区改造个数(计划) 0 个
+
+ 2021年老旧小区改造面积(计划
+ 0 万平方米
+
+
2021年老旧小区改造户数(计划) 0户
+
+
+
+
+
+
+
+
+
+
+
+
+ 目标1526套
+ 完成1628套
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/portal/Digitalgovernment/city/image/1.svg b/portal/Digitalgovernment/city/image/1.svg
new file mode 100644
index 0000000..682c4f2
--- /dev/null
+++ b/portal/Digitalgovernment/city/image/1.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/portal/Digitalgovernment/city/image/11.png b/portal/Digitalgovernment/city/image/11.png
new file mode 100644
index 0000000..bbfc814
Binary files /dev/null and b/portal/Digitalgovernment/city/image/11.png differ
diff --git a/portal/Digitalgovernment/city/image/11.svg b/portal/Digitalgovernment/city/image/11.svg
new file mode 100644
index 0000000..56c6290
--- /dev/null
+++ b/portal/Digitalgovernment/city/image/11.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/portal/Digitalgovernment/city/image/2.svg b/portal/Digitalgovernment/city/image/2.svg
new file mode 100644
index 0000000..d8adcdd
--- /dev/null
+++ b/portal/Digitalgovernment/city/image/2.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/portal/Digitalgovernment/city/image/22.png b/portal/Digitalgovernment/city/image/22.png
new file mode 100644
index 0000000..cebc1c4
Binary files /dev/null and b/portal/Digitalgovernment/city/image/22.png differ
diff --git a/portal/Digitalgovernment/city/image/22.svg b/portal/Digitalgovernment/city/image/22.svg
new file mode 100644
index 0000000..4c1ab0d
--- /dev/null
+++ b/portal/Digitalgovernment/city/image/22.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/portal/Digitalgovernment/city/image/3.svg b/portal/Digitalgovernment/city/image/3.svg
new file mode 100644
index 0000000..ce36659
--- /dev/null
+++ b/portal/Digitalgovernment/city/image/3.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/portal/Digitalgovernment/city/image/33.png b/portal/Digitalgovernment/city/image/33.png
new file mode 100644
index 0000000..f99cb62
Binary files /dev/null and b/portal/Digitalgovernment/city/image/33.png differ
diff --git a/portal/Digitalgovernment/city/image/33.svg b/portal/Digitalgovernment/city/image/33.svg
new file mode 100644
index 0000000..a8b38fe
--- /dev/null
+++ b/portal/Digitalgovernment/city/image/33.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/portal/Digitalgovernment/city/image/4.svg b/portal/Digitalgovernment/city/image/4.svg
new file mode 100644
index 0000000..a963c33
--- /dev/null
+++ b/portal/Digitalgovernment/city/image/4.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/portal/Digitalgovernment/city/image/44.png b/portal/Digitalgovernment/city/image/44.png
new file mode 100644
index 0000000..0b51299
Binary files /dev/null and b/portal/Digitalgovernment/city/image/44.png differ
diff --git a/portal/Digitalgovernment/city/image/44.svg b/portal/Digitalgovernment/city/image/44.svg
new file mode 100644
index 0000000..12fcfa9
--- /dev/null
+++ b/portal/Digitalgovernment/city/image/44.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/portal/Digitalgovernment/city/image/5.svg b/portal/Digitalgovernment/city/image/5.svg
new file mode 100644
index 0000000..b2420a3
--- /dev/null
+++ b/portal/Digitalgovernment/city/image/5.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/portal/Digitalgovernment/city/image/6.svg b/portal/Digitalgovernment/city/image/6.svg
new file mode 100644
index 0000000..b32898e
--- /dev/null
+++ b/portal/Digitalgovernment/city/image/6.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/portal/Digitalgovernment/city/image/7.svg b/portal/Digitalgovernment/city/image/7.svg
new file mode 100644
index 0000000..39fb50e
--- /dev/null
+++ b/portal/Digitalgovernment/city/image/7.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/portal/Digitalgovernment/city/image/8.svg b/portal/Digitalgovernment/city/image/8.svg
new file mode 100644
index 0000000..df4b966
--- /dev/null
+++ b/portal/Digitalgovernment/city/image/8.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/portal/Digitalgovernment/city/image/a.png b/portal/Digitalgovernment/city/image/a.png
new file mode 100644
index 0000000..0e898f2
Binary files /dev/null and b/portal/Digitalgovernment/city/image/a.png differ
diff --git a/portal/Digitalgovernment/city/image/b.png b/portal/Digitalgovernment/city/image/b.png
new file mode 100644
index 0000000..7057d03
Binary files /dev/null and b/portal/Digitalgovernment/city/image/b.png differ
diff --git a/portal/Digitalgovernment/city/image/banner.png b/portal/Digitalgovernment/city/image/banner.png
new file mode 100644
index 0000000..9aed9ae
Binary files /dev/null and b/portal/Digitalgovernment/city/image/banner.png differ
diff --git a/portal/Digitalgovernment/city/image/c.png b/portal/Digitalgovernment/city/image/c.png
new file mode 100644
index 0000000..aef566b
Binary files /dev/null and b/portal/Digitalgovernment/city/image/c.png differ
diff --git a/portal/Digitalgovernment/city/image/changjing.png b/portal/Digitalgovernment/city/image/changjing.png
new file mode 100644
index 0000000..ad71041
Binary files /dev/null and b/portal/Digitalgovernment/city/image/changjing.png differ
diff --git a/portal/Digitalgovernment/city/image/chengguo.png b/portal/Digitalgovernment/city/image/chengguo.png
new file mode 100644
index 0000000..16d2b32
Binary files /dev/null and b/portal/Digitalgovernment/city/image/chengguo.png differ
diff --git a/portal/Digitalgovernment/city/image/cz.svg b/portal/Digitalgovernment/city/image/cz.svg
new file mode 100644
index 0000000..f30a77a
--- /dev/null
+++ b/portal/Digitalgovernment/city/image/cz.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/portal/Digitalgovernment/city/image/cz1.svg b/portal/Digitalgovernment/city/image/cz1.svg
new file mode 100644
index 0000000..724ef6f
--- /dev/null
+++ b/portal/Digitalgovernment/city/image/cz1.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/portal/Digitalgovernment/city/image/d.png b/portal/Digitalgovernment/city/image/d.png
new file mode 100644
index 0000000..76ac2ba
Binary files /dev/null and b/portal/Digitalgovernment/city/image/d.png differ
diff --git a/portal/Digitalgovernment/city/image/danwei.png b/portal/Digitalgovernment/city/image/danwei.png
new file mode 100644
index 0000000..369cdb9
Binary files /dev/null and b/portal/Digitalgovernment/city/image/danwei.png differ
diff --git a/portal/Digitalgovernment/city/image/gognzuo.png b/portal/Digitalgovernment/city/image/gognzuo.png
new file mode 100644
index 0000000..1500f4c
Binary files /dev/null and b/portal/Digitalgovernment/city/image/gognzuo.png differ
diff --git a/portal/Digitalgovernment/city/image/hexin.png b/portal/Digitalgovernment/city/image/hexin.png
new file mode 100644
index 0000000..b898090
Binary files /dev/null and b/portal/Digitalgovernment/city/image/hexin.png differ
diff --git a/portal/Digitalgovernment/city/image/hy.svg b/portal/Digitalgovernment/city/image/hy.svg
new file mode 100644
index 0000000..ae15d96
--- /dev/null
+++ b/portal/Digitalgovernment/city/image/hy.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/portal/Digitalgovernment/city/image/hy1.svg b/portal/Digitalgovernment/city/image/hy1.svg
new file mode 100644
index 0000000..41f402f
--- /dev/null
+++ b/portal/Digitalgovernment/city/image/hy1.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/portal/Digitalgovernment/city/image/jigou0.png b/portal/Digitalgovernment/city/image/jigou0.png
new file mode 100644
index 0000000..7a0bd33
Binary files /dev/null and b/portal/Digitalgovernment/city/image/jigou0.png differ
diff --git a/portal/Digitalgovernment/city/image/jigouzhineng.png b/portal/Digitalgovernment/city/image/jigouzhineng.png
new file mode 100644
index 0000000..7fc085f
Binary files /dev/null and b/portal/Digitalgovernment/city/image/jigouzhineng.png differ
diff --git a/portal/Digitalgovernment/city/image/js.svg b/portal/Digitalgovernment/city/image/js.svg
new file mode 100644
index 0000000..cfd3515
--- /dev/null
+++ b/portal/Digitalgovernment/city/image/js.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/portal/Digitalgovernment/city/image/js1.svg b/portal/Digitalgovernment/city/image/js1.svg
new file mode 100644
index 0000000..5389cff
--- /dev/null
+++ b/portal/Digitalgovernment/city/image/js1.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/portal/Digitalgovernment/city/image/lunbotu1.png b/portal/Digitalgovernment/city/image/lunbotu1.png
new file mode 100644
index 0000000..7999957
Binary files /dev/null and b/portal/Digitalgovernment/city/image/lunbotu1.png differ
diff --git a/portal/Digitalgovernment/city/image/lunbotu2.png b/portal/Digitalgovernment/city/image/lunbotu2.png
new file mode 100644
index 0000000..d7cb311
Binary files /dev/null and b/portal/Digitalgovernment/city/image/lunbotu2.png differ
diff --git a/portal/Digitalgovernment/city/image/lunbotu3.png b/portal/Digitalgovernment/city/image/lunbotu3.png
new file mode 100644
index 0000000..699187a
Binary files /dev/null and b/portal/Digitalgovernment/city/image/lunbotu3.png differ
diff --git a/portal/Digitalgovernment/city/image/nianbao.png b/portal/Digitalgovernment/city/image/nianbao.png
new file mode 100644
index 0000000..4110db2
Binary files /dev/null and b/portal/Digitalgovernment/city/image/nianbao.png differ
diff --git a/portal/Digitalgovernment/city/image/shuzi.png b/portal/Digitalgovernment/city/image/shuzi.png
new file mode 100644
index 0000000..fb1d8ac
Binary files /dev/null and b/portal/Digitalgovernment/city/image/shuzi.png differ
diff --git a/portal/Digitalgovernment/city/image/tukuai.png b/portal/Digitalgovernment/city/image/tukuai.png
new file mode 100644
index 0000000..4609fb2
Binary files /dev/null and b/portal/Digitalgovernment/city/image/tukuai.png differ
diff --git a/portal/Digitalgovernment/city/image/workContent.png b/portal/Digitalgovernment/city/image/workContent.png
new file mode 100644
index 0000000..fce134a
Binary files /dev/null and b/portal/Digitalgovernment/city/image/workContent.png differ
diff --git a/portal/Digitalgovernment/city/image/yanguan.png b/portal/Digitalgovernment/city/image/yanguan.png
new file mode 100644
index 0000000..aa154f1
Binary files /dev/null and b/portal/Digitalgovernment/city/image/yanguan.png differ
diff --git a/portal/Digitalgovernment/city/image/yongquanma.png b/portal/Digitalgovernment/city/image/yongquanma.png
new file mode 100644
index 0000000..5b92208
Binary files /dev/null and b/portal/Digitalgovernment/city/image/yongquanma.png differ
diff --git a/portal/Digitalgovernment/city/image/yuandian.png b/portal/Digitalgovernment/city/image/yuandian.png
new file mode 100644
index 0000000..35fabb2
Binary files /dev/null and b/portal/Digitalgovernment/city/image/yuandian.png differ
diff --git a/portal/Digitalgovernment/city/image/zf.svg b/portal/Digitalgovernment/city/image/zf.svg
new file mode 100644
index 0000000..54c5831
--- /dev/null
+++ b/portal/Digitalgovernment/city/image/zf.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/portal/Digitalgovernment/city/image/zf1.svg b/portal/Digitalgovernment/city/image/zf1.svg
new file mode 100644
index 0000000..f0fb250
--- /dev/null
+++ b/portal/Digitalgovernment/city/image/zf1.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/portal/Digitalgovernment/city/image/zhineng.png b/portal/Digitalgovernment/city/image/zhineng.png
new file mode 100644
index 0000000..06b69e4
Binary files /dev/null and b/portal/Digitalgovernment/city/image/zhineng.png differ
diff --git a/portal/Digitalgovernment/city/jichuText/1.css b/portal/Digitalgovernment/city/jichuText/1.css
new file mode 100644
index 0000000..7ac6524
--- /dev/null
+++ b/portal/Digitalgovernment/city/jichuText/1.css
@@ -0,0 +1,58 @@
+.jianzhu {
+ position: absolute;
+ top: 73px;
+ left: 20px;
+ height: 720px;
+ width: 100%;
+ background: red;
+ /* width: 83.5%;
+ padding: 10px 20px; */
+}
+.jianzhu h3 {
+ text-align: left;
+ padding: 20px;
+ padding-left: 20px;
+ border-bottom: 1px solid #e1e1e1;
+}
+.jianzhu b {
+ margin: 0 10px;
+ font-size: 18px;
+}
+.jianzhu > :nth-child(1) {
+ display: flex;
+ justify-content: space-between;
+ align-items: center;
+ box-shadow: 0 0 1px 1px #e1e1e1;
+ margin-bottom: 20px;
+ padding-right: 20px;
+}
+.jianzhu > :nth-child(1) h3 {
+ border-bottom: none;
+ padding: 10px 20px;
+}
+.jianzhu > :nth-child(1) b {
+ font-size: 26px;
+}
+.jianzhu .top {
+ display: flex;
+ justify-content: space-between;
+ height: 600px;
+}
+.jianzhu .top > div {
+ width: 24%;
+ box-shadow: 0 0 1px 1px #e1e1e1;
+ text-align: left;
+ padding-bottom: 50px;
+}
+.jianzhu .top > div > :nth-child(2) {
+ padding-top: 20px;
+ padding-left: 20px;
+}
+.jianzhu .top > div > :nth-child(2) span {
+ margin-right: 20px;
+}
+.jianzhu .top > div > :nth-child(3) {
+ width: 80%;
+ height: 200px;
+ margin: 60px auto 0;
+}
diff --git a/portal/Digitalgovernment/city/jichuText/1.js b/portal/Digitalgovernment/city/jichuText/1.js
new file mode 100644
index 0000000..db8ae39
--- /dev/null
+++ b/portal/Digitalgovernment/city/jichuText/1.js
@@ -0,0 +1,61 @@
+var myChart31 = echarts.init(document.querySelector(".echart31"))
+var option31 = {
+ tooltip: {
+ trigger: "item",
+ show: true,
+ showContent: true,
+ },
+ // legend: {
+ // top: "5%",
+ // left: "center",
+ // itemStyle: {
+ // tooltip: true,
+ // },
+ // },
+ series: [{
+ // name: "Access From",
+ type: "pie",
+ radius: ["70%", "90%"],
+ avoidLabelOverlap: false,
+ label: {
+ show: true,
+ // position: "center",
+ },
+ itemStyle: {
+ color: "#3D9DF4",
+ },
+ emphasis: {
+ label: {
+ show: true,
+ fontSize: "40",
+ fontWeight: "bold",
+ },
+ itemStyle: {
+ shadowBlur: 10,
+ shadowOffsetX: 0,
+ shadowColor: "rgba(0, 0, 0, 0.5)",
+ },
+ },
+ labelLine: {
+ show: false,
+ },
+ data: [{
+ value: 100,
+ name: "100%",
+ label: {
+ position: "center",
+ fontSize: 18,
+ },
+ }, ],
+ }, ],
+}
+myChart31.setOption(option31)
+
+/* var myChart32 = echarts.init(document.querySelector(".echart32"))
+myChart32.setOption(option31)
+
+var myChart33 = echarts.init(document.querySelector(".echart33"))
+myChart33.setOption(option31)
+
+var myChart34 = echarts.init(document.querySelector(".echart34"))
+myChart34.setOption(option31) */
\ No newline at end of file
diff --git a/portal/Digitalgovernment/city/jichuText/1.less b/portal/Digitalgovernment/city/jichuText/1.less
new file mode 100644
index 0000000..2d02e96
--- /dev/null
+++ b/portal/Digitalgovernment/city/jichuText/1.less
@@ -0,0 +1,62 @@
+.jianzhu {
+ position: absolute;
+ top: 73px;
+ left: 20px;
+ height: 720px;
+ visibility: hidden;
+ background: #ffffff;
+ width: 83.5%;
+ padding: 10px 20px;
+ h3 {
+ text-align: left;
+
+ padding: 20px;
+ padding-left: 20px;
+ border-bottom: 1px solid #e1e1e1;
+ }
+ b {
+ margin: 0 10px;
+ font-size: 18px;
+ }
+ > :nth-child(1) {
+ display: flex;
+ justify-content: space-between;
+ align-items: center;
+
+ box-shadow: 0 0 1px 1px #e1e1e1;
+ margin-bottom: 20px;
+ padding-right: 20px;
+ h3 {
+ border-bottom: none;
+ padding: 10px 20px;
+ }
+ b {
+ font-size: 26px;
+ }
+ }
+ .top {
+ display: flex;
+ justify-content: space-between;
+ height: 600px;
+
+ > div {
+ width: 24%;
+ box-shadow: 0 0 1px 1px #e1e1e1;
+ text-align: left;
+ padding-bottom: 50px;
+ > :nth-child(2) {
+ padding-top: 20px;
+ padding-left: 20px;
+ // margin-top: 40px;
+ span {
+ margin-right: 20px;
+ }
+ }
+ > :nth-child(3) {
+ width: 80%;
+ height: 200px;
+ margin: 60px auto 0;
+ }
+ }
+ }
+}
diff --git a/Digitalgovernment/dandu/jquery.js b/portal/Digitalgovernment/city/jquery.js
similarity index 100%
rename from Digitalgovernment/dandu/jquery.js
rename to portal/Digitalgovernment/city/jquery.js
diff --git a/portal/Digitalgovernment/city/lunbotu1.webp b/portal/Digitalgovernment/city/lunbotu1.webp
new file mode 100644
index 0000000..7999957
Binary files /dev/null and b/portal/Digitalgovernment/city/lunbotu1.webp differ
diff --git a/portal/Digitalgovernment/city/ningbo_allareas.js b/portal/Digitalgovernment/city/ningbo_allareas.js
new file mode 100644
index 0000000..99ce903
--- /dev/null
+++ b/portal/Digitalgovernment/city/ningbo_allareas.js
@@ -0,0 +1,278 @@
+var ningbo_allareas = {
+ 330203000000: "海曙区",
+ 330205000000: "江北区",
+ 330206000000: "北仑区",
+ 330211000000: "镇海区",
+ 330212000000: "鄞州区",
+ 330213000000: "奉化区",
+ 330225000000: "象山县",
+ 330226000000: "宁海县",
+ 330281000000: "余姚市",
+ 330201000000: "宁波市本级",
+ 330283000000: "国家高新区",
+ 330284000000: "前湾新区",
+ 330282000000: "慈溪市",
+ 330285000000: "梅山物流产业集聚区",
+ 330287000000: "大榭开发区",
+ 330288000000: "东钱湖",
+ dbxc: "东部新城",
+}
+
+// Production steps of ECMA-262, Edition 5, 15.4.4.19
+// Reference: http://es5.github.io/#x15.4.4.19
+if (!Array.prototype.map) {
+ Array.prototype.map = function (callback, thisArg) {
+ var T, A, k
+
+ if (this == null) {
+ throw new TypeError(" this is null or not defined")
+ }
+
+ // 1. Let O be the result of calling ToObject passing the |this|
+ // value as the argument.
+ var O = Object(this)
+
+ // 2. Let lenValue be the result of calling the Get internal
+ // method of O with the argument "length".
+ // 3. Let len be ToUint32(lenValue).
+ var len = O.length >>> 0
+
+ // 4. If IsCallable(callback) is false, throw a TypeError exception.
+ // See: http://es5.github.com/#x9.11
+ if (typeof callback !== "function") {
+ throw new TypeError(callback + " is not a function")
+ }
+
+ // 5. If thisArg was supplied, let T be thisArg; else let T be undefined.
+ if (arguments.length > 1) {
+ T = thisArg
+ }
+
+ // 6. Let A be a new array created as if by the expression new Array(len)
+ // where Array is the standard built-in constructor with that name and
+ // len is the value of len.
+ A = new Array(len)
+
+ // 7. Let k be 0
+ k = 0
+
+ // 8. Repeat, while k < len
+ while (k < len) {
+ var kValue, mappedValue
+
+ // a. Let Pk be ToString(k).
+ // This is implicit for LHS operands of the in operator
+ // b. Let kPresent be the result of calling the HasProperty internal
+ // method of O with argument Pk.
+ // This step can be combined with c
+ // c. If kPresent is true, then
+ if (k in O) {
+ // i. Let kValue be the result of calling the Get internal
+ // method of O with argument Pk.
+ kValue = O[k]
+
+ // ii. Let mappedValue be the result of calling the Call internal
+ // method of callback with T as the this value and argument
+ // list containing kValue, k, and O.
+ mappedValue = callback.call(T, kValue, k, O)
+
+ // iii. Call the DefineOwnProperty internal method of A with arguments
+ // Pk, Property Descriptor
+ // { Value: mappedValue,
+ // Writable: true,
+ // Enumerable: true,
+ // Configurable: true },
+ // and false.
+
+ // In browsers that support Object.defineProperty, use the following:
+ // Object.defineProperty(A, k, {
+ // value: mappedValue,
+ // writable: true,
+ // enumerable: true,
+ // configurable: true
+ // });
+
+ // For best browser support, use the following:
+ A[k] = mappedValue
+ }
+ // d. Increase k by 1.
+ k++
+ }
+
+ // 9. return A
+ return A
+ }
+}
+
+if (!Array.prototype.filter) {
+ Array.prototype.filter = function (fun /*, thisArg */) {
+ "use strict"
+ if (this === void 0 || this === null) throw new TypeError()
+ var t = Object(this)
+ var len = t.length >>> 0
+ if (typeof fun !== "function") throw new TypeError()
+ var res = []
+ var thisArg = arguments.length >= 2 ? arguments[1] : void 0
+ for (var i = 0; i < len; i++) {
+ if (i in t) {
+ var val = t[i]
+ if (fun.call(thisArg, val, i, t)) res.push(val)
+ }
+ }
+ return res
+ }
+}
+
+// Production steps of ECMA-262, Edition 5, 15.4.4.18
+// Reference: http://es5.github.io/#x15.4.4.18
+if (!Array.prototype.forEach) {
+ Array.prototype.forEach = function (fun /*, thisp*/) {
+ var len = this.length
+ if (typeof fun != "function") throw new TypeError()
+ var thisp = arguments[1]
+ for (var i = 0; i < len; i++) {
+ if (i in this) fun.call(thisp, this[i], i, this)
+ }
+ }
+}
+
+// Production steps of ECMA-262, Edition 5, 15.4.4.19
+// Reference: http://es5.github.io/#x15.4.4.19
+if (!Array.prototype.map) {
+ Array.prototype.map = function (callback, thisArg) {
+ var T, A, k
+
+ if (this == null) {
+ throw new TypeError(" this is null or not defined")
+ }
+
+ // 1. Let O be the result of calling ToObject passing the |this|
+ // value as the argument.
+ var O = Object(this)
+
+ // 2. Let lenValue be the result of calling the Get internal
+ // method of O with the argument "length".
+ // 3. Let len be ToUint32(lenValue).
+ var len = O.length >>> 0
+
+ // 4. If IsCallable(callback) is false, throw a TypeError exception.
+ // See: http://es5.github.com/#x9.11
+ if (typeof callback !== "function") {
+ throw new TypeError(callback + " is not a function")
+ }
+
+ // 5. If thisArg was supplied, let T be thisArg; else let T be undefined.
+ if (arguments.length > 1) {
+ T = thisArg
+ }
+
+ // 6. Let A be a new array created as if by the expression new Array(len)
+ // where Array is the standard built-in constructor with that name and
+ // len is the value of len.
+ A = new Array(len)
+
+ // 7. Let k be 0
+ k = 0
+
+ // 8. Repeat, while k < len
+ while (k < len) {
+ var kValue, mappedValue
+
+ // a. Let Pk be ToString(k).
+ // This is implicit for LHS operands of the in operator
+ // b. Let kPresent be the result of calling the HasProperty internal
+ // method of O with argument Pk.
+ // This step can be combined with c
+ // c. If kPresent is true, then
+ if (k in O) {
+ // i. Let kValue be the result of calling the Get internal
+ // method of O with argument Pk.
+ kValue = O[k]
+
+ // ii. Let mappedValue be the result of calling the Call internal
+ // method of callback with T as the this value and argument
+ // list containing kValue, k, and O.
+ mappedValue = callback.call(T, kValue, k, O)
+
+ // iii. Call the DefineOwnProperty internal method of A with arguments
+ // Pk, Property Descriptor
+ // { Value: mappedValue,
+ // Writable: true,
+ // Enumerable: true,
+ // Configurable: true },
+ // and false.
+
+ // In browsers that support Object.defineProperty, use the following:
+ // Object.defineProperty(A, k, {
+ // value: mappedValue,
+ // writable: true,
+ // enumerable: true,
+ // configurable: true
+ // });
+
+ // For best browser support, use the following:
+ A[k] = mappedValue
+ }
+ // d. Increase k by 1.
+ k++
+ }
+
+ // 9. return A
+ return A
+ }
+}
+function countTotal(arr, keyName) {
+ let $total = 0
+ $total = arr.reduce(function (total, currentValue, currentIndex, arr) {
+ return currentValue[keyName]
+ ? parseFloat(total) + parseFloat(currentValue[keyName])
+ : parseFloat(total)
+ }, 0)
+ return $total
+}
+function unique(arr1) {
+ // const res = new Map();
+ // // return arr1.filter((a) => !res.has(a.areaCode) && res.set(a.areaCode, 1))
+ // return arr1;
+ var hash = {}
+ var Arr = arr1.reduce(function (arr, current) {
+ hash[current.areaCode]
+ ? ""
+ : (hash[current.areaCode] = true && arr.push(current))
+ return arr
+ }, [])
+ return Arr
+}
+
+
+function accAdd(arg1, arg2) {
+ var r1, r2, m, c;
+ try {
+ r1 = arg1.toString().split(".")[1].length
+ } catch (e) {
+ r1 = 0
+ }
+ try {
+ r2 = arg2.toString().split(".")[1].length
+ } catch (e) {
+ r2 = 0
+ }
+ c = Math.abs(r1 - r2);
+ m = Math.pow(10, Math.max(r1, r2))
+ if (c > 0) {
+ var cm = Math.pow(10, c);
+ if (r1 > r2) {
+ arg1 = Number(arg1.toString().replace(".", ""));
+ arg2 = Number(arg2.toString().replace(".", "")) * cm;
+ }
+ else {
+ arg1 = Number(arg1.toString().replace(".", "")) * cm;
+ arg2 = Number(arg2.toString().replace(".", ""));
+ }
+ }
+ else {
+ arg1 = Number(arg1.toString().replace(".", ""));
+ arg2 = Number(arg2.toString().replace(".", ""));
+ }
+ return (arg1 + arg2) / m
+}
diff --git a/portal/Digitalgovernment/city/textHome.css b/portal/Digitalgovernment/city/textHome.css
new file mode 100644
index 0000000..c97ca83
--- /dev/null
+++ b/portal/Digitalgovernment/city/textHome.css
@@ -0,0 +1,648 @@
+body {
+ background: #F7F7F7;
+ font-size: 14px;
+ font-family: "PingFangSC-Medium";
+}
+* {
+ margin: 0;
+ padding: 0;
+}
+a {
+ text-decoration: none;
+}
+html,
+body {
+ height: 100%;
+}
+.container {
+ position: relative;
+ height: 100%;
+
+ display: flex;
+ flex-direction: column;
+}
+.container .top::-webkit-scrollbar {
+ display: none;
+}
+.container > .top {
+ overflow-x: scroll;
+
+ width: auto;
+ padding-bottom: 10px;
+
+ white-space: nowrap;
+
+ background: #fff;
+ padding: 0 16px;
+}
+
+.container > .top > a {
+ display: inline-block;
+
+ margin: 0 10px;
+ padding: 15px 0;
+
+ text-align: center;
+ white-space: nowrap;
+
+ color: rgb(170, 163, 163);
+}
+
+.container > .top > a:first-child {
+ margin-left: 0;
+}
+
+.container > .top > a:last-child {
+ margin-right: 0;
+}
+.container .top .cycle {
+ color: #1492ff;
+ border-bottom: 2px solid #1492ff;
+}
+/* .cycle {
+ color: #1492ff;
+ border-bottom: 2px solid #1492ff;
+} */
+
+.allContent {
+ position: absolute;
+ top: 51px;
+ bottom: 0;
+ overflow: scroll;
+ width: 100%;
+}
+/* 基础建设的样式开始 */
+b {
+ font-weight: normal;
+}
+.text {
+ color: red;
+}
+.title {
+ width: 100%;
+ height: 45px;
+ display: flex;
+ flex-direction: row;
+}
+
+.titStl2 {
+ font-weight: normal;
+ font-style: normal;
+ font-size: 15px;
+ color: #363a44;
+ padding: 10px 0;
+ padding-left: 16px;
+}
+.textTit {
+ font-weight: 600;
+ font-style: normal;
+ color: #363a44;
+ font-size: 16px;
+ padding: 10px 0;
+ /* border-bottom: 1px solid #f5eaea; */
+}
+.boxStyle {
+ box-shadow: 0 0 2px 2px #e6e6e6;
+ padding-left: 10px;
+}
+.cityBuild {
+ width: 100%;
+ display: flex;
+ background: #f2f2f2;
+ padding-bottom: 20px;
+ box-shadow: 0 0 2px 2px #e6e6e6;
+}
+.cityBuild h3 {
+}
+.cityBuild h4 {
+}
+.cityBuild b {
+ font-size: 26px;
+ color: black;
+ font-weight: normal;
+}
+.cityBuild > div {
+ width: 100%;
+ background: #ffffff;
+}
+.cityBuild .left .box {
+ margin: 10px 10px;
+ padding-bottom: 10px;
+}
+.cityBuild .left .box li {
+ padding: 10px 0;
+ list-style: none;
+}
+.cityBuild .left .box li::before {
+ content: "●";
+ color: #1492ff;
+ margin-right: 5px;
+}
+.cityBuild .left .box ul li:nth-child(even) {
+ margin-bottom: 15px;
+}
+.cityBuild .middle .flex {
+ padding-left: 20px;
+}
+.cityBuild .middle .flex > div {
+ width: 50%;
+}
+.cityBuild .middle .flex span {
+ display: block;
+ margin: 10px 0;
+ color: #6e7178;
+}
+.cityBuild .middle .flex b {
+ margin-right: 10px;
+}
+.cityBuild .middle .flex i {
+ font-style: normal;
+ color: #269bff;
+}
+.cityBuild .middle p {
+ padding-left: 20px;
+ margin-top: 10px;
+ color: #6e7178;
+}
+.cityBuild .middle .echart02 {
+ height: 100px;
+ width: 90%;
+}
+.cityBuild .right h4 {
+ padding-left: 30px;
+ border-bottom: none;
+}
+.cityBuild .right .flex {
+ padding-left: 20px;
+}
+.cityBuild .right .flex > div {
+ width: 50%;
+}
+.cityBuild .right .flex > div span {
+ display: block;
+ margin: 10px 0;
+ color: #6e7178;
+}
+.cityBuild .right .flex > div b {
+ margin-right: 10px;
+}
+.cityBuild .right .flex > div i {
+ font-style: normal;
+ color: #1492ff;
+}
+.cityBuild .right div[class^="echart"] {
+ width: 90%;
+ height: 260px;
+ margin: 0 auto;
+}
+.cityBuild .right .echart03 {
+ margin-bottom: 20px;
+}
+.jichu {
+ width: 100%;
+ height: 200px;
+}
+/* middle */
+.middle {
+ margin-top: 15px;
+ width: 100%;
+ display: flex;
+ flex-direction: column;
+ background-color: #fff;
+ padding-bottom: 20px;
+ /* box-shadow: 0 0 2px 2px #e6e6e6; */
+}
+.middle h3 {
+ padding: 10px 0;
+ padding-left: 10px;
+}
+.middle .center {
+ margin: 0 16px;
+
+ margin-bottom: 10px;
+}
+.middle .flex > span {
+ display: block;
+ white-space: nowrap;
+ width: 90%;
+ margin: 15px auto;
+ padding: 10px 0;
+ overflow: hidden;
+ text-overflow: ellipsis;
+ color: #6e7178;
+ font-size: 14px;
+}
+.middle .flex {
+ display: flex;
+ justify-content: space-between;
+ margin-left: 16px;
+ margin-bottom: 10px;
+}
+
+.middle .flex > div {
+ width: 50%;
+}
+.middle .flex span {
+ display: block;
+ margin: 10px 0;
+ color: #6e7178;
+}
+.middle .flex b {
+ margin-right: 8px;
+ color: #1492ff;
+ font-size: 20px;
+ font-weight: 500;
+}
+
+.middle .flex i {
+ font-style: normal;
+ color: #6e7178;
+}
+
+.chengshi {
+ background: #ffffff;
+
+ margin: 0 16px;
+}
+.chengshi h3 {
+ text-align: left;
+ padding: 10px 20px;
+ padding-left: 20px;
+ /* border-bottom: 1px solid #e1e1e1;
+ */
+}
+.chengshi b {
+ margin: 0 8px;
+ color: #1492ff;
+ font-size: 20px;
+}
+.chengshi .ceshiTop {
+ display: flex;
+ flex-direction: column;
+}
+.chengshi .ceshiTop > div {
+ width: 100%;
+}
+.leftTit {
+ height: 30px;
+ line-height: 30px;
+ padding-top: 5px;
+ padding-bottom: 5px;
+ font-size: 15px;
+
+ /* border-bottom: 1px solid #e1e1e1; */
+ color: #363a44;
+}
+.leftStl {
+ font-weight: 500;
+ width: 90%;
+ padding-bottom: 10px;
+ /* border-bottom: 1px solid #e1e1e1; */
+
+}
+
+.leftStl b{
+ color: #1492ff;
+}
+.dandu {
+ font-weight: 600;
+ font-size: 16px;
+}
+.chengshi .ceshiTop .left .flexTwo {
+ display: flex;
+ flex-direction: column;
+ color: #6e7178;
+ font-size: 14px;
+}
+.chengshi .ceshiTop .left .flexTwo > :nth-child(1) {
+ width: 95%;
+ text-align: left;
+ padding-left: 0px;
+ line-height: 30px;
+ color: #6e7178;
+}
+
+.chengshi .ceshiTop .left .flexTwo > :nth-child(1) span {
+ display: block;
+}
+.chengshi .ceshiTop .left .flexTwo .r {
+ text-align: left;
+ color: #363a44;
+ padding-top: 10px;
+ position: relative;
+}
+/* .chengshi .top .left .flexTwo .r span {
+ color: black;
+}
+.chengshi .top .left .flexTwo .r > :nth-child(3) {
+ position: absolute;
+ right: 0px;
+ top: 10px;
+ width: 60%;
+ display: flex;
+ flex-wrap: wrap;
+}++++++++++++++++++++++++++++++++++++++++++++++
+.chengshi .top .left .flexTwo .r > :nth-child(3) > div {
+ display: flex;
+ align-items: center;
+}
+.chengshi .top .left .flexTwo .r > :nth-child(3) > div span {
+ height: 13px;
+ width: 5px;
+ display: inline-block;
+ border-radius: 3px;
+ margin-right: 5px;
+}
+.chengshi .top .left .flexTwo .r > :nth-child(3) > div i {
+ font-style: normal;
+ margin-right: 8px;
+ font-size: 12px;
+}
+ */
+.gaizao {
+ width: 100%;
+ background-color: #fff;
+ margin-top: 15px;
+}
+.gaizao .spanText {
+ height: 40px;
+ text-align: left;
+ vertical-align: auto;
+ line-height: 40px;
+ /* margin-top: 10px; */
+ color: #6e7178;
+}
+.gaizao .spanText2 {
+ height: 40px;
+ text-align: left;
+ vertical-align: auto;
+ line-height: 40px;
+ color: #6e7178;
+}
+.gzstl {
+ margin: 0 16px;
+}
+
+.new {
+ width: 100%;
+ background-color: #fff;
+ margin-top: 15px;
+}
+.new .flex {
+ margin-top: 10px;
+ margin-bottom: 10px;
+ width: 100%;
+ display: flex;
+}
+.new .flex span {
+ width: 50%;
+ text-align: center;
+ color: #6e7178;
+}
+.new .flex b {
+ color: #1492ff;
+ font-size: 20px;
+ font-weight: 500;
+ margin: 0 8px;
+}
+.jianshe {
+ width: 100%;
+ display: flex;
+ flex-direction: column;
+ background-color: #fff;
+ padding-bottom: 20px;
+ /* box-shadow: 0 0 2px 2px #e6e6e6; */
+}
+.jianshe h3 {
+ padding: 10px 0;
+ margin-left: 10px;
+}
+.jianshe h5 {
+ margin-top: 10px;
+ margin-left: 20px;
+}
+.jianshe .left p {
+ margin-left: 16px;
+ margin-top: 10px;
+ color: #6e7178;
+}
+.rightTwo {
+ display: flex;
+ flex-direction: column;
+ margin: 0px 16px;
+ color: #6e7178;
+}
+.pStl {
+ line-height: 30px;
+ border-bottom: 1px solid #e1e1e1;
+}
+.pStl b {
+ color: #1492ff;
+}
+.icon {
+ width: 100%;
+ display: flex;
+ align-items: center;
+ flex-direction: row;
+ margin-top: 10px;
+ margin-bottom: 10px;
+}
+.span1 {
+ width: 15px;
+ height: 8px;
+ margin-left: 0px;
+ color: #6e7178;
+}
+.span2 {
+ line-height: 8px;
+ margin-right: 16px;
+ color: #6e7178;
+}
+
+.water {
+ width: 100%;
+ background-color: #fff;
+ margin-top: 15px;
+ padding-bottom: 20px;
+}
+
+.waterTop {
+ margin: 0 16px;
+}
+.waterTop p {
+ /* border-bottom: 1px solid #e1e1e1; */
+}
+.echart11Div {
+ width: 100%;
+ /* margin-left: 50px; */
+}
+
+.start {
+ margin-top: 5px;
+ margin-bottom: 5px;
+ display: flex;
+ flex-direction: row;
+ padding: 10px 16px;
+ color: #6e7178;
+}
+.start .left {
+ width: 50%;
+ text-align: left;
+}
+.start .right {
+ width: 50%;
+ text-align: left;
+}
+.startBottom {
+ width: 100%;
+
+ padding-top: 10px;
+ padding-bottom: 10px;
+}
+.start b {
+ color: #1492ff;
+ font-size: 20px;
+ font-weight: 500;
+ margin: 0 8px;
+}
+
+/* 加粗样式修改 */
+.plantext {
+ color: #1492ff;
+ font-size: 20px;
+ font-weight: 500;
+ margin: 0 8px;
+}
+.planhu {
+ color: #1492ff;
+ font-size: 20px;
+ font-weight: 500;
+ margin: 0 8px;
+}
+.planmi {
+ color: #1492ff;
+ font-size: 20px;
+ font-weight: 500;
+ margin: 0 8px;
+}
+
+.startTit {
+ display: flex;
+ justify-content: space-between;
+ align-items: center;
+ padding: 0 16px;
+ font-size: 15px;
+ color: #363a44;
+ margin-bottom: 16px;
+}
+.textButton {
+ width: 90px;
+ height: 30px;
+ display: flex;
+ color: #363a44 !important;
+}
+.waterTopP {
+ padding-top: 10px;
+
+ padding-bottom: 10px;
+}
+.waterTopP b{
+ color: #198eff;
+}
+#xiangmu {
+ width: 50%;
+ line-height: 30px;
+ text-align: center;
+ border: 1px solid #198eff;
+ color: #198eff;
+}
+#mianji {
+ width: 50%;
+ line-height: 30px;
+ text-align: center;
+ border: 1px solid #b1afaf;
+
+ border-left: none;
+}
+#main {
+ width: 100%;
+ height: 200px;
+}
+.echart02Stl {
+ margin: 0 16px;
+ height: 40px;
+ margin-bottom: 20px;
+}
+.echart02 {
+ width: 100%;
+ height: 100%;
+}
+.echart03 {
+ width: 100%;
+ height: 150px;
+}
+.echart42 {
+ width: 100%;
+ height: 500px;
+}
+.echart43 {
+ width: 100%;
+ height: 900px;
+}
+
+.echart04 {
+ width: 100%;
+ height: 150px;
+}
+.echart05 {
+ padding-top: 10px;
+ width: 100%;
+ height: 200px;
+}
+
+ .echart06 {
+ width: 100%;
+ height: 30px;
+ overflow: hidden;
+}
+.echart07Stl{
+ width: 100%;
+ height: 600px;
+ overflow: hidden;
+}
+.echart07 {
+ width: 100%;
+ height: 100%;
+}
+.echart08Stl {
+ margin-top: 10px;
+ width: 100%;
+ height: 450px;
+}
+.echart08 {
+ width: 100%;
+ height: 100%;
+}
+.echart09 {
+ margin: 0 16px;
+ height: 1100px;
+}
+.echart10 {
+ width: 100%;
+ height: 250px;
+}
+.echart11 {
+ margin: 0 16px;
+ height: 120px;
+}
+.echart12 {
+ width: 100%;
+ height: 250px;
+}
+.echart13Stl {
+}
+.echart13 {
+ width: 100%;
+ height: 400px;
+}
+/* 基础建设的结束 */
diff --git a/portal/Digitalgovernment/city/textHome.js b/portal/Digitalgovernment/city/textHome.js
new file mode 100644
index 0000000..8ed2200
--- /dev/null
+++ b/portal/Digitalgovernment/city/textHome.js
@@ -0,0 +1,1377 @@
+/* var myChart31 = echarts.init(document.querySelector(".echart31"))
+ */
+$(".container> .top >:first-child").addClass("cycle")
+$(function () {
+ xiangmu() //执行函数
+ water() //污水零直排
+ village() //老旧小区改造
+ newG() //工棚区改造
+ jianshe() //海绵城市建设
+ jiansheY() //海绵城市建设要求
+ // new7() //基础设施建设
+ Mychart43() // 新建绿道
+ /* 面积的处理 */
+ mianji0()
+ let url = "http://118.178.224.202:8024/api/old-urban2"
+ let dataHtml = ""
+ let aimList = []
+ let startedList = []
+ $.get(url, function (data) {
+ data.data.map((item, index) => {
+ aimList.push(item.aim)
+ startedList.push(item.started)
+ })
+
+ aimList.map((item, index) => {
+ dataHtml = accAdd(Number(dataHtml), Number(item))
+ })
+ $(".planmi").html(dataHtml)
+ })
+})
+
+//基础设置
+// var chartDom = document.getElementById("main")
+// var myChart = echarts.init(chartDom)
+// var option = {
+// tooltip: {
+// trigger: "item",
+// show: true,
+// showContent: true,
+// },
+// // legend: {
+// // top: "5%",
+// // left: "center",
+// // itemStyle: {
+// // tooltip: true,
+// // },
+// // },
+// series: [
+// {
+// // name: "Access From",
+// type: "pie",
+// radius: ["70%", "90%"],
+// avoidLabelOverlap: false,
+// label: {
+// show: true,
+// // position: "center",
+// },
+// itemStyle: {
+// color: "#3D9DF4",
+// },
+// emphasis: {
+// label: {
+// show: true,
+// fontSize: "40",
+// fontWeight: "bold",
+// },
+// itemStyle: {
+// shadowBlur: 10,
+// shadowOffsetX: 0,
+// shadowColor: "rgba(0, 0, 0, 0.5)",
+// },
+// },
+// labelLine: {
+// show: false,
+// },
+// data: [
+// {
+// value: 100,
+// name: "100%",
+// label: {
+// position: "center",
+// fontSize: 18,
+// },
+// },
+// ],
+// },
+// ],
+// }
+// myChart.setOption(option)
+
+// 基础设施建设文字数据
+// function new7() {
+// let url = "http://118.178.224.202:8024/api/new7"
+
+// $.get(url, function (data) {
+// $(".total").html(data.data[0].total)
+// $(".total1").html(data.data[0].total1)
+// $(".total2").html(data.data[0].total2)
+// $(".total3").html(data.data[0].total3)
+// $(".total4").html(data.data[0].total4)
+
+// $(".now").html(data.data[0].now)
+// $(".now1").html(data.data[0].now1)
+// $(".now2").html(data.data[0].now2)
+// $(".now3").html(data.data[0].now3)
+// $(".now4").html(data.data[0].now4)
+// $(".area").html(data.data[0].area)
+// })
+// }
+
+//长条
+let myChart02 = echarts.init(document.querySelector(".echart02"))
+
+
+/* 宁波分区 */
+// 地图部分
+
+function Mychart43() {
+ let url = "http://118.178.224.202:8024/api/new-g"
+ var myChart43 = echarts.init(document.querySelector(".echart43"))
+
+ $.get(url, function (data) {
+ console.log("地图部分", data)
+ let areaList = []
+ let progressList = []
+ let finishList = []
+ let targetList = []
+ let myColor1 = [] //
+ data.data.map((item) => {
+ areaList.push(item.area)
+ progressList.push(item.progress)
+ finishList.push(item.finish)
+ targetList.push(item.target)
+ /* var lv = Number(item.finish.split('%')[0])
+ console.log("得到的各种数据",lv)
+ return lv >= 100 ? "#1491FD" : lv > 60 ? "#E89846" : "#FF0332" */
+ var c = parseFloat(item.finish.split("%")[0]) < 100 ? "#FF5C11" : "#15BE50"
+ /* var c = parseFloat((item["currentValue"] / item["targetValue"]) * 100).toFixed(
+ 0
+ ) < 100 ?
+ "#FF5C11" :
+ "#15BE50" */
+ myColor1.push(c)
+ })
+ var option43 = {
+ grid: {
+ left: 0,
+ right: 0,
+ bottom: 0,
+ top: 20,
+ },
+ // formatter: "{b} {c} ",
+ tooltip: {
+ confine: true ,
+ formatter: function (params, ticket, callback) {
+ if (params.data !== undefined) {
+ /* var currentValue = d[params.dataIndex]["currentValue"]
+ var targetValue = d[params.dataIndex]["targetValue"] */
+ let area = data.data[params.dataIndex]["area"]
+ let finish = data.data[params.dataIndex]["finish"]
+ let target = data.data[params.dataIndex]["target"]
+ let progress = data.data[params.dataIndex]["progress"]
+ return area + " 进度:" + progress + ",已完成" + finish + "km,目标:" + target + "km"
+ }
+ },
+ },
+ xAxis: {
+ type: "value",
+ splitLine: {
+ show: false,
+ },
+ axisLabel: {
+ show: false,
+ },
+ axisTick: {
+ show: false,
+ },
+ axisLine: {
+ show: false,
+ },
+ },
+ yAxis: [
+ {
+ type: "category",
+ axisTick: {
+ show: false,
+ },
+ axisLine: {
+ show: false,
+ },
+ axisLabel: {
+ color: "#6e7178",
+ fontSize: 14,
+ verticalAlign: "bottom",
+ lineHeight: 35,
+ margin: -0,
+ align: "left",
+ },
+ data: areaList,
+ },
+ ],
+ label: {
+ show: true,
+ color: "#6e7178",
+ align: "right",
+ position: "left",
+ offset: [$(".echart43").width(), -13],
+ formatter: ({ data }) => {
+ return data + "公里"
+ },
+ fontSize: 14,
+ },
+
+ series: [
+ {
+ name: "条",
+ type: "bar",
+ barWidth: 10,
+ barGap: "180",
+ data: finishList,
+ itemStyle: {
+ borderRadius: 5,
+ color: "#83BBFF",
+ },
+
+ showBackground: {
+ show: true,
+ },
+ backgroundStyle: {
+ color: "#E6F1FF",
+ borderRadius: 5,
+ },
+ },
+ ],
+ }
+ myChart43.setOption(option43)
+ })
+}
+
+
+
+var myChart42 = echarts.init(document.querySelector(".echart42"))
+// 新建绿道
+var myChart43 = echarts.init(document.querySelector(".echart43"))
+var taskId43 = "244837774619930624"
+var quotaCode43 = "Q249971129640398848"
+var url43 = "https://sznbs.ningbo.gov.cn:89/nbszhjkzz/tojcms/getQuotaByTaksIdOrQuotaCode.do?parentQuotaCode=" + quotaCode43 + "&systemName=government"
+$.post(url43, function (data) {
+ var d = unique(data.infoList)
+ d.push({
+ areaCode: "dbxc",
+ currentValue: "0",
+ targetValue: "3",
+ })
+ var mubiao2 = countTotal(d, 'targetValue');
+ var nb_value2 = countTotal(d, 'currentValue');
+ $("#leijimub").html(parseFloat(nb_value2).toFixed(2));
+ $(".dandu").html(parseFloat(nb_value2/mubiao2*100).toFixed(2))
+/* 新建绿道长条部分 */
+ let option02 = {
+ grid: {
+ right: 00,
+ top: 5,
+ bottom: 5,
+ left: 00,
+ },
+ xAxis: {
+ show: false,
+ },
+ yAxis: {
+ type: "category",
+ show: false,
+ },
+ series: [
+ {
+ name: "2021",
+ type: "bar",
+ data: [nb_value2/mubiao2*100],
+ itemStyle: {
+ color: "#83BBFF",
+ borderRadius: 5,
+ },
+ barWidth: "10",
+ zlevel: 2,
+ },
+ {
+ name: "2021",
+ type: "bar",
+ data: 100,
+ itemStyle: {
+ color: "#E6F1FF",
+ borderRadius: 5,
+ },
+ barWidth: "10",
+ barGap: "-100%",
+ },
+ ],
+ }
+ myChart02.setOption(option02)
+ $.post('https://sznbs.ningbo.gov.cn:89/nbszhjkzz/tojcms/targetProgress.do?taskId=' + taskId43 + '&taskSystem=government"aCode=' + quotaCode43, function (data3) {
+ var nb_value = (data3.infoList.filter(function (item) {
+ return item['areaName'] == '宁波市'
+ })[0]['quotaValue']);
+ $("#lblmubiao2").html(mubiao2);
+ $("#lblshiji2").html(parseFloat(nb_value).toFixed(2));
+ });
+ var myColor1 = []
+ d.forEach(function (item) {
+ var c = parseFloat((item["currentValue"] / item["targetValue"]) * 100).toFixed(0) < 100 ? "#FF5C11" : "#15BE50"
+
+ myColor1.push(c)
+ })
+ $.get("https://sznbs.ningbo.gov.cn:89/szzf/zdrw/fj_zhujianjun/330200_full.json", function (mapJson) {
+ echarts.registerMap("宁波市", mapJson)
+ var option42 = {
+ title: {
+ text: "宁波市",
+ left: 0,
+ top: 20,
+ textStyle: {
+ color: "#b3b5b9",
+ },
+ },
+ tooltip: {
+ trigger: "item",
+ formatter: function (params, ticket, callback) {
+ if (params.data !== undefined) {
+ let currentValue = d[params.dataIndex]["currentValue"]
+ let targetValue = d[params.dataIndex]["targetValue"]
+ return params.name + " 进度:" + parseFloat((currentValue / targetValue) * 100).toFixed(0) + "%,已完成" + currentValue + "km,目标:" + targetValue + "km"
+ }
+ },
+ },
+
+ geo: {
+ show: true,
+ map: "宁波市",
+ top: 90,
+
+ roam: false, //不开启缩放和平移
+ zoom: 1.23, //视角缩放比例
+ label: {
+ normal: {
+ show: true,
+ fontSize: "10",
+ color: "white",
+ },
+ },
+
+ regions: [],
+ },
+ series: [
+ {
+ mapType: "宁波市",
+ type: "map",
+
+ label: {
+ show: true,
+ },
+ geoIndex: 0,
+ },
+ ],
+ }
+
+ d.forEach(function (item) {
+ // debugger
+ let c = parseFloat((item["currentValue"] / item["targetValue"]) * 100).toFixed(0) < 100 ? "#3388ff" : "#fecc5d"
+ option42.geo.regions.push({
+ name: ningbo_allareas[item["areaCode"]],
+ itemStyle: {
+ normal: {
+ areaColor: c,
+ },
+ emphasis: {
+ areaColor: c,
+ },
+ },
+ label: {
+ show: true,
+ },
+ })
+
+ myColor1.push(c)
+ })
+
+
+ myChart42.setOption(option42)
+ })
+})
+
+/* 城市建设*/
+
+function jianshe() {
+ let url = "http://118.178.224.202:8024/api/new8"
+ $.get(url, function (data) {
+ let dataHtml = data.data[0].area
+ let dataHtml1 = data.data[0].area1
+ $(".area").html(dataHtml)
+ $(".area1").html(dataHtml1)
+ let myChart05 = echarts.init(document.querySelector(".echart05"))
+ let option05 = {
+ tooltip: {
+ confine: true ,
+ trigger: "item",
+ show: true,
+ formatter: " {b}:{c} " + "万㎡",
+ },
+ legend: {
+ top: "0%",
+ left: "0%",
+ selectedMode: false,
+ itemWidth: 15,
+ itemHeight:10,
+ textStyle: {
+ fontSize: 13,
+ color: "#6e7178",
+ },
+ },
+ label: {
+ width: 140,
+ overflow: "break",
+ formatter: `{b}\n{d}%`,
+ positon: "outside",
+ fontSize: 14,
+ color: "#6e7178",
+ },
+ series: [
+ {
+ type: "pie",
+ radius: ["40%", "60%"],
+ avoidLabelOverlap: false,
+ left: 70,
+ right: 70,
+ label: {
+ normal: {
+ position: 'inner',
+ show : false
+ }
+ },
+ data: [
+ {
+ value: dataHtml,
+ name: "中心城区建成面积",
+ itemStyle: {
+ color: "#3BA271",
+ },
+ },
+ {
+ value: dataHtml1,
+ name: "县(市)建成面积",
+ itemStyle: {
+ color: "#3388FF",
+ },
+ },
+ ],
+
+
+ },
+ ],
+ }
+ myChart05.setOption(option05)
+ })
+}
+ let myChart06 = echarts.init(document.querySelector(".echart06"))
+
+
+/* 海绵城市完成率 */
+var taskId2 = '249481498440331264';
+var quotaCode2 = 'Q259698764016517121';
+var target1 = 5;
+$.post('https://sznbs.ningbo.gov.cn:89/nbszhjkzz/tojcms/targetProgress.do?taskId=' + taskId2 + '&taskSystem=government"aCode=' + quotaCode2, function (data2) {
+ var nb_value = (data2.infoList.filter(function (item) {
+ return item['areaName'] == '宁波市'
+ })[0]['quotaValue']);
+ $("#mubiao1").html(target1+ "%");
+ $("#shiji1").html(parseFloat(nb_value).toFixed(2) + "%");
+ $("#wanhcneg1").html((parseFloat(nb_value) / target1 * 100).toFixed(2) + "%");
+ console.log("海绵城市请求",)
+ var option06 = {
+ xAxis: {
+ type: "value",
+ show: false,
+ },
+ yAxis: {
+ type: "category",
+ show: false,
+ },
+ grid: {
+ left: 0,
+ right: 0,
+ },
+ series: [
+ {
+ name: "2021",
+ type: "bar",
+ data: [target1],
+ itemStyle: {
+ color: "#83BBFF",
+ borderRadius: 5,
+ },
+ barWidth: "10",
+ zlevel: 2,
+ },
+ {
+ name: "2021",
+ type: "bar",
+ data: [0],
+ itemStyle: {
+ color: "#269BFF",
+ borderRadius: 5,
+ },
+ barWidth: "10",
+ barGap: "-100%",
+ },
+ ],
+ }
+ myChart06.setOption(option06)
+});
+
+// 海绵城市要求
+
+function jiansheY() {
+ let url = "http://118.178.224.202:8024/api/urban-r"
+ var myChart07 = echarts.init(document.querySelector(".echart07"))
+ $.get(url, function (data) {
+ console.log("海绵城市建设",data)
+ let areaList = []
+ let aimList = []
+ let actualList = []
+ let finishList = []
+ let myColor1=[]
+ data.data.map((item) => {
+ areaList.push(item.area)
+ aimList.push(item.aim)
+ actualList.push(parseInt(item.actual))
+ finishList.push(item.finish)
+
+
+ var c = parseFloat(item.finish.split("%")[0]) < 100 ? "#E89846" : "#FF0332"
+ /* var c = parseFloat((item["currentValue"] / item["targetValue"]) * 100).toFixed(
+ 0
+ ) < 100 ?
+ "#FF5C11" :
+ "#15BE50" */
+ myColor1.push(c)
+
+
+ })
+
+
+ var option07 = {
+ grid: {
+ top: 20,
+ bottom: 0,
+ left: 0,
+ right: 0,
+ },
+ tooltip: {
+ confine: true ,
+ formatter: function (params, ticket, callback) {
+ if (params.data !== undefined) {
+ var actual = data.data[params.dataIndex]["actual"]
+ if (actual == null || actual == undefined) actual = 0
+ var aim = data.data[params.dataIndex]["aim"]
+ var finish = data.data[params.dataIndex]["finish"]
+ return params.name + "完成率" + finish + ",已完成:" + actual + ",目标:" + aim
+ }
+ },
+ },
+
+ xAxis: {
+ type: "value",
+ splitLine: {
+ show: false,
+ },
+ axisLabel: {
+ show: false,
+ },
+ axisTick: {
+ show: false,
+ },
+ axisLine: {
+ show: false,
+ },
+ },
+
+ yAxis: [
+ {
+ type: "category",
+ axisTick: {
+ show: false,
+ },
+ axisLine: {
+ show: false,
+ },
+ axisLabel: {
+ verticalAlign: "bottom",
+ lineHeight: 28,
+ margin: -0,
+ align: "left",
+ color: "#6e7178",
+ fontSize: 14,
+ },
+ data: areaList,
+ },
+ ],
+ series: [
+ {
+ name: "条",
+ type: "bar",
+ barWidth: 10,
+ data: actualList,
+ showBackground: true,
+ itemStyle: {
+ color: "#83BBFF",
+ borderRadius: 5,
+ },
+ backgroundStyle: {
+ borderRadius: 5,
+ color: "#E6F1FF",
+ },
+ label: {
+ show: true,
+ position: "left",
+ align: "right",
+ offset: [$(".echart43").width(), -13],
+ formatter: ({ data }) => {
+ return "实际完成率" + data + "%"
+ },
+ fontSize: 14,
+ color: "#6e7178",
+ },
+ },
+ ],
+ }
+ myChart07.setOption(option07)
+ })
+}
+// 老旧小区改造
+function village() {
+ var myChart08 = echarts.init(document.querySelector(".echart08"))
+ let url = "http://118.178.224.202:8024/api/old-village"
+
+ let dataHtml = ""
+ let areaList = []
+ let reformOVList = []
+ let colors = ["#5c8ff8", "#5c8ff8"]
+
+ $.get(url, function (data) {
+ data.data.map((item, index) => {
+ areaList.push(item.area)
+ reformOVList.push(item.reformOV)
+ })
+ reformOVList.map((item, index) => {
+ console.log("数量", item)
+ dataHtml = Number(dataHtml) + Number(item)
+ })
+ $(".plantext").html(dataHtml)
+ option44 = {
+ tooltip: {
+ trigger: "axis",
+ axisPointer: {
+ type: "shadow",
+ },
+ formatter: "{b} {c} ",
+ },
+ grid: {
+ left: 0,
+ right: 0,
+ top: 10,
+ bottom: 10,
+ },
+
+ yAxis: [
+ {
+ type: "category",
+
+ data: areaList, //["海曙区", "江北区", "北仑区", "镇海区", "鄞州区", "奉化区", "象山县"],
+ axisLine: {
+ show: false,
+ },
+ axisTick: {
+ show: false,
+ },
+ axisLabel: {
+ fontSize: 14,
+
+ verticalAlign: "bottom",
+ lineHeight: 30,
+ margin: -0,
+ align: "left",
+ color: "#6e7178",
+ },
+ },
+ ],
+ xAxis: [
+ {
+ type: "value",
+ show: false,
+ },
+ ],
+ series: [
+ {
+ name: "条",
+ type: "bar",
+ barWidth: 10,
+
+ data: reformOVList,
+
+ itemStyle: {
+ borderRadius: 5,
+ color: "#83BBFF",
+ },
+
+ label: {
+ show: true,
+ position: "left",
+ align: "right",
+ offset: [$(".echart43").width(), -13],
+ formatter: "{c}户",
+ fontSize: 14,
+ color: "#6e7178",
+ },
+ showBackground: {
+ show: true,
+ },
+ backgroundStyle: {
+ color: "#E6F1FF",
+ borderRadius: 5,
+ },
+ },
+ ],
+ }
+ myChart08.setOption(option44)
+ })
+}
+
+function xiangmu() {
+ let url = "http://118.178.224.202:8024/api/old-urban"
+ let areaList = []
+ let aimList = []
+ let startedList = []
+ $.get(url, function (data) {
+ data.data.map((item, index) => {
+ areaList.push(item.area)
+ aimList.push(item.aim)
+ startedList.push(item.started)
+ })
+ console.log("xiangmu",data)
+ var shumu2 = countTotal(data.data, 'started');
+ $("#shumu2").html(shumu2)
+ let myChart09 = echarts.init(document.querySelector(".echart09"))
+ let option09 = {
+ tooltip: {
+ trigger: "axis",
+ axisPointer: {
+ type: "shadow",
+ },
+ },
+ legend: {
+ top: 0,
+ left: 0,
+ selectedMode: false,
+ itemWidth: 15,
+ itemHeight:10,
+ textStyle: {
+ fontSize: 13,
+ color: "#6e7178",
+ },
+ },
+ grid: {
+ left: 0,
+ right: 0,
+ bottom: 10,
+ top: 50,
+ },
+ yAxis: {
+ type: "category",
+ data: areaList,
+ axisTick: {
+ show: false,
+ },
+ axisLabel: {
+ fontSize: 14,
+
+ verticalAlign: "bottom",
+ align: "left",
+ lineHeight: 70,
+ margin: -0,
+ color: "#6e7178",
+ },
+ axisLine: {
+ show: false,
+ },
+ },
+
+ xAxis: {
+ type: "value",
+ show: false,
+ },
+ label: {
+ show: true,
+ position: "left",
+ align: "right",
+ offset: [$(".echart43").width(), -13],
+ // formatter: "{c}万㎡",
+ fontSize: 14,
+ color: "#6e7178",
+ },
+ series: [
+ {
+ name: "今年目标",
+ type: "bar",
+ barWidth: 10,
+ itemStyle: {
+ color: "#83BBFF",
+ borderRadius: 5,
+ },
+ data: aimList,
+ showBackground: {
+ show: true,
+ },
+ backgroundStyle: {
+ color: "#E6F1FF",
+ borderRadius: 5,
+ },
+ },
+ {
+ name: "已开工项目",
+ type: "bar",
+ barWidth: 10,
+ itemStyle: {
+ color: "#fecc5d",
+ borderRadius: 5,
+ },
+ data: startedList,
+ showBackground: {
+ show: true,
+ borderRadius: 5,
+ },
+ backgroundStyle: {
+ color: "#E6F1FF",
+ borderRadius: 5,
+ },
+ barGap: "250%",
+ },
+ ],
+ }
+ myChart09.setOption(option09)
+ })
+}
+
+function mianji0(){
+ let url = "http://118.178.224.202:8024/api/old-urban2"
+ $.get(url, function (data) {
+ var mianji2 = countTotal(data.data, 'started')
+ $("#mianji2").html(mianji2)
+
+ })
+}
+
+function mianji() {
+ let url = "http://118.178.224.202:8024/api/old-urban2"
+ let dataHtml = ""
+ let areaList = []
+ let aimList = []
+ let startedList = []
+ $.get(url, function (data) {
+ data.data.map((item, index) => {
+ areaList.push(item.area)
+ aimList.push(item.aim)
+ startedList.push(item.started)
+ })
+ console.log("数量", data)
+ var mianji2 = countTotal(data.data, 'started')
+ $("#mianji2").html(mianji2)
+
+ aimList.map((item, index) => {
+ dataHtml = Number(dataHtml) + Number(item)
+ })
+ $(".planmi").html(dataHtml)
+
+ let myChart09 = echarts.init(document.querySelector(".echart09"))
+ let option04 = {
+ tooltip: {
+ trigger: "axis",
+ axisPointer: {
+ type: "shadow",
+ },
+ },
+ legend: {
+ top: 0,
+ left: 0,
+ selectedMode: false,
+ itemWidth: 15,
+ itemHeight:10,
+ textStyle: {
+ fontSize: 13,
+ color: "#6e7178",
+ },
+ },
+ grid: {
+ left: 0,
+ right: 0,
+ bottom: 10,
+ top: 50,
+ },
+ yAxis: {
+ type: "category",
+ data: areaList,
+ axisLine: {
+ show: false,
+ },
+ axisLabel: {
+ fontSize: 14,
+
+ verticalAlign: "bottom",
+ align: "left",
+ lineHeight: 60,
+ margin: -0,
+ color: "#6e7178",
+ },
+ axisTick: {
+ show: false,
+ },
+ },
+
+ xAxis: {
+ type: "value",
+ axisLabel: {
+ show: true,
+ },
+ axisTick: {
+ show: false,
+ },
+ axisLine: {
+ show: false,
+ },
+ },
+ label: {
+ show: true,
+ position: "left",
+ align: "right",
+ offset: [$(".echart43").width(), -13],
+ // formatter: "{c}万㎡",
+ fontSize: 14,
+ color: "#6e7178",
+ },
+ series: [
+ {
+ name: "今年目标",
+ type: "bar",
+ barWidth: 10,
+ itemStyle: {
+ color: "#3388ff",
+ borderRadius: 5,
+ },
+ showBackground: {
+ show: true,
+ borderRadius: 5,
+ },
+ backgroundStyle: {
+ color: "#E6F1FF",
+ borderRadius: 5,
+ },
+ data: aimList,
+ },
+ {
+ name: "已开工项目",
+ type: "bar",
+ barWidth: 10,
+ itemStyle: {
+ color: "#fecc5d",
+ borderRadius: 5,
+ },
+ showBackground: {
+ show: true,
+ borderRadius: 5,
+ },
+ backgroundStyle: {
+ color: "#E6F1FF",
+ borderRadius: 5,
+ },
+ data: startedList,
+ barGap: "200%",
+ },
+ ],
+ }
+ myChart09.setOption(option04)
+ })
+}
+
+
+
+function newG() {
+ var myChart11 = echarts.init(document.querySelector(".echart11"))
+
+ let url = "http://118.178.224.202:8024/api/new-r"
+ $.get(url, function (data) {
+ let area1List = []
+ let targetList = []
+ let finishList = []
+ targetList.push(data.data[0].finish,data.data[1].finish)
+ finishList.push(data.data[0].target,data.data[1].target)
+ console.log("工棚去数据", data,targetList,finishList)
+
+ var mubioaT = countTotal(data.data,'target')
+ var wancchengT = countTotal(data.data,'finish')
+
+ $("#mubioaT").html(mubioaT)
+ $("#wancchengT").html(wancchengT)
+
+
+ var myChart10 = echarts.init(document.querySelector(".echart10"))
+ var option10 = {
+ tooltip: {
+ trigger: "item",
+ show: true,
+ showContent: true,
+ },
+ series: [
+ {
+ // name: "Access From",
+ type: "pie",
+ radius: ["60%", "80%"],
+ avoidLabelOverlap: false,
+ label: {
+ show: true,
+ // position: "center",
+ },
+ itemStyle: {
+ color: "#3D9DF4",
+ },
+ emphasis: {
+ label: {
+ show: true,
+ fontSize: "40",
+ fontWeight: "bold",
+ },
+ itemStyle: {
+ shadowBlur: 10,
+ shadowOffsetX: 0,
+ shadowColor: "rgba(0, 0, 0, 0.5)",
+ },
+ },
+ labelLine: {
+ show: false,
+ },
+ data: [
+ {
+ value: wancchengT,
+ name: (wancchengT/wancchengT*100).toFixed(0) + "%" ,
+ label: {
+ position: "center",
+ fontSize: 16,
+ },
+ },
+ {
+ value: wancchengT-wancchengT,
+ // name: "43%",
+ itemStyle: {
+ color: "#EEEEEE",
+ },
+ label: {
+ position: "center",
+ fontSize: 16,
+ },
+ },
+
+ ],
+ },
+ ],
+ }
+ myChart10.setOption(option10)
+
+
+
+
+
+
+ var option48 = {
+ grid: {
+ left: 0,
+ top: 10,
+ bottom: 10,
+ right: 0,
+ },
+ xAxis: [
+ {
+ show: false,
+ },
+ ],
+ yAxis: [
+ {
+ type: "category",
+ data: area1List,
+ axisLine: {
+ show: false,
+ }, //坐标轴
+ axisTick: [
+ {
+ //坐标轴小标记
+ show: false,
+ },
+ ],
+ axisLabel: {
+ fontSize: 14,
+
+ verticalAlign: "bottom",
+ align: "left",
+ lineHeight: 32,
+ margin: 0,
+ color: "#6e7178",
+ },
+ },
+ ],
+ label: {
+ show: true,
+ position: "left",
+ align: "right",
+ offset: [$(".echart43").width(), -13],
+ formatter: "{c}套",
+ color: "#6e7178",
+ fontSize: 14,
+ },
+ series: [
+ {
+ name: "套",
+ type: "bar",
+ barGap: "200%",
+ barWidth: 10, //柱宽度
+ data: finishList,
+ itemStyle: {
+ borderRadius: 5,
+ color: "#83BBFF",
+ },
+ showBackground: true,
+ backgroundStyle: {
+ color: "#E6F1FF",
+ borderRadius: 5,
+ },
+ },
+ ],
+ }
+ myChart11.setOption(option48)
+ })
+}
+
+/* 污水零直排数据 */
+
+
+function myChart12(val1,val2){
+ var myChart12 = echarts.init(document.querySelector(".echart12"))
+ var option12 = {
+ tooltip: {
+ trigger: "item",
+ show: false,
+ showContent: true,
+ },
+ grid: {
+ top: 0,
+ left: 0,
+ bottom: 0,
+ },
+ series: [
+ {
+ type: "pie",
+ radius: ["60%", "80%"],
+ avoidLabelOverlap: false,
+ label: {
+ show: true,
+ },
+ itemStyle: {
+ color: "#3D9DF4",
+ },
+ emphasis: {
+ label: {
+ show: true,
+ fontSize: "40",
+ fontWeight: "bold",
+ },
+ itemStyle: {
+ shadowBlur: 10,
+ shadowOffsetX: 0,
+ shadowColor: "rgba(0, 0, 0, 0.5)",
+ },
+ },
+ labelLine: {
+ show: false,
+ },
+ data: [
+ {
+ value: val1,
+ name: val1,
+ label: {
+ position: "center",
+ fontSize: 16,
+ },
+ },
+ {
+ value: val2,
+ name: val2,
+ itemStyle: {
+ color: "#EEEEEE",
+ },
+ label: {
+ position: "center",
+ fontSize: 16,
+ },
+ },
+ ],
+ },
+ ],
+ }
+ myChart12.setOption(option12)
+}
+
+
+
+function myChart13(dataList, actualList, targetList) {
+ var myChart13 = echarts.init(document.querySelector(".echart13"))
+ var option13 = {
+ tooltip: {
+ trigger: "axis",
+ // formatter: "{b}" + "{a1}" + ": " + "{c0}",
+ },
+ legend: {
+ show: false,
+ },
+
+ grid: {
+ left: 0,
+ top: 10,
+ bottom: 10,
+ right: 0,
+ },
+ xAxis: [
+ {
+ type: "value",
+
+ axisLine: {
+ show: false,
+ },
+ axisLabel: {
+ show: false,
+ },
+ splitLine: {
+ show: false, //隐藏或显示
+ },
+ axisTick: {
+ show: false,
+ }, //坐标轴刻度
+ },
+ ],
+ yAxis: {
+ type: "category",
+ axisTick: {
+ show: false,
+ alignWithLabel: true,
+ },
+
+ axisLine: {
+ show: false,
+ },
+ data: dataList,
+ axisLabel: {
+ fontSize: 14,
+
+ verticalAlign: "bottom",
+ align: "left",
+ lineHeight: 30,
+ margin: -0,
+ color: "#6e7178",
+ },
+ },
+
+ label: {
+ show: true,
+ position: "left",
+ align: "right",
+ offset: [$(".echart43").width(), -13],
+ // formatter: "{c}个",
+ fontSize: 14,
+ color: "#6e7178",
+ },
+ series: [
+ {
+ name: "实际值",
+ type: "bar",
+
+ barWidth: 10, //柱图宽度
+
+ showBackground: true,
+ backgroundStyle: {
+ color: "#E6F1FF",
+ borderRadius: 5,
+ },
+ itemStyle: {
+ borderRadius: 5,
+ color: "#83BBFF",
+ },
+ data: actualList,
+ },
+ ],
+ }
+ myChart13.setOption(option13)
+}
+/* c处理点击事件 */
+$("#xiangmu").click(function () {
+ $("#xiangmu").css({
+ border: "1px solid #198eff",
+ color: "#0066ff",
+ background: "#d9e8ff",
+ })
+ $("#mianji").css({
+ border: "1px solid #b1afaf",
+ color: "#363a44",
+ borderLeft: "none",
+ background: "none",
+ })
+ xiangmu()
+})
+$("#mianji").click(function () {
+ $("#mianji").css({
+ border: "1px solid #198eff",
+ color: "#0066ff",
+ background: "#d9e8ff",
+ })
+ $("#xiangmu").css({
+ border: "1px solid #b1afaf",
+ color: "#363a44",
+ borderRight: "none",
+ background: "none",
+ })
+ mianji()
+})
+/* 污水零直排区 */
+function water() {
+ let urlWater = "http://118.178.224.202:8024/api/biotope"
+ $.get(urlWater, function (data) {
+ let dataList = []
+ let actualList = []
+ let targetList = []
+ let val1 = 0 , val2 = 0
+ data.data.map((item, index) => {
+ dataList.push(item.area)
+ actualList.push(item.actual)
+ targetList.push(item.target)
+ // console.log("sadas111",Number(data.data[index].actual), Number(val1))
+ val1 = Number(data.data[index].actual) + Number(val1)
+ val2 = Number(data.data[index].target) + Number(val2)
+ })
+
+
+ let actual = (val1/val2).toFixed(2) * 100
+ let aim = (1 - val1/val2).toFixed(2) * 100
+ console.log("sadas",val1,val2,actual)
+
+
+
+
+ myChart12(actual,aim)
+ myChart13(dataList, actualList, targetList)
+ $(".jindutext").html(val2)
+ })
+}
+
+/**
+ * 头部四个标题点击事件
+ */
+
+$(".top")
+ .children()
+ .click(function () {
+ $(".top").children().removeClass("cycle")
+ $(this).addClass("cycle")
+ })
diff --git a/Digitalgovernment/dandu/home2.html b/portal/Digitalgovernment/dandu/home2.html
similarity index 100%
rename from Digitalgovernment/dandu/home2.html
rename to portal/Digitalgovernment/dandu/home2.html
diff --git a/portal/Digitalgovernment/dandu/jquery.js b/portal/Digitalgovernment/dandu/jquery.js
new file mode 100644
index 0000000..8c29064
--- /dev/null
+++ b/portal/Digitalgovernment/dandu/jquery.js
@@ -0,0 +1,674 @@
+/*! jQuery v3.6.0 | (c) OpenJS Foundation and other contributors | jquery.org/license */ ! function(e, t) { "use strict"; "object" == typeof module && "object" == typeof module.exports ? module.exports = e.document ? t(e, !0) : function(e) { if (!e.document) throw new Error("jQuery requires a window with a document"); return t(e) } : t(e) }("undefined" != typeof window ? window : this, function(C, e) { "use strict"; var t = [],
+ r = Object.getPrototypeOf,
+ s = t.slice,
+ g = t.flat ? function(e) { return t.flat.call(e) } : function(e) { return t.concat.apply([], e) },
+ u = t.push,
+ i = t.indexOf,
+ n = {},
+ o = n.toString,
+ v = n.hasOwnProperty,
+ a = v.toString,
+ l = a.call(Object),
+ y = {},
+ m = function(e) { return "function" == typeof e && "number" != typeof e.nodeType && "function" != typeof e.item },
+ x = function(e) { return null != e && e === e.window },
+ E = C.document,
+ c = { type: !0, src: !0, nonce: !0, noModule: !0 };
+
+ function b(e, t, n) { var r, i, o = (n = n || E).createElement("script"); if (o.text = e, t)
+ for (r in c)(i = t[r] || t.getAttribute && t.getAttribute(r)) && o.setAttribute(r, i);
+ n.head.appendChild(o).parentNode.removeChild(o) }
+
+ function w(e) { return null == e ? e + "" : "object" == typeof e || "function" == typeof e ? n[o.call(e)] || "object" : typeof e } var f = "3.6.0",
+ S = function(e, t) { return new S.fn.init(e, t) };
+
+ function p(e) { var t = !!e && "length" in e && e.length,
+ n = w(e); return !m(e) && !x(e) && ("array" === n || 0 === t || "number" == typeof t && 0 < t && t - 1 in e) }
+ S.fn = S.prototype = { jquery: f, constructor: S, length: 0, toArray: function() { return s.call(this) }, get: function(e) { return null == e ? s.call(this) : e < 0 ? this[e + this.length] : this[e] }, pushStack: function(e) { var t = S.merge(this.constructor(), e); return t.prevObject = this, t }, each: function(e) { return S.each(this, e) }, map: function(n) { return this.pushStack(S.map(this, function(e, t) { return n.call(e, t, e) })) }, slice: function() { return this.pushStack(s.apply(this, arguments)) }, first: function() { return this.eq(0) }, last: function() { return this.eq(-1) }, even: function() { return this.pushStack(S.grep(this, function(e, t) { return (t + 1) % 2 })) }, odd: function() { return this.pushStack(S.grep(this, function(e, t) { return t % 2 })) }, eq: function(e) { var t = this.length,
+ n = +e + (e < 0 ? t : 0); return this.pushStack(0 <= n && n < t ? [this[n]] : []) }, end: function() { return this.prevObject || this.constructor() }, push: u, sort: t.sort, splice: t.splice }, S.extend = S.fn.extend = function() { var e, t, n, r, i, o, a = arguments[0] || {},
+ s = 1,
+ u = arguments.length,
+ l = !1; for ("boolean" == typeof a && (l = a, a = arguments[s] || {}, s++), "object" == typeof a || m(a) || (a = {}), s === u && (a = this, s--); s < u; s++)
+ if (null != (e = arguments[s]))
+ for (t in e) r = e[t], "__proto__" !== t && a !== r && (l && r && (S.isPlainObject(r) || (i = Array.isArray(r))) ? (n = a[t], o = i && !Array.isArray(n) ? [] : i || S.isPlainObject(n) ? n : {}, i = !1, a[t] = S.extend(l, o, r)) : void 0 !== r && (a[t] = r));
+ return a }, S.extend({ expando: "jQuery" + (f + Math.random()).replace(/\D/g, ""), isReady: !0, error: function(e) { throw new Error(e) }, noop: function() {}, isPlainObject: function(e) { var t, n; return !(!e || "[object Object]" !== o.call(e)) && (!(t = r(e)) || "function" == typeof(n = v.call(t, "constructor") && t.constructor) && a.call(n) === l) }, isEmptyObject: function(e) { var t; for (t in e) return !1; return !0 }, globalEval: function(e, t, n) { b(e, { nonce: t && t.nonce }, n) }, each: function(e, t) { var n, r = 0; if (p(e)) { for (n = e.length; r < n; r++)
+ if (!1 === t.call(e[r], r, e[r])) break } else
+ for (r in e)
+ if (!1 === t.call(e[r], r, e[r])) break; return e }, makeArray: function(e, t) { var n = t || []; return null != e && (p(Object(e)) ? S.merge(n, "string" == typeof e ? [e] : e) : u.call(n, e)), n }, inArray: function(e, t, n) { return null == t ? -1 : i.call(t, e, n) }, merge: function(e, t) { for (var n = +t.length, r = 0, i = e.length; r < n; r++) e[i++] = t[r]; return e.length = i, e }, grep: function(e, t, n) { for (var r = [], i = 0, o = e.length, a = !n; i < o; i++) !t(e[i], i) !== a && r.push(e[i]); return r }, map: function(e, t, n) { var r, i, o = 0,
+ a = []; if (p(e))
+ for (r = e.length; o < r; o++) null != (i = t(e[o], o, n)) && a.push(i);
+ else
+ for (o in e) null != (i = t(e[o], o, n)) && a.push(i); return g(a) }, guid: 1, support: y }), "function" == typeof Symbol && (S.fn[Symbol.iterator] = t[Symbol.iterator]), S.each("Boolean Number String Function Array Date RegExp Object Error Symbol".split(" "), function(e, t) { n["[object " + t + "]"] = t.toLowerCase() }); var d = function(n) { var e, d, b, o, i, h, f, g, w, u, l, T, C, a, E, v, s, c, y, S = "sizzle" + 1 * new Date,
+ p = n.document,
+ k = 0,
+ r = 0,
+ m = ue(),
+ x = ue(),
+ A = ue(),
+ N = ue(),
+ j = function(e, t) { return e === t && (l = !0), 0 },
+ D = {}.hasOwnProperty,
+ t = [],
+ q = t.pop,
+ L = t.push,
+ H = t.push,
+ O = t.slice,
+ P = function(e, t) { for (var n = 0, r = e.length; n < r; n++)
+ if (e[n] === t) return n;
+ return -1 },
+ R = "checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",
+ M = "[\\x20\\t\\r\\n\\f]",
+ I = "(?:\\\\[\\da-fA-F]{1,6}" + M + "?|\\\\[^\\r\\n\\f]|[\\w-]|[^\0-\\x7f])+",
+ W = "\\[" + M + "*(" + I + ")(?:" + M + "*([*^$|!~]?=)" + M + "*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|(" + I + "))|)" + M + "*\\]",
+ F = ":(" + I + ")(?:\\((('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|((?:\\\\.|[^\\\\()[\\]]|" + W + ")*)|.*)\\)|)",
+ B = new RegExp(M + "+", "g"),
+ $ = new RegExp("^" + M + "+|((?:^|[^\\\\])(?:\\\\.)*)" + M + "+$", "g"),
+ _ = new RegExp("^" + M + "*," + M + "*"),
+ z = new RegExp("^" + M + "*([>+~]|" + M + ")" + M + "*"),
+ U = new RegExp(M + "|>"),
+ X = new RegExp(F),
+ V = new RegExp("^" + I + "$"),
+ G = { ID: new RegExp("^#(" + I + ")"), CLASS: new RegExp("^\\.(" + I + ")"), TAG: new RegExp("^(" + I + "|[*])"), ATTR: new RegExp("^" + W), PSEUDO: new RegExp("^" + F), CHILD: new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\(" + M + "*(even|odd|(([+-]|)(\\d*)n|)" + M + "*(?:([+-]|)" + M + "*(\\d+)|))" + M + "*\\)|)", "i"), bool: new RegExp("^(?:" + R + ")$", "i"), needsContext: new RegExp("^" + M + "*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\(" + M + "*((?:-\\d)?\\d*)" + M + "*\\)|)(?=[^-]|$)", "i") },
+ Y = /HTML$/i,
+ Q = /^(?:input|select|textarea|button)$/i,
+ J = /^h\d$/i,
+ K = /^[^{]+\{\s*\[native \w/,
+ Z = /^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,
+ ee = /[+~]/,
+ te = new RegExp("\\\\[\\da-fA-F]{1,6}" + M + "?|\\\\([^\\r\\n\\f])", "g"),
+ ne = function(e, t) { var n = "0x" + e.slice(1) - 65536; return t || (n < 0 ? String.fromCharCode(n + 65536) : String.fromCharCode(n >> 10 | 55296, 1023 & n | 56320)) },
+ re = /([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g,
+ ie = function(e, t) { return t ? "\0" === e ? "\ufffd" : e.slice(0, -1) + "\\" + e.charCodeAt(e.length - 1).toString(16) + " " : "\\" + e },
+ oe = function() { T() },
+ ae = be(function(e) { return !0 === e.disabled && "fieldset" === e.nodeName.toLowerCase() }, { dir: "parentNode", next: "legend" }); try { H.apply(t = O.call(p.childNodes), p.childNodes), t[p.childNodes.length].nodeType } catch (e) { H = { apply: t.length ? function(e, t) { L.apply(e, O.call(t)) } : function(e, t) { var n = e.length,
+ r = 0; while (e[n++] = t[r++]);
+ e.length = n - 1 } } }
+
+ function se(t, e, n, r) { var i, o, a, s, u, l, c, f = e && e.ownerDocument,
+ p = e ? e.nodeType : 9; if (n = n || [], "string" != typeof t || !t || 1 !== p && 9 !== p && 11 !== p) return n; if (!r && (T(e), e = e || C, E)) { if (11 !== p && (u = Z.exec(t)))
+ if (i = u[1]) { if (9 === p) { if (!(a = e.getElementById(i))) return n; if (a.id === i) return n.push(a), n } else if (f && (a = f.getElementById(i)) && y(e, a) && a.id === i) return n.push(a), n } else { if (u[2]) return H.apply(n, e.getElementsByTagName(t)), n; if ((i = u[3]) && d.getElementsByClassName && e.getElementsByClassName) return H.apply(n, e.getElementsByClassName(i)), n }
+ if (d.qsa && !N[t + " "] && (!v || !v.test(t)) && (1 !== p || "object" !== e.nodeName.toLowerCase())) { if (c = t, f = e, 1 === p && (U.test(t) || z.test(t))) {
+ (f = ee.test(t) && ye(e.parentNode) || e) === e && d.scope || ((s = e.getAttribute("id")) ? s = s.replace(re, ie) : e.setAttribute("id", s = S)), o = (l = h(t)).length; while (o--) l[o] = (s ? "#" + s : ":scope") + " " + xe(l[o]);
+ c = l.join(",") } try { return H.apply(n, f.querySelectorAll(c)), n } catch (e) { N(t, !0) } finally { s === S && e.removeAttribute("id") } } } return g(t.replace($, "$1"), e, n, r) }
+
+ function ue() { var r = []; return function e(t, n) { return r.push(t + " ") > b.cacheLength && delete e[r.shift()], e[t + " "] = n } }
+
+ function le(e) { return e[S] = !0, e }
+
+ function ce(e) { var t = C.createElement("fieldset"); try { return !!e(t) } catch (e) { return !1 } finally { t.parentNode && t.parentNode.removeChild(t), t = null } }
+
+ function fe(e, t) { var n = e.split("|"),
+ r = n.length; while (r--) b.attrHandle[n[r]] = t }
+
+ function pe(e, t) { var n = t && e,
+ r = n && 1 === e.nodeType && 1 === t.nodeType && e.sourceIndex - t.sourceIndex; if (r) return r; if (n)
+ while (n = n.nextSibling)
+ if (n === t) return -1;
+ return e ? 1 : -1 }
+
+ function de(t) { return function(e) { return "input" === e.nodeName.toLowerCase() && e.type === t } }
+
+ function he(n) { return function(e) { var t = e.nodeName.toLowerCase(); return ("input" === t || "button" === t) && e.type === n } }
+
+ function ge(t) { return function(e) { return "form" in e ? e.parentNode && !1 === e.disabled ? "label" in e ? "label" in e.parentNode ? e.parentNode.disabled === t : e.disabled === t : e.isDisabled === t || e.isDisabled !== !t && ae(e) === t : e.disabled === t : "label" in e && e.disabled === t } }
+
+ function ve(a) { return le(function(o) { return o = +o, le(function(e, t) { var n, r = a([], e.length, o),
+ i = r.length; while (i--) e[n = r[i]] && (e[n] = !(t[n] = e[n])) }) }) }
+
+ function ye(e) { return e && "undefined" != typeof e.getElementsByTagName && e } for (e in d = se.support = {}, i = se.isXML = function(e) { var t = e && e.namespaceURI,
+ n = e && (e.ownerDocument || e).documentElement; return !Y.test(t || n && n.nodeName || "HTML") }, T = se.setDocument = function(e) { var t, n, r = e ? e.ownerDocument || e : p; return r != C && 9 === r.nodeType && r.documentElement && (a = (C = r).documentElement, E = !i(C), p != C && (n = C.defaultView) && n.top !== n && (n.addEventListener ? n.addEventListener("unload", oe, !1) : n.attachEvent && n.attachEvent("onunload", oe)), d.scope = ce(function(e) { return a.appendChild(e).appendChild(C.createElement("div")), "undefined" != typeof e.querySelectorAll && !e.querySelectorAll(":scope fieldset div").length }), d.attributes = ce(function(e) { return e.className = "i", !e.getAttribute("className") }), d.getElementsByTagName = ce(function(e) { return e.appendChild(C.createComment("")), !e.getElementsByTagName("*").length }), d.getElementsByClassName = K.test(C.getElementsByClassName), d.getById = ce(function(e) { return a.appendChild(e).id = S, !C.getElementsByName || !C.getElementsByName(S).length }), d.getById ? (b.filter.ID = function(e) { var t = e.replace(te, ne); return function(e) { return e.getAttribute("id") === t } }, b.find.ID = function(e, t) { if ("undefined" != typeof t.getElementById && E) { var n = t.getElementById(e); return n ? [n] : [] } }) : (b.filter.ID = function(e) { var n = e.replace(te, ne); return function(e) { var t = "undefined" != typeof e.getAttributeNode && e.getAttributeNode("id"); return t && t.value === n } }, b.find.ID = function(e, t) { if ("undefined" != typeof t.getElementById && E) { var n, r, i, o = t.getElementById(e); if (o) { if ((n = o.getAttributeNode("id")) && n.value === e) return [o];
+ i = t.getElementsByName(e), r = 0; while (o = i[r++])
+ if ((n = o.getAttributeNode("id")) && n.value === e) return [o] } return [] } }), b.find.TAG = d.getElementsByTagName ? function(e, t) { return "undefined" != typeof t.getElementsByTagName ? t.getElementsByTagName(e) : d.qsa ? t.querySelectorAll(e) : void 0 } : function(e, t) { var n, r = [],
+ i = 0,
+ o = t.getElementsByTagName(e); if ("*" === e) { while (n = o[i++]) 1 === n.nodeType && r.push(n); return r } return o }, b.find.CLASS = d.getElementsByClassName && function(e, t) { if ("undefined" != typeof t.getElementsByClassName && E) return t.getElementsByClassName(e) }, s = [], v = [], (d.qsa = K.test(C.querySelectorAll)) && (ce(function(e) { var t;
+ a.appendChild(e).innerHTML = "", e.querySelectorAll("[msallowcapture^='']").length && v.push("[*^$]=" + M + "*(?:''|\"\")"), e.querySelectorAll("[selected]").length || v.push("\\[" + M + "*(?:value|" + R + ")"), e.querySelectorAll("[id~=" + S + "-]").length || v.push("~="), (t = C.createElement("input")).setAttribute("name", ""), e.appendChild(t), e.querySelectorAll("[name='']").length || v.push("\\[" + M + "*name" + M + "*=" + M + "*(?:''|\"\")"), e.querySelectorAll(":checked").length || v.push(":checked"), e.querySelectorAll("a#" + S + "+*").length || v.push(".#.+[+~]"), e.querySelectorAll("\\\f"), v.push("[\\r\\n\\f]") }), ce(function(e) { e.innerHTML = ""; var t = C.createElement("input");
+ t.setAttribute("type", "hidden"), e.appendChild(t).setAttribute("name", "D"), e.querySelectorAll("[name=d]").length && v.push("name" + M + "*[*^$|!~]?="), 2 !== e.querySelectorAll(":enabled").length && v.push(":enabled", ":disabled"), a.appendChild(e).disabled = !0, 2 !== e.querySelectorAll(":disabled").length && v.push(":enabled", ":disabled"), e.querySelectorAll("*,:x"), v.push(",.*:") })), (d.matchesSelector = K.test(c = a.matches || a.webkitMatchesSelector || a.mozMatchesSelector || a.oMatchesSelector || a.msMatchesSelector)) && ce(function(e) { d.disconnectedMatch = c.call(e, "*"), c.call(e, "[s!='']:x"), s.push("!=", F) }), v = v.length && new RegExp(v.join("|")), s = s.length && new RegExp(s.join("|")), t = K.test(a.compareDocumentPosition), y = t || K.test(a.contains) ? function(e, t) { var n = 9 === e.nodeType ? e.documentElement : e,
+ r = t && t.parentNode; return e === r || !(!r || 1 !== r.nodeType || !(n.contains ? n.contains(r) : e.compareDocumentPosition && 16 & e.compareDocumentPosition(r))) } : function(e, t) { if (t)
+ while (t = t.parentNode)
+ if (t === e) return !0;
+ return !1 }, j = t ? function(e, t) { if (e === t) return l = !0, 0; var n = !e.compareDocumentPosition - !t.compareDocumentPosition; return n || (1 & (n = (e.ownerDocument || e) == (t.ownerDocument || t) ? e.compareDocumentPosition(t) : 1) || !d.sortDetached && t.compareDocumentPosition(e) === n ? e == C || e.ownerDocument == p && y(p, e) ? -1 : t == C || t.ownerDocument == p && y(p, t) ? 1 : u ? P(u, e) - P(u, t) : 0 : 4 & n ? -1 : 1) } : function(e, t) { if (e === t) return l = !0, 0; var n, r = 0,
+ i = e.parentNode,
+ o = t.parentNode,
+ a = [e],
+ s = [t]; if (!i || !o) return e == C ? -1 : t == C ? 1 : i ? -1 : o ? 1 : u ? P(u, e) - P(u, t) : 0; if (i === o) return pe(e, t);
+ n = e; while (n = n.parentNode) a.unshift(n);
+ n = t; while (n = n.parentNode) s.unshift(n); while (a[r] === s[r]) r++; return r ? pe(a[r], s[r]) : a[r] == p ? -1 : s[r] == p ? 1 : 0 }), C }, se.matches = function(e, t) { return se(e, null, null, t) }, se.matchesSelector = function(e, t) { if (T(e), d.matchesSelector && E && !N[t + " "] && (!s || !s.test(t)) && (!v || !v.test(t))) try { var n = c.call(e, t); if (n || d.disconnectedMatch || e.document && 11 !== e.document.nodeType) return n } catch (e) { N(t, !0) }
+ return 0 < se(t, C, null, [e]).length }, se.contains = function(e, t) { return (e.ownerDocument || e) != C && T(e), y(e, t) }, se.attr = function(e, t) {
+ (e.ownerDocument || e) != C && T(e); var n = b.attrHandle[t.toLowerCase()],
+ r = n && D.call(b.attrHandle, t.toLowerCase()) ? n(e, t, !E) : void 0; return void 0 !== r ? r : d.attributes || !E ? e.getAttribute(t) : (r = e.getAttributeNode(t)) && r.specified ? r.value : null }, se.escape = function(e) { return (e + "").replace(re, ie) }, se.error = function(e) { throw new Error("Syntax error, unrecognized expression: " + e) }, se.uniqueSort = function(e) { var t, n = [],
+ r = 0,
+ i = 0; if (l = !d.detectDuplicates, u = !d.sortStable && e.slice(0), e.sort(j), l) { while (t = e[i++]) t === e[i] && (r = n.push(i)); while (r--) e.splice(n[r], 1) } return u = null, e }, o = se.getText = function(e) { var t, n = "",
+ r = 0,
+ i = e.nodeType; if (i) { if (1 === i || 9 === i || 11 === i) { if ("string" == typeof e.textContent) return e.textContent; for (e = e.firstChild; e; e = e.nextSibling) n += o(e) } else if (3 === i || 4 === i) return e.nodeValue } else
+ while (t = e[r++]) n += o(t); return n }, (b = se.selectors = { cacheLength: 50, createPseudo: le, match: G, attrHandle: {}, find: {}, relative: { ">": { dir: "parentNode", first: !0 }, " ": { dir: "parentNode" }, "+": { dir: "previousSibling", first: !0 }, "~": { dir: "previousSibling" } }, preFilter: { ATTR: function(e) { return e[1] = e[1].replace(te, ne), e[3] = (e[3] || e[4] || e[5] || "").replace(te, ne), "~=" === e[2] && (e[3] = " " + e[3] + " "), e.slice(0, 4) }, CHILD: function(e) { return e[1] = e[1].toLowerCase(), "nth" === e[1].slice(0, 3) ? (e[3] || se.error(e[0]), e[4] = +(e[4] ? e[5] + (e[6] || 1) : 2 * ("even" === e[3] || "odd" === e[3])), e[5] = +(e[7] + e[8] || "odd" === e[3])) : e[3] && se.error(e[0]), e }, PSEUDO: function(e) { var t, n = !e[6] && e[2]; return G.CHILD.test(e[0]) ? null : (e[3] ? e[2] = e[4] || e[5] || "" : n && X.test(n) && (t = h(n, !0)) && (t = n.indexOf(")", n.length - t) - n.length) && (e[0] = e[0].slice(0, t), e[2] = n.slice(0, t)), e.slice(0, 3)) } }, filter: { TAG: function(e) { var t = e.replace(te, ne).toLowerCase(); return "*" === e ? function() { return !0 } : function(e) { return e.nodeName && e.nodeName.toLowerCase() === t } }, CLASS: function(e) { var t = m[e + " "]; return t || (t = new RegExp("(^|" + M + ")" + e + "(" + M + "|$)")) && m(e, function(e) { return t.test("string" == typeof e.className && e.className || "undefined" != typeof e.getAttribute && e.getAttribute("class") || "") }) }, ATTR: function(n, r, i) { return function(e) { var t = se.attr(e, n); return null == t ? "!=" === r : !r || (t += "", "=" === r ? t === i : "!=" === r ? t !== i : "^=" === r ? i && 0 === t.indexOf(i) : "*=" === r ? i && -1 < t.indexOf(i) : "$=" === r ? i && t.slice(-i.length) === i : "~=" === r ? -1 < (" " + t.replace(B, " ") + " ").indexOf(i) : "|=" === r && (t === i || t.slice(0, i.length + 1) === i + "-")) } }, CHILD: function(h, e, t, g, v) { var y = "nth" !== h.slice(0, 3),
+ m = "last" !== h.slice(-4),
+ x = "of-type" === e; return 1 === g && 0 === v ? function(e) { return !!e.parentNode } : function(e, t, n) { var r, i, o, a, s, u, l = y !== m ? "nextSibling" : "previousSibling",
+ c = e.parentNode,
+ f = x && e.nodeName.toLowerCase(),
+ p = !n && !x,
+ d = !1; if (c) { if (y) { while (l) { a = e; while (a = a[l])
+ if (x ? a.nodeName.toLowerCase() === f : 1 === a.nodeType) return !1;
+ u = l = "only" === h && !u && "nextSibling" } return !0 } if (u = [m ? c.firstChild : c.lastChild], m && p) { d = (s = (r = (i = (o = (a = c)[S] || (a[S] = {}))[a.uniqueID] || (o[a.uniqueID] = {}))[h] || [])[0] === k && r[1]) && r[2], a = s && c.childNodes[s]; while (a = ++s && a && a[l] || (d = s = 0) || u.pop())
+ if (1 === a.nodeType && ++d && a === e) { i[h] = [k, s, d]; break } } else if (p && (d = s = (r = (i = (o = (a = e)[S] || (a[S] = {}))[a.uniqueID] || (o[a.uniqueID] = {}))[h] || [])[0] === k && r[1]), !1 === d)
+ while (a = ++s && a && a[l] || (d = s = 0) || u.pop())
+ if ((x ? a.nodeName.toLowerCase() === f : 1 === a.nodeType) && ++d && (p && ((i = (o = a[S] || (a[S] = {}))[a.uniqueID] || (o[a.uniqueID] = {}))[h] = [k, d]), a === e)) break;
+ return (d -= v) === g || d % g == 0 && 0 <= d / g } } }, PSEUDO: function(e, o) { var t, a = b.pseudos[e] || b.setFilters[e.toLowerCase()] || se.error("unsupported pseudo: " + e); return a[S] ? a(o) : 1 < a.length ? (t = [e, e, "", o], b.setFilters.hasOwnProperty(e.toLowerCase()) ? le(function(e, t) { var n, r = a(e, o),
+ i = r.length; while (i--) e[n = P(e, r[i])] = !(t[n] = r[i]) }) : function(e) { return a(e, 0, t) }) : a } }, pseudos: { not: le(function(e) { var r = [],
+ i = [],
+ s = f(e.replace($, "$1")); return s[S] ? le(function(e, t, n, r) { var i, o = s(e, null, r, []),
+ a = e.length; while (a--)(i = o[a]) && (e[a] = !(t[a] = i)) }) : function(e, t, n) { return r[0] = e, s(r, null, n, i), r[0] = null, !i.pop() } }), has: le(function(t) { return function(e) { return 0 < se(t, e).length } }), contains: le(function(t) { return t = t.replace(te, ne),
+ function(e) { return -1 < (e.textContent || o(e)).indexOf(t) } }), lang: le(function(n) { return V.test(n || "") || se.error("unsupported lang: " + n), n = n.replace(te, ne).toLowerCase(),
+ function(e) { var t;
+ do { if (t = E ? e.lang : e.getAttribute("xml:lang") || e.getAttribute("lang")) return (t = t.toLowerCase()) === n || 0 === t.indexOf(n + "-") } while ((e = e.parentNode) && 1 === e.nodeType); return !1 } }), target: function(e) { var t = n.location && n.location.hash; return t && t.slice(1) === e.id }, root: function(e) { return e === a }, focus: function(e) { return e === C.activeElement && (!C.hasFocus || C.hasFocus()) && !!(e.type || e.href || ~e.tabIndex) }, enabled: ge(!1), disabled: ge(!0), checked: function(e) { var t = e.nodeName.toLowerCase(); return "input" === t && !!e.checked || "option" === t && !!e.selected }, selected: function(e) { return e.parentNode && e.parentNode.selectedIndex, !0 === e.selected }, empty: function(e) { for (e = e.firstChild; e; e = e.nextSibling)
+ if (e.nodeType < 6) return !1;
+ return !0 }, parent: function(e) { return !b.pseudos.empty(e) }, header: function(e) { return J.test(e.nodeName) }, input: function(e) { return Q.test(e.nodeName) }, button: function(e) { var t = e.nodeName.toLowerCase(); return "input" === t && "button" === e.type || "button" === t }, text: function(e) { var t; return "input" === e.nodeName.toLowerCase() && "text" === e.type && (null == (t = e.getAttribute("type")) || "text" === t.toLowerCase()) }, first: ve(function() { return [0] }), last: ve(function(e, t) { return [t - 1] }), eq: ve(function(e, t, n) { return [n < 0 ? n + t : n] }), even: ve(function(e, t) { for (var n = 0; n < t; n += 2) e.push(n); return e }), odd: ve(function(e, t) { for (var n = 1; n < t; n += 2) e.push(n); return e }), lt: ve(function(e, t, n) { for (var r = n < 0 ? n + t : t < n ? t : n; 0 <= --r;) e.push(r); return e }), gt: ve(function(e, t, n) { for (var r = n < 0 ? n + t : n; ++r < t;) e.push(r); return e }) } }).pseudos.nth = b.pseudos.eq, { radio: !0, checkbox: !0, file: !0, password: !0, image: !0 }) b.pseudos[e] = de(e); for (e in { submit: !0, reset: !0 }) b.pseudos[e] = he(e);
+
+ function me() {}
+
+ function xe(e) { for (var t = 0, n = e.length, r = ""; t < n; t++) r += e[t].value; return r }
+
+ function be(s, e, t) { var u = e.dir,
+ l = e.next,
+ c = l || u,
+ f = t && "parentNode" === c,
+ p = r++; return e.first ? function(e, t, n) { while (e = e[u])
+ if (1 === e.nodeType || f) return s(e, t, n);
+ return !1 } : function(e, t, n) { var r, i, o, a = [k, p]; if (n) { while (e = e[u])
+ if ((1 === e.nodeType || f) && s(e, t, n)) return !0 } else
+ while (e = e[u])
+ if (1 === e.nodeType || f)
+ if (i = (o = e[S] || (e[S] = {}))[e.uniqueID] || (o[e.uniqueID] = {}), l && l === e.nodeName.toLowerCase()) e = e[u] || e;
+ else { if ((r = i[c]) && r[0] === k && r[1] === p) return a[2] = r[2]; if ((i[c] = a)[2] = s(e, t, n)) return !0 } return !1 } }
+
+ function we(i) { return 1 < i.length ? function(e, t, n) { var r = i.length; while (r--)
+ if (!i[r](e, t, n)) return !1;
+ return !0 } : i[0] }
+
+ function Te(e, t, n, r, i) { for (var o, a = [], s = 0, u = e.length, l = null != t; s < u; s++)(o = e[s]) && (n && !n(o, r, i) || (a.push(o), l && t.push(s))); return a }
+
+ function Ce(d, h, g, v, y, e) { return v && !v[S] && (v = Ce(v)), y && !y[S] && (y = Ce(y, e)), le(function(e, t, n, r) { var i, o, a, s = [],
+ u = [],
+ l = t.length,
+ c = e || function(e, t, n) { for (var r = 0, i = t.length; r < i; r++) se(e, t[r], n); return n }(h || "*", n.nodeType ? [n] : n, []),
+ f = !d || !e && h ? c : Te(c, s, d, n, r),
+ p = g ? y || (e ? d : l || v) ? [] : t : f; if (g && g(f, p, n, r), v) { i = Te(p, u), v(i, [], n, r), o = i.length; while (o--)(a = i[o]) && (p[u[o]] = !(f[u[o]] = a)) } if (e) { if (y || d) { if (y) { i = [], o = p.length; while (o--)(a = p[o]) && i.push(f[o] = a);
+ y(null, p = [], i, r) }
+ o = p.length; while (o--)(a = p[o]) && -1 < (i = y ? P(e, a) : s[o]) && (e[i] = !(t[i] = a)) } } else p = Te(p === t ? p.splice(l, p.length) : p), y ? y(null, t, p, r) : H.apply(t, p) }) }
+
+ function Ee(e) { for (var i, t, n, r = e.length, o = b.relative[e[0].type], a = o || b.relative[" "], s = o ? 1 : 0, u = be(function(e) { return e === i }, a, !0), l = be(function(e) { return -1 < P(i, e) }, a, !0), c = [function(e, t, n) { var r = !o && (n || t !== w) || ((i = t).nodeType ? u(e, t, n) : l(e, t, n)); return i = null, r }]; s < r; s++)
+ if (t = b.relative[e[s].type]) c = [be(we(c), t)];
+ else { if ((t = b.filter[e[s].type].apply(null, e[s].matches))[S]) { for (n = ++s; n < r; n++)
+ if (b.relative[e[n].type]) break;
+ return Ce(1 < s && we(c), 1 < s && xe(e.slice(0, s - 1).concat({ value: " " === e[s - 2].type ? "*" : "" })).replace($, "$1"), t, s < n && Ee(e.slice(s, n)), n < r && Ee(e = e.slice(n)), n < r && xe(e)) }
+ c.push(t) }
+ return we(c) } return me.prototype = b.filters = b.pseudos, b.setFilters = new me, h = se.tokenize = function(e, t) { var n, r, i, o, a, s, u, l = x[e + " "]; if (l) return t ? 0 : l.slice(0);
+ a = e, s = [], u = b.preFilter; while (a) { for (o in n && !(r = _.exec(a)) || (r && (a = a.slice(r[0].length) || a), s.push(i = [])), n = !1, (r = z.exec(a)) && (n = r.shift(), i.push({ value: n, type: r[0].replace($, " ") }), a = a.slice(n.length)), b.filter) !(r = G[o].exec(a)) || u[o] && !(r = u[o](r)) || (n = r.shift(), i.push({ value: n, type: o, matches: r }), a = a.slice(n.length)); if (!n) break } return t ? a.length : a ? se.error(e) : x(e, s).slice(0) }, f = se.compile = function(e, t) { var n, v, y, m, x, r, i = [],
+ o = [],
+ a = A[e + " "]; if (!a) { t || (t = h(e)), n = t.length; while (n--)(a = Ee(t[n]))[S] ? i.push(a) : o.push(a);
+ (a = A(e, (v = o, m = 0 < (y = i).length, x = 0 < v.length, r = function(e, t, n, r, i) { var o, a, s, u = 0,
+ l = "0",
+ c = e && [],
+ f = [],
+ p = w,
+ d = e || x && b.find.TAG("*", i),
+ h = k += null == p ? 1 : Math.random() || .1,
+ g = d.length; for (i && (w = t == C || t || i); l !== g && null != (o = d[l]); l++) { if (x && o) { a = 0, t || o.ownerDocument == C || (T(o), n = !E); while (s = v[a++])
+ if (s(o, t || C, n)) { r.push(o); break }
+ i && (k = h) }
+ m && ((o = !s && o) && u--, e && c.push(o)) } if (u += l, m && l !== u) { a = 0; while (s = y[a++]) s(c, f, t, n); if (e) { if (0 < u)
+ while (l--) c[l] || f[l] || (f[l] = q.call(r));
+ f = Te(f) }
+ H.apply(r, f), i && !e && 0 < f.length && 1 < u + y.length && se.uniqueSort(r) } return i && (k = h, w = p), c }, m ? le(r) : r))).selector = e } return a }, g = se.select = function(e, t, n, r) { var i, o, a, s, u, l = "function" == typeof e && e,
+ c = !r && h(e = l.selector || e); if (n = n || [], 1 === c.length) { if (2 < (o = c[0] = c[0].slice(0)).length && "ID" === (a = o[0]).type && 9 === t.nodeType && E && b.relative[o[1].type]) { if (!(t = (b.find.ID(a.matches[0].replace(te, ne), t) || [])[0])) return n;
+ l && (t = t.parentNode), e = e.slice(o.shift().value.length) }
+ i = G.needsContext.test(e) ? 0 : o.length; while (i--) { if (a = o[i], b.relative[s = a.type]) break; if ((u = b.find[s]) && (r = u(a.matches[0].replace(te, ne), ee.test(o[0].type) && ye(t.parentNode) || t))) { if (o.splice(i, 1), !(e = r.length && xe(o))) return H.apply(n, r), n; break } } } return (l || f(e, c))(r, t, !E, n, !t || ee.test(e) && ye(t.parentNode) || t), n }, d.sortStable = S.split("").sort(j).join("") === S, d.detectDuplicates = !!l, T(), d.sortDetached = ce(function(e) { return 1 & e.compareDocumentPosition(C.createElement("fieldset")) }), ce(function(e) { return e.innerHTML = "", "#" === e.firstChild.getAttribute("href") }) || fe("type|href|height|width", function(e, t, n) { if (!n) return e.getAttribute(t, "type" === t.toLowerCase() ? 1 : 2) }), d.attributes && ce(function(e) { return e.innerHTML = "", e.firstChild.setAttribute("value", ""), "" === e.firstChild.getAttribute("value") }) || fe("value", function(e, t, n) { if (!n && "input" === e.nodeName.toLowerCase()) return e.defaultValue }), ce(function(e) { return null == e.getAttribute("disabled") }) || fe(R, function(e, t, n) { var r; if (!n) return !0 === e[t] ? t.toLowerCase() : (r = e.getAttributeNode(t)) && r.specified ? r.value : null }), se }(C);
+ S.find = d, S.expr = d.selectors, S.expr[":"] = S.expr.pseudos, S.uniqueSort = S.unique = d.uniqueSort, S.text = d.getText, S.isXMLDoc = d.isXML, S.contains = d.contains, S.escapeSelector = d.escape; var h = function(e, t, n) { var r = [],
+ i = void 0 !== n; while ((e = e[t]) && 9 !== e.nodeType)
+ if (1 === e.nodeType) { if (i && S(e).is(n)) break;
+ r.push(e) }
+ return r },
+ T = function(e, t) { for (var n = []; e; e = e.nextSibling) 1 === e.nodeType && e !== t && n.push(e); return n },
+ k = S.expr.match.needsContext;
+
+ function A(e, t) { return e.nodeName && e.nodeName.toLowerCase() === t.toLowerCase() } var N = /^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i;
+
+ function j(e, n, r) { return m(n) ? S.grep(e, function(e, t) { return !!n.call(e, t, e) !== r }) : n.nodeType ? S.grep(e, function(e) { return e === n !== r }) : "string" != typeof n ? S.grep(e, function(e) { return -1 < i.call(n, e) !== r }) : S.filter(n, e, r) }
+ S.filter = function(e, t, n) { var r = t[0]; return n && (e = ":not(" + e + ")"), 1 === t.length && 1 === r.nodeType ? S.find.matchesSelector(r, e) ? [r] : [] : S.find.matches(e, S.grep(t, function(e) { return 1 === e.nodeType })) }, S.fn.extend({ find: function(e) { var t, n, r = this.length,
+ i = this; if ("string" != typeof e) return this.pushStack(S(e).filter(function() { for (t = 0; t < r; t++)
+ if (S.contains(i[t], this)) return !0 })); for (n = this.pushStack([]), t = 0; t < r; t++) S.find(e, i[t], n); return 1 < r ? S.uniqueSort(n) : n }, filter: function(e) { return this.pushStack(j(this, e || [], !1)) }, not: function(e) { return this.pushStack(j(this, e || [], !0)) }, is: function(e) { return !!j(this, "string" == typeof e && k.test(e) ? S(e) : e || [], !1).length } }); var D, q = /^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/;
+ (S.fn.init = function(e, t, n) { var r, i; if (!e) return this; if (n = n || D, "string" == typeof e) { if (!(r = "<" === e[0] && ">" === e[e.length - 1] && 3 <= e.length ? [null, e, null] : q.exec(e)) || !r[1] && t) return !t || t.jquery ? (t || n).find(e) : this.constructor(t).find(e); if (r[1]) { if (t = t instanceof S ? t[0] : t, S.merge(this, S.parseHTML(r[1], t && t.nodeType ? t.ownerDocument || t : E, !0)), N.test(r[1]) && S.isPlainObject(t))
+ for (r in t) m(this[r]) ? this[r](t[r]) : this.attr(r, t[r]); return this } return (i = E.getElementById(r[2])) && (this[0] = i, this.length = 1), this } return e.nodeType ? (this[0] = e, this.length = 1, this) : m(e) ? void 0 !== n.ready ? n.ready(e) : e(S) : S.makeArray(e, this) }).prototype = S.fn, D = S(E); var L = /^(?:parents|prev(?:Until|All))/,
+ H = { children: !0, contents: !0, next: !0, prev: !0 };
+
+ function O(e, t) { while ((e = e[t]) && 1 !== e.nodeType); return e }
+ S.fn.extend({ has: function(e) { var t = S(e, this),
+ n = t.length; return this.filter(function() { for (var e = 0; e < n; e++)
+ if (S.contains(this, t[e])) return !0 }) }, closest: function(e, t) { var n, r = 0,
+ i = this.length,
+ o = [],
+ a = "string" != typeof e && S(e); if (!k.test(e))
+ for (; r < i; r++)
+ for (n = this[r]; n && n !== t; n = n.parentNode)
+ if (n.nodeType < 11 && (a ? -1 < a.index(n) : 1 === n.nodeType && S.find.matchesSelector(n, e))) { o.push(n); break }
+ return this.pushStack(1 < o.length ? S.uniqueSort(o) : o) }, index: function(e) { return e ? "string" == typeof e ? i.call(S(e), this[0]) : i.call(this, e.jquery ? e[0] : e) : this[0] && this[0].parentNode ? this.first().prevAll().length : -1 }, add: function(e, t) { return this.pushStack(S.uniqueSort(S.merge(this.get(), S(e, t)))) }, addBack: function(e) { return this.add(null == e ? this.prevObject : this.prevObject.filter(e)) } }), S.each({ parent: function(e) { var t = e.parentNode; return t && 11 !== t.nodeType ? t : null }, parents: function(e) { return h(e, "parentNode") }, parentsUntil: function(e, t, n) { return h(e, "parentNode", n) }, next: function(e) { return O(e, "nextSibling") }, prev: function(e) { return O(e, "previousSibling") }, nextAll: function(e) { return h(e, "nextSibling") }, prevAll: function(e) { return h(e, "previousSibling") }, nextUntil: function(e, t, n) { return h(e, "nextSibling", n) }, prevUntil: function(e, t, n) { return h(e, "previousSibling", n) }, siblings: function(e) { return T((e.parentNode || {}).firstChild, e) }, children: function(e) { return T(e.firstChild) }, contents: function(e) { return null != e.contentDocument && r(e.contentDocument) ? e.contentDocument : (A(e, "template") && (e = e.content || e), S.merge([], e.childNodes)) } }, function(r, i) { S.fn[r] = function(e, t) { var n = S.map(this, i, e); return "Until" !== r.slice(-5) && (t = e), t && "string" == typeof t && (n = S.filter(t, n)), 1 < this.length && (H[r] || S.uniqueSort(n), L.test(r) && n.reverse()), this.pushStack(n) } }); var P = /[^\x20\t\r\n\f]+/g;
+
+ function R(e) { return e }
+
+ function M(e) { throw e }
+
+ function I(e, t, n, r) { var i; try { e && m(i = e.promise) ? i.call(e).done(t).fail(n) : e && m(i = e.then) ? i.call(e, t, n) : t.apply(void 0, [e].slice(r)) } catch (e) { n.apply(void 0, [e]) } }
+ S.Callbacks = function(r) { var e, n;
+ r = "string" == typeof r ? (e = r, n = {}, S.each(e.match(P) || [], function(e, t) { n[t] = !0 }), n) : S.extend({}, r); var i, t, o, a, s = [],
+ u = [],
+ l = -1,
+ c = function() { for (a = a || r.once, o = i = !0; u.length; l = -1) { t = u.shift(); while (++l < s.length) !1 === s[l].apply(t[0], t[1]) && r.stopOnFalse && (l = s.length, t = !1) }
+ r.memory || (t = !1), i = !1, a && (s = t ? [] : "") },
+ f = { add: function() { return s && (t && !i && (l = s.length - 1, u.push(t)), function n(e) { S.each(e, function(e, t) { m(t) ? r.unique && f.has(t) || s.push(t) : t && t.length && "string" !== w(t) && n(t) }) }(arguments), t && !i && c()), this }, remove: function() { return S.each(arguments, function(e, t) { var n; while (-1 < (n = S.inArray(t, s, n))) s.splice(n, 1), n <= l && l-- }), this }, has: function(e) { return e ? -1 < S.inArray(e, s) : 0 < s.length }, empty: function() { return s && (s = []), this }, disable: function() { return a = u = [], s = t = "", this }, disabled: function() { return !s }, lock: function() { return a = u = [], t || i || (s = t = ""), this }, locked: function() { return !!a }, fireWith: function(e, t) { return a || (t = [e, (t = t || []).slice ? t.slice() : t], u.push(t), i || c()), this }, fire: function() { return f.fireWith(this, arguments), this }, fired: function() { return !!o } }; return f }, S.extend({ Deferred: function(e) { var o = [
+ ["notify", "progress", S.Callbacks("memory"), S.Callbacks("memory"), 2],
+ ["resolve", "done", S.Callbacks("once memory"), S.Callbacks("once memory"), 0, "resolved"],
+ ["reject", "fail", S.Callbacks("once memory"), S.Callbacks("once memory"), 1, "rejected"]
+ ],
+ i = "pending",
+ a = { state: function() { return i }, always: function() { return s.done(arguments).fail(arguments), this }, "catch": function(e) { return a.then(null, e) }, pipe: function() { var i = arguments; return S.Deferred(function(r) { S.each(o, function(e, t) { var n = m(i[t[4]]) && i[t[4]];
+ s[t[1]](function() { var e = n && n.apply(this, arguments);
+ e && m(e.promise) ? e.promise().progress(r.notify).done(r.resolve).fail(r.reject) : r[t[0] + "With"](this, n ? [e] : arguments) }) }), i = null }).promise() }, then: function(t, n, r) { var u = 0;
+
+ function l(i, o, a, s) { return function() { var n = this,
+ r = arguments,
+ e = function() { var e, t; if (!(i < u)) { if ((e = a.apply(n, r)) === o.promise()) throw new TypeError("Thenable self-resolution");
+ t = e && ("object" == typeof e || "function" == typeof e) && e.then, m(t) ? s ? t.call(e, l(u, o, R, s), l(u, o, M, s)) : (u++, t.call(e, l(u, o, R, s), l(u, o, M, s), l(u, o, R, o.notifyWith))) : (a !== R && (n = void 0, r = [e]), (s || o.resolveWith)(n, r)) } },
+ t = s ? e : function() { try { e() } catch (e) { S.Deferred.exceptionHook && S.Deferred.exceptionHook(e, t.stackTrace), u <= i + 1 && (a !== M && (n = void 0, r = [e]), o.rejectWith(n, r)) } };
+ i ? t() : (S.Deferred.getStackHook && (t.stackTrace = S.Deferred.getStackHook()), C.setTimeout(t)) } } return S.Deferred(function(e) { o[0][3].add(l(0, e, m(r) ? r : R, e.notifyWith)), o[1][3].add(l(0, e, m(t) ? t : R)), o[2][3].add(l(0, e, m(n) ? n : M)) }).promise() }, promise: function(e) { return null != e ? S.extend(e, a) : a } },
+ s = {}; return S.each(o, function(e, t) { var n = t[2],
+ r = t[5];
+ a[t[1]] = n.add, r && n.add(function() { i = r }, o[3 - e][2].disable, o[3 - e][3].disable, o[0][2].lock, o[0][3].lock), n.add(t[3].fire), s[t[0]] = function() { return s[t[0] + "With"](this === s ? void 0 : this, arguments), this }, s[t[0] + "With"] = n.fireWith }), a.promise(s), e && e.call(s, s), s }, when: function(e) { var n = arguments.length,
+ t = n,
+ r = Array(t),
+ i = s.call(arguments),
+ o = S.Deferred(),
+ a = function(t) { return function(e) { r[t] = this, i[t] = 1 < arguments.length ? s.call(arguments) : e, --n || o.resolveWith(r, i) } }; if (n <= 1 && (I(e, o.done(a(t)).resolve, o.reject, !n), "pending" === o.state() || m(i[t] && i[t].then))) return o.then(); while (t--) I(i[t], a(t), o.reject); return o.promise() } }); var W = /^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/;
+ S.Deferred.exceptionHook = function(e, t) { C.console && C.console.warn && e && W.test(e.name) && C.console.warn("jQuery.Deferred exception: " + e.message, e.stack, t) }, S.readyException = function(e) { C.setTimeout(function() { throw e }) }; var F = S.Deferred();
+
+ function B() { E.removeEventListener("DOMContentLoaded", B), C.removeEventListener("load", B), S.ready() }
+ S.fn.ready = function(e) { return F.then(e)["catch"](function(e) { S.readyException(e) }), this }, S.extend({ isReady: !1, readyWait: 1, ready: function(e) {
+ (!0 === e ? --S.readyWait : S.isReady) || (S.isReady = !0) !== e && 0 < --S.readyWait || F.resolveWith(E, [S]) } }), S.ready.then = F.then, "complete" === E.readyState || "loading" !== E.readyState && !E.documentElement.doScroll ? C.setTimeout(S.ready) : (E.addEventListener("DOMContentLoaded", B), C.addEventListener("load", B)); var $ = function(e, t, n, r, i, o, a) { var s = 0,
+ u = e.length,
+ l = null == n; if ("object" === w(n))
+ for (s in i = !0, n) $(e, t, s, n[s], !0, o, a);
+ else if (void 0 !== r && (i = !0, m(r) || (a = !0), l && (a ? (t.call(e, r), t = null) : (l = t, t = function(e, t, n) { return l.call(S(e), n) })), t))
+ for (; s < u; s++) t(e[s], n, a ? r : r.call(e[s], s, t(e[s], n))); return i ? e : l ? t.call(e) : u ? t(e[0], n) : o },
+ _ = /^-ms-/,
+ z = /-([a-z])/g;
+
+ function U(e, t) { return t.toUpperCase() }
+
+ function X(e) { return e.replace(_, "ms-").replace(z, U) } var V = function(e) { return 1 === e.nodeType || 9 === e.nodeType || !+e.nodeType };
+
+ function G() { this.expando = S.expando + G.uid++ }
+ G.uid = 1, G.prototype = { cache: function(e) { var t = e[this.expando]; return t || (t = {}, V(e) && (e.nodeType ? e[this.expando] = t : Object.defineProperty(e, this.expando, { value: t, configurable: !0 }))), t }, set: function(e, t, n) { var r, i = this.cache(e); if ("string" == typeof t) i[X(t)] = n;
+ else
+ for (r in t) i[X(r)] = t[r]; return i }, get: function(e, t) { return void 0 === t ? this.cache(e) : e[this.expando] && e[this.expando][X(t)] }, access: function(e, t, n) { return void 0 === t || t && "string" == typeof t && void 0 === n ? this.get(e, t) : (this.set(e, t, n), void 0 !== n ? n : t) }, remove: function(e, t) { var n, r = e[this.expando]; if (void 0 !== r) { if (void 0 !== t) { n = (t = Array.isArray(t) ? t.map(X) : (t = X(t)) in r ? [t] : t.match(P) || []).length; while (n--) delete r[t[n]] }(void 0 === t || S.isEmptyObject(r)) && (e.nodeType ? e[this.expando] = void 0 : delete e[this.expando]) } }, hasData: function(e) { var t = e[this.expando]; return void 0 !== t && !S.isEmptyObject(t) } }; var Y = new G,
+ Q = new G,
+ J = /^(?:\{[\w\W]*\}|\[[\w\W]*\])$/,
+ K = /[A-Z]/g;
+
+ function Z(e, t, n) { var r, i; if (void 0 === n && 1 === e.nodeType)
+ if (r = "data-" + t.replace(K, "-$&").toLowerCase(), "string" == typeof(n = e.getAttribute(r))) { try { n = "true" === (i = n) || "false" !== i && ("null" === i ? null : i === +i + "" ? +i : J.test(i) ? JSON.parse(i) : i) } catch (e) {}
+ Q.set(e, t, n) } else n = void 0;
+ return n }
+ S.extend({ hasData: function(e) { return Q.hasData(e) || Y.hasData(e) }, data: function(e, t, n) { return Q.access(e, t, n) }, removeData: function(e, t) { Q.remove(e, t) }, _data: function(e, t, n) { return Y.access(e, t, n) }, _removeData: function(e, t) { Y.remove(e, t) } }), S.fn.extend({ data: function(n, e) { var t, r, i, o = this[0],
+ a = o && o.attributes; if (void 0 === n) { if (this.length && (i = Q.get(o), 1 === o.nodeType && !Y.get(o, "hasDataAttrs"))) { t = a.length; while (t--) a[t] && 0 === (r = a[t].name).indexOf("data-") && (r = X(r.slice(5)), Z(o, r, i[r]));
+ Y.set(o, "hasDataAttrs", !0) } return i } return "object" == typeof n ? this.each(function() { Q.set(this, n) }) : $(this, function(e) { var t; if (o && void 0 === e) return void 0 !== (t = Q.get(o, n)) ? t : void 0 !== (t = Z(o, n)) ? t : void 0;
+ this.each(function() { Q.set(this, n, e) }) }, null, e, 1 < arguments.length, null, !0) }, removeData: function(e) { return this.each(function() { Q.remove(this, e) }) } }), S.extend({ queue: function(e, t, n) { var r; if (e) return t = (t || "fx") + "queue", r = Y.get(e, t), n && (!r || Array.isArray(n) ? r = Y.access(e, t, S.makeArray(n)) : r.push(n)), r || [] }, dequeue: function(e, t) { t = t || "fx"; var n = S.queue(e, t),
+ r = n.length,
+ i = n.shift(),
+ o = S._queueHooks(e, t); "inprogress" === i && (i = n.shift(), r--), i && ("fx" === t && n.unshift("inprogress"), delete o.stop, i.call(e, function() { S.dequeue(e, t) }, o)), !r && o && o.empty.fire() }, _queueHooks: function(e, t) { var n = t + "queueHooks"; return Y.get(e, n) || Y.access(e, n, { empty: S.Callbacks("once memory").add(function() { Y.remove(e, [t + "queue", n]) }) }) } }), S.fn.extend({ queue: function(t, n) { var e = 2; return "string" != typeof t && (n = t, t = "fx", e--), arguments.length < e ? S.queue(this[0], t) : void 0 === n ? this : this.each(function() { var e = S.queue(this, t, n);
+ S._queueHooks(this, t), "fx" === t && "inprogress" !== e[0] && S.dequeue(this, t) }) }, dequeue: function(e) { return this.each(function() { S.dequeue(this, e) }) }, clearQueue: function(e) { return this.queue(e || "fx", []) }, promise: function(e, t) { var n, r = 1,
+ i = S.Deferred(),
+ o = this,
+ a = this.length,
+ s = function() {--r || i.resolveWith(o, [o]) }; "string" != typeof e && (t = e, e = void 0), e = e || "fx"; while (a--)(n = Y.get(o[a], e + "queueHooks")) && n.empty && (r++, n.empty.add(s)); return s(), i.promise(t) } }); var ee = /[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,
+ te = new RegExp("^(?:([+-])=|)(" + ee + ")([a-z%]*)$", "i"),
+ ne = ["Top", "Right", "Bottom", "Left"],
+ re = E.documentElement,
+ ie = function(e) { return S.contains(e.ownerDocument, e) },
+ oe = { composed: !0 };
+ re.getRootNode && (ie = function(e) { return S.contains(e.ownerDocument, e) || e.getRootNode(oe) === e.ownerDocument }); var ae = function(e, t) { return "none" === (e = t || e).style.display || "" === e.style.display && ie(e) && "none" === S.css(e, "display") };
+
+ function se(e, t, n, r) { var i, o, a = 20,
+ s = r ? function() { return r.cur() } : function() { return S.css(e, t, "") },
+ u = s(),
+ l = n && n[3] || (S.cssNumber[t] ? "" : "px"),
+ c = e.nodeType && (S.cssNumber[t] || "px" !== l && +u) && te.exec(S.css(e, t)); if (c && c[3] !== l) { u /= 2, l = l || c[3], c = +u || 1; while (a--) S.style(e, t, c + l), (1 - o) * (1 - (o = s() / u || .5)) <= 0 && (a = 0), c /= o;
+ c *= 2, S.style(e, t, c + l), n = n || [] } return n && (c = +c || +u || 0, i = n[1] ? c + (n[1] + 1) * n[2] : +n[2], r && (r.unit = l, r.start = c, r.end = i)), i } var ue = {};
+
+ function le(e, t) { for (var n, r, i, o, a, s, u, l = [], c = 0, f = e.length; c < f; c++)(r = e[c]).style && (n = r.style.display, t ? ("none" === n && (l[c] = Y.get(r, "display") || null, l[c] || (r.style.display = "")), "" === r.style.display && ae(r) && (l[c] = (u = a = o = void 0, a = (i = r).ownerDocument, s = i.nodeName, (u = ue[s]) || (o = a.body.appendChild(a.createElement(s)), u = S.css(o, "display"), o.parentNode.removeChild(o), "none" === u && (u = "block"), ue[s] = u)))) : "none" !== n && (l[c] = "none", Y.set(r, "display", n))); for (c = 0; c < f; c++) null != l[c] && (e[c].style.display = l[c]); return e }
+ S.fn.extend({ show: function() { return le(this, !0) }, hide: function() { return le(this) }, toggle: function(e) { return "boolean" == typeof e ? e ? this.show() : this.hide() : this.each(function() { ae(this) ? S(this).show() : S(this).hide() }) } }); var ce, fe, pe = /^(?:checkbox|radio)$/i,
+ de = /<([a-z][^\/\0>\x20\t\r\n\f]*)/i,
+ he = /^$|^module$|\/(?:java|ecma)script/i;
+ ce = E.createDocumentFragment().appendChild(E.createElement("div")), (fe = E.createElement("input")).setAttribute("type", "radio"), fe.setAttribute("checked", "checked"), fe.setAttribute("name", "t"), ce.appendChild(fe), y.checkClone = ce.cloneNode(!0).cloneNode(!0).lastChild.checked, ce.innerHTML = "", y.noCloneChecked = !!ce.cloneNode(!0).lastChild.defaultValue, ce.innerHTML = "", y.option = !!ce.lastChild; var ge = { thead: [1, ""], col: [2, ""], tr: [2, ""], td: [3, ""], _default: [0, "", ""] };
+
+ function ve(e, t) { var n; return n = "undefined" != typeof e.getElementsByTagName ? e.getElementsByTagName(t || "*") : "undefined" != typeof e.querySelectorAll ? e.querySelectorAll(t || "*") : [], void 0 === t || t && A(e, t) ? S.merge([e], n) : n }
+
+ function ye(e, t) { for (var n = 0, r = e.length; n < r; n++) Y.set(e[n], "globalEval", !t || Y.get(t[n], "globalEval")) }
+ ge.tbody = ge.tfoot = ge.colgroup = ge.caption = ge.thead, ge.th = ge.td, y.option || (ge.optgroup = ge.option = [1, ""]); var me = /<|?\w+;/;
+
+ function xe(e, t, n, r, i) { for (var o, a, s, u, l, c, f = t.createDocumentFragment(), p = [], d = 0, h = e.length; d < h; d++)
+ if ((o = e[d]) || 0 === o)
+ if ("object" === w(o)) S.merge(p, o.nodeType ? [o] : o);
+ else if (me.test(o)) { a = a || f.appendChild(t.createElement("div")), s = (de.exec(o) || ["", ""])[1].toLowerCase(), u = ge[s] || ge._default, a.innerHTML = u[1] + S.htmlPrefilter(o) + u[2], c = u[0]; while (c--) a = a.lastChild;
+ S.merge(p, a.childNodes), (a = f.firstChild).textContent = "" } else p.push(t.createTextNode(o));
+ f.textContent = "", d = 0; while (o = p[d++])
+ if (r && -1 < S.inArray(o, r)) i && i.push(o);
+ else if (l = ie(o), a = ve(f.appendChild(o), "script"), l && ye(a), n) { c = 0; while (o = a[c++]) he.test(o.type || "") && n.push(o) } return f } var be = /^([^.]*)(?:\.(.+)|)/;
+
+ function we() { return !0 }
+
+ function Te() { return !1 }
+
+ function Ce(e, t) { return e === function() { try { return E.activeElement } catch (e) {} }() == ("focus" === t) }
+
+ function Ee(e, t, n, r, i, o) { var a, s; if ("object" == typeof t) { for (s in "string" != typeof n && (r = r || n, n = void 0), t) Ee(e, s, n, r, t[s], o); return e } if (null == r && null == i ? (i = n, r = n = void 0) : null == i && ("string" == typeof n ? (i = r, r = void 0) : (i = r, r = n, n = void 0)), !1 === i) i = Te;
+ else if (!i) return e; return 1 === o && (a = i, (i = function(e) { return S().off(e), a.apply(this, arguments) }).guid = a.guid || (a.guid = S.guid++)), e.each(function() { S.event.add(this, t, i, r, n) }) }
+
+ function Se(e, i, o) { o ? (Y.set(e, i, !1), S.event.add(e, i, { namespace: !1, handler: function(e) { var t, n, r = Y.get(this, i); if (1 & e.isTrigger && this[i]) { if (r.length)(S.event.special[i] || {}).delegateType && e.stopPropagation();
+ else if (r = s.call(arguments), Y.set(this, i, r), t = o(this, i), this[i](), r !== (n = Y.get(this, i)) || t ? Y.set(this, i, !1) : n = {}, r !== n) return e.stopImmediatePropagation(), e.preventDefault(), n && n.value } else r.length && (Y.set(this, i, { value: S.event.trigger(S.extend(r[0], S.Event.prototype), r.slice(1), this) }), e.stopImmediatePropagation()) } })) : void 0 === Y.get(e, i) && S.event.add(e, i, we) }
+ S.event = { global: {}, add: function(t, e, n, r, i) { var o, a, s, u, l, c, f, p, d, h, g, v = Y.get(t); if (V(t)) { n.handler && (n = (o = n).handler, i = o.selector), i && S.find.matchesSelector(re, i), n.guid || (n.guid = S.guid++), (u = v.events) || (u = v.events = Object.create(null)), (a = v.handle) || (a = v.handle = function(e) { return "undefined" != typeof S && S.event.triggered !== e.type ? S.event.dispatch.apply(t, arguments) : void 0 }), l = (e = (e || "").match(P) || [""]).length; while (l--) d = g = (s = be.exec(e[l]) || [])[1], h = (s[2] || "").split(".").sort(), d && (f = S.event.special[d] || {}, d = (i ? f.delegateType : f.bindType) || d, f = S.event.special[d] || {}, c = S.extend({ type: d, origType: g, data: r, handler: n, guid: n.guid, selector: i, needsContext: i && S.expr.match.needsContext.test(i), namespace: h.join(".") }, o), (p = u[d]) || ((p = u[d] = []).delegateCount = 0, f.setup && !1 !== f.setup.call(t, r, h, a) || t.addEventListener && t.addEventListener(d, a)), f.add && (f.add.call(t, c), c.handler.guid || (c.handler.guid = n.guid)), i ? p.splice(p.delegateCount++, 0, c) : p.push(c), S.event.global[d] = !0) } }, remove: function(e, t, n, r, i) { var o, a, s, u, l, c, f, p, d, h, g, v = Y.hasData(e) && Y.get(e); if (v && (u = v.events)) { l = (t = (t || "").match(P) || [""]).length; while (l--)
+ if (d = g = (s = be.exec(t[l]) || [])[1], h = (s[2] || "").split(".").sort(), d) { f = S.event.special[d] || {}, p = u[d = (r ? f.delegateType : f.bindType) || d] || [], s = s[2] && new RegExp("(^|\\.)" + h.join("\\.(?:.*\\.|)") + "(\\.|$)"), a = o = p.length; while (o--) c = p[o], !i && g !== c.origType || n && n.guid !== c.guid || s && !s.test(c.namespace) || r && r !== c.selector && ("**" !== r || !c.selector) || (p.splice(o, 1), c.selector && p.delegateCount--, f.remove && f.remove.call(e, c));
+ a && !p.length && (f.teardown && !1 !== f.teardown.call(e, h, v.handle) || S.removeEvent(e, d, v.handle), delete u[d]) } else
+ for (d in u) S.event.remove(e, d + t[l], n, r, !0);
+ S.isEmptyObject(u) && Y.remove(e, "handle events") } }, dispatch: function(e) { var t, n, r, i, o, a, s = new Array(arguments.length),
+ u = S.event.fix(e),
+ l = (Y.get(this, "events") || Object.create(null))[u.type] || [],
+ c = S.event.special[u.type] || {}; for (s[0] = u, t = 1; t < arguments.length; t++) s[t] = arguments[t]; if (u.delegateTarget = this, !c.preDispatch || !1 !== c.preDispatch.call(this, u)) { a = S.event.handlers.call(this, u, l), t = 0; while ((i = a[t++]) && !u.isPropagationStopped()) { u.currentTarget = i.elem, n = 0; while ((o = i.handlers[n++]) && !u.isImmediatePropagationStopped()) u.rnamespace && !1 !== o.namespace && !u.rnamespace.test(o.namespace) || (u.handleObj = o, u.data = o.data, void 0 !== (r = ((S.event.special[o.origType] || {}).handle || o.handler).apply(i.elem, s)) && !1 === (u.result = r) && (u.preventDefault(), u.stopPropagation())) } return c.postDispatch && c.postDispatch.call(this, u), u.result } }, handlers: function(e, t) { var n, r, i, o, a, s = [],
+ u = t.delegateCount,
+ l = e.target; if (u && l.nodeType && !("click" === e.type && 1 <= e.button))
+ for (; l !== this; l = l.parentNode || this)
+ if (1 === l.nodeType && ("click" !== e.type || !0 !== l.disabled)) { for (o = [], a = {}, n = 0; n < u; n++) void 0 === a[i = (r = t[n]).selector + " "] && (a[i] = r.needsContext ? -1 < S(i, this).index(l) : S.find(i, this, null, [l]).length), a[i] && o.push(r);
+ o.length && s.push({ elem: l, handlers: o }) }
+ return l = this, u < t.length && s.push({ elem: l, handlers: t.slice(u) }), s }, addProp: function(t, e) { Object.defineProperty(S.Event.prototype, t, { enumerable: !0, configurable: !0, get: m(e) ? function() { if (this.originalEvent) return e(this.originalEvent) } : function() { if (this.originalEvent) return this.originalEvent[t] }, set: function(e) { Object.defineProperty(this, t, { enumerable: !0, configurable: !0, writable: !0, value: e }) } }) }, fix: function(e) { return e[S.expando] ? e : new S.Event(e) }, special: { load: { noBubble: !0 }, click: { setup: function(e) { var t = this || e; return pe.test(t.type) && t.click && A(t, "input") && Se(t, "click", we), !1 }, trigger: function(e) { var t = this || e; return pe.test(t.type) && t.click && A(t, "input") && Se(t, "click"), !0 }, _default: function(e) { var t = e.target; return pe.test(t.type) && t.click && A(t, "input") && Y.get(t, "click") || A(t, "a") } }, beforeunload: { postDispatch: function(e) { void 0 !== e.result && e.originalEvent && (e.originalEvent.returnValue = e.result) } } } }, S.removeEvent = function(e, t, n) { e.removeEventListener && e.removeEventListener(t, n) }, S.Event = function(e, t) { if (!(this instanceof S.Event)) return new S.Event(e, t);
+ e && e.type ? (this.originalEvent = e, this.type = e.type, this.isDefaultPrevented = e.defaultPrevented || void 0 === e.defaultPrevented && !1 === e.returnValue ? we : Te, this.target = e.target && 3 === e.target.nodeType ? e.target.parentNode : e.target, this.currentTarget = e.currentTarget, this.relatedTarget = e.relatedTarget) : this.type = e, t && S.extend(this, t), this.timeStamp = e && e.timeStamp || Date.now(), this[S.expando] = !0 }, S.Event.prototype = { constructor: S.Event, isDefaultPrevented: Te, isPropagationStopped: Te, isImmediatePropagationStopped: Te, isSimulated: !1, preventDefault: function() { var e = this.originalEvent;
+ this.isDefaultPrevented = we, e && !this.isSimulated && e.preventDefault() }, stopPropagation: function() { var e = this.originalEvent;
+ this.isPropagationStopped = we, e && !this.isSimulated && e.stopPropagation() }, stopImmediatePropagation: function() { var e = this.originalEvent;
+ this.isImmediatePropagationStopped = we, e && !this.isSimulated && e.stopImmediatePropagation(), this.stopPropagation() } }, S.each({ altKey: !0, bubbles: !0, cancelable: !0, changedTouches: !0, ctrlKey: !0, detail: !0, eventPhase: !0, metaKey: !0, pageX: !0, pageY: !0, shiftKey: !0, view: !0, "char": !0, code: !0, charCode: !0, key: !0, keyCode: !0, button: !0, buttons: !0, clientX: !0, clientY: !0, offsetX: !0, offsetY: !0, pointerId: !0, pointerType: !0, screenX: !0, screenY: !0, targetTouches: !0, toElement: !0, touches: !0, which: !0 }, S.event.addProp), S.each({ focus: "focusin", blur: "focusout" }, function(e, t) { S.event.special[e] = { setup: function() { return Se(this, e, Ce), !1 }, trigger: function() { return Se(this, e), !0 }, _default: function() { return !0 }, delegateType: t } }), S.each({ mouseenter: "mouseover", mouseleave: "mouseout", pointerenter: "pointerover", pointerleave: "pointerout" }, function(e, i) { S.event.special[e] = { delegateType: i, bindType: i, handle: function(e) { var t, n = e.relatedTarget,
+ r = e.handleObj; return n && (n === this || S.contains(this, n)) || (e.type = r.origType, t = r.handler.apply(this, arguments), e.type = i), t } } }), S.fn.extend({ on: function(e, t, n, r) { return Ee(this, e, t, n, r) }, one: function(e, t, n, r) { return Ee(this, e, t, n, r, 1) }, off: function(e, t, n) { var r, i; if (e && e.preventDefault && e.handleObj) return r = e.handleObj, S(e.delegateTarget).off(r.namespace ? r.origType + "." + r.namespace : r.origType, r.selector, r.handler), this; if ("object" == typeof e) { for (i in e) this.off(i, t, e[i]); return this } return !1 !== t && "function" != typeof t || (n = t, t = void 0), !1 === n && (n = Te), this.each(function() { S.event.remove(this, e, n, t) }) } }); var ke = /
+
+
+
+