hrp-ui-base 1.0.1 → 1.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/dist/components.cjs +1 -1
- package/dist/components.es.js +4 -4
- package/dist/index.cjs +1 -1
- package/dist/index.es.js +83 -67
- package/dist/style.css +1 -1
- package/package.json +15 -4
- package/packages/approval-process/.eslintrc +7 -0
- package/packages/approval-process/README.md +130 -0
- package/packages/approval-process/index.ts +65 -0
- package/packages/approval-process/package.json +17 -0
- package/packages/approval-process/packages/components/choose-member/BO/departBo.ts +8 -0
- package/packages/approval-process/packages/components/choose-member/BO/memberBo.ts +14 -0
- package/packages/approval-process/packages/components/choose-member/BO/role.svg +1 -0
- package/packages/approval-process/packages/components/choose-member/BO/roleBo.ts +16 -0
- package/packages/approval-process/packages/components/choose-member/index.vue +497 -0
- package/packages/approval-process/packages/components/choose-member/styles/common.scss +134 -0
- package/packages/approval-process/packages/components/comment/assets/avatar.svg +1 -0
- package/packages/approval-process/packages/components/comment/assets/download.svg +4 -0
- package/packages/approval-process/packages/components/comment/assets/mp3.svg +11 -0
- package/packages/approval-process/packages/components/comment/assets/mp4.svg +11 -0
- package/packages/approval-process/packages/components/comment/assets/other.svg +11 -0
- package/packages/approval-process/packages/components/comment/assets/pdf.svg +11 -0
- package/packages/approval-process/packages/components/comment/assets/ppt.svg +11 -0
- package/packages/approval-process/packages/components/comment/assets/preview.svg +4 -0
- package/packages/approval-process/packages/components/comment/assets/remove.png +0 -0
- package/packages/approval-process/packages/components/comment/assets/word.svg +11 -0
- package/packages/approval-process/packages/components/comment/assets/xls.svg +11 -0
- package/packages/approval-process/packages/components/comment/index.vue +843 -0
- package/packages/approval-process/packages/components/comment/modules/previewMp.vue +54 -0
- package/packages/approval-process/packages/components/comment/styles/comment-style.scss +304 -0
- package/packages/approval-process/packages/components/image-cropper/index.vue +202 -0
- package/packages/approval-process/packages/components/sign/index.vue +766 -0
- package/packages/approval-process/packages/components/sign/modules/full-screen-sign.vue +20 -0
- package/packages/approval-process/packages/components/urge-dialog/index.vue +121 -0
- package/packages/approval-process/packages/components/vue-esign/index.vue +289 -0
- package/packages/approval-process/packages/flow/approve-component/approve-success.vue +82 -0
- package/packages/approval-process/packages/flow/approve-component/route-params-error.vue +49 -0
- package/packages/approval-process/packages/flow/approve-component/submit-success.vue +59 -0
- package/packages/approval-process/packages/flow/examine-approve-itr.vue +978 -0
- package/packages/approval-process/packages/flow/examine-approve.vue +1065 -0
- package/packages/approval-process/packages/flow/form-component/associated-approval-form/README.md +38 -0
- package/packages/approval-process/packages/flow/form-component/associated-approval-form/assets/avatar.svg +1 -0
- package/packages/approval-process/packages/flow/form-component/associated-approval-form/index.vue +159 -0
- package/packages/approval-process/packages/flow/form-component/associated-approval-form/modules/associated-approval-form-mobile.vue +297 -0
- package/packages/approval-process/packages/flow/form-component/associated-approval-form/modules/associated-approval-form-pc.vue +314 -0
- package/packages/approval-process/packages/flow/form-component/associated-approval-form/style/curd-area-mobile.scss +110 -0
- package/packages/approval-process/packages/flow/form-component/associated-approval-form/style/curd-area.scss +96 -0
- package/packages/approval-process/packages/flow/form-component/associated-approval-form/style/out-put.scss +48 -0
- package/packages/approval-process/packages/flow/form-component/show-sign.vue +27 -0
- package/packages/approval-process/packages/flow/styles/common.scss +134 -0
- package/packages/approval-process/packages/flow/styles/examine-approve-pc.scss +465 -0
- package/packages/approval-process/packages/flow/styles/examine-approve-phone.scss +293 -0
- package/packages/approval-process/packages/flow/styles/submit-approve-pc.scss +379 -0
- package/packages/approval-process/packages/flow/styles/submit-approve-phone.scss +337 -0
- package/packages/approval-process/packages/flow/submit-approve-itr.vue +623 -0
- package/packages/approval-process/packages/flow/submit-approve.vue +628 -0
- package/packages/approval-process/packages/flow/systemCom/BO/departBo.ts +8 -0
- package/packages/approval-process/packages/flow/systemCom/BO/memberBo.ts +14 -0
- package/packages/approval-process/packages/flow/systemCom/BO/role.svg +1 -0
- package/packages/approval-process/packages/flow/systemCom/BO/roleBo.ts +16 -0
- package/packages/approval-process/packages/flow/systemCom/choose-depart.vue +399 -0
- package/packages/approval-process/packages/flow/systemCom/choose-member-phone.vue +515 -0
- package/packages/approval-process/packages/flow/systemCom/choose-member.vue +565 -0
- package/packages/approval-process/packages/flow/systemCom/choose-role.vue +301 -0
- package/packages/approval-process/packages/styles/common.scss +134 -0
- package/packages/approval-process/packages/styles/flex-common.scss +118 -0
- package/packages/approval-process/packages/styles/flexCommon.scss +73 -0
- package/packages/approval-process/packages/styles/main.css +216 -0
- package/packages/approval-process/packages/styles/router-page.scss +371 -0
- package/packages/approval-process/packages/styles/style-set.ts +207 -0
- package/packages/approval-process/packages/types.d.ts +4 -0
- package/packages/approval-process/packages/utils/base.ts +15 -0
- package/packages/approval-process/packages/utils/crypto.ts +67 -0
- package/packages/approval-process/packages/utils/ddUtils.ts +56 -0
- package/packages/approval-process/packages/utils/debounce.ts +36 -0
- package/packages/approval-process/packages/utils/des.js +1107 -0
- package/packages/approval-process/packages/utils/download.ts +38 -0
- package/packages/approval-process/packages/utils/editor.ts +37 -0
- package/packages/approval-process/packages/utils/getEnv.ts +36 -0
- package/packages/approval-process/packages/utils/os.ts +20 -0
- package/packages/approval-process/packages/utils/path-util.ts +31 -0
- package/packages/approval-process/packages/utils/routerUtil.ts +304 -0
- package/packages/approval-process/packages/utils/string-utils.ts +13 -0
- package/packages/approval-process/packages/utils/throttle.ts +44 -0
- package/packages/approval-process/packages/utils/validate.ts +92 -0
- package/packages/approval-process/packages/utils/ws.ts +218 -0
- package/packages/approval-process/tsconfig.json +72 -0
- package/packages/approval-process/vite.config.ts +56 -0
- package/src/api/bms/flow/FlowCommentController.ts +50 -0
- package/src/api/bms/flow/FlowInstanceController.ts +167 -0
- package/src/api/bms/flow/FlowProcessController.ts +55 -0
- package/src/api/bms/flow/FlowSheetController.ts +27 -0
- package/src/api/bms/flow/FlowSignController.ts +76 -0
- package/src/api/bms/flow/bo/AssociatedApprovalBO.ts +15 -0
- package/src/api/bms/flow/bo/AssociatedApprovalVO.ts +35 -0
- package/src/api/bms/flow/bo/AuditBaseInfo.ts +39 -0
- package/src/api/bms/flow/bo/ButtonVo.ts +7 -0
- package/src/api/bms/flow/bo/DingCallbackBo.ts +13 -0
- package/src/api/bms/flow/bo/FlowCommentBO.ts +12 -0
- package/src/api/bms/flow/bo/FlowCommentVO.ts +23 -0
- package/src/api/bms/flow/bo/FlowInstanceBO.ts +14 -0
- package/src/api/bms/flow/bo/FlowNodeVO.ts +24 -0
- package/src/api/bms/flow/bo/FlowNoticeBO.ts +17 -0
- package/src/api/bms/flow/bo/FlowProcessBO.ts +13 -0
- package/src/api/bms/flow/bo/FlowProcessVO.ts +9 -0
- package/src/api/bms/flow/bo/FlowReplyVO.ts +23 -0
- package/src/api/bms/flow/bo/FlowSheetVO.ts +16 -0
- package/src/api/bms/flow/bo/InstanceBackBO.ts +9 -0
- package/src/api/bms/flow/bo/InstanceNodeBO.ts +13 -0
- package/src/api/bms/flow/bo/InstanceNodeVO.ts +21 -0
- package/src/api/bms/flow/bo/NodeShowVo.ts +19 -0
- package/src/api/bms/flow/bo/ReviewBO.ts +11 -0
- package/src/api/bms/flow/bo/SheetSearchBO.ts +11 -0
- package/src/api/bms/flow/bo/SystemVO.ts +7 -0
- package/src/api/bms/flow/bo/TransmitBO.ts +9 -0
- package/src/api/bms/flow/bo/UrgeFlowBO.ts +7 -0
- package/src/api/bms/flow/bo/UserBaseInfoVo.ts +13 -0
- package/src/api/bms/flow/bo/UserInfoVo.ts +44 -0
- package/src/api/bms/flow/bo/UserResultVo.ts +17 -0
- package/src/api/bms/flow/bo/ValueMapBo.ts +7 -0
- package/src/api/bms/home/HomeController.ts +106 -0
- package/src/api/bms/home/bo/CollectedMenuBo.ts +9 -0
- package/src/api/bms/home/bo/DeptBaseVo.ts +9 -0
- package/src/api/bms/home/bo/DomainVO.ts +13 -0
- package/src/api/bms/home/bo/FunPermission.ts +17 -0
- package/src/api/bms/home/bo/GroupVO.ts +10 -0
- package/src/api/bms/home/bo/HomeMenu.ts +22 -0
- package/src/api/bms/home/bo/HomeMenuVo.ts +11 -0
- package/src/api/bms/home/bo/PersonalizationBo.ts +17 -0
- package/src/api/bms/home/bo/PersonalizationVo.ts +19 -0
- package/src/api/bms/home/bo/PhoneMenu.ts +14 -0
- package/src/api/bms/home/bo/SearchMenuVo.ts +10 -0
- package/src/api/bms/home/bo/UserBaseInfoVo.ts +11 -0
- package/src/api/hrms/dept/bo/DeptBaseVo.ts +6 -0
- package/src/api/hrms/dept/bo/DeptTreeVo.ts +23 -0
- package/src/api/hrms/dept/bo/DeptUserVo.ts +9 -0
- package/src/api/hrms/dept/bo/DeptUsersVo.ts +10 -0
- package/src/api/hrms/dept/bo/DeptVo.ts +19 -0
- package/src/api/hrms/dept/bo/UserBaseInfoVo.ts +8 -0
- package/src/api/hrms/dept/deptController.ts +100 -0
- package/src/api/hrms/role/bo/RoleBaseVo.ts +6 -0
- package/src/api/hrms/role/bo/RoleGroupVo.ts +11 -0
- package/src/api/hrms/role/bo/RoleVo.ts +22 -0
- package/src/api/hrms/role/roleController.ts +19 -0
- package/src/api/hrms/user/bo/UserBaseInfoVo.ts +11 -0
- package/src/api/hrms/user/bo/UserCardVO.ts +14 -0
- package/src/api/hrms/user/bo/UserDeptBO.ts +13 -0
- package/src/api/hrms/user/bo/UserRoleBO.ts +11 -0
- package/src/api/hrms/user/bo/UserVO.ts +23 -0
- package/src/api/hrms/user/userController.ts +86 -0
- package/src/api/work-order-pc/flow/Bo/ValueMapBo.ts +7 -0
- package/src/api/work-order-pc/flow/ItrFlowProcessController.ts +42 -0
- package/src/api/work-order-pc/flow/Vo/FlowNodeVO.ts +24 -0
- package/src/api/work-order-pc/flow/Vo/UserInfoVo.ts +44 -0
- package/src/assets/process/agree.png +0 -0
- package/src/assets/process/defaultAvatar.png +0 -0
- package/src/assets/process/drawer/departManagerJump.png +0 -0
- package/src/assets/process/drawer/manyLevel1close.svg +10 -0
- package/src/assets/process/drawer/manyLevel1open.svg +7 -0
- package/src/assets/process/drawer/manyLevel2close.svg +7 -0
- package/src/assets/process/drawer/manyLevel2open.svg +7 -0
- package/src/assets/process/inProcess.png +0 -0
- package/src/assets/process/manyPeople.png +0 -0
- package/src/assets/process/manyPeople2.png +0 -0
- package/src/assets/process/reject.png +0 -0
- package/src/assets/process/revoke.png +0 -0
- package/src/components/annex-img-upload/index.vue +4 -4
- package/src/components/annex-img-upload/modules/previewMp.vue +1 -1
- package/src/components/annex-upload/index.vue +4 -4
- package/src/components/annex-upload/modules/previewMp.vue +1 -1
- package/src/components/annex-upload-weijian/index.vue +4 -4
- package/src/components/annex-upload-weijian/modules/previewMp.vue +1 -1
- package/src/components/list-search-content/components/search-date-range.vue +1 -1
- package/src/components/list-search-content/components/search-date-time-range.vue +1 -1
- package/src/components/list-search-content/components/search-date.vue +1 -1
- package/src/components/list-search-content/components/search-input-number.vue +1 -1
- package/src/components/list-search-content/components/search-input.vue +1 -1
- package/src/components/list-search-content/components/search-multiple_select.vue +1 -1
- package/src/components/list-search-content/components/search-select.vue +1 -1
- package/src/components/list-search-content/index.vue +6 -6
- package/src/components/list-search-content/modules/add-views-package-dialog.vue +3 -3
- package/src/components/list-search-content/modules/search-condition-area.vue +2 -2
- package/src/components/list-search-content/modules/views-package-manage-dialog.vue +5 -5
- package/src/index.ts +1 -0
- package/src/utils/dd-utils.ts +1 -1
- package/src/utils/get-dict.ts +2 -2
- package/src/utils/permit-utils.ts +2 -2
- package/src/api/bms/dict/bo/TotalDictSearchBO.ts +0 -8
- package/src/api/bms/file/FileExportController.ts +0 -18
- package/src/api/bms/file/bo/FileExportVO.ts +0 -17
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "hrp-ui-base",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.2",
|
|
4
4
|
"description": "HRP 前端公共组件、工具方法和基础样式包",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"sideEffects": [
|
|
@@ -11,6 +11,7 @@
|
|
|
11
11
|
"files": [
|
|
12
12
|
"dist",
|
|
13
13
|
"src",
|
|
14
|
+
"packages",
|
|
14
15
|
"README.md"
|
|
15
16
|
],
|
|
16
17
|
"main": "./dist/index.cjs",
|
|
@@ -19,23 +20,33 @@
|
|
|
19
20
|
"exports": {
|
|
20
21
|
".": {
|
|
21
22
|
"types": "./src/index.ts",
|
|
22
|
-
"import": "./
|
|
23
|
+
"import": "./src/index.ts",
|
|
23
24
|
"require": "./dist/index.cjs"
|
|
24
25
|
},
|
|
25
26
|
"./components": {
|
|
26
27
|
"types": "./src/components.ts",
|
|
27
|
-
"import": "./
|
|
28
|
+
"import": "./src/components.ts",
|
|
28
29
|
"require": "./dist/components.cjs"
|
|
29
30
|
},
|
|
31
|
+
"./components/*": "./src/components/*",
|
|
30
32
|
"./utils": {
|
|
31
33
|
"types": "./src/utils.ts",
|
|
32
|
-
"import": "./
|
|
34
|
+
"import": "./src/utils.ts",
|
|
33
35
|
"require": "./dist/utils.cjs"
|
|
34
36
|
},
|
|
35
37
|
"./utils/*": {
|
|
36
38
|
"types": "./src/utils/*.ts",
|
|
37
39
|
"import": "./src/utils/*.ts"
|
|
38
40
|
},
|
|
41
|
+
"./api/*": {
|
|
42
|
+
"types": "./src/api/*.ts",
|
|
43
|
+
"import": "./src/api/*.ts"
|
|
44
|
+
},
|
|
45
|
+
"./approval-process": {
|
|
46
|
+
"types": "./packages/approval-process/packages/types.d.ts",
|
|
47
|
+
"import": "./packages/approval-process/index.ts"
|
|
48
|
+
},
|
|
49
|
+
"./approval-process/*": "./packages/approval-process/*",
|
|
39
50
|
"./assets/*": "./src/assets/*",
|
|
40
51
|
"./styles/*": "./src/styles/*",
|
|
41
52
|
"./package.json": "./package.json"
|
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
|
|
2
|
+
流程文档
|
|
3
|
+
第一步
|
|
4
|
+
|
|
5
|
+
1. 首先开发业务表单
|
|
6
|
+
2. 然后让后端维护表单
|
|
7
|
+
3. 给后端json 例如(需要用JSON.stringify转成字符串)
|
|
8
|
+
|
|
9
|
+
[{"domType":"SysSelect","multiple":false,"title":"请假类型","require":true,"placeHolder":"请输入...","disabled":false,"refreshProcess":true,"optionList":[{"name":"年假","id":"1","balance":"3","unit":"day"},{"name":"病假","id":"2","balance":"0","unit":"day"},{"name":"事假","id":"3","balance":"0","unit":"day"},{"name":"调休","id":"4","balance":"3","unit":"hour"},{"name":"产假","id":"5","balance":"3","unit":"day"},{"name":"陪产假","id":"6","balance":"3","unit":"day"},{"name":"婚假","id":"7","balance":"3","unit":"day"},{"name":"丧假","id":"8","balance":"3","unit":"day"},{"name":"工伤假","id":"9","balance":"3","unit":"day"}],"type":"String","id":"1","value":"","remark":"","field":"type"},{"domType":"SysDataPicker","multiple":false,"title":"开始时间","require":true,"placeHolder":"请选择...","disabled":false,"refreshProcess":true,"optionList":[ ],"id":"2","value":"","remark":"","field":"startTime","type":"Date"},{"domType":"SysDataPicker","multiple":false,"title":"结束时间","require":true,"placeHolder":"请选择...","disabled":false,"refreshProcess":true,"optionList":[ ],"id":"3","value":"","remark":"","field":"endTime","type":"Date"},{"domType":"SysInput","multiple":false,"title":"时长(分钟)","require":true,"placeHolder":"请输入...","disabled":true,"refreshProcess":false,"optionList":[ ],"id":"4","value":"","remark":"","rule":"${endTime} - ${startTime}","field":"timeLeng","type":"Number"},{"domType":"SysInput","multiple":true,"title":"请假理由","require":true,"placeHolder":"请输入...","disabled":false,"refreshProcess":false,"optionList":[ ],"id":"5","value":"","remark":"","rule":"${endTime} - ${startTime}","field":"reason","type":"String"}]
|
|
10
|
+
|
|
11
|
+
表单唯一凭证: 提交页面的路由,例如 /process/vacation
|
|
12
|
+
4. 由后端维护回调配置
|
|
13
|
+
5. 在 基础设置>基础管理功能>系统配置>流程管理 列表中找到您新增的数据,点击编辑流程,进入流程编辑器,配置流程后,根据提示,配置完成。
|
|
14
|
+
第二步
|
|
15
|
+
● 在 基础设置>基础管理功能>系统配置>流程管理 列表在流程找到您新增的数据,点击编辑流程,进入流程编辑器, 编辑器根据指示,新增节点信息,以及节点信息的配置数据,配置完成后点击左上角按钮 《保存当前流》,保存成功后即可
|
|
16
|
+
第三步
|
|
17
|
+
在你自己的业务模块中引入流程提交组件 组件引用方式如下
|
|
18
|
+
import { xxx } from "approval-process";
|
|
19
|
+
这个插件暴露多个组件
|
|
20
|
+
SubmitApprove 提交审批组件
|
|
21
|
+
ExamineApprove 审批组件
|
|
22
|
+
RouteParamsError 提交审批页面参数错误的显示页面
|
|
23
|
+
SubmitSuccess 提交审批成功的显示页面
|
|
24
|
+
ApproveSuccess 审批成功的显示页面
|
|
25
|
+
AssociatedApprovalForm 关联审批单的组件
|
|
26
|
+
AssociatedApprovalMobile 移动端选择审批单的组件
|
|
27
|
+
AssociatedApprovalPc pc端选择审批单的组件
|
|
28
|
+
|
|
29
|
+
组件具体参数说明:
|
|
30
|
+
ExamineApprove 提交审批组件
|
|
31
|
+
const props = defineProps({
|
|
32
|
+
/**是否可以提交 */
|
|
33
|
+
'canSubmit': {
|
|
34
|
+
type: Boolean,
|
|
35
|
+
required: true,
|
|
36
|
+
default: false
|
|
37
|
+
},
|
|
38
|
+
/**业务表单数据 */
|
|
39
|
+
'sendForm': {
|
|
40
|
+
type: Object as PropType<any>,
|
|
41
|
+
required: false,
|
|
42
|
+
default: () => { return {} }
|
|
43
|
+
},
|
|
44
|
+
/** 当前的流应用id */
|
|
45
|
+
'appId': {
|
|
46
|
+
type: String,
|
|
47
|
+
required: true,
|
|
48
|
+
default: ''
|
|
49
|
+
},
|
|
50
|
+
/**控制loading的传参 */
|
|
51
|
+
'submitLoading': {
|
|
52
|
+
type: Boolean,
|
|
53
|
+
required: true,
|
|
54
|
+
default: false
|
|
55
|
+
},
|
|
56
|
+
/** 发起人的id */
|
|
57
|
+
'promoterId': {
|
|
58
|
+
type: String,
|
|
59
|
+
required: true,
|
|
60
|
+
default: ''
|
|
61
|
+
},
|
|
62
|
+
/**发起人的部门id - 暂未启用 - 等待反馈后开发使用*/
|
|
63
|
+
'promoterDeptId': {
|
|
64
|
+
type: String,
|
|
65
|
+
required: false,
|
|
66
|
+
default: ''
|
|
67
|
+
},
|
|
68
|
+
/** 服务名称 */
|
|
69
|
+
'jobName': {
|
|
70
|
+
type: String,
|
|
71
|
+
required: true,
|
|
72
|
+
default: ''
|
|
73
|
+
},
|
|
74
|
+
/**列表的地址,用来返回列表*/
|
|
75
|
+
listPath: {
|
|
76
|
+
type: String,
|
|
77
|
+
required: true,
|
|
78
|
+
default: ''
|
|
79
|
+
}
|
|
80
|
+
})
|
|
81
|
+
const emits = defineEmits(['validateForm', 'submitProcess','backList'])
|
|
82
|
+
部分重点字段的详细解释
|
|
83
|
+
|
|
84
|
+
1. emit 事件
|
|
85
|
+
a. validateForm事件 这个时间主要是触发表单校验,当表单校验通过后,需要给SubmitApprove组件传递参数canSubmit改为true
|
|
86
|
+
2. props 参数
|
|
87
|
+
a. appId 当前维护表单APP的id
|
|
88
|
+
可以通过 /work-flow/work-flow-app/getAppIdByFormCode 这个接口用window.location.hash.split'#来取
|
|
89
|
+
b. canSubmit 默认传递false,当表单校验通过后需改为true
|
|
90
|
+
c. sendForm 需要传给后端的bo数据
|
|
91
|
+
d. 目前的数据转换我放在的外部页面,以请假为例
|
|
92
|
+
{
|
|
93
|
+
"type": { "type": "String", "value": "" },
|
|
94
|
+
"startTime": { "type": "Date", "value": "" },
|
|
95
|
+
"endTime": { "type": "Date", "value": "" },
|
|
96
|
+
"reason": { "type": "String", "value": "" },
|
|
97
|
+
"timeLeng": { "type": "Number", "value": "" }
|
|
98
|
+
}
|
|
99
|
+
type/startTime/endTime/reason/timeLeng 等是表单字段,需要给每个表单字段说明{"type": "这个字段的数据类型", "value": "这个字段用户所填写的数据"}数据类型type可选值 : String、Array、Number、Double、Date等
|
|
100
|
+
第四步
|
|
101
|
+
建立审批页面,在你自己的审批页面中引入 组件 ExamineApprove ,将你的表单放置在
|
|
102
|
+
组件 ExamineApprove 的默认插槽中
|
|
103
|
+
ExamineApprove 组件接收多个 props 与 emit 事件
|
|
104
|
+
|
|
105
|
+
部分重点的详细解释
|
|
106
|
+
|
|
107
|
+
1. emit 事件
|
|
108
|
+
a. validateForm 事件 这个时间主要是触发表单校验,当表单校验通过后,需要给 SubmitApprove 组件传递参数 canSubmit 改为 true
|
|
109
|
+
2. props 参数
|
|
110
|
+
a. activities
|
|
111
|
+
FlowCrudController.getWorkFlowByFormId 这个接口返回的 nodeShowVoList
|
|
112
|
+
b. taskId
|
|
113
|
+
从路由信息解析出来的 taskId
|
|
114
|
+
c. formId
|
|
115
|
+
从路由信息解析出来的 formId
|
|
116
|
+
d. formBaseInfo
|
|
117
|
+
FlowCrudController.getWorkFlowByFormId 返回的全部数据
|
|
118
|
+
3. 注意事项
|
|
119
|
+
a. 需要判断当前路由是否正确的传递了formId与taskId,如没有则需要加载组件"@/views/oa/process/approve-component/route-params-error.vue"
|
|
120
|
+
b. 由于第一版不支持审批中修改表单数据,所以审批页面表单默认disabled
|
|
121
|
+
第五步
|
|
122
|
+
与后端沟通,并把你的表单审批的路由菜单给到后端,让他配置相对应的卡片/消息通知,以便通过工作通知的形式推送到各个审批节点所对应的审批、抄送、执行人,进行相关审批活动
|
|
123
|
+
其他
|
|
124
|
+
接入事项:
|
|
125
|
+
1. 注意配置与你rule之前的关系,若出现配置禁用该表单项,但是rule校验为必填,这个由于没有自定义表单功能,所以无法自动判断出这种矛盾关系,需要使用者或者开发表单人员自己维护好配置或者rules,不要出现这种自相矛盾的问题,最后导致审批无法发起或者无法审批的问题,
|
|
126
|
+
2. 流组件所触发表单校验是由事件传入,由于父传子事件无法获取父事件的return所以你需要再开辟一个字段canSubmit,当你submitForm触发表单时,如果成功需要canSubmit赋值true,如果失败需要赋值false。
|
|
127
|
+
3. 由于多个审批页面的路由地址是不同的,所以提交/审批相关的我封装成了一个组件,而且由于接口以及功能的相关问题,提交跟审批成为了两个不同的组件,所以也就意味着你的表单页面也被分为了两个,有两个路由地址,提交/新增表单页,查看/审批表单页,同时页面的父层样式也需要你自己定义书写。
|
|
128
|
+
4. 表单提交成功的页面、参数错误、异常终止的页面,是有你自己维护的。在回调页面中,目前我的功能写的都是通用的,当你需要有什么新的业务需求时,比如说页面提交成功需要跳转到什么页面等各类需求
|
|
129
|
+
5. 目前表单数据支持 下拉选择、时间选择(非连续)、输入框、数字输入框、选择部门、选择成员、选择成员移动端、选择角色。文件地址 ~/proocess/systemCom,支持用过~/process/systemCom/index.vue一键引入。组件名大驼峰结构(需去除首单词),当通用组件不够你的审批需求
|
|
130
|
+
6. 测试开发进入-沐华数字化进行测试
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import { type App } from "vue";
|
|
2
|
+
import "./packages/styles/main.css";
|
|
3
|
+
import ExamineApprove from './packages/flow/examine-approve.vue'
|
|
4
|
+
import SubmitApprove from './packages/flow/submit-approve.vue'
|
|
5
|
+
import ApproveSuccess from './packages/flow/approve-component/approve-success.vue'
|
|
6
|
+
import RouteParamsError from './packages/flow/approve-component/route-params-error.vue'
|
|
7
|
+
import SubmitSuccess from './packages/flow/approve-component/submit-success.vue'
|
|
8
|
+
import AssociatedApprovalForm from './packages/flow/form-component/associated-approval-form/index.vue'
|
|
9
|
+
import AssociatedApprovalMobile from './packages/flow/form-component/associated-approval-form/modules/associated-approval-form-mobile.vue'
|
|
10
|
+
import AssociatedApprovalPc from './packages/flow/form-component/associated-approval-form/modules/associated-approval-form-pc.vue'
|
|
11
|
+
import Signature from './packages/components/sign/index.vue'
|
|
12
|
+
import ShowSign from './packages/flow/form-component/show-sign.vue'
|
|
13
|
+
import UrgeDialog from './packages/components/urge-dialog/index.vue'
|
|
14
|
+
/**
|
|
15
|
+
* 这里默认导出一个vue支持的install方法
|
|
16
|
+
* 可以在main.ts中使用以下方式全局导入组件
|
|
17
|
+
*
|
|
18
|
+
* import ViteVue3TsTestFjc from "vite-vue3-ts-test-fjc"
|
|
19
|
+
* .....
|
|
20
|
+
* app.use(ViteVue3TsTestFjc);
|
|
21
|
+
*/
|
|
22
|
+
export default {
|
|
23
|
+
install(app: App) {
|
|
24
|
+
app.component("ExamineApprove", ExamineApprove);
|
|
25
|
+
// 如果还有更多的组件需要注册,可以在这里继续添加
|
|
26
|
+
app.component("SubmitApprove", SubmitApprove);
|
|
27
|
+
app.component("ApproveSuccess", ApproveSuccess);
|
|
28
|
+
app.component("RouteParamsError", RouteParamsError);
|
|
29
|
+
app.component("SubmitSuccess", SubmitSuccess);
|
|
30
|
+
app.component("AssociatedApprovalForm", AssociatedApprovalForm);
|
|
31
|
+
app.component("AssociatedApprovalMobile", AssociatedApprovalMobile);
|
|
32
|
+
app.component("AssociatedApprovalPc", AssociatedApprovalPc);
|
|
33
|
+
app.component("Signature", Signature);
|
|
34
|
+
app.component("ShowSign", ShowSign);
|
|
35
|
+
app.component("UrgeDialog", UrgeDialog);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
/**
|
|
40
|
+
* 这里将组件导出,是为了在单独使用组件时,可以按需引入
|
|
41
|
+
* 为了将来支持类似这样按需使用 import {Vv3Test} from "vite-vue3-ts-test-fjc";
|
|
42
|
+
* 有多少个组件就添加多少个组件
|
|
43
|
+
*/
|
|
44
|
+
export { ExamineApprove, SubmitApprove, ApproveSuccess, RouteParamsError, SubmitSuccess, AssociatedApprovalForm, AssociatedApprovalMobile, AssociatedApprovalPc, Signature, ShowSign, UrgeDialog };
|
|
45
|
+
|
|
46
|
+
|
|
47
|
+
|
|
48
|
+
/**
|
|
49
|
+
* 这里是重点,需要将这些组件在ts中声明为全局组件;
|
|
50
|
+
*/
|
|
51
|
+
declare module "vue" {
|
|
52
|
+
export interface GlobalComponents {
|
|
53
|
+
ExamineApprove: typeof ExamineApprove,
|
|
54
|
+
SubmitApprove: typeof SubmitApprove,
|
|
55
|
+
ApproveSuccess: typeof ApproveSuccess,
|
|
56
|
+
RouteParamsError: typeof RouteParamsError,
|
|
57
|
+
SubmitSuccess: typeof SubmitSuccess,
|
|
58
|
+
AssociatedApprovalForm: typeof AssociatedApprovalForm,
|
|
59
|
+
AssociatedApprovalMobile: typeof AssociatedApprovalMobile,
|
|
60
|
+
AssociatedApprovalPc: typeof AssociatedApprovalPc,
|
|
61
|
+
Signature: typeof Signature,
|
|
62
|
+
ShowSign: typeof ShowSign,
|
|
63
|
+
UrgeDialog: typeof UrgeDialog,
|
|
64
|
+
}
|
|
65
|
+
}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "approval-process",
|
|
3
|
+
"private": true,
|
|
4
|
+
"version": "1.0.0",
|
|
5
|
+
"main": "index.ts",
|
|
6
|
+
"types": "packages/types.d.ts",
|
|
7
|
+
"scripts": {
|
|
8
|
+
"test": "echo \"Error: no test specified\" && exit 1"
|
|
9
|
+
},
|
|
10
|
+
"dependencies": {},
|
|
11
|
+
"devDependencies": {},
|
|
12
|
+
"module": "index.ts",
|
|
13
|
+
"peerDependencies": {
|
|
14
|
+
"hrp-ui-base": "^1.0.0",
|
|
15
|
+
"vue": "^3.0.0"
|
|
16
|
+
}
|
|
17
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export interface userBo {
|
|
2
|
+
userId: string;
|
|
3
|
+
userName: string;
|
|
4
|
+
avatar: string;
|
|
5
|
+
roleName: string;
|
|
6
|
+
}
|
|
7
|
+
export interface departBo {
|
|
8
|
+
deptId: string;
|
|
9
|
+
deptName: string;
|
|
10
|
+
}
|
|
11
|
+
export interface nameForSearchBo {
|
|
12
|
+
name: string;
|
|
13
|
+
id: string;
|
|
14
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg t="1724230585754" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="4282" width="200" height="200" xmlns:xlink="http://www.w3.org/1999/xlink"><path d="M486.881882 602.834824v80.353882a240.941176 240.941176 0 0 0-240.941176 240.941176H165.647059a321.234824 321.234824 0 0 1 321.234823-321.295058z m0-40.116706c-133.12 0-240.941176-107.821176-240.941176-240.941177s107.821176-240.941176 240.941176-240.941176 240.941176 107.821176 240.941177 240.941176-107.821176 240.941176-240.941177 240.941177z m0-80.353883a160.587294 160.587294 0 1 0 0-321.234823 160.587294 160.587294 0 1 0 0 321.234823z m104.207059 313.705412a140.950588 140.950588 0 0 1 0-65.174588l-39.815529-23.009883 40.176941-69.511529 39.755294 23.009882c16.022588-15.179294 35.358118-26.322824 56.500706-32.647529v-45.959529h80.293647v45.959529c21.383529 6.384941 40.658824 17.709176 56.440471 32.647529l39.755294-23.009882 40.237176 69.511529-39.875765 23.009883c5.12 21.443765 5.12 43.730824 0 65.174588l39.875765 23.009882-40.176941 69.51153-39.815529-23.009883a140.348235 140.348235 0 0 1-56.440471 32.64753v45.959529h-80.293647v-45.959529a140.348235 140.348235 0 0 1-56.440471-32.64753l-39.815529 23.009883-40.176941-69.51153 39.815529-23.009882z m136.734118 27.648a60.235294 60.235294 0 1 0 0-120.470588 60.235294 60.235294 0 0 0 0 120.470588z" fill="#8C8C8C" p-id="4283"></path></svg>
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
export interface roleBo {
|
|
2
|
+
groupId: string;
|
|
3
|
+
groupName: string;
|
|
4
|
+
roleId: string;
|
|
5
|
+
roleName: string;
|
|
6
|
+
roleVoList: roleItemBo[];
|
|
7
|
+
}
|
|
8
|
+
export interface roleOldBo {
|
|
9
|
+
groupId: string;
|
|
10
|
+
groupName: string;
|
|
11
|
+
roleVoList: roleItemBo[];
|
|
12
|
+
}
|
|
13
|
+
export interface roleItemBo {
|
|
14
|
+
roleId: string;
|
|
15
|
+
roleName: string;
|
|
16
|
+
}
|