Skip to content

Commit

Permalink
feat(MultipleTab): add tabs auto collapse interaction in fold mode an…
Browse files Browse the repository at this point in the history
…d setting (#3256)

* fix: validateFields await missing

* feat(MultipleTab): add tabs auto collapse interaction and setting

* chore(locales): update  setting name to better reflect its purpose

---------

Co-authored-by: invalid w <wangjuesix@gmail.com>
  • Loading branch information
xachary and wangjue666 authored Nov 9, 2023
1 parent b976933 commit 191e809
Show file tree
Hide file tree
Showing 13 changed files with 262 additions and 185 deletions.
3 changes: 3 additions & 0 deletions src/hooks/setting/useMultipleTabSetting.ts
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,8 @@ export function useMultipleTabSetting() {

const getShowFold = computed(() => appStore.getMultiTabsSetting.showFold);

const getAutoCollapse = computed(() => appStore.getMultiTabsSetting.autoCollapse);

function setMultipleTabSetting(multiTabsSetting: Partial<MultiTabsSetting>) {
appStore.setProjectConfig({ multiTabsSetting });
}
Expand All @@ -24,5 +26,6 @@ export function useMultipleTabSetting() {
getShowQuick,
getShowRedo,
getShowFold,
getAutoCollapse,
};
}
38 changes: 25 additions & 13 deletions src/layouts/default/header/MultipleHeader.vue
Original file line number Diff line number Diff line change
@@ -1,5 +1,9 @@
<template>
<div :style="getPlaceholderDomStyle" v-if="getIsShowPlaceholderDom"></div>
<div
:class="[`${prefixCls}__placeholder`]"
:style="getPlaceholderDomStyle"
v-if="getIsShowPlaceholderDom"
></div>
<div :style="getWrapStyle" :class="getClass">
<LayoutHeader v-if="getShowInsetHeaderRef" />
<MultipleTabs v-if="getShowTabs" :key="tabStore.getLastDragEndIndex" />
Expand Down Expand Up @@ -31,7 +35,7 @@
const tabStore = useMultipleTabStore();
const { prefixCls } = useDesign('layout-multiple-header');
const { getCalcContentWidth, getSplit } = useMenuSetting();
const { getCalcContentWidth, getSplit, getShowMenu } = useMenuSetting();
const { getIsMobile } = useAppInject();
const {
getFixed,
Expand All @@ -43,7 +47,7 @@
const { getFullContent } = useFullContent();
const { getShowMultipleTab } = useMultipleTabSetting();
const { getShowMultipleTab, getAutoCollapse } = useMultipleTabSetting();
const getShowTabs = computed(() => {
return unref(getShowMultipleTab) && !unref(getFullContent);
Expand All @@ -68,19 +72,23 @@
return unref(getFixed) || unref(getShowFullHeaderRef);
});
const getIsUnFold = computed(() => !unref(getShowMenu) && !unref(getShowHeader));
const getPlaceholderDomStyle = computed((): CSSProperties => {
let height = 0;
if (
(unref(getShowFullHeaderRef) || !unref(getSplit)) &&
unref(getShowHeader) &&
!unref(getFullContent)
) {
height += HEADER_HEIGHT;
}
if (unref(getShowMultipleTab) && !unref(getFullContent)) {
height += TABS_HEIGHT;
if (!(unref(getAutoCollapse) && unref(getIsUnFold))) {
if (
(unref(getShowFullHeaderRef) || !unref(getSplit)) &&
unref(getShowHeader) &&
!unref(getFullContent)
) {
height += HEADER_HEIGHT;
}
if (unref(getShowMultipleTab) && !unref(getFullContent)) {
height += TABS_HEIGHT;
}
setHeaderHeight(height);
}
setHeaderHeight(height);
return {
height: `${height}px`,
};
Expand Down Expand Up @@ -125,5 +133,9 @@
top: 0;
width: 100%;
}
&__placeholder {
transition: height 0.6s ease-in-out;
}
}
</style>
20 changes: 19 additions & 1 deletion src/layouts/default/index.vue
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
<Layout :class="prefixCls" v-bind="lockEvents">
<LayoutFeatures />
<LayoutHeader fixed v-if="getShowFullHeaderRef" />
<Layout :class="[layoutClass]">
<Layout :class="[layoutClass, `${prefixCls}-out`]">
<LayoutSideBar v-if="getShowSidebar || getIsMobile" />
<Layout :class="`${prefixCls}-main`">
<LayoutMultipleHeader />
Expand Down Expand Up @@ -30,6 +30,8 @@
import { useAppInject } from '/@/hooks/web/useAppInject';
import { useMultipleTabSetting } from '/@/hooks/setting/useMultipleTabSetting';
export default defineComponent({
name: 'DefaultLayout',
components: {
Expand All @@ -46,6 +48,7 @@
const { getIsMobile } = useAppInject();
const { getShowFullHeaderRef } = useHeaderSetting();
const { getShowSidebar, getIsMixSidebar, getShowMenu } = useMenuSetting();
const { getAutoCollapse } = useMultipleTabSetting();
// Create a lock screen monitor
const lockEvents = useLockPage();
Expand All @@ -55,6 +58,11 @@
if (unref(getIsMixSidebar) || unref(getShowMenu)) {
cls.push('ant-layout-has-sider');
}
if (!unref(getShowMenu) && unref(getAutoCollapse)) {
cls.push('ant-layout-auto-collapse-tabs');
}
return cls;
});
Expand Down Expand Up @@ -89,4 +97,14 @@
margin-left: 1px;
}
}
.@{prefix-cls}-out {
&.ant-layout-has-sider {
.@{prefix-cls} {
&-main {
margin-left: 1px;
}
}
}
}
</style>
9 changes: 8 additions & 1 deletion src/layouts/default/setting/SettingDrawer.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -89,7 +89,8 @@ export default defineComponent({
getShowSearch,
} = useHeaderSetting();

const { getShowMultipleTab, getShowQuick, getShowRedo, getShowFold } = useMultipleTabSetting();
const { getShowMultipleTab, getShowQuick, getShowRedo, getShowFold, getAutoCollapse } =
useMultipleTabSetting();

const getShowMenuRef = computed(() => {
return unref(getShowMenu) && !unref(getIsHorizontal);
Expand Down Expand Up @@ -221,6 +222,12 @@ export default defineComponent({
def={unref(getMenuFixed)}
disabled={!unref(getShowMenuRef) || unref(getIsMixSidebar)}
/>
<SwitchItem
title={t('layout.setting.autoCollapseTabsInFold')}
event={HandlerEnum.TABS_AUTO_COLLAPSE}
def={unref(getAutoCollapse)}
disabled={!unref(getShowMultipleTab)}
/>
<SelectItem
title={t('layout.setting.mixSidebarTrigger')}
event={HandlerEnum.MENU_TRIGGER_MIX_SIDEBAR}
Expand Down
1 change: 1 addition & 0 deletions src/layouts/default/setting/enum.ts
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,7 @@ export enum HandlerEnum {
TABS_SHOW_REDO,
TABS_SHOW,
TABS_SHOW_FOLD,
TABS_AUTO_COLLAPSE,

LOCK_TIME,
FULL_CONTENT,
Expand Down
3 changes: 3 additions & 0 deletions src/layouts/default/setting/handler.ts
Original file line number Diff line number Diff line change
Expand Up @@ -153,6 +153,9 @@ export function handler(event: HandlerEnum, value: any): DeepPartial<ProjectConf
case HandlerEnum.TABS_SHOW_FOLD:
return { multiTabsSetting: { showFold: value } };

case HandlerEnum.TABS_AUTO_COLLAPSE:
return { multiTabsSetting: { autoCollapse: value } };

// ============header==================
case HandlerEnum.HEADER_THEME:
updateHeaderBgColor(value);
Expand Down
20 changes: 20 additions & 0 deletions src/layouts/default/tabs/index.less
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
@prefix-cls: ~'@{namespace}-multiple-tabs';
@prefix-cls-default-layout: ~'@{namespace}-default-layout';

html[data-theme='light'] {
.@{prefix-cls} {
Expand All @@ -8,6 +9,25 @@ html[data-theme='light'] {
}
}

.@{prefix-cls-default-layout}-out {
&.ant-layout-auto-collapse-tabs {
.@{prefix-cls} {
margin-top: -(@multiple-height + 2);
opacity: 0.1;

&:hover,
&--hover {
margin-top: 0;
transition-delay: 0s;
opacity: 1;
}
}
}
.@{prefix-cls} {
transition: margin 0.2s ease-in-out 0.6s, opacity 0.2s ease-in-out 0.6s;
}
}

.@{prefix-cls} {
z-index: 10;
height: @multiple-height + 2;
Expand Down
6 changes: 6 additions & 0 deletions src/layouts/default/tabs/index.vue
Original file line number Diff line number Diff line change
Expand Up @@ -50,6 +50,9 @@
import { useRouter } from 'vue-router';
import { useMouse } from '@vueuse/core';
import { multipleTabHeight } from '/@/settings/designSetting';
export default defineComponent({
name: 'MultipleTabs',
components: {
Expand Down Expand Up @@ -78,11 +81,14 @@
const unClose = computed(() => unref(getTabsState).length === 1);
const { y: mouseY } = useMouse();
const getWrapClass = computed(() => {
return [
prefixCls,
{
[`${prefixCls}--hide-close`]: unref(unClose),
[`${prefixCls}--hover`]: unref(mouseY) < multipleTabHeight,
},
];
});
Expand Down
Loading

0 comments on commit 191e809

Please sign in to comment.