SettingDrawer.tsx 12.5 KB
Newer Older
V
vben 已提交
1
import { defineComponent, computed, unref } from 'vue';
陈文彬 已提交
2
import { BasicDrawer } from '/@/components/Drawer/index';
V
vben 已提交
3 4 5 6 7 8 9 10 11
import { Divider } from 'ant-design-vue';
import {
  TypePicker,
  ThemePicker,
  SettingFooter,
  SwitchItem,
  SelectItem,
  InputNumberItem,
} from './components';
V
vben 已提交
12

V
vben 已提交
13
import { MenuTypeEnum, TriggerEnum } from '/@/enums/menuEnum';
陈文彬 已提交
14

V
vben 已提交
15 16 17 18
import { useRootSetting } from '/@/hooks/setting/useRootSetting';
import { useMenuSetting } from '/@/hooks/setting/useMenuSetting';
import { useHeaderSetting } from '/@/hooks/setting/useHeaderSetting';
import { useMultipleTabSetting } from '/@/hooks/setting/useMultipleTabSetting';
V
vben 已提交
19
import { useTransitionSetting } from '/@/hooks/setting/useTransitionSetting';
V
vben 已提交
20
import { useI18n } from '/@/hooks/web/useI18n';
陈文彬 已提交
21

V
vben 已提交
22
import { baseHandler } from './handler';
V
vben 已提交
23

V
vben 已提交
24 25 26 27
import {
  HandlerEnum,
  contentModeOptions,
  topMenuAlignOptions,
V
vben 已提交
28
  getMenuTriggerOptions,
V
vben 已提交
29
  routerTransitionOptions,
V
vben 已提交
30
  menuTypeList,
31
  mixSidebarTriggerOptions,
V
vben 已提交
32 33
} from './enum';

V
vben 已提交
34 35 36 37 38
import {
  HEADER_PRESET_BG_COLOR_LIST,
  SIDE_BAR_BG_COLOR_LIST,
  APP_PRESET_COLOR_LIST,
} from '/@/settings/designSetting';
陈文彬 已提交
39

V
vben 已提交
40
const { t } = useI18n();
V
vben 已提交
41

陈文彬 已提交
42 43 44
export default defineComponent({
  name: 'SettingDrawer',
  setup(_, { attrs }) {
V
vben 已提交
45 46 47 48 49 50 51 52 53
    const {
      getContentMode,
      getShowFooter,
      getShowBreadCrumb,
      getShowBreadCrumbIcon,
      getShowLogo,
      getFullContent,
      getColorWeak,
      getGrayMode,
V
vben 已提交
54
      getLockTime,
V
vben 已提交
55
      getThemeColor,
V
vben 已提交
56
    } = useRootSetting();
陈文彬 已提交
57

V
vben 已提交
58 59 60 61 62 63 64
    const {
      getOpenPageLoading,
      getBasicTransition,
      getEnableTransition,
      getOpenNProgress,
    } = useTransitionSetting();

V
vben 已提交
65 66 67 68 69
    const {
      getIsHorizontal,
      getShowMenu,
      getMenuType,
      getTrigger,
V
vben 已提交
70
      getCollapsedShowTitle,
V
vben 已提交
71 72
      getMenuFixed,
      getCollapsed,
V
vben 已提交
73
      getCanDrag,
V
vben 已提交
74 75 76 77 78 79
      getTopMenuAlign,
      getAccordion,
      getMenuWidth,
      getMenuBgColor,
      getIsTopMenu,
      getSplit,
V
vben 已提交
80 81
      getIsMixSidebar,
      getCloseMixSidebarOnChange,
82
      getMixSideTrigger,
83
      getMixSideFixed,
V
vben 已提交
84
    } = useMenuSetting();
陈文彬 已提交
85

V
vben 已提交
86 87 88 89 90 91
    const {
      getShowHeader,
      getFixed: getHeaderFixed,
      getHeaderBgColor,
      getShowSearch,
    } = useHeaderSetting();
陈文彬 已提交
92

V
vben 已提交
93
    const { getShowMultipleTab, getShowQuick, getShowRedo, getShowFold } = useMultipleTabSetting();
陈文彬 已提交
94 95

    const getShowMenuRef = computed(() => {
V
vben 已提交
96
      return unref(getShowMenu) && !unref(getIsHorizontal);
陈文彬 已提交
97 98
    });

V
vben 已提交
99 100 101
    function renderSidebar() {
      return (
        <>
V
vben 已提交
102 103 104 105 106 107 108 109 110 111 112
          <TypePicker
            menuTypeList={menuTypeList}
            handler={(item: typeof menuTypeList[0]) => {
              baseHandler(HandlerEnum.CHANGE_LAYOUT, {
                mode: item.mode,
                type: item.type,
                split: unref(getIsHorizontal) ? false : undefined,
              });
            }}
            def={unref(getMenuType)}
          />
V
vben 已提交
113
        </>
陈文彬 已提交
114 115 116
      );
    }

V
vben 已提交
117
    function renderHeaderTheme() {
V
vben 已提交
118
      return (
V
vben 已提交
119 120 121 122 123 124 125 126 127 128 129 130 131 132 133
        <ThemePicker
          colorList={HEADER_PRESET_BG_COLOR_LIST}
          def={unref(getHeaderBgColor)}
          event={HandlerEnum.HEADER_THEME}
        />
      );
    }

    function renderSiderTheme() {
      return (
        <ThemePicker
          colorList={SIDE_BAR_BG_COLOR_LIST}
          def={unref(getMenuBgColor)}
          event={HandlerEnum.MENU_THEME}
        />
V
vben 已提交
134
      );
V
vben 已提交
135 136
    }

V
vben 已提交
137 138 139 140 141 142 143 144 145 146
    function renderMainTheme() {
      return (
        <ThemePicker
          colorList={APP_PRESET_COLOR_LIST}
          def={unref(getThemeColor)}
          event={HandlerEnum.CHANGE_THEME_COLOR}
        />
      );
    }

陈文彬 已提交
147 148 149 150
    /**
     * @description:
     */
    function renderFeatures() {
V
vben 已提交
151 152 153 154 155 156 157 158
      let triggerDef = unref(getTrigger);

      const triggerOptions = getMenuTriggerOptions(unref(getSplit));
      const some = triggerOptions.some((item) => item.value === triggerDef);
      if (!some) {
        triggerDef = TriggerEnum.FOOTER;
      }

V
vben 已提交
159 160
      return (
        <>
V
vben 已提交
161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186
          <SwitchItem
            title={t('layout.setting.splitMenu')}
            event={HandlerEnum.MENU_SPLIT}
            def={unref(getSplit)}
            disabled={!unref(getShowMenuRef) || unref(getMenuType) !== MenuTypeEnum.MIX}
          />
          <SwitchItem
            title={t('layout.setting.mixSidebarFixed')}
            event={HandlerEnum.MENU_FIXED_MIX_SIDEBAR}
            def={unref(getMixSideFixed)}
            disabled={!unref(getIsMixSidebar)}
          />

          <SwitchItem
            title={t('layout.setting.closeMixSidebarOnChange')}
            event={HandlerEnum.MENU_CLOSE_MIX_SIDEBAR_ON_CHANGE}
            def={unref(getCloseMixSidebarOnChange)}
            disabled={!unref(getIsMixSidebar)}
          />
          <SwitchItem
            title={t('layout.setting.menuCollapse')}
            event={HandlerEnum.MENU_COLLAPSED}
            def={unref(getCollapsed)}
            disabled={!unref(getShowMenuRef)}
          />

V
vben 已提交
187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204
          <SwitchItem
            title={t('layout.setting.menuDrag')}
            event={HandlerEnum.MENU_HAS_DRAG}
            def={unref(getCanDrag)}
            disabled={!unref(getShowMenuRef)}
          />
          <SwitchItem
            title={t('layout.setting.menuSearch')}
            event={HandlerEnum.HEADER_SEARCH}
            def={unref(getShowSearch)}
            disabled={!unref(getShowHeader)}
          />
          <SwitchItem
            title={t('layout.setting.menuAccordion')}
            event={HandlerEnum.MENU_ACCORDION}
            def={unref(getAccordion)}
            disabled={!unref(getShowMenuRef)}
          />
V
vben 已提交
205

V
vben 已提交
206 207 208 209
          <SwitchItem
            title={t('layout.setting.collapseMenuDisplayName')}
            event={HandlerEnum.MENU_COLLAPSED_SHOW_TITLE}
            def={unref(getCollapsedShowTitle)}
V
vben 已提交
210
            disabled={!unref(getShowMenuRef) || !unref(getCollapsed) || unref(getIsMixSidebar)}
V
vben 已提交
211
          />
V
vben 已提交
212

V
vben 已提交
213 214 215 216 217 218 219 220 221 222
          <SwitchItem
            title={t('layout.setting.fixedHeader')}
            event={HandlerEnum.HEADER_FIXED}
            def={unref(getHeaderFixed)}
            disabled={!unref(getShowHeader)}
          />
          <SwitchItem
            title={t('layout.setting.fixedSideBar')}
            event={HandlerEnum.MENU_FIXED}
            def={unref(getMenuFixed)}
V
vben 已提交
223
            disabled={!unref(getShowMenuRef) || unref(getIsMixSidebar)}
V
vben 已提交
224
          />
V
vben 已提交
225 226 227 228 229 230 231
          <SelectItem
            title={t('layout.setting.mixSidebarTrigger')}
            event={HandlerEnum.MENU_TRIGGER_MIX_SIDEBAR}
            def={unref(getMixSideTrigger)}
            options={mixSidebarTriggerOptions}
            disabled={!unref(getIsMixSidebar)}
          />
V
vben 已提交
232 233 234 235 236
          <SelectItem
            title={t('layout.setting.topMenuLayout')}
            event={HandlerEnum.MENU_TOP_ALIGN}
            def={unref(getTopMenuAlign)}
            options={topMenuAlignOptions}
V
vben 已提交
237
            disabled={
V
vben 已提交
238 239 240 241
              !unref(getShowHeader) ||
              unref(getSplit) ||
              (!unref(getIsTopMenu) && !unref(getSplit)) ||
              unref(getIsMixSidebar)
V
vben 已提交
242
            }
V
vben 已提交
243 244 245 246
          />
          <SelectItem
            title={t('layout.setting.menuCollapseButton')}
            event={HandlerEnum.MENU_TRIGGER}
V
vben 已提交
247 248
            def={triggerDef}
            options={triggerOptions}
V
vben 已提交
249
            disabled={!unref(getShowMenuRef) || unref(getIsMixSidebar)}
V
vben 已提交
250 251 252 253 254 255 256 257 258
          />
          <SelectItem
            title={t('layout.setting.contentMode')}
            event={HandlerEnum.CONTENT_MODE}
            def={unref(getContentMode)}
            options={contentModeOptions}
          />
          <InputNumberItem
            title={t('layout.setting.autoScreenLock')}
陈文彬 已提交
259
            min={0}
V
vben 已提交
260 261
            event={HandlerEnum.LOCK_TIME}
            defaultValue={unref(getLockTime)}
陈文彬 已提交
262
            formatter={(value: string) => {
V
vben 已提交
263 264 265
              return parseInt(value) === 0
                ? `0(${t('layout.setting.notAutoScreenLock')})`
                : `${value}${t('layout.setting.minute')}`;
陈文彬 已提交
266 267
            }}
          />
V
vben 已提交
268 269
          <InputNumberItem
            title={t('layout.setting.expandedMenuWidth')}
陈文彬 已提交
270 271 272
            max={600}
            min={100}
            step={10}
V
vben 已提交
273
            event={HandlerEnum.MENU_WIDTH}
陈文彬 已提交
274
            disabled={!unref(getShowMenuRef)}
V
vben 已提交
275
            defaultValue={unref(getMenuWidth)}
陈文彬 已提交
276 277
            formatter={(value: string) => `${parseInt(value)}px`}
          />
V
vben 已提交
278 279
        </>
      );
陈文彬 已提交
280 281 282
    }

    function renderContent() {
V
vben 已提交
283 284
      return (
        <>
V
vben 已提交
285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304
          <SwitchItem
            title={t('layout.setting.breadcrumb')}
            event={HandlerEnum.SHOW_BREADCRUMB}
            def={unref(getShowBreadCrumb)}
            disabled={!unref(getShowHeader)}
          />

          <SwitchItem
            title={t('layout.setting.breadcrumbIcon')}
            event={HandlerEnum.SHOW_BREADCRUMB_ICON}
            def={unref(getShowBreadCrumbIcon)}
            disabled={!unref(getShowHeader)}
          />

          <SwitchItem
            title={t('layout.setting.tabs')}
            event={HandlerEnum.TABS_SHOW}
            def={unref(getShowMultipleTab)}
          />

V
vben 已提交
305 306 307 308 309 310 311
          <SwitchItem
            title={t('layout.setting.tabsRedoBtn')}
            event={HandlerEnum.TABS_SHOW_REDO}
            def={unref(getShowRedo)}
            disabled={!unref(getShowMultipleTab)}
          />

V
vben 已提交
312 313 314 315 316 317
          <SwitchItem
            title={t('layout.setting.tabsQuickBtn')}
            event={HandlerEnum.TABS_SHOW_QUICK}
            def={unref(getShowQuick)}
            disabled={!unref(getShowMultipleTab)}
          />
V
vben 已提交
318 319 320 321 322 323
          <SwitchItem
            title={t('layout.setting.tabsFoldBtn')}
            event={HandlerEnum.TABS_SHOW_FOLD}
            def={unref(getShowFold)}
            disabled={!unref(getShowMultipleTab)}
          />
V
vben 已提交
324 325 326 327 328 329 330 331 332 333 334 335 336

          <SwitchItem
            title={t('layout.setting.sidebar')}
            event={HandlerEnum.MENU_SHOW_SIDEBAR}
            def={unref(getShowMenu)}
            disabled={unref(getIsHorizontal)}
          />

          <SwitchItem
            title={t('layout.setting.header')}
            event={HandlerEnum.HEADER_SHOW}
            def={unref(getShowHeader)}
          />
V
vben 已提交
337 338 339 340 341 342
          <SwitchItem
            title="Logo"
            event={HandlerEnum.SHOW_LOGO}
            def={unref(getShowLogo)}
            disabled={unref(getIsMixSidebar)}
          />
V
vben 已提交
343 344 345 346 347 348 349 350 351 352
          <SwitchItem
            title={t('layout.setting.footer')}
            event={HandlerEnum.SHOW_FOOTER}
            def={unref(getShowFooter)}
          />
          <SwitchItem
            title={t('layout.setting.fullContent')}
            event={HandlerEnum.FULL_CONTENT}
            def={unref(getFullContent)}
          />
V
vben 已提交
353

V
vben 已提交
354 355 356 357 358
          <SwitchItem
            title={t('layout.setting.grayMode')}
            event={HandlerEnum.GRAY_MODE}
            def={unref(getGrayMode)}
          />
V
vben 已提交
359

V
vben 已提交
360 361 362 363 364
          <SwitchItem
            title={t('layout.setting.colorWeak')}
            event={HandlerEnum.COLOR_WEAK}
            def={unref(getColorWeak)}
          />
V
vben 已提交
365 366 367 368
        </>
      );
    }

V
vben 已提交
369
    function renderTransition() {
陈文彬 已提交
370
      return (
V
vben 已提交
371 372 373 374 375 376 377 378 379 380
        <>
          <SwitchItem
            title={t('layout.setting.progress')}
            event={HandlerEnum.OPEN_PROGRESS}
            def={unref(getOpenNProgress)}
          />
          <SwitchItem
            title={t('layout.setting.switchLoading')}
            event={HandlerEnum.OPEN_PAGE_LOADING}
            def={unref(getOpenPageLoading)}
陈文彬 已提交
381 382
          />

V
vben 已提交
383 384 385 386
          <SwitchItem
            title={t('layout.setting.switchAnimation')}
            event={HandlerEnum.OPEN_ROUTE_TRANSITION}
            def={unref(getEnableTransition)}
陈文彬 已提交
387
          />
V
vben 已提交
388 389 390 391 392 393 394 395 396

          <SelectItem
            title={t('layout.setting.animationType')}
            event={HandlerEnum.ROUTER_TRANSITION}
            def={unref(getBasicTransition)}
            options={routerTransitionOptions}
            disabled={!unref(getEnableTransition)}
          />
        </>
陈文彬 已提交
397 398
      );
    }
V
vben 已提交
399

陈文彬 已提交
400
    return () => (
V
vben 已提交
401 402 403 404 405 406
      <BasicDrawer
        {...attrs}
        title={t('layout.setting.drawerTitle')}
        width={330}
        wrapClassName="setting-drawer"
      >
V
vben 已提交
407 408
        <Divider>{() => t('layout.setting.navMode')}</Divider>
        {renderSidebar()}
V
vben 已提交
409 410
        <Divider>{() => t('layout.setting.sysTheme')}</Divider>
        {renderMainTheme()}
V
vben 已提交
411 412 413 414 415 416 417 418 419 420 421 422
        <Divider>{() => t('layout.setting.headerTheme')}</Divider>
        {renderHeaderTheme()}
        <Divider>{() => t('layout.setting.sidebarTheme')}</Divider>
        {renderSiderTheme()}
        <Divider>{() => t('layout.setting.interfaceFunction')}</Divider>
        {renderFeatures()}
        <Divider>{() => t('layout.setting.interfaceDisplay')}</Divider>
        {renderContent()}
        <Divider>{() => t('layout.setting.animation')}</Divider>
        {renderTransition()}
        <Divider />
        <SettingFooter />
陈文彬 已提交
423 424 425 426
      </BasicDrawer>
    );
  },
});