初始版本提交

This commit is contained in:
yaoyn
2024-02-05 09:15:37 +08:00
parent b52d4414be
commit 445292105f
1848 changed files with 236859 additions and 75 deletions

39
src/directives/loading.ts Normal file
View File

@ -0,0 +1,39 @@
import { createLoading } from '/@/components/Loading';
import type { Directive, App } from 'vue';
const loadingDirective: Directive = {
mounted(el, binding) {
const tip = el.getAttribute('loading-tip');
const background = el.getAttribute('loading-background');
const size = el.getAttribute('loading-size');
const fullscreen = !!binding.modifiers.fullscreen;
const instance = createLoading(
{
tip,
background,
size: size || 'large',
loading: !!binding.value,
absolute: !fullscreen,
},
fullscreen ? document.body : el,
);
el.instance = instance;
},
updated(el, binding) {
const instance = el.instance;
if (!instance) return;
instance.setTip(el.getAttribute('loading-tip'));
if (binding.oldValue !== binding.value) {
instance.setLoading?.(binding.value && !instance.loading);
}
},
unmounted(el) {
el?.instance?.close();
},
};
export function setupLoadingDirective(app: App) {
app.directive('loading', loadingDirective);
}
export default loadingDirective;