haiwei-ui 1.0.3 → 1.0.5

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 (109) hide show
  1. package/README.md +10 -0
  2. package/package.json +1 -1
  3. package/packages/components/box/index.vue +116 -125
  4. package/packages/components/box-col/index.vue +30 -33
  5. package/packages/components/box-row/index.vue +17 -17
  6. package/packages/components/box-small/index.vue +38 -38
  7. package/packages/components/button/index.vue +29 -42
  8. package/packages/components/button-copy/index.vue +46 -62
  9. package/packages/components/button-delete/index.vue +64 -77
  10. package/packages/components/button-delete-batch/index.vue +82 -95
  11. package/packages/components/button-has/index.vue +29 -42
  12. package/packages/components/checkbox-group/index.vue +85 -85
  13. package/packages/components/color-picker/index.vue +41 -50
  14. package/packages/components/container/index.vue +8 -8
  15. package/packages/components/date-range-picker/index.vue +92 -103
  16. package/packages/components/details/index.vue +72 -79
  17. package/packages/components/dialog/index.vue +281 -294
  18. package/packages/components/drag-sort/index.vue +36 -36
  19. package/packages/components/drag-sort-dialog/index.vue +58 -58
  20. package/packages/components/drawer/index.vue +157 -166
  21. package/packages/components/enums/sex/index.vue +1 -1
  22. package/packages/components/flex/index.vue +33 -33
  23. package/packages/components/form/index.vue +123 -138
  24. package/packages/components/form-dialog/index.vue +184 -217
  25. package/packages/components/form-page/index.vue +134 -151
  26. package/packages/components/icon/index.vue +6 -6
  27. package/packages/components/icon-picker/index.vue +30 -30
  28. package/packages/components/icon-picker/panel.vue +58 -58
  29. package/packages/components/label/index.vue +22 -30
  30. package/packages/components/list/components/export/index.vue +101 -99
  31. package/packages/components/list/components/footer/index.vue +42 -51
  32. package/packages/components/list/components/header/index.vue +34 -34
  33. package/packages/components/list/components/querybar/index.vue +143 -143
  34. package/packages/components/list/components/select-column/index.vue +30 -30
  35. package/packages/components/list/components/table/index.vue +169 -188
  36. package/packages/components/list/index.vue +337 -391
  37. package/packages/components/list-agile/index.vue +145 -145
  38. package/packages/components/list-dialog/index.vue +70 -84
  39. package/packages/components/listbox/index.vue +48 -48
  40. package/packages/components/login-default/index.vue +107 -107
  41. package/packages/components/login-neon/index.vue +104 -104
  42. package/packages/components/map/index.vue +229 -229
  43. package/packages/components/map-coord-picking/index.vue +220 -219
  44. package/packages/components/map-search/index.vue +75 -72
  45. package/packages/components/scrollbar/index.vue +11 -11
  46. package/packages/components/select-whether/index.vue +30 -30
  47. package/packages/components/split/index.vue +141 -141
  48. package/packages/components/split/trigger.vue +15 -15
  49. package/packages/components/tabnav/index.vue +125 -89
  50. package/packages/components/tabs/index.vue +31 -31
  51. package/packages/components/toolbar/components/fullscreen/index.vue +10 -10
  52. package/packages/components/toolbar/components/logout/index.vue +13 -13
  53. package/packages/components/toolbar/components/skin-toggle/form.vue +59 -59
  54. package/packages/components/toolbar/components/skin-toggle/index.vue +12 -12
  55. package/packages/components/toolbar/components/userInfo/index.vue +18 -18
  56. package/packages/components/toolbar/index.vue +12 -12
  57. package/packages/components/tree-select/mixins.vue +261 -270
  58. package/packages/components/txt/index.vue +17 -17
  59. package/packages/components/update-password/index.vue +45 -57
  60. package/packages/layout.vue +18 -18
  61. package/packages/mixins/components/checkbox.vue +71 -82
  62. package/packages/mixins/components/radio.vue +69 -69
  63. package/packages/page/403/index.vue +32 -28
  64. package/packages/page/404/index.vue +32 -28
  65. package/packages/page/default/index.vue +17 -13
  66. package/packages/page/iframe/index.vue +6 -6
  67. package/packages/page/login/index.vue +9 -9
  68. package/packages/page/userInfo/index.vue +5 -5
  69. package/packages/router/index.js +1 -9
  70. package/packages/skins/pretty/components/header/components/breadcrumb/index.vue +29 -29
  71. package/packages/skins/pretty/components/header/components/theme/index.vue +22 -21
  72. package/packages/skins/pretty/components/header/index.vue +12 -12
  73. package/packages/skins/pretty/components/main/index.vue +27 -27
  74. package/packages/skins/pretty/components/menus/index.vue +28 -28
  75. package/packages/skins/pretty/components/menus/item.vue +23 -23
  76. package/packages/skins/pretty/components/sidebar/index.vue +7 -7
  77. package/packages/skins/pretty/index.vue +6 -6
  78. package/packages/skins/pretty/styles/themes/blue-light/_index.scss +2 -2
  79. package/packages/skins/pretty/styles/themes/default/_index.scss +1 -1
  80. package/packages/skins/pretty/styles/themes/green/_index.scss +2 -2
  81. package/packages/skins/pretty/styles/themes/green-light/_index.scss +2 -2
  82. package/packages/styles/_mixins.scss +24 -25
  83. package/packages/styles/animation/_index.scss +22 -23
  84. package/packages/styles/animation/breadcrumb.scss +6 -6
  85. package/packages/styles/animation/fade.scss +11 -11
  86. package/packages/styles/animation/move.scss +98 -98
  87. package/packages/styles/components/box-small/_index.scss +58 -58
  88. package/packages/styles/components/button/_index.scss +7 -7
  89. package/packages/styles/components/container/_index.scss +26 -26
  90. package/packages/styles/components/date-range-picker/_index.scss +4 -4
  91. package/packages/styles/components/details/_index.scss +66 -67
  92. package/packages/styles/components/details-dialog/_index.scss +13 -13
  93. package/packages/styles/components/drag-sort/_index.scss +20 -20
  94. package/packages/styles/components/drag-sort-dialog/_index.scss +7 -7
  95. package/packages/styles/components/flex/_index.scss +56 -56
  96. package/packages/styles/components/form-dialog/_index.scss +11 -11
  97. package/packages/styles/components/icon/_index.scss +6 -6
  98. package/packages/styles/components/label/_index.scss +245 -245
  99. package/packages/styles/components/listbox/_index.scss +47 -47
  100. package/packages/styles/components/split/_index.scss +102 -102
  101. package/packages/styles/components/toolbar/_index.scss +98 -98
  102. package/packages/styles/components/txt/_index.scss +13 -13
  103. package/packages/styles/components/upload-dialog/_index.scss +44 -44
  104. package/packages/styles/components/upload-multiple/_index.scss +19 -19
  105. package/packages/styles/components/upload-single/_index.scss +16 -16
  106. package/packages/utils/resize-event.js +3 -3
  107. package/packages/vuter/attributes.json +30 -40
  108. package/packages/vuter/tags.json +11 -27
  109. package/public/lib/font/iconfont.js +47 -1
@@ -48,162 +48,162 @@
48
48
  </section>
49
49
  </template>
50
50
  <script>
51
- const defaultAdvanced = {
52
- // 是否开启
53
- enabled: false,
54
- // 宽度
55
- width: '400px',
56
- // 高度
57
- height: '',
58
- // 表单标签宽度
59
- labelWidth: '100px',
60
- // 内联表单
61
- inline: false
62
- }
63
- export default {
64
- data() {
65
- return {
66
- // 是否显示高级查询
67
- showAdvanced: false,
68
- // 动态计算的高度
69
- dynamicHeight: ''
70
- }
71
- },
72
- props: {
73
- /** 输入框的宽度 */
74
- inputWidth: {
75
- type: String,
76
- default: '160px'
77
- },
78
- /** 查询模型 */
79
- model: Object,
80
- /** 验证规则 */
81
- rules: Object,
82
- /** 高级查询属性 */
83
- advanced: Object,
84
- /** 不显示按钮图标 */
85
- noSearchButtonIcon: Boolean,
86
- /** 不需要查询 */
87
- noSearch: Boolean,
88
- /**不显示查询按钮 */
89
- noReset: Boolean,
90
- /**显示导出按钮 */
91
- exportEnabled: Boolean,
92
- /**导出按钮权限编码 */
93
- exportBtnCode: String
94
- },
95
- computed: {
96
- model_() {
97
- return this.model || {}
98
- },
99
- /** 高级查询设置 */
100
- advanced_() {
101
- const ad = this.$_.merge({}, defaultAdvanced, this.advanced)
102
- ad.enabled = ad.enabled && !this.noSearch
103
- return ad
104
- },
105
- /** 高级查询框样式 */
106
- advancedStyle() {
51
+ const defaultAdvanced = {
52
+ // 是否开启
53
+ enabled: false,
54
+ // 宽度
55
+ width: '400px',
56
+ // 高度
57
+ height: '',
58
+ // 表单标签宽度
59
+ labelWidth: '100px',
60
+ // 内联表单
61
+ inline: false
62
+ }
63
+ export default {
64
+ data() {
107
65
  return {
108
- width: this.advanced_.width,
109
- height: this.advanced_.height || this.dynamicHeight
110
- }
111
- }
112
- },
113
- methods: {
114
- query() {
115
- this.$parent.page.index = 1
116
- this.$parent.query()
117
- // 如果高级查询框显示,重新计算高度
118
- if (this.showAdvanced && !this.advanced_.height) {
119
- this.$nextTick(() => {
120
- this.calculateAdvancedHeight()
121
- })
66
+ // 是否显示高级查询
67
+ showAdvanced: false,
68
+ // 动态计算的高度
69
+ dynamicHeight: ''
122
70
  }
123
71
  },
124
- /** 表单重置 */
125
- reset() {
126
- if (this.$refs.normalForm) {
127
- this.$refs.normalForm.reset()
128
- }
129
- if (this.$refs.advancedForm) {
130
- this.$refs.advancedForm.reset()
131
- }
132
- this.$emit('reset')
72
+ props: {
73
+ /** 输入框的宽度 */
74
+ inputWidth: {
75
+ type: String,
76
+ default: '160px'
77
+ },
78
+ /** 查询模型 */
79
+ model: Object,
80
+ /** 验证规则 */
81
+ rules: Object,
82
+ /** 高级查询属性 */
83
+ advanced: Object,
84
+ /** 不显示按钮图标 */
85
+ noSearchButtonIcon: Boolean,
86
+ /** 不需要查询 */
87
+ noSearch: Boolean,
88
+ /**不显示查询按钮 */
89
+ noReset: Boolean,
90
+ /**显示导出按钮 */
91
+ exportEnabled: Boolean,
92
+ /**导出按钮权限编码 */
93
+ exportBtnCode: String
133
94
  },
134
- validate(action) {
135
- return this.$refs.normalForm.validate(action)
136
- },
137
- /** 计算高级查询框高度 */
138
- calculateAdvancedHeight() {
139
- if (!this.$refs.advancedBox) return
140
-
141
- const $box = this.$refs.advancedBox
142
- const boxHeader = $box.querySelector('.nm-box-header')?.offsetHeight || 0
143
- const boxFooter = $box.querySelector('.nm-box-footer')?.offsetHeight || 0
144
- const form = $box.querySelector('.nm-form')
145
- if (!form) return
146
-
147
- let boxHeight = form.offsetHeight + boxHeader + boxFooter + 20
148
- if (!this.advanced_.inline) {
149
- boxHeight += 20
95
+ computed: {
96
+ model_() {
97
+ return this.model || {}
98
+ },
99
+ /** 高级查询设置 */
100
+ advanced_() {
101
+ const ad = this.$_.merge({}, defaultAdvanced, this.advanced)
102
+ ad.enabled = ad.enabled && !this.noSearch
103
+ return ad
104
+ },
105
+ /** 高级查询框样式 */
106
+ advancedStyle() {
107
+ return {
108
+ width: this.advanced_.width,
109
+ height: this.advanced_.height || this.dynamicHeight
110
+ }
150
111
  }
151
- $box.style.height = boxHeight + 'px'
152
- // 保存动态计算的高度,避免后续样式被覆盖
153
- this.dynamicHeight = boxHeight + 'px'
154
112
  },
113
+ methods: {
114
+ query() {
115
+ this.$parent.page.index = 1
116
+ this.$parent.query()
117
+ // 如果高级查询框显示,重新计算高度
118
+ if (this.showAdvanced && !this.advanced_.height) {
119
+ this.$nextTick(() => {
120
+ this.calculateAdvancedHeight()
121
+ })
122
+ }
123
+ },
124
+ /** 表单重置 */
125
+ reset() {
126
+ if (this.$refs.normalForm) {
127
+ this.$refs.normalForm.reset()
128
+ }
129
+ if (this.$refs.advancedForm) {
130
+ this.$refs.advancedForm.reset()
131
+ }
132
+ this.$emit('reset')
133
+ },
134
+ validate(action) {
135
+ return this.$refs.normalForm.validate(action)
136
+ },
137
+ /** 计算高级查询框高度 */
138
+ calculateAdvancedHeight() {
139
+ if (!this.$refs.advancedBox) return
155
140
 
156
- /** 高级查询按钮点击事件 */
157
- onAdvancedClick() {
158
- this.showAdvanced = !this.showAdvanced
141
+ const $box = this.$refs.advancedBox
142
+ const boxHeader = $box.querySelector('.nm-box-header')?.offsetHeight || 0
143
+ const boxFooter = $box.querySelector('.nm-box-footer')?.offsetHeight || 0
144
+ const form = $box.querySelector('.nm-form')
145
+ if (!form) return
159
146
 
160
- if (this.showAdvanced) {
161
- this.$nextTick(() => {
162
- let $box = this.$refs.advancedBox
163
- let $arrow = this.$refs.arrow
164
- const boxWidth = $box.offsetWidth
165
- const { x, y, width, height } = this.$refs.showAdvnacedBtn.$el.getBoundingClientRect()
166
- let left = x + width / 2 - $box.offsetWidth / 2
167
- // 判断右侧有没有超出页面
168
- if (left + boxWidth > document.body.offsetWidth) {
169
- left = document.body.offsetWidth - boxWidth - 20
170
- // 计算箭头的位置
171
- $arrow.style.left = x - left - 10 + width / 2 + 'px'
172
- } else {
173
- // 计算箭头的位置
174
- $arrow.style.left = $box.offsetWidth / 2 + 'px'
175
- }
147
+ let boxHeight = form.offsetHeight + boxHeader + boxFooter + 20
148
+ if (!this.advanced_.inline) {
149
+ boxHeight += 20
150
+ }
151
+ $box.style.height = boxHeight + 'px'
152
+ // 保存动态计算的高度,避免后续样式被覆盖
153
+ this.dynamicHeight = boxHeight + 'px'
154
+ },
176
155
 
177
- $box.style.left = left + 'px'
178
- $box.style.top = y + height + 14 + 'px'
156
+ /** 高级查询按钮点击事件 */
157
+ onAdvancedClick() {
158
+ this.showAdvanced = !this.showAdvanced
179
159
 
180
- // 设置高度
181
- if (!this.advanced_.height) {
182
- this.calculateAdvancedHeight()
183
- }
184
- })
160
+ if (this.showAdvanced) {
161
+ this.$nextTick(() => {
162
+ let $box = this.$refs.advancedBox
163
+ let $arrow = this.$refs.arrow
164
+ const boxWidth = $box.offsetWidth
165
+ const { x, y, width, height } = this.$refs.showAdvnacedBtn.$el.getBoundingClientRect()
166
+ let left = x + width / 2 - $box.offsetWidth / 2
167
+ // 判断右侧有没有超出页面
168
+ if (left + boxWidth > document.body.offsetWidth) {
169
+ left = document.body.offsetWidth - boxWidth - 20
170
+ // 计算箭头的位置
171
+ $arrow.style.left = x - left - 10 + width / 2 + 'px'
172
+ } else {
173
+ // 计算箭头的位置
174
+ $arrow.style.left = $box.offsetWidth / 2 + 'px'
175
+ }
176
+
177
+ $box.style.left = left + 'px'
178
+ $box.style.top = y + height + 14 + 'px'
179
+
180
+ // 设置高度
181
+ if (!this.advanced_.height) {
182
+ this.calculateAdvancedHeight()
183
+ }
184
+ })
185
+ }
186
+ },
187
+ onExport() {
188
+ this.$parent.triggerExport()
185
189
  }
186
190
  },
187
- onExport() {
188
- this.$parent.triggerExport()
189
- }
190
- },
191
- mounted() {
192
- this.$nextTick(() => {
193
- this.$refs.normalForm.$el.addEventListener('keydown', e => {
194
- if (e.keyCode === 13) {
195
- this.query()
196
- }
197
- })
198
- if (this.inputWidth) {
199
- let inputs = this.$refs.normalForm.$el.querySelectorAll('.el-input__inner')
200
- if (inputs) {
201
- for (let i = 0; i < inputs.length; i++) {
202
- inputs[i].style.width = this.inputWidth
191
+ mounted() {
192
+ this.$nextTick(() => {
193
+ this.$refs.normalForm.$el.addEventListener('keydown', e => {
194
+ if (e.keyCode === 13) {
195
+ this.query()
196
+ }
197
+ })
198
+ if (this.inputWidth) {
199
+ let inputs = this.$refs.normalForm.$el.querySelectorAll('.el-input__inner')
200
+ if (inputs) {
201
+ for (let i = 0; i < inputs.length; i++) {
202
+ inputs[i].style.width = this.inputWidth
203
+ }
203
204
  }
204
205
  }
205
- }
206
- })
206
+ })
207
+ }
207
208
  }
208
- }
209
209
  </script>
@@ -17,37 +17,37 @@
17
17
  </el-dropdown>
18
18
  </template>
19
19
  <script>
20
- export default {
21
- data() {
22
- return {
23
- checkAll: false,
24
- isIndeterminate: true,
25
- selection: [],
26
- visible: false
27
- }
28
- },
29
- props: ['columns'],
30
- methods: {
31
- change() {
32
- let checkedCount = this.selection.length
33
- this.checkAll = checkedCount === this.columns.length
34
- this.isIndeterminate = checkedCount > 0 && checkedCount < this.columns.length
35
- this.handleEvent()
36
- },
37
- handleCheckAllChange(val) {
38
- this.selection = val ? this.columns.map(item => item.name) : []
39
- this.isIndeterminate = false
40
- this.handleEvent()
41
- },
42
- handleEvent() {
43
- this.columns.forEach(col => {
44
- col.show = !this.selection.every(name => name !== col.name)
45
- })
46
- this.$emit('change')
20
+ export default {
21
+ data() {
22
+ return {
23
+ checkAll: false,
24
+ isIndeterminate: true,
25
+ selection: [],
26
+ visible: false
27
+ }
47
28
  },
48
- onVisible(visible) {
49
- this.visible = visible
29
+ props: ['columns'],
30
+ methods: {
31
+ change() {
32
+ let checkedCount = this.selection.length
33
+ this.checkAll = checkedCount === this.columns.length
34
+ this.isIndeterminate = checkedCount > 0 && checkedCount < this.columns.length
35
+ this.handleEvent()
36
+ },
37
+ handleCheckAllChange(val) {
38
+ this.selection = val ? this.columns.map(item => item.name) : []
39
+ this.isIndeterminate = false
40
+ this.handleEvent()
41
+ },
42
+ handleEvent() {
43
+ this.columns.forEach(col => {
44
+ col.show = !this.selection.every(name => name !== col.name)
45
+ })
46
+ this.$emit('change')
47
+ },
48
+ onVisible(visible) {
49
+ this.visible = visible
50
+ }
50
51
  }
51
52
  }
52
- }
53
53
  </script>