@toptal/picasso-lab 9.3.1 → 10.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.
- package/{dist-package/Calendar → Calendar}/Calendar.d.ts +0 -0
- package/{dist-package/Calendar → Calendar}/Calendar.js +0 -0
- package/{dist-package/Calendar → Calendar}/Calendar.js.map +0 -0
- package/{dist-package/Calendar → Calendar}/index.d.ts +0 -0
- package/{dist-package/Calendar → Calendar}/index.js +0 -0
- package/{dist-package/Calendar → Calendar}/index.js.map +0 -0
- package/{dist-package/Calendar → Calendar}/styles.d.ts +0 -0
- package/{dist-package/Calendar → Calendar}/styles.js +0 -0
- package/{dist-package/Calendar → Calendar}/styles.js.map +0 -0
- package/{dist-package/Calendar → Calendar}/types.d.ts +0 -0
- package/{dist-package/Calendar → Calendar}/types.js +0 -0
- package/{dist-package/Calendar → Calendar}/types.js.map +0 -0
- package/{dist-package/DatePicker → DatePicker}/DatePicker.d.ts +0 -0
- package/{dist-package/DatePicker → DatePicker}/DatePicker.js +0 -0
- package/{dist-package/DatePicker → DatePicker}/DatePicker.js.map +0 -0
- package/{dist-package/DatePicker → DatePicker}/constants.d.ts +0 -0
- package/{dist-package/DatePicker → DatePicker}/constants.js +0 -0
- package/{dist-package/DatePicker → DatePicker}/constants.js.map +0 -0
- package/{dist-package/DatePicker → DatePicker}/index.d.ts +0 -0
- package/{dist-package/DatePicker → DatePicker}/index.js +0 -0
- package/{dist-package/DatePicker → DatePicker}/index.js.map +0 -0
- package/{dist-package/DatePicker → DatePicker}/styles.d.ts +0 -0
- package/{dist-package/DatePicker → DatePicker}/styles.js +0 -0
- package/{dist-package/DatePicker → DatePicker}/styles.js.map +0 -0
- package/{dist-package/DatePicker → DatePicker}/types.d.ts +0 -0
- package/{dist-package/DatePicker → DatePicker}/types.js +0 -0
- package/{dist-package/DatePicker → DatePicker}/types.js.map +0 -0
- package/{dist-package/DatePicker → DatePicker}/utils.d.ts +0 -0
- package/{dist-package/DatePicker → DatePicker}/utils.js +0 -0
- package/{dist-package/DatePicker → DatePicker}/utils.js.map +0 -0
- package/{dist-package/Drawer → Drawer}/Drawer.d.ts +0 -0
- package/{dist-package/Drawer → Drawer}/Drawer.js +0 -0
- package/{dist-package/Drawer → Drawer}/Drawer.js.map +0 -0
- package/{dist-package/Drawer → Drawer}/index.d.ts +0 -0
- package/{dist-package/Drawer → Drawer}/index.js +0 -0
- package/{dist-package/Drawer → Drawer}/index.js.map +0 -0
- package/{dist-package/Drawer → Drawer}/styles.d.ts +0 -0
- package/{dist-package/Drawer → Drawer}/styles.js +0 -0
- package/{dist-package/Drawer → Drawer}/styles.js.map +0 -0
- package/{dist-package/DrawerTitle → DrawerTitle}/DrawerTitle.d.ts +0 -0
- package/{dist-package/DrawerTitle → DrawerTitle}/DrawerTitle.js +0 -0
- package/{dist-package/DrawerTitle → DrawerTitle}/DrawerTitle.js.map +0 -0
- package/{dist-package/DrawerTitle → DrawerTitle}/index.d.ts +0 -0
- package/{dist-package/DrawerTitle → DrawerTitle}/index.js +0 -0
- package/{dist-package/DrawerTitle → DrawerTitle}/index.js.map +0 -0
- package/{dist-package/DrawerTitle → DrawerTitle}/styles.d.ts +0 -0
- package/{dist-package/DrawerTitle → DrawerTitle}/styles.js +0 -0
- package/{dist-package/DrawerTitle → DrawerTitle}/styles.js.map +0 -0
- package/{dist-package/Dropzone → Dropzone}/Dropzone.d.ts +0 -0
- package/{dist-package/Dropzone → Dropzone}/Dropzone.js +0 -0
- package/{dist-package/Dropzone → Dropzone}/Dropzone.js.map +0 -0
- package/{dist-package/Dropzone → Dropzone}/index.d.ts +0 -0
- package/{dist-package/Dropzone → Dropzone}/index.js +0 -0
- package/{dist-package/Dropzone → Dropzone}/index.js.map +0 -0
- package/{dist-package/Dropzone → Dropzone}/styles.d.ts +0 -0
- package/{dist-package/Dropzone → Dropzone}/styles.js +0 -0
- package/{dist-package/Dropzone → Dropzone}/styles.js.map +0 -0
- package/{dist-package/Dropzone → Dropzone}/types.d.ts +0 -0
- package/{dist-package/Dropzone → Dropzone}/types.js +0 -0
- package/{dist-package/Dropzone → Dropzone}/types.js.map +0 -0
- package/{dist-package/EmptyState → EmptyState}/EmptyState.d.ts +0 -0
- package/{dist-package/EmptyState → EmptyState}/EmptyState.js +0 -0
- package/{dist-package/EmptyState → EmptyState}/EmptyState.js.map +0 -0
- package/{dist-package/EmptyState → EmptyState}/index.d.ts +0 -0
- package/{dist-package/EmptyState → EmptyState}/index.js +0 -0
- package/{dist-package/EmptyState → EmptyState}/index.js.map +0 -0
- package/{dist-package/EmptyStateCollection → EmptyStateCollection}/EmptyStateCollection.d.ts +0 -0
- package/{dist-package/EmptyStateCollection → EmptyStateCollection}/EmptyStateCollection.js +0 -0
- package/{dist-package/EmptyStateCollection → EmptyStateCollection}/EmptyStateCollection.js.map +0 -0
- package/{dist-package/EmptyStateCollection → EmptyStateCollection}/index.d.ts +0 -0
- package/{dist-package/EmptyStateCollection → EmptyStateCollection}/index.js +0 -0
- package/{dist-package/EmptyStateCollection → EmptyStateCollection}/index.js.map +0 -0
- package/{dist-package/EmptyStateCollection → EmptyStateCollection}/styles.d.ts +0 -0
- package/{dist-package/EmptyStateCollection → EmptyStateCollection}/styles.js +0 -0
- package/{dist-package/EmptyStateCollection → EmptyStateCollection}/styles.js.map +0 -0
- package/{dist-package/EmptyStatePage → EmptyStatePage}/EmptyStatePage.d.ts +0 -0
- package/{dist-package/EmptyStatePage → EmptyStatePage}/EmptyStatePage.js +0 -0
- package/{dist-package/EmptyStatePage → EmptyStatePage}/EmptyStatePage.js.map +0 -0
- package/{dist-package/EmptyStatePage → EmptyStatePage}/index.d.ts +0 -0
- package/{dist-package/EmptyStatePage → EmptyStatePage}/index.js +0 -0
- package/{dist-package/EmptyStatePage → EmptyStatePage}/index.js.map +0 -0
- package/{dist-package/EmptyStatePage → EmptyStatePage}/styles.d.ts +0 -0
- package/{dist-package/EmptyStatePage → EmptyStatePage}/styles.js +0 -0
- package/{dist-package/EmptyStatePage → EmptyStatePage}/styles.js.map +0 -0
- package/{dist-package/Note → Note}/Note.d.ts +0 -0
- package/{dist-package/Note → Note}/Note.js +0 -0
- package/{dist-package/Note → Note}/Note.js.map +0 -0
- package/{dist-package/Note → Note}/index.d.ts +0 -0
- package/{dist-package/Note → Note}/index.js +0 -0
- package/{dist-package/Note → Note}/index.js.map +0 -0
- package/{dist-package/Note → Note}/styles.d.ts +0 -0
- package/{dist-package/Note → Note}/styles.js +0 -0
- package/{dist-package/Note → Note}/styles.js.map +0 -0
- package/{dist-package/NoteContent → NoteContent}/NoteContent.d.ts +0 -0
- package/{dist-package/NoteContent → NoteContent}/NoteContent.js +0 -0
- package/{dist-package/NoteContent → NoteContent}/NoteContent.js.map +0 -0
- package/{dist-package/NoteContent → NoteContent}/index.d.ts +0 -0
- package/{dist-package/NoteContent → NoteContent}/index.js +0 -0
- package/{dist-package/NoteContent → NoteContent}/index.js.map +0 -0
- package/{dist-package/NoteSubtitle → NoteSubtitle}/NoteSubtitle.d.ts +0 -0
- package/{dist-package/NoteSubtitle → NoteSubtitle}/NoteSubtitle.js +0 -0
- package/{dist-package/NoteSubtitle → NoteSubtitle}/NoteSubtitle.js.map +0 -0
- package/{dist-package/NoteSubtitle → NoteSubtitle}/index.d.ts +0 -0
- package/{dist-package/NoteSubtitle → NoteSubtitle}/index.js +0 -0
- package/{dist-package/NoteSubtitle → NoteSubtitle}/index.js.map +0 -0
- package/{dist-package/NoteTitle → NoteTitle}/NoteTitle.d.ts +0 -0
- package/{dist-package/NoteTitle → NoteTitle}/NoteTitle.js +0 -0
- package/{dist-package/NoteTitle → NoteTitle}/NoteTitle.js.map +0 -0
- package/{dist-package/NoteTitle → NoteTitle}/index.d.ts +0 -0
- package/{dist-package/NoteTitle → NoteTitle}/index.js +0 -0
- package/{dist-package/NoteTitle → NoteTitle}/index.js.map +0 -0
- package/{dist-package/NoteTitle → NoteTitle}/styles.d.ts +0 -0
- package/{dist-package/NoteTitle → NoteTitle}/styles.js +0 -0
- package/{dist-package/NoteTitle → NoteTitle}/styles.js.map +0 -0
- package/{dist-package/OverviewBlock → OverviewBlock}/OverviewBlock.d.ts +0 -0
- package/{dist-package/OverviewBlock → OverviewBlock}/OverviewBlock.js +0 -0
- package/{dist-package/OverviewBlock → OverviewBlock}/OverviewBlock.js.map +0 -0
- package/{dist-package/OverviewBlock → OverviewBlock}/index.d.ts +0 -0
- package/{dist-package/OverviewBlock → OverviewBlock}/index.js +0 -0
- package/{dist-package/OverviewBlock → OverviewBlock}/index.js.map +0 -0
- package/{dist-package/OverviewBlock → OverviewBlock}/styles.d.ts +0 -0
- package/{dist-package/OverviewBlock → OverviewBlock}/styles.js +0 -0
- package/{dist-package/OverviewBlock → OverviewBlock}/styles.js.map +0 -0
- package/{dist-package/OverviewBlockGroup → OverviewBlockGroup}/OverviewBlockGroup.d.ts +0 -0
- package/{dist-package/OverviewBlockGroup → OverviewBlockGroup}/OverviewBlockGroup.js +0 -0
- package/{dist-package/OverviewBlockGroup → OverviewBlockGroup}/OverviewBlockGroup.js.map +0 -0
- package/{dist-package/OverviewBlockGroup → OverviewBlockGroup}/OverviewBlockGroupContext.d.ts +0 -0
- package/{dist-package/OverviewBlockGroup → OverviewBlockGroup}/OverviewBlockGroupContext.js +0 -0
- package/{dist-package/OverviewBlockGroup → OverviewBlockGroup}/OverviewBlockGroupContext.js.map +0 -0
- package/{dist-package/OverviewBlockGroup → OverviewBlockGroup}/index.d.ts +0 -0
- package/{dist-package/OverviewBlockGroup → OverviewBlockGroup}/index.js +0 -0
- package/{dist-package/OverviewBlockGroup → OverviewBlockGroup}/index.js.map +0 -0
- package/{dist-package/OverviewBlockGroup → OverviewBlockGroup}/settings.d.ts +0 -0
- package/{dist-package/OverviewBlockGroup → OverviewBlockGroup}/settings.js +0 -0
- package/{dist-package/OverviewBlockGroup → OverviewBlockGroup}/settings.js.map +0 -0
- package/{dist-package/OverviewBlockRow → OverviewBlockRow}/OverviewBlockRow.d.ts +0 -0
- package/{dist-package/OverviewBlockRow → OverviewBlockRow}/OverviewBlockRow.js +0 -0
- package/{dist-package/OverviewBlockRow → OverviewBlockRow}/OverviewBlockRow.js.map +0 -0
- package/{dist-package/OverviewBlockRow → OverviewBlockRow}/index.d.ts +0 -0
- package/{dist-package/OverviewBlockRow → OverviewBlockRow}/index.js +0 -0
- package/{dist-package/OverviewBlockRow → OverviewBlockRow}/index.js.map +0 -0
- package/{dist-package/OverviewBlockRow → OverviewBlockRow}/styles.d.ts +0 -0
- package/{dist-package/OverviewBlockRow → OverviewBlockRow}/styles.js +0 -0
- package/{dist-package/OverviewBlockRow → OverviewBlockRow}/styles.js.map +0 -0
- package/{dist-package/Section → Section}/Section.d.ts +0 -0
- package/{dist-package/Section → Section}/Section.js +0 -0
- package/{dist-package/Section → Section}/Section.js.map +0 -0
- package/{dist-package/Section → Section}/index.d.ts +0 -0
- package/{dist-package/Section → Section}/index.js +0 -0
- package/{dist-package/Section → Section}/index.js.map +0 -0
- package/{dist-package/Section → Section}/styles.d.ts +0 -0
- package/{dist-package/Section → Section}/styles.js +0 -0
- package/{dist-package/Section → Section}/styles.js.map +0 -0
- package/{dist-package/Timeline → Timeline}/Timeline.d.ts +0 -0
- package/{dist-package/Timeline → Timeline}/Timeline.js +0 -0
- package/{dist-package/Timeline → Timeline}/Timeline.js.map +0 -0
- package/{dist-package/Timeline → Timeline}/index.d.ts +0 -0
- package/{dist-package/Timeline → Timeline}/index.js +0 -0
- package/{dist-package/Timeline → Timeline}/index.js.map +0 -0
- package/{dist-package/TimelineRow → TimelineRow}/TimelineRow.d.ts +0 -0
- package/{dist-package/TimelineRow → TimelineRow}/TimelineRow.js +0 -0
- package/{dist-package/TimelineRow → TimelineRow}/TimelineRow.js.map +0 -0
- package/{dist-package/TimelineRow → TimelineRow}/index.d.ts +0 -0
- package/{dist-package/TimelineRow → TimelineRow}/index.js +0 -0
- package/{dist-package/TimelineRow → TimelineRow}/index.js.map +0 -0
- package/{dist-package/TimelineRow → TimelineRow}/styles.d.ts +0 -0
- package/{dist-package/TimelineRow → TimelineRow}/styles.js +0 -0
- package/{dist-package/TimelineRow → TimelineRow}/styles.js.map +0 -0
- package/{dist-package/TypographyOverflow → TypographyOverflow}/TypographyOverflow.d.ts +0 -0
- package/{dist-package/TypographyOverflow → TypographyOverflow}/TypographyOverflow.js +0 -0
- package/{dist-package/TypographyOverflow → TypographyOverflow}/TypographyOverflow.js.map +0 -0
- package/{dist-package/TypographyOverflow → TypographyOverflow}/index.d.ts +0 -0
- package/{dist-package/TypographyOverflow → TypographyOverflow}/index.js +0 -0
- package/{dist-package/TypographyOverflow → TypographyOverflow}/index.js.map +0 -0
- package/{dist-package/TypographyOverflow → TypographyOverflow}/styles.d.ts +0 -0
- package/{dist-package/TypographyOverflow → TypographyOverflow}/styles.js +0 -0
- package/{dist-package/TypographyOverflow → TypographyOverflow}/styles.js.map +0 -0
- package/{dist-package/index.d.ts → index.d.ts} +0 -0
- package/{dist-package/index.js → index.js} +0 -0
- package/{dist-package/index.js.map → index.js.map} +0 -0
- package/package.json +5 -5
- package/CHANGELOG.md +0 -1385
- package/dist-package/README.md +0 -26
- package/dist-package/package.json +0 -53
- package/src/Calendar/Calendar.tsx +0 -215
- package/src/Calendar/__snapshots__/test.tsx.snap +0 -447
- package/src/Calendar/index.ts +0 -2
- package/src/Calendar/styles.ts +0 -104
- package/src/Calendar/test.tsx +0 -20
- package/src/Calendar/types.ts +0 -42
- package/src/DatePicker/DatePicker.tsx +0 -366
- package/src/DatePicker/__image_snapshots__/datepicker-full-width-snap.png +0 -0
- package/src/DatePicker/__image_snapshots__/datepicker-with-custom-day-rendering-snap.png +0 -0
- package/src/DatePicker/__snapshots__/test.tsx.snap +0 -51
- package/src/DatePicker/constants.ts +0 -2
- package/src/DatePicker/index.ts +0 -5
- package/src/DatePicker/story/AllowCustomValue.example.tsx +0 -33
- package/src/DatePicker/story/Autocomplete.example.tsx +0 -47
- package/src/DatePicker/story/Default.example.tsx +0 -19
- package/src/DatePicker/story/Error.example.tsx +0 -26
- package/src/DatePicker/story/Range.example.tsx +0 -22
- package/src/DatePicker/story/WithCustomDayRendering.example.tsx +0 -47
- package/src/DatePicker/story/WithInitialValue.example.tsx +0 -19
- package/src/DatePicker/story/WithInputProps.example.tsx +0 -24
- package/src/DatePicker/story/WithNoHideOnSelect.example.tsx +0 -20
- package/src/DatePicker/story/WithOnBlurHandler.example.tsx +0 -22
- package/src/DatePicker/story/WithSelectionLimits.example.tsx +0 -32
- package/src/DatePicker/story/WithTimezone.example.tsx +0 -25
- package/src/DatePicker/story/index.jsx +0 -50
- package/src/DatePicker/styles.ts +0 -8
- package/src/DatePicker/test.tsx +0 -370
- package/src/DatePicker/types.ts +0 -13
- package/src/DatePicker/utils.ts +0 -123
- package/src/Drawer/Drawer.tsx +0 -105
- package/src/Drawer/__image_snapshots__/drawer-custom-title-effect-1-snap.png +0 -0
- package/src/Drawer/__image_snapshots__/drawer-custom-title-snap.png +0 -0
- package/src/Drawer/__image_snapshots__/drawer-default-effect-1-snap.png +0 -0
- package/src/Drawer/__image_snapshots__/drawer-default-snap.png +0 -0
- package/src/Drawer/__image_snapshots__/drawer-width-effect-1-snap.png +0 -0
- package/src/Drawer/__image_snapshots__/drawer-width-effect-2-snap.png +0 -0
- package/src/Drawer/__image_snapshots__/drawer-width-effect-3-snap.png +0 -0
- package/src/Drawer/__image_snapshots__/drawer-width-effect-4-snap.png +0 -0
- package/src/Drawer/__image_snapshots__/drawer-width-effect-5-snap.png +0 -0
- package/src/Drawer/__image_snapshots__/drawer-width-snap.png +0 -0
- package/src/Drawer/__image_snapshots__/drawer-without-title-effect-1-snap.png +0 -0
- package/src/Drawer/__image_snapshots__/drawer-without-title-snap.png +0 -0
- package/src/Drawer/index.ts +0 -6
- package/src/Drawer/story/CustomTitle.example.tsx +0 -32
- package/src/Drawer/story/Default.example.tsx +0 -29
- package/src/Drawer/story/DrawerAndNotification.example.tsx +0 -34
- package/src/Drawer/story/Widths.example.tsx +0 -46
- package/src/Drawer/story/WithoutTitle.example.tsx +0 -22
- package/src/Drawer/story/index.jsx +0 -80
- package/src/Drawer/styles.ts +0 -42
- package/src/DrawerTitle/DrawerTitle.tsx +0 -35
- package/src/DrawerTitle/index.ts +0 -1
- package/src/DrawerTitle/styles.ts +0 -12
- package/src/Dropzone/Dropzone.tsx +0 -146
- package/src/Dropzone/__snapshots__/test.tsx.snap +0 -40
- package/src/Dropzone/index.ts +0 -7
- package/src/Dropzone/story/Default.example.tsx +0 -8
- package/src/Dropzone/story/Disabled.example.tsx +0 -25
- package/src/Dropzone/story/Error.example.tsx +0 -16
- package/src/Dropzone/story/Multiple.example.tsx +0 -30
- package/src/Dropzone/story/Uploader.example.tsx +0 -116
- package/src/Dropzone/story/Uploading.example.tsx +0 -16
- package/src/Dropzone/story/index.jsx +0 -85
- package/src/Dropzone/styles.ts +0 -43
- package/src/Dropzone/test.tsx +0 -33
- package/src/Dropzone/types.ts +0 -56
- package/src/EmptyState/EmptyState.tsx +0 -7
- package/src/EmptyState/index.tsx +0 -1
- package/src/EmptyState/story/index.jsx +0 -13
- package/src/EmptyStateCollection/EmptyStateCollection.tsx +0 -56
- package/src/EmptyStateCollection/__image_snapshots__/emptystate-collection-emptystatecollection-snap.png +0 -0
- package/src/EmptyStateCollection/index.tsx +0 -1
- package/src/EmptyStateCollection/story/Default.example.tsx +0 -11
- package/src/EmptyStateCollection/story/index.jsx +0 -20
- package/src/EmptyStateCollection/styles.ts +0 -10
- package/src/EmptyStatePage/EmptyStatePage.tsx +0 -65
- package/src/EmptyStatePage/__image_snapshots__/emptystate-page-emptystatepage-snap.png +0 -0
- package/src/EmptyStatePage/index.tsx +0 -1
- package/src/EmptyStatePage/story/Default.example.tsx +0 -21
- package/src/EmptyStatePage/story/index.jsx +0 -21
- package/src/EmptyStatePage/styles.ts +0 -9
- package/src/Note/Note.tsx +0 -36
- package/src/Note/__snapshots__/test.tsx.snap +0 -37
- package/src/Note/index.ts +0 -6
- package/src/Note/story/Default.example.tsx +0 -14
- package/src/Note/story/index.jsx +0 -23
- package/src/Note/styles.ts +0 -27
- package/src/Note/test.tsx +0 -22
- package/src/NoteContent/NoteContent.tsx +0 -23
- package/src/NoteContent/index.ts +0 -1
- package/src/NoteContent/story/index.jsx +0 -12
- package/src/NoteSubtitle/NoteSubtitle.tsx +0 -25
- package/src/NoteSubtitle/index.ts +0 -1
- package/src/NoteSubtitle/story/index.jsx +0 -12
- package/src/NoteTitle/NoteTitle.tsx +0 -34
- package/src/NoteTitle/index.ts +0 -1
- package/src/NoteTitle/story/index.jsx +0 -12
- package/src/NoteTitle/styles.ts +0 -8
- package/src/OverviewBlock/OverviewBlock.tsx +0 -125
- package/src/OverviewBlock/__image_snapshots__/overviewblock-default-snap.png +0 -0
- package/src/OverviewBlock/__image_snapshots__/overviewblock-multi-line-snap.png +0 -0
- package/src/OverviewBlock/__image_snapshots__/overviewblock-number-snap.png +0 -0
- package/src/OverviewBlock/__image_snapshots__/overviewblock-routing-snap.png +0 -0
- package/src/OverviewBlock/__image_snapshots__/overviewblock-text-snap.png +0 -0
- package/src/OverviewBlock/index.ts +0 -6
- package/src/OverviewBlock/story/Default.example.tsx +0 -35
- package/src/OverviewBlock/story/Multiline.example.tsx +0 -51
- package/src/OverviewBlock/story/Number.example.tsx +0 -20
- package/src/OverviewBlock/story/Routing.example.tsx +0 -40
- package/src/OverviewBlock/story/Text.example.tsx +0 -15
- package/src/OverviewBlock/story/index.jsx +0 -100
- package/src/OverviewBlock/styles.ts +0 -44
- package/src/OverviewBlock/test.tsx +0 -111
- package/src/OverviewBlockGroup/OverviewBlockGroup.tsx +0 -56
- package/src/OverviewBlockGroup/OverviewBlockGroupContext.tsx +0 -21
- package/src/OverviewBlockGroup/__image_snapshots__/visual-variants-of-the-groups-block-width-snap.png +0 -0
- package/src/OverviewBlockGroup/__image_snapshots__/visual-variants-of-the-groups-center-aligned-snap.png +0 -0
- package/src/OverviewBlockGroup/index.ts +0 -1
- package/src/OverviewBlockGroup/settings.ts +0 -2
- package/src/OverviewBlockGroup/story/BlockWidth.example.tsx +0 -38
- package/src/OverviewBlockGroup/story/CenterAligned.example.tsx +0 -17
- package/src/OverviewBlockGroup/story/index.jsx +0 -25
- package/src/OverviewBlockGroup/test.tsx +0 -17
- package/src/OverviewBlockRow/OverviewBlockRow.tsx +0 -22
- package/src/OverviewBlockRow/index.ts +0 -1
- package/src/OverviewBlockRow/story/index.jsx +0 -11
- package/src/OverviewBlockRow/styles.ts +0 -27
- package/src/Section/Section.tsx +0 -163
- package/src/Section/__snapshots__/test.tsx.snap +0 -186
- package/src/Section/index.ts +0 -6
- package/src/Section/story/Actions.example.tsx +0 -85
- package/src/Section/story/Collapsible.example.tsx +0 -113
- package/src/Section/story/Default.example.tsx +0 -77
- package/src/Section/story/TitleSize.example.tsx +0 -34
- package/src/Section/story/Variant.example.tsx +0 -108
- package/src/Section/story/index.jsx +0 -35
- package/src/Section/styles.ts +0 -65
- package/src/Section/test.tsx +0 -115
- package/src/Timeline/Timeline.tsx +0 -25
- package/src/Timeline/__snapshots__/test.tsx.snap +0 -332
- package/src/Timeline/index.ts +0 -6
- package/src/Timeline/story/Dates.example.tsx +0 -52
- package/src/Timeline/story/Default.example.tsx +0 -34
- package/src/Timeline/story/TrimLastConnector.example.tsx +0 -29
- package/src/Timeline/story/index.jsx +0 -27
- package/src/Timeline/test.tsx +0 -101
- package/src/TimelineRow/TimelineRow.tsx +0 -83
- package/src/TimelineRow/index.ts +0 -6
- package/src/TimelineRow/story/index.jsx +0 -11
- package/src/TimelineRow/styles.ts +0 -47
- package/src/TypographyOverflow/TypographyOverflow.tsx +0 -153
- package/src/TypographyOverflow/__image_snapshots__/typographyoverflow-checkbox-label-effect-1-snap.png +0 -0
- package/src/TypographyOverflow/__image_snapshots__/typographyoverflow-checkbox-label-snap.png +0 -0
- package/src/TypographyOverflow/__image_snapshots__/typographyoverflow-custom-tooltip-content-effect-1-snap.png +0 -0
- package/src/TypographyOverflow/__image_snapshots__/typographyoverflow-custom-tooltip-content-snap.png +0 -0
- package/src/TypographyOverflow/__image_snapshots__/typographyoverflow-default-effect-1-snap.png +0 -0
- package/src/TypographyOverflow/__image_snapshots__/typographyoverflow-default-effect-2-snap.png +0 -0
- package/src/TypographyOverflow/__image_snapshots__/typographyoverflow-default-snap.png +0 -0
- package/src/TypographyOverflow/__image_snapshots__/typographyoverflow-delay-effect-1-snap.png +0 -0
- package/src/TypographyOverflow/__image_snapshots__/typographyoverflow-delay-effect-2-snap.png +0 -0
- package/src/TypographyOverflow/__image_snapshots__/typographyoverflow-delay-snap.png +0 -0
- package/src/TypographyOverflow/__image_snapshots__/typographyoverflow-light-tooltip-background-effect-1-snap.png +0 -0
- package/src/TypographyOverflow/__image_snapshots__/typographyoverflow-light-tooltip-background-effect-2-snap.png +0 -0
- package/src/TypographyOverflow/__image_snapshots__/typographyoverflow-light-tooltip-background-snap.png +0 -0
- package/src/TypographyOverflow/__image_snapshots__/typographyoverflow-multiline-effect-1-snap.png +0 -0
- package/src/TypographyOverflow/__image_snapshots__/typographyoverflow-multiline-effect-2-snap.png +0 -0
- package/src/TypographyOverflow/__image_snapshots__/typographyoverflow-multiline-effect-3-snap.png +0 -0
- package/src/TypographyOverflow/__image_snapshots__/typographyoverflow-multiline-snap.png +0 -0
- package/src/TypographyOverflow/index.ts +0 -6
- package/src/TypographyOverflow/story/CheckboxLabel.example.tsx +0 -21
- package/src/TypographyOverflow/story/CustomTooltip.example.tsx +0 -22
- package/src/TypographyOverflow/story/Default.example.tsx +0 -32
- package/src/TypographyOverflow/story/Delay.example.tsx +0 -29
- package/src/TypographyOverflow/story/GridWithControls.example.tsx +0 -64
- package/src/TypographyOverflow/story/Multiline.example.tsx +0 -59
- package/src/TypographyOverflow/story/TooltipVariants.example.tsx +0 -23
- package/src/TypographyOverflow/story/index.jsx +0 -83
- package/src/TypographyOverflow/styles.ts +0 -29
- package/src/TypographyOverflow/test.tsx +0 -60
- package/src/index.ts +0 -35
- package/src/story/index.jsx +0 -10
- package/tsconfig.build.json +0 -7
package/src/Drawer/Drawer.tsx
DELETED
@@ -1,105 +0,0 @@
|
|
1
|
-
import MUIDrawer from '@material-ui/core/Drawer'
|
2
|
-
import { makeStyles, Theme, useTheme } from '@material-ui/core/styles'
|
3
|
-
import cx from 'classnames'
|
4
|
-
import { Button, Container } from '@toptal/picasso'
|
5
|
-
import { BaseProps } from '@toptal/picasso-shared'
|
6
|
-
import { useDrawer, usePicassoRoot } from '@toptal/picasso-provider'
|
7
|
-
import { CloseMinor16 } from '@toptal/picasso/Icon'
|
8
|
-
import React, { FunctionComponent, ReactNode, useLayoutEffect } from 'react'
|
9
|
-
|
10
|
-
import styles from './styles'
|
11
|
-
import DrawerTitle from '../DrawerTitle'
|
12
|
-
|
13
|
-
type AnchorType = 'bottom' | 'left' | 'right' | 'top'
|
14
|
-
|
15
|
-
type WidthType = 'narrow' | 'regular' | 'medium' | 'wide' | 'ultra-wide'
|
16
|
-
|
17
|
-
export interface Props extends BaseProps {
|
18
|
-
/** Side from which the drawer will appear. */
|
19
|
-
anchor?: AnchorType
|
20
|
-
/** Drawer content */
|
21
|
-
children: ReactNode
|
22
|
-
/** Disable the portal behavior. The children stay within it's parent DOM hierarchy. */
|
23
|
-
disablePortal?: boolean
|
24
|
-
/** Specify if the drawer is opened or not */
|
25
|
-
open: boolean
|
26
|
-
/** Specify the drawer title */
|
27
|
-
title?: ReactNode
|
28
|
-
/** Callback fired when the component requests to be closed. */
|
29
|
-
onClose?: () => void
|
30
|
-
/** Width of Drawer */
|
31
|
-
width?: WidthType
|
32
|
-
}
|
33
|
-
|
34
|
-
const useStyles = makeStyles<Theme>(styles, { name: 'PicassoDrawer' })
|
35
|
-
|
36
|
-
export const Drawer: FunctionComponent<Props> = props => {
|
37
|
-
const {
|
38
|
-
children,
|
39
|
-
disablePortal,
|
40
|
-
open,
|
41
|
-
onClose,
|
42
|
-
title,
|
43
|
-
width = 'regular',
|
44
|
-
...rest
|
45
|
-
} = props
|
46
|
-
const classes = useStyles()
|
47
|
-
const { setHasDrawer } = useDrawer()
|
48
|
-
const theme = useTheme()
|
49
|
-
const container = usePicassoRoot()
|
50
|
-
|
51
|
-
useLayoutEffect(() => {
|
52
|
-
setHasDrawer(open)
|
53
|
-
|
54
|
-
const cleanup = () => {
|
55
|
-
setHasDrawer(false)
|
56
|
-
}
|
57
|
-
|
58
|
-
return cleanup
|
59
|
-
}, [open, setHasDrawer])
|
60
|
-
|
61
|
-
const handleOnClose = () => {
|
62
|
-
if (onClose) {
|
63
|
-
onClose()
|
64
|
-
}
|
65
|
-
}
|
66
|
-
|
67
|
-
return (
|
68
|
-
<MUIDrawer
|
69
|
-
{...rest}
|
70
|
-
open={open}
|
71
|
-
onClose={handleOnClose}
|
72
|
-
disablePortal={disablePortal}
|
73
|
-
container={container}
|
74
|
-
ModalProps={{ style: { zIndex: theme.zIndex.drawer } }}
|
75
|
-
>
|
76
|
-
<Container
|
77
|
-
flex
|
78
|
-
direction='column'
|
79
|
-
className={cx(classes.container, classes[width])}
|
80
|
-
>
|
81
|
-
<DrawerTitle title={title} />
|
82
|
-
<Container flex className={classes.content}>
|
83
|
-
{children}
|
84
|
-
</Container>
|
85
|
-
<Button.Circular
|
86
|
-
variant='flat'
|
87
|
-
icon={<CloseMinor16 />}
|
88
|
-
onClick={handleOnClose}
|
89
|
-
className={classes.closeButton}
|
90
|
-
/>
|
91
|
-
</Container>
|
92
|
-
</MUIDrawer>
|
93
|
-
)
|
94
|
-
}
|
95
|
-
|
96
|
-
Drawer.displayName = 'Drawer'
|
97
|
-
|
98
|
-
Drawer.defaultProps = {
|
99
|
-
anchor: 'right',
|
100
|
-
disablePortal: false,
|
101
|
-
onClose: () => {},
|
102
|
-
width: 'regular'
|
103
|
-
}
|
104
|
-
|
105
|
-
export default Drawer
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
package/src/Drawer/index.ts
DELETED
@@ -1,32 +0,0 @@
|
|
1
|
-
import { Button, Typography, Container, List } from '@toptal/picasso'
|
2
|
-
import { Drawer } from '@toptal/picasso-lab'
|
3
|
-
import React, { useState } from 'react'
|
4
|
-
|
5
|
-
const Title = () => (
|
6
|
-
<Container flex alignItems='center' padded='small'>
|
7
|
-
<Typography>This Drawer has a custom title</Typography>
|
8
|
-
<Button size='small'>OK!</Button>
|
9
|
-
</Container>
|
10
|
-
)
|
11
|
-
|
12
|
-
const Example = () => {
|
13
|
-
const [open, setOpen] = useState(false)
|
14
|
-
|
15
|
-
return (
|
16
|
-
<div>
|
17
|
-
<Button data-testid='trigger' onClick={() => setOpen(!open)}>
|
18
|
-
Show drawer
|
19
|
-
</Button>
|
20
|
-
<Drawer title={<Title />} open={open} onClose={() => setOpen(false)}>
|
21
|
-
<Container data-testid='content' padded='small'>
|
22
|
-
<List variant='ordered'>
|
23
|
-
<List.Item>Add at least 10 skills</List.Item>
|
24
|
-
<List.Item>Set your age</List.Item>
|
25
|
-
</List>
|
26
|
-
</Container>
|
27
|
-
</Drawer>
|
28
|
-
</div>
|
29
|
-
)
|
30
|
-
}
|
31
|
-
|
32
|
-
export default Example
|
@@ -1,29 +0,0 @@
|
|
1
|
-
import { Button, Container, List } from '@toptal/picasso'
|
2
|
-
import { Drawer } from '@toptal/picasso-lab'
|
3
|
-
import React, { useState } from 'react'
|
4
|
-
|
5
|
-
const Example = () => {
|
6
|
-
const [open, setOpen] = useState(false)
|
7
|
-
|
8
|
-
return (
|
9
|
-
<div>
|
10
|
-
<Button data-testid='trigger' onClick={() => setOpen(!open)}>
|
11
|
-
Show drawer
|
12
|
-
</Button>
|
13
|
-
<Drawer
|
14
|
-
title='My Operational Issues'
|
15
|
-
open={open}
|
16
|
-
onClose={() => setOpen(false)}
|
17
|
-
>
|
18
|
-
<Container data-testid='content' padded='medium'>
|
19
|
-
<List variant='ordered'>
|
20
|
-
<List.Item>Add at least 10 skills</List.Item>
|
21
|
-
<List.Item>Set your age</List.Item>
|
22
|
-
</List>
|
23
|
-
</Container>
|
24
|
-
</Drawer>
|
25
|
-
</div>
|
26
|
-
)
|
27
|
-
}
|
28
|
-
|
29
|
-
export default Example
|
@@ -1,34 +0,0 @@
|
|
1
|
-
import { Button, Container, List } from '@toptal/picasso'
|
2
|
-
import { Drawer } from '@toptal/picasso-lab'
|
3
|
-
import { useNotifications } from '@toptal/picasso/utils'
|
4
|
-
import React, { useState } from 'react'
|
5
|
-
|
6
|
-
const Example = () => {
|
7
|
-
const { showSuccess } = useNotifications()
|
8
|
-
const [open, setOpen] = useState(false)
|
9
|
-
|
10
|
-
const showDrawer = () => {
|
11
|
-
setOpen(!open)
|
12
|
-
showSuccess("That's one small step for a man, one giant leap for mankind.")
|
13
|
-
}
|
14
|
-
|
15
|
-
return (
|
16
|
-
<div>
|
17
|
-
<Button onClick={showDrawer}>Show drawer</Button>
|
18
|
-
<Drawer
|
19
|
-
title='My Operational Issues'
|
20
|
-
open={open}
|
21
|
-
onClose={() => setOpen(false)}
|
22
|
-
>
|
23
|
-
<Container padded='medium'>
|
24
|
-
<List variant='ordered'>
|
25
|
-
<List.Item>Add at least 10 skills</List.Item>
|
26
|
-
<List.Item>Set your age</List.Item>
|
27
|
-
</List>
|
28
|
-
</Container>
|
29
|
-
</Drawer>
|
30
|
-
</div>
|
31
|
-
)
|
32
|
-
}
|
33
|
-
|
34
|
-
export default Example
|
@@ -1,46 +0,0 @@
|
|
1
|
-
import { Container, List, Button } from '@toptal/picasso'
|
2
|
-
import { Drawer } from '@toptal/picasso-lab'
|
3
|
-
import React, { useState } from 'react'
|
4
|
-
|
5
|
-
type WidthType = 'narrow' | 'regular' | 'medium' | 'wide' | 'ultra-wide'
|
6
|
-
|
7
|
-
const types: WidthType[] = ['narrow', 'regular', 'medium', 'wide', 'ultra-wide']
|
8
|
-
|
9
|
-
const Example = () => {
|
10
|
-
const [width, setWidth] = useState<WidthType>('narrow')
|
11
|
-
const [open, setOpen] = useState(false)
|
12
|
-
|
13
|
-
const handleClick = (type: WidthType) => {
|
14
|
-
setWidth(type)
|
15
|
-
setOpen(!open)
|
16
|
-
}
|
17
|
-
|
18
|
-
return (
|
19
|
-
<div>
|
20
|
-
{types.map(type => (
|
21
|
-
<Button
|
22
|
-
data-testid={`show-${type}`}
|
23
|
-
onClick={() => handleClick(type)}
|
24
|
-
key={type}
|
25
|
-
>
|
26
|
-
Show {type} drawer
|
27
|
-
</Button>
|
28
|
-
))}
|
29
|
-
<Drawer
|
30
|
-
title='My Operational Issues'
|
31
|
-
open={open}
|
32
|
-
onClose={() => setOpen(false)}
|
33
|
-
width={width}
|
34
|
-
>
|
35
|
-
<Container data-testid='content' padded='medium'>
|
36
|
-
<List variant='ordered'>
|
37
|
-
<List.Item>Add at least 10 skills</List.Item>
|
38
|
-
<List.Item>Set your age</List.Item>
|
39
|
-
</List>
|
40
|
-
</Container>
|
41
|
-
</Drawer>
|
42
|
-
</div>
|
43
|
-
)
|
44
|
-
}
|
45
|
-
|
46
|
-
export default Example
|
@@ -1,22 +0,0 @@
|
|
1
|
-
import { Button, Typography, Container } from '@toptal/picasso'
|
2
|
-
import { Drawer } from '@toptal/picasso-lab'
|
3
|
-
import React, { useState } from 'react'
|
4
|
-
|
5
|
-
const Example = () => {
|
6
|
-
const [open, setOpen] = useState(false)
|
7
|
-
|
8
|
-
return (
|
9
|
-
<div>
|
10
|
-
<Button data-testid='trigger' onClick={() => setOpen(!open)}>
|
11
|
-
Show drawer
|
12
|
-
</Button>
|
13
|
-
<Drawer open={open} onClose={() => setOpen(false)}>
|
14
|
-
<Container data-testid='content' padded='small'>
|
15
|
-
<Typography>This is the content. The title is omitted.</Typography>
|
16
|
-
</Container>
|
17
|
-
</Drawer>
|
18
|
-
</div>
|
19
|
-
)
|
20
|
-
}
|
21
|
-
|
22
|
-
export default Example
|
@@ -1,80 +0,0 @@
|
|
1
|
-
import { Drawer } from '../Drawer'
|
2
|
-
import PicassoBook from '~/.storybook/components/PicassoBook'
|
3
|
-
|
4
|
-
const page = PicassoBook.section('Picasso Lab').createPage(
|
5
|
-
'Drawer',
|
6
|
-
`
|
7
|
-
Allows rendering a sidebar with custom content
|
8
|
-
|
9
|
-
${PicassoBook.createBaseDocsLink(
|
10
|
-
'https://share.goabstract.com/22ba178c-50b8-4eb3-9eeb-e527fbed15e5?collectionLayerId=e9a36438-d8c9-42a4-94bc-ea134fd2e2a1&mode=design&present=true'
|
11
|
-
)}
|
12
|
-
`
|
13
|
-
)
|
14
|
-
|
15
|
-
page.createTabChapter('Props').addComponentDocs({
|
16
|
-
component: Drawer,
|
17
|
-
name: 'Drawer'
|
18
|
-
})
|
19
|
-
|
20
|
-
page
|
21
|
-
.createChapter()
|
22
|
-
.addExample('Drawer/story/Default.example.tsx', {
|
23
|
-
title: 'Default',
|
24
|
-
effect: async (testPage, makeScreenshot) => {
|
25
|
-
await testPage.click('[data-testid="trigger"]')
|
26
|
-
|
27
|
-
await makeScreenshot({
|
28
|
-
isFullScreen: true,
|
29
|
-
selector: '[data-testid="content"]'
|
30
|
-
})
|
31
|
-
}
|
32
|
-
})
|
33
|
-
.addExample('Drawer/story/WithoutTitle.example.tsx', {
|
34
|
-
title: 'Without Title',
|
35
|
-
effect: async (testPage, makeScreenshot) => {
|
36
|
-
await testPage.click('[data-testid="trigger"]')
|
37
|
-
|
38
|
-
await makeScreenshot({
|
39
|
-
isFullScreen: true
|
40
|
-
})
|
41
|
-
}
|
42
|
-
})
|
43
|
-
.addExample('Drawer/story/CustomTitle.example.tsx', {
|
44
|
-
title: 'Custom Title',
|
45
|
-
effect: async (testPage, makeScreenshot) => {
|
46
|
-
await testPage.click('[data-testid="trigger"]')
|
47
|
-
|
48
|
-
await makeScreenshot({
|
49
|
-
isFullScreen: true
|
50
|
-
})
|
51
|
-
}
|
52
|
-
})
|
53
|
-
.addExample('Drawer/story/Widths.example.tsx', {
|
54
|
-
title: 'Width',
|
55
|
-
effect: async (testPage, makeScreenshot) => {
|
56
|
-
const types = ['narrow', 'regular', 'medium', 'wide', 'ultra-wide']
|
57
|
-
const contentSelector = '[data-testid="content"]'
|
58
|
-
|
59
|
-
for (const type in types) {
|
60
|
-
const buttonSelector = `[data-testid="show-${types[type]}"]`
|
61
|
-
|
62
|
-
await testPage.click(buttonSelector)
|
63
|
-
await testPage.waitFor(contentSelector, {
|
64
|
-
visible: true
|
65
|
-
})
|
66
|
-
await makeScreenshot({
|
67
|
-
isFullScreen: true,
|
68
|
-
selector: contentSelector
|
69
|
-
})
|
70
|
-
await testPage.click('[role="presentation"] button')
|
71
|
-
await testPage.waitFor(contentSelector, {
|
72
|
-
hidden: true
|
73
|
-
})
|
74
|
-
}
|
75
|
-
}
|
76
|
-
})
|
77
|
-
.addExample(
|
78
|
-
'Drawer/story/DrawerAndNotification.example.tsx',
|
79
|
-
'With notification'
|
80
|
-
) // picasso-skip-visuals
|
package/src/Drawer/styles.ts
DELETED
@@ -1,42 +0,0 @@
|
|
1
|
-
import { createStyles } from '@material-ui/core/styles'
|
2
|
-
import { PicassoProvider } from '@toptal/picasso-provider'
|
3
|
-
|
4
|
-
PicassoProvider.override(() => ({
|
5
|
-
MuiDrawer: {
|
6
|
-
paper: {
|
7
|
-
maxWidth: '100%'
|
8
|
-
}
|
9
|
-
}
|
10
|
-
}))
|
11
|
-
|
12
|
-
export default () =>
|
13
|
-
createStyles({
|
14
|
-
container: {
|
15
|
-
maxWidth: '100%',
|
16
|
-
position: 'relative',
|
17
|
-
flex: 1
|
18
|
-
},
|
19
|
-
content: {
|
20
|
-
flex: 1
|
21
|
-
},
|
22
|
-
closeButton: {
|
23
|
-
position: 'absolute',
|
24
|
-
right: '1.5rem',
|
25
|
-
top: '1rem'
|
26
|
-
},
|
27
|
-
narrow: {
|
28
|
-
width: '27.5rem'
|
29
|
-
},
|
30
|
-
regular: {
|
31
|
-
width: '35rem'
|
32
|
-
},
|
33
|
-
medium: {
|
34
|
-
width: '40rem'
|
35
|
-
},
|
36
|
-
wide: {
|
37
|
-
width: '60rem'
|
38
|
-
},
|
39
|
-
'ultra-wide': {
|
40
|
-
width: '73.75rem'
|
41
|
-
}
|
42
|
-
})
|
@@ -1,35 +0,0 @@
|
|
1
|
-
import React from 'react'
|
2
|
-
import { BaseProps } from '@toptal/picasso-shared'
|
3
|
-
import { Container, Typography } from '@toptal/picasso'
|
4
|
-
import { makeStyles, Theme } from '@material-ui/core/styles'
|
5
|
-
|
6
|
-
import styles from './styles'
|
7
|
-
import { DrawerProps } from '../Drawer'
|
8
|
-
|
9
|
-
export interface Props extends BaseProps, Pick<DrawerProps, 'title'> {}
|
10
|
-
|
11
|
-
const useStyles = makeStyles<Theme>(styles, { name: 'PicassoDrawerTitle' })
|
12
|
-
|
13
|
-
export const DrawerTitle = ({ title }: Props) => {
|
14
|
-
const classes = useStyles()
|
15
|
-
|
16
|
-
if (!title) {
|
17
|
-
return null
|
18
|
-
}
|
19
|
-
|
20
|
-
if (React.isValidElement(title)) {
|
21
|
-
return title
|
22
|
-
}
|
23
|
-
|
24
|
-
return (
|
25
|
-
<Container flex alignItems='center' className={classes.header}>
|
26
|
-
<Typography variant='heading' size='medium' className={classes.title}>
|
27
|
-
{title}
|
28
|
-
</Typography>
|
29
|
-
</Container>
|
30
|
-
)
|
31
|
-
}
|
32
|
-
|
33
|
-
DrawerTitle.displayName = 'DrawerTitle'
|
34
|
-
|
35
|
-
export default DrawerTitle
|
package/src/DrawerTitle/index.ts
DELETED
@@ -1 +0,0 @@
|
|
1
|
-
export { default } from './DrawerTitle'
|
@@ -1,146 +0,0 @@
|
|
1
|
-
import React, { forwardRef } from 'react'
|
2
|
-
import { useDropzone } from 'react-dropzone'
|
3
|
-
import cx from 'classnames'
|
4
|
-
import { makeStyles, Theme } from '@material-ui/core/styles'
|
5
|
-
import { BaseProps } from '@toptal/picasso-shared'
|
6
|
-
import { Upload24 } from '@toptal/picasso/Icon'
|
7
|
-
import {
|
8
|
-
FormError,
|
9
|
-
Container,
|
10
|
-
FileList,
|
11
|
-
Typography,
|
12
|
-
FormHint
|
13
|
-
} from '@toptal/picasso'
|
14
|
-
|
15
|
-
import { FileUpload, DropzoneOptions } from './types'
|
16
|
-
import styles from './styles'
|
17
|
-
|
18
|
-
export interface Props extends BaseProps {
|
19
|
-
/**
|
20
|
-
* Set accepted file types. See https://github.com/okonet/attr-accept for more information.
|
21
|
-
*/
|
22
|
-
accept?: DropzoneOptions['accept']
|
23
|
-
/** Enable/disable the dropzone */
|
24
|
-
disabled?: boolean
|
25
|
-
/** Maximum file size (in bytes) */
|
26
|
-
maxSize?: number
|
27
|
-
/** Minimum file size (in bytes) */
|
28
|
-
minSize?: number
|
29
|
-
/** Allow drag 'n' drop (or selection from the file dialog) of multiple files */
|
30
|
-
multiple?: boolean
|
31
|
-
/** The text of the hint */
|
32
|
-
hint?: string
|
33
|
-
/** Callback invoked when a file item is removed */
|
34
|
-
onRemove?: (fileName: string, index: number) => void
|
35
|
-
/** Callback for when the drop event occurs */
|
36
|
-
onDropAccepted?: DropzoneOptions['onDropAccepted']
|
37
|
-
/** callback for when the drop event occurs */
|
38
|
-
onDropRejected?: DropzoneOptions['onDropRejected']
|
39
|
-
/** callback for when the drop event occurs */
|
40
|
-
onDrop?: DropzoneOptions['onDrop']
|
41
|
-
/** Custom validation function */
|
42
|
-
validator?: DropzoneOptions['validator']
|
43
|
-
/** Value uses the File interface. */
|
44
|
-
value?: FileUpload[]
|
45
|
-
/** Reasons why files couldn't be droped into dropzone */
|
46
|
-
errorMessages?: string[]
|
47
|
-
focused?: boolean
|
48
|
-
hovered?: boolean
|
49
|
-
}
|
50
|
-
|
51
|
-
const useStyles = makeStyles<Theme>(styles, { name: 'Dropzone' })
|
52
|
-
|
53
|
-
export const Dropzone = forwardRef<HTMLInputElement, Props>(function Dropzone(
|
54
|
-
props,
|
55
|
-
ref
|
56
|
-
) {
|
57
|
-
const {
|
58
|
-
hint,
|
59
|
-
onRemove,
|
60
|
-
value,
|
61
|
-
className,
|
62
|
-
errorMessages = [],
|
63
|
-
style,
|
64
|
-
'data-testid': dataTestId,
|
65
|
-
focused,
|
66
|
-
hovered,
|
67
|
-
|
68
|
-
// dropzoneOptions
|
69
|
-
accept,
|
70
|
-
minSize,
|
71
|
-
maxSize,
|
72
|
-
multiple,
|
73
|
-
disabled,
|
74
|
-
onDrop,
|
75
|
-
onDropAccepted,
|
76
|
-
onDropRejected,
|
77
|
-
validator
|
78
|
-
} = props
|
79
|
-
|
80
|
-
const { getRootProps, isDragActive, getInputProps } = useDropzone({
|
81
|
-
accept,
|
82
|
-
minSize,
|
83
|
-
maxSize,
|
84
|
-
multiple,
|
85
|
-
disabled,
|
86
|
-
onDrop,
|
87
|
-
onDropAccepted,
|
88
|
-
onDropRejected,
|
89
|
-
validator
|
90
|
-
})
|
91
|
-
|
92
|
-
const classes = useStyles()
|
93
|
-
|
94
|
-
return (
|
95
|
-
<Container style={style} ref={ref} className={className}>
|
96
|
-
<Container
|
97
|
-
flex
|
98
|
-
direction='column'
|
99
|
-
alignItems='center'
|
100
|
-
data-testid={dataTestId}
|
101
|
-
{...getRootProps({
|
102
|
-
className: cx(classes.root, {
|
103
|
-
[classes.dragActive]: isDragActive,
|
104
|
-
[classes.hovered]: hovered,
|
105
|
-
[classes.disabled]: disabled,
|
106
|
-
[classes.focused]: focused
|
107
|
-
})
|
108
|
-
})}
|
109
|
-
>
|
110
|
-
<input {...getInputProps({ className: classes.nativeInput })} />
|
111
|
-
<Upload24 color='darkGrey' />
|
112
|
-
<Typography size='medium' color='black' weight='semibold'>
|
113
|
-
Click or drag file to upload
|
114
|
-
</Typography>
|
115
|
-
{hint && errorMessages.length === 0 && (
|
116
|
-
<FormHint className={cx(classes.hint)}>{hint}</FormHint>
|
117
|
-
)}
|
118
|
-
{errorMessages.length > 0 &&
|
119
|
-
errorMessages.map((error, index) => (
|
120
|
-
<FormError
|
121
|
-
className={classes.error}
|
122
|
-
key={`${error}-${String(index)}`}
|
123
|
-
>
|
124
|
-
{error}
|
125
|
-
</FormError>
|
126
|
-
))}
|
127
|
-
</Container>
|
128
|
-
{value && value.length > 0 && (
|
129
|
-
<Container top='xsmall'>
|
130
|
-
<FileList files={value} onItemRemove={onRemove} />
|
131
|
-
</Container>
|
132
|
-
)}
|
133
|
-
</Container>
|
134
|
-
)
|
135
|
-
})
|
136
|
-
|
137
|
-
Dropzone.displayName = 'Dropzone'
|
138
|
-
|
139
|
-
Dropzone.defaultProps = {
|
140
|
-
disabled: false,
|
141
|
-
maxSize: Infinity,
|
142
|
-
minSize: 0,
|
143
|
-
multiple: true
|
144
|
-
}
|
145
|
-
|
146
|
-
export default Dropzone
|
@@ -1,40 +0,0 @@
|
|
1
|
-
// Jest Snapshot v1, https://goo.gl/fbAQLP
|
2
|
-
|
3
|
-
exports[`Dropzone renders 1`] = `
|
4
|
-
<div>
|
5
|
-
<div
|
6
|
-
class="Picasso-root"
|
7
|
-
>
|
8
|
-
<div
|
9
|
-
class=""
|
10
|
-
>
|
11
|
-
<div
|
12
|
-
class="PicassoContainer-centerAlignItems PicassoContainer-flex PicassoContainer-column Dropzone-root"
|
13
|
-
tabindex="0"
|
14
|
-
>
|
15
|
-
<input
|
16
|
-
autocomplete="off"
|
17
|
-
multiple=""
|
18
|
-
style="display: none;"
|
19
|
-
tabindex="-1"
|
20
|
-
type="file"
|
21
|
-
/>
|
22
|
-
<svg
|
23
|
-
class="PicassoSvgUpload24-root PicassoSvgUpload24-darkGrey"
|
24
|
-
style="min-width: 24px; min-height: 24px;"
|
25
|
-
viewBox="0 0 24 24"
|
26
|
-
>
|
27
|
-
<path
|
28
|
-
d="M2 18v3h19v-3h1v4H1v-4h1zm9.5-16.207L16.207 6.5l-.707.707-3.501-3.501V19H11l-.001-15.294L7.5 7.207 6.793 6.5 11.5 1.793z"
|
29
|
-
/>
|
30
|
-
</svg>
|
31
|
-
<p
|
32
|
-
class="MuiTypography-root PicassoTypography-bodyMedium PicassoTypography-black PicassoTypography-semibold MuiTypography-body1"
|
33
|
-
>
|
34
|
-
Click or drag file to upload
|
35
|
-
</p>
|
36
|
-
</div>
|
37
|
-
</div>
|
38
|
-
</div>
|
39
|
-
</div>
|
40
|
-
`;
|