@toptal/picasso 17.3.2 → 18.0.0

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.
Files changed (211) hide show
  1. package/Autocomplete/Autocomplete.js +2 -2
  2. package/Autocomplete/Autocomplete.js.map +1 -1
  3. package/Calendar/Calendar.d.ts +23 -0
  4. package/Calendar/Calendar.js +86 -0
  5. package/Calendar/Calendar.js.map +1 -0
  6. package/Calendar/index.d.ts +2 -0
  7. package/Calendar/index.js +3 -0
  8. package/Calendar/index.js.map +1 -0
  9. package/Calendar/styles.d.ts +3 -0
  10. package/Calendar/styles.js +97 -0
  11. package/Calendar/styles.js.map +1 -0
  12. package/Calendar/types.d.ts +36 -0
  13. package/Calendar/types.js +2 -0
  14. package/Calendar/types.js.map +1 -0
  15. package/DatePicker/DatePicker.d.ts +62 -0
  16. package/DatePicker/DatePicker.js +198 -0
  17. package/DatePicker/DatePicker.js.map +1 -0
  18. package/DatePicker/constants.d.ts +12 -0
  19. package/DatePicker/constants.js +13 -0
  20. package/DatePicker/constants.js.map +1 -0
  21. package/DatePicker/index.d.ts +5 -0
  22. package/DatePicker/index.js +4 -0
  23. package/DatePicker/index.js.map +1 -0
  24. package/DatePicker/styles.d.ts +2 -0
  25. package/DatePicker/styles.js +7 -0
  26. package/DatePicker/styles.js.map +1 -0
  27. package/DatePicker/types.d.ts +13 -0
  28. package/DatePicker/types.js +2 -0
  29. package/DatePicker/types.js.map +1 -0
  30. package/DatePicker/utils.d.ts +12 -0
  31. package/DatePicker/utils.js +102 -0
  32. package/DatePicker/utils.js.map +1 -0
  33. package/Drawer/Drawer.d.ts +22 -0
  34. package/Drawer/Drawer.js +55 -0
  35. package/Drawer/Drawer.js.map +1 -0
  36. package/Drawer/index.d.ts +4 -0
  37. package/Drawer/index.js +2 -0
  38. package/Drawer/index.js.map +1 -0
  39. package/Drawer/styles.d.ts +2 -0
  40. package/Drawer/styles.js +40 -0
  41. package/Drawer/styles.js.map +1 -0
  42. package/DrawerTitle/DrawerTitle.d.ts +9 -0
  43. package/DrawerTitle/DrawerTitle.js +20 -0
  44. package/DrawerTitle/DrawerTitle.js.map +1 -0
  45. package/DrawerTitle/index.d.ts +1 -0
  46. package/DrawerTitle/index.js +2 -0
  47. package/DrawerTitle/index.js.map +1 -0
  48. package/DrawerTitle/styles.d.ts +3 -0
  49. package/DrawerTitle/styles.js +11 -0
  50. package/DrawerTitle/styles.js.map +1 -0
  51. package/Dropzone/Dropzone.d.ts +37 -0
  52. package/Dropzone/Dropzone.js +55 -0
  53. package/Dropzone/Dropzone.js.map +1 -0
  54. package/Dropzone/index.d.ts +5 -0
  55. package/Dropzone/index.js +3 -0
  56. package/Dropzone/index.js.map +1 -0
  57. package/Dropzone/styles.d.ts +3 -0
  58. package/Dropzone/styles.js +42 -0
  59. package/Dropzone/styles.js.map +1 -0
  60. package/Dropzone/types.d.ts +43 -0
  61. package/Dropzone/types.js +7 -0
  62. package/Dropzone/types.js.map +1 -0
  63. package/EmptyState/EmptyState.d.ts +5 -0
  64. package/EmptyState/EmptyState.js +7 -0
  65. package/EmptyState/EmptyState.js.map +1 -0
  66. package/EmptyState/index.d.ts +1 -0
  67. package/EmptyState/index.js +2 -0
  68. package/EmptyState/index.js.map +1 -0
  69. package/EmptyStateCollection/EmptyStateCollection.d.ts +7 -0
  70. package/EmptyStateCollection/EmptyStateCollection.js +36 -0
  71. package/EmptyStateCollection/EmptyStateCollection.js.map +1 -0
  72. package/EmptyStateCollection/index.d.ts +1 -0
  73. package/EmptyStateCollection/index.js +2 -0
  74. package/EmptyStateCollection/index.js.map +1 -0
  75. package/EmptyStateCollection/styles.d.ts +2 -0
  76. package/EmptyStateCollection/styles.js +9 -0
  77. package/EmptyStateCollection/styles.js.map +1 -0
  78. package/EmptyStatePage/EmptyStatePage.d.ts +9 -0
  79. package/EmptyStatePage/EmptyStatePage.js +31 -0
  80. package/EmptyStatePage/EmptyStatePage.js.map +1 -0
  81. package/EmptyStatePage/index.d.ts +1 -0
  82. package/EmptyStatePage/index.js +2 -0
  83. package/EmptyStatePage/index.js.map +1 -0
  84. package/EmptyStatePage/styles.d.ts +2 -0
  85. package/EmptyStatePage/styles.js +8 -0
  86. package/EmptyStatePage/styles.js.map +1 -0
  87. package/MenuItem/MenuItem.js +6 -1
  88. package/MenuItem/MenuItem.js.map +1 -1
  89. package/NonNativeSelect/NonNativeSelect.js +1 -1
  90. package/NonNativeSelect/NonNativeSelect.js.map +1 -1
  91. package/NonNativeSelectLoader/NonNativeSelectLoader.js +2 -2
  92. package/NonNativeSelectLoader/NonNativeSelectLoader.js.map +1 -1
  93. package/NonNativeSelectOptions/NonNativeSelectOptions.js +3 -3
  94. package/NonNativeSelectOptions/NonNativeSelectOptions.js.map +1 -1
  95. package/Note/Note.d.ts +12 -0
  96. package/Note/Note.js +31 -0
  97. package/Note/Note.js.map +1 -0
  98. package/Note/index.d.ts +4 -0
  99. package/Note/index.js +2 -0
  100. package/Note/index.js.map +1 -0
  101. package/Note/styles.d.ts +3 -0
  102. package/Note/styles.js +23 -0
  103. package/Note/styles.js.map +1 -0
  104. package/NoteContent/NoteContent.d.ts +7 -0
  105. package/NoteContent/NoteContent.js +21 -0
  106. package/NoteContent/NoteContent.js.map +1 -0
  107. package/NoteContent/index.d.ts +1 -0
  108. package/NoteContent/index.js +2 -0
  109. package/NoteContent/index.js.map +1 -0
  110. package/NoteSubtitle/NoteSubtitle.d.ts +7 -0
  111. package/NoteSubtitle/NoteSubtitle.js +23 -0
  112. package/NoteSubtitle/NoteSubtitle.js.map +1 -0
  113. package/NoteSubtitle/index.d.ts +1 -0
  114. package/NoteSubtitle/index.js +2 -0
  115. package/NoteSubtitle/index.js.map +1 -0
  116. package/NoteTitle/NoteTitle.d.ts +7 -0
  117. package/NoteTitle/NoteTitle.js +27 -0
  118. package/NoteTitle/NoteTitle.js.map +1 -0
  119. package/NoteTitle/index.d.ts +1 -0
  120. package/NoteTitle/index.js +2 -0
  121. package/NoteTitle/index.js.map +1 -0
  122. package/NoteTitle/styles.d.ts +2 -0
  123. package/NoteTitle/styles.js +7 -0
  124. package/NoteTitle/styles.js.map +1 -0
  125. package/OverviewBlock/OverviewBlock.d.ts +25 -0
  126. package/OverviewBlock/OverviewBlock.js +54 -0
  127. package/OverviewBlock/OverviewBlock.js.map +1 -0
  128. package/OverviewBlock/index.d.ts +4 -0
  129. package/OverviewBlock/index.js +2 -0
  130. package/OverviewBlock/index.js.map +1 -0
  131. package/OverviewBlock/styles.d.ts +3 -0
  132. package/OverviewBlock/styles.js +42 -0
  133. package/OverviewBlock/styles.js.map +1 -0
  134. package/OverviewBlockGroup/OverviewBlockGroup.d.ts +10 -0
  135. package/OverviewBlockGroup/OverviewBlockGroup.js +36 -0
  136. package/OverviewBlockGroup/OverviewBlockGroup.js.map +1 -0
  137. package/OverviewBlockGroup/OverviewBlockGroupContext.d.ts +8 -0
  138. package/OverviewBlockGroup/OverviewBlockGroupContext.js +10 -0
  139. package/OverviewBlockGroup/OverviewBlockGroupContext.js.map +1 -0
  140. package/OverviewBlockGroup/index.d.ts +1 -0
  141. package/OverviewBlockGroup/index.js +2 -0
  142. package/OverviewBlockGroup/index.js.map +1 -0
  143. package/OverviewBlockGroup/settings.d.ts +2 -0
  144. package/OverviewBlockGroup/settings.js +2 -0
  145. package/OverviewBlockGroup/settings.js.map +1 -0
  146. package/OverviewBlockRow/OverviewBlockRow.d.ts +4 -0
  147. package/OverviewBlockRow/OverviewBlockRow.js +26 -0
  148. package/OverviewBlockRow/OverviewBlockRow.js.map +1 -0
  149. package/OverviewBlockRow/index.d.ts +1 -0
  150. package/OverviewBlockRow/index.js +2 -0
  151. package/OverviewBlockRow/index.js.map +1 -0
  152. package/OverviewBlockRow/styles.d.ts +3 -0
  153. package/OverviewBlockRow/styles.js +26 -0
  154. package/OverviewBlockRow/styles.js.map +1 -0
  155. package/PageFooter/PageFooter.d.ts +2 -0
  156. package/PageFooter/PageFooter.js +5 -4
  157. package/PageFooter/PageFooter.js.map +1 -1
  158. package/ScrollMenu/ScrollMenu.js +7 -2
  159. package/ScrollMenu/ScrollMenu.js.map +1 -1
  160. package/Section/Section.d.ts +29 -0
  161. package/Section/Section.js +60 -0
  162. package/Section/Section.js.map +1 -0
  163. package/Section/index.d.ts +4 -0
  164. package/Section/index.js +2 -0
  165. package/Section/index.js.map +1 -0
  166. package/Section/styles.d.ts +3 -0
  167. package/Section/styles.js +62 -0
  168. package/Section/styles.js.map +1 -0
  169. package/SelectOptions/SelectOptions.d.ts +6 -0
  170. package/SelectOptions/SelectOptions.js +33 -0
  171. package/SelectOptions/SelectOptions.js.map +1 -0
  172. package/SelectOptions/index.d.ts +4 -0
  173. package/SelectOptions/index.js +2 -0
  174. package/SelectOptions/index.js.map +1 -0
  175. package/SelectOptions/styles.d.ts +3 -0
  176. package/SelectOptions/styles.js +19 -0
  177. package/SelectOptions/styles.js.map +1 -0
  178. package/ShowMore/ShowMore.d.ts +1 -1
  179. package/ShowMore/ShowMore.js +4 -2
  180. package/ShowMore/ShowMore.js.map +1 -1
  181. package/ShowMore/utils.d.ts +1 -0
  182. package/ShowMore/utils.js +17 -0
  183. package/ShowMore/utils.js.map +1 -0
  184. package/Timeline/Timeline.d.ts +23 -0
  185. package/Timeline/Timeline.js +9 -0
  186. package/Timeline/Timeline.js.map +1 -0
  187. package/Timeline/index.d.ts +4 -0
  188. package/Timeline/index.js +2 -0
  189. package/Timeline/index.js.map +1 -0
  190. package/TimelineRow/TimelineRow.d.ts +24 -0
  191. package/TimelineRow/TimelineRow.js +27 -0
  192. package/TimelineRow/TimelineRow.js.map +1 -0
  193. package/TimelineRow/index.d.ts +4 -0
  194. package/TimelineRow/index.js +2 -0
  195. package/TimelineRow/index.js.map +1 -0
  196. package/TimelineRow/styles.d.ts +3 -0
  197. package/TimelineRow/styles.js +45 -0
  198. package/TimelineRow/styles.js.map +1 -0
  199. package/TypographyOverflow/TypographyOverflow.d.ts +26 -0
  200. package/TypographyOverflow/TypographyOverflow.js +79 -0
  201. package/TypographyOverflow/TypographyOverflow.js.map +1 -0
  202. package/TypographyOverflow/index.d.ts +4 -0
  203. package/TypographyOverflow/index.js +2 -0
  204. package/TypographyOverflow/index.js.map +1 -0
  205. package/TypographyOverflow/styles.d.ts +2 -0
  206. package/TypographyOverflow/styles.js +28 -0
  207. package/TypographyOverflow/styles.js.map +1 -0
  208. package/index.d.ts +19 -0
  209. package/index.js +10 -0
  210. package/index.js.map +1 -1
  211. package/package.json +9 -4
@@ -0,0 +1,25 @@
1
+ import React, { ElementType, HTMLAttributes, MouseEvent, ReactNode } from 'react';
2
+ import { OverridableComponent, ColorType, BaseProps, TextLabelProps } from '@toptal/picasso-shared';
3
+ declare type VariantColorType = Extract<ColorType, 'red' | 'green' | 'yellow'>;
4
+ declare type Variant = `value-${VariantColorType}` | `label-${VariantColorType}`;
5
+ export declare type Props = BaseProps & TextLabelProps & HTMLAttributes<HTMLButtonElement> & {
6
+ /** Counter value */
7
+ value: ReactNode;
8
+ /** Counter title */
9
+ label: string;
10
+ /** The color variant */
11
+ variant?: Variant;
12
+ /** Component used for the root node. Either a string to use a DOM element or a component. */
13
+ as?: ElementType;
14
+ /** Callback invoked when component is clicked */
15
+ onClick?: (event: MouseEvent) => void;
16
+ };
17
+ export declare const OverviewBlock: OverridableComponent<Props>;
18
+ declare const _default: OverridableComponent<Props> & {
19
+ Group: React.FunctionComponent<React.HTMLAttributes<HTMLDivElement> & {
20
+ align?: import("../OverviewBlockGroup/settings").Alignment | undefined;
21
+ blockWidth?: import("../OverviewBlockGroup/settings").BlockWidth | undefined;
22
+ }>;
23
+ Row: React.FunctionComponent<React.HTMLAttributes<HTMLDivElement>>;
24
+ };
25
+ export default _default;
@@ -0,0 +1,54 @@
1
+ var __rest = (this && this.__rest) || function (s, e) {
2
+ var t = {};
3
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
4
+ t[p] = s[p];
5
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
6
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
7
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
8
+ t[p[i]] = s[p[i]];
9
+ }
10
+ return t;
11
+ };
12
+ import React, { forwardRef } from 'react';
13
+ import { makeStyles } from '@material-ui/core/styles';
14
+ import cx from 'classnames';
15
+ import { useTitleCase } from '@toptal/picasso-shared';
16
+ import styles from './styles';
17
+ import { useOverviewBlockGroupContext } from '../OverviewBlockGroup/OverviewBlockGroupContext';
18
+ import OverviewBlockGroup from '../OverviewBlockGroup';
19
+ import OverviewBlockRow from '../OverviewBlockRow';
20
+ import Container from '../Container';
21
+ import Typography from '../Typography';
22
+ import { toTitleCase } from '../utils';
23
+ const useStyles = makeStyles(styles, {
24
+ name: 'PicassoOverviewBlock'
25
+ });
26
+ export const OverviewBlock = forwardRef(function OverviewBlock(props, ref) {
27
+ const { value, label, variant, as, className, onClick, titleCase: propsTitleCase } = props, rest = __rest(props, ["value", "label", "variant", "as", "className", "onClick", "titleCase"]);
28
+ const classes = useStyles();
29
+ const { align, blockWidth } = useOverviewBlockGroupContext();
30
+ const color = {
31
+ value: 'black',
32
+ label: 'dark-grey'
33
+ };
34
+ if (variant) {
35
+ const [partName, colorName] = variant.split('-');
36
+ color[partName] = colorName;
37
+ }
38
+ const isClickable = Boolean(onClick) || typeof as !== 'string';
39
+ const Component = isClickable && as ? as : 'div';
40
+ const titleCase = useTitleCase(propsTitleCase);
41
+ return (React.createElement(Component, Object.assign({}, rest, { ref: ref, className: cx({ [classes.clickable]: isClickable }, { [classes.disableOutline]: !isClickable }, classes[`${align}Align`], classes[`${blockWidth}Width`], classes.root, className), onClick: onClick }),
42
+ React.createElement(Container, { align: 'left' },
43
+ React.createElement(Typography, { size: 'xxsmall', weight: 'semibold', color: color.label }, titleCase ? toTitleCase(label) : label),
44
+ React.createElement(Typography, { size: 'large', weight: 'semibold', color: color.value }, value))));
45
+ });
46
+ OverviewBlock.defaultProps = {
47
+ as: 'button'
48
+ };
49
+ OverviewBlock.displayName = 'OverviewBlock';
50
+ export default Object.assign(OverviewBlock, {
51
+ Group: OverviewBlockGroup,
52
+ Row: OverviewBlockRow
53
+ });
54
+ //# sourceMappingURL=OverviewBlock.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"OverviewBlock.js","sourceRoot":"","sources":["../../src/OverviewBlock/OverviewBlock.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ import { OmitInternalProps } from '@toptal/picasso-shared';
2
+ import { Props } from './OverviewBlock';
3
+ export { default } from './OverviewBlock';
4
+ export declare type OverviewBlockProps = OmitInternalProps<Props>;
@@ -0,0 +1,2 @@
1
+ export { default } from './OverviewBlock';
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/OverviewBlock/index.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAA"}
@@ -0,0 +1,3 @@
1
+ import { Theme } from '@material-ui/core/styles';
2
+ declare const _default: ({ palette, sizes }: Theme) => import("@material-ui/styles").StyleRules<{}, "root" | "clickable" | "disableOutline" | "defaultAlign" | "centerAlign" | "narrowWidth" | "regularWidth" | "wideWidth">;
3
+ export default _default;
@@ -0,0 +1,42 @@
1
+ import { createStyles } from '@material-ui/core/styles';
2
+ import { rem } from '@toptal/picasso-shared';
3
+ export default ({ palette, sizes }) => createStyles({
4
+ root: {
5
+ display: 'flex',
6
+ flexDirection: 'column',
7
+ backgroundColor: palette.common.white,
8
+ margin: 0,
9
+ minWidth: rem('150px'),
10
+ border: 'none',
11
+ textDecoration: 'none',
12
+ '&:not(:first-child)': {
13
+ borderLeft: `${sizes.borderWidth} solid ${palette.grey.light2}`
14
+ }
15
+ },
16
+ clickable: {
17
+ cursor: 'pointer',
18
+ outline: 'none',
19
+ '&:hover': {
20
+ backgroundColor: palette.blue.lighter
21
+ }
22
+ },
23
+ disableOutline: {
24
+ outline: 'none'
25
+ },
26
+ defaultAlign: {
27
+ alignItems: 'flex-start'
28
+ },
29
+ centerAlign: {
30
+ alignItems: 'center'
31
+ },
32
+ narrowWidth: {
33
+ padding: '0.75rem 1rem'
34
+ },
35
+ regularWidth: {
36
+ padding: '0.75rem 1.5rem'
37
+ },
38
+ wideWidth: {
39
+ padding: '0.75rem 2rem'
40
+ }
41
+ });
42
+ //# sourceMappingURL=styles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"styles.js","sourceRoot":"","sources":["../../src/OverviewBlock/styles.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAS,MAAM,0BAA0B,CAAA;AAC9D,OAAO,EAAE,GAAG,EAAE,MAAM,wBAAwB,CAAA;AAE5C,eAAe,CAAC,EAAE,OAAO,EAAE,KAAK,EAAS,EAAE,EAAE,CAC3C,YAAY,CAAC;IACX,IAAI,EAAE;QACJ,OAAO,EAAE,MAAM;QACf,aAAa,EAAE,QAAQ;QACvB,eAAe,EAAE,OAAO,CAAC,MAAM,CAAC,KAAK;QACrC,MAAM,EAAE,CAAC;QACT,QAAQ,EAAE,GAAG,CAAC,OAAO,CAAC;QACtB,MAAM,EAAE,MAAM;QACd,cAAc,EAAE,MAAM;QACtB,qBAAqB,EAAE;YACrB,UAAU,EAAE,GAAG,KAAK,CAAC,WAAW,UAAU,OAAO,CAAC,IAAI,CAAC,MAAM,EAAE;SAChE;KACF;IACD,SAAS,EAAE;QACT,MAAM,EAAE,SAAS;QACjB,OAAO,EAAE,MAAM;QACf,SAAS,EAAE;YACT,eAAe,EAAE,OAAO,CAAC,IAAI,CAAC,OAAO;SACtC;KACF;IACD,cAAc,EAAE;QACd,OAAO,EAAE,MAAM;KAChB;IAED,YAAY,EAAE;QACZ,UAAU,EAAE,YAAY;KACzB;IACD,WAAW,EAAE;QACX,UAAU,EAAE,QAAQ;KACrB;IACD,WAAW,EAAE;QACX,OAAO,EAAE,cAAc;KACxB;IACD,YAAY,EAAE;QACZ,OAAO,EAAE,gBAAgB;KAC1B;IACD,SAAS,EAAE;QACT,OAAO,EAAE,cAAc;KACxB;CACF,CAAC,CAAA"}
@@ -0,0 +1,10 @@
1
+ import { FunctionComponent, HTMLAttributes } from 'react';
2
+ import { Alignment, BlockWidth } from './settings';
3
+ declare type Props = HTMLAttributes<HTMLDivElement> & {
4
+ /** Value and label alignment for blocks. By default content is aligned to the left. */
5
+ align?: Alignment;
6
+ /** The block width variant */
7
+ blockWidth?: BlockWidth;
8
+ };
9
+ declare const OverviewBlockGroup: FunctionComponent<Props>;
10
+ export default OverviewBlockGroup;
@@ -0,0 +1,36 @@
1
+ var __rest = (this && this.__rest) || function (s, e) {
2
+ var t = {};
3
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
4
+ t[p] = s[p];
5
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
6
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
7
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
8
+ t[p[i]] = s[p[i]];
9
+ }
10
+ return t;
11
+ };
12
+ import React from 'react';
13
+ import { OverviewBlockGroupContext } from './OverviewBlockGroupContext';
14
+ import OverviewBlockRow from '../OverviewBlockRow';
15
+ // We need to inject a single row if there is none provided.
16
+ // It allows to skip `OverviewBlock.Row` component for a single-row groups.
17
+ const shouldInjectRow = (children) => {
18
+ if (!children) {
19
+ return false;
20
+ }
21
+ return !React.Children.toArray(children)
22
+ .filter((el) => React.isValidElement(el))
23
+ .some(el => el.type.displayName === OverviewBlockRow.displayName);
24
+ };
25
+ const OverviewBlockGroup = props => {
26
+ const { children, align = 'default', blockWidth = 'regular' } = props, rest = __rest(props, ["children", "align", "blockWidth"]);
27
+ return (React.createElement("section", Object.assign({}, rest),
28
+ React.createElement(OverviewBlockGroupContext.Provider, { value: { align, blockWidth } }, shouldInjectRow(children) ? (React.createElement(OverviewBlockRow, null, children)) : (children))));
29
+ };
30
+ OverviewBlockGroup.displayName = 'OverviewBlockGroup';
31
+ OverviewBlockGroup.defaultProps = {
32
+ align: 'default',
33
+ blockWidth: 'regular'
34
+ };
35
+ export default OverviewBlockGroup;
36
+ //# sourceMappingURL=OverviewBlockGroup.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"OverviewBlockGroup.js","sourceRoot":"","sources":["../../src/OverviewBlockGroup/OverviewBlockGroup.tsx"],"names":[],"mappings":";;;;;;;;;;;AAAA,OAAO,KAKN,MAAM,OAAO,CAAA;AAGd,OAAO,EAAE,yBAAyB,EAAE,MAAM,6BAA6B,CAAA;AACvE,OAAO,gBAAgB,MAAM,qBAAqB,CAAA;AASlD,4DAA4D;AAC5D,2EAA2E;AAC3E,MAAM,eAAe,GAAG,CAAC,QAAoB,EAAE,EAAE;IAC/C,IAAI,CAAC,QAAQ,EAAE;QACb,OAAO,KAAK,CAAA;KACb;IAED,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,QAAQ,CAAC;SACrC,MAAM,CAAC,CAAC,EAAE,EAAwD,EAAE,CACnE,KAAK,CAAC,cAAc,CAAC,EAAE,CAAC,CACzB;SACA,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC,WAAW,KAAK,gBAAgB,CAAC,WAAW,CAAC,CAAA;AACrE,CAAC,CAAA;AAED,MAAM,kBAAkB,GAA6B,KAAK,CAAC,EAAE;IAC3D,MAAM,EAAE,QAAQ,EAAE,KAAK,GAAG,SAAS,EAAE,UAAU,GAAG,SAAS,KAAc,KAAK,EAAd,IAAI,UAAK,KAAK,EAAxE,mCAAgE,CAAQ,CAAA;IAE9E,OAAO,CACL,iDAAa,IAAI;QACf,oBAAC,yBAAyB,CAAC,QAAQ,IAAC,KAAK,EAAE,EAAE,KAAK,EAAE,UAAU,EAAE,IAC7D,eAAe,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAC3B,oBAAC,gBAAgB,QAAE,QAAQ,CAAoB,CAChD,CAAC,CAAC,CAAC,CACF,QAAQ,CACT,CACkC,CAC7B,CACX,CAAA;AACH,CAAC,CAAA;AAED,kBAAkB,CAAC,WAAW,GAAG,oBAAoB,CAAA;AAErD,kBAAkB,CAAC,YAAY,GAAG;IAChC,KAAK,EAAE,SAAS;IAChB,UAAU,EAAE,SAAS;CACtB,CAAA;AAED,eAAe,kBAAkB,CAAA"}
@@ -0,0 +1,8 @@
1
+ import { Alignment, BlockWidth } from './settings';
2
+ interface OverviewBlockGroupSettings {
3
+ align: Alignment;
4
+ blockWidth: BlockWidth;
5
+ }
6
+ export declare const OverviewBlockGroupContext: import("react").Context<OverviewBlockGroupSettings>;
7
+ export declare const useOverviewBlockGroupContext: () => OverviewBlockGroupSettings;
8
+ export {};
@@ -0,0 +1,10 @@
1
+ import { createContext, useContext } from 'react';
2
+ const defaultSettings = {
3
+ align: 'default',
4
+ blockWidth: 'regular'
5
+ };
6
+ export const OverviewBlockGroupContext = createContext(defaultSettings);
7
+ export const useOverviewBlockGroupContext = () => {
8
+ return useContext(OverviewBlockGroupContext);
9
+ };
10
+ //# sourceMappingURL=OverviewBlockGroupContext.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"OverviewBlockGroupContext.js","sourceRoot":"","sources":["../../src/OverviewBlockGroup/OverviewBlockGroupContext.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;AASjD,MAAM,eAAe,GAAG;IACtB,KAAK,EAAE,SAAkB;IACzB,UAAU,EAAE,SAAkB;CAC/B,CAAA;AAED,MAAM,CAAC,MAAM,yBAAyB,GAAG,aAAa,CACpD,eAAe,CAChB,CAAA;AAED,MAAM,CAAC,MAAM,4BAA4B,GAAG,GAAG,EAAE;IAC/C,OAAO,UAAU,CAAC,yBAAyB,CAAC,CAAA;AAC9C,CAAC,CAAA"}
@@ -0,0 +1 @@
1
+ export { default } from './OverviewBlockGroup';
@@ -0,0 +1,2 @@
1
+ export { default } from './OverviewBlockGroup';
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/OverviewBlockGroup/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAA"}
@@ -0,0 +1,2 @@
1
+ export declare type Alignment = 'default' | 'center';
2
+ export declare type BlockWidth = 'narrow' | 'regular' | 'wide';
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=settings.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"settings.js","sourceRoot":"","sources":["../../src/OverviewBlockGroup/settings.ts"],"names":[],"mappings":""}
@@ -0,0 +1,4 @@
1
+ import { FunctionComponent, HTMLAttributes } from 'react';
2
+ declare type Props = HTMLAttributes<HTMLDivElement>;
3
+ declare const OverviewBlockRow: FunctionComponent<Props>;
4
+ export default OverviewBlockRow;
@@ -0,0 +1,26 @@
1
+ var __rest = (this && this.__rest) || function (s, e) {
2
+ var t = {};
3
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
4
+ t[p] = s[p];
5
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
6
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
7
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
8
+ t[p[i]] = s[p[i]];
9
+ }
10
+ return t;
11
+ };
12
+ import React from 'react';
13
+ import { makeStyles } from '@material-ui/core/styles';
14
+ import cx from 'classnames';
15
+ import styles from './styles';
16
+ const useStyles = makeStyles(styles, {
17
+ name: 'PicassoOverviewBlockRow'
18
+ });
19
+ const OverviewBlockRow = props => {
20
+ const { className } = props, rest = __rest(props, ["className"]);
21
+ const classes = useStyles();
22
+ return React.createElement("div", Object.assign({}, rest, { className: cx(classes.root, className) }));
23
+ };
24
+ OverviewBlockRow.displayName = 'OverviewBlockRow';
25
+ export default OverviewBlockRow;
26
+ //# sourceMappingURL=OverviewBlockRow.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"OverviewBlockRow.js","sourceRoot":"","sources":["../../src/OverviewBlockRow/OverviewBlockRow.tsx"],"names":[],"mappings":";;;;;;;;;;;AAAA,OAAO,KAA4C,MAAM,OAAO,CAAA;AAChE,OAAO,EAAS,UAAU,EAAE,MAAM,0BAA0B,CAAA;AAC5D,OAAO,EAAE,MAAM,YAAY,CAAA;AAE3B,OAAO,MAAM,MAAM,UAAU,CAAA;AAI7B,MAAM,SAAS,GAAG,UAAU,CAAQ,MAAM,EAAE;IAC1C,IAAI,EAAE,yBAAyB;CAChC,CAAC,CAAA;AAEF,MAAM,gBAAgB,GAA6B,KAAK,CAAC,EAAE;IACzD,MAAM,EAAE,SAAS,KAAc,KAAK,EAAd,IAAI,UAAK,KAAK,EAA9B,aAAsB,CAAQ,CAAA;IACpC,MAAM,OAAO,GAAG,SAAS,EAAE,CAAA;IAE3B,OAAO,6CAAS,IAAI,IAAE,SAAS,EAAE,EAAE,CAAC,OAAO,CAAC,IAAI,EAAE,SAAS,CAAC,IAAI,CAAA;AAClE,CAAC,CAAA;AAED,gBAAgB,CAAC,WAAW,GAAG,kBAAkB,CAAA;AAEjD,eAAe,gBAAgB,CAAA"}
@@ -0,0 +1 @@
1
+ export { default } from './OverviewBlockRow';
@@ -0,0 +1,2 @@
1
+ export { default } from './OverviewBlockRow';
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/OverviewBlockRow/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,oBAAoB,CAAA"}
@@ -0,0 +1,3 @@
1
+ import { Theme } from '@material-ui/core/styles';
2
+ declare const _default: ({ palette, sizes }: Theme) => import("@material-ui/styles").StyleRules<{}, "root">;
3
+ export default _default;
@@ -0,0 +1,26 @@
1
+ import { createStyles } from '@material-ui/core/styles';
2
+ export default ({ palette, sizes }) => createStyles({
3
+ root: {
4
+ display: 'flex',
5
+ borderRadius: sizes.borderRadius.medium,
6
+ padding: '1rem 0',
7
+ border: `${sizes.borderWidth} solid ${palette.grey.lighter2}`,
8
+ backgroundColor: palette.common.white,
9
+ justifyContent: 'flex-start',
10
+ '& > *': {
11
+ flex: '1 0'
12
+ },
13
+ '&:not(:first-child)': {
14
+ borderTop: 0,
15
+ borderTopLeftRadius: 0,
16
+ borderTopRightRadius: 0
17
+ },
18
+ '&:not(:last-child)': {
19
+ borderBottom: 0,
20
+ borderBottomLeftRadius: 0,
21
+ borderBottomRightRadius: 0,
22
+ paddingBottom: 0
23
+ }
24
+ }
25
+ });
26
+ //# sourceMappingURL=styles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"styles.js","sourceRoot":"","sources":["../../src/OverviewBlockRow/styles.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAS,MAAM,0BAA0B,CAAA;AAE9D,eAAe,CAAC,EAAE,OAAO,EAAE,KAAK,EAAS,EAAE,EAAE,CAC3C,YAAY,CAAC;IACX,IAAI,EAAE;QACJ,OAAO,EAAE,MAAM;QACf,YAAY,EAAE,KAAK,CAAC,YAAY,CAAC,MAAM;QACvC,OAAO,EAAE,QAAQ;QACjB,MAAM,EAAE,GAAG,KAAK,CAAC,WAAW,UAAU,OAAO,CAAC,IAAI,CAAC,QAAQ,EAAE;QAC7D,eAAe,EAAE,OAAO,CAAC,MAAM,CAAC,KAAK;QACrC,cAAc,EAAE,YAAY;QAC5B,OAAO,EAAE;YACP,IAAI,EAAE,KAAK;SACZ;QACD,qBAAqB,EAAE;YACrB,SAAS,EAAE,CAAC;YACZ,mBAAmB,EAAE,CAAC;YACtB,oBAAoB,EAAE,CAAC;SACxB;QACD,oBAAoB,EAAE;YACpB,YAAY,EAAE,CAAC;YACf,sBAAsB,EAAE,CAAC;YACzB,uBAAuB,EAAE,CAAC;YAC1B,aAAa,EAAE,CAAC;SACjB;KACF;CACF,CAAC,CAAA"}
@@ -1,6 +1,8 @@
1
1
  import React, { ReactNode, HTMLAttributes } from 'react';
2
2
  import { BaseProps } from '@toptal/picasso-shared';
3
3
  export interface Props extends BaseProps, HTMLAttributes<HTMLElement> {
4
+ /** Content for copyright. You can override default if needed. */
5
+ copyrightContent?: ReactNode;
4
6
  /** Content for the right side of the `Footer` */
5
7
  rightContent?: ReactNode;
6
8
  }
@@ -14,12 +14,11 @@ import { makeStyles } from '@material-ui/core/styles';
14
14
  import cx from 'classnames';
15
15
  import { PageContext } from '../Page';
16
16
  import styles from './styles';
17
- const currentYear = new Date().getFullYear();
18
17
  const useStyles = makeStyles(styles, {
19
18
  name: 'PicassoPageFooter'
20
19
  });
21
20
  export const PageFooter = forwardRef(function PageFooter(props, ref) {
22
- const { className, style, rightContent } = props, rest = __rest(props, ["className", "style", "rightContent"]);
21
+ const { className, style, rightContent, copyrightContent } = props, rest = __rest(props, ["className", "style", "rightContent", "copyrightContent"]);
23
22
  const classes = useStyles();
24
23
  const { width, fullWidth } = useContext(PageContext);
25
24
  const contentClassnames = cx({
@@ -28,11 +27,13 @@ export const PageFooter = forwardRef(function PageFooter(props, ref) {
28
27
  }, classes.content);
29
28
  return (React.createElement("footer", Object.assign({}, rest, { ref: ref, className: cx(classes.root, className), style: style }),
30
29
  React.createElement("div", { className: contentClassnames },
31
- React.createElement("div", { className: classes.left }, `© Copyright 2010 – ${currentYear} Toptal, LLC`),
30
+ React.createElement("div", { className: classes.left }, copyrightContent),
32
31
  React.createElement("div", { className: classes.right }, rightContent))));
33
32
  });
33
+ const CopyrightContent = () => (React.createElement(React.Fragment, null, `© Copyright 2010 – ${new Date().getFullYear()} Toptal, LLC`));
34
34
  PageFooter.defaultProps = {
35
- rightContent: null
35
+ rightContent: null,
36
+ copyrightContent: React.createElement(CopyrightContent, null)
36
37
  };
37
38
  PageFooter.displayName = 'PageFooter';
38
39
  export default PageFooter;
@@ -1 +1 @@
1
- {"version":3,"file":"PageFooter.js","sourceRoot":"","sources":["../../src/PageFooter/PageFooter.tsx"],"names":[],"mappings":";;;;;;;;;;;AAAA,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,UAAU,EAA6B,MAAM,OAAO,CAAA;AAChF,OAAO,EAAE,UAAU,EAAS,MAAM,0BAA0B,CAAA;AAC5D,OAAO,EAAE,MAAM,YAAY,CAAA;AAG3B,OAAO,EAAE,WAAW,EAAE,MAAM,SAAS,CAAA;AAErC,OAAO,MAAM,MAAM,UAAU,CAAA;AAO7B,MAAM,WAAW,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAA;AAE5C,MAAM,SAAS,GAAG,UAAU,CAAQ,MAAM,EAAE;IAC1C,IAAI,EAAE,mBAAmB;CAC1B,CAAC,CAAA;AAEF,MAAM,CAAC,MAAM,UAAU,GAAG,UAAU,CAAqB,SAAS,UAAU,CAC1E,KAAK,EACL,GAAG;IAEH,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,YAAY,KAAc,KAAK,EAAd,IAAI,UAAK,KAAK,EAAnD,sCAA2C,CAAQ,CAAA;IACzD,MAAM,OAAO,GAAG,SAAS,EAAE,CAAA;IAC3B,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,UAAU,CAAmB,WAAW,CAAC,CAAA;IAEtE,MAAM,iBAAiB,GAAG,EAAE,CAC1B;QACE,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE,SAAS,IAAI,KAAK,KAAK,MAAM;QAClD,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,KAAK,KAAK,MAAM;KACjC,EACD,OAAO,CAAC,OAAO,CAChB,CAAA;IAED,OAAO,CACL,gDACM,IAAI,IACR,GAAG,EAAE,GAAG,EACR,SAAS,EAAE,EAAE,CAAC,OAAO,CAAC,IAAI,EAAE,SAAS,CAAC,EACtC,KAAK,EAAE,KAAK;QAEZ,6BAAK,SAAS,EAAE,iBAAiB;YAC/B,6BAAK,SAAS,EAAE,OAAO,CAAC,IAAI,IACzB,sBAAsB,WAAW,cAAc,CAC5C;YAEN,6BAAK,SAAS,EAAE,OAAO,CAAC,KAAK,IAAG,YAAY,CAAO,CAC/C,CACC,CACV,CAAA;AACH,CAAC,CAAC,CAAA;AAEF,UAAU,CAAC,YAAY,GAAG;IACxB,YAAY,EAAE,IAAI;CACnB,CAAA;AAED,UAAU,CAAC,WAAW,GAAG,YAAY,CAAA;AAErC,eAAe,UAAU,CAAA"}
1
+ {"version":3,"file":"PageFooter.js","sourceRoot":"","sources":["../../src/PageFooter/PageFooter.tsx"],"names":[],"mappings":";;;;;;;;;;;AAAA,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,UAAU,EAA6B,MAAM,OAAO,CAAA;AAChF,OAAO,EAAE,UAAU,EAAS,MAAM,0BAA0B,CAAA;AAC5D,OAAO,EAAE,MAAM,YAAY,CAAA;AAG3B,OAAO,EAAE,WAAW,EAAE,MAAM,SAAS,CAAA;AAErC,OAAO,MAAM,MAAM,UAAU,CAAA;AAS7B,MAAM,SAAS,GAAG,UAAU,CAAQ,MAAM,EAAE;IAC1C,IAAI,EAAE,mBAAmB;CAC1B,CAAC,CAAA;AAEF,MAAM,CAAC,MAAM,UAAU,GAAG,UAAU,CAAqB,SAAS,UAAU,CAC1E,KAAK,EACL,GAAG;IAEH,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,YAAY,EAAE,gBAAgB,KAAc,KAAK,EAAd,IAAI,UAAK,KAAK,EAArE,0DAA6D,CAAQ,CAAA;IAC3E,MAAM,OAAO,GAAG,SAAS,EAAE,CAAA;IAC3B,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,UAAU,CAAmB,WAAW,CAAC,CAAA;IAEtE,MAAM,iBAAiB,GAAG,EAAE,CAC1B;QACE,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE,SAAS,IAAI,KAAK,KAAK,MAAM;QAClD,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,KAAK,KAAK,MAAM;KACjC,EACD,OAAO,CAAC,OAAO,CAChB,CAAA;IAED,OAAO,CACL,gDACM,IAAI,IACR,GAAG,EAAE,GAAG,EACR,SAAS,EAAE,EAAE,CAAC,OAAO,CAAC,IAAI,EAAE,SAAS,CAAC,EACtC,KAAK,EAAE,KAAK;QAEZ,6BAAK,SAAS,EAAE,iBAAiB;YAC/B,6BAAK,SAAS,EAAE,OAAO,CAAC,IAAI,IAAG,gBAAgB,CAAO;YAEtD,6BAAK,SAAS,EAAE,OAAO,CAAC,KAAK,IAAG,YAAY,CAAO,CAC/C,CACC,CACV,CAAA;AACH,CAAC,CAAC,CAAA;AAEF,MAAM,gBAAgB,GAAG,GAAG,EAAE,CAAC,CAC7B,0CAAG,sBAAsB,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,cAAc,CAAI,CACpE,CAAA;AAED,UAAU,CAAC,YAAY,GAAG;IACxB,YAAY,EAAE,IAAI;IAClB,gBAAgB,EAAE,oBAAC,gBAAgB,OAAG;CACvC,CAAA;AAED,UAAU,CAAC,WAAW,GAAG,YAAY,CAAA;AAErC,eAAe,UAAU,CAAA"}
@@ -11,6 +11,7 @@ var __rest = (this && this.__rest) || function (s, e) {
11
11
  };
12
12
  import React, { useLayoutEffect, useRef } from 'react';
13
13
  import { makeStyles } from '@material-ui/core/styles';
14
+ import cx from 'classnames';
14
15
  import Menu from '../Menu';
15
16
  import styles from './styles';
16
17
  const useStyles = makeStyles(styles, {
@@ -38,13 +39,13 @@ export const scrollToSelection = (menuRef, selectedIndex) => {
38
39
  }
39
40
  };
40
41
  const ScrollMenu = props => {
41
- const { selectedIndex, onBlur, children, style, fixedHeader, fixedFooter, role = 'menu' } = props, rest = __rest(props, ["selectedIndex", "onBlur", "children", "style", "fixedHeader", "fixedFooter", "role"]);
42
+ const { selectedIndex, onBlur, children, style, fixedHeader, fixedFooter, className, role } = props, rest = __rest(props, ["selectedIndex", "onBlur", "children", "style", "fixedHeader", "fixedFooter", "className", "role"]);
42
43
  const classes = useStyles();
43
44
  const menuRef = useRef(null);
44
45
  useLayoutEffect(() => scrollToSelection(menuRef, selectedIndex), [
45
46
  selectedIndex
46
47
  ]);
47
- return (React.createElement(Menu, Object.assign({ className: classes.menu, style: style, role: role }, rest, { onMouseDown: e => {
48
+ return (React.createElement(Menu, Object.assign({ className: cx(classes.menu, className), style: style, role: role }, rest, { onMouseDown: e => {
48
49
  // ScrollMenu is used in dropdowns. Prevents blur --> dropdown close when scrolled.
49
50
  e.preventDefault();
50
51
  } }),
@@ -52,5 +53,9 @@ const ScrollMenu = props => {
52
53
  React.createElement("div", { ref: menuRef, className: classes.scrollView, onBlur: onBlur }, children),
53
54
  fixedFooter));
54
55
  };
56
+ ScrollMenu.defaultProps = {
57
+ role: 'menu'
58
+ };
59
+ ScrollMenu.displayName = 'ScrollMenu';
55
60
  export default ScrollMenu;
56
61
  //# sourceMappingURL=ScrollMenu.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"ScrollMenu.js","sourceRoot":"","sources":["../../src/ScrollMenu/ScrollMenu.tsx"],"names":[],"mappings":";;;;;;;;;;;AAAA,OAAO,KAAK,EAAE,EAIZ,eAAe,EACf,MAAM,EACP,MAAM,OAAO,CAAA;AACd,OAAO,EAAE,UAAU,EAAS,MAAM,0BAA0B,CAAA;AAG5D,OAAO,IAAI,MAAM,SAAS,CAAA;AAC1B,OAAO,MAAM,MAAM,UAAU,CAAA;AAU7B,MAAM,SAAS,GAAG,UAAU,CAAQ,MAAM,EAAE;IAC1C,IAAI,EAAE,mBAAmB;CAC1B,CAAC,CAAA;AAEF,MAAM,mBAAmB,GAAG,CAC1B,OAAkC,EAClC,aAA6B,EAC7B,EAAE;;IACF,OAAA,OAAO,aAAa,KAAK,QAAQ;QAC/B,CAAC,CAAC,MAAA,OAAO,CAAC,OAAO,0CAAE,QAAQ,CAAC,aAAa,CAAC;QAC1C,CAAC,CAAC,SAAS,CAAA;CAAA,CAAA;AAEf,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAC/B,OAAkC,EAClC,aAA6B,EAC7B,EAAE;IACF,MAAM,QAAQ,GAAG,OAAO,CAAC,OAAO,CAAA;IAChC,MAAM,YAAY,GAAG,mBAAmB,CAAC,OAAO,EAAE,aAAa,CAAC,CAAA;IAEhE,IAAI,CAAC,QAAQ,IAAI,CAAC,YAAY,EAAE;QAC9B,OAAM;KACP;IAED,MAAM,QAAQ,GAAG,QAAQ,CAAC,qBAAqB,EAAE,CAAA;IACjD,MAAM,YAAY,GAAG,YAAY,CAAC,qBAAqB,EAAE,CAAA;IAEzD,IAAI,YAAY,CAAC,GAAG,GAAG,QAAQ,CAAC,GAAG,EAAE;QACnC,QAAQ,CAAC,SAAS,IAAI,QAAQ,CAAC,GAAG,GAAG,YAAY,CAAC,GAAG,CAAA;KACtD;SAAM,IAAI,YAAY,CAAC,MAAM,GAAG,QAAQ,CAAC,MAAM,EAAE;QAChD,QAAQ,CAAC,SAAS,IAAI,YAAY,CAAC,MAAM,GAAG,QAAQ,CAAC,MAAM,CAAA;KAC5D;AACH,CAAC,CAAA;AAED,MAAM,UAAU,GAA6B,KAAK,CAAC,EAAE;IACnD,MAAM,EACJ,aAAa,EACb,MAAM,EACN,QAAQ,EACR,KAAK,EACL,WAAW,EACX,WAAW,EACX,IAAI,GAAG,MAAM,KAEX,KAAK,EADJ,IAAI,UACL,KAAK,EATH,sFASL,CAAQ,CAAA;IACT,MAAM,OAAO,GAAG,SAAS,EAAE,CAAA;IAC3B,MAAM,OAAO,GAAG,MAAM,CAAiB,IAAI,CAAC,CAAA;IAE5C,eAAe,CAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC,OAAO,EAAE,aAAa,CAAC,EAAE;QAC/D,aAAa;KACd,CAAC,CAAA;IAEF,OAAO,CACL,oBAAC,IAAI,kBACH,SAAS,EAAE,OAAO,CAAC,IAAI,EACvB,KAAK,EAAE,KAAK,EACZ,IAAI,EAAE,IAAI,IAEN,IAAI,IACR,WAAW,EAAE,CAAC,CAAC,EAAE;YACf,mFAAmF;YACnF,CAAC,CAAC,cAAc,EAAE,CAAA;QACpB,CAAC;QAEA,WAAW;QACZ,6BAAK,GAAG,EAAE,OAAO,EAAE,SAAS,EAAE,OAAO,CAAC,UAAU,EAAE,MAAM,EAAE,MAAM,IAC7D,QAAQ,CACL;QACL,WAAW,CACP,CACR,CAAA;AACH,CAAC,CAAA;AAED,eAAe,UAAU,CAAA"}
1
+ {"version":3,"file":"ScrollMenu.js","sourceRoot":"","sources":["../../src/ScrollMenu/ScrollMenu.tsx"],"names":[],"mappings":";;;;;;;;;;;AAAA,OAAO,KAAK,EAAE,EAIZ,eAAe,EACf,MAAM,EACP,MAAM,OAAO,CAAA;AACd,OAAO,EAAE,UAAU,EAAS,MAAM,0BAA0B,CAAA;AAE5D,OAAO,EAAE,MAAM,YAAY,CAAA;AAE3B,OAAO,IAAI,MAAM,SAAS,CAAA;AAC1B,OAAO,MAAM,MAAM,UAAU,CAAA;AAU7B,MAAM,SAAS,GAAG,UAAU,CAAQ,MAAM,EAAE;IAC1C,IAAI,EAAE,mBAAmB;CAC1B,CAAC,CAAA;AAEF,MAAM,mBAAmB,GAAG,CAC1B,OAAkC,EAClC,aAA6B,EAC7B,EAAE;;IACF,OAAA,OAAO,aAAa,KAAK,QAAQ;QAC/B,CAAC,CAAC,MAAA,OAAO,CAAC,OAAO,0CAAE,QAAQ,CAAC,aAAa,CAAC;QAC1C,CAAC,CAAC,SAAS,CAAA;CAAA,CAAA;AAEf,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAC/B,OAAkC,EAClC,aAA6B,EAC7B,EAAE;IACF,MAAM,QAAQ,GAAG,OAAO,CAAC,OAAO,CAAA;IAChC,MAAM,YAAY,GAAG,mBAAmB,CAAC,OAAO,EAAE,aAAa,CAAC,CAAA;IAEhE,IAAI,CAAC,QAAQ,IAAI,CAAC,YAAY,EAAE;QAC9B,OAAM;KACP;IAED,MAAM,QAAQ,GAAG,QAAQ,CAAC,qBAAqB,EAAE,CAAA;IACjD,MAAM,YAAY,GAAG,YAAY,CAAC,qBAAqB,EAAE,CAAA;IAEzD,IAAI,YAAY,CAAC,GAAG,GAAG,QAAQ,CAAC,GAAG,EAAE;QACnC,QAAQ,CAAC,SAAS,IAAI,QAAQ,CAAC,GAAG,GAAG,YAAY,CAAC,GAAG,CAAA;KACtD;SAAM,IAAI,YAAY,CAAC,MAAM,GAAG,QAAQ,CAAC,MAAM,EAAE;QAChD,QAAQ,CAAC,SAAS,IAAI,YAAY,CAAC,MAAM,GAAG,QAAQ,CAAC,MAAM,CAAA;KAC5D;AACH,CAAC,CAAA;AAED,MAAM,UAAU,GAA6B,KAAK,CAAC,EAAE;IACnD,MAAM,EACJ,aAAa,EACb,MAAM,EACN,QAAQ,EACR,KAAK,EACL,WAAW,EACX,WAAW,EACX,SAAS,EACT,IAAI,KAEF,KAAK,EADJ,IAAI,UACL,KAAK,EAVH,mGAUL,CAAQ,CAAA;IACT,MAAM,OAAO,GAAG,SAAS,EAAE,CAAA;IAC3B,MAAM,OAAO,GAAG,MAAM,CAAiB,IAAI,CAAC,CAAA;IAE5C,eAAe,CAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC,OAAO,EAAE,aAAa,CAAC,EAAE;QAC/D,aAAa;KACd,CAAC,CAAA;IAEF,OAAO,CACL,oBAAC,IAAI,kBACH,SAAS,EAAE,EAAE,CAAC,OAAO,CAAC,IAAI,EAAE,SAAS,CAAC,EACtC,KAAK,EAAE,KAAK,EACZ,IAAI,EAAE,IAAI,IAEN,IAAI,IACR,WAAW,EAAE,CAAC,CAAC,EAAE;YACf,mFAAmF;YACnF,CAAC,CAAC,cAAc,EAAE,CAAA;QACpB,CAAC;QAEA,WAAW;QACZ,6BAAK,GAAG,EAAE,OAAO,EAAE,SAAS,EAAE,OAAO,CAAC,UAAU,EAAE,MAAM,EAAE,MAAM,IAC7D,QAAQ,CACL;QACL,WAAW,CACP,CACR,CAAA;AACH,CAAC,CAAA;AAED,UAAU,CAAC,YAAY,GAAG;IACxB,IAAI,EAAE,MAAM;CACb,CAAA;AAED,UAAU,CAAC,WAAW,GAAG,YAAY,CAAA;AAErC,eAAe,UAAU,CAAA"}
@@ -0,0 +1,29 @@
1
+ import React, { ReactNode } from 'react';
2
+ import { SizeType, BaseProps } from '@toptal/picasso-shared';
3
+ declare type VariantType = 'bordered' | 'default' | 'withHeaderBar';
4
+ export interface Props extends BaseProps {
5
+ /** Title of the Section */
6
+ title?: ReactNode;
7
+ /** Subtitle of the Section */
8
+ subtitle?: ReactNode;
9
+ /** Additional actions of the Section */
10
+ actions?: ReactNode;
11
+ /** Main content of the Section */
12
+ children?: ReactNode;
13
+ /** Whether section can be collapsed */
14
+ collapsible?: boolean;
15
+ /** Default collapsed value **(applied if `collapsible: true`)** */
16
+ defaultCollapsed?: boolean;
17
+ testIds?: {
18
+ header?: string;
19
+ title?: string;
20
+ subtitle?: string;
21
+ actions?: string;
22
+ collapse?: string;
23
+ };
24
+ variant?: VariantType;
25
+ /** Title size of the inner text */
26
+ titleSize?: SizeType<'small' | 'medium'>;
27
+ }
28
+ export declare const Section: React.ForwardRefExoticComponent<Props & React.RefAttributes<HTMLDivElement>>;
29
+ export default Section;
@@ -0,0 +1,60 @@
1
+ var __rest = (this && this.__rest) || function (s, e) {
2
+ var t = {};
3
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
4
+ t[p] = s[p];
5
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
6
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
7
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
8
+ t[p[i]] = s[p[i]];
9
+ }
10
+ return t;
11
+ };
12
+ import cx from 'classnames';
13
+ import React, { forwardRef, useState } from 'react';
14
+ import { makeStyles } from '@material-ui/core/styles';
15
+ import { Collapse } from '@material-ui/core';
16
+ import styles from './styles';
17
+ import Button from '../Button';
18
+ import Container from '../Container';
19
+ import Typography from '../Typography';
20
+ import { isString } from '../utils';
21
+ import { Rotate180 } from '../utils/Transitions';
22
+ import { ArrowDownMinor16 } from '../Icon';
23
+ const useStyles = makeStyles(styles, {
24
+ name: 'PicassoSection'
25
+ });
26
+ export const Section = forwardRef(function Section(props, ref) {
27
+ const { className, style, title, subtitle, actions, children, testIds, collapsible = false, defaultCollapsed = true, variant = 'default', titleSize = 'medium' } = props, rest = __rest(props, ["className", "style", "title", "subtitle", "actions", "children", "testIds", "collapsible", "defaultCollapsed", "variant", "titleSize"]);
28
+ const classes = useStyles();
29
+ const [collapsed, setCollapsed] = useState(collapsible ? defaultCollapsed : false);
30
+ const toggleCollapse = () => setCollapsed(!collapsed);
31
+ const renderTitle = () => title ? (React.createElement(Typography, { as: isString(title) ? undefined : 'div', className: classes.title, "data-testid": testIds === null || testIds === void 0 ? void 0 : testIds.title, variant: 'heading', size: titleSize }, title)) : null;
32
+ const renderSubtitle = () => subtitle ? (React.createElement(Typography, { as: isString(title) ? undefined : 'div', className: classes.subtitle, "data-testid": testIds === null || testIds === void 0 ? void 0 : testIds.subtitle, size: 'medium', color: 'dark-grey' }, subtitle)) : null;
33
+ const renderCollapse = () => collapsible ? (React.createElement(Button.Circular, { onClick: toggleCollapse, "data-testid": testIds === null || testIds === void 0 ? void 0 : testIds.collapse, variant: 'flat', icon: React.createElement(Rotate180, { on: !collapsed },
34
+ React.createElement(ArrowDownMinor16, null)) })) : null;
35
+ const hasActions = actions || collapsible;
36
+ const renderActions = () => hasActions ? (React.createElement(Container, { "data-testid": testIds === null || testIds === void 0 ? void 0 : testIds.actions, className: classes.actions },
37
+ actions,
38
+ renderCollapse())) : null;
39
+ const hasHeader = title || subtitle || hasActions;
40
+ return (React.createElement(Container, Object.assign({ ref: ref, className: cx({
41
+ [classes[variant]]: true,
42
+ [classes.collapsed]: variant === 'default' && collapsed
43
+ }, classes.root, className), variant: ['bordered', 'withHeaderBar'].includes(variant) ? 'white' : undefined, style: style }, rest),
44
+ hasHeader && (React.createElement(Container, { "data-testid": testIds === null || testIds === void 0 ? void 0 : testIds.header, className: cx({
45
+ [classes[`${variant}Header`]]: true,
46
+ [classes[`${variant}CollapsedHeader`]]: collapsed
47
+ }) },
48
+ renderTitle(),
49
+ renderSubtitle(),
50
+ renderActions())),
51
+ React.createElement(Collapse, { in: !collapsed, unmountOnExit: true }, children)));
52
+ });
53
+ Section.displayName = 'Section';
54
+ Section.defaultProps = {
55
+ collapsible: false,
56
+ defaultCollapsed: true,
57
+ titleSize: 'medium'
58
+ };
59
+ export default Section;
60
+ //# sourceMappingURL=Section.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Section.js","sourceRoot":"","sources":["../../src/Section/Section.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ import { OmitInternalProps } from '@toptal/picasso-shared';
2
+ import { Props } from './Section';
3
+ export { default } from './Section';
4
+ export declare type SectionProps = OmitInternalProps<Props>;
@@ -0,0 +1,2 @@
1
+ export { default } from './Section';
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/Section/index.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA"}
@@ -0,0 +1,3 @@
1
+ import { Theme } from '@material-ui/core';
2
+ declare const _default: ({ sizes, palette }: Theme) => import("@material-ui/styles").StyleRules<{}, "default" | "title" | "root" | "bordered" | "actions" | "subtitle" | "collapsed" | "withHeaderBar" | "defaultHeader" | "borderedHeader" | "withHeaderBarHeader" | "defaultCollapsedHeader" | "borderedCollapsedHeader" | "withHeaderBarCollapsedHeader">;
3
+ export default _default;
@@ -0,0 +1,62 @@
1
+ import { createStyles } from '@material-ui/core';
2
+ const defaultHeader = {
3
+ display: 'flex',
4
+ paddingBottom: '1.5rem'
5
+ };
6
+ const defaultCollapsedHeader = {
7
+ paddingBottom: '0'
8
+ };
9
+ export default ({ sizes, palette }) => createStyles({
10
+ root: {
11
+ paddingTop: '2rem'
12
+ },
13
+ title: {
14
+ marginRight: '1rem',
15
+ minWidth: 0
16
+ },
17
+ subtitle: {
18
+ alignSelf: 'center',
19
+ marginRight: '1rem',
20
+ minWidth: 0
21
+ },
22
+ actions: {
23
+ display: 'flex',
24
+ marginLeft: 'auto'
25
+ },
26
+ collapsed: {
27
+ paddingBottom: '2rem'
28
+ },
29
+ default: {},
30
+ bordered: {
31
+ borderRadius: sizes.borderRadius.medium,
32
+ border: `solid ${sizes.borderWidth} ${palette.grey.light}`,
33
+ padding: '2rem',
34
+ '& > :last-child': {
35
+ paddingBottom: '0'
36
+ }
37
+ },
38
+ withHeaderBar: {
39
+ padding: 0,
40
+ '& > :last-child:not(:first-child)': {
41
+ padding: '1.5rem'
42
+ },
43
+ borderRadius: sizes.borderRadius.medium,
44
+ border: `solid ${sizes.borderWidth} ${palette.grey.light2}`
45
+ },
46
+ defaultHeader,
47
+ borderedHeader: defaultHeader,
48
+ withHeaderBarHeader: {
49
+ display: 'flex',
50
+ padding: '0.75rem 1rem',
51
+ borderRadius: `${sizes.borderRadius.medium} ${sizes.borderRadius.medium} 0 0`,
52
+ borderBottom: `solid ${sizes.borderWidth} ${palette.grey.light2}`,
53
+ backgroundColor: palette.grey.lighter
54
+ },
55
+ defaultCollapsedHeader,
56
+ borderedCollapsedHeader: defaultCollapsedHeader,
57
+ withHeaderBarCollapsedHeader: {
58
+ borderBottom: 'none',
59
+ borderRadius: sizes.borderRadius.medium
60
+ }
61
+ });
62
+ //# sourceMappingURL=styles.js.map