SettingDrawer.tsx 11.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 31 32
  menuTypeList,
} from './enum';

33
import { HEADER_PRESET_BG_COLOR_LIST, SIDE_BAR_BG_COLOR_LIST } from '/@/settings/colorSetting';
陈文彬 已提交
34

V
vben 已提交
35
const { t } = useI18n();
V
vben 已提交
36

陈文彬 已提交
37 38 39
export default defineComponent({
  name: 'SettingDrawer',
  setup(_, { attrs }) {
V
vben 已提交
40 41 42 43 44 45 46 47 48
    const {
      getContentMode,
      getShowFooter,
      getShowBreadCrumb,
      getShowBreadCrumbIcon,
      getShowLogo,
      getFullContent,
      getColorWeak,
      getGrayMode,
V
vben 已提交
49
      getLockTime,
V
vben 已提交
50
    } = useRootSetting();
陈文彬 已提交
51

V
vben 已提交
52 53 54 55 56 57 58
    const {
      getOpenPageLoading,
      getBasicTransition,
      getEnableTransition,
      getOpenNProgress,
    } = useTransitionSetting();

V
vben 已提交
59 60 61 62 63
    const {
      getIsHorizontal,
      getShowMenu,
      getMenuType,
      getTrigger,
V
vben 已提交
64
      getCollapsedShowTitle,
V
vben 已提交
65 66
      getMenuFixed,
      getCollapsed,
V
vben 已提交
67
      getCanDrag,
V
vben 已提交
68 69 70 71 72 73
      getTopMenuAlign,
      getAccordion,
      getMenuWidth,
      getMenuBgColor,
      getIsTopMenu,
      getSplit,
V
vben 已提交
74 75
      getIsMixSidebar,
      getCloseMixSidebarOnChange,
V
vben 已提交
76
    } = useMenuSetting();
陈文彬 已提交
77

V
vben 已提交
78 79 80 81 82 83
    const {
      getShowHeader,
      getFixed: getHeaderFixed,
      getHeaderBgColor,
      getShowSearch,
    } = useHeaderSetting();
陈文彬 已提交
84

V
vben 已提交
85
    const { getShowMultipleTab, getShowQuick, getShowRedo } = useMultipleTabSetting();
陈文彬 已提交
86 87

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

V
vben 已提交
91 92 93
    function renderSidebar() {
      return (
        <>
V
vben 已提交
94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110
          <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)}
          />
          <SwitchItem
            title={t('layout.setting.splitMenu')}
            event={HandlerEnum.MENU_SPLIT}
            def={unref(getSplit)}
            disabled={!unref(getShowMenuRef) || unref(getMenuType) !== MenuTypeEnum.MIX}
          />
V
vben 已提交
111 112 113 114 115 116 117

          <SwitchItem
            title={t('layout.setting.closeMixSidebarOnChange')}
            event={HandlerEnum.MENU_CLOSE_MIX_SIDEBAR_ON_CHANGE}
            def={unref(getCloseMixSidebarOnChange)}
            disabled={!unref(getIsMixSidebar)}
          />
V
vben 已提交
118
        </>
陈文彬 已提交
119 120 121
      );
    }

V
vben 已提交
122
    function renderHeaderTheme() {
V
vben 已提交
123
      return (
V
vben 已提交
124 125 126 127 128 129 130 131 132 133 134 135 136 137 138
        <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 已提交
139
      );
V
vben 已提交
140 141
    }

陈文彬 已提交
142 143 144 145
    /**
     * @description:
     */
    function renderFeatures() {
V
vben 已提交
146 147 148 149 150 151 152 153
      let triggerDef = unref(getTrigger);

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

V
vben 已提交
154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177
      return (
        <>
          <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)}
          />
          <SwitchItem
            title={t('layout.setting.menuCollapse')}
            event={HandlerEnum.MENU_COLLAPSED}
            def={unref(getCollapsed)}
V
vben 已提交
178
            disabled={!unref(getShowMenuRef) || unref(getIsMixSidebar)}
V
vben 已提交
179
          />
V
vben 已提交
180 181 182 183 184 185
          <SwitchItem
            title={t('layout.setting.collapseMenuDisplayName')}
            event={HandlerEnum.MENU_COLLAPSED_SHOW_TITLE}
            def={unref(getCollapsedShowTitle)}
            disabled={!unref(getShowMenuRef) || !unref(getCollapsed)}
          />
V
vben 已提交
186

V
vben 已提交
187 188 189 190 191 192 193 194 195 196
          <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 已提交
197
            disabled={!unref(getShowMenuRef) || unref(getIsMixSidebar)}
V
vben 已提交
198 199 200 201 202 203
          />
          <SelectItem
            title={t('layout.setting.topMenuLayout')}
            event={HandlerEnum.MENU_TOP_ALIGN}
            def={unref(getTopMenuAlign)}
            options={topMenuAlignOptions}
V
vben 已提交
204
            disabled={
V
vben 已提交
205 206 207 208
              !unref(getShowHeader) ||
              unref(getSplit) ||
              (!unref(getIsTopMenu) && !unref(getSplit)) ||
              unref(getIsMixSidebar)
V
vben 已提交
209
            }
V
vben 已提交
210 211 212 213
          />
          <SelectItem
            title={t('layout.setting.menuCollapseButton')}
            event={HandlerEnum.MENU_TRIGGER}
V
vben 已提交
214 215
            def={triggerDef}
            options={triggerOptions}
V
vben 已提交
216
            disabled={!unref(getShowMenuRef) || unref(getIsMixSidebar)}
V
vben 已提交
217 218 219 220 221 222 223 224 225
          />
          <SelectItem
            title={t('layout.setting.contentMode')}
            event={HandlerEnum.CONTENT_MODE}
            def={unref(getContentMode)}
            options={contentModeOptions}
          />
          <InputNumberItem
            title={t('layout.setting.autoScreenLock')}
陈文彬 已提交
226
            min={0}
V
vben 已提交
227 228
            event={HandlerEnum.LOCK_TIME}
            defaultValue={unref(getLockTime)}
陈文彬 已提交
229
            formatter={(value: string) => {
V
vben 已提交
230 231 232
              return parseInt(value) === 0
                ? `0(${t('layout.setting.notAutoScreenLock')})`
                : `${value}${t('layout.setting.minute')}`;
陈文彬 已提交
233 234
            }}
          />
V
vben 已提交
235 236
          <InputNumberItem
            title={t('layout.setting.expandedMenuWidth')}
陈文彬 已提交
237 238 239
            max={600}
            min={100}
            step={10}
V
vben 已提交
240
            event={HandlerEnum.MENU_WIDTH}
陈文彬 已提交
241
            disabled={!unref(getShowMenuRef)}
V
vben 已提交
242
            defaultValue={unref(getMenuWidth)}
陈文彬 已提交
243 244
            formatter={(value: string) => `${parseInt(value)}px`}
          />
V
vben 已提交
245 246
        </>
      );
陈文彬 已提交
247 248 249
    }

    function renderContent() {
V
vben 已提交
250 251
      return (
        <>
V
vben 已提交
252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271
          <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 已提交
272 273 274 275 276 277 278
          <SwitchItem
            title={t('layout.setting.tabsRedoBtn')}
            event={HandlerEnum.TABS_SHOW_REDO}
            def={unref(getShowRedo)}
            disabled={!unref(getShowMultipleTab)}
          />

V
vben 已提交
279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297
          <SwitchItem
            title={t('layout.setting.tabsQuickBtn')}
            event={HandlerEnum.TABS_SHOW_QUICK}
            def={unref(getShowQuick)}
            disabled={!unref(getShowMultipleTab)}
          />

          <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 已提交
298 299 300 301 302 303
          <SwitchItem
            title="Logo"
            event={HandlerEnum.SHOW_LOGO}
            def={unref(getShowLogo)}
            disabled={unref(getIsMixSidebar)}
          />
V
vben 已提交
304 305 306 307 308 309 310 311 312 313
          <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 已提交
314

V
vben 已提交
315 316 317 318 319
          <SwitchItem
            title={t('layout.setting.grayMode')}
            event={HandlerEnum.GRAY_MODE}
            def={unref(getGrayMode)}
          />
V
vben 已提交
320

V
vben 已提交
321 322 323 324 325
          <SwitchItem
            title={t('layout.setting.colorWeak')}
            event={HandlerEnum.COLOR_WEAK}
            def={unref(getColorWeak)}
          />
V
vben 已提交
326 327 328 329
        </>
      );
    }

V
vben 已提交
330
    function renderTransition() {
陈文彬 已提交
331
      return (
V
vben 已提交
332 333 334 335 336 337 338 339 340 341
        <>
          <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)}
陈文彬 已提交
342 343
          />

V
vben 已提交
344 345 346 347
          <SwitchItem
            title={t('layout.setting.switchAnimation')}
            event={HandlerEnum.OPEN_ROUTE_TRANSITION}
            def={unref(getEnableTransition)}
陈文彬 已提交
348
          />
V
vben 已提交
349 350 351 352 353 354 355 356 357

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

陈文彬 已提交
361
    return () => (
V
vben 已提交
362 363 364 365 366 367
      <BasicDrawer
        {...attrs}
        title={t('layout.setting.drawerTitle')}
        width={330}
        wrapClassName="setting-drawer"
      >
陈文彬 已提交
368 369 370
        {{
          default: () => (
            <>
V
vben 已提交
371
              <Divider>{() => t('layout.setting.navMode')}</Divider>
陈文彬 已提交
372
              {renderSidebar()}
V
vben 已提交
373 374 375 376
              <Divider>{() => t('layout.setting.headerTheme')}</Divider>
              {renderHeaderTheme()}
              <Divider>{() => t('layout.setting.sidebarTheme')}</Divider>
              {renderSiderTheme()}
V
vben 已提交
377
              <Divider>{() => t('layout.setting.interfaceFunction')}</Divider>
陈文彬 已提交
378
              {renderFeatures()}
V
vben 已提交
379
              <Divider>{() => t('layout.setting.interfaceDisplay')}</Divider>
陈文彬 已提交
380
              {renderContent()}
V
vben 已提交
381
              <Divider>{() => t('layout.setting.animation')}</Divider>
陈文彬 已提交
382 383
              {renderTransition()}
              <Divider />
V
vben 已提交
384
              <SettingFooter />
陈文彬 已提交
385 386 387 388 389 390 391
            </>
          ),
        }}
      </BasicDrawer>
    );
  },
});