eoss-ui 0.7.77 → 0.7.79

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 (161) hide show
  1. package/lib/calogin.js +233 -233
  2. package/lib/eoss-ui.common.js +290 -270
  3. package/lib/index.js +1 -1
  4. package/lib/main.js +20 -16
  5. package/lib/qr-code.js +13 -13
  6. package/lib/selector-panel.js +18 -2
  7. package/lib/theme-chalk/index.css +1 -1
  8. package/lib/theme-chalk/login.css +1 -1
  9. package/package.json +1 -1
  10. package/packages/button/index.js +5 -5
  11. package/packages/button/src/main.vue +418 -418
  12. package/packages/button-group/index.js +5 -5
  13. package/packages/calendar/index.js +5 -5
  14. package/packages/calogin/index.js +5 -5
  15. package/packages/calogin/src/plugin.js +915 -915
  16. package/packages/card/index.js +5 -5
  17. package/packages/card/src/main.vue +156 -156
  18. package/packages/cascader/index.js +5 -5
  19. package/packages/cascader/src/main.vue +168 -168
  20. package/packages/checkbox-group/index.js +5 -5
  21. package/packages/checkbox-group/src/main.vue +333 -333
  22. package/packages/clients/index.js +5 -5
  23. package/packages/data-table/index.js +5 -5
  24. package/packages/data-table/src/children.vue +39 -39
  25. package/packages/data-table/src/sizer.vue +195 -195
  26. package/packages/data-table-form/index.js +5 -5
  27. package/packages/data-table-form/src/checkbox.vue +101 -101
  28. package/packages/data-table-form/src/colgroup.vue +17 -17
  29. package/packages/data-table-form/src/main.vue +181 -181
  30. package/packages/data-table-form/src/radio.vue +65 -65
  31. package/packages/data-table-form/src/table.vue +233 -233
  32. package/packages/data-table-form/src/tbody.vue +336 -336
  33. package/packages/data-table-form/src/thead.vue +68 -68
  34. package/packages/date-picker/index.js +5 -5
  35. package/packages/date-picker/src/main.vue +236 -236
  36. package/packages/dialog/index.js +5 -5
  37. package/packages/enable-drag/index.js +5 -5
  38. package/packages/enterprise/index.js +5 -5
  39. package/packages/enterprise/src/main.vue +66 -66
  40. package/packages/error-page/index.js +5 -5
  41. package/packages/error-page/src/main.vue +44 -44
  42. package/packages/flow/index.js +5 -5
  43. package/packages/flow/src/component/TimeLimit.vue +190 -190
  44. package/packages/flow/src/table.vue +58 -58
  45. package/packages/flow-group/index.js +5 -5
  46. package/packages/flow-list/index.js +5 -5
  47. package/packages/form/index.js +5 -5
  48. package/packages/handle-user/index.js +5 -5
  49. package/packages/handler/index.js +5 -5
  50. package/packages/icon/index.js +5 -5
  51. package/packages/icons/index.js +5 -5
  52. package/packages/icons/src/main.vue +81 -81
  53. package/packages/input/index.js +5 -5
  54. package/packages/input/src/main.vue +356 -356
  55. package/packages/input-number/index.js +5 -5
  56. package/packages/input-number/src/main.vue +106 -106
  57. package/packages/label/index.js +5 -5
  58. package/packages/label/src/main.vue +457 -457
  59. package/packages/layout/index.js +5 -5
  60. package/packages/layout/src/item.vue +152 -152
  61. package/packages/layout/src/main.vue +31 -31
  62. package/packages/login/index.js +5 -5
  63. package/packages/main/index.js +5 -5
  64. package/packages/main/src/default/message.vue +249 -249
  65. package/packages/main/src/default/notice.vue +157 -157
  66. package/packages/main/src/simplicity/index.vue +1 -0
  67. package/packages/main/src/simplicity/lists.vue +84 -84
  68. package/packages/main/src/simplicity/router-page.vue +45 -45
  69. package/packages/main/src/simplicity/sub-menu.vue +2 -0
  70. package/packages/menu/index.js +5 -5
  71. package/packages/nav/index.js +5 -5
  72. package/packages/notify/index.js +5 -5
  73. package/packages/notify/src/main.vue +538 -538
  74. package/packages/page/index.js +5 -5
  75. package/packages/page/src/main.vue +167 -167
  76. package/packages/pagination/index.js +5 -5
  77. package/packages/pagination/src/main.vue +96 -96
  78. package/packages/player/index.js +5 -5
  79. package/packages/player/src/main.vue +194 -194
  80. package/packages/qr-code/index.js +5 -5
  81. package/packages/qr-code/src/main.vue +170 -170
  82. package/packages/radio-group/index.js +6 -6
  83. package/packages/radio-group/src/main.vue +319 -319
  84. package/packages/retrial-auth/index.js +5 -5
  85. package/packages/retrial-auth/src/main.vue +280 -280
  86. package/packages/select/index.js +5 -5
  87. package/packages/select-ganged/index.js +5 -5
  88. package/packages/select-ganged/src/main.vue +724 -724
  89. package/packages/selector/index.js +5 -5
  90. package/packages/selector-panel/index.js +5 -5
  91. package/packages/selector-panel/src/main.vue +3 -0
  92. package/packages/selector-panel/src/tree.vue +129 -129
  93. package/packages/sizer/index.js +5 -5
  94. package/packages/sizer/src/main.vue +254 -254
  95. package/packages/steps/index.js +5 -5
  96. package/packages/steps/src/main.vue +181 -181
  97. package/packages/switch/index.js +5 -5
  98. package/packages/table-form/index.js +5 -5
  99. package/packages/tabs/index.js +5 -5
  100. package/packages/tabs/src/main.vue +788 -788
  101. package/packages/tabs-panel/index.js +5 -5
  102. package/packages/tabs-panel/src/main.vue +29 -29
  103. package/packages/theme-chalk/lib/index.css +1 -1
  104. package/packages/theme-chalk/lib/login.css +1 -1
  105. package/packages/theme-chalk/src/base.scss +261 -261
  106. package/packages/theme-chalk/src/button-group.scss +176 -176
  107. package/packages/theme-chalk/src/button.scss +24 -24
  108. package/packages/theme-chalk/src/calendar.scss +113 -113
  109. package/packages/theme-chalk/src/card.scss +99 -99
  110. package/packages/theme-chalk/src/checkbox-group.scss +8 -8
  111. package/packages/theme-chalk/src/clients.scss +87 -87
  112. package/packages/theme-chalk/src/data-table-form.scss +67 -67
  113. package/packages/theme-chalk/src/date-picker.scss +7 -7
  114. package/packages/theme-chalk/src/dialog.scss +77 -77
  115. package/packages/theme-chalk/src/enable-drag.scss +181 -181
  116. package/packages/theme-chalk/src/enterprise.scss +5 -5
  117. package/packages/theme-chalk/src/error-page.scss +18 -18
  118. package/packages/theme-chalk/src/flow-group.scss +110 -110
  119. package/packages/theme-chalk/src/flow-list.scss +39 -39
  120. package/packages/theme-chalk/src/handle-user.scss +40 -40
  121. package/packages/theme-chalk/src/icons.scss +99 -99
  122. package/packages/theme-chalk/src/input.scss +9 -9
  123. package/packages/theme-chalk/src/label.scss +24 -24
  124. package/packages/theme-chalk/src/layout.scss +46 -46
  125. package/packages/theme-chalk/src/mixins/color.scss +117 -117
  126. package/packages/theme-chalk/src/nav.scss +111 -111
  127. package/packages/theme-chalk/src/page.scss +3 -3
  128. package/packages/theme-chalk/src/pagination.scss +29 -29
  129. package/packages/theme-chalk/src/player.scss +9 -9
  130. package/packages/theme-chalk/src/qr-code.scss +17 -17
  131. package/packages/theme-chalk/src/radio-group.scss +9 -9
  132. package/packages/theme-chalk/src/retrial-auth.scss +38 -38
  133. package/packages/theme-chalk/src/select-ganged.scss +8 -8
  134. package/packages/theme-chalk/src/select.scss +8 -8
  135. package/packages/theme-chalk/src/selector-panel.scss +204 -204
  136. package/packages/theme-chalk/src/sizer.scss +36 -36
  137. package/packages/theme-chalk/src/steps.scss +88 -88
  138. package/packages/theme-chalk/src/switch.scss +3 -3
  139. package/packages/theme-chalk/src/table-form.scss +1 -1
  140. package/packages/theme-chalk/src/tabs.scss +87 -87
  141. package/packages/theme-chalk/src/tips.scss +7 -7
  142. package/packages/theme-chalk/src/toolbar.scss +179 -179
  143. package/packages/theme-chalk/src/tree-group.scss +72 -72
  144. package/packages/theme-chalk/src/wxlogin.scss +3 -3
  145. package/packages/tips/index.js +5 -5
  146. package/packages/toolbar/index.js +5 -5
  147. package/packages/tree/index.js +5 -5
  148. package/packages/tree-group/index.js +5 -5
  149. package/packages/upload/index.js +5 -5
  150. package/packages/upload/src/picture.js +15 -15
  151. package/packages/wujie/index.js +5 -5
  152. package/packages/wujie/src/main.vue +145 -145
  153. package/packages/wxlogin/index.js +5 -5
  154. package/packages/wxlogin/src/main.vue +128 -128
  155. package/src/config/image.js +2 -2
  156. package/src/index.js +1 -1
  157. package/src/utils/bus.js +3 -3
  158. package/src/utils/date-util.js +312 -312
  159. package/src/utils/http.js +50 -50
  160. package/src/utils/store.js +21 -21
  161. package/src/utils/webSocket.js +107 -107
@@ -1,39 +1,39 @@
1
- <template>
2
- <column v-bind="$attrs" v-on="$listeners">
3
- <template v-if="childrens.length">
4
- <template v-for="(item, index) in childrens">
5
- <children
6
- v-if="item.hide !== true"
7
- :key="item.key || item.id || item.label || item.title || index"
8
- v-bind="{
9
- ...$attrs,
10
- ...item,
11
- indexs: index,
12
- ...(dragSort ? { ...item, fixed: false } : item)
13
- }"
14
- v-on="$listeners"
15
- ></children
16
- ></template>
17
- </template>
18
- </column>
19
- </template>
20
- <script type="text/babel">
21
- import column from './column.vue';
22
- export default {
23
- name: 'Children',
24
- components: {
25
- column
26
- },
27
- props: {
28
- dragSort: Boolean,
29
- children: Array,
30
- childHead: Array
31
- },
32
- created() {},
33
- computed: {
34
- childrens() {
35
- return this.children || this.childHead || [];
36
- }
37
- }
38
- };
39
- </script>
1
+ <template>
2
+ <column v-bind="$attrs" v-on="$listeners">
3
+ <template v-if="childrens.length">
4
+ <template v-for="(item, index) in childrens">
5
+ <children
6
+ v-if="item.hide !== true"
7
+ :key="item.key || item.id || item.label || item.title || index"
8
+ v-bind="{
9
+ ...$attrs,
10
+ ...item,
11
+ indexs: index,
12
+ ...(dragSort ? { ...item, fixed: false } : item)
13
+ }"
14
+ v-on="$listeners"
15
+ ></children
16
+ ></template>
17
+ </template>
18
+ </column>
19
+ </template>
20
+ <script type="text/babel">
21
+ import column from './column.vue';
22
+ export default {
23
+ name: 'Children',
24
+ components: {
25
+ column
26
+ },
27
+ props: {
28
+ dragSort: Boolean,
29
+ children: Array,
30
+ childHead: Array
31
+ },
32
+ created() {},
33
+ computed: {
34
+ childrens() {
35
+ return this.children || this.childHead || [];
36
+ }
37
+ }
38
+ };
39
+ </script>
@@ -1,195 +1,195 @@
1
- <template>
2
- <div class="es-table-sizer">
3
- <div class="es-table-sizer-tips">
4
- 提示:锁定的列排序无效,列的内容是数字才能合计
5
- </div>
6
- <es-data-table
7
- dragSort
8
- numbers
9
- form
10
- row-key="id"
11
- default-expand-all
12
- height="480px"
13
- :mode="mode"
14
- :data="theads"
15
- :thead="thead"
16
- :tree-props="{ children: 'childHead' }"
17
- @change="handleChange"
18
- @update-drag-sort="handleDrag"
19
- >
20
- </es-data-table>
21
- <div class="sizer-btn-box">
22
- <el-button type="primary" size="medium" @click="handleConfirm"
23
- >确定</el-button
24
- >
25
- </div>
26
- </div>
27
- </template>
28
-
29
- <script type="text/babel">
30
- import util from 'eoss-ui/src/utils/util';
31
- export default {
32
- name: 'Sizer',
33
- props: {
34
- mode: String,
35
- data: Array
36
- },
37
- computed: {
38
- theads: {
39
- get() {
40
- if (this.data && this.data.length) {
41
- let newData = [];
42
- this.getThead(this.data, newData);
43
- return newData;
44
- }
45
- return [];
46
- }
47
- }
48
- },
49
- data() {
50
- return {
51
- visible: false,
52
- thead: [
53
- {
54
- title: '名称',
55
- field: 'title'
56
- },
57
- {
58
- title: '锁定列位置',
59
- field: 'fixed',
60
- type: 'select',
61
- clearable: true,
62
- width: 160,
63
- data: [
64
- {
65
- value: 'left',
66
- name: '左'
67
- },
68
- {
69
- value: 'right',
70
- name: '右'
71
- }
72
- ]
73
- },
74
- {
75
- title: '列是否显示',
76
- field: 'hide',
77
- type: 'switch',
78
- width: 160,
79
- align: 'center',
80
- data: [
81
- {
82
- value: false,
83
- name: '隐藏'
84
- },
85
- {
86
- value: true,
87
- name: '显示'
88
- }
89
- ]
90
- },
91
- {
92
- title: '是否开启合计',
93
- field: 'total',
94
- type: 'switch',
95
- width: 160,
96
- align: 'center',
97
- data: [
98
- {
99
- value: false,
100
- name: '关闭'
101
- },
102
- {
103
- value: true,
104
- name: '开启'
105
- }
106
- ]
107
- }
108
- ],
109
- newThead: [],
110
- nid: 0
111
- };
112
- },
113
- mounted() {
114
- this.newThead = util.extend(true, [], this.data);
115
- },
116
- methods: {
117
- show() {
118
- this.visible = true;
119
- },
120
- getThead(res, data) {
121
- res.forEach((item, index) => {
122
- if (
123
- item.type !== 'index' &&
124
- item.type !== 'selection' &&
125
- item.type !== 'handle'
126
- ) {
127
- let { fixed, hide, childHead, children, title, ...other } = item;
128
- let items = {
129
- title: title ? title : item.label,
130
- fixed:
131
- fixed === true
132
- ? 'left'
133
- : fixed === undefined || fixed === false
134
- ? ''
135
- : fixed,
136
- hide: hide ? false : true,
137
- id: index,
138
- ...other
139
- };
140
- if (childHead && childHead.length) {
141
- let childHeads = [];
142
- this.getThead(childHead, childHeads);
143
- items.childHead = childHeads;
144
- }
145
- if (children && children.length) {
146
- let childHeads = [];
147
- this.getThead(children, childHeads);
148
- items.children = childHeads;
149
- }
150
- data.push(items);
151
- } else {
152
- this.nid++;
153
- }
154
- });
155
- },
156
- setThead(res, thead) {
157
- let { name, value, data } = res;
158
- for (let i in thead) {
159
- let item = thead[i];
160
- if (data.field === item.field) {
161
- thead[i][name] = name === 'hide' ? !value : value;
162
- thead[i].hide === false && delete thead[i].hide;
163
- break;
164
- } else {
165
- if (item.childHead && item.childHead.length) {
166
- this.setThead(res, item.childHead);
167
- }
168
- if (item.children && item.children.length) {
169
- this.setThead(res, item.children);
170
- }
171
- }
172
- }
173
- },
174
- handleChange(res) {
175
- this.setThead(res, this.newThead);
176
- },
177
- handleDrag(res, evt) {
178
- let { oldIndex, newIndex } = evt;
179
- oldIndex += this.nid;
180
- newIndex += this.nid;
181
- if (oldIndex > newIndex) {
182
- this.newThead.splice(newIndex, 0, this.newThead[oldIndex]);
183
- this.newThead.splice(oldIndex + 1, 1);
184
- } else {
185
- this.newThead.splice(newIndex + 1, 0, this.newThead[oldIndex]);
186
- this.newThead.splice(oldIndex, 1);
187
- }
188
- },
189
- handleConfirm() {
190
- this.visible = false;
191
- this.$emit('confirm', this.newThead);
192
- }
193
- }
194
- };
195
- </script>
1
+ <template>
2
+ <div class="es-table-sizer">
3
+ <div class="es-table-sizer-tips">
4
+ 提示:锁定的列排序无效,列的内容是数字才能合计
5
+ </div>
6
+ <es-data-table
7
+ dragSort
8
+ numbers
9
+ form
10
+ row-key="id"
11
+ default-expand-all
12
+ height="480px"
13
+ :mode="mode"
14
+ :data="theads"
15
+ :thead="thead"
16
+ :tree-props="{ children: 'childHead' }"
17
+ @change="handleChange"
18
+ @update-drag-sort="handleDrag"
19
+ >
20
+ </es-data-table>
21
+ <div class="sizer-btn-box">
22
+ <el-button type="primary" size="medium" @click="handleConfirm"
23
+ >确定</el-button
24
+ >
25
+ </div>
26
+ </div>
27
+ </template>
28
+
29
+ <script type="text/babel">
30
+ import util from 'eoss-ui/src/utils/util';
31
+ export default {
32
+ name: 'Sizer',
33
+ props: {
34
+ mode: String,
35
+ data: Array
36
+ },
37
+ computed: {
38
+ theads: {
39
+ get() {
40
+ if (this.data && this.data.length) {
41
+ let newData = [];
42
+ this.getThead(this.data, newData);
43
+ return newData;
44
+ }
45
+ return [];
46
+ }
47
+ }
48
+ },
49
+ data() {
50
+ return {
51
+ visible: false,
52
+ thead: [
53
+ {
54
+ title: '名称',
55
+ field: 'title'
56
+ },
57
+ {
58
+ title: '锁定列位置',
59
+ field: 'fixed',
60
+ type: 'select',
61
+ clearable: true,
62
+ width: 160,
63
+ data: [
64
+ {
65
+ value: 'left',
66
+ name: '左'
67
+ },
68
+ {
69
+ value: 'right',
70
+ name: '右'
71
+ }
72
+ ]
73
+ },
74
+ {
75
+ title: '列是否显示',
76
+ field: 'hide',
77
+ type: 'switch',
78
+ width: 160,
79
+ align: 'center',
80
+ data: [
81
+ {
82
+ value: false,
83
+ name: '隐藏'
84
+ },
85
+ {
86
+ value: true,
87
+ name: '显示'
88
+ }
89
+ ]
90
+ },
91
+ {
92
+ title: '是否开启合计',
93
+ field: 'total',
94
+ type: 'switch',
95
+ width: 160,
96
+ align: 'center',
97
+ data: [
98
+ {
99
+ value: false,
100
+ name: '关闭'
101
+ },
102
+ {
103
+ value: true,
104
+ name: '开启'
105
+ }
106
+ ]
107
+ }
108
+ ],
109
+ newThead: [],
110
+ nid: 0
111
+ };
112
+ },
113
+ mounted() {
114
+ this.newThead = util.extend(true, [], this.data);
115
+ },
116
+ methods: {
117
+ show() {
118
+ this.visible = true;
119
+ },
120
+ getThead(res, data) {
121
+ res.forEach((item, index) => {
122
+ if (
123
+ item.type !== 'index' &&
124
+ item.type !== 'selection' &&
125
+ item.type !== 'handle'
126
+ ) {
127
+ let { fixed, hide, childHead, children, title, ...other } = item;
128
+ let items = {
129
+ title: title ? title : item.label,
130
+ fixed:
131
+ fixed === true
132
+ ? 'left'
133
+ : fixed === undefined || fixed === false
134
+ ? ''
135
+ : fixed,
136
+ hide: hide ? false : true,
137
+ id: index,
138
+ ...other
139
+ };
140
+ if (childHead && childHead.length) {
141
+ let childHeads = [];
142
+ this.getThead(childHead, childHeads);
143
+ items.childHead = childHeads;
144
+ }
145
+ if (children && children.length) {
146
+ let childHeads = [];
147
+ this.getThead(children, childHeads);
148
+ items.children = childHeads;
149
+ }
150
+ data.push(items);
151
+ } else {
152
+ this.nid++;
153
+ }
154
+ });
155
+ },
156
+ setThead(res, thead) {
157
+ let { name, value, data } = res;
158
+ for (let i in thead) {
159
+ let item = thead[i];
160
+ if (data.field === item.field) {
161
+ thead[i][name] = name === 'hide' ? !value : value;
162
+ thead[i].hide === false && delete thead[i].hide;
163
+ break;
164
+ } else {
165
+ if (item.childHead && item.childHead.length) {
166
+ this.setThead(res, item.childHead);
167
+ }
168
+ if (item.children && item.children.length) {
169
+ this.setThead(res, item.children);
170
+ }
171
+ }
172
+ }
173
+ },
174
+ handleChange(res) {
175
+ this.setThead(res, this.newThead);
176
+ },
177
+ handleDrag(res, evt) {
178
+ let { oldIndex, newIndex } = evt;
179
+ oldIndex += this.nid;
180
+ newIndex += this.nid;
181
+ if (oldIndex > newIndex) {
182
+ this.newThead.splice(newIndex, 0, this.newThead[oldIndex]);
183
+ this.newThead.splice(oldIndex + 1, 1);
184
+ } else {
185
+ this.newThead.splice(newIndex + 1, 0, this.newThead[oldIndex]);
186
+ this.newThead.splice(oldIndex, 1);
187
+ }
188
+ },
189
+ handleConfirm() {
190
+ this.visible = false;
191
+ this.$emit('confirm', this.newThead);
192
+ }
193
+ }
194
+ };
195
+ </script>
@@ -1,5 +1,5 @@
1
- import EsDataTableForm from './src/main';
2
-
3
- EsDataTableForm.install = Vue => Vue.component(EsDataTableForm.name, EsDataTableForm);
4
-
5
- export default EsDataTableForm;
1
+ import EsDataTableForm from './src/main';
2
+
3
+ EsDataTableForm.install = Vue => Vue.component(EsDataTableForm.name, EsDataTableForm);
4
+
5
+ export default EsDataTableForm;
@@ -1,101 +1,101 @@
1
- <template>
2
- <div class="el-checkbox-group">
3
- <label class="el-checkbox" v-for="(item, index) in options" :key="index">
4
- <input
5
- type="checkbox"
6
- :name="_name"
7
- :checked="isChecked(item)"
8
- @change="
9
- (event) => {
10
- handeChange(event, item, index);
11
- }
12
- "
13
- />{{ labelKey ? item[labelKey] : item.name || item.label }}
14
- </label>
15
- </div>
16
- </template>
17
- <script>
18
- export default {
19
- name: 'EoCheckbox',
20
- props: {
21
- field: {
22
- required: true,
23
- type: String
24
- },
25
- prop: String,
26
- index: Number,
27
- labelKey: String,
28
- valueKey: String,
29
- data: {
30
- type: Object,
31
- default() {
32
- return {};
33
- }
34
- },
35
- options: {
36
- type: Array,
37
- default() {
38
- return [];
39
- }
40
- },
41
- decollator: {
42
- type: String,
43
- default: ','
44
- },
45
- valueToString: Boolean,
46
- value: {}
47
- },
48
- data() {
49
- return {
50
- _value: this.value
51
- };
52
- },
53
- computed: {
54
- model: {
55
- get() {
56
- if (Array.isArray(this.value)) {
57
- return this.value;
58
- }
59
- if (typeof this.value === 'string') {
60
- return this.value.split(this.decollator);
61
- }
62
- return [this.value];
63
- }
64
- // set(val) {
65
- // this.$emit(
66
- // 'input',
67
- // this.valueToString ? val.join(this.decollator) : val
68
- // );
69
- // return val;
70
- // }
71
- },
72
- _name() {
73
- if (this.index !== undefined) {
74
- return `${this.field || this.prop}[${this.index}]`;
75
- }
76
- return this.field || this.prop;
77
- }
78
- },
79
- methods: {
80
- isChecked(res) {
81
- return this.valueKey
82
- ? this.model.indexOf(res[this.valueKey]) > -1
83
- : this.model.indexOf(res.value) > -1;
84
- },
85
- handeChange(event, res, index) {
86
- let val = this.model;
87
- if (event.target.checked) {
88
- if (val.length > index) {
89
- val.splice(index, 0, this.valueKey ? res[this.valueKey] : res.value);
90
- } else {
91
- val.push(this.valueKey ? res[this.valueKey] : res.value);
92
- }
93
- } else {
94
- let i = val.indexOf(this.valueKey ? res[this.valueKey] : res.value);
95
- val.splice(i, 1);
96
- }
97
- this.$emit('input', this.valueToString ? val.join(this.decollator) : val);
98
- }
99
- }
100
- };
101
- </script>
1
+ <template>
2
+ <div class="el-checkbox-group">
3
+ <label class="el-checkbox" v-for="(item, index) in options" :key="index">
4
+ <input
5
+ type="checkbox"
6
+ :name="_name"
7
+ :checked="isChecked(item)"
8
+ @change="
9
+ (event) => {
10
+ handeChange(event, item, index);
11
+ }
12
+ "
13
+ />{{ labelKey ? item[labelKey] : item.name || item.label }}
14
+ </label>
15
+ </div>
16
+ </template>
17
+ <script>
18
+ export default {
19
+ name: 'EoCheckbox',
20
+ props: {
21
+ field: {
22
+ required: true,
23
+ type: String
24
+ },
25
+ prop: String,
26
+ index: Number,
27
+ labelKey: String,
28
+ valueKey: String,
29
+ data: {
30
+ type: Object,
31
+ default() {
32
+ return {};
33
+ }
34
+ },
35
+ options: {
36
+ type: Array,
37
+ default() {
38
+ return [];
39
+ }
40
+ },
41
+ decollator: {
42
+ type: String,
43
+ default: ','
44
+ },
45
+ valueToString: Boolean,
46
+ value: {}
47
+ },
48
+ data() {
49
+ return {
50
+ _value: this.value
51
+ };
52
+ },
53
+ computed: {
54
+ model: {
55
+ get() {
56
+ if (Array.isArray(this.value)) {
57
+ return this.value;
58
+ }
59
+ if (typeof this.value === 'string') {
60
+ return this.value.split(this.decollator);
61
+ }
62
+ return [this.value];
63
+ }
64
+ // set(val) {
65
+ // this.$emit(
66
+ // 'input',
67
+ // this.valueToString ? val.join(this.decollator) : val
68
+ // );
69
+ // return val;
70
+ // }
71
+ },
72
+ _name() {
73
+ if (this.index !== undefined) {
74
+ return `${this.field || this.prop}[${this.index}]`;
75
+ }
76
+ return this.field || this.prop;
77
+ }
78
+ },
79
+ methods: {
80
+ isChecked(res) {
81
+ return this.valueKey
82
+ ? this.model.indexOf(res[this.valueKey]) > -1
83
+ : this.model.indexOf(res.value) > -1;
84
+ },
85
+ handeChange(event, res, index) {
86
+ let val = this.model;
87
+ if (event.target.checked) {
88
+ if (val.length > index) {
89
+ val.splice(index, 0, this.valueKey ? res[this.valueKey] : res.value);
90
+ } else {
91
+ val.push(this.valueKey ? res[this.valueKey] : res.value);
92
+ }
93
+ } else {
94
+ let i = val.indexOf(this.valueKey ? res[this.valueKey] : res.value);
95
+ val.splice(i, 1);
96
+ }
97
+ this.$emit('input', this.valueToString ? val.join(this.decollator) : val);
98
+ }
99
+ }
100
+ };
101
+ </script>