cnhis-design-vue 3.1.47-beta.13 → 3.1.47-beta.15

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 (38) hide show
  1. package/README.md +87 -87
  2. package/es/components/bpmn-workflow/src/BpmnWorkflow.d.ts +0 -0
  3. package/es/components/bpmn-workflow/types/BpmnViewer.d.ts +1 -0
  4. package/es/components/bpmn-workflow/types/ModelingModule.d.ts +1 -0
  5. package/es/components/bpmn-workflow/types/MoveCanvasModule.d.ts +1 -0
  6. package/es/components/fabric-chart/src/hooks/birthProcess/useBirthProcess.js +1 -1
  7. package/es/components/fabric-chart/src/hooks/surgicalAnesthesia/index.d.ts +1 -0
  8. package/es/components/fabric-chart/src/hooks/surgicalAnesthesia/index.js +1 -1
  9. package/es/components/fabric-chart/src/hooks/surgicalAnesthesia/useLeft.d.ts +4 -0
  10. package/es/components/fabric-chart/src/hooks/surgicalAnesthesia/useLeft.js +1 -0
  11. package/es/components/fabric-chart/src/hooks/surgicalAnesthesia/useSurgicalAnesthesiaChart.js +1 -1
  12. package/es/components/fabric-chart/src/utils/index.d.ts +7 -0
  13. package/es/components/fabric-chart/src/utils/index.js +1 -1
  14. package/es/components/iho-table/src/hooks/useColumnConfigAdaptor.js +1 -1
  15. package/es/components/scale-view/src/ScaleView.vue2.js +1 -1
  16. package/es/components/select-label/src/LabelFormContent.vue2.js +1 -1
  17. package/es/components/select-person/src/SearchMultiple.vue.d.ts +0 -6
  18. package/es/components/shortcut-provider/src/hooks/useShortcuts.js +1 -1
  19. package/es/components/shortcut-provider/src/types/index.d.ts +1 -1
  20. package/es/components/table-export-field/src/components/ExportModal.vue.d.ts +3 -0
  21. package/es/env.d.ts +25 -25
  22. package/es/shared/assets/img/failure.png.js +1 -1
  23. package/es/shared/assets/img/no-permission.png.js +1 -1
  24. package/es/shared/assets/img/nodata.png.js +1 -1
  25. package/es/shared/assets/img/notfound.png.js +1 -1
  26. package/es/shared/assets/img/qr.png.js +1 -1
  27. package/es/shared/assets/img/success.png.js +1 -1
  28. package/es/shared/assets/img/video.png.js +1 -1
  29. package/es/shared/assets/img/video_default_cover.png.js +1 -1
  30. package/es/shared/assets/img/xb_big.png.js +1 -1
  31. package/es/shared/assets/img/xb_small.png.js +1 -1
  32. package/es/shared/components/VueDraggable/src/vuedraggable.d.ts +86 -0
  33. package/es/shared/package.json.js +1 -1
  34. package/es/shared/utils/fabricjs/index.d.ts +6823 -0
  35. package/es/shared/utils/tapable/index.d.ts +139 -0
  36. package/es/shared/utils/tapableLess.d.ts +28 -0
  37. package/es/shared/utils/tapableLess.js +1 -0
  38. package/package.json +2 -2
package/README.md CHANGED
@@ -1,87 +1,87 @@
1
- # 安装
2
-
3
- ```shell
4
- npm i cnhis-design-vue@[版本号]
5
- # or
6
- yarn add cnhis-design-vue@[版本号] #推荐
7
- ```
8
-
9
- ## 1.全局引入
10
-
11
- ```typescript
12
- // main.ts
13
- import { createApp } from 'vue';
14
- import App from './App.vue';
15
- import 'cnhis-design-vue/es/packages/index.css';
16
- import cui from 'cnhis-design-vue';
17
-
18
- const app = createApp(App);
19
- app.use(cui).mount('#app');
20
- ```
21
-
22
- ## 2. 按需引入
23
-
24
- 组件现在支持了自动按需引入, 但是样式文件需要额外的处理
25
-
26
- ### 2.1 样式处理方式1 (按需引入样式)
27
-
28
- ```shell
29
- # 安装自动导入样式的插件
30
- npm i -d vite-plugin-style-import
31
- ```
32
-
33
- ```typescript
34
- // vite.config.ts
35
- import { defineConfig } from 'vite';
36
- import { createStyleImportPlugin } from 'vite-plugin-style-import';
37
-
38
- export default defineConfig({
39
- plugins: [
40
- // ...otherPlugins
41
- createStyleImportPlugin({
42
- libs: [
43
- {
44
- libraryName: 'cnhis-design-vue',
45
- esModule: true,
46
- ensureStyleFile: true,
47
- resolveStyle: name => {
48
- return `cnhis-design-vue/es/components/${ name.slice(2) }/style/index.css`;
49
- }
50
- }
51
- ]
52
- })
53
- ]
54
- });
55
- ```
56
-
57
- ### 2.2 样式处理方式2 (全局引入样式)
58
-
59
- ```typescript
60
- // main.ts
61
- import 'cnhis-design-vue/es/components/index.css';
62
- ```
63
-
64
- ## 3.FAQ
65
-
66
- ### 3.1 项目打包后样式丢失
67
-
68
- 处理方法, 将 cnhis-design-vue 从 vendor 包中移除 (没有出现此问题则不需要)
69
-
70
- ```typescript
71
- // vite.config.ts
72
- import { defineConfig } from 'vite';
73
-
74
- export default defineConfig({
75
- build: {
76
- rollupOptions: {
77
- // ..otherOptions
78
- output: {
79
- dir: './dist',
80
- manualChunks: {
81
- 'cnhis-vendor': ['cnhis-design-vue']
82
- }
83
- }
84
- }
85
- }
86
- });
87
- ```
1
+ # 安装
2
+
3
+ ```shell
4
+ npm i cnhis-design-vue@[版本号]
5
+ # or
6
+ yarn add cnhis-design-vue@[版本号] #推荐
7
+ ```
8
+
9
+ ## 1.全局引入
10
+
11
+ ```typescript
12
+ // main.ts
13
+ import { createApp } from 'vue';
14
+ import App from './App.vue';
15
+ import 'cnhis-design-vue/es/packages/index.css';
16
+ import cui from 'cnhis-design-vue';
17
+
18
+ const app = createApp(App);
19
+ app.use(cui).mount('#app');
20
+ ```
21
+
22
+ ## 2. 按需引入
23
+
24
+ 组件现在支持了自动按需引入, 但是样式文件需要额外的处理
25
+
26
+ ### 2.1 样式处理方式1 (按需引入样式)
27
+
28
+ ```shell
29
+ # 安装自动导入样式的插件
30
+ npm i -d vite-plugin-style-import
31
+ ```
32
+
33
+ ```typescript
34
+ // vite.config.ts
35
+ import { defineConfig } from 'vite';
36
+ import { createStyleImportPlugin } from 'vite-plugin-style-import';
37
+
38
+ export default defineConfig({
39
+ plugins: [
40
+ // ...otherPlugins
41
+ createStyleImportPlugin({
42
+ libs: [
43
+ {
44
+ libraryName: 'cnhis-design-vue',
45
+ esModule: true,
46
+ ensureStyleFile: true,
47
+ resolveStyle: name => {
48
+ return `cnhis-design-vue/es/components/${ name.slice(2) }/style/index.css`;
49
+ }
50
+ }
51
+ ]
52
+ })
53
+ ]
54
+ });
55
+ ```
56
+
57
+ ### 2.2 样式处理方式2 (全局引入样式)
58
+
59
+ ```typescript
60
+ // main.ts
61
+ import 'cnhis-design-vue/es/components/index.css';
62
+ ```
63
+
64
+ ## 3.FAQ
65
+
66
+ ### 3.1 项目打包后样式丢失
67
+
68
+ 处理方法, 将 cnhis-design-vue 从 vendor 包中移除 (没有出现此问题则不需要)
69
+
70
+ ```typescript
71
+ // vite.config.ts
72
+ import { defineConfig } from 'vite';
73
+
74
+ export default defineConfig({
75
+ build: {
76
+ rollupOptions: {
77
+ // ..otherOptions
78
+ output: {
79
+ dir: './dist',
80
+ manualChunks: {
81
+ 'cnhis-vendor': ['cnhis-design-vue']
82
+ }
83
+ }
84
+ }
85
+ }
86
+ });
87
+ ```
@@ -0,0 +1 @@
1
+ declare module 'bpmn-js/lib/Viewer';
@@ -0,0 +1 @@
1
+ declare module 'bpmn-js/lib/features/modeling';
@@ -0,0 +1 @@
1
+ declare module 'diagram-js/lib/navigation/movecanvas';
@@ -1 +1 @@
1
- import{fabric as t}from"../../../../../shared/utils/fabricjs/index.js";import{drawLine as e,drawArrow as n,drawText as o,defaultTextStyle as i,drawPoint as r,defaultStyle as l,defaultRectStyle as s}from"../useDraw.js";import{useGrid as a}from"../useGrid.js";import{useBirthProcessCumputedPoint as u}from"../useCumputedPoint.js";import"@vueuse/core";import{getScaleInfo as c,drawScaleNumber as f,drawScaleLine as d}from"../useScaleColumn.js";import{useCommon as p}from"../useCommon.js";import"vue";import{getIndex as h,isEffectiveNode as g,getTime as v}from"../../utils/index.js";import"../temperature/useShadow.js";import{cloneDeep as m}from"lodash-es";import{format as y}from"date-fns";function k(k,w,x,b,j){const{cumputedX:S,cumputedY:C,getXValue:T,getYValue:M}=u(w),{getEqualXTypes:P,handleAddPrevent:E}=p(k,x),{xAxis:G,grid:L,originX:Y,originY:X,xCellWidth:A,endY:H,startTime:I,leftAddAreaWidth:O,leftScales:W,rightScales:V,yCellHeight:D,endX:N,scaleValues:R,canvasWidth:$,borderStyle:B,rightAddAreaWidth:F,event:q,originYCervix:z,other:J,canvasHeight:K}=w,Q=m(R),U=new Set;function Z(){Q.filter((t=>t.show)).forEach(((t,l)=>{var s;const a=[],u=[],c=[];null==(s=t.data)||s.forEach(((s,f)=>{!function(s,f,d){let p,h;const{pointAttr:g={},lineAttr:v={},title:m="",key:y,type:j="circle",childbirthStyle:S={}}=t,C=t.data[d+1],P=ot(C,t);if(s&&P&&!f.breakpoint)h=e([...s,...P],{...v});else if(s&&!P&&!f.breakpoint){const n=ot(C,t);h=n?e([...s,...n],{...v}):null}let E,G;if(f.childbirth){const t=s[1]+D;E=n([s[0],s[1],t],S),c.push(E),G=o([s[0]+A/2,t-D/2],{value:String(f.childbirth),...i,originX:"left",originY:"center",...S}),c.push(G)}const L=u[d-1],Y={origin:{data:f,title:m,key:y||"",dataIndex:l,index:d},leftLine:L,rightLine:h,arrowGroup:E,arrowGroupText:G,...g,...w.event.hovered?w.event.evented?{selectable:!0}:{selectable:!0,lockMovementX:!0,lockMovementY:!0}:w.event};L?p=r(j,{left:L.get("x2"),top:L.get("y2"),...Y}):s&&(Y.leftLine=null,p=r(j,{left:s[0],top:s[1],...Y}));u.push(h),p&&(!function(t){q.hovered&&(t.on("mouseover",(()=>{nt(t,"hover")})),t.on("mouseout",(()=>{b.show=!1})));if(t.lockMovementX&&t.lockMovementY)return;t.on("moving",(()=>{et(t),function(t){var e,n,o,i;null==(e=t.leftLine)||e.setCoords().set({x2:t.left,y2:t.top}),null==(n=t.rightLine)||n.setCoords().set({x1:t.left,y1:t.top}),null==(o=t.arrowGroup)||o.setCoords().set({left:t.left,top:t.top}),null==(i=t.arrowGroupText)||i.setCoords().set({left:t.left+A/2,top:t.top+D/2})}(t),q.hovered&&nt(t)})),t.on("mouseup",(e=>{if(b.show=!1,1===e.button){const{key:e}=t.origin,n={...t.origin,data:{...t.origin.data,time:T(t.left),value:M(e,t.top)}};k.value.discardActiveObject(),x("change",n),_(n,"change")}}))}(p),a.push(p),U.add(p))}(ot(s,t),s,f)})),Promise.all(a).then((t=>{const e=u.filter((t=>t));let n=null;t=t.filter((t=>(t&&n&&(n.nextPoint=t,t.prevPoint=n),n=t||n,t))),Promise.all(c).then((n=>{k.value.add(...e,...t,...n),t.forEach((t=>{null==t||t.bringToFront()}))}))}))}))}function _(t,e="add"){const{dataIndex:n,data:o,index:i,key:r}=t,l=Q.find((t=>t.key===r));switch(e){case"remove":l.data.splice(i,1);break;case"change":l.data[i]=o;break;default:{const t=h(o.time,l.data);l.data.splice(t,0,o);break}}tt()}function tt(){var t;U.size&&(null==(t=k.value)||t.remove(...function(t){const e=[];return t.forEach((t=>{t&&e.push(t),(null==t?void 0:t.leftLine)&&e.push(null==t?void 0:t.leftLine),(null==t?void 0:t.rightLine)&&e.push(null==t?void 0:t.rightLine),(null==t?void 0:t.arrowGroup)&&e.push(null==t?void 0:t.arrowGroup),(null==t?void 0:t.arrowGroupText)&&e.push(null==t?void 0:t.arrowGroupText)})),e}([...U]))),U.clear(),Z()}function et(t){const e=t.prevPoint?t.prevPoint.left:Y,n=t.nextPoint?t.nextPoint.left:N;t.setCoords(),["cervix","fetalPresentation"].includes(t.origin.key)&&t.top<z&&t.set("top",z),t.top<X&&t.set("top",X),t.top>H&&t.set("top",H),t.left<e&&t.set("left",e),t.left>n&&t.set("left",n)}function nt(t,e="moving"){const{title:n,key:o,data:i}=t.origin;b.point={x:t.left,y:t.top},b.list=[`${n} ${"hover"===e?i.value:M(o,t.top)}`,`时间 ${T(t.left).slice(-5)}`],b.show=!0}function ot(t,e){if(g(t)&&function(t){const e=I+864e5,n=v(t);return n>=I&&n<=e}(t.time)){const n=S(t.time),o=C(e.key,e.range,t.value);return[n,o<X?X:o>H?H:o]}}function it(t,e){return t+1>e[1]?e[0]:t+1}return a(k,w),function(){const e=new t.Rect({...B,width:$-O-F-1,height:H-1,left:O,top:0,fill:"transparent"});k.value.add(e)}(),function(){function e(e,n="left"){let r="left"===n?O:N;e.forEach(((e,n)=>{const{range:a,spaceValue:u,width:p,title:h,titleStyle:g,key:v,position:m="center",spaceGridNumber:y=1,showNumber:w,showMaxMinNumber:x}=e,b=[],j=[],S=r+p/2,C=function(t,e){const n=[],[o,i]=t;for(let t=o;e>0?t<=i:t>=i;t+=e)n.push(t);return n}(a,u),T=C.length;C.forEach(((t,n)=>{const{lineXMain:o,lineXSub:i,textLeft:l}=c(m,r,p),s=H-n*D*y,a=0===n?H-8:n!==C.length-1||X||z&&"FHR"!==v?s:X+8;!w||(0===n||n===T-1)&&!x||b.push(f(String(t),e,l,a)),j.push(...d(e,n,o,i,s,D,X,T))}));const M=new t.Rect({...s,strokeWidth:.5,width:p,height:H,left:S,top:H/2}),P=o([S,X>0?X-D/2:D/2],{value:String(h),...i,...g}),E=new t.Group([...j,...b,M,...P?[P]:[]],{objectCaching:!1,...l});k.value.add(E),E.sendToBack(),r+=p}))}e(W),e(V,"right")}(),function(){const{show:e,startTime:n,range:r=[0,23],position:s="top",style:a}=G.time,{show:u,range:c=[0,23],position:f,style:d}=G.processTime;if(e||u){const p=[],h=[],g=[],v=[],m=Y+A/2,y=D/2;for(let t=0;t<L.mainXCell;t++){if(e){const e=0===t?+n.slice(11,13):it(p.at(-1),r);p.push(e);const l="top"===s?X-y:H+y;g.push(o([m+t*A,l],{value:String(e),...i,...a||{}}))}if(u){const e=0===t?c[0]:h.at(-1)+1;h.push(e);const n="top"===f?y:K-y;v.push(o([m+t*A,n],{value:String(e),...i,...d||{}}))}}const w=new t.Group([...g,...v],{objectCaching:!1,...l});k.value.add(w),k.value.sendToBack(w)}}(),function(){var t;const n=Object.values(J),o=[],i={},r=Q.find((t=>"cervix"===t.key&&t.show)),l=null==(t=null==r?void 0:r.data)?void 0:t.find((t=>3==+t.value));function s(t,e){const{key:n,range:o}=r||{},i=C(n,o,10),l=[0,e],s=[-e/t,0],a=[(H-i-e)/t,H-i],u=[N-Y,t*(N-Y)+e];let c=[],f=[];function d([n,o]){return Math.abs(o-t*n-e)<=1}function p([t,e]){const[n,o]=[...h([t,e])];return n>=Y&&n<=N&&o>=i&&o<=H}function h([t,e]){return[Y+t,H-e]}return d(l)&&p(l)&&(c=h(l)),d(s)&&p(s)&&(c=h(s)),d(a)&&p(a)&&(f=h(a)),d(u)&&p(u)&&(f=h(u)),[...c,...f]}n.forEach((t=>{if(!t.show)return;const{key:n}=t;switch(n){case"fetalPresentation":{const{range:i,show:r}=Q.find((t=>t.key===n));if(r){const r=C(n,i,0);o.push(e([Y,r,N,r],{...t}))}break}case"alert":if(l){const{key:n,range:a}=r||{},u=216e5,c={time:y(new Date(v(l.time)+u),"yyyy-MM-dd HH:mm"),value:10},[f,d]=[S(l.time)-Y,H-C(n,a,l.value)],[p,h]=[S(c.time)-Y,H-C(n,a,c.value)],g=(h-d)/(p-f),m=d-f*g,k=s(g,m);k.length>0&&(o.push(e(k,{...t})),Object.assign(i,{k:g,b:m}))}break;case"handling":if(l){const{k:n,b:r}=i,a=144e5,u=s(n,r-(S(y(new Date(v(l.time)+a),"yyyy-MM-dd HH:mm"))-S(l.time))*n);u.length>0&&o.push(e(u,{...t}))}}})),k.value.add(...o)}(),Z(),function(){function t(t,e){const n=Q.findIndex((e=>e.key===t.key));return{renderItem:()=>t.title,origin:{title:t.title,unit:t.unit,dataIndex:n,key:t.key},pointer:e}}w.event.evented&&k.value.on("mouse:up",(e=>{if(3===e.button){const{x:n=0,y:o=0}=e.pointer||{};n>=Y&&n<=N&&o>=X&&o<=H&&(j.point={x:n,y:o},j.show=!0,e.target?(j.target=e.target,j.list=["删除节点"],k.value.forEachObject((t=>{t.origin&&t.left===e.target.left&&t.top===e.target.top&&j.list.push({renderItem:()=>t.origin.title,origin:{...t.origin},mode:"remove",pointer:e.pointer})}))):(j.target=null,j.list=["新增节点"],Q.filter((t=>t.show)).forEach((i=>{if(!P(n,"key",A).includes(i.key)){if(["cervix","fetalPresentation"].includes(i.key)&&o<z)return;j.list.push(t(i,e.pointer))}})),1===j.list.length&&(j.show=!1,E("repeat"),console.log("当前时间段内无可新增节点"))))}}))}(),function(){const e=$-F/2;function n(e,n){if(!e.length)return;let l=X;const s=[];e.forEach((e=>{const o=e.title.split("").join("\n"),a=R.findIndex((t=>t.key===e.key)),u=new t.Text(String(o),{...i,...e.titleStyle||{},originY:"top",left:n,top:l,lineHeight:1}),c=r(e.type,{left:n,top:l+u.height+3,...e.pointAttr,originY:"top",origin:{title:e.title,unit:e.unit,type:e.type,dataIndex:a,key:e.key,isMenu:!0},originLeft:n,originTop:l+u.height+3,...w.event});l+=u.height+c.height+15,function(t){function e(t){const{left:e,top:n}=t;return e>=Y&&e<=N&&n>=X&&n<=H}t.on("moving",(()=>{t.set("originY","center"),e(t)?(et(t),nt(t)):b.show=!1})),t.on("mouseup:before",(n=>{if(b.show=!1,0===n.e.button&&e(t))if(P(t.left,"key",A).includes(t.origin.key))E("repeat");else{const e={data:{time:T(t.left),value:M(t.origin.key,t.top)},...t.origin};x("add",e),_(e)}!function(t){t.setCoords().set({originY:"top",left:t.originLeft,top:t.originTop})}(t)}))}(c),s.push(u,c)})),o(s),k.value.add(...s)}function o(t){const e=t.at(-1),n=(H-X)/2,o=(e.height+e.top-X)/2;t.forEach((t=>{const e=t.top+n-o;t.set({top:e,originTop:e})}))}n(W,O/2),n(V,e)}(),{clickMenu:function({item:t,target:e}){const n={...t.origin};"remove"===t.mode?(x("remove",n),_(n,"remove")):(Object.assign(n,{data:{time:T(t.pointer.x),value:M(t.origin.key,t.pointer.y)}}),x("add",n),_(n))},redrawPoints:tt}}export{k as useBirthProcess};
1
+ import{fabric as t}from"../../../../../shared/utils/fabricjs/index.js";import{drawLine as e,drawArrow as n,drawText as o,defaultTextStyle as i,drawPoint as r,defaultStyle as l,defaultRectStyle as s}from"../useDraw.js";import{useGrid as a}from"../useGrid.js";import{useBirthProcessCumputedPoint as u}from"../useCumputedPoint.js";import"@vueuse/core";import{getScaleInfo as c,drawScaleNumber as f,drawScaleLine as d}from"../useScaleColumn.js";import{useCommon as p}from"../useCommon.js";import"vue";import{getIndex as h,isEffectiveNode as g,getTime as v,getScaleNumberList as m}from"../../utils/index.js";import"../temperature/useShadow.js";import{cloneDeep as y}from"lodash-es";import{format as k}from"date-fns";function w(w,x,b,j,S){const{cumputedX:C,cumputedY:T,getXValue:M,getYValue:P}=u(x),{getEqualXTypes:E,handleAddPrevent:G}=p(w,b),{xAxis:L,grid:Y,originX:X,originY:A,xCellWidth:H,endY:I,startTime:O,leftAddAreaWidth:W,leftScales:V,rightScales:D,yCellHeight:N,endX:R,scaleValues:$,canvasWidth:B,borderStyle:F,rightAddAreaWidth:q,event:z,originYCervix:J,other:K,canvasHeight:Q}=x,U=y($),Z=new Set;function _(){U.filter((t=>t.show)).forEach(((t,l)=>{var s;const a=[],u=[],c=[];null==(s=t.data)||s.forEach(((s,f)=>{!function(s,f,d){let p,h;const{pointAttr:g={},lineAttr:v={},title:m="",key:y,type:k="circle",childbirthStyle:S={}}=t,C=t.data[d+1],T=it(C,t);if(s&&T&&!f.breakpoint)h=e([...s,...T],{...v});else if(s&&!T&&!f.breakpoint){const n=it(C,t);h=n?e([...s,...n],{...v}):null}let E,G;if(f.childbirth){const t=s[1]+N;E=n([s[0],s[1],t],S),c.push(E),G=o([s[0]+H/2,t-N/2],{value:String(f.childbirth),...i,originX:"left",originY:"center",...S}),c.push(G)}const L=u[d-1],Y={origin:{data:f,title:m,key:y||"",dataIndex:l,index:d},leftLine:L,rightLine:h,arrowGroup:E,arrowGroupText:G,...g,...x.event.hovered?x.event.evented?{selectable:!0}:{selectable:!0,lockMovementX:!0,lockMovementY:!0}:x.event};L?p=r(k,{left:L.get("x2"),top:L.get("y2"),...Y}):s&&(Y.leftLine=null,p=r(k,{left:s[0],top:s[1],...Y}));u.push(h),p&&(!function(t){z.hovered&&(t.on("mouseover",(()=>{ot(t,"hover")})),t.on("mouseout",(()=>{j.show=!1})));if(t.lockMovementX&&t.lockMovementY)return;t.on("moving",(()=>{nt(t),function(t){var e,n,o,i;null==(e=t.leftLine)||e.setCoords().set({x2:t.left,y2:t.top}),null==(n=t.rightLine)||n.setCoords().set({x1:t.left,y1:t.top}),null==(o=t.arrowGroup)||o.setCoords().set({left:t.left,top:t.top}),null==(i=t.arrowGroupText)||i.setCoords().set({left:t.left+H/2,top:t.top+N/2})}(t),z.hovered&&ot(t)})),t.on("mouseup",(e=>{if(j.show=!1,1===e.button){const{key:e}=t.origin,n={...t.origin,data:{...t.origin.data,time:M(t.left),value:P(e,t.top)}};w.value.discardActiveObject(),b("change",n),tt(n,"change")}}))}(p),a.push(p),Z.add(p))}(it(s,t),s,f)})),Promise.all(a).then((t=>{const e=u.filter((t=>t));let n=null;t=t.filter((t=>(t&&n&&(n.nextPoint=t,t.prevPoint=n),n=t||n,t))),Promise.all(c).then((n=>{w.value.add(...e,...t,...n),t.forEach((t=>{null==t||t.bringToFront()}))}))}))}))}function tt(t,e="add"){const{dataIndex:n,data:o,index:i,key:r}=t,l=U.find((t=>t.key===r));switch(e){case"remove":l.data.splice(i,1);break;case"change":l.data[i]=o;break;default:{const t=h(o.time,l.data);l.data.splice(t,0,o);break}}et()}function et(){var t;Z.size&&(null==(t=w.value)||t.remove(...function(t){const e=[];return t.forEach((t=>{t&&e.push(t),(null==t?void 0:t.leftLine)&&e.push(null==t?void 0:t.leftLine),(null==t?void 0:t.rightLine)&&e.push(null==t?void 0:t.rightLine),(null==t?void 0:t.arrowGroup)&&e.push(null==t?void 0:t.arrowGroup),(null==t?void 0:t.arrowGroupText)&&e.push(null==t?void 0:t.arrowGroupText)})),e}([...Z]))),Z.clear(),_()}function nt(t){const e=t.prevPoint?t.prevPoint.left:X,n=t.nextPoint?t.nextPoint.left:R;t.setCoords(),["cervix","fetalPresentation"].includes(t.origin.key)&&t.top<J&&t.set("top",J),t.top<A&&t.set("top",A),t.top>I&&t.set("top",I),t.left<e&&t.set("left",e),t.left>n&&t.set("left",n)}function ot(t,e="moving"){const{title:n,key:o,data:i}=t.origin;j.point={x:t.left,y:t.top},j.list=[`${n} ${"hover"===e?i.value:P(o,t.top)}`,`时间 ${M(t.left).slice(-5)}`],j.show=!0}function it(t,e){if(g(t)&&function(t){const e=O+864e5,n=v(t);return n>=O&&n<=e}(t.time)){const n=C(t.time),o=T(e.key,e.range,t.value);return[n,o<A?A:o>I?I:o]}}function rt(t,e){return t+1>e[1]?e[0]:t+1}return a(w,x),function(){const e=new t.Rect({...F,width:B-W-q-1,height:I-1,left:W,top:0,fill:"transparent"});w.value.add(e)}(),function(){function e(e,n="left"){let r="left"===n?W:R;e.forEach(((e,n)=>{const{range:a,spaceValue:u,width:p,title:h,titleStyle:g,key:v,position:y="center",spaceGridNumber:k=1,showNumber:x,showMaxMinNumber:b}=e,j=[],S=[],C=r+p/2,T=m(a,u),M=T.length;T.forEach(((t,n)=>{const{lineXMain:o,lineXSub:i,textLeft:l}=c(y,r,p),s=I-n*N*k,a=0===n?I-8:n!==T.length-1||A||J&&"FHR"!==v?s:A+8;!x||(0===n||n===M-1)&&!b||j.push(f(String(t),e,l,a)),S.push(...d(e,n,o,i,s,N,A,M))}));const P=new t.Rect({...s,strokeWidth:.5,width:p,height:I,left:C,top:I/2}),E=o([C,A>0?A-N/2:N/2],{value:String(h),...i,...g}),G=new t.Group([...S,...j,P,...E?[E]:[]],{objectCaching:!1,...l});w.value.add(G),G.sendToBack(),r+=p}))}e(V),e(D,"right")}(),function(){const{show:e,startTime:n,range:r=[0,23],position:s="top",style:a}=L.time,{show:u,range:c=[0,23],position:f,style:d}=L.processTime;if(e||u){const p=[],h=[],g=[],v=[],m=X+H/2,y=N/2;for(let t=0;t<Y.mainXCell;t++){if(e){const e=0===t?+n.slice(11,13):rt(p.at(-1),r);p.push(e);const l="top"===s?A-y:I+y;g.push(o([m+t*H,l],{value:String(e),...i,...a||{}}))}if(u){const e=0===t?c[0]:h.at(-1)+1;h.push(e);const n="top"===f?y:Q-y;v.push(o([m+t*H,n],{value:String(e),...i,...d||{}}))}}const k=new t.Group([...g,...v],{objectCaching:!1,...l});w.value.add(k),w.value.sendToBack(k)}}(),function(){var t;const n=Object.values(K),o=[],i={},r=U.find((t=>"cervix"===t.key&&t.show)),l=null==(t=null==r?void 0:r.data)?void 0:t.find((t=>3==+t.value));function s(t,e){const{key:n,range:o}=r||{},i=T(n,o,10),l=[0,e],s=[-e/t,0],a=[(I-i-e)/t,I-i],u=[R-X,t*(R-X)+e];let c=[],f=[];function d([n,o]){return Math.abs(o-t*n-e)<=1}function p([t,e]){const[n,o]=[...h([t,e])];return n>=X&&n<=R&&o>=i&&o<=I}function h([t,e]){return[X+t,I-e]}return d(l)&&p(l)&&(c=h(l)),d(s)&&p(s)&&(c=h(s)),d(a)&&p(a)&&(f=h(a)),d(u)&&p(u)&&(f=h(u)),[...c,...f]}n.forEach((t=>{if(!t.show)return;const{key:n}=t;switch(n){case"fetalPresentation":{const{range:i,show:r}=U.find((t=>t.key===n));if(r){const r=T(n,i,0);o.push(e([X,r,R,r],{...t}))}break}case"alert":if(l){const{key:n,range:a}=r||{},u=216e5,c={time:k(new Date(v(l.time)+u),"yyyy-MM-dd HH:mm"),value:10},[f,d]=[C(l.time)-X,I-T(n,a,l.value)],[p,h]=[C(c.time)-X,I-T(n,a,c.value)],g=(h-d)/(p-f),m=d-f*g,y=s(g,m);y.length>0&&(o.push(e(y,{...t})),Object.assign(i,{k:g,b:m}))}break;case"handling":if(l){const{k:n,b:r}=i,a=144e5,u=s(n,r-(C(k(new Date(v(l.time)+a),"yyyy-MM-dd HH:mm"))-C(l.time))*n);u.length>0&&o.push(e(u,{...t}))}}})),w.value.add(...o)}(),_(),function(){function t(t,e){const n=U.findIndex((e=>e.key===t.key));return{renderItem:()=>t.title,origin:{title:t.title,unit:t.unit,dataIndex:n,key:t.key},pointer:e}}x.event.evented&&w.value.on("mouse:up",(e=>{if(3===e.button){const{x:n=0,y:o=0}=e.pointer||{};n>=X&&n<=R&&o>=A&&o<=I&&(S.point={x:n,y:o},S.show=!0,e.target?(S.target=e.target,S.list=["删除节点"],w.value.forEachObject((t=>{t.origin&&t.left===e.target.left&&t.top===e.target.top&&S.list.push({renderItem:()=>t.origin.title,origin:{...t.origin},mode:"remove",pointer:e.pointer})}))):(S.target=null,S.list=["新增节点"],U.filter((t=>t.show)).forEach((i=>{if(!E(n,"key",H).includes(i.key)){if(["cervix","fetalPresentation"].includes(i.key)&&o<J)return;S.list.push(t(i,e.pointer))}})),1===S.list.length&&(S.show=!1,G("repeat"),console.log("当前时间段内无可新增节点"))))}}))}(),function(){const e=B-q/2;function n(e,n){if(!e.length)return;let l=A;const s=[];e.forEach((e=>{const o=e.title.split("").join("\n"),a=$.findIndex((t=>t.key===e.key)),u=new t.Text(String(o),{...i,...e.titleStyle||{},originY:"top",left:n,top:l,lineHeight:1}),c=r(e.type,{left:n,top:l+u.height+3,...e.pointAttr,originY:"top",origin:{title:e.title,unit:e.unit,type:e.type,dataIndex:a,key:e.key,isMenu:!0},originLeft:n,originTop:l+u.height+3,...x.event});l+=u.height+c.height+15,function(t){function e(t){const{left:e,top:n}=t;return e>=X&&e<=R&&n>=A&&n<=I}t.on("moving",(()=>{t.set("originY","center"),e(t)?(nt(t),ot(t)):j.show=!1})),t.on("mouseup:before",(n=>{if(j.show=!1,0===n.e.button&&e(t))if(E(t.left,"key",H).includes(t.origin.key))G("repeat");else{const e={data:{time:M(t.left),value:P(t.origin.key,t.top)},...t.origin};b("add",e),tt(e)}!function(t){t.setCoords().set({originY:"top",left:t.originLeft,top:t.originTop})}(t)}))}(c),s.push(u,c)})),o(s),w.value.add(...s)}function o(t){const e=t.at(-1),n=(I-A)/2,o=(e.height+e.top-A)/2;t.forEach((t=>{const e=t.top+n-o;t.set({top:e,originTop:e})}))}n(V,W/2),n(D,e)}(),{clickMenu:function({item:t,target:e}){const n={...t.origin};"remove"===t.mode?(b("remove",n),tt(n,"remove")):(Object.assign(n,{data:{time:M(t.pointer.x),value:P(t.origin.key,t.pointer.y)}}),b("add",n),tt(n))},redrawPoints:et}}export{w as useBirthProcess};
@@ -1,2 +1,3 @@
1
1
  export * from './useTop';
2
+ export * from './useLeft';
2
3
  export * from './useCenter';
@@ -1 +1 @@
1
- export{useTop}from"./useTop.js";export{useCenter}from"./useCenter.js";
1
+ export{useTop}from"./useTop.js";export{useLeft}from"./useLeft.js";export{useCenter}from"./useCenter.js";
@@ -0,0 +1,4 @@
1
+ import { type Ref } from 'vue';
2
+ import { fabric } from '../../../../../../es/shared/utils/fabricjs';
3
+ import { AnyObject } from '../../../../../../es/shared/types';
4
+ export declare function useLeft(canvas: Ref<fabric.Canvas>, propItems: AnyObject, emits: Function): void;
@@ -0,0 +1 @@
1
+ import{fabric as t}from"../../../../../shared/utils/fabricjs/index.js";import{drawTextGroup as e,defaultStyle as i,drawPoint as o,drawText as n,defaultTextStyle as r}from"../useDraw.js";import"date-fns";import{getScaleNumberList as l}from"../../utils/index.js";import"@vueuse/core";import{drawScaleNumber as s}from"../useScaleColumn.js";import"vue";import"lodash-es";import"../temperature/useShadow.js";function a(a,u,c){const{originY:h,endY:d,borderStyle:p,left:g,itemList:f,scaleValues:m,originX:y,endX:S,yCellHeight:w}=u;!function(){if(!g)return;const{title:t,titleWidth:i,titleStyle:o}=g,n=e({width:i,height:d-h,...p},{value:t.split("").join("\n"),...o||{}},{left:0,top:h},!0);a.value.add(n)}(),m.forEach(((e,o)=>{const u="left"===e.layout?y-5:S+5,{range:c,spaceValue:p,title:f,titleStyle:m,spaceGridNumber:b=1,showNumber:j,showMaxMinNumber:v}=e,x=[],N=l(c,p);console.log(555,N);const C=N.length;N.forEach(((t,i)=>{const o=0===i?d-5:d-i*w*b;!j||(0===i||i===C-1)&&!v||x.push(s(String(t),{...e,position:e.layout},u,o))}));const T=n([g.width/2,h+w],{value:String(f),...r,...m}),X=new t.Group([...x,...T?[T]:[]],{objectCaching:!1,...i});a.value.add(X),X.sendToBack()})),function(){const e=JSON.parse(JSON.stringify(f));let n=d;const r=g.titleWidth+15;e.reverse().forEach((e=>{n-=10;const l=e.title,s=new t.Text(String(l),{...i,objectCaching:!1,...e.titleStyle||{},originX:"left",originY:"bottom",left:r,top:n,lineHeight:1,fontSize:12}),u=o(e.type,{left:r+s.width+5,top:n-(s.height||30)/2-1,...e.pointAttr,originY:"center",originX:"left",origin:{title:e.title,unit:e.unit,type:e.bigType,dataIndex:e.dataIndex,key:e.key,isMenu:!0},originLeft:r+s.width+5,originTop:n-(s.height||30)/2-1});n-=s.height||30,a.value.add(s,u)}))}()}export{a as useLeft};
@@ -1 +1 @@
1
- import{ref as t,reactive as e,computed as a,unref as r,onMounted as i,nextTick as l}from"vue";import{defaultBorderStyle as o}from"../useDraw.js";import"../../../../../shared/utils/fabricjs/index.js";import{format as n}from"date-fns";import{getChildrenSize as s}from"../../utils/index.js";import"@vueuse/core";import{cloneDeep as d,range as u}from"lodash-es";import"../temperature/useShadow.js";import{useTop as p}from"./useTop.js";import{useCenter as h}from"./useCenter.js";function m(m,c,v,g){const f=t(),x=t(),w=t(),y=e({show:!1,point:{x:0,y:0},list:[]}),b=e({show:!1,point:{x:0,y:0},list:[],target:null}),C=a((()=>{var t;return null!=(t=c.data.left.width)?t:0})),H=a((()=>s(c.data.top.treeData))),Y=a((()=>{const{xAxis:t}=c.data;return"top"===t.position?t.height:0})),j=function(){const t=d(c.data.top.treeData);let e=0;const{cellWidth:a,cellHeight:r}=c.data.top.tree;return function t(i,l=0){i.forEach((i=>{var o;const n={top:e*r+Y.value,left:l*a,width:a,height:r};if(e++,null==(o=i.children)?void 0:o.length){e--;const a=s(i.children);n.height=a*r,t(i.children,l+1)}else n.width=C.value-n.left;Object.assign(i,n)}))}(t),t}();const D=a((()=>{const{grid:t}=c.data;return t.mainXCell*t.subXCell})),T=a((()=>c.data.top.tree.cellHeight)),M=a((()=>Y.value+T.value*H.value)),X=a((()=>{const t=d(c.data.xAxis),{position:e,spaceValue:a,spaceTimeStamp:r}=t,i=u(D.value/a+1).map((e=>0===e?t.startTime:n(new Date(E.value+e*a*r),"yyyy-MM-dd HH:mm:ss")));return{...t,list:i,left:C.value,top:"top"===e?0:M.value}})),A=a((()=>{const{grid:t}=c.data;return t.mainYCell*t.subYCell})),S=a((()=>{var t;const{width:e,right:a}=c.data;if(!a)return e;return e-(null!=(t=a.width)?t:0)})),G=a((()=>c.data.xAxis.height+T.value*H.value)),N=a((()=>{var t;const{bottom:e=null,height:a}=c.data;if(!e)return a;return a-(null!=(t=e.height)?t:0)})),P=a((()=>(S.value-C.value)/D.value)),W=a((()=>(N.value-G.value)/A.value)),E=a((()=>{var t;return Date.parse((null==(t=c.data.xAxis)?void 0:t.startTime)||n(new Date,"yyyy-MM-dd HH:mm:ss"))})),O=a((()=>X.value.spaceTimeStamp/P.value)),k=e({canvasWidth:c.data.width,canvasHeight:c.data.height,borderStyle:{...o,...c.data.borderStyle||{}},grid:c.data.grid,top:c.data.top,other:c.data.other,topGridYNumber:r(H),topGridYCellHeight:r(T),topGridOriginY:r(Y),topGridEndY:r(M),treeData:j,xAxis:r(X),startTime:r(E),timeXCell:r(O),gridXNumber:r(D),gridYNumber:r(A),xCellWidth:r(P),yCellHeight:r(W),originX:r(C),endX:r(S),originY:r(G),endY:r(N)});return i((async()=>{await l(),p(m,k),h(m,k)})),{propItems:k,redrawPoints:x,select:f,pointTipProps:y,pointMenuProps:b,clickMenu:w}}export{m as useSurgicalAnesthesiaChart};
1
+ import{ref as t,reactive as e,computed as a,unref as i,onMounted as r,nextTick as l}from"vue";import{defaultBorderStyle as o}from"../useDraw.js";import"../../../../../shared/utils/fabricjs/index.js";import{format as s}from"date-fns";import{getChildrenSize as n}from"../../utils/index.js";import"@vueuse/core";import{cloneDeep as u,range as d}from"lodash-es";import"../temperature/useShadow.js";import{useTop as p}from"./useTop.js";import{useLeft as m}from"./useLeft.js";import{useCenter as h}from"./useCenter.js";function c(c,v,f,g){const x=t(),y=t(),w=t(),b=e({show:!1,point:{x:0,y:0},list:[]}),j=e({show:!1,point:{x:0,y:0},list:[],target:null}),C=a((()=>{var t;return null!=(t=v.data.left.width)?t:0})),H=a((()=>n(v.data.top.treeData))),Y=a((()=>{const{xAxis:t}=v.data;return"top"===t.position?t.height:0})),T=function(){const t=u(v.data.top.treeData);let e=0;const{cellWidth:a,cellHeight:i}=v.data.top.tree;return function t(r,l=0){r.forEach((r=>{var o;const s={top:e*i+Y.value,left:l*a,width:a,height:i};if(e++,null==(o=r.children)?void 0:o.length){e--;const a=n(r.children);s.height=a*i,t(r.children,l+1)}else s.width=C.value-s.left;Object.assign(r,s)}))}(t),t}();const D=a((()=>{const{grid:t}=v.data;return t.mainXCell*t.subXCell})),M=a((()=>v.data.top.tree.cellHeight)),X=a((()=>Y.value+M.value*H.value)),A=a((()=>{const t=u(v.data.xAxis),{position:e,spaceValue:a,spaceTimeStamp:i}=t,r=d(D.value/a+1).map((e=>0===e?t.startTime:s(new Date(W.value+e*a*i),"yyyy-MM-dd HH:mm:ss")));return{...t,list:r,left:C.value,top:"top"===e?0:X.value}})),S=a((()=>{const{grid:t}=v.data;return t.mainYCell*t.subYCell})),G=a((()=>{var t;const{width:e,right:a}=v.data;if(!a)return e;return e-(null!=(t=a.width)?t:0)})),V=a((()=>v.data.xAxis.height+M.value*H.value)),L=a((()=>{var t;const{bottom:e=null,height:a}=v.data;if(!e)return a;return a-(null!=(t=e.height)?t:0)})),N=a((()=>(G.value-C.value)/D.value)),P=a((()=>(L.value-V.value)/S.value)),W=a((()=>{var t;return Date.parse((null==(t=v.data.xAxis)?void 0:t.startTime)||s(new Date,"yyyy-MM-dd HH:mm:ss"))})),E=a((()=>A.value.spaceTimeStamp/N.value)),I=a((()=>{const{scaleValues:t}=v.data;return t.map((t=>t.dataList.filter((t=>t.show)).map(((e,a)=>({...e,bigType:t.type,unit:t.unit,dataIndex:a}))))).flat()})),O=e({canvasWidth:v.data.width,canvasHeight:v.data.height,borderStyle:{...o,...v.data.borderStyle||{}},grid:v.data.grid,top:v.data.top,left:v.data.left,other:v.data.other,topGridYNumber:i(H),topGridYCellHeight:i(M),topGridOriginY:i(Y),topGridEndY:i(X),treeData:T,xAxis:i(A),startTime:i(W),timeXCell:i(E),gridXNumber:i(D),gridYNumber:i(S),xCellWidth:i(N),yCellHeight:i(P),originX:i(C),endX:i(G),originY:i(V),endY:i(L),itemList:i(I),scaleValues:v.data.scaleValues});return r((async()=>{await l(),p(c,O),m(c,O),h(c,O)})),{propItems:O,redrawPoints:y,select:x,pointTipProps:b,pointMenuProps:j,clickMenu:w}}export{c as useSurgicalAnesthesiaChart};
@@ -16,3 +16,10 @@ export declare function isOverlapPoint(pointObj1: any, pointObj2: any): boolean;
16
16
  export declare function getFloorNumber(value: number, n?: number): number;
17
17
  export declare function getChildrenSize(treeData: ITreeItem[]): number;
18
18
  export declare function getTime(value: number | string): number;
19
+ /**
20
+ * @description: 获取y轴刻度数值列表
21
+ * @param {[number, number]} range
22
+ * @param {number} spaceValue
23
+ * @return {number[]}
24
+ */
25
+ export declare function getScaleNumberList(range: [number, number], spaceValue: number): number[];
@@ -1 +1 @@
1
- import{isNull as n,isNumber as t}from"lodash-es";function e(n){return(null==n?void 0:n.time)&&((null==n?void 0:n.value)||0===(null==n?void 0:n.value))}function r(n,t){const e={};for(const r in n)t.map((n=>n.type)).includes(r)||(e[r]=n[r]);return e}function u(n,t){const e=t.findIndex((t=>d(t.time)>d(n)));return~e?e:t.length}function o(n){return["temperature","pulse"].includes(n)}function i(n,t){return n.includes("心率")?"pulse_other":t}function l(n){return n.includes("_other")?n.split("_")[0]:n}function c(t){return!Number.isNaN(+t)&&!n(t)}function f(n,t){return a(n.left,1)===a(t.left,1)&&Math.abs(a(n.top,1)-a(t.top,1))<=2}function a(n,t=100){return Math.floor(n*t)/t}function s(n){let t=0;return n.forEach((n=>{var e;(null==(e=n.children)?void 0:e.length)?t+=s(n.children):t++})),t}function d(n){return n?t(n)?new Date(n).getTime():Date.parse(n.replace(/-/g,"/")):Date.now()}export{r as deleteProperty,s as getChildrenSize,a as getFloorNumber,u as getIndex,d as getTime,l as getType,e as isEffectiveNode,o as isOneLine,f as isOverlapPoint,c as isValidValue,i as setOtherType};
1
+ import{isNull as n,isNumber as t}from"lodash-es";function e(n){return(null==n?void 0:n.time)&&((null==n?void 0:n.value)||0===(null==n?void 0:n.value))}function r(n,t){const e={};for(const r in n)t.map((n=>n.type)).includes(r)||(e[r]=n[r]);return e}function u(n,t){const e=t.findIndex((t=>d(t.time)>d(n)));return~e?e:t.length}function o(n){return["temperature","pulse"].includes(n)}function i(n,t){return n.includes("心率")?"pulse_other":t}function l(n){return n.includes("_other")?n.split("_")[0]:n}function c(t){return!Number.isNaN(+t)&&!n(t)}function f(n,t){return s(n.left,1)===s(t.left,1)&&Math.abs(s(n.top,1)-s(t.top,1))<=2}function s(n,t=100){return Math.floor(n*t)/t}function a(n){let t=0;return n.forEach((n=>{var e;(null==(e=n.children)?void 0:e.length)?t+=a(n.children):t++})),t}function d(n){return n?t(n)?new Date(n).getTime():Date.parse(n.replace(/-/g,"/")):Date.now()}function p(n,t){const e=[],[r,u]=n;for(let n=r;t>0?n<=u:n>=u;n+=t)e.push(n);return e}export{r as deleteProperty,a as getChildrenSize,s as getFloorNumber,u as getIndex,p as getScaleNumberList,d as getTime,l as getType,e as isEffectiveNode,o as isOneLine,f as isOverlapPoint,c as isValidValue,i as setOtherType};
@@ -1 +1 @@
1
- import{cloneDeep as e,isString as t,isFunction as n,pick as o,isArray as i,isNumber as a}from"lodash-es";import{isObject as r}from"@vue/shared";const s=Symbol("remove property");function l(){return{formConfigLikeAdaptor:function(l){const p={};return r(l)?{fieldList:function(l){const m=new Map([["NONE",0],["LEFT",1],["RIGHT",2]]),u=new Map([["0",0],["1",1]]),c=new Map([...["RADIO","RADIO_BLOCK","CHECKBOX","CHECKBOX_BLOCK","SELECT","SEARCH","SEARCH_MORE","SWITCH_COMPONENT"].map((e=>[e,"select"])),...["DATE"].map((e=>[e,"date"])),...["INPUT"].map((e=>[e,"input"])),...["DIGITAL"].map((e=>[e,"number"]))]),d=(e,t)=>{if(!r(e))return;const n={label:e.describe,...e};t.options=i(t.options)?[...t.options,n]:[n]},f=(e,n)=>{0!==e&&"0"!==e&&e&&(t(e)||a(e))&&(console.log("value=>",e),n.componentProps={maxTagCount:+e,...n.componentProps})},_=new Map([["multi_select_value",f],["is_null",(e,t,n,o)=>{"1"!==e&&"0"===e&&(o[n.val_key]=[{required:!0,message:"必填"}])}],["validate",(e,t)=>{if(!r(e))return;t.componentProps={...Object.entries({maxlength:"max_length",minlength:"min_length",max:"max_value",min:"min_value",precision:"decimal_length"}).reduce(((t,[n,o])=>(t[n]=e[o],t)),{}),...t.componentProps}}],["dateValidate",(e,t)=>{r(e)&&(t.isDateDisabled=(t,n)=>{if(!r(n))return;const{startDate:o,endDate:i}=e;let a=!1;return o&&(a=new Date(n[o]).getTime()>t),i&&(a=a||new Date(n[i]).getTime()<t),a})}],["date_format","valueFormat"],...["open","close"].map((e=>[e,d])),["is_edit",{property:"isEdit",valueMap:u}],["html_type",(e,n,o)=>{var i;if(!t(e))return;if("DATE"===e)return void(n.formType=t(o.date_format)&&o.date_format.startsWith("HH:mm")?"time":"date");n.formType=null!=(i=c.get(e))?i:e;const a="SEARCH"!==e&&("SEARCH_MORE"===e||("SELECT"===e?"0"===o.multi_select:null));a&&(n.componentProps={multiple:a,...n.componentProps})}],["option",{property:"options",fieldMap:new Map([["text","label"]])}],["alias",(e,t,n)=>{t.title=`${e}${n.suffix?`(${n.suffix})`:""}`}]]),E=new Map([["sum","isSum"],["show","isShow"],["elementId","columnName"],["columnWidth","colWidth"],["fixedWayEnum",{property:"isFixed",valueMap:m}],["multi_select_value",f],["setting",{fieldMap:_,assign:!0}]]);return l.map((e=>g(e,p,E)));function g(a,l,p){if(!p)return e(a);const m={};return Object.entries(a).forEach((([e,o])=>{const i=p.get(e);return i?i!==s?t(i)?m[i]=o:n(i)?i(o,m,a,l):void(r(i)&&(i.assign?Object.assign(m,u(o,i)):m[i.property||e]=u(o,i))):void 0:m[e]=o})),m.componentProps=Object.assign({},m.componentProps,o(m,["options","isDateDisabled"])),m;function u(e,t){var o,a;return!r(t)||n(t)?e:i(e)?e.map((e=>u(e,t))):r(e)?g(e,l,t.fieldMap):null!=(a=null==(o=t.valueMap)?void 0:o.get(e))?a:e}}}(l.fieldList),editRules:p}:{fieldList:[],editRules:p}}}}export{l as useColumnConfigAdaptor};
1
+ import{cloneDeep as e,isString as t,isFunction as n,pick as o,isArray as i,isNumber as a}from"lodash-es";import{isObject as r}from"@vue/shared";const s=Symbol("remove property");function l(){return{formConfigLikeAdaptor:function(l){const p={};return r(l)?{fieldList:function(l){const m=new Map([["NONE",0],["LEFT",1],["RIGHT",2]]),u=new Map([["0",0],["1",1]]),c=new Map([...["RADIO","RADIO_BLOCK","CHECKBOX","CHECKBOX_BLOCK","SELECT","SEARCH","SEARCH_MORE","SWITCH_COMPONENT"].map((e=>[e,"select"])),...["DATE"].map((e=>[e,"date"])),...["INPUT"].map((e=>[e,"input"])),...["DIGITAL"].map((e=>[e,"number"]))]),d=(e,t)=>{if(!r(e))return;const n={label:e.describe,...e};t.options=i(t.options)?[...t.options,n]:[n]},f=(e,n)=>{0!==e&&"0"!==e&&e&&(t(e)||a(e))&&(console.log("value=>",e),n.componentProps={maxTagCount:+e,...n.componentProps})},_=new Map([["multi_select_value",f],["is_null",(e,t,n,o)=>{"1"!==e&&"0"===e&&(o[n.val_key]=[{required:!0,message:"必填"}])}],["validate",(e,t)=>{if(!r(e))return;t.componentProps={...Object.entries({maxlength:"max_length",minlength:"min_length",max:"max_value",min:"min_value",precision:"decimal_length"}).reduce(((t,[n,o])=>(t[n]=e[o],t)),{}),...t.componentProps}}],["dateValidate",(e,t)=>{r(e)&&(t.isDateDisabled=(t,n)=>{if(!r(n))return;const{startDate:o,endDate:i}=e;let a=!1;return o&&(a=new Date(n[o]).getTime()>t),i&&(a=a||new Date(n[i]).getTime()<t),a})}],["date_format","valueFormat"],...["open","close"].map((e=>[e,d])),["is_edit",{property:"isEdit",valueMap:u}],["html_type",(e,n,o)=>{var i;if(!t(e))return;if("DATE"===e)return void(n.formType=t(o.date_format)&&o.date_format.startsWith("HH:mm")?"time":"date");n.formType=null!=(i=c.get(e))?i:e;const a="SEARCH"!==e&&("SEARCH_MORE"===e||("SELECT"===e?"0"===o.multi_select:null));a&&(n.componentProps={multiple:a,...n.componentProps})}],["option",{property:"options",fieldMap:new Map([["text","label"]])}],...["alias","name"].map((e=>[e,(e,t,n)=>{var o;t.title=`${null!=(o=n.alias)?o:n.name}${n.suffix?`(${n.suffix})`:""}`}]))]),v=new Map([["sum","isSum"],["show","isShow"],["elementId","columnName"],["columnWidth","colWidth"],["fixedWayEnum",{property:"isFixed",valueMap:m}],["multi_select_value",f],["setting",{fieldMap:_,assign:!0}]]);return l.map((e=>E(e,p,v)));function E(a,l,p){if(!p)return e(a);const m={};return Object.entries(a).forEach((([e,o])=>{const i=p.get(e);return i?i!==s?t(i)?m[i]=o:n(i)?i(o,m,a,l):void(r(i)&&(i.assign?Object.assign(m,u(o,i)):m[i.property||e]=u(o,i))):void 0:m[e]=o})),m.componentProps=Object.assign({},m.componentProps,o(m,["options","isDateDisabled"])),m;function u(e,t){var o,a;return!r(t)||n(t)?e:i(e)?e.map((e=>u(e,t))):r(e)?E(e,l,t.fieldMap):null!=(a=null==(o=t.valueMap)?void 0:o.get(e))?a:e}}}(l.fieldList),editRules:p}:{fieldList:[],editRules:p}}}}export{l as useColumnConfigAdaptor};
@@ -1 +1 @@
1
- import{defineComponent as e,reactive as t,ref as a,watch as o,nextTick as l,openBlock as i,createElementBlock as n,normalizeClass as s,unref as r,createCommentVNode as u,Fragment as c,createBlock as p,mergeProps as d,createElementVNode as m,normalizeStyle as v,createVNode as f,withCtx as g,renderList as y,toDisplayString as b,createTextVNode as k,resolveDynamicComponent as C,h as S}from"vue";import w from"./hooks/use-noData.js";import{getScaleViewState as h}from"./hooks/scaleview-state.js";import{ScaleViewComputed as E}from"./hooks/scaleview-computed.js";import{ScaleViewInit as O}from"./hooks/scaleview-init.js";import{ScaleViewSubmit as A}from"./hooks/scaleview-submit.js";import{handleQueryParams as j,isCollection as _,isEvaluation as T}from"./utils/judge-types.js";import{useEvent as L}from"./hooks/use-event.js";import P from"./components/NoData.vue.js";import D from"./components/EvaluateCountdown.vue.js";import F from"./components/EvaluatePage.vue.js";import B from"./components/AnswerParse.vue.js";import N from"./components/ScaleScore.js";import{useDialog as x,useMessage as I,NForm as q,NFormItem as M,NButton as R}from"naive-ui";const K=["innerHTML"],V={key:0,class:"required-text"},H={key:1,class:"evalute-label"},U=["onClick"],W=m("i",{class:"scale-view-iconfont icon-scale-view-dengpao"},null,-1),J={key:1,class:"footer"};var Y=e({__name:"ScaleView",props:{guageData:{type:Object,default:()=>({})},styleSetting:{type:Object,default:()=>({})},ids:{type:Object,default:()=>({guage_id:"",db_id:void 0})},params:{default:()=>({}),type:Object},noBtn:{type:[Boolean,String,Number],default:!1},hideBtn:{type:[Boolean,String,Number],default:!1},isLock:{type:[Boolean,String,Number],default:!1},type:{type:String,default:""},openType:{type:String,default:""},scaleApiConfig:{type:Object,default:()=>({})},getSelectOptions:{type:Function,default:()=>Promise.resolve([])},getSearchOptions:{type:Function,default:()=>Promise.resolve([])},getCascadeOptions:{type:Function,default:()=>Promise.resolve([])},getLabelList:{type:Function,default:()=>Promise.resolve([])},deleteLabel:{type:Function,default:()=>Promise.resolve({status:!0})},saveLabelItem:{type:Function,default:()=>Promise.resolve({status:!0})},uploadPictureUrl:{type:String,default:""},uploadFileUrl:{type:String,default:""},ak:{type:String,default:"KP3BZ-OAC3W-PY6RY-OJ6DV-JYKN3-H6F72"},sourceType:{type:String,default:""},getChunkUploadConfig:{type:Function,default:()=>Promise.resolve({})},fontSizeObj:{type:Object,default:()=>({large:1.25,medium:1.1,small:1,extrasmall:.9})}},emits:["onCloseSetting","submitNoRequest","onSubmit","startWriteScale"],setup(e,{expose:Y,emit:X}){const z=e,{ScaleViewState:G}=h(),Q=t(G),Z=x(),$=I(),ee=a(null),te=a(null),{noDataState:ae,setNoData:oe,resetNodata:le}=w(),ie=j(),{showEvatip:ne,isFormBoldOpen:se,scaleStyle:re,handlePageClass:ue,isShowItem:ce,handleShowQuestionNumber:pe,hasScore:de,isPreviewScale:me,showEvaluateEntry:ve,showEvaluateCoundownPage:fe,showSaveBtn:ge,showEvaluateLabel:ye,showAnswerParse:be,propsConfig:ke,evaluatePageProps:Ce,evaluateCountdownProps:Se,skipCover:we,scaleEdit:he}=E(z,Q,{query:ie}),{initForm:Ee}=O(z,Q,X,{query:ie}),{submitMethod:Oe}=A(z,Q,X,{query:ie}),{nextLogicEvent:Ae,handleDynamicDataRelation:je}=L(z,Q);(()=>{let{id:e}=ie;e&&(Q.shareId=e)})();const _e=e=>{try{le(),Ee(e)}catch(e){console.log(e,"--error"),Q.spinning=!1,Q.hasFrontAddress=!1,oe(!0,null==e?void 0:e.resultMsg,null==e?void 0:e.result)}};o((()=>z.ids),((e,t)=>{t?e.guage_id&&e.guage_id!=t.guage_id&&_e(e):e.guage_id&&_e(e)}),{immediate:!0}),o((()=>z.guageData),(e=>{if(!e||!Object.keys(e||{}).length)return;Q.form={},Q.formArray=[];const t=JSON.parse(JSON.stringify(e));l((()=>{Ee(t)}))}),{immediate:!0});const Te=e=>{Q.showEvaluateSettingWrap=!1,Q.showEvaluateCountdown=!!e,X("startWriteScale")},Le=()=>{console.log("----closeEvaluateCountdown"),Q.showEvaluateCountdown=!1,me.value||(Q.banSubmit=!0,Oe(),Z.warning({title:"温馨提示",content:"测评时间到了,结束测评!",maskClosable:!1,positiveText:"确定",onPositiveClick:()=>({})}))},Pe=e=>{Z.warning({title:"提示",content:()=>S("div",{class:"evatip-container"},[S("span","答案解析:"),S("p",e)]),class:"c-evatip-dialog-wrap",showIcon:!1,positiveText:"确定",negativeText:"关闭",maskClosable:!1,onPositiveClick(){},onNegativeClick(){}})},De=(e,t,a)=>{let{choiceObj:o,isSetObj:l}=a||{};switch(t.type.includes("SELECT")||(Q.form[t.val_key]=e),t.type){case"SELECT":case"EVALUATE_SELECT":{let{value:a,list:o=[]}=e;Q.form[t.val_key]=a,Ae(e,t,Q.formArray),je(o,t,Q.formArray)}break;case"RADIO_BLOCK":case"CHECKBOX_BLOCK":l&&(Q.choiceComObj[t.val_key]=o),Ae(e,t,Q.formArray);break;case"EVALUATE_RADIO_BLOCK":case"EVALUATE_CHECKBOX_BLOCK":Ae(e,t,Q.formArray);break;case"DATE":case"TIME":case"DATETIME":case"SEARCH_CASCADE":Q.submitForm[t.val_key]=e}},Fe=(e,t)=>{console.log(t),Q.form[t.val_key]=e},Be=e=>{if(!e||!e.length)return{labelStr:"",labels:[]};const t=e||[],a=[],o=[];return t.forEach((e=>{o.push(e),a.push(e.labelName)})),Q.labelSelectedList=t,{labelStr:a.join(","),labels:o}},Ne=()=>{var e;if(!Q.formArray.find((e=>T(e.type))))return void xe("确认要提交吗?");let{evaluateResultSetting:t}=Q.config;if(!t||!Object.keys(t).length&&!ve.value||he.value)return void xe("确认要结束测评吗?");if("formIframe"==z.openType&&ve.value)return void X("submitNoRequest");let a="确定要提前结束测评吗?";if(fe.value&&(null==(e=ee.value)?void 0:e.getCountdownObj)){const e=ee.value.getCountdownObj(),{setAnswered:t,totalLen:o}=e;t<o?a="存在未作答的题目,确定要提前结束测评吗?":!(null==Q?void 0:Q.showEvaluateCountdown)&&(a="确认要结束测评吗?")}we.value&&!(null==Q?void 0:Q.showEvaluateCountdown)&&(a="确认要结束测评吗?"),xe(a)},xe=e=>{Z.warning({title:"温馨提示",content:()=>S("div",{style:{paddingLeft:"30px"}},e),positiveText:"确定",negativeText:"取消",maskClosable:!1,closable:!1,positiveButtonProps:{type:"primary"},onPositiveClick:async()=>{const e=await Ie();X("onSubmit",e)},onNegativeClick(){}})},Ie=()=>new Promise(((e,t)=>{var a;null==(a=te.value)||a.validate((t=>{var a;if(t){console.log(t);let o=(null==(a=t[0])?void 0:a[0])||{},l=o.field,i=o.message,n=Q.formArray.find((e=>e.databaseTitle===l));return n&&(l=n.title),$.error(l+i),e(!1),!1}{const t=Oe();e(t)}}))})),qe=()=>{X("onCloseSetting")};return Y({getScaleData:()=>({...Q}),onSubmitForm:Ie,cancel:qe}),(e,t)=>(i(),n("div",{class:s(["c-scale-view-block",{"c-scale-view-block-hasfooter":r(ge)}])},[u(' <template v-if="state.spinning">\r\n <n-spin :show="state.spinning" description="加载中"></n-spin>\r\n </template> '),Q.spinning||Q.hasFrontAddress?u("v-if",!0):(i(),n(c,{key:0},[r(ae).noData?(i(),p(P,{key:0,noDataImg:r(ae).noDataImg,noDataTip:r(ae).noDataTip},null,8,["noDataImg","noDataTip"])):(i(),n(c,{key:1},[r(ve)&&!r(we)?(i(),p(F,d({key:0},r(Ce),{onWriteGuage:Te}),null,16)):(i(),n(c,{key:1},[r(fe)?(i(),p(D,d({key:0,ref_key:"countdownDom",ref:ee},r(Se),{onCloseEvaluateCountdown:Le}),null,16)):u("v-if",!0),m("div",{class:s(["scale-container",{"scale-container-nopadding":r(ue),"scale-container-hasfooter":r(ge)}]),style:v(r(re))},[r(de)?(i(),p(r(N),{key:0,config:Q.config,maxScore:Q.maxScore},null,8,["config","maxScore"])):u("v-if",!0),f(r(q),{ref_key:"formRef",ref:te,model:Q.form,rules:Q.rules,"require-mark-placement":"left",class:"main"},{default:g((()=>[(i(!0),n(c,null,y(Q.formArray,((e,t)=>(i(),n(c,{key:(e.id||e.seq)+t},[r(ce)(e)?(i(),p(r(M),{key:0,path:e.val_key,"show-label":!r(_)(e.type),class:"c-scle-form-item"},{label:g((()=>[m("span",{class:s({"scale-label-required":r(se)(e)}),innerHTML:r(pe)(e)},null,10,K),r(se)(e)?(i(),n("span",V,"(必填)")):u("v-if",!0),r(ye)(e)?(i(),n("span",H,b(r(ye)(e)),1)):u("v-if",!0),r(ne)(e)?(i(),n("span",{key:2,class:"evalute-tip",onClick:t=>(async e=>{var t;if(Q.evatipMap[e.id])return void Pe(Q.evatipMap[e.id]);let a="getSubjectAnswer";const o=(null==(t=z.scaleApiConfig)?void 0:t[a])||null;if(!o||"function"!=typeof o)return void $.error(`${a} Is not a function`);let l=await o(e.id);l&&(Q.evatipMap[e.id]||(Q.evatipMap[e.id]=l,Pe(l)))})(e)},[W,k(" 查看提示 ")],8,U)):u("v-if",!0)])),default:g((()=>[(i(),p(C(e.renderCom),d(r(ke)(e,t),{key:(e.id||e.seq)+t,onScaleChange:De,onOnChange:t=>((e,t)=>{Q.form[t.val_key]=Be(e)})(t,e),onVodFileList:Fe}),null,16,["onOnChange"])),r(be)(e)?(i(),p(B,{key:0,item:e},null,8,["item"])):u("v-if",!0)])),_:2},1032,["path","show-label"])):u("v-if",!0)],64)))),128))])),_:1},8,["model","rules"])],6),r(ge)?(i(),n("div",J,[u(" 分享的链接 隐藏取消按钮 "),"guage"!==z.sourceType?(i(),p(r(R),{key:0,onClick:qe},{default:g((()=>[k("取消")])),_:1})):u("v-if",!0),z.isLock?u("v-if",!0):(i(),p(r(R),{key:1,onClick:Ne,disabled:Q.banSubmit,type:"primary"},{default:g((()=>[k(" 保存 ")])),_:1},8,["disabled"]))])):u("v-if",!0)],64))],64))],64))],2))}});export{Y as default};
1
+ import{defineComponent as e,reactive as t,ref as a,watch as o,nextTick as l,openBlock as i,createElementBlock as n,normalizeClass as s,unref as r,createCommentVNode as u,Fragment as c,createBlock as p,mergeProps as d,createElementVNode as m,normalizeStyle as v,createVNode as f,withCtx as g,renderList as y,toDisplayString as b,createTextVNode as k,resolveDynamicComponent as C,h as S}from"vue";import w from"./hooks/use-noData.js";import{getScaleViewState as h}from"./hooks/scaleview-state.js";import{ScaleViewComputed as E}from"./hooks/scaleview-computed.js";import{ScaleViewInit as O}from"./hooks/scaleview-init.js";import{ScaleViewSubmit as A}from"./hooks/scaleview-submit.js";import{handleQueryParams as j,isCollection as _,isEvaluation as T}from"./utils/judge-types.js";import{useEvent as L}from"./hooks/use-event.js";import P from"./components/NoData.vue.js";import D from"./components/EvaluateCountdown.vue.js";import F from"./components/EvaluatePage.vue.js";import B from"./components/AnswerParse.vue.js";import N from"./components/ScaleScore.js";import{useDialog as x,useMessage as I,NForm as q,NFormItem as M,NButton as R}from"naive-ui";const K=["innerHTML"],V={key:0,class:"required-text"},H={key:1,class:"evalute-label"},U=["onClick"],W=m("i",{class:"scale-view-iconfont icon-scale-view-dengpao"},null,-1),J={key:1,class:"footer"};var Y=e({__name:"ScaleView",props:{guageData:{type:Object,default:()=>({})},styleSetting:{type:Object,default:()=>({})},ids:{type:Object,default:()=>({guage_id:"",db_id:void 0})},params:{default:()=>({}),type:Object},noBtn:{type:[Boolean,String,Number],default:!1},hideBtn:{type:[Boolean,String,Number],default:!1},isLock:{type:[Boolean,String,Number],default:!1},type:{type:String,default:""},openType:{type:String,default:""},scaleApiConfig:{type:Object,default:()=>({})},getSelectOptions:{type:Function,default:()=>Promise.resolve([])},getSearchOptions:{type:Function,default:()=>Promise.resolve([])},getCascadeOptions:{type:Function,default:()=>Promise.resolve([])},getLabelList:{type:Function,default:()=>Promise.resolve([])},deleteLabel:{type:Function,default:()=>Promise.resolve({status:!0})},saveLabelItem:{type:Function,default:()=>Promise.resolve({status:!0})},uploadPictureUrl:{type:String,default:""},uploadFileUrl:{type:String,default:""},ak:{type:String,default:"KP3BZ-OAC3W-PY6RY-OJ6DV-JYKN3-H6F72"},sourceType:{type:String,default:""},getChunkUploadConfig:{type:Function,default:()=>Promise.resolve({})},fontSizeObj:{type:Object,default:()=>({large:1.25,medium:1.1,small:1,extrasmall:.9})}},emits:["onCloseSetting","submitNoRequest","onSubmit","startWriteScale"],setup(e,{expose:Y,emit:X}){const z=e,{ScaleViewState:G}=h(),Q=t(G),Z=x(),$=I(),ee=a(null),te=a(null),{noDataState:ae,setNoData:oe,resetNodata:le}=w(),ie=j(),{showEvatip:ne,isFormBoldOpen:se,scaleStyle:re,handlePageClass:ue,isShowItem:ce,handleShowQuestionNumber:pe,hasScore:de,isPreviewScale:me,showEvaluateEntry:ve,showEvaluateCoundownPage:fe,showSaveBtn:ge,showEvaluateLabel:ye,showAnswerParse:be,propsConfig:ke,evaluatePageProps:Ce,evaluateCountdownProps:Se,skipCover:we,scaleEdit:he}=E(z,Q,{query:ie}),{initForm:Ee}=O(z,Q,X,{query:ie}),{submitMethod:Oe}=A(z,Q,X,{query:ie}),{nextLogicEvent:Ae,handleDynamicDataRelation:je}=L(z,Q);(()=>{let{id:e}=ie;e&&(Q.shareId=e)})();const _e=e=>{try{le(),Ee(e)}catch(e){console.log(e,"--error"),Q.spinning=!1,Q.hasFrontAddress=!1,oe(!0,null==e?void 0:e.resultMsg,null==e?void 0:e.result)}};o((()=>z.ids),((e,t)=>{t?e.guage_id&&e.guage_id!=t.guage_id&&_e(e):e.guage_id&&_e(e)}),{immediate:!0}),o((()=>z.guageData),(e=>{if(!e||!Object.keys(e||{}).length)return;Q.form={},Q.formArray=[];const t=JSON.parse(JSON.stringify(e));l((()=>{Ee(t)}))}),{immediate:!0});const Te=e=>{Q.showEvaluateSettingWrap=!1,Q.showEvaluateCountdown=!!e,X("startWriteScale")},Le=()=>{console.log("----closeEvaluateCountdown"),Q.showEvaluateCountdown=!1,me.value||(Q.banSubmit=!0,Oe(),Z.warning({title:"温馨提示",content:"测评时间到了,结束测评!",maskClosable:!1,positiveText:"确定",onPositiveClick:()=>({})}))},Pe=e=>{Z.warning({title:"提示",content:()=>S("div",{class:"evatip-container"},[S("span","答案解析:"),S("p",e)]),class:"c-evatip-dialog-wrap",showIcon:!1,positiveText:"确定",negativeText:"关闭",maskClosable:!1,onPositiveClick(){},onNegativeClick(){}})},De=(e,t,a)=>{let{choiceObj:o,isSetObj:l}=a||{};switch(t.type.includes("SELECT")||(Q.form[t.val_key]=e),t.type){case"SELECT":case"EVALUATE_SELECT":{let{value:a,list:o=[]}=e;Q.form[t.val_key]=a,Ae(e,t,Q.formArray),je(o,t,Q.formArray)}break;case"RADIO_BLOCK":case"CHECKBOX_BLOCK":l&&(Q.choiceComObj[t.val_key]=o),Ae(e,t,Q.formArray);break;case"EVALUATE_RADIO_BLOCK":case"EVALUATE_CHECKBOX_BLOCK":Ae(e,t,Q.formArray);break;case"DATE":case"TIME":case"DATETIME":case"SEARCH_CASCADE":Q.submitForm[t.val_key]=e}},Fe=(e,t)=>{console.log(t),Q.form[t.val_key]=e},Be=e=>{if(!e||!e.length)return{labelStr:"",labels:[]};const t=e||[],a=[],o=[];return t.forEach((e=>{o.push(e),a.push(e.labelName)})),Q.labelSelectedList=t,{labelStr:a.join(","),labels:o}},Ne=()=>{var e;if(!Q.formArray.find((e=>T(e.type))))return void xe("确认要提交吗?");let{evaluateResultSetting:t}=Q.config;if(!t||!Object.keys(t).length&&!ve.value||he.value)return void xe("确认要结束测评吗?");if("formIframe"==z.openType&&ve.value)return void X("submitNoRequest");let a="确定要提前结束测评吗?";if(fe.value&&(null==(e=ee.value)?void 0:e.getCountdownObj)){const e=ee.value.getCountdownObj(),{setAnswered:t,totalLen:o}=e;t<o?a="存在未作答的题目,确定要提前结束测评吗?":!(null==Q?void 0:Q.showEvaluateCountdown)&&(a="确认要结束测评吗?")}we.value&&!(null==Q?void 0:Q.showEvaluateCountdown)&&(a="确认要结束测评吗?"),xe(a)},xe=e=>{Z.warning({title:"温馨提示",content:()=>S("div",{style:{paddingLeft:"30px"}},e),positiveText:"确定",negativeText:"取消",maskClosable:!1,closable:!1,positiveButtonProps:{type:"primary"},onPositiveClick:async()=>{const e=await Ie();X("onSubmit",e)},onNegativeClick(){}})},Ie=()=>new Promise(((e,t)=>{var a;null==(a=te.value)||a.validate((t=>{var a;if(t){console.log(t);let o=(null==(a=t[0])?void 0:a[0])||{},l=o.field,i=o.message,n=Q.formArray.find((e=>e.databaseTitle===l));return n&&(l=n.title),$.error(l+i),e(!1),!1}{const t=Oe();e(t)}}))})),qe=()=>{X("onCloseSetting")};return Y({getScaleData:()=>({...Q}),onSubmitForm:Ie,cancel:qe}),(e,t)=>(i(),n("div",{class:s(["c-scale-view-block",{"c-scale-view-block-hasfooter":r(ge)}])},[u(' <template v-if="state.spinning">\n <n-spin :show="state.spinning" description="加载中"></n-spin>\n </template> '),Q.spinning||Q.hasFrontAddress?u("v-if",!0):(i(),n(c,{key:0},[r(ae).noData?(i(),p(P,{key:0,noDataImg:r(ae).noDataImg,noDataTip:r(ae).noDataTip},null,8,["noDataImg","noDataTip"])):(i(),n(c,{key:1},[r(ve)&&!r(we)?(i(),p(F,d({key:0},r(Ce),{onWriteGuage:Te}),null,16)):(i(),n(c,{key:1},[r(fe)?(i(),p(D,d({key:0,ref_key:"countdownDom",ref:ee},r(Se),{onCloseEvaluateCountdown:Le}),null,16)):u("v-if",!0),m("div",{class:s(["scale-container",{"scale-container-nopadding":r(ue),"scale-container-hasfooter":r(ge)}]),style:v(r(re))},[r(de)?(i(),p(r(N),{key:0,config:Q.config,maxScore:Q.maxScore},null,8,["config","maxScore"])):u("v-if",!0),f(r(q),{ref_key:"formRef",ref:te,model:Q.form,rules:Q.rules,"require-mark-placement":"left",class:"main"},{default:g((()=>[(i(!0),n(c,null,y(Q.formArray,((e,t)=>(i(),n(c,{key:(e.id||e.seq)+t},[r(ce)(e)?(i(),p(r(M),{key:0,path:e.val_key,"show-label":!r(_)(e.type),class:"c-scle-form-item"},{label:g((()=>[m("span",{class:s({"scale-label-required":r(se)(e)}),innerHTML:r(pe)(e)},null,10,K),r(se)(e)?(i(),n("span",V,"(必填)")):u("v-if",!0),r(ye)(e)?(i(),n("span",H,b(r(ye)(e)),1)):u("v-if",!0),r(ne)(e)?(i(),n("span",{key:2,class:"evalute-tip",onClick:t=>(async e=>{var t;if(Q.evatipMap[e.id])return void Pe(Q.evatipMap[e.id]);let a="getSubjectAnswer";const o=(null==(t=z.scaleApiConfig)?void 0:t[a])||null;if(!o||"function"!=typeof o)return void $.error(`${a} Is not a function`);let l=await o(e.id);l&&(Q.evatipMap[e.id]||(Q.evatipMap[e.id]=l,Pe(l)))})(e)},[W,k(" 查看提示 ")],8,U)):u("v-if",!0)])),default:g((()=>[(i(),p(C(e.renderCom),d(r(ke)(e,t),{key:(e.id||e.seq)+t,onScaleChange:De,onOnChange:t=>((e,t)=>{Q.form[t.val_key]=Be(e)})(t,e),onVodFileList:Fe}),null,16,["onOnChange"])),r(be)(e)?(i(),p(B,{key:0,item:e},null,8,["item"])):u("v-if",!0)])),_:2},1032,["path","show-label"])):u("v-if",!0)],64)))),128))])),_:1},8,["model","rules"])],6),r(ge)?(i(),n("div",J,[u(" 分享的链接 隐藏取消按钮 "),"guage"!==z.sourceType?(i(),p(r(R),{key:0,onClick:qe},{default:g((()=>[k("取消")])),_:1})):u("v-if",!0),z.isLock?u("v-if",!0):(i(),p(r(R),{key:1,onClick:Ne,disabled:Q.banSubmit,type:"primary"},{default:g((()=>[k(" 保存 ")])),_:1},8,["disabled"]))])):u("v-if",!0)],64))],64))],64))],2))}});export{Y as default};
@@ -1 +1 @@
1
- import{defineComponent as t,ref as e,reactive as l,computed as a,watch as i,openBlock as n,createElementBlock as s,unref as r,createCommentVNode as d,withDirectives as o,createElementVNode as c,normalizeClass as b,createVNode as u,withCtx as p,Fragment as f,renderList as h,createBlock as y,createTextVNode as v,toDisplayString as m,vShow as g,nextTick as C}from"vue";import{useMessage as L,NAnchor as I,NAnchorLink as S}from"naive-ui";import E from"./components/label-classify.vue.js";import{handleLabelColor as w}from"../../../shared/utils/vexutils.js";import x from"../../../shared/utils/vexutilsExpand.js";const A={key:0,class:"label-disable-wrap"},O=[c("p",{class:"label-disable-title"},"无可选标签",-1),c("p",{class:"label-disable-desc"},"请联系管理员进行标签管理设置",-1)],K={style:{height:"100%"}},j={class:"label-wrap"},k=["id"],T={class:"edit-label-type"};var B=t({__name:"LabelFormContent",props:{item:{default:()=>({})},isEdit:{type:Boolean,default:!0},isLock:{type:Boolean,default:!1},labelSelectedList:null,isChangeWindow:{type:Boolean},getLabelList:{type:Function,default:()=>Promise.resolve({rows:[]})},deleteLabel:{type:Function,default:()=>Promise.resolve({status:!0})},saveLabelItem:{type:Function,default:()=>Promise.resolve({status:!0})},labelOptions:null,sourceType:{default:""},explicit:{type:Boolean,default:!1}},emits:["explicitOnChange","change","updateLabelData"],setup(t,{expose:B,emit:D}){const V=t,F=L(),P=e(null),_=l({editLabelItem:{},inited:!1,labelSelectedEdit:[],labelAnchorKey:"",cacheAnchorKey:"",labelConfig:{}});let N=e(0);const W=a((()=>{if(!_.inited)return!1;let t=_.labelConfig;return!t||Object.keys(t).every((e=>!t[e].itemList))})),$=a((()=>{let t=[].concat(..._.labelSelectedEdit,...V.labelSelectedList);return J(t,"labelId")})),q=a((()=>{const t=$.value||[];return Array.isArray(t)?t.map((t=>t.labelId)):[]})),J=(t,e)=>{let l={};return t.reduce(((t,a)=>(!l[a[e]]&&(l[a[e]]=t.push(a)),t)),[])},R=()=>{if(_.labelSelectedEdit=$.value,"object"==typeof _.labelConfig){Object.keys(_.labelConfig||{}).forEach((t=>{var e;let l=(null==(e=_.labelConfig[t])?void 0:e.itemList)||[];l.length&&l.forEach((t=>{q.value.includes(t.labelId)&&(t.isSelect=!0)}))}))}},z=(t,e)=>{if(!t)return;let l=Object.keys(t)||[];if(!l.length)return;let a=t[l[0]].curKey;if(e&&"string"==typeof e){let[i]=e.split("~"),n=l.find((e=>t[e]&&t[e].curKey&&t[e].curKey.includes(i)));n&&(a=t[n].curKey)}a&&Y(a)},G=(t,e)=>{e.showAdd=!0;const l=t.target.nextElementSibling;C((()=>{var t;null==(t=null==l?void 0:l.firstChild)||t.focus()}))},H=(t,e)=>{setTimeout((()=>{e.addVal?Q(e):e.showAdd=!1}),150)},M=(t,e)=>{e.addVal="",e.showAdd=!1},Q=async t=>{var e;if(!!t.itemList.filter((t=>!(t.isPublic&&1==t.isPublic))).find((e=>e.labelName===t.addVal)))return F.error("标签名称重复!"),!1;let l="";l=(null==(e=t.itemList)?void 0:e.length)?t.itemList[0].parentColor||t.parentColor||"":(null==t?void 0:t.parentColor)||"";const a={type:t.typeId,name:t.addVal,parentColor:l},{status:i}=await V.saveLabelItem(a,t);i&&(F.success("添加成功!"),D("updateLabelData"),t.showAdd=!1)},U=(t,e,l,a)=>{var i;const n=l.itemList,s=l.multipleChoice;let r=(null==(i=_.labelSelectedEdit)?void 0:i.length)&&x.clone(_.labelSelectedEdit,!0)||[];if(t){if(r.some((t=>t.labelId==e.labelId)))return;if(2==s){const{typeId:t,labelId:l}=e;r=r.filter((e=>e.typeId!==t)),n.forEach((t=>{t.labelId!==l&&(t.isSelect=!1)}))}r.push(e)}else{const t=r.findIndex((t=>t.labelId==e.labelId));-1!=t&&r.splice(t,1)}_.labelSelectedEdit=[...r],N.value++,V.explicit&&D("explicitOnChange",[..._.labelSelectedEdit])},X=async t=>{const{status:e}=await V.deleteLabel(t,V.item);if(e){F.success("删除成功!");for(const e in _.labelConfig){const l=_.labelConfig[e].itemList.findIndex((e=>e.labelId==t.labelId));-1!=l&&_.labelConfig[e].itemList.splice(l,1)}const e=_.labelSelectedEdit||[],l=V.labelSelectedList||[];if(e&&e.length){const l=e.findIndex((e=>e.labelId==t.labelId));-1!=l&&e.splice(l,1)}if(l&&l.length){const e=l.findIndex((e=>e.labelId==t.labelId));-1!=e&&l.splice(e,1),D("change",[...l],V.item)}D("updateLabelData")}else F.warning("删除失败")},Y=t=>{t&&setTimeout((()=>{let e,l="#"+t;e=P.value.querySelector("a[href='"+l+"']"),e&&e.click(),_.labelAnchorKey=t}),32)},Z=t=>{t.preventDefault()},tt=t=>{if(!t)return;let e=t.slice(1);_.cacheAnchorKey=e},et=()=>{var t;return null==(t=P.value)?void 0:t.querySelector(".right-label-wrap")};return i((()=>V.labelOptions),(t=>{t&&(()=>{var t;if(V.isLock)return;const e=JSON.parse(JSON.stringify(V.labelOptions));for(let l in e){let a=(null==(t=e[l])?void 0:t.typeId)||"";Object.assign(e[l],{curKey:`${l}_${a}}`})}_.labelConfig=e,C((()=>{let t;R(),V.explicit&&_.inited&&(t=_.labelAnchorKey),z(_.labelConfig,t),_.inited=!0}))})()}),{immediate:!0,deep:!0}),B({resetShowAdd:()=>{let{labelObj:t}=_.editLabelItem;if(t&&Object.keys(t).length)for(let e in t){let l=t[e];Object.assign(l,{showAdd:!1})}},handleLabelForm:t=>{t([..._.labelSelectedEdit||[]])},handleResetOptions:()=>{},hanldeSetLabelItem:(t,e)=>{if("object"==typeof _.labelConfig){Object.keys(_.labelConfig||{}).forEach((l=>{var a;let i=(null==(a=_.labelConfig[l])?void 0:a.itemList)||[];i.length&&i.forEach((l=>{t==l.labelId&&(l.isSelect=e)}))}))}if(!1===e&&Array.isArray(_.labelSelectedEdit)){const e=_.labelSelectedEdit.findIndex((e=>e.labelId==t));-1!=e&&_.labelSelectedEdit.splice(e,1)}}}),(e,l)=>(n(),s("div",{class:"c-label-form-content",ref_key:"labelFormContent",ref:P},[r(W)?(n(),s("div",A,O)):d("v-if",!0),o(c("div",K,[c("div",j,[d(" 表单内嵌打开标签组件的样式 "),d(' <div v-if="explicit" class="explicit-continer">\r\n\t\t\t\t\t<n-tabs :value="state.labelAnchorKey" type="card" @change="labelAnchorTabsOnChange" tab-position="top">\r\n\t\t\t\t\t\t<template v-for="(v, i) in state.labelConfig">\r\n\t\t\t\t\t\t\t<n-tab-pane :name="v.curKey">\r\n\t\t\t\t\t\t\t\t<span slot="tab">\r\n\t\t\t\t\t\t\t\t\t{{ i }}\r\n\t\t\t\t\t\t\t\t\t<span class="edit-label-type">({{ v.multipleChoice == 2 ? \'单\' : \'多\' }}选)</span>\r\n\t\t\t\t\t\t\t\t</span>\r\n\t\t\t\t\t\t\t\t<div class="explicit-label-wrap left-label-wrap">\r\n\t\t\t\t\t\t\t\t\t<div class="edit-label-content">\r\n\t\t\t\t\t\t\t\t\t\t<labelClassify\r\n\t\t\t\t\t\t\t\t\t\t\t:classifyItem="v"\r\n\t\t\t\t\t\t\t\t\t\t\t:handleLabelChange="handleLabelChange"\r\n\t\t\t\t\t\t\t\t\t\t\t:handleLabelColor="handleLabelColor"\r\n\t\t\t\t\t\t\t\t\t\t\t:handleDelLabel="handleDelLabel"\r\n\t\t\t\t\t\t\t\t\t\t\t:hanldeBlur="hanldeBlur"\r\n\t\t\t\t\t\t\t\t\t\t\t:handleAddLabel="handleAddLabel"\r\n\t\t\t\t\t\t\t\t\t\t\t:clearaddVal="clearaddVal"\r\n\t\t\t\t\t\t\t\t\t\t\t:isEdit="isEdit"\r\n\t\t\t\t\t\t\t\t\t\t\t:sourceType="sourceType"\r\n\t\t\t\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t\t\t\t</div>\r\n\t\t\t\t\t\t\t\t</div>\r\n\t\t\t\t\t\t\t</n-tab-pane>\r\n\t\t\t\t\t\t</template>\r\n\t\t\t\t\t</n-tabs>\r\n\t\t\t\t</div> '),d("\r\n\t\t\t\t\t普通标签样式\r\n\t\t\t\t\tv-else\r\n\t\t\t\t\texplicit\r\n\t\t\t\t "),c("div",{class:b(["left-label-wrap",{"total-left-label-wrap":t.isChangeWindow}])},[u(r(I),{"offset-target":et,type:"block",onClick:Z,onChange:tt},{default:p((()=>[(n(!0),s(f,null,h(_.labelConfig,((t,e)=>(n(),y(r(S),{href:`#${t.curKey}`,title:String(e)},null,8,["href","title"])))),256))])),_:1})],2),d(' v-if="!explicit" '),c("div",{class:b(["right-label-wrap",{"total-right-label-wrap":t.isChangeWindow}])},[(n(!0),s(f,null,h(_.labelConfig,((e,l)=>(n(),s("div",{key:l,class:"edit-label-content"},[c("div",{class:"edit-label",id:e.curKey},[v(m(l)+" ",1),c("span",T,"("+m(2==e.multipleChoice?"单":"多")+"选)",1)],8,k),u(E,{classifyItem:e,handleLabelChange:U,handleLabelColor:r(w),handleDelLabel:X,hanldeBlur:H,handleAddLabel:G,clearaddVal:M,isEdit:t.isEdit,sourceType:t.sourceType},null,8,["classifyItem","handleLabelColor","isEdit","sourceType"])])))),128))],2)])],512),[[g,!r(W)]])],512))}});export{B as default};
1
+ import{defineComponent as t,ref as e,reactive as l,computed as a,watch as i,openBlock as n,createElementBlock as s,unref as d,createCommentVNode as o,withDirectives as r,createElementVNode as c,normalizeClass as b,createVNode as u,withCtx as p,Fragment as f,renderList as h,createBlock as y,createTextVNode as v,toDisplayString as m,vShow as g,nextTick as C}from"vue";import{useMessage as L,NAnchor as I,NAnchorLink as S}from"naive-ui";import E from"./components/label-classify.vue.js";import{handleLabelColor as w}from"../../../shared/utils/vexutils.js";import x from"../../../shared/utils/vexutilsExpand.js";const A={key:0,class:"label-disable-wrap"},O=[c("p",{class:"label-disable-title"},"无可选标签",-1),c("p",{class:"label-disable-desc"},"请联系管理员进行标签管理设置",-1)],K={style:{height:"100%"}},j={class:"label-wrap"},k=["id"],T={class:"edit-label-type"};var B=t({__name:"LabelFormContent",props:{item:{default:()=>({})},isEdit:{type:Boolean,default:!0},isLock:{type:Boolean,default:!1},labelSelectedList:null,isChangeWindow:{type:Boolean},getLabelList:{type:Function,default:()=>Promise.resolve({rows:[]})},deleteLabel:{type:Function,default:()=>Promise.resolve({status:!0})},saveLabelItem:{type:Function,default:()=>Promise.resolve({status:!0})},labelOptions:null,sourceType:{default:""},explicit:{type:Boolean,default:!1}},emits:["explicitOnChange","change","updateLabelData"],setup(t,{expose:B,emit:D}){const V=t,F=L(),P=e(null),_=l({editLabelItem:{},inited:!1,labelSelectedEdit:[],labelAnchorKey:"",cacheAnchorKey:"",labelConfig:{}});let N=e(0);const W=a((()=>{if(!_.inited)return!1;let t=_.labelConfig;return!t||Object.keys(t).every((e=>!t[e].itemList))})),$=a((()=>{let t=[].concat(..._.labelSelectedEdit,...V.labelSelectedList);return J(t,"labelId")})),q=a((()=>{const t=$.value||[];return Array.isArray(t)?t.map((t=>t.labelId)):[]})),J=(t,e)=>{let l={};return t.reduce(((t,a)=>(!l[a[e]]&&(l[a[e]]=t.push(a)),t)),[])},R=()=>{if(_.labelSelectedEdit=$.value,"object"==typeof _.labelConfig){Object.keys(_.labelConfig||{}).forEach((t=>{var e;let l=(null==(e=_.labelConfig[t])?void 0:e.itemList)||[];l.length&&l.forEach((t=>{q.value.includes(t.labelId)&&(t.isSelect=!0)}))}))}},z=(t,e)=>{if(!t)return;let l=Object.keys(t)||[];if(!l.length)return;let a=t[l[0]].curKey;if(e&&"string"==typeof e){let[i]=e.split("~"),n=l.find((e=>t[e]&&t[e].curKey&&t[e].curKey.includes(i)));n&&(a=t[n].curKey)}a&&Y(a)},G=(t,e)=>{e.showAdd=!0;const l=t.target.nextElementSibling;C((()=>{var t;null==(t=null==l?void 0:l.firstChild)||t.focus()}))},H=(t,e)=>{setTimeout((()=>{e.addVal?Q(e):e.showAdd=!1}),150)},M=(t,e)=>{e.addVal="",e.showAdd=!1},Q=async t=>{var e;if(!!t.itemList.filter((t=>!(t.isPublic&&1==t.isPublic))).find((e=>e.labelName===t.addVal)))return F.error("标签名称重复!"),!1;let l="";l=(null==(e=t.itemList)?void 0:e.length)?t.itemList[0].parentColor||t.parentColor||"":(null==t?void 0:t.parentColor)||"";const a={type:t.typeId,name:t.addVal,parentColor:l},{status:i}=await V.saveLabelItem(a,t);i&&(F.success("添加成功!"),D("updateLabelData"),t.showAdd=!1)},U=(t,e,l,a)=>{var i;const n=l.itemList,s=l.multipleChoice;let d=(null==(i=_.labelSelectedEdit)?void 0:i.length)&&x.clone(_.labelSelectedEdit,!0)||[];if(t){if(d.some((t=>t.labelId==e.labelId)))return;if(2==s){const{typeId:t,labelId:l}=e;d=d.filter((e=>e.typeId!==t)),n.forEach((t=>{t.labelId!==l&&(t.isSelect=!1)}))}d.push(e)}else{const t=d.findIndex((t=>t.labelId==e.labelId));-1!=t&&d.splice(t,1)}_.labelSelectedEdit=[...d],N.value++,V.explicit&&D("explicitOnChange",[..._.labelSelectedEdit])},X=async t=>{const{status:e}=await V.deleteLabel(t,V.item);if(e){F.success("删除成功!");for(const e in _.labelConfig){const l=_.labelConfig[e].itemList.findIndex((e=>e.labelId==t.labelId));-1!=l&&_.labelConfig[e].itemList.splice(l,1)}const e=_.labelSelectedEdit||[],l=V.labelSelectedList||[];if(e&&e.length){const l=e.findIndex((e=>e.labelId==t.labelId));-1!=l&&e.splice(l,1)}if(l&&l.length){const e=l.findIndex((e=>e.labelId==t.labelId));-1!=e&&l.splice(e,1),D("change",[...l],V.item)}D("updateLabelData")}else F.warning("删除失败")},Y=t=>{t&&setTimeout((()=>{let e,l="#"+t;e=P.value.querySelector("a[href='"+l+"']"),e&&e.click(),_.labelAnchorKey=t}),32)},Z=t=>{t.preventDefault()},tt=t=>{if(!t)return;let e=t.slice(1);_.cacheAnchorKey=e},et=()=>{var t;return null==(t=P.value)?void 0:t.querySelector(".right-label-wrap")};return i((()=>V.labelOptions),(t=>{t&&(()=>{var t;if(V.isLock)return;const e=JSON.parse(JSON.stringify(V.labelOptions));for(let l in e){let a=(null==(t=e[l])?void 0:t.typeId)||"";Object.assign(e[l],{curKey:`${l}_${a}}`})}_.labelConfig=e,C((()=>{let t;R(),V.explicit&&_.inited&&(t=_.labelAnchorKey),z(_.labelConfig,t),_.inited=!0}))})()}),{immediate:!0,deep:!0}),B({resetShowAdd:()=>{let{labelObj:t}=_.editLabelItem;if(t&&Object.keys(t).length)for(let e in t){let l=t[e];Object.assign(l,{showAdd:!1})}},handleLabelForm:t=>{t([..._.labelSelectedEdit||[]])},handleResetOptions:()=>{},hanldeSetLabelItem:(t,e)=>{if("object"==typeof _.labelConfig){Object.keys(_.labelConfig||{}).forEach((l=>{var a;let i=(null==(a=_.labelConfig[l])?void 0:a.itemList)||[];i.length&&i.forEach((l=>{t==l.labelId&&(l.isSelect=e)}))}))}if(!1===e&&Array.isArray(_.labelSelectedEdit)){const e=_.labelSelectedEdit.findIndex((e=>e.labelId==t));-1!=e&&_.labelSelectedEdit.splice(e,1)}}}),(e,l)=>(n(),s("div",{class:"c-label-form-content",ref_key:"labelFormContent",ref:P},[d(W)?(n(),s("div",A,O)):o("v-if",!0),r(c("div",K,[c("div",j,[o(" 表单内嵌打开标签组件的样式 "),o(' <div v-if="explicit" class="explicit-continer">\n\t\t\t\t\t<n-tabs :value="state.labelAnchorKey" type="card" @change="labelAnchorTabsOnChange" tab-position="top">\n\t\t\t\t\t\t<template v-for="(v, i) in state.labelConfig">\n\t\t\t\t\t\t\t<n-tab-pane :name="v.curKey">\n\t\t\t\t\t\t\t\t<span slot="tab">\n\t\t\t\t\t\t\t\t\t{{ i }}\n\t\t\t\t\t\t\t\t\t<span class="edit-label-type">({{ v.multipleChoice == 2 ? \'单\' : \'多\' }}选)</span>\n\t\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t\t\t<div class="explicit-label-wrap left-label-wrap">\n\t\t\t\t\t\t\t\t\t<div class="edit-label-content">\n\t\t\t\t\t\t\t\t\t\t<labelClassify\n\t\t\t\t\t\t\t\t\t\t\t:classifyItem="v"\n\t\t\t\t\t\t\t\t\t\t\t:handleLabelChange="handleLabelChange"\n\t\t\t\t\t\t\t\t\t\t\t:handleLabelColor="handleLabelColor"\n\t\t\t\t\t\t\t\t\t\t\t:handleDelLabel="handleDelLabel"\n\t\t\t\t\t\t\t\t\t\t\t:hanldeBlur="hanldeBlur"\n\t\t\t\t\t\t\t\t\t\t\t:handleAddLabel="handleAddLabel"\n\t\t\t\t\t\t\t\t\t\t\t:clearaddVal="clearaddVal"\n\t\t\t\t\t\t\t\t\t\t\t:isEdit="isEdit"\n\t\t\t\t\t\t\t\t\t\t\t:sourceType="sourceType"\n\t\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t</n-tab-pane>\n\t\t\t\t\t\t</template>\n\t\t\t\t\t</n-tabs>\n\t\t\t\t</div> '),o("\n\t\t\t\t\t普通标签样式\n\t\t\t\t\tv-else\n\t\t\t\t\texplicit\n\t\t\t\t "),c("div",{class:b(["left-label-wrap",{"total-left-label-wrap":t.isChangeWindow}])},[u(d(I),{"offset-target":et,type:"block",onClick:Z,onChange:tt},{default:p((()=>[(n(!0),s(f,null,h(_.labelConfig,((t,e)=>(n(),y(d(S),{href:`#${t.curKey}`,title:String(e)},null,8,["href","title"])))),256))])),_:1})],2),o(' v-if="!explicit" '),c("div",{class:b(["right-label-wrap",{"total-right-label-wrap":t.isChangeWindow}])},[(n(!0),s(f,null,h(_.labelConfig,((e,l)=>(n(),s("div",{key:l,class:"edit-label-content"},[c("div",{class:"edit-label",id:e.curKey},[v(m(l)+" ",1),c("span",T,"("+m(2==e.multipleChoice?"单":"多")+"选)",1)],8,k),u(E,{classifyItem:e,handleLabelChange:U,handleLabelColor:d(w),handleDelLabel:X,hanldeBlur:H,handleAddLabel:G,clearaddVal:M,isEdit:t.isEdit,sourceType:t.sourceType},null,8,["classifyItem","handleLabelColor","isEdit","sourceType"])])))),128))],2)])],512),[[g,!d(W)]])],512))}});export{B as default};
@@ -95,12 +95,6 @@ declare const _default: import("vue").DefineComponent<{
95
95
  };
96
96
  readonly 'onUpdate:value': PropType<import("naive-ui/es/_utils").MaybeArray<(value: (string | number)[], meta: {
97
97
  actionType: "check" | "uncheck";
98
- /**
99
- * 取消勾选树节点
100
- * baseKeys:基准值
101
- * currentTree:当前树节点
102
- * value:树节点的key值
103
- */
104
98
  value: string | number;
105
99
  }) => void>>;
106
100
  readonly onUpdateValue: PropType<import("naive-ui/es/_utils").MaybeArray<(value: (string | number)[], meta: {
@@ -1 +1 @@
1
- import{findAncestor as t}from"../../../../shared/utils/index.js";import{useEventListener as e,useDebounceFn as r}from"@vueuse/core";import{once as s,pick as a,omit as n,isFunction as u,isString as c}from"lodash-es";import{reactive as o,ref as i,unref as l,computed as h,getCurrentInstance as d,inject as p,onBeforeUnmount as g,onDeactivated as b,onActivated as v}from"vue";import{ShortcutStatus as f,InjectionShortcutManager as k}from"../constants/index.js";import{normalizeSignatureInfo as y,getKeySignature as C,getDisplaySignature as m,isInvalidSignature as S,isKeyboardEvent as w,isShortcutProvider as E,isInvalidKeyboardEvent as M}from"../utils/index.js";const K=Symbol("Glob"),j=new Map;class ${constructor(t,e=K){this.shortcutCallbackMap=o(new Map),this.shortcutCache=i({}),this.disabled=!1,this.environmentEle=t||window,j.set(e,this)}static log(t,e=!1){const r=`[ShortcutManager] ${t}`;return!e&&console.warn(r),r}get traverse(){return[...Object.values(this.shortcutCache.value)].sort(((t,e)=>(t.order||0)-(e.order||0)))}query(t){return this.shortcutCache.value[t]}async update(t,e){var r,s;const a=null==(r=this.query(t))?void 0:r.currentKeySignature;e&&u(this.shortcutCache,e);const n=this.query(t);function u(t,e){if(a!==C(e)){if(Object.values(t.value).some((t=>t.currentKeySignature===C(e))))throw`重复的快捷键=> ${m(e)}`;if(S(e))throw`非法的快捷键=>${e.key}`}}n&&(await(null==(s=n.onUpdate)?void 0:s.call(n,t,e?y(e):void 0)),u(this.shortcutCache,e),n.currentKeySignature=C(e),n.shortcutSignature=y(e),this.shortcutCallbackMap.set(n.currentKeySignature,this.shortcutCallbackMap.get(a)),this.shortcutCallbackMap.delete(a))}register(t){const e=this.query(t.key);return e?(e.status=f.ACTIVE,this.shortcutCallbackMap.set(e.currentKeySignature,t.callback),Object.assign(e,a(t,["debounce","debounceOption","label","order","key"])),r(e)):(this.shortcutCache.value[t.key]=n(t,["callback"]),this.shortcutCallbackMap.set(t.currentKeySignature,t.callback),r(this.shortcutCache.value[t.key]));function r(t){return{stop:()=>{t.status=f.INACTIVE},start:()=>{t.status=f.ACTIVE},signature:()=>t.currentKeySignature}}}start(){return this.handle?($.log(`请勿重复启动=>${this}`),this):(this.handle=async e=>{if(!w(e)||this.disabled)return;const r=t(e.target,E);if(r&&r!==l(this.environmentEle)||M(e))return;const s=C(e),a=this.shortcutCallbackMap.get(s);if(!a)return;e.preventDefault();const n=Object.values(this.shortcutCache.value).find((t=>t.currentKeySignature===s));n&&n.status===f.ACTIVE&&!n.disabled&&a()},e(this.environmentEle,"keyup",this.handle,{capture:!0}),this)}destroy(){var t;this.handle&&(null==(t=l(this.environmentEle))||t.removeEventListener("keyup",this.handle,{capture:!0})),this.handle=void 0,this.clear()}clear(){this.shortcutCallbackMap.clear(),this.shortcutCache.value={}}}const I=(new $).start(),O=s((()=>$.log("非setup语境下的shortcut将影响全局"))),A=s((()=>$.log("在非setup语境下使用register函数,组件销毁时可能需要手动调用stop函数使快捷键失活")));function T(t){const e=h((()=>{if(l(t)){const e=j.get(l(t));return e||$.log(`不存在的scope=>${t}, 将使用全局快捷键`),e||I}return d()?p(k,I):(O(),I)}));return{register:function(t){const{stop:s,signature:a,start:n}=l(e).register(function(t){return{...t,shortcutSignature:y(t.shortcutSignature),currentKeySignature:C(t.shortcutSignature),key:function(t){const e=t.key||t.label;if(!c(e))throw new Error($.log(`非法的key类型=>${e}`,!0));return e}(t),status:f.ACTIVE,callback:function(t){var e,s;if(!u(t.callback))throw new Error($.log(`非法的callback类型=>${t.callback}`,!0));return t.debounce?r(t.callback,null!=(s=null==(e=t.debounceOption)?void 0:e.duration)?s:300):t.callback}(t)}}(t));return d()?(g(s),b(s),v(n)):A(),{stop:s,signature:a}},traverse:function(){return l(e).traverse},clear:function(){l(e).clear()},update:function(t,r){return l(e).update(t,r)},updateManagerDisabled:function(t){l(e).disabled=!!t}}}export{K as GlobalShortcutProvider,$ as ShortcutManager,T as useShortcuts};
1
+ import{findAncestor as t}from"../../../../shared/utils/index.js";import{useEventListener as e,useDebounceFn as r}from"@vueuse/core";import{once as s,pick as a,omit as n,isFunction as u,isString as c}from"lodash-es";import{reactive as o,ref as i,unref as l,computed as h,getCurrentInstance as d,inject as p,onBeforeUnmount as g,onDeactivated as b,onActivated as v}from"vue";import{ShortcutStatus as f,InjectionShortcutManager as k}from"../constants/index.js";import{normalizeSignatureInfo as y,getKeySignature as C,getDisplaySignature as m,isInvalidSignature as S,isKeyboardEvent as w,isShortcutProvider as E,isInvalidKeyboardEvent as M}from"../utils/index.js";const K=Symbol("Glob"),j=new Map;class ${constructor(t,e=K){this.shortcutCallbackMap=o(new Map),this.shortcutCache=i({}),this.disabled=!1,this.environmentEle=t||window,j.set(e,this)}static log(t,e=!1){const r=`[ShortcutManager] ${t}`;return!e&&console.warn(r),r}get traverse(){return[...Object.values(this.shortcutCache.value)].sort(((t,e)=>(t.order||0)-(e.order||0)))}query(t){return this.shortcutCache.value[t]}async update(t,e){var r,s;const a=null==(r=this.query(t))?void 0:r.currentKeySignature;e&&u(this.shortcutCache,e);const n=this.query(t);function u(t,e){if(a!==C(e)){if(Object.values(t.value).some((t=>t.currentKeySignature===C(e))))throw`重复的快捷键=> ${m(e)}`;if(S(e))throw`非法的快捷键=>${e.key}`}}n&&(await(null==(s=n.onUpdate)?void 0:s.call(n,t,e?y(e):void 0)),u(this.shortcutCache,e),n.currentKeySignature=C(e),n.shortcutSignature=y(e),this.shortcutCallbackMap.set(n.currentKeySignature,this.shortcutCallbackMap.get(a)),this.shortcutCallbackMap.delete(a))}register(t){const e=this.query(t.key);return e?(e.status=f.ACTIVE,this.shortcutCallbackMap.set(e.currentKeySignature,t.callback),Object.assign(e,a(t,["debounce","debounceOption","label","order","key"])),r(e)):(this.shortcutCache.value[t.key]=n(t,["callback"]),this.shortcutCallbackMap.set(t.currentKeySignature,t.callback),r(this.shortcutCache.value[t.key]));function r(t){return{stop:()=>{t.status=f.INACTIVE},start:()=>{t.status=f.ACTIVE},signature:()=>t.currentKeySignature}}}start(){return this.handle?($.log(`请勿重复启动=>${this}`),this):(this.handle=async e=>{if(!w(e)||this.disabled)return;const r=t(e.target,E);if(r&&r!==l(this.environmentEle)||M(e))return;const s=C(e),a=this.shortcutCallbackMap.get(s);if(!a)return;e.preventDefault();const n=Object.values(this.shortcutCache.value).find((t=>t.currentKeySignature===s));n&&n.status===f.ACTIVE&&!n.disabled&&a(e)},e(this.environmentEle,"keyup",this.handle,{capture:!0}),this)}destroy(){var t;this.handle&&(null==(t=l(this.environmentEle))||t.removeEventListener("keyup",this.handle,{capture:!0})),this.handle=void 0,this.clear()}clear(){this.shortcutCallbackMap.clear(),this.shortcutCache.value={}}}const I=(new $).start(),O=s((()=>$.log("非setup语境下的shortcut将影响全局"))),A=s((()=>$.log("在非setup语境下使用register函数,组件销毁时可能需要手动调用stop函数使快捷键失活")));function T(t){const e=h((()=>{if(l(t)){const e=j.get(l(t));return e||$.log(`不存在的scope=>${t}, 将使用全局快捷键`),e||I}return d()?p(k,I):(O(),I)}));return{register:function(t){const{stop:s,signature:a,start:n}=l(e).register(function(t){return{...t,shortcutSignature:y(t.shortcutSignature),currentKeySignature:C(t.shortcutSignature),key:function(t){const e=t.key||t.label;if(!c(e))throw new Error($.log(`非法的key类型=>${e}`,!0));return e}(t),status:f.ACTIVE,callback:function(t){var e,s;if(!u(t.callback))throw new Error($.log(`非法的callback类型=>${t.callback}`,!0));return t.debounce?r(t.callback,null!=(s=null==(e=t.debounceOption)?void 0:e.duration)?s:300):t.callback}(t)}}(t));return d()?(g(s),b(s),v(n)):A(),{stop:s,signature:a}},traverse:function(){return l(e).traverse},clear:function(){l(e).clear()},update:function(t,r){return l(e).update(t,r)},updateManagerDisabled:function(t){l(e).disabled=!!t}}}export{K as GlobalShortcutProvider,$ as ShortcutManager,T as useShortcuts};
@@ -8,7 +8,7 @@ export interface ShortcutSignatureInfo {
8
8
  export declare type ShortcutOption = {
9
9
  label: string;
10
10
  shortcutSignature: ShortcutSignatureInfo;
11
- callback(): void;
11
+ callback(event: KeyboardEvent): void;
12
12
  } & Partial<{
13
13
  /**
14
14
  * @description 更新快捷键回调
@@ -111,6 +111,9 @@ declare const _default: import("vue").DefineComponent<{
111
111
  readonly type: PropType<(string | number)[] | null>;
112
112
  readonly default: null;
113
113
  };
114
+ /**
115
+ * 拖拽完成
116
+ */
114
117
  readonly disabled: {
115
118
  readonly type: PropType<boolean | undefined>;
116
119
  readonly default: undefined;
package/es/env.d.ts CHANGED
@@ -1,25 +1,25 @@
1
- /// <reference types="vite/client" />
2
-
3
- interface ImportMetaEnv {
4
- readonly VITE_APP_TYPE: string;
5
- // 更多环境变量...
6
- }
7
-
8
- interface ImportMeta {
9
- readonly env: ImportMetaEnv;
10
- }
11
-
12
- declare module '*.vue' {
13
- // @ts-ignore
14
- import type { App, defineComponent } from 'vue';
15
- // // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/ban-types
16
- // // const component: DefineComponent<{}, {}, any>
17
- const component: ReturnType<typeof defineComponent> & {
18
- install(app: App): void;
19
- };
20
- // @ts-ignore
21
- export default component;
22
- }
23
-
24
- declare module '*.js';
25
-
1
+ /// <reference types="vite/client" />
2
+
3
+ interface ImportMetaEnv {
4
+ readonly VITE_APP_TYPE: string;
5
+ // 更多环境变量...
6
+ }
7
+
8
+ interface ImportMeta {
9
+ readonly env: ImportMetaEnv;
10
+ }
11
+
12
+ declare module '*.vue' {
13
+ // @ts-ignore
14
+ import type { App, defineComponent } from 'vue';
15
+ // // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/ban-types
16
+ // // const component: DefineComponent<{}, {}, any>
17
+ const component: ReturnType<typeof defineComponent> & {
18
+ install(app: App): void;
19
+ };
20
+ // @ts-ignore
21
+ export default component;
22
+ }
23
+
24
+ declare module '*.js';
25
+
@@ -1 +1 @@
1
- var A="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAPoAAADCCAMAAABXGy/PAAAABGdBTUEAALGPC/xhBQAAAAFzUkdCAK7OHOkAAALKaVRYdFhNTDpjb20uYWRvYmUueG1wAAAAAAA8eDp4bXBtZXRhIHhtbG5zOng9ImFkb2JlOm5zOm1ldGEvIiB4OnhtcHRrPSJYTVAgQ29yZSA2LjAuMCI+CiAgIDxyZGY6UkRGIHhtbG5zOnJkZj0iaHR0cDovL3d3dy53My5vcmcvMTk5OS8wMi8yMi1yZGYtc3ludGF4LW5zIyI+CiAgICAgIDxyZGY6RGVzY3JpcHRpb24gcmRmOmFib3V0PSIiCiAgICAgICAgICAgIHhtbG5zOnRpZmY9Imh0dHA6Ly9ucy5hZG9iZS5jb20vdGlmZi8xLjAvIgogICAgICAgICAgICB4bWxuczpleGlmPSJodHRwOi8vbnMuYWRvYmUuY29tL2V4aWYvMS4wLyI+CiAgICAgICAgIDx0aWZmOllSZXNvbHV0aW9uPjcyPC90aWZmOllSZXNvbHV0aW9uPgogICAgICAgICA8dGlmZjpSZXNvbHV0aW9uVW5pdD4yPC90aWZmOlJlc29sdXRpb25Vbml0PgogICAgICAgICA8dGlmZjpYUmVzb2x1dGlvbj43MjwvdGlmZjpYUmVzb2x1dGlvbj4KICAgICAgICAgPHRpZmY6T3JpZW50YXRpb24+MTwvdGlmZjpPcmllbnRhdGlvbj4KICAgICAgICAgPGV4aWY6UGl4ZWxYRGltZW5zaW9uPjMxMjwvZXhpZjpQaXhlbFhEaW1lbnNpb24+CiAgICAgICAgIDxleGlmOkNvbG9yU3BhY2U+MTwvZXhpZjpDb2xvclNwYWNlPgogICAgICAgICA8ZXhpZjpQaXhlbFlEaW1lbnNpb24+MjQyPC9leGlmOlBpeGVsWURpbWVuc2lvbj4KICAgICAgPC9yZGY6RGVzY3JpcHRpb24+CiAgIDwvcmRmOlJERj4KPC94OnhtcG1ldGE+CtnKyDAAAAAJcEhZcwAACxMAAAsTAQCanBgAAACEZVhJZk1NACoAAAAIAAUBEgADAAAAAQABAAABGgAFAAAAAQAAAEoBGwAFAAAAAQAAAFIBKAADAAAAAQACAACHaQAEAAAAAQAAAFoAAAAAAAAASAAAAAEAAABIAAAAAQADoAEAAwAAAAEAAQAAoAIABAAAAAEAAAD6oAMABAAAAAEAAADCAAAAAM8fc3cAAAA8UExURUdwTPf39/X29vb29vr6+vX19ff39/X19fHx8fn5+bq5ufb399jY2J6cnOTk5Ojo6Nzc3M3MzGRfXzUvMYIScTkAAAAPdFJOUwAylrcfXET+eA/+2b772WtWGMQAABI1SURBVHja7JwLY7OsDoBfVOSiFtj+/389BAIEsJdt7ep3Znp3bdeHJBBC8N+/U0455ZRTTjnllFNOOeWUU0455ZRTTjnllFNOqWRiM5v+JLgcvEjJ/hz5DNhehoGrv8Ks2DwzlcgBnv8VbUc7z+Agf8Pm+VBBo/wND5d7cuR+fmLsGZ2RkvvoUs4H7o6HZ/y66Rr5Ifs6NUseHXRgT0PnO+zH6+vkUDom9Uytt/iHUzt76iikWlzSAvx4Xl5Z5U+7YnbN1/nxOjo1VLb5Y4fkydY5oeZP8abnW3ylG/Xc7yPffMShHaaWcIGres4X4jfmi//mcwp/yimnnHLK4SIfNc3z3yAlyIxzOY4XZ9a/o+fIvBgBYq3lf4JZyvGCzEIYL9bZC/u/9ueK2RQRHn3tolw++ticc6a8XHWZ48skh7Fnzk89epdWVZf89uUyhhngPHn5b604qMFUzKK9d653dSnyu0X2jWVZRsj78P/IcpsaRadnQw0eXL0lmRZRvSd+SJRWuKz/geEwkKdbeVKhd0PbIKoWEu2H4NV6dOOXnfJa2XF11nH2n7JmPbjVX8S1H1/I7bxnKeUdtAGyIwD7ocnZHaVbQHeN6c6iaRxExZZCeH/g0IEQF7u8gBwuHqBzdXVpPuRcvMFT7ZzGRrD2clx3Vx26jfYbb+Hidcr77sEmO0dNJ3J4sDqh2/nwWidqTk/xWXB11gxsiTx/wus6Po0KdxbRzZFXmJlJuPmJza0A1z6KlcLmFoqqd15s8Xo0/qOjT4XBdtjBZl3z+5mh1hH6Qc8Nt6x1jU14bHR1oaSZO1IHctc47CrCcXy/DUOAtahp6OKC39uodX7kqcwaf75JsJkZn7RRLAujGLUR+lnweu1waDj6NH/ITp0fK/FuPHdNZSs76SymtOShA3lZmXclMTjz7KyetxjCRpvMUC+I8qZQFryM3+1nuLnGHOckkKhwUxvzVzM76iA0FnofOqQgxHB3dKPIFplFmsGJPklzEfvTlsoQUN4UzU18WIQY777tkvScqHOWAl8IP2QR9rmfp3fT3NQK70Cf5IhZg3v/HAJyQanjC3JQNOzD/oynm7O/ZerGhpIwuettIyU2NG9RLNsP12sVyF4VksJ4B7oU4gvoQ6Xu7Oq1LfjBWu5nN0R5qDI3EPiY4ffJzRfQeW/upJNLYJRdjeK+0qF3vBXHqhd0/kzQNOl4t6OZSXdeNQE1+pp9TnmJ3QSVyNn768GcmuULSuVHYZECRD7aVKZRfAelteNNSJcH8rarE2EWR3PYU5WeVjKUjjP1dKWn9Lh5wN4xPhNNLja+JhF9xT6ZnRiwaoQwk81x7OSVLHkOClksJB6eCg9pF0vWBh6YOYHndp28wfDduTzq+yFO63mnp7OmCWZyAIwRMFh3LCILpBOtIuXz8+AHQcjlI53JKKhbJ2RKnQA9O7vd02Ewn/IXUwQnpHzuqof5c1SvlFzGZcEujj+0Bjage2ZoWzGXfLMf3rWeck9n7I3QRoTvUv/Cyu1dmZ+wVqegZA8aFla+GJvUA1/JRemXrL2SncXUW1Z7aDB7I7SxfkhYp5ljsWh7idf8ChYrf44+B2GhAPKhxuTiVhoeAQO+JgPc1GRlu09q51YeFqI9XMdeHwv4848MX0WtI/1D5q687V5z25yqxGdE6TDRv8UOzuHRIzfeUZH9Mcl/5PWe3QsL8pC1l+xDn4wv+DH34slJUK6WlJG5jf41+QE8FDlMwL9X7XCji++UXVLTNmXjKqVDeqe8+WnoHn76ydiu/n0BvF08pEsSZEXCNkrnmM7swQWuQGktZxjM8C485NucjqWX5Mj8e7mdFJ9UCzDJ00usRiIaP7hhwOPszlAY415A96PNHO7gEp7jLZHO6WV+CPdM/Ro61V6JzpwteEZvROnTxYa/EGmaIKEn+keF50769fS45EhTyDZDXVP6avqcdW6DjP4l5l7Y63XPiKoraFNutdKl2Zm3ZFOJAf/m0eNAy/DWgO3BNodfjq4uqHFit7ZamWiUzq11tyZt0A4bfCCOshhfNdIf6d/4epu/NGttfWreOK90VfLXzrpCb3bo7bZl9O/Lb6y7kd49m3jVBN5+02RdrSHad43WK3jhm0qv7PjoUpSf31Oj0rek9EAe4d1VevjA6uNKvLKpes7oA72QN7HpN+oOPXoxdFdbc6d0GbrC9CbXLt6kagPQ+kSEVQ83hL7je76uvtBHcIFac7XsKX1OoUzbQCZ1iNngpZp+KN8Dh6xfiUDUI+tuDsqf3B4+jNH4TeUPO+ZBq2siephO4KV9Ug7goal92zfBpRxwXGScpASvlVZYmG9ovEttgGAkO7OmTE6C7z0+6B2GdRmmEj+RL6+3kWSYd5yUDGN30EG1GR7v0atBg0hOzMHtuHse5UIw96voapqv5sJuzIXXoClQLiCTB8AzReky/7HYRaN47Od1CIFgEhlnkjuX+m/77/2Cvrnss17pwA34wXfxsMdFJ4nVX+D8wRwwL8UCbTSN3AaVa+TZva4n9y8ORwGcZnv6rNA1n58uuFCVkHJde1BqUrpau06wa4Sk919EV2x+LAmyV9iz5sVJ+MWbIwu1of9Dpa97Y0Ce8MRewksK+bX6HXCe8h23ueGm+pmbELg6CwO4pmvUIbUalS7t3uCHqnZlsovDofsFdNh7yB/KCcSMybSvdOOgfsKjW1GxexqJsYx2vdptHufoGBcyc6+uHJnYVzMALTpbCihMuLAhbGFnOZbR5L4f50q+Csz/xejqG8mP6UYpgtmSp+dtPCYWCKxIrHetvh3kHV2teJWTf1laXw8rh1DWilq32fEjuxFzGNGpueta87bSPORp4M/yxfWx35gEqzaAN2Zz24dFdJOGuVyb4cN3nnG1u9LZVXO5iP7iLg5neXQmXK5TPQWO0+aCHno8aYT+cNvnFnv4iL4Z++EbI7IPEMtocnW98duCH67+D/zl3dyXpaBvPMTvQn9+fnwE9C0avPvQmz+C7n7xsYwm4PlZSEba2uxR621V8Qu0rqZbl2nvqMr9xCZx/WHbPj9d7OVCN6c/P3xjfCT0NaI2ii99Y+v00QZY8nX1KvZvT4fk5tGZSWFcCNq1/oDBzQJ40roxaR5btO50Nfrb2uOj1idcBCsPT19BuHXZP4jm7uXfQH599N/NxB5fpG2qMaAr+D15Zs+rNf5hzbMz8kMOIWoL6GMaww1Ot3SiKgVoCT11azqRY71Z6B9dBe9gMyiuexLqg7AH9GkkAC5aOdnHntjz7MTFSXzoF8IuxrjBjfp7mMCHGvrKy1RS/lHQ5zHvXBcWurYUwdcbs6tyMhcNw5tC8oxQPU3JLVQLtl3MYQx+Dugy15r5Id2D63KOipBnyp14uccGCZvaADhubqNqT3vj4ngSboT+/fxcB3YeXRbyiB8bGa/a3fikZBoLMYE2VMdpTD8Xa4cBfxnCeSxSLJHZD6P1bRsRx1lDp6qiPhsDlp1melH2suJuVrILJlvLCAVxU0V/CLUjuq7ON0FzFNXhrPBSSxq3COQyqzTlqb9tlLiaEu3+WGp31Vkm9sXUewOSQ8T5Gu6DLTtH6gZYhpmwH0rtm97VegtPi+Wxghh07kIuztKtUoU/w8eJ03HUPujEbm+zG9Huhoq7eEOmmrDXXWG6C/BzUvsRxnbIUCT2zd1WfN4AVe3rcw5LMWgBUVF68f0w55+Oo/bQs2f2zdmrHt9ujcBFBtutN9FtBNnlkwHMqZN//7Ae9ei2Aq/BgE0Vw4h+U8jejl/MyOH6cqXubPhjVvp74VXZ3eayw9tiAxsE6vX2zhrcEWq66FYq4gs2tgJTB9H6UrY0OY3ooc+K5Bsuu7XbvizZGJKhyTzdFsUbMi7AdY7d3FvVDmtzQ7WJ0UZjL+cpAAPQV7Z35KWmnHqvVhwN3RpKY8AZS3ffAw67MXB7SLuZre6xfFts2vU72aq6yL3lt6J1GvpFZy8LveoN1CStYrtzRpFN6HFubndOLJULKvVOExB37yLfOL6PQ+L/nbXIaa6o0wpq1YGR8q9g/zq5AD3zjqnqZ1u1Z4M3DXewqjJ0LuNTtvncd2zeY+OZMm2rTyRPS+au3rpmTV897Np0pDW22fwen9gml+fxX3rmdDUPu9gJ3VqqT9zeA16+YTFJGbNwp0ce2ZwtnV1dNGq6/bFhG5nd+Q3j8JL6X8XkVeyIXu3gK/U/ML6F616pCAlo3P6JPSzd24q2Hj62/zO89p9bAwzOfWcmVrRHXD0upoRh3Y/zdFWJFsVdOZ9JtwUoOXn80PWfAq7/LG44R4VYygWu/mbwqYH7ojVa+R5jO43BnStlQiVOt+25t0phbBvFG3rWHv+L4OyjS7gt+FPC78M5/RPc23+XWRLukoBF9d+WxdiyGp5rIsICWoCPxUO6qR2kkHs7P9sogJ64SOT/nfWBSllCpLH8yPGjfy9JEvyu0MlHSbFh9ZyzxrblYbXWKa/9X3tnoqYoDANgKaJFOrW+/8tujzRHD0SdmW93v6YICAr9SS9KE3p2vWAdCAm+FxPED/n+3Wps7pO20PFZeGJ310fO+blmr4aMEuqOOSsfK0vhSNQ8/RtVXlD4FoyYj6NTVk9dbC6Pj7ymkq6f3jtmoOiFi7uwy9NRrbyo+pDDE/i8zfN2JFgy4oD7L2jKfD3igO6vVoKXhbio7O7C/EcYzKXFdT9CGHEv6vCT+XXx4PM8swOwo3VOVWk9PVHyzO6edP6FKf4mRgvVdgLC/5qAFlqnyPSw45qfbcdceARw4J5xmb/0hSs9ksRyPbVfSeeyme74ECl+nye9rgm/nFTsszjV0dvkmp89hQ9t1bfEikZZUC2gg76/btSek8OEGk2ZyvLFieI/fiL69kIMn1R274Izrcfx7tArFZN87J4qwEUSqYaAc7vfvh+HzdptttsL+Dt5/qzDfhHkam/yQWg9d8hF1QO6qNcerqd05lyvUeVzdDun4KcGveKRywRz55WXPpPPSs3dsDOFwNWOSsZOSX7zIkbEFaYuqHFkbRvz+/SO4A1oHmn2xX9aWd5X5BHkXZmpQYPt2RuS536IgvxR3rOJEn2n2r9eE7VtKZtQiyiGT13NX9SnYpwjpHTbTcMBb9XI17aRS9W2bTd3/O0ZUttK3U9E5vhVq8/FWOxN5n0PVdeLGADa0Ld71rQNt+WR2AKyzJVPhb8D8KxVDGmRprzkC0Vr9C3/3C8s73Lh/cr1aOcqn4vazO26qPEqNzH4ScUPQjNyrSQLBUWl3YTUsFjoyxIDbNJ5bYE9MM9/1qmgf7TgxYOVh6tN+Zzbr81Q45tnntOnAOfcWkPMGJfGacrk+NLbj0I6hrVOcIPFKutz6zRjRC9Fj9sX7Fnh3Wytn8cSrPSmTK0XmtPyeMgX0Fj+/IwN863K9o7Jtutx37fZGEjtntv4EFc4t+7EnXFl9rMGz0UqGvIoMOlSzLhLSxc/Yq6ZgyCdXy5qBD1L/XVtVhdwro0dWm/GJJWrBN5I5AlGca9FxIN80VJvPTELNsBXCy7hSi3s6i3FPP1Ls2sVr4Cnt5ZcbjBd1+CumdQdG2523wK2AX2bpPACO4Gj1hSRaJwrpjiP/iOSdJ/x784VJfuj6HglfxZUzl0zdcSO1EblECrTtMAy9sUoFuiXyrjtsnAXPxdu/fbUBjAqP/Jbt9fpXHghwmdZW6b2xzCAj+SGVWBHuS8FenbsI2bSyQ/6+uFbsvOfhVwEsd/BaYA+XwFbPpXkz9LyE/RAjMwe2hqbsYnbADjpmxwUVZHCDTyK66lpy7eIbcsBZz/NQ8Rl4FdGiE3XoRazLzy5s9xdnZmDN3iyj5rLb4jU/yHxl+Fh0oeoQduGuN+P03rKr1CWYeIbq73il8nlT+dHF1oLWUC/egFKtSujTSQH7Im8E5Wxl1GvY7iepl8VSgEvXoKgbka9XD52z/Pb6MFZ4QQ+GxdIBYcuQsTOafxb4gGGbRPNcTb1PbxM+95fqk2T2IoeZVIygJSw5IawKUJ+43xK4PHaMY881QmngqexN/31LZu+nxG4FDlfMH9iwPvNAugrzXFW+79Zq5XGvtamVW6FU5TuZUDYKgkYGNI/8DjlCVnU1/ZeRF//FjnnaUX7lnNl7fKNso9+YvNiY2PH3jEO/KVxstOBg58OnLW599nQ18aItLWx9tfJv/V61yFDhgwZMmTIkCFDhgwZMmTIkCFDhgwZMuT/kz/btvK0Sf2ZHQAAAABJRU5ErkJggg==";export{A as default};
1
+ var f="data:image/png;base64,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";export{f as default};