@bdsoft/element 1.1.9 → 1.1.12

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 (244) hide show
  1. package/dist/BdElement.js +23111 -0
  2. package/index.js +11 -11
  3. package/package.json +2 -1
  4. package/global/index.ts +0 -6
  5. package/global/register-properties.ts +0 -10
  6. package/index.html +0 -13
  7. package/package-form/core/components/formCreate.js +0 -274
  8. package/package-form/core/components/fragment.js +0 -12
  9. package/package-form/core/factory/context.js +0 -257
  10. package/package-form/core/factory/creator.js +0 -63
  11. package/package-form/core/factory/maker.js +0 -17
  12. package/package-form/core/factory/manager.js +0 -79
  13. package/package-form/core/factory/node.js +0 -85
  14. package/package-form/core/factory/parser.js +0 -28
  15. package/package-form/core/frame/api.js +0 -599
  16. package/package-form/core/frame/attrs.js +0 -12
  17. package/package-form/core/frame/dataDriver.js +0 -76
  18. package/package-form/core/frame/fetch.js +0 -119
  19. package/package-form/core/frame/formCreate.js +0 -274
  20. package/package-form/core/frame/index.js +0 -760
  21. package/package-form/core/frame/provider.js +0 -288
  22. package/package-form/core/frame/util.js +0 -274
  23. package/package-form/core/handler/context.js +0 -380
  24. package/package-form/core/handler/effect.js +0 -122
  25. package/package-form/core/handler/index.js +0 -111
  26. package/package-form/core/handler/inject.js +0 -145
  27. package/package-form/core/handler/input.js +0 -197
  28. package/package-form/core/handler/lifecycle.js +0 -43
  29. package/package-form/core/handler/loader.js +0 -373
  30. package/package-form/core/handler/page.js +0 -46
  31. package/package-form/core/handler/render.js +0 -29
  32. package/package-form/core/index.js +0 -12
  33. package/package-form/core/package.json +0 -15
  34. package/package-form/core/parser/html.js +0 -17
  35. package/package-form/core/render/cache.js +0 -47
  36. package/package-form/core/render/index.js +0 -31
  37. package/package-form/core/render/render.js +0 -393
  38. package/package-form/element-form/components/checkbox/package.json +0 -17
  39. package/package-form/element-form/components/checkbox/src/component.jsx +0 -110
  40. package/package-form/element-form/components/checkbox/src/index.js +0 -3
  41. package/package-form/element-form/components/frame/package.json +0 -17
  42. package/package-form/element-form/components/frame/src/IconCircleClose.vue +0 -14
  43. package/package-form/element-form/components/frame/src/IconDelete.vue +0 -12
  44. package/package-form/element-form/components/frame/src/IconDocument.vue +0 -12
  45. package/package-form/element-form/components/frame/src/IconFolderOpened.vue +0 -12
  46. package/package-form/element-form/components/frame/src/IconView.vue +0 -12
  47. package/package-form/element-form/components/frame/src/component.jsx +0 -349
  48. package/package-form/element-form/components/frame/src/index.js +0 -3
  49. package/package-form/element-form/components/frame/src/style.css +0 -66
  50. package/package-form/element-form/components/group/package.json +0 -17
  51. package/package-form/element-form/components/group/src/component.jsx +0 -314
  52. package/package-form/element-form/components/group/src/index.js +0 -3
  53. package/package-form/element-form/components/group/src/style.css +0 -125
  54. package/package-form/element-form/components/index.js +0 -22
  55. package/package-form/element-form/components/radio/package.json +0 -17
  56. package/package-form/element-form/components/radio/src/component.jsx +0 -101
  57. package/package-form/element-form/components/radio/src/index.js +0 -3
  58. package/package-form/element-form/components/select/package.json +0 -17
  59. package/package-form/element-form/components/select/src/component.jsx +0 -52
  60. package/package-form/element-form/components/select/src/index.js +0 -3
  61. package/package-form/element-form/components/subform/package.json +0 -14
  62. package/package-form/element-form/components/subform/src/component.jsx +0 -76
  63. package/package-form/element-form/components/subform/src/index.js +0 -3
  64. package/package-form/element-form/components/tree/package.json +0 -17
  65. package/package-form/element-form/components/tree/src/component.jsx +0 -62
  66. package/package-form/element-form/components/tree/src/index.js +0 -3
  67. package/package-form/element-form/components/upload/package.json +0 -17
  68. package/package-form/element-form/components/upload/src/IconUpload.vue +0 -12
  69. package/package-form/element-form/components/upload/src/component.jsx +0 -129
  70. package/package-form/element-form/components/upload/src/index.js +0 -3
  71. package/package-form/element-form/components/upload/src/style.css +0 -11
  72. package/package-form/element-form/index.js +0 -8
  73. package/package-form/element-form/package.json +0 -16
  74. package/package-form/element-form/src/components/icon/IconWarning.vue +0 -12
  75. package/package-form/element-form/src/components/index.js +0 -22
  76. package/package-form/element-form/src/core/alias.js +0 -34
  77. package/package-form/element-form/src/core/api.js +0 -208
  78. package/package-form/element-form/src/core/config.js +0 -62
  79. package/package-form/element-form/src/core/index.js +0 -60
  80. package/package-form/element-form/src/core/maker.js +0 -76
  81. package/package-form/element-form/src/core/manager.js +0 -315
  82. package/package-form/element-form/src/core/provider.js +0 -79
  83. package/package-form/element-form/src/parsers/datePicker.js +0 -31
  84. package/package-form/element-form/src/parsers/hidden.js +0 -12
  85. package/package-form/element-form/src/parsers/index.js +0 -17
  86. package/package-form/element-form/src/parsers/input.js +0 -21
  87. package/package-form/element-form/src/parsers/row.js +0 -10
  88. package/package-form/element-form/src/parsers/select.js +0 -15
  89. package/package-form/element-form/src/parsers/slider.js +0 -21
  90. package/package-form/element-form/src/parsers/timePicker.js +0 -17
  91. package/package-form/element-form/src/style/index.css +0 -52
  92. package/src/App.vue +0 -28
  93. package/src/assets/css/element.scss +0 -196
  94. package/src/assets/css/layout.scss +0 -215
  95. package/src/assets/css/tailwind.scss +0 -67
  96. package/src/assets/images/banner.gif +0 -0
  97. package/src/assets/images/banner.png +0 -0
  98. package/src/assets/images/bg1.svg +0 -22
  99. package/src/assets/images/bg2.png +0 -0
  100. package/src/assets/images/ff.png +0 -0
  101. package/src/assets/images/home-file1.png +0 -0
  102. package/src/assets/images/ky.png +0 -0
  103. package/src/assets/images/menu/add.png +0 -0
  104. package/src/assets/images/menu/del.png +0 -0
  105. package/src/assets/images/menu/down.png +0 -0
  106. package/src/assets/images/menu/dr.png +0 -0
  107. package/src/assets/images/menu/edit.png +0 -0
  108. package/src/assets/images/menu/kx.png +0 -0
  109. package/src/assets/images/menu/mb.png +0 -0
  110. package/src/assets/images/menu/pz.png +0 -0
  111. package/src/assets/images/menu/save.png +0 -0
  112. package/src/assets/images/menu/sj.png +0 -0
  113. package/src/assets/images/menu/sjk.png +0 -0
  114. package/src/assets/images/menu/up.png +0 -0
  115. package/src/assets/images/po-i.png +0 -0
  116. package/src/assets/images/po1-i1.png +0 -0
  117. package/src/assets/images/po1-i2.png +0 -0
  118. package/src/assets/images/po1-i3.png +0 -0
  119. package/src/assets/images/po1-i4.png +0 -0
  120. package/src/assets/images/po1-i5.png +0 -0
  121. package/src/assets/images/po1-i6.png +0 -0
  122. package/src/assets/images/po1-i7.png +0 -0
  123. package/src/assets/images/po1-i8.png +0 -0
  124. package/src/assets/images/po2-i1.png +0 -0
  125. package/src/assets/images/po2-i2.png +0 -0
  126. package/src/assets/images/po3-i1.png +0 -0
  127. package/src/assets/images/po4-i1.png +0 -0
  128. package/src/assets/images/po5-i1.png +0 -0
  129. package/src/assets/images/po6-i1.png +0 -0
  130. package/src/assets/images/po6-i2.png +0 -0
  131. package/src/assets/images/po7-i1.png +0 -0
  132. package/src/assets/images/tj1.png +0 -0
  133. package/src/assets/images/tj2.png +0 -0
  134. package/src/assets/images/tj3.png +0 -0
  135. package/src/components/3dcloudwords/index.js +0 -346
  136. package/src/components/3dcloudwords/index.vue +0 -99
  137. package/src/components/3dcloudwords/readme.md +0 -66
  138. package/src/components/badge/index.js +0 -167
  139. package/src/components/badge/index.scss +0 -166
  140. package/src/components/badge/index.vue +0 -98
  141. package/src/components/badge/readme.md +0 -18
  142. package/src/components/basic/Finish.vue +0 -107
  143. package/src/components/basic/button.vue +0 -19
  144. package/src/components/basic/readme.md +0 -7
  145. package/src/components/button/index.vue +0 -48
  146. package/src/components/button/readme.md +0 -62
  147. package/src/components/carousel/index.vue +0 -104
  148. package/src/components/carousel/readme.md +0 -12
  149. package/src/components/chartconfig/index.vue +0 -141
  150. package/src/components/chartconfig/readme.md +0 -25
  151. package/src/components/contextMenu/hookContxtMenu.js +0 -41
  152. package/src/components/contextMenu/index.vue +0 -245
  153. package/src/components/contextMenu/readme.md +0 -55
  154. package/src/components/contextMenu/useElementBounding.js +0 -40
  155. package/src/components/countup/countUp.js +0 -196
  156. package/src/components/countup/index.vue +0 -114
  157. package/src/components/countup/readme.md +0 -9
  158. package/src/components/empty/assets/build.png +0 -0
  159. package/src/components/empty/assets/emptybg.gif +0 -0
  160. package/src/components/empty/assets/emptybg.png +0 -0
  161. package/src/components/empty/assets/emptybg2.jpg +0 -0
  162. package/src/components/empty/assets/emptybg3.jpg +0 -0
  163. package/src/components/empty/assets/wuxiao.png +0 -0
  164. package/src/components/empty/assets/wuxiao.webp +0 -0
  165. package/src/components/empty/building.vue +0 -117
  166. package/src/components/empty/empty.vue +0 -120
  167. package/src/components/empty/index.js +0 -12
  168. package/src/components/empty/invalid.vue +0 -56
  169. package/src/components/error/Error.vue +0 -79
  170. package/src/components/error/readme.md +0 -20
  171. package/src/components/form/Form.vue +0 -84
  172. package/src/components/form/FormItem.vue +0 -143
  173. package/src/components/form/data.js +0 -52
  174. package/src/components/form/readme.md +0 -69
  175. package/src/components/layout/banner.vue +0 -412
  176. package/src/components/layout/bar.vue +0 -43
  177. package/src/components/layout/layout1.vue +0 -60
  178. package/src/components/layout/layout2.vue +0 -134
  179. package/src/components/layout/layout3.vue +0 -107
  180. package/src/components/layout/layout4.vue +0 -66
  181. package/src/components/layout/nav.vue +0 -333
  182. package/src/components/layout/readme.md +0 -61
  183. package/src/components/loading/index.vue +0 -122
  184. package/src/components/loading/readme.md +0 -6
  185. package/src/components/notice/NoticeList.vue +0 -198
  186. package/src/components/notice/NoticeListPaging.vue +0 -281
  187. package/src/components/notice/NoticeView.vue +0 -92
  188. package/src/components/notice/readme.md +0 -1
  189. package/src/components/pagination/index.vue +0 -100
  190. package/src/components/pagination/readme.md +0 -19
  191. package/src/components/pagination/scroll-to.js +0 -51
  192. package/src/components/progress/bar.vue +0 -72
  193. package/src/components/progress/progress.vue +0 -58
  194. package/src/components/screenfull/index.js +0 -3
  195. package/src/components/screenfull/index.vue +0 -65
  196. package/src/components/screenfull/package.json +0 -15
  197. package/src/components/screenfull/readme.md +0 -6
  198. package/src/components/statisticalCount/index.vue +0 -80
  199. package/src/components/statisticalCount/readme.md +0 -21
  200. package/src/components/username/index.vue +0 -79
  201. package/src/components/username/readme.md +0 -22
  202. package/src/components/username//346/225/210/346/236/234/345/233/276.png +0 -0
  203. package/src/index.js +0 -88
  204. package/src/utils/index.js +0 -32
  205. package/src/xm_components/HeadSearch/hook/hookSearch.js +0 -96
  206. package/src/xm_components/HeadSearch/index.vue +0 -206
  207. package/src/xm_components/HeadSearch/readme.md +0 -12
  208. package/src/xm_components/HeadSearch//346/220/234/347/264/242/345/210/227/350/241/250.png +0 -0
  209. package/src/xm_components/Milestone/index.vue +0 -213
  210. package/src/xm_components/Milestone/readme.md +0 -15
  211. package/src/xm_components/MultiStatisticalCard/image.png +0 -0
  212. package/src/xm_components/MultiStatisticalCard/index.vue +0 -114
  213. package/src/xm_components/MultiStatisticalCard/readme.md +0 -29
  214. package/src/xm_components/StatisticalCard/image.png +0 -0
  215. package/src/xm_components/StatisticalCard/index.vue +0 -196
  216. package/src/xm_components/StatisticalCard/readme.md +0 -41
  217. package/src/xm_components/readme.md +0 -1
  218. package/utils/coms/load.jsx +0 -10
  219. package/utils/func.js +0 -32
  220. package/utils/hookDialog.js +0 -38
  221. package/utils/hookPage.js +0 -49
  222. package/utils/index.js +0 -5
  223. package/utils/lib/console.js +0 -39
  224. package/utils/lib/debounce.js +0 -19
  225. package/utils/lib/deepextend.js +0 -51
  226. package/utils/lib/deepset.js +0 -14
  227. package/utils/lib/extend.js +0 -28
  228. package/utils/lib/index.js +0 -13
  229. package/utils/lib/json.js +0 -90
  230. package/utils/lib/mergeprops.js +0 -62
  231. package/utils/lib/mitt.js +0 -43
  232. package/utils/lib/modify.js +0 -8
  233. package/utils/lib/slot.js +0 -19
  234. package/utils/lib/toarray.js +0 -5
  235. package/utils/lib/tocase.js +0 -11
  236. package/utils/lib/todate.js +0 -10
  237. package/utils/lib/toline.js +0 -10
  238. package/utils/lib/tostring.js +0 -7
  239. package/utils/lib/type.js +0 -45
  240. package/utils/lib/unique.js +0 -6
  241. package/utils/message.js +0 -164
  242. package/utils/package.json +0 -16
  243. package/utils/type.js +0 -45
  244. package/vite.config.js +0 -56
@@ -1,196 +0,0 @@
1
- <!--
2
- * @FileDescription: 统计组件
3
- * @Author: 李兵泉
4
- * @Date: 2025-11-26
5
- * @LastEditors: 最后更新作者
6
- * @LastEditTime: 最后更新时间
7
- -->
8
- <template>
9
- <!-- 投资总额卡片容器 -->
10
- <div
11
- class="investment-card"
12
- :style="{ width: width }"
13
- v-if="_datas && _datas != ''"
14
- >
15
- <!-- 循环渲染数据项(空数据则不显示) -->
16
- <div class="data-item">
17
- <!-- 标题行(带提示图标) -->
18
- <div class="title-row">
19
- <span class="title">{{ _datas[0]?.title }}</span>
20
- <el-tooltip v-if="tip" :content="tip" placement="top">
21
- <el-icon size="16px" class="info-icon"><question-filled /></el-icon>
22
- </el-tooltip>
23
- </div>
24
- <!-- 数值行 -->
25
- <div
26
- class="value"
27
- :style="{
28
- color: _datas[0]?.valueColor || '#000',
29
- cursor: _datas[0]?.onClick ? 'pointer' : 'default',
30
- }"
31
- @click="handleItemClick(_datas[0], 0)"
32
- >
33
- {{ _datas[0]?.value }}
34
- </div>
35
- </div>
36
- <div style="display: flex" @click="handleItemClick(_datas[1], 1)">
37
- <!-- 数组 up2 -->
38
- <div v-if="_datas[1]" class="extra-row">
39
- <span class="extra-item">
40
- {{ _datas[1]?.title }}
41
- <span :class="['trend', _datas[1]?.trend === 'up' ? 'up' : 'down']">
42
- {{ _datas[1]?.value }}
43
- <el-icon class="trend-icon">
44
- <component
45
- :is="_datas[1]?.trend === 'up' ? 'caret-top' : 'caret-bottom'"
46
- />
47
- </el-icon>
48
- </span>
49
- </span>
50
- </div>
51
- <!-- 数组 down3 -->
52
- <div
53
- v-if="_datas[2]"
54
- class="extra-row"
55
- style="margin-left: 10%"
56
- @click="handleItemClick(_datas[2], 2)"
57
- >
58
- <span class="extra-item">
59
- {{ _datas[2]?.title }}
60
- <span :class="['trend', _datas[2]?.trend === 'up' ? 'up' : 'down']">
61
- {{ _datas[2]?.value }}
62
- <el-icon class="trend-icon">
63
- <component
64
- :is="_datas[2]?.trend === 'up' ? 'caret-top' : 'caret-bottom'"
65
- />
66
- </el-icon>
67
- </span>
68
- </span>
69
- </div>
70
- </div>
71
- <el-divider style="margin: 10px 0" />
72
- <div
73
- v-if="_datas[3]"
74
- class="extra-row"
75
- @click="handleItemClick(_datas[3], 3)"
76
- >
77
- <span class="extra-item" style="color: #595858">
78
- {{ _datas[3]?.title }}
79
- <span class="trend">
80
- {{ _datas[3]?.value }}
81
- </span>
82
- </span>
83
- </div>
84
- </div>
85
- </template>
86
-
87
- <script setup>
88
- import { ref, watch } from "vue";
89
-
90
- const _datas = ref([]);
91
- // 接收父组件传入的4组数据(数组,每个对象对应一组数据)
92
- const props = defineProps({
93
- // 组件默认宽度
94
- width: {
95
- type: String,
96
- default: "350px",
97
- },
98
- // 右上角提示信息
99
- tip: {
100
- type: String,
101
- default: "",
102
- },
103
- // 数据列表 格式参考readme
104
- dataList: {
105
- type: Array,
106
- default: () => [],
107
- },
108
- });
109
- const handleItemClick = (item, index) => {
110
- // 触发自定义事件,传递点击的指标项数据和索引
111
- if (item && item.onClick) {
112
- item.onClick(item, index);
113
- }
114
- };
115
- watch(
116
- () => props.dataList,
117
- (newVal) => {
118
- if (newVal && newVal.length > 0) {
119
- _datas.value = newVal;
120
- }
121
- },
122
- {
123
- immediate: true,
124
- }
125
- );
126
- </script>
127
-
128
- <style scoped>
129
- .investment-card {
130
- background: #fff;
131
- border-radius: 8px;
132
- padding: 12px;
133
- box-shadow: 0 2px 12px rgba(0, 0, 0, 0.1);
134
- }
135
-
136
- .data-item {
137
- margin-bottom: 12px;
138
- }
139
-
140
- .title-row {
141
- display: flex;
142
- justify-content: space-between;
143
- align-items: center;
144
- margin-bottom: 8px;
145
- color: #666;
146
- font-size: 14px;
147
- }
148
-
149
- .info-icon {
150
- cursor: pointer;
151
- color: #999;
152
- }
153
-
154
- .value {
155
- font-size: 28px;
156
- font-weight: bold;
157
- margin-bottom: 8px;
158
- }
159
-
160
- .extra-row {
161
- display: flex;
162
- gap: 16px;
163
- margin-bottom: 8px;
164
- font-size: 14px;
165
- }
166
-
167
- .extra-item {
168
- display: flex;
169
- align-items: center;
170
- color: #999;
171
- }
172
-
173
- .trend {
174
- margin-left: 4px;
175
- }
176
-
177
- .trend.up {
178
- color: #f56c6c;
179
- /* 红色-上升 */
180
- }
181
-
182
- .trend.down {
183
- color: #67c23a;
184
- /* 绿色-下降 */
185
- }
186
-
187
- .trend-icon {
188
- font-size: 12px;
189
- margin-left: 2px;
190
- }
191
-
192
- .additional {
193
- font-size: 14px;
194
- color: #666;
195
- }
196
- </style>
@@ -1,41 +0,0 @@
1
- ## 统计数组组件
2
-
3
- ```
4
-
5
- <template>
6
- <StatisticalCard :dataList="dataList" tip="投资总额说明111"></StatisticalCard>
7
- </template>
8
- <script setup>
9
- import { ref, reactive, computed, watch, onMounted } from "vue";
10
- import { StatisticalCard } from '@bdsoft/element'
11
-
12
- const dataList = ref([
13
- {
14
- title: '总用户数',
15
- value: 1024,
16
- valueColor:'red',
17
- trend: '',
18
- },
19
- {
20
- title: '活跃用户数',
21
- value: 768,
22
- valueColor:'',
23
- trend: 'up',
24
- },
25
- {
26
- title: '新增用户数',
27
- value: 256,
28
- valueColor:'',
29
- trend: 'down',
30
- },
31
- {
32
- title: '付费用户数',
33
- value: 128,
34
- valueColor:'',
35
- trend: ''
36
- }
37
- ]);
38
- </script>
39
-
40
- <style lang="scss" scoped></style>
41
- ```
@@ -1 +0,0 @@
1
- 项目组件说明
@@ -1,10 +0,0 @@
1
- function LoadComponent(props, { slots, emit, attrs }) {
2
- return (
3
- <div class="loadsvg" style="height:20px;width:20px;">
4
- <svg viewBox="0 0 1024 1024" focusable="false" data-icon="loading" width="1em" height="1em" fill="currentColor" aria-hidden="true">
5
- <path d="M988 548c-19.9 0-36-16.1-36-36 0-59.4-11.6-117-34.6-171.3a440.45 440.45 0 00-94.3-139.9 437.71 437.71 0 00-139.9-94.3C629 83.6 571.4 72 512 72c-19.9 0-36-16.1-36-36s16.1-36 36-36c69.1 0 136.2 13.5 199.3 40.3C772.3 66 827 103 874 150c47 47 83.9 101.8 109.7 162.7 26.7 63.1 40.2 130.2 40.2 199.3.1 19.9-16 36-35.9 36z"></path>
6
- </svg>
7
- </div>
8
- )
9
- }
10
- export default LoadComponent
package/utils/func.js DELETED
@@ -1,32 +0,0 @@
1
- import is from './type';
2
-
3
- /**
4
- * 获取url参数
5
- * @param {*} name
6
- * @returns
7
- */
8
- export function getUrlKey(name, url) {
9
- return decodeURIComponent((new RegExp('[?|&]' + name + '=' + '([^&;]+?)(&|#|;|$)').exec(url || location.href) || [, ''])[1].replace(/\+/g, '%20')) || null
10
- }
11
-
12
- // 生成guid
13
- function S4() {
14
- return (((1 + Math.random()) * 0x10000) | 0).toString(16).substring(1)
15
- }
16
-
17
- // 生成guid
18
- export function NewGuid() {
19
- return S4() + S4() + '-' + S4() + '-' + S4() + '-' + S4() + '-' + S4() + S4() + S4()
20
- }
21
-
22
- // 创建一个防抖函数
23
- // const debouncedClick = debounce(handleQa, 500);
24
- export const debounce = (func, delay) => {
25
- let timer
26
- return (...args) => {
27
- clearTimeout(timer)
28
- timer = setTimeout(() => {
29
- func(...args)
30
- }, delay)
31
- }
32
- }
@@ -1,38 +0,0 @@
1
- import { ref, nextTick } from 'vue'
2
-
3
- // 公共的Hook,用于管理对话框的显示和隐藏 用法如下:
4
- // import {useDialog} from '@bdsoft/element'
5
- // const { visible, showDialog,openParms,hideDialog } = useDialog()
6
- // defineExpose({
7
- // showDialog,
8
- // hideDialog
9
- // })
10
- // 自定义Hook,用于管理对话框的显示和隐藏
11
- export function useDialog(showFn) {
12
- const visible = ref(false)
13
- // 打开窗体传递的对象
14
- const openParms = ref({})
15
- const extParms = ref({}) // 扩展用
16
- // 显示窗体
17
- const showDialog = (parm,ext) => {
18
- visible.value = true
19
- openParms.value = parm
20
-
21
- extParms.value = ext
22
- nextTick(() => {
23
- showFn && showFn()
24
- })
25
- }
26
- // 隐藏窗体
27
- const hideDialog = () => {
28
- visible.value = false
29
- }
30
-
31
- return {
32
- visible,
33
- openParms,
34
- extParms,
35
- showDialog,
36
- hideDialog
37
- }
38
- }
package/utils/hookPage.js DELETED
@@ -1,49 +0,0 @@
1
- // 分页hook函数 参考说明 components/Pagination/readme.md
2
- import { reactive, toRefs } from 'vue'
3
-
4
- export function usePage(changeFn) {
5
- //
6
-
7
- let page = reactive({
8
- // 数据服务分页参数值
9
- pageHeader: {
10
- startindex: 0,
11
- pagesize: 30,
12
- carrytotal: true
13
- },
14
- currentPage: 1,
15
- pageSizes: [30, 60, 90],
16
- pageSize: 30,
17
- total: 0
18
- })
19
-
20
- function handleSizeChange(val) {
21
- page.pageSize = val
22
- // page.pageHeader.mend = val
23
- changeFn()
24
- }
25
- function handleCurrentChange(val) {
26
- page.currentPage = val
27
- page.pageHeader.startindex = val - 1
28
- changeFn()
29
- }
30
- /**
31
- *
32
- * @param {*} pageobj { page: currentPage.value, pageSize: val }
33
- */
34
- function handlePagination(pageobj) {
35
- let pageIndex = pageobj.page
36
- let pageSize = pageobj.pageSize
37
- page.currentPage = pageIndex
38
- page.pageSize = pageSize
39
- page.pageHeader.startindex = (pageIndex - 1) * pageSize
40
- page.pageHeader.pagesize = pageSize
41
- changeFn()
42
- }
43
- return {
44
- ...toRefs(page),
45
- handleSizeChange,
46
- handleCurrentChange,
47
- handlePagination
48
- }
49
- }
package/utils/index.js DELETED
@@ -1,5 +0,0 @@
1
- export * from './message.js'
2
- export * from './func.js'
3
- // export * from './usewerter.js'
4
- // export * from './filter.js'
5
- // export * from './bus.js'
@@ -1,39 +0,0 @@
1
- /**
2
- * 格式化日志信息
3
- *
4
- * @param {String} type - 日志类型,如 'tip' 或 'err'
5
- * @param {String} msg - 日志消息内容
6
- * @param {Object} rule - 可选参数,与日志相关的规则对象
7
- * @returns {String} - 返回格式化后的日志字符串
8
- */
9
- export function format(type, msg, rule) {
10
- // 使用模板字符串构建日志信息,包含日志类型和消息内容
11
- let logMsg = `[form-create ${type}]: ${msg}`;
12
- // 如果提供了规则对象,则将其转换为JSON字符串并添加到日志信息中
13
- if (rule) {
14
- logMsg += `\n\nrule: ${JSON.stringify(rule.getRule ? rule.getRule() : rule)}`;
15
- }
16
- // 返回格式化后的日志字符串
17
- return logMsg;
18
- }
19
-
20
- /**
21
- * 输出格式化的提示信息到控制台
22
- *
23
- * @param {String} msg - 提示信息的内容
24
- * @param {Object} rule - 可选参数,与提示信息相关的规则对象
25
- */
26
- export function tip(msg, rule) {
27
- // 使用 format 函数格式化提示信息,并通过 console.warn 输出到控制台
28
- console.warn(format('tip', msg, rule));
29
- }
30
-
31
-
32
- export function err(msg, rule) {
33
- console.error(format('err', msg, rule));
34
- }
35
-
36
- export function logError(e) {
37
- err(e.toString());
38
- console.error(e);
39
- }
@@ -1,19 +0,0 @@
1
- /**
2
- * 防抖函数,用于限制函数的执行频率。
3
- *
4
- * @param {Function} fn - 需要防抖的函数。
5
- * @param {number} wait - 防抖的时间间隔,单位为毫秒。
6
- * @returns {Function} - 返回一个新的函数,该函数在指定的时间间隔内只会执行一次。
7
- */
8
- export default function debounce(fn, wait) {
9
- // 用于存储定时器的变量
10
- var timeout = null;
11
- // 返回一个新的函数,该函数在指定的时间间隔内只会执行一次
12
- return function (...arg) {
13
- // 如果定时器已经存在,则清除定时器
14
- if (timeout !== null)
15
- clearTimeout(timeout);
16
- // 设置新的定时器,在指定的时间间隔后执行传入的函数
17
- timeout = setTimeout(() => fn.call(this, ...arg), wait);
18
- }
19
- }
@@ -1,51 +0,0 @@
1
- import {$set} from './modify';
2
- import is from './type';
3
-
4
- export default function deepExtend(origin, target = {}, mode) {
5
- let isArr = false;
6
- for (let key in target) {
7
- if (Object.prototype.hasOwnProperty.call(target, key)) {
8
- let clone = target[key];
9
- if ((isArr = Array.isArray(clone)) || is.Object(clone)) {
10
- let nst = origin[key] === undefined;
11
- if (isArr) {
12
- isArr = false;
13
- nst && $set(origin, key, []);
14
- } else if (clone._clone && mode !== undefined) {
15
- if (mode) {
16
- clone = clone.getRule();
17
- nst && $set(origin, key, {});
18
- } else {
19
- $set(origin, key, clone._clone());
20
- continue;
21
- }
22
- } else {
23
- nst && $set(origin, key, {});
24
- }
25
- origin[key] = deepExtend(origin[key], clone, mode);
26
- } else {
27
- $set(origin, key, clone);
28
- if (!is.Undef(clone)) {
29
- if (!is.Undef(clone.__json)) {
30
- origin[key].__json = clone.__json;
31
- }
32
- if (!is.Undef(clone.__origin)) {
33
- origin[key].__origin = clone.__origin;
34
- }
35
- }
36
- }
37
- }
38
- }
39
- return (mode !== undefined && Array.isArray(origin)) ? origin.filter(v => !v || !v.__ctrl) : origin
40
- }
41
-
42
- export function deepCopy(value) {
43
- return deepExtend({}, {value}).value;
44
- }
45
-
46
- export function deepExtendArgs(origin, ...lst) {
47
- lst.forEach(target => {
48
- origin = deepExtend(origin, target);
49
- });
50
- return origin;
51
- }
@@ -1,14 +0,0 @@
1
- export default function deepSet(data, idx, val) {
2
- let _data = data, to;
3
- (idx || '').split('.').forEach(v => {
4
- if (to) {
5
- if (!_data[to] || typeof _data[to] != 'object') {
6
- _data[to] = {}
7
- }
8
- _data = _data[to];
9
- }
10
- to = v;
11
- })
12
- _data[to] = val;
13
- return _data;
14
- }
@@ -1,28 +0,0 @@
1
- import {$set} from './modify';
2
-
3
- const _extends = Object.assign || function (a) {
4
- for (let b, c = 1; c < arguments.length; c++) {
5
- for (let d in b = arguments[c], b) {
6
- Object.prototype.hasOwnProperty.call(b, d) && ($set(a, d, b[d]));
7
- }
8
- }
9
-
10
- return a;
11
- }
12
- /**
13
- * 将传入的多个对象合并成一个新的对象,并返回这个新对象。
14
- *
15
- * @returns {Object} - 合并后的新对象。
16
- */
17
- export default function extend() {
18
- // 使用 _extends 函数将传入的所有对象合并成一个新的对象,并返回这个新对象
19
- return _extends.apply(this, arguments);
20
- }
21
-
22
- export function copy(obj) {
23
- // 如果 obj 不是对象或者为 null,则直接返回 obj
24
- if (typeof obj !== 'object' || obj === null) return obj;
25
- // 如果 obj 是数组,则使用扩展运算符复制数组
26
- // 如果 obj 是对象,则使用扩展运算符复制对象
27
- return obj instanceof Array ? [...obj] : {...obj};
28
- }
@@ -1,13 +0,0 @@
1
- export {default as debounce} from './debounce';
2
- export {default as toArray} from './toarray';
3
- export {default as toString} from './tostring';
4
- export {default as toLine} from './toline';
5
- export {default as toDate} from './todate';
6
- export {default as deepExtend, deepExtendArgs, deepCopy} from './deepextend';
7
- export {default as extend, copy} from './extend';
8
- export {parseJson, toJson} from './json';
9
- export {$set, $del} from './modify';
10
- export {default as is} from './type';
11
- export {default as uniqueId} from './unique';
12
- export {default as getSlot} from './slot';
13
- export {default as deepSet} from './deepset';
package/utils/lib/json.js DELETED
@@ -1,90 +0,0 @@
1
- import deepExtend from './deepextend';
2
- import {err} from './console';
3
- import is from './type';
4
-
5
- const PREFIX = '[[FORM-CREATE-PREFIX-';
6
- const SUFFIX = '-FORM-CREATE-SUFFIX]]';
7
-
8
- export function toJson(obj, space) {
9
- return JSON.stringify(deepExtend(Array.isArray(obj) ? [] : {}, obj, true), function (key, val) {
10
- if (val && val._isVue === true)
11
- return undefined;
12
-
13
- if (typeof val !== 'function') {
14
- return val;
15
- }
16
- if (val.__json) {
17
- return val.__json;
18
- }
19
- if (val.__origin)
20
- val = val.__origin;
21
-
22
- if (val.__emit)
23
- return undefined;
24
- return PREFIX + val + SUFFIX;
25
- }, space);
26
- }
27
-
28
- function makeFn(fn) {
29
- return (new Function('return ' + fn))();
30
- }
31
-
32
- export function parseFn(fn, mode) {
33
- if (fn && is.String(fn) && fn.length > 4) {
34
- let v = fn.trim();
35
- let flag = false;
36
- try {
37
- if (v.indexOf(SUFFIX) > 0 && v.indexOf(PREFIX) === 0) {
38
- v = v.replace(SUFFIX, '').replace(PREFIX, '');
39
- flag = true;
40
- } else if (v.indexOf('$FN:') === 0) {
41
- v = v.substring(4);
42
- flag = true;
43
- } else if (v.indexOf('$EXEC:') === 0) {
44
- v = v.substring(6);
45
- flag = true;
46
- } else if (v.indexOf('$GLOBAL:') === 0) {
47
- const name = v.substring(8);
48
- v = function (...args) {
49
- const callback = args[0].api.getGlobalEvent(name);
50
- if (callback) {
51
- return callback.call(this, ...args);
52
- }
53
- return undefined;
54
- }
55
- v.__json = fn;
56
- v.__inject = true;
57
- return v;
58
- } else if (v.indexOf('$FNX:') === 0) {
59
- v = makeFn('function($inject){' + v.substring(5) + '}');
60
- v.__json = fn;
61
- v.__inject = true;
62
- return v;
63
- } else if (!mode && v.indexOf('function ') === 0 && v !== 'function ') {
64
- flag = true;
65
- } else if (!mode && v.indexOf('function(') === 0 && v !== 'function(') {
66
- flag = true;
67
- }
68
- if (!flag) return fn;
69
- let val;
70
- try{
71
- val = makeFn(v);
72
- }catch (e){
73
- val = makeFn('function ' + v);
74
- }
75
- val.__json = fn;
76
- return val;
77
- } catch (e) {
78
- err(`解析失败:${v}\n\nerr: ${e}`);
79
- return undefined;
80
- }
81
- }
82
- return fn;
83
- }
84
-
85
- export function parseJson(json, mode) {
86
- return JSON.parse(json, function (k, v) {
87
- if (is.Undef(v) || !v.indexOf) return v;
88
- return parseFn(v, mode);
89
- });
90
- }