import { createHotContext as __vite__createHotContext } from "/@vite/client";import.meta.hot = __vite__createHotContext("/src/components/Provider/Modal.tsx");import { mergeProps as _mergeProps, createVNode as _createVNode, Fragment as _Fragment } from "/node_modules/.vite/deps/vue.js?v=3bf0172c"; import { Modal as AntdModal } from "/node_modules/.vite/deps/ant-design-vue.js?v=f7d2fa05"; import { CloseOutlined } from "/node_modules/.vite/deps/@ant-design_icons-vue.js?v=2150c144"; import { defineComponent, inject, onBeforeUnmount, onMounted, provide, reactive, ref } from "/node_modules/.vite/deps/vue.js?v=3bf0172c"; import { bool, number } from "/node_modules/.vite/deps/vue-types.js?v=3b44f7bd"; import { useRouter } from "/node_modules/.vite/deps/vue-router.js?v=0a002a54"; import "/src/components/Provider/Modal.less"; import ModalConfirm from "/src/components/Provider/ModalConfirm.tsx"; import ModalInput from "/src/components/Provider/ModalInput.tsx"; const store = reactive({ modalKeys: [], modalMaps: /* @__PURE__ */new Map() }); const MyModal = defineComponent({ props: { visible: bool().isRequired, modalKey: number().isRequired }, setup(props) { provide("modalContext", props.modalKey); const closeRef = ref(); const { context, children, closable, title, fullscreen, width, ...otherProps } = store.modalMaps.get(props.modalKey); const baseProps = { width, closable }; const isSelfWidth = !(width && !fullscreen); if (context) { Object.entries(context).forEach(([key, value]) => { provide(key, value); }); } if (isSelfWidth) { baseProps.closable = false; baseProps.width = "auto"; baseProps.class = "inf-modal" + (fullscreen ? " ant-modal-fullscreen" : ""); onMounted(() => { const closeEl = closeRef.value; if (closeEl) { const maskEl = closeEl.parentElement.parentElement; } }); onBeforeUnmount(() => { const closeEl = closeRef.value; if (closeEl) { const maskEl = closeEl.parentElement.parentElement; maskEl.removeEventListener("click", closeModal); } }); } else { baseProps.title = title; } function closeModal(e) { if (e.target === e.currentTarget) { otherProps.onCancel?.(); } } const RenderSelfHeader = () => _createVNode(_Fragment, null, [closable ? _createVNode(CloseOutlined, { "class": "ant-modal-close", "onClick": () => otherProps.onCancel(), "ref": closeRef }, null) : null, title ? _createVNode("div", { "class": "ant-modal-header" }, [title]) : null]); return () => { return _createVNode(AntdModal, _mergeProps({ "key": props.modalKey, "visible": props.visible, "footer": null }, baseProps, otherProps), { default: () => [isSelfWidth ? RenderSelfHeader() : null, children] }); }; } }); function hidden(key) { if (key) { const modal = store.modalKeys.find(item => item.key === key); modal && (modal.visible = false); } } const Modal = { show(children, config, context) { return new Promise((resolve, reject) => { const key = Date.now(); const { afterClose, ...otherConfig } = config || {}; store.modalMaps.set(key, { context, children, closable: true, afterClose: () => { const itemIndex = store.modalKeys.findIndex(item => item.key === key); if (itemIndex != -1) { store.modalKeys.splice(itemIndex, 1); store.modalMaps.delete(key); } afterClose?.(); }, ...otherConfig, onOk: async value => { if (otherConfig.onOk) { await otherConfig.onOk(value); } resolve(value); hidden(key); }, onCancel: msg => { reject(console.warn(msg)); hidden(key); } }); store.modalKeys.push({ key, visible: true }); }); }, use() { const key = inject("modalContext"); const ctx = store.modalMaps.get(key); return { submit: ctx.onOk, cancel: ctx.onCancel }; }, input(params) { const { title, defaultValue, placeholder, maxLength, okText, cancelText, selection, onValid, ...otherParams } = params; return Modal.show(_createVNode(ModalInput, { "defaultValue": defaultValue, "placeholder": placeholder, "maxLength": maxLength, "selection": selection, "okText": okText, "cancelText": cancelText }, null), { width: "400px", title, closable: true, ...otherParams, onOk: async v => { const isValid = await (onValid ? onValid(v) : true); if (isValid) return v; throw console.warn({ msg: "invalid input value", silence: true }); } }); }, confirm(params) { const { type, okText, refuseText, cancelText, content, ...otherParams } = params; return Modal.show(_createVNode(ModalConfirm, { "type": type, "content": content, "okText": okText, "refuseText": refuseText, "cancelText": cancelText }, null), { width: "400px", ...otherParams }); }, clear() { store.modalKeys = []; store.modalMaps.clear(); } }; export const ModalProvider = defineComponent(() => { const router = useRouter(); router.beforeEach(() => { Modal.clear(); }); return () => store.modalKeys.map(({ key, visible }) => _createVNode(MyModal, { "key": key, "visible": visible, "modalKey": key }, null)); }); export default Modal; ModalProvider.__hmrId = "4070dbe2" __VUE_HMR_RUNTIME__.createRecord("4070dbe2", ModalProvider) import.meta.hot.accept(({ModalProvider: __ModalProvider}) => { __VUE_HMR_RUNTIME__.reload("4070dbe2", __ModalProvider) }) //# sourceMappingURL=data:application/json;base64,{"version":3,"mappings":"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","names":["Modal","AntdModal","CloseOutlined","defineComponent","inject","onBeforeUnmount","onMounted","provide","reactive","ref","bool","number","useRouter","ModalConfirm","ModalInput","store","modalKeys","modalMaps","Map","MyModal","props","visible","isRequired","modalKey","setup","closeRef","context","children","closable","title","fullscreen","width","otherProps","get","baseProps","isSelfWidth","Object","entries","forEach","key","value","class","closeEl","maskEl","parentElement","removeEventListener","closeModal","e","target","currentTarget","onCancel","RenderSelfHeader","_createVNode","_Fragment","onClick","_mergeProps","default","hidden","modal","find","item","show","config","Promise","resolve","reject","Date","now","afterClose","otherConfig","set","itemIndex","findIndex","splice","delete","onOk","msg","console","warn","push","use","ctx","submit","cancel","input","params","defaultValue","placeholder","maxLength","okText","cancelText","selection","onValid","otherParams","v","isValid","silence","confirm","type","refuseText","content","clear","ModalProvider","router","beforeEach","map"],"sources":["Modal.tsx"],"file":"D:/work_files/crrc_admin/src/components/Provider/Modal.tsx","sourcesContent":["import { Modal as AntdModal } from \"ant-design-vue\";\r\nimport { CloseOutlined } from \"@ant-design/icons-vue\";\r\nimport {\r\n  defineComponent,\r\n  inject,\r\n  onBeforeUnmount,\r\n  onMounted,\r\n  provide,\r\n  reactive,\r\n  ref,\r\n} from \"vue\";\r\nimport { bool, number } from \"vue-types\";\r\nimport { useRouter } from \"vue-router\";\r\nimport \"./Modal.less\";\r\nimport ModalConfirm from \"./ModalConfirm\";\r\nimport ModalInput from \"./ModalInput\";\r\n\r\nconst store = reactive({\r\n  modalKeys: [] as Array<{ key: number; visible: boolean }>,\r\n  modalMaps: new Map() as Map<number, any>,\r\n});\r\n\r\nconst MyModal = defineComponent({\r\n  props: {\r\n    visible: bool().isRequired,\r\n    modalKey: number().isRequired,\r\n  },\r\n  setup(props) {\r\n    provide(\"modalContext\", props.modalKey);\r\n    const closeRef = ref();\r\n    const {\r\n      context,\r\n      children,\r\n      closable,\r\n      title,\r\n      fullscreen,\r\n      width,\r\n      ...otherProps\r\n    } = store.modalMaps.get(props.modalKey);\r\n    const baseProps: any = {\r\n      width,\r\n      closable,\r\n    };\r\n    const isSelfWidth = !(width && !fullscreen);\r\n\r\n    if (context) {\r\n      Object.entries(context).forEach(([key, value]) => {\r\n        provide(key, value);\r\n      });\r\n    }\r\n\r\n    if (isSelfWidth) {\r\n      baseProps.closable = false;\r\n      baseProps.width = \"auto\";\r\n      baseProps.class =\r\n        \"inf-modal\" + (fullscreen ? \" ant-modal-fullscreen\" : \"\");\r\n      onMounted(() => {\r\n        const closeEl = closeRef.value;\r\n        if (closeEl) {\r\n          const maskEl = closeEl.parentElement.parentElement;\r\n          // maskEl.addEventListener(\"click\", closeModal, { once: true }); 选择文件过后,会触发事件但被拦截\r\n          // maskEl.addEventListener(\"click\", closeModal);\r\n        }\r\n      });\r\n      onBeforeUnmount(() => {\r\n        const closeEl = closeRef.value;\r\n        if (closeEl) {\r\n          const maskEl = closeEl.parentElement.parentElement;\r\n          maskEl.removeEventListener(\"click\", closeModal);\r\n        }\r\n      });\r\n    } else {\r\n      baseProps.title = title;\r\n    }\r\n\r\n    function closeModal(e: MouseEvent) {\r\n      if (e.target === e.currentTarget) {\r\n        otherProps.onCancel?.();\r\n      }\r\n    }\r\n\r\n    const RenderSelfHeader = () => (\r\n      <>\r\n        {closable ? (\r\n          <CloseOutlined\r\n            class=\"ant-modal-close\"\r\n            onClick={() => otherProps.onCancel()}\r\n            ref={closeRef}\r\n          />\r\n        ) : null}\r\n        {title ? <div class=\"ant-modal-header\">{title}</div> : null}\r\n      </>\r\n    );\r\n\r\n    return () => {\r\n      return (\r\n        <AntdModal\r\n          key={props.modalKey}\r\n          visible={props.visible}\r\n          footer={null}\r\n          {...baseProps}\r\n          {...otherProps}\r\n        >\r\n          {isSelfWidth ? RenderSelfHeader() : null}\r\n          {children}\r\n        </AntdModal>\r\n      );\r\n    };\r\n  },\r\n});\r\n\r\nfunction hidden(key: number) {\r\n  if (key) {\r\n    const modal = store.modalKeys.find((item) => item.key === key);\r\n    modal && (modal.visible = false);\r\n  }\r\n}\r\n\r\nconst Modal = {\r\n  show(\r\n    children: JSX.Element,\r\n    config?: {\r\n      width?: string;\r\n      title?: string;\r\n      afterClose?: VoidFunction;\r\n      closable?: boolean;\r\n      fullscreen?: boolean;\r\n      onOk?: any;\r\n      onCancel?: any;\r\n      [name: string]: any;\r\n    },\r\n    context?: {\r\n      [name: string]: any;\r\n    }\r\n  ) {\r\n    return new Promise((resolve, reject) => {\r\n      const key = Date.now();\r\n      const { afterClose, ...otherConfig } = config || {};\r\n      store.modalMaps.set(key, {\r\n        context,\r\n        children,\r\n        closable: true,\r\n        afterClose: () => {\r\n          const itemIndex = store.modalKeys.findIndex(\r\n            (item) => item.key === key\r\n          );\r\n          if (itemIndex != -1) {\r\n            store.modalKeys.splice(itemIndex, 1);\r\n            store.modalMaps.delete(key);\r\n          }\r\n          afterClose?.();\r\n        },\r\n        ...otherConfig,\r\n        onOk: async (value?: any) => {\r\n          if (otherConfig.onOk) {\r\n            await otherConfig.onOk(value);\r\n          }\r\n          resolve(value);\r\n          hidden(key);\r\n        },\r\n        onCancel: (msg?: string) => {\r\n          reject(console.warn(msg));\r\n          hidden(key);\r\n        },\r\n      });\r\n      store.modalKeys.push({ key, visible: true });\r\n    });\r\n  },\r\n  use() {\r\n    const key = inject(\"modalContext\") as number;\r\n    const ctx = store.modalMaps.get(key);\r\n    return {\r\n      submit: ctx.onOk as (value?: any) => void,\r\n      cancel: ctx.onCancel as (msg?: any) => void,\r\n    };\r\n  },\r\n  input(params: {\r\n    title?: string;\r\n    defaultValue?: string;\r\n    placeholder?: string;\r\n    okText?: string;\r\n    cancelText?: string;\r\n    selection?: boolean;\r\n    onValid?: (value: string) => Promise<boolean>;\r\n    [name: string]: any;\r\n  }) {\r\n    const {\r\n      title,\r\n      defaultValue,\r\n      placeholder,\r\n      maxLength,\r\n      okText,\r\n      cancelText,\r\n      selection,\r\n      onValid,\r\n      ...otherParams\r\n    } = params;\r\n    return Modal.show(\r\n      <ModalInput\r\n        defaultValue={defaultValue}\r\n        placeholder={placeholder}\r\n        maxLength={maxLength}\r\n        selection={selection}\r\n        okText={okText}\r\n        cancelText={cancelText}\r\n      />,\r\n      {\r\n        width: \"400px\",\r\n        title: title,\r\n        closable: true,\r\n        ...otherParams,\r\n        onOk: async (v: any) => {\r\n          const isValid = await (onValid ? onValid(v) : true);\r\n          if (isValid) return v;\r\n          throw console.warn({ msg: \"invalid input value\", silence: true });\r\n        },\r\n      }\r\n    );\r\n  },\r\n\r\n  confirm(params: {\r\n    title?: string;\r\n    content?: any;\r\n    okText?: string;\r\n    refuseText?: string;\r\n    cancelText?: string;\r\n    type?: \"danger\";\r\n    [name: string]: any;\r\n  }) {\r\n    const { type, okText, refuseText, cancelText, content, ...otherParams } =\r\n      params;\r\n    return Modal.show(\r\n      <ModalConfirm\r\n        type={type}\r\n        content={content}\r\n        okText={okText}\r\n        refuseText={refuseText}\r\n        cancelText={cancelText}\r\n      />,\r\n      {\r\n        width: \"400px\",\r\n        ...otherParams,\r\n      }\r\n    );\r\n  },\r\n  clear() {\r\n    store.modalKeys = [];\r\n    store.modalMaps.clear();\r\n  },\r\n};\r\n\r\nexport const ModalProvider = defineComponent(() => {\r\n  // 路由跳转前销毁当前页面的弹层\r\n  const router = useRouter();\r\n  router.beforeEach(() => {\r\n    Modal.clear();\r\n  });\r\n\r\n  return () =>\r\n    store.modalKeys.map(({ key, visible }) => (\r\n      <MyModal key={key} visible={visible} modalKey={key} />\r\n    ));\r\n});\r\n\r\nexport default Modal;\r\n"]}