react-lightning-design-components
Version:
Salesforce Lightning Design System components built with React 16
227 lines (185 loc) • 24.8 kB
JavaScript
'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"]}