focus-components-v3
Version:
Focus web components to build applications (based on Material Design)
256 lines (209 loc) • 25.2 kB
JavaScript
Object.defineProperty(exports, "__esModule", {
value: true
});
var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
var _dec, _class;
var _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _reactDom = require('react-dom');
var _reactDom2 = _interopRequireDefault(_reactDom);
var _material = require('../behaviours/material');
var _material2 = _interopRequireDefault(_material);
var _i18next = require('i18next');
var _i18next2 = _interopRequireDefault(_i18next);
var _mdlSpinner = require('../spinner/mdl-spinner');
var _mdlSpinner2 = _interopRequireDefault(_mdlSpinner);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _defaults(obj, defaults) { var keys = Object.getOwnPropertyNames(defaults); for (var i = 0; i < keys.length; i++) { var key = keys[i]; var value = Object.getOwnPropertyDescriptor(defaults, key); if (value && value.configurable && obj[key] === undefined) { Object.defineProperty(obj, key, value); } } return obj; }
function _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : _defaults(subClass, superClass); }
var BTN_JS = 'mdl-js-button';
var BTN_CLASS = 'mdl-button';
var BUTTON_PRFX = 'mdl-button--';
var RIPPLE_EFFECT = 'mdl-js-ripple-effect';
var propTypes = {
className: _react.PropTypes.string,
color: _react.PropTypes.oneOf([undefined, 'colored', 'primary', 'accent']),
handleOnClick: _react.PropTypes.func, //to remove in V2
hasRipple: _react.PropTypes.bool,
id: _react.PropTypes.string,
isJs: _react.PropTypes.bool,
icon: _react.PropTypes.string,
iconLibrary: _react.PropTypes.oneOf(['material', 'font-awesome', 'font-custom']),
iconPosition: _react.PropTypes.oneOf(['left', 'right']),
label: _react.PropTypes.string,
onClick: _react.PropTypes.func,
processLabel: _react.PropTypes.string,
saving: _react.PropTypes.bool,
shape: _react.PropTypes.oneOf([undefined, 'raised', 'fab', 'icon', 'mini-fab']),
type: _react.PropTypes.oneOf(['submit', 'button'])
};
var defaultProps = {
hasRipple: true,
icon: null,
iconLibrary: 'material',
iconPosition: 'left',
id: '',
isJs: true,
label: '',
shape: 'raised',
type: 'submit'
};
var Button = (_dec = (0, _material2.default)('materialButton', 'MaterialButton'), _dec(_class = function (_Component) {
_inherits(Button, _Component);
function Button() {
_classCallCheck(this, Button);
return _possibleConstructorReturn(this, _Component.apply(this, arguments));
}
/**
* Called when component is mounted.
*/
Button.prototype.componentDidMount = function componentDidMount() {
var hasRipple = this.props.hasRipple;
var refNode = _reactDom2.default.findDOMNode(this.refs['materialButton']);
if (hasRipple) {
componentHandler.upgradeElement(refNode, 'MaterialRipple');
}
};
/**
* Date de composant.
* @return {string} Classe.
*/
Button.prototype._getComponentClassName = function _getComponentClassName() {
var _props = this.props,
shape = _props.shape,
color = _props.color,
hasRipple = _props.hasRipple,
isJs = _props.isJs;
var SHAPE_CLASS = void 0;
switch (shape) {
case 'raised':
SHAPE_CLASS = BUTTON_PRFX + 'raised';
break;
case 'fab':
SHAPE_CLASS = BUTTON_PRFX + 'fab';
break;
case 'icon':
SHAPE_CLASS = BUTTON_PRFX + 'icon';
break;
case 'mini-fab':
SHAPE_CLASS = BUTTON_PRFX + 'mini-fab ' + BUTTON_PRFX + 'fab';
break;
case null:
SHAPE_CLASS = '';
break;
default:
SHAPE_CLASS = null;
break;
}
var COLOR_CLASS = color ? '' + BUTTON_PRFX + color : '';
var JS_CLASS = isJs ? BTN_JS : '';
var RIPPLE_EFFECT_CLASS = hasRipple ? RIPPLE_EFFECT : '';
return BTN_CLASS + ' ' + COLOR_CLASS + ' ' + SHAPE_CLASS + ' ' + JS_CLASS + ' ' + RIPPLE_EFFECT_CLASS;
};
/**
* Render the pressed button.
* @return {Component} - Component button.
*/
Button.prototype.renderPressedButton = function renderPressedButton() {
return _react2.default.createElement(
'button',
null,
'Loading...'
);
};
/**
* Render an icon.
* @return {Component} - Composant icone.
*/
Button.prototype._renderIcon = function _renderIcon() {
var _props2 = this.props,
icon = _props2.icon,
iconLibrary = _props2.iconLibrary;
switch (iconLibrary) {
case 'material':
return _react2.default.createElement(
'i',
{ className: 'material-icons' },
icon
);
case 'font-awesome':
var faCss = 'fa fa-' + icon;
return _react2.default.createElement('i', { className: faCss });
case 'font-custom':
return _react2.default.createElement('span', { className: 'icon-' + icon });
default:
return null;
}
};
/**
* Render the label.
* @return {Component} - Tle button label.
*/
Button.prototype._renderLabel = function _renderLabel() {
var _props3 = this.props,
label = _props3.label,
processLabel = _props3.processLabel,
saving = _props3.saving,
shape = _props3.shape;
if (label && 'fab' !== shape && 'icon' !== shape && 'mini-fab' !== shape && (!saving || !processLabel)) {
return _react2.default.createElement(
'span',
{ 'data-focus': 'button-label' },
_i18next2.default.t(label)
);
} else if (processLabel && 'fab' !== shape && 'icon' !== shape && 'mini-fab' !== shape && saving) {
return _react2.default.createElement(
'span',
{ 'data-focus': 'button-label' },
_i18next2.default.t(processLabel)
);
}
return null;
};
/** inheritedDoc */
Button.prototype.render = function render() {
// attribute doc : https://developer.mozilla.org/fr/docs/Web/HTML/Element/Button
// be careful the way you declare your attribute names : https://developer.mozilla.org/fr/docs/Web/HTML/Element/Button
var _props4 = this.props,
className = _props4.className,
disabled = _props4.disabled,
formNoValidate = _props4.formNoValidate,
handleOnClick = _props4.handleOnClick,
icon = _props4.icon,
iconPosition = _props4.iconPosition,
id = _props4.id,
onClick = _props4.onClick,
type = _props4.type,
label = _props4.label,
style = _props4.style,
hasRipple = _props4.hasRipple,
isJs = _props4.isJs,
iconLibrary = _props4.iconLibrary,
saving = _props4.saving,
shape = _props4.shape,
route = _props4.route,
processLabel = _props4.processLabel,
otherProps = _objectWithoutProperties(_props4, ['className', 'disabled', 'formNoValidate', 'handleOnClick', 'icon', 'iconPosition', 'id', 'onClick', 'type', 'label', 'style', 'hasRipple', 'isJs', 'iconLibrary', 'saving', 'shape', 'route', 'processLabel']);
var otherInputProps = _extends({ formNoValidate: formNoValidate, onClick: handleOnClick ? handleOnClick : onClick, style: style, type: type }, otherProps); //on click for legacy. Remove handleOnClick in v2
var renderedClassName = ((className ? className : '') + ' ' + this._getComponentClassName.call(this)).trim();
var showSpinner = saving && (shape === 'fab' || shape === 'mini-fab' || shape === 'icon') || !saving ? false : true;
return _react2.default.createElement(
'button',
_extends({ alt: _i18next2.default.t(label), className: renderedClassName, 'data-focus': 'button-action', 'data-icon': icon && iconPosition || "none", 'data-saving': saving, disabled: disabled || saving, id: id, title: _i18next2.default.t(label) }, otherInputProps, { ref: 'materialButton' }),
icon && this._renderIcon.call(this),
this._renderLabel.call(this),
showSpinner && _react2.default.createElement(_mdlSpinner2.default, { className: 'double-action-button-spinner' })
);
};
return Button;
}(_react.Component)) || _class);
Button.displayName = 'Button';
Button.defaultProps = defaultProps;
Button.propTypes = propTypes;
exports.default = Button;
module.exports = exports['default'];
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["fr-FR.js"],"names":["BTN_JS","BTN_CLASS","BUTTON_PRFX","RIPPLE_EFFECT","propTypes","className","string","color","oneOf","undefined","handleOnClick","func","hasRipple","bool","id","isJs","icon","iconLibrary","iconPosition","label","onClick","processLabel","saving","shape","type","defaultProps","Button","componentDidMount","props","refNode","findDOMNode","refs","componentHandler","upgradeElement","_getComponentClassName","SHAPE_CLASS","COLOR_CLASS","JS_CLASS","RIPPLE_EFFECT_CLASS","renderPressedButton","_renderIcon","faCss","_renderLabel","t","render","disabled","formNoValidate","style","route","otherProps","otherInputProps","renderedClassName","trim","showSpinner","displayName"],"mappings":"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","file":"fr-FR.js","sourcesContent":["import React, {Component, PropTypes} from 'react';\r\nimport ReactDOM from 'react-dom';\r\nimport MDBehaviour from '../behaviours/material';\r\nimport i18next from 'i18next';\r\nimport Spinner from '../spinner/mdl-spinner';\r\n\r\nconst BTN_JS = 'mdl-js-button';\r\nconst BTN_CLASS = 'mdl-button';\r\nconst BUTTON_PRFX = 'mdl-button--';\r\nconst RIPPLE_EFFECT = 'mdl-js-ripple-effect';\r\n\r\nconst propTypes = {\r\n    className: PropTypes.string,\r\n    color: PropTypes.oneOf([undefined,'colored', 'primary', 'accent']),\r\n    handleOnClick: PropTypes.func, //to remove in V2\r\n    hasRipple: PropTypes.bool,\r\n    id: PropTypes.string,\r\n    isJs: PropTypes.bool,\r\n    icon: PropTypes.string,\r\n    iconLibrary: PropTypes.oneOf(['material', 'font-awesome', 'font-custom']),\r\n    iconPosition: PropTypes.oneOf(['left', 'right']),\r\n    label: PropTypes.string,\r\n    onClick: PropTypes.func,\r\n    processLabel: PropTypes.string,\r\n    saving: PropTypes.bool,\r\n    shape: PropTypes.oneOf([undefined, 'raised', 'fab', 'icon', 'mini-fab']),\r\n    type: PropTypes.oneOf(['submit', 'button'])\r\n}\r\n\r\nconst defaultProps = {\r\n    hasRipple: true,\r\n    icon: null,\r\n    iconLibrary: 'material',\r\n    iconPosition: 'left',\r\n    id: '',\r\n    isJs: true,\r\n    label: '',\r\n    shape: 'raised',\r\n    type: 'submit'\r\n}\r\n\r\n@MDBehaviour('materialButton', 'MaterialButton')\r\nclass Button extends Component {\r\n\r\n    /**\r\n    * Called when component is mounted.\r\n    */\r\n    componentDidMount() {\r\n        const {hasRipple} = this.props;\r\n        const refNode = ReactDOM.findDOMNode(this.refs['materialButton']);\r\n        if (hasRipple) {\r\n            componentHandler.upgradeElement(refNode, 'MaterialRipple');\r\n        }\r\n    }\r\n\r\n    /**\r\n    * Date de composant.\r\n    * @return {string} Classe.\r\n    */\r\n    _getComponentClassName() {\r\n        const {shape, color, hasRipple, isJs} = this.props;\r\n        let SHAPE_CLASS;\r\n        switch (shape) {\r\n            case 'raised':\r\n            SHAPE_CLASS = `${BUTTON_PRFX}raised`;\r\n            break;\r\n            case 'fab':\r\n            SHAPE_CLASS = `${BUTTON_PRFX}fab`;\r\n            break;\r\n            case 'icon':\r\n            SHAPE_CLASS = `${BUTTON_PRFX}icon`;\r\n            break;\r\n            case 'mini-fab':\r\n            SHAPE_CLASS = `${BUTTON_PRFX}mini-fab ${BUTTON_PRFX}fab`;\r\n            break;\r\n            case null:\r\n            SHAPE_CLASS = '';\r\n            break;\r\n            default:\r\n            SHAPE_CLASS = null;\r\n            break;\r\n        }\r\n        const COLOR_CLASS = color ? `${BUTTON_PRFX}${color}` : '';\r\n        const JS_CLASS = isJs ? BTN_JS : '';\r\n        const RIPPLE_EFFECT_CLASS = hasRipple ? RIPPLE_EFFECT : '';\r\n        return `${BTN_CLASS} ${COLOR_CLASS} ${SHAPE_CLASS} ${JS_CLASS} ${RIPPLE_EFFECT_CLASS}`;\r\n    }\r\n\r\n    /**\r\n    * Render the pressed button.\r\n    * @return {Component} - Component button.\r\n    */\r\n    renderPressedButton() {\r\n        return (<button>Loading...</button>);\r\n    }\r\n\r\n    /**\r\n    * Render an icon.\r\n    * @return {Component} - Composant icone.\r\n    */\r\n    _renderIcon() {\r\n        const {icon, iconLibrary} = this.props;\r\n        switch (iconLibrary) {\r\n            case 'material':\r\n                return <i className='material-icons'>{icon}</i>;\r\n            case 'font-awesome':\r\n                const faCss = `fa fa-${icon}`;\r\n                return <i className={faCss}></i>;\r\n            case 'font-custom':\r\n                return <span className={`icon-${icon}`}></span>;\r\n            default:\r\n                return null;\r\n        }\r\n    };\r\n\r\n    /**\r\n    * Render the label.\r\n    * @return {Component} - Tle button label.\r\n    */\r\n    _renderLabel() {\r\n        const {label,processLabel, saving, shape} = this.props;\r\n\r\n        if (label && 'fab' !== shape && 'icon' !== shape && 'mini-fab' !== shape && (!saving || !processLabel)) {\r\n            return <span data-focus='button-label'>{i18next.t(label)}</span>;\r\n        } else if (processLabel && 'fab' !== shape && 'icon' !== shape && 'mini-fab' !== shape && saving) {\r\n            return <span data-focus='button-label'>{i18next.t(processLabel)}</span>\r\n        }\r\n        return null;\r\n    };\r\n\r\n    /** inheritedDoc */\r\n    render() {\r\n        // attribute doc : https://developer.mozilla.org/fr/docs/Web/HTML/Element/Button\r\n        // be careful the way you declare your attribute names : https://developer.mozilla.org/fr/docs/Web/HTML/Element/Button\r\n        const {className, disabled, formNoValidate, handleOnClick, icon, iconPosition, id, onClick, type, label, style, hasRipple, isJs, iconLibrary, saving, shape, route, processLabel, ...otherProps } = this.props;\r\n        const otherInputProps = { formNoValidate, onClick: handleOnClick ? handleOnClick : onClick, style, type, ...otherProps}; //on click for legacy. Remove handleOnClick in v2\r\n        const renderedClassName = `${className ? className : ''} ${::this._getComponentClassName()}`.trim();\r\n        const showSpinner = (saving && (shape === 'fab' || shape === 'mini-fab' || shape === 'icon')) || !saving ? false : true;\r\n        return (\r\n            <button alt={i18next.t(label)} className={renderedClassName} data-focus='button-action' data-icon={icon && iconPosition || \"none\"} data-saving={saving} disabled={disabled || saving} id={id} title={i18next.t(label)} {...otherInputProps} ref='materialButton'>\r\n                {icon && ::this._renderIcon()}\r\n                {::this._renderLabel()}\r\n                {showSpinner && <Spinner className='double-action-button-spinner' />}\r\n            </button>\r\n        );\r\n    }\r\n}\r\n\r\nButton.displayName = 'Button'\r\nButton.defaultProps = defaultProps;\r\nButton.propTypes = propTypes;\r\n\r\nexport default Button;\r\n"]}
;