@peng_kai/kit 0.1.15 → 0.1.17

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 (45) hide show
  1. package/admin/components/filter/src/FilterDrawer.vue +153 -153
  2. package/admin/components/filter/src/FilterParam.vue +78 -78
  3. package/admin/components/scroll-nav/index.ts +1 -1
  4. package/admin/components/scroll-nav/src/ScrollNav.vue +59 -59
  5. package/admin/components/text/index.ts +13 -13
  6. package/admin/components/text/src/Amount.vue +121 -121
  7. package/admin/components/text/src/Datetime.vue +48 -48
  8. package/admin/components/text/src/Duration.vue +26 -26
  9. package/admin/components/text/src/Hash.vue +51 -51
  10. package/admin/components/text/src/createTagGetter.ts +13 -13
  11. package/admin/hooks/useMenu.ts +128 -128
  12. package/admin/hooks/usePage.ts +141 -141
  13. package/admin/hooks/usePageTab.ts +35 -35
  14. package/admin/layout/large/Breadcrumb.vue +69 -69
  15. package/admin/layout/large/Content.vue +24 -24
  16. package/admin/layout/large/Menu.vue +69 -69
  17. package/admin/layout/large/PageTab.vue +71 -71
  18. package/admin/permission/index.ts +4 -4
  19. package/admin/permission/routerGuard.ts +43 -43
  20. package/admin/permission/usePermission.ts +52 -52
  21. package/admin/permission/vuePlugin.ts +30 -30
  22. package/admin/route-guards/index.ts +3 -3
  23. package/admin/route-guards/pageProgress.ts +27 -27
  24. package/admin/route-guards/pageTitle.ts +19 -19
  25. package/admin/scripts/deploy.ts +67 -0
  26. package/admin/styles/globalCover.scss +54 -54
  27. package/antd/components/InputNumberRange.vue +59 -59
  28. package/antd/directives/formLabelAlign.ts +36 -36
  29. package/antd/hooks/useAntdDrawer.ts +73 -73
  30. package/antd/hooks/useAntdTable.ts +115 -115
  31. package/package.json +58 -55
  32. package/request/helpers.ts +49 -49
  33. package/request/interceptors/checkCode.ts +3 -3
  34. package/request/interceptors/returnResultType.ts +2 -2
  35. package/request/interceptors/toLogin.ts +26 -26
  36. package/request/type.d.ts +92 -92
  37. package/stylelint.config.cjs +7 -7
  38. package/tsconfig.json +50 -50
  39. package/utils/blockchain.ts +57 -0
  40. package/utils/index.ts +12 -82
  41. package/utils/object.ts +17 -0
  42. package/utils/string.ts +28 -0
  43. package/vue/components/infinite-query/index.ts +1 -1
  44. package/vue/components/infinite-query/src/InfiniteQuery.vue +205 -205
  45. package/vue/components/infinite-query/src/useCreateTrigger.ts +39 -39
@@ -1,30 +1,30 @@
1
- import type { App } from 'vue';
2
- import { getDependencies } from '../../kitDependencies';
3
-
4
- export type THasPermissionsFn = ReturnType<ReturnType<typeof getDependencies>['usePermission']>['hasPermissions'];
5
-
6
- export function setupPermissionPlugin(app: App) {
7
- const { usePermission } = getDependencies();
8
- const { hasPermissions } = usePermission();
9
-
10
- app.directive('has-permissions', {
11
- mounted(el, binding) {
12
- const codes = binding.value;
13
-
14
- if (!hasPermissions(codes))
15
- el.remove();
16
- },
17
- updated(el, binding) {
18
- const codes = binding.value;
19
-
20
- if (!hasPermissions(codes))
21
- el.remove();
22
- },
23
- });
24
-
25
- app.use({
26
- install(app) {
27
- app.config.globalProperties.$hasPermission = hasPermissions;
28
- },
29
- });
30
- }
1
+ import type { App } from 'vue';
2
+ import { getDependencies } from '../../kitDependencies';
3
+
4
+ export type THasPermissionsFn = ReturnType<ReturnType<typeof getDependencies>['usePermission']>['hasPermissions'];
5
+
6
+ export function setupPermissionPlugin(app: App) {
7
+ const { usePermission } = getDependencies();
8
+ const { hasPermissions } = usePermission();
9
+
10
+ app.directive('has-permissions', {
11
+ mounted(el, binding) {
12
+ const codes = binding.value;
13
+
14
+ if (!hasPermissions(codes))
15
+ el.remove();
16
+ },
17
+ updated(el, binding) {
18
+ const codes = binding.value;
19
+
20
+ if (!hasPermissions(codes))
21
+ el.remove();
22
+ },
23
+ });
24
+
25
+ app.use({
26
+ install(app) {
27
+ app.config.globalProperties.$hasPermission = hasPermissions;
28
+ },
29
+ });
30
+ }
@@ -1,3 +1,3 @@
1
- export { setupPageProgress } from './pageProgress';
2
- export { setupPageTitle } from './pageTitle';
3
- export { setupCollapseMenu } from './collapseMenu';
1
+ export { setupPageProgress } from './pageProgress';
2
+ export { setupPageTitle } from './pageTitle';
3
+ export { setupCollapseMenu } from './collapseMenu';
@@ -1,27 +1,27 @@
1
- import type { Router } from 'vue-router';
2
- import { useStyleTag } from '@vueuse/core';
3
- import NProgress from 'nprogress';
4
- import 'nprogress/nprogress.css';
5
-
6
- /**
7
- * 用于显示页面跳转时,页面顶部进度条
8
- */
9
- export function setupPageProgress(router: Router) {
10
- NProgress.configure({ showSpinner: false });
11
- useStyleTag(`
12
- #nprogress .bar {
13
- height: 3px;
14
- background: var(--antd-colorPrimary);
15
- }
16
- #nprogress .peg {
17
- box-shadow: 0 0 10px var(--antd-colorPrimary), 0 0 5px var(--antd-colorPrimary);
18
- }
19
- `);
20
-
21
- router.beforeEach(() => {
22
- NProgress.start();
23
- });
24
- router.afterEach(() => {
25
- setTimeout(() => NProgress.done(), 200);
26
- });
27
- }
1
+ import type { Router } from 'vue-router';
2
+ import { useStyleTag } from '@vueuse/core';
3
+ import NProgress from 'nprogress';
4
+ import 'nprogress/nprogress.css';
5
+
6
+ /**
7
+ * 用于显示页面跳转时,页面顶部进度条
8
+ */
9
+ export function setupPageProgress(router: Router) {
10
+ NProgress.configure({ showSpinner: false });
11
+ useStyleTag(`
12
+ #nprogress .bar {
13
+ height: 3px;
14
+ background: var(--antd-colorPrimary);
15
+ }
16
+ #nprogress .peg {
17
+ box-shadow: 0 0 10px var(--antd-colorPrimary), 0 0 5px var(--antd-colorPrimary);
18
+ }
19
+ `);
20
+
21
+ router.beforeEach(() => {
22
+ NProgress.start();
23
+ });
24
+ router.afterEach(() => {
25
+ setTimeout(() => NProgress.done(), 200);
26
+ });
27
+ }
@@ -1,19 +1,19 @@
1
- import type { Router } from 'vue-router';
2
- import { getDependencies } from '../../kitDependencies';
3
-
4
- /**
5
- * 用于在路由跳转后,同步修改 title
6
- */
7
- export function setupPageTitle(router: Router) {
8
- const deps = getDependencies();
9
-
10
- router.afterEach((to, _, err) => {
11
- const title = to.meta.title;
12
-
13
- if (!err) {
14
- document.title = typeof title === 'function'
15
- ? title()
16
- : title ?? deps.appName;
17
- }
18
- });
19
- }
1
+ import type { Router } from 'vue-router';
2
+ import { getDependencies } from '../../kitDependencies';
3
+
4
+ /**
5
+ * 用于在路由跳转后,同步修改 title
6
+ */
7
+ export function setupPageTitle(router: Router) {
8
+ const deps = getDependencies();
9
+
10
+ router.afterEach((to, _, err) => {
11
+ const title = to.meta.title;
12
+
13
+ if (!err) {
14
+ document.title = typeof title === 'function'
15
+ ? title()
16
+ : title ?? deps.appName;
17
+ }
18
+ });
19
+ }
@@ -0,0 +1,67 @@
1
+ import fs from 'node:fs';
2
+ import process from 'node:process';
3
+ import path from 'node:path';
4
+ import { execa } from 'execa';
5
+ import archiver from 'archiver';
6
+
7
+ const DIST_DIR = 'dist';
8
+ const DEV_BRANCH = 'develop';
9
+
10
+ const distPath = path.join(process.cwd(), DIST_DIR);
11
+ const distZipName = `${DIST_DIR}.zip`;
12
+ const distZipPath = `${distPath}.zip`;
13
+
14
+ const { stdout } = await execa(`git branch --show-current`);
15
+ const currentBranch = stdout;
16
+
17
+ if (currentBranch !== DEV_BRANCH) {
18
+ await build();
19
+ await execa(`git stash push -u -m "部署"`);
20
+ await execa(`git checkout ${DEV_BRANCH}`);
21
+ console.log('⏬ 拉取代码成功!');
22
+ await execa(`git pull`);
23
+ }
24
+ else {
25
+ console.log('⏬ 拉取代码成功!');
26
+ await execa(`git pull`);
27
+ await build();
28
+ }
29
+
30
+ if (fs.existsSync(distZipPath)) {
31
+ fs.unlinkSync(distZipPath);
32
+ console.log('🗑️ 删除旧 dist.zip');
33
+ }
34
+
35
+ await zipDirectory(path.join(process.cwd(), DIST_DIR));
36
+ console.log('✨ 生成新 dist.zip');
37
+
38
+ await execa(`git add ${distZipName}`);
39
+ await execa(`git commit -m "部署"`);
40
+ await execa(`git push`);
41
+ console.log('✅ 推送代码成功!\n');
42
+
43
+ if (currentBranch !== DEV_BRANCH) {
44
+ await execa(`git checkout ${currentBranch}`);
45
+ await execa(`git stash pop`);
46
+ }
47
+
48
+ async function build() {
49
+ process.stdout.write('📦 打包中...');
50
+ await execa(`pnpm run build@script`);
51
+ process.stdout.write('\r📦 打包成功!\n');
52
+ }
53
+
54
+ function zipDirectory(dir: string) {
55
+ const archive = archiver('zip', { zlib: { level: 5 } });
56
+ const stream = fs.createWriteStream(`${dir}.zip`);
57
+
58
+ return new Promise((resolve, reject) => {
59
+ archive
60
+ .directory(dir, DIST_DIR)
61
+ .on('error', err => reject(err))
62
+ .pipe(stream);
63
+
64
+ stream.on('close', () => resolve(1));
65
+ archive.finalize();
66
+ });
67
+ }
@@ -1,54 +1,54 @@
1
- :root {
2
- // table 组件头部圆角设为 0
3
- .ant-table-wrapper {
4
- .ant-table .ant-table-header,
5
- table,
6
- .ant-table-container table > thead > tr:first-child > *:first-child,
7
- .ant-table-container table > thead > tr:first-child > *:last-child {
8
- border-radius: 0;
9
- }
10
-
11
- .ant-pagination {
12
- margin-bottom: 0;
13
- }
14
- }
15
-
16
-
17
- // 隐藏在 sticky 模式下的滚动条
18
- .ant-table-sticky-scroll {
19
- display: none;
20
- }
21
-
22
- // 卡片
23
- .ant-card .ant-card-actions > li > span {
24
- cursor: inherit;
25
- }
26
-
27
- // Tab 溢出出现下列框时
28
- .ant-tabs-dropdown-menu-title-content {
29
- display: flex;
30
- align-items: center;
31
- justify-content: space-between;
32
- }
33
-
34
- // 表格
35
- .ant-table-wrapper {
36
- .ant-table-row-expand-icon-collapsed::before {
37
- height: 1.5px;
38
- }
39
- .ant-table-row-expand-icon-collapsed::after {
40
- width: 1.5px;
41
- }
42
- }
43
-
44
- .ant-drawer {
45
- &:focus {
46
- outline: none;
47
- }
48
-
49
- &.ant-drawer-bottom .ant-drawer-content {
50
- border-top-left-radius: 8px;
51
- border-top-right-radius: 8px;
52
- }
53
- }
54
- }
1
+ :root {
2
+ // table 组件头部圆角设为 0
3
+ .ant-table-wrapper {
4
+ .ant-table .ant-table-header,
5
+ table,
6
+ .ant-table-container table > thead > tr:first-child > *:first-child,
7
+ .ant-table-container table > thead > tr:first-child > *:last-child {
8
+ border-radius: 0;
9
+ }
10
+
11
+ .ant-pagination {
12
+ margin-bottom: 0;
13
+ }
14
+ }
15
+
16
+
17
+ // 隐藏在 sticky 模式下的滚动条
18
+ .ant-table-sticky-scroll {
19
+ display: none;
20
+ }
21
+
22
+ // 卡片
23
+ .ant-card .ant-card-actions > li > span {
24
+ cursor: inherit;
25
+ }
26
+
27
+ // Tab 溢出出现下列框时
28
+ .ant-tabs-dropdown-menu-title-content {
29
+ display: flex;
30
+ align-items: center;
31
+ justify-content: space-between;
32
+ }
33
+
34
+ // 表格
35
+ .ant-table-wrapper {
36
+ .ant-table-row-expand-icon-collapsed::before {
37
+ height: 1.5px;
38
+ }
39
+ .ant-table-row-expand-icon-collapsed::after {
40
+ width: 1.5px;
41
+ }
42
+ }
43
+
44
+ .ant-drawer {
45
+ &:focus {
46
+ outline: none;
47
+ }
48
+
49
+ &.ant-drawer-bottom .ant-drawer-content {
50
+ border-top-left-radius: 8px;
51
+ border-top-right-radius: 8px;
52
+ }
53
+ }
54
+ }
@@ -1,59 +1,59 @@
1
- <script lang="ts">
2
- import { computed } from 'vue';
3
- import { InputNumber as AInputNumber, Form } from 'ant-design-vue';
4
- </script>
5
-
6
- <script setup lang="ts">
7
- const props = withDefaults(
8
- defineProps<{
9
- value: [number | undefined, number | undefined]
10
- placeholder?: [string, string]
11
- min?: number
12
- max?: number
13
- }>(),
14
- {
15
- min: Number.NEGATIVE_INFINITY,
16
- max: Number.POSITIVE_INFINITY,
17
- },
18
- );
19
- const emits = defineEmits<{
20
- (e: 'update:value', value: typeof props.value): void
21
- }>();
22
-
23
- const formItemContext = Form.useInjectFormItemContext();
24
- const minValue = computed({
25
- get() {
26
- return props.value[0];
27
- },
28
- set(value) {
29
- updateValue(value, maxValue.value);
30
- },
31
- });
32
- const maxValue = computed({
33
- get() {
34
- return props.value[1];
35
- },
36
- set(value) {
37
- updateValue(minValue.value, value);
38
- },
39
- });
40
-
41
- function updateValue(...args: typeof props.value) {
42
- emits('update:value', args.sort());
43
- formItemContext.onFieldChange();
44
- }
45
- </script>
46
-
47
- <template>
48
- <div class="flex items-center">
49
- <AInputNumber
50
- v-model:value="minValue" class="w-full" :min="props.min"
51
- :max="props.max" :placeholder="props.placeholder?.[0]"
52
- />
53
- <span>&nbsp;-&nbsp;</span>
54
- <AInputNumber
55
- v-model:value="maxValue" class="w-full" :min="props.min"
56
- :max="props.max" :placeholder="props.placeholder?.[1]"
57
- />
58
- </div>
59
- </template>
1
+ <script lang="ts">
2
+ import { computed } from 'vue';
3
+ import { InputNumber as AInputNumber, Form } from 'ant-design-vue';
4
+ </script>
5
+
6
+ <script setup lang="ts">
7
+ const props = withDefaults(
8
+ defineProps<{
9
+ value: [number | undefined, number | undefined]
10
+ placeholder?: [string, string]
11
+ min?: number
12
+ max?: number
13
+ }>(),
14
+ {
15
+ min: Number.NEGATIVE_INFINITY,
16
+ max: Number.POSITIVE_INFINITY,
17
+ },
18
+ );
19
+ const emits = defineEmits<{
20
+ (e: 'update:value', value: typeof props.value): void
21
+ }>();
22
+
23
+ const formItemContext = Form.useInjectFormItemContext();
24
+ const minValue = computed({
25
+ get() {
26
+ return props.value[0];
27
+ },
28
+ set(value) {
29
+ updateValue(value, maxValue.value);
30
+ },
31
+ });
32
+ const maxValue = computed({
33
+ get() {
34
+ return props.value[1];
35
+ },
36
+ set(value) {
37
+ updateValue(minValue.value, value);
38
+ },
39
+ });
40
+
41
+ function updateValue(...args: typeof props.value) {
42
+ emits('update:value', args.sort());
43
+ formItemContext.onFieldChange();
44
+ }
45
+ </script>
46
+
47
+ <template>
48
+ <div class="flex items-center">
49
+ <AInputNumber
50
+ v-model:value="minValue" class="w-full" :min="props.min"
51
+ :max="props.max" :placeholder="props.placeholder?.[0]"
52
+ />
53
+ <span>&nbsp;-&nbsp;</span>
54
+ <AInputNumber
55
+ v-model:value="maxValue" class="w-full" :min="props.min"
56
+ :max="props.max" :placeholder="props.placeholder?.[1]"
57
+ />
58
+ </div>
59
+ </template>
@@ -1,36 +1,36 @@
1
- import type { App } from 'vue';
2
-
3
- export function formLabelAlign(app: App) {
4
- const directiveName = 'antd-form-label-align';
5
- const resizeObserverKey = `${directiveName}@resizeObserver`;
6
-
7
- function init(el: HTMLElement) {
8
- const labels = el.querySelectorAll('.ant-form-item .ant-form-item-label');
9
- const resizeObserver = new ResizeObserver((entries) => {
10
- const widths = entries.map(e => e.borderBoxSize?.[0]?.inlineSize ?? 0);
11
- const maxWidth = Math.max(...widths);
12
-
13
- if (maxWidth <= 0)
14
- return;
15
-
16
- el.style.setProperty('--max-label-width', `${maxWidth}px`);
17
- entries.forEach((e) => {
18
- const target = e.target as HTMLElement;
19
- target.style.setProperty('width', 'var(--max-label-width)');
20
- });
21
- });
22
-
23
- Array.from(labels).forEach(label => resizeObserver.observe(label));
24
-
25
- return resizeObserver;
26
- }
27
-
28
- app.directive(directiveName, {
29
- mounted(el: HTMLElement) {
30
- (el as any)[resizeObserverKey] = init(el);
31
- },
32
- updated(el) {
33
- (el as any)[resizeObserverKey] = init(el);
34
- },
35
- });
36
- }
1
+ import type { App } from 'vue';
2
+
3
+ export function formLabelAlign(app: App) {
4
+ const directiveName = 'antd-form-label-align';
5
+ const resizeObserverKey = `${directiveName}@resizeObserver`;
6
+
7
+ function init(el: HTMLElement) {
8
+ const labels = el.querySelectorAll('.ant-form-item .ant-form-item-label');
9
+ const resizeObserver = new ResizeObserver((entries) => {
10
+ const widths = entries.map(e => e.borderBoxSize?.[0]?.inlineSize ?? 0);
11
+ const maxWidth = Math.max(...widths);
12
+
13
+ if (maxWidth <= 0)
14
+ return;
15
+
16
+ el.style.setProperty('--max-label-width', `${maxWidth}px`);
17
+ entries.forEach((e) => {
18
+ const target = e.target as HTMLElement;
19
+ target.style.setProperty('width', 'var(--max-label-width)');
20
+ });
21
+ });
22
+
23
+ Array.from(labels).forEach(label => resizeObserver.observe(label));
24
+
25
+ return resizeObserver;
26
+ }
27
+
28
+ app.directive(directiveName, {
29
+ mounted(el: HTMLElement) {
30
+ (el as any)[resizeObserverKey] = init(el);
31
+ },
32
+ updated(el) {
33
+ (el as any)[resizeObserverKey] = init(el);
34
+ },
35
+ });
36
+ }
@@ -1,73 +1,73 @@
1
- import { Button as AButton, Drawer as ADrawer, Space as ASpace } from 'ant-design-vue';
2
- import { defineComponent, h, isProxy, reactive, toRef, toRefs } from 'vue';
3
- import type { Component } from 'vue';
4
- import type { ButtonProps, DrawerProps } from 'ant-design-vue';
5
- import type { ComponentProps } from 'vue-component-type-helpers';
6
- import type { Writable } from 'type-fest';
7
- import { useComponentRef } from '../../vue';
8
-
9
- const defaultDrawerProps: DrawerProps = { open: false, destroyOnClose: true, rootClassName: 'antd-cover__basic-drawer' };
10
-
11
- interface IComponentConfig<Comp extends Component> {
12
- is: Comp
13
- props?: Writable<ComponentProps<Comp>>
14
- }
15
-
16
- export function useAntdDrawer<Comp extends Component>(
17
- comp: IComponentConfig<Comp> | Comp,
18
- drawerProps = defaultDrawerProps,
19
- ) {
20
- const _comp = ({ props: {}, ...((comp as any)?.is ? comp : { is: comp }) }) as Required<IComponentConfig<Comp>>;
21
- const compProps = reactive(_comp.props);
22
- const compRef = useComponentRef(_comp.is);
23
- const _drawerProps: DrawerProps = reactive({
24
- ...defaultDrawerProps,
25
- ...isProxy(drawerProps) ? toRefs(drawerProps) : drawerProps,
26
- });
27
-
28
- const open = (newBodyProps?: Partial<typeof compProps>, newAntdModalProps?: Omit<Partial<DrawerProps>, 'open'>) => {
29
- Object.assign(_drawerProps, newAntdModalProps);
30
- Object.assign(compProps, newBodyProps);
31
- _drawerProps.open = true;
32
- };
33
- const close = () => {
34
- _drawerProps.open = false;
35
- };
36
-
37
- const DrawerFooter = defineComponent({
38
- setup() {
39
- const cancelBtnProps: ButtonProps = reactive({ onClick: close });
40
- const confirmBtnProps: ButtonProps = reactive({
41
- type: 'primary',
42
- loading: toRef(() => (compRef as any)?.loading),
43
- onClick: () => (compRef as any)?.confirm?.(),
44
- });
45
-
46
- return { cancelBtnProps, confirmBtnProps };
47
- },
48
- render() {
49
- const { cancelBtnProps, confirmBtnProps } = this;
50
-
51
- return h(ASpace, {}, () => [
52
- h(AButton, cancelBtnProps, () => '取消'),
53
- h(AButton, confirmBtnProps, () => '确定'),
54
- ]);
55
- },
56
- });
57
- const PresetComponent = defineComponent({
58
- render() {
59
- return h(ADrawer, _drawerProps, {
60
- default: () => h(_comp.is, compProps as any),
61
- });
62
- },
63
- });
64
-
65
- _drawerProps.footer = _drawerProps.footer === undefined ? h(DrawerFooter) : _drawerProps.footer;
66
- _drawerProps['onUpdate:open'] = (visiable) => {
67
- _drawerProps.open = visiable;
68
- };
69
- (compProps as any).ref = compRef;
70
- (compProps as any).onClose = close;
71
-
72
- return { PresetComponent, drawerProps: _drawerProps, open, close };
73
- }
1
+ import { Button as AButton, Drawer as ADrawer, Space as ASpace } from 'ant-design-vue';
2
+ import { defineComponent, h, isProxy, reactive, toRef, toRefs } from 'vue';
3
+ import type { Component } from 'vue';
4
+ import type { ButtonProps, DrawerProps } from 'ant-design-vue';
5
+ import type { ComponentProps } from 'vue-component-type-helpers';
6
+ import type { Writable } from 'type-fest';
7
+ import { useComponentRef } from '../../vue';
8
+
9
+ const defaultDrawerProps: DrawerProps = { open: false, destroyOnClose: true, rootClassName: 'antd-cover__basic-drawer' };
10
+
11
+ interface IComponentConfig<Comp extends Component> {
12
+ is: Comp
13
+ props?: Writable<ComponentProps<Comp>>
14
+ }
15
+
16
+ export function useAntdDrawer<Comp extends Component>(
17
+ comp: IComponentConfig<Comp> | Comp,
18
+ drawerProps = defaultDrawerProps,
19
+ ) {
20
+ const _comp = ({ props: {}, ...((comp as any)?.is ? comp : { is: comp }) }) as Required<IComponentConfig<Comp>>;
21
+ const compProps = reactive(_comp.props);
22
+ const compRef = useComponentRef(_comp.is);
23
+ const _drawerProps: DrawerProps = reactive({
24
+ ...defaultDrawerProps,
25
+ ...isProxy(drawerProps) ? toRefs(drawerProps) : drawerProps,
26
+ });
27
+
28
+ const open = (newBodyProps?: Partial<typeof compProps>, newAntdModalProps?: Omit<Partial<DrawerProps>, 'open'>) => {
29
+ Object.assign(_drawerProps, newAntdModalProps);
30
+ Object.assign(compProps, newBodyProps);
31
+ _drawerProps.open = true;
32
+ };
33
+ const close = () => {
34
+ _drawerProps.open = false;
35
+ };
36
+
37
+ const DrawerFooter = defineComponent({
38
+ setup() {
39
+ const cancelBtnProps: ButtonProps = reactive({ onClick: close });
40
+ const confirmBtnProps: ButtonProps = reactive({
41
+ type: 'primary',
42
+ loading: toRef(() => (compRef as any)?.loading),
43
+ onClick: () => (compRef as any)?.confirm?.(),
44
+ });
45
+
46
+ return { cancelBtnProps, confirmBtnProps };
47
+ },
48
+ render() {
49
+ const { cancelBtnProps, confirmBtnProps } = this;
50
+
51
+ return h(ASpace, {}, () => [
52
+ h(AButton, cancelBtnProps, () => '取消'),
53
+ h(AButton, confirmBtnProps, () => '确定'),
54
+ ]);
55
+ },
56
+ });
57
+ const PresetComponent = defineComponent({
58
+ render() {
59
+ return h(ADrawer, _drawerProps, {
60
+ default: () => h(_comp.is, compProps as any),
61
+ });
62
+ },
63
+ });
64
+
65
+ _drawerProps.footer = _drawerProps.footer === undefined ? h(DrawerFooter) : _drawerProps.footer;
66
+ _drawerProps['onUpdate:open'] = (visiable) => {
67
+ _drawerProps.open = visiable;
68
+ };
69
+ (compProps as any).ref = compRef;
70
+ (compProps as any).onClose = close;
71
+
72
+ return { PresetComponent, drawerProps: _drawerProps, open, close };
73
+ }