@gx-design-vue/pro-layout 0.1.0-alpha.2 → 0.1.0-alpha.4

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 (256) hide show
  1. package/dist/ProLayout.d.ts +5 -536
  2. package/dist/ProLayout.js +487 -356
  3. package/dist/components/AppPage/context.d.ts +4 -3
  4. package/dist/components/AppPage/context.js +3 -5
  5. package/dist/components/AppPage/index.d.ts +32 -28
  6. package/dist/components/AppPage/index.js +58 -52
  7. package/dist/components/AppPage/style.d.ts +9 -7
  8. package/dist/components/AppPage/style.js +15 -16
  9. package/dist/components/Breadcrumb/index.d.ts +20 -0
  10. package/dist/components/Breadcrumb/index.js +123 -0
  11. package/dist/components/Breadcrumb/interface.d.ts +28 -0
  12. package/dist/components/Breadcrumb/interface.js +1 -0
  13. package/dist/components/CollapseButton/Arrow.d.ts +6 -0
  14. package/dist/components/{SiderMenu → CollapseButton}/Arrow.js +2 -4
  15. package/dist/components/CollapseButton/index.d.ts +8 -0
  16. package/dist/components/CollapseButton/index.js +39 -0
  17. package/dist/components/CollapseButton/interface.d.ts +18 -0
  18. package/dist/components/CollapseButton/interface.js +1 -0
  19. package/dist/components/Footer/index.d.ts +11 -0
  20. package/dist/components/Footer/index.js +71 -0
  21. package/dist/components/Footer/interface.d.ts +22 -0
  22. package/dist/components/Footer/interface.js +1 -0
  23. package/dist/components/FooterToolbar/index.d.ts +6 -72
  24. package/dist/components/FooterToolbar/index.js +78 -90
  25. package/dist/components/FooterToolbar/style.d.ts +11 -0
  26. package/dist/components/FooterToolbar/style.js +34 -0
  27. package/dist/components/Header/index.d.ts +8 -0
  28. package/dist/components/Header/index.js +144 -0
  29. package/dist/components/Header/interface.d.ts +35 -0
  30. package/dist/components/Header/interface.js +1 -0
  31. package/dist/components/Logo/index.d.ts +10 -0
  32. package/dist/components/Logo/index.js +60 -0
  33. package/dist/components/Logo/interface.d.ts +14 -0
  34. package/dist/components/Logo/interface.js +1 -0
  35. package/dist/components/Menu/convert.d.ts +14 -0
  36. package/dist/components/Menu/convert.js +50 -0
  37. package/dist/components/Menu/index.d.ts +15 -0
  38. package/dist/components/Menu/index.js +236 -0
  39. package/dist/components/Menu/interface.d.ts +50 -0
  40. package/dist/components/Menu/interface.js +9 -0
  41. package/dist/components/PageContainer/PageHeader.d.ts +34 -36
  42. package/dist/components/PageContainer/PageHeader.js +88 -46
  43. package/dist/components/PageContainer/index.d.ts +9 -194
  44. package/dist/components/PageContainer/index.js +290 -209
  45. package/dist/components/PageContainer/style.d.ts +7 -0
  46. package/dist/components/PageContainer/style.js +129 -0
  47. package/dist/components/PageTransition/animate.d.ts +41 -0
  48. package/dist/components/PageTransition/animate.js +106 -0
  49. package/dist/components/PageTransition/index.d.ts +58 -0
  50. package/dist/components/PageTransition/index.js +66 -0
  51. package/dist/components/{PageTranstion → PageTransition}/keyFrame/back.d.ts +4 -4
  52. package/dist/components/{PageTranstion → PageTransition}/keyFrame/back.js +2 -4
  53. package/dist/components/{PageTranstion → PageTransition}/keyFrame/bounce.d.ts +4 -4
  54. package/dist/components/{PageTranstion → PageTransition}/keyFrame/bounce.js +2 -4
  55. package/dist/components/{PageTranstion → PageTransition}/keyFrame/fade.d.ts +4 -4
  56. package/dist/components/{PageTranstion → PageTransition}/keyFrame/fade.js +2 -4
  57. package/dist/components/{PageTranstion → PageTransition}/keyFrame/flip.d.ts +4 -4
  58. package/dist/components/{PageTranstion → PageTransition}/keyFrame/flip.js +2 -4
  59. package/dist/components/{PageTranstion → PageTransition}/keyFrame/lightSpeed.d.ts +4 -4
  60. package/dist/components/{PageTranstion → PageTransition}/keyFrame/lightSpeed.js +2 -4
  61. package/dist/components/PageTransition/keyFrame/roll.d.ts +10 -0
  62. package/dist/components/{PageTranstion → PageTransition}/keyFrame/roll.js +2 -4
  63. package/dist/components/{PageTranstion → PageTransition}/keyFrame/rotate.d.ts +4 -4
  64. package/dist/components/{PageTranstion → PageTransition}/keyFrame/rotate.js +2 -4
  65. package/dist/components/{PageTranstion → PageTransition}/keyFrame/slide.d.ts +4 -4
  66. package/dist/components/{PageTranstion → PageTransition}/keyFrame/slide.js +2 -4
  67. package/dist/components/{PageTranstion → PageTransition}/keyFrame/zoom.d.ts +4 -4
  68. package/dist/components/{PageTranstion → PageTransition}/keyFrame/zoom.js +2 -4
  69. package/dist/components/PageTransition/style.d.ts +12 -0
  70. package/dist/components/{PageTranstion → PageTransition}/style.js +9 -13
  71. package/dist/components/Sider/SiderMenu.d.ts +28 -0
  72. package/dist/components/Sider/SiderMenu.js +674 -0
  73. package/dist/components/Sider/index.d.ts +8 -0
  74. package/dist/components/Sider/index.js +157 -0
  75. package/dist/components/Sider/interface.d.ts +36 -0
  76. package/dist/components/Sider/interface.js +1 -0
  77. package/dist/components/Sider/style.d.ts +298 -0
  78. package/dist/components/Sider/style.js +369 -0
  79. package/dist/components/Tabs/contextMenu.d.ts +41 -0
  80. package/dist/components/Tabs/contextMenu.js +87 -0
  81. package/dist/components/Tabs/index.d.ts +8 -0
  82. package/dist/components/Tabs/index.js +163 -0
  83. package/dist/components/Tabs/interface.d.ts +35 -0
  84. package/dist/components/Tabs/interface.js +1 -0
  85. package/dist/components/WrapContent/index.d.ts +10 -0
  86. package/dist/components/WrapContent/index.js +26 -0
  87. package/dist/components/WrapContent/interface.d.ts +15 -0
  88. package/dist/components/WrapContent/interface.js +1 -0
  89. package/dist/context/index.d.ts +49 -0
  90. package/dist/context/index.js +5 -0
  91. package/dist/defaultConfig.d.ts +10 -0
  92. package/dist/defaultConfig.js +38 -0
  93. package/dist/hooks/useLayoutBase.d.ts +78 -0
  94. package/dist/hooks/useLayoutBase.js +78 -0
  95. package/dist/hooks/useMenu.d.ts +77 -0
  96. package/dist/hooks/useMenu.js +166 -0
  97. package/dist/hooks/useTabs.d.ts +58 -0
  98. package/dist/hooks/useTabs.js +348 -0
  99. package/dist/index.d.ts +21 -27
  100. package/dist/index.js +14 -24
  101. package/dist/interface.d.ts +492 -0
  102. package/dist/interface.js +36 -0
  103. package/dist/pro-layout.esm.js +5843 -5435
  104. package/dist/pro-layout.js +1 -37
  105. package/dist/style/breadcrumb.d.ts +8 -0
  106. package/dist/style/breadcrumb.js +76 -0
  107. package/dist/style/collapseButton.d.ts +8 -0
  108. package/dist/style/collapseButton.js +57 -0
  109. package/dist/style/content.d.ts +8 -0
  110. package/dist/style/content.js +27 -0
  111. package/dist/style/footer.d.ts +8 -0
  112. package/dist/style/footer.js +33 -0
  113. package/dist/style/header.d.ts +8 -0
  114. package/dist/style/header.js +76 -0
  115. package/dist/style/index.d.ts +4 -21
  116. package/dist/style/index.js +51 -55
  117. package/dist/style/logo.d.ts +8 -0
  118. package/dist/style/logo.js +72 -0
  119. package/dist/style/menu.d.ts +15 -0
  120. package/dist/style/menu.js +49 -0
  121. package/dist/style/rightContent.d.ts +12 -0
  122. package/dist/style/rightContent.js +74 -0
  123. package/dist/style/search.d.ts +12 -0
  124. package/dist/style/search.js +94 -0
  125. package/dist/style/sider.d.ts +8 -0
  126. package/dist/style/sider.js +77 -0
  127. package/dist/style/tabs.d.ts +8 -0
  128. package/dist/style/tabs.js +128 -0
  129. package/dist/theme/augment.d.ts +18 -0
  130. package/dist/theme/augment.js +1 -0
  131. package/dist/theme/interface/components.d.ts +18 -0
  132. package/dist/theme/interface/components.js +1 -0
  133. package/dist/utils/config.d.ts +12 -0
  134. package/dist/utils/config.js +18 -0
  135. package/dist/utils/menu.d.ts +111 -20
  136. package/dist/utils/menu.js +262 -118
  137. package/dist/utils/style.d.ts +4 -0
  138. package/dist/utils/style.js +21 -0
  139. package/dist/utils/themeComponents.d.ts +24 -0
  140. package/dist/utils/themeComponents.js +79 -0
  141. package/package.json +13 -13
  142. package/dist/Context/expose.d.ts +0 -6
  143. package/dist/Context/expose.js +0 -7
  144. package/dist/Context/index.d.ts +0 -43
  145. package/dist/Context/index.js +0 -18
  146. package/dist/WrapContent.d.ts +0 -100
  147. package/dist/WrapContent.js +0 -45
  148. package/dist/components/BaseMenu/index.d.ts +0 -255
  149. package/dist/components/BaseMenu/index.js +0 -381
  150. package/dist/components/BaseMenu/props.d.ts +0 -105
  151. package/dist/components/BaseMenu/props.js +0 -94
  152. package/dist/components/BaseMenu/style.d.ts +0 -6
  153. package/dist/components/BaseMenu/style.js +0 -155
  154. package/dist/components/BreadCrumb/Breadcrumb.d.ts +0 -33
  155. package/dist/components/BreadCrumb/Breadcrumb.js +0 -75
  156. package/dist/components/BreadCrumb/index.d.ts +0 -7
  157. package/dist/components/BreadCrumb/index.js +0 -44
  158. package/dist/components/BreadCrumb/style.d.ts +0 -8
  159. package/dist/components/BreadCrumb/style.js +0 -87
  160. package/dist/components/CollapsedIcon/index.d.ts +0 -33
  161. package/dist/components/CollapsedIcon/index.js +0 -51
  162. package/dist/components/CollapsedIcon/style.d.ts +0 -9
  163. package/dist/components/CollapsedIcon/style.js +0 -34
  164. package/dist/components/FooterToolbar/props.d.ts +0 -47
  165. package/dist/components/FooterToolbar/props.js +0 -33
  166. package/dist/components/FooterToolbar/style/index.d.ts +0 -14
  167. package/dist/components/FooterToolbar/style/index.js +0 -48
  168. package/dist/components/FooterToolbar/style/stylish.d.ts +0 -18
  169. package/dist/components/FooterToolbar/style/stylish.js +0 -16
  170. package/dist/components/GlobalFooter/index.d.ts +0 -73
  171. package/dist/components/GlobalFooter/index.js +0 -77
  172. package/dist/components/GlobalFooter/style.d.ts +0 -6
  173. package/dist/components/GlobalFooter/style.js +0 -29
  174. package/dist/components/GlobalHeader/DefaultHeader.d.ts +0 -164
  175. package/dist/components/GlobalHeader/DefaultHeader.js +0 -149
  176. package/dist/components/GlobalHeader/index.d.ts +0 -164
  177. package/dist/components/GlobalHeader/index.js +0 -78
  178. package/dist/components/GlobalHeader/props.d.ts +0 -70
  179. package/dist/components/GlobalHeader/props.js +0 -56
  180. package/dist/components/GlobalHeader/style/defaultHeader.d.ts +0 -6
  181. package/dist/components/GlobalHeader/style/defaultHeader.js +0 -108
  182. package/dist/components/GlobalHeader/style/header.d.ts +0 -6
  183. package/dist/components/GlobalHeader/style/header.js +0 -41
  184. package/dist/components/LogoContent/index.d.ts +0 -80
  185. package/dist/components/LogoContent/index.js +0 -90
  186. package/dist/components/LogoContent/props.d.ts +0 -57
  187. package/dist/components/LogoContent/props.js +0 -37
  188. package/dist/components/LogoContent/style.d.ts +0 -6
  189. package/dist/components/LogoContent/style.js +0 -63
  190. package/dist/components/PageContainer/props.d.ts +0 -138
  191. package/dist/components/PageContainer/props.js +0 -103
  192. package/dist/components/PageContainer/style/index.d.ts +0 -14
  193. package/dist/components/PageContainer/style/index.js +0 -52
  194. package/dist/components/PageContainer/style/pageHeader.d.ts +0 -6
  195. package/dist/components/PageContainer/style/pageHeader.js +0 -44
  196. package/dist/components/PageTranstion/index.d.ts +0 -40
  197. package/dist/components/PageTranstion/index.js +0 -71
  198. package/dist/components/PageTranstion/keyFrame/roll.d.ts +0 -10
  199. package/dist/components/PageTranstion/style.d.ts +0 -10
  200. package/dist/components/SiderMenu/Arrow.d.ts +0 -6
  201. package/dist/components/SiderMenu/SiderMenu.d.ts +0 -180
  202. package/dist/components/SiderMenu/SiderMenu.js +0 -265
  203. package/dist/components/SiderMenu/index.d.ts +0 -193
  204. package/dist/components/SiderMenu/index.js +0 -51
  205. package/dist/components/SiderMenu/props.d.ts +0 -77
  206. package/dist/components/SiderMenu/props.js +0 -67
  207. package/dist/components/SiderMenu/style/index.d.ts +0 -12
  208. package/dist/components/SiderMenu/style/index.js +0 -162
  209. package/dist/components/SiderMenu/typings.d.ts +0 -38
  210. package/dist/components/SiderMenu/typings.js +0 -1
  211. package/dist/components/TabsRoute/index.d.ts +0 -95
  212. package/dist/components/TabsRoute/index.js +0 -405
  213. package/dist/components/TabsRoute/props.d.ts +0 -78
  214. package/dist/components/TabsRoute/props.js +0 -47
  215. package/dist/components/TabsRoute/style.d.ts +0 -15
  216. package/dist/components/TabsRoute/style.js +0 -133
  217. package/dist/components/TabsRoute/utils/config.d.ts +0 -18
  218. package/dist/components/TabsRoute/utils/config.js +0 -64
  219. package/dist/config/animate.d.ts +0 -11
  220. package/dist/config/animate.js +0 -76
  221. package/dist/config/index.d.ts +0 -34
  222. package/dist/config/index.js +0 -30
  223. package/dist/hooks/collapsed/index.d.ts +0 -15
  224. package/dist/hooks/collapsed/index.js +0 -50
  225. package/dist/hooks/layout/useLayoutExpose.d.ts +0 -15
  226. package/dist/hooks/layout/useLayoutExpose.js +0 -22
  227. package/dist/hooks/layout/usePageContent.d.ts +0 -6
  228. package/dist/hooks/layout/usePageContent.js +0 -28
  229. package/dist/hooks/menu/context.d.ts +0 -21
  230. package/dist/hooks/menu/context.js +0 -7
  231. package/dist/hooks/menu/index.d.ts +0 -29
  232. package/dist/hooks/menu/index.js +0 -118
  233. package/dist/hooks/theme/index.d.ts +0 -11
  234. package/dist/hooks/theme/index.js +0 -13
  235. package/dist/props/collapsedProps.d.ts +0 -39
  236. package/dist/props/collapsedProps.js +0 -45
  237. package/dist/props/defaultSettings.d.ts +0 -62
  238. package/dist/props/defaultSettings.js +0 -56
  239. package/dist/props/index.d.ts +0 -226
  240. package/dist/props/index.js +0 -109
  241. package/dist/props/themeProps.d.ts +0 -14
  242. package/dist/props/themeProps.js +0 -10
  243. package/dist/types/Breadcrumb.d.ts +0 -22
  244. package/dist/types/Breadcrumb.js +0 -1
  245. package/dist/types/MenuTypings.d.ts +0 -46
  246. package/dist/types/MenuTypings.js +0 -1
  247. package/dist/types/RouteTypings.d.ts +0 -96
  248. package/dist/types/RouteTypings.js +0 -1
  249. package/dist/types/SlotsTypings.d.ts +0 -124
  250. package/dist/types/SlotsTypings.js +0 -32
  251. package/dist/types/typings.d.ts +0 -73
  252. package/dist/types/typings.js +0 -3
  253. package/dist/utils/index.d.ts +0 -7
  254. package/dist/utils/index.js +0 -17
  255. package/dist/utils/style/index.d.ts +0 -44
  256. package/dist/utils/style/index.js +0 -103
package/dist/ProLayout.js CHANGED
@@ -1,371 +1,502 @@
1
- import { defaultContextKey, provideProLayoutContext } from "./Context/index.js";
2
- import GlobalFooter_default from "./components/GlobalFooter/index.js";
3
- import { useProLayoutMenuContext } from "./hooks/menu/context.js";
4
- import { calculateCss, getCssVarOrUnit } from "./utils/style/index.js";
5
- import "./utils/index.js";
6
- import { defaultSettings } from "./config/index.js";
7
- import { compatibleStyle, genProLayoutStyle } from "./style/index.js";
8
- import GlobalHeader_default from "./components/GlobalHeader/index.js";
9
- import SiderMenu_default from "./components/SiderMenu/index.js";
10
- import { provideProLayoutExposeContext } from "./Context/expose.js";
11
- import { basicLayoutProps } from "./props/index.js";
12
- import { defaultSlots, headerSlots, siderMenuSlots } from "./types/SlotsTypings.js";
13
- import { WrapContent, baseWrapContentKeys } from "./WrapContent.js";
14
- import { Fragment, computed, createVNode, defineComponent, mergeProps, reactive, ref, toRefs, watch } from "vue";
1
+ import { useInjectLayoutContext, useProvideLayoutContext } from "./context/index.js";
2
+ import LayoutFooter$1 from "./components/Footer/index.js";
3
+ import Header from "./components/Header/index.js";
4
+ import LayoutSider$1 from "./components/Sider/index.js";
5
+ import LayoutTabs from "./components/Tabs/index.js";
6
+ import WrapContent from "./components/WrapContent/index.js";
7
+ import { DEFAULT_LAYOUT_CONFIG } from "./defaultConfig.js";
8
+ import { useMenu } from "./hooks/useMenu.js";
9
+ import { useTabsState } from "./hooks/useTabs.js";
10
+ import { LAYOUT_SLOT_KEYS } from "./interface.js";
11
+ import style_default from "./style/index.js";
12
+ import { normalizeSectionConfig } from "./utils/config.js";
13
+ import { computed, createVNode, defineComponent, mergeDefaults, ref } from "vue";
15
14
  import { ThemeContext, useThemeContext } from "@gx-design-vue/context";
16
- import { useMediaQuery, useSlotsProps, useState } from "@gx-design-vue/pro-hooks";
17
- import { GProConfigProvider, useProConfigContext, useProStyle } from "@gx-design-vue/pro-provider";
18
- import { classNames, deepMerge, getLevelData, getPrefixCls, getRandomNumber, getSlot, getSlotVNode, getSlotsProps } from "@gx-design-vue/pro-utils";
19
- import { useDark } from "@vueuse/core";
20
- import { ConfigProvider, Layout } from "ant-design-vue";
21
- import { omit, pick } from "es-toolkit";
22
-
15
+ import { GProConfigProvider, useProToken } from "@gx-design-vue/pro-provider";
16
+ import { classNames, getSlot, getSlotsProps } from "@gx-design-vue/pro-utils";
17
+ import { useDark, useMediaQuery, useVModel } from "@vueuse/core";
18
+ import { ConfigProvider, Layout } from "antdv-next";
19
+ import { useBaseConfig } from "antdv-next/config-provider/context";
20
+ import useCSSVarCls from "antdv-next/config-provider/hooks/useCSSVarCls";
21
+ import { useRouter } from "vue-router";
23
22
  //#region src/ProLayout.tsx
24
- const { Content } = Layout;
25
- const BaseProLayout = /* @__PURE__ */ defineComponent({
26
- name: "BaseProLayout",
27
- inheritAttrs: false,
23
+ const InnerLayout = /* @__PURE__ */ defineComponent((props, { slots }) => {
24
+ const parentCtx = useInjectLayoutContext();
25
+ const { proLayoutToken } = useProToken();
26
+ const { prefixCls } = useBaseConfig("pro-layout");
27
+ const rootCls = useCSSVarCls(prefixCls);
28
+ const [hashId, cssVarCls] = style_default(prefixCls, rootCls);
29
+ useProvideLayoutContext({
30
+ ...parentCtx,
31
+ hashId,
32
+ cssVarCls,
33
+ rootCls
34
+ });
35
+ return () => createVNode("div", {
36
+ "class": classNames(prefixCls.value, `${prefixCls.value}-${props.layout}`, hashId.value, cssVarCls.value, rootCls.value, props.proClasses?.root),
37
+ "style": props.proStyles?.root,
38
+ "data-layout": props.layout
39
+ }, [proLayoutToken.value?.bgLayout && createVNode("div", { "class": `${prefixCls.value}-bg-list` }, null), createVNode(Layout, { "style": {
40
+ minHeight: "100%",
41
+ flexDirection: props.showSider ? "row" : void 0
42
+ } }, { default: () => [slots.default?.()] })]);
43
+ }, {
28
44
  props: {
29
- ...basicLayoutProps,
30
- onCollapse: Function
45
+ layout: {
46
+ type: String,
47
+ required: true
48
+ },
49
+ showSider: {
50
+ type: Boolean,
51
+ required: true
52
+ },
53
+ proClasses: {
54
+ type: Object,
55
+ required: false
56
+ },
57
+ proStyles: {
58
+ type: Object,
59
+ required: false
60
+ }
31
61
  },
32
- slots: Object,
33
- setup(props, { slots }) {
34
- const baseClassName = getPrefixCls({
35
- suffixCls: "basic-layout",
36
- isPor: true
37
- });
38
- const { wrapSSR, hashId } = useProStyle("ProLayout", [compatibleStyle, genProLayoutStyle], baseClassName);
39
- const { theme, resolvedTheme } = useThemeContext();
40
- const [hasFooterToolbar, setHasFooterToolbar] = useState(false);
41
- const colSize = useMediaQuery();
42
- const layoutMenuContext = useProLayoutMenuContext();
43
- const slotsProps = useSlotsProps({
62
+ name: "InnerLayout"
63
+ });
64
+ const GProLayout = /* @__PURE__ */ defineComponent((props, { emit, expose, slots }) => {
65
+ const router = useRouter();
66
+ const themeValue = useThemeContext();
67
+ const mergeToken = computed(() => {
68
+ const token = props.token || {};
69
+ if (!token.headerHeightLayoutHeader) token.headerHeightLayoutHeader = DEFAULT_LAYOUT_CONFIG.header.height;
70
+ return {
71
+ ...token,
72
+ layoutKey: `${isDark.value ? "dark" : "light"}:${props.layout}`
73
+ };
74
+ });
75
+ const layout = computed(() => props.layout ?? "side");
76
+ const isMobile = useMediaQuery("(max-width: 768px)");
77
+ const collapsed = useVModel(props, "collapsed", emit, {
78
+ passive: true,
79
+ defaultValue: false
80
+ });
81
+ const isDark = useDark();
82
+ const theme = useVModel(props, "theme", emit, {
83
+ passive: true,
84
+ defaultValue: themeValue?.theme?.value ?? "system"
85
+ });
86
+ const { menuState } = useMenu({
87
+ menus: () => props.menus,
88
+ selectedKeys: () => props.selectedKeys,
89
+ openKeys: () => props.openKeys,
90
+ config: () => props.menu ?? {},
91
+ layout: () => layout.value,
92
+ isMobile: () => isMobile.value
93
+ });
94
+ const selectedKeysModel = useVModel(props, "selectedKeys", emit, {
95
+ passive: true,
96
+ defaultValue: []
97
+ });
98
+ const openKeysModel = useVModel(props, "openKeys", emit, {
99
+ passive: true,
100
+ defaultValue: []
101
+ });
102
+ const contentFullscreen = ref(false);
103
+ const renderRouterView = ref(true);
104
+ const hasFooterToolbar = ref(false);
105
+ const breadcrumbRender = ref(null);
106
+ const zIndex = ref(100);
107
+ function navigate(name) {
108
+ const target = menuState.resolveRoute(name);
109
+ if (target.type === "external" && target.link) {
110
+ window.open(target.link);
111
+ return;
112
+ }
113
+ if (target.path && router.currentRoute.value.fullPath !== target.path) router.push(target.path);
114
+ }
115
+ const tabsConf = computed(() => normalizeSectionConfig(props.tabsConfig, DEFAULT_LAYOUT_CONFIG.tabsConfig));
116
+ const tabsStateConfig = computed(() => tabsConf.value ?? {});
117
+ const tabsState = useTabsState({
118
+ tabs: useVModel(props, "tabs", emit, {
119
+ passive: true,
120
+ defaultValue: []
121
+ }),
122
+ config: tabsStateConfig,
123
+ flatMenus: menuState.flatMenus,
124
+ collapsed,
125
+ siderWidth: props.sider?.width ?? DEFAULT_LAYOUT_CONFIG.sider.width,
126
+ collapseWidth: props.collapseConfig ? props.collapseConfig.width ?? DEFAULT_LAYOUT_CONFIG.collapseConfig.width : DEFAULT_LAYOUT_CONFIG.collapseConfig.width,
127
+ isMobile: computed(() => isMobile.value),
128
+ contentFullscreen,
129
+ onTabsChange: (val) => {
130
+ emit("tabsChange", val);
131
+ },
132
+ onUpdateTabs: (val) => {
133
+ emit("update:tabs", val);
134
+ },
135
+ onReloadPage: () => {
136
+ emit("reloadPage");
137
+ renderRouterView.value = false;
138
+ setTimeout(() => {
139
+ renderRouterView.value = true;
140
+ }, 200);
141
+ },
142
+ onContentFullscreenChange: (val) => {
143
+ emit("contentFullscreenChange", val);
144
+ }
145
+ });
146
+ function handleSelect(info) {
147
+ menuState.selectedKeys.value = info.keys;
148
+ selectedKeysModel.value = info.keys;
149
+ emit("select", info);
150
+ emit("update:selectedKeys", info.keys);
151
+ navigate(info.key);
152
+ }
153
+ function handleOpenChange(keys) {
154
+ menuState.openKeys.value = keys;
155
+ openKeysModel.value = keys;
156
+ emit("openChange", keys);
157
+ emit("update:openKeys", keys);
158
+ }
159
+ function handleCollapsedUpdate(value) {
160
+ collapsed.value = value;
161
+ emit("update:collapsed", value);
162
+ }
163
+ function handleLogoClick() {
164
+ emit("logoClick");
165
+ }
166
+ const logoConfig = computed(() => normalizeSectionConfig(props.logoConfig, DEFAULT_LAYOUT_CONFIG.logoConfig));
167
+ const collapseConfig = computed(() => normalizeSectionConfig(props.collapseConfig, DEFAULT_LAYOUT_CONFIG.collapseConfig));
168
+ const footerConfig = computed(() => normalizeSectionConfig(props.footerConfig, DEFAULT_LAYOUT_CONFIG.footerConfig));
169
+ const breadcrumbConfig = computed(() => normalizeSectionConfig(props.breadcrumbConfig, DEFAULT_LAYOUT_CONFIG.breadcrumbConfig));
170
+ const pageContainerConfig = computed(() => ({
171
+ ...DEFAULT_LAYOUT_CONFIG.pageContainerConfig,
172
+ ...props.pageContainerConfig || {}
173
+ }));
174
+ const showHeader = computed(() => !contentFullscreen.value && layout.value !== "simple" && props.header?.height !== 0);
175
+ const showSider = computed(() => !contentFullscreen.value && [
176
+ "side",
177
+ "mix",
178
+ "wide"
179
+ ].includes(layout.value ?? "") && props.sider?.width !== 0);
180
+ const showFooter = computed(() => !contentFullscreen.value && layout.value !== "simple" && footerConfig.value !== null);
181
+ const { prefixCls } = useBaseConfig("pro-layout");
182
+ function getPrefixCls(suffixCls) {
183
+ return [prefixCls.value, suffixCls].filter(Boolean).join("-");
184
+ }
185
+ useProvideLayoutContext({
186
+ layout,
187
+ header: computed(() => ({
188
+ ...DEFAULT_LAYOUT_CONFIG.header,
189
+ ...props.header || {}
190
+ })),
191
+ sider: computed(() => ({
192
+ ...DEFAULT_LAYOUT_CONFIG.sider,
193
+ ...props.sider || {}
194
+ })),
195
+ menuState,
196
+ logoConfig,
197
+ breadcrumbConfig,
198
+ pageContainerConfig,
199
+ watermark: computed(() => props.watermark),
200
+ proStyles: computed(() => props.proStyles ?? {}),
201
+ proClasses: computed(() => props.proClasses ?? {}),
202
+ collapsed,
203
+ collapseConfig,
204
+ isMobile: computed(() => isMobile.value),
205
+ contentFullscreen,
206
+ renderRouterView,
207
+ zIndex,
208
+ currentMeta: menuState.currentMeta,
209
+ prefixCls,
210
+ hashId: ref(""),
211
+ cssVarCls: computed(() => ""),
212
+ rootCls: computed(() => ""),
213
+ breadcrumbRender,
214
+ hasFooterToolbar,
215
+ getPrefixCls,
216
+ setHasFooterToolbar: (value) => {
217
+ hasFooterToolbar.value = value;
218
+ },
219
+ navigate,
220
+ tabsState
221
+ });
222
+ expose({ tabs: tabsState.tabsController });
223
+ function resolveLayoutSlots() {
224
+ const merged = getSlotsProps({
44
225
  slots,
45
226
  props,
46
- keys: defaultSlots,
47
- render: true
48
- });
49
- const { token } = useProConfigContext();
50
- const currentMeta = ref();
51
- const collapsed = ref(!!props.collapsedProps?.value);
52
- const renderRouterView = ref(true);
53
- const fullScreenOnTabsHide = ref(false);
54
- const contentFullScreen = ref(false);
55
- const breadcrumbRender = ref();
56
- const layoutChangKey = ref(getRandomNumber().uuid(10));
57
- const genLayoutStyle = reactive({ position: "relative" });
58
- const layoutProps = computed(() => {
59
- let siderWidth = 0;
60
- if (contentFullScreen.value) siderWidth = 0;
61
- else if (props.settings.siderWidth === 0) siderWidth = 0;
62
- else {
63
- const wideSiderWidth = props.settings.layout === "wide" ? 208 : defaultSettings.siderWidth;
64
- siderWidth = getCssVarOrUnit(props.settings.siderWidth || wideSiderWidth);
65
- }
66
- return {
67
- isWide: props.settings.layout === "wide",
68
- headerHeight: props.settings.headerHeight === 0 ? 0 : getCssVarOrUnit(props.settings.headerHeight || defaultSettings.headerHeight),
69
- siderWidth,
70
- hasSilder: props.settings.layout === "mix" || props.settings.layout === "side" || props.settings.layout === "wide" || false
71
- };
72
- });
73
- const collapsedProps = computed(() => {
74
- return deepMerge({
75
- position: "fixed",
76
- width: 64
77
- }, props.collapsedProps || {});
227
+ keys: LAYOUT_SLOT_KEYS,
228
+ render: false
78
229
  });
79
- const menu = computed(() => {
80
- const menuData = props.route || layoutMenuContext?.menuData?.value || [];
81
- const flatMenus = layoutMenuContext?.flatMenus?.value ?? getLevelData(menuData);
82
- return {
83
- ...props.menu,
84
- menuData,
85
- flatMenus,
86
- key: theme.value,
87
- baseTheme: resolvedTheme.value,
88
- mixSiderMenus: menuData.find((item) => item.name === props.selectedKeys[0])?.children || []
89
- };
90
- });
91
- const isMobile = computed(() => (colSize.value === "sm" || colSize.value === "xs") && !props.disableMobile && !layoutProps.value.isWide);
92
- const breadcrumb = computed(() => ({
93
- ...props.breadcrumb,
94
- position: props.breadcrumb?.position ?? "header",
95
- visible: props.breadcrumb?.visible ?? true,
96
- homeIcon: props.breadcrumb?.homeIcon ?? true,
97
- breadcrumbRender: getSlot({
230
+ const normalized = Object.fromEntries(Object.entries(merged).map(([key, value]) => [key, typeof value === "function" ? value : () => value]));
231
+ if (slots.logo) normalized.logo = slots.logo;
232
+ if (props.collapseConfig) {
233
+ const collapseIconSlot = getSlot({
98
234
  slots,
99
- props: { breadcrumbRender: props.pageContainer?.breadcrumbRender },
100
- key: "breadcrumbRender"
101
- })
102
- }));
103
- watch(() => props.collapsedProps?.value, (value) => {
104
- collapsed.value = !!value;
105
- });
106
- watch(() => collapsed.value, (value) => {
107
- props.onCollapse?.(value);
108
- });
109
- watch(() => props.settings.layout, ([layout]) => {
110
- if (layout === "wide" || layout === "simple") contentFullScreen.value = false;
111
- layoutChangKey.value = getRandomNumber().uuid(10);
112
- });
113
- watch(() => layoutProps.value.isWide, (wide) => {
114
- if (wide) {
115
- const metaViewport = document.querySelector("meta[name=\"viewport\"]");
116
- if (metaViewport) metaViewport.content = "";
117
- }
118
- }, { immediate: true });
119
- watch(contentFullScreen, (val) => {
120
- props.onContentFullScreenChange?.(val);
121
- });
122
- watch(() => props.isChildrenLayout, () => {
123
- const contentStyle = props.styles?.content;
124
- if (props.isChildrenLayout || contentStyle && contentStyle.minHeight) genLayoutStyle.minHeight = 0;
125
- }, {
126
- immediate: true,
127
- deep: true
128
- });
129
- function getCommonLayoutSlots() {
130
- return getSlotsProps({
131
- slots,
132
- props,
133
- keys: [
134
- "menuItemRender",
135
- "menuTextRender",
136
- "subMenuItemRender",
137
- "collapsedIconRender",
138
- "collapsedButtonRender"
139
- ]
235
+ props: { collapseIcon: props.collapseConfig.icon },
236
+ key: "collapseIcon"
140
237
  });
238
+ if (collapseIconSlot) normalized.collapseIcon = collapseIconSlot;
141
239
  }
142
- const GlobalHeaderRender = () => {
143
- if (props.headerRender === false || props.pure || props.settings.layout === "simple" || !layoutProps.value.headerHeight || layoutProps.value.headerHeight === 0) return null;
144
- const slotPropsFn = getSlotsProps({
145
- slots,
146
- props,
147
- keys: [
148
- "logoRender",
149
- "headerRender",
150
- "headerContentRender",
151
- "rightContentRender"
152
- ]
153
- });
154
- return createVNode(GlobalHeader_default, mergeProps(props, getSlotsProps({
155
- slots,
156
- props,
157
- keys: headerSlots,
158
- render: true
159
- }), getCommonLayoutSlots(), {
160
- "logoRender": slotPropsFn.logoRender,
161
- "headerRender": slotPropsFn.headerRender,
162
- "rightContentRender": slotPropsFn.rightContentRender,
163
- "headerContentRender": slotPropsFn.headerContentRender
164
- }), null);
165
- };
166
- const GlobalSilderMenuRender = () => {
167
- if (!layoutProps.value.siderWidth || layoutProps.value.siderWidth === 0) return null;
168
- const defaultSilderMenuSlots = getSlotsProps({
169
- slots,
170
- props,
171
- keys: siderMenuSlots,
172
- render: true
173
- });
174
- const slotsPropsFn = getSlotsProps({
175
- slots,
176
- props,
177
- keys: [
178
- "logoRender",
179
- "menuHeaderRender",
180
- "menuFooterRender",
181
- "menuContentRender"
182
- ]
183
- });
184
- return createVNode(SiderMenu_default, mergeProps(props, defaultSilderMenuSlots, getCommonLayoutSlots(), {
185
- "isMobile": isMobile.value,
186
- "logoRender": slotsPropsFn.logoRender,
187
- "siderWidth": layoutProps.value.siderWidth,
188
- "menuHeaderRender": slotsPropsFn.menuHeaderRender,
189
- "menuFooterRender": slotsPropsFn.menuFooterRender,
190
- "menuContentRender": slotsPropsFn.menuContentRender
191
- }), null);
192
- };
193
- const GlobalFooterRender = () => {
194
- const footerRender = getSlot({
195
- slots,
196
- props,
197
- key: "footerRender",
198
- render: false
199
- });
200
- return createVNode(Fragment, null, [footerRender === false ? null : typeof footerRender === "function" ? footerRender(props) : footerRender || createVNode(GlobalFooter_default, {
201
- "copyright": slotsProps.value.copyrightRender,
202
- "links": props.footerLinks
203
- }, null), hasFooterToolbar.value && createVNode("div", {
204
- "class": `${baseClassName}-has-footer`,
205
- "style": {
206
- height: "64px",
207
- marginBlockStart: token.value.marginMD
240
+ return normalized;
241
+ }
242
+ return () => {
243
+ if (props.pure) return slots.default?.();
244
+ const layoutSlots = resolveLayoutSlots();
245
+ return createVNode(ConfigProvider, { "theme": props.colorPrimary ? { token: { colorPrimary: props.colorPrimary } } : void 0 }, { default: () => [createVNode(GProConfigProvider, {
246
+ "dark": isDark.value,
247
+ "theme": { token: mergeToken.value }
248
+ }, { default: () => [createVNode(ThemeContext, {
249
+ "theme": theme.value,
250
+ "onChange": (value) => theme.value = value
251
+ }, { default: () => [createVNode(InnerLayout, {
252
+ "layout": layout.value,
253
+ "showSider": showSider.value,
254
+ "proClasses": props.proClasses,
255
+ "proStyles": props.proStyles
256
+ }, { default: () => [showSider.value && createVNode(LayoutSider$1, {
257
+ "onSelect": handleSelect,
258
+ "onOpenChange": handleOpenChange,
259
+ "onLogoClick": handleLogoClick,
260
+ "onUpdate:collapsed": handleCollapsedUpdate
261
+ }, layoutSlots), createVNode("div", {
262
+ "style": { position: "relative" },
263
+ "class": `${prefixCls.value}-container`,
264
+ "data-testid": "pro-layout-container"
265
+ }, [
266
+ showHeader.value && createVNode(Header, {
267
+ "onLogoClick": handleLogoClick,
268
+ "onUpdate:collapsed": handleCollapsedUpdate,
269
+ "onSelect": handleSelect
270
+ }, layoutSlots),
271
+ tabsConf.value && createVNode(LayoutTabs, {
272
+ "config": tabsConf.value,
273
+ "onReloadPage": () => emit("reloadPage"),
274
+ "onContentFullscreenChange": (val) => {
275
+ contentFullscreen.value = val;
276
+ emit("contentFullscreenChange", val);
208
277
  }
209
- }, null)]);
210
- };
211
- provideProLayoutContext({
212
- ...pick(toRefs(props), defaultContextKey),
213
- collapsedProps,
214
- getPrefixCls,
215
- collapsed,
216
- collapsedEffect: computed(() => {
217
- if (collapsedProps.value?.width) return collapsed.value;
218
- return false;
278
+ }, { tabBarItem: layoutSlots.tabBarItem }),
279
+ createVNode(WrapContent, { "loading": props.loading }, {
280
+ default: () => [slots.default?.()],
281
+ ...layoutSlots
219
282
  }),
220
- settings: computed(() => props.settings),
221
- menu,
222
- currentMeta,
223
- contentFullScreen,
224
- layoutProps,
225
- isMobile,
226
- renderRouterView,
227
- breadcrumb,
228
- fullScreenOnTabsHide,
229
- breadcrumbRender,
230
- hasFooterToolbar,
231
- setHasFooterToolbar,
232
- pageHeaderRender: computed(() => getSlotVNode({
233
- slots,
234
- props: { pageHeaderRender: props.pageContainer?.pageHeaderRender },
235
- key: "pageHeaderRender"
236
- }))
237
- });
238
- return () => {
239
- const rootStyle = {
240
- minWidth: layoutProps.value.isWide ? getCssVarOrUnit(props.settings.wideWidth) : void 0,
241
- minHeight: props.settings.layout === "simple" ? `calc(100vh - ${getCssVarOrUnit(props.settings.headerHeight)})` : void 0,
242
- ...props.styles?.root || {}
243
- };
244
- return wrapSSR(createVNode(Fragment, null, [props.pure ? slots.default?.() : createVNode("div", {
245
- "id": props.id,
246
- "class": classNames({
247
- [`${hashId.value}`]: true,
248
- [`${props.classNames?.root}`]: !!props.classNames?.root,
249
- [`${baseClassName}`]: true,
250
- [`${baseClassName}-${props.settings.layout}`]: true
251
- }),
252
- "style": rootStyle
253
- }, [
254
- token.value.layout?.bgLayout ? createVNode("div", { "class": classNames(`${baseClassName}-bg-list`, hashId.value) }, null) : null,
255
- createVNode(Layout, { "style": layoutProps.value.isWide ? {
256
- width: getCssVarOrUnit(props.settings.wideWidth),
257
- paddingTop: calculateCss(layoutProps.value.headerHeight, 20),
258
- margin: layoutProps.value.isWide ? "0 auto" : void 0
259
- } : void 0 }, { default: () => [GlobalSilderMenuRender(), createVNode(Layout, { "style": genLayoutStyle }, { default: () => [
260
- GlobalHeaderRender(),
261
- createVNode(WrapContent, mergeProps(pick(props, baseWrapContentKeys), {
262
- "tabsRoute": {
263
- ...props.tabsRoute,
264
- itemRender: slots.tabsRouteItemRender || props.tabsRoute?.itemRender
265
- },
266
- "hashId": hashId.value,
267
- "prefixCls": baseClassName
268
- }), { default: () => [createVNode(Content, { "class": classNames(`${baseClassName}-content`, hashId.value) }, { default: () => [slots.default?.()] })] }),
269
- !layoutProps.value.isWide && GlobalFooterRender()
270
- ] })] }),
271
- layoutProps.value.isWide && GlobalFooterRender()
272
- ])]));
273
- };
274
- }
275
- });
276
- var ProLayout_default = /* @__PURE__ */ defineComponent({
283
+ showFooter.value && createVNode(LayoutFooter$1, {
284
+ "links": footerConfig.value.links,
285
+ "copyright": footerConfig.value.copyright
286
+ }, {
287
+ footer: layoutSlots.footer,
288
+ copyright: layoutSlots.copyright
289
+ })
290
+ ])] })] })] })] });
291
+ };
292
+ }, {
293
+ props: /* @__PURE__ */ mergeDefaults({
294
+ layout: {
295
+ type: String,
296
+ required: false
297
+ },
298
+ colorPrimary: {
299
+ type: String,
300
+ required: false
301
+ },
302
+ menus: {
303
+ type: Array,
304
+ required: false
305
+ },
306
+ pure: {
307
+ type: Boolean,
308
+ required: false,
309
+ default: void 0
310
+ },
311
+ loading: {
312
+ type: Boolean,
313
+ required: false,
314
+ default: void 0
315
+ },
316
+ collapsed: {
317
+ type: Boolean,
318
+ required: false,
319
+ default: void 0
320
+ },
321
+ theme: {
322
+ type: String,
323
+ required: false
324
+ },
325
+ selectedKeys: {
326
+ type: Array,
327
+ required: false
328
+ },
329
+ openKeys: {
330
+ type: Array,
331
+ required: false
332
+ },
333
+ tabs: {
334
+ type: Array,
335
+ required: false
336
+ },
337
+ token: { required: false },
338
+ proStyles: {
339
+ type: Object,
340
+ required: false
341
+ },
342
+ proClasses: {
343
+ type: Object,
344
+ required: false
345
+ },
346
+ watermark: {
347
+ type: Object,
348
+ required: false
349
+ },
350
+ header: {
351
+ type: Object,
352
+ required: false
353
+ },
354
+ sider: {
355
+ type: Object,
356
+ required: false
357
+ },
358
+ footerConfig: {
359
+ type: [Object, Boolean],
360
+ required: false,
361
+ default: void 0
362
+ },
363
+ menu: {
364
+ type: Object,
365
+ required: false
366
+ },
367
+ breadcrumbConfig: {
368
+ type: [Object, Boolean],
369
+ required: false,
370
+ default: void 0
371
+ },
372
+ tabsConfig: {
373
+ type: [Object, Boolean],
374
+ required: false,
375
+ default: void 0
376
+ },
377
+ logoConfig: {
378
+ type: [Object, Boolean],
379
+ required: false,
380
+ default: void 0
381
+ },
382
+ collapseConfig: {
383
+ type: [Object, Boolean],
384
+ required: false,
385
+ default: void 0
386
+ },
387
+ pageContainerConfig: {
388
+ type: Object,
389
+ required: false
390
+ },
391
+ headerContent: {
392
+ type: Function,
393
+ required: false
394
+ },
395
+ headerRight: {
396
+ type: Function,
397
+ required: false
398
+ },
399
+ headerRightExtra: {
400
+ type: [
401
+ Function,
402
+ Object,
403
+ String,
404
+ Number,
405
+ Boolean,
406
+ null,
407
+ Array
408
+ ],
409
+ required: false,
410
+ default: void 0
411
+ },
412
+ siderHeader: {
413
+ type: Function,
414
+ required: false
415
+ },
416
+ siderFooter: {
417
+ type: Function,
418
+ required: false
419
+ },
420
+ siderExtra: {
421
+ type: [
422
+ Function,
423
+ Object,
424
+ String,
425
+ Number,
426
+ Boolean,
427
+ null,
428
+ Array
429
+ ],
430
+ required: false,
431
+ default: void 0
432
+ },
433
+ collapseButton: {
434
+ type: Function,
435
+ required: false
436
+ },
437
+ menuItemIcon: {
438
+ type: Function,
439
+ required: false
440
+ },
441
+ menuItemLabel: {
442
+ type: Function,
443
+ required: false
444
+ },
445
+ menuItemExtra: {
446
+ type: Function,
447
+ required: false
448
+ },
449
+ breadcrumb: {
450
+ type: Function,
451
+ required: false
452
+ },
453
+ tabBarItem: {
454
+ type: Function,
455
+ required: false
456
+ },
457
+ footer: {
458
+ type: [
459
+ Function,
460
+ Object,
461
+ String,
462
+ Number,
463
+ Boolean,
464
+ null,
465
+ Array
466
+ ],
467
+ required: false,
468
+ default: void 0
469
+ },
470
+ copyright: {
471
+ type: [
472
+ Function,
473
+ Object,
474
+ String,
475
+ Number,
476
+ Boolean,
477
+ null,
478
+ Array
479
+ ],
480
+ required: false,
481
+ default: void 0
482
+ }
483
+ }, DEFAULT_LAYOUT_CONFIG),
484
+ emits: [
485
+ "update:collapsed",
486
+ "update:theme",
487
+ "update:selectedKeys",
488
+ "update:openKeys",
489
+ "update:tabs",
490
+ "select",
491
+ "openChange",
492
+ "darkChange",
493
+ "logoClick",
494
+ "reloadPage",
495
+ "tabsChange",
496
+ "contentFullscreenChange"
497
+ ],
277
498
  name: "GProLayout",
278
- compatConfig: { MODE: 3 },
279
- inheritAttrs: false,
280
- props: basicLayoutProps,
281
- emits: {
282
- select: (_value) => true,
283
- "update:selected-keys": (_value) => true,
284
- openKeys: (_value) => true,
285
- "update:open-keys": (_value) => true,
286
- collapse: (_value) => true,
287
- reloadPage: () => true,
288
- logoClick: () => true,
289
- tabsChange: (tabs) => tabs.length > 0,
290
- "update:tabs": (tabs) => tabs.length > 0,
291
- themeChange: (_value) => true,
292
- darkChange: (_value) => true,
293
- "update:theme": (_value) => true,
294
- contentFullScreenChange: (_value) => true
295
- },
296
- slots: Object,
297
- setup(props, { slots, emit, expose }) {
298
- const themeValue = useThemeContext();
299
- const tabsRouteRef = ref();
300
- const [theme, setTheme] = useState(props.theme ?? themeValue?.theme?.value ?? "system");
301
- watch(() => props.theme, (value) => {
302
- if (value) theme.value = value;
303
- });
304
- const isDark = useDark();
305
- const mergeToken = computed(() => {
306
- let token = props.token || {};
307
- if (!token.layout?.header?.heightLayoutHeader) {
308
- const height = props.settings.headerHeight === 0 ? defaultSettings.headerHeight : getCssVarOrUnit(props.settings.headerHeight || defaultSettings.headerHeight);
309
- token = deepMerge(token, { layout: { header: { heightLayoutHeader: height } } });
310
- }
311
- return deepMerge(token, { layout: { key: `${isDark.value ? "dark" : "light"}:${props.settings.layout}` } });
312
- });
313
- const onCollapse = (collapsed) => {
314
- emit("collapse", collapsed);
315
- if (props.collapsedProps?.onCollapse) props.collapsedProps.onCollapse(collapsed);
316
- };
317
- const onOpenKeys = (openKeys) => {
318
- emit("update:open-keys", openKeys);
319
- emit("openKeys", openKeys);
320
- };
321
- const onSelect = (selectedKeys) => {
322
- emit("update:selected-keys", selectedKeys);
323
- emit("select", selectedKeys);
324
- };
325
- const onTabsChange = (tabs) => {
326
- emit("update:tabs", tabs);
327
- emit("tabsChange", tabs);
328
- };
329
- const onContentFullScreenChange = (value) => {
330
- emit("contentFullScreenChange", value);
331
- };
332
- provideProLayoutExposeContext({ tabsRouteRef });
333
- expose({ tabsRouteRef });
334
- return () => {
335
- const omitProps = [
336
- "onSelect",
337
- "onOpenKeys",
338
- "onCollapse",
339
- "onTabsChange",
340
- "onDarkChange",
341
- "theme",
342
- "onContentFullScreenChange",
343
- "onThemeChange"
344
- ];
345
- return createVNode(ConfigProvider, null, { default: () => [createVNode(GProConfigProvider, {
346
- "token": mergeToken.value,
347
- "dark": isDark.value,
348
- "cssVar": props.cssVar
349
- }, { default: () => [createVNode(ThemeContext, {
350
- "theme": theme.value,
351
- "onChange": (val) => {
352
- setTheme(val);
353
- emit("themeChange", val);
354
- emit("update:theme", val);
355
- },
356
- "onChangeBase": () => {
357
- props.onDarkChange?.(isDark.value);
358
- }
359
- }, { default: () => [createVNode(BaseProLayout, mergeProps(omit(props, omitProps), {
360
- "onSelect": onSelect,
361
- "onOpenKeys": onOpenKeys,
362
- "onCollapse": onCollapse,
363
- "onTabsChange": onTabsChange,
364
- "onContentFullScreenChange": onContentFullScreenChange
365
- }), slots)] })] })] });
366
- };
367
- }
499
+ inheritAttrs: false
368
500
  });
369
-
370
501
  //#endregion
371
- export { ProLayout_default as default };
502
+ export { GProLayout as default };