unify-external-plugin-platform 0.0.2-3 → 0.0.2-6

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 (60) hide show
  1. package/.idea/misc.xml +6 -0
  2. package/.idea/modules.xml +8 -0
  3. package/.idea/unify-external-plugin-platform.iml +12 -0
  4. package/.idea/vcs.xml +6 -0
  5. package/dist/demo.html +1 -0
  6. package/dist/external-plugin.common.js +3128 -0
  7. package/dist/external-plugin.common.js.map +1 -0
  8. package/dist/external-plugin.css +1 -0
  9. package/dist/external-plugin.umd.js +3147 -0
  10. package/dist/external-plugin.umd.js.map +1 -0
  11. package/dist/external-plugin.umd.min.js +8 -0
  12. package/dist/external-plugin.umd.min.js.map +1 -0
  13. package/{packages/zs-empty/src/assets/images/img_blank_empty.png → dist/img/img_blank_empty.92ddadbb.png} +0 -0
  14. package/package.json +3 -7
  15. package/packages/index.js +3 -3
  16. package/vue.config.js +1 -0
  17. package/docs/.vuepress/public/logo.png +0 -0
  18. package/packages/id-card-reader-demo/src/id-card-reader-demo.vue +0 -142
  19. package/packages/scanner-high-camera-jieyu/src/component/scanner-high-camera-component.vue +0 -292
  20. package/packages/scanner-high-camera-jieyu/src/scanner-high-camera-jieyu.vue +0 -174
  21. package/packages/zs-empty/src/zs-empty.vue +0 -42
  22. package/public/favicon.ico +0 -0
  23. package/public/img/icons/android-chrome-192x192.png +0 -0
  24. package/public/img/icons/android-chrome-512x512.png +0 -0
  25. package/public/img/icons/android-chrome-maskable-192x192.png +0 -0
  26. package/public/img/icons/android-chrome-maskable-512x512.png +0 -0
  27. package/public/img/icons/apple-touch-icon-120x120.png +0 -0
  28. package/public/img/icons/apple-touch-icon-152x152.png +0 -0
  29. package/public/img/icons/apple-touch-icon-180x180.png +0 -0
  30. package/public/img/icons/apple-touch-icon-60x60.png +0 -0
  31. package/public/img/icons/apple-touch-icon-76x76.png +0 -0
  32. package/public/img/icons/apple-touch-icon.png +0 -0
  33. package/public/img/icons/favicon-16x16.png +0 -0
  34. package/public/img/icons/favicon-32x32.png +0 -0
  35. package/public/img/icons/msapplication-icon-144x144.png +0 -0
  36. package/public/img/icons/mstile-150x150.png +0 -0
  37. package/public/img/icons/safari-pinned-tab.svg +0 -3
  38. package/public/index.html +0 -23
  39. package/public/robots.txt +0 -2
  40. package/src/App.vue +0 -15
  41. package/src/assets/images/reg-developing.png +0 -0
  42. package/src/assets/logo.png +0 -0
  43. package/src/components/404.vue +0 -17
  44. package/src/components/HelloWorld.vue +0 -61
  45. package/src/main.ts +0 -22
  46. package/src/registerServiceWorker.ts +0 -32
  47. package/src/router/id-card-reader/id-card-reader.ts +0 -19
  48. package/src/router/index.ts +0 -46
  49. package/src/router/scan/scan.ts +0 -19
  50. package/src/shims-tsx.d.ts +0 -11
  51. package/src/shims-vue.d.ts +0 -4
  52. package/src/store/index.ts +0 -17
  53. package/src/views/AboutView.vue +0 -5
  54. package/src/views/HomeView.vue +0 -109
  55. package/src/views/id-card-reader/id-card-reader-page.vue +0 -139
  56. package/src/views/id-card-reader/model/conatant/id-card-form-attr.ts +0 -31
  57. package/src/views/id-card-reader/model/vo/id-card.ts +0 -44
  58. package/src/views/layout/home-layout.vue +0 -72
  59. package/src/views/layout/model/menu-data.ts +0 -29
  60. package/src/views/scan/scan-page.vue +0 -56
package/package.json CHANGED
@@ -1,22 +1,18 @@
1
1
  {
2
2
  "name": "unify-external-plugin-platform",
3
- "version": "0.0.2-3",
3
+ "version": "0.0.2-6",
4
4
  "description": "统一对外插件平台",
5
- "main": "packages/index.js",
5
+ "main": "./dist/external-plugin.umd.min.js",
6
6
  "author": "Young",
7
7
  "license": "ISC",
8
8
  "scripts": {
9
9
  "serve": "vue-cli-service serve",
10
10
  "build": "vue-cli-service build",
11
+ "lib": "vue-cli-service build --target lib --name external-plugin ./packages/index.js",
11
12
  "docs:dev": "vuepress dev docs",
12
13
  "docs:build": "vuepress build docs"
13
14
  },
14
15
  "dependencies": {
15
- "sass": "^1.32.7",
16
- "sass-loader": "^12.0.0",
17
- "typescript": "~4.5.5",
18
- "vue-template-compiler": "^2.6.14",
19
- "vuepress": "^1.9.7",
20
16
  "core-js": "^3.8.3",
21
17
  "element-ui": "^2.15.12",
22
18
  "register-service-worker": "^1.7.2",
package/packages/index.js CHANGED
@@ -1,6 +1,6 @@
1
- import ZSEmpty from "./zs-empty/index.ts";
2
- import IdCardReaderDemo from "./id-card-reader-demo/index.ts";
3
- import ScannerHighCameraJieyu from "./scanner-high-camera-jieyu/index.ts";
1
+ import ZSEmpty from "./zs-empty";
2
+ import IdCardReaderDemo from "./id-card-reader-demo";
3
+ import ScannerHighCameraJieyu from "./scanner-high-camera-jieyu";
4
4
 
5
5
 
6
6
  // 组件列表
package/vue.config.js CHANGED
@@ -1,4 +1,5 @@
1
1
  const { defineConfig } = require('@vue/cli-service')
2
+
2
3
  module.exports = defineConfig({
3
4
  transpileDependencies: true
4
5
  })
Binary file
@@ -1,142 +0,0 @@
1
- <!--
2
- - @author: lvcy
3
- - @date: 2022-12-30
4
- - @description:index
5
- -->
6
- <template>
7
- <el-tooltip
8
- :content="tip"
9
- class="id-card-reader-demo"
10
- placement="top"
11
- v-if="tip"
12
- >
13
- <el-button
14
- @click="handleClick"
15
- v-bind="{
16
- disabled,
17
- icon,
18
- loading,
19
- plain,
20
- round,
21
- size,
22
- type,
23
- class: _className,
24
- }"
25
- >
26
- <slot>{{ label }}</slot>
27
- </el-button>
28
- </el-tooltip>
29
- <el-button
30
- v-else
31
- @click="handleClick"
32
- v-bind="{
33
- disabled,
34
- icon,
35
- loading,
36
- plain,
37
- round,
38
- size,
39
- type,
40
- class: _className,
41
- }"
42
- >
43
- <slot>{{ label }}</slot>
44
- </el-button>
45
-
46
- </template>
47
-
48
- <script lang="ts">
49
- import {Component, Prop, Vue} from "vue-property-decorator";
50
- import {ButtonType} from "element-ui/types/button";
51
- import {ElementUIComponentSize} from "element-ui/types/component";
52
-
53
- @Component({
54
- name: 'id-card-reader-demo'
55
- })
56
- export default class IdCardReaderDemo extends Vue {
57
- @Prop()
58
- label!: string
59
-
60
- @Prop()
61
- tip!: string
62
-
63
- @Prop()
64
- className!: string | string[]
65
- /** Button size */
66
- @Prop()
67
- size!: ElementUIComponentSize
68
-
69
- /** Button type */
70
- @Prop()
71
- type!: ButtonType
72
-
73
- /** Determine whether it's a plain button */
74
- @Prop()
75
- plain!: boolean
76
-
77
- /** Determine whether it's a round button */
78
- @Prop()
79
- round!: boolean
80
-
81
- /** Determine whether it's loading */
82
- @Prop()
83
- loading!: boolean
84
-
85
- /** Button icon, accepts an icon name of Element icon component */
86
- @Prop({ default: 'el-icon-postcard' })
87
- icon!: string
88
-
89
- @Prop({ default: false })
90
- disabled?: boolean
91
-
92
- get _className() {
93
- const classBase = ['z-button']
94
-
95
- if (this.type === 'text') {
96
- classBase.push('i-font-size')
97
- }
98
-
99
- if (!this.className) {
100
- return classBase
101
- } else if (typeof this.className === 'string') {
102
- classBase.push(this.className)
103
- } else {
104
- classBase.push(...this.className)
105
- }
106
- return classBase
107
- }
108
-
109
- handleClick() {
110
- const readData = {
111
- /** 身份证信息 */
112
- info: {
113
- /** 姓名 */
114
- name: '张三',
115
- /** 性别 */
116
- sex: '男',
117
- /** 民族 */
118
- nation: '汉',
119
- /** 出生日期 */
120
- birthday: '19950710',
121
- /** 地址 */
122
- address: '浙江省杭州市西湖区',
123
- /** 证件号码 */
124
- cardId: '140*************11',
125
- /** 签发机关 */
126
- police: '公安局',
127
- /** 有效期开始 */
128
- validStart: '20220516',
129
- /** 有效期结束 */
130
- validEnd: '20420516',
131
- },
132
- /** 身份证照片 */
133
- headImage: '',
134
- }
135
- this.$emit('click', readData)
136
- }
137
- }
138
- </script>
139
-
140
- <style scoped>
141
-
142
- </style>
@@ -1,292 +0,0 @@
1
- <!--
2
- - @author: lvcy
3
- - @date: 2023-02-07
4
- - @description:scanner-high-camera-component
5
- -->
6
- <template>
7
- <div class="scanner-high-camera-component">
8
- <div class="scanner-result-content">
9
- <div class="content-main flex-1">
10
- <div class="load-success" v-if="loadSuccess">
11
- <img id="photo" :src="scannerResultSrc"/>
12
- </div>
13
- <div class="load-error" v-else>
14
- <i class="el-icon-s-cooperation"></i>
15
- <p>请先安装插件</p>
16
- </div>
17
- </div>
18
- <div class="handle-action">
19
- <el-select v-model="camera" @change="selectChange" size="small" class="select">
20
- <el-option v-for="item in cameras" :key="item.value" :label="item.name" :value="item.value">
21
- </el-option>
22
- </el-select>
23
- <template
24
- v-for="item in buttonList"
25
- >
26
- <el-button
27
- :key="item.name"
28
- type="primary"
29
- size="small"
30
- @click="handleAction(item.name)"
31
- >{{ item.label }}</el-button>
32
- </template>
33
- </div>
34
- </div>
35
- </div>
36
- </template>
37
-
38
- <script lang="ts">
39
- import {Component, Vue} from "vue-property-decorator";
40
-
41
-
42
- const BEGIN_DATA = 'data:image/jpeg;base64,';
43
-
44
- @Component({
45
- name: "scanner-high-camera-component"
46
- })
47
- export default class ScannerHighCameraComponent extends Vue {
48
- totalTimeLength: number = 0;
49
- timeLength: string = '';
50
- timer: number = 0;
51
- str1: string = '';
52
- str2: string = '';
53
- webSocket: any;
54
-
55
- scannerResultSrc = '';
56
-
57
- loadSuccess = true;
58
-
59
- camera = 0;
60
-
61
- cameras = [
62
- {name: '文档', value: 0},
63
- {name: '照片', value: 1}
64
- ]
65
-
66
-
67
-
68
- buttonList = [
69
- // {label: '启动主', name: 'start-main'},
70
- // {label: '旋转启动主', name: 'rotation'},
71
- // {label: '启动副', name: 'start-vice'},
72
- // {label: '停止', name: 'stop'},
73
- // {label: '自动对焦', name: 'autofocus'},
74
- // {label: '去黑边', name: 'Black edge'},
75
- // {label: 'Base64', name: 'base64'},
76
- // {label: '开始录屏', name: 'start-record'},
77
- // {label: '停止录屏', name: 'stop-record'},
78
- {label: '拍照', name: 'take-pictures'},
79
- // {label: '设置去灰底', name: ''},
80
- // {label: 'FILTER设置', name: ''},
81
- // {label: 'PIN设置', name: ''},
82
- // {label: '自动寻边', name: ''},
83
- // {label: '身份证自动寻边', name: ''},
84
- // {label: 'vSetExposure', name: ''},
85
- // {label: 'vSetBrightness', name: ''},
86
- // {label: 'vSetContrast', name: ''},
87
- // {label: '设置分辨率', name: ''},
88
- ]
89
-
90
- mounted () {
91
- this.webSocket = new WebSocket('ws://127.0.0.1:1818');
92
-
93
- window.onbeforeunload = () => {
94
- this.webSocket.send("bStopPlay()");
95
- this.webSocket.send("bStopPlay4()");
96
- };
97
-
98
-
99
- this.webSocket.onerror = (event) => {
100
- this.onError(event);
101
- };
102
-
103
- this.webSocket.onopen = (event) => {
104
- this.onOpen(event);
105
- };
106
-
107
- this.webSocket.onclose = (event) => {
108
- this.onClose(event);
109
- this.webSocket.send("bStopPlay()");
110
- };
111
-
112
- this.webSocket.onmessage = (event) => {
113
- this.onMessage(event)
114
- }
115
-
116
- setTimeout(() => {
117
- this.handleAction('start-main')
118
- }, 800)
119
-
120
- }
121
-
122
- destroyed () {
123
- this.handleAction('stop');
124
- this.webSocket.close();
125
- }
126
-
127
- selectChange(val) {
128
- let handleName = val === 1 ? 'start-vice' : 'start-main';
129
- this.handleAction(handleName);
130
- }
131
-
132
- handleAction(name) {
133
- switch (name) {
134
- case 'start-main':
135
- this.StartPlay_onclick()
136
- break;
137
- case 'rotation':
138
- this.start('bStartPlayRotate(90)');
139
- break;
140
- case 'start-vice':
141
- this.start('bStartPlay2');
142
- break;
143
- case 'stop':
144
- this.start('bStopPlay');
145
- break;
146
- case 'autofocus':
147
- this.start('AutoFocus');
148
- break;
149
- case 'Black edge':
150
- this.start('vSetDelHBFlag(true)');
151
- break;
152
- case 'base64':
153
- this.start('sGetBase64');
154
- break;
155
- case 'start-record':
156
- this.start('bStartRec(d:\\test.avi)');
157
- break;
158
- case 'stop-record':
159
- this.start('bStopRec');
160
- break;
161
- case 'take-pictures':
162
- this.start('bSaveJPG(D:\\,Photo)');
163
- this.$emit('send-scanner-result', this.scannerResultSrc);
164
- break;
165
-
166
- }
167
- }
168
-
169
- timeGo() {
170
- this.totalTimeLength++;
171
- let Hour: number = 0,
172
- Minue: number = 0,
173
- Second: number = 0;
174
- Hour = Math.floor(this.totalTimeLength / 3600);
175
- Minue = Math.floor((this.totalTimeLength / 60) % 60);
176
- Second = Math.floor(this.totalTimeLength % 60);
177
- this.timeLength = Hour + "时" + Minue + "分" + Second + "秒";
178
- }
179
-
180
- onMessage(event) {
181
- if (event.data.indexOf('BarCodeTransferBegin') >= 0) {
182
- console.log(event.data.replace('BarCodeTransferBegin', '').replace('BarCodeTransferEnd', ''));
183
- } else if (event.data.indexOf('BeginbSaveJPG') >= 0) {
184
- this.str1 = event.data.replace('BeginbSaveJPG', '').replace('EndbSaveJPG', '');
185
- console.log(this.str1);
186
- } else if (event.data.indexOf('BeginbStopPlay') >= 0) {
187
- console.log(event.data);
188
- console.log(event.data.replace('BeginbStopPlay', '').replace('EndbStopPlay', ''));
189
- } else if (event.data.indexOf('BeginvSetResolution') >= 0) {
190
- console.log(event.data.replace('BeginvSetResolution', '').replace('EndvSetResolution', ''));
191
- } else if (event.data.indexOf('BeginvSetRemoveGBFlag') >= 0) {
192
- console.log(event.data.replace('BeginvSetRemoveGBFlag', '').replace('EndvSetRemoveGBFlag', ''));
193
- } else if (event.data.indexOf('BeginbFileExist') >= 0) {
194
- console.log(event.data.replace('BeginbFileExist', '').replace('EndbFileExist', ''));
195
- } else if (event.data.indexOf('BeginbStartPlay2') >= 0) {
196
- console.log(event.data.replace('BeginbStartPlay2', '').replace('EndbStartPlay2', ''));
197
- } else if (event.data.indexOf('BeginbStartPlay') >= 0) {
198
- console.log(event.data.replace('BeginbStartPlay', '').replace('EndbStartPlay', ''));
199
- } else if (event.data.indexOf('BeginbSetMode') >= 0) {
200
- console.log(event.data.replace('BeginbSetMode', '').replace('EndbSetMode', ''));
201
- } else {
202
- this.scannerResultSrc = `${BEGIN_DATA}${event.data}`;
203
- this.$emit('send-scanner-result', this.scannerResultSrc);
204
- }
205
- }
206
-
207
- onError(event) {
208
- console.log('error', event.data);
209
- this.loadSuccess = false;
210
- }
211
- onClose(event) {
212
- this.webSocket.send("bStopPlay()");
213
- this.webSocket.send("bStopPlay4()");
214
- }
215
- onOpen(event) {
216
-
217
- }
218
-
219
- start(el) {
220
- if (el == 'bStartRec(d:\\test.avi)') {
221
- this.timer = window.setInterval(this.timeGo, 1000);
222
- }
223
- if (el == 'bStopRec') {
224
- window.clearInterval(this.timer);
225
- this.totalTimeLength = 0;
226
- console.log("录屏结束");
227
- }
228
- this.webSocket.send(el);
229
- return false;
230
- }
231
-
232
- vout_OnClick() {
233
-
234
- }
235
-
236
-
237
- Stop_onclick() {
238
- this.webSocket.send("bStopPlay()");
239
- }
240
-
241
- StartPlay_onclick() {
242
- this.webSocket.send("vSetResolution(8)");
243
- this.webSocket.send("bStartPlay()");
244
- // this.loadSuccess = true
245
- }
246
- }
247
- </script>
248
-
249
- <style scoped lang="scss">
250
- .scanner-high-camera-component {
251
- height: 100%;
252
- .scanner-result-content {
253
- height: 100%;
254
- display: flex;
255
- flex-direction: column;
256
- .content-main {
257
- flex: 1;
258
- background-color: #F7F7F7;
259
- }
260
-
261
- .load-success,
262
- .load-error {
263
- height: 100%;
264
- display: flex;
265
- flex-direction: column;
266
- justify-content: center;
267
- align-items: center;
268
- text-align: center;
269
- }
270
-
271
- .load-error {
272
- color: #999999;
273
- i {
274
- font-size: 88px;
275
- }
276
- p {
277
- font-size: 16px;
278
-
279
- line-height: 30px;
280
- }
281
- }
282
-
283
- .handle-action {
284
- margin: 10px 0;
285
- .select {
286
- margin-right: 15px;
287
- }
288
- }
289
-
290
- }
291
- }
292
- </style>