From d1bf665060af80c7d105b79d032c2f651ae803b3 Mon Sep 17 00:00:00 2001 From: cchaos Date: Wed, 26 Sep 2018 17:09:39 -0400 Subject: [PATCH 01/14] =?UTF-8?q?Don=E2=80=99t=20shrink=20date=20picker=20?= =?UTF-8?q?icon=20fixes=20#1207?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../date_picker/_date_picker_range.scss | 23 +++++++++++-------- 1 file changed, 14 insertions(+), 9 deletions(-) diff --git a/src/components/date_picker/_date_picker_range.scss b/src/components/date_picker/_date_picker_range.scss index 593f2085fe7..d6e0cb103b0 100644 --- a/src/components/date_picker/_date_picker_range.scss +++ b/src/components/date_picker/_date_picker_range.scss @@ -5,7 +5,7 @@ * 1. Account for inner box-shadow style border */ - .euiDatePickerRange { +.euiDatePickerRange { @include euiFormControlSize(auto, $includeAlternates: true); // Match just the regular drop shadow of inputs @include euiFormControlDefaultShadow(); @@ -36,14 +36,19 @@ height: $euiFormControlHeight - 2px; } } -} -.euiDatePickerRange__icon { - padding-left: $euiFormControlPadding; - padding-right: $euiFormControlPadding; -} + // Direct descendent selectors to override `> span` + + > .euiDatePickerRange__icon { + flex: 0 0 auto; + padding-left: $euiFormControlPadding; + padding-right: $euiFormControlPadding; + } -.euiDatePickerRange__delimeter { - padding-left: $euiFormControlPadding/2; - padding-right: $euiFormControlPadding/2; + > .euiDatePickerRange__delimeter { + padding-left: $euiFormControlPadding/2; + padding-right: $euiFormControlPadding/2; + } } + + From 922b6fbf7954cbaeb6659ff153837f30bdfd2d78 Mon Sep 17 00:00:00 2001 From: cchaos Date: Thu, 27 Sep 2018 15:21:30 -0400 Subject: [PATCH 02/14] Altering global time picker to use buttons --- src-docs/src/theme_dark.scss | 1 + src-docs/src/theme_k6_dark.scss | 1 + src-docs/src/theme_k6_light.scss | 1 + src-docs/src/theme_light.scss | 2 +- .../date_picker/_global_date_picker.scss | 78 ++++++ .../views/date_picker/global_date_picker.js | 260 ++++++++++++++---- .../date_picker/_date_picker_range.scss | 6 +- .../date_picker/date_picker_range.js | 46 +++- src/components/form/_mixins.scss | 14 +- 9 files changed, 335 insertions(+), 74 deletions(-) create mode 100644 src-docs/src/views/date_picker/_global_date_picker.scss diff --git a/src-docs/src/theme_dark.scss b/src-docs/src/theme_dark.scss index f09a1aede5c..97d4ef0207c 100644 --- a/src-docs/src/theme_dark.scss +++ b/src-docs/src/theme_dark.scss @@ -1,3 +1,4 @@ @import '../../src/theme_dark'; @import './components/guide_components'; @import './views/header/global_filter_group'; +@import './views/date_picker/global_date_picker'; diff --git a/src-docs/src/theme_k6_dark.scss b/src-docs/src/theme_k6_dark.scss index 99e708a00f1..a3738416b1d 100644 --- a/src-docs/src/theme_k6_dark.scss +++ b/src-docs/src/theme_k6_dark.scss @@ -1,3 +1,4 @@ @import '../../src/theme_k6_dark'; @import './components/guide_components'; @import './views/header/global_filter_group'; +@import './views/date_picker/global_date_picker'; diff --git a/src-docs/src/theme_k6_light.scss b/src-docs/src/theme_k6_light.scss index 544617f335d..6fe9d55fe4b 100644 --- a/src-docs/src/theme_k6_light.scss +++ b/src-docs/src/theme_k6_light.scss @@ -1,3 +1,4 @@ @import '../../src/theme_k6_light'; @import './components/guide_components'; @import './views/header/global_filter_group'; +@import './views/date_picker/global_date_picker'; diff --git a/src-docs/src/theme_light.scss b/src-docs/src/theme_light.scss index 9a8ac0e7586..bd607c9114f 100644 --- a/src-docs/src/theme_light.scss +++ b/src-docs/src/theme_light.scss @@ -1,4 +1,4 @@ @import '../../src/theme_light'; @import './components/guide_components'; @import './views/header/global_filter_group'; - +@import './views/date_picker/global_date_picker'; diff --git a/src-docs/src/views/date_picker/_global_date_picker.scss b/src-docs/src/views/date_picker/_global_date_picker.scss new file mode 100644 index 00000000000..db0fea4284b --- /dev/null +++ b/src-docs/src/views/date_picker/_global_date_picker.scss @@ -0,0 +1,78 @@ +//// GLOBAL Date picker + +.euiGlobalDatePicker__quickSelectButton { + .euiButtonEmpty__text { + margin-right: $euiSizeXS !important; + } +} + +.euiGlobalDatePicker.euiFormControlLayout { + max-width: 480px; + + > .euiFormControlLayout__childrenWrapper { + flex: 1 1 100%; + overflow: hidden; + + > .euiDatePickerRange { + max-width: none; + width: auto; + + .euiPopover__anchor { + display: block; + } + } + } +} + +.euiGlobalDatePicker__dateButton { + display: block; + width: 100%; + @include euiFormControlText; + padding: 0 $euiSizeS; + line-height: $euiFormControlHeight - 2px; + height: $euiFormControlHeight - 2px; + word-break: break-all; + + $backgroundColor: tintOrShade($euiColorSuccess, 90%, 70%); + $textColor: makeHighContrastColor($euiColorSuccess, $backgroundColor); + + &-isSelected, + &-needsUpdating, + &:hover, + &:focus { + background-color: $backgroundColor; + } + + &-needsUpdating { + color: $textColor; + } + + &-isInvalid { + $backgroundColor: tintOrShade($euiColorDanger, 90%, 70%); + $textColor: makeHighContrastColor($euiColorDanger, $backgroundColor); + background-color: $backgroundColor; + color: $textColor; + } + + .euiFormControlLayout__prepend { + border: none; + } +} + +.euiGlobalDatePicker__dateButton--start { + text-align: right; +} + +.euiGlobalDatePicker__dateButton--end { + text-align: left; +} + +.euiGlobalDatePicker__updateButton { + @include euiBreakpoint('xs', 's') { + min-width: 0; + + .euiButton__text { + display: none; + } + } +} diff --git a/src-docs/src/views/date_picker/global_date_picker.js b/src-docs/src/views/date_picker/global_date_picker.js index e45e76e2404..03a9d15ee3e 100644 --- a/src-docs/src/views/date_picker/global_date_picker.js +++ b/src-docs/src/views/date_picker/global_date_picker.js @@ -2,9 +2,10 @@ import React, { Component, Fragment, } from 'react'; +import PropTypes from 'prop-types'; import moment from 'moment'; -import { CalendarContainer } from 'react-datepicker'; +import classNames from 'classnames'; import { EuiDatePicker, @@ -26,6 +27,8 @@ import { EuiForm, EuiSwitch, EuiTextColor, + EuiToolTip, + EuiFieldText, } from '../../../../src/components'; const commonDates = [ @@ -57,9 +60,16 @@ class GlobalDatePopover extends Component { id: 'absolute', name: 'Absolute', content: ( - - {props.children} - +
+ + + + +
), }, { id: 'relative', @@ -79,7 +89,7 @@ class GlobalDatePopover extends Component { - + @@ -117,21 +127,113 @@ class GlobalDatePopover extends Component { tabs={this.tabs} selectedTab={this.state.selectedTab} onTabClick={this.onTabClick} + size="s" expand /> ); } } +// eslint-disable-next-line react/no-multi-comp +class GlobalDateButton extends Component { + static propTypes = { + position: PropTypes.oneOf(['start', 'end']), + isInvalid: PropTypes.bool, + needsUpdating: PropTypes.bool, + buttonOnly: PropTypes.bool, + date: PropTypes.string, + } + + constructor(props) { + super(props); + + this.state = { + isPopoverOpen: false, + }; + } + + togglePopover = () => { + this.setState({ + isPopoverOpen: !this.state.isPopoverOpen, + }); + } + + closePopover = () => { + this.setState({ + isPopoverOpen: false, + }); + } + + render() { + const { + position, + isInvalid, + needsUpdating, + date, + buttonProps, + buttonOnly, + ...rest + } = this.props; + + const { + isPopoverOpen, + } = this.state; + + const classes = classNames([ + 'euiGlobalDatePicker__dateButton', + `euiGlobalDatePicker__dateButton--${position}`, + { + 'euiGlobalDatePicker__dateButton-isSelected': isPopoverOpen, + 'euiGlobalDatePicker__dateButton-isInvalid': isInvalid, + 'euiGlobalDatePicker__dateButton-needsUpdating': needsUpdating + } + ]); + + let title = date; + if (isInvalid) { + title = `Invalid date: ${title}`; + } else if (needsUpdating) { + title = `Update needed: ${title}`; + } + + const button = ( + + ); + + return buttonOnly ? button : ( + + + + ); + } +} + // eslint-disable-next-line react/no-multi-comp export default class extends Component { constructor(props) { super(props); this.state = { - startDate: moment(), - endDate: moment().add(11, 'd'), + startDate: moment().format('MMM DD YYYY h:mm:ss.SSS'), + endDate: moment().add(11, 'd').format('MMM DD YYYY hh:mm:ss.SSS'), isPopoverOpen: false, + showPrettyFormat: false, + showNeedsUpdate: false, recentlyUsed: [ ['11/25/2017 00:00 AM', '11/25/2017 11:59 PM'], ['3 hours ago', '4 minutes ago'], @@ -141,21 +243,44 @@ export default class extends Component { }; } - handleChangeStart = (date) => { - this.setState({ - startDate: date - }); + setTootipRef = node => (this.tooltip = node); + + showTooltip = () => this.tooltip.showToolTip(); + hideTooltip = () => this.tooltip.hideToolTip(); + + togglePopover = (e) => { + // HACK TODO: + // this works because react listens to all events at the + // document level, and you need to interact with the native + // event's propagation to short-circuit outside click handler + // see also: https://stackoverflow.com/a/24421834 + e.nativeEvent.stopImmediatePropagation(); + + this.setState(prevState => ({ + isPopoverOpen: !prevState.isPopoverOpen, + })); } - handleChangeEnd = (date) => { - this.setState({ - endDate: date - }); + togglePrettyFormat = () => { + this.setState(prevState => ({ + showPrettyFormat: !prevState.showPrettyFormat, + })); } - onButtonClick = () => { - this.setState({ - isPopoverOpen: !this.state.isPopoverOpen, + toggleNeedsUpdate = () => { + this.setState(prevState => { + + if (!prevState.showNeedsUpdate) { + clearTimeout(this.tooltipTimeout); + this.showTooltip(); + this.tooltipTimeout = setTimeout(() => { + this.hideTooltip(); + }, 10000); + } + + return ({ + showNeedsUpdate: !prevState.showNeedsUpdate, + }); }); } @@ -165,12 +290,13 @@ export default class extends Component { }); } + render() { const quickSelectButton = ( - this.state.endDate} - aria-label="Start date" - calendarContainer={GlobalDatePopover} - showTimeSelect - /> - } - endDateControl={ - this.state.endDate} - aria-label="End date" - calendarContainer={GlobalDatePopover} - showTimeSelect - /> - } - /> - + +   + + + + + + + + } + endDateControl={ + + } + > + {this.state.showPrettyFormat && + + + Show dates + + } + + + + + {this.renderUpdateButton()} + + + + ); + } + + renderUpdateButton = () => { + const color = this.state.showNeedsUpdate ? 'secondary' : 'primary'; + const icon = this.state.showNeedsUpdate ? 'kqlFunction' : 'refresh'; + const text = this.state.showNeedsUpdate ? 'Update' : 'Refresh'; + + return ( + + {text} + ); } diff --git a/src/components/date_picker/_date_picker_range.scss b/src/components/date_picker/_date_picker_range.scss index d6e0cb103b0..72af8f229de 100644 --- a/src/components/date_picker/_date_picker_range.scss +++ b/src/components/date_picker/_date_picker_range.scss @@ -13,7 +13,7 @@ align-items: center; padding: 1px; /* 1 */ - > span { + > * { flex: 1 1 0%; // All values necessary for IE support } @@ -46,9 +46,9 @@ } > .euiDatePickerRange__delimeter { + line-height: 1 !important; + flex: 0 0 auto; padding-left: $euiFormControlPadding/2; padding-right: $euiFormControlPadding/2; } } - - diff --git a/src/components/date_picker/date_picker_range.js b/src/components/date_picker/date_picker_range.js index a3177121091..8dc3b5e5fd0 100644 --- a/src/components/date_picker/date_picker_range.js +++ b/src/components/date_picker/date_picker_range.js @@ -1,5 +1,5 @@ import React, { - cloneElement, + cloneElement, Fragment, } from 'react'; import PropTypes from 'prop-types'; import classNames from 'classnames'; @@ -11,11 +11,13 @@ import { } from '../icon'; export const EuiDatePickerRange = ({ + children, className, startDateControl, endDateControl, iconType, fullWidth, + isCustom, ...rest }) => { @@ -38,25 +40,35 @@ export const EuiDatePickerRange = ({ optionalIcon = null; } - const clonedStartDate = cloneElement(startDateControl, { - showIcon: false, - fullWidth: fullWidth, - }); + let startControl = startDateControl; + let endControl = endDateControl; + + if (!isCustom) { + startControl = cloneElement(startDateControl, { + showIcon: false, + fullWidth: fullWidth, + }); + + endControl = cloneElement(endDateControl, { + showIcon: false, + fullWidth: fullWidth, + }); + } - const clonedEndDate = cloneElement(endDateControl, { - showIcon: false, - fullWidth: fullWidth, - }); return (
- {optionalIcon} - {clonedStartDate} - - {clonedEndDate} + {children ? (children) : ( + + {optionalIcon} + {startControl} + + {endControl} + + )}
); }; @@ -78,6 +90,14 @@ EuiDatePickerRange.propTypes = { PropTypes.oneOf(ICON_TYPES), ]), fullWidth: PropTypes.bool, + /** + * Won't apply any additional props to start and end date components + */ + isCustom: PropTypes.bool, + /** + * Including any children will replace all innerds with the provided children + */ + children: PropTypes.node, }; EuiDatePickerRange.defaultProps = { diff --git a/src/components/form/_mixins.scss b/src/components/form/_mixins.scss index 66c65d74f84..f5ecd320de9 100644 --- a/src/components/form/_mixins.scss +++ b/src/components/form/_mixins.scss @@ -13,6 +13,13 @@ * 3. Must supply both values to background-size or some browsers apply the single value to both directions */ +@mixin euiFormControlText { + font-size: $euiFontSizeS; + font-family: $euiFontFamily; + line-height: 1em; // fixes text alignment in IE + color: $euiTextColor; +} + @mixin euiFormControlSize( $height: $euiFormControlHeight, $includeAlternates: false @@ -134,14 +141,11 @@ @mixin euiFormControlStyle($borderOnly: false, $includeStates: true, $includeSizes: true) { @include euiFormControlSize($includeAlternates: $includeSizes); @include euiFormControlDefaultShadow; + @include euiFormControlText; border: none; - font-size: $euiFontSizeS; - font-family: $euiFontFamily; - padding: $euiFormControlPadding; - line-height: 1em; // fixes text alignment in IE - color: $euiTextColor; border-radius: 0; + padding: $euiFormControlPadding; @if ($includeSizes) { &--compressed { From 46c721b90eb748c1b38a49bc5a9cfd0c23b2319f Mon Sep 17 00:00:00 2001 From: cchaos Date: Mon, 5 Nov 2018 16:56:17 -0500 Subject: [PATCH 03/14] Added more: - overflow scrolling per section - time range arrows - timer options --- .../date_picker/_global_date_picker.scss | 7 ++ .../views/date_picker/global_date_picker.js | 88 ++++++++++++++++--- 2 files changed, 84 insertions(+), 11 deletions(-) diff --git a/src-docs/src/views/date_picker/_global_date_picker.scss b/src-docs/src/views/date_picker/_global_date_picker.scss index db0fea4284b..21b4b0537eb 100644 --- a/src-docs/src/views/date_picker/_global_date_picker.scss +++ b/src-docs/src/views/date_picker/_global_date_picker.scss @@ -76,3 +76,10 @@ } } } + +.euiGlobalDatePicker__popoverSection { + @include euiScrollBar; + max-height: $euiSizeM * 11; + overflow: hidden; + overflow-y: auto; +} diff --git a/src-docs/src/views/date_picker/global_date_picker.js b/src-docs/src/views/date_picker/global_date_picker.js index 03a9d15ee3e..e863d417dcc 100644 --- a/src-docs/src/views/date_picker/global_date_picker.js +++ b/src-docs/src/views/date_picker/global_date_picker.js @@ -29,6 +29,7 @@ import { EuiTextColor, EuiToolTip, EuiFieldText, + EuiButtonIcon, } from '../../../../src/components'; const commonDates = [ @@ -234,11 +235,15 @@ export default class extends Component { isPopoverOpen: false, showPrettyFormat: false, showNeedsUpdate: false, + timerIsOn: false, recentlyUsed: [ ['11/25/2017 00:00 AM', '11/25/2017 11:59 PM'], ['3 hours ago', '4 minutes ago'], 'Last 6 months', ['06/11/2017 06:11 AM', '06/11/2017 06:11 PM'], + ['06/11/2017 06:11 AM', '06/11/2017 06:11 PM'], + ['06/11/2017 06:11 AM', '06/11/2017 06:11 PM'], + ['06/11/2017 06:11 AM', '06/11/2017 06:11 PM'], ], }; } @@ -290,6 +295,12 @@ export default class extends Component { }); } + toggleTimer = () => { + this.setState(prevState => ({ + timerIsOn: !prevState.timerIsOn, + })); + } + render() { const quickSelectButton = ( @@ -302,7 +313,7 @@ export default class extends Component { iconType="arrowDown" iconSide="right" > - +
); @@ -318,12 +329,14 @@ export default class extends Component { anchorPosition="downLeft" ownFocus > -
+
{this.renderQuickSelect()} - + {commonlyUsed} - + {recentlyUsed} + + {this.renderTimer()}
); @@ -412,27 +425,41 @@ export default class extends Component { return ( - Quick select + + + Quick select + + + + + + + + + + + + - + - + - + - Apply + Apply @@ -451,7 +478,7 @@ export default class extends Component { Commonly used - + {links} @@ -476,7 +503,7 @@ export default class extends Component { Recently used date ranges - + {links} @@ -484,4 +511,43 @@ export default class extends Component { ); } + + renderTimer = () => { + const lastOptions = [ + { value: 'minutes', text: 'minutes' }, + { value: 'hours', text: 'hours' }, + ]; + + return ( + + Refresh every + + + + + + + + + + + + + + + + {this.state.timerIsOn ? 'Stop' : 'Start'} + + + + + + ); + } + } From f6b4f71a7e467d191228e7f2c3d527f01399a244 Mon Sep 17 00:00:00 2001 From: cchaos Date: Wed, 7 Nov 2018 18:07:08 -0500 Subject: [PATCH 04/14] Addressed feedback --- .../date_picker/_global_date_picker.scss | 14 ++++++-- .../views/date_picker/global_date_picker.js | 32 +++++++++++++++---- src/components/button/button.js | 16 +++++++--- .../button/button_empty/button_empty.js | 16 +++++++--- .../date_picker/_date_picker_range.scss | 7 ++-- 5 files changed, 65 insertions(+), 20 deletions(-) diff --git a/src-docs/src/views/date_picker/_global_date_picker.scss b/src-docs/src/views/date_picker/_global_date_picker.scss index 21b4b0537eb..f167cc635db 100644 --- a/src-docs/src/views/date_picker/_global_date_picker.scss +++ b/src-docs/src/views/date_picker/_global_date_picker.scss @@ -1,7 +1,11 @@ //// GLOBAL Date picker .euiGlobalDatePicker__quickSelectButton { - .euiButtonEmpty__text { + // Override prepend border since button already lives inside another prepend + border-right: none !important; + + .euiGlobalDatePicker__quickSelectButtonText { + // Override specificity from universal and sibiling selectors margin-right: $euiSizeXS !important; } } @@ -25,13 +29,14 @@ } .euiGlobalDatePicker__dateButton { + @include euiFormControlText; display: block; width: 100%; - @include euiFormControlText; padding: 0 $euiSizeS; line-height: $euiFormControlHeight - 2px; height: $euiFormControlHeight - 2px; word-break: break-all; + transition: background $euiAnimSpeedFast ease-in; $backgroundColor: tintOrShade($euiColorSuccess, 90%, 70%); $textColor: makeHighContrastColor($euiColorSuccess, $backgroundColor); @@ -68,10 +73,13 @@ } .euiGlobalDatePicker__updateButton { + // Just wide enough for all 3 states + min-width: $euiButtonMinWidth + ($euiSizeXS * 1.5); + @include euiBreakpoint('xs', 's') { min-width: 0; - .euiButton__text { + .euiGlobalDatePicker__updateButtonText { display: none; } } diff --git a/src-docs/src/views/date_picker/global_date_picker.js b/src-docs/src/views/date_picker/global_date_picker.js index e863d417dcc..cd7a4839f13 100644 --- a/src-docs/src/views/date_picker/global_date_picker.js +++ b/src-docs/src/views/date_picker/global_date_picker.js @@ -235,6 +235,7 @@ export default class extends Component { isPopoverOpen: false, showPrettyFormat: false, showNeedsUpdate: false, + isUpdating: false, timerIsOn: false, recentlyUsed: [ ['11/25/2017 00:00 AM', '11/25/2017 11:59 PM'], @@ -301,12 +302,18 @@ export default class extends Component { })); } + toggleIsUpdating = () => { + this.setState(prevState => ({ + isUpdating: !prevState.isUpdating, + })); + } + render() { const quickSelectButton = (
{this.renderQuickSelect()} @@ -344,7 +350,8 @@ export default class extends Component { return (   - +   + @@ -398,11 +405,24 @@ export default class extends Component { renderUpdateButton = () => { const color = this.state.showNeedsUpdate ? 'secondary' : 'primary'; const icon = this.state.showNeedsUpdate ? 'kqlFunction' : 'refresh'; - const text = this.state.showNeedsUpdate ? 'Update' : 'Refresh'; + let text = this.state.showNeedsUpdate ? 'Update' : 'Refresh'; + + if (this.state.isUpdating) { + text = 'Updating'; + } return ( - {text} + + {text} + ); } @@ -539,7 +559,7 @@ export default class extends Component { iconType={this.state.timerIsOn ? 'stop' : 'play'} size="s" onClick={this.toggleTimer} - style={{ minWidth: 0 }} + style={{ minWidth: 90 }} > {this.state.timerIsOn ? 'Stop' : 'Start'} diff --git a/src/components/button/button.js b/src/components/button/button.js index 9a4875d7b25..0d5eb1fc26a 100644 --- a/src/components/button/button.js +++ b/src/components/button/button.js @@ -53,6 +53,8 @@ export const EuiButton = ({ rel, type, buttonRef, + contentProps, + textProps, ...rest }) => { @@ -105,9 +107,9 @@ export const EuiButton = ({ ref={buttonRef} {...rest} > - + {buttonIcon} - {children} + {children} ); @@ -120,9 +122,9 @@ export const EuiButton = ({ ref={buttonRef} {...rest} > - + {buttonIcon} - {children} + {children} ); @@ -165,6 +167,12 @@ EuiButton.propTypes = { */ type: PropTypes.string, buttonRef: PropTypes.func, + + /** + * Props passing + */ + contentProps: PropTypes.object, + textProps: PropTypes.object, }; EuiButton.defaultProps = { diff --git a/src/components/button/button_empty/button_empty.js b/src/components/button/button_empty/button_empty.js index 799db99bf2a..51f515dc5ce 100644 --- a/src/components/button/button_empty/button_empty.js +++ b/src/components/button/button_empty/button_empty.js @@ -60,6 +60,8 @@ export const EuiButtonEmpty = ({ rel, type, buttonRef, + contentProps, + textProps, ...rest }) => { @@ -110,9 +112,9 @@ export const EuiButtonEmpty = ({ ref={buttonRef} {...rest} > - + {buttonIcon} - {children} + {children} ); @@ -125,9 +127,9 @@ export const EuiButtonEmpty = ({ ref={buttonRef} {...rest} > - + {buttonIcon} - {children} + {children} ); @@ -155,6 +157,12 @@ EuiButtonEmpty.propTypes = { type: PropTypes.string, buttonRef: PropTypes.func, + + /** + * Props passing + */ + contentProps: PropTypes.object, + textProps: PropTypes.object, }; EuiButtonEmpty.defaultProps = { diff --git a/src/components/date_picker/_date_picker_range.scss b/src/components/date_picker/_date_picker_range.scss index 72af8f229de..a88f2331894 100644 --- a/src/components/date_picker/_date_picker_range.scss +++ b/src/components/date_picker/_date_picker_range.scss @@ -13,8 +13,9 @@ align-items: center; padding: 1px; /* 1 */ + // Allow any child to fill entire range container > * { - flex: 1 1 0%; // All values necessary for IE support + flex-grow: 1; } .euiFieldText.euiDatePicker { @@ -48,7 +49,7 @@ > .euiDatePickerRange__delimeter { line-height: 1 !important; flex: 0 0 auto; - padding-left: $euiFormControlPadding/2; - padding-right: $euiFormControlPadding/2; + padding-left: $euiFormControlPadding / 2; + padding-right: $euiFormControlPadding / 2; } } From 9e44a7eda9ada16f75556628fcb0ead9fda19154 Mon Sep 17 00:00:00 2001 From: cchaos Date: Fri, 16 Nov 2018 14:14:49 -0500 Subject: [PATCH 05/14] Some tweaks --- .../date_picker/_global_date_picker.scss | 20 +++++++++++-------- .../views/date_picker/date_picker_example.js | 4 +--- .../views/date_picker/global_date_picker.js | 19 ++++++------------ 3 files changed, 19 insertions(+), 24 deletions(-) diff --git a/src-docs/src/views/date_picker/_global_date_picker.scss b/src-docs/src/views/date_picker/_global_date_picker.scss index f167cc635db..d522ce46bcb 100644 --- a/src-docs/src/views/date_picker/_global_date_picker.scss +++ b/src-docs/src/views/date_picker/_global_date_picker.scss @@ -1,5 +1,6 @@ //// GLOBAL Date picker +// sass-lint:disable no-important .euiGlobalDatePicker__quickSelectButton { // Override prepend border since button already lives inside another prepend border-right: none !important; @@ -21,6 +22,7 @@ max-width: none; width: auto; + // sass-lint:disable nesting-depth .euiPopover__anchor { display: block; } @@ -75,14 +77,6 @@ .euiGlobalDatePicker__updateButton { // Just wide enough for all 3 states min-width: $euiButtonMinWidth + ($euiSizeXS * 1.5); - - @include euiBreakpoint('xs', 's') { - min-width: 0; - - .euiGlobalDatePicker__updateButtonText { - display: none; - } - } } .euiGlobalDatePicker__popoverSection { @@ -91,3 +85,13 @@ overflow: hidden; overflow-y: auto; } + +@include euiBreakpoint('xs', 's') { + .euiGlobalDatePicker__updateButton { + min-width: 0; + + .euiGlobalDatePicker__updateButtonText { + display: none; + } + } +} diff --git a/src-docs/src/views/date_picker/date_picker_example.js b/src-docs/src/views/date_picker/date_picker_example.js index e40743e58bf..38dcff6a3f9 100644 --- a/src-docs/src/views/date_picker/date_picker_example.js +++ b/src-docs/src/views/date_picker/date_picker_example.js @@ -279,9 +279,7 @@ export const DatePickerExample = {

This documents a visual pattern for the eventual replacement of Kibana's - global date/time picker. It uses all EUI components without any custom styles. However, it - currently depends strongly on react-datepicker's calendarContainer option - which has it's own problems and limitations (like auto-focus on input stealing focus from inputs inside of popover). + global date/time picker. It uses all EUI components with some custom styles.

diff --git a/src-docs/src/views/date_picker/global_date_picker.js b/src-docs/src/views/date_picker/global_date_picker.js index cd7a4839f13..0b4b809576c 100644 --- a/src-docs/src/views/date_picker/global_date_picker.js +++ b/src-docs/src/views/date_picker/global_date_picker.js @@ -26,7 +26,6 @@ import { EuiTabbedContent, EuiForm, EuiSwitch, - EuiTextColor, EuiToolTip, EuiFieldText, EuiButtonIcon, @@ -90,7 +89,7 @@ class GlobalDatePopover extends Component { - + @@ -101,14 +100,11 @@ class GlobalDatePopover extends Component { id: 'now', name: 'Now', content: ( - - {moment().format('MMMM Do YYYY')} - - - - {moment().format('h:mm:ss a')} - - + +

+ Setting the time to "Now" means that on every refresh + this time will be set to the time of the refresh. +

), }]; @@ -242,9 +238,6 @@ export default class extends Component { ['3 hours ago', '4 minutes ago'], 'Last 6 months', ['06/11/2017 06:11 AM', '06/11/2017 06:11 PM'], - ['06/11/2017 06:11 AM', '06/11/2017 06:11 PM'], - ['06/11/2017 06:11 AM', '06/11/2017 06:11 PM'], - ['06/11/2017 06:11 AM', '06/11/2017 06:11 PM'], ], }; } From d8c1f8e58d82db5a5373394f605a14d256dae711 Mon Sep 17 00:00:00 2001 From: cchaos Date: Fri, 16 Nov 2018 14:24:29 -0500 Subject: [PATCH 06/14] cl --- CHANGELOG.md | 1 + 1 file changed, 1 insertion(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index b3c6b4fe414..715261d2c63 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,6 +1,7 @@ ## [`master`](https://github.com/elastic/eui/tree/master) - Added support for nodes as "Action" column headers in `EuiBasicTable`, which was overlooked in the original change in `4.5.0` ([#1312](https://github.com/elastic/eui/pull/1312)) +- Updated `GlobalDatePicker` example to include all Kibana features ([#1219](https://github.com/elastic/eui/pull/1219)) **Bug fixes** From 4b333e60ee722486657434a5899dc9af921ecd74 Mon Sep 17 00:00:00 2001 From: cchaos Date: Fri, 16 Nov 2018 14:32:18 -0500 Subject: [PATCH 07/14] quick ize fix (for IE) --- src-docs/src/views/date_picker/global_date_picker.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src-docs/src/views/date_picker/global_date_picker.js b/src-docs/src/views/date_picker/global_date_picker.js index 0b4b809576c..13930214175 100644 --- a/src-docs/src/views/date_picker/global_date_picker.js +++ b/src-docs/src/views/date_picker/global_date_picker.js @@ -328,7 +328,7 @@ export default class extends Component { closePopover={this.closePopover.bind(this)} anchorPosition="downLeft" > -
+
{this.renderQuickSelect()} {commonlyUsed} From 67d291fe1ae195929872585615cf7b210e1bfff1 Mon Sep 17 00:00:00 2001 From: cchaos Date: Fri, 16 Nov 2018 14:45:23 -0500 Subject: [PATCH 08/14] more cl and comments --- CHANGELOG.md | 2 ++ src/components/button/button.js | 6 +++++- src/components/button/button_empty/button_empty.js | 6 +++++- 3 files changed, 12 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 715261d2c63..741e6513cef 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,6 +2,8 @@ - Added support for nodes as "Action" column headers in `EuiBasicTable`, which was overlooked in the original change in `4.5.0` ([#1312](https://github.com/elastic/eui/pull/1312)) - Updated `GlobalDatePicker` example to include all Kibana features ([#1219](https://github.com/elastic/eui/pull/1219)) +- Adjusted `EuiDatePickerRange` to allow for deeper customization ([#1219](https://github.com/elastic/eui/pull/1219)) +- Added `contentProps` and `textProps` to `EuiButton` and `EuiButtonEmpty` ([#1219](https://github.com/elastic/eui/pull/1219)) **Bug fixes** diff --git a/src/components/button/button.js b/src/components/button/button.js index 0d5eb1fc26a..9d5fbf68b56 100644 --- a/src/components/button/button.js +++ b/src/components/button/button.js @@ -169,9 +169,13 @@ EuiButton.propTypes = { buttonRef: PropTypes.func, /** - * Props passing + * Passes props to `euiButton__content` span */ contentProps: PropTypes.object, + + /** + * Passes props to `euiButton__text` span + */ textProps: PropTypes.object, }; diff --git a/src/components/button/button_empty/button_empty.js b/src/components/button/button_empty/button_empty.js index 51f515dc5ce..20c57e60f06 100644 --- a/src/components/button/button_empty/button_empty.js +++ b/src/components/button/button_empty/button_empty.js @@ -159,9 +159,13 @@ EuiButtonEmpty.propTypes = { buttonRef: PropTypes.func, /** - * Props passing + * Passes props to `euiButton__content` span */ contentProps: PropTypes.object, + + /** + * Passes props to `euiButton__text` span + */ textProps: PropTypes.object, }; From 550ee0cb465eadba26badb192c86c16b59d1d2e3 Mon Sep 17 00:00:00 2001 From: cchaos Date: Fri, 16 Nov 2018 14:47:51 -0500 Subject: [PATCH 09/14] ts defs? --- src/components/button/index.d.ts | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/src/components/button/index.d.ts b/src/components/button/index.d.ts index fe10d678721..efe61d2755d 100644 --- a/src/components/button/index.d.ts +++ b/src/components/button/index.d.ts @@ -33,6 +33,8 @@ declare module '@elastic/eui' { size?: ButtonSize; isLoading?: boolean; isDisabled?: boolean; + contentProps?: object; + textProps?: object; } export const EuiButton: SFC< EuiButtonPropsForButtonOrLink @@ -87,6 +89,8 @@ declare module '@elastic/eui' { flush?: EmptyButtonFlush; isLoading?: boolean; isDisabled?: boolean; + contentProps?: object; + textProps?: object; } export const EuiButtonEmpty: SFC< From a13183c40fd6a052be0684ba56d4b82a4cd4bd55 Mon Sep 17 00:00:00 2001 From: Chandler Prall Date: Tue, 20 Nov 2018 11:46:14 -0500 Subject: [PATCH 10/14] Update src/components/button/index.d.ts Co-Authored-By: cchaos <549577+cchaos@users.noreply.github.com> --- src/components/button/index.d.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/components/button/index.d.ts b/src/components/button/index.d.ts index efe61d2755d..3c8fad3f4a9 100644 --- a/src/components/button/index.d.ts +++ b/src/components/button/index.d.ts @@ -33,7 +33,7 @@ declare module '@elastic/eui' { size?: ButtonSize; isLoading?: boolean; isDisabled?: boolean; - contentProps?: object; + contentProps?: HTMLAttributes; textProps?: object; } export const EuiButton: SFC< From b4ef2ac9b5551a4ea7a534076d1ba5d093d3f10f Mon Sep 17 00:00:00 2001 From: Chandler Prall Date: Tue, 20 Nov 2018 11:46:30 -0500 Subject: [PATCH 11/14] Update src/components/button/index.d.ts Co-Authored-By: cchaos <549577+cchaos@users.noreply.github.com> --- src/components/button/index.d.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/components/button/index.d.ts b/src/components/button/index.d.ts index 3c8fad3f4a9..7a81514aa55 100644 --- a/src/components/button/index.d.ts +++ b/src/components/button/index.d.ts @@ -34,7 +34,7 @@ declare module '@elastic/eui' { isLoading?: boolean; isDisabled?: boolean; contentProps?: HTMLAttributes; - textProps?: object; + textProps?: HTMLAttributes; } export const EuiButton: SFC< EuiButtonPropsForButtonOrLink From 128e385c9671f34aeec8f5debfa4c04ca5be7500 Mon Sep 17 00:00:00 2001 From: Chandler Prall Date: Tue, 20 Nov 2018 11:46:37 -0500 Subject: [PATCH 12/14] Update src/components/button/index.d.ts Co-Authored-By: cchaos <549577+cchaos@users.noreply.github.com> --- src/components/button/index.d.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/components/button/index.d.ts b/src/components/button/index.d.ts index 7a81514aa55..b8f2c4c35a1 100644 --- a/src/components/button/index.d.ts +++ b/src/components/button/index.d.ts @@ -89,7 +89,7 @@ declare module '@elastic/eui' { flush?: EmptyButtonFlush; isLoading?: boolean; isDisabled?: boolean; - contentProps?: object; + contentProps?: HTMLAttributes; textProps?: object; } From 55038ffc76a141c31dfe51c65ae5f398ebe2c8a1 Mon Sep 17 00:00:00 2001 From: Chandler Prall Date: Tue, 20 Nov 2018 11:46:44 -0500 Subject: [PATCH 13/14] Update src/components/button/index.d.ts Co-Authored-By: cchaos <549577+cchaos@users.noreply.github.com> --- src/components/button/index.d.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/components/button/index.d.ts b/src/components/button/index.d.ts index b8f2c4c35a1..b1be1f5dc83 100644 --- a/src/components/button/index.d.ts +++ b/src/components/button/index.d.ts @@ -90,7 +90,7 @@ declare module '@elastic/eui' { isLoading?: boolean; isDisabled?: boolean; contentProps?: HTMLAttributes; - textProps?: object; + textProps?: HTMLAttributes; } export const EuiButtonEmpty: SFC< From 4fc04fcef9656fc6843b66586e8a202295db8af3 Mon Sep 17 00:00:00 2001 From: cchaos Date: Tue, 20 Nov 2018 12:04:17 -0500 Subject: [PATCH 14/14] Import HTMLAttributes --- src/components/button/index.d.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/components/button/index.d.ts b/src/components/button/index.d.ts index b1be1f5dc83..fd3096cee25 100644 --- a/src/components/button/index.d.ts +++ b/src/components/button/index.d.ts @@ -1,7 +1,7 @@ /// /// -import { SFC, ButtonHTMLAttributes, AnchorHTMLAttributes, MouseEventHandler } from 'react'; +import { SFC, ButtonHTMLAttributes, AnchorHTMLAttributes, MouseEventHandler, HTMLAttributes } from 'react'; declare module '@elastic/eui' { type EuiButtonPropsForButtonOrLink = (