From acfc740d92cd3a9c01872d1704227fa699f0e7f8 Mon Sep 17 00:00:00 2001 From: Michael Shilman Date: Wed, 27 Feb 2019 22:56:56 +0800 Subject: [PATCH] Merge pull request #5716 from storybooks/5421-notifications-styling Notifications placement --- .../__snapshots__/storyshots.test.js.snap | 449 +++++++----------- .../tabs/__snapshots__/tabs.stories.storyshot | 14 - lib/components/src/tabs/tabs.js | 4 +- lib/ui/src/app.js | 2 + lib/ui/src/components/layout/desktop.js | 11 +- .../src/components/layout/layout.stories.js | 3 +- lib/ui/src/components/layout/mobile.js | 12 +- .../item.js} | 11 +- .../item.stories.js} | 4 +- .../components/notifications/notifications.js | 50 ++ .../notifications.stories.js} | 19 +- .../__snapshots__/panel.stories.storyshot | 2 - .../components/sidebar/NotificationList.js | 43 -- lib/ui/src/components/sidebar/Sidebar.js | 27 +- .../src/components/sidebar/Sidebar.stories.js | 14 +- lib/ui/src/containers/nav.js | 2 - lib/ui/src/containers/notifications.js | 18 + lib/ui/src/core/versions.js | 4 +- .../__snapshots__/about.stories.storyshot | 6 - 19 files changed, 281 insertions(+), 414 deletions(-) rename lib/ui/src/components/{sidebar/NotificationItem.js => notifications/item.js} (80%) rename lib/ui/src/components/{sidebar/NotificationItem.stories.js => notifications/item.stories.js} (87%) create mode 100644 lib/ui/src/components/notifications/notifications.js rename lib/ui/src/components/{sidebar/NotificationList.stories.js => notifications/notifications.stories.js} (65%) delete mode 100644 lib/ui/src/components/sidebar/NotificationList.js create mode 100644 lib/ui/src/containers/notifications.js diff --git a/examples/official-storybook/tests/__snapshots__/storyshots.test.js.snap b/examples/official-storybook/tests/__snapshots__/storyshots.test.js.snap index 2c69de59a58..a2c80ea1e62 100644 --- a/examples/official-storybook/tests/__snapshots__/storyshots.test.js.snap +++ b/examples/official-storybook/tests/__snapshots__/storyshots.test.js.snap @@ -2850,8 +2850,8 @@ exports[`Storyshots Core|Scroll story with 100vh padding 2 1`] = ` `; -exports[`Storyshots UI|Notifications/NotificationItem longText 1`] = ` -.emotion-1 { +exports[`Storyshots UI|Notifications/Item longText 1`] = ` +.emotion-0 { display: block; padding: 16px 20px; border-radius: 10px; @@ -2865,7 +2865,7 @@ exports[`Storyshots UI|Notifications/NotificationItem longText 1`] = ` text-decoration: none; } -.emotion-1 { +.emotion-0 { display: block; padding: 16px 20px; border-radius: 10px; @@ -2883,19 +2883,15 @@ exports[`Storyshots UI|Notifications/NotificationItem longText 1`] = ` style="width:240px;margin:1rem" >
-
- ๐ŸŽ‰ This is a long message that extends over two lines! -
+ ๐ŸŽ‰ This is a long message that extends over two lines!
`; -exports[`Storyshots UI|Notifications/NotificationItem simple 1`] = ` -.emotion-1 { +exports[`Storyshots UI|Notifications/Item simple 1`] = ` +.emotion-0 { display: block; padding: 16px 20px; border-radius: 10px; @@ -2909,7 +2905,7 @@ exports[`Storyshots UI|Notifications/NotificationItem simple 1`] = ` text-decoration: none; } -.emotion-1 { +.emotion-0 { display: block; padding: 16px 20px; border-radius: 10px; @@ -2927,19 +2923,15 @@ exports[`Storyshots UI|Notifications/NotificationItem simple 1`] = ` style="width:240px;margin:1rem" >
-
- ๐ŸŽ‰ Storybook is cool! -
+ ๐ŸŽ‰ Storybook is cool!
`; -exports[`Storyshots UI|Notifications/NotificationItem withLink 1`] = ` -.emotion-1 { +exports[`Storyshots UI|Notifications/Item withLink 1`] = ` +.emotion-0 { display: block; padding: 16px 20px; border-radius: 10px; @@ -2953,7 +2945,7 @@ exports[`Storyshots UI|Notifications/NotificationItem withLink 1`] = ` text-decoration: none; } -.emotion-1 { +.emotion-0 { display: block; padding: 16px 20px; border-radius: 10px; @@ -2971,20 +2963,16 @@ exports[`Storyshots UI|Notifications/NotificationItem withLink 1`] = ` style="width:240px;margin:1rem" > -
- ๐ŸŽ‰ Storybook X.X is available! Download now ยป -
+ ๐ŸŽ‰ Storybook X.X is available! Download now ยป
`; -exports[`Storyshots UI|Notifications/NotificationList all 1`] = ` -.emotion-1 { +exports[`Storyshots UI|Notifications/Notifications all 1`] = ` +.emotion-0 { display: block; padding: 16px 20px; border-radius: 10px; @@ -2998,15 +2986,23 @@ exports[`Storyshots UI|Notifications/NotificationList all 1`] = ` text-decoration: none; } -.emotion-6 > * + * { +.emotion-3 { + z-index: 10; + bottom: 0; + left: 0; + right: 0; + position: fixed; +} + +.emotion-3 > * + * { margin-top: 10px; } -.emotion-6:empty { +.emotion-3:empty { display: none; } -.emotion-1 { +.emotion-0 { display: block; padding: 16px 20px; border-radius: 10px; @@ -3020,11 +3016,19 @@ exports[`Storyshots UI|Notifications/NotificationList all 1`] = ` text-decoration: none; } -.emotion-6 > * + * { +.emotion-3 { + z-index: 10; + bottom: 0; + left: 0; + right: 0; + position: fixed; +} + +.emotion-3 > * + * { margin-top: 10px; } -.emotion-6:empty { +.emotion-3:empty { display: none; } @@ -3032,42 +3036,30 @@ exports[`Storyshots UI|Notifications/NotificationList all 1`] = ` style="width:240px;margin:1rem" >
-
- ๐ŸŽ‰ Storybook is cool! -
+ ๐ŸŽ‰ Storybook is cool!
-
- ๐ŸŽ‰ This is a long message that extends over two lines! -
+ ๐ŸŽ‰ This is a long message that extends over two lines!
-
- ๐ŸŽ‰ Storybook X.X is available! Download now ยป -
+ ๐ŸŽ‰ Storybook X.X is available! Download now ยป
`; -exports[`Storyshots UI|Notifications/NotificationList single 1`] = ` -.emotion-1 { +exports[`Storyshots UI|Notifications/Notifications placement 1`] = ` +.emotion-0 { display: block; padding: 16px 20px; border-radius: 10px; @@ -3081,15 +3073,22 @@ exports[`Storyshots UI|Notifications/NotificationList single 1`] = ` text-decoration: none; } -.emotion-2 > * + * { +.emotion-3 { + z-index: 10; + position: fixed; + left: 20px; + bottom: 20px; +} + +.emotion-3 > * + * { margin-top: 10px; } -.emotion-2:empty { +.emotion-3:empty { display: none; } -.emotion-1 { +.emotion-0 { display: block; padding: 16px 20px; border-radius: 10px; @@ -3103,11 +3102,18 @@ exports[`Storyshots UI|Notifications/NotificationList single 1`] = ` text-decoration: none; } -.emotion-2 > * + * { +.emotion-3 { + z-index: 10; + position: fixed; + left: 20px; + bottom: 20px; +} + +.emotion-3 > * + * { margin-top: 10px; } -.emotion-2:empty { +.emotion-3:empty { display: none; } @@ -3115,16 +3121,99 @@ exports[`Storyshots UI|Notifications/NotificationList single 1`] = ` style="width:240px;margin:1rem" >
-
- ๐ŸŽ‰ Storybook is cool! -
+ ๐ŸŽ‰ Storybook is cool! +
+
+ ๐ŸŽ‰ This is a long message that extends over two lines! +
+ + ๐ŸŽ‰ Storybook X.X is available! Download now ยป + +
+ +`; + +exports[`Storyshots UI|Notifications/Notifications single 1`] = ` +.emotion-0 { + display: block; + padding: 16px 20px; + border-radius: 10px; + font-size: 12px; + font-weight: 700; + line-height: 16px; + box-shadow: 0 5px 15px 0 rgba(0,0,0,0.1),0 2px 5px 0 rgba(0,0,0,0.05); + color: #FFFFFF; + background-color: rgba(0,0,0,0.95); + -webkit-text-decoration: none; + text-decoration: none; +} + +.emotion-1 { + z-index: 10; + bottom: 0; + left: 0; + right: 0; + position: fixed; +} + +.emotion-1 > * + * { + margin-top: 10px; +} + +.emotion-1:empty { + display: none; +} + +.emotion-0 { + display: block; + padding: 16px 20px; + border-radius: 10px; + font-size: 12px; + font-weight: 700; + line-height: 16px; + box-shadow: 0 5px 15px 0 rgba(0,0,0,0.1),0 2px 5px 0 rgba(0,0,0,0.05); + color: #FFFFFF; + background-color: rgba(0,0,0,0.95); + -webkit-text-decoration: none; + text-decoration: none; +} + +.emotion-1 { + z-index: 10; + bottom: 0; + left: 0; + right: 0; + position: fixed; +} + +.emotion-1 > * + * { + margin-top: 10px; +} + +.emotion-1:empty { + display: none; +} + +
+
+
+ ๐ŸŽ‰ Storybook is cool!
@@ -4422,11 +4511,9 @@ exports[`Storyshots UI|Settings/ShortcutsScreen default shortcuts 1`] = `
* + * { - margin-top: 10px; -} - -.emotion-78:empty { - display: none; -} - -.emotion-84 { +.emotion-77 { position: absolute; z-index: 1; left: 0; @@ -5409,23 +5474,6 @@ exports[`Storyshots UI|Sidebar/Sidebar loading 1`] = ` color: #774dd7; } -.emotion-77 { - height: 48px; -} - -.emotion-83 { - position: fixed; - display: block; - bottom: 20px; - left: 20px; - margin: 0; - padding: 0; - width: 20%; - min-width: 200px; - max-width: 280px; - z-index: 2; -} - .emotion-76 { margin-top: 8px; } @@ -5622,29 +5670,7 @@ exports[`Storyshots UI|Sidebar/Sidebar loading 1`] = ` fill: currentColor; } -.emotion-81 { - display: block; - padding: 16px 20px; - border-radius: 10px; - font-size: 12px; - font-weight: 700; - line-height: 16px; - box-shadow: 0 5px 15px 0 rgba(0,0,0,0.1),0 2px 5px 0 rgba(0,0,0,0.05); - color: #FFFFFF; - background-color: rgba(0,0,0,0.95); - -webkit-text-decoration: none; - text-decoration: none; -} - -.emotion-78 > * + * { - margin-top: 10px; -} - -.emotion-78:empty { - display: none; -} - -.emotion-84 { +.emotion-77 { position: absolute; z-index: 1; left: 0; @@ -5809,23 +5835,6 @@ exports[`Storyshots UI|Sidebar/Sidebar loading 1`] = ` color: #774dd7; } -.emotion-77 { - height: 48px; -} - -.emotion-83 { - position: fixed; - display: block; - bottom: 20px; - left: 20px; - margin: 0; - padding: 0; - width: 20%; - min-width: 200px; - max-width: 280px; - z-index: 2; -} - .emotion-76 { margin-top: 8px; } @@ -5971,7 +5980,7 @@ exports[`Storyshots UI|Sidebar/Sidebar loading 1`] = ` }
-
-
-
-
-
-
-
-
-
- ๐ŸŽ‰ Storybook is cool! -
-
-
-
`; @@ -6420,29 +6401,7 @@ exports[`Storyshots UI|Sidebar/Sidebar simple 1`] = ` fill: currentColor; } -.emotion-52 { - display: block; - padding: 16px 20px; - border-radius: 10px; - font-size: 12px; - font-weight: 700; - line-height: 16px; - box-shadow: 0 5px 15px 0 rgba(0,0,0,0.1),0 2px 5px 0 rgba(0,0,0,0.05); - color: #FFFFFF; - background-color: rgba(0,0,0,0.95); - -webkit-text-decoration: none; - text-decoration: none; -} - -.emotion-49 > * + * { - margin-top: 10px; -} - -.emotion-49:empty { - display: none; -} - -.emotion-55 { +.emotion-48 { position: absolute; z-index: 1; left: 0; @@ -6914,23 +6873,6 @@ exports[`Storyshots UI|Sidebar/Sidebar simple 1`] = ` color: #774dd7; } -.emotion-48 { - height: 48px; -} - -.emotion-54 { - position: fixed; - display: block; - bottom: 20px; - left: 20px; - margin: 0; - padding: 0; - width: 20%; - min-width: 200px; - max-width: 280px; - z-index: 2; -} - .emotion-4 { shape-rendering: inherit; -webkit-transform: translate3d(0,0,0); @@ -6943,29 +6885,7 @@ exports[`Storyshots UI|Sidebar/Sidebar simple 1`] = ` fill: currentColor; } -.emotion-52 { - display: block; - padding: 16px 20px; - border-radius: 10px; - font-size: 12px; - font-weight: 700; - line-height: 16px; - box-shadow: 0 5px 15px 0 rgba(0,0,0,0.1),0 2px 5px 0 rgba(0,0,0,0.05); - color: #FFFFFF; - background-color: rgba(0,0,0,0.95); - -webkit-text-decoration: none; - text-decoration: none; -} - -.emotion-49 > * + * { - margin-top: 10px; -} - -.emotion-49:empty { - display: none; -} - -.emotion-55 { +.emotion-48 { position: absolute; z-index: 1; left: 0; @@ -7437,25 +7357,8 @@ exports[`Storyshots UI|Sidebar/Sidebar simple 1`] = ` color: #774dd7; } -.emotion-48 { - height: 48px; -} - -.emotion-54 { - position: fixed; - display: block; - bottom: 20px; - left: 20px; - margin: 0; - padding: 0; - width: 20%; - min-width: 200px; - max-width: 280px; - z-index: 2; -} - `; diff --git a/lib/components/src/tabs/__snapshots__/tabs.stories.storyshot b/lib/components/src/tabs/__snapshots__/tabs.stories.storyshot index 0b1f616cad8..172fa52ea43 100644 --- a/lib/components/src/tabs/__snapshots__/tabs.stories.storyshot +++ b/lib/components/src/tabs/__snapshots__/tabs.stories.storyshot @@ -219,11 +219,9 @@ exports[`Storyshots Basics|Tabs stateful - dynamic 1`] = ` >
- + + {list.map(({ title, id, active }) => ( ({ Nav, Preview, Panel, + Notifications, pages: [ { key: 'settings', diff --git a/lib/ui/src/components/layout/desktop.js b/lib/ui/src/components/layout/desktop.js index ae8e509003c..da51326d594 100644 --- a/lib/ui/src/components/layout/desktop.js +++ b/lib/ui/src/components/layout/desktop.js @@ -5,8 +5,16 @@ import ResizeDetector from 'react-resize-detector'; import * as S from './container'; -const Desktop = React.memo(({ Panel, Nav, Preview, pages, options, viewMode }) => ( +const Desktop = React.memo(({ Panel, Nav, Preview, Notifications, pages, options, viewMode }) => ( + + {(width, height) => width && height ? ( @@ -48,6 +56,7 @@ Desktop.propTypes = { Nav: PropTypes.any.isRequired, // eslint-disable-line react/forbid-prop-types Preview: PropTypes.any.isRequired, // eslint-disable-line react/forbid-prop-types Panel: PropTypes.any.isRequired, // eslint-disable-line react/forbid-prop-types + Notifications: PropTypes.any.isRequired, // eslint-disable-line react/forbid-prop-types pages: PropTypes.arrayOf( PropTypes.shape({ key: PropTypes.string.isRequired, diff --git a/lib/ui/src/components/layout/layout.stories.js b/lib/ui/src/components/layout/layout.stories.js index c11cc9004c1..2cc10e64b72 100644 --- a/lib/ui/src/components/layout/layout.stories.js +++ b/lib/ui/src/components/layout/layout.stories.js @@ -19,7 +19,6 @@ import { mockDataset } from '../sidebar/treeview/treeview.mockdata'; const realNavProps = { title: 'Title', url: 'https://example.com', - notifications: [], stories: mockDataset.withRoot, menu: [], }; @@ -110,6 +109,7 @@ const mockProps = { Nav: MockNav, Preview: MockPreview, Panel: MockPanel, + Notifications: () => null, pages: [], options: { isFullscreen: false, showNav: true, showPanel: true, panelPosition: 'right' }, path: '/story/UI-DesktopLayout-noNav', @@ -120,6 +120,7 @@ const mockProps = { const realProps = { Nav: () => , Preview: () => , + Notifications: () => null, Panel: () => ( + +