@dtdot/lego 0.14.8 → 0.14.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/components/ActionMessage/ActionMessage.stories.js +2 -2
- package/build/components/Menu/Menu.component.d.ts +3 -3
- package/build/components/Menu/Menu.stories.js +5 -5
- package/build/components/Menu/_MenuContent.component.d.ts +1 -5
- package/build/components/Menu/_MenuContent.component.js +3 -14
- package/build/components/Menu/_MenuPage.component.d.ts +2 -1
- package/build/components/Menu/_MenuPage.component.js +8 -10
- package/build/components/Menu/_MenuPanel.component.d.ts +4 -1
- package/build/components/Menu/_MenuPanel.component.js +9 -11
- package/package.json +1 -1
- package/build/components/Menu/_MenuContent.context.d.ts +0 -7
- package/build/components/Menu/_MenuContent.context.js +0 -6
|
@@ -8,8 +8,8 @@ export const Standard = () => (React.createElement(React.Fragment, null,
|
|
|
8
8
|
export const InPanel = () => (React.createElement(React.Fragment, null,
|
|
9
9
|
React.createElement(Menu, null,
|
|
10
10
|
React.createElement(Menu.Heading, null, "Action Message")),
|
|
11
|
-
React.createElement(Menu.Content,
|
|
12
|
-
React.createElement(Menu.Panel,
|
|
11
|
+
React.createElement(Menu.Content, null,
|
|
12
|
+
React.createElement(Menu.Panel, { panelSize: 'sm' },
|
|
13
13
|
React.createElement(ActionMessage, { header: 'Create an asset', info: "It looks like you don't have any assets, create one to get started", action: 'Create', onAction: () => {
|
|
14
14
|
console.log('testing');
|
|
15
15
|
} })),
|
|
@@ -4,10 +4,10 @@ export interface MenuProps {
|
|
|
4
4
|
}
|
|
5
5
|
declare const Menu: {
|
|
6
6
|
({ children }: MenuProps): JSX.Element;
|
|
7
|
-
Page: ({ children }: import("./_MenuPage.component").MenuPageProps) => JSX.Element;
|
|
7
|
+
Page: ({ children, scrollable }: import("./_MenuPage.component").MenuPageProps) => JSX.Element;
|
|
8
8
|
Heading: ({ children }: import("./_MenuHeading.component").MenuHeadingProps) => JSX.Element;
|
|
9
9
|
Item: ({ children, icon, active, onClick }: import("./_MenuItem.component").MenuItemProps) => JSX.Element;
|
|
10
|
-
Content: ({
|
|
11
|
-
Panel: ({ children }: import("./_MenuPanel.component").MenuPanelProps) => JSX.Element;
|
|
10
|
+
Content: ({ children }: import("./_MenuContent.component").MenuContentProps) => JSX.Element;
|
|
11
|
+
Panel: ({ children, scrollable, panelSize }: import("./_MenuPanel.component").MenuPanelProps) => JSX.Element;
|
|
12
12
|
};
|
|
13
13
|
export default Menu;
|
|
@@ -29,8 +29,8 @@ export const WithPanel = () => {
|
|
|
29
29
|
React.createElement(Menu.Item, { icon: faHamburger, active: menuHelpers.isActiveItem([/\/eat/g], route), onClick: () => setRoute('/eat') }, "Eat"),
|
|
30
30
|
React.createElement(Menu.Item, { icon: faCalendarAlt, active: menuHelpers.isActiveItem([/\/plan/g], route), onClick: () => setRoute('/plan') }, "Plan"),
|
|
31
31
|
React.createElement(Menu.Item, { icon: faCogs, active: menuHelpers.isActiveItem([/\/manage/g], route), onClick: () => setRoute('/manage') }, "Manage")),
|
|
32
|
-
React.createElement(Menu.Content,
|
|
33
|
-
React.createElement(Menu.Panel,
|
|
32
|
+
React.createElement(Menu.Content, null,
|
|
33
|
+
React.createElement(Menu.Panel, { panelSize: 'md' },
|
|
34
34
|
React.createElement(PaddedLayout, null,
|
|
35
35
|
React.createElement(ControlGroup, { variation: 'comfortable' },
|
|
36
36
|
React.createElement(Heading.SubHeading, null, "You"),
|
|
@@ -57,8 +57,8 @@ export const IndependentScrolling = () => {
|
|
|
57
57
|
React.createElement(Menu.Item, { icon: faHamburger, active: menuHelpers.isActiveItem([/\/eat/g], route), onClick: () => setRoute('/eat') }, "Eat"),
|
|
58
58
|
React.createElement(Menu.Item, { icon: faCalendarAlt, active: menuHelpers.isActiveItem([/\/plan/g], route), onClick: () => setRoute('/plan') }, "Plan"),
|
|
59
59
|
React.createElement(Menu.Item, { icon: faCogs, active: menuHelpers.isActiveItem([/\/manage/g], route), onClick: () => setRoute('/manage') }, "Manage")),
|
|
60
|
-
React.createElement(Menu.Content,
|
|
61
|
-
React.createElement(Menu.Panel,
|
|
60
|
+
React.createElement(Menu.Content, null,
|
|
61
|
+
React.createElement(Menu.Panel, { panelSize: 'sm', scrollable: true },
|
|
62
62
|
React.createElement(PaddedLayout, null,
|
|
63
63
|
React.createElement(Text, null,
|
|
64
64
|
"Suspendisse sit amet pellentesque nisi. Quisque eget velit sit amet mauris tincidunt dictum id et ex. Integer pulvinar tellus id viverra finibus. Cras dapibus diam a ante eleifend, ac ultrices ligula vestibulum. Nulla gravida ante nec mi tristique, vel elementum arcu volutpat. Nunc in lorem id ligula sodales tincidunt non ut ipsum. Fusce risus eros, dapibus sed lacus et, faucibus auctor purus. Nulla sed rhoncus ligula, at porttitor tellus. Aliquam vitae gravida quam. Interdum et malesuada fames ac ante ipsum primis in faucibus. Pellentesque quis tempus risus.",
|
|
@@ -68,7 +68,7 @@ export const IndependentScrolling = () => {
|
|
|
68
68
|
React.createElement("br", null),
|
|
69
69
|
React.createElement("br", null),
|
|
70
70
|
"Aenean vestibulum aliquam purus ut fringilla. Maecenas aliquet a nunc eget scelerisque. Mauris varius dignissim velit, vitae faucibus massa posuere sit amet. Nulla rutrum enim tellus, eget interdum massa ultricies sed. Proin pulvinar odio non lectus scelerisque, et varius nisl blandit. Donec nisl ante, ultricies eu volutpat ut, dapibus sed ex. Aliquam risus ex, porttitor vel commodo in, convallis laoreet dolor. Proin pretium neque pretium, laoreet dolor ultrices, vulputate sapien. Aenean rutrum lorem non mauris egestas accumsan."))),
|
|
71
|
-
React.createElement(Menu.Page,
|
|
71
|
+
React.createElement(Menu.Page, { scrollable: true },
|
|
72
72
|
React.createElement(ContentLayout, null,
|
|
73
73
|
React.createElement(ContentLayout.Content, { size: 'sm' },
|
|
74
74
|
React.createElement(Text, null,
|
|
@@ -1,10 +1,6 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
|
-
export declare type PanelSize = 'sm' | 'md';
|
|
3
|
-
export declare const getMaxSize: (size: PanelSize) => "tablet" | "desktop";
|
|
4
2
|
export interface MenuContentProps {
|
|
5
3
|
children: React.ReactNode;
|
|
6
|
-
panelSize?: PanelSize;
|
|
7
|
-
independentScroll?: boolean;
|
|
8
4
|
}
|
|
9
|
-
declare const MenuContent: ({
|
|
5
|
+
declare const MenuContent: ({ children }: MenuContentProps) => JSX.Element;
|
|
10
6
|
export default MenuContent;
|
|
@@ -1,16 +1,6 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
import styled from 'styled-components';
|
|
3
3
|
import responsive from '../../responsive/responsive';
|
|
4
|
-
import MenuContentContext from './_MenuContent.context';
|
|
5
|
-
export const getMaxSize = (size) => {
|
|
6
|
-
switch (size) {
|
|
7
|
-
case 'sm':
|
|
8
|
-
return 'tablet';
|
|
9
|
-
case 'md':
|
|
10
|
-
default:
|
|
11
|
-
return 'desktop';
|
|
12
|
-
}
|
|
13
|
-
};
|
|
14
4
|
const MenuContentOuter = styled.div `
|
|
15
5
|
display: flex;
|
|
16
6
|
|
|
@@ -20,12 +10,11 @@ const MenuContentOuter = styled.div `
|
|
|
20
10
|
min-height: 100vh;
|
|
21
11
|
padding: 8px;
|
|
22
12
|
|
|
23
|
-
${
|
|
13
|
+
${responsive.useStylesFor('tablet').andSmaller(`
|
|
24
14
|
flex-direction: column;
|
|
25
15
|
`)}
|
|
26
16
|
`;
|
|
27
|
-
const MenuContent = ({
|
|
28
|
-
return
|
|
29
|
-
React.createElement(MenuContentOuter, { panelSize: panelSize }, children)));
|
|
17
|
+
const MenuContent = ({ children }) => {
|
|
18
|
+
return React.createElement(MenuContentOuter, null, children);
|
|
30
19
|
};
|
|
31
20
|
export default MenuContent;
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
export interface MenuPageProps {
|
|
3
3
|
children: React.ReactNode;
|
|
4
|
+
scrollable?: boolean;
|
|
4
5
|
}
|
|
5
|
-
declare const MenuPage: ({ children }: MenuPageProps) => JSX.Element;
|
|
6
|
+
declare const MenuPage: ({ children, scrollable }: MenuPageProps) => JSX.Element;
|
|
6
7
|
export default MenuPage;
|
|
@@ -1,20 +1,18 @@
|
|
|
1
|
-
import React
|
|
1
|
+
import React from 'react';
|
|
2
2
|
import styled from 'styled-components';
|
|
3
3
|
import responsive from '../../responsive/responsive';
|
|
4
|
-
import { getMaxSize } from './_MenuContent.component';
|
|
5
|
-
import MenuContentContext from './_MenuContent.context';
|
|
6
4
|
const MenuPageInner = styled.div `
|
|
7
5
|
background-color: ${(props) => props.theme.colours.background};
|
|
8
6
|
border-radius: 2px;
|
|
9
7
|
min-height: calc(100vh - 16px);
|
|
10
8
|
flex-grow: 1;
|
|
11
9
|
|
|
12
|
-
${
|
|
10
|
+
${responsive.useStylesFor('tablet').andSmaller(`
|
|
13
11
|
min-height: unset;
|
|
14
12
|
`)}
|
|
15
13
|
|
|
16
|
-
${(props) => props.
|
|
17
|
-
`
|
|
14
|
+
${(props) => responsive.useStylesFor('desktop').andLarger(props.scrollable
|
|
15
|
+
? `
|
|
18
16
|
max-height: calc(100vh - 16px);
|
|
19
17
|
overflow-y: auto;
|
|
20
18
|
|
|
@@ -30,10 +28,10 @@ const MenuPageInner = styled.div `
|
|
|
30
28
|
&::-webkit-scrollbar-track {
|
|
31
29
|
box-shadow: inset 0 0 6px rgba(0, 0, 0, 0.3);
|
|
32
30
|
}
|
|
33
|
-
`
|
|
31
|
+
`
|
|
32
|
+
: ``)}
|
|
34
33
|
`;
|
|
35
|
-
const MenuPage = ({ children }) => {
|
|
36
|
-
|
|
37
|
-
return (React.createElement(MenuPageInner, { panelSize: panelSize, independentScroll: independentScroll }, children));
|
|
34
|
+
const MenuPage = ({ children, scrollable }) => {
|
|
35
|
+
return React.createElement(MenuPageInner, { scrollable: scrollable }, children);
|
|
38
36
|
};
|
|
39
37
|
export default MenuPage;
|
|
@@ -1,6 +1,9 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
|
+
export declare type PanelSize = 'sm' | 'md';
|
|
2
3
|
export interface MenuPanelProps {
|
|
3
4
|
children: React.ReactNode;
|
|
5
|
+
scrollable?: boolean;
|
|
6
|
+
panelSize: PanelSize;
|
|
4
7
|
}
|
|
5
|
-
declare const MenuPanel: ({ children }: MenuPanelProps) => JSX.Element;
|
|
8
|
+
declare const MenuPanel: ({ children, scrollable, panelSize }: MenuPanelProps) => JSX.Element;
|
|
6
9
|
export default MenuPanel;
|
|
@@ -1,8 +1,6 @@
|
|
|
1
|
-
import React
|
|
1
|
+
import React from 'react';
|
|
2
2
|
import styled from 'styled-components';
|
|
3
3
|
import responsive from '../../responsive/responsive';
|
|
4
|
-
import { getMaxSize } from './_MenuContent.component';
|
|
5
|
-
import MenuContentContext from './_MenuContent.context';
|
|
6
4
|
const MenuPanelDiv = styled.div `
|
|
7
5
|
background-color: ${(props) => props.theme.colours.background};
|
|
8
6
|
border-radius: 2px;
|
|
@@ -27,7 +25,7 @@ const MenuPanelDiv = styled.div `
|
|
|
27
25
|
}
|
|
28
26
|
}}
|
|
29
27
|
|
|
30
|
-
${
|
|
28
|
+
${responsive.useStylesFor('tablet').andSmaller(`
|
|
31
29
|
max-width: unset;
|
|
32
30
|
min-width: unset;
|
|
33
31
|
min-height: unset;
|
|
@@ -36,9 +34,9 @@ const MenuPanelDiv = styled.div `
|
|
|
36
34
|
margin-bottom: 8px;
|
|
37
35
|
`)}
|
|
38
36
|
|
|
39
|
-
|
|
40
|
-
`
|
|
41
|
-
|
|
37
|
+
${(props) => responsive.useStylesFor('desktop').andLarger(props.scrollable
|
|
38
|
+
? `
|
|
39
|
+
max-height: calc(100vh - 16px);
|
|
42
40
|
overflow-y: auto;
|
|
43
41
|
|
|
44
42
|
&::-webkit-scrollbar {
|
|
@@ -53,10 +51,10 @@ const MenuPanelDiv = styled.div `
|
|
|
53
51
|
&::-webkit-scrollbar-track {
|
|
54
52
|
box-shadow: inset 0 0 6px rgba(0, 0, 0, 0.3);
|
|
55
53
|
}
|
|
56
|
-
|
|
54
|
+
`
|
|
55
|
+
: ``)}
|
|
57
56
|
`;
|
|
58
|
-
const MenuPanel = ({ children }) => {
|
|
59
|
-
|
|
60
|
-
return (React.createElement(MenuPanelDiv, { panelSize: panelSize, independentScroll: independentScroll }, children));
|
|
57
|
+
const MenuPanel = ({ children, scrollable, panelSize = 'sm' }) => {
|
|
58
|
+
return (React.createElement(MenuPanelDiv, { panelSize: panelSize, scrollable: scrollable }, children));
|
|
61
59
|
};
|
|
62
60
|
export default MenuPanel;
|
package/package.json
CHANGED