-
Notifications
You must be signed in to change notification settings - Fork 13.5k
Expand file tree
/
Copy pathLayoutProvider.tsx
More file actions
115 lines (104 loc) · 3.81 KB
/
LayoutProvider.tsx
File metadata and controls
115 lines (104 loc) · 3.81 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
import { useBreakpoints } from '@rocket.chat/fuselage-hooks';
import { useFeaturePreview } from '@rocket.chat/ui-client';
import { LayoutContext, useRouter, useSetting } from '@rocket.chat/ui-contexts';
import type { ReactNode } from 'react';
import { useMemo, useState, useEffect } from 'react';
const hiddenActionsDefaultValue = {
roomToolbox: [],
messageToolbox: [],
composerToolbox: [],
userToolbox: [],
};
type LayoutProviderProps = {
children?: ReactNode;
};
const LayoutProvider = ({ children }: LayoutProviderProps) => {
const showTopNavbarEmbeddedLayout = useSetting('UI_Show_top_navbar_embedded_layout', false);
const [isCollapsed, setIsCollapsed] = useState(false);
const [displaySidePanel, setDisplaySidePanel] = useState(true);
const [overlayed, setOverlayed] = useState(false);
const [navBarSearchExpanded, setNavBarSearchExpanded] = useState(false);
const breakpoints = useBreakpoints(); // ["xs", "sm", "md", "lg", "xl", xxl"]
const [hiddenActions, setHiddenActions] = useState(hiddenActionsDefaultValue);
const enhancedNavigationEnabled = useFeaturePreview('newNavigation');
const secondSidebarEnabled = useFeaturePreview('secondarySidebar');
const router = useRouter();
// Once the layout is embedded, it can't be changed
const [isEmbedded] = useState(() => router.getSearchParameters().layout === 'embedded');
const isMobile = !breakpoints.includes('md');
const isTablet = !breakpoints.includes('lg');
const shouldToggle = enhancedNavigationEnabled ? isTablet || isMobile : isMobile;
const shouldDisplaySidePanel = !isTablet || displaySidePanel;
const defaultSidebarWidth = secondSidebarEnabled ? '220px' : '240px';
useEffect(() => {
setIsCollapsed(shouldToggle);
}, [shouldToggle]);
useEffect(() => {
const eventHandler = (event: MessageEvent<any>) => {
if (event.data?.event !== 'overrideUi') {
return;
}
setHiddenActions({ ...hiddenActionsDefaultValue, ...event.data.hideActions });
};
window.addEventListener('message', eventHandler);
return () => window.removeEventListener('message', eventHandler);
}, []);
return (
<LayoutContext.Provider
children={children}
value={useMemo(
() => ({
isMobile,
isTablet,
isEmbedded,
showTopNavbarEmbeddedLayout,
navbar: {
searchExpanded: navBarSearchExpanded,
expandSearch: isMobile ? () => setNavBarSearchExpanded(true) : undefined,
collapseSearch: isMobile ? () => setNavBarSearchExpanded(false) : undefined,
},
sidebar: {
overlayed,
setOverlayed,
isCollapsed,
toggle: shouldToggle ? () => setIsCollapsed((isCollapsed) => !isCollapsed) : () => undefined,
collapse: () => setIsCollapsed(true),
expand: () => setIsCollapsed(false),
close: () => (isEmbedded ? setIsCollapsed(true) : router.navigate('/home')),
},
sidePanel: {
displaySidePanel: shouldDisplaySidePanel,
closeSidePanel: () => setDisplaySidePanel(false),
openSidePanel: () => setDisplaySidePanel(true),
},
size: {
sidebar: isTablet ? '280px' : defaultSidebarWidth,
// eslint-disable-next-line no-nested-ternary
contextualBar: breakpoints.includes('sm') ? (breakpoints.includes('xl') ? '38%' : '380px') : '100%',
},
roomToolboxExpanded: breakpoints.includes('lg'),
contextualBarExpanded: breakpoints.includes('sm'),
// eslint-disable-next-line no-nested-ternary
contextualBarPosition: breakpoints.includes('sm') ? (breakpoints.includes('lg') ? 'relative' : 'absolute') : 'fixed',
hiddenActions,
}),
[
isMobile,
isTablet,
isEmbedded,
showTopNavbarEmbeddedLayout,
navBarSearchExpanded,
overlayed,
isCollapsed,
shouldToggle,
shouldDisplaySidePanel,
defaultSidebarWidth,
breakpoints,
hiddenActions,
router,
],
)}
/>
);
};
export default LayoutProvider;