@creekjs/web-components 1.0.4 → 1.0.6

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 (189) hide show
  1. package/.turbo/turbo-father$colon$build.log +33 -17
  2. package/README.md +97 -18
  3. package/dist/creek-config-provider/CreekConfigContext.d.ts +4 -0
  4. package/dist/creek-config-provider/CreekConfigContext.d.ts.map +1 -0
  5. package/dist/creek-config-provider/CreekConfigContext.js.map +2 -2
  6. package/dist/creek-config-provider/CreekI18nProvider.d.ts +22 -0
  7. package/dist/creek-config-provider/CreekI18nProvider.d.ts.map +1 -0
  8. package/dist/creek-config-provider/CreekI18nProvider.js +92 -0
  9. package/dist/creek-config-provider/CreekI18nProvider.js.map +7 -0
  10. package/dist/creek-config-provider/index.d.ts +5 -3
  11. package/dist/creek-config-provider/index.d.ts.map +1 -0
  12. package/dist/creek-config-provider/index.js +47 -4
  13. package/dist/creek-config-provider/index.js.map +3 -3
  14. package/dist/creek-hooks/index.d.ts.map +1 -0
  15. package/dist/creek-hooks/useApp/DrawerHelper.d.ts.map +1 -0
  16. package/dist/creek-hooks/useApp/ModalHelper.d.ts.map +1 -0
  17. package/dist/creek-hooks/useApp/index.d.ts +3 -3
  18. package/dist/creek-hooks/useApp/index.d.ts.map +1 -0
  19. package/dist/creek-hooks/useApp/types.d.ts.map +1 -0
  20. package/dist/creek-hooks/useViewportHeight.d.ts.map +1 -0
  21. package/dist/creek-icon/index.d.ts.map +1 -0
  22. package/dist/creek-keep-alive/index.d.ts +24 -1
  23. package/dist/creek-keep-alive/index.d.ts.map +1 -0
  24. package/dist/creek-keep-alive/index.js +141 -4
  25. package/dist/creek-keep-alive/index.js.map +2 -2
  26. package/dist/creek-layout/ActionRender/FullScreen.d.ts.map +1 -0
  27. package/dist/creek-layout/{HeaderContent → ActionRender}/FullScreen.js +4 -2
  28. package/dist/creek-layout/ActionRender/FullScreen.js.map +7 -0
  29. package/dist/creek-layout/ActionRender/LayoutSettings.d.ts +5 -0
  30. package/dist/creek-layout/ActionRender/LayoutSettings.d.ts.map +1 -0
  31. package/dist/creek-layout/ActionRender/LayoutSettings.js +73 -0
  32. package/dist/creek-layout/ActionRender/LayoutSettings.js.map +7 -0
  33. package/dist/creek-layout/ActionRender/UserInfo.d.ts +8 -0
  34. package/dist/creek-layout/ActionRender/UserInfo.d.ts.map +1 -0
  35. package/dist/creek-layout/{HeaderContent → ActionRender}/UserInfo.js +7 -29
  36. package/dist/creek-layout/ActionRender/UserInfo.js.map +7 -0
  37. package/dist/creek-layout/ActionRender/index.d.ts +3 -0
  38. package/dist/creek-layout/ActionRender/index.d.ts.map +1 -0
  39. package/dist/creek-layout/ActionRender/index.js +36 -0
  40. package/dist/creek-layout/ActionRender/index.js.map +7 -0
  41. package/dist/creek-layout/CollapseButton.d.ts.map +1 -0
  42. package/dist/creek-layout/Exception/NotFound.d.ts.map +1 -0
  43. package/dist/creek-layout/Exception/NotFoundPage.d.ts.map +1 -0
  44. package/dist/creek-layout/Exception/index.d.ts.map +1 -0
  45. package/dist/creek-layout/index.d.ts +9 -2
  46. package/dist/creek-layout/index.d.ts.map +1 -0
  47. package/dist/creek-layout/index.js +96 -39
  48. package/dist/creek-layout/index.js.map +3 -3
  49. package/dist/creek-layout/useLayoutSettingsStore.d.ts +20 -0
  50. package/dist/creek-layout/useLayoutSettingsStore.d.ts.map +1 -0
  51. package/dist/creek-layout/useLayoutSettingsStore.js +45 -0
  52. package/dist/creek-layout/useLayoutSettingsStore.js.map +7 -0
  53. package/dist/creek-loading/index.d.ts.map +1 -0
  54. package/dist/creek-locale-button/index.d.ts +1 -0
  55. package/dist/creek-locale-button/index.d.ts.map +1 -0
  56. package/dist/creek-locale-button/index.js +66 -0
  57. package/dist/creek-locale-button/index.js.map +7 -0
  58. package/dist/creek-page-container/index.d.ts +4 -0
  59. package/dist/creek-page-container/index.d.ts.map +1 -0
  60. package/dist/creek-page-container/index.js +68 -0
  61. package/dist/creek-page-container/index.js.map +7 -0
  62. package/dist/creek-style/index.d.ts +1 -0
  63. package/dist/creek-style/index.d.ts.map +1 -0
  64. package/dist/creek-style/index.js +24 -0
  65. package/dist/creek-style/index.js.map +7 -0
  66. package/dist/creek-style/scrollbar.d.ts +2 -0
  67. package/dist/creek-style/scrollbar.d.ts.map +1 -0
  68. package/dist/creek-style/scrollbar.js +55 -0
  69. package/dist/creek-style/scrollbar.js.map +7 -0
  70. package/dist/creek-table/SearchTable.d.ts +9 -0
  71. package/dist/creek-table/SearchTable.d.ts.map +1 -0
  72. package/dist/creek-table/SearchTable.js +109 -72
  73. package/dist/creek-table/SearchTable.js.map +3 -3
  74. package/dist/creek-table/components/DensityIcon.d.ts +9 -0
  75. package/dist/creek-table/components/DensityIcon.d.ts.map +1 -0
  76. package/dist/creek-table/components/DensityIcon.js +77 -0
  77. package/dist/creek-table/components/DensityIcon.js.map +7 -0
  78. package/dist/creek-table/components/EllipsisTooltip.d.ts +9 -0
  79. package/dist/creek-table/components/EllipsisTooltip.d.ts.map +1 -0
  80. package/dist/creek-table/components/EllipsisTooltip.js +122 -0
  81. package/dist/creek-table/components/EllipsisTooltip.js.map +7 -0
  82. package/dist/creek-table/components/index.d.ts +2 -0
  83. package/dist/creek-table/components/index.d.ts.map +1 -0
  84. package/dist/creek-table/components/index.js +26 -0
  85. package/dist/creek-table/components/index.js.map +7 -0
  86. package/dist/creek-table/hooks/index.d.ts +5 -0
  87. package/dist/creek-table/hooks/index.d.ts.map +1 -0
  88. package/dist/creek-table/hooks/index.js +10 -0
  89. package/dist/creek-table/hooks/index.js.map +2 -2
  90. package/dist/creek-table/hooks/useAdaptiveToolBar.d.ts.map +1 -0
  91. package/dist/creek-table/hooks/useAutoWidthColumns.d.ts +1 -1
  92. package/dist/creek-table/hooks/useAutoWidthColumns.d.ts.map +1 -0
  93. package/dist/creek-table/hooks/useAutoWidthColumns.js +76 -17
  94. package/dist/creek-table/hooks/useAutoWidthColumns.js.map +2 -2
  95. package/dist/creek-table/hooks/useElementDistance.d.ts.map +1 -0
  96. package/dist/creek-table/hooks/useEllipsisColumns.d.ts +8 -0
  97. package/dist/creek-table/hooks/useEllipsisColumns.d.ts.map +1 -0
  98. package/dist/creek-table/hooks/useEllipsisColumns.js +58 -0
  99. package/dist/creek-table/hooks/useEllipsisColumns.js.map +7 -0
  100. package/dist/creek-table/hooks/useIndexColumn.d.ts +2 -0
  101. package/dist/creek-table/hooks/useIndexColumn.d.ts.map +1 -0
  102. package/dist/creek-table/hooks/useIndexColumn.js +52 -0
  103. package/dist/creek-table/hooks/useIndexColumn.js.map +7 -0
  104. package/dist/creek-table/hooks/useResizableColumns.d.ts +20 -0
  105. package/dist/creek-table/hooks/useResizableColumns.d.ts.map +1 -0
  106. package/dist/creek-table/hooks/useResizableColumns.js +279 -0
  107. package/dist/creek-table/hooks/useResizableColumns.js.map +7 -0
  108. package/dist/creek-table/hooks/useStatusColumns.d.ts +2 -0
  109. package/dist/creek-table/hooks/useStatusColumns.d.ts.map +1 -0
  110. package/dist/creek-table/hooks/useStatusColumns.js +215 -0
  111. package/dist/creek-table/hooks/useStatusColumns.js.map +7 -0
  112. package/dist/creek-table/hooks/useTableOptions.d.ts +15 -0
  113. package/dist/creek-table/hooks/useTableOptions.d.ts.map +1 -0
  114. package/dist/creek-table/hooks/useTableOptions.js +78 -0
  115. package/dist/creek-table/hooks/useTableOptions.js.map +7 -0
  116. package/dist/creek-table/hooks/useTableScrollHeight.d.ts +6 -1
  117. package/dist/creek-table/hooks/useTableScrollHeight.d.ts.map +1 -0
  118. package/dist/creek-table/hooks/useTableScrollHeight.js +44 -5
  119. package/dist/creek-table/hooks/useTableScrollHeight.js.map +2 -2
  120. package/dist/creek-table/index.d.ts.map +1 -0
  121. package/dist/creek-table/type.d.ts +4 -6
  122. package/dist/creek-table/type.d.ts.map +1 -0
  123. package/dist/creek-table/type.js.map +1 -1
  124. package/dist/index.d.ts +4 -0
  125. package/dist/index.d.ts.map +1 -0
  126. package/dist/index.js +8 -0
  127. package/dist/index.js.map +2 -2
  128. package/dist/locales/en-US.d.ts +25 -0
  129. package/dist/locales/en-US.d.ts.map +1 -0
  130. package/dist/locales/en-US.js +49 -0
  131. package/dist/locales/en-US.js.map +7 -0
  132. package/dist/locales/zh-CN.d.ts +25 -0
  133. package/dist/locales/zh-CN.d.ts.map +1 -0
  134. package/dist/locales/zh-CN.js +49 -0
  135. package/dist/locales/zh-CN.js.map +7 -0
  136. package/dist/utils/i18n.d.ts +2 -0
  137. package/dist/utils/i18n.d.ts.map +1 -0
  138. package/dist/utils/i18n.js +34 -0
  139. package/dist/utils/i18n.js.map +7 -0
  140. package/i18n.config.ts +27 -0
  141. package/package.json +17 -3
  142. package/src/creek-config-provider/CreekConfigContext.tsx +5 -1
  143. package/src/creek-config-provider/CreekI18nProvider.tsx +87 -0
  144. package/src/creek-config-provider/index.tsx +53 -4
  145. package/src/creek-keep-alive/index.tsx +225 -6
  146. package/src/creek-layout/{HeaderContent → ActionRender}/FullScreen.tsx +10 -6
  147. package/src/creek-layout/ActionRender/LayoutSettings.tsx +67 -0
  148. package/src/creek-layout/ActionRender/UserInfo.tsx +43 -0
  149. package/src/creek-layout/ActionRender/index.tsx +4 -0
  150. package/src/creek-layout/index.tsx +121 -53
  151. package/src/creek-layout/useLayoutSettingsStore.ts +25 -0
  152. package/src/creek-locale-button/index.tsx +42 -0
  153. package/src/creek-page-container/index.tsx +32 -0
  154. package/src/creek-style/index.ts +1 -0
  155. package/src/creek-style/scrollbar.ts +29 -0
  156. package/src/creek-table/SearchTable.tsx +125 -72
  157. package/src/creek-table/components/DensityIcon.tsx +63 -0
  158. package/src/creek-table/components/EllipsisTooltip.tsx +116 -0
  159. package/src/creek-table/components/index.tsx +3 -0
  160. package/src/creek-table/hooks/index.ts +5 -1
  161. package/src/creek-table/hooks/useAutoWidthColumns.tsx +93 -19
  162. package/src/creek-table/hooks/useEllipsisColumns.tsx +47 -0
  163. package/src/creek-table/hooks/useIndexColumn.tsx +27 -0
  164. package/src/creek-table/hooks/useResizableColumns.tsx +323 -0
  165. package/src/creek-table/hooks/useStatusColumns.tsx +252 -0
  166. package/src/creek-table/hooks/useTableOptions.tsx +81 -0
  167. package/src/creek-table/hooks/useTableScrollHeight.tsx +61 -6
  168. package/src/creek-table/type.ts +5 -7
  169. package/src/index.tsx +4 -0
  170. package/src/locales/en-US.ts +24 -0
  171. package/src/locales/zh-CN.ts +24 -0
  172. package/src/utils/i18n.ts +4 -0
  173. package/dist/creek-layout/HeaderContent/FullScreen.js.map +0 -7
  174. package/dist/creek-layout/HeaderContent/UserInfo.d.ts +0 -1
  175. package/dist/creek-layout/HeaderContent/UserInfo.js.map +0 -7
  176. package/dist/creek-layout/HeaderContent/index.d.ts +0 -1
  177. package/dist/creek-layout/HeaderContent/index.js +0 -49
  178. package/dist/creek-layout/HeaderContent/index.js.map +0 -7
  179. package/dist/creek-table/TableOptionRender.d.ts +0 -9
  180. package/dist/creek-table/TableOptionRender.js +0 -74
  181. package/dist/creek-table/TableOptionRender.js.map +0 -7
  182. package/dist/creek-table/toolBarRender.d.ts +0 -5
  183. package/dist/creek-table/toolBarRender.js +0 -58
  184. package/dist/creek-table/toolBarRender.js.map +0 -7
  185. package/src/creek-layout/HeaderContent/UserInfo.tsx +0 -54
  186. package/src/creek-layout/HeaderContent/index.tsx +0 -24
  187. package/src/creek-table/TableOptionRender.tsx +0 -57
  188. package/src/creek-table/toolBarRender.tsx +0 -28
  189. /package/dist/creek-layout/{HeaderContent → ActionRender}/FullScreen.d.ts +0 -0
@@ -22,14 +22,151 @@ __export(creek_keep_alive_exports, {
22
22
  CreekKeepAlive: () => CreekKeepAlive
23
23
  });
24
24
  module.exports = __toCommonJS(creek_keep_alive_exports);
25
+ var import_ahooks = require("ahooks");
26
+ var import_antd = require("antd");
27
+ var import_lodash = require("lodash");
25
28
  var import_react = require("react");
29
+ var import_react_router_dom = require("react-router-dom");
30
+ var import_i18n = require("../utils/i18n");
26
31
  var import_jsx_runtime = require("react/jsx-runtime");
27
- var CreekKeepAlive = () => {
28
- const [isMounted, setIsMounted] = (0, import_react.useState)(false);
32
+ var CreekKeepAlive = (props) => {
33
+ const { exclude = [], getTabTitle, homePath = "/", tabBarStyle, maxTabCount = 20 } = props;
34
+ const t = (0, import_i18n.useT)();
35
+ const outlet = (0, import_react_router_dom.useOutlet)();
36
+ const location = (0, import_react_router_dom.useLocation)();
37
+ const navigate = (0, import_react_router_dom.useNavigate)();
38
+ const [tabItems, setTabItems] = (0, import_react.useState)([]);
39
+ const [activeKey, setActiveKey] = (0, import_react.useState)("");
40
+ const [cachedPages, setCachedPages] = (0, import_react.useState)({});
41
+ const isPathExcluded = (path) => {
42
+ return exclude.some((item) => {
43
+ if ((0, import_lodash.isString)(item)) {
44
+ return item === path;
45
+ }
46
+ if ((0, import_lodash.isRegExp)(item)) {
47
+ return item.test(path);
48
+ }
49
+ return false;
50
+ });
51
+ };
52
+ (0, import_react.useEffect)(() => {
53
+ const currentPath = location.pathname;
54
+ setActiveKey(currentPath);
55
+ setCachedPages((prev) => {
56
+ if (prev[currentPath]) {
57
+ return prev;
58
+ }
59
+ return {
60
+ ...prev,
61
+ [currentPath]: outlet
62
+ };
63
+ });
64
+ setTabItems((prev) => {
65
+ if (prev.find((i) => i.key === currentPath)) {
66
+ return prev;
67
+ }
68
+ const title = (getTabTitle == null ? void 0 : getTabTitle(currentPath)) || currentPath;
69
+ const newItems = [...prev, { key: currentPath, label: title, closable: currentPath !== homePath }];
70
+ if (newItems.length > maxTabCount) {
71
+ const indexToRemove = newItems.findIndex((item) => item.closable && item.key !== currentPath);
72
+ if (indexToRemove !== -1) {
73
+ const itemToRemove = newItems[indexToRemove];
74
+ setCachedPages((currentCached) => (0, import_lodash.omit)(currentCached, [itemToRemove.key]));
75
+ newItems.splice(indexToRemove, 1);
76
+ }
77
+ }
78
+ return newItems;
79
+ });
80
+ }, [location.pathname, outlet, getTabTitle, homePath, maxTabCount]);
29
81
  (0, import_react.useEffect)(() => {
30
- setIsMounted(true);
31
82
  }, []);
32
- return /* @__PURE__ */ (0, import_jsx_runtime.jsx)("div", { children: "KeepAlive" });
83
+ const closeTab = (0, import_ahooks.useMemoizedFn)((targetKey) => {
84
+ const targetIndex = tabItems.findIndex((item) => item.key === targetKey);
85
+ const newTabItems = tabItems.filter((item) => item.key !== targetKey);
86
+ setCachedPages((prev) => (0, import_lodash.omit)(prev, [targetKey]));
87
+ setTabItems(newTabItems);
88
+ if (targetKey === activeKey) {
89
+ if (newTabItems.length > 0) {
90
+ const nextIndex = targetIndex >= newTabItems.length ? newTabItems.length - 1 : targetIndex;
91
+ const nextKey = newTabItems[nextIndex].key;
92
+ navigate(nextKey);
93
+ } else {
94
+ navigate(homePath);
95
+ }
96
+ }
97
+ });
98
+ const closeOtherTabs = (0, import_ahooks.useMemoizedFn)((currentKey) => {
99
+ const newTabItems = tabItems.filter((item) => item.key === currentKey || item.key === homePath);
100
+ setTabItems(newTabItems);
101
+ const keepKeys = newTabItems.map((i) => i.key);
102
+ setCachedPages((prev) => {
103
+ const newCachedPages = {};
104
+ keepKeys.forEach((k) => {
105
+ if (prev[k])
106
+ newCachedPages[k] = prev[k];
107
+ });
108
+ return newCachedPages;
109
+ });
110
+ if (activeKey !== currentKey) {
111
+ navigate(currentKey);
112
+ }
113
+ });
114
+ const closeRightTabs = (0, import_ahooks.useMemoizedFn)((currentKey) => {
115
+ const currentIndex = tabItems.findIndex((i) => i.key === currentKey);
116
+ const rightItems = tabItems.slice(currentIndex + 1);
117
+ const rightKeys = rightItems.map((i) => i.key);
118
+ const newTabItems = tabItems.filter((i) => !rightKeys.includes(i.key));
119
+ setTabItems(newTabItems);
120
+ setCachedPages((prev) => (0, import_lodash.omit)(prev, rightKeys));
121
+ if (rightKeys.includes(activeKey)) {
122
+ navigate(currentKey);
123
+ }
124
+ });
125
+ const handleTabEdit = (targetKey, action) => {
126
+ if (action === "remove" && (0, import_lodash.isString)(targetKey)) {
127
+ closeTab(targetKey);
128
+ }
129
+ };
130
+ const handleTabClick = (key) => {
131
+ navigate(key);
132
+ };
133
+ const renderTabLabel = (item) => {
134
+ const menuItems = [
135
+ {
136
+ key: "close",
137
+ label: t("creek-keep-alive.index.guanBiDangQian", "关闭当前"),
138
+ disabled: item.key === homePath,
139
+ onClick: () => closeTab(item.key)
140
+ },
141
+ {
142
+ key: "closeOthers",
143
+ label: t("creek-keep-alive.index.guanBiQiTa", "关闭其他"),
144
+ onClick: () => closeOtherTabs(item.key)
145
+ },
146
+ {
147
+ key: "closeRight",
148
+ label: t("creek-keep-alive.index.guanBiYouCe", "关闭右侧"),
149
+ onClick: () => closeRightTabs(item.key)
150
+ }
151
+ ];
152
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_antd.Dropdown, { menu: { items: menuItems }, trigger: ["contextMenu"], children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)("span", { children: item.label }) });
153
+ };
154
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsx)("div", { className: "creek-keep-alive", children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
155
+ import_antd.Tabs,
156
+ {
157
+ activeKey,
158
+ type: "editable-card",
159
+ hideAdd: true,
160
+ onChange: handleTabClick,
161
+ onEdit: handleTabEdit,
162
+ tabBarStyle: { margin: 0, ...tabBarStyle },
163
+ items: tabItems.map((item) => ({
164
+ ...item,
165
+ label: renderTabLabel(item),
166
+ children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)("div", { style: { height: "100%", display: activeKey === item.key ? "block" : "none" }, children: !isPathExcluded(item.key) || activeKey === item.key ? cachedPages[item.key] : null }, item.key)
167
+ }))
168
+ }
169
+ ) });
33
170
  };
34
171
  // Annotate the CommonJS export names for ESM import in node:
35
172
  0 && (module.exports = {
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../src/creek-keep-alive/index.tsx"],
4
- "sourcesContent": ["import { useEffect, useState } from 'react';\n\nexport const CreekKeepAlive = () => {\n const [isMounted, setIsMounted] = useState(false);\n\n useEffect(() => {\n setIsMounted(true);\n }, []);\n\n return <div>KeepAlive</div>;\n};"],
5
- "mappings": ";;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mBAAoC;AAS3B;AAPF,IAAM,iBAAiB,MAAM;AAClC,QAAM,CAAC,WAAW,YAAY,QAAI,uBAAS,KAAK;AAEhD,8BAAU,MAAM;AACd,iBAAa,IAAI;AAAA,EACnB,GAAG,CAAC,CAAC;AAEL,SAAO,4CAAC,SAAI,uBAAS;AACvB;",
4
+ "sourcesContent": ["import { useMemoizedFn } from 'ahooks';\nimport { Dropdown, MenuProps, Tabs } from 'antd';\nimport { isRegExp, isString, omit } from 'lodash';\nimport React, { useEffect, useState } from 'react';\nimport { useLocation, useNavigate, useOutlet } from 'react-router-dom';\n\nimport { useT } from '@/utils/i18n';\n\nexport interface CreekKeepAliveProps {\n /**\n * 不需要缓存的路径\n */\n exclude?: (string | RegExp)[];\n /**\n * 自定义Tab标题获取方法\n */\n getTabTitle?: (pathname: string) => React.ReactNode;\n /**\n * 默认首页路径\n */\n homePath?: string;\n /**\n * Tabs的样式\n */\n tabBarStyle?: React.CSSProperties;\n /**\n * 最大缓存数量,默认为 20\n */\n maxTabCount?: number;\n}\n\ninterface TabItem {\n key: string;\n label: React.ReactNode;\n closable?: boolean;\n}\n\nexport const CreekKeepAlive: React.FC<CreekKeepAliveProps> = (props) => {\n const { exclude = [], getTabTitle, homePath = '/', tabBarStyle, maxTabCount = 20 } = props;\n\n const t = useT();\n const outlet = useOutlet();\n const location = useLocation();\n const navigate = useNavigate();\n\n const [tabItems, setTabItems] = useState<TabItem[]>([]);\n const [activeKey, setActiveKey] = useState<string>('');\n const [cachedPages, setCachedPages] = useState<Record<string, React.ReactNode>>({});\n\n // 判断是否不需要缓存\n const isPathExcluded = (path: string) => {\n return exclude.some((item) => {\n if (isString(item)) {\n return item === path;\n }\n if (isRegExp(item)) {\n return item.test(path);\n }\n return false;\n });\n };\n\n // 初始化或路由变化时更新\n useEffect(() => {\n const currentPath = location.pathname;\n setActiveKey(currentPath);\n\n // 更新页面内容缓存\n setCachedPages((prev) => {\n if (prev[currentPath]) {\n return prev;\n }\n return {\n ...prev,\n [currentPath]: outlet,\n };\n });\n\n // 更新 Tab 列表\n setTabItems((prev) => {\n if (prev.find((i) => i.key === currentPath)) {\n return prev;\n }\n const title = getTabTitle?.(currentPath) || currentPath;\n const newItems = [...prev, { key: currentPath, label: title, closable: currentPath !== homePath }];\n\n // 超过最大数量限制\n if (newItems.length > maxTabCount) {\n // 找到第一个可以关闭的 Tab(非首页、非当前页)\n // 这里策略是移除最早加入的那个可关闭 Tab。prev[0] 是最早的。\n // 但要注意不要移除当前页(currentPath),虽然 currentPath 是刚加进去的,但在极端情况下(比如 max=1)\n // 简单策略:移除第一个 closable 且 key !== currentPath 的 item\n const indexToRemove = newItems.findIndex((item) => item.closable && item.key !== currentPath);\n if (indexToRemove !== -1) {\n const itemToRemove = newItems[indexToRemove];\n // 顺便移除缓存\n setCachedPages((currentCached) => omit(currentCached, [itemToRemove.key]));\n newItems.splice(indexToRemove, 1);\n }\n }\n return newItems;\n });\n }, [location.pathname, outlet, getTabTitle, homePath, maxTabCount]);\n\n // 清理不需要缓存的页面\n useEffect(() => {\n // 监听路由离开\n // 这里比较 tricky,因为 useEffect 拿到的 activeKey 已经是新的了\n // 我们需要知道\"上一个\"路径\n // 简化处理:每次 render 时,检查 pages 里哪些是不需要缓存且不处于 active 状态的,将其移除?\n // 但如果在 setState 里做会导致死循环。\n // 另一种策略:不缓存 = 离开时销毁。\n // 我们可以在 pages 渲染时控制。\n }, []);\n\n const closeTab = useMemoizedFn((targetKey: string) => {\n const targetIndex = tabItems.findIndex((item) => item.key === targetKey);\n const newTabItems = tabItems.filter((item) => item.key !== targetKey);\n\n // 移除缓存\n setCachedPages((prev) => omit(prev, [targetKey]));\n setTabItems(newTabItems);\n\n // 如果关闭的是当前页,跳转到临近页\n if (targetKey === activeKey) {\n if (newTabItems.length > 0) {\n // 尝试跳到右边,没有则左边\n const nextIndex = targetIndex >= newTabItems.length ? newTabItems.length - 1 : targetIndex;\n const nextKey = newTabItems[nextIndex].key;\n navigate(nextKey);\n } else {\n navigate(homePath);\n }\n }\n });\n\n const closeOtherTabs = useMemoizedFn((currentKey: string) => {\n const newTabItems = tabItems.filter((item) => item.key === currentKey || item.key === homePath);\n setTabItems(newTabItems);\n\n const keepKeys = newTabItems.map((i) => i.key);\n setCachedPages((prev) => {\n const newCachedPages: Record<string, React.ReactNode> = {};\n keepKeys.forEach((k) => {\n if (prev[k]) newCachedPages[k] = prev[k];\n });\n return newCachedPages;\n });\n\n if (activeKey !== currentKey) {\n navigate(currentKey);\n }\n });\n\n const closeRightTabs = useMemoizedFn((currentKey: string) => {\n const currentIndex = tabItems.findIndex((i) => i.key === currentKey);\n const rightItems = tabItems.slice(currentIndex + 1);\n const rightKeys = rightItems.map((i) => i.key);\n\n const newTabItems = tabItems.filter((i) => !rightKeys.includes(i.key));\n setTabItems(newTabItems);\n\n setCachedPages((prev) => omit(prev, rightKeys));\n\n if (rightKeys.includes(activeKey)) {\n navigate(currentKey);\n }\n });\n\n const handleTabEdit = (targetKey: React.MouseEvent | React.KeyboardEvent | string, action: 'add' | 'remove') => {\n if (action === 'remove' && isString(targetKey)) {\n closeTab(targetKey);\n }\n };\n\n const handleTabClick = (key: string) => {\n navigate(key);\n };\n\n const renderTabLabel = (item: TabItem) => {\n const menuItems: MenuProps['items'] = [\n {\n key: 'close',\n label: t('creek-keep-alive.index.guanBiDangQian', '关闭当前'),\n disabled: item.key === homePath,\n onClick: () => closeTab(item.key),\n },\n {\n key: 'closeOthers',\n label: t('creek-keep-alive.index.guanBiQiTa', '关闭其他'),\n onClick: () => closeOtherTabs(item.key),\n },\n {\n key: 'closeRight',\n label: t('creek-keep-alive.index.guanBiYouCe', '关闭右侧'),\n onClick: () => closeRightTabs(item.key),\n },\n ];\n\n return (\n <Dropdown menu={{ items: menuItems }} trigger={['contextMenu']}>\n <span>{item.label}</span>\n </Dropdown>\n );\n };\n\n return (\n <div className=\"creek-keep-alive\">\n <Tabs\n activeKey={activeKey}\n type=\"editable-card\"\n hideAdd\n onChange={handleTabClick}\n onEdit={handleTabEdit}\n tabBarStyle={{ margin: 0, ...tabBarStyle }}\n items={tabItems.map((item) => ({\n ...item,\n label: renderTabLabel(item),\n children: (\n <div key={item.key} style={{ height: '100%', display: activeKey === item.key ? 'block' : 'none' }}>\n {/* 如果是不缓存的页面,且不是当前页,则不渲染(销毁) */}\n {/* 如果是缓存页面,或者是当前页,则渲染 */}\n {!isPathExcluded(item.key) || activeKey === item.key ? cachedPages[item.key] : null}\n </div>\n ),\n }))}\n />\n </div>\n );\n};\n"],
5
+ "mappings": "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",
6
6
  "names": []
7
7
  }
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FullScreen.d.ts","sourceRoot":"","sources":["../../../src/creek-layout/ActionRender/FullScreen.tsx"],"names":[],"mappings":"AAQA,MAAM,MAAM,eAAe,GAAG;IAC5B,YAAY,EAAE,OAAO,CAAC;IACtB,gBAAgB,EAAE,MAAM,IAAI,CAAC;CAC9B,CAAC;AAEF,eAAO,MAAM,kBAAkB,8EAU7B,CAAC;AAEH,eAAO,MAAM,UAAU,+CAwBtB,CAAC"}
@@ -16,7 +16,7 @@ var __copyProps = (to, from, except, desc) => {
16
16
  };
17
17
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
18
18
 
19
- // src/creek-layout/HeaderContent/FullScreen.tsx
19
+ // src/creek-layout/ActionRender/FullScreen.tsx
20
20
  var FullScreen_exports = {};
21
21
  __export(FullScreen_exports, {
22
22
  FullScreen: () => FullScreen,
@@ -27,6 +27,7 @@ var import_icons = require("@ant-design/icons");
27
27
  var import_ahooks = require("ahooks");
28
28
  var import_antd = require("antd");
29
29
  var import_zustand = require("zustand");
30
+ var import_i18n = require("../../utils/i18n");
30
31
  var import_jsx_runtime = require("react/jsx-runtime");
31
32
  var useFullScreenStore = (0, import_zustand.create)((set, get) => {
32
33
  return {
@@ -40,13 +41,14 @@ var useFullScreenStore = (0, import_zustand.create)((set, get) => {
40
41
  };
41
42
  });
42
43
  var FullScreen = () => {
44
+ const t = (0, import_i18n.useT)();
43
45
  const [, { toggleFullscreen }] = (0, import_ahooks.useFullscreen)(document.body);
44
46
  const { isFullScreen, changeFullScreen } = useFullScreenStore.getState();
45
47
  const handleFullScreen = (0, import_ahooks.useMemoizedFn)(() => {
46
48
  toggleFullscreen();
47
49
  changeFullScreen();
48
50
  });
49
- return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_jsx_runtime.Fragment, { children: isFullScreen ? /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_antd.Tooltip, { title: "退出全屏", placement: "top", children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_icons.FullscreenExitOutlined, { onClick: handleFullScreen }) }) : /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_antd.Tooltip, { title: "全屏", placement: "top", children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_icons.FullscreenOutlined, { onClick: handleFullScreen }) }) });
51
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_jsx_runtime.Fragment, { children: isFullScreen ? /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_antd.Tooltip, { title: t("creek-layout.ActionRender.FullScreen.tuiChuQuanPing", "退出全屏"), placement: "top", children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_icons.FullscreenExitOutlined, { onClick: handleFullScreen }) }) : /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_antd.Tooltip, { title: t("creek-layout.ActionRender.FullScreen.quanPing", "全屏"), placement: "top", children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_icons.FullscreenOutlined, { onClick: handleFullScreen }) }) });
50
52
  };
51
53
  // Annotate the CommonJS export names for ESM import in node:
52
54
  0 && (module.exports = {
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/creek-layout/ActionRender/FullScreen.tsx"],
4
+ "sourcesContent": ["import { FullscreenExitOutlined, FullscreenOutlined } from '@ant-design/icons';\nimport { useFullscreen, useMemoizedFn } from 'ahooks';\nimport { Tooltip } from 'antd';\n\nimport { create } from 'zustand';\n\nimport { useT } from '@/utils/i18n';\n\nexport type FullScreenStore = {\n isFullScreen: boolean;\n changeFullScreen: () => void;\n};\n\nexport const useFullScreenStore = create<FullScreenStore>((set, get) => {\n return {\n isFullScreen: false,\n changeFullScreen: () => {\n const _isFullScreen = get().isFullScreen;\n set({\n isFullScreen: !_isFullScreen,\n });\n },\n };\n});\n\nexport const FullScreen = () => {\n const t = useT();\n const [, { toggleFullscreen }] = useFullscreen(document.body);\n\n const { isFullScreen, changeFullScreen } = useFullScreenStore.getState();\n\n const handleFullScreen = useMemoizedFn(() => {\n toggleFullscreen();\n changeFullScreen();\n });\n\n return (\n <>\n {isFullScreen ? (\n <Tooltip title={t('creek-layout.ActionRender.FullScreen.tuiChuQuanPing', '退出全屏')} placement=\"top\">\n <FullscreenExitOutlined onClick={handleFullScreen} />\n </Tooltip>\n ) : (\n <Tooltip title={t('creek-layout.ActionRender.FullScreen.quanPing', '全屏')} placement=\"top\">\n <FullscreenOutlined onClick={handleFullScreen} />\n </Tooltip>\n )}\n </>\n );\n};\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mBAA2D;AAC3D,oBAA6C;AAC7C,kBAAwB;AAExB,qBAAuB;AAEvB,kBAAqB;AA+BjB;AAxBG,IAAM,yBAAqB,uBAAwB,CAAC,KAAK,QAAQ;AACtE,SAAO;AAAA,IACL,cAAc;AAAA,IACd,kBAAkB,MAAM;AACtB,YAAM,gBAAgB,IAAI,EAAE;AAC5B,UAAI;AAAA,QACF,cAAc,CAAC;AAAA,MACjB,CAAC;AAAA,IACH;AAAA,EACF;AACF,CAAC;AAEM,IAAM,aAAa,MAAM;AAC9B,QAAM,QAAI,kBAAK;AACf,QAAM,CAAC,EAAE,EAAE,iBAAiB,CAAC,QAAI,6BAAc,SAAS,IAAI;AAE5D,QAAM,EAAE,cAAc,iBAAiB,IAAI,mBAAmB,SAAS;AAEvE,QAAM,uBAAmB,6BAAc,MAAM;AAC3C,qBAAiB;AACjB,qBAAiB;AAAA,EACnB,CAAC;AAED,SACE,2EACG,yBACC,4CAAC,uBAAQ,OAAO,EAAE,uDAAuD,MAAM,GAAG,WAAU,OAC1F,sDAAC,uCAAuB,SAAS,kBAAkB,GACrD,IAEA,4CAAC,uBAAQ,OAAO,EAAE,iDAAiD,IAAI,GAAG,WAAU,OAClF,sDAAC,mCAAmB,SAAS,kBAAkB,GACjD,GAEJ;AAEJ;",
6
+ "names": []
7
+ }
@@ -0,0 +1,5 @@
1
+ export declare const LayoutSettings: ({ defaultShowFullScreen, defaultShowLocaleButton, defaultKeepAlive, }: {
2
+ defaultShowFullScreen?: boolean | undefined;
3
+ defaultShowLocaleButton?: boolean | undefined;
4
+ defaultKeepAlive?: boolean | undefined;
5
+ }) => import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LayoutSettings.d.ts","sourceRoot":"","sources":["../../../src/creek-layout/ActionRender/LayoutSettings.tsx"],"names":[],"mappings":"AAwCA,eAAO,MAAM,cAAc;;;;6CA0B1B,CAAC"}
@@ -0,0 +1,73 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __export = (target, all) => {
6
+ for (var name in all)
7
+ __defProp(target, name, { get: all[name], enumerable: true });
8
+ };
9
+ var __copyProps = (to, from, except, desc) => {
10
+ if (from && typeof from === "object" || typeof from === "function") {
11
+ for (let key of __getOwnPropNames(from))
12
+ if (!__hasOwnProp.call(to, key) && key !== except)
13
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
14
+ }
15
+ return to;
16
+ };
17
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
18
+
19
+ // src/creek-layout/ActionRender/LayoutSettings.tsx
20
+ var LayoutSettings_exports = {};
21
+ __export(LayoutSettings_exports, {
22
+ LayoutSettings: () => LayoutSettings
23
+ });
24
+ module.exports = __toCommonJS(LayoutSettings_exports);
25
+ var import_icons = require("@ant-design/icons");
26
+ var import_antd = require("antd");
27
+ var import_react = require("@creekjs/i18n/react");
28
+ var import_creek_hooks = require("../../creek-hooks");
29
+ var import_useLayoutSettingsStore = require("../useLayoutSettingsStore");
30
+ var import_jsx_runtime = require("react/jsx-runtime");
31
+ var SettingsForm = ({ defaultShowFullScreen, defaultShowLocaleButton, defaultKeepAlive }) => {
32
+ const t = (0, import_react.useT)();
33
+ const { colorPrimary, showFullScreen, showLocaleButton, keepAlive, setSettings } = (0, import_useLayoutSettingsStore.useLayoutSettingsStore)();
34
+ const currentShowFullScreen = showFullScreen ?? defaultShowFullScreen ?? false;
35
+ const currentShowLocaleButton = showLocaleButton ?? defaultShowLocaleButton ?? true;
36
+ const currentKeepAlive = keepAlive ?? defaultKeepAlive ?? true;
37
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(import_antd.Form, { layout: "vertical", children: [
38
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_antd.Form.Item, { label: t("creek-layout.ActionRender.LayoutSettings.themeColor", "主题色"), children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
39
+ import_antd.ColorPicker,
40
+ {
41
+ value: colorPrimary,
42
+ onChange: (color, hex) => {
43
+ setSettings({ colorPrimary: hex || void 0 });
44
+ },
45
+ allowClear: true
46
+ }
47
+ ) }),
48
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_antd.Form.Item, { label: t("creek-layout.ActionRender.LayoutSettings.showFullScreen", "展示全屏按钮"), children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_antd.Switch, { checked: currentShowFullScreen, onChange: (checked) => setSettings({ showFullScreen: checked }) }) }),
49
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_antd.Form.Item, { label: t("creek-layout.ActionRender.LayoutSettings.showLocaleButton", "展示国际化按钮"), children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_antd.Switch, { checked: currentShowLocaleButton, onChange: (checked) => setSettings({ showLocaleButton: checked }) }) }),
50
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_antd.Form.Item, { label: t("creek-layout.ActionRender.LayoutSettings.keepAlive", "开启页面缓存 (Keep Alive)"), children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_antd.Switch, { checked: currentKeepAlive, onChange: (checked) => setSettings({ keepAlive: checked }) }) })
51
+ ] });
52
+ };
53
+ var LayoutSettings = ({
54
+ defaultShowFullScreen,
55
+ defaultShowLocaleButton,
56
+ defaultKeepAlive
57
+ }) => {
58
+ const t = (0, import_react.useT)();
59
+ const { drawer } = (0, import_creek_hooks.useApp)();
60
+ const handleOpenSettings = () => {
61
+ drawer.open({
62
+ title: t("creek-layout.ActionRender.LayoutSettings.title", "系统设置"),
63
+ placement: "right",
64
+ content: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(SettingsForm, { defaultShowFullScreen, defaultShowLocaleButton, defaultKeepAlive })
65
+ });
66
+ };
67
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_antd.Tooltip, { title: t("creek-layout.ActionRender.LayoutSettings.title", "系统设置"), placement: "top", children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_icons.SettingOutlined, { onClick: handleOpenSettings }) });
68
+ };
69
+ // Annotate the CommonJS export names for ESM import in node:
70
+ 0 && (module.exports = {
71
+ LayoutSettings
72
+ });
73
+ //# sourceMappingURL=LayoutSettings.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/creek-layout/ActionRender/LayoutSettings.tsx"],
4
+ "sourcesContent": ["import { SettingOutlined } from '@ant-design/icons';\nimport { ColorPicker, Form, Switch, Tooltip } from 'antd';\n\nimport { useT } from '@creekjs/i18n/react';\n\nimport { useApp } from '../../creek-hooks';\nimport { useLayoutSettingsStore } from '../useLayoutSettingsStore';\n\nconst SettingsForm = ({ defaultShowFullScreen, defaultShowLocaleButton, defaultKeepAlive }: { defaultShowFullScreen?: boolean; defaultShowLocaleButton?: boolean; defaultKeepAlive?: boolean }) => {\n const t = useT();\n const { colorPrimary, showFullScreen, showLocaleButton, keepAlive, setSettings } = useLayoutSettingsStore();\n\n const currentShowFullScreen = showFullScreen ?? defaultShowFullScreen ?? false;\n const currentShowLocaleButton = showLocaleButton ?? defaultShowLocaleButton ?? true;\n const currentKeepAlive = keepAlive ?? defaultKeepAlive ?? true;\n\n return (\n <Form layout=\"vertical\">\n <Form.Item label={t('creek-layout.ActionRender.LayoutSettings.themeColor', '主题色')}>\n <ColorPicker\n value={colorPrimary}\n onChange={(color, hex) => {\n setSettings({ colorPrimary: hex || undefined });\n }}\n allowClear\n />\n </Form.Item>\n <Form.Item label={t('creek-layout.ActionRender.LayoutSettings.showFullScreen', '展示全屏按钮')}>\n <Switch checked={currentShowFullScreen} onChange={(checked) => setSettings({ showFullScreen: checked })} />\n </Form.Item>\n <Form.Item label={t('creek-layout.ActionRender.LayoutSettings.showLocaleButton', '展示国际化按钮')}>\n <Switch checked={currentShowLocaleButton} onChange={(checked) => setSettings({ showLocaleButton: checked })} />\n </Form.Item>\n <Form.Item label={t('creek-layout.ActionRender.LayoutSettings.keepAlive', '开启页面缓存 (Keep Alive)')}>\n <Switch checked={currentKeepAlive} onChange={(checked) => setSettings({ keepAlive: checked })} />\n </Form.Item>\n </Form>\n );\n};\n\nexport const LayoutSettings = ({\n defaultShowFullScreen,\n defaultShowLocaleButton,\n defaultKeepAlive,\n}: {\n defaultShowFullScreen?: boolean;\n defaultShowLocaleButton?: boolean;\n defaultKeepAlive?: boolean;\n}) => {\n const t = useT();\n const { drawer } = useApp();\n\n const handleOpenSettings = () => {\n drawer.open({\n title: t('creek-layout.ActionRender.LayoutSettings.title', '系统设置'),\n placement: 'right',\n\n content: <SettingsForm defaultShowFullScreen={defaultShowFullScreen} defaultShowLocaleButton={defaultShowLocaleButton} defaultKeepAlive={defaultKeepAlive} />,\n });\n };\n\n return (\n <Tooltip title={t('creek-layout.ActionRender.LayoutSettings.title', '系统设置')} placement=\"top\">\n <SettingOutlined onClick={handleOpenSettings} />\n </Tooltip>\n );\n};\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mBAAgC;AAChC,kBAAmD;AAEnD,mBAAqB;AAErB,yBAAuB;AACvB,oCAAuC;AAWnC;AATJ,IAAM,eAAe,CAAC,EAAE,uBAAuB,yBAAyB,iBAAiB,MAA0G;AACjM,QAAM,QAAI,mBAAK;AACf,QAAM,EAAE,cAAc,gBAAgB,kBAAkB,WAAW,YAAY,QAAI,sDAAuB;AAE1G,QAAM,wBAAwB,kBAAkB,yBAAyB;AACzE,QAAM,0BAA0B,oBAAoB,2BAA2B;AAC/E,QAAM,mBAAmB,aAAa,oBAAoB;AAE1D,SACE,6CAAC,oBAAK,QAAO,YACX;AAAA,gDAAC,iBAAK,MAAL,EAAU,OAAO,EAAE,uDAAuD,KAAK,GAC9E;AAAA,MAAC;AAAA;AAAA,QACC,OAAO;AAAA,QACP,UAAU,CAAC,OAAO,QAAQ;AACxB,sBAAY,EAAE,cAAc,OAAO,OAAU,CAAC;AAAA,QAChD;AAAA,QACA,YAAU;AAAA;AAAA,IACZ,GACF;AAAA,IACA,4CAAC,iBAAK,MAAL,EAAU,OAAO,EAAE,2DAA2D,QAAQ,GACrF,sDAAC,sBAAO,SAAS,uBAAuB,UAAU,CAAC,YAAY,YAAY,EAAE,gBAAgB,QAAQ,CAAC,GAAG,GAC3G;AAAA,IACA,4CAAC,iBAAK,MAAL,EAAU,OAAO,EAAE,6DAA6D,SAAS,GACxF,sDAAC,sBAAO,SAAS,yBAAyB,UAAU,CAAC,YAAY,YAAY,EAAE,kBAAkB,QAAQ,CAAC,GAAG,GAC/G;AAAA,IACA,4CAAC,iBAAK,MAAL,EAAU,OAAO,EAAE,sDAAsD,qBAAqB,GAC7F,sDAAC,sBAAO,SAAS,kBAAkB,UAAU,CAAC,YAAY,YAAY,EAAE,WAAW,QAAQ,CAAC,GAAG,GACjG;AAAA,KACF;AAEJ;AAEO,IAAM,iBAAiB,CAAC;AAAA,EAC7B;AAAA,EACA;AAAA,EACA;AACF,MAIM;AACJ,QAAM,QAAI,mBAAK;AACf,QAAM,EAAE,OAAO,QAAI,2BAAO;AAE1B,QAAM,qBAAqB,MAAM;AAC/B,WAAO,KAAK;AAAA,MACV,OAAO,EAAE,kDAAkD,MAAM;AAAA,MACjE,WAAW;AAAA,MAEX,SAAS,4CAAC,gBAAa,uBAA8C,yBAAkD,kBAAoC;AAAA,IAC7J,CAAC;AAAA,EACH;AAEA,SACE,4CAAC,uBAAQ,OAAO,EAAE,kDAAkD,MAAM,GAAG,WAAU,OACrF,sDAAC,gCAAgB,SAAS,oBAAoB,GAChD;AAEJ;",
6
+ "names": []
7
+ }
@@ -0,0 +1,8 @@
1
+ /// <reference types="react" />
2
+ import { DropDownProps } from "antd";
3
+ export interface UserInfoProps {
4
+ name?: React.ReactNode;
5
+ avatar?: string;
6
+ menu?: DropDownProps['menu'];
7
+ }
8
+ export declare const UserInfo: (props: UserInfoProps) => import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1 @@
1
+ {"version":3,"file":"UserInfo.d.ts","sourceRoot":"","sources":["../../../src/creek-layout/ActionRender/UserInfo.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAoB,aAAa,EAAS,MAAM,MAAM,CAAC;AAsB9D,MAAM,WAAW,aAAa;IAC5B,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACvB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE,aAAa,CAAC,MAAM,CAAC,CAAC;CAC9B;AAED,eAAO,MAAM,QAAQ,UAAW,aAAa,4CAc5C,CAAC"}
@@ -16,13 +16,12 @@ var __copyProps = (to, from, except, desc) => {
16
16
  };
17
17
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
18
18
 
19
- // src/creek-layout/HeaderContent/UserInfo.tsx
19
+ // src/creek-layout/ActionRender/UserInfo.tsx
20
20
  var UserInfo_exports = {};
21
21
  __export(UserInfo_exports, {
22
22
  UserInfo: () => UserInfo
23
23
  });
24
24
  module.exports = __toCommonJS(UserInfo_exports);
25
- var import_icons = require("@ant-design/icons");
26
25
  var import_antd = require("antd");
27
26
  var import_antd_style = require("antd-style");
28
27
  var import_jsx_runtime = require("react/jsx-runtime");
@@ -44,34 +43,13 @@ var useStyles = (0, import_antd_style.createStyles)(({ token }) => ({
44
43
  }
45
44
  }
46
45
  }));
47
- var UserInfo = () => {
46
+ var UserInfo = (props) => {
48
47
  const { styles } = useStyles();
49
- const userInfoMenu = {
50
- items: [
51
- {
52
- key: "logout",
53
- label: /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(import_antd.Space, { size: 8, children: [
54
- /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_icons.LogoutOutlined, {}),
55
- /* @__PURE__ */ (0, import_jsx_runtime.jsx)("span", { children: "退出登录" })
56
- ] }),
57
- onClick: () => {
58
- }
59
- }
60
- ]
61
- };
62
- return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
63
- import_antd.Dropdown,
64
- {
65
- arrow: true,
66
- placement: "bottom",
67
- overlayClassName: styles.userInfoDropdownOverlay,
68
- menu: userInfoMenu,
69
- children: /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(import_antd.Space, { size: 4, align: "center", children: [
70
- /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_antd.Avatar, { className: styles.avatarContainer, children: "C" }),
71
- /* @__PURE__ */ (0, import_jsx_runtime.jsx)("span", { children: "Creek" })
72
- ] })
73
- }
74
- );
48
+ const { name, avatar, menu } = props;
49
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_antd.Dropdown, { arrow: true, placement: "bottom", overlayClassName: styles.userInfoDropdownOverlay, menu, children: /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(import_antd.Space, { size: 4, align: "center", children: [
50
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_antd.Avatar, { className: styles.avatarContainer, src: avatar, children: name }),
51
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)("span", { children: name })
52
+ ] }) });
75
53
  };
76
54
  // Annotate the CommonJS export names for ESM import in node:
77
55
  0 && (module.exports = {
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/creek-layout/ActionRender/UserInfo.tsx"],
4
+ "sourcesContent": ["import { Avatar, Dropdown, DropDownProps, Space } from \"antd\";\nimport { createStyles } from \"antd-style\";\n\nconst useStyles = createStyles(({ token}) => ({\n avatarContainer: {\n backgroundColor: token.colorPrimary,\n width: 24,\n height: 24,\n },\n userInfoDropdownOverlay: {\n \".ant-dropdown-menu\": {\n padding: \"8px 0\",\n },\n \".ant-dropdown-menu-item\": {\n \".ant-dropdown-menu-item-icon\": {\n fontSize: \"18px\",\n marginRight: \"8px\",\n },\n },\n },\n}));\n\nexport interface UserInfoProps {\n name?: React.ReactNode;\n avatar?: string;\n menu?: DropDownProps['menu'];\n}\n\nexport const UserInfo = (props: UserInfoProps) => {\n const { styles } = useStyles();\n const { name, avatar, menu } = props;\n\n return (\n <Dropdown arrow placement=\"bottom\" overlayClassName={styles.userInfoDropdownOverlay} menu={menu}>\n <Space size={4} align=\"center\">\n <Avatar className={styles.avatarContainer} src={avatar}>\n {name}\n </Avatar>\n <span>{name}</span>\n </Space>\n </Dropdown>\n );\n};\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,kBAAuD;AACvD,wBAA6B;AAiCvB;AA/BN,IAAM,gBAAY,gCAAa,CAAC,EAAE,MAAK,OAAO;AAAA,EAC5C,iBAAiB;AAAA,IACf,iBAAiB,MAAM;AAAA,IACvB,OAAO;AAAA,IACP,QAAQ;AAAA,EACV;AAAA,EACA,yBAAyB;AAAA,IACvB,sBAAsB;AAAA,MACpB,SAAS;AAAA,IACX;AAAA,IACA,2BAA2B;AAAA,MACzB,gCAAgC;AAAA,QAC9B,UAAU;AAAA,QACV,aAAa;AAAA,MACf;AAAA,IACF;AAAA,EACF;AACF,EAAE;AAQK,IAAM,WAAW,CAAC,UAAyB;AAChD,QAAM,EAAE,OAAO,IAAI,UAAU;AAC7B,QAAM,EAAE,MAAM,QAAQ,KAAK,IAAI;AAE/B,SACE,4CAAC,wBAAS,OAAK,MAAC,WAAU,UAAS,kBAAkB,OAAO,yBAAyB,MACnF,uDAAC,qBAAM,MAAM,GAAG,OAAM,UACpB;AAAA,gDAAC,sBAAO,WAAW,OAAO,iBAAiB,KAAK,QAC7C,gBACH;AAAA,IACA,4CAAC,UAAM,gBAAK;AAAA,KACd,GACF;AAEJ;",
6
+ "names": []
7
+ }
@@ -0,0 +1,3 @@
1
+ export { FullScreen } from './FullScreen';
2
+ export { UserInfo } from './UserInfo';
3
+ export { LayoutSettings } from './LayoutSettings';
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/creek-layout/ActionRender/index.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACtC,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC"}
@@ -0,0 +1,36 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __export = (target, all) => {
6
+ for (var name in all)
7
+ __defProp(target, name, { get: all[name], enumerable: true });
8
+ };
9
+ var __copyProps = (to, from, except, desc) => {
10
+ if (from && typeof from === "object" || typeof from === "function") {
11
+ for (let key of __getOwnPropNames(from))
12
+ if (!__hasOwnProp.call(to, key) && key !== except)
13
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
14
+ }
15
+ return to;
16
+ };
17
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
18
+
19
+ // src/creek-layout/ActionRender/index.tsx
20
+ var ActionRender_exports = {};
21
+ __export(ActionRender_exports, {
22
+ FullScreen: () => import_FullScreen.FullScreen,
23
+ LayoutSettings: () => import_LayoutSettings.LayoutSettings,
24
+ UserInfo: () => import_UserInfo.UserInfo
25
+ });
26
+ module.exports = __toCommonJS(ActionRender_exports);
27
+ var import_FullScreen = require("./FullScreen");
28
+ var import_UserInfo = require("./UserInfo");
29
+ var import_LayoutSettings = require("./LayoutSettings");
30
+ // Annotate the CommonJS export names for ESM import in node:
31
+ 0 && (module.exports = {
32
+ FullScreen,
33
+ LayoutSettings,
34
+ UserInfo
35
+ });
36
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/creek-layout/ActionRender/index.tsx"],
4
+ "sourcesContent": ["export { FullScreen } from './FullScreen';\nexport { UserInfo } from './UserInfo';\nexport { LayoutSettings } from './LayoutSettings';\n\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,wBAA2B;AAC3B,sBAAyB;AACzB,4BAA+B;",
6
+ "names": []
7
+ }
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CollapseButton.d.ts","sourceRoot":"","sources":["../../src/creek-layout/CollapseButton.tsx"],"names":[],"mappings":"AAKA,MAAM,MAAM,oBAAoB,GAAG;IACjC,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB,CAAC;AAEF,MAAM,MAAM,oBAAoB,GAAG;IACjC,SAAS,EAAE,OAAO,CAAC;IACnB,eAAe,EAAE,MAAM,IAAI,CAAC;CAC7B,CAAC;AAiBF,eAAO,MAAM,iBAAiB,mFAU5B,CAAC;AAEH,eAAO,MAAM,eAAe,UAAW,oBAAoB,4CAwB1D,CAAC"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NotFound.d.ts","sourceRoot":"","sources":["../../../src/creek-layout/Exception/NotFound.tsx"],"names":[],"mappings":"AAEA,eAAO,MAAM,QAAQ,+CASpB,CAAC"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NotFoundPage.d.ts","sourceRoot":"","sources":["../../../src/creek-layout/Exception/NotFoundPage.tsx"],"names":[],"mappings":";AACA,wBAEE"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/creek-layout/Exception/index.tsx"],"names":[],"mappings":";AAAA,cAAc,YAAY,CAAC;AAE3B,MAAM,MAAM,cAAc,GAAG;IAC3B,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;CAC5B,CAAC;AAEF,eAAO,MAAM,SAAS,UAAW,cAAc,4CAG9C,CAAC"}
@@ -1,13 +1,20 @@
1
- import { ProLayoutProps } from "@ant-design/pro-components";
1
+ /// <reference types="react" />
2
+ import { ProLayoutProps } from '@ant-design/pro-components';
3
+ import { CreekKeepAliveProps } from '../creek-keep-alive';
2
4
  export type LayoutProps = ProLayoutProps & {
3
5
  runtimeConfig: ProLayoutProps;
4
6
  userConfig?: ProLayoutProps;
5
7
  navigate?: (path?: string | number) => void;
8
+ showFullScreen?: boolean;
9
+ showLocaleButton?: boolean;
10
+ showSettingsButton?: boolean;
6
11
  initialInfo?: {
7
12
  initialState: any;
8
13
  loading: boolean;
9
14
  setInitialState: () => void;
10
15
  };
16
+ keepAlive?: boolean | CreekKeepAliveProps;
17
+ extraActions?: React.ReactNode[];
11
18
  };
12
19
  export declare const CreekLayout: (props: LayoutProps) => import("react/jsx-runtime").JSX.Element;
13
- export * from "./Exception";
20
+ export * from './Exception';
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/creek-layout/index.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAa,cAAc,EAAE,MAAM,4BAA4B,CAAC;AASvE,OAAO,EAAkB,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAQ1E,MAAM,MAAM,WAAW,GAAG,cAAc,GAAG;IACzC,aAAa,EAAE,cAAc,CAAC;IAC9B,UAAU,CAAC,EAAE,cAAc,CAAC;IAC5B,QAAQ,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,MAAM,GAAG,MAAM,KAAK,IAAI,CAAC;IAC5C,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,kBAAkB,CAAC,EAAE,OAAO,CAAC;IAC7B,WAAW,CAAC,EAAE;QACZ,YAAY,EAAE,GAAG,CAAC;QAClB,OAAO,EAAE,OAAO,CAAC;QACjB,eAAe,EAAE,MAAM,IAAI,CAAC;KAC7B,CAAC;IACF,SAAS,CAAC,EAAE,OAAO,GAAG,mBAAmB,CAAC;IAC1C,YAAY,CAAC,EAAE,KAAK,CAAC,SAAS,EAAE,CAAC;CAClC,CAAC;AAQF,eAAO,MAAM,WAAW,UAAW,WAAW,4CA6H7C,CAAC;AAEF,cAAc,aAAa,CAAC"}