imatrix-ui 0.2.6-up → 0.2.7-up

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 (206) hide show
  1. package/README.md +7 -7
  2. package/index.html +13 -13
  3. package/lib/super-ui.css +1 -1
  4. package/lib/super-ui.js +2724 -1932
  5. package/lib/super-ui.umd.cjs +24 -24
  6. package/package.json +1 -1
  7. package/packages/IntervalSelection/index.js +6 -6
  8. package/packages/IntervalSelection/src/quarterScope.vue +405 -405
  9. package/packages/IntervalSelection/src/sectionDate.vue +475 -475
  10. package/packages/breadcrumb/index.js +6 -6
  11. package/packages/breadcrumb/src/breadcrumb.vue +81 -81
  12. package/packages/department-tree/index.js +6 -6
  13. package/packages/department-tree/src/department-tree.vue +113 -113
  14. package/packages/department-tree-inline/index.js +6 -6
  15. package/packages/department-tree-inline/src/department-multi-tree-inline.vue +472 -472
  16. package/packages/department-tree-inline/src/department-single-tree-inline.vue +340 -340
  17. package/packages/department-tree-inline/src/department-tree-inline.vue +86 -86
  18. package/packages/department-tree-inline/src/department-tree-service.js +344 -344
  19. package/packages/department-tree-inline/src/search-result.vue +235 -235
  20. package/packages/department-user-tree/index.js +6 -6
  21. package/packages/department-user-tree/src/department-user-multiple-tree.vue +129 -129
  22. package/packages/department-user-tree/src/department-user-single-tree.vue +94 -94
  23. package/packages/department-user-tree/src/department-user-tree.vue +114 -114
  24. package/packages/department-user-tree-inline/index.js +9 -9
  25. package/packages/department-user-tree-inline/src/department-user-multiple-tree-inline.vue +731 -731
  26. package/packages/department-user-tree-inline/src/department-user-single-tree-inline.vue +334 -334
  27. package/packages/department-user-tree-inline/src/department-user-tree-inline.vue +87 -87
  28. package/packages/department-user-tree-inline/src/department-user-tree-multi-service.js +309 -309
  29. package/packages/department-user-tree-inline/src/department-user-tree-single-service.js +179 -179
  30. package/packages/department-user-tree-inline/src/search-result.vue +273 -273
  31. package/packages/directives/prevent-reclick.js +22 -22
  32. package/packages/dynamic-source-select/index.js +6 -6
  33. package/packages/dynamic-source-select/src/dynamic-source-select-service.js +106 -106
  34. package/packages/dynamic-source-select/src/dynamic-source-select.vue +675 -675
  35. package/packages/dynamic-source-select/src/events.js +78 -78
  36. package/packages/fs-preview/index.js +6 -6
  37. package/packages/fs-preview/src/fs-preview.vue +287 -287
  38. package/packages/fs-upload/index.js +6 -6
  39. package/packages/fs-upload/src/fs-upload-multi.vue +443 -443
  40. package/packages/fs-upload/src/fs-upload-single.vue +353 -353
  41. package/packages/fs-upload/src/fs-upload.vue +191 -191
  42. package/packages/fs-upload/src/see-big-picture.vue +67 -67
  43. package/packages/fs-upload-list/index.js +6 -6
  44. package/packages/fs-upload-list/src/fs-upload-list.vue +372 -372
  45. package/packages/hamburger/index.js +6 -6
  46. package/packages/hamburger/src/hamburger.vue +40 -40
  47. package/packages/index.js +123 -123
  48. package/packages/multipart-upload/index.js +6 -6
  49. package/packages/multipart-upload/src/index.vue +66 -66
  50. package/packages/multipart-upload/src/multipart-upload-form.vue +377 -377
  51. package/packages/multipart-upload/src/multipart-upload-list.vue +517 -517
  52. package/packages/organization-input/index.js +6 -6
  53. package/packages/organization-input/src/organization-input.vue +583 -583
  54. package/packages/plugins/export-data-new.js +623 -623
  55. package/packages/plugins/export-data.js +431 -431
  56. package/packages/plugins/index.js +15 -15
  57. package/packages/plugins/public-method.js +47 -47
  58. package/packages/remove-department/index.js +6 -6
  59. package/packages/remove-department/src/remove-department.vue +200 -200
  60. package/packages/remove-department/src/remove-dept-service.js +31 -31
  61. package/packages/remove-user/index.js +6 -6
  62. package/packages/remove-user/src/remove-user-service.js +31 -31
  63. package/packages/remove-user/src/remove-user.vue +226 -226
  64. package/packages/remove-workgroup/index.js +6 -6
  65. package/packages/remove-workgroup/src/remove-workgroup-service.js +31 -31
  66. package/packages/remove-workgroup/src/remove-workgroup.vue +183 -183
  67. package/packages/rich-editor/index.js +7 -7
  68. package/packages/rich-editor/index.vue +297 -297
  69. package/packages/rich-editor/langs/zh-Hans.js +438 -438
  70. package/packages/rich-editor/viewer.vue +105 -105
  71. package/packages/scan-code-input/index.js +6 -6
  72. package/packages/scan-code-input/src/events.js +34 -34
  73. package/packages/scan-code-input/src/scan-code-input-colse.vue +140 -140
  74. package/packages/scan-code-input/src/scan-code-input.vue +132 -132
  75. package/packages/secret-info/index.js +7 -7
  76. package/packages/secret-info/index.vue +100 -100
  77. package/packages/super-grid/index.js +7 -7
  78. package/packages/super-grid/src/apis.js +1092 -1092
  79. package/packages/super-grid/src/columns-config.vue +427 -427
  80. package/packages/super-grid/src/custom-formatter.js +394 -394
  81. package/packages/super-grid/src/eventBus.js +2 -2
  82. package/packages/super-grid/src/events.js +56 -56
  83. package/packages/super-grid/src/formValidatorUtil.js +300 -300
  84. package/packages/super-grid/src/formatter.js +196 -196
  85. package/packages/super-grid/src/group-column.vue +99 -99
  86. package/packages/super-grid/src/header-context-menu.vue +82 -82
  87. package/packages/super-grid/src/index-column.vue +69 -69
  88. package/packages/super-grid/src/public-methods.js +30 -30
  89. package/packages/super-grid/src/row-operation.vue +193 -193
  90. package/packages/super-grid/src/search-button.vue +74 -74
  91. package/packages/super-grid/src/search-condition-input.vue +73 -73
  92. package/packages/super-grid/src/search-condition-list.vue +68 -68
  93. package/packages/super-grid/src/search-form-advancedQuery.vue +819 -819
  94. package/packages/super-grid/src/search-form-dialog.vue +77 -77
  95. package/packages/super-grid/src/search-form-item.vue +495 -495
  96. package/packages/super-grid/src/search-form-number.vue +111 -111
  97. package/packages/super-grid/src/search-form-ordinarySearch.vue +239 -239
  98. package/packages/super-grid/src/search-form.vue +762 -762
  99. package/packages/super-grid/src/search-methods.js +592 -592
  100. package/packages/super-grid/src/selection-column.vue +46 -46
  101. package/packages/super-grid/src/store.js +3 -3
  102. package/packages/super-grid/src/super-grid-service.js +728 -728
  103. package/packages/super-grid/src/super-grid.vue +3011 -3011
  104. package/packages/super-grid/src/utils.js +880 -880
  105. package/packages/super-grid/src/view-image-dialog.vue +176 -176
  106. package/packages/super-nine-grid/index.js +7 -7
  107. package/packages/super-nine-grid/src/apis.js +108 -108
  108. package/packages/super-nine-grid/src/custom-formatter.js +73 -73
  109. package/packages/super-nine-grid/src/formatter.js +134 -134
  110. package/packages/super-nine-grid/src/search-form-number.vue +35 -35
  111. package/packages/super-nine-grid/src/search-form.vue +700 -700
  112. package/packages/super-nine-grid/src/search-methods.js +151 -151
  113. package/packages/super-nine-grid/src/store.js +3 -3
  114. package/packages/super-nine-grid/src/super-grid-service.js +107 -107
  115. package/packages/svg-icon/index.js +6 -6
  116. package/packages/svg-icon/src/svg-icon.vue +43 -43
  117. package/packages/utils/date-util.js +292 -292
  118. package/packages/utils/dom.js +227 -227
  119. package/packages/utils/gogocodeTransfer.js +59 -59
  120. package/packages/utils/memory-cache-utils.js +117 -117
  121. package/packages/utils/utils.js +180 -180
  122. package/packages/utils/value-set.js +97 -97
  123. package/packages/valid-code/index.js +7 -7
  124. package/packages/valid-code/src/valid-code.vue +104 -104
  125. package/packages/workflow-button/index.js +6 -6
  126. package/packages/workflow-button/src/workflow-button.vue +550 -550
  127. package/packages/workflow-history-list/index.js +6 -6
  128. package/packages/workflow-history-list/src/api.js +7 -7
  129. package/packages/workflow-history-list/src/workflow-history-list.vue +291 -291
  130. package/packages/workgroup-tree/index.js +6 -6
  131. package/packages/workgroup-tree/src/workgroup-tree.vue +86 -86
  132. package/packages/workgroup-tree-inline/index.js +6 -6
  133. package/packages/workgroup-tree-inline/src/search-result.vue +222 -222
  134. package/packages/workgroup-tree-inline/src/workgroup-tree-inline.vue +516 -516
  135. package/packages/workgroup-tree-inline/src/workgroup-tree-service.js +93 -93
  136. package/packages/workgroup-user-tree/index.js +6 -6
  137. package/packages/workgroup-user-tree/src/workgroup-user-tree.vue +103 -103
  138. package/packages/workgroup-user-tree-inline/index.js +9 -9
  139. package/packages/workgroup-user-tree-inline/src/search-result.vue +266 -266
  140. package/packages/workgroup-user-tree-inline/src/workgroup-tree-inline-service.js +239 -239
  141. package/packages/workgroup-user-tree-inline/src/workgroup-user-tree-inline.vue +657 -657
  142. package/packages/year-range-picker/index.js +6 -6
  143. package/packages/year-range-picker/src/year-range-picker.vue +53 -53
  144. package/src/api/sso-service.js +172 -172
  145. package/src/api/tab.js +36 -36
  146. package/src/api/user-service.js +11 -11
  147. package/src/directives/permission/index.js +13 -13
  148. package/src/directives/permission/permission.js +20 -20
  149. package/src/i18n/langs/cn.js +259 -259
  150. package/src/i18n/langs/en.js +269 -269
  151. package/src/index.js +93 -93
  152. package/src/plugins.js +18 -18
  153. package/src/router/index.js +8 -26
  154. package/src/store/getters.js +15 -15
  155. package/src/store/index.js +19 -19
  156. package/src/store/modules/app.js +54 -54
  157. package/src/store/modules/tab-content.js +36 -36
  158. package/src/store/modules/user.js +285 -285
  159. package/src/utils/auth.js +61 -61
  160. package/src/utils/calculator/calculator-factory-wf.js +558 -558
  161. package/src/utils/calculator/calculator-factory.js +145 -145
  162. package/src/utils/calculator/calculator-util.js +166 -166
  163. package/src/utils/eventBus.js +2 -2
  164. package/src/utils/iconUtils.js +28 -28
  165. package/src/utils/index.js +102 -102
  166. package/src/utils/jump-page-utils.js +824 -824
  167. package/src/utils/menu.js +19 -19
  168. package/src/utils/permission.js +31 -31
  169. package/src/utils/permissionAuth.js +96 -96
  170. package/src/utils/range-selector.js +188 -188
  171. package/src/utils/request.js +269 -269
  172. package/src/utils/restful-interface-utils.js +57 -57
  173. package/src/utils/util.js +703 -703
  174. package/src/utils/validate.js +34 -34
  175. package/src/utils/watermark.js +108 -108
  176. package/src/utils/workflow-util.js +93 -93
  177. package/src/views/404.vue +248 -248
  178. package/src/views/dsc-component/Sidebar/Item.vue +84 -84
  179. package/src/views/dsc-component/Sidebar/Link.vue +38 -38
  180. package/src/views/dsc-component/Sidebar/SidebarItem.vue +198 -198
  181. package/src/views/dsc-component/Sidebar/index.vue +229 -229
  182. package/src/views/dsc-component/tabs/tab-content.vue +203 -203
  183. package/src/views/error-page/401.vue +106 -106
  184. package/src/views/error-page/404.vue +248 -248
  185. package/src/views/layout/EmptyLayout.vue +3 -3
  186. package/src/views/layout/Layout.vue +81 -81
  187. package/src/views/layout/NewLayout.vue +18 -18
  188. package/src/views/layout/components/AppMain.vue +39 -39
  189. package/src/views/layout/components/Breadcrumb/index.vue +158 -158
  190. package/src/views/layout/components/Menubar/Item.vue +79 -79
  191. package/src/views/layout/components/Menubar/Link.vue +38 -38
  192. package/src/views/layout/components/Menubar/index.vue +210 -210
  193. package/src/views/layout/components/Sidebar/Item.vue +53 -53
  194. package/src/views/layout/components/Sidebar/Link.vue +38 -38
  195. package/src/views/layout/components/Sidebar/index.vue +141 -141
  196. package/src/views/layout/components/iframe-page.vue +38 -38
  197. package/src/views/layout/components/index.js +4 -4
  198. package/src/views/layout/components/tabs/tab-content.vue +207 -207
  199. package/src/views/layout/mixin/ResizeHandler.js +41 -41
  200. package/src/views/layout/tab-content-iframe-index.vue +38 -38
  201. package/src/views/layout/tab-content-index.vue +93 -93
  202. package/src/views/login/authredirect.vue +10 -10
  203. package/src/views/login/index.vue +296 -296
  204. package/src/views/login/update-password.vue +243 -243
  205. package/src/views/redirect/index.vue +14 -14
  206. package/src/views/wf-history/tache-subprocess-history.vue +45 -45
@@ -1,105 +1,105 @@
1
- <template>
2
- <el-dialog
3
- model-value
4
- :title="title"
5
- append-to-body
6
- fullscreen
7
- @close="$emit('closeRichEditorContent')"
8
- >
9
- <el-image
10
- ref="previewImg"
11
- :src="srcList[0]"
12
- :preview-src-list="srcList"
13
- style="display: none; width: 100px; height: 100px"
14
- />
15
- <div :id="fullscreenViewerId" />
16
- </el-dialog>
17
- </template>
18
-
19
- <script>
20
- import * as Vue from 'vue'
21
- export default {
22
- name: 'RichEditorViewer',
23
- props: {
24
- entity: {
25
- type: Object,
26
- default: null,
27
- },
28
- prop: {
29
- type: String,
30
- default: null,
31
- },
32
- value: {
33
- type: String,
34
- default: '',
35
- },
36
- disabled: {
37
- type: Boolean,
38
- default: false,
39
- },
40
- options: {
41
- type: Object,
42
- default: null,
43
- },
44
- plugins: {
45
- type: [String, Array],
46
- default:
47
- 'print preview searchreplace directionality fullscreen image link table hr advlist lists wordcount ',
48
- },
49
- toolbar: {
50
- type: [String, Array],
51
- default:
52
- ' undo redo | formatselect fontsizeselect bold italic strikethrough underline hr forecolor backcolor | image | ' +
53
- ' lineheight bullist numlist table | print fullscreen preview ',
54
- },
55
- },
56
- data() {
57
- return {
58
- srcList: [],
59
- psrcList: [],
60
- viewerId: 'aglie_rich_editor_' + new Date().getTime(),
61
- dialogVisible: false,
62
- fullscreenViewerId: 'editor_viewer_' + new Date().getTime(),
63
- ImageComponent: null,
64
- title: '',
65
- }
66
- },
67
- watch: {
68
- value(newValue) {
69
- this.contentValue = newValue
70
- this.entity[this.prop] = newValue
71
- },
72
- },
73
- created() {},
74
- mounted() {},
75
- methods: {
76
- showImage($event) {
77
- this.srcList = [$event.target.currentSrc]
78
- this.$refs.previewImg.showViewer = true
79
- },
80
- showContent(content, title) {
81
- this.title = title
82
- const that = this
83
- let m = content.replaceAll('<img', '<img @click="showImage" ')
84
- m = '<div> ' + m + ' </div> '
85
- this.ImageComponent = {
86
- methods: {
87
- showImage($event) {
88
- console.log($event)
89
- that.showImage($event)
90
- },
91
- },
92
- template: m,
93
- emits: ['closeRichEditorContent', 'update:value', 'update:value'],
94
- }
95
- const viewContent = new this.ImageComponent().$mount()
96
- this.$nextTick(() => {
97
- document
98
- .getElementById(this.fullscreenViewerId)
99
- .appendChild(viewContent.$el)
100
- })
101
- },
102
- },
103
- emits: ['closeRichEditorContent', 'update:value'],
104
- }
105
- </script>
1
+ <template>
2
+ <el-dialog
3
+ model-value
4
+ :title="title"
5
+ append-to-body
6
+ fullscreen
7
+ @close="$emit('closeRichEditorContent')"
8
+ >
9
+ <el-image
10
+ ref="previewImg"
11
+ :src="srcList[0]"
12
+ :preview-src-list="srcList"
13
+ style="display: none; width: 100px; height: 100px"
14
+ />
15
+ <div :id="fullscreenViewerId" />
16
+ </el-dialog>
17
+ </template>
18
+
19
+ <script>
20
+ import * as Vue from 'vue'
21
+ export default {
22
+ name: 'RichEditorViewer',
23
+ props: {
24
+ entity: {
25
+ type: Object,
26
+ default: null,
27
+ },
28
+ prop: {
29
+ type: String,
30
+ default: null,
31
+ },
32
+ value: {
33
+ type: String,
34
+ default: '',
35
+ },
36
+ disabled: {
37
+ type: Boolean,
38
+ default: false,
39
+ },
40
+ options: {
41
+ type: Object,
42
+ default: null,
43
+ },
44
+ plugins: {
45
+ type: [String, Array],
46
+ default:
47
+ 'print preview searchreplace directionality fullscreen image link table hr advlist lists wordcount ',
48
+ },
49
+ toolbar: {
50
+ type: [String, Array],
51
+ default:
52
+ ' undo redo | formatselect fontsizeselect bold italic strikethrough underline hr forecolor backcolor | image | ' +
53
+ ' lineheight bullist numlist table | print fullscreen preview ',
54
+ },
55
+ },
56
+ data() {
57
+ return {
58
+ srcList: [],
59
+ psrcList: [],
60
+ viewerId: 'aglie_rich_editor_' + new Date().getTime(),
61
+ dialogVisible: false,
62
+ fullscreenViewerId: 'editor_viewer_' + new Date().getTime(),
63
+ ImageComponent: null,
64
+ title: '',
65
+ }
66
+ },
67
+ watch: {
68
+ value(newValue) {
69
+ this.contentValue = newValue
70
+ this.entity[this.prop] = newValue
71
+ },
72
+ },
73
+ created() {},
74
+ mounted() {},
75
+ methods: {
76
+ showImage($event) {
77
+ this.srcList = [$event.target.currentSrc]
78
+ this.$refs.previewImg.showViewer = true
79
+ },
80
+ showContent(content, title) {
81
+ this.title = title
82
+ const that = this
83
+ let m = content.replaceAll('<img', '<img @click="showImage" ')
84
+ m = '<div> ' + m + ' </div> '
85
+ this.ImageComponent = {
86
+ methods: {
87
+ showImage($event) {
88
+ console.log($event)
89
+ that.showImage($event)
90
+ },
91
+ },
92
+ template: m,
93
+ emits: ['closeRichEditorContent', 'update:value', 'update:value'],
94
+ }
95
+ const viewContent = new this.ImageComponent().$mount()
96
+ this.$nextTick(() => {
97
+ document
98
+ .getElementById(this.fullscreenViewerId)
99
+ .appendChild(viewContent.$el)
100
+ })
101
+ },
102
+ },
103
+ emits: ['closeRichEditorContent', 'update:value'],
104
+ }
105
+ </script>
@@ -1,6 +1,6 @@
1
- import ScanCodeInput from './src/scan-code-input.vue'
2
- ScanCodeInput.install = function (Vue) {
3
- Vue.component(ScanCodeInput.name, ScanCodeInput)
4
- }
5
-
6
- export default ScanCodeInput
1
+ import ScanCodeInput from './src/scan-code-input.vue'
2
+ ScanCodeInput.install = function (Vue) {
3
+ Vue.component(ScanCodeInput.name, ScanCodeInput)
4
+ }
5
+
6
+ export default ScanCodeInput
@@ -1,34 +1,34 @@
1
- import { $on, $off, $once, $emit } from '../../utils/gogocodeTransfer'
2
- const events = {
3
- /**
4
- * 选中值发生变化时触发
5
- * @param {*} newValue
6
- */
7
- change: function (newValue) {
8
- $emit(this, 'change', newValue)
9
- },
10
- /**
11
- * 可清空的单选模式下用户点击清空按钮时触发
12
- */
13
- clear: function () {
14
- $emit(this, 'clear')
15
- },
16
- /**
17
- * 当 input 失去焦点时触发
18
- * @param {*} event
19
- */
20
- blur: function (event) {
21
- $emit(this, 'blur', event)
22
- },
23
- /**
24
- * 当 input 获得焦点时触发
25
- * @param {*} event
26
- */
27
- focus: function (event) {
28
- $emit(this, 'focus', event)
29
- },
30
- input(newValue) {
31
- $emit(this, 'update:value', newValue)
32
- },
33
- }
34
- export default events
1
+ import { $on, $off, $once, $emit } from '../../utils/gogocodeTransfer'
2
+ const events = {
3
+ /**
4
+ * 选中值发生变化时触发
5
+ * @param {*} newValue
6
+ */
7
+ change: function (newValue) {
8
+ $emit(this, 'change', newValue)
9
+ },
10
+ /**
11
+ * 可清空的单选模式下用户点击清空按钮时触发
12
+ */
13
+ clear: function () {
14
+ $emit(this, 'clear')
15
+ },
16
+ /**
17
+ * 当 input 失去焦点时触发
18
+ * @param {*} event
19
+ */
20
+ blur: function (event) {
21
+ $emit(this, 'blur', event)
22
+ },
23
+ /**
24
+ * 当 input 获得焦点时触发
25
+ * @param {*} event
26
+ */
27
+ focus: function (event) {
28
+ $emit(this, 'focus', event)
29
+ },
30
+ input(newValue) {
31
+ $emit(this, 'update:value', newValue)
32
+ },
33
+ }
34
+ export default events
@@ -1,140 +1,140 @@
1
- <template>
2
- <div class>
3
- <video
4
- id="video"
5
- ref="video"
6
- height="300"
7
- class="video vjs-fluid"
8
- autoplay
9
- @click="clickVideo"
10
- />
11
- <div v-show="tipShow" class="tip">
12
- {{ tipMsg }}
13
- </div>
14
- </div>
15
- </template>
16
-
17
- <script type="text/ecmascript-6">
18
- import { $on, $off, $once, $emit } from '../../utils/gogocodeTransfer';
19
- import { BrowserMultiFormatReader } from '@zxing/library'
20
-
21
- export default {name: 'ScanCodeInputColse',
22
- components: {},
23
- props: {
24
- colseVideo: {
25
- type: Boolean,
26
- default: false
27
- }
28
- },
29
- data() {
30
- return {
31
- loadingShow: false,
32
- codeReader: new BrowserMultiFormatReader(),
33
- textContent: null,
34
- vin: null,
35
- tipMsg: this.$t('messageVideo.attemptingToIdentify'),
36
- tipShow: false,
37
- isVideo: false
38
- };
39
- },
40
- created() {
41
- this.openScan()
42
- },
43
- beforeUnmount() {
44
- console.log('销毁定时器')
45
- this.codeReader.reset()
46
- },
47
- methods: {
48
- async openScan() {
49
- const that = this
50
- that.codeReader.listVideoInputDevices().then((videoInputDevices) => {
51
- that.tipShow = true
52
- that.tipMsg = this.$t('messageVideo.callingRearCamera')
53
- console.log('videoInputDevices', videoInputDevices)
54
- // 默认获取第一个摄像头设备id
55
- let firstDeviceId = videoInputDevices[0].deviceId
56
- // 获取第一个摄像头设备的名称
57
- const videoInputDeviceslablestr = JSON.stringify(videoInputDevices[0].label)
58
- if (videoInputDevices.length > 1) {
59
- // 判断是否后置摄像头
60
- if (videoInputDeviceslablestr.indexOf('back') > -1) {
61
- firstDeviceId = videoInputDevices[0].deviceId
62
- } else {
63
- firstDeviceId = videoInputDevices[1].deviceId
64
- }
65
- }
66
- that.decodeFromInputVideoFunc(firstDeviceId)
67
- }).catch((err) => {
68
- that.tipShow = false
69
- console.error(err)
70
- })
71
- },
72
- async openScanTwo() {
73
- const that = this
74
- // codeReader.reset() // 重置
75
- // that.textContent = null // 重置
76
- that.codeReader = await new BrowserMultiFormatReader()
77
- that.codeReader.listVideoInputDevices().then((videoInputDevices) => {
78
- that.tipShow = true
79
- that.tipMsg = this.$t('messageVideo.callingRearCamera')
80
- console.log('videoInputDevices', videoInputDevices)
81
- // 默认获取第一个摄像头设备id
82
- let firstDeviceId = videoInputDevices[0].deviceId
83
- // 获取第一个摄像头设备的名称
84
- const videoInputDeviceslablestr = JSON.stringify(videoInputDevices[0].label)
85
- if (videoInputDevices.length > 1) {
86
- // 判断是否后置摄像头
87
- if (videoInputDeviceslablestr.indexOf('back') > -1) {
88
- firstDeviceId = videoInputDevices[0].deviceId
89
- } else {
90
- firstDeviceId = videoInputDevices[1].deviceId
91
- }
92
- }
93
- that.decodeFromInputVideoFunc(firstDeviceId)
94
- }).catch((err) => {
95
- that.tipShow = false
96
- console.error(err)
97
- })
98
- },
99
- decodeFromInputVideoFunc(firstDeviceId) {
100
- const that = this
101
- that.codeReader.reset() // 重置
102
- that.textContent = null // 重置
103
- that.codeReader.decodeFromVideoDevice(firstDeviceId, 'video', (result, err) => {
104
- that.tipMsg = this.$t('messageVideo.attemptingToIdentify')
105
- // let nowContent = null
106
- that.textContent = null
107
- if (result) {
108
- console.log(result)
109
- that.textContent = result.text
110
- if (that.textContent) {
111
- that.tipShow = false
112
- that.msgBoxFunc(that.textContent)
113
- }
114
- }
115
- if (err && !(err)) {
116
- that.tipMsg = this.$t('messageVideo.identificationFailed')
117
- setTimeout(() => {
118
- that.tipShow = false
119
- }, 2000)
120
- console.error(err)
121
- }
122
- })
123
- },
124
- // that.$createDialog 是 cube-ui滴滴 messageBox ,到这一步 二维码值已出,这里是可有可无的代码块,看各自项目ui使用情况 自行替换 messageBox
125
- msgBoxFunc(textContent) {
126
- const that = this
127
- that.vin = textContent
128
- $emit(that, "close",that.vin)
129
- that.codeReader.reset()
130
- },
131
- clickVideo() {
132
- if (this.colseVideo) {
133
- $emit(this, "close",this.vin)
134
- this.codeReader.reset()
135
- }
136
- }
137
- },
138
- emits:['close',]
139
- }
140
- </script>
1
+ <template>
2
+ <div class>
3
+ <video
4
+ id="video"
5
+ ref="video"
6
+ height="300"
7
+ class="video vjs-fluid"
8
+ autoplay
9
+ @click="clickVideo"
10
+ />
11
+ <div v-show="tipShow" class="tip">
12
+ {{ tipMsg }}
13
+ </div>
14
+ </div>
15
+ </template>
16
+
17
+ <script type="text/ecmascript-6">
18
+ import { $on, $off, $once, $emit } from '../../utils/gogocodeTransfer';
19
+ import { BrowserMultiFormatReader } from '@zxing/library'
20
+
21
+ export default {name: 'ScanCodeInputColse',
22
+ components: {},
23
+ props: {
24
+ colseVideo: {
25
+ type: Boolean,
26
+ default: false
27
+ }
28
+ },
29
+ data() {
30
+ return {
31
+ loadingShow: false,
32
+ codeReader: new BrowserMultiFormatReader(),
33
+ textContent: null,
34
+ vin: null,
35
+ tipMsg: this.$t('messageVideo.attemptingToIdentify'),
36
+ tipShow: false,
37
+ isVideo: false
38
+ };
39
+ },
40
+ created() {
41
+ this.openScan()
42
+ },
43
+ beforeUnmount() {
44
+ console.log('销毁定时器')
45
+ this.codeReader.reset()
46
+ },
47
+ methods: {
48
+ async openScan() {
49
+ const that = this
50
+ that.codeReader.listVideoInputDevices().then((videoInputDevices) => {
51
+ that.tipShow = true
52
+ that.tipMsg = this.$t('messageVideo.callingRearCamera')
53
+ console.log('videoInputDevices', videoInputDevices)
54
+ // 默认获取第一个摄像头设备id
55
+ let firstDeviceId = videoInputDevices[0].deviceId
56
+ // 获取第一个摄像头设备的名称
57
+ const videoInputDeviceslablestr = JSON.stringify(videoInputDevices[0].label)
58
+ if (videoInputDevices.length > 1) {
59
+ // 判断是否后置摄像头
60
+ if (videoInputDeviceslablestr.indexOf('back') > -1) {
61
+ firstDeviceId = videoInputDevices[0].deviceId
62
+ } else {
63
+ firstDeviceId = videoInputDevices[1].deviceId
64
+ }
65
+ }
66
+ that.decodeFromInputVideoFunc(firstDeviceId)
67
+ }).catch((err) => {
68
+ that.tipShow = false
69
+ console.error(err)
70
+ })
71
+ },
72
+ async openScanTwo() {
73
+ const that = this
74
+ // codeReader.reset() // 重置
75
+ // that.textContent = null // 重置
76
+ that.codeReader = await new BrowserMultiFormatReader()
77
+ that.codeReader.listVideoInputDevices().then((videoInputDevices) => {
78
+ that.tipShow = true
79
+ that.tipMsg = this.$t('messageVideo.callingRearCamera')
80
+ console.log('videoInputDevices', videoInputDevices)
81
+ // 默认获取第一个摄像头设备id
82
+ let firstDeviceId = videoInputDevices[0].deviceId
83
+ // 获取第一个摄像头设备的名称
84
+ const videoInputDeviceslablestr = JSON.stringify(videoInputDevices[0].label)
85
+ if (videoInputDevices.length > 1) {
86
+ // 判断是否后置摄像头
87
+ if (videoInputDeviceslablestr.indexOf('back') > -1) {
88
+ firstDeviceId = videoInputDevices[0].deviceId
89
+ } else {
90
+ firstDeviceId = videoInputDevices[1].deviceId
91
+ }
92
+ }
93
+ that.decodeFromInputVideoFunc(firstDeviceId)
94
+ }).catch((err) => {
95
+ that.tipShow = false
96
+ console.error(err)
97
+ })
98
+ },
99
+ decodeFromInputVideoFunc(firstDeviceId) {
100
+ const that = this
101
+ that.codeReader.reset() // 重置
102
+ that.textContent = null // 重置
103
+ that.codeReader.decodeFromVideoDevice(firstDeviceId, 'video', (result, err) => {
104
+ that.tipMsg = this.$t('messageVideo.attemptingToIdentify')
105
+ // let nowContent = null
106
+ that.textContent = null
107
+ if (result) {
108
+ console.log(result)
109
+ that.textContent = result.text
110
+ if (that.textContent) {
111
+ that.tipShow = false
112
+ that.msgBoxFunc(that.textContent)
113
+ }
114
+ }
115
+ if (err && !(err)) {
116
+ that.tipMsg = this.$t('messageVideo.identificationFailed')
117
+ setTimeout(() => {
118
+ that.tipShow = false
119
+ }, 2000)
120
+ console.error(err)
121
+ }
122
+ })
123
+ },
124
+ // that.$createDialog 是 cube-ui滴滴 messageBox ,到这一步 二维码值已出,这里是可有可无的代码块,看各自项目ui使用情况 自行替换 messageBox
125
+ msgBoxFunc(textContent) {
126
+ const that = this
127
+ that.vin = textContent
128
+ $emit(that, "close",that.vin)
129
+ that.codeReader.reset()
130
+ },
131
+ clickVideo() {
132
+ if (this.colseVideo) {
133
+ $emit(this, "close",this.vin)
134
+ this.codeReader.reset()
135
+ }
136
+ }
137
+ },
138
+ emits:['close',]
139
+ }
140
+ </script>