From d5233c3b1b973777d85ae661ef58d073f8c06038 Mon Sep 17 00:00:00 2001
From: Caroline Horn <549577+cchaos@users.noreply.github.com>
Date: Sat, 20 Jul 2019 00:39:06 -0400
Subject: [PATCH] Attempting to fix with EuiFlyout maxWidth (#2125)
* Rounding min and max widths
* Reduced min-width of medium flyouts to 448
..to accomodate forms.
Also added docs example for this forms width trick.
---
CHANGELOG.md | 1 +
src-docs/src/views/flyout/flyout_example.js | 23 ++--
src-docs/src/views/flyout/flyout_max_width.js | 111 +++++++++++++++---
.../src/views/not_found/not_found_view.js | 31 ++---
src/components/flyout/_flyout.scss | 15 ++-
src/components/flyout/flyout.js | 4 +-
6 files changed, 141 insertions(+), 44 deletions(-)
diff --git a/CHANGELOG.md b/CHANGELOG.md
index 932a368fbfd..e8255121914 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -8,6 +8,7 @@
- Fixed `EuiComboBox`'s padding on the right ([#2135](https://github.com/elastic/eui/pull/2135))
- Fixed `EuiAccordion` to correctly account for changing computed height of child elements ([#2136](https://github.com/elastic/eui/pull/2136))
+- Fixed some `EuiFlyout` sizing ([#2125](https://github.com/elastic/eui/pull/2125))
**Breaking changes**
diff --git a/src-docs/src/views/flyout/flyout_example.js b/src-docs/src/views/flyout/flyout_example.js
index cf9d3c0d5d6..c4f43923011 100644
--- a/src-docs/src/views/flyout/flyout_example.js
+++ b/src-docs/src/views/flyout/flyout_example.js
@@ -1,4 +1,4 @@
-import React from 'react';
+import React, { Fragment } from 'react';
import { renderToHtml } from '../../services';
@@ -9,6 +9,7 @@ import {
EuiFlyout,
EuiFlyoutHeader,
EuiFlyoutFooter,
+ EuiCallOut,
} from '../../../../src/components';
import { Flyout } from './flyout';
@@ -216,7 +217,7 @@ export const FlyoutExample = {
demo: ,
},
{
- title: 'maxWidth',
+ title: 'Max width',
source: [
{
type: GuideSectionTypes.JS,
@@ -228,14 +229,22 @@ export const FlyoutExample = {
},
],
text: (
-
- In this example, we set maxWidth to{' '}
- 448px, to set the width of the flyout at the ideal
- width for a form.
-
+
+
+ By default, flyouts will continue to grow with the width of the
+ window. To stop this growth at an ideal width, set{' '}
+ maxWidth to true, or pass your
+ own custom size.
+
- Show max-width flyout
+ this.showFlyout('s')}>
+ Show small flyout with no max-width
+
+
+ this.showFlyout('s', true)}>
+ Show small flyout with{' '}
+ default max-width
+
+
+ this.showFlyout('s', 200)}>
+ Show small flyout with{' '}
+ smaller custom max-width -- minWidth wins except for
+ on small screens
+
+
+ this.showFlyout('s', 448)}>
+ Show small flyout with{' '}
+ larger custom max-width -- minWidth wins except for
+ on small screens
+
+
+
+
+ this.showFlyout('m')}>
+ Show medium flyout with no max-width
+
+
+ this.showFlyout('m', true)}>
+ Show medium flyout with{' '}
+ default max-width
+
+
+ this.showFlyout('m', 448)}>
+ Show medium flyout with{' '}
+ smaller custom max-width -- minWidth wins and full
+ 100vw wins on small screens
+
+
+ this.showFlyout('m', 900)}>
+ Show medium flyout with{' '}
+ larger custom max-width
+
+
+
+
+ this.showFlyout('l')}>
+ Show large flyout with no max-width
+
+
+ this.showFlyout('l', true)}>
+ Show large flyout with{' '}
+ default max-width
+
+
+ this.showFlyout('l', 448)}>
+ Show large flyout with{' '}
+ smaller custom max-width -- minWidth wins and full
+ 100vw wins on small screens
+
+
+ this.showFlyout('l', 1600)}>
+ Show large flyout with{' '}
+ larger custom max-width
+
+
+
+
+ this.showFlyout('m', 0)}>
+ Trick for forms: Medium flyout with{' '}
+ 0 as max-width
+
{flyout}
diff --git a/src-docs/src/views/not_found/not_found_view.js b/src-docs/src/views/not_found/not_found_view.js
index d9400e71eb3..d17729d6477 100644
--- a/src-docs/src/views/not_found/not_found_view.js
+++ b/src-docs/src/views/not_found/not_found_view.js
@@ -1,26 +1,27 @@
import React from 'react';
import { Link } from 'react-router';
+import { EuiText } from '../../../../src/components/text';
export const NotFoundView = () => (
-
- Wow, a 404! You just created something from nothing.
-
+
+
404
-
- You visited a page which doesn’t exist, causing this page
- to exist. This page thanks you for summoning it into existence from the
- raw fabric of reality, but it thinks you may find another page more
- interesting. Might it suggest the{' '}
- {
-
- home page
-
- }
- ?
-
+
+ You visited a page which doesn’t exist, causing this{' '}
+ page to exist. This page thanks you for summoning it into existence
+ from the raw fabric of reality, but it thinks you may find another
+ page more interesting. Might it suggest the{' '}
+ {
+
+ home page
+
+ }
+ ?
+
+
);
diff --git a/src/components/flyout/_flyout.scss b/src/components/flyout/_flyout.scss
index 226c6f6a741..cda11c8a26b 100644
--- a/src/components/flyout/_flyout.scss
+++ b/src/components/flyout/_flyout.scss
@@ -1,3 +1,5 @@
+@import '../form/variables';
+
.euiFlyout {
border-left: $euiBorderThin;
// The mixin augments the above
@@ -31,17 +33,18 @@
*/
$flyoutSizes: (
'small': (
- min: map-get($euiBreakpoints, 'm') * .5, /* 1 */
+ min: round(map-get($euiBreakpoints, 'm') * .5), /* 1 */
width: 25vw,
- max: map-get($euiBreakpoints, 's'),
+ max: round(map-get($euiBreakpoints, 's') * .7),
),
'medium': (
- min: map-get($euiBreakpoints, 'm') * .7, /* 1 */
+ // Calculated for forms plus padding
+ min: $euiFormMaxWidth + ($euiSizeM * 2),
width: 50vw,
max: map-get($euiBreakpoints, 'm'),
),
'large': (
- min: map-get($euiBreakpoints, 'm') * .9, /* 1 */
+ min: round(map-get($euiBreakpoints, 'm') * .9), /* 1 */
width: 75vw,
max: map-get($euiBreakpoints, 'l'),
)
@@ -85,8 +88,8 @@ $flyoutSizes: (
}
.euiFlyout--small {
- width: 80vw; // ensure that it's only partially showing the main content
+ width: 90vw; // ensure that it's only partially showing the main content
min-width: 0; /* 1 */
- max-width: 80vw !important; /* 2 */
+ max-width: map-get(map-get($flyoutSizes, 'small'), 'max');
}
}
diff --git a/src/components/flyout/flyout.js b/src/components/flyout/flyout.js
index 96da9206d38..17f3e88b43a 100644
--- a/src/components/flyout/flyout.js
+++ b/src/components/flyout/flyout.js
@@ -123,8 +123,8 @@ EuiFlyout.propTypes = {
* Sets the max-width of the page,
* set to `true` to use the default size,
* set to `false` to not restrict the width,
- * set to a number for a custom width in px,
- * set to a string for a custom width in custom measurement.
+ * set to a `number` for a custom width in `px`,
+ * set to a `string` for a custom width in a custom measurement.
*/
maxWidth: PropTypes.oneOfType([
PropTypes.bool,