interDetails.vue 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404
  1. <template>
  2. <div>
  3. <div class="DetilsCon">
  4. <div class="sm-panel sm-function-module-query" v-drag>
  5. <div class="sm-panel-header">
  6. <span>占压耕地图斑</span>
  7. <i class="el-icon-close" @click="closeInster"></i>
  8. </div>
  9. <div class="tableCon">
  10. <el-table
  11. :header-cell-style="{
  12. background: 'rgba(10, 25, 38, 0.6)',
  13. color: '#66b1ff',
  14. fontSize: '14px',
  15. fontFamily: 'Microsoft YaHei',
  16. fontWeight: '400',
  17. }"
  18. :data="tableData"
  19. style="width: 100%"
  20. height="731"
  21. >
  22. <el-table-column
  23. show-overflow-tooltip="true"
  24. prop="id"
  25. label="编号"
  26. >
  27. </el-table-column>
  28. <el-table-column
  29. show-overflow-tooltip="true"
  30. prop="siweiarea"
  31. label="图斑面积(㎡)"
  32. >
  33. </el-table-column>
  34. <el-table-column width="100" label="操作">
  35. <template slot-scope="scope">
  36. <!-- <span>编辑</span> -->
  37. <el-button size="mini" type="text" @click="flyTo(scope.row)"
  38. >定位</el-button
  39. >
  40. <el-button
  41. size="mini"
  42. type="text"
  43. @click="handleView(scope.row)"
  44. >详情</el-button
  45. >
  46. </template>
  47. </el-table-column></el-table
  48. >
  49. </div>
  50. </div>
  51. </div>
  52. <div class="conViews" v-if="isShallow">
  53. <div class="sm-panel sm-function-module-query" v-drag>
  54. <div class="sm-panel-header">
  55. <span>图斑详情</span>
  56. <i class="el-icon-close" @click="isShallow = false"></i>
  57. </div>
  58. <el-tabs
  59. type="border-card"
  60. class="xz_box info"
  61. v-model="activeTabs"
  62. stretch
  63. >
  64. <el-tab-pane label="套合结果" name="thjg">
  65. <!-- <div class="inter_result"></div> -->
  66. <div class="Integration inter_result">
  67. <!-- <div
  68. class="Integration_list"
  69. v-for="(item, i) in yzjgData"
  70. :key="i"
  71. >
  72. <div>{{ item.mx_bsmmc }}:</div> -->
  73. <el-table :data="yzjgData">
  74. <el-table-column
  75. prop="bsmmc"
  76. label="套合数据"
  77. show-overflow-tooltip
  78. >
  79. </el-table-column>
  80. <el-table-column
  81. prop="sumcount"
  82. label="监测图斑数(个)"
  83. align="center"
  84. width="80"
  85. >
  86. </el-table-column>
  87. <el-table-column
  88. prop="sumvalue"
  89. label="重叠面积(㎡)"
  90. align="center"
  91. show-overflow-tooltip
  92. >
  93. </el-table-column>
  94. </el-table>
  95. <!-- <div
  96. v-for="(item2, c) in item.mx_data"
  97. :key="c"
  98. class="list_Cont"
  99. >
  100. <div class="list_item">
  101. <div class="listText">
  102. <span style="color: #fff">{{ item2.bsmmc }}图斑数</span>
  103. <span
  104. style="
  105. color: #2d8cf0;
  106. font-weight: bold;
  107. cursor: pointer;
  108. "
  109. @click="resultDeatils(item2, item.mx_bsm)"
  110. >{{ item2.sumcount }}个</span
  111. >
  112. </div>
  113. </div>
  114. <div class="list_item">
  115. <div class="listText">
  116. <span style="color: #fff">{{ item2.bsmmc }}面积(㎡)</span>
  117. <span color="#80FFFF">{{ item2.sumvalue }}</span>
  118. </div>
  119. </div>
  120. </div> -->
  121. <!-- </div>-->
  122. </div>
  123. </el-tab-pane>
  124. <el-tab-pane label="基本信息" name="jbxx">
  125. <div class="inter_result" v-if="activeTabs == 'jbxx'">
  126. <el-table
  127. :header-cell-style="{
  128. background: 'rgba(10, 25, 38, 0.6)',
  129. color: '#66b1ff',
  130. fontSize: '14px',
  131. fontFamily: 'Microsoft YaHei',
  132. fontWeight: '400',
  133. }"
  134. :data="jbxxData"
  135. height="455"
  136. style="width: 100%"
  137. >
  138. <el-table-column
  139. show-overflow-tooltip="true"
  140. prop="name"
  141. label="属性名称"
  142. >
  143. </el-table-column>
  144. <el-table-column
  145. show-overflow-tooltip="true"
  146. prop="value"
  147. label="属性值"
  148. >
  149. </el-table-column>
  150. </el-table>
  151. <!-- <el-carousel indicator-position="outside">
  152. <el-carousel-item v-for="item in 4" :key="item">
  153. <h3>{{ item }}</h3>
  154. </el-carousel-item>
  155. </el-carousel> -->
  156. </div>
  157. </el-tab-pane>
  158. </el-tabs>
  159. </div>
  160. </div>
  161. </div>
  162. </template>
  163. <script>
  164. import { name } from "file-loader";
  165. import { getYZ, getgeoms, getOneDetail } from "../../../api/ghss/gdbh.js";
  166. import { loadGeoJSON } from "@/utils/MapHelper/help.js";
  167. let layerSources = {};
  168. export default {
  169. props: {
  170. interObj: {
  171. type: Object,
  172. },
  173. },
  174. data() {
  175. return {
  176. activeTabs: "thjg",
  177. tableData: [],
  178. viewsData: null,
  179. isShallow: false,
  180. jbxxData: null,
  181. yzjgData: [],
  182. tempdataLayerId: null,
  183. };
  184. },
  185. mounted() {
  186. // this.init();
  187. },
  188. methods: {
  189. //关闭套合结果详情
  190. closeInster() {
  191. this.$emit("updateParent", "showInter", false);
  192. this.isShallow = false;
  193. viewer.entities.removeAll();
  194. viewer.dataSources.removeAll();
  195. },
  196. flyTo(item) {
  197. let id = "h_" + item.id;
  198. this.tempdataLayerId = id;
  199. loadGeoJSON(item.geom, "#ff0000", { isfly: true }, (data) => {
  200. layerSources[id] = data;
  201. });
  202. },
  203. handleView(val) {
  204. this.isShallow = true;
  205. getOneDetail({
  206. bsm: this.interObj.bsm,
  207. id: val.id,
  208. }).then((res) => {
  209. if (res.statuscode == 200) {
  210. this.viewsData = res.data;
  211. this.yzjgData = []; // res.data.yzjg;
  212. res.data.yzjg.forEach((jsi) => {
  213. jsi.mx_data.forEach((mx) => {
  214. this.yzjgData.push({
  215. ...mx,
  216. mx_bsm: jsi.mx_bsm,
  217. mx_bsmmc: jsi.mx_bsmmc,
  218. });
  219. });
  220. });
  221. let geomJson = JSON.parse(res.data.tbxx.geomJson);
  222. this.jbxxData = Object.keys(geomJson).map((key) => ({
  223. name: key,
  224. value: geomJson[key],
  225. }));
  226. } else {
  227. this.$message.error(res.message);
  228. }
  229. });
  230. this.isShallow = true;
  231. },
  232. init() {
  233. if (!this.interObj.mxbsm) {
  234. this.getAll();
  235. } else {
  236. this.getYZ();
  237. }
  238. },
  239. getYZ() {
  240. getYZ(this.interObj).then((res) => {
  241. if (res.statuscode == 200) {
  242. this.tableData = res.data.datalist;
  243. this.active_tableData(this.tableData);
  244. } else {
  245. this.$message.error(res.message);
  246. }
  247. });
  248. },
  249. getAll() {
  250. getgeoms(this.interObj).then((res) => {
  251. if (res.statuscode == 200) {
  252. this.tableData = res.data;
  253. this.active_tableData(res.data);
  254. } else {
  255. this.$message.error(res.message);
  256. }
  257. });
  258. },
  259. active_tableData(newVal) {
  260. newVal.forEach((res, index) => {
  261. res.type = "图斑上图";
  262. if (res.geom)
  263. loadGeoJSON(res.geom, "#55A1E3", { isfly: false }, (data) => {
  264. layerSources[res.id] = data;
  265. data.entities.values.forEach((entity) => {
  266. entity.properties = res;
  267. });
  268. });
  269. });
  270. },
  271. },
  272. mounted() {},
  273. watch: {
  274. // interObj(newValue) {
  275. // this.init();
  276. // },
  277. interObj: {
  278. handler(newVal) {
  279. this.init();
  280. },
  281. deep: true,
  282. immediate: true,
  283. },
  284. tempdataLayerId(newVal, oldVal) {
  285. if (oldVal && layerSources[oldVal]) {
  286. viewer.dataSources.remove(layerSources[oldVal]);
  287. layerSources[oldVal] = null;
  288. }
  289. },
  290. },
  291. };
  292. </script>
  293. <style lang="scss" scoped>
  294. .DetilsCon {
  295. position: relative;
  296. right: 57%;
  297. }
  298. .tableCon {
  299. height: 48rem;
  300. }
  301. /deep/ .el-icon-close:before {
  302. position: absolute;
  303. top: 10px;
  304. right: 10px;
  305. font-size: larger;
  306. font-weight: bold;
  307. &:hover {
  308. color: aqua;
  309. }
  310. }
  311. /deep/ .el-carousel--horizontal {
  312. margin-top: 15px;
  313. }
  314. /deep/ .el-carousel__item h3 {
  315. color: #475669;
  316. font-size: 18px;
  317. opacity: 0.75;
  318. line-height: 200px;
  319. text-align: center;
  320. margin: 0;
  321. }
  322. /deep/ .el-carousel__container {
  323. height: 200px;
  324. }
  325. /deep/ .el-carousel__item:nth-child(2n) {
  326. background-color: #99a9bf;
  327. }
  328. /deep/ .el-carousel__item:nth-child(2n + 1) {
  329. background-color: #d3dce6;
  330. }
  331. .inter_result {
  332. // height: 580px;
  333. height: 695px;
  334. }
  335. .Integration {
  336. // max-height: 580px;
  337. height: 695px;
  338. overflow: hidden;
  339. overflow-y: auto;
  340. .Integration_list {
  341. background-color: #0f7bc875;
  342. // display: flex;
  343. // justify-content: space-between;
  344. margin-top: 8px;
  345. // flex-wrap: wrap;
  346. padding: 10px;
  347. .listCol {
  348. width: 49%;
  349. display: flex;
  350. align-items: center;
  351. white-space: nowrap;
  352. margin-bottom: 5px;
  353. .listText {
  354. width: 100%;
  355. display: flex;
  356. flex-direction: column;
  357. span {
  358. height: 20px;
  359. height: 20px;
  360. line-height: 20px;
  361. }
  362. }
  363. }
  364. .list_Cont {
  365. width: 100%;
  366. display: flex;
  367. align-items: center;
  368. white-space: nowrap;
  369. margin-bottom: 5px;
  370. .list_item {
  371. width: 50%;
  372. .listText {
  373. width: 100%;
  374. display: flex;
  375. flex-direction: column;
  376. span {
  377. height: 20px;
  378. line-height: 20px;
  379. }
  380. }
  381. }
  382. }
  383. }
  384. }
  385. .sm-function-module-query {
  386. max-height: 800px !important;
  387. top: 28px !important;
  388. }
  389. </style>