UNPKG

react-lightning-design-components

Version:

Salesforce Lightning Design System components built with React 16

227 lines (185 loc) 24.8 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); var _getPrototypeOf = require('babel-runtime/core-js/object/get-prototype-of'); var _getPrototypeOf2 = _interopRequireDefault(_getPrototypeOf); var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck'); var _classCallCheck3 = _interopRequireDefault(_classCallCheck2); var _createClass2 = require('babel-runtime/helpers/createClass'); var _createClass3 = _interopRequireDefault(_createClass2); var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn'); var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2); var _inherits2 = require('babel-runtime/helpers/inherits'); var _inherits3 = _interopRequireDefault(_inherits2); var _react = require('react'); var _react2 = _interopRequireDefault(_react); var _reactDom = require('react-dom'); var _reactDom2 = _interopRequireDefault(_reactDom); var _Button = require('./Button'); var _Button2 = _interopRequireDefault(_Button); var _Input = require('./Input'); var _Input2 = _interopRequireDefault(_Input); var _Icon = require('./Icon'); var _Icon2 = _interopRequireDefault(_Icon); var _util = require('./util'); var _classnames = require('classnames'); var _classnames2 = _interopRequireDefault(_classnames); var _propTypes = require('prop-types'); var _propTypes2 = _interopRequireDefault(_propTypes); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var SearchButtonField = function (_React$Component) { (0, _inherits3.default)(SearchButtonField, _React$Component); function SearchButtonField(props) { (0, _classCallCheck3.default)(this, SearchButtonField); var _this = (0, _possibleConstructorReturn3.default)(this, (SearchButtonField.__proto__ || (0, _getPrototypeOf2.default)(SearchButtonField)).call(this, props)); _this.state = { expanded: !!props.value, collapsing: false, value: props.value || '' }; _this.expandField = _this.expandField.bind(_this); _this.collapseField = _this.collapseField.bind(_this); _this.onCancelClick = _this.onCancelClick.bind(_this); _this.onChange = _this.onChange.bind(_this); _this.onKeyDown = _this.onKeyDown.bind(_this); _this.onClick = _this.onClick.bind(_this); _this.inputRef = _this.inputRef.bind(_this); _this.closeSearchIconRef = _this.closeSearchIconRef.bind(_this); (0, _util.registerStyle)('search-button-field', [['.search-button-field-container', '{ position: relative; display: flex; justify-content: flex-end; width: 100%; }'], ['.search-button-field-input', '{ position: absolute; top:0; right: 0; opacity: 0; ' + 'max-width: 0; transition: max-width 500ms ease-in-out 300ms,' + ' opacity 300ms ease-in-out 300ms; }'], ['.search-button-field-input.expanded', '{ max-width: 100%; opacity: 1; }'], ['.search-button-field-input.expanded.collapsing', '{ max-width: 0; opacity: 0;' + 'transition: max-width 500ms ease-in-out, opacity 200ms ease-in-out 300ms;}'], ['.search-button-field-btn', '{ background-color: white; opacity: 1; transition: opacity 300ms ease-in-out; }'], ['.search-button-field-btn:hover', '{ background-color: #f4f6f9; }'], ['.search-button-field-btn.expanded', '{ background-color: white; opacity: 0; cursor: default; }'], ['.search-button-field-btn.expanded.collapsing', '{ opacity: 1; transition: opacity 300ms ease-in-out 700ms; }'], ['.search-button-field-cancel-container', '{ position: relative; display: flex; justify-content: center;' + 'align-items: center; height: 32px; width: 32px; }'], ['.search-button-field-cancel', '{ background-color: #9faab5; border-radius: 50%;' + 'width: 13px; height: 13px; padding: 2px; z-index: 0;' + 'opacity: 0; transition: opacity 300ms ease-in-out 300ms; }'], ['.search-button-field-cancel.expanded', '{ opacity: 1; right: 8px; z-index: 1;}'], ['.search-button-field-cancel.expanded:hover', '{ background-color: #1589ee; cursor: pointer; }'], ['.search-button-field-cancel.expanded:hover:active', '{ background-color: #54698d; cursor: pointer; }'], ['.search-button-field-cancel.expanded.collapsing', '{ opacity: 0; transition: opacity 300ms ease-in-out; }']]); return _this; } (0, _createClass3.default)(SearchButtonField, [{ key: 'onCancelClick', value: function onCancelClick() { var shouldRaiseOnChangeEventWithoutValue = this.props.onChange && this.state.value; if (shouldRaiseOnChangeEventWithoutValue) { this.props.onChange(); } this.collapseField(); if (this.props.onCancel) this.props.onCancel(); if (this.props.onClosed) this.props.onClosed(); } }, { key: 'onChange', value: function onChange(event) { this.setState({ value: event.target.value }); if (this.props.onChange) this.props.onChange(event); } }, { key: 'onKeyDown', value: function onKeyDown(event) { var _props = this.props, closeOnEscape = _props.closeOnEscape, onEnter = _props.onEnter; if (event.keyCode === 13 && onEnter) { onEnter(event); } else if (closeOnEscape && event.keyCode === 27) { this.onCancelClick(); } } }, { key: 'onClick', value: function onClick() { this.expandField(); if (this.props.onClick) this.props.onClick(); } }, { key: 'expandField', value: function expandField() { this.setState({ expanded: true }); _reactDom2.default.findDOMNode(this.input).focus(); if (this.props.onExpand) this.props.onExpand(); } }, { key: 'collapseField', value: function collapseField() { var _this2 = this; this.setState({ collapsing: true, value: '' }); setTimeout(function () { _this2.setState({ collapsing: false, expanded: false }); if (_this2.props.onCollapse) _this2.props.onCollapse(); }, 500); } }, { key: 'inputRef', value: function inputRef(ref) { this.input = ref; } }, { key: 'closeSearchIconRef', value: function closeSearchIconRef(ref) { this.closeSearchIcon = ref; } }, { key: 'renderSearchButton', value: function renderSearchButton() { var expanded = this.state.expanded; var _props2 = this.props, searchButtonTitle = _props2.searchButtonTitle, renderButton = _props2.renderButton; var buttonProps = { type: 'icon-border', icon: 'search', className: (0, _classnames2.default)('search-button-field-btn', this.state.expanded ? 'expanded' : '', this.state.collapsing ? 'collapsing' : ''), onClick: this.onClick, title: searchButtonTitle, tabIndex: !expanded ? 0 : -1 }; return renderButton ? renderButton(buttonProps) : _react2.default.createElement(_Button2.default, buttonProps); } }, { key: 'render', value: function render() { var expanded = this.state.expanded; return _react2.default.createElement( 'div', { className: 'search-button-field-container' }, _react2.default.createElement(_Input2.default, { placeholder: this.props.placeholder, onChange: this.onChange, value: this.state.value, onKeyDown: this.onKeyDown, ref: this.inputRef, tabIndex: expanded ? 0 : -1, className: (0, _classnames2.default)('search-button-field-input', this.state.expanded ? 'expanded' : '', this.state.collapsing ? 'collapsing' : '') }), _react2.default.createElement( 'div', { className: 'search-button-field-cancel-container' }, _react2.default.createElement(_Icon2.default, { ref: this.closeSearchIconRef, category: 'action', icon: 'reject', size: 'x-small', className: (0, _classnames2.default)('search-button-field-cancel', this.state.expanded ? 'expanded' : '', this.state.collapsing ? 'collapsing' : ''), onClick: this.onCancelClick }) ), this.renderSearchButton(), this.props.children ); } }]); return SearchButtonField; }(_react2.default.Component); exports.default = SearchButtonField; SearchButtonField.propTypes = { placeholder: _propTypes2.default.string, onCancel: _propTypes2.default.func, onClosed: _propTypes2.default.func, onChange: _propTypes2.default.func, onEnter: _propTypes2.default.func, onClick: _propTypes2.default.func, onExpand: _propTypes2.default.func, onCollapse: _propTypes2.default.func, searchButtonTitle: _propTypes2.default.string, children: _propTypes2.default.node, value: _propTypes2.default.string, renderButton: _propTypes2.default.func, closeOnEscape: _propTypes2.default.bool }; SearchButtonField.defaultProps = { placeholder: 'Search this feed' }; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/scripts/SearchButtonField.js"],"names":["SearchButtonField","props","state","expanded","value","collapsing","expandField","bind","collapseField","onCancelClick","onChange","onKeyDown","onClick","inputRef","closeSearchIconRef","shouldRaiseOnChangeEventWithoutValue","onCancel","onClosed","event","setState","target","closeOnEscape","onEnter","keyCode","findDOMNode","input","focus","onExpand","setTimeout","onCollapse","ref","closeSearchIcon","searchButtonTitle","renderButton","buttonProps","type","icon","className","title","tabIndex","placeholder","renderSearchButton","children","Component","propTypes","string","func","node","bool","defaultProps"],"mappings":"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","file":"SearchButtonField.js","sourcesContent":["import React from 'react';\nimport ReactDOM from 'react-dom';\nimport Button from './Button';\nimport Input from './Input';\nimport Icon from './Icon';\nimport { registerStyle } from './util';\nimport classnames from 'classnames';\nimport PropTypes from 'prop-types';\n\nexport default class SearchButtonField extends React.Component {\n  constructor(props) {\n    super(props);\n    this.state = {\n      expanded: !!props.value,\n      collapsing: false,\n      value: props.value || '',\n    };\n    this.expandField = this.expandField.bind(this);\n    this.collapseField = this.collapseField.bind(this);\n    this.onCancelClick = this.onCancelClick.bind(this);\n    this.onChange = this.onChange.bind(this);\n    this.onKeyDown = this.onKeyDown.bind(this);\n    this.onClick = this.onClick.bind(this);\n    this.inputRef = this.inputRef.bind(this);\n    this.closeSearchIconRef = this.closeSearchIconRef.bind(this);\n\n    registerStyle('search-button-field', [\n      [\n        '.search-button-field-container',\n        '{ position: relative; display: flex; justify-content: flex-end; width: 100%; }',\n      ],\n      [\n        '.search-button-field-input',\n        '{ position: absolute; top:0; right: 0; opacity: 0; ' +\n        'max-width: 0; transition: max-width 500ms ease-in-out 300ms,' +\n        ' opacity 300ms ease-in-out 300ms; }',\n      ],\n      [\n        '.search-button-field-input.expanded',\n        '{ max-width: 100%; opacity: 1; }',\n      ],\n      [\n        '.search-button-field-input.expanded.collapsing',\n        '{ max-width: 0; opacity: 0;' +\n        'transition: max-width 500ms ease-in-out, opacity 200ms ease-in-out 300ms;}',\n      ],\n      [\n        '.search-button-field-btn',\n        '{ background-color: white; opacity: 1; transition: opacity 300ms ease-in-out; }',\n      ],\n      [\n        '.search-button-field-btn:hover',\n        '{ background-color: #f4f6f9; }',\n      ],\n      [\n        '.search-button-field-btn.expanded',\n        '{ background-color: white; opacity: 0; cursor: default; }',\n      ],\n      [\n        '.search-button-field-btn.expanded.collapsing',\n        '{ opacity: 1; transition: opacity 300ms ease-in-out 700ms; }',\n      ],\n      [\n        '.search-button-field-cancel-container',\n        '{ position: relative; display: flex; justify-content: center;' +\n        'align-items: center; height: 32px; width: 32px; }',\n      ],\n      [\n        '.search-button-field-cancel',\n        '{ background-color: #9faab5; border-radius: 50%;' +\n        'width: 13px; height: 13px; padding: 2px; z-index: 0;' +\n        'opacity: 0; transition: opacity 300ms ease-in-out 300ms; }',\n      ],\n      [\n        '.search-button-field-cancel.expanded',\n        '{ opacity: 1; right: 8px; z-index: 1;}',\n      ],\n      [\n        '.search-button-field-cancel.expanded:hover',\n        '{ background-color: #1589ee; cursor: pointer; }',\n      ],\n      [\n        '.search-button-field-cancel.expanded:hover:active',\n        '{ background-color: #54698d; cursor: pointer; }',\n      ],\n      [\n        '.search-button-field-cancel.expanded.collapsing',\n        '{ opacity: 0; transition: opacity 300ms ease-in-out; }',\n      ],\n    ]);\n  }\n\n  onCancelClick() {\n    const shouldRaiseOnChangeEventWithoutValue = (this.props.onChange && this.state.value);\n    if (shouldRaiseOnChangeEventWithoutValue) {\n      this.props.onChange();\n    }\n    this.collapseField();\n    if (this.props.onCancel) this.props.onCancel();\n    if (this.props.onClosed) this.props.onClosed();\n  }\n\n  onChange(event) {\n    this.setState({ value: event.target.value });\n    if (this.props.onChange) this.props.onChange(event);\n  }\n\n  onKeyDown(event) {\n    const { closeOnEscape, onEnter } = this.props;\n    if (event.keyCode === 13 && onEnter) {\n      onEnter(event);\n    } else if (closeOnEscape && event.keyCode === 27) {\n      this.onCancelClick();\n    }\n  }\n\n  onClick() {\n    this.expandField();\n    if (this.props.onClick) this.props.onClick();\n  }\n\n  expandField() {\n    this.setState({ expanded: true });\n    ReactDOM.findDOMNode(this.input).focus();\n    if (this.props.onExpand) this.props.onExpand();\n  }\n\n  collapseField() {\n    this.setState({ collapsing: true, value: '' });\n    setTimeout(() => {\n      this.setState({ collapsing: false, expanded: false });\n      if (this.props.onCollapse) this.props.onCollapse();\n    }, 500);\n  }\n\n  inputRef(ref) {\n    this.input = ref;\n  }\n\n  closeSearchIconRef(ref) {\n    this.closeSearchIcon = ref;\n  }\n\n  renderSearchButton() {\n    const { expanded } = this.state;\n    const { searchButtonTitle, renderButton } = this.props;\n    const buttonProps = {\n      type: 'icon-border',\n      icon: 'search',\n      className: classnames(\n        'search-button-field-btn',\n        this.state.expanded ? 'expanded' : '',\n        this.state.collapsing ? 'collapsing' : ''\n      ),\n      onClick: this.onClick,\n      title: searchButtonTitle,\n      tabIndex: !expanded ? 0 : -1,\n    };\n\n    return renderButton ? renderButton(buttonProps) : <Button {...buttonProps} />;\n  }\n\n  render() {\n    const { expanded } = this.state;\n    return (\n      <div className='search-button-field-container'>\n        <Input\n          placeholder={this.props.placeholder}\n          onChange={this.onChange}\n          value={this.state.value}\n          onKeyDown={this.onKeyDown}\n          ref={this.inputRef}\n          tabIndex={expanded ? 0 : -1}\n          className={\n            classnames(\n              'search-button-field-input',\n              this.state.expanded ? 'expanded' : '',\n              this.state.collapsing ? 'collapsing' : ''\n            )\n          }\n        />\n        <div className={'search-button-field-cancel-container'}>\n          <Icon\n            ref={this.closeSearchIconRef}\n            category='action'\n            icon='reject'\n            size='x-small'\n            className={\n              classnames(\n                'search-button-field-cancel',\n                this.state.expanded ? 'expanded' : '',\n                this.state.collapsing ? 'collapsing' : ''\n              )\n            }\n            onClick={this.onCancelClick}\n          />\n        </div>\n        {this.renderSearchButton()}\n        { this.props.children }\n      </div>\n    );\n  }\n}\n\nSearchButtonField.propTypes = {\n  placeholder: PropTypes.string,\n  onCancel: PropTypes.func,\n  onClosed: PropTypes.func,\n  onChange: PropTypes.func,\n  onEnter: PropTypes.func,\n  onClick: PropTypes.func,\n  onExpand: PropTypes.func,\n  onCollapse: PropTypes.func,\n  searchButtonTitle: PropTypes.string,\n  children: PropTypes.node,\n  value: PropTypes.string,\n  renderButton: PropTypes.func,\n  closeOnEscape: PropTypes.bool,\n};\n\nSearchButtonField.defaultProps = {\n  placeholder: 'Search this feed',\n};\n"]}