@mc20230601/keep-up 1.0.18 → 1.0.23

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 (115) hide show
  1. package/es/components/codeEditor/index.d.ts +3 -3
  2. package/es/{packages/components → components}/codeEditor/index.mjs +3 -3
  3. package/es/components/codeEditor/index.mjs.map +1 -0
  4. package/es/components/commonDrawer/index.mjs.map +1 -0
  5. package/es/components/commonLocations/constants.d.ts +28 -0
  6. package/es/components/commonLocations/constants.mjs +18 -0
  7. package/es/components/commonLocations/constants.mjs.map +1 -0
  8. package/es/components/commonLocations/index.d.ts +40 -0
  9. package/es/components/commonLocations/index.mjs +94 -0
  10. package/es/components/commonLocations/index.mjs.map +1 -0
  11. package/es/components/commonLocations/index.module.mjs +4 -0
  12. package/es/components/commonLocations/index.module.mjs.map +1 -0
  13. package/es/components/commonLocations/interfaces.d.ts +100 -0
  14. package/es/components/commonLocations/interfaces.mjs +2 -0
  15. package/es/components/commonLocations/interfaces.mjs.map +1 -0
  16. package/es/components/commonLocations/useLocations.d.ts +2 -0
  17. package/es/components/commonLocations/useLocations.mjs +151 -0
  18. package/es/components/commonLocations/useLocations.mjs.map +1 -0
  19. package/es/components/commonLocations/utils.d.ts +14 -0
  20. package/es/components/commonLocations/utils.mjs +73 -0
  21. package/es/components/commonLocations/utils.mjs.map +1 -0
  22. package/es/components/formilyCmps/formTab/index.d.ts +83 -0
  23. package/es/components/formilyCmps/formTab/index.mjs +146 -0
  24. package/es/components/formilyCmps/formTab/index.mjs.map +1 -0
  25. package/es/components/formilyCmps/formilyForm/constants.d.ts +39 -0
  26. package/es/components/formilyCmps/formilyForm/constants.mjs +41 -0
  27. package/es/components/formilyCmps/formilyForm/constants.mjs.map +1 -0
  28. package/es/components/formilyCmps/formilyForm/index.d.ts +131 -0
  29. package/es/components/formilyCmps/formilyForm/index.mjs +148 -0
  30. package/es/components/formilyCmps/formilyForm/index.mjs.map +1 -0
  31. package/es/components/formilyCmps/formilyForm/index.module.mjs +4 -0
  32. package/es/components/formilyCmps/formilyForm/index.module.mjs.map +1 -0
  33. package/es/components/formilyCmps/formilyForm/interfaces.d.ts +28 -0
  34. package/es/components/formilyCmps/formilyForm/interfaces.mjs +2 -0
  35. package/es/components/formilyCmps/formilyForm/interfaces.mjs.map +1 -0
  36. package/es/components/formilyCmps/formilyForm/utils.d.ts +3 -0
  37. package/es/components/formilyCmps/formilyForm/utils.mjs +14 -0
  38. package/es/components/formilyCmps/formilyForm/utils.mjs.map +1 -0
  39. package/es/components/formilyCmps/index.d.ts +3 -0
  40. package/es/components/formilyCmps/index.mjs +3 -0
  41. package/es/components/formilyCmps/sectionTitle/index.d.ts +28 -0
  42. package/es/components/formilyCmps/sectionTitle/index.mjs +30 -0
  43. package/es/components/formilyCmps/sectionTitle/index.mjs.map +1 -0
  44. package/es/components/formilyCmps/sectionTitle/index.module.mjs +4 -0
  45. package/es/components/formilyCmps/sectionTitle/index.module.mjs.map +1 -0
  46. package/es/components/index.d.ts +3 -0
  47. package/es/components/index.mjs +7 -0
  48. package/es/{packages/interfaces → components}/index.mjs.map +1 -1
  49. package/es/components/radioGroup/constants.d.ts +371 -0
  50. package/es/components/radioGroup/constants.mjs +11 -0
  51. package/es/components/radioGroup/constants.mjs.map +1 -0
  52. package/es/components/radioGroup/index.d.ts +203 -0
  53. package/es/components/radioGroup/index.mjs +60 -0
  54. package/es/components/radioGroup/index.mjs.map +1 -0
  55. package/es/components/radioGroup/interfaces.d.ts +7 -0
  56. package/es/components/radioGroup/interfaces.mjs +2 -0
  57. package/es/components/radioGroup/interfaces.mjs.map +1 -0
  58. package/es/components/space/index.d.ts +61 -0
  59. package/es/components/space/index.mjs +59 -0
  60. package/es/components/space/index.mjs.map +1 -0
  61. package/es/constants/common.d.ts +1 -1
  62. package/es/constants/common.mjs.map +1 -0
  63. package/es/index.d.ts +5 -1
  64. package/es/index.mjs +6 -2
  65. package/es/index.mjs.map +1 -1
  66. package/es/styles/index.css +52 -0
  67. package/es/utils/common.d.ts +1 -1
  68. package/es/utils/common.mjs.map +1 -0
  69. package/es/{packages/utils → utils}/emitter.mjs +1 -1
  70. package/es/utils/emitter.mjs.map +1 -0
  71. package/es/utils/shared.mjs.map +1 -0
  72. package/es/utils/storage.mjs.map +1 -0
  73. package/package.json +1 -2
  74. package/es/_virtual/ace.mjs +0 -4
  75. package/es/_virtual/ace.mjs.map +0 -1
  76. package/es/_virtual/mode-javascript.mjs +0 -4
  77. package/es/_virtual/mode-javascript.mjs.map +0 -1
  78. package/es/_virtual/theme-monokai.mjs +0 -4
  79. package/es/_virtual/theme-monokai.mjs.map +0 -1
  80. package/es/constants/index.d.ts +0 -0
  81. package/es/node_modules/.pnpm/ace-builds@1.43.5/node_modules/ace-builds/src-noconflict/ace.mjs +0 -21889
  82. package/es/node_modules/.pnpm/ace-builds@1.43.5/node_modules/ace-builds/src-noconflict/ace.mjs.map +0 -1
  83. package/es/node_modules/.pnpm/ace-builds@1.43.5/node_modules/ace-builds/src-noconflict/mode-javascript.mjs +0 -1186
  84. package/es/node_modules/.pnpm/ace-builds@1.43.5/node_modules/ace-builds/src-noconflict/mode-javascript.mjs.map +0 -1
  85. package/es/node_modules/.pnpm/ace-builds@1.43.5/node_modules/ace-builds/src-noconflict/theme-monokai.mjs +0 -22
  86. package/es/node_modules/.pnpm/ace-builds@1.43.5/node_modules/ace-builds/src-noconflict/theme-monokai.mjs.map +0 -1
  87. package/es/node_modules/.pnpm/mitt@3.0.1/node_modules/mitt/dist/mitt.mjs +0 -4
  88. package/es/node_modules/.pnpm/mitt@3.0.1/node_modules/mitt/dist/mitt.mjs.map +0 -1
  89. package/es/packages/components/codeEditor/index.mjs.map +0 -1
  90. package/es/packages/components/commonDrawer/index.mjs.map +0 -1
  91. package/es/packages/components/index.mjs +0 -3
  92. package/es/packages/constants/common.mjs.map +0 -1
  93. package/es/packages/interfaces/index.mjs +0 -2
  94. package/es/packages/utils/common.mjs.map +0 -1
  95. package/es/packages/utils/emitter.mjs.map +0 -1
  96. package/es/packages/utils/shared.mjs.map +0 -1
  97. package/es/packages/utils/storage.mjs.map +0 -1
  98. /package/es/{packages/components → components}/commonDrawer/index.mjs +0 -0
  99. /package/es/{packages/components → components}/commonDrawer/index.module.mjs +0 -0
  100. /package/es/{packages/components → components}/commonDrawer/index.module.mjs.map +0 -0
  101. /package/es/{packages/components → components}/commonDrawer/interfaces.mjs +0 -0
  102. /package/es/{packages/components → components}/commonDrawer/interfaces.mjs.map +0 -0
  103. /package/es/{packages/components → components/formilyCmps}/index.mjs.map +0 -0
  104. /package/es/{packages/constants → constants}/common.mjs +0 -0
  105. /package/es/{packages/interfaces → interfaces}/common.mjs +0 -0
  106. /package/es/{packages/interfaces → interfaces}/common.mjs.map +0 -0
  107. /package/es/{packages/interfaces → interfaces}/commonPage.mjs +0 -0
  108. /package/es/{packages/interfaces → interfaces}/commonPage.mjs.map +0 -0
  109. /package/es/{packages/constants → interfaces}/index.mjs +0 -0
  110. /package/es/{packages/constants → interfaces}/index.mjs.map +0 -0
  111. /package/es/{packages/utils → utils}/common.mjs +0 -0
  112. /package/es/{packages/utils → utils}/index.mjs +0 -0
  113. /package/es/{packages/utils → utils}/index.mjs.map +0 -0
  114. /package/es/{packages/utils → utils}/shared.mjs +0 -0
  115. /package/es/{packages/utils → utils}/storage.mjs +0 -0
@@ -27,7 +27,7 @@ declare const _default: {
27
27
  onChange?: (...args: any[]) => any;
28
28
  }>, () => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
29
29
  [key: string]: any;
30
- }>, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, ("update:modelValue" | "change")[], import("vue").PublicProps, {
30
+ }>, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, ("change" | "update:modelValue")[], import("vue").PublicProps, {
31
31
  value: string;
32
32
  modelValue: string;
33
33
  language: string;
@@ -100,7 +100,7 @@ declare const _default: {
100
100
  onChange?: (...args: any[]) => any;
101
101
  }>, () => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
102
102
  [key: string]: any;
103
- }>, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, ("update:modelValue" | "change")[], "update:modelValue" | "change", {
103
+ }>, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, ("change" | "update:modelValue")[], "change" | "update:modelValue", {
104
104
  value: string;
105
105
  modelValue: string;
106
106
  language: string;
@@ -129,7 +129,7 @@ declare const _default: {
129
129
  };
130
130
  }>, () => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
131
131
  [key: string]: any;
132
- }>, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, ("update:modelValue" | "change")[], "update:modelValue" | "change", import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<{
132
+ }>, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, ("change" | "update:modelValue")[], "change" | "update:modelValue", import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<{
133
133
  /** v-model体系-内容 */
134
134
  modelValue: {
135
135
  type: StringConstructor;
@@ -1,8 +1,8 @@
1
1
  import { defineComponent, ref, onMounted, h } from 'vue';
2
2
  import { connect, mapProps, mapReadPretty } from '@formily/vue';
3
- import ace from '../../../node_modules/.pnpm/ace-builds@1.43.5/node_modules/ace-builds/src-noconflict/ace.mjs';
4
- import '../../../node_modules/.pnpm/ace-builds@1.43.5/node_modules/ace-builds/src-noconflict/mode-javascript.mjs';
5
- import '../../../node_modules/.pnpm/ace-builds@1.43.5/node_modules/ace-builds/src-noconflict/theme-monokai.mjs';
3
+ import ace from 'ace-builds';
4
+ import 'ace-builds/src-noconflict/mode-javascript';
5
+ import 'ace-builds/src-noconflict/theme-monokai';
6
6
  import '../../utils/emitter.mjs';
7
7
  import { composeExpose } from '../../utils/shared.mjs';
8
8
  import { PreviewText } from '@formily/element-plus';
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.mjs","sources":["../../../../../packages/components/codeEditor/index.ts"],"sourcesContent":["import { defineComponent, h, ref, onMounted } from 'vue'\nimport { connect, mapProps, mapReadPretty } from '@formily/vue'\nimport ace from 'ace-builds'\nimport 'ace-builds/src-noconflict/mode-javascript'\nimport 'ace-builds/src-noconflict/theme-monokai'\nimport { composeExpose } from '../../utils'\n\nimport { PreviewText } from '@formily/element-plus'\n\nconst props = {\n /** v-model体系-内容 */\n modelValue: {\n type: String,\n default: '',\n },\n /** formily体系-内容 */\n value: {\n type: String,\n default: '',\n },\n /** 语言 */\n language: {\n type: String,\n default: '',\n },\n /** 主题 */\n theme: {\n type: String,\n default: '',\n },\n}\nconst CodeEditor = defineComponent({\n name: 'CodeEditor',\n props,\n emits: ['update:modelValue', 'change'],\n setup(props, { emit, attrs }) {\n const codeEditorRef = ref<HTMLDivElement | null>(null)\n const codeEditorInstance = ref<ace.Ace.Editor | null>(null)\n const init = async () => {\n codeEditorInstance.value = ace.edit(codeEditorRef.value)\n codeEditorInstance.value.session.setMode(`ace/mode/${props.language || 'javascript'}`)\n codeEditorInstance.value.setOptions({\n fontSize: 14,\n tabSize: 2,\n useSoftTabs: true,\n showPrintMargin: false,\n wrap: true,\n })\n codeEditorInstance.value.on('change', () => {\n emit('update:modelValue', codeEditorInstance.value!.getValue())\n emit('change', codeEditorInstance.value!.getValue())\n })\n setTimeout(() => {\n codeEditorInstance.value.setValue(props.modelValue || props.value || '', -1)\n }, 500)\n }\n onMounted(init)\n return () =>\n h('div', {\n ref: codeEditorRef,\n style: 'width: 100%; height: 100%; border: 1px solid #333',\n })\n },\n})\n\nconst FormilyCodeEditor = connect(\n CodeEditor,\n mapProps({ value: 'modelValue' }),\n mapReadPretty(PreviewText.Input),\n)\n\nexport default composeExpose(CodeEditor, {\n FormilyCodeEditor: FormilyCodeEditor,\n})\n"],"names":["props"],"mappings":";;;;;;;;;AASA,MAAM,KAAQ,GAAA;AAAA;AAAA,EAEZ,UAAY,EAAA;AAAA,IACV,IAAM,EAAA,MAAA;AAAA,IACN,OAAS,EAAA,EAAA;AAAA,GACX;AAAA;AAAA,EAEA,KAAO,EAAA;AAAA,IACL,IAAM,EAAA,MAAA;AAAA,IACN,OAAS,EAAA,EAAA;AAAA,GACX;AAAA;AAAA,EAEA,QAAU,EAAA;AAAA,IACR,IAAM,EAAA,MAAA;AAAA,IACN,OAAS,EAAA,EAAA;AAAA,GACX;AAAA;AAAA,EAEA,KAAO,EAAA;AAAA,IACL,IAAM,EAAA,MAAA;AAAA,IACN,OAAS,EAAA,EAAA;AAAA,GACX;AACF,CAAA,CAAA;AACA,MAAM,aAAa,eAAgB,CAAA;AAAA,EACjC,IAAM,EAAA,YAAA;AAAA,EACN,KAAA;AAAA,EACA,KAAA,EAAO,CAAC,mBAAA,EAAqB,QAAQ,CAAA;AAAA,EACrC,KAAMA,CAAAA,MAAAA,EAAO,EAAE,IAAA,EAAM,OAAS,EAAA;AAC5B,IAAM,MAAA,aAAA,GAAgB,IAA2B,IAAI,CAAA,CAAA;AACrD,IAAM,MAAA,kBAAA,GAAqB,IAA2B,IAAI,CAAA,CAAA;AAC1D,IAAA,MAAM,OAAO,YAAY;AACvB,MAAA,kBAAA,CAAmB,KAAQ,GAAA,GAAA,CAAI,IAAK,CAAA,aAAA,CAAc,KAAK,CAAA,CAAA;AACvD,MAAA,kBAAA,CAAmB,MAAM,OAAQ,CAAA,OAAA,CAAQ,YAAYA,MAAM,CAAA,QAAA,IAAY,YAAY,CAAE,CAAA,CAAA,CAAA;AACrF,MAAA,kBAAA,CAAmB,MAAM,UAAW,CAAA;AAAA,QAClC,QAAU,EAAA,EAAA;AAAA,QACV,OAAS,EAAA,CAAA;AAAA,QACT,WAAa,EAAA,IAAA;AAAA,QACb,eAAiB,EAAA,KAAA;AAAA,QACjB,IAAM,EAAA,IAAA;AAAA,OACP,CAAA,CAAA;AACD,MAAmB,kBAAA,CAAA,KAAA,CAAM,EAAG,CAAA,QAAA,EAAU,MAAM;AAC1C,QAAA,IAAA,CAAK,mBAAqB,EAAA,kBAAA,CAAmB,KAAO,CAAA,QAAA,EAAU,CAAA,CAAA;AAC9D,QAAA,IAAA,CAAK,QAAU,EAAA,kBAAA,CAAmB,KAAO,CAAA,QAAA,EAAU,CAAA,CAAA;AAAA,OACpD,CAAA,CAAA;AACD,MAAA,UAAA,CAAW,MAAM;AACf,QAAA,kBAAA,CAAmB,MAAM,QAASA,CAAAA,MAAAA,CAAM,cAAcA,MAAM,CAAA,KAAA,IAAS,IAAI,CAAE,CAAA,CAAA,CAAA;AAAA,SAC1E,GAAG,CAAA,CAAA;AAAA,KACR,CAAA;AACA,IAAA,SAAA,CAAU,IAAI,CAAA,CAAA;AACd,IAAO,OAAA,MACL,EAAE,KAAO,EAAA;AAAA,MACP,GAAK,EAAA,aAAA;AAAA,MACL,KAAO,EAAA,mDAAA;AAAA,KACR,CAAA,CAAA;AAAA,GACL;AACF,CAAC,CAAA,CAAA;AAED,MAAM,iBAAoB,GAAA,OAAA;AAAA,EACxB,UAAA;AAAA,EACA,QAAS,CAAA,EAAE,KAAO,EAAA,YAAA,EAAc,CAAA;AAAA,EAChC,aAAA,CAAc,YAAY,KAAK,CAAA;AACjC,CAAA,CAAA;AAEA,YAAe,cAAc,UAAY,EAAA;AAAA,EACvC,iBAAA;AACF,CAAC,CAAA;;;;"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.mjs","sources":["../../../../../packages/components/commonDrawer/index.tsx"],"sourcesContent":["import { defineComponent, ref } from 'vue'\nimport { ElDrawer, ElEmpty } from 'element-plus'\nimport styles from './index.module.scss'\n\nimport type { ICommonDrawerExpose } from './interfaces'\n\nconst props = {\n title: {\n type: String,\n default: '默认标题',\n },\n size: {\n type: String,\n default: '70%',\n },\n}\n\nexport * from './interfaces'\nexport default defineComponent({\n name: 'CommonEditor',\n inheritAttrs: false,\n props,\n setup(props, { expose, slots, attrs }) {\n const visible = ref(false)\n /** 打开抽屉 */\n const open = () => {\n visible.value = true\n }\n /** 关闭抽屉 */\n const close = () => {\n visible.value = false\n }\n expose<ICommonDrawerExpose>({\n open,\n close,\n })\n return () => (\n <ElDrawer\n class={styles.container}\n v-model={visible.value}\n {...attrs}\n title={props.title}\n size={props.size}\n destroyOnClose\n appendToBody\n v-slots={{\n title: slots.title?.(),\n footer: slots.footer?.(),\n }}\n >\n {slots.default?.() || <ElEmpty description='No Data' />}\n </ElDrawer>\n )\n },\n})\n"],"names":["props","title","type","String","default","size","defineComponent","name","inheritAttrs","setup","expose","slots","attrs","visible","ref","open","value","close","_createVNode","ElDrawer","_mergeProps","styles","container","$event","_a","ElEmpty","footer"],"mappings":";;;;AAMA,MAAMA,KAAQ,GAAA;AAAA,EACZC,KAAO,EAAA;AAAA,IACLC,IAAMC,EAAAA,MAAAA;AAAAA,IACNC,OAAS,EAAA,0BAAA;AAAA,GACX;AAAA,EACAC,IAAM,EAAA;AAAA,IACJH,IAAMC,EAAAA,MAAAA;AAAAA,IACNC,OAAS,EAAA,KAAA;AAAA,GACX;AACF,CAAA,CAAA;AAGA,YAAeE,eAAgB,CAAA;AAAA,EAC7BC,IAAM,EAAA,cAAA;AAAA,EACNC,YAAc,EAAA,KAAA;AAAA,EACdR,KAAAA;AAAAA,EACAS,MAAMT,MAAO,EAAA;AAAA,IAAEU,MAAAA;AAAAA,IAAQC,KAAAA;AAAAA,IAAOC,KAAAA;AAAAA,GAAS,EAAA;AACrC,IAAMC,MAAAA,OAAAA,GAAUC,IAAI,KAAK,CAAA,CAAA;AAEzB,IAAA,MAAMC,OAAOA,MAAM;AACjBF,MAAAA,OAAAA,CAAQG,KAAQ,GAAA,IAAA,CAAA;AAAA,KAClB,CAAA;AAEA,IAAA,MAAMC,QAAQA,MAAM;AAClBJ,MAAAA,OAAAA,CAAQG,KAAQ,GAAA,KAAA,CAAA;AAAA,KAClB,CAAA;AACAN,IAA4B,MAAA,CAAA;AAAA,MAC1BK,IAAAA;AAAAA,MACAE,KAAAA;AAAAA,KACD,CAAA,CAAA;AACD,IAAA,OAAO,MAAAC;AApCX,MAAA,IAAA,EAAA,EAAA,EAAA,CAAA;AAoCWA,MAAAA,OAAAA,WAAAA,CAAAC,UAAAC,UAAA,CAAA;AAAA,QAAA,SAEIC,MAAOC,CAAAA,SAAAA;AAAAA,QAAS,cACdT,OAAQG,CAAAA,KAAAA;AAAAA,QAAK,qBAAA,EAAAO,CAAbV,MAAAA,KAAAA,OAAAA,CAAQG,KAAKO,GAAAA,MAAAA;AAAAA,SAClBX,KAAK,EAAA;AAAA,QAAA,SACFZ,MAAMC,CAAAA,KAAAA;AAAAA,QAAK,QACZD,MAAMK,CAAAA,IAAAA;AAAAA,QAAI,gBAAA,EAAA,IAAA;AAAA,QAAA,cAAA,EAAA,IAAA;AAAA,OAAA,CAAA,EAAA;AAAA,QAAAD,SAAAA,MAAA;AA1CxB,UAAAoB,IAAAA,GAAAA,CAAAA;AA0CwB,UAAA,OAAA,CAAA,CAAA,CAQfb,MAAAA,KAAMP,CAAAA,OAAAA,KAANO,gBAAAA,GAAAA,CAAAA,IAAAA,CAAAA,KAAAA,CAAAA,KAAiBO,YAAAO,OAAA,EAAA;AAAA,YAAA,aAAA,EAAA,SAAA;AAAA,WAAA,EAAqC,IAAA,CAAA,CAAA,CAAA;AAAA,SAAA;AAAA,QAJrDxB,KAAAA,EAAAA,CAAOU,WAAMV,KAANU,KAAAA,IAAAA,GAAAA,KAAAA,CAAAA,GAAAA,EAAAA,CAAAA,IAAAA,CAAAA,KAAAA,CAAAA;AAAAA,QACPe,MAAAA,EAAAA,CAAQf,WAAMe,MAANf,KAAAA,IAAAA,GAAAA,KAAAA,CAAAA,GAAAA,EAAAA,CAAAA,IAAAA,CAAAA,KAAAA,CAAAA;AAAAA,OAKb,CAAA,CAAA;AAAA,KAAA,CAAA;AAAA,GACH;AACF,CAAC,CAAA;;;;"}
@@ -0,0 +1,28 @@
1
+ /** locations节点种类 */
2
+ export declare enum Type {
3
+ /** 运营商 全选 */
4
+ IS_ISP = "IS_ISP",
5
+ /** 组 全选 */
6
+ IS_GROUP = "IS_GROUP",
7
+ /** 全选 */
8
+ IS_ALL = "IS_ALL",
9
+ /** 叶子结点 */
10
+ IS_LEAF = "IS_LEAF"
11
+ }
12
+ /**
13
+ * 值是根据nodeId
14
+ * 归类是根据TypeKey
15
+ */
16
+ /** 值的键名 */
17
+ export declare const valueKey = "nodeId";
18
+ /** 存储节点值的key */
19
+ export declare enum TypeKey {
20
+ /** 运营商 全选 */
21
+ IS_ISP = "asn",
22
+ /** 组 全选 */
23
+ IS_GROUP = "regionId",
24
+ /** 全选 */
25
+ IS_ALL = "regionId",
26
+ /** 叶子结点 */
27
+ IS_LEAF = "regionId"
28
+ }
@@ -0,0 +1,18 @@
1
+ var Type = /* @__PURE__ */ ((Type2) => {
2
+ Type2["IS_ISP"] = "IS_ISP";
3
+ Type2["IS_GROUP"] = "IS_GROUP";
4
+ Type2["IS_ALL"] = "IS_ALL";
5
+ Type2["IS_LEAF"] = "IS_LEAF";
6
+ return Type2;
7
+ })(Type || {});
8
+ const valueKey = "nodeId";
9
+ var TypeKey = /* @__PURE__ */ ((TypeKey2) => {
10
+ TypeKey2["IS_ISP"] = "asn";
11
+ TypeKey2["IS_GROUP"] = "regionId";
12
+ TypeKey2["IS_ALL"] = "regionId";
13
+ TypeKey2["IS_LEAF"] = "regionId";
14
+ return TypeKey2;
15
+ })(TypeKey || {});
16
+
17
+ export { Type, TypeKey, valueKey };
18
+ //# sourceMappingURL=constants.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constants.mjs","sources":["../../../../../packages/components/commonLocations/constants.ts"],"sourcesContent":["/** locations节点种类 */\nexport enum Type {\n /** 运营商 全选 */\n IS_ISP = 'IS_ISP',\n /** 组 全选 */\n IS_GROUP = 'IS_GROUP',\n /** 全选 */\n IS_ALL = 'IS_ALL',\n /** 叶子结点 */\n IS_LEAF = 'IS_LEAF',\n}\n\n/**\n * 值是根据nodeId\n * 归类是根据TypeKey\n */\n/** 值的键名 */\n// export const valueKey = 'friendlyArea'\nexport const valueKey = 'nodeId'\n\n/** 存储节点值的key */\nexport enum TypeKey {\n /** 运营商 全选 */\n IS_ISP = 'asn',\n /** 组 全选 */\n IS_GROUP = 'regionId',\n /** 全选 */\n IS_ALL = 'regionId',\n /** 叶子结点 */\n IS_LEAF = 'regionId',\n}\n"],"names":["Type","TypeKey"],"mappings":"AACY,IAAA,IAAA,qBAAAA,KAAL,KAAA;AAEL,EAAAA,MAAA,QAAS,CAAA,GAAA,QAAA,CAAA;AAET,EAAAA,MAAA,UAAW,CAAA,GAAA,UAAA,CAAA;AAEX,EAAAA,MAAA,QAAS,CAAA,GAAA,QAAA,CAAA;AAET,EAAAA,MAAA,SAAU,CAAA,GAAA,SAAA,CAAA;AARA,EAAAA,OAAAA,KAAAA,CAAAA;AAAA,CAAA,EAAA,IAAA,IAAA,EAAA,EAAA;AAiBL,MAAM,QAAW,GAAA,SAAA;AAGZ,IAAA,OAAA,qBAAAC,QAAL,KAAA;AAEL,EAAAA,SAAA,QAAS,CAAA,GAAA,KAAA,CAAA;AAET,EAAAA,SAAA,UAAW,CAAA,GAAA,UAAA,CAAA;AAEX,EAAAA,SAAA,QAAS,CAAA,GAAA,UAAA,CAAA;AAET,EAAAA,SAAA,SAAU,CAAA,GAAA,UAAA,CAAA;AARA,EAAAA,OAAAA,QAAAA,CAAAA;AAAA,CAAA,EAAA,OAAA,IAAA,EAAA;;;;"}
@@ -0,0 +1,40 @@
1
+ import type { PropType } from 'vue';
2
+ import type { ILocationItem } from './interfaces';
3
+ declare const _default: import("vue").DefineComponent<import("vue").ExtractPropTypes<{
4
+ /** value */
5
+ value: {
6
+ type: PropType<string[]>;
7
+ default: () => any[];
8
+ };
9
+ /** 主要用于做数据回显 */
10
+ options: {
11
+ type: PropType<ILocationItem[]>;
12
+ default: () => any[];
13
+ };
14
+ /** 禁用 */
15
+ disabled: {
16
+ type: BooleanConstructor;
17
+ default: boolean;
18
+ };
19
+ }>, () => import("vue/jsx-runtime").JSX.Element, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<{
20
+ /** value */
21
+ value: {
22
+ type: PropType<string[]>;
23
+ default: () => any[];
24
+ };
25
+ /** 主要用于做数据回显 */
26
+ options: {
27
+ type: PropType<ILocationItem[]>;
28
+ default: () => any[];
29
+ };
30
+ /** 禁用 */
31
+ disabled: {
32
+ type: BooleanConstructor;
33
+ default: boolean;
34
+ };
35
+ }>> & Readonly<{}>, {
36
+ value: string[];
37
+ disabled: boolean;
38
+ options: ILocationItem[];
39
+ }, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
40
+ export default _default;
@@ -0,0 +1,94 @@
1
+ import { defineComponent, watch, createVNode, resolveComponent, mergeProps, isVNode } from 'vue';
2
+ import { useLocations } from './useLocations.mjs';
3
+ import { valueKey } from './constants.mjs';
4
+ import styles from './index.module.mjs';
5
+
6
+ function _isSlot(s) {
7
+ return typeof s === "function" || Object.prototype.toString.call(s) === "[object Object]" && !isVNode(s);
8
+ }
9
+ const props = {
10
+ /** value */
11
+ value: {
12
+ type: Array,
13
+ default: () => []
14
+ },
15
+ /** 主要用于做数据回显 */
16
+ options: {
17
+ type: Array,
18
+ default: () => []
19
+ },
20
+ /** 禁用 */
21
+ disabled: {
22
+ type: Boolean,
23
+ default: false
24
+ }
25
+ };
26
+ var index = defineComponent({
27
+ name: "Locations",
28
+ props,
29
+ setup(props2, {
30
+ emit
31
+ }) {
32
+ const {
33
+ locations,
34
+ allLocations
35
+ } = useLocations(props2);
36
+ watch(() => allLocations.value.selectedChildren, (val) => {
37
+ emit("change", val);
38
+ });
39
+ return () => {
40
+ let _slot2;
41
+ return createVNode(resolveComponent("el-space"), {
42
+ "class": styles.container,
43
+ "direction": "column",
44
+ "alignment": "space-between",
45
+ "fill": true,
46
+ "style": {
47
+ padding: "0 16px"
48
+ }
49
+ }, _isSlot(_slot2 = Object.entries(locations.value).sort(([aKey]) => aKey === "all" ? -1 : 0).map(([k, v]) => {
50
+ let _slot;
51
+ return createVNode("div", {
52
+ "style": {
53
+ width: "100%",
54
+ display: "flex",
55
+ alignItems: "flex-start",
56
+ justifyContent: "space-between"
57
+ }
58
+ }, [createVNode(resolveComponent("el-checkbox"), {
59
+ "modelValue": v.isAllChecked,
60
+ "onUpdate:modelValue": ($event) => v.isAllChecked = $event,
61
+ "indeterminate": v.isHalfChecked,
62
+ "disabled": props2.disabled,
63
+ "onChange": v.onChange
64
+ }, {
65
+ default: () => [v.label]
66
+ }), createVNode(resolveComponent("el-checkbox-group"), {
67
+ "modelValue": v.selectedChildren,
68
+ "onUpdate:modelValue": ($event) => v.selectedChildren = $event,
69
+ "disabled": props2.disabled,
70
+ "style": {
71
+ width: "calc(100% - 132px - 8px)"
72
+ }
73
+ }, _isSlot(_slot = v.children.map((v1) => createVNode(resolveComponent("el-checkbox"), mergeProps({
74
+ "key": v1.label,
75
+ "label": v1.label,
76
+ "value": v1[valueKey]
77
+ }, v.label === "\u5168\u9009" ? {
78
+ indeterminate: v1.isHalfChecked
79
+ } : {}, {
80
+ "onChange": v1.onChange
81
+ }), {
82
+ default: () => [v1.label]
83
+ }))) ? _slot : {
84
+ default: () => [_slot]
85
+ })]);
86
+ })) ? _slot2 : {
87
+ default: () => [_slot2]
88
+ });
89
+ };
90
+ }
91
+ });
92
+
93
+ export { index as default };
94
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.mjs","sources":["../../../../../packages/components/commonLocations/index.tsx"],"sourcesContent":["import { defineComponent, watch } from 'vue'\nimport { useLocations } from './useLocations'\nimport { valueKey } from './constants'\nimport styles from './index.module.scss'\n\nimport type { PropType } from 'vue'\nimport type { ILocationItem } from './interfaces'\n\nconst props = {\n /** value */\n value: {\n type: Array as PropType<string[]>,\n default: () => ([]),\n },\n /** 主要用于做数据回显 */\n options: {\n type: Array as PropType<ILocationItem[]>,\n default: () => ([]),\n },\n /** 禁用 */\n disabled: {\n type: Boolean,\n default: false,\n },\n}\n\nexport default defineComponent({\n name: 'Locations',\n props,\n setup(props, { emit }) {\n const {\n locations,\n allLocations,\n } = useLocations(props)\n\n /** 配合formily的value/change模式 */\n watch(() => allLocations.value.selectedChildren, (val) => {\n emit('change', val)\n })\n \n return () => {\n return (\n <el-space class={styles.container} direction='column' alignment='space-between' fill={true} style={{ padding: '0 16px' }}>\n {\n Object.entries(locations.value)\n .sort(([aKey]) => aKey === 'all' ? -1 : 0)\n .map(([k, v]) => (\n <div \n style={{ \n width: '100%', \n display: 'flex', \n alignItems: 'flex-start', \n justifyContent: 'space-between'\n }}\n >\n <el-checkbox\n v-model={v.isAllChecked}\n indeterminate={v.isHalfChecked}\n disabled={props.disabled}\n onChange={v.onChange}\n >{v.label}</el-checkbox>\n <el-checkbox-group\n v-model={v.selectedChildren}\n disabled={props.disabled}\n style={{\n width: 'calc(100% - 132px - 8px)'\n }}\n >\n {v.children.map(v1 => (\n <el-checkbox \n key={v1.label} \n label={v1.label} \n value={v1[valueKey]} \n {...(v.label === '全选' ? { indeterminate: v1.isHalfChecked } : {})}\n onChange={v1.onChange}\n >{v1.label}</el-checkbox>\n ))}\n </el-checkbox-group>\n </div>\n ))\n }\n </el-space>\n )\n }\n }\n})\n"],"names":["_isSlot","s","Object","prototype","toString","call","_isVNode","props","value","type","Array","default","options","disabled","Boolean","defineComponent","name","setup","emit","locations","allLocations","useLocations","watch","selectedChildren","val","_slot2","_createVNode","_resolveComponent","styles","container","padding","entries","sort","aKey","map","k","v","_slot","width","display","alignItems","justifyContent","isAllChecked","$event","isHalfChecked","onChange","label","children","v1","_mergeProps","valueKey","indeterminate"],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ var styles = {"container":"index-module_container__VGtEq"};
2
+
3
+ export { styles as default };
4
+ //# sourceMappingURL=index.module.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.module.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
@@ -0,0 +1,100 @@
1
+ import type { Ref, ComputedRef } from 'vue';
2
+ import type { Type } from './constants';
3
+ /** 位置(接口数据) */
4
+ export interface ILocationItem {
5
+ /** 节点id */
6
+ nodeId: string;
7
+ /** 所属地区id */
8
+ regionId: string;
9
+ /** 所属地区名称 */
10
+ regionName: string;
11
+ /** 所属省份 */
12
+ subdivision: string;
13
+ /** 所属城市 */
14
+ city: string;
15
+ /** 运营商唯一标识 */
16
+ asn: string;
17
+ /** 运营商 */
18
+ ispName: string;
19
+ /** 用于前端友好展示的区域名称,比如:浙江杭州电信 */
20
+ friendlyArea: string;
21
+ }
22
+ /** props */
23
+ export interface IProps {
24
+ /** value */
25
+ value: string[];
26
+ /** options,主要用于触发渲染时机 */
27
+ options: ILocationItem[];
28
+ }
29
+ /** useLocations出参 */
30
+ export interface IUseLocationsRes {
31
+ /** 格式化后的位置数据 */
32
+ locations: Ref<ILocations>;
33
+ /** 所有选中的和可选的leaf节点 */
34
+ allLocations: ComputedRef<ISelectedData>;
35
+ }
36
+ /** 转换后数据 */
37
+ /** 叶子节点 */
38
+ export interface ILeafNode extends Partial<ILocationItem> {
39
+ /** 标题 */
40
+ label: string;
41
+ /** 是否选中(废弃) */
42
+ selected: boolean;
43
+ /** 节点类型 */
44
+ type: Type.IS_LEAF;
45
+ /** 子节点 */
46
+ children: [];
47
+ /** 选中的子节点 */
48
+ selectedChildren: [];
49
+ /** 选中状态改变 */
50
+ onChange: () => void;
51
+ }
52
+ /** 根节点 */
53
+ interface IBasicGroupNode extends Partial<Omit<ILocationItem, 'nodeId' | 'regionName' | 'subdivision' | 'city' | 'ispName' | 'friendlyArea'>> {
54
+ /** 标题 */
55
+ label: string;
56
+ /** 选中部分 */
57
+ isHalfChecked: boolean;
58
+ /** 全选 */
59
+ isAllChecked: boolean;
60
+ /** 节点类型 */
61
+ type: Type;
62
+ /** 子节点 */
63
+ children: ILeafNode[];
64
+ /** 选中的子节点 */
65
+ selectedChildren: string[];
66
+ /** 根据子节点选中状态,检查更新自身的选中状态 */
67
+ onCheck: () => void;
68
+ /** 选中状态手动改变 */
69
+ onChange: (p?: any) => void;
70
+ }
71
+ /** 叶子节点的父节点(唯一) */
72
+ export interface IGroupNode extends IBasicGroupNode {
73
+ /** 节点类型 */
74
+ type: Type.IS_GROUP;
75
+ }
76
+ /** 运营商节点 */
77
+ export interface IIspNode extends IBasicGroupNode {
78
+ type: Type.IS_ISP;
79
+ }
80
+ /** 全选节点 */
81
+ export interface IAllNode extends Omit<IBasicGroupNode, 'children'> {
82
+ type: Type.IS_ALL;
83
+ /** 子节点 */
84
+ children: IIspNode[];
85
+ }
86
+ /** 用于渲染的数据结构 */
87
+ export type ILocations = {
88
+ all?: IAllNode;
89
+ } & {
90
+ [K in Exclude<string, 'all'>]: IGroupNode;
91
+ };
92
+ /** 转换后数据 */
93
+ /** 不同维度归类的数据Map */
94
+ export interface ISelectedData {
95
+ /** 所有可选的叶子结点 */
96
+ children: ILeafNode[];
97
+ /** 所有选中的叶子结点 */
98
+ selectedChildren: string[];
99
+ }
100
+ export {};
@@ -0,0 +1,2 @@
1
+
2
+ //# sourceMappingURL=interfaces.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"interfaces.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":""}
@@ -0,0 +1,2 @@
1
+ import type { IProps, IUseLocationsRes } from './interfaces';
2
+ export declare const useLocations: (props: IProps) => IUseLocationsRes;
@@ -0,0 +1,151 @@
1
+ import { ref, computed, watch } from 'vue';
2
+ import { isEqual, isEmpty } from 'lodash';
3
+ import { getUtils } from './utils.mjs';
4
+ import { valueKey, TypeKey, Type } from './constants.mjs';
5
+
6
+ const useLocations = (props) => {
7
+ const locations = ref({});
8
+ const allLocations = computed(() => {
9
+ return Object.entries(locations.value).filter(([k]) => k !== "all").reduce(
10
+ (iniVal, [_, v]) => ({
11
+ selectedChildren: [
12
+ ...iniVal.selectedChildren,
13
+ ...v.selectedChildren || []
14
+ ],
15
+ children: [...iniVal.children, ...v.children || []]
16
+ }),
17
+ { children: [], selectedChildren: [] }
18
+ );
19
+ });
20
+ const { ispNodeOnCheck, groupNodeOnCheck, allNodeOnCheck, dispatchAllNodesOnCheck } = getUtils(
21
+ locations,
22
+ allLocations
23
+ );
24
+ const formatLocations = (curLocations = []) => {
25
+ const getLeafNode = (curItem) => ({
26
+ ...curItem,
27
+ label: curItem.friendlyArea,
28
+ selected: false,
29
+ type: Type.IS_LEAF,
30
+ children: [],
31
+ selectedChildren: [],
32
+ onChange: () => {
33
+ console.log(
34
+ `\u3010\u{1F527} \u70B9\u51FB\u3011\u8282\u70B9\u7C7B\u578B\uFF1A\u53F6\u5B50\u8282\u70B9\u3002\u52A8\u4F5C: \u624B\u52A8\u5207\u6362\u3010${curItem.friendlyArea}\u3011\u5730\u533A\u7684\u9009\u4E2D\u72B6\u6001\u3002`
35
+ );
36
+ dispatchAllNodesOnCheck();
37
+ }
38
+ });
39
+ return curLocations.reduce((initVal, curItem) => {
40
+ var _a, _b, _c, _d, _e;
41
+ if (curItem[TypeKey[Type.IS_LEAF]] in initVal) {
42
+ (_b = (_a = initVal[curItem[TypeKey[Type.IS_LEAF]]].children) == null ? void 0 : _a.push) == null ? void 0 : _b.call(_a, getLeafNode(curItem));
43
+ } else {
44
+ initVal[curItem[TypeKey[Type.IS_GROUP]]] = {
45
+ label: curItem.regionName,
46
+ [TypeKey[Type.IS_GROUP]]: curItem[TypeKey[Type.IS_GROUP]],
47
+ isHalfChecked: false,
48
+ isAllChecked: false,
49
+ type: Type.IS_GROUP,
50
+ children: [getLeafNode(curItem)],
51
+ selectedChildren: [],
52
+ onCheck: () => {
53
+ console.log(
54
+ `\u3010\u{1F527} \u68C0\u67E5\u3011\u8282\u70B9\u7C7B\u578B\uFF1A\u7EC4\u8282\u70B9\u3002\u52A8\u4F5C: \u68C0\u67E5\u66F4\u65B0\u3010${curItem.regionName}\u3011\u5730\u533A\u7684\u9009\u4E2D\u72B6\u6001`
55
+ );
56
+ groupNodeOnCheck(curItem, Type.IS_GROUP);
57
+ },
58
+ onChange: (val) => {
59
+ console.log(
60
+ `\u3010\u{1F527} \u70B9\u51FB\u3011\u8282\u70B9\u7C7B\u578B\uFF1A\u7EC4\u8282\u70B9\u3002\u52A8\u4F5C: \u624B\u52A8\u5207\u6362\u3010${curItem.regionName}\u3011\u5730\u533A\u7684\u9009\u4E2D\u72B6\u6001`
61
+ );
62
+ locations.value[curItem[TypeKey[Type.IS_GROUP]]].selectedChildren = val ? locations.value[curItem[TypeKey[Type.IS_GROUP]]].children.map((v) => v[valueKey]) : [];
63
+ dispatchAllNodesOnCheck();
64
+ }
65
+ };
66
+ }
67
+ if (!("all" in initVal)) {
68
+ initVal["all"] = {
69
+ label: "\u5168\u9009",
70
+ isHalfChecked: false,
71
+ isAllChecked: false,
72
+ type: Type.IS_ALL,
73
+ children: [],
74
+ selectedChildren: [],
75
+ onCheck: () => {
76
+ console.log(`\u3010\u{1F527} \u68C0\u67E5\u3011\u8282\u70B9\u7C7B\u578B\uFF1A\u5168\u9009\u8282\u70B9\u3002\u52A8\u4F5C: \u68C0\u67E5\u66F4\u65B0\u5168\u9009\u8282\u70B9\u7684\u9009\u4E2D\u72B6\u6001`);
77
+ allNodeOnCheck();
78
+ },
79
+ onChange: (val) => {
80
+ console.log(`\u3010\u{1F527} \u70B9\u51FB\u3011\u8282\u70B9\u7C7B\u578B\uFF1A\u5168\u9009\u8282\u70B9\u3002\u52A8\u4F5C: \u624B\u52A8\u5207\u6362\u6240\u6709\u53F6\u5B50\u8282\u70B9\u7684\u9009\u4E2D\u72B6\u6001`);
81
+ Object.entries(locations.value).filter(([k, v]) => k !== "all").forEach(([k, v]) => {
82
+ v.selectedChildren = val ? v.children.map((v1) => v1[valueKey]) : [];
83
+ });
84
+ dispatchAllNodesOnCheck();
85
+ }
86
+ };
87
+ }
88
+ if (!(((_c = initVal["all"]) == null ? void 0 : _c.children) || []).find(
89
+ (v) => v[TypeKey[Type.IS_ISP]] === curItem[TypeKey[Type.IS_ISP]]
90
+ )) {
91
+ (_e = (_d = initVal["all"]) == null ? void 0 : _d.children) == null ? void 0 : _e.push({
92
+ label: curItem.ispName,
93
+ [TypeKey[Type.IS_ISP]]: curItem[TypeKey[Type.IS_ISP]],
94
+ /** 因为运营商的唯一值是asn,其余的叶子节点唯一值是regionId,所以在这里如果要把运营商模拟为叶子结点的话,需要把asn填进regionId */
95
+ [valueKey]: curItem[TypeKey[Type.IS_ISP]],
96
+ // 用唯一的asn,因为ui中将运营商节点放入leaf节点的位置,所以有了这个key
97
+ isHalfChecked: false,
98
+ isAllChecked: false,
99
+ type: Type.IS_ISP,
100
+ children: [],
101
+ selectedChildren: [],
102
+ onCheck: () => {
103
+ console.log(
104
+ `\u3010\u{1F527} \u68C0\u67E5\u3011\u8282\u70B9\u7C7B\u578B\uFF1A\u8FD0\u8425\u5546\u8282\u70B9\u3002\u52A8\u4F5C: \u68C0\u67E5\u66F4\u65B0\u3010${curItem.ispName}\u3011\u8FD0\u8425\u5546\u8282\u70B9\u7684\u9009\u4E2D\u72B6\u6001`
105
+ );
106
+ ispNodeOnCheck(curItem, Type.IS_ISP);
107
+ },
108
+ onChange: (val) => {
109
+ console.log(
110
+ `\u3010\u{1F527} \u70B9\u51FB\u3011\u8282\u70B9\u7C7B\u578B\uFF1A\u5168\u9009\u8282\u70B9\u3002\u52A8\u4F5C: \u624B\u52A8\u5207\u6362\u3010${curItem.ispName}\u3011\u8FD0\u8425\u5546\u8282\u70B9\u7684\u9009\u4E2D\u72B6\u6001`
111
+ );
112
+ Object.entries(locations.value).filter(([k, v]) => k !== "all").forEach(([k, v]) => {
113
+ v.selectedChildren = val ? v.children.filter((v1) => v1[TypeKey[Type.IS_ISP]] === curItem[TypeKey[Type.IS_ISP]]).map((v2) => v2[valueKey]) : [];
114
+ });
115
+ dispatchAllNodesOnCheck();
116
+ }
117
+ });
118
+ }
119
+ return initVal;
120
+ }, {});
121
+ };
122
+ const init = () => {
123
+ locations.value = formatLocations(props.options);
124
+ if (isEmpty(locations.value)) {
125
+ return;
126
+ }
127
+ Object.entries(locations.value).filter(([k]) => k !== "all").map(([_, v]) => {
128
+ const same = v.children.filter((v2) => props.value.includes(v2[valueKey])).map((v2) => v2[valueKey]);
129
+ if (same.length) {
130
+ v.selectedChildren = [...v.selectedChildren, ...same];
131
+ }
132
+ });
133
+ dispatchAllNodesOnCheck();
134
+ };
135
+ watch(
136
+ () => [props.options, props.value],
137
+ (newVal, oldVal) => {
138
+ if (!isEqual(newVal == null ? void 0 : newVal[0], oldVal == null ? void 0 : oldVal[0]) || !isEqual(newVal == null ? void 0 : newVal[1], oldVal == null ? void 0 : oldVal[1])) {
139
+ init();
140
+ }
141
+ },
142
+ { immediate: true }
143
+ );
144
+ return {
145
+ locations,
146
+ allLocations
147
+ };
148
+ };
149
+
150
+ export { useLocations };
151
+ //# sourceMappingURL=useLocations.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useLocations.mjs","sources":["../../../../../packages/components/commonLocations/useLocations.ts"],"sourcesContent":["import { ref, computed, watch } from 'vue'\nimport { isEmpty, isEqual } from 'lodash'\nimport { getUtils } from './utils'\nimport { Type, TypeKey, valueKey } from './constants'\n\nimport type {\n IProps,\n IUseLocationsRes,\n ILocationItem,\n IAllNode,\n IIspNode,\n IGroupNode,\n ILeafNode,\n ILocations,\n ISelectedData,\n} from './interfaces'\n\nexport const useLocations = (props: IProps): IUseLocationsRes => {\n const locations = ref<ILocations>({})\n /** 获取所有选中的和可选的leaf节点 */\n const allLocations = computed<ISelectedData>(() => {\n return Object.entries(locations.value)\n .filter(([k]) => k !== 'all')\n .reduce(\n (iniVal, [_, v]) => ({\n selectedChildren: [\n ...iniVal.selectedChildren,\n ...((v as unknown as ILeafNode).selectedChildren || []),\n ],\n children: [...iniVal.children, ...((v as unknown as ILeafNode).children || [])],\n }),\n { children: [], selectedChildren: [] } as ISelectedData,\n )\n })\n const { ispNodeOnCheck, groupNodeOnCheck, allNodeOnCheck, dispatchAllNodesOnCheck } = getUtils(\n locations,\n allLocations,\n )\n /** 格式化locations */\n const formatLocations = (curLocations: ILocationItem[] = []): ILocations => {\n const getLeafNode = (curItem: ILeafNode): ILeafNode => ({\n ...curItem,\n label: curItem.friendlyArea,\n selected: false,\n type: Type.IS_LEAF,\n children: [],\n selectedChildren: [],\n onChange: () => {\n console.log(\n `【🔧 点击】节点类型:叶子节点。动作: 手动切换【${curItem.friendlyArea}】地区的选中状态。`,\n )\n dispatchAllNodesOnCheck()\n },\n })\n return curLocations.reduce((initVal, curItem) => {\n // 按regionName分组\n if (curItem[TypeKey[Type.IS_LEAF]] in initVal) {\n initVal[curItem[TypeKey[Type.IS_LEAF]]].children?.push?.(getLeafNode(curItem as ILeafNode))\n } else {\n initVal[curItem[TypeKey[Type.IS_GROUP]]] = {\n label: curItem.regionName,\n [TypeKey[Type.IS_GROUP]]: curItem[TypeKey[Type.IS_GROUP]],\n isHalfChecked: false,\n isAllChecked: false,\n type: Type.IS_GROUP,\n children: [getLeafNode(curItem as ILeafNode)],\n selectedChildren: [],\n onCheck: () => {\n console.log(\n `【🔧 检查】节点类型:组节点。动作: 检查更新【${curItem.regionName}】地区的选中状态`,\n )\n groupNodeOnCheck(curItem, Type.IS_GROUP)\n },\n onChange: (val: boolean) => {\n console.log(\n `【🔧 点击】节点类型:组节点。动作: 手动切换【${curItem.regionName}】地区的选中状态`,\n )\n locations.value[curItem[TypeKey[Type.IS_GROUP]]].selectedChildren = val\n ? locations.value[curItem[TypeKey[Type.IS_GROUP]]].children.map((v) => v[valueKey])\n : []\n /** 调用所有IGroupNode和IIspNode的onCheck */\n dispatchAllNodesOnCheck()\n },\n } as IGroupNode\n }\n // 全选\n if (!('all' in initVal)) {\n initVal['all'] = {\n label: '全选',\n isHalfChecked: false,\n isAllChecked: false,\n type: Type.IS_ALL,\n children: [],\n selectedChildren: [],\n onCheck: () => {\n console.log(`【🔧 检查】节点类型:全选节点。动作: 检查更新全选节点的选中状态`)\n allNodeOnCheck()\n },\n onChange: (val: boolean) => {\n console.log(`【🔧 点击】节点类型:全选节点。动作: 手动切换所有叶子节点的选中状态`)\n Object.entries(locations.value)\n .filter(([k, v]) => k !== 'all')\n .forEach(([k, v]) => {\n v.selectedChildren = val ? (v as IGroupNode).children.map((v1) => v1[valueKey]) : []\n })\n /** 调用所有IGroupNode和IIspNode的onCheck */\n dispatchAllNodesOnCheck()\n },\n } as IAllNode\n }\n // 运营商全选节点【布局方便,所以放进all的children中】\n if (\n !(initVal['all']?.children || []).find(\n (v) => v[TypeKey[Type.IS_ISP]] === curItem[TypeKey[Type.IS_ISP]],\n )\n ) {\n initVal['all']?.children?.push({\n label: curItem.ispName,\n [TypeKey[Type.IS_ISP]]: curItem[TypeKey[Type.IS_ISP]],\n /** 因为运营商的唯一值是asn,其余的叶子节点唯一值是regionId,所以在这里如果要把运营商模拟为叶子结点的话,需要把asn填进regionId */\n [valueKey]: curItem[TypeKey[Type.IS_ISP]], // 用唯一的asn,因为ui中将运营商节点放入leaf节点的位置,所以有了这个key\n isHalfChecked: false,\n isAllChecked: false,\n type: Type.IS_ISP,\n children: [],\n selectedChildren: [],\n onCheck: () => {\n console.log(\n `【🔧 检查】节点类型:运营商节点。动作: 检查更新【${curItem.ispName}】运营商节点的选中状态`,\n )\n ispNodeOnCheck(curItem, Type.IS_ISP)\n },\n onChange: (val: boolean) => {\n console.log(\n `【🔧 点击】节点类型:全选节点。动作: 手动切换【${curItem.ispName}】运营商节点的选中状态`,\n )\n Object.entries(locations.value)\n .filter(([k, v]) => k !== 'all')\n .forEach(([k, v]) => {\n v.selectedChildren = val\n ? (v as IGroupNode).children\n .filter((v1) => v1[TypeKey[Type.IS_ISP]] === curItem[TypeKey[Type.IS_ISP]])\n .map((v) => v[valueKey])\n : []\n })\n dispatchAllNodesOnCheck()\n },\n } as IIspNode)\n }\n return initVal\n }, {} as ILocations)\n }\n const init = () => {\n locations.value = formatLocations(props.options as ILocationItem[])\n if (isEmpty(locations.value)) {\n return\n }\n Object.entries(locations.value)\n .filter(([k]) => k !== 'all')\n .map(([_, v]) => {\n const same = v.children\n .filter((v) => props.value.includes(v[valueKey]))\n .map((v) => v[valueKey])\n if (same.length) {\n v.selectedChildren = [...v.selectedChildren, ...same]\n }\n })\n dispatchAllNodesOnCheck()\n }\n /** 配合formily的value/change模式 */\n watch(\n () => [props.options, props.value],\n (newVal, oldVal) => {\n if (!isEqual(newVal?.[0], oldVal?.[0]) || !isEqual(newVal?.[1], oldVal?.[1])) {\n init()\n }\n },\n { immediate: true },\n )\n return {\n locations,\n allLocations,\n }\n}\n"],"names":["v"],"mappings":"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"}
@@ -0,0 +1,14 @@
1
+ import { Type } from './constants';
2
+ import type { Ref, ComputedRef } from 'vue';
3
+ import type { ILocations, ILocationItem, ISelectedData } from './interfaces';
4
+ /** 获取状态检查函数 */
5
+ export declare const getUtils: (locations: Ref<ILocations>, allLocations: ComputedRef<ISelectedData>) => {
6
+ /** 运营商选中状态检查【运营商节点和all节点】 */
7
+ ispNodeOnCheck(curItem: ILocationItem, type: Type): void;
8
+ /** 组节点选中状态检查 */
9
+ groupNodeOnCheck(curItem: ILocationItem, type: Type): void;
10
+ /** 全选节点选中状态检查 */
11
+ allNodeOnCheck(): void;
12
+ /** 调用组节点/运营商节点/全选节点的onCheck */
13
+ dispatchAllNodesOnCheck(): void;
14
+ };