vue2-client 1.22.2 → 1.22.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (170) hide show
  1. package/.claude/settings.local.json +30 -30
  2. package/.env.his +19 -19
  3. package/.eslintrc.js +74 -74
  4. package/.history/.eslintrc_20260521171150.js +74 -0
  5. package/.history/.eslintrc_20260521171213.js +74 -0
  6. package/.history/src/base-client/components/common/HIS/HAddNativeForm/HAddNativeForm_20260601154443.vue +726 -0
  7. package/.history/src/base-client/components/common/HIS/HAddNativeForm/HAddNativeForm_20260601154700.vue +478 -0
  8. package/.history/src/base-client/components/common/HIS/HButtons/HButtons_20260512175435.vue +706 -0
  9. package/.history/src/base-client/components/common/HIS/HButtons/HButtons_20260512175450.vue +694 -0
  10. package/.history/src/base-client/components/common/HIS/HButtons/HButtons_20260611152602.vue +755 -0
  11. package/.history/src/base-client/components/common/HIS/HForm/HForm_20260513145941.vue +524 -0
  12. package/.history/src/base-client/components/common/HIS/HForm/HForm_20260513153133.vue +731 -0
  13. package/.history/src/base-client/components/common/HIS/HForm/HForm_20260513160316.vue +525 -0
  14. package/.history/src/base-client/components/common/HIS/HForm/HForm_20260601144150.vue +1046 -0
  15. package/.history/src/base-client/components/common/HIS/HFormTable/HFormTable_20260310142713.vue +512 -0
  16. package/.history/src/base-client/components/common/HIS/HFormTable/HFormTable_20260310145118.vue +511 -0
  17. package/.history/src/base-client/components/common/HIS/HFormTable/HFormTable_20260311094834.vue +696 -0
  18. package/.history/src/base-client/components/common/HIS/HFormTable/HFormTable_20260320143028.vue +693 -0
  19. package/.history/src/base-client/components/common/HIS/HFormTable/HFormTable_20260409101450.vue +677 -0
  20. package/.history/src/base-client/components/common/HIS/HTab/HTab_20260508164645.vue +758 -0
  21. package/.history/src/base-client/components/common/HIS/HTab/HTab_20260508164714.vue +693 -0
  22. package/.history/src/base-client/components/common/HIS/HTab/HTab_20260508171651.vue +716 -0
  23. package/.history/src/base-client/components/common/HIS/HTab/HTab_20260509133717.vue +695 -0
  24. package/.history/src/base-client/components/common/HIS/HTab/HTab_20260509171115.vue +664 -0
  25. package/.history/src/base-client/components/common/XAddNativeForm/XAddNativeForm_20260513140637.vue +1455 -0
  26. package/.history/src/base-client/components/common/XAddNativeForm/XAddNativeForm_20260513140935.vue +1441 -0
  27. package/.history/src/base-client/components/common/XAddNativeForm/XAddNativeForm_20260513150818.vue +1441 -0
  28. package/.history/src/base-client/components/common/XAddNativeForm/XAddNativeForm_20260513153119.vue +1442 -0
  29. package/.history/src/base-client/components/common/XAddNativeForm/XAddNativeForm_20260513153126.vue +1486 -0
  30. package/.history/src/base-client/components/common/XForm/XFormItem_20260513140854.vue +1607 -0
  31. package/.history/src/base-client/components/common/XMarkdownViewer/XMarkdownViewer_20260519140403.vue +643 -0
  32. package/.history/src/base-client/components/common/XMarkdownViewer/XMarkdownViewer_20260519140829.vue +628 -0
  33. package/.history/src/base-client/components/common/XMarkdownViewer/demo_20260519142824.vue +104 -0
  34. package/.history/src/base-client/components/common/XMarkdownViewer/demo_20260519143155.vue +102 -0
  35. package/.history/src/base-client/components/common/XReportGrid/XReport_20260309171231.vue +1241 -0
  36. package/.history/src/base-client/components/common/XReportGrid/XReport_20260309171441.vue +1223 -0
  37. package/.history/src/base-client/components/his/HAi/HAi_20260612174826.vue +472 -0
  38. package/.history/src/base-client/components/his/HAi/HAi_20260612175839.vue +538 -0
  39. package/.history/src/base-client/components/his/HAi/HAi_20260615103331.vue +650 -0
  40. package/.history/src/base-client/components/his/XHDescriptions/XHDescriptions_20260424134504.vue +1469 -0
  41. package/.history/src/base-client/components/his/XSidebar/XSidebar_20260610171133.vue +788 -0
  42. package/.history/src/base-client/components/his/XSidebar/XSidebar_20260610171151.vue +780 -0
  43. package/.history/src/base-client/components/his/XTransfer/XTransfer_20260511170841.vue +585 -0
  44. package/.history/src/base-client/components/his/XTransfer/XTransfer_20260511171138.vue +787 -0
  45. package/.history/src/base-client/components/his/XTransfer/XTransfer_20260512141830.vue +739 -0
  46. package/.history/src/components/STable/index_20260409155138.js +806 -0
  47. package/.history/src/components/STable/index_20260409155218.js +814 -0
  48. package/.history/src/expression/core/Expression_20260305164427.js +1371 -0
  49. package/.history/src/expression/core/Expression_20260305170258.js +1358 -0
  50. package/.history/src/expression/core/Program_20260305111830.js +944 -0
  51. package/.history/src/expression/core/Program_20260305112041.js +931 -0
  52. package/.history/src/logic/LogicRunner_20260304154306.js +170 -0
  53. package/.history/src/logic/LogicRunner_20260304155553.js +112 -0
  54. package/.history/src/logic/LogicRunner_20260305105834.js +112 -0
  55. package/.history/src/logic/LogicRunner_20260305112718.js +129 -0
  56. package/.history/src/logic/LogicRunner_20260305182436.js +133 -0
  57. package/.history/src/logic/LogicRunner_20260306151301.js +213 -0
  58. package/.history/src/logic/LogicRunner_20260306152419.js +213 -0
  59. package/.history/src/logic/plugins/common/DateTools_20260305154159.js +61 -0
  60. package/.history/src/logic/plugins/common/DateTools_20260305154217.js +44 -0
  61. package/.history/src/logic/plugins/common/DateTools_20260305161014.js +44 -0
  62. package/.history/src/logic/plugins/common/HttpTools_20260305164352.js +80 -0
  63. package/.history/src/logic/plugins/common/HttpTools_20260305170258.js +75 -0
  64. package/.history/src/logic/plugins/common/HttpTools_20260305171634.js +75 -0
  65. package/.history/src/logic/plugins/common/HttpTools_20260306152419.js +72 -0
  66. package/.history/src/services/api/restTools_20260427142149.js +245 -0
  67. package/.history/src/services/api/restTools_20260427142853.js +230 -0
  68. package/.history/src/services/api/restTools_20260519135558.js +230 -0
  69. package/.history/src/services/api/restTools_20260519140825.js +230 -0
  70. package/.history/src/services/api/restTools_20260519151223.js +230 -0
  71. package/.history/src/utils/indexedDB_20260306150918.js +593 -0
  72. package/.history/src/utils/indexedDB_20260306151301.js +586 -0
  73. package/.idea/af-vue2-client.iml +9 -0
  74. package/.idea/codeStyles/Project.xml +62 -0
  75. package/.idea/codeStyles/codeStyleConfig.xml +5 -0
  76. package/.idea/misc.xml +6 -0
  77. package/.idea/modules.xml +1 -1
  78. package/Components.md +60 -60
  79. package/index.js +31 -31
  80. package/jest-transform-stub.js +8 -8
  81. package/jest.setup.js +7 -7
  82. package/package.json +1 -1
  83. package/preview-input-box.html +180 -0
  84. package/src/assets/img/querySlotDemo.svg +15 -15
  85. package/src/base-client/components/common/AmapMarker/AmapPointRendering.vue +120 -120
  86. package/src/base-client/components/common/CitySelect/index.js +3 -3
  87. package/src/base-client/components/common/CitySelect/index.md +109 -109
  88. package/src/base-client/components/common/FormGroupEdit/index.js +3 -3
  89. package/src/base-client/components/common/FormGroupEdit/index.md +43 -43
  90. package/src/base-client/components/common/HIS/HButtons/HButtons.vue +55 -1
  91. package/src/base-client/components/common/HIS/HForm/HForm.vue +1186 -1186
  92. package/src/base-client/components/common/HIS/HTab/HTab.vue +88 -1
  93. package/src/base-client/components/common/JSONToTree/jsontotree.vue +271 -271
  94. package/src/base-client/components/common/PersonSetting/index.js +3 -3
  95. package/src/base-client/components/common/Tree/index.js +2 -2
  96. package/src/base-client/components/common/Upload/index.js +3 -3
  97. package/src/base-client/components/common/XAddNativeForm/index.md +146 -146
  98. package/src/base-client/components/common/XAddReport/XAddReport.vue +16 -1
  99. package/src/base-client/components/common/XCard/XCard.vue +64 -64
  100. package/src/base-client/components/common/XDataDrawer/XDataDrawer.vue +180 -180
  101. package/src/base-client/components/common/XDataDrawer/index.js +3 -3
  102. package/src/base-client/components/common/XDataDrawer/index.md +41 -41
  103. package/src/base-client/components/common/XDescriptions/index.js +3 -3
  104. package/src/base-client/components/common/XDescriptions/index.md +382 -382
  105. package/src/base-client/components/common/XForm/index.md +178 -178
  106. package/src/base-client/components/common/XInput/XInput.vue +32 -1
  107. package/src/base-client/components/common/XInspectionDetailDrawer/index.vue +1 -1
  108. package/src/base-client/components/common/XMarkdownViewer/demo.vue +102 -102
  109. package/src/base-client/components/common/XStepView/XStepView.vue +252 -252
  110. package/src/base-client/components/common/XStepView/index.js +3 -3
  111. package/src/base-client/components/common/XStepView/index.md +31 -31
  112. package/src/base-client/components/common/XTable/index.md +255 -255
  113. package/src/base-client/components/his/HAi/HAi.vue +1177 -436
  114. package/src/base-client/components/his/XList/XList.vue +337 -58
  115. package/src/base-client/components/his/XSidebar/XSidebar.vue +36 -12
  116. package/src/base-client/components/his/XTransfer/index.md +327 -327
  117. package/src/base-client/components/system/DictionaryDetailsView/DictionaryDetailsView.vue +232 -232
  118. package/src/base-client/plugins/Config.js +19 -19
  119. package/src/base-client/plugins/tabs-page-plugin.js +39 -39
  120. package/src/components/Charts/Bar.vue +62 -62
  121. package/src/components/Charts/ChartCard.vue +134 -134
  122. package/src/components/Charts/Liquid.vue +67 -67
  123. package/src/components/Charts/MiniArea.vue +39 -39
  124. package/src/components/Charts/MiniBar.vue +39 -39
  125. package/src/components/Charts/MiniProgress.vue +75 -75
  126. package/src/components/Charts/MiniSmoothArea.vue +40 -40
  127. package/src/components/Charts/Radar.vue +68 -68
  128. package/src/components/Charts/RankList.vue +77 -77
  129. package/src/components/Charts/TagCloud.vue +113 -113
  130. package/src/components/Charts/TransferBar.vue +64 -64
  131. package/src/components/Charts/Trend.vue +82 -82
  132. package/src/components/Charts/chart.less +12 -12
  133. package/src/components/Charts/smooth.area.less +13 -13
  134. package/src/components/NumberInfo/NumberInfo.vue +54 -54
  135. package/src/components/NumberInfo/index.js +3 -3
  136. package/src/components/NumberInfo/index.less +54 -54
  137. package/src/components/NumberInfo/index.md +43 -43
  138. package/src/components/STable/index.js +953 -953
  139. package/src/components/card/ChartCard.vue +79 -79
  140. package/src/components/chart/Bar.vue +60 -60
  141. package/src/components/chart/MiniArea.vue +67 -67
  142. package/src/components/chart/MiniBar.vue +59 -59
  143. package/src/components/chart/MiniProgress.vue +57 -57
  144. package/src/components/chart/Radar.vue +80 -80
  145. package/src/components/chart/RankingList.vue +60 -60
  146. package/src/components/chart/Trend.vue +79 -79
  147. package/src/components/chart/index.less +9 -9
  148. package/src/components/checkbox/ColorCheckbox.vue +157 -157
  149. package/src/components/input/IInput.vue +66 -66
  150. package/src/components/menu/SideMenu.vue +75 -75
  151. package/src/components/menu/menu.js +273 -273
  152. package/src/components/tool/AStepItem.vue +60 -60
  153. package/src/layouts/CommonLayout.vue +56 -56
  154. package/src/lib.js +1 -1
  155. package/src/mock/extend/index.js +84 -84
  156. package/src/mock/goods/index.js +108 -108
  157. package/src/pages/dashboard/workplace/WorkPlace.vue +141 -141
  158. package/src/pages/system/dictionary/index.vue +44 -44
  159. package/src/pages/system/monitor/loginInfor/index.vue +37 -37
  160. package/src/pages/system/monitor/operLog/index.vue +37 -37
  161. package/src/services/api/cas.js +79 -79
  162. package/src/store/modules/setting.js +119 -119
  163. package/src/utils/errorCode.js +6 -6
  164. package//350/277/201/347/247/273/346/227/245/345/277/227.md +15 -15
  165. package/.idea/MarsCodeWorkspaceAppSettings.xml +0 -7
  166. package/.idea/google-java-format.xml +0 -6
  167. package/.idea/inspectionProfiles/Project_Default.xml +0 -24
  168. package/.idea/jsLinters/eslint.xml +0 -6
  169. package/.idea/vue2-client.iml +0 -12
  170. package/.vscode/settings.json +0 -28
@@ -23,8 +23,17 @@ const wrapperClassObject = computed(() => {
23
23
  const classes = {}
24
24
 
25
25
  // 通用布尔样式开关(以存在/空字符串/'true' 为真)
26
+ // hasTopMargin: 标签增加顶部外边距,同时调整 ant-card-body 内边距
27
+ // useStyle7: 细下划线指示器样式,透明背景,支持配合 useCycle 显示圆点
28
+ // useCycle: 与 useStyle7 配合使用,在标签左侧显示蓝色圆点指示器
29
+ // useStyle8: 等宽卡片式标签,带边框和圆角,激活项高亮并隐藏底部边框
30
+ // out-tab: 去除标签栏所有外边距与内边距,实现紧凑贴边效果
31
+ // no-underline: 隐藏底部边框与 ink-bar 下划线指示器
32
+ // useStyle9: 圆角卡片标签,带边框,激活项填充品牌色,禁用切换动画
33
+ // useStyle10: 无下划线 + 左侧蓝色圆点,透明背景,激活项高亮品牌色
34
+ // useStyle11: 去除边框,选中显示蓝色下划线,字体 #313131 / #0057FE,标签宽度平均分配
26
35
  const booleanStyleKeys = [
27
- 'hasTopMargin', 'useStyle7', 'useCycle', 'useStyle8', 'out-tab', 'no-underline', 'useStyle9', 'useStyle10'
36
+ 'hasTopMargin', 'useStyle7', 'useCycle', 'useStyle8', 'out-tab', 'no-underline', 'useStyle9', 'useStyle10', 'useStyle11'
28
37
  ]
29
38
  for (const key of booleanStyleKeys) {
30
39
  const val = a[key]
@@ -666,5 +675,83 @@ defineExpose({
666
675
  }
667
676
  }
668
677
  }
678
+
679
+ // 样式11:去除边框、选中显示蓝色下划线,标签宽度平均分配
680
+ &.h-tab-useStyle11 {
681
+ :deep(.ant-tabs-tab-next),
682
+ :deep(.ant-tabs-tab-prev-icon-target),
683
+ :deep(.ant-tabs-tab-next-icon) { display: none; }
684
+
685
+ :deep(.ant-tabs-bar) {
686
+ border-bottom: none !important;
687
+ height: 32px !important;
688
+ line-height: 32px !important;
689
+ }
690
+
691
+ :deep(.ant-tabs-ink-bar) {
692
+ display: block !important;
693
+ background-color: #0057FE !important;
694
+ bottom: 0px !important;
695
+ height: 2px !important;
696
+ margin-left: 0 !important;
697
+ }
698
+
699
+ :deep(.ant-tabs-nav-wrap) {
700
+ margin-top: 0;
701
+ padding-left: 0 !important;
702
+ padding-right: 0 !important;
703
+ width: 100% !important;
704
+ }
705
+
706
+ :deep(.ant-tabs-nav-container) {
707
+ padding-left: 0 !important;
708
+ padding-right: 0 !important;
709
+ width: 100% !important;
710
+ }
711
+
712
+ :deep(.ant-tabs-nav-container-scrolling) {
713
+ padding-left: 0 !important;
714
+ padding-right: 0 !important;
715
+ }
716
+
717
+ :deep(.ant-tabs-nav) {
718
+ width: 100% !important;
719
+
720
+ .ant-tabs-nav-list {
721
+ width: 100% !important;
722
+ display: grid !important;
723
+ grid-template-columns: repeat(auto-fit, minmax(0, 1fr));
724
+ }
725
+
726
+ .ant-tabs-tab {
727
+ width: 50%;
728
+ height: 32px;
729
+ box-sizing: border-box !important;
730
+ opacity: 1;
731
+ font-family: "Source Han Sans";
732
+ font-size: 16px;
733
+ font-weight: bold;
734
+ line-height: normal;
735
+ text-align: center;
736
+ letter-spacing: 0em;
737
+ color: #313131;
738
+ background-color: transparent;
739
+ border: none;
740
+ border-radius: 0;
741
+ padding: 0 12px 6px;
742
+ margin-right: 0 !important;
743
+ display: inline-flex !important;
744
+ align-items: center;
745
+ justify-content: center;
746
+ transition: all 0.3s;
747
+ }
748
+
749
+ .ant-tabs-tab-active {
750
+ color: #0057FE;
751
+ background-color: transparent;
752
+ border: none;
753
+ }
754
+ }
755
+ }
669
756
  }
670
757
  </style>
@@ -1,271 +1,271 @@
1
- <template>
2
- <a-drawer
3
- title="设备类型配置生成"
4
- placement="right"
5
- :width="isMobile ? screenWidth : screenWidth * 0.85"
6
- :visible="visible"
7
- @close="onClose"
8
- >
9
- <a-row :gutter="24">
10
- <a-col :xl="12" :lg="12" :md="12" :sm="24" :xs="24">
11
- <div class="page-header-index-wide">
12
- <a-card :bordered="false">
13
- <div slot="title">
14
- <div v-show="changeflag" >
15
- <a-button v-show="treeData.length === 0" @click="showModal('eventAddRoot')">添加根节点</a-button>
16
- <a-divider v-show="treeData.length === 0" type="vertical" />
17
- <a-button v-show="treeData.length > 0" @click="showModal('eventAddSame')">添加同级</a-button>
18
- <a-divider v-show="treeData.length > 0" type="vertical" />
19
- <a-button v-show="treeData.length > 0" @click="showModal('eventAddSub')">添加下级</a-button>
20
- <a-divider v-show="treeData.length > 0" type="vertical" />
21
- <a-button v-show="treeData.length > 0" @click="showModal('eventModify')">修改</a-button>
22
- <a-divider v-show="treeData.length > 0" type="vertical" />
23
- <a-button v-show="treeData.length > 0" @click="eventDelete">删除</a-button>
24
- </div>
25
- </div>
26
- <a-tree
27
- :tree-data="treeData"
28
- @select="onEventTreeNodeSelected"
29
- :defaultExpandAll="true"
30
- :selectedKeys.sync="selectKeys"
31
- showLine >
32
- <template slot="custom" slot-scope="item">
33
- <div style="position: relative;float:left;">
34
- {{ item.title }}
35
- </div>
36
- <div v-show="item.visibleModel" style="position: absolute;height:25px;top: 3%;left:3.8%" >
37
- <a-input-group compact>
38
- <a-input type="text" style="width: 30%" placeholder="名称" ref="myInput" v-model="nowchangetitle" />
39
- <a-input type="text" style="width: 30%" placeholder="值" ref="myInput" v-model="nowchangevalue" />
40
- <a-button
41
- @click="handleOk(item)"
42
- type="link">
43
- 保存
44
- </a-button>
45
- <a-divider type="vertical" />
46
- <a-button
47
- @click="handleCancel(item)"
48
- type="link"
49
- >取消</a-button>
50
- </a-input-group>
51
- </div>
52
- </template>
53
- </a-tree>
54
- </a-card>
55
- </div>
56
- </a-col>
57
- <a-col :xl="12" :lg="12" :md="12" :sm="24" :xs="24">
58
- <a-card :bordered="false" title="预览" size="small" style="overflow: auto">
59
- <json-viewer :copyable="{copyText: '复制', copiedText: '已复制'}" :value="treeData" :expand-depth="parseInt('100')" style="overflow: auto;max-height: 440px"></json-viewer>
60
- </a-card>
61
- </a-col>
62
- </a-row>
63
- </a-drawer>
64
- </template>
65
-
66
- <script>
67
-
68
- import { mapState } from 'vuex'
69
- import JsonViewer from 'vue-json-viewer'
70
-
71
- export default {
72
- name: 'LogDetailsView',
73
- data () {
74
- return {
75
- // 页面宽度
76
- screenWidth: document.documentElement.clientWidth,
77
- selectKeys: [],
78
- treeData: [],
79
- eventSelectedNode: null,
80
- // 当前操作类型
81
- operate: '',
82
- // 新建节点中的值
83
- nowchangetitle: '',
84
- // 新建节点中的值
85
- nowchangevalue: '',
86
- // 操作按钮显示控制
87
- changeflag: true
88
- }
89
- },
90
- props: {
91
- visible: {
92
- type: Boolean,
93
- default: () => {
94
- return false
95
- }
96
- }
97
- },
98
- components: {
99
- JsonViewer
100
- },
101
- methods: {
102
- showModal (operate) {
103
- if (!this.eventSelectedNode && this.treeData.length > 0) {
104
- this.$message.warning('请选择节点后进行操作')
105
- return
106
- }
107
- if (operate === 'eventAddSame' && this.eventSelectedNode && !this.eventSelectedNode.$parent.dataRef && this.treeData.length > 0) {
108
- this.$message.warning('不能给根节点添加同级')
109
- return
110
- }
111
- this.changeflag = false
112
- this.operate = operate
113
- switch (this.operate) {
114
- case 'eventAddRoot':
115
- this.eventAddRoot()
116
- break
117
- case 'eventAddSame':
118
- this.eventAddSame()
119
- break
120
- case 'eventAddSub':
121
- this.eventAddSub()
122
- break
123
- case 'eventModify':
124
- this.nowchangetitle = this.eventSelectedNode.dataRef.title
125
- this.nowchangevalue = this.eventSelectedNode.dataRef.value
126
- this.setvisibleModel(true, 'visibleModel')
127
- break
128
- default:
129
- this.$message.warning('未获取到操作指令')
130
- }
131
- },
132
- handleOk (item) {
133
- if (this.operate === 'eventModify') {
134
- this.eventModify()
135
- } else {
136
- this.eventSelectedNode.dataRef.title = this.nowchangetitle
137
- this.eventSelectedNode.dataRef.value = this.nowchangevalue
138
- }
139
- this.setvisibleModel(false, 'visibleModel')
140
- this.clearnodename()
141
- },
142
- setvisibleModel (flag, value) {
143
- const dataRef = this.eventSelectedNode.dataRef
144
- this.$set(dataRef, value, flag)
145
- },
146
- handleCancel (item) {
147
- if (this.operate === 'eventModify') {
148
- this.setvisibleModel(false, 'visibleModel')
149
- } else if (this.operate === 'eventAddRoot') {
150
- this.treeData = []
151
- } else {
152
- this.searchitem(item, this.treeData)
153
- }
154
- this.clearnodename()
155
- },
156
- searchitem (option, arr, type = 'delete') {
157
- // 递归删除树中某个节点
158
- for (let s = 0; s < arr.length; s++) {
159
- if (arr[s].key === option.key) {
160
- if (type === 'delete') {
161
- arr.splice(s, 1)
162
- }
163
- break
164
- } else if (arr[s].children && arr[s].children.length > 0) { // 递归条件
165
- this.searchitem(option, arr[s].children)
166
- }
167
- }
168
- },
169
- clearnodename () {
170
- this.operate = ''
171
- this.nowchangetitle = ''
172
- this.nowchangevalue = ''
173
- this.changeflag = true
174
- },
175
- onClose () {
176
- this.$emit('update:visible', false)
177
- },
178
- onEventTreeNodeSelected (seleteKeys, e) {
179
- if (e.selected) {
180
- this.eventSelectedNode = e.node
181
- return
182
- }
183
- this.eventSelectedNode = null
184
- },
185
- eventAddRoot () {
186
- this.$set(this.treeData, 'children', [])
187
- this.treeData.push({
188
- title: '',
189
- value: '',
190
- key: new Date().getTime(),
191
- scopedSlots: { title: 'custom' },
192
- visibleModel: true
193
- })
194
- },
195
- eventAddSame () {
196
- // 查找父级
197
- const dataRef = this.eventSelectedNode.$parent.dataRef
198
- if (!dataRef.children) {
199
- this.$set(dataRef, 'children', [])
200
- }
201
- dataRef.children.push({
202
- title: '',
203
- value: '',
204
- key: new Date().getTime(),
205
- scopedSlots: { title: 'custom' },
206
- visibleModel: true
207
- })
208
- },
209
- eventAddSub () {
210
- const dataRef = this.eventSelectedNode.dataRef
211
- if (!dataRef.children) {
212
- this.$set(dataRef, 'children', [])
213
- }
214
- this.eventSelectedNode.vcTree.$data._expandedKeys.push(dataRef.key)
215
- dataRef.children.push({
216
- title: '',
217
- value: '',
218
- key: new Date().getTime(),
219
- scopedSlots: { title: 'custom' },
220
- children: [],
221
- visibleModel: true
222
- })
223
- },
224
- eventModify () {
225
- const dataRef = this.eventSelectedNode.dataRef
226
- // this.$set(dataRef, 'children', [])
227
- dataRef.title = this.nowchangetitle
228
- dataRef.value = this.nowchangevalue
229
- },
230
- eventDelete () {
231
- if (!this.eventSelectedNode.$parent.dataRef) {
232
- this.treeData = []
233
- return
234
- }
235
- const parentDataRef = this.eventSelectedNode.$parent.dataRef
236
- // 判断是否是顶层
237
- const children = parentDataRef.children
238
- const currentDataRef = this.eventSelectedNode.dataRef
239
- const index = children.indexOf(currentDataRef)
240
- children.splice(index, 1)
241
- },
242
- onSelect (selectedKeys, info) {
243
- console.log('selected', selectedKeys, info)
244
- }
245
- },
246
- computed: {
247
- ...mapState('setting', ['isMobile'])
248
- }
249
- }
250
- </script>
251
- <style lang="less" scoped>
252
- .ant-tree-title {
253
- width: 100%;
254
- }
255
- .title {
256
- float: left;
257
- }
258
- .ant-card-body {
259
- .ant-tree {
260
- line-height: 3;
261
- li {
262
- position: relative;
263
- }
264
- }
265
- }
266
- .ant-card-body .but_type {
267
- float: right;
268
- position: absolute;
269
- right: 40px;
270
- }
271
- </style>
1
+ <template>
2
+ <a-drawer
3
+ title="设备类型配置生成"
4
+ placement="right"
5
+ :width="isMobile ? screenWidth : screenWidth * 0.85"
6
+ :visible="visible"
7
+ @close="onClose"
8
+ >
9
+ <a-row :gutter="24">
10
+ <a-col :xl="12" :lg="12" :md="12" :sm="24" :xs="24">
11
+ <div class="page-header-index-wide">
12
+ <a-card :bordered="false">
13
+ <div slot="title">
14
+ <div v-show="changeflag" >
15
+ <a-button v-show="treeData.length === 0" @click="showModal('eventAddRoot')">添加根节点</a-button>
16
+ <a-divider v-show="treeData.length === 0" type="vertical" />
17
+ <a-button v-show="treeData.length > 0" @click="showModal('eventAddSame')">添加同级</a-button>
18
+ <a-divider v-show="treeData.length > 0" type="vertical" />
19
+ <a-button v-show="treeData.length > 0" @click="showModal('eventAddSub')">添加下级</a-button>
20
+ <a-divider v-show="treeData.length > 0" type="vertical" />
21
+ <a-button v-show="treeData.length > 0" @click="showModal('eventModify')">修改</a-button>
22
+ <a-divider v-show="treeData.length > 0" type="vertical" />
23
+ <a-button v-show="treeData.length > 0" @click="eventDelete">删除</a-button>
24
+ </div>
25
+ </div>
26
+ <a-tree
27
+ :tree-data="treeData"
28
+ @select="onEventTreeNodeSelected"
29
+ :defaultExpandAll="true"
30
+ :selectedKeys.sync="selectKeys"
31
+ showLine >
32
+ <template slot="custom" slot-scope="item">
33
+ <div style="position: relative;float:left;">
34
+ {{ item.title }}
35
+ </div>
36
+ <div v-show="item.visibleModel" style="position: absolute;height:25px;top: 3%;left:3.8%" >
37
+ <a-input-group compact>
38
+ <a-input type="text" style="width: 30%" placeholder="名称" ref="myInput" v-model="nowchangetitle" />
39
+ <a-input type="text" style="width: 30%" placeholder="值" ref="myInput" v-model="nowchangevalue" />
40
+ <a-button
41
+ @click="handleOk(item)"
42
+ type="link">
43
+ 保存
44
+ </a-button>
45
+ <a-divider type="vertical" />
46
+ <a-button
47
+ @click="handleCancel(item)"
48
+ type="link"
49
+ >取消</a-button>
50
+ </a-input-group>
51
+ </div>
52
+ </template>
53
+ </a-tree>
54
+ </a-card>
55
+ </div>
56
+ </a-col>
57
+ <a-col :xl="12" :lg="12" :md="12" :sm="24" :xs="24">
58
+ <a-card :bordered="false" title="预览" size="small" style="overflow: auto">
59
+ <json-viewer :copyable="{copyText: '复制', copiedText: '已复制'}" :value="treeData" :expand-depth="parseInt('100')" style="overflow: auto;max-height: 440px"></json-viewer>
60
+ </a-card>
61
+ </a-col>
62
+ </a-row>
63
+ </a-drawer>
64
+ </template>
65
+
66
+ <script>
67
+
68
+ import { mapState } from 'vuex'
69
+ import JsonViewer from 'vue-json-viewer'
70
+
71
+ export default {
72
+ name: 'LogDetailsView',
73
+ data () {
74
+ return {
75
+ // 页面宽度
76
+ screenWidth: document.documentElement.clientWidth,
77
+ selectKeys: [],
78
+ treeData: [],
79
+ eventSelectedNode: null,
80
+ // 当前操作类型
81
+ operate: '',
82
+ // 新建节点中的值
83
+ nowchangetitle: '',
84
+ // 新建节点中的值
85
+ nowchangevalue: '',
86
+ // 操作按钮显示控制
87
+ changeflag: true
88
+ }
89
+ },
90
+ props: {
91
+ visible: {
92
+ type: Boolean,
93
+ default: () => {
94
+ return false
95
+ }
96
+ }
97
+ },
98
+ components: {
99
+ JsonViewer
100
+ },
101
+ methods: {
102
+ showModal (operate) {
103
+ if (!this.eventSelectedNode && this.treeData.length > 0) {
104
+ this.$message.warning('请选择节点后进行操作')
105
+ return
106
+ }
107
+ if (operate === 'eventAddSame' && this.eventSelectedNode && !this.eventSelectedNode.$parent.dataRef && this.treeData.length > 0) {
108
+ this.$message.warning('不能给根节点添加同级')
109
+ return
110
+ }
111
+ this.changeflag = false
112
+ this.operate = operate
113
+ switch (this.operate) {
114
+ case 'eventAddRoot':
115
+ this.eventAddRoot()
116
+ break
117
+ case 'eventAddSame':
118
+ this.eventAddSame()
119
+ break
120
+ case 'eventAddSub':
121
+ this.eventAddSub()
122
+ break
123
+ case 'eventModify':
124
+ this.nowchangetitle = this.eventSelectedNode.dataRef.title
125
+ this.nowchangevalue = this.eventSelectedNode.dataRef.value
126
+ this.setvisibleModel(true, 'visibleModel')
127
+ break
128
+ default:
129
+ this.$message.warning('未获取到操作指令')
130
+ }
131
+ },
132
+ handleOk (item) {
133
+ if (this.operate === 'eventModify') {
134
+ this.eventModify()
135
+ } else {
136
+ this.eventSelectedNode.dataRef.title = this.nowchangetitle
137
+ this.eventSelectedNode.dataRef.value = this.nowchangevalue
138
+ }
139
+ this.setvisibleModel(false, 'visibleModel')
140
+ this.clearnodename()
141
+ },
142
+ setvisibleModel (flag, value) {
143
+ const dataRef = this.eventSelectedNode.dataRef
144
+ this.$set(dataRef, value, flag)
145
+ },
146
+ handleCancel (item) {
147
+ if (this.operate === 'eventModify') {
148
+ this.setvisibleModel(false, 'visibleModel')
149
+ } else if (this.operate === 'eventAddRoot') {
150
+ this.treeData = []
151
+ } else {
152
+ this.searchitem(item, this.treeData)
153
+ }
154
+ this.clearnodename()
155
+ },
156
+ searchitem (option, arr, type = 'delete') {
157
+ // 递归删除树中某个节点
158
+ for (let s = 0; s < arr.length; s++) {
159
+ if (arr[s].key === option.key) {
160
+ if (type === 'delete') {
161
+ arr.splice(s, 1)
162
+ }
163
+ break
164
+ } else if (arr[s].children && arr[s].children.length > 0) { // 递归条件
165
+ this.searchitem(option, arr[s].children)
166
+ }
167
+ }
168
+ },
169
+ clearnodename () {
170
+ this.operate = ''
171
+ this.nowchangetitle = ''
172
+ this.nowchangevalue = ''
173
+ this.changeflag = true
174
+ },
175
+ onClose () {
176
+ this.$emit('update:visible', false)
177
+ },
178
+ onEventTreeNodeSelected (seleteKeys, e) {
179
+ if (e.selected) {
180
+ this.eventSelectedNode = e.node
181
+ return
182
+ }
183
+ this.eventSelectedNode = null
184
+ },
185
+ eventAddRoot () {
186
+ this.$set(this.treeData, 'children', [])
187
+ this.treeData.push({
188
+ title: '',
189
+ value: '',
190
+ key: new Date().getTime(),
191
+ scopedSlots: { title: 'custom' },
192
+ visibleModel: true
193
+ })
194
+ },
195
+ eventAddSame () {
196
+ // 查找父级
197
+ const dataRef = this.eventSelectedNode.$parent.dataRef
198
+ if (!dataRef.children) {
199
+ this.$set(dataRef, 'children', [])
200
+ }
201
+ dataRef.children.push({
202
+ title: '',
203
+ value: '',
204
+ key: new Date().getTime(),
205
+ scopedSlots: { title: 'custom' },
206
+ visibleModel: true
207
+ })
208
+ },
209
+ eventAddSub () {
210
+ const dataRef = this.eventSelectedNode.dataRef
211
+ if (!dataRef.children) {
212
+ this.$set(dataRef, 'children', [])
213
+ }
214
+ this.eventSelectedNode.vcTree.$data._expandedKeys.push(dataRef.key)
215
+ dataRef.children.push({
216
+ title: '',
217
+ value: '',
218
+ key: new Date().getTime(),
219
+ scopedSlots: { title: 'custom' },
220
+ children: [],
221
+ visibleModel: true
222
+ })
223
+ },
224
+ eventModify () {
225
+ const dataRef = this.eventSelectedNode.dataRef
226
+ // this.$set(dataRef, 'children', [])
227
+ dataRef.title = this.nowchangetitle
228
+ dataRef.value = this.nowchangevalue
229
+ },
230
+ eventDelete () {
231
+ if (!this.eventSelectedNode.$parent.dataRef) {
232
+ this.treeData = []
233
+ return
234
+ }
235
+ const parentDataRef = this.eventSelectedNode.$parent.dataRef
236
+ // 判断是否是顶层
237
+ const children = parentDataRef.children
238
+ const currentDataRef = this.eventSelectedNode.dataRef
239
+ const index = children.indexOf(currentDataRef)
240
+ children.splice(index, 1)
241
+ },
242
+ onSelect (selectedKeys, info) {
243
+ console.log('selected', selectedKeys, info)
244
+ }
245
+ },
246
+ computed: {
247
+ ...mapState('setting', ['isMobile'])
248
+ }
249
+ }
250
+ </script>
251
+ <style lang="less" scoped>
252
+ .ant-tree-title {
253
+ width: 100%;
254
+ }
255
+ .title {
256
+ float: left;
257
+ }
258
+ .ant-card-body {
259
+ .ant-tree {
260
+ line-height: 3;
261
+ li {
262
+ position: relative;
263
+ }
264
+ }
265
+ }
266
+ .ant-card-body .but_type {
267
+ float: right;
268
+ position: absolute;
269
+ right: 40px;
270
+ }
271
+ </style>
@@ -1,3 +1,3 @@
1
- import PersonSetting from './PersonSetting'
2
-
3
- export default PersonSetting
1
+ import PersonSetting from './PersonSetting'
2
+
3
+ export default PersonSetting
@@ -1,2 +1,2 @@
1
- import Tree from './Tree'
2
- export default Tree
1
+ import Tree from './Tree'
2
+ export default Tree
@@ -1,3 +1,3 @@
1
- import Upload from './Upload'
2
-
3
- export default Upload
1
+ import Upload from './Upload'
2
+
3
+ export default Upload