example.vue 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  1. <template>
  2. <div class="example-com">
  3. <template v-for="p in listMapper">
  4. <div class="p-label">{{p.label}}</div>
  5. <div class="son">
  6. <template v-for="s in p.children">
  7. <div class="son-item">
  8. <img :src="s.icon" alt=""/>
  9. <div class="label" v-html="s.label"/>
  10. </div>
  11. </template>
  12. </div>
  13. </template>
  14. </div>
  15. </template>
  16. <script lang="ts">
  17. import {
  18. defineComponent,
  19. computed,
  20. onMounted,
  21. ref,
  22. reactive,
  23. watch,
  24. getCurrentInstance,
  25. ComponentInternalInstance,
  26. toRefs,
  27. nextTick
  28. } from 'vue'
  29. import {useStore} from 'vuex'
  30. import {useRouter, useRoute} from 'vue-router'
  31. import {ElMessage, ElMessageBox} from "element-plus";
  32. import iconHAJC from '@/assets/images/gis-layout/gis-layout-tools_hajc.png'
  33. import iconJSJ from '@/assets/images/gis-layout/gis-layout-tools_jsj.png'
  34. import iconWGY from '@/assets/images/gis-layout/gis-layout-tools_wgy.png'
  35. import iconWXCL from '@/assets/images/gis-layout/gis-layout-tools_wxcl.png'
  36. import iconGALSB from '@/assets/images/gis-layout/gis-layout-tools_galsb.png'
  37. import iconSHLSB from '@/assets/images/gis-layout/gis-layout-tools_shlsb.png'
  38. import iconMYLSB from '@/assets/images/gis-layout/gis-layout-tools_mylsb.png'
  39. import iconLGSZYJKSCSB from '@/assets/images/gis-layout/gis-layout-tools_lgszyjcscsb.png'
  40. import iconJGZZMGS from '@/assets/images/gis-layout/gis-layout-tools_jgzzmgs.png'
  41. import iconLGSJKYFL from '@/assets/images/gis-layout/gis-layout-tools_lgsjkyfl.png'
  42. import iconJQ from '@/assets/images/gis-layout/gis-layout-tools_jq.png'
  43. import iconLG from '@/assets/images/gis-layout/gis-layout-tools_lg.png'
  44. import iconCZW from '@/assets/images/gis-layout/gis-layout-tools_czw.png'
  45. import iconHCZ from '@/assets/images/gis-layout/gis-layout-tools_hcz.png'
  46. import iconFZS from '@/assets/images/gis-layout/gis-layout-tools_fzs.png'
  47. import iconAXCBYPYJ from '@/assets/images/gis-layout/gis-layout-tools_axcbypyj.png'
  48. import iconGGCSFXYF from '@/assets/images/gis-layout/gis-layout-tools_ggcsfxyf.png'
  49. import iconXFJY from '@/assets/images/gis-layout/gis-layout-tools_xfjy.png'
  50. import iconQYFXFK from '@/assets/images/gis-layout/gis-layout-tools_qyfxfk.png'
  51. import iconSHZLFXFK from '@/assets/images/gis-layout/gis-layout-tools_shzlfxfk.png'
  52. import iconAJ from '@/assets/images/gis-layout/gis-layout-tools_aj.png'
  53. export default defineComponent({
  54. name: '',
  55. components: {},
  56. props: {
  57. },
  58. setup(props, {emit}) {
  59. const store = useStore();
  60. const router = useRouter();
  61. const route = useRoute();
  62. const that = (getCurrentInstance() as ComponentInternalInstance).appContext.config.globalProperties
  63. const state = reactive({
  64. })
  65. const listMapper = [
  66. {
  67. label: '处置力量',
  68. children: [
  69. {label: '海岸警察', icon: iconHAJC},
  70. {label: '缉私警', icon: iconJSJ},
  71. {label: '网格员', icon: iconWGY},
  72. ]
  73. },
  74. {
  75. label: '危险车辆',
  76. children: [
  77. {label: '危险车辆', icon: iconWXCL},
  78. ]
  79. },
  80. {
  81. label: '设备资源',
  82. children: [
  83. {label: '公安类设备', icon: iconGALSB},
  84. {label: '社会类设备', icon: iconSHLSB},
  85. {label: '民用类设备', icon: iconMYLSB},
  86. ]
  87. },
  88. {
  89. label: '企业',
  90. children: [
  91. {label: '零关税自用<br/>进口生产设备', icon: iconLGSZYJKSCSB},
  92. {label: '加工增值免关税', icon: iconJGZZMGS},
  93. {label: '零关税<br/>进口原辅料', icon: iconLGSJKYFL},
  94. ]
  95. },
  96. {
  97. label: '景区',
  98. children: [
  99. {label: '景区', icon: iconJQ},
  100. ]
  101. },
  102. {
  103. label: '旅馆',
  104. children: [
  105. {label: '旅馆', icon: iconLG},
  106. ]
  107. },
  108. {
  109. label: '出租屋',
  110. children: [
  111. {label: '出租屋', icon: iconCZW},
  112. ]
  113. },
  114. {
  115. label: '火车站',
  116. children: [
  117. {label: '火车站', icon: iconHCZ},
  118. ]
  119. },
  120. {
  121. label: '线索',
  122. children: [
  123. {label: '线索(反走私)', icon: iconFZS},
  124. {label: '线索(岸线船舶<br/>研判预警)', icon: iconAXCBYPYJ},
  125. {label: '线索(公共场所<br/>风险预防)', icon: iconGGCSFXYF},
  126. {label: '线索(消防救援)', icon: iconXFJY},
  127. {label: '线索(企业风险<br/>防控)', icon: iconQYFXFK},
  128. {label: '线索(社会治理<br/>风险防控)', icon: iconSHZLFXFK},
  129. ]
  130. },
  131. {
  132. label: '案件',
  133. children: [
  134. {label: '案件', icon: iconAJ},
  135. ]
  136. },
  137. ]
  138. onMounted(() => {
  139. })
  140. return {
  141. ...toRefs(state),
  142. listMapper
  143. }
  144. },
  145. })
  146. </script>
  147. <style scoped lang="scss">
  148. .example-com {
  149. padding: 12px 14px;
  150. position: fixed;
  151. width: 404px;
  152. height: calc(100% - 100px);
  153. background-color: #FFFFFF;
  154. box-sizing: border-box;
  155. overflow-y: auto;
  156. .p-label {
  157. margin-bottom: 12px;
  158. font-size: 16px;
  159. font-family: Microsoft YaHei;
  160. font-weight: 400;
  161. color: #4C4C4C;
  162. &:not(:first-child) {
  163. margin-top: 12px;
  164. }
  165. }
  166. .son {
  167. width: 100%;
  168. display: grid;
  169. grid-template-columns: repeat(3, 1fr);
  170. gap: 10px;
  171. .son-item {
  172. height: 119px;
  173. background-image: url("@/assets/images/gis-layout/gis-layout-tools_bg.png");
  174. background-size: 100% 100%;
  175. background-repeat: no-repeat;
  176. display: flex;
  177. flex-direction: column;
  178. align-items: center;
  179. >img {
  180. width: 40px;
  181. height: 55px;
  182. margin-top: 12px;
  183. }
  184. .label {
  185. font-size: 14px;
  186. font-family: Microsoft YaHei;
  187. font-weight: 400;
  188. color: #4C4C4C;
  189. text-align: center;
  190. flex: 1;
  191. display: flex;
  192. align-items: center;
  193. justify-content: center;
  194. }
  195. }
  196. }
  197. }
  198. </style>