apeman-react-select
Version:
apeman react package for select component.
210 lines (180 loc) • 16 kB
JavaScript
/**
* Style for ApSelect.
* @class ApSelectStyle
*/
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _assign = require('babel-runtime/core-js/object/assign');
var _assign2 = _interopRequireDefault(_assign);
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 _apemanReactStyle = require('apeman-react-style');
var _acolor = require('acolor');
var _acolor2 = _interopRequireDefault(_acolor);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/** @lends ApSelectStyle */
var ApSelectStyle = function (_Component) {
(0, _inherits3.default)(ApSelectStyle, _Component);
function ApSelectStyle() {
(0, _classCallCheck3.default)(this, ApSelectStyle);
return (0, _possibleConstructorReturn3.default)(this, (ApSelectStyle.__proto__ || (0, _getPrototypeOf2.default)(ApSelectStyle)).apply(this, arguments));
}
(0, _createClass3.default)(ApSelectStyle, [{
key: 'render',
value: function render() {
var s = this;
var props = s.props;
var _ApSelectStyle$styleD = ApSelectStyle.styleData(props),
all = _ApSelectStyle$styleD.all,
small = _ApSelectStyle$styleD.small,
medium = _ApSelectStyle$styleD.medium,
large = _ApSelectStyle$styleD.large;
return _react2.default.createElement(
_apemanReactStyle.ApStyle,
{ data: (0, _assign2.default)(all, props.style),
smallMediaData: small,
mediumMediaData: medium,
largeMediaData: large
},
props.children
);
}
}]);
return ApSelectStyle;
}(_react.Component);
(0, _assign2.default)(ApSelectStyle, {
propTypes: {
style: _react.PropTypes.object,
highlightColor: _react.PropTypes.string,
maxWidth: _react.PropTypes.number
},
defaultProps: {
style: {},
maxWidth: _apemanReactStyle.ApStyle.CONTENT_WIDTH,
highlightColor: _apemanReactStyle.ApStyle.DEFAULT_HIGHLIGHT_COLOR,
backgroundColor: _apemanReactStyle.ApStyle.DEFAULT_BACKGROUND_COLOR
},
styleData: function styleData(config) {
var highlightColor = config.highlightColor,
maxWidth = config.maxWidth,
backgroundColor = config.backgroundColor;
var minWidth = 240;
return {
all: {
'.ap-select-wrap': {
position: 'relative',
boxSizing: 'border-box',
display: 'inline-block'
},
'.ap-select,.ap-select-dummy-text': {
opacity: 0,
zIndex: -99,
position: 'absolute',
display: 'block',
width: 1,
height: 1,
overflow: 'hidden'
},
'.ap-select-options-list': {
padding: 0,
margin: 0,
zIndex: 24,
position: 'absolute',
left: 0,
top: 0,
width: '100%',
display: 'none',
boxSizing: 'border-box',
background: 'transparent',
boxShadow: 'none',
border: 'none'
},
'.ap-select-options-list-inner': {
padding: 0,
margin: 0,
background: 'white',
border: '1px solid #F0F0F0',
boxShadow: '2px 2px 4px rgba(0,0,0,0.22)',
borderRadius: '2px',
width: '100%',
minWidth: minWidth + 'px',
overflow: 'auto'
},
'.ap-select-options-list-visible': {
display: 'block'
},
'.ap-select-options-list-item': {
display: 'block',
listStyle: 'none',
padding: 0,
margin: 0
},
'.ap-select-item': {
display: 'block',
padding: '4px 8px',
fontSize: 'smaller',
cursor: 'pointer',
whiteSpace: 'nowrap',
textOverflow: 'ellipsis',
overflow: 'hidden'
},
'.ap-select-item-focused, .ap-select-item-focused:hover, .ap-select-item-focused:active': {
textDecoration: 'none',
backgroundColor: '' + highlightColor,
color: 'white'
},
'.ap-select-item:hover': {
textDecoration: 'none',
backgroundColor: '' + _acolor2.default.alpha(highlightColor, 0.9),
color: 'white'
},
'.ap-select-item:active': {
opacity: '0.9'
},
'.ap-select-label': {
verticalAlign: 'middle',
display: 'inline-flex',
alignItems: 'center',
padding: '4px 2px 4px 8px',
color: 'inherit',
fontSize: 'smaller',
minHeight: '28px',
minWidth: minWidth + 'px',
maxWidth: maxWidth + 'px',
cursor: 'pointer',
background: 'white',
boxSizing: 'border-box',
borderRadius: '2px',
border: '1px solid #CCC',
justifyContent: 'space-between'
},
'.ap-select-label:hover': {
background: '#FAFAFA'
},
'.ap-select-label:active': {
background: '#F0F0F0'
},
'.ap-select-label-text': {
padding: '0 4px'
},
'.ap-select-label-placeholder': {
color: '#CCC'
}
}
};
}
});
exports.default = ApSelectStyle;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ap_select_style.jsx"],"names":["ApSelectStyle","s","props","styleData","all","small","medium","large","style","children","propTypes","object","highlightColor","string","maxWidth","number","defaultProps","CONTENT_WIDTH","DEFAULT_HIGHLIGHT_COLOR","backgroundColor","DEFAULT_BACKGROUND_COLOR","config","minWidth","position","boxSizing","display","opacity","zIndex","width","height","overflow","padding","margin","left","top","background","boxShadow","border","borderRadius","listStyle","fontSize","cursor","whiteSpace","textOverflow","textDecoration","color","alpha","verticalAlign","alignItems","minHeight","justifyContent"],"mappings":"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","file":"ap_select_style.jsx","sourceRoot":"lib","sourcesContent":["/**\n * Style for ApSelect.\n * @class ApSelectStyle\n */\n\n'use strict'\n\nimport React, {Component, PropTypes as types} from 'react'\nimport {ApStyle} from 'apeman-react-style'\nimport acolor from 'acolor'\n\n/** @lends ApSelectStyle */\nclass ApSelectStyle extends Component {\n  render () {\n    const s = this\n    let { props } = s\n\n    let { all, small, medium, large } = ApSelectStyle.styleData(props)\n\n    return (\n      <ApStyle data={ Object.assign(all, props.style) }\n               smallMediaData={ small }\n               mediumMediaData={ medium }\n               largeMediaData={ large }\n      >{ props.children }</ApStyle>\n    )\n  }\n}\n\nObject.assign(ApSelectStyle, {\n  propTypes: {\n    style: types.object,\n    highlightColor: types.string,\n    maxWidth: types.number\n  },\n  defaultProps: {\n    style: {},\n    maxWidth: ApStyle.CONTENT_WIDTH,\n    highlightColor: ApStyle.DEFAULT_HIGHLIGHT_COLOR,\n    backgroundColor: ApStyle.DEFAULT_BACKGROUND_COLOR\n  },\n\n  styleData (config) {\n    let { highlightColor, maxWidth, backgroundColor } = config\n\n    let minWidth = 240\n    return {\n      all: {\n        '.ap-select-wrap': {\n          position: 'relative',\n          boxSizing: 'border-box',\n          display: 'inline-block'\n        },\n        '.ap-select,.ap-select-dummy-text': {\n          opacity: 0,\n          zIndex: -99,\n          position: 'absolute',\n          display: 'block',\n          width: 1,\n          height: 1,\n          overflow: 'hidden'\n        },\n        '.ap-select-options-list': {\n          padding: 0,\n          margin: 0,\n          zIndex: 24,\n          position: 'absolute',\n          left: 0,\n          top: 0,\n          width: '100%',\n          display: 'none',\n          boxSizing: 'border-box',\n          background: 'transparent',\n          boxShadow: 'none',\n          border: 'none'\n        },\n        '.ap-select-options-list-inner': {\n          padding: 0,\n          margin: 0,\n          background: 'white',\n          border: '1px solid #F0F0F0',\n          boxShadow: '2px 2px 4px rgba(0,0,0,0.22)',\n          borderRadius: '2px',\n          width: '100%',\n          minWidth: `${minWidth}px`,\n          overflow: 'auto'\n        },\n        '.ap-select-options-list-visible': {\n          display: 'block'\n        },\n        '.ap-select-options-list-item': {\n          display: 'block',\n          listStyle: 'none',\n          padding: 0,\n          margin: 0\n        },\n        '.ap-select-item': {\n          display: 'block',\n          padding: '4px 8px',\n          fontSize: 'smaller',\n          cursor: 'pointer',\n          whiteSpace: 'nowrap',\n          textOverflow: 'ellipsis',\n          overflow: 'hidden'\n        },\n        '.ap-select-item-focused, .ap-select-item-focused:hover, .ap-select-item-focused:active': {\n          textDecoration: 'none',\n          backgroundColor: `${highlightColor}`,\n          color: 'white'\n        },\n        '.ap-select-item:hover': {\n          textDecoration: 'none',\n          backgroundColor: `${acolor.alpha(highlightColor, 0.9)}`,\n          color: 'white'\n        },\n        '.ap-select-item:active': {\n          opacity: '0.9'\n        },\n        '.ap-select-label': {\n          verticalAlign: 'middle',\n          display: 'inline-flex',\n          alignItems: 'center',\n          padding: '4px 2px 4px 8px',\n          color: 'inherit',\n          fontSize: 'smaller',\n          minHeight: '28px',\n          minWidth: `${minWidth}px`,\n          maxWidth: `${maxWidth}px`,\n          cursor: 'pointer',\n          background: 'white',\n          boxSizing: 'border-box',\n          borderRadius: '2px',\n          border: '1px solid #CCC',\n          justifyContent: 'space-between'\n        },\n        '.ap-select-label:hover': {\n          background: '#FAFAFA'\n        },\n        '.ap-select-label:active': {\n          background: '#F0F0F0'\n        },\n        '.ap-select-label-text': {\n          padding: '0 4px'\n        },\n        '.ap-select-label-placeholder': {\n          color: '#CCC'\n        }\n      }\n    }\n  }\n})\n\nexport default ApSelectStyle\n"]}