vue2-client 1.5.13 → 1.5.14

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 (112) hide show
  1. package/CHANGELOG.md +511 -504
  2. package/index.js +30 -30
  3. package/package.json +78 -78
  4. package/src/base-client/components/common/AddressSearchCombobox/AddressSearchCombobox.vue +225 -225
  5. package/src/base-client/components/common/CreateQuery/CreateQuery.vue +667 -667
  6. package/src/base-client/components/common/CreateQuery/CreateQueryItem.vue +713 -713
  7. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQuery.vue +457 -457
  8. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQueryItem.vue +508 -508
  9. package/src/base-client/components/common/FormGroupEdit/FormGroupEdit.vue +140 -140
  10. package/src/base-client/components/common/FormGroupQuery/FormGroupQuery.vue +165 -165
  11. package/src/base-client/components/common/JSONToTree/jsontotree.vue +275 -275
  12. package/src/base-client/components/common/XAddForm/XAddForm.vue +316 -316
  13. package/src/base-client/components/common/XAddNativeForm/XAddNativeForm.vue +277 -277
  14. package/src/base-client/components/common/XCard/XCard.vue +64 -64
  15. package/src/base-client/components/common/XForm/XForm.vue +185 -185
  16. package/src/base-client/components/common/XForm/XFormItem.vue +502 -485
  17. package/src/base-client/components/common/XForm/index.md +177 -177
  18. package/src/base-client/components/common/XFormTable/XFormTable.vue +324 -324
  19. package/src/base-client/components/common/XFormTable/index.md +96 -96
  20. package/src/base-client/components/common/XTable/XTable.vue +505 -505
  21. package/src/base-client/components/common/XTreeOne/XTreeOne.vue +109 -109
  22. package/src/base-client/components/system/QueryParamsDetailsView/QueryParamsDetailsView.vue +281 -281
  23. package/src/base-client/components/ticket/TicketDetailsView/TicketDetailsView.vue +807 -807
  24. package/src/base-client/components/ticket/TicketDetailsView/index.md +29 -29
  25. package/src/base-client/components/ticket/TicketDetailsView/part/TicketDetailsFlow.vue +260 -260
  26. package/src/base-client/components/ticket/TicketSubmitSuccessView/TicketSubmitSuccessView.vue +532 -532
  27. package/src/base-client/components/ticket/TicketSubmitSuccessView/index.md +29 -29
  28. package/src/base-client/plugins/AppData.js +70 -70
  29. package/src/base-client/plugins/GetLoginInfoService.js +179 -179
  30. package/src/base-client/plugins/PagedList.js +177 -177
  31. package/src/base-client/plugins/compatible/LoginServiceOA.js +20 -20
  32. package/src/base-client/plugins/i18n-extend.js +32 -32
  33. package/src/components/Ellipsis/Ellipsis.vue +65 -65
  34. package/src/components/Ellipsis/index.md +38 -38
  35. package/src/components/NumberInfo/index.md +43 -43
  36. package/src/components/STable/README.md +341 -341
  37. package/src/components/STable/index.js +318 -318
  38. package/src/components/Trend/index.md +45 -45
  39. package/src/components/checkbox/ColorCheckbox.vue +157 -157
  40. package/src/components/checkbox/ImgCheckbox.vue +163 -163
  41. package/src/components/exception/ExceptionPage.vue +70 -70
  42. package/src/components/form/FormRow.vue +52 -52
  43. package/src/components/index.js +36 -36
  44. package/src/components/menu/SideMenu.vue +62 -62
  45. package/src/components/menu/menu.js +273 -273
  46. package/src/components/page/header/index.less +40 -40
  47. package/src/components/setting/Setting.vue +235 -235
  48. package/src/components/table/StandardTable.vue +141 -141
  49. package/src/components/table/advance/ActionColumns.vue +158 -158
  50. package/src/components/table/advance/SearchArea.vue +355 -355
  51. package/src/components/tool/AStepItem.vue +60 -60
  52. package/src/components/tool/AvatarList.vue +68 -68
  53. package/src/components/tool/Drawer.vue +142 -142
  54. package/src/components/tool/TagSelect.vue +83 -83
  55. package/src/components/transition/PageToggleTransition.vue +97 -97
  56. package/src/config/CreateQueryConfig.js +307 -307
  57. package/src/config/default/admin.config.js +18 -18
  58. package/src/config/default/setting.config.js +44 -44
  59. package/src/config/replacer/resolve.config.js +67 -67
  60. package/src/layouts/AdminLayout.vue +174 -174
  61. package/src/layouts/CommonLayout.vue +42 -42
  62. package/src/layouts/ComponentLayoutOne.vue +47 -47
  63. package/src/layouts/PageLayout.vue +151 -151
  64. package/src/layouts/SinglePageView.vue +111 -111
  65. package/src/layouts/footer/PageFooter.vue +49 -49
  66. package/src/layouts/header/AdminHeader.vue +104 -104
  67. package/src/layouts/header/HeaderAvatar.vue +61 -61
  68. package/src/layouts/header/HeaderNotice.vue +176 -176
  69. package/src/layouts/header/HeaderSearch.vue +67 -67
  70. package/src/layouts/header/InstitutionDetail.vue +181 -181
  71. package/src/layouts/header/index.less +92 -92
  72. package/src/layouts/tabs/TabsHead.vue +190 -190
  73. package/src/layouts/tabs/TabsView.vue +379 -379
  74. package/src/mock/goods/index.js +108 -108
  75. package/src/pages/exception/404.vue +25 -25
  76. package/src/pages/login/Login.vue +363 -363
  77. package/src/pages/report/ReportTable.js +124 -124
  78. package/src/pages/report/ReportTableHome.vue +28 -28
  79. package/src/pages/resourceManage/orgListManage.vue +98 -98
  80. package/src/pages/system/dictionary/index.vue +43 -43
  81. package/src/pages/system/file/index.vue +317 -317
  82. package/src/pages/system/monitor/loginInfor/index.vue +36 -36
  83. package/src/pages/system/monitor/operLog/index.vue +36 -36
  84. package/src/pages/system/queryParams/index.vue +43 -43
  85. package/src/router/async/config.async.js +27 -27
  86. package/src/router/async/router.map.js +68 -68
  87. package/src/router/guards.js +113 -113
  88. package/src/router/index.js +27 -27
  89. package/src/services/api/DictionaryDetailsViewApi.js +6 -6
  90. package/src/services/api/LogDetailsViewApi.js +10 -10
  91. package/src/services/api/QueryParamsDetailsViewApi.js +6 -6
  92. package/src/services/api/TicketDetailsViewApi.js +34 -34
  93. package/src/services/api/cas.js +79 -79
  94. package/src/services/api/commonTempTable.js +10 -10
  95. package/src/services/api/index.js +17 -17
  96. package/src/services/api/logininfor/index.js +6 -6
  97. package/src/services/api/manage.js +8 -8
  98. package/src/services/apiService.js +13 -13
  99. package/src/services/user.js +53 -53
  100. package/src/store/modules/index.js +4 -4
  101. package/src/theme/default/nprogress.less +76 -76
  102. package/src/theme/default/style.less +47 -47
  103. package/src/utils/colors.js +107 -107
  104. package/src/utils/excel/Blob.js +180 -180
  105. package/src/utils/excel/Export2Excel.js +141 -141
  106. package/src/utils/formatter.js +68 -68
  107. package/src/utils/i18n.js +80 -80
  108. package/src/utils/indexedDB.js +145 -145
  109. package/src/utils/theme-color-replacer-extend.js +91 -91
  110. package/src/utils/themeUtil.js +100 -100
  111. package/src/utils/util.js +230 -230
  112. package/vue.config.js +106 -106
@@ -1,277 +1,277 @@
1
- <template>
2
- <div class="table-page-search-wrapper">
3
- <a-form-model
4
- v-if="loaded"
5
- ref="selectForm"
6
- :model="form"
7
- :rules="rules">
8
- <a-row :gutter="16">
9
- <x-form-item
10
- v-for="(item, index) in realJsonData"
11
- :key="index"
12
- :attr="item"
13
- :disabled="itemDisabled(item)"
14
- :files="files"
15
- :form="form"
16
- :images="images"
17
- :service-name="serviceName"
18
- :xl="12"
19
- :xxl="8"
20
- mode="新增/修改"
21
- />
22
- </a-row>
23
- </a-form-model>
24
- </div>
25
- </template>
26
- <script>
27
- import XFormItem from '@vue2-client/base-client/components/common/XForm/XFormItem'
28
- import { formatDate } from '@vue2-client/utils/util'
29
- import { mapState } from 'vuex'
30
- import { post } from '@vue2-client/services/api'
31
-
32
- export default {
33
- name: 'XAddNativeForm',
34
- components: {
35
- XFormItem
36
- },
37
- data () {
38
- return {
39
- // 内容加载是否完成
40
- loaded: false,
41
- // 表单Model
42
- form: {},
43
- // 修改有文件得表单时使用
44
- files: [],
45
- images: [],
46
- // 校验
47
- rules: {}
48
- }
49
- },
50
- computed: {
51
- // 过滤出用于新增/修改场景的表单项
52
- realJsonData: function () {
53
- return this.jsonData.filter(function (item) {
54
- return item.addOrEdit && item.addOrEdit !== 'no' && item.addOrEdit !== 'silenceAdd' && item.addOrEdit !== 'version'
55
- })
56
- },
57
- // 过滤出用于静默新增场景的表单项
58
- silenceAddJsonData: function () {
59
- return this.jsonData.filter(function (item) {
60
- return item.addOrEdit === 'silenceAdd'
61
- })
62
- },
63
- // 过滤出版本号表单项
64
- versionJsonData: function () {
65
- return this.jsonData.filter(function (item) {
66
- return item.addOrEdit === 'version'
67
- })
68
- },
69
- ...mapState('account', { currUser: 'user' })
70
- },
71
- props: {
72
- jsonData: {
73
- type: Array,
74
- default: () => {
75
- return []
76
- }
77
- },
78
- serviceName: {
79
- type: String,
80
- default: 'af-system'
81
- },
82
- // 业务类型
83
- businessType: {
84
- type: String,
85
- default: ''
86
- },
87
- // 修改操作前查询出的业务数据
88
- modifyModelData: {
89
- type: Object,
90
- default: () => {
91
- return {}
92
- }
93
- },
94
- // 新增或修改业务是否执行中
95
- loading: {
96
- type: Boolean,
97
- default: () => {
98
- return false
99
- }
100
- },
101
- // 固定新增表单
102
- fixedAddForm: {
103
- type: Object,
104
- default: () => {
105
- return {}
106
- }
107
- }
108
- },
109
- watch: {
110
- visible (rel) {
111
- if (rel) {
112
- this.formItemLoad()
113
- }
114
- }
115
- },
116
- mounted () {
117
- this.formItemLoad()
118
- },
119
- methods: {
120
- formItemLoad () {
121
- const formData = Object.assign({}, this.fixedAddForm)
122
- for (let i = 0; i < this.realJsonData.length; i++) {
123
- const item = this.realJsonData[i]
124
- formData[item.model] = undefined
125
- // 处理表单校验情况
126
- if (item.rule) {
127
- this.rules[item.model] = []
128
- const required = item.rule.required ? item.rule.required === true || item.rule.required === 'true' : false
129
- let trigger
130
- let message
131
- if (required) {
132
- switch (item.type) {
133
- case 'select':
134
- message = '请选择' + item.name
135
- trigger = 'change'
136
- break
137
- default:
138
- message = '请输入' + item.name
139
- trigger = 'blur'
140
- }
141
- this.rules[item.model].push({
142
- required: true,
143
- message: message,
144
- trigger: trigger
145
- })
146
- }
147
-
148
- switch (item.rule.type) {
149
- case 'number':
150
- case 'integer':
151
- case 'float':
152
- let defaultValue
153
- let message
154
- switch (item.rule.type) {
155
- case 'number':
156
- message = '数字'
157
- defaultValue = 0
158
- break
159
- case 'integer':
160
- message = '整数'
161
- defaultValue = 0
162
- break
163
- case 'float':
164
- message = '小数'
165
- defaultValue = 0.0
166
- break
167
- }
168
- this.rules[item.model].push({
169
- type: item.rule.type,
170
- message: item.name + '必须为' + message,
171
- transform: (value) => {
172
- if (value && value.length !== 0) {
173
- return Number(value)
174
- } else {
175
- return defaultValue
176
- }
177
- },
178
- trigger: 'blur'
179
- })
180
- break
181
- }
182
- }
183
- }
184
- this.form = formData
185
- if (this.modifyModelData.data) {
186
- this.files = this.modifyModelData.files
187
- this.images = this.modifyModelData.images
188
- if (Object.keys(this.modifyModelData.data).length > 0) {
189
- this.getModifyModelData()
190
- }
191
- }
192
- },
193
- itemDisabled (value) {
194
- return (this.businessType === '新增' && value.addOrEdit === 'edit') ||
195
- (this.businessType === '修改' && value.addOrEdit === 'add')
196
- },
197
- async onSubmit () {
198
- this.$refs.selectForm.validate(async valid => {
199
- for (const key of Object.keys(this.form)) {
200
- if (this.form[key] === null || this.form[key] === '') {
201
- this.form[key] = undefined
202
- }
203
- }
204
- const requestForm = Object.assign({}, this.form)
205
- // 追加静默新增字段
206
- if (this.businessType === '新增') {
207
- for (const item of this.silenceAddJsonData) {
208
- switch (item.silencePurpose) {
209
- case 'createTime':
210
- requestForm[item.model] = formatDate('now')
211
- break
212
- case 'operator':
213
- requestForm[item.model] = this.currUser.name
214
- break
215
- case 'orgId':
216
- requestForm[item.model] = this.currUser.orgid
217
- break
218
- }
219
- }
220
- // 通过请求追加静默新增:自定义字段
221
- for (const item of this.silenceAddJsonData.filter((item) => item.silencePurpose === 'customize')) {
222
- requestForm[item.model] = await this.getSilenceSource(item.silenceSource, requestForm)
223
- }
224
- }
225
- const data = {
226
- valid: valid,
227
- form: requestForm
228
- }
229
- this.$emit('onSubmit', data)
230
- })
231
- },
232
- /**
233
- * 获取通过logic静默新增的字段
234
- * @param logicName logic名称
235
- * @param requestParameters 请求参数
236
- */
237
- async getSilenceSource (logicName, requestParameters) {
238
- const result = await post('/api/' + this.serviceName + '/logic/' + logicName, requestParameters)
239
- return result
240
- },
241
- /**
242
- * 获取被修改记录数据
243
- * @param modifyModelData 被修改记录的数据
244
- */
245
- getModifyModelData () {
246
- for (let i = 0; i < this.realJsonData.length; i++) {
247
- if (['FilesId', 'Images'].includes(this.realJsonData[i])) {
248
- // 附件需要跳过 因为会通过 modifyModelData中的files,images属性给upload赋值
249
- // 新增修改表单每次提交时只会提交最新添加的文件
250
- continue
251
- }
252
- const item = this.realJsonData[i]
253
- if (this.modifyModelData.data[item.model] || this.modifyModelData.data[item.model] === 0) {
254
- if (this.modifyModelData.data[item.model] instanceof Array) {
255
- this.form[item.model] = this.modifyModelData.data[item.model]
256
- } else {
257
- this.form[item.model] = this.modifyModelData.data[item.model] + ''
258
- }
259
- } else {
260
- this.form[item.model] = undefined
261
- }
262
- }
263
- // 追加版本号信息
264
- for (const item of this.versionJsonData) {
265
- if (!this.modifyModelData.data[item.model]) {
266
- this.form[item.model] = 0
267
- } else {
268
- this.form[item.model] = this.modifyModelData.data[item.model] + ''
269
- }
270
- }
271
- },
272
- onClose () {
273
- this.$emit('update:visible', false)
274
- }
275
- }
276
- }
277
- </script>
1
+ <template>
2
+ <div class="table-page-search-wrapper">
3
+ <a-form-model
4
+ v-if="loaded"
5
+ ref="selectForm"
6
+ :model="form"
7
+ :rules="rules">
8
+ <a-row :gutter="16">
9
+ <x-form-item
10
+ v-for="(item, index) in realJsonData"
11
+ :key="index"
12
+ :attr="item"
13
+ :disabled="itemDisabled(item)"
14
+ :files="files"
15
+ :form="form"
16
+ :images="images"
17
+ :service-name="serviceName"
18
+ :xl="12"
19
+ :xxl="8"
20
+ mode="新增/修改"
21
+ />
22
+ </a-row>
23
+ </a-form-model>
24
+ </div>
25
+ </template>
26
+ <script>
27
+ import XFormItem from '@vue2-client/base-client/components/common/XForm/XFormItem'
28
+ import { formatDate } from '@vue2-client/utils/util'
29
+ import { mapState } from 'vuex'
30
+ import { post } from '@vue2-client/services/api'
31
+
32
+ export default {
33
+ name: 'XAddNativeForm',
34
+ components: {
35
+ XFormItem
36
+ },
37
+ data () {
38
+ return {
39
+ // 内容加载是否完成
40
+ loaded: false,
41
+ // 表单Model
42
+ form: {},
43
+ // 修改有文件得表单时使用
44
+ files: [],
45
+ images: [],
46
+ // 校验
47
+ rules: {}
48
+ }
49
+ },
50
+ computed: {
51
+ // 过滤出用于新增/修改场景的表单项
52
+ realJsonData: function () {
53
+ return this.jsonData.filter(function (item) {
54
+ return item.addOrEdit && item.addOrEdit !== 'no' && item.addOrEdit !== 'silenceAdd' && item.addOrEdit !== 'version'
55
+ })
56
+ },
57
+ // 过滤出用于静默新增场景的表单项
58
+ silenceAddJsonData: function () {
59
+ return this.jsonData.filter(function (item) {
60
+ return item.addOrEdit === 'silenceAdd'
61
+ })
62
+ },
63
+ // 过滤出版本号表单项
64
+ versionJsonData: function () {
65
+ return this.jsonData.filter(function (item) {
66
+ return item.addOrEdit === 'version'
67
+ })
68
+ },
69
+ ...mapState('account', { currUser: 'user' })
70
+ },
71
+ props: {
72
+ jsonData: {
73
+ type: Array,
74
+ default: () => {
75
+ return []
76
+ }
77
+ },
78
+ serviceName: {
79
+ type: String,
80
+ default: 'af-system'
81
+ },
82
+ // 业务类型
83
+ businessType: {
84
+ type: String,
85
+ default: ''
86
+ },
87
+ // 修改操作前查询出的业务数据
88
+ modifyModelData: {
89
+ type: Object,
90
+ default: () => {
91
+ return {}
92
+ }
93
+ },
94
+ // 新增或修改业务是否执行中
95
+ loading: {
96
+ type: Boolean,
97
+ default: () => {
98
+ return false
99
+ }
100
+ },
101
+ // 固定新增表单
102
+ fixedAddForm: {
103
+ type: Object,
104
+ default: () => {
105
+ return {}
106
+ }
107
+ }
108
+ },
109
+ watch: {
110
+ visible (rel) {
111
+ if (rel) {
112
+ this.formItemLoad()
113
+ }
114
+ }
115
+ },
116
+ mounted () {
117
+ this.formItemLoad()
118
+ },
119
+ methods: {
120
+ formItemLoad () {
121
+ const formData = Object.assign({}, this.fixedAddForm)
122
+ for (let i = 0; i < this.realJsonData.length; i++) {
123
+ const item = this.realJsonData[i]
124
+ formData[item.model] = undefined
125
+ // 处理表单校验情况
126
+ if (item.rule) {
127
+ this.rules[item.model] = []
128
+ const required = item.rule.required ? item.rule.required === true || item.rule.required === 'true' : false
129
+ let trigger
130
+ let message
131
+ if (required) {
132
+ switch (item.type) {
133
+ case 'select':
134
+ message = '请选择' + item.name
135
+ trigger = 'change'
136
+ break
137
+ default:
138
+ message = '请输入' + item.name
139
+ trigger = 'blur'
140
+ }
141
+ this.rules[item.model].push({
142
+ required: true,
143
+ message: message,
144
+ trigger: trigger
145
+ })
146
+ }
147
+
148
+ switch (item.rule.type) {
149
+ case 'number':
150
+ case 'integer':
151
+ case 'float':
152
+ let defaultValue
153
+ let message
154
+ switch (item.rule.type) {
155
+ case 'number':
156
+ message = '数字'
157
+ defaultValue = 0
158
+ break
159
+ case 'integer':
160
+ message = '整数'
161
+ defaultValue = 0
162
+ break
163
+ case 'float':
164
+ message = '小数'
165
+ defaultValue = 0.0
166
+ break
167
+ }
168
+ this.rules[item.model].push({
169
+ type: item.rule.type,
170
+ message: item.name + '必须为' + message,
171
+ transform: (value) => {
172
+ if (value && value.length !== 0) {
173
+ return Number(value)
174
+ } else {
175
+ return defaultValue
176
+ }
177
+ },
178
+ trigger: 'blur'
179
+ })
180
+ break
181
+ }
182
+ }
183
+ }
184
+ this.form = formData
185
+ if (this.modifyModelData.data) {
186
+ this.files = this.modifyModelData.files
187
+ this.images = this.modifyModelData.images
188
+ if (Object.keys(this.modifyModelData.data).length > 0) {
189
+ this.getModifyModelData()
190
+ }
191
+ }
192
+ },
193
+ itemDisabled (value) {
194
+ return (this.businessType === '新增' && value.addOrEdit === 'edit') ||
195
+ (this.businessType === '修改' && value.addOrEdit === 'add')
196
+ },
197
+ async onSubmit () {
198
+ this.$refs.selectForm.validate(async valid => {
199
+ for (const key of Object.keys(this.form)) {
200
+ if (this.form[key] === null || this.form[key] === '') {
201
+ this.form[key] = undefined
202
+ }
203
+ }
204
+ const requestForm = Object.assign({}, this.form)
205
+ // 追加静默新增字段
206
+ if (this.businessType === '新增') {
207
+ for (const item of this.silenceAddJsonData) {
208
+ switch (item.silencePurpose) {
209
+ case 'createTime':
210
+ requestForm[item.model] = formatDate('now')
211
+ break
212
+ case 'operator':
213
+ requestForm[item.model] = this.currUser.name
214
+ break
215
+ case 'orgId':
216
+ requestForm[item.model] = this.currUser.orgid
217
+ break
218
+ }
219
+ }
220
+ // 通过请求追加静默新增:自定义字段
221
+ for (const item of this.silenceAddJsonData.filter((item) => item.silencePurpose === 'customize')) {
222
+ requestForm[item.model] = await this.getSilenceSource(item.silenceSource, requestForm)
223
+ }
224
+ }
225
+ const data = {
226
+ valid: valid,
227
+ form: requestForm
228
+ }
229
+ this.$emit('onSubmit', data)
230
+ })
231
+ },
232
+ /**
233
+ * 获取通过logic静默新增的字段
234
+ * @param logicName logic名称
235
+ * @param requestParameters 请求参数
236
+ */
237
+ async getSilenceSource (logicName, requestParameters) {
238
+ const result = await post('/api/' + this.serviceName + '/logic/' + logicName, requestParameters)
239
+ return result
240
+ },
241
+ /**
242
+ * 获取被修改记录数据
243
+ * @param modifyModelData 被修改记录的数据
244
+ */
245
+ getModifyModelData () {
246
+ for (let i = 0; i < this.realJsonData.length; i++) {
247
+ if (['FilesId', 'Images'].includes(this.realJsonData[i])) {
248
+ // 附件需要跳过 因为会通过 modifyModelData中的files,images属性给upload赋值
249
+ // 新增修改表单每次提交时只会提交最新添加的文件
250
+ continue
251
+ }
252
+ const item = this.realJsonData[i]
253
+ if (this.modifyModelData.data[item.model] || this.modifyModelData.data[item.model] === 0) {
254
+ if (this.modifyModelData.data[item.model] instanceof Array) {
255
+ this.form[item.model] = this.modifyModelData.data[item.model]
256
+ } else {
257
+ this.form[item.model] = this.modifyModelData.data[item.model] + ''
258
+ }
259
+ } else {
260
+ this.form[item.model] = undefined
261
+ }
262
+ }
263
+ // 追加版本号信息
264
+ for (const item of this.versionJsonData) {
265
+ if (!this.modifyModelData.data[item.model]) {
266
+ this.form[item.model] = 0
267
+ } else {
268
+ this.form[item.model] = this.modifyModelData.data[item.model] + ''
269
+ }
270
+ }
271
+ },
272
+ onClose () {
273
+ this.$emit('update:visible', false)
274
+ }
275
+ }
276
+ }
277
+ </script>