@vef-framework/starter 1.0.134 → 2.0.1

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 (600) hide show
  1. package/README +15 -0
  2. package/dist/cjs/components/access-denied/access-denied-icon.cjs +210 -0
  3. package/dist/cjs/components/access-denied/index.cjs +47 -0
  4. package/dist/cjs/components/app/index.cjs +47 -0
  5. package/dist/cjs/components/app/props.cjs +3 -0
  6. package/dist/cjs/components/base-layout/index.cjs +45 -0
  7. package/dist/cjs/components/base-layout/props.cjs +3 -0
  8. package/dist/cjs/components/base-layout/styles.cjs +57 -0
  9. package/dist/cjs/components/base-layout/use-base-layout.cjs +41 -0
  10. package/dist/cjs/components/crud/components/action-button-group.cjs +20 -0
  11. package/dist/cjs/components/crud/components/index.cjs +20 -0
  12. package/dist/cjs/components/crud/components/main.cjs +57 -0
  13. package/dist/cjs/components/crud/components/mutation-holder.cjs +40 -0
  14. package/dist/cjs/components/crud/components/operation-button-group.cjs +22 -0
  15. package/dist/cjs/components/crud/components/scene-form.cjs +84 -0
  16. package/dist/cjs/components/crud/components/selection-indicator.cjs +83 -0
  17. package/dist/cjs/components/crud/components/toolbar-actions.cjs +19 -0
  18. package/dist/cjs/components/crud/components/toolbar.cjs +38 -0
  19. package/dist/cjs/components/crud/event.cjs +12 -0
  20. package/dist/cjs/components/crud/helpers.cjs +26 -0
  21. package/dist/cjs/components/crud/hooks/index.cjs +14 -0
  22. package/dist/cjs/components/crud/hooks/use-query-observer.cjs +37 -0
  23. package/dist/cjs/components/crud/hooks/use-search-values.cjs +12 -0
  24. package/dist/cjs/components/crud/hooks/use-selected-rows.cjs +12 -0
  25. package/dist/cjs/components/crud/index.cjs +46 -0
  26. package/dist/cjs/components/crud/props.cjs +3 -0
  27. package/dist/cjs/components/crud/store.cjs +93 -0
  28. package/dist/cjs/components/crud/styles.cjs +34 -0
  29. package/dist/cjs/components/crud-page/index.cjs +19 -0
  30. package/dist/cjs/components/crud-page/props.cjs +3 -0
  31. package/dist/cjs/components/error/error-icon.cjs +179 -0
  32. package/dist/cjs/components/error/index.cjs +69 -0
  33. package/dist/cjs/components/flex-card/index.cjs +18 -0
  34. package/dist/cjs/components/flex-card/props.cjs +3 -0
  35. package/dist/cjs/components/flex-card/styles.cjs +26 -0
  36. package/dist/cjs/components/form-drawer/components/form-actions.cjs +38 -0
  37. package/dist/cjs/components/form-drawer/components/index.cjs +10 -0
  38. package/dist/cjs/components/form-drawer/index.cjs +112 -0
  39. package/dist/cjs/components/form-modal/components/form-actions.cjs +38 -0
  40. package/dist/cjs/components/form-modal/components/index.cjs +10 -0
  41. package/dist/cjs/components/form-modal/index.cjs +88 -0
  42. package/dist/cjs/components/index.cjs +45 -0
  43. package/dist/cjs/components/layout/components/footer.cjs +27 -0
  44. package/dist/cjs/components/layout/components/header/boy-icon.cjs +20 -0
  45. package/dist/cjs/components/layout/components/header/breadcrumb-navigation.cjs +90 -0
  46. package/dist/cjs/components/layout/components/header/color-scheme.cjs +40 -0
  47. package/dist/cjs/components/layout/components/header/fullscreen.cjs +23 -0
  48. package/dist/cjs/components/layout/components/header/girl-icon.cjs +21 -0
  49. package/dist/cjs/components/layout/components/header/index.cjs +88 -0
  50. package/dist/cjs/components/layout/components/header/menu-burger.cjs +24 -0
  51. package/dist/cjs/components/layout/components/header/menu-fold-left-icon.cjs +20 -0
  52. package/dist/cjs/components/layout/components/header/menu-unfold-left-icon.cjs +20 -0
  53. package/dist/cjs/components/layout/components/header/search.cjs +22 -0
  54. package/dist/cjs/components/layout/components/header/theme-config.cjs +23 -0
  55. package/dist/cjs/components/layout/components/header/user-avatar.cjs +86 -0
  56. package/dist/cjs/components/layout/components/honeycomb-pattern.cjs +39 -0
  57. package/dist/cjs/components/layout/components/index.cjs +20 -0
  58. package/dist/cjs/components/layout/components/logo.cjs +60 -0
  59. package/dist/cjs/components/layout/components/menu.cjs +95 -0
  60. package/dist/cjs/components/layout/components/search/index.cjs +79 -0
  61. package/dist/cjs/components/layout/components/search/keyboard-arrow-down-icon.cjs +15 -0
  62. package/dist/cjs/components/layout/components/search/keyboard-arrow-up-icon.cjs +15 -0
  63. package/dist/cjs/components/layout/components/search/keyboard-control-icon.cjs +15 -0
  64. package/dist/cjs/components/layout/components/search/keyboard-esc-icon.cjs +15 -0
  65. package/dist/cjs/components/layout/components/search/keyboard-help.cjs +46 -0
  66. package/dist/cjs/components/layout/components/search/keyboard-return-icon.cjs +15 -0
  67. package/dist/cjs/components/layout/components/search/keyboard-shift-icon.cjs +15 -0
  68. package/dist/cjs/components/layout/components/search/keyboard.cjs +32 -0
  69. package/dist/cjs/components/layout/components/search/letter-s-icon.cjs +15 -0
  70. package/dist/cjs/components/layout/components/search/search-result-item.cjs +69 -0
  71. package/dist/cjs/components/layout/components/search/search-result.cjs +135 -0
  72. package/dist/cjs/components/layout/components/sidebar.cjs +54 -0
  73. package/dist/cjs/components/layout/components/tabs/context-menu.cjs +96 -0
  74. package/dist/cjs/components/layout/components/tabs/index.cjs +40 -0
  75. package/dist/cjs/components/layout/components/tabs/main-content-maximum.cjs +23 -0
  76. package/dist/cjs/components/layout/components/tabs/reload.cjs +21 -0
  77. package/dist/cjs/components/layout/components/tabs/tab-item.cjs +84 -0
  78. package/dist/cjs/components/layout/components/tabs/tab-list.cjs +91 -0
  79. package/dist/cjs/components/layout/components/tabs/tabs-container.cjs +85 -0
  80. package/dist/cjs/components/layout/components/theme-config/color-scheme-switcher.cjs +49 -0
  81. package/dist/cjs/components/layout/components/theme-config/color-scheme.cjs +57 -0
  82. package/dist/cjs/components/layout/components/theme-config/config-item.cjs +27 -0
  83. package/dist/cjs/components/layout/components/theme-config/index.cjs +59 -0
  84. package/dist/cjs/components/layout/components/theme-config/menu-layout-card.cjs +75 -0
  85. package/dist/cjs/components/layout/components/theme-config/menu-layout.cjs +33 -0
  86. package/dist/cjs/components/layout/components/theme-config/operations.cjs +22 -0
  87. package/dist/cjs/components/layout/components/theme-config/theme-color-picker.cjs +33 -0
  88. package/dist/cjs/components/layout/components/theme-config/theme-colors.cjs +29 -0
  89. package/dist/cjs/components/layout/hooks/index.cjs +14 -0
  90. package/dist/cjs/components/layout/hooks/use-color-scheme-updater.cjs +72 -0
  91. package/dist/cjs/components/layout/hooks/use-menu-navigate.cjs +29 -0
  92. package/dist/cjs/components/layout/hooks/use-tab-navigate.cjs +39 -0
  93. package/dist/cjs/components/layout/index.cjs +81 -0
  94. package/dist/cjs/components/layout/props.cjs +3 -0
  95. package/dist/cjs/components/layout/store.cjs +23 -0
  96. package/dist/cjs/components/layout/styles.cjs +16 -0
  97. package/dist/cjs/components/login/icon-login.cjs +149 -0
  98. package/dist/cjs/components/login/index.cjs +162 -0
  99. package/dist/cjs/components/login/payload.cjs +3 -0
  100. package/dist/cjs/components/login/props.cjs +3 -0
  101. package/dist/cjs/components/login/styles.cjs +97 -0
  102. package/dist/cjs/components/login/welcome-messages.cjs +135 -0
  103. package/dist/cjs/components/logo-icon/index.cjs +22 -0
  104. package/dist/cjs/components/logo-icon/props.cjs +3 -0
  105. package/dist/cjs/components/n-progress/components/bar.cjs +53 -0
  106. package/dist/cjs/components/n-progress/components/container.cjs +25 -0
  107. package/dist/cjs/components/n-progress/components/index.cjs +12 -0
  108. package/dist/cjs/components/n-progress/event.cjs +10 -0
  109. package/dist/cjs/components/n-progress/index.cjs +34 -0
  110. package/dist/cjs/components/not-found/index.cjs +47 -0
  111. package/dist/cjs/components/not-found/not-found-icon.cjs +205 -0
  112. package/dist/cjs/components/page/index.cjs +58 -0
  113. package/dist/cjs/components/page/props.cjs +3 -0
  114. package/dist/cjs/components/page/scroll-content.cjs +65 -0
  115. package/dist/cjs/components/page/styles.cjs +86 -0
  116. package/dist/cjs/components/page/use-page-key.cjs +22 -0
  117. package/dist/cjs/components/page/viewport-context.cjs +19 -0
  118. package/dist/cjs/components/pro-search/components/advanced-search-toggler.cjs +23 -0
  119. package/dist/cjs/components/pro-search/components/advanced-search.cjs +30 -0
  120. package/dist/cjs/components/pro-search/components/index.cjs +14 -0
  121. package/dist/cjs/components/pro-search/components/search-actions.cjs +36 -0
  122. package/dist/cjs/components/pro-search/index.cjs +70 -0
  123. package/dist/cjs/components/pro-search/styles.cjs +65 -0
  124. package/dist/cjs/components/pro-table/components/index.cjs +17 -0
  125. package/dist/cjs/components/pro-table/components/operation-button-group.cjs +22 -0
  126. package/dist/cjs/components/pro-table/components/ref.cjs +24 -0
  127. package/dist/cjs/components/pro-table/components/table-subscriber.cjs +25 -0
  128. package/dist/cjs/components/pro-table/components/table-summary.cjs +15 -0
  129. package/dist/cjs/components/pro-table/components/table-title.cjs +15 -0
  130. package/dist/cjs/components/pro-table/components/table.cjs +132 -0
  131. package/dist/cjs/components/pro-table/context.cjs +15 -0
  132. package/dist/cjs/components/pro-table/event.cjs +12 -0
  133. package/dist/cjs/components/pro-table/hooks/index.cjs +12 -0
  134. package/dist/cjs/components/pro-table/hooks/use-row-selection.cjs +43 -0
  135. package/dist/cjs/components/pro-table/hooks/use-table-columns.cjs +60 -0
  136. package/dist/cjs/components/pro-table/index.cjs +53 -0
  137. package/dist/cjs/components/pro-table/store.cjs +40 -0
  138. package/dist/cjs/components/router-provider/context.cjs +15 -0
  139. package/dist/cjs/components/router-provider/index.cjs +29 -0
  140. package/dist/cjs/components/router-provider/props.cjs +3 -0
  141. package/dist/cjs/components/theme-config-provider/global-style.cjs +20 -0
  142. package/dist/cjs/components/theme-config-provider/index.cjs +19 -0
  143. package/dist/cjs/components/theme-config-provider/use-color-mode-effect.cjs +35 -0
  144. package/dist/cjs/components/theme-config-provider/use-theme-config.cjs +73 -0
  145. package/dist/cjs/constants/event.cjs +8 -0
  146. package/dist/cjs/constants/index.cjs +23 -0
  147. package/dist/cjs/constants/router.cjs +18 -0
  148. package/dist/cjs/constants/storage.cjs +10 -0
  149. package/dist/cjs/constants/symbols.cjs +10 -0
  150. package/dist/cjs/helpers/api.cjs +50 -0
  151. package/dist/cjs/helpers/app-version.cjs +227 -0
  152. package/dist/cjs/helpers/app.cjs +37 -0
  153. package/dist/cjs/helpers/auth.cjs +24 -0
  154. package/dist/cjs/helpers/event.cjs +24 -0
  155. package/dist/cjs/helpers/index.cjs +25 -0
  156. package/dist/cjs/helpers/query.cjs +27 -0
  157. package/dist/cjs/helpers/router.cjs +110 -0
  158. package/dist/cjs/hooks/index.cjs +10 -0
  159. package/dist/cjs/hooks/use-route-full-path.cjs +32 -0
  160. package/dist/cjs/index.cjs +83 -0
  161. package/dist/cjs/routes/access-denied.cjs +31 -0
  162. package/dist/cjs/routes/index.cjs +16 -0
  163. package/dist/cjs/routes/layout.cjs +140 -0
  164. package/dist/cjs/routes/login.cjs +41 -0
  165. package/dist/cjs/routes/root.cjs +35 -0
  166. package/dist/cjs/stores/app.cjs +25 -0
  167. package/dist/cjs/stores/index.cjs +14 -0
  168. package/dist/cjs/stores/tab.cjs +101 -0
  169. package/dist/cjs/stores/theme.cjs +32 -0
  170. package/dist/es/components/access-denied/access-denied-icon.js +206 -0
  171. package/dist/es/components/access-denied/index.js +43 -0
  172. package/dist/es/components/app/index.js +43 -0
  173. package/dist/es/components/app/props.js +1 -0
  174. package/dist/es/components/base-layout/index.js +41 -0
  175. package/dist/es/components/base-layout/props.js +1 -0
  176. package/dist/es/components/base-layout/styles.js +47 -0
  177. package/dist/es/components/base-layout/use-base-layout.js +37 -0
  178. package/dist/es/components/crud/components/action-button-group.js +16 -0
  179. package/dist/es/components/crud/components/index.js +7 -0
  180. package/dist/es/components/crud/components/main.js +53 -0
  181. package/dist/es/components/crud/components/mutation-holder.js +36 -0
  182. package/dist/es/components/crud/components/operation-button-group.js +18 -0
  183. package/dist/es/components/crud/components/scene-form.js +80 -0
  184. package/dist/es/components/crud/components/selection-indicator.js +79 -0
  185. package/dist/es/components/crud/components/toolbar-actions.js +15 -0
  186. package/dist/es/components/crud/components/toolbar.js +34 -0
  187. package/dist/es/components/crud/event.js +8 -0
  188. package/dist/es/components/crud/helpers.js +22 -0
  189. package/dist/es/components/crud/hooks/index.js +4 -0
  190. package/dist/es/components/crud/hooks/use-query-observer.js +33 -0
  191. package/dist/es/components/crud/hooks/use-search-values.js +8 -0
  192. package/dist/es/components/crud/hooks/use-selected-rows.js +8 -0
  193. package/dist/es/components/crud/index.js +41 -0
  194. package/dist/es/components/crud/props.js +1 -0
  195. package/dist/es/components/crud/store.js +87 -0
  196. package/dist/es/components/crud/styles.js +28 -0
  197. package/dist/es/components/crud-page/index.js +15 -0
  198. package/dist/es/components/crud-page/props.js +1 -0
  199. package/dist/es/components/error/error-icon.js +175 -0
  200. package/dist/es/components/error/index.js +65 -0
  201. package/dist/es/components/flex-card/index.js +14 -0
  202. package/dist/es/components/flex-card/props.js +1 -0
  203. package/dist/es/components/flex-card/styles.js +22 -0
  204. package/dist/es/components/form-drawer/components/form-actions.js +34 -0
  205. package/dist/es/components/form-drawer/components/index.js +2 -0
  206. package/dist/es/components/form-drawer/index.js +108 -0
  207. package/dist/es/components/form-modal/components/form-actions.js +34 -0
  208. package/dist/es/components/form-modal/components/index.js +2 -0
  209. package/dist/es/components/form-modal/index.js +84 -0
  210. package/dist/es/components/index.js +20 -0
  211. package/dist/es/components/layout/components/footer.js +23 -0
  212. package/dist/es/components/layout/components/header/boy-icon.js +16 -0
  213. package/dist/es/components/layout/components/header/breadcrumb-navigation.js +86 -0
  214. package/dist/es/components/layout/components/header/color-scheme.js +36 -0
  215. package/dist/es/components/layout/components/header/fullscreen.js +19 -0
  216. package/dist/es/components/layout/components/header/girl-icon.js +17 -0
  217. package/dist/es/components/layout/components/header/index.js +84 -0
  218. package/dist/es/components/layout/components/header/menu-burger.js +20 -0
  219. package/dist/es/components/layout/components/header/menu-fold-left-icon.js +16 -0
  220. package/dist/es/components/layout/components/header/menu-unfold-left-icon.js +16 -0
  221. package/dist/es/components/layout/components/header/search.js +18 -0
  222. package/dist/es/components/layout/components/header/theme-config.js +19 -0
  223. package/dist/es/components/layout/components/header/user-avatar.js +82 -0
  224. package/dist/es/components/layout/components/honeycomb-pattern.js +35 -0
  225. package/dist/es/components/layout/components/index.js +7 -0
  226. package/dist/es/components/layout/components/logo.js +56 -0
  227. package/dist/es/components/layout/components/menu.js +91 -0
  228. package/dist/es/components/layout/components/search/index.js +75 -0
  229. package/dist/es/components/layout/components/search/keyboard-arrow-down-icon.js +11 -0
  230. package/dist/es/components/layout/components/search/keyboard-arrow-up-icon.js +11 -0
  231. package/dist/es/components/layout/components/search/keyboard-control-icon.js +11 -0
  232. package/dist/es/components/layout/components/search/keyboard-esc-icon.js +11 -0
  233. package/dist/es/components/layout/components/search/keyboard-help.js +42 -0
  234. package/dist/es/components/layout/components/search/keyboard-return-icon.js +11 -0
  235. package/dist/es/components/layout/components/search/keyboard-shift-icon.js +11 -0
  236. package/dist/es/components/layout/components/search/keyboard.js +28 -0
  237. package/dist/es/components/layout/components/search/letter-s-icon.js +11 -0
  238. package/dist/es/components/layout/components/search/search-result-item.js +65 -0
  239. package/dist/es/components/layout/components/search/search-result.js +131 -0
  240. package/dist/es/components/layout/components/sidebar.js +50 -0
  241. package/dist/es/components/layout/components/tabs/context-menu.js +92 -0
  242. package/dist/es/components/layout/components/tabs/index.js +36 -0
  243. package/dist/es/components/layout/components/tabs/main-content-maximum.js +19 -0
  244. package/dist/es/components/layout/components/tabs/reload.js +17 -0
  245. package/dist/es/components/layout/components/tabs/tab-item.js +80 -0
  246. package/dist/es/components/layout/components/tabs/tab-list.js +87 -0
  247. package/dist/es/components/layout/components/tabs/tabs-container.js +81 -0
  248. package/dist/es/components/layout/components/theme-config/color-scheme-switcher.js +45 -0
  249. package/dist/es/components/layout/components/theme-config/color-scheme.js +53 -0
  250. package/dist/es/components/layout/components/theme-config/config-item.js +23 -0
  251. package/dist/es/components/layout/components/theme-config/index.js +55 -0
  252. package/dist/es/components/layout/components/theme-config/menu-layout-card.js +71 -0
  253. package/dist/es/components/layout/components/theme-config/menu-layout.js +29 -0
  254. package/dist/es/components/layout/components/theme-config/operations.js +18 -0
  255. package/dist/es/components/layout/components/theme-config/theme-color-picker.js +29 -0
  256. package/dist/es/components/layout/components/theme-config/theme-colors.js +25 -0
  257. package/dist/es/components/layout/hooks/index.js +4 -0
  258. package/dist/es/components/layout/hooks/use-color-scheme-updater.js +68 -0
  259. package/dist/es/components/layout/hooks/use-menu-navigate.js +25 -0
  260. package/dist/es/components/layout/hooks/use-tab-navigate.js +35 -0
  261. package/dist/es/components/layout/index.js +77 -0
  262. package/dist/es/components/layout/props.js +1 -0
  263. package/dist/es/components/layout/store.js +18 -0
  264. package/dist/es/components/layout/styles.js +12 -0
  265. package/dist/es/components/login/icon-login.js +145 -0
  266. package/dist/es/components/login/index.js +158 -0
  267. package/dist/es/components/login/payload.js +1 -0
  268. package/dist/es/components/login/props.js +1 -0
  269. package/dist/es/components/login/styles.js +85 -0
  270. package/dist/es/components/login/welcome-messages.js +130 -0
  271. package/dist/es/components/logo-icon/index.js +18 -0
  272. package/dist/es/components/logo-icon/props.js +1 -0
  273. package/dist/es/components/n-progress/components/bar.js +49 -0
  274. package/dist/es/components/n-progress/components/container.js +21 -0
  275. package/dist/es/components/n-progress/components/index.js +3 -0
  276. package/dist/es/components/n-progress/event.js +6 -0
  277. package/dist/es/components/n-progress/index.js +29 -0
  278. package/dist/es/components/not-found/index.js +43 -0
  279. package/dist/es/components/not-found/not-found-icon.js +201 -0
  280. package/dist/es/components/page/index.js +53 -0
  281. package/dist/es/components/page/props.js +1 -0
  282. package/dist/es/components/page/scroll-content.js +61 -0
  283. package/dist/es/components/page/styles.js +73 -0
  284. package/dist/es/components/page/use-page-key.js +18 -0
  285. package/dist/es/components/page/viewport-context.js +14 -0
  286. package/dist/es/components/pro-search/components/advanced-search-toggler.js +19 -0
  287. package/dist/es/components/pro-search/components/advanced-search.js +26 -0
  288. package/dist/es/components/pro-search/components/index.js +4 -0
  289. package/dist/es/components/pro-search/components/search-actions.js +32 -0
  290. package/dist/es/components/pro-search/index.js +66 -0
  291. package/dist/es/components/pro-search/styles.js +57 -0
  292. package/dist/es/components/pro-table/components/index.js +5 -0
  293. package/dist/es/components/pro-table/components/operation-button-group.js +18 -0
  294. package/dist/es/components/pro-table/components/ref.js +20 -0
  295. package/dist/es/components/pro-table/components/table-subscriber.js +21 -0
  296. package/dist/es/components/pro-table/components/table-summary.js +11 -0
  297. package/dist/es/components/pro-table/components/table-title.js +11 -0
  298. package/dist/es/components/pro-table/components/table.js +127 -0
  299. package/dist/es/components/pro-table/context.js +10 -0
  300. package/dist/es/components/pro-table/event.js +8 -0
  301. package/dist/es/components/pro-table/hooks/index.js +3 -0
  302. package/dist/es/components/pro-table/hooks/use-row-selection.js +39 -0
  303. package/dist/es/components/pro-table/hooks/use-table-columns.js +56 -0
  304. package/dist/es/components/pro-table/index.js +49 -0
  305. package/dist/es/components/pro-table/store.js +34 -0
  306. package/dist/es/components/router-provider/context.js +10 -0
  307. package/dist/es/components/router-provider/index.js +25 -0
  308. package/dist/es/components/router-provider/props.js +1 -0
  309. package/dist/es/components/theme-config-provider/global-style.js +16 -0
  310. package/dist/es/components/theme-config-provider/index.js +15 -0
  311. package/dist/es/components/theme-config-provider/use-color-mode-effect.js +31 -0
  312. package/dist/es/components/theme-config-provider/use-theme-config.js +69 -0
  313. package/dist/es/constants/event.js +4 -0
  314. package/dist/es/constants/index.js +5 -0
  315. package/dist/es/constants/router.js +9 -0
  316. package/dist/es/constants/storage.js +5 -0
  317. package/dist/es/constants/symbols.js +5 -0
  318. package/dist/es/helpers/api.js +46 -0
  319. package/dist/es/helpers/app-version.js +223 -0
  320. package/dist/es/helpers/app.js +33 -0
  321. package/dist/es/helpers/auth.js +20 -0
  322. package/dist/es/helpers/event.js +18 -0
  323. package/dist/es/helpers/index.js +8 -0
  324. package/dist/es/helpers/query.js +22 -0
  325. package/dist/es/helpers/router.js +106 -0
  326. package/dist/es/hooks/index.js +2 -0
  327. package/dist/es/hooks/use-route-full-path.js +28 -0
  328. package/dist/es/index.js +36 -0
  329. package/dist/es/routes/access-denied.js +27 -0
  330. package/dist/es/routes/index.js +5 -0
  331. package/dist/es/routes/layout.js +136 -0
  332. package/dist/es/routes/login.js +37 -0
  333. package/dist/es/routes/root.js +31 -0
  334. package/dist/es/stores/app.js +21 -0
  335. package/dist/es/stores/index.js +4 -0
  336. package/dist/es/stores/tab.js +97 -0
  337. package/dist/es/stores/theme.js +28 -0
  338. package/dist/types/components/access-denied/access-denied-icon.d.ts +2 -0
  339. package/dist/types/components/access-denied/index.d.ts +1 -0
  340. package/dist/types/components/app/index.d.ts +4 -0
  341. package/dist/types/components/app/props.d.ts +21 -0
  342. package/dist/types/components/base-layout/index.d.ts +3 -0
  343. package/dist/types/components/base-layout/props.d.ts +70 -0
  344. package/dist/types/components/base-layout/styles.d.ts +8 -0
  345. package/dist/types/components/base-layout/use-base-layout.d.ts +9 -0
  346. package/dist/types/components/crud/components/action-button-group.d.ts +8 -0
  347. package/dist/types/components/crud/components/index.d.ts +6 -0
  348. package/dist/types/components/crud/components/main.d.ts +6 -0
  349. package/dist/types/components/crud/components/mutation-holder.d.ts +10 -0
  350. package/dist/types/components/crud/components/operation-button-group.d.ts +8 -0
  351. package/dist/types/components/crud/components/scene-form.d.ts +7 -0
  352. package/dist/types/components/crud/components/selection-indicator.d.ts +6 -0
  353. package/dist/types/components/crud/components/toolbar-actions.d.ts +6 -0
  354. package/dist/types/components/crud/components/toolbar.d.ts +8 -0
  355. package/dist/types/components/crud/event.d.ts +3 -0
  356. package/dist/types/components/crud/helpers.d.ts +18 -0
  357. package/dist/types/components/crud/hooks/index.d.ts +3 -0
  358. package/dist/types/components/crud/hooks/use-query-observer.d.ts +11 -0
  359. package/dist/types/components/crud/hooks/use-search-values.d.ts +2 -0
  360. package/dist/types/components/crud/hooks/use-selected-rows.d.ts +2 -0
  361. package/dist/types/components/crud/index.d.ts +7 -0
  362. package/dist/types/components/crud/props.d.ts +153 -0
  363. package/dist/types/components/crud/store.d.ts +145 -0
  364. package/dist/types/components/crud/styles.d.ts +4 -0
  365. package/dist/types/components/crud/types.d.ts +48 -0
  366. package/dist/types/components/crud-page/index.d.ts +3 -0
  367. package/dist/types/components/crud-page/props.d.ts +20 -0
  368. package/dist/types/components/error/error-icon.d.ts +2 -0
  369. package/dist/types/components/error/index.d.ts +2 -0
  370. package/dist/types/components/error/props.d.ts +6 -0
  371. package/dist/types/components/flex-card/index.d.ts +3 -0
  372. package/dist/types/components/flex-card/props.d.ts +3 -0
  373. package/dist/types/components/flex-card/styles.d.ts +2 -0
  374. package/dist/types/components/form-drawer/components/form-actions.d.ts +18 -0
  375. package/dist/types/components/form-drawer/components/index.d.ts +1 -0
  376. package/dist/types/components/form-drawer/index.d.ts +5 -0
  377. package/dist/types/components/form-drawer/props.d.ts +70 -0
  378. package/dist/types/components/form-modal/components/form-actions.d.ts +18 -0
  379. package/dist/types/components/form-modal/components/index.d.ts +1 -0
  380. package/dist/types/components/form-modal/index.d.ts +5 -0
  381. package/dist/types/components/form-modal/props.d.ts +66 -0
  382. package/dist/types/components/index.d.ts +19 -0
  383. package/dist/types/components/layout/components/footer.d.ts +1 -0
  384. package/dist/types/components/layout/components/header/boy-icon.d.ts +2 -0
  385. package/dist/types/components/layout/components/header/breadcrumb-navigation.d.ts +2 -0
  386. package/dist/types/components/layout/components/header/color-scheme.d.ts +5 -0
  387. package/dist/types/components/layout/components/header/fullscreen.d.ts +5 -0
  388. package/dist/types/components/layout/components/header/girl-icon.d.ts +2 -0
  389. package/dist/types/components/layout/components/header/index.d.ts +5 -0
  390. package/dist/types/components/layout/components/header/menu-burger.d.ts +5 -0
  391. package/dist/types/components/layout/components/header/menu-fold-left-icon.d.ts +2 -0
  392. package/dist/types/components/layout/components/header/menu-unfold-left-icon.d.ts +2 -0
  393. package/dist/types/components/layout/components/header/search.d.ts +5 -0
  394. package/dist/types/components/layout/components/header/theme-config.d.ts +5 -0
  395. package/dist/types/components/layout/components/header/user-avatar.d.ts +6 -0
  396. package/dist/types/components/layout/components/honeycomb-pattern.d.ts +1 -0
  397. package/dist/types/components/layout/components/index.d.ts +6 -0
  398. package/dist/types/components/layout/components/logo.d.ts +8 -0
  399. package/dist/types/components/layout/components/menu.d.ts +7 -0
  400. package/dist/types/components/layout/components/search/index.d.ts +1 -0
  401. package/dist/types/components/layout/components/search/keyboard-arrow-down-icon.d.ts +2 -0
  402. package/dist/types/components/layout/components/search/keyboard-arrow-up-icon.d.ts +2 -0
  403. package/dist/types/components/layout/components/search/keyboard-control-icon.d.ts +2 -0
  404. package/dist/types/components/layout/components/search/keyboard-esc-icon.d.ts +2 -0
  405. package/dist/types/components/layout/components/search/keyboard-help.d.ts +1 -0
  406. package/dist/types/components/layout/components/search/keyboard-return-icon.d.ts +2 -0
  407. package/dist/types/components/layout/components/search/keyboard-shift-icon.d.ts +2 -0
  408. package/dist/types/components/layout/components/search/keyboard.d.ts +6 -0
  409. package/dist/types/components/layout/components/search/letter-s-icon.d.ts +2 -0
  410. package/dist/types/components/layout/components/search/search-result-item.d.ts +8 -0
  411. package/dist/types/components/layout/components/search/search-result.d.ts +5 -0
  412. package/dist/types/components/layout/components/sidebar.d.ts +6 -0
  413. package/dist/types/components/layout/components/tabs/context-menu.d.ts +6 -0
  414. package/dist/types/components/layout/components/tabs/index.d.ts +1 -0
  415. package/dist/types/components/layout/components/tabs/main-content-maximum.d.ts +5 -0
  416. package/dist/types/components/layout/components/tabs/reload.d.ts +5 -0
  417. package/dist/types/components/layout/components/tabs/tab-item.d.ts +10 -0
  418. package/dist/types/components/layout/components/tabs/tab-list.d.ts +1 -0
  419. package/dist/types/components/layout/components/tabs/tabs-container.d.ts +1 -0
  420. package/dist/types/components/layout/components/theme-config/color-scheme-switcher.d.ts +1 -0
  421. package/dist/types/components/layout/components/theme-config/color-scheme.d.ts +1 -0
  422. package/dist/types/components/layout/components/theme-config/config-item.d.ts +7 -0
  423. package/dist/types/components/layout/components/theme-config/index.d.ts +1 -0
  424. package/dist/types/components/layout/components/theme-config/menu-layout-card.d.ts +7 -0
  425. package/dist/types/components/layout/components/theme-config/menu-layout.d.ts +1 -0
  426. package/dist/types/components/layout/components/theme-config/operations.d.ts +1 -0
  427. package/dist/types/components/layout/components/theme-config/theme-color-picker.d.ts +6 -0
  428. package/dist/types/components/layout/components/theme-config/theme-colors.d.ts +1 -0
  429. package/dist/types/components/layout/hooks/index.d.ts +3 -0
  430. package/dist/types/components/layout/hooks/use-color-scheme-updater.d.ts +13 -0
  431. package/dist/types/components/layout/hooks/use-menu-navigate.d.ts +7 -0
  432. package/dist/types/components/layout/hooks/use-tab-navigate.d.ts +11 -0
  433. package/dist/types/components/layout/index.d.ts +3 -0
  434. package/dist/types/components/layout/props.d.ts +28 -0
  435. package/dist/types/components/layout/store.d.ts +17 -0
  436. package/dist/types/components/layout/styles.d.ts +2 -0
  437. package/dist/types/components/login/icon-login.d.ts +2 -0
  438. package/dist/types/components/login/index.d.ts +4 -0
  439. package/dist/types/components/login/payload.d.ts +45 -0
  440. package/dist/types/components/login/props.d.ts +27 -0
  441. package/dist/types/components/login/styles.d.ts +10 -0
  442. package/dist/types/components/login/welcome-messages.d.ts +11 -0
  443. package/dist/types/components/logo-icon/index.d.ts +3 -0
  444. package/dist/types/components/logo-icon/props.d.ts +10 -0
  445. package/dist/types/components/n-progress/components/bar.d.ts +5 -0
  446. package/dist/types/components/n-progress/components/container.d.ts +7 -0
  447. package/dist/types/components/n-progress/components/index.d.ts +2 -0
  448. package/dist/types/components/n-progress/event.d.ts +7 -0
  449. package/dist/types/components/n-progress/index.d.ts +2 -0
  450. package/dist/types/components/not-found/index.d.ts +1 -0
  451. package/dist/types/components/not-found/not-found-icon.d.ts +2 -0
  452. package/dist/types/components/page/index.d.ts +4 -0
  453. package/dist/types/components/page/props.d.ts +51 -0
  454. package/dist/types/components/page/scroll-content.d.ts +8 -0
  455. package/dist/types/components/page/styles.d.ts +11 -0
  456. package/dist/types/components/page/use-page-key.d.ts +1 -0
  457. package/dist/types/components/page/viewport-context.d.ts +7 -0
  458. package/dist/types/components/pro-search/components/advanced-search-toggler.d.ts +7 -0
  459. package/dist/types/components/pro-search/components/advanced-search.d.ts +6 -0
  460. package/dist/types/components/pro-search/components/index.d.ts +3 -0
  461. package/dist/types/components/pro-search/components/search-actions.d.ts +22 -0
  462. package/dist/types/components/pro-search/index.d.ts +5 -0
  463. package/dist/types/components/pro-search/props.d.ts +66 -0
  464. package/dist/types/components/pro-search/styles.d.ts +6 -0
  465. package/dist/types/components/pro-table/components/index.d.ts +4 -0
  466. package/dist/types/components/pro-table/components/operation-button-group.d.ts +7 -0
  467. package/dist/types/components/pro-table/components/ref.d.ts +3 -0
  468. package/dist/types/components/pro-table/components/table-subscriber.d.ts +9 -0
  469. package/dist/types/components/pro-table/components/table-summary.d.ts +7 -0
  470. package/dist/types/components/pro-table/components/table-title.d.ts +7 -0
  471. package/dist/types/components/pro-table/components/table.d.ts +6 -0
  472. package/dist/types/components/pro-table/context.d.ts +3 -0
  473. package/dist/types/components/pro-table/event.d.ts +16 -0
  474. package/dist/types/components/pro-table/hooks/index.d.ts +2 -0
  475. package/dist/types/components/pro-table/hooks/use-row-selection.d.ts +12 -0
  476. package/dist/types/components/pro-table/hooks/use-table-columns.d.ts +11 -0
  477. package/dist/types/components/pro-table/index.d.ts +11 -0
  478. package/dist/types/components/pro-table/props.d.ts +118 -0
  479. package/dist/types/components/pro-table/store.d.ts +35 -0
  480. package/dist/types/components/pro-table/types.d.ts +86 -0
  481. package/dist/types/components/router-provider/context.d.ts +6 -0
  482. package/dist/types/components/router-provider/index.d.ts +5 -0
  483. package/dist/types/components/router-provider/props.d.ts +7 -0
  484. package/dist/types/components/theme-config-provider/global-style.d.ts +2 -0
  485. package/dist/types/components/theme-config-provider/index.d.ts +2 -0
  486. package/dist/types/components/theme-config-provider/use-color-mode-effect.d.ts +1 -0
  487. package/dist/types/components/theme-config-provider/use-theme-config.d.ts +2 -0
  488. package/dist/types/constants/event.d.ts +4 -0
  489. package/dist/types/constants/index.d.ts +4 -0
  490. package/dist/types/constants/router.d.ts +24 -0
  491. package/dist/types/constants/storage.d.ts +8 -0
  492. package/dist/types/constants/symbols.d.ts +8 -0
  493. package/dist/types/helpers/api.d.ts +9 -0
  494. package/dist/types/helpers/app-version.d.ts +88 -0
  495. package/dist/types/helpers/app.d.ts +24 -0
  496. package/dist/types/helpers/auth.d.ts +7 -0
  497. package/dist/types/helpers/event.d.ts +16 -0
  498. package/dist/types/helpers/index.d.ts +7 -0
  499. package/dist/types/helpers/query.d.ts +33 -0
  500. package/dist/types/helpers/router.d.ts +28 -0
  501. package/dist/types/hooks/index.d.ts +1 -0
  502. package/dist/types/hooks/use-route-full-path.d.ts +6 -0
  503. package/dist/types/index.d.ts +6 -0
  504. package/dist/types/models/index.d.ts +1 -0
  505. package/dist/types/routes/access-denied.d.ts +13 -0
  506. package/dist/types/routes/index.d.ts +4 -0
  507. package/dist/types/routes/layout.d.ts +25 -0
  508. package/dist/types/routes/login.d.ts +18 -0
  509. package/dist/types/routes/root.d.ts +13 -0
  510. package/dist/types/stores/app.d.ts +38 -0
  511. package/dist/types/stores/index.d.ts +6 -0
  512. package/dist/types/stores/tab.d.ts +73 -0
  513. package/dist/types/stores/theme.d.ts +46 -0
  514. package/dist/types/types/api.d.ts +67 -0
  515. package/dist/types/types/common.d.ts +81 -0
  516. package/dist/types/types/index.d.ts +3 -0
  517. package/dist/types/types/router.d.ts +9 -0
  518. package/package.json +61 -44
  519. package/README.md +0 -25
  520. package/cjs/api.cjs +0 -2
  521. package/cjs/app.cjs +0 -2
  522. package/cjs/components/index.cjs +0 -2
  523. package/cjs/components/vef-access-denied-page/index.cjs +0 -2
  524. package/cjs/components/vef-access-denied-page/props.cjs +0 -2
  525. package/cjs/components/vef-app/index.cjs +0 -2
  526. package/cjs/components/vef-app/props.cjs +0 -2
  527. package/cjs/components/vef-dev-assistant/index.cjs +0 -31
  528. package/cjs/components/vef-dev-assistant/props.cjs +0 -2
  529. package/cjs/components/vef-error-page/index.cjs +0 -2
  530. package/cjs/components/vef-error-page/props.cjs +0 -2
  531. package/cjs/components/vef-login-page/index.cjs +0 -2
  532. package/cjs/components/vef-login-page/props.cjs +0 -2
  533. package/cjs/components/vef-not-found-page/index.cjs +0 -2
  534. package/cjs/components/vef-not-found-page/props.cjs +0 -2
  535. package/cjs/components/vef-router-provider/index.cjs +0 -2
  536. package/cjs/components/vef-router-provider/props.cjs +0 -2
  537. package/cjs/constants.cjs +0 -2
  538. package/cjs/helper.cjs +0 -2
  539. package/cjs/index.cjs +0 -2
  540. package/cjs/router.cjs +0 -2
  541. package/cjs/routes/access-denied.cjs +0 -2
  542. package/cjs/routes/index.cjs +0 -2
  543. package/cjs/routes/layout.cjs +0 -2
  544. package/cjs/routes/login.cjs +0 -2
  545. package/cjs/routes/root.cjs +0 -2
  546. package/cjs/store.cjs +0 -2
  547. package/esm/api.js +0 -2
  548. package/esm/app.js +0 -2
  549. package/esm/components/index.js +0 -2
  550. package/esm/components/vef-access-denied-page/index.js +0 -2
  551. package/esm/components/vef-access-denied-page/props.js +0 -2
  552. package/esm/components/vef-app/index.js +0 -2
  553. package/esm/components/vef-app/props.js +0 -2
  554. package/esm/components/vef-dev-assistant/index.js +0 -31
  555. package/esm/components/vef-dev-assistant/props.js +0 -2
  556. package/esm/components/vef-error-page/index.js +0 -2
  557. package/esm/components/vef-error-page/props.js +0 -2
  558. package/esm/components/vef-login-page/index.js +0 -2
  559. package/esm/components/vef-login-page/props.js +0 -2
  560. package/esm/components/vef-not-found-page/index.js +0 -2
  561. package/esm/components/vef-not-found-page/props.js +0 -2
  562. package/esm/components/vef-router-provider/index.js +0 -2
  563. package/esm/components/vef-router-provider/props.js +0 -2
  564. package/esm/constants.js +0 -2
  565. package/esm/helper.js +0 -2
  566. package/esm/index.js +0 -2
  567. package/esm/router.js +0 -2
  568. package/esm/routes/access-denied.js +0 -2
  569. package/esm/routes/index.js +0 -2
  570. package/esm/routes/layout.js +0 -2
  571. package/esm/routes/login.js +0 -2
  572. package/esm/routes/root.js +0 -2
  573. package/esm/store.js +0 -2
  574. package/types/api.d.ts +0 -9
  575. package/types/app.d.ts +0 -15
  576. package/types/components/index.d.ts +0 -7
  577. package/types/components/vef-access-denied-page/index.d.ts +0 -4
  578. package/types/components/vef-access-denied-page/props.d.ts +0 -5
  579. package/types/components/vef-app/index.d.ts +0 -4
  580. package/types/components/vef-app/props.d.ts +0 -7
  581. package/types/components/vef-dev-assistant/index.d.ts +0 -4
  582. package/types/components/vef-dev-assistant/props.d.ts +0 -5
  583. package/types/components/vef-error-page/index.d.ts +0 -4
  584. package/types/components/vef-error-page/props.d.ts +0 -6
  585. package/types/components/vef-login-page/index.d.ts +0 -4
  586. package/types/components/vef-login-page/props.d.ts +0 -7
  587. package/types/components/vef-not-found-page/index.d.ts +0 -4
  588. package/types/components/vef-not-found-page/props.d.ts +0 -6
  589. package/types/components/vef-router-provider/index.d.ts +0 -4
  590. package/types/components/vef-router-provider/props.d.ts +0 -16
  591. package/types/constants.d.ts +0 -24
  592. package/types/helper.d.ts +0 -9
  593. package/types/index.d.ts +0 -8
  594. package/types/router.d.ts +0 -23
  595. package/types/routes/access-denied.d.ts +0 -9
  596. package/types/routes/index.d.ts +0 -4
  597. package/types/routes/layout.d.ts +0 -33
  598. package/types/routes/login.d.ts +0 -27
  599. package/types/routes/root.d.ts +0 -7
  600. package/types/store.d.ts +0 -34
@@ -0,0 +1,81 @@
1
+ /*! @vef-framework/starter v2.0.0 made with ❤️ by Venus | 2025-11-25T10:06:38.668Z */
2
+ import { jsx } from '@emotion/react/jsx-runtime';
3
+ import { css } from '@emotion/react';
4
+ import { globalCssVars, ScrollArea } from '@vef-framework/components';
5
+ import { clsx } from '@vef-framework/core';
6
+ import { useIsomorphicEffect } from '@vef-framework/hooks';
7
+ import { useRef, useState, useCallback } from 'react';
8
+ import { TabList } from './tab-list.js';
9
+
10
+ const tabsWrapperStyle = /* @__PURE__ */ css({
11
+ flex: "auto",
12
+ "&.shadow-right::after": {
13
+ content: "''",
14
+ position: "absolute",
15
+ top: 0,
16
+ bottom: 0,
17
+ right: 0,
18
+ width: "10px",
19
+ boxShadow: "inset -10px 0 8px -8px var(--vef-color-split)",
20
+ transition: `box-shadow ${globalCssVars.motionDurationMid} ease`,
21
+ pointerEvents: "none"
22
+ },
23
+ "&.shadow-left::before": {
24
+ content: "''",
25
+ position: "absolute",
26
+ top: 0,
27
+ bottom: 0,
28
+ left: 0,
29
+ width: "10px",
30
+ boxShadow: "inset 10px 0 8px -8px var(--vef-color-split)",
31
+ transition: `box-shadow ${globalCssVars.motionDurationMid} ease`,
32
+ pointerEvents: "none"
33
+ }
34
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RhYnMvdGFicy1jb250YWluZXIudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVd5QiIsImZpbGUiOiIvVXNlcnMvdmVudXMvVkVGL3ZlZi1mcmFtZXdvcmstcmVhY3QvcGFja2FnZXMvc3RhcnRlci9zcmMvY29tcG9uZW50cy9sYXlvdXQvY29tcG9uZW50cy90YWJzL3RhYnMtY29udGFpbmVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgUG9zaXRpb24gfSBmcm9tIFwiQHZlZi1mcmFtZXdvcmsvY29tcG9uZW50c1wiO1xuaW1wb3J0IHR5cGUgeyBNYXliZVVuZGVmaW5lZCB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9zaGFyZWRcIjtcblxuaW1wb3J0IHsgY3NzIH0gZnJvbSBcIkBlbW90aW9uL3JlYWN0XCI7XG5pbXBvcnQgeyBnbG9iYWxDc3NWYXJzLCBTY3JvbGxBcmVhIH0gZnJvbSBcIkB2ZWYtZnJhbWV3b3JrL2NvbXBvbmVudHNcIjtcbmltcG9ydCB7IGNsc3ggfSBmcm9tIFwiQHZlZi1mcmFtZXdvcmsvY29yZVwiO1xuaW1wb3J0IHsgdXNlSXNvbW9ycGhpY0VmZmVjdCB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9ob29rc1wiO1xuaW1wb3J0IHsgdXNlQ2FsbGJhY2ssIHVzZVJlZiwgdXNlU3RhdGUgfSBmcm9tIFwicmVhY3RcIjtcblxuaW1wb3J0IHsgVGFiTGlzdCB9IGZyb20gXCIuL3RhYi1saXN0XCI7XG5cbmNvbnN0IHRhYnNXcmFwcGVyU3R5bGUgPSBjc3Moe1xuICBmbGV4OiBcImF1dG9cIixcbiAgXCImLnNoYWRvdy1yaWdodDo6YWZ0ZXJcIjoge1xuICAgIGNvbnRlbnQ6IFwiJydcIixcbiAgICBwb3NpdGlvbjogXCJhYnNvbHV0ZVwiLFxuICAgIHRvcDogMCxcbiAgICBib3R0b206IDAsXG4gICAgcmlnaHQ6IDAsXG4gICAgd2lkdGg6IFwiMTBweFwiLFxuICAgIGJveFNoYWRvdzogXCJpbnNldCAtMTBweCAwIDhweCAtOHB4IHZhcigtLXZlZi1jb2xvci1zcGxpdClcIixcbiAgICB0cmFuc2l0aW9uOiBgYm94LXNoYWRvdyAke2dsb2JhbENzc1ZhcnMubW90aW9uRHVyYXRpb25NaWR9IGVhc2VgLFxuICAgIHBvaW50ZXJFdmVudHM6IFwibm9uZVwiXG4gIH0sXG4gIFwiJi5zaGFkb3ctbGVmdDo6YmVmb3JlXCI6IHtcbiAgICBjb250ZW50OiBcIicnXCIsXG4gICAgcG9zaXRpb246IFwiYWJzb2x1dGVcIixcbiAgICB0b3A6IDAsXG4gICAgYm90dG9tOiAwLFxuICAgIGxlZnQ6IDAsXG4gICAgd2lkdGg6IFwiMTBweFwiLFxuICAgIGJveFNoYWRvdzogXCJpbnNldCAxMHB4IDAgOHB4IC04cHggdmFyKC0tdmVmLWNvbG9yLXNwbGl0KVwiLFxuICAgIHRyYW5zaXRpb246IGBib3gtc2hhZG93ICR7Z2xvYmFsQ3NzVmFycy5tb3Rpb25EdXJhdGlvbk1pZH0gZWFzZWAsXG4gICAgcG9pbnRlckV2ZW50czogXCJub25lXCJcbiAgfVxufSk7XG5cbmV4cG9ydCBmdW5jdGlvbiBUYWJzQ29udGFpbmVyKCkge1xuICBjb25zdCB0YWJzQ29udGFpbmVyUmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKTtcbiAgY29uc3QgaXNPdmVyZmxvd1JlZiA9IHVzZVJlZihmYWxzZSk7XG4gIGNvbnN0IG92ZXJmbG93V2lkdGhSZWYgPSB1c2VSZWYoMCk7XG4gIGNvbnN0IFtyb290Q2xhc3NOYW1lLCBzZXRSb290Q2xhc3NOYW1lXSA9IHVzZVN0YXRlPE1heWJlVW5kZWZpbmVkPHN0cmluZz4+KCk7XG5cbiAgLy8gVXBkYXRlIG92ZXJmbG93IHN0YXRlIGFuZCBzaGFkb3cgY2xhc3Nlc1xuICBjb25zdCB1cGRhdGVPdmVyZmxvd1N0YXRlID0gdXNlQ2FsbGJhY2soKCkgPT4ge1xuICAgIGlmICh0YWJzQ29udGFpbmVyUmVmLmN1cnJlbnQpIHtcbiAgICAgIGNvbnN0IGNvbnRhaW5lckVsID0gdGFic0NvbnRhaW5lclJlZi5jdXJyZW50O1xuICAgICAgb3ZlcmZsb3dXaWR0aFJlZi5jdXJyZW50ID0gY29udGFpbmVyRWwuc2Nyb2xsV2lkdGggLSBjb250YWluZXJFbC5jbGllbnRXaWR0aDtcbiAgICAgIGlzT3ZlcmZsb3dSZWYuY3VycmVudCA9IG92ZXJmbG93V2lkdGhSZWYuY3VycmVudCA+IDA7XG4gICAgICBjb25zdCB7IHNjcm9sbExlZnQgfSA9IGNvbnRhaW5lckVsO1xuXG4gICAgICBzZXRSb290Q2xhc3NOYW1lKGNsc3goe1xuICAgICAgICBcInNoYWRvdy1sZWZ0XCI6IHNjcm9sbExlZnQgPiAwLFxuICAgICAgICBcInNoYWRvdy1yaWdodFwiOiBzY3JvbGxMZWZ0IDwgb3ZlcmZsb3dXaWR0aFJlZi5jdXJyZW50XG4gICAgICB9KSk7XG4gICAgfVxuICB9LCBbXSk7XG5cbiAgdXNlSXNvbW9ycGhpY0VmZmVjdCgoKSA9PiB7XG4gICAgY29uc3QgY29udGFpbmVyRWwgPSB0YWJzQ29udGFpbmVyUmVmLmN1cnJlbnQ7XG5cbiAgICBpZiAoIWNvbnRhaW5lckVsKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgLy8gSW5pdGlhbCBjYWxjdWxhdGlvblxuICAgIHVwZGF0ZU92ZXJmbG93U3RhdGUoKTtcblxuICAgIC8vIENyZWF0ZSBSZXNpemVPYnNlcnZlciB0byB3YXRjaCBmb3IgY29udGFpbmVyIHNpemUgY2hhbmdlc1xuICAgIGNvbnN0IHJlc2l6ZU9ic2VydmVyID0gbmV3IFJlc2l6ZU9ic2VydmVyKCgpID0+IHtcbiAgICAgIHVwZGF0ZU92ZXJmbG93U3RhdGUoKTtcbiAgICB9KTtcblxuICAgIHJlc2l6ZU9ic2VydmVyLm9ic2VydmUoY29udGFpbmVyRWwpO1xuXG4gICAgcmV0dXJuICgpID0+IHtcbiAgICAgIHJlc2l6ZU9ic2VydmVyLmRpc2Nvbm5lY3QoKTtcbiAgICB9O1xuICB9LCBbdXBkYXRlT3ZlcmZsb3dTdGF0ZV0pO1xuXG4gIGNvbnN0IGhhbmRsZVNjcm9sbFBvc2l0aW9uQ2hhbmdlID0gdXNlQ2FsbGJhY2soKHsgeCB9OiBQb3NpdGlvbikgPT4ge1xuICAgIGlmIChpc092ZXJmbG93UmVmLmN1cnJlbnQpIHtcbiAgICAgIHNldFJvb3RDbGFzc05hbWUoY2xzeCh7XG4gICAgICAgIFwic2hhZG93LWxlZnRcIjogeCA+IDAsXG4gICAgICAgIFwic2hhZG93LXJpZ2h0XCI6IHggPCBvdmVyZmxvd1dpZHRoUmVmLmN1cnJlbnRcbiAgICAgIH0pKTtcbiAgICB9XG4gIH0sIFtdKTtcblxuICByZXR1cm4gKFxuICAgIDxTY3JvbGxBcmVhXG4gICAgICBjbGFzc05hbWU9e3Jvb3RDbGFzc05hbWV9XG4gICAgICBjc3M9e3RhYnNXcmFwcGVyU3R5bGV9XG4gICAgICBzY3JvbGxiYXJQYWRkaW5nPXsxfVxuICAgICAgc2Nyb2xsYmFyU2l6ZT17NX1cbiAgICAgIHR5cGU9XCJzY3JvbGxcIlxuICAgICAgdmlld3BvcnRSZWY9e3RhYnNDb250YWluZXJSZWZ9XG4gICAgICBvblNjcm9sbFBvc2l0aW9uQ2hhbmdlPXtoYW5kbGVTY3JvbGxQb3NpdGlvbkNoYW5nZX1cbiAgICA+XG4gICAgICA8VGFiTGlzdCAvPlxuICAgIDwvU2Nyb2xsQXJlYT5cbiAgKTtcbn1cbiJdfQ== */");
35
+ function TabsContainer() {
36
+ const tabsContainerRef = useRef(null);
37
+ const isOverflowRef = useRef(false);
38
+ const overflowWidthRef = useRef(0);
39
+ const [rootClassName, setRootClassName] = useState();
40
+ const updateOverflowState = useCallback(() => {
41
+ if (tabsContainerRef.current) {
42
+ const containerEl = tabsContainerRef.current;
43
+ overflowWidthRef.current = containerEl.scrollWidth - containerEl.clientWidth;
44
+ isOverflowRef.current = overflowWidthRef.current > 0;
45
+ const {
46
+ scrollLeft
47
+ } = containerEl;
48
+ setRootClassName(clsx({
49
+ "shadow-left": scrollLeft > 0,
50
+ "shadow-right": scrollLeft < overflowWidthRef.current
51
+ }));
52
+ }
53
+ }, []);
54
+ useIsomorphicEffect(() => {
55
+ const containerEl = tabsContainerRef.current;
56
+ if (!containerEl) {
57
+ return;
58
+ }
59
+ updateOverflowState();
60
+ const resizeObserver = new ResizeObserver(() => {
61
+ updateOverflowState();
62
+ });
63
+ resizeObserver.observe(containerEl);
64
+ return () => {
65
+ resizeObserver.disconnect();
66
+ };
67
+ }, [updateOverflowState]);
68
+ const handleScrollPositionChange = useCallback(({
69
+ x
70
+ }) => {
71
+ if (isOverflowRef.current) {
72
+ setRootClassName(clsx({
73
+ "shadow-left": x > 0,
74
+ "shadow-right": x < overflowWidthRef.current
75
+ }));
76
+ }
77
+ }, []);
78
+ return /* @__PURE__ */ jsx(ScrollArea, { className: rootClassName, css: tabsWrapperStyle, scrollbarPadding: 1, scrollbarSize: 5, type: "scroll", viewportRef: tabsContainerRef, onScrollPositionChange: handleScrollPositionChange, children: /* @__PURE__ */ jsx(TabList, {}) });
79
+ }
80
+
81
+ export { TabsContainer };
@@ -0,0 +1,45 @@
1
+ /*! @vef-framework/starter v2.0.0 made with ❤️ by Venus | 2025-11-25T10:06:38.668Z */
2
+ import { jsx } from '@emotion/react/jsx-runtime';
3
+ import { css } from '@emotion/react';
4
+ import { globalCssVars, Center, Icon, Segmented } from '@vef-framework/components';
5
+ import { SunIcon, MoonIcon, SunMoon } from 'lucide-react';
6
+ import { useRef } from 'react';
7
+ import '../../../../stores/index.js';
8
+ import '../../hooks/index.js';
9
+ import { useThemeStore } from '../../../../stores/theme.js';
10
+ import { useColorSchemeUpdater } from '../../hooks/use-color-scheme-updater.js';
11
+
12
+ const itemStyle = /* @__PURE__ */ css({
13
+ height: `calc(${globalCssVars.controlHeight} - var(--vef-segmented-track-padding) * 2)`,
14
+ width: "64px"
15
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RoZW1lLWNvbmZpZy9jb2xvci1zY2hlbWUtc3dpdGNoZXIudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVlrQiIsImZpbGUiOiIvVXNlcnMvdmVudXMvVkVGL3ZlZi1mcmFtZXdvcmstcmVhY3QvcGFja2FnZXMvc3RhcnRlci9zcmMvY29tcG9uZW50cy9sYXlvdXQvY29tcG9uZW50cy90aGVtZS1jb25maWcvY29sb3Itc2NoZW1lLXN3aXRjaGVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgUG9zaXRpb24sIFNlZ21lbnRlZE9wdGlvbiB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9jb21wb25lbnRzXCI7XG5cbmltcG9ydCB0eXBlIHsgQ29sb3JTY2hlbWUgfSBmcm9tIFwiLi4vLi4vLi4vLi4vc3RvcmVzXCI7XG5cbmltcG9ydCB7IGNzcyB9IGZyb20gXCJAZW1vdGlvbi9yZWFjdFwiO1xuaW1wb3J0IHsgQ2VudGVyLCBnbG9iYWxDc3NWYXJzLCBJY29uLCBTZWdtZW50ZWQgfSBmcm9tIFwiQHZlZi1mcmFtZXdvcmsvY29tcG9uZW50c1wiO1xuaW1wb3J0IHsgTW9vbkljb24sIFN1bkljb24sIFN1bk1vb24gfSBmcm9tIFwibHVjaWRlLXJlYWN0XCI7XG5pbXBvcnQgeyB1c2VSZWYgfSBmcm9tIFwicmVhY3RcIjtcblxuaW1wb3J0IHsgdXNlVGhlbWVTdG9yZSB9IGZyb20gXCIuLi8uLi8uLi8uLi9zdG9yZXNcIjtcbmltcG9ydCB7IHVzZUNvbG9yU2NoZW1lVXBkYXRlciB9IGZyb20gXCIuLi8uLi9ob29rc1wiO1xuXG5jb25zdCBpdGVtU3R5bGUgPSBjc3Moe1xuICBoZWlnaHQ6IGBjYWxjKCR7Z2xvYmFsQ3NzVmFycy5jb250cm9sSGVpZ2h0fSAtIHZhcigtLXZlZi1zZWdtZW50ZWQtdHJhY2stcGFkZGluZykgKiAyKWAsXG4gIHdpZHRoOiBcIjY0cHhcIlxufSk7XG5cbmNvbnN0IG9wdGlvbnM6IFNlZ21lbnRlZE9wdGlvbltdID0gW1xuICB7XG4gICAgbGFiZWw6IChcbiAgICAgIDxDZW50ZXIgY3NzPXtpdGVtU3R5bGV9PlxuICAgICAgICA8SWNvbiBjb21wb25lbnQ9e1N1bkljb259IC8+XG4gICAgICA8L0NlbnRlcj5cbiAgICApLFxuICAgIHZhbHVlOiBcImxpZ2h0XCJcbiAgfSxcbiAge1xuICAgIGxhYmVsOiAoXG4gICAgICA8Q2VudGVyIGNzcz17aXRlbVN0eWxlfT5cbiAgICAgICAgPEljb24gY29tcG9uZW50PXtNb29uSWNvbn0gLz5cbiAgICAgIDwvQ2VudGVyPlxuICAgICksXG4gICAgdmFsdWU6IFwiZGFya1wiXG4gIH0sXG4gIHtcbiAgICBsYWJlbDogKFxuICAgICAgPENlbnRlciBjc3M9e2l0ZW1TdHlsZX0+XG4gICAgICAgIDxJY29uIGNvbXBvbmVudD17U3VuTW9vbn0gLz5cbiAgICAgIDwvQ2VudGVyPlxuICAgICksXG4gICAgdmFsdWU6IFwic3lzdGVtXCJcbiAgfVxuXTtcblxuZXhwb3J0IGZ1bmN0aW9uIENvbG9yU2NoZW1lU3dpdGNoZXIoKSB7XG4gIGNvbnN0IGNvbG9yU2NoZW1lID0gdXNlVGhlbWVTdG9yZShzdGF0ZSA9PiBzdGF0ZS5jb2xvclNjaGVtZSk7XG4gIGNvbnN0IHsgdXBkYXRlQ29sb3JTY2hlbWUgfSA9IHVzZUNvbG9yU2NoZW1lVXBkYXRlcigpO1xuICBjb25zdCBwb3NpdGlvblJlZiA9IHVzZVJlZjxQb3NpdGlvbj4oe1xuICAgIHg6IHdpbmRvdy5pbm5lcldpZHRoIC8gMixcbiAgICB5OiB3aW5kb3cuaW5uZXJIZWlnaHQgLyAyXG4gIH0pO1xuXG4gIHJldHVybiAoXG4gICAgPFNlZ21lbnRlZFxuICAgICAgb3B0aW9ucz17b3B0aW9uc31cbiAgICAgIHZhbHVlPXtjb2xvclNjaGVtZX1cbiAgICAgIG9uQ2hhbmdlPXt2YWx1ZSA9PiB7XG4gICAgICAgIHVwZGF0ZUNvbG9yU2NoZW1lKHZhbHVlIGFzIENvbG9yU2NoZW1lLCBwb3NpdGlvblJlZi5jdXJyZW50KTtcbiAgICAgIH19XG4gICAgICBvbkNsaWNrPXtldmVudCA9PiB7XG4gICAgICAgIHBvc2l0aW9uUmVmLmN1cnJlbnQgPSB7XG4gICAgICAgICAgeDogZXZlbnQuY2xpZW50WCxcbiAgICAgICAgICB5OiBldmVudC5jbGllbnRZXG4gICAgICAgIH07XG4gICAgICB9fVxuICAgIC8+XG4gICk7XG59XG4iXX0= */");
16
+ const options = [{
17
+ label: /* @__PURE__ */ jsx(Center, { css: itemStyle, children: /* @__PURE__ */ jsx(Icon, { component: SunIcon }) }),
18
+ value: "light"
19
+ }, {
20
+ label: /* @__PURE__ */ jsx(Center, { css: itemStyle, children: /* @__PURE__ */ jsx(Icon, { component: MoonIcon }) }),
21
+ value: "dark"
22
+ }, {
23
+ label: /* @__PURE__ */ jsx(Center, { css: itemStyle, children: /* @__PURE__ */ jsx(Icon, { component: SunMoon }) }),
24
+ value: "system"
25
+ }];
26
+ function ColorSchemeSwitcher() {
27
+ const colorScheme = useThemeStore((state) => state.colorScheme);
28
+ const {
29
+ updateColorScheme
30
+ } = useColorSchemeUpdater();
31
+ const positionRef = useRef({
32
+ x: window.innerWidth / 2,
33
+ y: window.innerHeight / 2
34
+ });
35
+ return /* @__PURE__ */ jsx(Segmented, { options, value: colorScheme, onChange: (value) => {
36
+ updateColorScheme(value, positionRef.current);
37
+ }, onClick: (event) => {
38
+ positionRef.current = {
39
+ x: event.clientX,
40
+ y: event.clientY
41
+ };
42
+ } });
43
+ }
44
+
45
+ export { ColorSchemeSwitcher };
@@ -0,0 +1,53 @@
1
+ /*! @vef-framework/starter v2.0.0 made with ❤️ by Venus | 2025-11-25T10:06:38.668Z */
2
+ import { jsxs, jsx } from '@emotion/react/jsx-runtime';
3
+ import { css } from '@emotion/react';
4
+ import { globalCssVars, Center, Switch } from '@vef-framework/components';
5
+ import { useShallow } from '@vef-framework/core';
6
+ import '../../../../stores/index.js';
7
+ import { ColorSchemeSwitcher } from './color-scheme-switcher.js';
8
+ import { ConfigItem } from './config-item.js';
9
+ import { useThemeStore } from '../../../../stores/theme.js';
10
+
11
+ const wrapperStyle = /* @__PURE__ */ css({
12
+ display: "flex",
13
+ flexDirection: "column",
14
+ gap: globalCssVars.spacingMd
15
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RoZW1lLWNvbmZpZy9jb2xvci1zY2hlbWUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVFxQiIsImZpbGUiOiIvVXNlcnMvdmVudXMvVkVGL3ZlZi1mcmFtZXdvcmstcmVhY3QvcGFja2FnZXMvc3RhcnRlci9zcmMvY29tcG9uZW50cy9sYXlvdXQvY29tcG9uZW50cy90aGVtZS1jb25maWcvY29sb3Itc2NoZW1lLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gXCJAZW1vdGlvbi9yZWFjdFwiO1xuaW1wb3J0IHsgQ2VudGVyLCBnbG9iYWxDc3NWYXJzLCBTd2l0Y2ggfSBmcm9tIFwiQHZlZi1mcmFtZXdvcmsvY29tcG9uZW50c1wiO1xuaW1wb3J0IHsgdXNlU2hhbGxvdyB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9jb3JlXCI7XG5cbmltcG9ydCB7IHVzZVRoZW1lU3RvcmUgfSBmcm9tIFwiLi4vLi4vLi4vLi4vc3RvcmVzXCI7XG5pbXBvcnQgeyBDb2xvclNjaGVtZVN3aXRjaGVyIH0gZnJvbSBcIi4vY29sb3Itc2NoZW1lLXN3aXRjaGVyXCI7XG5pbXBvcnQgeyBDb25maWdJdGVtIH0gZnJvbSBcIi4vY29uZmlnLWl0ZW1cIjtcblxuY29uc3Qgd3JhcHBlclN0eWxlID0gY3NzKHtcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGZsZXhEaXJlY3Rpb246IFwiY29sdW1uXCIsXG4gIGdhcDogZ2xvYmFsQ3NzVmFycy5zcGFjaW5nTWRcbn0pO1xuXG5leHBvcnQgZnVuY3Rpb24gQ29sb3JTY2hlbWUoKSB7XG4gIGNvbnN0IHtcbiAgICBpc0dyYXlzY2FsZU1vZGUsXG4gICAgaXNDb2xvckJsaW5kTW9kZSxcbiAgICBpc01lbnVBY2NvcmRpb25Nb2RlXG4gIH0gPSB1c2VUaGVtZVN0b3JlKFxuICAgIHVzZVNoYWxsb3coXG4gICAgICBzdGF0ZSA9PiB7XG4gICAgICAgIGNvbnN0IHtcbiAgICAgICAgICBpc0dyYXlzY2FsZU1vZGUsXG4gICAgICAgICAgaXNDb2xvckJsaW5kTW9kZSxcbiAgICAgICAgICBpc01lbnVBY2NvcmRpb25Nb2RlXG4gICAgICAgIH0gPSBzdGF0ZTtcblxuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgIGlzR3JheXNjYWxlTW9kZSxcbiAgICAgICAgICBpc0NvbG9yQmxpbmRNb2RlLFxuICAgICAgICAgIGlzTWVudUFjY29yZGlvbk1vZGVcbiAgICAgICAgfTtcbiAgICAgIH1cbiAgICApXG4gICk7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNzcz17d3JhcHBlclN0eWxlfT5cbiAgICAgIDxDZW50ZXI+XG4gICAgICAgIDxDb2xvclNjaGVtZVN3aXRjaGVyIC8+XG4gICAgICA8L0NlbnRlcj5cblxuICAgICAgPENvbmZpZ0l0ZW0gbGFiZWw9XCLngbDluqbmqKHlvI9cIj5cbiAgICAgICAgPFN3aXRjaFxuICAgICAgICAgIGNoZWNrZWQ9e2lzR3JheXNjYWxlTW9kZX1cbiAgICAgICAgICBvbkNoYW5nZT17XG4gICAgICAgICAgICB2YWx1ZSA9PiB7XG4gICAgICAgICAgICAgIHVzZVRoZW1lU3RvcmUuc2V0U3RhdGUoc3RhdGUgPT4ge1xuICAgICAgICAgICAgICAgIHN0YXRlLmlzR3JheXNjYWxlTW9kZSA9IHZhbHVlO1xuICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9XG4gICAgICAgIC8+XG4gICAgICA8L0NvbmZpZ0l0ZW0+XG5cbiAgICAgIDxDb25maWdJdGVtIGxhYmVsPVwi6Imy5byx5qih5byPXCI+XG4gICAgICAgIDxTd2l0Y2hcbiAgICAgICAgICBjaGVja2VkPXtpc0NvbG9yQmxpbmRNb2RlfVxuICAgICAgICAgIG9uQ2hhbmdlPXtcbiAgICAgICAgICAgIHZhbHVlID0+IHtcbiAgICAgICAgICAgICAgdXNlVGhlbWVTdG9yZS5zZXRTdGF0ZShzdGF0ZSA9PiB7XG4gICAgICAgICAgICAgICAgc3RhdGUuaXNDb2xvckJsaW5kTW9kZSA9IHZhbHVlO1xuICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9XG4gICAgICAgIC8+XG4gICAgICA8L0NvbmZpZ0l0ZW0+XG5cbiAgICAgIDxDb25maWdJdGVtIGxhYmVsPVwi6I+c5Y2V5omL6aOO55C05qih5byPXCI+XG4gICAgICAgIDxTd2l0Y2hcbiAgICAgICAgICBjaGVja2VkPXtpc01lbnVBY2NvcmRpb25Nb2RlfVxuICAgICAgICAgIG9uQ2hhbmdlPXtcbiAgICAgICAgICAgIHZhbHVlID0+IHtcbiAgICAgICAgICAgICAgdXNlVGhlbWVTdG9yZS5zZXRTdGF0ZShzdGF0ZSA9PiB7XG4gICAgICAgICAgICAgICAgc3RhdGUuaXNNZW51QWNjb3JkaW9uTW9kZSA9IHZhbHVlO1xuICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9XG4gICAgICAgIC8+XG4gICAgICA8L0NvbmZpZ0l0ZW0+XG4gICAgPC9kaXY+XG4gICk7XG59XG4iXX0= */");
16
+ function ColorScheme() {
17
+ const {
18
+ isGrayscaleMode,
19
+ isColorBlindMode,
20
+ isMenuAccordionMode
21
+ } = useThemeStore(useShallow((state) => {
22
+ const {
23
+ isGrayscaleMode: isGrayscaleMode2,
24
+ isColorBlindMode: isColorBlindMode2,
25
+ isMenuAccordionMode: isMenuAccordionMode2
26
+ } = state;
27
+ return {
28
+ isGrayscaleMode: isGrayscaleMode2,
29
+ isColorBlindMode: isColorBlindMode2,
30
+ isMenuAccordionMode: isMenuAccordionMode2
31
+ };
32
+ }));
33
+ return /* @__PURE__ */ jsxs("div", { css: wrapperStyle, children: [
34
+ /* @__PURE__ */ jsx(Center, { children: /* @__PURE__ */ jsx(ColorSchemeSwitcher, {}) }),
35
+ /* @__PURE__ */ jsx(ConfigItem, { label: "灰度模式", children: /* @__PURE__ */ jsx(Switch, { checked: isGrayscaleMode, onChange: (value) => {
36
+ useThemeStore.setState((state) => {
37
+ state.isGrayscaleMode = value;
38
+ });
39
+ } }) }),
40
+ /* @__PURE__ */ jsx(ConfigItem, { label: "色弱模式", children: /* @__PURE__ */ jsx(Switch, { checked: isColorBlindMode, onChange: (value) => {
41
+ useThemeStore.setState((state) => {
42
+ state.isColorBlindMode = value;
43
+ });
44
+ } }) }),
45
+ /* @__PURE__ */ jsx(ConfigItem, { label: "菜单手风琴模式", children: /* @__PURE__ */ jsx(Switch, { checked: isMenuAccordionMode, onChange: (value) => {
46
+ useThemeStore.setState((state) => {
47
+ state.isMenuAccordionMode = value;
48
+ });
49
+ } }) })
50
+ ] });
51
+ }
52
+
53
+ export { ColorScheme };
@@ -0,0 +1,23 @@
1
+ /*! @vef-framework/starter v2.0.0 made with ❤️ by Venus | 2025-11-25T10:06:38.668Z */
2
+ import { jsxs, jsx } from '@emotion/react/jsx-runtime';
3
+ import { css } from '@emotion/react';
4
+ import { globalCssVars } from '@vef-framework/components';
5
+
6
+ const itemStyle = /* @__PURE__ */ css({
7
+ display: "flex",
8
+ alignItems: "center",
9
+ justifyContent: "space-between",
10
+ columnGap: globalCssVars.spacingXs
11
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RoZW1lLWNvbmZpZy9jb25maWctaXRlbS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBVWtCIiwiZmlsZSI6Ii9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RoZW1lLWNvbmZpZy9jb25maWctaXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFByb3BzV2l0aENoaWxkcmVuLCBSZWFjdE5vZGUgfSBmcm9tIFwicmVhY3RcIjtcblxuaW1wb3J0IHsgY3NzIH0gZnJvbSBcIkBlbW90aW9uL3JlYWN0XCI7XG5pbXBvcnQgeyBnbG9iYWxDc3NWYXJzIH0gZnJvbSBcIkB2ZWYtZnJhbWV3b3JrL2NvbXBvbmVudHNcIjtcblxuaW50ZXJmYWNlIENvbmZpZ0l0ZW1Qcm9wcyBleHRlbmRzIFByb3BzV2l0aENoaWxkcmVuIHtcbiAgY2xhc3NOYW1lPzogc3RyaW5nO1xuICBsYWJlbDogUmVhY3ROb2RlO1xufVxuXG5jb25zdCBpdGVtU3R5bGUgPSBjc3Moe1xuICBkaXNwbGF5OiBcImZsZXhcIixcbiAgYWxpZ25JdGVtczogXCJjZW50ZXJcIixcbiAganVzdGlmeUNvbnRlbnQ6IFwic3BhY2UtYmV0d2VlblwiLFxuICBjb2x1bW5HYXA6IGdsb2JhbENzc1ZhcnMuc3BhY2luZ1hzXG59KTtcblxuZXhwb3J0IGZ1bmN0aW9uIENvbmZpZ0l0ZW0oe1xuICBjbGFzc05hbWUsXG4gIGxhYmVsLFxuICBjaGlsZHJlblxufTogQ29uZmlnSXRlbVByb3BzKSB7XG4gIHJldHVybiAoXG4gICAgPGRpdiBjbGFzc05hbWU9e2NsYXNzTmFtZX0gY3NzPXtpdGVtU3R5bGV9PlxuICAgICAgPHNwYW4+XG4gICAgICAgIHtsYWJlbH1cbiAgICAgIDwvc3Bhbj5cblxuICAgICAge2NoaWxkcmVufVxuICAgIDwvZGl2PlxuICApO1xufVxuIl19 */");
12
+ function ConfigItem({
13
+ className,
14
+ label,
15
+ children
16
+ }) {
17
+ return /* @__PURE__ */ jsxs("div", { className, css: itemStyle, children: [
18
+ /* @__PURE__ */ jsx("span", { children: label }),
19
+ children
20
+ ] });
21
+ }
22
+
23
+ export { ConfigItem };
@@ -0,0 +1,55 @@
1
+ /*! @vef-framework/starter v2.0.0 made with ❤️ by Venus | 2025-11-25T10:06:38.668Z */
2
+ import { jsx, jsxs } from '@emotion/react/jsx-runtime';
3
+ import { css, ClassNames } from '@emotion/react';
4
+ import { globalCssVars, Drawer, ScrollArea, Divider } from '@vef-framework/components';
5
+ import '../../../../stores/index.js';
6
+ import { ColorScheme } from './color-scheme.js';
7
+ import { MenuLayout } from './menu-layout.js';
8
+ import { Operations } from './operations.js';
9
+ import { ThemeColors } from './theme-colors.js';
10
+ import { useThemeStore } from '../../../../stores/theme.js';
11
+
12
+ function _EMOTION_STRINGIFIED_CSS_ERROR__() {
13
+ return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
14
+ }
15
+ const drawerBodyStyle = process.env.NODE_ENV === "production" ? {
16
+ name: "1hcx8jb",
17
+ styles: "padding:0"
18
+ } : {
19
+ name: "1hcx8jb",
20
+ styles: "padding:0/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RoZW1lLWNvbmZpZy9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBU3dCIiwiZmlsZSI6Ii9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RoZW1lLWNvbmZpZy9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDbGFzc05hbWVzLCBjc3MgfSBmcm9tIFwiQGVtb3Rpb24vcmVhY3RcIjtcbmltcG9ydCB7IERpdmlkZXIsIERyYXdlciwgZ2xvYmFsQ3NzVmFycywgU2Nyb2xsQXJlYSB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9jb21wb25lbnRzXCI7XG5cbmltcG9ydCB7IHVzZVRoZW1lU3RvcmUgfSBmcm9tIFwiLi4vLi4vLi4vLi4vc3RvcmVzXCI7XG5pbXBvcnQgeyBDb2xvclNjaGVtZSB9IGZyb20gXCIuL2NvbG9yLXNjaGVtZVwiO1xuaW1wb3J0IHsgTWVudUxheW91dCB9IGZyb20gXCIuL21lbnUtbGF5b3V0XCI7XG5pbXBvcnQgeyBPcGVyYXRpb25zIH0gZnJvbSBcIi4vb3BlcmF0aW9uc1wiO1xuaW1wb3J0IHsgVGhlbWVDb2xvcnMgfSBmcm9tIFwiLi90aGVtZS1jb2xvcnNcIjtcblxuY29uc3QgZHJhd2VyQm9keVN0eWxlID0gY3NzKHtcbiAgcGFkZGluZzogMFxufSk7XG5jb25zdCBjb250ZW50U3R5bGUgPSBjc3Moe1xuICBoZWlnaHQ6IFwiMTAwJVwiLFxuICBwYWRkaW5nSW5saW5lOiBnbG9iYWxDc3NWYXJzLnNwYWNpbmdTbSxcbiAgcGFkZGluZ0Jsb2NrU3RhcnQ6IGdsb2JhbENzc1ZhcnMuc3BhY2luZ1hzLFxuICBwYWRkaW5nQmxvY2tFbmQ6IGdsb2JhbENzc1ZhcnMuc3BhY2luZ0xnXG59KTtcblxuY29uc3QgY29udGFpbmVyU3R5bGUgPSBjc3Moe1xuICBwYWRkaW5nSW5saW5lOiBnbG9iYWxDc3NWYXJzLnNwYWNpbmdYc1xufSk7XG5cbmV4cG9ydCBmdW5jdGlvbiBUaGVtZUNvbmZpZygpIHtcbiAgY29uc3QgaXNUaGVtZUNvbmZpZ1Zpc2libGUgPSB1c2VUaGVtZVN0b3JlKHN0YXRlID0+IHN0YXRlLmlzVGhlbWVDb25maWdWaXNpYmxlKTtcblxuICBjb25zdCBoYW5kbGVDbG9zZSA9ICgpID0+IHtcbiAgICB1c2VUaGVtZVN0b3JlLnNldFN0YXRlKHN0YXRlID0+IHtcbiAgICAgIHN0YXRlLmlzVGhlbWVDb25maWdWaXNpYmxlID0gZmFsc2U7XG4gICAgfSk7XG4gIH07XG5cbiAgcmV0dXJuIChcbiAgICA8Q2xhc3NOYW1lcz5cbiAgICAgIHsoeyBjc3MgfSkgPT4gKFxuICAgICAgICA8RHJhd2VyXG4gICAgICAgICAgY2xvc2FibGU9e3sgcGxhY2VtZW50OiBcImVuZFwiIH19XG4gICAgICAgICAgb3Blbj17aXNUaGVtZUNvbmZpZ1Zpc2libGV9XG4gICAgICAgICAgdGl0bGU9XCLkuLvpopjphY3nva5cIlxuICAgICAgICAgIGNsYXNzTmFtZXM9e3tcbiAgICAgICAgICAgIGJvZHk6IGNzcyhkcmF3ZXJCb2R5U3R5bGUpXG4gICAgICAgICAgfX1cbiAgICAgICAgICBmb290ZXI9e1xuICAgICAgICAgICAgPE9wZXJhdGlvbnMgLz5cbiAgICAgICAgICB9XG4gICAgICAgICAgb25DbG9zZT17aGFuZGxlQ2xvc2V9XG4gICAgICAgID5cbiAgICAgICAgICA8U2Nyb2xsQXJlYVxuICAgICAgICAgICAgY2xhc3NOYW1lPXtjc3MoY29udGVudFN0eWxlKX1cbiAgICAgICAgICAgIHZpZXdwb3J0Q2xhc3NOYW1lPXtjc3MoY29udGFpbmVyU3R5bGUpfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIDxEaXZpZGVyPuS4u+mimOaooeW8jzwvRGl2aWRlcj5cbiAgICAgICAgICAgIDxDb2xvclNjaGVtZSAvPlxuICAgICAgICAgICAgPERpdmlkZXI+6I+c5Y2V5biD5bGAPC9EaXZpZGVyPlxuICAgICAgICAgICAgPE1lbnVMYXlvdXQgLz5cbiAgICAgICAgICAgIDxEaXZpZGVyPuS4u+mimOminOiJsjwvRGl2aWRlcj5cbiAgICAgICAgICAgIDxUaGVtZUNvbG9ycyAvPlxuICAgICAgICAgIDwvU2Nyb2xsQXJlYT5cbiAgICAgICAgPC9EcmF3ZXI+XG4gICAgICApfVxuICAgIDwvQ2xhc3NOYW1lcz5cbiAgKTtcbn1cbiJdfQ== */",
21
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
22
+ };
23
+ const contentStyle = /* @__PURE__ */ css({
24
+ height: "100%",
25
+ paddingInline: globalCssVars.spacingSm,
26
+ paddingBlockStart: globalCssVars.spacingXs,
27
+ paddingBlockEnd: globalCssVars.spacingLg
28
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RoZW1lLWNvbmZpZy9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBWXFCIiwiZmlsZSI6Ii9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RoZW1lLWNvbmZpZy9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDbGFzc05hbWVzLCBjc3MgfSBmcm9tIFwiQGVtb3Rpb24vcmVhY3RcIjtcbmltcG9ydCB7IERpdmlkZXIsIERyYXdlciwgZ2xvYmFsQ3NzVmFycywgU2Nyb2xsQXJlYSB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9jb21wb25lbnRzXCI7XG5cbmltcG9ydCB7IHVzZVRoZW1lU3RvcmUgfSBmcm9tIFwiLi4vLi4vLi4vLi4vc3RvcmVzXCI7XG5pbXBvcnQgeyBDb2xvclNjaGVtZSB9IGZyb20gXCIuL2NvbG9yLXNjaGVtZVwiO1xuaW1wb3J0IHsgTWVudUxheW91dCB9IGZyb20gXCIuL21lbnUtbGF5b3V0XCI7XG5pbXBvcnQgeyBPcGVyYXRpb25zIH0gZnJvbSBcIi4vb3BlcmF0aW9uc1wiO1xuaW1wb3J0IHsgVGhlbWVDb2xvcnMgfSBmcm9tIFwiLi90aGVtZS1jb2xvcnNcIjtcblxuY29uc3QgZHJhd2VyQm9keVN0eWxlID0gY3NzKHtcbiAgcGFkZGluZzogMFxufSk7XG5jb25zdCBjb250ZW50U3R5bGUgPSBjc3Moe1xuICBoZWlnaHQ6IFwiMTAwJVwiLFxuICBwYWRkaW5nSW5saW5lOiBnbG9iYWxDc3NWYXJzLnNwYWNpbmdTbSxcbiAgcGFkZGluZ0Jsb2NrU3RhcnQ6IGdsb2JhbENzc1ZhcnMuc3BhY2luZ1hzLFxuICBwYWRkaW5nQmxvY2tFbmQ6IGdsb2JhbENzc1ZhcnMuc3BhY2luZ0xnXG59KTtcblxuY29uc3QgY29udGFpbmVyU3R5bGUgPSBjc3Moe1xuICBwYWRkaW5nSW5saW5lOiBnbG9iYWxDc3NWYXJzLnNwYWNpbmdYc1xufSk7XG5cbmV4cG9ydCBmdW5jdGlvbiBUaGVtZUNvbmZpZygpIHtcbiAgY29uc3QgaXNUaGVtZUNvbmZpZ1Zpc2libGUgPSB1c2VUaGVtZVN0b3JlKHN0YXRlID0+IHN0YXRlLmlzVGhlbWVDb25maWdWaXNpYmxlKTtcblxuICBjb25zdCBoYW5kbGVDbG9zZSA9ICgpID0+IHtcbiAgICB1c2VUaGVtZVN0b3JlLnNldFN0YXRlKHN0YXRlID0+IHtcbiAgICAgIHN0YXRlLmlzVGhlbWVDb25maWdWaXNpYmxlID0gZmFsc2U7XG4gICAgfSk7XG4gIH07XG5cbiAgcmV0dXJuIChcbiAgICA8Q2xhc3NOYW1lcz5cbiAgICAgIHsoeyBjc3MgfSkgPT4gKFxuICAgICAgICA8RHJhd2VyXG4gICAgICAgICAgY2xvc2FibGU9e3sgcGxhY2VtZW50OiBcImVuZFwiIH19XG4gICAgICAgICAgb3Blbj17aXNUaGVtZUNvbmZpZ1Zpc2libGV9XG4gICAgICAgICAgdGl0bGU9XCLkuLvpopjphY3nva5cIlxuICAgICAgICAgIGNsYXNzTmFtZXM9e3tcbiAgICAgICAgICAgIGJvZHk6IGNzcyhkcmF3ZXJCb2R5U3R5bGUpXG4gICAgICAgICAgfX1cbiAgICAgICAgICBmb290ZXI9e1xuICAgICAgICAgICAgPE9wZXJhdGlvbnMgLz5cbiAgICAgICAgICB9XG4gICAgICAgICAgb25DbG9zZT17aGFuZGxlQ2xvc2V9XG4gICAgICAgID5cbiAgICAgICAgICA8U2Nyb2xsQXJlYVxuICAgICAgICAgICAgY2xhc3NOYW1lPXtjc3MoY29udGVudFN0eWxlKX1cbiAgICAgICAgICAgIHZpZXdwb3J0Q2xhc3NOYW1lPXtjc3MoY29udGFpbmVyU3R5bGUpfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIDxEaXZpZGVyPuS4u+mimOaooeW8jzwvRGl2aWRlcj5cbiAgICAgICAgICAgIDxDb2xvclNjaGVtZSAvPlxuICAgICAgICAgICAgPERpdmlkZXI+6I+c5Y2V5biD5bGAPC9EaXZpZGVyPlxuICAgICAgICAgICAgPE1lbnVMYXlvdXQgLz5cbiAgICAgICAgICAgIDxEaXZpZGVyPuS4u+mimOminOiJsjwvRGl2aWRlcj5cbiAgICAgICAgICAgIDxUaGVtZUNvbG9ycyAvPlxuICAgICAgICAgIDwvU2Nyb2xsQXJlYT5cbiAgICAgICAgPC9EcmF3ZXI+XG4gICAgICApfVxuICAgIDwvQ2xhc3NOYW1lcz5cbiAgKTtcbn1cbiJdfQ== */");
29
+ const containerStyle = /* @__PURE__ */ css({
30
+ paddingInline: globalCssVars.spacingXs
31
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RoZW1lLWNvbmZpZy9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBbUJ1QiIsImZpbGUiOiIvVXNlcnMvdmVudXMvVkVGL3ZlZi1mcmFtZXdvcmstcmVhY3QvcGFja2FnZXMvc3RhcnRlci9zcmMvY29tcG9uZW50cy9sYXlvdXQvY29tcG9uZW50cy90aGVtZS1jb25maWcvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2xhc3NOYW1lcywgY3NzIH0gZnJvbSBcIkBlbW90aW9uL3JlYWN0XCI7XG5pbXBvcnQgeyBEaXZpZGVyLCBEcmF3ZXIsIGdsb2JhbENzc1ZhcnMsIFNjcm9sbEFyZWEgfSBmcm9tIFwiQHZlZi1mcmFtZXdvcmsvY29tcG9uZW50c1wiO1xuXG5pbXBvcnQgeyB1c2VUaGVtZVN0b3JlIH0gZnJvbSBcIi4uLy4uLy4uLy4uL3N0b3Jlc1wiO1xuaW1wb3J0IHsgQ29sb3JTY2hlbWUgfSBmcm9tIFwiLi9jb2xvci1zY2hlbWVcIjtcbmltcG9ydCB7IE1lbnVMYXlvdXQgfSBmcm9tIFwiLi9tZW51LWxheW91dFwiO1xuaW1wb3J0IHsgT3BlcmF0aW9ucyB9IGZyb20gXCIuL29wZXJhdGlvbnNcIjtcbmltcG9ydCB7IFRoZW1lQ29sb3JzIH0gZnJvbSBcIi4vdGhlbWUtY29sb3JzXCI7XG5cbmNvbnN0IGRyYXdlckJvZHlTdHlsZSA9IGNzcyh7XG4gIHBhZGRpbmc6IDBcbn0pO1xuY29uc3QgY29udGVudFN0eWxlID0gY3NzKHtcbiAgaGVpZ2h0OiBcIjEwMCVcIixcbiAgcGFkZGluZ0lubGluZTogZ2xvYmFsQ3NzVmFycy5zcGFjaW5nU20sXG4gIHBhZGRpbmdCbG9ja1N0YXJ0OiBnbG9iYWxDc3NWYXJzLnNwYWNpbmdYcyxcbiAgcGFkZGluZ0Jsb2NrRW5kOiBnbG9iYWxDc3NWYXJzLnNwYWNpbmdMZ1xufSk7XG5cbmNvbnN0IGNvbnRhaW5lclN0eWxlID0gY3NzKHtcbiAgcGFkZGluZ0lubGluZTogZ2xvYmFsQ3NzVmFycy5zcGFjaW5nWHNcbn0pO1xuXG5leHBvcnQgZnVuY3Rpb24gVGhlbWVDb25maWcoKSB7XG4gIGNvbnN0IGlzVGhlbWVDb25maWdWaXNpYmxlID0gdXNlVGhlbWVTdG9yZShzdGF0ZSA9PiBzdGF0ZS5pc1RoZW1lQ29uZmlnVmlzaWJsZSk7XG5cbiAgY29uc3QgaGFuZGxlQ2xvc2UgPSAoKSA9PiB7XG4gICAgdXNlVGhlbWVTdG9yZS5zZXRTdGF0ZShzdGF0ZSA9PiB7XG4gICAgICBzdGF0ZS5pc1RoZW1lQ29uZmlnVmlzaWJsZSA9IGZhbHNlO1xuICAgIH0pO1xuICB9O1xuXG4gIHJldHVybiAoXG4gICAgPENsYXNzTmFtZXM+XG4gICAgICB7KHsgY3NzIH0pID0+IChcbiAgICAgICAgPERyYXdlclxuICAgICAgICAgIGNsb3NhYmxlPXt7IHBsYWNlbWVudDogXCJlbmRcIiB9fVxuICAgICAgICAgIG9wZW49e2lzVGhlbWVDb25maWdWaXNpYmxlfVxuICAgICAgICAgIHRpdGxlPVwi5Li76aKY6YWN572uXCJcbiAgICAgICAgICBjbGFzc05hbWVzPXt7XG4gICAgICAgICAgICBib2R5OiBjc3MoZHJhd2VyQm9keVN0eWxlKVxuICAgICAgICAgIH19XG4gICAgICAgICAgZm9vdGVyPXtcbiAgICAgICAgICAgIDxPcGVyYXRpb25zIC8+XG4gICAgICAgICAgfVxuICAgICAgICAgIG9uQ2xvc2U9e2hhbmRsZUNsb3NlfVxuICAgICAgICA+XG4gICAgICAgICAgPFNjcm9sbEFyZWFcbiAgICAgICAgICAgIGNsYXNzTmFtZT17Y3NzKGNvbnRlbnRTdHlsZSl9XG4gICAgICAgICAgICB2aWV3cG9ydENsYXNzTmFtZT17Y3NzKGNvbnRhaW5lclN0eWxlKX1cbiAgICAgICAgICA+XG4gICAgICAgICAgICA8RGl2aWRlcj7kuLvpopjmqKHlvI88L0RpdmlkZXI+XG4gICAgICAgICAgICA8Q29sb3JTY2hlbWUgLz5cbiAgICAgICAgICAgIDxEaXZpZGVyPuiPnOWNleW4g+WxgDwvRGl2aWRlcj5cbiAgICAgICAgICAgIDxNZW51TGF5b3V0IC8+XG4gICAgICAgICAgICA8RGl2aWRlcj7kuLvpopjpopzoibI8L0RpdmlkZXI+XG4gICAgICAgICAgICA8VGhlbWVDb2xvcnMgLz5cbiAgICAgICAgICA8L1Njcm9sbEFyZWE+XG4gICAgICAgIDwvRHJhd2VyPlxuICAgICAgKX1cbiAgICA8L0NsYXNzTmFtZXM+XG4gICk7XG59XG4iXX0= */");
32
+ function ThemeConfig() {
33
+ const isThemeConfigVisible = useThemeStore((state) => state.isThemeConfigVisible);
34
+ const handleClose = () => {
35
+ useThemeStore.setState((state) => {
36
+ state.isThemeConfigVisible = false;
37
+ });
38
+ };
39
+ return /* @__PURE__ */ jsx(ClassNames, { children: ({
40
+ css: css2
41
+ }) => /* @__PURE__ */ jsx(Drawer, { closable: {
42
+ placement: "end"
43
+ }, open: isThemeConfigVisible, title: "主题配置", classNames: {
44
+ body: css2(drawerBodyStyle)
45
+ }, footer: /* @__PURE__ */ jsx(Operations, {}), onClose: handleClose, children: /* @__PURE__ */ jsxs(ScrollArea, { className: css2(contentStyle), viewportClassName: css2(containerStyle), children: [
46
+ /* @__PURE__ */ jsx(Divider, { children: "主题模式" }),
47
+ /* @__PURE__ */ jsx(ColorScheme, {}),
48
+ /* @__PURE__ */ jsx(Divider, { children: "菜单布局" }),
49
+ /* @__PURE__ */ jsx(MenuLayout, {}),
50
+ /* @__PURE__ */ jsx(Divider, { children: "主题颜色" }),
51
+ /* @__PURE__ */ jsx(ThemeColors, {})
52
+ ] }) }) });
53
+ }
54
+
55
+ export { ThemeConfig };
@@ -0,0 +1,71 @@
1
+ /*! @vef-framework/starter v2.0.0 made with ❤️ by Venus | 2025-11-25T10:06:38.668Z */
2
+ import { jsxs, jsx, Fragment } from '@emotion/react/jsx-runtime';
3
+ import { css } from '@emotion/react';
4
+ import { globalCssVars } from '@vef-framework/components';
5
+
6
+ function _EMOTION_STRINGIFIED_CSS_ERROR__() {
7
+ return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
8
+ }
9
+ const cardStyle = /* @__PURE__ */ css({
10
+ cursor: "pointer",
11
+ display: "flex",
12
+ height: "68px",
13
+ width: "96px",
14
+ gap: "6px",
15
+ padding: "6px",
16
+ border: `2px solid transparent`,
17
+ borderRadius: globalCssVars.borderRadius,
18
+ boxShadow: globalCssVars.shadowSm,
19
+ transition: `border-color ${globalCssVars.motionDurationMid} ease`,
20
+ "&:hover": {
21
+ borderColor: globalCssVars.colorPrimary
22
+ },
23
+ "&.selected": {
24
+ borderColor: globalCssVars.colorPrimary
25
+ },
26
+ ".dark &": {
27
+ boxShadow: "0 1px 3px 0 rgb(255 255 255 / 0.3), 0 1px 2px -1px rgb(255 255 255 / 0.3)"
28
+ }
29
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RoZW1lLWNvbmZpZy9tZW51LWxheW91dC1jYXJkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFVa0IiLCJmaWxlIjoiL1VzZXJzL3ZlbnVzL1ZFRi92ZWYtZnJhbWV3b3JrLXJlYWN0L3BhY2thZ2VzL3N0YXJ0ZXIvc3JjL2NvbXBvbmVudHMvbGF5b3V0L2NvbXBvbmVudHMvdGhlbWUtY29uZmlnL21lbnUtbGF5b3V0LWNhcmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBPcmllbnRhdGlvbiB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9jb21wb25lbnRzXCI7XG5pbXBvcnQgdHlwZSB7IENvbXBvbmVudFByb3BzIH0gZnJvbSBcInJlYWN0XCI7XG5cbmltcG9ydCB7IGNzcyB9IGZyb20gXCJAZW1vdGlvbi9yZWFjdFwiO1xuaW1wb3J0IHsgZ2xvYmFsQ3NzVmFycyB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9jb21wb25lbnRzXCI7XG5cbmludGVyZmFjZSBNZW51TGF5b3V0Q2FyZFByb3BzIGV4dGVuZHMgQ29tcG9uZW50UHJvcHM8XCJkaXZcIj4ge1xuICBtb2RlOiBPcmllbnRhdGlvbjtcbn1cblxuY29uc3QgY2FyZFN0eWxlID0gY3NzKHtcbiAgY3Vyc29yOiBcInBvaW50ZXJcIixcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGhlaWdodDogXCI2OHB4XCIsXG4gIHdpZHRoOiBcIjk2cHhcIixcbiAgZ2FwOiBcIjZweFwiLFxuICBwYWRkaW5nOiBcIjZweFwiLFxuICBib3JkZXI6IGAycHggc29saWQgdHJhbnNwYXJlbnRgLFxuICBib3JkZXJSYWRpdXM6IGdsb2JhbENzc1ZhcnMuYm9yZGVyUmFkaXVzLFxuICBib3hTaGFkb3c6IGdsb2JhbENzc1ZhcnMuc2hhZG93U20sXG4gIHRyYW5zaXRpb246IGBib3JkZXItY29sb3IgJHtnbG9iYWxDc3NWYXJzLm1vdGlvbkR1cmF0aW9uTWlkfSBlYXNlYCxcbiAgXCImOmhvdmVyXCI6IHtcbiAgICBib3JkZXJDb2xvcjogZ2xvYmFsQ3NzVmFycy5jb2xvclByaW1hcnlcbiAgfSxcbiAgXCImLnNlbGVjdGVkXCI6IHtcbiAgICBib3JkZXJDb2xvcjogZ2xvYmFsQ3NzVmFycy5jb2xvclByaW1hcnlcbiAgfSxcbiAgXCIuZGFyayAmXCI6IHtcbiAgICBib3hTaGFkb3c6IFwiMCAxcHggM3B4IDAgcmdiKDI1NSAyNTUgMjU1IC8gMC4zKSwgMCAxcHggMnB4IC0xcHggcmdiKDI1NSAyNTUgMjU1IC8gMC4zKVwiXG4gIH1cbn0pO1xuXG5jb25zdCBsYXlvdXRTdHlsZSA9IHtcbiAgaGVhZGVyOiBjc3Moe1xuICAgIGZsZXg6IFwibm9uZVwiLFxuICAgIGhlaWdodDogXCIxNnB4XCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeSxcbiAgICBib3JkZXJSYWRpdXM6IFwiNHB4XCJcbiAgfSksXG4gIG1haW46IGNzcyh7XG4gICAgZmxleDogXCJhdXRvXCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeTIwMCxcbiAgICBib3JkZXJSYWRpdXM6IFwiNHB4XCJcbiAgfSksXG4gIHdyYXBwZXI6IGNzcyh7XG4gICAgZmxleDogXCJhdXRvXCIsXG4gICAgZGlzcGxheTogXCJmbGV4XCIsXG4gICAgZmxleERpcmVjdGlvbjogXCJjb2x1bW5cIixcbiAgICBnYXA6IFwiNnB4XCJcbiAgfSksXG4gIHNpZGViYXI6IGNzcyh7XG4gICAgd2lkdGg6IFwiMThweFwiLFxuICAgIGhlaWdodDogXCIxMDAlXCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeTMwMCxcbiAgICBib3JkZXJSYWRpdXM6IFwiNHB4XCJcbiAgfSlcbn07XG5cbmV4cG9ydCBmdW5jdGlvbiBNZW51TGF5b3V0Q2FyZCh7IG1vZGUsIC4uLnByb3BzIH06IE1lbnVMYXlvdXRDYXJkUHJvcHMpIHtcbiAgY29uc3QgYm9keSA9IChcbiAgICA8ZGl2IGNzcz17bGF5b3V0U3R5bGUud3JhcHBlcn0+XG4gICAgICA8ZGl2IGNzcz17bGF5b3V0U3R5bGUuaGVhZGVyfSAvPlxuICAgICAgPGRpdiBjc3M9e2xheW91dFN0eWxlLm1haW59IC8+XG4gICAgPC9kaXY+XG4gICk7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNzcz17Y2FyZFN0eWxlfSB7Li4ucHJvcHN9PlxuICAgICAge1xuICAgICAgICBtb2RlID09PSBcImhvcml6b250YWxcIlxuICAgICAgICAgID8gYm9keVxuICAgICAgICAgIDogKFxuICAgICAgICAgICAgICA8PlxuICAgICAgICAgICAgICAgIDxkaXYgY3NzPXtsYXlvdXRTdHlsZS5zaWRlYmFyfSAvPlxuICAgICAgICAgICAgICAgIHtib2R5fVxuICAgICAgICAgICAgICA8Lz5cbiAgICAgICAgICAgIClcbiAgICAgIH1cbiAgICA8L2Rpdj5cbiAgKTtcbn1cbiJdfQ== */");
30
+ const layoutStyle = {
31
+ header: /* @__PURE__ */ css({
32
+ flex: "none",
33
+ height: "16px",
34
+ backgroundColor: globalCssVars.colorPrimary,
35
+ borderRadius: "4px"
36
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RoZW1lLWNvbmZpZy9tZW51LWxheW91dC1jYXJkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpQ1UiLCJmaWxlIjoiL1VzZXJzL3ZlbnVzL1ZFRi92ZWYtZnJhbWV3b3JrLXJlYWN0L3BhY2thZ2VzL3N0YXJ0ZXIvc3JjL2NvbXBvbmVudHMvbGF5b3V0L2NvbXBvbmVudHMvdGhlbWUtY29uZmlnL21lbnUtbGF5b3V0LWNhcmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBPcmllbnRhdGlvbiB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9jb21wb25lbnRzXCI7XG5pbXBvcnQgdHlwZSB7IENvbXBvbmVudFByb3BzIH0gZnJvbSBcInJlYWN0XCI7XG5cbmltcG9ydCB7IGNzcyB9IGZyb20gXCJAZW1vdGlvbi9yZWFjdFwiO1xuaW1wb3J0IHsgZ2xvYmFsQ3NzVmFycyB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9jb21wb25lbnRzXCI7XG5cbmludGVyZmFjZSBNZW51TGF5b3V0Q2FyZFByb3BzIGV4dGVuZHMgQ29tcG9uZW50UHJvcHM8XCJkaXZcIj4ge1xuICBtb2RlOiBPcmllbnRhdGlvbjtcbn1cblxuY29uc3QgY2FyZFN0eWxlID0gY3NzKHtcbiAgY3Vyc29yOiBcInBvaW50ZXJcIixcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGhlaWdodDogXCI2OHB4XCIsXG4gIHdpZHRoOiBcIjk2cHhcIixcbiAgZ2FwOiBcIjZweFwiLFxuICBwYWRkaW5nOiBcIjZweFwiLFxuICBib3JkZXI6IGAycHggc29saWQgdHJhbnNwYXJlbnRgLFxuICBib3JkZXJSYWRpdXM6IGdsb2JhbENzc1ZhcnMuYm9yZGVyUmFkaXVzLFxuICBib3hTaGFkb3c6IGdsb2JhbENzc1ZhcnMuc2hhZG93U20sXG4gIHRyYW5zaXRpb246IGBib3JkZXItY29sb3IgJHtnbG9iYWxDc3NWYXJzLm1vdGlvbkR1cmF0aW9uTWlkfSBlYXNlYCxcbiAgXCImOmhvdmVyXCI6IHtcbiAgICBib3JkZXJDb2xvcjogZ2xvYmFsQ3NzVmFycy5jb2xvclByaW1hcnlcbiAgfSxcbiAgXCImLnNlbGVjdGVkXCI6IHtcbiAgICBib3JkZXJDb2xvcjogZ2xvYmFsQ3NzVmFycy5jb2xvclByaW1hcnlcbiAgfSxcbiAgXCIuZGFyayAmXCI6IHtcbiAgICBib3hTaGFkb3c6IFwiMCAxcHggM3B4IDAgcmdiKDI1NSAyNTUgMjU1IC8gMC4zKSwgMCAxcHggMnB4IC0xcHggcmdiKDI1NSAyNTUgMjU1IC8gMC4zKVwiXG4gIH1cbn0pO1xuXG5jb25zdCBsYXlvdXRTdHlsZSA9IHtcbiAgaGVhZGVyOiBjc3Moe1xuICAgIGZsZXg6IFwibm9uZVwiLFxuICAgIGhlaWdodDogXCIxNnB4XCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeSxcbiAgICBib3JkZXJSYWRpdXM6IFwiNHB4XCJcbiAgfSksXG4gIG1haW46IGNzcyh7XG4gICAgZmxleDogXCJhdXRvXCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeTIwMCxcbiAgICBib3JkZXJSYWRpdXM6IFwiNHB4XCJcbiAgfSksXG4gIHdyYXBwZXI6IGNzcyh7XG4gICAgZmxleDogXCJhdXRvXCIsXG4gICAgZGlzcGxheTogXCJmbGV4XCIsXG4gICAgZmxleERpcmVjdGlvbjogXCJjb2x1bW5cIixcbiAgICBnYXA6IFwiNnB4XCJcbiAgfSksXG4gIHNpZGViYXI6IGNzcyh7XG4gICAgd2lkdGg6IFwiMThweFwiLFxuICAgIGhlaWdodDogXCIxMDAlXCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeTMwMCxcbiAgICBib3JkZXJSYWRpdXM6IFwiNHB4XCJcbiAgfSlcbn07XG5cbmV4cG9ydCBmdW5jdGlvbiBNZW51TGF5b3V0Q2FyZCh7IG1vZGUsIC4uLnByb3BzIH06IE1lbnVMYXlvdXRDYXJkUHJvcHMpIHtcbiAgY29uc3QgYm9keSA9IChcbiAgICA8ZGl2IGNzcz17bGF5b3V0U3R5bGUud3JhcHBlcn0+XG4gICAgICA8ZGl2IGNzcz17bGF5b3V0U3R5bGUuaGVhZGVyfSAvPlxuICAgICAgPGRpdiBjc3M9e2xheW91dFN0eWxlLm1haW59IC8+XG4gICAgPC9kaXY+XG4gICk7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNzcz17Y2FyZFN0eWxlfSB7Li4ucHJvcHN9PlxuICAgICAge1xuICAgICAgICBtb2RlID09PSBcImhvcml6b250YWxcIlxuICAgICAgICAgID8gYm9keVxuICAgICAgICAgIDogKFxuICAgICAgICAgICAgICA8PlxuICAgICAgICAgICAgICAgIDxkaXYgY3NzPXtsYXlvdXRTdHlsZS5zaWRlYmFyfSAvPlxuICAgICAgICAgICAgICAgIHtib2R5fVxuICAgICAgICAgICAgICA8Lz5cbiAgICAgICAgICAgIClcbiAgICAgIH1cbiAgICA8L2Rpdj5cbiAgKTtcbn1cbiJdfQ== */"),
37
+ main: /* @__PURE__ */ css({
38
+ flex: "auto",
39
+ backgroundColor: globalCssVars.colorPrimary200,
40
+ borderRadius: "4px"
41
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RoZW1lLWNvbmZpZy9tZW51LWxheW91dC1jYXJkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1Q1EiLCJmaWxlIjoiL1VzZXJzL3ZlbnVzL1ZFRi92ZWYtZnJhbWV3b3JrLXJlYWN0L3BhY2thZ2VzL3N0YXJ0ZXIvc3JjL2NvbXBvbmVudHMvbGF5b3V0L2NvbXBvbmVudHMvdGhlbWUtY29uZmlnL21lbnUtbGF5b3V0LWNhcmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBPcmllbnRhdGlvbiB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9jb21wb25lbnRzXCI7XG5pbXBvcnQgdHlwZSB7IENvbXBvbmVudFByb3BzIH0gZnJvbSBcInJlYWN0XCI7XG5cbmltcG9ydCB7IGNzcyB9IGZyb20gXCJAZW1vdGlvbi9yZWFjdFwiO1xuaW1wb3J0IHsgZ2xvYmFsQ3NzVmFycyB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9jb21wb25lbnRzXCI7XG5cbmludGVyZmFjZSBNZW51TGF5b3V0Q2FyZFByb3BzIGV4dGVuZHMgQ29tcG9uZW50UHJvcHM8XCJkaXZcIj4ge1xuICBtb2RlOiBPcmllbnRhdGlvbjtcbn1cblxuY29uc3QgY2FyZFN0eWxlID0gY3NzKHtcbiAgY3Vyc29yOiBcInBvaW50ZXJcIixcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGhlaWdodDogXCI2OHB4XCIsXG4gIHdpZHRoOiBcIjk2cHhcIixcbiAgZ2FwOiBcIjZweFwiLFxuICBwYWRkaW5nOiBcIjZweFwiLFxuICBib3JkZXI6IGAycHggc29saWQgdHJhbnNwYXJlbnRgLFxuICBib3JkZXJSYWRpdXM6IGdsb2JhbENzc1ZhcnMuYm9yZGVyUmFkaXVzLFxuICBib3hTaGFkb3c6IGdsb2JhbENzc1ZhcnMuc2hhZG93U20sXG4gIHRyYW5zaXRpb246IGBib3JkZXItY29sb3IgJHtnbG9iYWxDc3NWYXJzLm1vdGlvbkR1cmF0aW9uTWlkfSBlYXNlYCxcbiAgXCImOmhvdmVyXCI6IHtcbiAgICBib3JkZXJDb2xvcjogZ2xvYmFsQ3NzVmFycy5jb2xvclByaW1hcnlcbiAgfSxcbiAgXCImLnNlbGVjdGVkXCI6IHtcbiAgICBib3JkZXJDb2xvcjogZ2xvYmFsQ3NzVmFycy5jb2xvclByaW1hcnlcbiAgfSxcbiAgXCIuZGFyayAmXCI6IHtcbiAgICBib3hTaGFkb3c6IFwiMCAxcHggM3B4IDAgcmdiKDI1NSAyNTUgMjU1IC8gMC4zKSwgMCAxcHggMnB4IC0xcHggcmdiKDI1NSAyNTUgMjU1IC8gMC4zKVwiXG4gIH1cbn0pO1xuXG5jb25zdCBsYXlvdXRTdHlsZSA9IHtcbiAgaGVhZGVyOiBjc3Moe1xuICAgIGZsZXg6IFwibm9uZVwiLFxuICAgIGhlaWdodDogXCIxNnB4XCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeSxcbiAgICBib3JkZXJSYWRpdXM6IFwiNHB4XCJcbiAgfSksXG4gIG1haW46IGNzcyh7XG4gICAgZmxleDogXCJhdXRvXCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeTIwMCxcbiAgICBib3JkZXJSYWRpdXM6IFwiNHB4XCJcbiAgfSksXG4gIHdyYXBwZXI6IGNzcyh7XG4gICAgZmxleDogXCJhdXRvXCIsXG4gICAgZGlzcGxheTogXCJmbGV4XCIsXG4gICAgZmxleERpcmVjdGlvbjogXCJjb2x1bW5cIixcbiAgICBnYXA6IFwiNnB4XCJcbiAgfSksXG4gIHNpZGViYXI6IGNzcyh7XG4gICAgd2lkdGg6IFwiMThweFwiLFxuICAgIGhlaWdodDogXCIxMDAlXCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeTMwMCxcbiAgICBib3JkZXJSYWRpdXM6IFwiNHB4XCJcbiAgfSlcbn07XG5cbmV4cG9ydCBmdW5jdGlvbiBNZW51TGF5b3V0Q2FyZCh7IG1vZGUsIC4uLnByb3BzIH06IE1lbnVMYXlvdXRDYXJkUHJvcHMpIHtcbiAgY29uc3QgYm9keSA9IChcbiAgICA8ZGl2IGNzcz17bGF5b3V0U3R5bGUud3JhcHBlcn0+XG4gICAgICA8ZGl2IGNzcz17bGF5b3V0U3R5bGUuaGVhZGVyfSAvPlxuICAgICAgPGRpdiBjc3M9e2xheW91dFN0eWxlLm1haW59IC8+XG4gICAgPC9kaXY+XG4gICk7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNzcz17Y2FyZFN0eWxlfSB7Li4ucHJvcHN9PlxuICAgICAge1xuICAgICAgICBtb2RlID09PSBcImhvcml6b250YWxcIlxuICAgICAgICAgID8gYm9keVxuICAgICAgICAgIDogKFxuICAgICAgICAgICAgICA8PlxuICAgICAgICAgICAgICAgIDxkaXYgY3NzPXtsYXlvdXRTdHlsZS5zaWRlYmFyfSAvPlxuICAgICAgICAgICAgICAgIHtib2R5fVxuICAgICAgICAgICAgICA8Lz5cbiAgICAgICAgICAgIClcbiAgICAgIH1cbiAgICA8L2Rpdj5cbiAgKTtcbn1cbiJdfQ== */"),
42
+ wrapper: process.env.NODE_ENV === "production" ? {
43
+ name: "8xclx9",
44
+ styles: "flex:auto;display:flex;flex-direction:column;gap:6px"
45
+ } : {
46
+ name: "8xclx9",
47
+ styles: "flex:auto;display:flex;flex-direction:column;gap:6px/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RoZW1lLWNvbmZpZy9tZW51LWxheW91dC1jYXJkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0Q1ciLCJmaWxlIjoiL1VzZXJzL3ZlbnVzL1ZFRi92ZWYtZnJhbWV3b3JrLXJlYWN0L3BhY2thZ2VzL3N0YXJ0ZXIvc3JjL2NvbXBvbmVudHMvbGF5b3V0L2NvbXBvbmVudHMvdGhlbWUtY29uZmlnL21lbnUtbGF5b3V0LWNhcmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBPcmllbnRhdGlvbiB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9jb21wb25lbnRzXCI7XG5pbXBvcnQgdHlwZSB7IENvbXBvbmVudFByb3BzIH0gZnJvbSBcInJlYWN0XCI7XG5cbmltcG9ydCB7IGNzcyB9IGZyb20gXCJAZW1vdGlvbi9yZWFjdFwiO1xuaW1wb3J0IHsgZ2xvYmFsQ3NzVmFycyB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9jb21wb25lbnRzXCI7XG5cbmludGVyZmFjZSBNZW51TGF5b3V0Q2FyZFByb3BzIGV4dGVuZHMgQ29tcG9uZW50UHJvcHM8XCJkaXZcIj4ge1xuICBtb2RlOiBPcmllbnRhdGlvbjtcbn1cblxuY29uc3QgY2FyZFN0eWxlID0gY3NzKHtcbiAgY3Vyc29yOiBcInBvaW50ZXJcIixcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGhlaWdodDogXCI2OHB4XCIsXG4gIHdpZHRoOiBcIjk2cHhcIixcbiAgZ2FwOiBcIjZweFwiLFxuICBwYWRkaW5nOiBcIjZweFwiLFxuICBib3JkZXI6IGAycHggc29saWQgdHJhbnNwYXJlbnRgLFxuICBib3JkZXJSYWRpdXM6IGdsb2JhbENzc1ZhcnMuYm9yZGVyUmFkaXVzLFxuICBib3hTaGFkb3c6IGdsb2JhbENzc1ZhcnMuc2hhZG93U20sXG4gIHRyYW5zaXRpb246IGBib3JkZXItY29sb3IgJHtnbG9iYWxDc3NWYXJzLm1vdGlvbkR1cmF0aW9uTWlkfSBlYXNlYCxcbiAgXCImOmhvdmVyXCI6IHtcbiAgICBib3JkZXJDb2xvcjogZ2xvYmFsQ3NzVmFycy5jb2xvclByaW1hcnlcbiAgfSxcbiAgXCImLnNlbGVjdGVkXCI6IHtcbiAgICBib3JkZXJDb2xvcjogZ2xvYmFsQ3NzVmFycy5jb2xvclByaW1hcnlcbiAgfSxcbiAgXCIuZGFyayAmXCI6IHtcbiAgICBib3hTaGFkb3c6IFwiMCAxcHggM3B4IDAgcmdiKDI1NSAyNTUgMjU1IC8gMC4zKSwgMCAxcHggMnB4IC0xcHggcmdiKDI1NSAyNTUgMjU1IC8gMC4zKVwiXG4gIH1cbn0pO1xuXG5jb25zdCBsYXlvdXRTdHlsZSA9IHtcbiAgaGVhZGVyOiBjc3Moe1xuICAgIGZsZXg6IFwibm9uZVwiLFxuICAgIGhlaWdodDogXCIxNnB4XCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeSxcbiAgICBib3JkZXJSYWRpdXM6IFwiNHB4XCJcbiAgfSksXG4gIG1haW46IGNzcyh7XG4gICAgZmxleDogXCJhdXRvXCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeTIwMCxcbiAgICBib3JkZXJSYWRpdXM6IFwiNHB4XCJcbiAgfSksXG4gIHdyYXBwZXI6IGNzcyh7XG4gICAgZmxleDogXCJhdXRvXCIsXG4gICAgZGlzcGxheTogXCJmbGV4XCIsXG4gICAgZmxleERpcmVjdGlvbjogXCJjb2x1bW5cIixcbiAgICBnYXA6IFwiNnB4XCJcbiAgfSksXG4gIHNpZGViYXI6IGNzcyh7XG4gICAgd2lkdGg6IFwiMThweFwiLFxuICAgIGhlaWdodDogXCIxMDAlXCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeTMwMCxcbiAgICBib3JkZXJSYWRpdXM6IFwiNHB4XCJcbiAgfSlcbn07XG5cbmV4cG9ydCBmdW5jdGlvbiBNZW51TGF5b3V0Q2FyZCh7IG1vZGUsIC4uLnByb3BzIH06IE1lbnVMYXlvdXRDYXJkUHJvcHMpIHtcbiAgY29uc3QgYm9keSA9IChcbiAgICA8ZGl2IGNzcz17bGF5b3V0U3R5bGUud3JhcHBlcn0+XG4gICAgICA8ZGl2IGNzcz17bGF5b3V0U3R5bGUuaGVhZGVyfSAvPlxuICAgICAgPGRpdiBjc3M9e2xheW91dFN0eWxlLm1haW59IC8+XG4gICAgPC9kaXY+XG4gICk7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNzcz17Y2FyZFN0eWxlfSB7Li4ucHJvcHN9PlxuICAgICAge1xuICAgICAgICBtb2RlID09PSBcImhvcml6b250YWxcIlxuICAgICAgICAgID8gYm9keVxuICAgICAgICAgIDogKFxuICAgICAgICAgICAgICA8PlxuICAgICAgICAgICAgICAgIDxkaXYgY3NzPXtsYXlvdXRTdHlsZS5zaWRlYmFyfSAvPlxuICAgICAgICAgICAgICAgIHtib2R5fVxuICAgICAgICAgICAgICA8Lz5cbiAgICAgICAgICAgIClcbiAgICAgIH1cbiAgICA8L2Rpdj5cbiAgKTtcbn1cbiJdfQ== */",
48
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
49
+ },
50
+ sidebar: /* @__PURE__ */ css({
51
+ width: "18px",
52
+ height: "100%",
53
+ backgroundColor: globalCssVars.colorPrimary300,
54
+ borderRadius: "4px"
55
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RoZW1lLWNvbmZpZy9tZW51LWxheW91dC1jYXJkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrRFciLCJmaWxlIjoiL1VzZXJzL3ZlbnVzL1ZFRi92ZWYtZnJhbWV3b3JrLXJlYWN0L3BhY2thZ2VzL3N0YXJ0ZXIvc3JjL2NvbXBvbmVudHMvbGF5b3V0L2NvbXBvbmVudHMvdGhlbWUtY29uZmlnL21lbnUtbGF5b3V0LWNhcmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBPcmllbnRhdGlvbiB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9jb21wb25lbnRzXCI7XG5pbXBvcnQgdHlwZSB7IENvbXBvbmVudFByb3BzIH0gZnJvbSBcInJlYWN0XCI7XG5cbmltcG9ydCB7IGNzcyB9IGZyb20gXCJAZW1vdGlvbi9yZWFjdFwiO1xuaW1wb3J0IHsgZ2xvYmFsQ3NzVmFycyB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9jb21wb25lbnRzXCI7XG5cbmludGVyZmFjZSBNZW51TGF5b3V0Q2FyZFByb3BzIGV4dGVuZHMgQ29tcG9uZW50UHJvcHM8XCJkaXZcIj4ge1xuICBtb2RlOiBPcmllbnRhdGlvbjtcbn1cblxuY29uc3QgY2FyZFN0eWxlID0gY3NzKHtcbiAgY3Vyc29yOiBcInBvaW50ZXJcIixcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGhlaWdodDogXCI2OHB4XCIsXG4gIHdpZHRoOiBcIjk2cHhcIixcbiAgZ2FwOiBcIjZweFwiLFxuICBwYWRkaW5nOiBcIjZweFwiLFxuICBib3JkZXI6IGAycHggc29saWQgdHJhbnNwYXJlbnRgLFxuICBib3JkZXJSYWRpdXM6IGdsb2JhbENzc1ZhcnMuYm9yZGVyUmFkaXVzLFxuICBib3hTaGFkb3c6IGdsb2JhbENzc1ZhcnMuc2hhZG93U20sXG4gIHRyYW5zaXRpb246IGBib3JkZXItY29sb3IgJHtnbG9iYWxDc3NWYXJzLm1vdGlvbkR1cmF0aW9uTWlkfSBlYXNlYCxcbiAgXCImOmhvdmVyXCI6IHtcbiAgICBib3JkZXJDb2xvcjogZ2xvYmFsQ3NzVmFycy5jb2xvclByaW1hcnlcbiAgfSxcbiAgXCImLnNlbGVjdGVkXCI6IHtcbiAgICBib3JkZXJDb2xvcjogZ2xvYmFsQ3NzVmFycy5jb2xvclByaW1hcnlcbiAgfSxcbiAgXCIuZGFyayAmXCI6IHtcbiAgICBib3hTaGFkb3c6IFwiMCAxcHggM3B4IDAgcmdiKDI1NSAyNTUgMjU1IC8gMC4zKSwgMCAxcHggMnB4IC0xcHggcmdiKDI1NSAyNTUgMjU1IC8gMC4zKVwiXG4gIH1cbn0pO1xuXG5jb25zdCBsYXlvdXRTdHlsZSA9IHtcbiAgaGVhZGVyOiBjc3Moe1xuICAgIGZsZXg6IFwibm9uZVwiLFxuICAgIGhlaWdodDogXCIxNnB4XCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeSxcbiAgICBib3JkZXJSYWRpdXM6IFwiNHB4XCJcbiAgfSksXG4gIG1haW46IGNzcyh7XG4gICAgZmxleDogXCJhdXRvXCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeTIwMCxcbiAgICBib3JkZXJSYWRpdXM6IFwiNHB4XCJcbiAgfSksXG4gIHdyYXBwZXI6IGNzcyh7XG4gICAgZmxleDogXCJhdXRvXCIsXG4gICAgZGlzcGxheTogXCJmbGV4XCIsXG4gICAgZmxleERpcmVjdGlvbjogXCJjb2x1bW5cIixcbiAgICBnYXA6IFwiNnB4XCJcbiAgfSksXG4gIHNpZGViYXI6IGNzcyh7XG4gICAgd2lkdGg6IFwiMThweFwiLFxuICAgIGhlaWdodDogXCIxMDAlXCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiBnbG9iYWxDc3NWYXJzLmNvbG9yUHJpbWFyeTMwMCxcbiAgICBib3JkZXJSYWRpdXM6IFwiNHB4XCJcbiAgfSlcbn07XG5cbmV4cG9ydCBmdW5jdGlvbiBNZW51TGF5b3V0Q2FyZCh7IG1vZGUsIC4uLnByb3BzIH06IE1lbnVMYXlvdXRDYXJkUHJvcHMpIHtcbiAgY29uc3QgYm9keSA9IChcbiAgICA8ZGl2IGNzcz17bGF5b3V0U3R5bGUud3JhcHBlcn0+XG4gICAgICA8ZGl2IGNzcz17bGF5b3V0U3R5bGUuaGVhZGVyfSAvPlxuICAgICAgPGRpdiBjc3M9e2xheW91dFN0eWxlLm1haW59IC8+XG4gICAgPC9kaXY+XG4gICk7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNzcz17Y2FyZFN0eWxlfSB7Li4ucHJvcHN9PlxuICAgICAge1xuICAgICAgICBtb2RlID09PSBcImhvcml6b250YWxcIlxuICAgICAgICAgID8gYm9keVxuICAgICAgICAgIDogKFxuICAgICAgICAgICAgICA8PlxuICAgICAgICAgICAgICAgIDxkaXYgY3NzPXtsYXlvdXRTdHlsZS5zaWRlYmFyfSAvPlxuICAgICAgICAgICAgICAgIHtib2R5fVxuICAgICAgICAgICAgICA8Lz5cbiAgICAgICAgICAgIClcbiAgICAgIH1cbiAgICA8L2Rpdj5cbiAgKTtcbn1cbiJdfQ== */")
56
+ };
57
+ function MenuLayoutCard({
58
+ mode,
59
+ ...props
60
+ }) {
61
+ const body = /* @__PURE__ */ jsxs("div", { css: layoutStyle.wrapper, children: [
62
+ /* @__PURE__ */ jsx("div", { css: layoutStyle.header }),
63
+ /* @__PURE__ */ jsx("div", { css: layoutStyle.main })
64
+ ] });
65
+ return /* @__PURE__ */ jsx("div", { css: cardStyle, ...props, children: mode === "horizontal" ? body : /* @__PURE__ */ jsxs(Fragment, { children: [
66
+ /* @__PURE__ */ jsx("div", { css: layoutStyle.sidebar }),
67
+ body
68
+ ] }) });
69
+ }
70
+
71
+ export { MenuLayoutCard };
@@ -0,0 +1,29 @@
1
+ /*! @vef-framework/starter v2.0.0 made with ❤️ by Venus | 2025-11-25T10:06:38.668Z */
2
+ import { jsxs, jsx } from '@emotion/react/jsx-runtime';
3
+ import { Center, Tooltip } from '@vef-framework/components';
4
+ import { clsx } from '@vef-framework/core';
5
+ import '../../../../stores/index.js';
6
+ import { MenuLayoutCard } from './menu-layout-card.js';
7
+ import { useThemeStore } from '../../../../stores/theme.js';
8
+
9
+ function MenuLayout() {
10
+ const menuLayout = useThemeStore((state) => state.menuLayout);
11
+ return /* @__PURE__ */ jsxs(Center, { gap: "large", children: [
12
+ /* @__PURE__ */ jsx(Tooltip, { placement: "bottom", title: "垂直菜单模式", children: /* @__PURE__ */ jsx(MenuLayoutCard, { mode: "vertical", className: clsx({
13
+ selected: menuLayout === "vertical"
14
+ }), onClick: () => {
15
+ useThemeStore.setState((state) => {
16
+ state.menuLayout = "vertical";
17
+ });
18
+ } }) }),
19
+ /* @__PURE__ */ jsx(Tooltip, { placement: "bottom", title: "水平菜单模式", children: /* @__PURE__ */ jsx(MenuLayoutCard, { mode: "horizontal", className: clsx({
20
+ selected: menuLayout === "horizontal"
21
+ }), onClick: () => {
22
+ useThemeStore.setState((state) => {
23
+ state.menuLayout = "horizontal";
24
+ });
25
+ } }) })
26
+ ] });
27
+ }
28
+
29
+ export { MenuLayout };
@@ -0,0 +1,18 @@
1
+ /*! @vef-framework/starter v2.0.0 made with ❤️ by Venus | 2025-11-25T10:06:38.668Z */
2
+ import { jsx } from '@emotion/react/jsx-runtime';
3
+ import { Button, showSuccessMessage, Icon } from '@vef-framework/components';
4
+ import { RefreshCwIcon } from 'lucide-react';
5
+ import '../../../../stores/index.js';
6
+ import { useThemeStore } from '../../../../stores/theme.js';
7
+
8
+ function Operations() {
9
+ return /* @__PURE__ */ jsx(Button, { block: true, danger: true, icon: /* @__PURE__ */ jsx(Icon, { component: RefreshCwIcon }), onClick: () => {
10
+ useThemeStore.setState({
11
+ ...useThemeStore.getInitialState(),
12
+ isThemeConfigVisible: true
13
+ }, true);
14
+ showSuccessMessage("主题配置已重置成功");
15
+ }, children: "重置配置" });
16
+ }
17
+
18
+ export { Operations };
@@ -0,0 +1,29 @@
1
+ /*! @vef-framework/starter v2.0.0 made with ❤️ by Venus | 2025-11-25T10:06:38.668Z */
2
+ import { jsx } from '@emotion/react/jsx-runtime';
3
+ import { ColorPicker } from '@vef-framework/components';
4
+ import { useDidUpdate } from '@vef-framework/hooks';
5
+ import { useState, useTransition } from 'react';
6
+ import '../../../../stores/index.js';
7
+ import { useThemeStore } from '../../../../stores/theme.js';
8
+
9
+ function ThemeColorPicker({
10
+ color
11
+ }) {
12
+ const currentValue = useThemeStore((state) => state.colors[color]);
13
+ const [localValue, setLocalValue] = useState(currentValue);
14
+ useDidUpdate(() => {
15
+ setLocalValue(currentValue);
16
+ }, [currentValue]);
17
+ const [_, startTransition] = useTransition();
18
+ return /* @__PURE__ */ jsx(ColorPicker, { arrow: false, format: "hex", value: localValue, onChange: (value) => {
19
+ setLocalValue(value.toHexString());
20
+ }, onChangeComplete: (value) => {
21
+ startTransition(() => {
22
+ useThemeStore.setState((state) => {
23
+ state.colors[color] = value.toHexString();
24
+ });
25
+ });
26
+ } });
27
+ }
28
+
29
+ export { ThemeColorPicker };
@@ -0,0 +1,25 @@
1
+ /*! @vef-framework/starter v2.0.0 made with ❤️ by Venus | 2025-11-25T10:06:38.668Z */
2
+ import { jsx } from '@emotion/react/jsx-runtime';
3
+ import { css } from '@emotion/react';
4
+ import { globalCssVars, semanticColors } from '@vef-framework/components';
5
+ import { ConfigItem } from './config-item.js';
6
+ import { ThemeColorPicker } from './theme-color-picker.js';
7
+
8
+ const wrapperStyle = /* @__PURE__ */ css({
9
+ display: "flex",
10
+ flexDirection: "column",
11
+ gap: globalCssVars.spacingSm
12
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy92ZW51cy9WRUYvdmVmLWZyYW1ld29yay1yZWFjdC9wYWNrYWdlcy9zdGFydGVyL3NyYy9jb21wb25lbnRzL2xheW91dC9jb21wb25lbnRzL3RoZW1lLWNvbmZpZy90aGVtZS1jb2xvcnMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVFxQiIsImZpbGUiOiIvVXNlcnMvdmVudXMvVkVGL3ZlZi1mcmFtZXdvcmstcmVhY3QvcGFja2FnZXMvc3RhcnRlci9zcmMvY29tcG9uZW50cy9sYXlvdXQvY29tcG9uZW50cy90aGVtZS1jb25maWcvdGhlbWUtY29sb3JzLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgU2VtYW50aWNDb2xvciB9IGZyb20gXCJAdmVmLWZyYW1ld29yay9jb21wb25lbnRzXCI7XG5cbmltcG9ydCB7IGNzcyB9IGZyb20gXCJAZW1vdGlvbi9yZWFjdFwiO1xuaW1wb3J0IHsgZ2xvYmFsQ3NzVmFycywgc2VtYW50aWNDb2xvcnMgfSBmcm9tIFwiQHZlZi1mcmFtZXdvcmsvY29tcG9uZW50c1wiO1xuXG5pbXBvcnQgeyBDb25maWdJdGVtIH0gZnJvbSBcIi4vY29uZmlnLWl0ZW1cIjtcbmltcG9ydCB7IFRoZW1lQ29sb3JQaWNrZXIgfSBmcm9tIFwiLi90aGVtZS1jb2xvci1waWNrZXJcIjtcblxuY29uc3Qgd3JhcHBlclN0eWxlID0gY3NzKHtcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGZsZXhEaXJlY3Rpb246IFwiY29sdW1uXCIsXG4gIGdhcDogZ2xvYmFsQ3NzVmFycy5zcGFjaW5nU21cbn0pO1xuXG5jb25zdCBzZW1hbnRpY0NvbG9yTGFiZWxzOiBSZWNvcmQ8U2VtYW50aWNDb2xvciwgc3RyaW5nPiA9IHtcbiAgcHJpbWFyeTogXCLkuLvoibJcIixcbiAgaW5mbzogXCLkv6Hmga/oibJcIixcbiAgc3VjY2VzczogXCLmiJDlip/oibJcIixcbiAgd2FybmluZzogXCLorablkYroibJcIixcbiAgZXJyb3I6IFwi6ZSZ6K+v6ImyXCJcbn07XG5cbmV4cG9ydCBmdW5jdGlvbiBUaGVtZUNvbG9ycygpIHtcbiAgY29uc3QgaXRlbXMgPSBzZW1hbnRpY0NvbG9ycy5tYXAoY29sb3IgPT4gKFxuICAgIDxDb25maWdJdGVtXG4gICAgICBrZXk9e2NvbG9yfVxuICAgICAgbGFiZWw9e3NlbWFudGljQ29sb3JMYWJlbHNbY29sb3JdfVxuICAgID5cbiAgICAgIDxUaGVtZUNvbG9yUGlja2VyIGNvbG9yPXtjb2xvcn0gLz5cbiAgICA8L0NvbmZpZ0l0ZW0+XG4gICkpO1xuXG4gIHJldHVybiAoXG4gICAgPGRpdiBjc3M9e3dyYXBwZXJTdHlsZX0+XG4gICAgICB7aXRlbXN9XG4gICAgPC9kaXY+XG4gICk7XG59XG4iXX0= */");
13
+ const semanticColorLabels = {
14
+ primary: "主色",
15
+ info: "信息色",
16
+ success: "成功色",
17
+ warning: "警告色",
18
+ error: "错误色"
19
+ };
20
+ function ThemeColors() {
21
+ const items = semanticColors.map((color) => /* @__PURE__ */ jsx(ConfigItem, { label: semanticColorLabels[color], children: /* @__PURE__ */ jsx(ThemeColorPicker, { color }) }, color));
22
+ return /* @__PURE__ */ jsx("div", { css: wrapperStyle, children: items });
23
+ }
24
+
25
+ export { ThemeColors };
@@ -0,0 +1,4 @@
1
+ /*! @vef-framework/starter v2.0.0 made with ❤️ by Venus | 2025-11-25T10:06:38.668Z */
2
+ export { useColorSchemeUpdater } from './use-color-scheme-updater.js';
3
+ export { useMenuNavigate } from './use-menu-navigate.js';
4
+ export { useTabNavigate } from './use-tab-navigate.js';
@@ -0,0 +1,68 @@
1
+ /*! @vef-framework/starter v2.0.0 made with ❤️ by Venus | 2025-11-25T10:06:38.668Z */
2
+ import { useReducedMotion, useColorScheme } from '@vef-framework/hooks';
3
+ import '../../../stores/index.js';
4
+ import { useThemeStore } from '../../../stores/theme.js';
5
+
6
+ function getNextColorScheme(colorScheme) {
7
+ return colorScheme === "system" ? "light" : colorScheme === "light" ? "dark" : "system";
8
+ }
9
+ function removeColorSchemeTransitionClass() {
10
+ document.documentElement.classList.remove("color-scheme-transition");
11
+ }
12
+ function useColorSchemeUpdater() {
13
+ const currentColorScheme = useThemeStore((state) => state.colorScheme);
14
+ const reducedMotion = useReducedMotion(false, {
15
+ getInitialValueInEffect: false
16
+ });
17
+ const systemColorScheme = useColorScheme("light", {
18
+ getInitialValueInEffect: false
19
+ });
20
+ function updateColorSchemeInternal(colorScheme) {
21
+ useThemeStore.setState((state) => {
22
+ state.colorScheme = colorScheme;
23
+ });
24
+ }
25
+ function updateColorScheme(nextColorScheme, position, isLoop = false) {
26
+ if (reducedMotion) {
27
+ updateColorSchemeInternal(nextColorScheme);
28
+ return;
29
+ }
30
+ if (isLoop && (currentColorScheme === "system" && systemColorScheme === "light" || currentColorScheme === "dark" && systemColorScheme === "dark")) {
31
+ updateColorSchemeInternal(nextColorScheme);
32
+ return;
33
+ }
34
+ if (!isLoop && (nextColorScheme === "system" && currentColorScheme === systemColorScheme || currentColorScheme === "system" && nextColorScheme === systemColorScheme)) {
35
+ updateColorSchemeInternal(nextColorScheme);
36
+ return;
37
+ }
38
+ document.documentElement.classList.add("color-scheme-transition");
39
+ const transition = document.startViewTransition(() => {
40
+ updateColorSchemeInternal(nextColorScheme);
41
+ });
42
+ const {
43
+ x,
44
+ y
45
+ } = position;
46
+ const radius = Math.hypot(Math.max(x, window.innerWidth - x), Math.max(y, window.innerHeight - y));
47
+ const isDarken = nextColorScheme === "dark" || nextColorScheme === "system" && systemColorScheme === "dark";
48
+ transition.ready.then(() => {
49
+ const animation = document.documentElement.animate({
50
+ clipPath: [`circle(0px at ${x}px ${y}px)`, `circle(${radius}px at ${x}px ${y}px)`]
51
+ }, {
52
+ duration: 800,
53
+ easing: "ease-out",
54
+ direction: isDarken ? "normal" : "reverse",
55
+ pseudoElement: isDarken ? "::view-transition-new(root)" : "::view-transition-old(root)"
56
+ });
57
+ animation.addEventListener("cancel", removeColorSchemeTransitionClass);
58
+ animation.addEventListener("remove", removeColorSchemeTransitionClass);
59
+ });
60
+ transition.finished.then(removeColorSchemeTransitionClass);
61
+ }
62
+ return {
63
+ getNextColorScheme,
64
+ updateColorScheme
65
+ };
66
+ }
67
+
68
+ export { useColorSchemeUpdater };
@@ -0,0 +1,25 @@
1
+ /*! @vef-framework/starter v2.0.0 made with ❤️ by Venus | 2025-11-25T10:06:38.668Z */
2
+ import { useNavigate } from '@tanstack/react-router';
3
+ import { isPlainObject } from '@vef-framework/shared';
4
+ import { useCallback } from 'react';
5
+
6
+ function useMenuNavigate() {
7
+ const navigate = useNavigate();
8
+ return useCallback(({
9
+ path,
10
+ meta
11
+ }) => {
12
+ const {
13
+ params,
14
+ search
15
+ } = meta ?? {};
16
+ return navigate({
17
+ to: path,
18
+ params: isPlainObject(params) ? params : void 0,
19
+ search: isPlainObject(search) ? search : void 0,
20
+ viewTransition: false
21
+ });
22
+ }, [navigate]);
23
+ }
24
+
25
+ export { useMenuNavigate };