@weitutech/by-components 1.0.31 → 1.1.1

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.
package/package.json CHANGED
@@ -1,13 +1,24 @@
1
1
  {
2
2
  "name": "@weitutech/by-components",
3
- "version": "1.0.31",
3
+ "version": "1.1.1",
4
4
  "private": false,
5
- "main": "src/index",
5
+ "main": "lib/by-components.umd.js",
6
+ "module": "lib/by-components.esm.js",
7
+ "files": [
8
+ "lib",
9
+ "dist"
10
+ ],
11
+ "sideEffects": [
12
+ "*.vue",
13
+ "*.scss"
14
+ ],
6
15
  "scripts": {
7
16
  "dev": "vue-cli-service serve",
8
17
  "build": "npm run build:js && npm run build:css",
9
18
  "build:js": "vue-cli-service build --target lib --name by-components src/index.js",
10
- "build:css": "sass src/style/index.scss lib/index.css --no-source-map --style=compressed"
19
+ "build:css": "sass src/style/index.scss lib/index.css --no-source-map --style=compressed",
20
+ "lint:fix": "eslint --ext .js,.vue src --fix",
21
+ "format": "prettier --write \"src/**/*.{js,vue,json,scss}\""
11
22
  },
12
23
  "dependencies": {
13
24
  "axios": "^1.7.7",
@@ -18,15 +29,23 @@
18
29
  "moment": "^2.30.1",
19
30
  "vue": "^2.6.14",
20
31
  "vuedraggable": "^2.24.3",
21
- "vxe-table": "3.8.24"
32
+ "vxe-table": "^3.8.24"
22
33
  },
23
34
  "devDependencies": {
35
+ "@babel/core": "^7.19.1",
24
36
  "@babel/plugin-proposal-nullish-coalescing-operator": "^7.18.6",
25
37
  "@babel/plugin-proposal-optional-chaining": "^7.21.0",
38
+ "@babel/preset-env": "^7.27.2",
26
39
  "@vue/cli-plugin-babel": "~5.0.0",
27
40
  "@vue/cli-service": "~5.0.0",
41
+ "@vue/eslint-config-prettier": "^10.2.0",
42
+ "eslint": "^8.57.1",
43
+ "eslint-config-prettier": "^9.1.0",
44
+ "eslint-plugin-prettier": "^4.2.1",
45
+ "eslint-plugin-vue": "^9.3.0",
46
+ "prettier": "^3.5.3",
28
47
  "sass": "^1.79.4",
29
48
  "sass-loader": "^16.0.2",
30
49
  "vue-template-compiler": "^2.6.14"
31
50
  }
32
- }
51
+ }
package/CHANGELOG.md DELETED
@@ -1,44 +0,0 @@
1
- # 1.0.30 (2025-04-17)
2
-
3
- ### feat
4
-
5
- - 增加表格列表的保存
6
-
7
- # 1.0.27 (2024-12-04)
8
-
9
- ### 🍏 Perf
10
-
11
- - 多级表头分组之间增加间隔
12
-
13
- # 1.0.26 (2024-12-04)
14
-
15
- ### 🐞 Bug fixes
16
-
17
- - 修复自定义列中,没有列设置 fixed 时的报错
18
-
19
- # 1.0.25 (2024-12-04)
20
-
21
- ### 🍏 Perf
22
-
23
- - 自定义列支持多级表头展示
24
-
25
- # 1.0.24 (2024-11-30)
26
-
27
- ### 🐞 Bug fixes
28
-
29
- - 修复表单中通过插槽的组件数据被清空问题导致卡顿问题
30
-
31
- ### 🍏 Perf
32
-
33
- - 优化选择器组件移除 input 事件、防止选择器选择的时候执行两次
34
-
35
- # 1.0.23 (2024-11-25)
36
-
37
- ### 🐞 Bug fixes
38
-
39
- - 修复日期选择器组件在 form 表格组件中使用时对多个不同的时间配置设置初始时间没有生效问题
40
-
41
- ### 🍏 Perf
42
-
43
- - 优化日期选择器手动设置自定义值的时候自动匹配高亮出现有的时间选项
44
- - 优化表格组件中对最大宽度和最小宽度的设置
package/docs/extension.md DELETED
@@ -1,15 +0,0 @@
1
- ### 如需要扩展
2
-
3
- 1. 应从 vex-table 第三方组件库查看是否有相应的功能
4
-
5
- 2. 如需要加入通用实用的表单元素、应该先考虑在组件form中加入、其次是以custom插槽的形式插入
6
-
7
- ### 第三方插件
8
-
9
- [element-ui](https://element.eleme.cn/#/zh-CN)
10
-
11
- [vuedraggable](https://www.npmjs.com/package/vuedraggable)
12
-
13
- [vxe-table](https://vxetable.cn/pluginDocs/table3/#/demo/list)
14
-
15
- [moment](https://momentjs.cn/)
package/docs/form.md DELETED
@@ -1,52 +0,0 @@
1
- ### 类型(没有注册看 Element 的组件使用方法)
2
-
3
- ```
4
- | 'input'
5
- | 'inputNumber'
6
- | 'select'
7
- | 'treeSelect'
8
- | 'datepicker'
9
- | 'cascader'
10
- | 'switch'
11
- | 'checkbox'
12
- | 'radio'
13
- | 'upload'
14
- | 'customDatePicker' // 自定义的时间选择器
15
- | 'search' // 搜索按钮区域
16
- | 'custom' // 自定义
17
- ```
18
-
19
- #### Event
20
-
21
- | 事件 | 参数 |
22
- | ------------- | ------------------- |
23
- | change | context: IFormItems |
24
- | queryBtnClick | 无 |
25
-
26
- 完整案列见 [表单 by-form](../README.md)
27
-
28
- ### 特殊说明
29
-
30
- #### 'customDatePicker'特别说明
31
-
32
- 自定义时间选中器同时支持时间段方式绑定值 和 单独时间方式绑定值
33
-
34
- ```
35
- // 时间段方式绑定值
36
- {
37
- type: 'customDatePicker',
38
- field: 'report_time',
39
- label: '报表时间'
40
- }
41
- ```
42
-
43
- ```
44
- // 单独时间方式绑定值
45
- {
46
- type: 'customDatePicker',
47
- field: 'report_time', // 仍然保留原来的字段,保证兼容性
48
- startTimeField: 'start_time', // 新增开始时间字段
49
- endTimeField: 'end_time', // 新增结束时间字段
50
- label: '报表时间'
51
- }
52
- ```
package/docs/table.md DELETED
@@ -1,26 +0,0 @@
1
- ### table
2
- #### 自定义列宽
3
- 注意📢: 一个项目中的name属性千万不能重名、一个项目中的name属性千万不能重名、一个项目中的name属性千万不能重名
4
- 给table组件设置name值属性、类型为String格式、表格会自动缓存用户拖拽之后的结果
5
- #### 自定义列
6
- 给table组件设置以下对象
7
- customColumnConfig: { // 自定义列
8
- showCustomColumn: true, // 是否显示自定义列
9
- infoMethod: getCustomTableList, // 回显用的接口
10
- infoMethodParams: {}, // 回显用的接口参数
11
- submitMethod: setCustomTableList, // 保存用的接口
12
- submitMethodParams: {}, // 保存用的接口参数
13
- slots: ["source_material_count"] // 需要使用插槽的字段集合
14
- }
15
- 并通过事件Event @setColumn="handleSetColumn" 实现对列的设置
16
- const handleSetColumn = (columns) => {
17
- this.gridOptions.columns = [
18
- { type: "checkbox", width: 50, fixed: "left" },
19
- { type: "seq", width: 50, fixed: "left", title: "序号" },
20
- ...columns,
21
- { title: "操作", width: 80, fixed: "right", slots: { default: "operate" }}
22
- ]
23
- }
24
- #### Event
25
- 见[第三方插件vxe-table](./extension.md)
26
- 完整案列见 [表格 by-table](../README.md)
@@ -1,369 +0,0 @@
1
- <!-- 自定义表头 -->
2
- <template>
3
- <div id="custom_column">
4
- <el-dialog
5
- :close-on-click-modal="false"
6
- :visible="dialogVisible"
7
- width="920px"
8
- :append-to-body="true"
9
- :show-close="false"
10
- custom-class="custom_dialog_class"
11
- @close="closeDialog"
12
- >
13
- <div class="el-dialog-box">
14
- <!-- 数据指标 -->
15
- <div class="left_box">
16
- <div class="box_title">数据指标</div>
17
- <div class="row" style="padding-right: 20px;">
18
- <div class="cell">
19
- <el-input
20
- v-model="search"
21
- style="width: 228px; margin-bottom: 10px"
22
- placeholder="搜索指标"
23
- size="medium"
24
- prefix-icon="el-icon-search"
25
- />
26
- </div>
27
- <el-button type="text" @click="selectNone">全不选</el-button>
28
- </div>
29
- <div class="left_box_body">
30
- <div class="left_nav">
31
- <ul>
32
- <li
33
- v-for="(item, index) in checkBoxMenuBySearch"
34
- :key="index"
35
- :class="{ active: activeId === index }"
36
- @click="setHighlight(index)"
37
- >
38
- {{ item.label }}
39
- </li>
40
- </ul>
41
- </div>
42
- <div class="left_menu">
43
- <div v-for="(item, index) in checkBoxMenuBySearch" :key="index" ref="tagItem">
44
- <div class="checkbox_title">
45
- {{ item.label }}
46
- </div>
47
- <el-row>
48
- <el-col
49
- v-for="(each, idx) in item.data"
50
- :key="idx"
51
- :span="12"
52
- style="margin-bottom:3px"
53
- >
54
- <el-checkbox
55
- v-model="each.type"
56
- @change="changeCheckbox(each.key,each.type)"
57
- >
58
- {{ each.label }}
59
- </el-checkbox>
60
- </el-col>
61
- </el-row>
62
- </div>
63
- </div>
64
- </div>
65
- </div>
66
- <!-- 已选指标 -->
67
- <div class="right_box">
68
- <div class="drag_box">
69
- <el-row>
70
- <div class="drag_text_box">
71
- <span class="drag_title">{{`已选指标(${number})`}}</span>
72
- <span class="recover" @click="recoverDefault">恢复默认</span>
73
- </div>
74
- </el-row>
75
- <div class="drag_ul">
76
- <draggable
77
- v-model="draggableMenu"
78
- chosen-class="chosen"
79
- force-fallback="true"
80
- animation="500"
81
- @end="onEnd"
82
- >
83
- <transition-group>
84
- <div
85
- v-for="(col) in draggableMenu"
86
- v-show="col.type"
87
- :class="col.key === 'sort-cut-off' ? 'fixedClass' : 'drag_li_box'"
88
- :key="col.key"
89
- >
90
- <div v-if="col.key !== 'sort-cut-off'">
91
- <i class="el-icon-rank icon-box" />
92
- <span class="drag_li_text">{{ col.label }}</span>
93
- </div>
94
- <i
95
- v-if="col.key !== 'sort-cut-off'"
96
- class="el-icon-close remove"
97
- @click="changeCheckbox(col.key, false)"
98
- />
99
- </div>
100
- </transition-group>
101
- </draggable>
102
- </div>
103
- </div>
104
- </div>
105
- </div>
106
- <template #footer>
107
- <el-row style="margin-top: 7px">
108
- <el-button
109
- size="small"
110
- style="width: 96px"
111
- @click="closeDialog"
112
- >取消</el-button>
113
- <el-button
114
- size="small"
115
- style="width: 96px"
116
- type="primary"
117
- @click="submit"
118
- >确定</el-button>
119
- </el-row>
120
- </template>
121
- </el-dialog>
122
- </div>
123
- </template>
124
-
125
- <script>
126
- import draggable from "vuedraggable"
127
- import { deepClone } from "../../utils/index"
128
- export default {
129
- name: "CustomColumn",
130
- components: {
131
- draggable
132
- },
133
- props: {
134
- dialogVisible: {
135
- type: Boolean,
136
- default: false
137
- },
138
- infoMethod: {
139
- type: Function,
140
- required: true,
141
- default: () => {}
142
- },
143
- submitMethod: {
144
- type: Function,
145
- required: true,
146
- default: () => {}
147
- }
148
- },
149
- data() {
150
- return {
151
- draggableMenu: [],
152
- /** 勾选的主标题菜单 */
153
- checkBoxMenu: [],
154
- /** 选中高亮的菜单ID */
155
- activeId: 0,
156
- /** 表头id */
157
- id: undefined,
158
- /** 表格列接口路径 */
159
- page: "",
160
- /** 搜索字段 */
161
- search: "",
162
- }
163
- },
164
- computed: {
165
- number() {
166
- return this.draggableMenu.filter(item => item.type && item.key !== "sort-cut-off").length
167
- },
168
- checkBoxMenuBySearch() {
169
- if (this.search) {
170
- return this.checkBoxMenu.map(group => {
171
- const filteredItems = group.data.filter(item => item.label.includes(this.search))
172
- return {
173
- label: group.label,
174
- data: filteredItems
175
- };
176
- }).filter(group => group.data.length > 0)
177
- } else {
178
- return this.checkBoxMenu
179
- }
180
-
181
- }
182
- },
183
- methods: {
184
- deepClone,
185
- /**
186
- * @describe 获取自定义表头数据
187
- * @param { string } page 表格列接口路径
188
- * @param { object[] } column 列数据
189
- */
190
- async getCustomTableList(page, column) {
191
- if (!page) {
192
- throw new Error("缺少表格列接口路径");
193
- } else {
194
- // 克隆一份
195
- this.columnList = this.deepClone(column)
196
- this.page = page || ""
197
- const bePreservedColumn = []
198
- const res = await this.infoMethod({ page: page })
199
- if (JSON.stringify(res.data) !== "[]") {
200
- this.id = res.data.id || undefined
201
- res.data.column.forEach(col => bePreservedColumn.push(...col.data))
202
- }
203
- this.initTableList(this.deepClone(column), bePreservedColumn)
204
- }
205
- },
206
- /**
207
- * @describe 第一次保存执行的函数(还未保存过的情况下)
208
- * @param { object[] } initColumn 初始的列数据
209
- * @param { object[] } bePreservedColumn 被保存过的列数据
210
- */
211
- initTableList(initColumn, bePreservedColumn = []) {
212
- const setDraggableMenu = (arr) => {
213
- const cols = []
214
- arr.forEach(item => cols.push(...item.data))
215
- cols.sort((a, b) => a.sort - b.sort)
216
- if(cols.some(item=> item.fixed)) {
217
- let cutOffIndex = 0
218
- for(let index = 0; index <= cols.length; index++) {
219
- const col = cols[index]
220
- const nextCol = cols[index + 1]
221
- if (col.fixed === "left" && (!nextCol || !nextCol.fixed)) {
222
- cutOffIndex = index + 1
223
- break
224
- }
225
- }
226
- cols.splice(cutOffIndex, 0, {
227
- type: true,
228
- label: "",
229
- key: "sort-cut-off",
230
- parent: ""
231
- })
232
- }
233
- return cols
234
- }
235
- if (bePreservedColumn && bePreservedColumn.length > 0) {
236
- // 需要处理被保存过的进行回显
237
- initColumn.forEach((cols) => {
238
- cols.data.forEach((col) => {
239
- const beSaveCol = bePreservedColumn.find(item => item.key === col.key) || {}
240
- col.type = (beSaveCol.type === "true" || beSaveCol.type === true) ? true : false
241
- col.sort = beSaveCol.sort
242
- col.fixed = beSaveCol.fixed ? beSaveCol.fixed : col.fixed,
243
- col.parent = { label: cols.label }
244
- })
245
- })
246
- // 需要显示的列的数据
247
- this.checkBoxMenu = this.deepClone(initColumn)
248
- this.draggableMenu = setDraggableMenu(this.checkBoxMenu)
249
- } else {
250
- // 从未被保存过
251
- let num = 0
252
- initColumn.forEach((cols) => {
253
- cols.data.forEach((col) => {
254
- num++
255
- col.type = true
256
- col.width = col.width ? +col.width : 0,
257
- col.sort = num
258
- col.parent = { label: cols.label }
259
- })
260
- })
261
- this.checkBoxMenu = this.deepClone(initColumn)
262
- this.draggableMenu = setDraggableMenu(this.checkBoxMenu)
263
- }
264
- this.$emit("changeTable", this.draggableMenu.filter(item => item.key !== "sort-cut-off").sort((a, b) => a.sort - b.sort))
265
- this.$emit("changeTableGroup", this.checkBoxMenu)
266
- },
267
- // 全不选
268
- selectNone() {
269
- this.checkBoxMenu.forEach(cols => cols.data.forEach(col => col.type = false))
270
- this.draggableMenu.forEach(item => {
271
- if (item.key === "sort-cut-off") {
272
- item.type = true
273
- } else {
274
- item.type = false
275
- }
276
- })
277
- },
278
- /**
279
- * @describe 点击高亮
280
- * @param { number } index 索引
281
- */
282
- setHighlight(index) {
283
- this.activeId = index
284
- if (this.$refs.tagItem) {
285
- this.$refs.tagItem[index].scrollIntoView({ behavior: "smooth" })
286
- }
287
- },
288
- /**
289
- * @describe 勾选、关闭
290
- * @param { string } key 唯一标识
291
- * @param { boolean } type 是否显示
292
- */
293
- changeCheckbox(key, type) {
294
- this.draggableMenu.forEach(item => {
295
- if (item.key === key) {
296
- item.type = type
297
- }
298
- })
299
- this.checkBoxMenu.forEach(item => {
300
- item.data.forEach(each => {
301
- if (each.key === key) {
302
- each.type = type
303
- }
304
- })
305
- })
306
- },
307
- // 恢复默认
308
- recoverDefault() {
309
- this.initTableList(this.deepClone(this.columnList))
310
- },
311
- // 拖拽结束事件
312
- onEnd() {
313
- let isFixed = true
314
- this.draggableMenu.forEach((item, index) => {
315
- if (item.key === "sort-cut-off") { isFixed = false }
316
- if (isFixed) {
317
- item.sort = index + 1
318
- item.fixed = "left"
319
- } else {
320
- item.sort = index
321
- delete item.fixed
322
- }
323
- })
324
- },
325
- // 点击保存
326
- async submit() {
327
- const params = {
328
- column: [],
329
- id: this.id,
330
- page: this.page
331
- }
332
- this.draggableMenu.forEach(item => {
333
- if (item.key !== "sort-cut-off") {
334
- const { parent, ...other } = item
335
- // 是否存在
336
- const isExit = params.column.some(col => col.label === parent.label)
337
- if (isExit) {
338
- params.column.forEach(col => {
339
- if (col.label === parent.label) {
340
- col.data.push(other)
341
- }
342
- })
343
- } else {
344
- params.column.push({
345
- label: parent.label,
346
- data: [other]
347
- })
348
- }
349
- }
350
- })
351
- await this.submitMethod(params)
352
- const cols = []
353
- params.column.forEach(item => {
354
- cols.push(...item.data)
355
- })
356
- this.$emit("changeTable", cols.sort((a, b) => a.sort - b.sort))
357
- this.$emit("changeTableGroup", params.column)
358
- this.closeDialog()
359
- },
360
- // 关闭弹窗
361
- closeDialog() {
362
- // 重置数据
363
- this.search = ""
364
- this.activeId = 0
365
- this.$emit("closeDialog")
366
- }
367
- }
368
- }
369
- </script>
@@ -1,29 +0,0 @@
1
- <template>
2
- <div class="drawer_query_btn b-fold-search">
3
- <div @click="drawer">
4
- <template v-if="show == true">
5
- <span style="color: #3aa1ff; vertical-align:middle;">收起</span>&nbsp;&nbsp;<img style="vertical-align:middle;" src="" alt="收起">
6
- </template>
7
- <template v-else>
8
- <span style="color: #3aa1ff; vertical-align:middle;">展开更多</span>&nbsp;&nbsp;<img style="vertical-align:middle;" src="" alt="展开更多">
9
- </template>
10
- </div>
11
- </div>
12
- </template>
13
- <script>
14
- export default {
15
- data() {
16
- return {
17
- show: false
18
- }
19
- },
20
- methods: {
21
- drawer(value) {
22
- this.show = !this.show
23
- this.$emit("change", this.show)
24
- }
25
-
26
- }
27
- }
28
- </script>
29
-