UNPKG

element-plus

Version:

A Component Library for Vue 3

1 lines 7.85 kB
{"version":3,"file":"service.mjs","names":[],"sources":["../../../../../../packages/components/loading/src/service.ts"],"sourcesContent":["// @ts-nocheck\nimport { nextTick } from 'vue'\nimport {\n addClass,\n getStyle,\n isClient,\n isString,\n removeClass,\n} from '@element-plus/utils'\nimport { createLoadingComponent } from './loading'\n\nimport type { UseNamespaceReturn, UseZIndexReturn } from '@element-plus/hooks'\nimport type { LoadingInstance } from './loading'\nimport type { LoadingOptionsResolved } from '..'\nimport type { LoadingOptions } from './types'\nimport type { AppContext, CSSProperties } from 'vue'\n\nlet fullscreenInstance: LoadingInstance | undefined = undefined\n\nconst Loading = function (\n options: LoadingOptions = {},\n context?: AppContext | null\n): LoadingInstance {\n if (!isClient) return undefined as any\n\n const resolved = resolveOptions(options)\n\n if (resolved.fullscreen && fullscreenInstance) {\n return fullscreenInstance\n }\n\n const instance = createLoadingComponent(\n {\n ...resolved,\n closed: () => {\n resolved.closed?.()\n if (resolved.fullscreen) fullscreenInstance = undefined\n },\n },\n context ?? Loading._context\n )\n\n addStyle(resolved, resolved.parent, instance)\n addClassList(resolved, resolved.parent, instance)\n\n resolved.parent.vLoadingAddClassList = () =>\n addClassList(resolved, resolved.parent, instance)\n\n /**\n * add loading-number to parent.\n * because if a fullscreen loading is triggered when somewhere\n * a v-loading.body was triggered before and it's parent is\n * document.body which with a margin , the fullscreen loading's\n * destroySelf function will remove 'el-loading-parent--relative',\n * and then the position of v-loading.body will be error.\n */\n let loadingNumber: string | null =\n resolved.parent.getAttribute('loading-number')\n if (!loadingNumber) {\n loadingNumber = '1'\n } else {\n loadingNumber = `${Number.parseInt(loadingNumber) + 1}`\n }\n resolved.parent.setAttribute('loading-number', loadingNumber)\n\n resolved.parent.appendChild(instance.$el)\n\n // after instance render, then modify visible to trigger transition\n nextTick(() => (instance.visible.value = resolved.visible))\n\n if (resolved.fullscreen) {\n fullscreenInstance = instance\n }\n return instance\n}\n\nconst resolveOptions = (options: LoadingOptions): LoadingOptionsResolved => {\n let target: HTMLElement\n if (isString(options.target)) {\n target =\n document.querySelector<HTMLElement>(options.target) ?? document.body\n } else {\n target = options.target || document.body\n }\n return {\n parent: target === document.body || options.body ? document.body : target,\n background: options.background || '',\n svg: options.svg || '',\n svgViewBox: options.svgViewBox || '',\n spinner: options.spinner || false,\n text: options.text || '',\n fullscreen: target === document.body && (options.fullscreen ?? true),\n lock: options.lock ?? false,\n customClass: options.customClass || '',\n visible: options.visible ?? true,\n beforeClose: options.beforeClose,\n closed: options.closed,\n target,\n }\n}\n\nconst addStyle = async (\n options: LoadingOptionsResolved,\n parent: HTMLElement,\n instance: LoadingInstance\n) => {\n // Compatible with the instance data format of vue@3.2.12 and earlier versions #12351\n const { nextZIndex } =\n ((instance.vm as any).zIndex as UseZIndexReturn) ||\n (instance.vm as any)._.exposed.zIndex\n\n const maskStyle: CSSProperties = {}\n if (options.fullscreen) {\n instance.originalPosition.value = getStyle(document.body, 'position')\n instance.originalOverflow.value = getStyle(document.body, 'overflow')\n maskStyle.zIndex = nextZIndex()\n } else if (options.parent === document.body) {\n instance.originalPosition.value = getStyle(document.body, 'position')\n /**\n * await dom render when visible is true in init,\n * because some component's height maybe 0.\n * e.g. el-table.\n */\n await nextTick()\n for (const property of ['top', 'left']) {\n const scroll = property === 'top' ? 'scrollTop' : 'scrollLeft'\n maskStyle[property] = `${\n (options.target as HTMLElement).getBoundingClientRect()[property] +\n document.body[scroll] +\n document.documentElement[scroll] -\n Number.parseInt(getStyle(document.body, `margin-${property}`), 10)\n }px`\n }\n for (const property of ['height', 'width']) {\n maskStyle[property] = `${\n (options.target as HTMLElement).getBoundingClientRect()[property]\n }px`\n }\n } else {\n instance.originalPosition.value = getStyle(parent, 'position')\n }\n for (const [key, value] of Object.entries(maskStyle)) {\n instance.$el.style[key] = value\n }\n}\n\nconst addClassList = (\n options: LoadingOptions,\n parent: HTMLElement,\n instance: LoadingInstance\n) => {\n // Compatible with the instance data format of vue@3.2.12 and earlier versions #12351\n const ns =\n ((instance.vm as any).ns as UseNamespaceReturn) ||\n (instance.vm as any)._.exposed.ns\n\n if (\n !['absolute', 'fixed', 'sticky'].includes(instance.originalPosition.value)\n ) {\n addClass(parent, ns.bm('parent', 'relative'))\n } else {\n removeClass(parent, ns.bm('parent', 'relative'))\n }\n if (options.fullscreen && options.lock) {\n addClass(parent, ns.bm('parent', 'hidden'))\n } else {\n removeClass(parent, ns.bm('parent', 'hidden'))\n }\n}\n\nLoading._context = null as AppContext | null\nexport default Loading\n"],"mappings":"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"}