@zesty-io/material 0.2.5 → 0.3.1
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/es/ConfirmDialog/ConfirmDialog.stories.d.ts +6 -0
- package/es/ConfirmDialog/ConfirmDialog.stories.js +24 -0
- package/es/ConfirmDialog/index.d.ts +18 -0
- package/es/ConfirmDialog/index.js +11 -0
- package/es/ConfirmModal/ConfirmModal.stories.d.ts +6 -0
- package/es/ConfirmModal/ConfirmModal.stories.js +24 -0
- package/es/ConfirmModal/index.d.ts +18 -0
- package/es/ConfirmModal/index.js +11 -0
- package/es/CopyButton/CopyButton.stories.d.ts +5 -0
- package/es/CopyButton/CopyButton.stories.js +14 -0
- package/es/CopyButton/index.d.ts +10 -0
- package/es/CopyButton/index.js +26 -0
- package/es/FieldTypeColor/FieldTypeColor.stories.d.ts +5 -0
- package/es/FieldTypeColor/FieldTypeColor.stories.js +21 -0
- package/es/FieldTypeColor/index.d.ts +6 -0
- package/es/FieldTypeColor/index.js +16 -0
- package/es/FieldTypeDate/FieldTypeDate.stories.d.ts +5 -0
- package/es/FieldTypeDate/FieldTypeDate.stories.js +17 -0
- package/es/FieldTypeDate/index.d.ts +9 -0
- package/es/FieldTypeDate/index.js +10 -0
- package/es/FieldTypeDateTime/FieldTypeDateTime.stories.d.ts +5 -0
- package/es/FieldTypeDateTime/FieldTypeDateTime.stories.js +17 -0
- package/es/FieldTypeDateTime/index.d.ts +9 -0
- package/es/FieldTypeDateTime/index.js +10 -0
- package/es/FieldTypeDropdown/FieldTypeDropwdon.stories.d.ts +5 -0
- package/es/FieldTypeDropdown/FieldTypeDropwdon.stories.js +35 -0
- package/es/FieldTypeDropdown/index.d.ts +11 -0
- package/es/FieldTypeDropdown/index.js +10 -0
- package/es/FieldTypeNumber/FieldTypeNumber.stories.d.ts +5 -0
- package/es/FieldTypeNumber/FieldTypeNumber.stories.js +21 -0
- package/es/FieldTypeNumber/index.d.ts +6 -0
- package/es/FieldTypeNumber/index.js +7 -0
- package/es/FieldTypeOneToMany/FieldTypeOneToMany.stories.d.ts +5 -0
- package/es/FieldTypeOneToMany/FieldTypeOneToMany.stories.js +28 -0
- package/es/FieldTypeOneToMany/index.d.ts +32 -0
- package/es/FieldTypeOneToMany/index.js +29 -0
- package/es/FieldTypeOneToOne/FieldTypeOneToOne.stories.d.ts +5 -0
- package/es/FieldTypeOneToOne/FieldTypeOneToOne.stories.js +28 -0
- package/es/FieldTypeOneToOne/index.d.ts +34 -0
- package/es/FieldTypeOneToOne/index.js +33 -0
- package/es/FieldTypeSort/FieldTypeSort.stories.d.ts +5 -0
- package/es/FieldTypeSort/FieldTypeSort.stories.js +22 -0
- package/es/FieldTypeSort/index.d.ts +7 -0
- package/es/FieldTypeSort/index.js +34 -0
- package/es/FieldTypeText/FieldTypeText.stories.d.ts +6 -0
- package/es/FieldTypeText/FieldTypeText.stories.js +29 -0
- package/es/FieldTypeText/index.d.ts +12 -0
- package/es/FieldTypeText/index.js +7 -0
- package/es/FieldTypeUrl/FieldTypeUrl.stories.d.ts +5 -0
- package/es/FieldTypeUrl/FieldTypeUrl.stories.js +21 -0
- package/es/FieldTypeUrl/index.d.ts +12 -0
- package/es/FieldTypeUrl/index.js +14 -0
- package/es/LegacyTheme/index.d.ts +3 -0
- package/es/LegacyTheme/index.js +83 -0
- package/es/LegacyTheme/palette.d.ts +3 -0
- package/es/LegacyTheme/palette.js +23 -0
- package/{src/LegacyTheme/typography.ts → es/LegacyTheme/typography.d.ts} +1 -5
- package/es/LegacyTheme/typography.js +4 -0
- package/es/TextField.stories.d.ts +5 -0
- package/es/TextField.stories.js +18 -0
- package/es/VitualizedAutocomplete/VirtualizedAutocomplete.stories.d.ts +5 -0
- package/es/VitualizedAutocomplete/VirtualizedAutocomplete.stories.js +27 -0
- package/es/VitualizedAutocomplete/index.d.ts +28 -0
- package/es/VitualizedAutocomplete/index.js +21 -0
- package/es/icons/FolderGlobal.d.ts +3 -0
- package/es/icons/FolderGlobal.js +3 -0
- package/es/icons/index.d.ts +1 -0
- package/es/icons/index.js +1 -0
- package/{src/index.ts → es/index.d.ts} +4 -3
- package/es/index.js +15 -0
- package/es/stories/Theme.stories.d.ts +4 -0
- package/es/stories/Theme.stories.js +10 -0
- package/es/theme/Theme.stories.d.ts +4 -0
- package/es/theme/Theme.stories.js +10 -0
- package/es/theme/index.d.ts +11 -0
- package/es/theme/index.js +210 -0
- package/es/theme/palette.d.ts +16 -0
- package/es/theme/palette.js +138 -0
- package/es/theme/typography.d.ts +9 -0
- package/es/theme/typography.js +57 -0
- package/es/utils/virtualization.d.ts +2 -0
- package/es/utils/virtualization.js +63 -0
- package/package.json +12 -10
- package/.storybook/main.js +0 -25
- package/.storybook/preview-head.html +0 -1
- package/.storybook/preview.js +0 -15
- package/src/ConfirmDialog/ConfirmDialog.stories.tsx +0 -35
- package/src/ConfirmDialog/index.tsx +0 -50
- package/src/CopyButton/CopyButton.stories.tsx +0 -20
- package/src/CopyButton/index.tsx +0 -55
- package/src/FieldTypeColor/FieldTypeColor.stories.tsx +0 -35
- package/src/FieldTypeColor/index.tsx +0 -43
- package/src/FieldTypeDate/FieldTypeDate.stories.tsx +0 -23
- package/src/FieldTypeDate/index.tsx +0 -35
- package/src/FieldTypeDateTime/FieldTypeDateTime.stories.tsx +0 -23
- package/src/FieldTypeDateTime/index.tsx +0 -36
- package/src/FieldTypeNumber/FieldTypeNumber.stories.tsx +0 -35
- package/src/FieldTypeNumber/index.tsx +0 -22
- package/src/FieldTypeOneToMany/FieldTypeOneToMany.stories.tsx +0 -47
- package/src/FieldTypeOneToMany/index.tsx +0 -90
- package/src/FieldTypeOneToOne/FieldTypeOneToOne.stories.tsx +0 -46
- package/src/FieldTypeOneToOne/index.tsx +0 -96
- package/src/FieldTypeSort/FieldTypeSort.stories.tsx +0 -36
- package/src/FieldTypeSort/index.tsx +0 -70
- package/src/FieldTypeText/FieldTypeText.stories.tsx +0 -45
- package/src/FieldTypeText/index.tsx +0 -35
- package/src/FieldTypeUrl/FieldTypeUrl.stories.tsx +0 -33
- package/src/FieldTypeUrl/index.tsx +0 -44
- package/src/LegacyTheme/index.ts +0 -88
- package/src/LegacyTheme/palette.ts +0 -25
- package/src/VitualizedAutocomplete/VirtualizedAutocomplete.stories.tsx +0 -45
- package/src/VitualizedAutocomplete/index.tsx +0 -69
- package/src/theme/Theme.stories.tsx +0 -16
- package/src/theme/index.ts +0 -53
- package/src/theme/palette.ts +0 -153
- package/src/theme/typography.ts +0 -69
- package/src/utils/virtualization.tsx +0 -107
- package/tsconfig.json +0 -22
|
@@ -0,0 +1,210 @@
|
|
|
1
|
+
import palette from './palette';
|
|
2
|
+
import typography from './typography';
|
|
3
|
+
import { alpha, createTheme, } from '@mui/material/styles';
|
|
4
|
+
let theme = createTheme({
|
|
5
|
+
palette,
|
|
6
|
+
typography,
|
|
7
|
+
});
|
|
8
|
+
theme = createTheme(theme, {
|
|
9
|
+
components: {
|
|
10
|
+
MuiFormLabel: {
|
|
11
|
+
styleOverrides: {
|
|
12
|
+
root: {
|
|
13
|
+
...theme.typography.body2,
|
|
14
|
+
},
|
|
15
|
+
},
|
|
16
|
+
},
|
|
17
|
+
MuiTab: {
|
|
18
|
+
styleOverrides: {
|
|
19
|
+
root: {
|
|
20
|
+
borderBottom: 2,
|
|
21
|
+
borderColor: theme.palette.grey[100],
|
|
22
|
+
borderStyle: "solid",
|
|
23
|
+
},
|
|
24
|
+
},
|
|
25
|
+
},
|
|
26
|
+
MuiCardHeader: {
|
|
27
|
+
styleOverrides: {
|
|
28
|
+
root: {
|
|
29
|
+
padding: "16px 16px 0px",
|
|
30
|
+
},
|
|
31
|
+
},
|
|
32
|
+
},
|
|
33
|
+
MuiCardContent: {
|
|
34
|
+
styleOverrides: {
|
|
35
|
+
root: {
|
|
36
|
+
padding: "8px 16px 16px",
|
|
37
|
+
":last-child": {
|
|
38
|
+
paddingBottom: "16px",
|
|
39
|
+
},
|
|
40
|
+
},
|
|
41
|
+
},
|
|
42
|
+
},
|
|
43
|
+
MuiButton: {
|
|
44
|
+
styleOverrides: {
|
|
45
|
+
root: {
|
|
46
|
+
textTransform: 'none',
|
|
47
|
+
},
|
|
48
|
+
sizeSmall: {
|
|
49
|
+
fontSize: '14px',
|
|
50
|
+
},
|
|
51
|
+
outlined: {
|
|
52
|
+
borderColor: theme.palette.border,
|
|
53
|
+
},
|
|
54
|
+
containedInherit: {
|
|
55
|
+
backgroundColor: theme.palette.grey[100],
|
|
56
|
+
},
|
|
57
|
+
textInherit: {
|
|
58
|
+
color: theme.palette.text.secondary,
|
|
59
|
+
}
|
|
60
|
+
},
|
|
61
|
+
defaultProps: {
|
|
62
|
+
disableElevation: true,
|
|
63
|
+
},
|
|
64
|
+
},
|
|
65
|
+
MuiOutlinedInput: {
|
|
66
|
+
styleOverrides: {
|
|
67
|
+
root: {
|
|
68
|
+
padding: "0px 8px",
|
|
69
|
+
borderRadius: '8px',
|
|
70
|
+
},
|
|
71
|
+
input: {
|
|
72
|
+
padding: "10px 0px",
|
|
73
|
+
},
|
|
74
|
+
sizeSmall: {
|
|
75
|
+
'input': {
|
|
76
|
+
padding: "8px 0px",
|
|
77
|
+
},
|
|
78
|
+
},
|
|
79
|
+
notchedOutline: {
|
|
80
|
+
// Important to override all pseudo classes
|
|
81
|
+
borderColor: `${theme.palette.border} !important`,
|
|
82
|
+
},
|
|
83
|
+
}
|
|
84
|
+
},
|
|
85
|
+
MuiInputBase: {
|
|
86
|
+
styleOverrides: {
|
|
87
|
+
input: {
|
|
88
|
+
...theme.typography.body2,
|
|
89
|
+
'::placeholder': {
|
|
90
|
+
color: theme.palette.text.disabled
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
},
|
|
95
|
+
MuiInputLabel: {
|
|
96
|
+
styleOverrides: {
|
|
97
|
+
root: {
|
|
98
|
+
...theme.typography.body2,
|
|
99
|
+
color: theme.palette.text.primary,
|
|
100
|
+
marginBottom: '4px',
|
|
101
|
+
},
|
|
102
|
+
},
|
|
103
|
+
},
|
|
104
|
+
MuiInputAdornment: {
|
|
105
|
+
styleOverrides: {
|
|
106
|
+
root: {
|
|
107
|
+
'& > .MuiSvgIcon-root': {
|
|
108
|
+
margin: '4px',
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
},
|
|
113
|
+
MuiIconButton: {
|
|
114
|
+
styleOverrides: {
|
|
115
|
+
sizeSmall: {
|
|
116
|
+
padding: '4px',
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
},
|
|
120
|
+
MuiDialog: {
|
|
121
|
+
styleOverrides: {
|
|
122
|
+
paperWidthXs: {
|
|
123
|
+
width: '480px',
|
|
124
|
+
maxWidth: '480px',
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
},
|
|
128
|
+
MuiDialogTitle: {
|
|
129
|
+
styleOverrides: {
|
|
130
|
+
root: {
|
|
131
|
+
...theme.typography.h5,
|
|
132
|
+
fontWeight: 600,
|
|
133
|
+
padding: '20px',
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
},
|
|
137
|
+
MuiDialogContent: {
|
|
138
|
+
styleOverrides: {
|
|
139
|
+
root: {
|
|
140
|
+
padding: '20px',
|
|
141
|
+
paddingTop: 0,
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
},
|
|
145
|
+
MuiDialogContentText: {
|
|
146
|
+
styleOverrides: {
|
|
147
|
+
root: {
|
|
148
|
+
...theme.typography.body2,
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
},
|
|
152
|
+
MuiDialogActions: {
|
|
153
|
+
styleOverrides: {
|
|
154
|
+
root: {
|
|
155
|
+
padding: '20px',
|
|
156
|
+
paddingTop: 0,
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
},
|
|
160
|
+
MuiBackdrop: {
|
|
161
|
+
styleOverrides: {
|
|
162
|
+
root: {
|
|
163
|
+
backgroundColor: alpha(theme.palette.grey[900], 0.5),
|
|
164
|
+
},
|
|
165
|
+
invisible: {
|
|
166
|
+
backgroundColor: 'transparent',
|
|
167
|
+
}
|
|
168
|
+
},
|
|
169
|
+
},
|
|
170
|
+
MuiMenu: {
|
|
171
|
+
styleOverrides: {
|
|
172
|
+
list: {
|
|
173
|
+
minWidth: '240px',
|
|
174
|
+
}
|
|
175
|
+
},
|
|
176
|
+
},
|
|
177
|
+
MuiTreeItem: {
|
|
178
|
+
styleOverrides: {
|
|
179
|
+
content: {
|
|
180
|
+
paddingTop: '6px',
|
|
181
|
+
paddingBottom: '6px',
|
|
182
|
+
paddingLeft: 0,
|
|
183
|
+
paddingRight: '12px',
|
|
184
|
+
borderRadius: 4,
|
|
185
|
+
width: "unset",
|
|
186
|
+
'&.Mui-selected': {
|
|
187
|
+
background: alpha(theme.palette.primary.main, 0.04),
|
|
188
|
+
' .MuiTreeItem-label .MuiSvgIcon-root': {
|
|
189
|
+
color: theme.palette.primary.main,
|
|
190
|
+
},
|
|
191
|
+
' .MuiTypography-root': {
|
|
192
|
+
color: theme.palette.primary.dark,
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
},
|
|
196
|
+
label: {
|
|
197
|
+
paddingLeft: '0',
|
|
198
|
+
},
|
|
199
|
+
iconContainer: {
|
|
200
|
+
marginRight: '0',
|
|
201
|
+
width: '24px',
|
|
202
|
+
'svg': {
|
|
203
|
+
fontSize: '24px',
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
},
|
|
209
|
+
});
|
|
210
|
+
export default theme;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { Color } from '@mui/material';
|
|
2
|
+
import { PaletteOptions } from '@mui/material/styles';
|
|
3
|
+
declare module '@mui/material/styles' {
|
|
4
|
+
interface PaletteOptions {
|
|
5
|
+
red?: Partial<Color>;
|
|
6
|
+
deepPurple?: Partial<Color>;
|
|
7
|
+
deepOrange?: Partial<Color>;
|
|
8
|
+
pink?: Partial<Color>;
|
|
9
|
+
blue?: Partial<Color>;
|
|
10
|
+
green?: Partial<Color>;
|
|
11
|
+
purple?: Partial<Color>;
|
|
12
|
+
border?: string;
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
declare const palette: PaletteOptions;
|
|
16
|
+
export default palette;
|
|
@@ -0,0 +1,138 @@
|
|
|
1
|
+
const palette = {
|
|
2
|
+
primary: {
|
|
3
|
+
main: "#FF5D0A",
|
|
4
|
+
dark: "#EC4A0A",
|
|
5
|
+
light: "#FD853A",
|
|
6
|
+
},
|
|
7
|
+
success: {
|
|
8
|
+
main: "#12B76A",
|
|
9
|
+
dark: "#027A48",
|
|
10
|
+
light: "#D1FADF",
|
|
11
|
+
},
|
|
12
|
+
warning: {
|
|
13
|
+
main: "#F79009",
|
|
14
|
+
dark: "B54708",
|
|
15
|
+
light: "#FEF0C7",
|
|
16
|
+
},
|
|
17
|
+
error: {
|
|
18
|
+
main: "#F04438",
|
|
19
|
+
dark: "#B42318",
|
|
20
|
+
light: "#FECDCA",
|
|
21
|
+
},
|
|
22
|
+
info: {
|
|
23
|
+
main: "#0BA5EC",
|
|
24
|
+
dark: "#026AA2",
|
|
25
|
+
light: "#7CD4FD",
|
|
26
|
+
},
|
|
27
|
+
text: {
|
|
28
|
+
primary: "#101828",
|
|
29
|
+
secondary: "#475467",
|
|
30
|
+
disabled: "#101828",
|
|
31
|
+
},
|
|
32
|
+
grey: {
|
|
33
|
+
50: "#F9FAFB",
|
|
34
|
+
100: "#F2F4F7",
|
|
35
|
+
200: "#E4E7EC",
|
|
36
|
+
300: "#D0D5DD",
|
|
37
|
+
400: "#98A2B3",
|
|
38
|
+
500: "#667085",
|
|
39
|
+
600: "#475467",
|
|
40
|
+
700: "#344054",
|
|
41
|
+
800: "#1D2939",
|
|
42
|
+
900: "#101828",
|
|
43
|
+
},
|
|
44
|
+
deepPurple: {
|
|
45
|
+
50: '#F8F9FC',
|
|
46
|
+
100: '#EAECF5',
|
|
47
|
+
200: '#C8CCE5',
|
|
48
|
+
300: '#9EA5D1',
|
|
49
|
+
400: "#4E5BA6",
|
|
50
|
+
500: '#4E5BA6',
|
|
51
|
+
600: '#3E4784',
|
|
52
|
+
700: '#363F72',
|
|
53
|
+
800: '#293056',
|
|
54
|
+
900: '#101323'
|
|
55
|
+
},
|
|
56
|
+
deepOrange: {
|
|
57
|
+
50: "#FFF6ED",
|
|
58
|
+
100: "#FFEAD5",
|
|
59
|
+
200: "#FDDCAB",
|
|
60
|
+
300: "#FEB273",
|
|
61
|
+
400: "#FD853A",
|
|
62
|
+
500: "#FF5C08",
|
|
63
|
+
600: "#EC4A0A",
|
|
64
|
+
700: "#C4320A",
|
|
65
|
+
800: "#9C2A10",
|
|
66
|
+
900: "#7E2410",
|
|
67
|
+
},
|
|
68
|
+
red: {
|
|
69
|
+
50: '#FEF3F2',
|
|
70
|
+
100: '#FEE4E2',
|
|
71
|
+
200: '#FECDCA',
|
|
72
|
+
300: '#FDA29B',
|
|
73
|
+
400: '#F97066',
|
|
74
|
+
500: '#F04438',
|
|
75
|
+
600: '#D92D20',
|
|
76
|
+
700: '#B42318',
|
|
77
|
+
800: '#912018',
|
|
78
|
+
900: '#7A271A',
|
|
79
|
+
},
|
|
80
|
+
pink: {
|
|
81
|
+
50: '#FDF2FA',
|
|
82
|
+
100: '#FCE7F6',
|
|
83
|
+
200: '#FCCEEE',
|
|
84
|
+
300: '#FAA7E0',
|
|
85
|
+
400: "#F670C7",
|
|
86
|
+
500: '#EE46BC',
|
|
87
|
+
600: '#DD2590',
|
|
88
|
+
700: '#C11574',
|
|
89
|
+
800: '#9E165F',
|
|
90
|
+
900: '#851651',
|
|
91
|
+
},
|
|
92
|
+
blue: {
|
|
93
|
+
50: '#F0F9FF',
|
|
94
|
+
100: "#E0F2FE",
|
|
95
|
+
200: '#B9E6FE',
|
|
96
|
+
300: '#7CD4FD',
|
|
97
|
+
400: "#36BFFA",
|
|
98
|
+
500: '#0BA5EC',
|
|
99
|
+
600: '#0086C9',
|
|
100
|
+
700: '#026AA2',
|
|
101
|
+
800: '#065986',
|
|
102
|
+
900: '#0B4A6F',
|
|
103
|
+
},
|
|
104
|
+
green: {
|
|
105
|
+
50: '#ECFDF3',
|
|
106
|
+
100: "#D1FADF",
|
|
107
|
+
200: '#A6F4C5',
|
|
108
|
+
300: '#6CE9A6',
|
|
109
|
+
400: "#32D583",
|
|
110
|
+
500: '#12B76A',
|
|
111
|
+
600: '#039855',
|
|
112
|
+
700: '#027A48',
|
|
113
|
+
800: '#05603A',
|
|
114
|
+
900: '#054F31',
|
|
115
|
+
},
|
|
116
|
+
purple: {
|
|
117
|
+
50: '#F3E5F5',
|
|
118
|
+
100: '#E1BEE7',
|
|
119
|
+
200: '#CE93D8',
|
|
120
|
+
300: '#BA68C8',
|
|
121
|
+
400: '#AB47BC',
|
|
122
|
+
500: '#9C27B0',
|
|
123
|
+
600: '#8E24AA',
|
|
124
|
+
700: '#7B1FA2',
|
|
125
|
+
800: '#6A1B9A',
|
|
126
|
+
900: '#4A148C',
|
|
127
|
+
},
|
|
128
|
+
border: "#F2F4F7",
|
|
129
|
+
action: {
|
|
130
|
+
active: "rgba(16, 24, 40, 0.40)",
|
|
131
|
+
hover: "rgba(16, 24, 40, 0.04)",
|
|
132
|
+
selected: "rgba(16, 24, 40, 0.08)",
|
|
133
|
+
disabled: "rgba(16, 24, 40, 0.26)",
|
|
134
|
+
disabledBackground: "rgba(16, 24, 40, 0.12)",
|
|
135
|
+
focus: "rgba(16, 24, 40, 0.12)",
|
|
136
|
+
}
|
|
137
|
+
};
|
|
138
|
+
export default palette;
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { TypographyVariantsOptions } from '@mui/material/styles';
|
|
2
|
+
import { TypographyStyleOptions } from '@mui/material/styles/createTypography';
|
|
3
|
+
declare module '@mui/material/styles' {
|
|
4
|
+
interface TypographyVariantsOptions {
|
|
5
|
+
body3?: TypographyStyleOptions;
|
|
6
|
+
}
|
|
7
|
+
}
|
|
8
|
+
declare const typography: TypographyVariantsOptions;
|
|
9
|
+
export default typography;
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
const typography = {
|
|
2
|
+
fontFamily: "'Mulish'",
|
|
3
|
+
h1: {
|
|
4
|
+
fontSize: "36px",
|
|
5
|
+
lineHeight: "44px",
|
|
6
|
+
},
|
|
7
|
+
h2: {
|
|
8
|
+
fontSize: "32px",
|
|
9
|
+
lineHeight: "40px",
|
|
10
|
+
},
|
|
11
|
+
h3: {
|
|
12
|
+
fontSize: "28px",
|
|
13
|
+
lineHeight: "36px",
|
|
14
|
+
},
|
|
15
|
+
h4: {
|
|
16
|
+
fontSize: "24px",
|
|
17
|
+
lineHeight: "32px",
|
|
18
|
+
},
|
|
19
|
+
h5: {
|
|
20
|
+
fontSize: "20px",
|
|
21
|
+
lineHeight: "28px",
|
|
22
|
+
},
|
|
23
|
+
h6: {
|
|
24
|
+
fontSize: "16px",
|
|
25
|
+
lineHeight: "22px",
|
|
26
|
+
},
|
|
27
|
+
body1: {
|
|
28
|
+
fontSize: '16px',
|
|
29
|
+
lineHeight: '24px',
|
|
30
|
+
},
|
|
31
|
+
body2: {
|
|
32
|
+
fontSize: '14px',
|
|
33
|
+
lineHeight: '20px',
|
|
34
|
+
},
|
|
35
|
+
body3: {
|
|
36
|
+
fontSize: '12px',
|
|
37
|
+
lineHeight: '18px',
|
|
38
|
+
letterSpacing: '0.15px',
|
|
39
|
+
},
|
|
40
|
+
subtitle1: {
|
|
41
|
+
fontSize: '16px',
|
|
42
|
+
lineHeight: "28px",
|
|
43
|
+
},
|
|
44
|
+
subtitle2: {
|
|
45
|
+
fontSize: '14px',
|
|
46
|
+
lineHeight: "22px",
|
|
47
|
+
},
|
|
48
|
+
caption: {
|
|
49
|
+
fontSize: '12px',
|
|
50
|
+
lineHeight: "20px",
|
|
51
|
+
},
|
|
52
|
+
overline: {
|
|
53
|
+
fontSize: "12px",
|
|
54
|
+
letterSpacing: "1px",
|
|
55
|
+
},
|
|
56
|
+
};
|
|
57
|
+
export default typography;
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import * as React from 'react';
|
|
3
|
+
import useMediaQuery from '@mui/material/useMediaQuery';
|
|
4
|
+
import ListSubheader from '@mui/material/ListSubheader';
|
|
5
|
+
import { useTheme } from '@mui/material/styles';
|
|
6
|
+
import { VariableSizeList } from 'react-window';
|
|
7
|
+
import Typography from '@mui/material/Typography';
|
|
8
|
+
const LISTBOX_PADDING = 8; // px
|
|
9
|
+
function renderRow(props) {
|
|
10
|
+
const { data, index, style } = props;
|
|
11
|
+
const dataSet = data[index];
|
|
12
|
+
const inlineStyle = {
|
|
13
|
+
...style,
|
|
14
|
+
top: style.top + LISTBOX_PADDING,
|
|
15
|
+
};
|
|
16
|
+
if (dataSet.hasOwnProperty('group')) {
|
|
17
|
+
return (_jsx(ListSubheader, { component: "div", style: inlineStyle, children: dataSet.group }, dataSet.key));
|
|
18
|
+
}
|
|
19
|
+
return (_jsx(Typography, { component: "li", ...dataSet[0], noWrap: true, style: inlineStyle, children: dataSet[1] }));
|
|
20
|
+
}
|
|
21
|
+
const OuterElementContext = React.createContext({});
|
|
22
|
+
const OuterElementType = React.forwardRef((props, ref) => {
|
|
23
|
+
const outerProps = React.useContext(OuterElementContext);
|
|
24
|
+
return _jsx("div", { ref: ref, ...props, ...outerProps });
|
|
25
|
+
});
|
|
26
|
+
function useResetCache(data) {
|
|
27
|
+
const ref = React.useRef(null);
|
|
28
|
+
React.useEffect(() => {
|
|
29
|
+
if (ref.current != null) {
|
|
30
|
+
ref.current.resetAfterIndex(0, true);
|
|
31
|
+
}
|
|
32
|
+
}, [data]);
|
|
33
|
+
return ref;
|
|
34
|
+
}
|
|
35
|
+
// Adapter for react-window
|
|
36
|
+
export const ListboxComponent = React.forwardRef(function ListboxComponent(props, ref) {
|
|
37
|
+
const { children, ...other } = props;
|
|
38
|
+
const itemData = [];
|
|
39
|
+
children.forEach((item) => {
|
|
40
|
+
itemData.push(item);
|
|
41
|
+
itemData.push(...(item.children || []));
|
|
42
|
+
});
|
|
43
|
+
const theme = useTheme();
|
|
44
|
+
const smUp = useMediaQuery(theme.breakpoints.up('sm'), {
|
|
45
|
+
noSsr: true,
|
|
46
|
+
});
|
|
47
|
+
const itemCount = itemData.length;
|
|
48
|
+
const itemSize = smUp ? 36 : 48;
|
|
49
|
+
const getChildSize = (child) => {
|
|
50
|
+
if (child.hasOwnProperty('group')) {
|
|
51
|
+
return 48;
|
|
52
|
+
}
|
|
53
|
+
return itemSize;
|
|
54
|
+
};
|
|
55
|
+
const getHeight = () => {
|
|
56
|
+
if (itemCount > 8) {
|
|
57
|
+
return 8 * itemSize;
|
|
58
|
+
}
|
|
59
|
+
return itemData.map(getChildSize).reduce((a, b) => a + b, 0);
|
|
60
|
+
};
|
|
61
|
+
const gridRef = useResetCache(itemCount);
|
|
62
|
+
return (_jsx("div", { ref: ref, children: _jsx(OuterElementContext.Provider, { value: other, children: _jsx(VariableSizeList, { itemData: itemData, height: getHeight() + 2 * LISTBOX_PADDING, width: "100%", ref: gridRef, outerElementType: OuterElementType, innerElementType: "ul", itemSize: (index) => getChildSize(itemData[index]), overscanCount: 5, itemCount: itemCount, children: renderRow }) }) }));
|
|
63
|
+
});
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@zesty-io/material",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.3.1",
|
|
4
4
|
"description": "Contains custom components which are in addition to the @mui design-system",
|
|
5
5
|
"author": "Zesty.io",
|
|
6
6
|
"license": "MIT",
|
|
@@ -12,13 +12,11 @@
|
|
|
12
12
|
"url": "https://github.com/zesty-io/material/issues"
|
|
13
13
|
},
|
|
14
14
|
"homepage": "https://zesty-io.github.io/material",
|
|
15
|
-
"main": "cjs/index.js",
|
|
16
|
-
"module": "es/index.js",
|
|
17
|
-
"types": "es/index.d.ts",
|
|
15
|
+
"main": "./cjs/index.js",
|
|
16
|
+
"module": "./es/index.js",
|
|
17
|
+
"types": "./es/index.d.ts",
|
|
18
18
|
"scripts": {
|
|
19
|
-
"build": "npm
|
|
20
|
-
"build:esm": "tsc",
|
|
21
|
-
"build:cjs": "tsc --module commonjs --outDir cjs",
|
|
19
|
+
"build": "npm ci && tsc",
|
|
22
20
|
"prerelease": "npm test",
|
|
23
21
|
"release": "npm run build && npm publish --access public",
|
|
24
22
|
"release:alpha": "npm run build && npm publish --access public --tag alpha",
|
|
@@ -48,10 +46,14 @@
|
|
|
48
46
|
"@types/react-window": "^1.8.5",
|
|
49
47
|
"babel-loader": "^8.2.5",
|
|
50
48
|
"gh-pages": "^3.2.3",
|
|
51
|
-
"react": "^
|
|
49
|
+
"react": "^17.0.2",
|
|
52
50
|
"react-docgen-typescript": "^2.2.2",
|
|
53
|
-
"react-dom": "^
|
|
51
|
+
"react-dom": "^17.0.2",
|
|
54
52
|
"react-json-view": "^1.21.3",
|
|
55
53
|
"typescript": "^4.6.3"
|
|
56
|
-
}
|
|
54
|
+
},
|
|
55
|
+
"files": [
|
|
56
|
+
"cjs",
|
|
57
|
+
"es"
|
|
58
|
+
]
|
|
57
59
|
}
|
package/.storybook/main.js
DELETED
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
module.exports = {
|
|
2
|
-
"stories": [
|
|
3
|
-
"../src/**/*.stories.mdx",
|
|
4
|
-
"../src/**/*.stories.@(js|jsx|ts|tsx)"
|
|
5
|
-
],
|
|
6
|
-
"addons": [
|
|
7
|
-
"@storybook/addon-links",
|
|
8
|
-
"@storybook/addon-essentials",
|
|
9
|
-
],
|
|
10
|
-
"framework": "@storybook/react",
|
|
11
|
-
typescript: {
|
|
12
|
-
check: true,
|
|
13
|
-
reactDocgen: 'react-docgen-typescript',
|
|
14
|
-
reactDocgenTypescriptOptions: {
|
|
15
|
-
shouldExtractLiteralValuesFromEnum: true,
|
|
16
|
-
shouldRemoveUndefinedFromOptional: true,
|
|
17
|
-
propFilter: (prop) => {
|
|
18
|
-
return prop.parent
|
|
19
|
-
? /@mui/.test(prop.parent.fileName) ||
|
|
20
|
-
!/node_modules/.test(prop.parent.fileName)
|
|
21
|
-
: true;
|
|
22
|
-
},
|
|
23
|
-
},
|
|
24
|
-
},
|
|
25
|
-
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
<link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Mulish" />
|
package/.storybook/preview.js
DELETED
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
|
-
import { ThemeProvider } from 'emotion-theming';
|
|
3
|
-
import { theme } from '../src/index.ts';
|
|
4
|
-
|
|
5
|
-
export const parameters = {
|
|
6
|
-
actions: { argTypesRegex: '^on[A-Z].*' },
|
|
7
|
-
};
|
|
8
|
-
|
|
9
|
-
export const decorators = [
|
|
10
|
-
(Story) => (
|
|
11
|
-
<ThemeProvider theme={theme}>
|
|
12
|
-
<Story />
|
|
13
|
-
</ThemeProvider>
|
|
14
|
-
),
|
|
15
|
-
];
|
|
@@ -1,35 +0,0 @@
|
|
|
1
|
-
import { useState } from 'react';
|
|
2
|
-
import { Story, Meta } from '@storybook/react/types-6-0';
|
|
3
|
-
import { Button, Stack } from '@mui/material';
|
|
4
|
-
import ConfirmDialog, { ConfirmDialogProps } from '.';
|
|
5
|
-
|
|
6
|
-
export default {
|
|
7
|
-
title: 'ConfirmDialog',
|
|
8
|
-
component: ConfirmDialog,
|
|
9
|
-
argType: {},
|
|
10
|
-
} as Meta;
|
|
11
|
-
|
|
12
|
-
const Template: Story<ConfirmDialogProps> = (args) => {
|
|
13
|
-
const [open, setOpen] = useState(false);
|
|
14
|
-
|
|
15
|
-
return (
|
|
16
|
-
<>
|
|
17
|
-
<Button variant="contained" onClick={() => setOpen(true)}>Click me to open</Button>
|
|
18
|
-
<ConfirmDialog {...args} open={open} callback={(confirmed) => setOpen(false) } />
|
|
19
|
-
</>
|
|
20
|
-
);
|
|
21
|
-
};
|
|
22
|
-
|
|
23
|
-
export const Default = Template.bind({});
|
|
24
|
-
Default.args = {
|
|
25
|
-
title: 'Confirm modal title',
|
|
26
|
-
content: 'Confirm modal content',
|
|
27
|
-
};
|
|
28
|
-
|
|
29
|
-
export const CustomChildren = Template.bind({});
|
|
30
|
-
CustomChildren.args = {
|
|
31
|
-
title: 'Confirm modal title',
|
|
32
|
-
content: 'Confirm modal content',
|
|
33
|
-
children: <><Button color="error" variant="contained">Custom 1</Button><Button color="success" variant="contained">Custom 2</Button></>
|
|
34
|
-
};
|
|
35
|
-
|
|
@@ -1,50 +0,0 @@
|
|
|
1
|
-
import { ReactNode } from 'react';
|
|
2
|
-
import Dialog, { DialogProps } from '@mui/material/Dialog';
|
|
3
|
-
import DialogActions from '@mui/material/DialogActions';
|
|
4
|
-
import DialogContent from '@mui/material/DialogContent';
|
|
5
|
-
import DialogContentText from '@mui/material/DialogContentText';
|
|
6
|
-
import DialogTitle from '@mui/material/DialogTitle';
|
|
7
|
-
import { Button } from '@mui/material';
|
|
8
|
-
|
|
9
|
-
export interface ConfirmDialogProps extends Omit<DialogProps, 'title'> {
|
|
10
|
-
/**
|
|
11
|
-
* Title of confirm dialog
|
|
12
|
-
*/
|
|
13
|
-
title: string | ReactNode ;
|
|
14
|
-
/**
|
|
15
|
-
* Content of confirm dialog
|
|
16
|
-
*/
|
|
17
|
-
content: string | ReactNode ;
|
|
18
|
-
/**
|
|
19
|
-
* Callback of confirm dialog
|
|
20
|
-
*/
|
|
21
|
-
callback: (confirmed: boolean) => void ;
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
const ConfirmDialog = ({title, content, onClose, children, callback, ...props }: ConfirmDialogProps) => {
|
|
25
|
-
|
|
26
|
-
return (
|
|
27
|
-
<Dialog
|
|
28
|
-
{...props}
|
|
29
|
-
>
|
|
30
|
-
<DialogTitle>
|
|
31
|
-
{title}
|
|
32
|
-
</DialogTitle>
|
|
33
|
-
<DialogContent>
|
|
34
|
-
<DialogContentText>
|
|
35
|
-
{content}
|
|
36
|
-
</DialogContentText>
|
|
37
|
-
</DialogContent>
|
|
38
|
-
{children ? <DialogActions>{children}</DialogActions> : (
|
|
39
|
-
<DialogActions>
|
|
40
|
-
<Button variant="contained" onClick={() => callback(false)}>No</Button>
|
|
41
|
-
<Button variant="contained" onClick={() => callback(true)} autoFocus>
|
|
42
|
-
Yes
|
|
43
|
-
</Button>
|
|
44
|
-
</DialogActions>
|
|
45
|
-
)}
|
|
46
|
-
</Dialog>
|
|
47
|
-
);
|
|
48
|
-
};
|
|
49
|
-
|
|
50
|
-
export default ConfirmDialog;
|