unify-external-plugin-platform 0.0.1 → 0.0.2
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.
- package/README.md +49 -1
- package/docs/.vuepress/config.js +46 -0
- package/docs/.vuepress/public/logo.png +0 -0
- package/docs/README.md +15 -0
- package/docs/guide/changelog.md +1 -0
- package/docs/guide/installation.md +10 -0
- package/docs/guide/quickstart.md +26 -0
- package/docs/plugin/README.md +1 -0
- package/docs/plugin/empty.md +1 -0
- package/package.json +6 -3
- package/packages/id-card-reader-demo/index.ts +9 -0
- package/packages/id-card-reader-demo/src/id-card-reader-demo.vue +142 -0
- package/packages/index.js +29 -25
- package/packages/{ZSEmpty/src/assets → scanner-high-camera-jieyu}/images/img_blank_empty.png +0 -0
- package/packages/scanner-high-camera-jieyu/index.ts +14 -0
- package/packages/scanner-high-camera-jieyu/src/component/scanner-high-camera-component.vue +292 -0
- package/packages/scanner-high-camera-jieyu/src/scanner-high-camera-jieyu.vue +174 -0
- package/packages/{ZSEmpty → zs-empty}/index.ts +9 -9
- package/packages/zs-empty/src/assets/images/img_blank_empty.png +0 -0
- package/packages/{ZSEmpty/src/index.vue → zs-empty/src/zs-empty.vue} +42 -42
- package/public/index.html +6 -0
- package/src/App.vue +6 -23
- package/src/assets/images/reg-developing.png +0 -0
- package/src/components/404.vue +17 -0
- package/src/main.ts +22 -22
- package/src/router/id-card-reader/id-card-reader.ts +19 -0
- package/src/router/index.ts +21 -2
- package/src/router/scan/scan.ts +19 -0
- package/src/views/HomeView.vue +94 -2
- package/src/views/id-card-reader/id-card-reader-page.vue +139 -0
- package/src/views/id-card-reader/model/conatant/id-card-form-attr.ts +31 -0
- package/src/views/id-card-reader/model/vo/id-card.ts +44 -0
- package/src/views/layout/home-layout.vue +72 -0
- package/src/views/layout/model/menu-data.ts +29 -0
- package/src/views/scan/scan-page.vue +56 -0
package/README.md
CHANGED
@@ -1 +1,49 @@
|
|
1
|
-
# unify-external-plugin-platform
|
1
|
+
# unify-external-plugin-platform
|
2
|
+
|
3
|
+
# 目录说明
|
4
|
+
```
|
5
|
+
* unify-external-plugin-platform
|
6
|
+
* node_modules 依赖包
|
7
|
+
* packages 插件组件目录(插件组件大驼峰命名)
|
8
|
+
* ZSEmpty 空组件(demo)
|
9
|
+
* src 插件内容
|
10
|
+
* index.ts 单个插件导出文件,以便单个引入
|
11
|
+
* ......
|
12
|
+
* index.js 整体导出
|
13
|
+
* public
|
14
|
+
* src 业务代码
|
15
|
+
|
16
|
+
```
|
17
|
+
|
18
|
+
# 运行
|
19
|
+
### 文档
|
20
|
+
```shell
|
21
|
+
npm run docs:dev
|
22
|
+
```
|
23
|
+
|
24
|
+
### Demo
|
25
|
+
```shell
|
26
|
+
npm run serve
|
27
|
+
```
|
28
|
+
|
29
|
+
|
30
|
+
# 使用
|
31
|
+
1. 安装
|
32
|
+
```
|
33
|
+
npm i unify-external-plugin-platform
|
34
|
+
```
|
35
|
+
|
36
|
+
3. 引入:
|
37
|
+
```javascript
|
38
|
+
// 在main.js中
|
39
|
+
import unifyExternalPluginPlatform from 'unify-external-plugin-platform';
|
40
|
+
Vue.use(unifyExternalPluginPlatform);
|
41
|
+
```
|
42
|
+
|
43
|
+
3. 使用:
|
44
|
+
```vue
|
45
|
+
<z-s-empty empty-tip="暂无数据组件"></z-s-empty>
|
46
|
+
```
|
47
|
+
|
48
|
+
|
49
|
+
|
@@ -0,0 +1,46 @@
|
|
1
|
+
/**
|
2
|
+
* @author: lvcy
|
3
|
+
* @date: 2022-12-30
|
4
|
+
* @description:config
|
5
|
+
*/
|
6
|
+
module.exports = {
|
7
|
+
// 网站的一些基本配置
|
8
|
+
// base:配置部署站点的基础路径,后续再介绍
|
9
|
+
title: '统一对外插件平台', // 网站的标题
|
10
|
+
description: '统一对外插件平台-测试', // 网站的描述,它将会以 <meta> 标签渲染到当前页面的 HTML 中。
|
11
|
+
head: [
|
12
|
+
['link', { rel: 'icon', href: '/logo.png' }] // 需要被注入到当前页面的 HTML <head> 中的标签
|
13
|
+
],
|
14
|
+
themeConfig: {
|
15
|
+
logo: '/logo.png',
|
16
|
+
nav: [
|
17
|
+
{ text: '首页', link: '/' },
|
18
|
+
{ text: '组件', link: '/guide/installation' },
|
19
|
+
],
|
20
|
+
// 设置自动生成侧边栏
|
21
|
+
sidebar: [
|
22
|
+
{
|
23
|
+
title: '更新日志',
|
24
|
+
path: '/guide/changelog',
|
25
|
+
collapsable: false,
|
26
|
+
sidebarDepth: 0,
|
27
|
+
},
|
28
|
+
{
|
29
|
+
title: '开发指南',
|
30
|
+
collapsable: false,
|
31
|
+
children: [
|
32
|
+
['/guide/installation', '安装'],
|
33
|
+
['/guide/quickstart', '快速上手'],
|
34
|
+
],
|
35
|
+
},
|
36
|
+
{
|
37
|
+
title: '组件',
|
38
|
+
collapsable: false,
|
39
|
+
children: [
|
40
|
+
['/plugin/empty', '空组件']
|
41
|
+
]
|
42
|
+
}
|
43
|
+
],
|
44
|
+
sidebarDepth: 2,
|
45
|
+
}
|
46
|
+
}
|
Binary file
|
package/docs/README.md
ADDED
@@ -0,0 +1,15 @@
|
|
1
|
+
---
|
2
|
+
home: true
|
3
|
+
heroImage: /logo.png
|
4
|
+
actionText: 快速上手 →
|
5
|
+
actionLink: /guide/installation
|
6
|
+
features:
|
7
|
+
- title: 简洁至上
|
8
|
+
details: 以 Markdown 为中心的项目结构,以最少的配置帮助你专注于写作。
|
9
|
+
- title: Vue驱动
|
10
|
+
details: 享受 Vue + webpack 的开发体验,在 Markdown 中使用 Vue 组件,同时可以使用 Vue 来开发自定义主题。
|
11
|
+
- title: 高性能
|
12
|
+
details: VuePress 为每个页面预渲染生成静态的 HTML,同时在页面被加载的时候,将作为 SPA 运行。
|
13
|
+
footer: MIT Licensed | Copyright © 2018-present Evan You
|
14
|
+
---
|
15
|
+
|
@@ -0,0 +1 @@
|
|
1
|
+
### 更新日志
|
@@ -0,0 +1,26 @@
|
|
1
|
+
## 快速上手
|
2
|
+
|
3
|
+
本节将介绍如何在项目中使用 UnifyExternalPluginPlatform。
|
4
|
+
|
5
|
+
### 引入 UnifyExternalPluginPlatform
|
6
|
+
|
7
|
+
你可以引入整个 Element,或是根据需要仅引入部分组件。我们先介绍如何引入完整的 UnifyExternalPluginPlatform。
|
8
|
+
|
9
|
+
#### 完整引入
|
10
|
+
|
11
|
+
在 main.js 中写入以下内容:
|
12
|
+
|
13
|
+
```javascript
|
14
|
+
import Vue from 'vue';
|
15
|
+
import App from './App.vue';
|
16
|
+
import UnifyExternalPluginPlatform from 'unify-external-plugin-platform';
|
17
|
+
|
18
|
+
Vue.use(UnifyExternalPluginPlatform);
|
19
|
+
|
20
|
+
new Vue({
|
21
|
+
el: '#app',
|
22
|
+
render: h => h(App)
|
23
|
+
});
|
24
|
+
```
|
25
|
+
|
26
|
+
以上代码便完成了 UnifyExternalPluginPlatform 的引入。
|
@@ -0,0 +1 @@
|
|
1
|
+
### 统一插件平台
|
@@ -0,0 +1 @@
|
|
1
|
+
### Empty
|
package/package.json
CHANGED
@@ -1,13 +1,15 @@
|
|
1
1
|
{
|
2
2
|
"name": "unify-external-plugin-platform",
|
3
|
-
"version": "0.0.
|
3
|
+
"version": "0.0.2",
|
4
4
|
"description": "统一对外插件平台",
|
5
5
|
"main": "packages/index.js",
|
6
6
|
"author": "Young",
|
7
7
|
"license": "ISC",
|
8
8
|
"scripts": {
|
9
9
|
"serve": "vue-cli-service serve",
|
10
|
-
"build": "vue-cli-service build"
|
10
|
+
"build": "vue-cli-service build",
|
11
|
+
"docs:dev": "vuepress dev docs",
|
12
|
+
"docs:build": "vuepress build docs"
|
11
13
|
},
|
12
14
|
"dependencies": {
|
13
15
|
"core-js": "^3.8.3",
|
@@ -29,6 +31,7 @@
|
|
29
31
|
"sass": "^1.32.7",
|
30
32
|
"sass-loader": "^12.0.0",
|
31
33
|
"typescript": "~4.5.5",
|
32
|
-
"vue-template-compiler": "^2.6.14"
|
34
|
+
"vue-template-compiler": "^2.6.14",
|
35
|
+
"vuepress": "^1.9.7"
|
33
36
|
}
|
34
37
|
}
|
@@ -0,0 +1,142 @@
|
|
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>
|
package/packages/index.js
CHANGED
@@ -1,25 +1,29 @@
|
|
1
|
-
import ZSEmpty from "./
|
2
|
-
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
}
|
20
|
-
|
21
|
-
|
22
|
-
install
|
23
|
-
|
24
|
-
|
25
|
-
|
1
|
+
import ZSEmpty from "./zs-empty";
|
2
|
+
import IdCardReaderDemo from "./id-card-reader-demo";
|
3
|
+
import ScannerHighCameraJieyu from "./scanner-high-camera-jieyu";
|
4
|
+
|
5
|
+
|
6
|
+
// 组件列表
|
7
|
+
const components = [
|
8
|
+
ZSEmpty,
|
9
|
+
IdCardReaderDemo,
|
10
|
+
ScannerHighCameraJieyu
|
11
|
+
];
|
12
|
+
|
13
|
+
// 定义 install 方法,接收 Vue 作为参数。如果使用 use 注册插件,那么所有的组件都会被注册
|
14
|
+
const install = Vue => {
|
15
|
+
// 判断是否安装
|
16
|
+
if (install.installed) return
|
17
|
+
// 遍历注册全局组件
|
18
|
+
components.map(component => Vue.component(component.name, component))
|
19
|
+
}
|
20
|
+
// 判断是否是直接引入文件
|
21
|
+
if (typeof window !== 'undefined' && window.Vue) {
|
22
|
+
install(window.Vue)
|
23
|
+
}
|
24
|
+
export default {
|
25
|
+
// 导出的对象必须具有 install,才能被 Vue.use() 方法安装
|
26
|
+
install,
|
27
|
+
//具体的组件列表
|
28
|
+
...components
|
29
|
+
};
|
package/packages/{ZSEmpty/src/assets → scanner-high-camera-jieyu}/images/img_blank_empty.png
RENAMED
File without changes
|
@@ -0,0 +1,14 @@
|
|
1
|
+
/**
|
2
|
+
* @author: lvcy
|
3
|
+
* @date: 2023-01-09
|
4
|
+
* @description:index
|
5
|
+
*/
|
6
|
+
import ScannerHighCameraJieyu from './src/scanner-high-camera-jieyu.vue';
|
7
|
+
|
8
|
+
// 组件的install方法用于按需引入
|
9
|
+
// @ts-ignore
|
10
|
+
ScannerHighCameraJieyu.install = (Vue) => {
|
11
|
+
Vue.component(ScannerHighCameraJieyu.name, ScannerHighCameraJieyu)
|
12
|
+
};
|
13
|
+
|
14
|
+
export default ScannerHighCameraJieyu;
|