handler.ts 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  1. import { HandlerEnum } from './const';
  2. import { MenuThemeEnum, MenuTypeEnum } from '/@/enums/menuEnum';
  3. import { updateColorWeak, updateGrayMode } from '/@/setup/theme';
  4. import { appStore } from '/@/store/modules/app';
  5. import { ProjectConfig } from '/@/types/config';
  6. export function baseHandler(event: HandlerEnum, value: any) {
  7. const config = handler(event, value);
  8. appStore.commitProjectConfigState(config);
  9. }
  10. export function handler(event: HandlerEnum, value: any): DeepPartial<ProjectConfig> {
  11. switch (event) {
  12. case HandlerEnum.CHANGE_LAYOUT:
  13. const { mode, type, split } = value;
  14. const splitOpt = split === undefined ? { split } : {};
  15. let headerSetting = {};
  16. if (type === MenuTypeEnum.TOP_MENU) {
  17. headerSetting = {
  18. theme: MenuThemeEnum.DARK,
  19. };
  20. }
  21. return {
  22. menuSetting: {
  23. mode,
  24. type,
  25. collapsed: false,
  26. show: true,
  27. ...splitOpt,
  28. },
  29. headerSetting,
  30. };
  31. case HandlerEnum.MENU_HAS_DRAG:
  32. return {
  33. menuSetting: {
  34. hasDrag: value,
  35. },
  36. };
  37. case HandlerEnum.MENU_ACCORDION:
  38. return {
  39. menuSetting: {
  40. accordion: value,
  41. },
  42. };
  43. case HandlerEnum.MENU_TRIGGER:
  44. return {
  45. menuSetting: {
  46. trigger: value,
  47. },
  48. };
  49. case HandlerEnum.MENU_TOP_ALIGN:
  50. return {
  51. menuSetting: {
  52. topMenuAlign: value,
  53. },
  54. };
  55. case HandlerEnum.MENU_COLLAPSED:
  56. return {
  57. menuSetting: {
  58. collapsed: value,
  59. },
  60. };
  61. case HandlerEnum.MENU_WIDTH:
  62. return {
  63. menuSetting: {
  64. menuWidth: value,
  65. },
  66. };
  67. case HandlerEnum.MENU_COLLAPSED_SHOW_TITLE:
  68. return {
  69. menuSetting: {
  70. collapsedShowTitle: value,
  71. },
  72. };
  73. case HandlerEnum.MENU_SHOW_SIDEBAR:
  74. return {
  75. menuSetting: {
  76. show: value,
  77. },
  78. };
  79. case HandlerEnum.MENU_THEME:
  80. return {
  81. menuSetting: {
  82. theme: value,
  83. },
  84. };
  85. case HandlerEnum.MENU_SPLIT:
  86. return {
  87. menuSetting: {
  88. split: value,
  89. },
  90. };
  91. case HandlerEnum.MENU_SHOW_SEARCH:
  92. return {
  93. menuSetting: {
  94. showSearch: value,
  95. },
  96. };
  97. case HandlerEnum.OPEN_PAGE_LOADING:
  98. return {
  99. openPageLoading: value,
  100. };
  101. case HandlerEnum.OPEN_ROUTE_TRANSITION:
  102. return {
  103. openRouterTransition: value,
  104. };
  105. case HandlerEnum.ROUTER_TRANSITION:
  106. return {
  107. routerTransition: value,
  108. };
  109. case HandlerEnum.LOCK_TIME:
  110. return {
  111. lockTime: value,
  112. };
  113. case HandlerEnum.FULL_CONTENT:
  114. return {
  115. fullContent: value,
  116. };
  117. case HandlerEnum.CONTENT_MODE:
  118. return {
  119. contentMode: value,
  120. };
  121. case HandlerEnum.SHOW_BREADCRUMB:
  122. return {
  123. showBreadCrumb: value,
  124. };
  125. case HandlerEnum.SHOW_BREADCRUMB_ICON:
  126. return {
  127. showBreadCrumbIcon: value,
  128. };
  129. case HandlerEnum.GRAY_MODE:
  130. updateGrayMode(value);
  131. return {
  132. grayMode: value,
  133. };
  134. case HandlerEnum.COLOR_WEAK:
  135. updateColorWeak(value);
  136. return {
  137. colorWeak: value,
  138. };
  139. case HandlerEnum.SHOW_LOGO:
  140. return {
  141. showLogo: value,
  142. };
  143. case HandlerEnum.TABS_SHOW_QUICK:
  144. return {
  145. multiTabsSetting: {
  146. showQuick: value,
  147. },
  148. };
  149. case HandlerEnum.TABS_SHOW_QUICK:
  150. return {
  151. multiTabsSetting: {
  152. showIcon: value,
  153. },
  154. };
  155. case HandlerEnum.TABS_SHOW:
  156. return {
  157. multiTabsSetting: {
  158. show: value,
  159. },
  160. };
  161. case HandlerEnum.HEADER_THEME:
  162. return {
  163. headerSetting: {
  164. theme: value,
  165. },
  166. };
  167. case HandlerEnum.HEADER_FIXED:
  168. return {
  169. headerSetting: {
  170. fixed: value,
  171. },
  172. };
  173. case HandlerEnum.HEADER_SHOW:
  174. return {
  175. headerSetting: {
  176. show: value,
  177. },
  178. };
  179. default:
  180. return {};
  181. }
  182. }