hzzt-kfb-slide 0.0.1 → 0.0.3

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 (180) hide show
  1. package/dist/components/annotateBNqnmoMI.js +1 -0
  2. package/dist/components/{annotateDDGAeaL1.js → annotateCdbWkykl.js} +1 -1
  3. package/dist/components/{annotateCVLkqudX.js → annotateCtCMs-ef.js} +1 -1
  4. package/dist/components/{annotateCYZEG4by.js → annotateD0egGTin.js} +46 -46
  5. package/dist/components/{arrow6aTSOsV2.js → arrowC9aIuvQe.js} +1 -1
  6. package/dist/components/{arrowDOQZx-5i.js → arrowDG9uJA9k.js} +1 -1
  7. package/dist/components/arrowDownC6bqk-lY.js +1 -0
  8. package/dist/components/arrowDownGmouwhLr.js +18 -0
  9. package/dist/components/arrowLeftBOXSO3ql.js +1 -0
  10. package/dist/components/arrowLeftDtz6Sjds.js +18 -0
  11. package/dist/components/arrowRightDSH6IzNE.js +19 -0
  12. package/dist/components/arrowRightHppOESBK.js +1 -0
  13. package/dist/components/arrowUpCHU6h7kZ.js +18 -0
  14. package/dist/components/arrowUpCuroteRQ.js +1 -0
  15. package/dist/components/channelB8E2yoQ7.js +35 -0
  16. package/dist/components/channelNB37p_zP.js +1 -0
  17. package/dist/components/{checkDT-yvng0.js → checkLEGWCAxP.js} +1 -1
  18. package/dist/components/{checkCazbS-c6.js → checkseAngK1P.js} +1 -1
  19. package/dist/components/{configB5XxbCMh.js → configCCGG0UB4.js} +3 -3
  20. package/dist/components/{configOyvUhGVP.js → configDLPuCFH1.js} +1 -1
  21. package/dist/components/customBbYfn41m.js +1 -0
  22. package/dist/components/customDo3qaJ1U.js +39 -0
  23. package/dist/components/deleteD2WtxFlL.js +1 -0
  24. package/dist/components/deleteMXhIkgfB.js +25 -0
  25. package/dist/components/dotBgHmd0mz.js +1 -0
  26. package/dist/components/{dot1kt2iBMi.js → dotDJRbd0BV.js} +1 -1
  27. package/dist/components/{dotBzY_NqlA.js → dotEN0Eh5Op.js} +1 -1
  28. package/dist/components/{dotDKLgWFRD.js → dotg0NvS9Ck.js} +29 -29
  29. package/dist/components/{downloadCshCNWAW.js → downloadCaAoF5Or.js} +1 -1
  30. package/dist/components/{downloadBWFjb3Fj.js → downloadCaJyQTwU.js} +1 -1
  31. package/dist/components/{downloadDmK-mUW4.js → downloadD_Bmec44.js} +19 -19
  32. package/dist/components/downloadGX-_YQez.js +1 -0
  33. package/dist/components/{flipDUjW55Vh.js → flipBkZOXGJN.js} +5 -5
  34. package/dist/components/{flipDA2I3h_e.js → flipCC_nhFBO.js} +1 -1
  35. package/dist/components/{fullscreenDUzPX17n.js → fullscreenC380_EU3.js} +1 -1
  36. package/dist/components/fullscreenDUzxAfXo.js +1 -0
  37. package/dist/components/{fullscreenQqpG_OS1.js → fullscreenDjH9QoF2.js} +15 -16
  38. package/dist/components/{fullscreenDyMv4lzQ.js → fullscreenEVnYx--1.js} +1 -1
  39. package/dist/components/indexD_phlegk.js +30 -0
  40. package/dist/components/indexDdIv5EKS.js +11179 -0
  41. package/dist/components/{infoBJj_CFzD.js → infoBFIavOPB.js} +3 -3
  42. package/dist/components/{infoB_-hN7Fr.js → infoCp5QUeZm.js} +1 -1
  43. package/dist/components/levelC1Ud4D0B.js +35 -0
  44. package/dist/components/levelZfTb2sPf.js +1 -0
  45. package/dist/components/microscopeBeixYxYI.js +1 -0
  46. package/dist/components/{microscopeQHJ_dU_L.js → microscopeCmqOpPc4.js} +13 -13
  47. package/dist/components/{microscopeBsAciWA9.js → microscopeDZWMA8RW.js} +1 -1
  48. package/dist/components/{microscopeCJwTonZV.js → microscopeXeEtWd1W.js} +1 -1
  49. package/dist/components/moveB1DiH4PI.js +74 -0
  50. package/dist/components/{moveDxSu5JyS.js → moveBea2jbYH.js} +1 -1
  51. package/dist/components/moveBzePKtM6.js +1 -0
  52. package/dist/components/{moveUEjGdGB8.js → moveDwsVnmQi.js} +1 -1
  53. package/dist/components/{nextUojG6t-0.js → nextC52pb5sE.js} +1 -1
  54. package/dist/components/{nextXkdsQP9z.js → nextDYmCUlzZ.js} +3 -3
  55. package/dist/components/{prevhOkmcBJ2.js → prevT7x-zgKu.js} +1 -1
  56. package/dist/components/{prevBjMmvSpY.js → prevv0XqJ_iF.js} +3 -3
  57. package/dist/components/{processCaqwpK4F.js → process0WK-TxPd.js} +24 -24
  58. package/dist/components/{processRSLucFP3.js → processBiTw6vPV.js} +1 -1
  59. package/dist/components/processCmTYHlH3.js +1 -0
  60. package/dist/components/{processCigaxNDK.js → processDW13CjX-.js} +1 -1
  61. package/dist/components/rotateBViLTXxd.js +1 -0
  62. package/dist/components/{rotateBgPHUO92.js → rotateCbkJvPFi.js} +1 -1
  63. package/dist/components/{rotateCIEP8gXK.js → rotateDlk_Qk4Y.js} +1 -1
  64. package/dist/components/rotateLcm0V_kN.js +130 -0
  65. package/dist/components/setting3RU3dG2s.js +1 -0
  66. package/dist/components/settingCZkmIJSr.js +147 -0
  67. package/dist/components/{settingDEgu1o7Z.js → settingDVPXWTEf.js} +1 -1
  68. package/dist/components/{settingBwRgwtCV.js → settingDyHmqPh3.js} +1 -1
  69. package/dist/components/{tailor0e5PmiKv.js → tailorBgKlGdZj.js} +1 -1
  70. package/dist/components/{tailorA3InL_3L.js → tailorDHg9ZsXw.js} +1 -1
  71. package/dist/components/useCommonB2St3W5r.js +1 -0
  72. package/dist/components/useCommonCwKio4Jh.js +22 -0
  73. package/dist/components/{zoomD7pWi-kc.js → zoomBKsf5GkB.js} +1 -1
  74. package/dist/components/{zoomCOaNFEUh.js → zoomCnS6EmhN.js} +2 -2
  75. package/dist/components/zoomIn73PRBFpz.js +1 -0
  76. package/dist/components/zoomInDWX2Osc6.js +30 -0
  77. package/dist/components/zoomOutD8Mlbb8q.js +1 -0
  78. package/dist/components/zoomOutgHFV2sxE.js +32 -0
  79. package/dist/index.cjs.js +1 -1
  80. package/dist/index.css +1 -1
  81. package/dist/index.es.js +3 -3
  82. package/package.json +9 -7
  83. package/types/components/KfbIcon.vue.d.ts +12 -0
  84. package/types/components/KfbImage.vue.d.ts +47 -0
  85. package/types/components/KfbSlideList.vue.d.ts +24 -0
  86. package/types/components/KfbToolConfig.vue.d.ts +13 -0
  87. package/types/components/KfbToolbox.vue.d.ts +26 -0
  88. package/types/components/KfbView/KfbChannel.vue.d.ts +16 -0
  89. package/types/components/KfbView/KfbKeyword.vue.d.ts +2 -0
  90. package/types/components/KfbView/KfbLabel.vue.d.ts +13 -0
  91. package/types/components/KfbView/KfbLevel.vue.d.ts +14 -0
  92. package/types/components/KfbView/KfbMenu.vue.d.ts +10 -0
  93. package/types/components/KfbView/KfbMicroscope.vue.d.ts +14 -0
  94. package/types/components/KfbView/index.d.ts +237 -0
  95. package/types/components/KfbView/index.vue.d.ts +271 -0
  96. package/types/components/KfbView/useDot.d.ts +3 -0
  97. package/types/components/KfbView/useHotmap.d.ts +38 -0
  98. package/types/components/KfbView/useImageProcess.d.ts +15 -0
  99. package/types/components/KfbView/useLabel.d.ts +85 -0
  100. package/types/components/KfbView/useMove.d.ts +9 -0
  101. package/types/components/KfbView/usePointer.d.ts +12 -0
  102. package/types/components/KfbView/useSync.d.ts +5 -0
  103. package/types/components/KfbView/useTailor.d.ts +7 -0
  104. package/types/components/ai/list.vue.d.ts +13 -0
  105. package/types/components/ai/useAi.d.ts +87 -0
  106. package/types/components/icon/annotate.vue.d.ts +2 -0
  107. package/types/components/icon/arrow.vue.d.ts +2 -0
  108. package/types/components/icon/arrowDown.vue.d.ts +2 -0
  109. package/types/components/icon/arrowLeft.vue.d.ts +2 -0
  110. package/types/components/icon/arrowRight.vue.d.ts +2 -0
  111. package/types/components/icon/arrowUp.vue.d.ts +2 -0
  112. package/types/components/icon/channel.vue.d.ts +2 -0
  113. package/types/components/icon/check.vue.d.ts +2 -0
  114. package/types/components/icon/config.vue.d.ts +2 -0
  115. package/types/components/icon/delete.vue.d.ts +2 -0
  116. package/types/components/icon/dot.vue.d.ts +2 -0
  117. package/types/components/icon/download.vue.d.ts +2 -0
  118. package/types/components/icon/flip.vue.d.ts +2 -0
  119. package/types/components/icon/fullscreen.vue.d.ts +2 -0
  120. package/types/components/icon/index.d.ts +5 -0
  121. package/types/components/icon/info.vue.d.ts +2 -0
  122. package/types/components/icon/level.vue.d.ts +2 -0
  123. package/types/components/icon/list.vue.d.ts +2 -0
  124. package/types/components/icon/menu.vue.d.ts +2 -0
  125. package/types/components/icon/microscope.vue.d.ts +2 -0
  126. package/types/components/icon/move.vue.d.ts +2 -0
  127. package/types/components/icon/next.vue.d.ts +2 -0
  128. package/types/components/icon/prev.vue.d.ts +2 -0
  129. package/types/components/icon/process.vue.d.ts +2 -0
  130. package/types/components/icon/rotate.vue.d.ts +2 -0
  131. package/types/components/icon/setting.vue.d.ts +2 -0
  132. package/types/components/icon/tailor.vue.d.ts +2 -0
  133. package/types/components/icon/zoomIn.vue.d.ts +2 -0
  134. package/types/components/toolbox/annotate.vue.d.ts +10 -0
  135. package/types/components/toolbox/custom.vue.d.ts +20 -0
  136. package/types/components/toolbox/dot.vue.d.ts +10 -0
  137. package/types/components/toolbox/download.vue.d.ts +10 -0
  138. package/types/components/toolbox/fullscreen.vue.d.ts +10 -0
  139. package/types/components/toolbox/instances.d.ts +17 -0
  140. package/types/components/toolbox/microscope.vue.d.ts +15 -0
  141. package/types/components/toolbox/move.vue.d.ts +10 -0
  142. package/types/components/toolbox/process.vue.d.ts +12 -0
  143. package/types/components/toolbox/rotate.vue.d.ts +6 -0
  144. package/types/components/toolbox/setting.vue.d.ts +10 -0
  145. package/types/components/toolbox/useCommon.d.ts +9 -0
  146. package/types/components/toolbox/zoom.vue.d.ts +6 -0
  147. package/types/index.d.ts +911 -0
  148. package/types/index.vue.d.ts +53 -0
  149. package/types/instances.d.ts +70 -0
  150. package/types/plugins/i18n.d.ts +6 -0
  151. package/dist/components/annotateCX9GkmOg.js +0 -1
  152. package/dist/components/configB7FH_Li-.js +0 -1
  153. package/dist/components/configCPI2rG9d.js +0 -40
  154. package/dist/components/custom-mCr5M_c.js +0 -1
  155. package/dist/components/customc4LeZve5.js +0 -40
  156. package/dist/components/dotB1Nn2uO0.js +0 -1
  157. package/dist/components/download_UT5bsTk.js +0 -1
  158. package/dist/components/flipCbiBH_o3.js +0 -1
  159. package/dist/components/flipDUZT4wIY.js +0 -40
  160. package/dist/components/fullscreenD6c_uo6X.js +0 -1
  161. package/dist/components/indexDvexHnyj.js +0 -10651
  162. package/dist/components/indexNnjbVZ_m.js +0 -30
  163. package/dist/components/infoBNm69fP0.js +0 -41
  164. package/dist/components/infoDvOItrdO.js +0 -1
  165. package/dist/components/microscopeDQl6TocT.js +0 -1
  166. package/dist/components/moveBzYl-c4_.js +0 -1
  167. package/dist/components/moveCe8MSGn0.js +0 -74
  168. package/dist/components/nextCGxHdIok.js +0 -1
  169. package/dist/components/nextDeuoTRY7.js +0 -40
  170. package/dist/components/prevBrrsxCoK.js +0 -40
  171. package/dist/components/prevDCKFCMZw.js +0 -1
  172. package/dist/components/processCUjiU4DT.js +0 -1
  173. package/dist/components/rotateCt5rJEBm.js +0 -1
  174. package/dist/components/rotateWiDuyX22.js +0 -130
  175. package/dist/components/setting8L58q_d4.js +0 -134
  176. package/dist/components/settingCgwUdss3.js +0 -1
  177. package/dist/components/tailorBB_gVLzK.js +0 -40
  178. package/dist/components/tailorCeILe_eG.js +0 -1
  179. package/dist/components/useCommonDK4IjSxd.js +0 -17
  180. package/dist/components/useCommon_CFgwTZy.js +0 -1
@@ -0,0 +1,53 @@
1
+ import { DigitalSlide, Props } from "@/instances.ts";
2
+ type __VLS_Props = Props;
3
+ type __VLS_PublicProps = __VLS_Props & {
4
+ 'index'?: number;
5
+ };
6
+ declare var __VLS_8: {}, __VLS_34: {}, __VLS_48: {
7
+ slide: DigitalSlide;
8
+ }, __VLS_63: {
9
+ slide: DigitalSlide;
10
+ }, __VLS_74: {
11
+ slide: DigitalSlide;
12
+ }, __VLS_85: {};
13
+ type __VLS_Slots = {} & {
14
+ left?: (props: typeof __VLS_8) => any;
15
+ } & {
16
+ right?: (props: typeof __VLS_34) => any;
17
+ } & {
18
+ list?: (props: typeof __VLS_48) => any;
19
+ } & {
20
+ kfb?: (props: typeof __VLS_63) => any;
21
+ } & {
22
+ kfb?: (props: typeof __VLS_74) => any;
23
+ } & {
24
+ default?: (props: typeof __VLS_85) => any;
25
+ };
26
+ declare const __VLS_component: import("vue").DefineComponent<__VLS_PublicProps, {
27
+ divide: import("vue").Ref<boolean, boolean>;
28
+ slide: import("vue").ComputedRef<DigitalSlide>;
29
+ kfbViewRef: import("vue").ComputedRef<any>;
30
+ enableAI: import("vue").ComputedRef<number | false>;
31
+ }, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
32
+ "update:index": (value: number) => any;
33
+ } & {
34
+ tool: (action: string, value?: any) => any;
35
+ }, string, import("vue").PublicProps, Readonly<__VLS_PublicProps> & Readonly<{
36
+ onTool?: ((action: string, value?: any) => any) | undefined;
37
+ "onUpdate:index"?: ((value: number) => any) | undefined;
38
+ }>, {
39
+ teleport: boolean;
40
+ slides: DigitalSlide[];
41
+ menus: (string | import("@/instances.ts").ToolboxMenu)[];
42
+ showKeyboard: boolean;
43
+ showMenuText: boolean;
44
+ showKfbLabel: boolean;
45
+ showList: boolean;
46
+ }, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
47
+ declare const _default: __VLS_WithSlots<typeof __VLS_component, __VLS_Slots>;
48
+ export default _default;
49
+ type __VLS_WithSlots<T, S> = T & {
50
+ new (): {
51
+ $slots: S;
52
+ };
53
+ };
@@ -0,0 +1,70 @@
1
+ import type { VNode } from "vue";
2
+ import { FileInterface, KfbProps, Label, Menu, Microscope, Process, TileParams } from "@/components/KfbView/index.ts";
3
+ export type ToolboxMenu = {
4
+ name: string;
5
+ props?: Record<string, unknown>;
6
+ slots?: Record<string, (...args: any[]) => VNode | string | null | undefined>;
7
+ show?: boolean;
8
+ };
9
+ export interface DigitalSlide {
10
+ id?: number;
11
+ file?: string;
12
+ labelImg?: string;
13
+ previewImg?: string;
14
+ check?: boolean;
15
+ name?: string;
16
+ read?: boolean;
17
+ score?: string;
18
+ gradeColor?: string;
19
+ grade?: number;
20
+ analysis?: {
21
+ id: number;
22
+ class: string;
23
+ result: string;
24
+ };
25
+ slide_id?: number;
26
+ pathology_id?: number;
27
+ pathology_number?: string;
28
+ paraffin_block_number?: string;
29
+ reagent?: string;
30
+ angle?: number;
31
+ hotmap?: {
32
+ type: string;
33
+ file: string;
34
+ info?: [];
35
+ roi?: [];
36
+ };
37
+ children?: string[];
38
+ }
39
+ export interface Kfb {
40
+ fileHandle?: (slide: DigitalSlide) => Promise<FileInterface>;
41
+ labelHandle?: (type: string, slide: DigitalSlide, data?: any) => Promise<Label[]>;
42
+ navigatorHandle?: (type: string, slide: DigitalSlide, data?: any) => Promise<Label[]>;
43
+ tileHandle?: (params: TileParams) => string;
44
+ pathologyHandle: (slide: DigitalSlide) => Promise<boolean>;
45
+ options?: Record<string, any>;
46
+ process?: Process;
47
+ microscope?: Microscope;
48
+ menus?: Menu[];
49
+ handle?: (slide: DigitalSlide, options: KfbProps) => KfbProps;
50
+ }
51
+ export interface Props {
52
+ menus: (string | ToolboxMenu)[];
53
+ kfb: Kfb;
54
+ slides: DigitalSlide[];
55
+ ai: {
56
+ enable: boolean;
57
+ default?: boolean;
58
+ handle: (type: string, slide: DigitalSlide) => Promise<Label[]>;
59
+ };
60
+ teleport?: boolean;
61
+ process?: Process;
62
+ microscope?: Microscope;
63
+ showList?: boolean;
64
+ showKfbLabel?: boolean;
65
+ showKeyboard?: boolean;
66
+ showMenuText?: boolean;
67
+ }
68
+ export interface Emits {
69
+ (e: 'tool', action: string, value?: any): void;
70
+ }
@@ -0,0 +1,6 @@
1
+ import type { Plugin } from 'vue';
2
+ export declare function useLocalI18n(): {
3
+ locale: import("vue").WritableComputedRef<string, string> | undefined;
4
+ t: (key: string) => string;
5
+ };
6
+ export declare const i18nPlugin: Plugin;
@@ -1 +0,0 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("vue"),t=require("./indexNnjbVZ_m.js"),x=require("./useCommon_CFgwTZy.js"),o=require("element-plus"),v=require("./annotateCVLkqudX.js"),C=["onClick"],h=["src","alt"],b=e.defineComponent({name:"ToolAnnotate",__name:"annotate",props:e.mergeDefaults({size:{},text:{},name:{},component:{},isPrevent:{type:Boolean},callback:{type:Function}},t.defaultProps),emits:["tool"],setup(c,{emit:i}){const u=c,d=i,{t:l,textClass:f}=x.useCommon(u),s={line:t.line,arrow:t.arrow,bilateral:t.bilateral,rectangle:t.rectangle,ellipse:t.ellipse,polygon:t.polygon,star:t.star,flag:t.flag,dot:t.dot,font:t.font},p=Object.keys(s).map(n=>({name:n,src:s[n]})),a=e.ref(!1);function m(n){a.value=!1,d("tool","annotate",{tool:n.substring(0,1).toLocaleUpperCase()+n.substring(1)})}function g(){a.value=!a.value}return(n,E)=>(e.openBlock(),e.createBlock(e.unref(o.ElPopover),{visible:a.value,"popper-class":"el-popover-padding-0",placement:"bottom",width:"220px",trigger:"click"},{reference:e.withCtx(()=>[e.createElementVNode("div",{class:"hzzt-kfb-toolbox__icon",onClick:g},[e.createVNode(e.unref(o.ElIcon),{size:n.size},{default:e.withCtx(()=>[e.createVNode(v.default)]),_:1},8,["size"]),e.createElementVNode("div",{class:e.normalizeClass(e.unref(f))},e.toDisplayString(e.unref(l)(n.text||"标注")),3)])]),default:e.withCtx(()=>[e.createVNode(e.unref(o.ElCard),{shadow:"never",header:e.unref(l)("标注工具"),"body-style":{padding:"8px"}},{default:e.withCtx(()=>[e.createElementVNode("div",null,[e.createVNode(e.unref(o.ElText),{type:"danger"},{default:e.withCtx(()=>[e.createTextVNode(e.toDisplayString(e.unref(l)("按ESC可退出标注模式")),1)]),_:1})]),e.createElementVNode("div",null,[e.createVNode(e.unref(o.ElText),{type:"danger"},{default:e.withCtx(()=>[e.createTextVNode(e.toDisplayString(e.unref(l)("点击标注按Delete键可删除标注")),1)]),_:1})]),e.createVNode(e.unref(o.ElRow),null,{default:e.withCtx(()=>[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(e.unref(p),(r,_)=>(e.openBlock(),e.createBlock(e.unref(o.ElCol),{key:_,class:"flex justify-content-center align-items-center",span:8},{default:e.withCtx(()=>[e.createElementVNode("div",{class:"hzzt-kfb-toolbox-annotate-img",onClick:k=>m(r.name)},[e.createElementVNode("img",{style:{width:"100%"},src:r.src,alt:r.name},null,8,h)],8,C)]),_:2},1024))),128))]),_:1})]),_:1},8,["header"])]),_:1},8,["visible"]))}}),y=t._export_sfc(b,[["__scopeId","data-v-55085851"]]);exports.default=y;
@@ -1 +0,0 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("vue"),a=require("element-plus"),u=require("./configOyvUhGVP.js"),m=require("./indexNnjbVZ_m.js"),f=require("./useCommon_CFgwTZy.js"),d=e.defineComponent({name:"ToolConfig",__name:"config",props:e.mergeDefaults({size:{},text:{},name:{},component:{},isPrevent:{type:Boolean},callback:{type:Function}},m.defaultProps),emits:["tool"],setup(t,{emit:n}){const s=t,c=n,{t:i,textClass:r}=f.useCommon(s),l=()=>{c("tool","config")};return(o,p)=>(e.openBlock(),e.createElementBlock("div",{class:"hzzt-kfb-toolbox__icon",onClick:l},[e.createVNode(e.unref(a.ElIcon),{size:o.size},{default:e.withCtx(()=>[e.createVNode(u.default)]),_:1},8,["size"]),e.createElementVNode("div",{class:e.normalizeClass(e.unref(r))},e.toDisplayString(e.unref(i)(o.text||"配置")),3)]))}});exports.default=d;
@@ -1,40 +0,0 @@
1
- import { defineComponent as c, mergeDefaults as p, createElementBlock as f, openBlock as u, createVNode as t, createElementVNode as d, unref as o, withCtx as z, normalizeClass as C, toDisplayString as _ } from "vue";
2
- import { ElIcon as g } from "element-plus";
3
- import k from "./configB5XxbCMh.js";
4
- import { d as x } from "./indexDvexHnyj.js";
5
- import { u as h } from "./useCommonDK4IjSxd.js";
6
- const N = /* @__PURE__ */ c({
7
- name: "ToolConfig",
8
- __name: "config",
9
- props: /* @__PURE__ */ p({
10
- size: {},
11
- text: {},
12
- name: {},
13
- component: {},
14
- isPrevent: { type: Boolean },
15
- callback: { type: Function }
16
- }, x),
17
- emits: ["tool"],
18
- setup(n, { emit: s }) {
19
- const i = n, r = s, { t: a, textClass: l } = h(i), m = () => {
20
- r("tool", "config");
21
- };
22
- return (e, b) => (u(), f("div", {
23
- class: "hzzt-kfb-toolbox__icon",
24
- onClick: m
25
- }, [
26
- t(o(g), { size: e.size }, {
27
- default: z(() => [
28
- t(k)
29
- ]),
30
- _: 1
31
- }, 8, ["size"]),
32
- d("div", {
33
- class: C(o(l))
34
- }, _(o(a)(e.text || "配置")), 3)
35
- ]));
36
- }
37
- });
38
- export {
39
- N as default
40
- };
@@ -1 +0,0 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("vue"),m=require("./indexNnjbVZ_m.js"),u=require("./useCommon_CFgwTZy.js"),f=e.defineComponent({name:"ToolCustom",__name:"custom",props:e.mergeDefaults({size:{},text:{},name:{},component:{},isPrevent:{type:Boolean},callback:{type:Function}},m.defaultProps),emits:["tool"],setup(l,{emit:s}){const t=l,r=s,{t:c,textClass:a}=u.useCommon(t),n=e.useTemplateRef("toolRef");function i(){r("tool",t.name||"",n.value)}return(o,p)=>(e.openBlock(),e.createElementBlock("div",{ref_key:"toolRef",ref:n,class:"hzzt-kfb-toolbox__icon",onClick:i},[(e.openBlock(),e.createBlock(e.resolveDynamicComponent(o.component),{size:o.size},null,8,["size"])),e.createElementVNode("div",{class:e.normalizeClass(e.unref(a))},[e.renderSlot(o.$slots,"default",{},()=>[e.createTextVNode(e.toDisplayString(e.unref(c)(o.text||" ")),1)])],2)],512))}});exports.default=f;
@@ -1,40 +0,0 @@
1
- import { defineComponent as p, mergeDefaults as f, useTemplateRef as u, createElementBlock as d, openBlock as n, createBlock as k, createElementVNode as z, resolveDynamicComponent as C, normalizeClass as v, unref as s, renderSlot as y, createTextVNode as _, toDisplayString as B } from "vue";
2
- import { d as R } from "./indexDvexHnyj.js";
3
- import { u as T } from "./useCommonDK4IjSxd.js";
4
- const g = /* @__PURE__ */ p({
5
- name: "ToolCustom",
6
- __name: "custom",
7
- props: /* @__PURE__ */ f({
8
- size: {},
9
- text: {},
10
- name: {},
11
- component: {},
12
- isPrevent: { type: Boolean },
13
- callback: { type: Function }
14
- }, R),
15
- emits: ["tool"],
16
- setup(l, { emit: a }) {
17
- const o = l, m = a, { t: r, textClass: c } = T(o), t = u("toolRef");
18
- function i() {
19
- m("tool", o.name || "", t.value);
20
- }
21
- return (e, b) => (n(), d("div", {
22
- ref_key: "toolRef",
23
- ref: t,
24
- class: "hzzt-kfb-toolbox__icon",
25
- onClick: i
26
- }, [
27
- (n(), k(C(e.component), { size: e.size }, null, 8, ["size"])),
28
- z("div", {
29
- class: v(s(c))
30
- }, [
31
- y(e.$slots, "default", {}, () => [
32
- _(B(s(r)(e.text || " ")), 1)
33
- ])
34
- ], 2)
35
- ], 512));
36
- }
37
- });
38
- export {
39
- g as default
40
- };
@@ -1 +0,0 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("vue"),d=require("./indexNnjbVZ_m.js"),b=require("./useCommon_CFgwTZy.js"),C=require("./dotBzY_NqlA.js"),_=require("./checkCazbS-c6.js"),r=require("element-plus"),E={class:"margin-b-1"},g={class:"flex align-items-center"},x=["onClick"],y=e.defineComponent({name:"ToolDot",__name:"dot",props:e.mergeDefaults({size:{},text:{},name:{},component:{},isPrevent:{type:Boolean},callback:{type:Function}},d.defaultProps),emits:["tool"],setup(f,{emit:v}){const k=f,i=v,{t:u,textClass:m}=b.useCommon(k),n=e.ref(!1),c=e.ref([{label:"#004BFF",value:0,checked:!1},{label:"#FF4B40",value:0,checked:!1},{label:"#FFAA00",value:0,checked:!1},{label:"#51C964",value:0,checked:!1},{label:"#00BEFF",value:0,checked:!1},{label:"#8C58CE",value:0,checked:!1},{label:"#F261A7",value:0,checked:!1}]),s=e.inject("kfbViewRef");e.watch(()=>{var l,t;return(t=(l=s==null?void 0:s.value)==null?void 0:l.kfbView)==null?void 0:t.labelList},l=>{c.value.forEach(t=>{var o;t.value=(o=(l??[]).filter(a=>(a==null?void 0:a.custom)&&(a==null?void 0:a.strokeStyle)===t.label&&(a==null?void 0:a.tool)==="Dot"))==null?void 0:o.length})});function p(l){c.value.forEach(t=>{t.checked=!1}),l.checked=!0,i("tool","annotate",{strokeStyle:l.label,tool:"Dot",once:!1,custom:!0})}function h(){n.value=!n.value,n.value||c.value.forEach(l=>{l.checked=!1}),i("tool","endDraw")}return(l,t)=>(e.openBlock(),e.createBlock(e.unref(r.ElPopover),{visible:n.value,"popper-class":"el-popover-padding-0",placement:"bottom",width:"300px",trigger:"click"},{reference:e.withCtx(()=>[e.createElementVNode("div",{class:"hzzt-kfb-toolbox__icon",onClick:t[0]||(t[0]=o=>h())},[e.createVNode(e.unref(r.ElIcon),{size:l.size},{default:e.withCtx(()=>[e.createVNode(C.default)]),_:1},8,["size"]),e.createElementVNode("div",{class:e.normalizeClass(e.unref(m))},e.toDisplayString(e.unref(u)(l.text||"打点")),3)])]),default:e.withCtx(()=>[e.createVNode(e.unref(r.ElCard),{shadow:"never"},{default:e.withCtx(()=>[e.createElementVNode("div",null,[e.createElementVNode("p",E,e.toDisplayString(e.unref(u)("按下ESC键结束打点操作")),1),e.createElementVNode("div",g,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(c.value,o=>(e.openBlock(),e.createElementBlock("div",{key:o.label,class:"flex column align-items-center"},[e.createElementVNode("div",{style:e.normalizeStyle({"background-color":o.label}),class:"hzzt-kfb-toolbox-dot__box flex justify-content-center align-items-center",onClick:a=>p(o)},[e.createVNode(e.unref(r.ElIcon),{size:"16"},{default:e.withCtx(()=>[o.checked?(e.openBlock(),e.createBlock(_.default,{key:0})):e.createCommentVNode("",!0)]),_:2},1024)],12,x),e.createElementVNode("p",null,e.toDisplayString(o.value?o.value:" "),1)]))),128))])])]),_:1})]),_:1},8,["visible"]))}}),V=d._export_sfc(y,[["__scopeId","data-v-e2d9f6c1"]]);exports.default=V;
@@ -1 +0,0 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("vue"),s=require("./indexNnjbVZ_m.js"),m=require("./useCommon_CFgwTZy.js"),o=require("element-plus"),v=require("./downloadBWFjb3Fj.js"),C={class:"flex column align-items-center"},x=e.defineComponent({name:"ToolDownload",__name:"download",props:e.mergeDefaults({size:{},text:{},name:{},component:{},isPrevent:{type:Boolean},callback:{type:Function}},s.defaultProps),emits:["tool"],setup(d,{emit:c}){const u=d,f=c,{t:r,textClass:p}=m.useCommon(u),n=e.ref(!1);function i(l){f("tool","download",l),n.value=!1}return(l,t)=>(e.openBlock(),e.createBlock(e.unref(o.ElPopover),{visible:n.value,"popper-class":"el-popover-padding-0",placement:"bottom",width:180,trigger:"click"},{reference:e.withCtx(()=>[e.createElementVNode("div",{class:"hzzt-kfb-toolbox__icon",onClick:t[2]||(t[2]=a=>n.value=!n.value)},[e.createVNode(e.unref(o.ElIcon),{size:l.size},{default:e.withCtx(()=>[e.createVNode(v.default)]),_:1},8,["size"]),e.createElementVNode("div",{class:e.normalizeClass(e.unref(p))},e.toDisplayString(e.unref(r)(l.text||"下载")),3)])]),default:e.withCtx(()=>[e.createVNode(e.unref(o.ElCard),{shadow:"never"},{default:e.withCtx(()=>[e.createElementVNode("div",C,[e.createVNode(e.unref(o.ElLink),{onClick:t[0]||(t[0]=a=>i("all"))},{default:e.withCtx(()=>[e.createTextVNode(e.toDisplayString(e.unref(r)("下载全部切片")),1)]),_:1}),e.createVNode(e.unref(o.ElLink),{type:"primary",class:"margin-t-2",onClick:t[1]||(t[1]=a=>i("single"))},{default:e.withCtx(()=>[e.createTextVNode(e.toDisplayString(e.unref(r)("下载当前切片")),1)]),_:1})])]),_:1})]),_:1},8,["visible"]))}}),w=s._export_sfc(x,[["__scopeId","data-v-5e120452"]]);exports.default=w;
@@ -1 +0,0 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("vue"),a=require("element-plus"),u=require("./flipDA2I3h_e.js"),m=require("./indexNnjbVZ_m.js"),p=require("./useCommon_CFgwTZy.js"),f=e.defineComponent({name:"ToolFlip",__name:"flip",props:e.mergeDefaults({size:{},text:{},name:{},component:{},isPrevent:{type:Boolean},callback:{type:Function}},m.defaultProps),emits:["tool"],setup(o,{emit:n}){const s=o,l=n,{t:i,textClass:r}=p.useCommon(s),c=()=>{l("tool","flip")};return(t,d)=>(e.openBlock(),e.createElementBlock("div",{class:"hzzt-kfb-toolbox__icon",onClick:c},[e.createVNode(e.unref(a.ElIcon),{size:t.size},{default:e.withCtx(()=>[e.createVNode(u.default)]),_:1},8,["size"]),e.createElementVNode("div",{class:e.normalizeClass(e.unref(r))},e.toDisplayString(e.unref(i)(t.text||"镜像")),3)]))}});exports.default=f;
@@ -1,40 +0,0 @@
1
- import { defineComponent as c, mergeDefaults as p, createElementBlock as f, openBlock as u, createVNode as t, createElementVNode as d, unref as e, withCtx as z, normalizeClass as _, toDisplayString as C } from "vue";
2
- import { ElIcon as k } from "element-plus";
3
- import x from "./flipDUjW55Vh.js";
4
- import { d as h } from "./indexDvexHnyj.js";
5
- import { u as b } from "./useCommonDK4IjSxd.js";
6
- const F = /* @__PURE__ */ c({
7
- name: "ToolFlip",
8
- __name: "flip",
9
- props: /* @__PURE__ */ p({
10
- size: {},
11
- text: {},
12
- name: {},
13
- component: {},
14
- isPrevent: { type: Boolean },
15
- callback: { type: Function }
16
- }, h),
17
- emits: ["tool"],
18
- setup(n, { emit: s }) {
19
- const i = n, l = s, { t: r, textClass: a } = b(i), m = () => {
20
- l("tool", "flip");
21
- };
22
- return (o, v) => (u(), f("div", {
23
- class: "hzzt-kfb-toolbox__icon",
24
- onClick: m
25
- }, [
26
- t(e(k), { size: o.size }, {
27
- default: z(() => [
28
- t(x)
29
- ]),
30
- _: 1
31
- }, 8, ["size"]),
32
- d("div", {
33
- class: _(e(a))
34
- }, C(e(r)(o.text || "镜像")), 3)
35
- ]));
36
- }
37
- });
38
- export {
39
- F as default
40
- };
@@ -1 +0,0 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const n=require("vue"),h=require("element-plus"),g=require("./fullscreenDUzPX17n.js"),q=require("./indexNnjbVZ_m.js"),z=require("./useCommon_CFgwTZy.js"),k=n.defineComponent({name:"ToolFullscreen",__name:"fullscreen",props:n.mergeDefaults({size:{},text:{},name:{},component:{},isPrevent:{type:Boolean},callback:{type:Function}},q.defaultProps),emits:["tool"],setup(i,{emit:m}){const c=i,a=m,s=n.ref(!1),{t:u,textClass:f}=z.useCommon(c),e=document,l=document.documentElement,t=()=>{setTimeout(()=>{s.value=o()},500)},o=()=>!!(e.fullscreenElement||e.webkitFullscreenElement||e.mozFullScreenElement||e.msFullscreenElement),F=()=>{o()?v():d()},d=()=>{l.requestFullscreen?l.requestFullscreen():l.webkitRequestFullscreen?l.webkitRequestFullscreen():l.mozRequestFullScreen?l.mozRequestFullScreen():l.msRequestFullscreen&&l.msRequestFullscreen()},v=()=>{e.exitFullscreen?e.exitFullscreen():e.webkitExitFullscreen?e.webkitExitFullscreen():e.mozCancelFullScreen?e.mozCancelFullScreen():e.msExitFullscreen&&e.msExitFullscreen()},E=()=>{a("tool","fullscreen",!s.value),c.isPrevent||F()};return e.addEventListener("fullscreenchange",t),e.addEventListener("webkitfullscreenchange",t),e.addEventListener("mozfullscreenchange",t),e.addEventListener("MSFullscreenChange",t),n.onBeforeUnmount(()=>{e.removeEventListener("fullscreenchange",t),e.removeEventListener("webkitfullscreenchange",t),e.removeEventListener("mozfullscreenchange",t),e.removeEventListener("MSFullscreenChange",t)}),(r,p)=>(n.openBlock(),n.createElementBlock("div",{class:"hzzt-kfb-toolbox__icon",onClick:E},[n.createVNode(n.unref(h.ElIcon),{size:r.size},{default:n.withCtx(()=>[n.createVNode(g.default)]),_:1},8,["size"]),n.createElementVNode("div",{class:n.normalizeClass(n.unref(f))},n.toDisplayString(s.value?n.unref(u)(r.text||"退出全屏"):n.unref(u)(r.text||"全屏")),3)]))}});exports.default=k;