/** * * @author Ray * * @date 2023-01-18 * * @workspace ray-template * * @remark 今天也是元气满满撸代码的一天 */ import { NSpin } from 'naive-ui' import { spinProps } from 'naive-ui' import { spinValue } from './hook' export { useSpin } from './hook' const GlobalSpin = defineComponent({ name: 'GlobalSpin', props: { ...spinProps, }, setup() { const overrides = { opacitySpinning: '0', } return { spinValue, overrides, } }, render() { return ( {{ default: () => this.$slots.default?.(), description: () => this.$slots.description?.(), }} ) }, }) export default GlobalSpin /** * * 全屏加载效果 * * 基于 Naive UI Spin 组件 * * 使用方法 * 1. import { useSpin } from '@/spin' * 2. useSpin(true) | useSpin(false) * * 仅需按照上述步骤实现全屏加载动画 * * 注意 * 1. 该组件为全屏加载动画效果, 其遮罩会导致页面元素不可被命中 * 2. 如果需要使用该组件请注意控制取消时机 */