@hipay/hipay-material-ui 1.0.0-beta.7 → 1.0.0-beta.8

Sign up to get free protection for your applications and to get access to all the features.
Files changed (41) hide show
  1. package/HiBreadcrumb/HiBreadcrumb.js +143 -0
  2. package/HiBreadcrumb/HiStep.js +123 -0
  3. package/HiBreadcrumb/HiStepConnector.js +142 -0
  4. package/HiBreadcrumb/HiStepIcon.js +134 -0
  5. package/HiBreadcrumb/HiStepLabel.js +182 -0
  6. package/HiBreadcrumb/HiStepper.js +125 -0
  7. package/HiBreadcrumb/index.js +16 -0
  8. package/HiDatePicker/HiDateRangeSelector.js +1 -1
  9. package/HiForm/HiFormControl.js +19 -27
  10. package/HiForm/HiSearchField.js +1 -1
  11. package/HiPins/HiPins.js +0 -1
  12. package/HiSelectableList/HiSelectableListItem.js +22 -9
  13. package/HiTable/BodyCells/CellLayout.js +5 -1
  14. package/HiTable/BodyCells/CellStatus.js +5 -1
  15. package/HiTable/BodyCells/CellText.js +2 -1
  16. package/HiTable/ColumnFilter.js +5 -1
  17. package/HiTable/HiTable.js +15 -8
  18. package/HiTable/HiTableBody.js +13 -3
  19. package/HiTable/OrderColumns.js +6 -2
  20. package/es/HiBreadcrumb/HiBreadcrumb.js +73 -0
  21. package/es/HiBreadcrumb/HiStep.js +93 -0
  22. package/es/HiBreadcrumb/HiStepConnector.js +83 -0
  23. package/es/HiBreadcrumb/HiStepIcon.js +81 -0
  24. package/es/HiBreadcrumb/HiStepLabel.js +154 -0
  25. package/es/HiBreadcrumb/HiStepper.js +62 -0
  26. package/es/HiBreadcrumb/index.js +1 -0
  27. package/es/HiDatePicker/HiDateRangeSelector.js +1 -1
  28. package/es/HiForm/HiFormControl.js +15 -15
  29. package/es/HiForm/HiSearchField.js +1 -1
  30. package/es/HiPins/HiPins.js +0 -1
  31. package/es/HiSelectableList/HiSelectableListItem.js +21 -9
  32. package/es/HiTable/BodyCells/CellLayout.js +5 -1
  33. package/es/HiTable/BodyCells/CellStatus.js +5 -1
  34. package/es/HiTable/BodyCells/CellText.js +2 -1
  35. package/es/HiTable/ColumnFilter.js +5 -1
  36. package/es/HiTable/HiTable.js +15 -8
  37. package/es/HiTable/HiTableBody.js +13 -3
  38. package/es/HiTable/OrderColumns.js +6 -2
  39. package/package.json +1 -1
  40. package/umd/hipay-material-ui.development.js +104 -66
  41. package/umd/hipay-material-ui.production.min.js +2 -2
@@ -17037,6 +17037,21 @@ var HiFormControl = function (_React$PureComponent) {
17037
17037
 
17038
17038
  var _this = _possibleConstructorReturn(this, (HiFormControl.__proto__ || Object.getPrototypeOf(HiFormControl)).call(this, props));
17039
17039
 
17040
+ _this.handleFocus = function (value) {
17041
+ return function () {
17042
+ _this.setState({ focused: value });
17043
+ if (value === false && _this.state.hovered) {
17044
+ _this.setState({ hovered: false });
17045
+ }
17046
+ };
17047
+ };
17048
+
17049
+ _this.handleHover = function (value) {
17050
+ return function () {
17051
+ _this.setState({ hovered: value });
17052
+ };
17053
+ };
17054
+
17040
17055
  _this.state = {
17041
17056
  helperOpen: false,
17042
17057
  focused: false,
@@ -17059,24 +17074,9 @@ var HiFormControl = function (_React$PureComponent) {
17059
17074
  event.preventDefault();
17060
17075
  }
17061
17076
  }
17062
- }, {
17063
- key: 'handleFocus',
17064
- value: function handleFocus(value) {
17065
- this.setState({ focused: value });
17066
- if (value === false && this.state.hovered) {
17067
- this.setState({ hovered: false });
17068
- }
17069
- }
17070
- }, {
17071
- key: 'handleHover',
17072
- value: function handleHover(value) {
17073
- this.setState({ hovered: value });
17074
- }
17075
17077
  }, {
17076
17078
  key: 'render',
17077
17079
  value: function render() {
17078
- var _this2 = this;
17079
-
17080
17080
  var _props = this.props,
17081
17081
  children = _props.children,
17082
17082
  classes = _props.classes,
@@ -17155,18 +17155,10 @@ var HiFormControl = function (_React$PureComponent) {
17155
17155
  _react2.default.createElement(
17156
17156
  'div',
17157
17157
  {
17158
- onMouseEnter: function onMouseEnter() {
17159
- return _this2.handleHover(true);
17160
- },
17161
- onMouseLeave: function onMouseLeave() {
17162
- return _this2.handleHover(false);
17163
- },
17164
- onFocus: function onFocus() {
17165
- return _this2.handleFocus(true);
17166
- },
17167
- onBlur: function onBlur() {
17168
- return _this2.handleFocus(false);
17169
- }
17158
+ onMouseEnter: this.handleHover(true),
17159
+ onMouseLeave: this.handleHover(false),
17160
+ onFocus: this.handleFocus(true),
17161
+ onBlur: this.handleFocus(false)
17170
17162
  },
17171
17163
  children
17172
17164
  ),
@@ -17281,7 +17273,7 @@ HiFormControl.defaultProps = {
17281
17273
  maxLength: 280
17282
17274
  };
17283
17275
  exports.default = (0, _withStyles2.default)(styles, { name: 'HmuiHiFormControl' })(HiFormControl);
17284
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["src/HiForm/HiFormControl.js"],"names":["styles","helperTextClassName","color","theme","palette","neutral","normal","fontSize","textAlign","marginTop","errorIcon","width","height","negative","position","right","cursor","top","errorDiv","typography","h5","backgroundColor","padding","verticalAlign","borderRadius","marginBottom","fontWeight","fontWeightRegular","arrowDown","borderLeft","borderRight","borderTop","bottom","errorDivArrowDown","borderTopColor","helperIcon","helperIconActive","business","primary","helperDiv","dark","boxShadow","lineHeight","helperDivArrowDown","HiFormControl","props","state","helperOpen","focused","hovered","handleHelperClick","bind","handleFocus","handleHover","event","setState","prevState","preventDefault","value","children","classes","className","disabled","error","errorText","id","label","InputLabelProps","helperText","FormHelperTextProps","fullWidth","required","multiline","rootRef","maxLength","nbChars","others","__html","PureComponent","propTypes","node","object","string","bool","number","defaultProps","name"],"mappings":"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","file":"HiFormControl.js","sourceRoot":"/home/mfazio/dev/projects/hipay-material-ui","sourcesContent":["// @inheritedComponent FormControl\n\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport classNames from 'classnames';\nimport { Alert, Information } from 'mdi-material-ui';\nimport { FormControl, FormHelperText } from 'material-ui/Form';\nimport withStyles from '../styles/withStyles';\nimport HiFormLabel from './HiFormLabel';\nimport {escapeHTML} from \"../utils/hiHelpers\";\n\nexport const styles = theme => ({\n    helperTextClassName: {\n        color: theme.palette.neutral.normal,\n        fontSize: 11,\n        textAlign: 'right',\n        marginTop: 2,\n    },\n    errorIcon: {\n        width: 19,\n        height: 19,\n        color: theme.palette.negative.normal,\n        position: 'absolute',\n        right: 8,\n        cursor: 'pointer',\n        top: '-2px',\n    },\n    errorDiv: {\n        ...theme.typography.h5,\n        backgroundColor: theme.palette.negative.normal,\n        color: '#FFFFFF',\n        padding: '16px 8px',\n        verticalAlign: 'middle',\n        borderRadius: 2,\n        position: 'relative',\n        marginBottom: 5,\n        fontWeight: theme.typography.fontWeightRegular,\n    },\n    arrowDown: {\n        width: 0,\n        height: 0,\n        borderLeft: '4px solid transparent',\n        borderRight: '4px solid transparent',\n        borderTop: '4px solid #000',\n        position: 'absolute',\n        bottom: -4,\n        right: 14,\n    },\n    errorDivArrowDown: {\n        borderTopColor: theme.palette.negative.normal,\n    },\n    helperIcon: {\n        width: 19,\n        height: 19,\n        color: theme.palette.neutral.normal,\n        position: 'absolute',\n        right: 8,\n        cursor: 'pointer',\n        top: '-2px',\n    },\n    helperIconActive: {\n        color: theme.palette.business.primary.normal,\n    },\n    helperDiv: {\n        ...theme.typography.h5,\n        width: '100%',\n        backgroundColor: '#ffffff',\n        color: theme.palette.neutral.dark,\n        padding: '16px 8px',\n        borderRadius: 2,\n        position: 'relative',\n        marginBottom: 5,\n        fontWeight: theme.typography.fontWeightRegular,\n        boxShadow: '0px 1px 7px rgba(0, 0, 0, 0.16)',\n        lineHeight: 1.5,\n    },\n    helperDivArrowDown: {\n        borderTopColor: '#ffffff',\n    },\n});\n\n/**\n * Champs input pour formulaire\n */\nclass HiFormControl extends React.PureComponent {\n    static propTypes = {\n        /**\n         * Contenu du form control\n         */\n        children: PropTypes.node,\n        /**\n         * Useful to extend the style applied to components.\n         */\n        classes: PropTypes.object,\n        /**\n         * Classes CSS appliquées\n         */\n        className: PropTypes.string,\n        /**\n         * Si `true`, l'input sera inactif.\n         */\n        disabled: PropTypes.bool,\n        /**\n         * Si `true`, le champs sera en erreur.\n         */\n        error: PropTypes.bool,\n        /**\n         * Texte de l'erreur\n         */\n        errorText: PropTypes.string,\n        /**\n         * Propriétés appliquées au composant FormHelperText\n         */\n        FormHelperTextProps: PropTypes.object,\n        /**\n         * Si `true`, le chamsp prendra toute la largeur.\n         */\n        fullWidth: PropTypes.bool,\n        /**\n         * Si \"true\", le texte d'aide s'affichera seulement au clic sur l'icône \"Information\"\n         */\n        helperIcon: PropTypes.bool,\n        /**\n         * Texte de l'aide\n         */\n        helperText: PropTypes.string,\n        /**\n         * id de l'élément input\n         */\n        id: PropTypes.string,\n        /**\n         * Propriétés appliquées au composant InputLabel\n         */\n        InputLabelProps: PropTypes.object,\n        /**\n         * Label du champs\n         */\n        label: PropTypes.string,\n        /**\n         * Nombre de caractères max pour un text area\n         * Valable uniquement si l'option multiline est à true\n         */\n        maxLength: PropTypes.number,\n        /**\n         * Si `true`, le champs input sera un textarea\n         */\n        multiline: PropTypes.bool,\n        /**\n         * Nombre de caractères autorisés pour les textArea\n         */\n        nbChars: PropTypes.number,\n        /**\n         * true si champs obligatoire\n         */\n        required: PropTypes.bool,\n        /**\n         * Passé à la prop ref du composant FormControl\n         */\n        rootRef: PropTypes.string,\n    };\n\n    static defaultProps = {\n        fullWidth: true,\n        required: true,\n        disabled: false,\n        error: false,\n        errorText: '',\n        helperText: '',\n        helperIcon: false,\n        multiline: false,\n        nbChars: 0,\n        maxLength: 280,\n    };\n\n    constructor(props) {\n        super(props);\n\n        this.state = {\n            helperOpen: false,\n            focused: false,\n            hovered: false,\n        };\n\n        this.handleHelperClick = this.handleHelperClick.bind(this);\n        this.handleFocus = this.handleFocus.bind(this);\n        this.handleHover = this.handleHover.bind(this);\n    }\n\n    handleHelperClick(event) {\n        this.setState(prevState => ({ helperOpen: !prevState.helperOpen }));\n        if (event) {\n            event.preventDefault();\n        }\n    }\n\n    handleFocus(value) {\n        this.setState({ focused: value });\n        if (value === false && this.state.hovered) {\n            this.setState({ hovered: false });\n        }\n    }\n\n    handleHover(value) {\n        this.setState({ hovered: value });\n    }\n\n    render() {\n        const {\n            children,\n            classes,\n            className,\n            disabled,\n            error,\n            errorText,\n            id,\n            label,\n            InputLabelProps,\n            helperText,\n            helperIcon,\n            FormHelperTextProps,\n            fullWidth,\n            required,\n            multiline,\n            rootRef,\n            maxLength,\n            nbChars,\n            ...others\n        } = this.props;\n\n        const { helperOpen, focused, hovered } = this.state;\n\n        return (\n            <FormControl\n                fullWidth={fullWidth}\n                className={className}\n                error={error}\n                ref={rootRef}\n                {...others}\n            >\n                {!disabled &&\n                    error &&\n                    errorText &&\n                    helperOpen && (\n                        <div className={classes.errorDiv}>\n                            <div\n                                className={classNames(classes.arrowDown, classes.errorDivArrowDown)}\n                            />\n                            {errorText}\n                        </div>\n                    )}\n\n                {!disabled &&\n                    helperIcon &&\n                    helperText &&\n                    !error &&\n                    helperOpen && (\n                        <div\n                            className={classes.helperDiv}\n                        >\n                            <div\n                                className={classNames(\n                                    classes.arrowDown,\n                                    classes.helperDivArrowDown,\n                                )}\n\n                            />\n                            <span\n                                dangerouslySetInnerHTML={{\n                                    __html: escapeHTML(helperText),\n                                }} />\n                        </div>\n                    )}\n\n                {label && (\n                    <HiFormLabel\n                        htmlFor={id}\n                        label={label}\n                        required={required}\n                        disabled={disabled}\n                        focused={!disabled && (focused || hovered)}\n                        {...InputLabelProps}\n                    >\n                        {!disabled &&\n                            error && (\n                                <Alert\n                                    className={classes.errorIcon}\n                                    onClick={this.handleHelperClick}\n                                />\n                            )}\n                        {!disabled &&\n                            helperIcon &&\n                            helperText &&\n                            !error && (\n                                <Information\n                                    className={classNames(classes.helperIcon, {\n                                        [classes.helperIconActive]: helperOpen,\n                                    })}\n                                    onClick={this.handleHelperClick}\n                                />\n                            )}\n                    </HiFormLabel>\n                )}\n                <div\n                    onMouseEnter={() => this.handleHover(true)}\n                    onMouseLeave={() => this.handleHover(false)}\n                    onFocus={() => this.handleFocus(true)}\n                    onBlur={() => this.handleFocus(false)}\n                >\n                    {children}\n                </div>\n                {!multiline &&\n                    helperText &&\n                    !helperIcon && (\n                        <FormHelperText\n                            className={classes.helperTextClassName}\n                            {...FormHelperTextProps}\n                        >\n                            {helperText}\n                        </FormHelperText>\n                    )}\n\n                {multiline && (\n                    <FormHelperText\n                        className={classes.helperTextClassName}\n                        {...FormHelperTextProps}\n                    >\n                        {nbChars}/{maxLength}\n                    </FormHelperText>\n                )}\n            </FormControl>\n        );\n    }\n}\n\nexport default withStyles(styles, { name: 'HmuiHiFormControl' })(HiFormControl);\n"]}
17276
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["src/HiForm/HiFormControl.js"],"names":["styles","helperTextClassName","color","theme","palette","neutral","normal","fontSize","textAlign","marginTop","errorIcon","width","height","negative","position","right","cursor","top","errorDiv","typography","h5","backgroundColor","padding","verticalAlign","borderRadius","marginBottom","fontWeight","fontWeightRegular","arrowDown","borderLeft","borderRight","borderTop","bottom","errorDivArrowDown","borderTopColor","helperIcon","helperIconActive","business","primary","helperDiv","dark","boxShadow","lineHeight","helperDivArrowDown","HiFormControl","props","handleFocus","setState","focused","value","state","hovered","handleHover","helperOpen","handleHelperClick","bind","event","prevState","preventDefault","children","classes","className","disabled","error","errorText","id","label","InputLabelProps","helperText","FormHelperTextProps","fullWidth","required","multiline","rootRef","maxLength","nbChars","others","__html","PureComponent","propTypes","node","object","string","bool","number","defaultProps","name"],"mappings":"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","file":"HiFormControl.js","sourceRoot":"/home/mfazio/dev/projects/hipay-material-ui","sourcesContent":["// @inheritedComponent FormControl\n\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport classNames from 'classnames';\nimport { Alert, Information } from 'mdi-material-ui';\nimport { FormControl, FormHelperText } from 'material-ui/Form';\nimport withStyles from '../styles/withStyles';\nimport HiFormLabel from './HiFormLabel';\nimport {escapeHTML} from \"../utils/hiHelpers\";\n\nexport const styles = theme => ({\n    helperTextClassName: {\n        color: theme.palette.neutral.normal,\n        fontSize: 11,\n        textAlign: 'right',\n        marginTop: 2,\n    },\n    errorIcon: {\n        width: 19,\n        height: 19,\n        color: theme.palette.negative.normal,\n        position: 'absolute',\n        right: 8,\n        cursor: 'pointer',\n        top: '-2px',\n    },\n    errorDiv: {\n        ...theme.typography.h5,\n        backgroundColor: theme.palette.negative.normal,\n        color: '#FFFFFF',\n        padding: '16px 8px',\n        verticalAlign: 'middle',\n        borderRadius: 2,\n        position: 'relative',\n        marginBottom: 5,\n        fontWeight: theme.typography.fontWeightRegular,\n    },\n    arrowDown: {\n        width: 0,\n        height: 0,\n        borderLeft: '4px solid transparent',\n        borderRight: '4px solid transparent',\n        borderTop: '4px solid #000',\n        position: 'absolute',\n        bottom: -4,\n        right: 14,\n    },\n    errorDivArrowDown: {\n        borderTopColor: theme.palette.negative.normal,\n    },\n    helperIcon: {\n        width: 19,\n        height: 19,\n        color: theme.palette.neutral.normal,\n        position: 'absolute',\n        right: 8,\n        cursor: 'pointer',\n        top: '-2px',\n    },\n    helperIconActive: {\n        color: theme.palette.business.primary.normal,\n    },\n    helperDiv: {\n        ...theme.typography.h5,\n        width: '100%',\n        backgroundColor: '#ffffff',\n        color: theme.palette.neutral.dark,\n        padding: '16px 8px',\n        borderRadius: 2,\n        position: 'relative',\n        marginBottom: 5,\n        fontWeight: theme.typography.fontWeightRegular,\n        boxShadow: '0px 1px 7px rgba(0, 0, 0, 0.16)',\n        lineHeight: 1.5,\n    },\n    helperDivArrowDown: {\n        borderTopColor: '#ffffff',\n    },\n});\n\n/**\n * Champs input pour formulaire\n */\nclass HiFormControl extends React.PureComponent {\n    static propTypes = {\n        /**\n         * Contenu du form control\n         */\n        children: PropTypes.node,\n        /**\n         * Useful to extend the style applied to components.\n         */\n        classes: PropTypes.object,\n        /**\n         * Classes CSS appliquées\n         */\n        className: PropTypes.string,\n        /**\n         * Si `true`, l'input sera inactif.\n         */\n        disabled: PropTypes.bool,\n        /**\n         * Si `true`, le champs sera en erreur.\n         */\n        error: PropTypes.bool,\n        /**\n         * Texte de l'erreur\n         */\n        errorText: PropTypes.string,\n        /**\n         * Propriétés appliquées au composant FormHelperText\n         */\n        FormHelperTextProps: PropTypes.object,\n        /**\n         * Si `true`, le chamsp prendra toute la largeur.\n         */\n        fullWidth: PropTypes.bool,\n        /**\n         * Si \"true\", le texte d'aide s'affichera seulement au clic sur l'icône \"Information\"\n         */\n        helperIcon: PropTypes.bool,\n        /**\n         * Texte de l'aide\n         */\n        helperText: PropTypes.string,\n        /**\n         * id de l'élément input\n         */\n        id: PropTypes.string,\n        /**\n         * Propriétés appliquées au composant InputLabel\n         */\n        InputLabelProps: PropTypes.object,\n        /**\n         * Label du champs\n         */\n        label: PropTypes.string,\n        /**\n         * Nombre de caractères max pour un text area\n         * Valable uniquement si l'option multiline est à true\n         */\n        maxLength: PropTypes.number,\n        /**\n         * Si `true`, le champs input sera un textarea\n         */\n        multiline: PropTypes.bool,\n        /**\n         * Nombre de caractères autorisés pour les textArea\n         */\n        nbChars: PropTypes.number,\n        /**\n         * true si champs obligatoire\n         */\n        required: PropTypes.bool,\n        /**\n         * Passé à la prop ref du composant FormControl\n         */\n        rootRef: PropTypes.string,\n    };\n\n    static defaultProps = {\n        fullWidth: true,\n        required: true,\n        disabled: false,\n        error: false,\n        errorText: '',\n        helperText: '',\n        helperIcon: false,\n        multiline: false,\n        nbChars: 0,\n        maxLength: 280,\n    };\n\n    constructor(props) {\n        super(props);\n\n        this.state = {\n            helperOpen: false,\n            focused: false,\n            hovered: false,\n        };\n\n        this.handleHelperClick = this.handleHelperClick.bind(this);\n        this.handleFocus = this.handleFocus.bind(this);\n        this.handleHover = this.handleHover.bind(this);\n    }\n\n    handleHelperClick(event) {\n        this.setState(prevState => ({ helperOpen: !prevState.helperOpen }));\n        if (event) {\n            event.preventDefault();\n        }\n    }\n\n    handleFocus = value => () => {\n        this.setState({ focused: value });\n        if (value === false && this.state.hovered) {\n            this.setState({ hovered: false });\n        }\n    };\n\n    handleHover = value => () => {\n        this.setState({ hovered: value });\n    };\n\n    render() {\n        const {\n            children,\n            classes,\n            className,\n            disabled,\n            error,\n            errorText,\n            id,\n            label,\n            InputLabelProps,\n            helperText,\n            helperIcon,\n            FormHelperTextProps,\n            fullWidth,\n            required,\n            multiline,\n            rootRef,\n            maxLength,\n            nbChars,\n            ...others\n        } = this.props;\n\n        const { helperOpen, focused, hovered } = this.state;\n\n        return (\n            <FormControl\n                fullWidth={fullWidth}\n                className={className}\n                error={error}\n                ref={rootRef}\n                {...others}\n            >\n                {!disabled &&\n                    error &&\n                    errorText &&\n                    helperOpen && (\n                        <div className={classes.errorDiv}>\n                            <div\n                                className={classNames(classes.arrowDown, classes.errorDivArrowDown)}\n                            />\n                            {errorText}\n                        </div>\n                    )}\n\n                {!disabled &&\n                    helperIcon &&\n                    helperText &&\n                    !error &&\n                    helperOpen && (\n                        <div\n                            className={classes.helperDiv}\n                        >\n                            <div\n                                className={classNames(\n                                    classes.arrowDown,\n                                    classes.helperDivArrowDown,\n                                )}\n\n                            />\n                            <span\n                                dangerouslySetInnerHTML={{\n                                    __html: escapeHTML(helperText),\n                                }} />\n                        </div>\n                    )}\n\n                {label && (\n                    <HiFormLabel\n                        htmlFor={id}\n                        label={label}\n                        required={required}\n                        disabled={disabled}\n                        focused={!disabled && (focused || hovered)}\n                        {...InputLabelProps}\n                    >\n                        {!disabled &&\n                            error && (\n                                <Alert\n                                    className={classes.errorIcon}\n                                    onClick={this.handleHelperClick}\n                                />\n                            )}\n                        {!disabled &&\n                            helperIcon &&\n                            helperText &&\n                            !error && (\n                                <Information\n                                    className={classNames(classes.helperIcon, {\n                                        [classes.helperIconActive]: helperOpen,\n                                    })}\n                                    onClick={this.handleHelperClick}\n                                />\n                            )}\n                    </HiFormLabel>\n                )}\n                <div\n                    onMouseEnter={this.handleHover(true)}\n                    onMouseLeave={this.handleHover(false)}\n                    onFocus={this.handleFocus(true)}\n                    onBlur={this.handleFocus(false)}\n                >\n                    {children}\n                </div>\n                {!multiline &&\n                    helperText &&\n                    !helperIcon && (\n                        <FormHelperText\n                            className={classes.helperTextClassName}\n                            {...FormHelperTextProps}\n                        >\n                            {helperText}\n                        </FormHelperText>\n                    )}\n\n                {multiline && (\n                    <FormHelperText\n                        className={classes.helperTextClassName}\n                        {...FormHelperTextProps}\n                    >\n                        {nbChars}/{maxLength}\n                    </FormHelperText>\n                )}\n            </FormControl>\n        );\n    }\n}\n\nexport default withStyles(styles, { name: 'HmuiHiFormControl' })(HiFormControl);\n"]}
17285
17277
 
17286
17278
  /***/ }),
17287
17279
  /* 119 */
@@ -30691,7 +30683,8 @@ var HiTable = function (_React$Component) {
30691
30683
  translations = _props.translations,
30692
30684
  view = _props.view,
30693
30685
  groupBy = _props.groupBy,
30694
- lookupColumns = _props.lookupColumns;
30686
+ lookupColumns = _props.lookupColumns,
30687
+ loading = _props.loading;
30695
30688
  var _state = this.state,
30696
30689
  dateUpdate = _state.dateUpdate,
30697
30690
  isScrollToBottom = _state.isScrollToBottom,
@@ -30766,7 +30759,8 @@ var HiTable = function (_React$Component) {
30766
30759
  groupBy: groupBy,
30767
30760
  onClickNext: this.handleNextStickyRow,
30768
30761
  groupByIds: groupByIds,
30769
- lookupColumns: lookupColumns
30762
+ lookupColumns: lookupColumns,
30763
+ loading: loading
30770
30764
  }),
30771
30765
  infiniteScroll && _react2.default.createElement(_HiTableFooterScroll2.default, {
30772
30766
  tabId: tabId,
@@ -30837,6 +30831,10 @@ HiTable.propTypes = {
30837
30831
  * Active le filtre sur les colonnes filtrables
30838
30832
  */
30839
30833
  filterable: _propTypes2.default.bool,
30834
+ /**
30835
+ * Id de la colonne par laquelle sont regroupé les éléments
30836
+ */
30837
+ groupBy: _propTypes2.default.string,
30840
30838
  /**
30841
30839
  * Ajoute le loader et le requestNextDatas en fin de tableau (si infiniteScroll activé)
30842
30840
  */
@@ -30849,6 +30847,10 @@ HiTable.propTypes = {
30849
30847
  * Ajoute l'infinite scroll
30850
30848
  */
30851
30849
  infiniteScroll: _propTypes2.default.bool,
30850
+ /**
30851
+ * État du tableau en cours de chargement des données
30852
+ */
30853
+ loading: _propTypes2.default.bool,
30852
30854
  /**
30853
30855
  * Identifiant de la ou des colonnes sur la/lesquelles il y a une 'lookup' search
30854
30856
  */
@@ -30960,11 +30962,7 @@ HiTable.propTypes = {
30960
30962
  * Taille du tableau (L/M/S),
30961
30963
  * définit l'espace entre les cellules et leurs tailles par default
30962
30964
  */
30963
- view: _propTypes2.default.oneOf(['l', 'm', 's']),
30964
- /**
30965
- * Id de la colonne par laquelle sont regroupé les éléments
30966
- */
30967
- groupBy: _propTypes2.default.string
30965
+ view: _propTypes2.default.oneOf(['l', 'm', 's'])
30968
30966
  };
30969
30967
  HiTable.defaultProps = {
30970
30968
  orderable: false,
@@ -30994,7 +30992,8 @@ HiTable.defaultProps = {
30994
30992
  }
30995
30993
  },
30996
30994
  view: 'l',
30997
- lookupColumns: []
30995
+ lookupColumns: [],
30996
+ loading: false
30998
30997
  };
30999
30998
 
31000
30999
  var _initialiseProps = function _initialiseProps() {
@@ -31042,7 +31041,7 @@ var _initialiseProps = function _initialiseProps() {
31042
31041
  };
31043
31042
 
31044
31043
  exports.default = (0, _styles.withStyles)(styles, { withTheme: true, name: 'HmuiHiTable' })(HiTable);
31045
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["src/HiTable/HiTable.js"],"names":["cst","styles","root","position","backgroundColor","theme","palette","background3","tableWrapper","overflowX","overflowY","filter","top","left","cursor","table","width","overflow","borderCollapse","zIndex","backToTopButtonContainer","textAlign","height","backToTopButton","backToTopButtonArrow","margin","MANDATORY_COLUMN_ERROR_MESSAGE","SORTED_COLUMN_ERROR_MESSAGE","HiTable","props","state","dateUpdate","Date","now","isScrollToBottom","groupByIds","groupBy","dataSource","map","value","row","datas","date","isFinite","substr","hasOwnProperty","push","openOrderColumnsMenu","bind","closeOrderColumnsMenu","toggleItem","toggleAll","selectAll","deselectAll","handleHorizontalScroll","handleVerticalScroll","placeHorizontalFloatingElement","scrollToTop","handleRequestLiveDatas","handleNextStickyRow","handleStickyRowPositions","wrapperScrollOffset","wrapperDiv","scrollWidth","offsetWidth","tHead","querySelector","tHeadLeftPadding","tHeadRightPadding","tHeadFirst","tBody","tFoot","tFootCenteredDiv","updateFloatingBodyElementRefs","style","Math","round","bottom","updateStickyRowsPosition","prevProps","prevState","prevContext","orderedColumns","colId","tBodyFirstElements","querySelectorAll","length","countLiveDatas","liveDataSpan","setState","dense","sortedColumnId","sortDirection","scrollTop","scrollHeight","offsetHeight","rowHeight","CELL_HEIGHT_DENSE","CELL_HEIGHT","groupByRowsPositions","tableBody","document","getElementById","tabId","stickyRows","getElementsByClassName","Array","prototype","call","stickyRow","nextSibling","offsetTop","item","selectedIdList","includes","rowId","onSelect","itemId","event","target","nodeName","scrollLeft","scrollingUp","shadowBottom","NB_ROWS_BACK_TO_TOP","index","fakeTr","display","maxHeight","minHeight","clientWidth","tBodyLeftPaddingElements","forEach","element","tBodyRightPaddingElements","right","max","tBodyScrollbarWidth","sticky","shadowRight","stickyRowContentDiv","div","selectable","requestLiveDatas","orderColumnsAnchor","currentTarget","orderColumnsMenuOpen","stickyRowIndex","classes","columns","orderable","onColumnsOrderUpdate","mandatoryColumnId","onRowClick","sortable","onSort","filterable","onFilterChange","infiniteScroll","hasNextDatas","requestNextDatas","dateLocale","numberLocale","translations","view","lookupColumns","headerHeight","CELL_HEADER_HEIGHT_DENSE","CELL_HEADER_HEIGHT","addNewRowRefs","onSearch","onRedirect","back_to_top","Component","propTypes","object","isRequired","number","array","string","bool","func","oneOf","defaultProps","load_more","get_the_n_new_items","choose_and_organize_columns","search","time","button","next","wrapperWidth","setTimeout","withTheme","name"],"mappings":"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","file":"HiTable.js","sourceRoot":"/home/mfazio/dev/projects/hipay-material-ui","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport Table from 'material-ui/Table';\nimport ArrowUp from 'mdi-material-ui/ArrowUp';\nimport isRequiredIf from 'react-proptype-conditional-require';\nimport HiButton from '../HiButton';\n\nimport { withStyles, withTheme } from '../styles';\nimport HiTableHead from './HiTableHead';\nimport HiTableBody from './HiTableBody';\nimport HiTableFooterScroll from './HiTableFooterScroll';\nimport * as cst from './constants';\nimport HiTableContextMenu from './HiTableContextMenu';\n\nexport const styles = theme => ({\n    root: {\n        position: 'relative',\n        backgroundColor: theme.palette.background3,\n    },\n    tableWrapper: {\n        overflowX: 'auto',\n        overflowY: 'hidden',\n    },\n    filter: {\n        position: 'relative',\n        top: 2,\n        left: 2,\n        cursor: 'pointer',\n    },\n    table: {\n        position: 'relative',\n        width: '100%',\n        overflow: 'hidden',\n        borderCollapse: 'collapse',\n        backgroundColor: theme.palette.background3,\n        zIndex: 10,\n    },\n    backToTopButtonContainer: {\n        position: 'absolute',\n        width: '100%',\n        textAlign: 'center',\n        height: 48,\n        top: -99999,\n    },\n    backToTopButton: {\n        zIndex: 11,\n    },\n    backToTopButtonArrow: {\n        height: 18,\n        width: 18,\n        position: 'relative',\n        top: -2,\n        margin: 2,\n    },\n});\n\nexport const MANDATORY_COLUMN_ERROR_MESSAGE =\n    'Vous devez saisir la propriété \"mandatoryColumnId\" pour les tableaux \"orderable\"';\nexport const SORTED_COLUMN_ERROR_MESSAGE =\n    'Vous devez saisir la propriété \"sortedColumnId\" pour les tableaux \"sortable\"';\n\n/**\n * Display a list of elements in a table\n * The click on FilterVariant opens a menu that allows the user\n * to filter by value or to order by a specific column\n *\n * Renderer behaviors:\n * - Widths:\n *      - all cells types have default width size (px) for each kind of view (L/M/S).\n *      - if view isn't set we use the largest one (large).\n *      - cell width can be overriden by column's props.\n *      - if there is not enough space to render all cells,\n *        we use horizontal scroll and cells width are fixed\n *      - if there is enough space, no scroll and only the first cell (column),\n *      which is not explicitly set as unfixed (fixedWidth = false),\n *      has not fixed width and may enlarge his width to fit available space.\n *\n * - Fixed Header:\n *      - header rows should be fixed and always be visible on body scroll.\n *      - vertical scrollbar should be hidden\n *      - if nbRows * cellHeight > tableHeight,\n *        we virtually enlarge the table then crop arbitrary width to hide the scrollbar.\n *      as each browsers may have different scrollbar widths,\n *      it may trouble column header alignment.\n */\nclass HiTable extends React.Component {\n    static propTypes = {\n        /**\n         * Useful to extend the style applied to components.\n         */\n        classes: PropTypes.object,\n        /**\n         * Colonnes du tableau (label, largeur, données, ... )\n         */\n        columns: PropTypes.object.isRequired,\n        /**\n         * Nombre de nouvelles données disponibles (live)\n         */\n        countLiveDatas: PropTypes.number,\n        /**\n         * Tableau des données\n         */\n        dataSource: PropTypes.array.isRequired,\n        /**\n         * Locale utilisé pour le format des dates\n         */\n        dateLocale: PropTypes.string,\n        /**\n         * Densité d'affichage (joue sur la hauteur des lignes)\n         */\n        dense: PropTypes.bool,\n        /**\n         * Active le filtre sur les colonnes filtrables\n         */\n        filterable: PropTypes.bool,\n        /**\n         * Ajoute le loader et le requestNextDatas en fin de tableau (si infiniteScroll activé)\n         */\n        hasNextDatas: PropTypes.bool,\n        /**\n         * Hauteur du tableau (px)\n         */\n        height: PropTypes.number,\n        /**\n         * Ajoute l'infinite scroll\n         */\n        infiniteScroll: PropTypes.bool,\n        /**\n         * Identifiant de la ou des colonnes sur la/lesquelles il y a une 'lookup' search\n         */\n        lookupColumns: PropTypes.array,\n        /**\n         * Pour les tableaux \"orderable\" uniquement : Id de la colonne obligatoire,\n         * elle sera toujours affichée dans le tableau et ne pourra pas être cachée.\n         */\n        mandatoryColumnId: isRequiredIf(\n            PropTypes.string,\n            props => props.hasOwnProperty('orderable') && props.orderable === true,\n            MANDATORY_COLUMN_ERROR_MESSAGE,\n        ),\n        /**\n         * Locale utilisé pour le format des nombres\n         */\n        numberLocale: PropTypes.string,\n        /**\n         * Fonction de callback qui prend en paramètre le tableau des colonnes mis à jour.\n         */\n        onColumnsOrderUpdate: PropTypes.func,\n        /**\n         * Fonction de callback sur le filtre d'une colonne\n         * Passe l'id de la colonne et la liste des id des éléments inclus\n         */\n        onFilterChange: PropTypes.func,\n        /**\n         * Fonction de callback appelée au clic sur l'item redirection\n         * du menu contextuel ouvert au clic droit\n         *\n         * @param {int} id\n         */\n        onRedirect: PropTypes.func,\n        /**\n         * Fonction de callback au click sur une ligne\n         * Passe l'element (row)\n         */\n        onRowClick: PropTypes.func,\n        /**\n         * Fonction de callback appelée au clic sur les items de recherche\n         * du menu contextuel ouvert au clic droit\n         *\n         * @param {string} searched field\n         * @param {string} searched value\n         * @param {string} search type (lookup, exclude)\n         */\n        onSearch: PropTypes.func,\n        /**\n         * Fonction de callback sur la sélection d'une ligne\n         * (ou sélection/déselection de tous dans le header)\n         * Passe la liste des id des lignes sélectionnées (selectedIdList)\n         */\n        onSelect: PropTypes.func,\n        /**\n         * Fonction de callback sur le tri d'une colonne\n         * Passe l'id de la colonne et la direction du tri (ou false si tri par défaut)\n         */\n        onSort: PropTypes.func,\n        /**\n         * L'utilisateur peut changer l'ordre des colonnes,\n         * les afficher ou non, et changer la vue de chaque colonne (small, medium, large).\n         */\n        orderable: PropTypes.bool,\n        /**\n         * Tableau des colonnes affichées (ordonnées, visibles/cachées, l/m/s)\n         */\n        orderedColumns: PropTypes.array.isRequired,\n        /**\n         * Fonction de callback requérant l'affichage des nouvelles données (live)\n         */\n        requestLiveDatas: PropTypes.func,\n        /**\n         * Fonction de callback requérant l'affichage des données suivantes\n         */\n        requestNextDatas: PropTypes.func,\n        /**\n         * [v2 - à venir] Les lignes sont sélectionnables (affichage d'une checkbox)\n         */\n        selectable: PropTypes.bool,\n        /**\n         * Liste des id des lignes sélectionnées\n         */\n        selectedIdList: PropTypes.array,\n        /**\n         * Active le tri sur les colonnes\n         */\n        sortable: PropTypes.bool,\n        /**\n         * Sens du tri\n         */\n        sortDirection: PropTypes.oneOf(['asc', 'desc']),\n        /**\n         * Id de la colonne trié\n         */\n        sortedColumnId: isRequiredIf(\n            PropTypes.string,\n            props => props.hasOwnProperty('sortable') && props.sortable === true,\n            SORTED_COLUMN_ERROR_MESSAGE,\n        ),\n        /**\n         * Fixe la première colonne\n         */\n        sticky: PropTypes.bool,\n        /**\n         * Identifiant unique à spécifier si on utilise plusieurs composants HiTable\n         */\n        tabId: PropTypes.string.isRequired,\n        /**\n         * Traduction des chaînes affichées\n         */\n        translations: PropTypes.object,\n        /**\n         * Taille du tableau (L/M/S),\n         * définit l'espace entre les cellules et leurs tailles par default\n         */\n        view: PropTypes.oneOf(['l', 'm', 's']),\n        /**\n         * Id de la colonne par laquelle sont regroupé les éléments\n         */\n        groupBy: PropTypes.string,\n    };\n\n    static defaultProps = {\n        orderable: false,\n        selectable: false,\n        sortable: true,\n        sortDirection: 'asc',\n        filterable: true,\n        infiniteScroll: false,\n        hasNextDatas: false,\n        countLiveDatas: 0,\n        dateLocale: 'en-EN',\n        numberLocale: 'en-EN',\n        dense: false,\n        height: 450,\n        sticky: true,\n        translations: {\n            load_more: 'Load More',\n            back_to_top: 'Back to top',\n            get_the_n_new_items: 'See %s new items',\n            choose_and_organize_columns: 'Choose & organize columns',\n            search: 'Search',\n            time: 'Time',\n            stickyRow: {\n                button: {\n                    next: 'Next day',\n                },\n            },\n        },\n        view: 'l',\n        lookupColumns: [],\n    };\n\n    constructor(props) {\n        super(props);\n\n        this.state = {\n            dateUpdate: Date.now(),\n            isScrollToBottom: false,\n            groupByIds: {},\n        };\n\n        // create associative array (object) with sticky row key & its values\n        // => used for sticky row badges\n        if (props.groupBy) {\n            props.dataSource.map(row => {\n                let value = row.datas[props.groupBy].value;\n                let date = new Date(value);\n\n                if (date instanceof Date && isFinite(date)) {\n                    value = value.substr(0, 10);\n                }\n                if (!this.state.groupByIds.hasOwnProperty(value)) {\n                    this.state.groupByIds[value] = [];\n                }\n                this.state.groupByIds[value].push(row.datas);\n            });\n        }\n\n        // Orderable\n        this.openOrderColumnsMenu = this.openOrderColumnsMenu.bind(this);\n        this.closeOrderColumnsMenu = this.closeOrderColumnsMenu.bind(this);\n\n        // Selectable\n        this.toggleItem = this.toggleItem.bind(this);\n        this.toggleAll = this.toggleAll.bind(this);\n        this.selectAll = this.selectAll.bind(this);\n        this.deselectAll = this.deselectAll.bind(this);\n\n        // Manage scrolling\n        this.handleHorizontalScroll = this.handleHorizontalScroll.bind(this);\n        this.handleVerticalScroll = this.handleVerticalScroll.bind(this);\n        this.placeHorizontalFloatingElement = this.placeHorizontalFloatingElement.bind(this);\n        this.scrollToTop = this.scrollToTop.bind(this);\n\n        this.isScrollToBottom = this.isScrollToBottom.bind(this);\n        this.handleRequestLiveDatas = this.handleRequestLiveDatas.bind(this);\n        this.handleNextStickyRow = this.handleNextStickyRow.bind(this);\n        this.handleStickyRowPositions = this.handleStickyRowPositions.bind(this);\n    }\n\n    /**\n     * DOM references\n     * use to replace element on horizontal & vertical scroll\n     */\n    wrapperDiv = <div />;\n    wrapperWidth = 0;\n    tHead = <div />;\n    tHeadLeftPadding = <div />;\n    tHeadRightPadding = <div />;\n    tHeadFirst = <div />;\n    tBody = <div />;\n    tBodyScrollbarWidth = 0;\n    tBodyLeftPaddingElements = [];\n    tBodyRightPaddingElements = [];\n    tBodyFirstElements = [];\n    tFoot = <div />;\n    tFootCenteredDiv = <div />;\n    backToTopButton = null;\n    liveDataSpan = null;\n    scrollTop = 0;\n    scrollLeft = 0;\n    groupByRowsPositions = [];\n\n    /** Lifecycle methods */\n\n    componentDidMount() {\n        this.wrapperScrollOffset = this.wrapperDiv.scrollWidth - this.wrapperDiv.offsetWidth;\n\n        // Set DOM references\n        this.tHead = this.wrapperDiv.querySelector('table thead');\n        this.tHeadLeftPadding = this.tHead.querySelector('tr th:nth-child(1)');\n        this.tHeadRightPadding = this.tHead.querySelector('tr th:nth-last-child(1)');\n        this.tHeadFirst = this.tHead.querySelector('tr th:nth-child(2)');\n        this.tBody = this.wrapperDiv.querySelector('table tbody');\n        this.tFoot = this.wrapperDiv.querySelector('table tfoot');\n        this.tFootCenteredDiv = this.wrapperDiv.querySelector('table tfoot tr td div');\n        this.backToTopButton = this.wrapperDiv.querySelector('.back-to-top-button');\n\n        this.updateFloatingBodyElementRefs();\n\n        // Detect if root has horizontal scroll bar\n        if (this.wrapperDiv.scrollWidth > this.wrapperDiv.offsetWidth) {\n            // adapt first column to fixed width\n            if (this.tHeadFirst && this.tHeadFirst.style) {\n                this.tHeadFirst.style.width = 'auto';\n            }\n            // fixed footer width\n            if (this.tFootCenteredDiv && this.tFootCenteredDiv.style) {\n                this.tFootCenteredDiv.style.width = (Math.round(this.wrapperDiv.offsetWidth / 2)) + 'px';\n                this.tFootCenteredDiv.style.position = 'absolute';\n                this.tFootCenteredDiv.style.bottom = '0px';\n            }\n        }\n\n        this.updateStickyRowsPosition();\n\n        this.placeHorizontalFloatingElement();\n    }\n\n    componentDidUpdate(prevProps, prevState, prevContext) {\n        this.wrapperScrollOffset = this.wrapperDiv.scrollWidth - this.wrapperDiv.offsetWidth;\n\n        // If orderedColumns has change, possibly the sticky cells has changed too\n        if (this.props.orderedColumns[0].colId !== prevProps.orderedColumns[0].colId) {\n            this.tHeadFirst = this.tHead.querySelector('tr th:nth-child(2)');\n            this.tBodyFirstElements = this.wrapperDiv.querySelectorAll(\n                'table tbody tr td:nth-child(2)',\n            );\n        }\n\n        // If there is new rows, update tbody first element list and left padding cells\n        if (this.props.dataSource.length > prevProps.dataSource.length) {\n            this.updateFloatingBodyElementRefs();\n        }\n\n        if (this.props.countLiveDatas > 0) {\n            this.liveDataSpan = this.tHead.querySelector('tr:nth-child(2) th span');\n            this.backToTopButton.style.top = '-99999px';\n        }\n\n        if (prevProps.countLiveDatas > this.props.countLiveDatas) {\n            this.setState({\n                dateUpdate: Date.now(),\n            });\n        }\n\n        // Only if needed\n        if (\n            this.props.dataSource.length > prevProps.dataSource.length ||\n            this.props.dense !== prevProps.dense ||\n            this.props.sortedColumnId !== prevProps.sortedColumnId ||\n            this.props.sortDirection !== prevProps.sortDirection\n        ) {\n            this.updateStickyRowsPosition();\n            if (this.props.dataSource.length > prevProps.dataSource.length) {\n                this.handleStickyRowPositions();\n            }\n        }\n        if (this.props.dataSource.length > prevProps.dataSource.length && this.props.groupBy) {\n            // create associative array (object) with sticky row key & its values\n            // => used for sticky row badges\n            let groupByIds = {};\n            this.props.dataSource.map(row => {\n                let value = row.datas[this.props.groupBy].value;\n                let date = new Date(value);\n\n                if (date instanceof Date && isFinite(date)) {\n                    value = value.substr(0, 10);\n                }\n                if (!groupByIds.hasOwnProperty(value)) {\n                    groupByIds[value] = [];\n                }\n                groupByIds[value].push(row.datas);\n            });\n            this.setState({ groupByIds: groupByIds });\n        }\n\n        this.isScrollToBottom(this.scrollTop === this.tBody.scrollHeight - this.tBody.offsetHeight);\n\n        this.placeHorizontalFloatingElement();\n    }\n\n    /**    END Lifecycle methods   */\n\n    updateStickyRowsPosition() {\n        const rowHeight = this.props.dense ? cst.CELL_HEIGHT_DENSE : cst.CELL_HEIGHT;\n        this.groupByRowsPositions = [];\n        // Initialize new stickyRows position\n        const tableBody = document.getElementById(`${this.props.tabId}-body`);\n        const stickyRows = tableBody.getElementsByClassName('stickyGroupBy');\n        if (stickyRows.length > 0) {\n            Array.prototype.filter.call(stickyRows, stickyRow => {\n                this.groupByRowsPositions.push(\n                    stickyRow.nextSibling.nextSibling.offsetTop - rowHeight,\n                );\n            });\n        }\n    }\n\n    updateFloatingBodyElementRefs = () => {\n        this.tBodyScrollbarWidth = this.tBody.offsetWidth - this.tBody.clientWidth;\n\n        if (this.tHead && this.tBodyScrollbarWidth > 0) {\n            this.tHead.style.width = 'calc(100% - ' + this.tBodyScrollbarWidth + 'px)';\n        }\n\n        this.tBodyLeftPaddingElements = this.tBody.querySelectorAll(\n            'tr td:nth-child(1), .floating-parent-row-label',\n        );\n        this.tBodyRightPaddingElements = this.tBody.querySelectorAll(\n            'tr td:nth-last-child(1), .floating-parent-row-indicator',\n        );\n\n        this.tBodyFirstElements = this.tBody.querySelectorAll('tr td:nth-child(2)');\n    };\n\n    isScrollToBottom(value) {\n        if (this.state.isScrollToBottom !== value) {\n            this.setState({\n                isScrollToBottom: value,\n            });\n        }\n    }\n\n    /**\n     * Ajoute / Supprime l'id de l'item du selectedIdList\n     * @param item\n     */\n    toggleItem(item) {\n        if (this.props.selectedIdList.includes(item.rowId)) {\n            this.props.onSelect(\n                this.props.selectedIdList.filter(function(itemId) {\n                    return itemId !== item.rowId;\n                }),\n            );\n        } else {\n            this.props.onSelect([...this.props.selectedIdList, item.rowId]);\n        }\n    }\n\n    /**\n     * Sélectionne / Déselectionne tous les éléments en fonction de l'état de la liste\n     */\n    toggleAll() {\n        if (this.props.selectedIdList.length === this.props.dataSource.length) {\n            this.deselectAll();\n        } else {\n            this.selectAll();\n        }\n    }\n\n    /**\n     * Sélectionne tous les items\n     */\n    selectAll() {\n        this.props.onSelect(this.props.dataSource.map(item => item.rowId));\n    }\n\n    /**\n     * Désélectionne tous les items\n     */\n    deselectAll() {\n        this.props.onSelect([]);\n    }\n\n    /**\n     * Handle horizontal scroll (wrapperDiv)\n     * - replace each first cells body & header & add right shadows\n     */\n    handleHorizontalScroll(event) {\n        // cancel if scroll is from tbody OR it didn't change\n        if (event.target.nodeName === 'TBODY' || this.scrollLeft === event.target.scrollLeft) {\n            return;\n        }\n\n        this.scrollLeft = event.target.scrollLeft;\n\n        // Replace live datas notification\n        this.placeHorizontalFloatingElement();\n    }\n\n    /**\n     * Handle vertical scroll (tbody)\n     * - add bottom shadow\n     * - place back to top button\n     * - request next datas if reach bottom\n     */\n    handleVerticalScroll(event) {\n        // cancel if scroll is not from tbody OR it didn't change\n        if (event.target.nodeName !== 'TBODY' || this.scrollTop === event.target.scrollTop) return;\n\n        const scrollingUp = this.scrollTop > event.target.scrollTop;\n\n        this.scrollTop = event.target.scrollTop;\n\n        // Add bottom shadow to header row\n        const shadowBottom = '0px 0px 2px 0px rgba(128, 128, 128, 0.32)';\n        this.tHead.style['box-shadow'] = this.scrollTop > 0 ? shadowBottom : 'none';\n        const rowHeight = this.props.dense ? cst.CELL_HEIGHT_DENSE : cst.CELL_HEIGHT;\n\n        // Add back to top button when scrolling up from constant defined scroll point\n        // if there not live data notification\n        if (this.props.countLiveDatas === 0) {\n            if (scrollingUp && this.scrollTop >= cst.NB_ROWS_BACK_TO_TOP * rowHeight) {\n                this.backToTopButton.style.top = `${rowHeight * 1.5} px`;\n            } else {\n                this.backToTopButton.style.top = `${-99999}px`;\n            }\n        }\n\n        this.handleStickyRowPositions();\n\n        this.isScrollToBottom(\n            this.scrollTop === event.target.scrollHeight - this.tBody.offsetHeight,\n        );\n    }\n\n    handleStickyRowPositions() {\n        const tableBody = document.getElementById(`${this.props.tabId}-body`);\n        const stickyRows = tableBody.getElementsByClassName('stickyGroupBy');\n        const rowHeight = this.props.dense ? cst.CELL_HEIGHT_DENSE : cst.CELL_HEIGHT;\n        if (stickyRows.length > 0) {\n            Array.prototype.filter.call(stickyRows, (stickyRow, index) => {\n                const fakeTr = stickyRow.nextSibling;\n                if (tableBody.scrollTop > this.groupByRowsPositions[index]) {\n                    // Calcul de la position du 'pinned' item\n                    // positionnement juste en dessous du header\n                    if (\n                        typeof stickyRows[index + 1] === 'undefined' ||\n                        tableBody.scrollTop < stickyRows[index + 1].offsetTop\n                    ) {\n                        // Si la prochaine ligne est aussi un 'pinned' item,\n                        // il pousse le précédent vers le haut\n                        if (\n                            typeof this.groupByRowsPositions[index + 1] !== 'undefined' &&\n                            this.groupByRowsPositions[index + 1] - tableBody.scrollTop <\n                            rowHeight - 10\n                        ) {\n                            stickyRow.style.top = `${tableBody.scrollTop +\n                            this.groupByRowsPositions[index + 1] -\n                            tableBody.scrollTop -\n                            rowHeight}\n                                px`;\n                        } else {\n                            stickyRow.style.top = `${tableBody.scrollTop}px`;\n                        }\n\n                        if (stickyRow.style.position !== 'absolute') {\n                            // Repositionnement des éléments dans une row en position absolute\n                            stickyRow.style.position = 'absolute';\n                            fakeTr.style.display = 'inline-block';\n                            stickyRow.style.height = this.props.dense\n                                ? `${cst.CELL_HEIGHT_DENSE - 8}px`\n                                : `${cst.CELL_HEIGHT - 8}px`;\n                            stickyRow.querySelector('button').style.maxHeight = this.props.dense\n                                ? `${cst.CELL_HEIGHT_DENSE - 16}px`\n                                : `${cst.CELL_HEIGHT - 16}px`;\n                            stickyRow.querySelector('button').style.minHeight = this.props.dense\n                                ? `${cst.CELL_HEIGHT_DENSE - 16}px`\n                                : `${cst.CELL_HEIGHT - 16}px`;\n                            stickyRow.querySelector('button').style.top = '-3px';\n                            stickyRow.querySelector('#stickyRowContent').style.top = !this.props\n                                .dense\n                                ? '4px'\n                                : '-3px';\n                            stickyRow.querySelector('td').style.height = this.props.dense\n                                ? `${cst.CELL_HEIGHT_DENSE - 8}px`\n                                : `${cst.CELL_HEIGHT - 8}px`;\n                            if (this.props.dense) {\n                                stickyRow.querySelector('button').style.top = '0px';\n                                stickyRow.querySelector('button span').style.position = 'relative';\n                                stickyRow.querySelector('button span').style.top = '-4px';\n                            }\n                        }\n                    }\n                } else if (stickyRow.style.position !== 'relative') {\n                    // Repositionnement normal\n                    stickyRow.style.position = 'relative';\n                    stickyRow.style.top = '0px';\n                    fakeTr.style.display = 'none';\n                    stickyRow.style.height = this.props.dense\n                        ? `${cst.CELL_HEIGHT_DENSE}px`\n                        : `${cst.CELL_HEIGHT}px`;\n                    stickyRow.querySelector('#sticky-badge').style.top = '0px';\n                    stickyRow.querySelector('#stickyRowContent').style.top = '2px';\n                    stickyRow.querySelector('td').style.height = this.props.dense\n                        ? `${cst.CELL_HEIGHT_DENSE}px`\n                        : `${cst.CELL_HEIGHT}px`;\n                    stickyRow.querySelector('button').style.maxHeight = this.props.dense\n                        ? `${cst.CELL_HEIGHT_DENSE - 2}px`\n                        : `${cst.CELL_HEIGHT - 8}px`;\n                    stickyRow.querySelector('button').style.minHeight = this.props.dense\n                        ? `${cst.CELL_HEIGHT_DENSE - 2}px`\n                        : `${cst.CELL_HEIGHT - 8}px`;\n                    if (this.props.dense) {\n                        stickyRow.querySelector('button span').style.top = '0px';\n                    }\n                }\n            });\n        }\n    }\n\n    /**\n     * Some element must be replace \"manually\"\n     */\n    placeHorizontalFloatingElement() {\n        // live datas notification\n        if (this.liveDataSpan) {\n            this.liveDataSpan.style.left =\n                this.wrapperDiv.clientWidth / 2 - 100 + this.scrollLeft + 'px';\n        }\n\n        // Replace left padding cells\n        [...this.tBodyLeftPaddingElements, this.tHeadLeftPadding].forEach(element => {\n            element.style.left = this.scrollLeft + 'px';\n        });\n\n        // TODO - FIX\n        // Les éléments de droite sont décalés de 22px lorsque de nouvelles lignes sont\n        // visible (children ou details)\n\n        // Replace right padding cells\n        [...this.tBodyRightPaddingElements, this.tHeadRightPadding].forEach(element => {\n            element.style.right =\n                Math.max(0, this.wrapperScrollOffset - this.scrollLeft - this.tBodyScrollbarWidth) + 'px';\n        });\n\n        // Replace first cells & add right shadows\n        if (this.props.sticky) {\n            const shadowRight = '1px 0px 0px 0px rgba(128, 128, 128, 0.32)';\n            [...this.tBodyFirstElements, this.tHeadFirst].forEach(element => {\n                element.style.left = this.scrollLeft + 'px';\n                element.style['box-shadow'] = this.scrollLeft > 0 ? shadowRight : 'none';\n            });\n        }\n\n        // Replace centered elements (elements width should be 50% of wrapper)\n        if (this.tFootCenteredDiv) {\n            this.tFootCenteredDiv.style.left =\n                Math.round(this.wrapperDiv.offsetWidth / 4) + this.scrollLeft + 'px';\n        }\n\n        // Replace stickyRowContent\n        const tableBody = document.getElementById(`${this.props.tabId}-body`);\n        const stickyRowContentDiv = tableBody.getElementsByClassName('stickyRowContent');\n        if (stickyRowContentDiv.length > 0) {\n            Array.prototype.filter.call(stickyRowContentDiv, div => {\n                div.style.left = `${this.wrapperDiv.scrollLeft +\n                    (this.props.selectable ? 25 : 0)}px`;\n            });\n        }\n    }\n\n    handleRequestLiveDatas() {\n        this.scrollToTop();\n        this.props.requestLiveDatas();\n    }\n\n    /**\n     * Scroll back to table top\n     */\n    scrollToTop() {\n        // Hide back to top button\n        this.backToTopButton['style'].top = -99999 + 'px';\n\n        // Set scroll top to 0\n        this.tBody.scrollTop = 0;\n        this.scrollTop = 0;\n    }\n\n    openOrderColumnsMenu(event) {\n        this.setState({\n            orderColumnsAnchor: event.currentTarget,\n            orderColumnsMenuOpen: true,\n        });\n    }\n\n    closeOrderColumnsMenu() {\n        this.setState({\n            orderColumnsAnchor: null,\n            orderColumnsMenuOpen: false,\n        });\n    }\n\n    /**\n     * This function is pass to table body to be advised when new rows are dynamically added (ex detail rows)\n     * we can then update our list of floating body elements refs\n     **/\n    addNewRowRefs = () => {\n        // delayed refs getting to let time at new rows to build up\n        setTimeout(() => {\n            this.updateFloatingBodyElementRefs();\n            this.placeHorizontalFloatingElement();\n        }, 10);\n    };\n\n    /**\n     * Scroll jusqu'au prochain stickRow\n     *\n     * @param stickyRowIndex\n     */\n    handleNextStickyRow(stickyRowIndex) {\n        if (this.groupByRowsPositions.length - 1 > stickyRowIndex) {\n            const tableBody = document.getElementById(`${this.props.tabId}-body`);\n            tableBody.scrollTop = this.groupByRowsPositions[stickyRowIndex + 1];\n        }\n    }\n\n    render() {\n        const {\n            classes,\n            tabId,\n            columns,\n            orderedColumns,\n            dataSource,\n            orderable,\n            onColumnsOrderUpdate,\n            mandatoryColumnId,\n            selectable,\n            selectedIdList,\n            onRowClick,\n            sortable,\n            sortedColumnId,\n            sortDirection,\n            onSort,\n            filterable,\n            onFilterChange,\n            infiniteScroll,\n            hasNextDatas,\n            requestNextDatas,\n            countLiveDatas,\n            dateLocale,\n            numberLocale,\n            dense,\n            height,\n            sticky,\n            translations,\n            view,\n            groupBy,\n            lookupColumns,\n        } = this.props;\n\n        const { dateUpdate, isScrollToBottom, groupByIds } = this.state;\n\n        const headerHeight = dense ? cst.CELL_HEADER_HEIGHT_DENSE : cst.CELL_HEADER_HEIGHT;\n\n        return (\n            <div className={classes.root}>\n                <div\n                    id={tabId}\n                    className={classes.tableWrapper}\n                    ref={div => this.wrapperDiv = div}\n                    onScroll={this.handleHorizontalScroll}\n                >\n                    <Table className={classes.table} style={{ height: height }}>\n                        <HiTableHead\n                            columns={columns}\n                            orderedColumns={orderedColumns}\n                            dataSource={dataSource}\n                            selectable={selectable}\n                            selectedIdList={selectedIdList}\n                            onSelect={this.toggleAll}\n                            sortable={sortable}\n                            sortedColumnId={sortedColumnId}\n                            sortDirection={sortDirection}\n                            onSort={onSort}\n                            filterable={filterable}\n                            onFilterChange={onFilterChange}\n                            orderable={orderable}\n                            onColumnsOrderUpdate={onColumnsOrderUpdate}\n                            mandatoryColumnId={mandatoryColumnId}\n                            onRequestLiveDatas={this.handleRequestLiveDatas}\n                            countLiveDatas={countLiveDatas}\n                            dateLocale={dateLocale}\n                            numberLocale={numberLocale}\n                            dense={dense}\n                            height={headerHeight}\n                            sticky={sticky}\n                            view={view}\n                            translations={translations}\n                            lookupColumns={lookupColumns}\n                        />\n                        <HiTableBody\n                            tabId={tabId}\n                            columns={columns}\n                            orderedColumns={orderedColumns}\n                            dataSource={dataSource}\n                            selectable={selectable}\n                            selectedIdList={selectedIdList}\n                            sortedColumnId={sortedColumnId}\n                            onSelect={this.toggleItem}\n                            dateUpdate={dateUpdate}\n                            dateLocale={dateLocale}\n                            numberLocale={numberLocale}\n                            dense={dense}\n                            height={height - headerHeight}\n                            sticky={sticky}\n                            view={view}\n                            onRowClick={onRowClick}\n                            onScroll={this.handleVerticalScroll}\n                            addNewRowRefs={this.addNewRowRefs}\n                            translations={translations}\n                            groupBy={groupBy}\n                            onClickNext={this.handleNextStickyRow}\n                            groupByIds={groupByIds}\n                            lookupColumns={lookupColumns}\n                        />\n                        {infiniteScroll && (\n                            <HiTableFooterScroll\n                                tabId={tabId}\n                                hasNextDatas={hasNextDatas}\n                                requestNextDatas={requestNextDatas}\n                                maxAutoRequest={3}\n                                isScrollToBottom={isScrollToBottom}\n                                translations={translations}\n                            />\n                        )}\n                    </Table>\n\n                    <HiTableContextMenu\n                        tabId={tabId}\n                        onSearch={this.props.onSearch}\n                        onRedirect={this.props.onRedirect}\n                    />\n\n                    <div className={`back-to-top-button ${classes.backToTopButtonContainer}`}>\n                        <HiButton\n                            variant=\"raised\"\n                            color=\"primary\"\n                            className={classes.backToTopButton}\n                            onClick={() => this.scrollToTop()}\n                        >\n                            <ArrowUp className={classes.backToTopButtonArrow} />\n                            {translations.back_to_top}\n                            <ArrowUp className={classes.backToTopButtonArrow} />\n                        </HiButton>\n                    </div>\n                </div>\n            </div>\n        );\n    }\n}\n\nexport default withStyles(styles, { withTheme: true, name: 'HmuiHiTable' })(HiTable);\n"]}
31044
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["src/HiTable/HiTable.js"],"names":["cst","styles","root","position","backgroundColor","theme","palette","background3","tableWrapper","overflowX","overflowY","filter","top","left","cursor","table","width","overflow","borderCollapse","zIndex","backToTopButtonContainer","textAlign","height","backToTopButton","backToTopButtonArrow","margin","MANDATORY_COLUMN_ERROR_MESSAGE","SORTED_COLUMN_ERROR_MESSAGE","HiTable","props","state","dateUpdate","Date","now","isScrollToBottom","groupByIds","groupBy","dataSource","map","value","row","datas","date","isFinite","substr","hasOwnProperty","push","openOrderColumnsMenu","bind","closeOrderColumnsMenu","toggleItem","toggleAll","selectAll","deselectAll","handleHorizontalScroll","handleVerticalScroll","placeHorizontalFloatingElement","scrollToTop","handleRequestLiveDatas","handleNextStickyRow","handleStickyRowPositions","wrapperScrollOffset","wrapperDiv","scrollWidth","offsetWidth","tHead","querySelector","tHeadLeftPadding","tHeadRightPadding","tHeadFirst","tBody","tFoot","tFootCenteredDiv","updateFloatingBodyElementRefs","style","Math","round","bottom","updateStickyRowsPosition","prevProps","prevState","prevContext","orderedColumns","colId","tBodyFirstElements","querySelectorAll","length","countLiveDatas","liveDataSpan","setState","dense","sortedColumnId","sortDirection","scrollTop","scrollHeight","offsetHeight","rowHeight","CELL_HEIGHT_DENSE","CELL_HEIGHT","groupByRowsPositions","tableBody","document","getElementById","tabId","stickyRows","getElementsByClassName","Array","prototype","call","stickyRow","nextSibling","offsetTop","item","selectedIdList","includes","rowId","onSelect","itemId","event","target","nodeName","scrollLeft","scrollingUp","shadowBottom","NB_ROWS_BACK_TO_TOP","index","fakeTr","display","maxHeight","minHeight","clientWidth","tBodyLeftPaddingElements","forEach","element","tBodyRightPaddingElements","right","max","tBodyScrollbarWidth","sticky","shadowRight","stickyRowContentDiv","div","selectable","requestLiveDatas","orderColumnsAnchor","currentTarget","orderColumnsMenuOpen","stickyRowIndex","classes","columns","orderable","onColumnsOrderUpdate","mandatoryColumnId","onRowClick","sortable","onSort","filterable","onFilterChange","infiniteScroll","hasNextDatas","requestNextDatas","dateLocale","numberLocale","translations","view","lookupColumns","loading","headerHeight","CELL_HEADER_HEIGHT_DENSE","CELL_HEADER_HEIGHT","addNewRowRefs","onSearch","onRedirect","back_to_top","Component","propTypes","object","isRequired","number","array","string","bool","func","oneOf","defaultProps","load_more","get_the_n_new_items","choose_and_organize_columns","search","time","button","next","wrapperWidth","setTimeout","withTheme","name"],"mappings":";;;;;;;;;AAAA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AAEA;;AACA;;;;AACA;;;;AACA;;;;AACA;;IAAYA,G;;AACZ;;;;;;;;;;;;;;;;AAEO,IAAMC,0BAAS,SAATA,MAAS;AAAA,WAAU;AAC5BC,cAAM;AACFC,sBAAU,UADR;AAEFC,6BAAiBC,MAAMC,OAAN,CAAcC;AAF7B,SADsB;AAK5BC,sBAAc;AACVC,uBAAW,MADD;AAEVC,uBAAW;AAFD,SALc;AAS5BC,gBAAQ;AACJR,sBAAU,UADN;AAEJS,iBAAK,CAFD;AAGJC,kBAAM,CAHF;AAIJC,oBAAQ;AAJJ,SAToB;AAe5BC,eAAO;AACHZ,sBAAU,UADP;AAEHa,mBAAO,MAFJ;AAGHC,sBAAU,QAHP;AAIHC,4BAAgB,UAJb;AAKHd,6BAAiBC,MAAMC,OAAN,CAAcC,WAL5B;AAMHY,oBAAQ;AANL,SAfqB;AAuB5BC,kCAA0B;AACtBjB,sBAAU,UADY;AAEtBa,mBAAO,MAFe;AAGtBK,uBAAW,QAHW;AAItBC,oBAAQ,EAJc;AAKtBV,iBAAK,CAAC;AALgB,SAvBE;AA8B5BW,yBAAiB;AACbJ,oBAAQ;AADK,SA9BW;AAiC5BK,8BAAsB;AAClBF,oBAAQ,EADU;AAElBN,mBAAO,EAFW;AAGlBb,sBAAU,UAHQ;AAIlBS,iBAAK,CAAC,CAJY;AAKlBa,oBAAQ;AALU;AAjCM,KAAV;AAAA,CAAf;;AA0CA,IAAMC,0EACT,kFADG;AAEA,IAAMC,oEACT,8EADG;;AAGP;;;;;;;;;;;;;;;;;;;;;;;;;IAwBMC,O;;;AAwMF,qBAAYC,KAAZ,EAAmB;AAAA;;AAAA,sHACTA,KADS;;AAAA;;AAGf,cAAKC,KAAL,GAAa;AACTC,wBAAYC,KAAKC,GAAL,EADH;AAETC,8BAAkB,KAFT;AAGTC,wBAAY;AAHH,SAAb;;AAMA;AACA;AACA,YAAIN,MAAMO,OAAV,EAAmB;AACfP,kBAAMQ,UAAN,CAAiBC,GAAjB,CAAqB,eAAO;AACxB,oBAAIC,QAAQC,IAAIC,KAAJ,CAAUZ,MAAMO,OAAhB,EAAyBG,KAArC;AACA,oBAAIG,OAAO,IAAIV,IAAJ,CAASO,KAAT,CAAX;;AAEA,oBAAIG,gBAAgBV,IAAhB,IAAwBW,SAASD,IAAT,CAA5B,EAA4C;AACxCH,4BAAQA,MAAMK,MAAN,CAAa,CAAb,EAAgB,EAAhB,CAAR;AACH;AACD,oBAAI,CAAC,MAAKd,KAAL,CAAWK,UAAX,CAAsBU,cAAtB,CAAqCN,KAArC,CAAL,EAAkD;AAC9C,0BAAKT,KAAL,CAAWK,UAAX,CAAsBI,KAAtB,IAA+B,EAA/B;AACH;AACD,sBAAKT,KAAL,CAAWK,UAAX,CAAsBI,KAAtB,EAA6BO,IAA7B,CAAkCN,IAAIC,KAAtC;AACH,aAXD;AAYH;;AAED;AACA,cAAKM,oBAAL,GAA4B,MAAKA,oBAAL,CAA0BC,IAA1B,OAA5B;AACA,cAAKC,qBAAL,GAA6B,MAAKA,qBAAL,CAA2BD,IAA3B,OAA7B;;AAEA;AACA,cAAKE,UAAL,GAAkB,MAAKA,UAAL,CAAgBF,IAAhB,OAAlB;AACA,cAAKG,SAAL,GAAiB,MAAKA,SAAL,CAAeH,IAAf,OAAjB;AACA,cAAKI,SAAL,GAAiB,MAAKA,SAAL,CAAeJ,IAAf,OAAjB;AACA,cAAKK,WAAL,GAAmB,MAAKA,WAAL,CAAiBL,IAAjB,OAAnB;;AAEA;AACA,cAAKM,sBAAL,GAA8B,MAAKA,sBAAL,CAA4BN,IAA5B,OAA9B;AACA,cAAKO,oBAAL,GAA4B,MAAKA,oBAAL,CAA0BP,IAA1B,OAA5B;AACA,cAAKQ,8BAAL,GAAsC,MAAKA,8BAAL,CAAoCR,IAApC,OAAtC;AACA,cAAKS,WAAL,GAAmB,MAAKA,WAAL,CAAiBT,IAAjB,OAAnB;;AAEA,cAAKd,gBAAL,GAAwB,MAAKA,gBAAL,CAAsBc,IAAtB,OAAxB;AACA,cAAKU,sBAAL,GAA8B,MAAKA,sBAAL,CAA4BV,IAA5B,OAA9B;AACA,cAAKW,mBAAL,GAA2B,MAAKA,mBAAL,CAAyBX,IAAzB,OAA3B;AACA,cAAKY,wBAAL,GAAgC,MAAKA,wBAAL,CAA8BZ,IAA9B,OAAhC;AA7Ce;AA8ClB;;AAED;;;;;;;;;;AAuBA;;4CAEoB;AAChB,iBAAKa,mBAAL,GAA2B,KAAKC,UAAL,CAAgBC,WAAhB,GAA8B,KAAKD,UAAL,CAAgBE,WAAzE;;AAEA;AACA,iBAAKC,KAAL,GAAa,KAAKH,UAAL,CAAgBI,aAAhB,CAA8B,aAA9B,CAAb;AACA,iBAAKC,gBAAL,GAAwB,KAAKF,KAAL,CAAWC,aAAX,CAAyB,oBAAzB,CAAxB;AACA,iBAAKE,iBAAL,GAAyB,KAAKH,KAAL,CAAWC,aAAX,CAAyB,yBAAzB,CAAzB;AACA,iBAAKG,UAAL,GAAkB,KAAKJ,KAAL,CAAWC,aAAX,CAAyB,oBAAzB,CAAlB;AACA,iBAAKI,KAAL,GAAa,KAAKR,UAAL,CAAgBI,aAAhB,CAA8B,aAA9B,CAAb;AACA,iBAAKK,KAAL,GAAa,KAAKT,UAAL,CAAgBI,aAAhB,CAA8B,aAA9B,CAAb;AACA,iBAAKM,gBAAL,GAAwB,KAAKV,UAAL,CAAgBI,aAAhB,CAA8B,uBAA9B,CAAxB;AACA,iBAAK3C,eAAL,GAAuB,KAAKuC,UAAL,CAAgBI,aAAhB,CAA8B,qBAA9B,CAAvB;;AAEA,iBAAKO,6BAAL;;AAEA;AACA,gBAAI,KAAKX,UAAL,CAAgBC,WAAhB,GAA8B,KAAKD,UAAL,CAAgBE,WAAlD,EAA+D;AAC3D;AACA,oBAAI,KAAKK,UAAL,IAAmB,KAAKA,UAAL,CAAgBK,KAAvC,EAA8C;AAC1C,yBAAKL,UAAL,CAAgBK,KAAhB,CAAsB1D,KAAtB,GAA8B,MAA9B;AACH;AACD;AACA,oBAAI,KAAKwD,gBAAL,IAAyB,KAAKA,gBAAL,CAAsBE,KAAnD,EAA0D;AACtD,yBAAKF,gBAAL,CAAsBE,KAAtB,CAA4B1D,KAA5B,GAAqC2D,KAAKC,KAAL,CAAW,KAAKd,UAAL,CAAgBE,WAAhB,GAA8B,CAAzC,CAAD,GAAgD,IAApF;AACA,yBAAKQ,gBAAL,CAAsBE,KAAtB,CAA4BvE,QAA5B,GAAuC,UAAvC;AACA,yBAAKqE,gBAAL,CAAsBE,KAAtB,CAA4BG,MAA5B,GAAqC,KAArC;AACH;AACJ;;AAED,iBAAKC,wBAAL;;AAEA,iBAAKtB,8BAAL;AACH;;;2CAEkBuB,S,EAAWC,S,EAAWC,W,EAAa;AAAA;;AAClD,iBAAKpB,mBAAL,GAA2B,KAAKC,UAAL,CAAgBC,WAAhB,GAA8B,KAAKD,UAAL,CAAgBE,WAAzE;;AAEA;AACA,gBAAI,KAAKnC,KAAL,CAAWqD,cAAX,CAA0B,CAA1B,EAA6BC,KAA7B,KAAuCJ,UAAUG,cAAV,CAAyB,CAAzB,EAA4BC,KAAvE,EAA8E;AAC1E,qBAAKd,UAAL,GAAkB,KAAKJ,KAAL,CAAWC,aAAX,CAAyB,oBAAzB,CAAlB;AACA,qBAAKkB,kBAAL,GAA0B,KAAKtB,UAAL,CAAgBuB,gBAAhB,CACtB,gCADsB,CAA1B;AAGH;;AAED;AACA,gBAAI,KAAKxD,KAAL,CAAWQ,UAAX,CAAsBiD,MAAtB,GAA+BP,UAAU1C,UAAV,CAAqBiD,MAAxD,EAAgE;AAC5D,qBAAKb,6BAAL;AACH;;AAED,gBAAI,KAAK5C,KAAL,CAAW0D,cAAX,GAA4B,CAAhC,EAAmC;AAC/B,qBAAKC,YAAL,GAAoB,KAAKvB,KAAL,CAAWC,aAAX,CAAyB,yBAAzB,CAApB;AACA,qBAAK3C,eAAL,CAAqBmD,KAArB,CAA2B9D,GAA3B,GAAiC,UAAjC;AACH;;AAED,gBAAImE,UAAUQ,cAAV,GAA2B,KAAK1D,KAAL,CAAW0D,cAA1C,EAA0D;AACtD,qBAAKE,QAAL,CAAc;AACV1D,gCAAYC,KAAKC,GAAL;AADF,iBAAd;AAGH;;AAED;AACA,gBACI,KAAKJ,KAAL,CAAWQ,UAAX,CAAsBiD,MAAtB,GAA+BP,UAAU1C,UAAV,CAAqBiD,MAApD,IACA,KAAKzD,KAAL,CAAW6D,KAAX,KAAqBX,UAAUW,KAD/B,IAEA,KAAK7D,KAAL,CAAW8D,cAAX,KAA8BZ,UAAUY,cAFxC,IAGA,KAAK9D,KAAL,CAAW+D,aAAX,KAA6Bb,UAAUa,aAJ3C,EAKE;AACE,qBAAKd,wBAAL;AACA,oBAAI,KAAKjD,KAAL,CAAWQ,UAAX,CAAsBiD,MAAtB,GAA+BP,UAAU1C,UAAV,CAAqBiD,MAAxD,EAAgE;AAC5D,yBAAK1B,wBAAL;AACH;AACJ;AACD,gBAAI,KAAK/B,KAAL,CAAWQ,UAAX,CAAsBiD,MAAtB,GAA+BP,UAAU1C,UAAV,CAAqBiD,MAApD,IAA8D,KAAKzD,KAAL,CAAWO,OAA7E,EAAsF;AAClF;AACA;AACA,oBAAID,aAAa,EAAjB;AACA,qBAAKN,KAAL,CAAWQ,UAAX,CAAsBC,GAAtB,CAA0B,eAAO;AAC7B,wBAAIC,QAAQC,IAAIC,KAAJ,CAAU,OAAKZ,KAAL,CAAWO,OAArB,EAA8BG,KAA1C;AACA,wBAAIG,OAAO,IAAIV,IAAJ,CAASO,KAAT,CAAX;;AAEA,wBAAIG,gBAAgBV,IAAhB,IAAwBW,SAASD,IAAT,CAA5B,EAA4C;AACxCH,gCAAQA,MAAMK,MAAN,CAAa,CAAb,EAAgB,EAAhB,CAAR;AACH;AACD,wBAAI,CAACT,WAAWU,cAAX,CAA0BN,KAA1B,CAAL,EAAuC;AACnCJ,mCAAWI,KAAX,IAAoB,EAApB;AACH;AACDJ,+BAAWI,KAAX,EAAkBO,IAAlB,CAAuBN,IAAIC,KAA3B;AACH,iBAXD;AAYA,qBAAKgD,QAAL,CAAc,EAAEtD,YAAYA,UAAd,EAAd;AACH;;AAED,iBAAKD,gBAAL,CAAsB,KAAK2D,SAAL,KAAmB,KAAKvB,KAAL,CAAWwB,YAAX,GAA0B,KAAKxB,KAAL,CAAWyB,YAA9E;;AAEA,iBAAKvC,8BAAL;AACH;;AAED;;;;mDAE2B;AAAA;;AACvB,gBAAMwC,YAAY,KAAKnE,KAAL,CAAW6D,KAAX,GAAmB1F,IAAIiG,iBAAvB,GAA2CjG,IAAIkG,WAAjE;AACA,iBAAKC,oBAAL,GAA4B,EAA5B;AACA;AACA,gBAAMC,YAAYC,SAASC,cAAT,CAA2B,KAAKzE,KAAL,CAAW0E,KAAtC,WAAlB;AACA,gBAAMC,aAAaJ,UAAUK,sBAAV,CAAiC,eAAjC,CAAnB;AACA,gBAAID,WAAWlB,MAAX,GAAoB,CAAxB,EAA2B;AACvBoB,sBAAMC,SAAN,CAAgBhG,MAAhB,CAAuBiG,IAAvB,CAA4BJ,UAA5B,EAAwC,qBAAa;AACjD,2BAAKL,oBAAL,CAA0BrD,IAA1B,CACI+D,UAAUC,WAAV,CAAsBA,WAAtB,CAAkCC,SAAlC,GAA8Cf,SADlD;AAGH,iBAJD;AAKH;AACJ;;;yCAmBgBzD,K,EAAO;AACpB,gBAAI,KAAKT,KAAL,CAAWI,gBAAX,KAAgCK,KAApC,EAA2C;AACvC,qBAAKkD,QAAL,CAAc;AACVvD,sCAAkBK;AADR,iBAAd;AAGH;AACJ;;AAED;;;;;;;mCAIWyE,I,EAAM;AACb,gBAAI,KAAKnF,KAAL,CAAWoF,cAAX,CAA0BC,QAA1B,CAAmCF,KAAKG,KAAxC,CAAJ,EAAoD;AAChD,qBAAKtF,KAAL,CAAWuF,QAAX,CACI,KAAKvF,KAAL,CAAWoF,cAAX,CAA0BtG,MAA1B,CAAiC,UAAS0G,MAAT,EAAiB;AAC9C,2BAAOA,WAAWL,KAAKG,KAAvB;AACH,iBAFD,CADJ;AAKH,aAND,MAMO;AACH,qBAAKtF,KAAL,CAAWuF,QAAX,8BAAwB,KAAKvF,KAAL,CAAWoF,cAAnC,IAAmDD,KAAKG,KAAxD;AACH;AACJ;;AAED;;;;;;oCAGY;AACR,gBAAI,KAAKtF,KAAL,CAAWoF,cAAX,CAA0B3B,MAA1B,KAAqC,KAAKzD,KAAL,CAAWQ,UAAX,CAAsBiD,MAA/D,EAAuE;AACnE,qBAAKjC,WAAL;AACH,aAFD,MAEO;AACH,qBAAKD,SAAL;AACH;AACJ;;AAED;;;;;;oCAGY;AACR,iBAAKvB,KAAL,CAAWuF,QAAX,CAAoB,KAAKvF,KAAL,CAAWQ,UAAX,CAAsBC,GAAtB,CAA0B;AAAA,uBAAQ0E,KAAKG,KAAb;AAAA,aAA1B,CAApB;AACH;;AAED;;;;;;sCAGc;AACV,iBAAKtF,KAAL,CAAWuF,QAAX,CAAoB,EAApB;AACH;;AAED;;;;;;;+CAIuBE,K,EAAO;AAC1B;AACA,gBAAIA,MAAMC,MAAN,CAAaC,QAAb,KAA0B,OAA1B,IAAqC,KAAKC,UAAL,KAAoBH,MAAMC,MAAN,CAAaE,UAA1E,EAAsF;AAClF;AACH;;AAED,iBAAKA,UAAL,GAAkBH,MAAMC,MAAN,CAAaE,UAA/B;;AAEA;AACA,iBAAKjE,8BAAL;AACH;;AAED;;;;;;;;;6CAMqB8D,K,EAAO;AACxB;AACA,gBAAIA,MAAMC,MAAN,CAAaC,QAAb,KAA0B,OAA1B,IAAqC,KAAK3B,SAAL,KAAmByB,MAAMC,MAAN,CAAa1B,SAAzE,EAAoF;;AAEpF,gBAAM6B,cAAc,KAAK7B,SAAL,GAAiByB,MAAMC,MAAN,CAAa1B,SAAlD;;AAEA,iBAAKA,SAAL,GAAiByB,MAAMC,MAAN,CAAa1B,SAA9B;;AAEA;AACA,gBAAM8B,eAAe,2CAArB;AACA,iBAAK1D,KAAL,CAAWS,KAAX,CAAiB,YAAjB,IAAiC,KAAKmB,SAAL,GAAiB,CAAjB,GAAqB8B,YAArB,GAAoC,MAArE;AACA,gBAAM3B,YAAY,KAAKnE,KAAL,CAAW6D,KAAX,GAAmB1F,IAAIiG,iBAAvB,GAA2CjG,IAAIkG,WAAjE;;AAEA;AACA;AACA,gBAAI,KAAKrE,KAAL,CAAW0D,cAAX,KAA8B,CAAlC,EAAqC;AACjC,oBAAImC,eAAe,KAAK7B,SAAL,IAAkB7F,IAAI4H,mBAAJ,GAA0B5B,SAA/D,EAA0E;AACtE,yBAAKzE,eAAL,CAAqBmD,KAArB,CAA2B9D,GAA3B,GAAoCoF,YAAY,GAAhD;AACH,iBAFD,MAEO;AACH,yBAAKzE,eAAL,CAAqBmD,KAArB,CAA2B9D,GAA3B,GAAoC,CAAC,KAArC;AACH;AACJ;;AAED,iBAAKgD,wBAAL;;AAEA,iBAAK1B,gBAAL,CACI,KAAK2D,SAAL,KAAmByB,MAAMC,MAAN,CAAazB,YAAb,GAA4B,KAAKxB,KAAL,CAAWyB,YAD9D;AAGH;;;mDAE0B;AAAA;;AACvB,gBAAMK,YAAYC,SAASC,cAAT,CAA2B,KAAKzE,KAAL,CAAW0E,KAAtC,WAAlB;AACA,gBAAMC,aAAaJ,UAAUK,sBAAV,CAAiC,eAAjC,CAAnB;AACA,gBAAMT,YAAY,KAAKnE,KAAL,CAAW6D,KAAX,GAAmB1F,IAAIiG,iBAAvB,GAA2CjG,IAAIkG,WAAjE;AACA,gBAAIM,WAAWlB,MAAX,GAAoB,CAAxB,EAA2B;AACvBoB,sBAAMC,SAAN,CAAgBhG,MAAhB,CAAuBiG,IAAvB,CAA4BJ,UAA5B,EAAwC,UAACK,SAAD,EAAYgB,KAAZ,EAAsB;AAC1D,wBAAMC,SAASjB,UAAUC,WAAzB;AACA,wBAAIV,UAAUP,SAAV,GAAsB,OAAKM,oBAAL,CAA0B0B,KAA1B,CAA1B,EAA4D;AACxD;AACA;AACA,4BACI,OAAOrB,WAAWqB,QAAQ,CAAnB,CAAP,KAAiC,WAAjC,IACAzB,UAAUP,SAAV,GAAsBW,WAAWqB,QAAQ,CAAnB,EAAsBd,SAFhD,EAGE;AACE;AACA;AACA,gCACI,OAAO,OAAKZ,oBAAL,CAA0B0B,QAAQ,CAAlC,CAAP,KAAgD,WAAhD,IACA,OAAK1B,oBAAL,CAA0B0B,QAAQ,CAAlC,IAAuCzB,UAAUP,SAAjD,GACAG,YAAY,EAHhB,EAIE;AACEa,0CAAUnC,KAAV,CAAgB9D,GAAhB,GAAyBwF,UAAUP,SAAV,GACzB,OAAKM,oBAAL,CAA0B0B,QAAQ,CAAlC,CADyB,GAEzBzB,UAAUP,SAFe,GAGzBG,SAHA;AAKH,6BAVD,MAUO;AACHa,0CAAUnC,KAAV,CAAgB9D,GAAhB,GAAyBwF,UAAUP,SAAnC;AACH;;AAED,gCAAIgB,UAAUnC,KAAV,CAAgBvE,QAAhB,KAA6B,UAAjC,EAA6C;AACzC;AACA0G,0CAAUnC,KAAV,CAAgBvE,QAAhB,GAA2B,UAA3B;AACA2H,uCAAOpD,KAAP,CAAaqD,OAAb,GAAuB,cAAvB;AACAlB,0CAAUnC,KAAV,CAAgBpD,MAAhB,GAAyB,OAAKO,KAAL,CAAW6D,KAAX,GAChB1F,IAAIiG,iBAAJ,GAAwB,CADR,UAEhBjG,IAAIkG,WAAJ,GAAkB,CAFF,OAAzB;AAGAW,0CAAU3C,aAAV,CAAwB,QAAxB,EAAkCQ,KAAlC,CAAwCsD,SAAxC,GAAoD,OAAKnG,KAAL,CAAW6D,KAAX,GAC3C1F,IAAIiG,iBAAJ,GAAwB,EADmB,UAE3CjG,IAAIkG,WAAJ,GAAkB,EAFyB,OAApD;AAGAW,0CAAU3C,aAAV,CAAwB,QAAxB,EAAkCQ,KAAlC,CAAwCuD,SAAxC,GAAoD,OAAKpG,KAAL,CAAW6D,KAAX,GAC3C1F,IAAIiG,iBAAJ,GAAwB,EADmB,UAE3CjG,IAAIkG,WAAJ,GAAkB,EAFyB,OAApD;AAGAW,0CAAU3C,aAAV,CAAwB,QAAxB,EAAkCQ,KAAlC,CAAwC9D,GAAxC,GAA8C,MAA9C;AACAiG,0CAAU3C,aAAV,CAAwB,mBAAxB,EAA6CQ,KAA7C,CAAmD9D,GAAnD,GAAyD,CAAC,OAAKiB,KAAL,CACrD6D,KADoD,GAEnD,KAFmD,GAGnD,MAHN;AAIAmB,0CAAU3C,aAAV,CAAwB,IAAxB,EAA8BQ,KAA9B,CAAoCpD,MAApC,GAA6C,OAAKO,KAAL,CAAW6D,KAAX,GACpC1F,IAAIiG,iBAAJ,GAAwB,CADY,UAEpCjG,IAAIkG,WAAJ,GAAkB,CAFkB,OAA7C;AAGA,oCAAI,OAAKrE,KAAL,CAAW6D,KAAf,EAAsB;AAClBmB,8CAAU3C,aAAV,CAAwB,QAAxB,EAAkCQ,KAAlC,CAAwC9D,GAAxC,GAA8C,KAA9C;AACAiG,8CAAU3C,aAAV,CAAwB,aAAxB,EAAuCQ,KAAvC,CAA6CvE,QAA7C,GAAwD,UAAxD;AACA0G,8CAAU3C,aAAV,CAAwB,aAAxB,EAAuCQ,KAAvC,CAA6C9D,GAA7C,GAAmD,MAAnD;AACH;AACJ;AACJ;AACJ,qBAnDD,MAmDO,IAAIiG,UAAUnC,KAAV,CAAgBvE,QAAhB,KAA6B,UAAjC,EAA6C;AAChD;AACA0G,kCAAUnC,KAAV,CAAgBvE,QAAhB,GAA2B,UAA3B;AACA0G,kCAAUnC,KAAV,CAAgB9D,GAAhB,GAAsB,KAAtB;AACAkH,+BAAOpD,KAAP,CAAaqD,OAAb,GAAuB,MAAvB;AACAlB,kCAAUnC,KAAV,CAAgBpD,MAAhB,GAAyB,OAAKO,KAAL,CAAW6D,KAAX,GAChB1F,IAAIiG,iBADY,UAEhBjG,IAAIkG,WAFY,OAAzB;AAGAW,kCAAU3C,aAAV,CAAwB,eAAxB,EAAyCQ,KAAzC,CAA+C9D,GAA/C,GAAqD,KAArD;AACAiG,kCAAU3C,aAAV,CAAwB,mBAAxB,EAA6CQ,KAA7C,CAAmD9D,GAAnD,GAAyD,KAAzD;AACAiG,kCAAU3C,aAAV,CAAwB,IAAxB,EAA8BQ,KAA9B,CAAoCpD,MAApC,GAA6C,OAAKO,KAAL,CAAW6D,KAAX,GACpC1F,IAAIiG,iBADgC,UAEpCjG,IAAIkG,WAFgC,OAA7C;AAGAW,kCAAU3C,aAAV,CAAwB,QAAxB,EAAkCQ,KAAlC,CAAwCsD,SAAxC,GAAoD,OAAKnG,KAAL,CAAW6D,KAAX,GAC3C1F,IAAIiG,iBAAJ,GAAwB,CADmB,UAE3CjG,IAAIkG,WAAJ,GAAkB,CAFyB,OAApD;AAGAW,kCAAU3C,aAAV,CAAwB,QAAxB,EAAkCQ,KAAlC,CAAwCuD,SAAxC,GAAoD,OAAKpG,KAAL,CAAW6D,KAAX,GAC3C1F,IAAIiG,iBAAJ,GAAwB,CADmB,UAE3CjG,IAAIkG,WAAJ,GAAkB,CAFyB,OAApD;AAGA,4BAAI,OAAKrE,KAAL,CAAW6D,KAAf,EAAsB;AAClBmB,sCAAU3C,aAAV,CAAwB,aAAxB,EAAuCQ,KAAvC,CAA6C9D,GAA7C,GAAmD,KAAnD;AACH;AACJ;AACJ,iBA5ED;AA6EH;AACJ;;AAED;;;;;;yDAGiC;AAAA;;AAC7B;AACA,gBAAI,KAAK4E,YAAT,EAAuB;AACnB,qBAAKA,YAAL,CAAkBd,KAAlB,CAAwB7D,IAAxB,GACI,KAAKiD,UAAL,CAAgBoE,WAAhB,GAA8B,CAA9B,GAAkC,GAAlC,GAAwC,KAAKT,UAA7C,GAA0D,IAD9D;AAEH;;AAED;AACA,yCAAI,KAAKU,wBAAT,IAAmC,KAAKhE,gBAAxC,GAA0DiE,OAA1D,CAAkE,mBAAW;AACzEC,wBAAQ3D,KAAR,CAAc7D,IAAd,GAAqB,OAAK4G,UAAL,GAAkB,IAAvC;AACH,aAFD;;AAIA;AACA;AACA;;AAEA;AACA,yCAAI,KAAKa,yBAAT,IAAoC,KAAKlE,iBAAzC,GAA4DgE,OAA5D,CAAoE,mBAAW;AAC3EC,wBAAQ3D,KAAR,CAAc6D,KAAd,GACI5D,KAAK6D,GAAL,CAAS,CAAT,EAAY,OAAK3E,mBAAL,GAA2B,OAAK4D,UAAhC,GAA6C,OAAKgB,mBAA9D,IAAqF,IADzF;AAEH,aAHD;;AAKA;AACA,gBAAI,KAAK5G,KAAL,CAAW6G,MAAf,EAAuB;AACnB,oBAAMC,cAAc,2CAApB;AACA,6CAAI,KAAKvD,kBAAT,IAA6B,KAAKf,UAAlC,GAA8C+D,OAA9C,CAAsD,mBAAW;AAC7DC,4BAAQ3D,KAAR,CAAc7D,IAAd,GAAqB,OAAK4G,UAAL,GAAkB,IAAvC;AACAY,4BAAQ3D,KAAR,CAAc,YAAd,IAA8B,OAAK+C,UAAL,GAAkB,CAAlB,GAAsBkB,WAAtB,GAAoC,MAAlE;AACH,iBAHD;AAIH;;AAED;AACA,gBAAI,KAAKnE,gBAAT,EAA2B;AACvB,qBAAKA,gBAAL,CAAsBE,KAAtB,CAA4B7D,IAA5B,GACI8D,KAAKC,KAAL,CAAW,KAAKd,UAAL,CAAgBE,WAAhB,GAA8B,CAAzC,IAA8C,KAAKyD,UAAnD,GAAgE,IADpE;AAEH;;AAED;AACA,gBAAMrB,YAAYC,SAASC,cAAT,CAA2B,KAAKzE,KAAL,CAAW0E,KAAtC,WAAlB;AACA,gBAAMqC,sBAAsBxC,UAAUK,sBAAV,CAAiC,kBAAjC,CAA5B;AACA,gBAAImC,oBAAoBtD,MAApB,GAA6B,CAAjC,EAAoC;AAChCoB,sBAAMC,SAAN,CAAgBhG,MAAhB,CAAuBiG,IAAvB,CAA4BgC,mBAA5B,EAAiD,eAAO;AACpDC,wBAAInE,KAAJ,CAAU7D,IAAV,GAAoB,OAAKiD,UAAL,CAAgB2D,UAAhB,IACf,OAAK5F,KAAL,CAAWiH,UAAX,GAAwB,EAAxB,GAA6B,CADd,CAApB;AAEH,iBAHD;AAIH;AACJ;;;iDAEwB;AACrB,iBAAKrF,WAAL;AACA,iBAAK5B,KAAL,CAAWkH,gBAAX;AACH;;AAED;;;;;;sCAGc;AACV;AACA,iBAAKxH,eAAL,CAAqB,OAArB,EAA8BX,GAA9B,GAAoC,CAAC,KAAD,GAAS,IAA7C;;AAEA;AACA,iBAAK0D,KAAL,CAAWuB,SAAX,GAAuB,CAAvB;AACA,iBAAKA,SAAL,GAAiB,CAAjB;AACH;;;6CAEoByB,K,EAAO;AACxB,iBAAK7B,QAAL,CAAc;AACVuD,oCAAoB1B,MAAM2B,aADhB;AAEVC,sCAAsB;AAFZ,aAAd;AAIH;;;gDAEuB;AACpB,iBAAKzD,QAAL,CAAc;AACVuD,oCAAoB,IADV;AAEVE,sCAAsB;AAFZ,aAAd;AAIH;;AAED;;;;;;;;;AAYA;;;;;4CAKoBC,c,EAAgB;AAChC,gBAAI,KAAKhD,oBAAL,CAA0Bb,MAA1B,GAAmC,CAAnC,GAAuC6D,cAA3C,EAA2D;AACvD,oBAAM/C,YAAYC,SAASC,cAAT,CAA2B,KAAKzE,KAAL,CAAW0E,KAAtC,WAAlB;AACAH,0BAAUP,SAAV,GAAsB,KAAKM,oBAAL,CAA0BgD,iBAAiB,CAA3C,CAAtB;AACH;AACJ;;;iCAEQ;AAAA;;AAAA,yBAiCD,KAAKtH,KAjCJ;AAAA,gBAEDuH,OAFC,UAEDA,OAFC;AAAA,gBAGD7C,KAHC,UAGDA,KAHC;AAAA,gBAID8C,OAJC,UAIDA,OAJC;AAAA,gBAKDnE,cALC,UAKDA,cALC;AAAA,gBAMD7C,UANC,UAMDA,UANC;AAAA,gBAODiH,SAPC,UAODA,SAPC;AAAA,gBAQDC,oBARC,UAQDA,oBARC;AAAA,gBASDC,iBATC,UASDA,iBATC;AAAA,gBAUDV,UAVC,UAUDA,UAVC;AAAA,gBAWD7B,cAXC,UAWDA,cAXC;AAAA,gBAYDwC,UAZC,UAYDA,UAZC;AAAA,gBAaDC,QAbC,UAaDA,QAbC;AAAA,gBAcD/D,cAdC,UAcDA,cAdC;AAAA,gBAeDC,aAfC,UAeDA,aAfC;AAAA,gBAgBD+D,MAhBC,UAgBDA,MAhBC;AAAA,gBAiBDC,UAjBC,UAiBDA,UAjBC;AAAA,gBAkBDC,cAlBC,UAkBDA,cAlBC;AAAA,gBAmBDC,cAnBC,UAmBDA,cAnBC;AAAA,gBAoBDC,YApBC,UAoBDA,YApBC;AAAA,gBAqBDC,gBArBC,UAqBDA,gBArBC;AAAA,gBAsBDzE,cAtBC,UAsBDA,cAtBC;AAAA,gBAuBD0E,UAvBC,UAuBDA,UAvBC;AAAA,gBAwBDC,YAxBC,UAwBDA,YAxBC;AAAA,gBAyBDxE,KAzBC,UAyBDA,KAzBC;AAAA,gBA0BDpE,MA1BC,UA0BDA,MA1BC;AAAA,gBA2BDoH,MA3BC,UA2BDA,MA3BC;AAAA,gBA4BDyB,YA5BC,UA4BDA,YA5BC;AAAA,gBA6BDC,IA7BC,UA6BDA,IA7BC;AAAA,gBA8BDhI,OA9BC,UA8BDA,OA9BC;AAAA,gBA+BDiI,aA/BC,UA+BDA,aA/BC;AAAA,gBAgCDC,OAhCC,UAgCDA,OAhCC;AAAA,yBAmCgD,KAAKxI,KAnCrD;AAAA,gBAmCGC,UAnCH,UAmCGA,UAnCH;AAAA,gBAmCeG,gBAnCf,UAmCeA,gBAnCf;AAAA,gBAmCiCC,UAnCjC,UAmCiCA,UAnCjC;;;AAqCL,gBAAMoI,eAAe7E,QAAQ1F,IAAIwK,wBAAZ,GAAuCxK,IAAIyK,kBAAhE;;AAEA,mBACI;AAAA;AAAA,kBAAK,WAAWrB,QAAQlJ,IAAxB;AACI;AAAA;AAAA;AACI,4BAAIqG,KADR;AAEI,mCAAW6C,QAAQ5I,YAFvB;AAGI,6BAAK;AAAA,mCAAO,OAAKsD,UAAL,GAAkB+E,GAAzB;AAAA,yBAHT;AAII,kCAAU,KAAKvF;AAJnB;AAMI;AAAA;AAAA,0BAAO,WAAW8F,QAAQrI,KAA1B,EAAiC,OAAO,EAAEO,QAAQA,MAAV,EAAxC;AACI;AACI,qCAAS+H,OADb;AAEI,4CAAgBnE,cAFpB;AAGI,wCAAY7C,UAHhB;AAII,wCAAYyG,UAJhB;AAKI,4CAAgB7B,cALpB;AAMI,sCAAU,KAAK9D,SANnB;AAOI,sCAAUuG,QAPd;AAQI,4CAAgB/D,cARpB;AASI,2CAAeC,aATnB;AAUI,oCAAQ+D,MAVZ;AAWI,wCAAYC,UAXhB;AAYI,4CAAgBC,cAZpB;AAaI,uCAAWP,SAbf;AAcI,kDAAsBC,oBAd1B;AAeI,+CAAmBC,iBAfvB;AAgBI,gDAAoB,KAAK9F,sBAhB7B;AAiBI,4CAAgB6B,cAjBpB;AAkBI,wCAAY0E,UAlBhB;AAmBI,0CAAcC,YAnBlB;AAoBI,mCAAOxE,KApBX;AAqBI,oCAAQ6E,YArBZ;AAsBI,oCAAQ7B,MAtBZ;AAuBI,kCAAM0B,IAvBV;AAwBI,0CAAcD,YAxBlB;AAyBI,2CAAeE;AAzBnB,0BADJ;AA4BI;AACI,mCAAO9D,KADX;AAEI,qCAAS8C,OAFb;AAGI,4CAAgBnE,cAHpB;AAII,wCAAY7C,UAJhB;AAKI,wCAAYyG,UALhB;AAMI,4CAAgB7B,cANpB;AAOI,4CAAgBtB,cAPpB;AAQI,sCAAU,KAAKzC,UARnB;AASI,wCAAYnB,UAThB;AAUI,wCAAYkI,UAVhB;AAWI,0CAAcC,YAXlB;AAYI,mCAAOxE,KAZX;AAaI,oCAAQpE,SAASiJ,YAbrB;AAcI,oCAAQ7B,MAdZ;AAeI,kCAAM0B,IAfV;AAgBI,wCAAYX,UAhBhB;AAiBI,sCAAU,KAAKlG,oBAjBnB;AAkBI,2CAAe,KAAKmH,aAlBxB;AAmBI,0CAAcP,YAnBlB;AAoBI,qCAAS/H,OApBb;AAqBI,yCAAa,KAAKuB,mBArBtB;AAsBI,wCAAYxB,UAtBhB;AAuBI,2CAAekI,aAvBnB;AAwBI,qCAASC;AAxBb,0BA5BJ;AAsDKR,0CACG;AACI,mCAAOvD,KADX;AAEI,0CAAcwD,YAFlB;AAGI,8CAAkBC,gBAHtB;AAII,4CAAgB,CAJpB;AAKI,8CAAkB9H,gBALtB;AAMI,0CAAciI;AANlB;AAvDR,qBANJ;AAwEI;AACI,+BAAO5D,KADX;AAEI,kCAAU,KAAK1E,KAAL,CAAW8I,QAFzB;AAGI,oCAAY,KAAK9I,KAAL,CAAW+I;AAH3B,sBAxEJ;AA8EI;AAAA;AAAA,0BAAK,mCAAiCxB,QAAQhI,wBAA9C;AACI;AAAA;AAAA;AACI,yCAAQ,QADZ;AAEI,uCAAM,SAFV;AAGI,2CAAWgI,QAAQ7H,eAHvB;AAII,yCAAS;AAAA,2CAAM,OAAKkC,WAAL,EAAN;AAAA;AAJb;AAMI,+EAAS,WAAW2F,QAAQ5H,oBAA5B,GANJ;AAOK2I,yCAAaU,WAPlB;AAQI,+EAAS,WAAWzB,QAAQ5H,oBAA5B;AARJ;AADJ;AA9EJ;AADJ,aADJ;AA+FH;;;;EA9zBiB,gBAAMsJ,S;;AAAtBlJ,O,CACKmJ,S,GAAY;AACf;;;AAGA3B,aAAS,oBAAU4B,MAJJ;AAKf;;;AAGA3B,aAAS,oBAAU2B,MAAV,CAAiBC,UARX;AASf;;;AAGA1F,oBAAgB,oBAAU2F,MAZX;AAaf;;;AAGA7I,gBAAY,oBAAU8I,KAAV,CAAgBF,UAhBb;AAiBf;;;AAGAhB,gBAAY,oBAAUmB,MApBP;AAqBf;;;AAGA1F,WAAO,oBAAU2F,IAxBF;AAyBf;;;AAGAzB,gBAAY,oBAAUyB,IA5BP;AA6Bf;;;AAGAjJ,aAAS,oBAAUgJ,MAhCJ;AAiCf;;;AAGArB,kBAAc,oBAAUsB,IApCT;AAqCf;;;AAGA/J,YAAQ,oBAAU4J,MAxCH;AAyCf;;;AAGApB,oBAAgB,oBAAUuB,IA5CX;AA6Cf;;;AAGAf,aAAS,oBAAUe,IAhDJ;AAiDf;;;AAGAhB,mBAAe,oBAAUc,KApDV;AAqDf;;;;AAIA3B,uBAAmB,+CACf,oBAAU4B,MADK,EAEf;AAAA,eAASvJ,MAAMgB,cAAN,CAAqB,WAArB,KAAqChB,MAAMyH,SAAN,KAAoB,IAAlE;AAAA,KAFe,EAGf5H,8BAHe,CAzDJ;AA8Df;;;AAGAwI,kBAAc,oBAAUkB,MAjET;AAkEf;;;AAGA7B,0BAAsB,oBAAU+B,IArEjB;AAsEf;;;;AAIAzB,oBAAgB,oBAAUyB,IA1EX;AA2Ef;;;;;;AAMAV,gBAAY,oBAAUU,IAjFP;AAkFf;;;;AAIA7B,gBAAY,oBAAU6B,IAtFP;AAuFf;;;;;;;;AAQAX,cAAU,oBAAUW,IA/FL;AAgGf;;;;;AAKAlE,cAAU,oBAAUkE,IArGL;AAsGf;;;;AAIA3B,YAAQ,oBAAU2B,IA1GH;AA2Gf;;;;AAIAhC,eAAW,oBAAU+B,IA/GN;AAgHf;;;AAGAnG,oBAAgB,oBAAUiG,KAAV,CAAgBF,UAnHjB;AAoHf;;;AAGAlC,sBAAkB,oBAAUuC,IAvHb;AAwHf;;;AAGAtB,sBAAkB,oBAAUsB,IA3Hb;AA4Hf;;;AAGAxC,gBAAY,oBAAUuC,IA/HP;AAgIf;;;AAGApE,oBAAgB,oBAAUkE,KAnIX;AAoIf;;;AAGAzB,cAAU,oBAAU2B,IAvIL;AAwIf;;;AAGAzF,mBAAe,oBAAU2F,KAAV,CAAgB,CAAC,KAAD,EAAQ,MAAR,CAAhB,CA3IA;AA4If;;;AAGA5F,oBAAgB,+CACZ,oBAAUyF,MADE,EAEZ;AAAA,eAASvJ,MAAMgB,cAAN,CAAqB,UAArB,KAAoChB,MAAM6H,QAAN,KAAmB,IAAhE;AAAA,KAFY,EAGZ/H,2BAHY,CA/ID;AAoJf;;;AAGA+G,YAAQ,oBAAU2C,IAvJH;AAwJf;;;AAGA9E,WAAO,oBAAU6E,MAAV,CAAiBH,UA3JT;AA4Jf;;;AAGAd,kBAAc,oBAAUa,MA/JT;AAgKf;;;;AAIAZ,UAAM,oBAAUmB,KAAV,CAAgB,CAAC,GAAD,EAAM,GAAN,EAAW,GAAX,CAAhB;AApKS,C;AADjB3J,O,CAwKK4J,Y,GAAe;AAClBlC,eAAW,KADO;AAElBR,gBAAY,KAFM;AAGlBY,cAAU,IAHQ;AAIlB9D,mBAAe,KAJG;AAKlBgE,gBAAY,IALM;AAMlBE,oBAAgB,KANE;AAOlBC,kBAAc,KAPI;AAQlBxE,oBAAgB,CARE;AASlB0E,gBAAY,OATM;AAUlBC,kBAAc,OAVI;AAWlBxE,WAAO,KAXW;AAYlBpE,YAAQ,GAZU;AAalBoH,YAAQ,IAbU;AAclByB,kBAAc;AACVsB,mBAAW,WADD;AAEVZ,qBAAa,aAFH;AAGVa,6BAAqB,kBAHX;AAIVC,qCAA6B,2BAJnB;AAKVC,gBAAQ,QALE;AAMVC,cAAM,MANI;AAOVhF,mBAAW;AACPiF,oBAAQ;AACJC,sBAAM;AADF;AADD;AAPD,KAdI;AA2BlB3B,UAAM,GA3BY;AA4BlBC,mBAAe,EA5BG;AA6BlBC,aAAS;AA7BS,C;;;;;SAoFtBxG,U,GAAa,0C;SACbkI,Y,GAAe,C;SACf/H,K,GAAQ,0C;SACRE,gB,GAAmB,0C;SACnBC,iB,GAAoB,0C;SACpBC,U,GAAa,0C;SACbC,K,GAAQ,0C;SACRmE,mB,GAAsB,C;SACtBN,wB,GAA2B,E;SAC3BG,yB,GAA4B,E;SAC5BlD,kB,GAAqB,E;SACrBb,K,GAAQ,0C;SACRC,gB,GAAmB,0C;SACnBjD,e,GAAkB,I;SAClBiE,Y,GAAe,I;SACfK,S,GAAY,C;SACZ4B,U,GAAa,C;SACbtB,oB,GAAuB,E;;SAsHvB1B,6B,GAAgC,YAAM;AAClC,eAAKgE,mBAAL,GAA2B,OAAKnE,KAAL,CAAWN,WAAX,GAAyB,OAAKM,KAAL,CAAW4D,WAA/D;;AAEA,YAAI,OAAKjE,KAAL,IAAc,OAAKwE,mBAAL,GAA2B,CAA7C,EAAgD;AAC5C,mBAAKxE,KAAL,CAAWS,KAAX,CAAiB1D,KAAjB,GAAyB,iBAAiB,OAAKyH,mBAAtB,GAA4C,KAArE;AACH;;AAED,eAAKN,wBAAL,GAAgC,OAAK7D,KAAL,CAAWe,gBAAX,CAC5B,gDAD4B,CAAhC;AAGA,eAAKiD,yBAAL,GAAiC,OAAKhE,KAAL,CAAWe,gBAAX,CAC7B,yDAD6B,CAAjC;;AAIA,eAAKD,kBAAL,GAA0B,OAAKd,KAAL,CAAWe,gBAAX,CAA4B,oBAA5B,CAA1B;AACH,K;;SAkRDqF,a,GAAgB,YAAM;AAClB;AACAuB,mBAAW,YAAM;AACb,mBAAKxH,6BAAL;AACA,mBAAKjB,8BAAL;AACH,SAHD,EAGG,EAHH;AAIH,K;;;kBAuJU,wBAAWvD,MAAX,EAAmB,EAAEiM,WAAW,IAAb,EAAmBC,MAAM,aAAzB,EAAnB,EAA6DvK,OAA7D,C","file":"HiTable.js","sourceRoot":"/home/mfazio/dev/projects/hipay-material-ui","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport Table from 'material-ui/Table';\nimport ArrowUp from 'mdi-material-ui/ArrowUp';\nimport isRequiredIf from 'react-proptype-conditional-require';\nimport HiButton from '../HiButton';\n\nimport { withStyles, withTheme } from '../styles';\nimport HiTableHead from './HiTableHead';\nimport HiTableBody from './HiTableBody';\nimport HiTableFooterScroll from './HiTableFooterScroll';\nimport * as cst from './constants';\nimport HiTableContextMenu from './HiTableContextMenu';\n\nexport const styles = theme => ({\n    root: {\n        position: 'relative',\n        backgroundColor: theme.palette.background3,\n    },\n    tableWrapper: {\n        overflowX: 'auto',\n        overflowY: 'hidden',\n    },\n    filter: {\n        position: 'relative',\n        top: 2,\n        left: 2,\n        cursor: 'pointer',\n    },\n    table: {\n        position: 'relative',\n        width: '100%',\n        overflow: 'hidden',\n        borderCollapse: 'collapse',\n        backgroundColor: theme.palette.background3,\n        zIndex: 10,\n    },\n    backToTopButtonContainer: {\n        position: 'absolute',\n        width: '100%',\n        textAlign: 'center',\n        height: 48,\n        top: -99999,\n    },\n    backToTopButton: {\n        zIndex: 11,\n    },\n    backToTopButtonArrow: {\n        height: 18,\n        width: 18,\n        position: 'relative',\n        top: -2,\n        margin: 2,\n    },\n});\n\nexport const MANDATORY_COLUMN_ERROR_MESSAGE =\n    'Vous devez saisir la propriété \"mandatoryColumnId\" pour les tableaux \"orderable\"';\nexport const SORTED_COLUMN_ERROR_MESSAGE =\n    'Vous devez saisir la propriété \"sortedColumnId\" pour les tableaux \"sortable\"';\n\n/**\n * Display a list of elements in a table\n * The click on FilterVariant opens a menu that allows the user\n * to filter by value or to order by a specific column\n *\n * Renderer behaviors:\n * - Widths:\n *      - all cells types have default width size (px) for each kind of view (L/M/S).\n *      - if view isn't set we use the largest one (large).\n *      - cell width can be overriden by column's props.\n *      - if there is not enough space to render all cells,\n *        we use horizontal scroll and cells width are fixed\n *      - if there is enough space, no scroll and only the first cell (column),\n *      which is not explicitly set as unfixed (fixedWidth = false),\n *      has not fixed width and may enlarge his width to fit available space.\n *\n * - Fixed Header:\n *      - header rows should be fixed and always be visible on body scroll.\n *      - vertical scrollbar should be hidden\n *      - if nbRows * cellHeight > tableHeight,\n *        we virtually enlarge the table then crop arbitrary width to hide the scrollbar.\n *      as each browsers may have different scrollbar widths,\n *      it may trouble column header alignment.\n */\nclass HiTable extends React.Component {\n    static propTypes = {\n        /**\n         * Useful to extend the style applied to components.\n         */\n        classes: PropTypes.object,\n        /**\n         * Colonnes du tableau (label, largeur, données, ... )\n         */\n        columns: PropTypes.object.isRequired,\n        /**\n         * Nombre de nouvelles données disponibles (live)\n         */\n        countLiveDatas: PropTypes.number,\n        /**\n         * Tableau des données\n         */\n        dataSource: PropTypes.array.isRequired,\n        /**\n         * Locale utilisé pour le format des dates\n         */\n        dateLocale: PropTypes.string,\n        /**\n         * Densité d'affichage (joue sur la hauteur des lignes)\n         */\n        dense: PropTypes.bool,\n        /**\n         * Active le filtre sur les colonnes filtrables\n         */\n        filterable: PropTypes.bool,\n        /**\n         * Id de la colonne par laquelle sont regroupé les éléments\n         */\n        groupBy: PropTypes.string,\n        /**\n         * Ajoute le loader et le requestNextDatas en fin de tableau (si infiniteScroll activé)\n         */\n        hasNextDatas: PropTypes.bool,\n        /**\n         * Hauteur du tableau (px)\n         */\n        height: PropTypes.number,\n        /**\n         * Ajoute l'infinite scroll\n         */\n        infiniteScroll: PropTypes.bool,\n        /**\n         * État du tableau en cours de chargement des données\n         */\n        loading: PropTypes.bool,\n        /**\n         * Identifiant de la ou des colonnes sur la/lesquelles il y a une 'lookup' search\n         */\n        lookupColumns: PropTypes.array,\n        /**\n         * Pour les tableaux \"orderable\" uniquement : Id de la colonne obligatoire,\n         * elle sera toujours affichée dans le tableau et ne pourra pas être cachée.\n         */\n        mandatoryColumnId: isRequiredIf(\n            PropTypes.string,\n            props => props.hasOwnProperty('orderable') && props.orderable === true,\n            MANDATORY_COLUMN_ERROR_MESSAGE,\n        ),\n        /**\n         * Locale utilisé pour le format des nombres\n         */\n        numberLocale: PropTypes.string,\n        /**\n         * Fonction de callback qui prend en paramètre le tableau des colonnes mis à jour.\n         */\n        onColumnsOrderUpdate: PropTypes.func,\n        /**\n         * Fonction de callback sur le filtre d'une colonne\n         * Passe l'id de la colonne et la liste des id des éléments inclus\n         */\n        onFilterChange: PropTypes.func,\n        /**\n         * Fonction de callback appelée au clic sur l'item redirection\n         * du menu contextuel ouvert au clic droit\n         *\n         * @param {int} id\n         */\n        onRedirect: PropTypes.func,\n        /**\n         * Fonction de callback au click sur une ligne\n         * Passe l'element (row)\n         */\n        onRowClick: PropTypes.func,\n        /**\n         * Fonction de callback appelée au clic sur les items de recherche\n         * du menu contextuel ouvert au clic droit\n         *\n         * @param {string} searched field\n         * @param {string} searched value\n         * @param {string} search type (lookup, exclude)\n         */\n        onSearch: PropTypes.func,\n        /**\n         * Fonction de callback sur la sélection d'une ligne\n         * (ou sélection/déselection de tous dans le header)\n         * Passe la liste des id des lignes sélectionnées (selectedIdList)\n         */\n        onSelect: PropTypes.func,\n        /**\n         * Fonction de callback sur le tri d'une colonne\n         * Passe l'id de la colonne et la direction du tri (ou false si tri par défaut)\n         */\n        onSort: PropTypes.func,\n        /**\n         * L'utilisateur peut changer l'ordre des colonnes,\n         * les afficher ou non, et changer la vue de chaque colonne (small, medium, large).\n         */\n        orderable: PropTypes.bool,\n        /**\n         * Tableau des colonnes affichées (ordonnées, visibles/cachées, l/m/s)\n         */\n        orderedColumns: PropTypes.array.isRequired,\n        /**\n         * Fonction de callback requérant l'affichage des nouvelles données (live)\n         */\n        requestLiveDatas: PropTypes.func,\n        /**\n         * Fonction de callback requérant l'affichage des données suivantes\n         */\n        requestNextDatas: PropTypes.func,\n        /**\n         * [v2 - à venir] Les lignes sont sélectionnables (affichage d'une checkbox)\n         */\n        selectable: PropTypes.bool,\n        /**\n         * Liste des id des lignes sélectionnées\n         */\n        selectedIdList: PropTypes.array,\n        /**\n         * Active le tri sur les colonnes\n         */\n        sortable: PropTypes.bool,\n        /**\n         * Sens du tri\n         */\n        sortDirection: PropTypes.oneOf(['asc', 'desc']),\n        /**\n         * Id de la colonne trié\n         */\n        sortedColumnId: isRequiredIf(\n            PropTypes.string,\n            props => props.hasOwnProperty('sortable') && props.sortable === true,\n            SORTED_COLUMN_ERROR_MESSAGE,\n        ),\n        /**\n         * Fixe la première colonne\n         */\n        sticky: PropTypes.bool,\n        /**\n         * Identifiant unique à spécifier si on utilise plusieurs composants HiTable\n         */\n        tabId: PropTypes.string.isRequired,\n        /**\n         * Traduction des chaînes affichées\n         */\n        translations: PropTypes.object,\n        /**\n         * Taille du tableau (L/M/S),\n         * définit l'espace entre les cellules et leurs tailles par default\n         */\n        view: PropTypes.oneOf(['l', 'm', 's']),\n    };\n\n    static defaultProps = {\n        orderable: false,\n        selectable: false,\n        sortable: true,\n        sortDirection: 'asc',\n        filterable: true,\n        infiniteScroll: false,\n        hasNextDatas: false,\n        countLiveDatas: 0,\n        dateLocale: 'en-EN',\n        numberLocale: 'en-EN',\n        dense: false,\n        height: 450,\n        sticky: true,\n        translations: {\n            load_more: 'Load More',\n            back_to_top: 'Back to top',\n            get_the_n_new_items: 'See %s new items',\n            choose_and_organize_columns: 'Choose & organize columns',\n            search: 'Search',\n            time: 'Time',\n            stickyRow: {\n                button: {\n                    next: 'Next day',\n                },\n            },\n        },\n        view: 'l',\n        lookupColumns: [],\n        loading: false,\n    };\n\n    constructor(props) {\n        super(props);\n\n        this.state = {\n            dateUpdate: Date.now(),\n            isScrollToBottom: false,\n            groupByIds: {},\n        };\n\n        // create associative array (object) with sticky row key & its values\n        // => used for sticky row badges\n        if (props.groupBy) {\n            props.dataSource.map(row => {\n                let value = row.datas[props.groupBy].value;\n                let date = new Date(value);\n\n                if (date instanceof Date && isFinite(date)) {\n                    value = value.substr(0, 10);\n                }\n                if (!this.state.groupByIds.hasOwnProperty(value)) {\n                    this.state.groupByIds[value] = [];\n                }\n                this.state.groupByIds[value].push(row.datas);\n            });\n        }\n\n        // Orderable\n        this.openOrderColumnsMenu = this.openOrderColumnsMenu.bind(this);\n        this.closeOrderColumnsMenu = this.closeOrderColumnsMenu.bind(this);\n\n        // Selectable\n        this.toggleItem = this.toggleItem.bind(this);\n        this.toggleAll = this.toggleAll.bind(this);\n        this.selectAll = this.selectAll.bind(this);\n        this.deselectAll = this.deselectAll.bind(this);\n\n        // Manage scrolling\n        this.handleHorizontalScroll = this.handleHorizontalScroll.bind(this);\n        this.handleVerticalScroll = this.handleVerticalScroll.bind(this);\n        this.placeHorizontalFloatingElement = this.placeHorizontalFloatingElement.bind(this);\n        this.scrollToTop = this.scrollToTop.bind(this);\n\n        this.isScrollToBottom = this.isScrollToBottom.bind(this);\n        this.handleRequestLiveDatas = this.handleRequestLiveDatas.bind(this);\n        this.handleNextStickyRow = this.handleNextStickyRow.bind(this);\n        this.handleStickyRowPositions = this.handleStickyRowPositions.bind(this);\n    }\n\n    /**\n     * DOM references\n     * use to replace element on horizontal & vertical scroll\n     */\n    wrapperDiv = <div />;\n    wrapperWidth = 0;\n    tHead = <div />;\n    tHeadLeftPadding = <div />;\n    tHeadRightPadding = <div />;\n    tHeadFirst = <div />;\n    tBody = <div />;\n    tBodyScrollbarWidth = 0;\n    tBodyLeftPaddingElements = [];\n    tBodyRightPaddingElements = [];\n    tBodyFirstElements = [];\n    tFoot = <div />;\n    tFootCenteredDiv = <div />;\n    backToTopButton = null;\n    liveDataSpan = null;\n    scrollTop = 0;\n    scrollLeft = 0;\n    groupByRowsPositions = [];\n\n    /** Lifecycle methods */\n\n    componentDidMount() {\n        this.wrapperScrollOffset = this.wrapperDiv.scrollWidth - this.wrapperDiv.offsetWidth;\n\n        // Set DOM references\n        this.tHead = this.wrapperDiv.querySelector('table thead');\n        this.tHeadLeftPadding = this.tHead.querySelector('tr th:nth-child(1)');\n        this.tHeadRightPadding = this.tHead.querySelector('tr th:nth-last-child(1)');\n        this.tHeadFirst = this.tHead.querySelector('tr th:nth-child(2)');\n        this.tBody = this.wrapperDiv.querySelector('table tbody');\n        this.tFoot = this.wrapperDiv.querySelector('table tfoot');\n        this.tFootCenteredDiv = this.wrapperDiv.querySelector('table tfoot tr td div');\n        this.backToTopButton = this.wrapperDiv.querySelector('.back-to-top-button');\n\n        this.updateFloatingBodyElementRefs();\n\n        // Detect if root has horizontal scroll bar\n        if (this.wrapperDiv.scrollWidth > this.wrapperDiv.offsetWidth) {\n            // adapt first column to fixed width\n            if (this.tHeadFirst && this.tHeadFirst.style) {\n                this.tHeadFirst.style.width = 'auto';\n            }\n            // fixed footer width\n            if (this.tFootCenteredDiv && this.tFootCenteredDiv.style) {\n                this.tFootCenteredDiv.style.width = (Math.round(this.wrapperDiv.offsetWidth / 2)) + 'px';\n                this.tFootCenteredDiv.style.position = 'absolute';\n                this.tFootCenteredDiv.style.bottom = '0px';\n            }\n        }\n\n        this.updateStickyRowsPosition();\n\n        this.placeHorizontalFloatingElement();\n    }\n\n    componentDidUpdate(prevProps, prevState, prevContext) {\n        this.wrapperScrollOffset = this.wrapperDiv.scrollWidth - this.wrapperDiv.offsetWidth;\n\n        // If orderedColumns has change, possibly the sticky cells has changed too\n        if (this.props.orderedColumns[0].colId !== prevProps.orderedColumns[0].colId) {\n            this.tHeadFirst = this.tHead.querySelector('tr th:nth-child(2)');\n            this.tBodyFirstElements = this.wrapperDiv.querySelectorAll(\n                'table tbody tr td:nth-child(2)',\n            );\n        }\n\n        // If there is new rows, update tbody first element list and left padding cells\n        if (this.props.dataSource.length > prevProps.dataSource.length) {\n            this.updateFloatingBodyElementRefs();\n        }\n\n        if (this.props.countLiveDatas > 0) {\n            this.liveDataSpan = this.tHead.querySelector('tr:nth-child(2) th span');\n            this.backToTopButton.style.top = '-99999px';\n        }\n\n        if (prevProps.countLiveDatas > this.props.countLiveDatas) {\n            this.setState({\n                dateUpdate: Date.now(),\n            });\n        }\n\n        // Only if needed\n        if (\n            this.props.dataSource.length > prevProps.dataSource.length ||\n            this.props.dense !== prevProps.dense ||\n            this.props.sortedColumnId !== prevProps.sortedColumnId ||\n            this.props.sortDirection !== prevProps.sortDirection\n        ) {\n            this.updateStickyRowsPosition();\n            if (this.props.dataSource.length > prevProps.dataSource.length) {\n                this.handleStickyRowPositions();\n            }\n        }\n        if (this.props.dataSource.length > prevProps.dataSource.length && this.props.groupBy) {\n            // create associative array (object) with sticky row key & its values\n            // => used for sticky row badges\n            let groupByIds = {};\n            this.props.dataSource.map(row => {\n                let value = row.datas[this.props.groupBy].value;\n                let date = new Date(value);\n\n                if (date instanceof Date && isFinite(date)) {\n                    value = value.substr(0, 10);\n                }\n                if (!groupByIds.hasOwnProperty(value)) {\n                    groupByIds[value] = [];\n                }\n                groupByIds[value].push(row.datas);\n            });\n            this.setState({ groupByIds: groupByIds });\n        }\n\n        this.isScrollToBottom(this.scrollTop === this.tBody.scrollHeight - this.tBody.offsetHeight);\n\n        this.placeHorizontalFloatingElement();\n    }\n\n    /**    END Lifecycle methods   */\n\n    updateStickyRowsPosition() {\n        const rowHeight = this.props.dense ? cst.CELL_HEIGHT_DENSE : cst.CELL_HEIGHT;\n        this.groupByRowsPositions = [];\n        // Initialize new stickyRows position\n        const tableBody = document.getElementById(`${this.props.tabId}-body`);\n        const stickyRows = tableBody.getElementsByClassName('stickyGroupBy');\n        if (stickyRows.length > 0) {\n            Array.prototype.filter.call(stickyRows, stickyRow => {\n                this.groupByRowsPositions.push(\n                    stickyRow.nextSibling.nextSibling.offsetTop - rowHeight,\n                );\n            });\n        }\n    }\n\n    updateFloatingBodyElementRefs = () => {\n        this.tBodyScrollbarWidth = this.tBody.offsetWidth - this.tBody.clientWidth;\n\n        if (this.tHead && this.tBodyScrollbarWidth > 0) {\n            this.tHead.style.width = 'calc(100% - ' + this.tBodyScrollbarWidth + 'px)';\n        }\n\n        this.tBodyLeftPaddingElements = this.tBody.querySelectorAll(\n            'tr td:nth-child(1), .floating-parent-row-label',\n        );\n        this.tBodyRightPaddingElements = this.tBody.querySelectorAll(\n            'tr td:nth-last-child(1), .floating-parent-row-indicator',\n        );\n\n        this.tBodyFirstElements = this.tBody.querySelectorAll('tr td:nth-child(2)');\n    };\n\n    isScrollToBottom(value) {\n        if (this.state.isScrollToBottom !== value) {\n            this.setState({\n                isScrollToBottom: value,\n            });\n        }\n    }\n\n    /**\n     * Ajoute / Supprime l'id de l'item du selectedIdList\n     * @param item\n     */\n    toggleItem(item) {\n        if (this.props.selectedIdList.includes(item.rowId)) {\n            this.props.onSelect(\n                this.props.selectedIdList.filter(function(itemId) {\n                    return itemId !== item.rowId;\n                }),\n            );\n        } else {\n            this.props.onSelect([...this.props.selectedIdList, item.rowId]);\n        }\n    }\n\n    /**\n     * Sélectionne / Déselectionne tous les éléments en fonction de l'état de la liste\n     */\n    toggleAll() {\n        if (this.props.selectedIdList.length === this.props.dataSource.length) {\n            this.deselectAll();\n        } else {\n            this.selectAll();\n        }\n    }\n\n    /**\n     * Sélectionne tous les items\n     */\n    selectAll() {\n        this.props.onSelect(this.props.dataSource.map(item => item.rowId));\n    }\n\n    /**\n     * Désélectionne tous les items\n     */\n    deselectAll() {\n        this.props.onSelect([]);\n    }\n\n    /**\n     * Handle horizontal scroll (wrapperDiv)\n     * - replace each first cells body & header & add right shadows\n     */\n    handleHorizontalScroll(event) {\n        // cancel if scroll is from tbody OR it didn't change\n        if (event.target.nodeName === 'TBODY' || this.scrollLeft === event.target.scrollLeft) {\n            return;\n        }\n\n        this.scrollLeft = event.target.scrollLeft;\n\n        // Replace live datas notification\n        this.placeHorizontalFloatingElement();\n    }\n\n    /**\n     * Handle vertical scroll (tbody)\n     * - add bottom shadow\n     * - place back to top button\n     * - request next datas if reach bottom\n     */\n    handleVerticalScroll(event) {\n        // cancel if scroll is not from tbody OR it didn't change\n        if (event.target.nodeName !== 'TBODY' || this.scrollTop === event.target.scrollTop) return;\n\n        const scrollingUp = this.scrollTop > event.target.scrollTop;\n\n        this.scrollTop = event.target.scrollTop;\n\n        // Add bottom shadow to header row\n        const shadowBottom = '0px 0px 2px 0px rgba(128, 128, 128, 0.32)';\n        this.tHead.style['box-shadow'] = this.scrollTop > 0 ? shadowBottom : 'none';\n        const rowHeight = this.props.dense ? cst.CELL_HEIGHT_DENSE : cst.CELL_HEIGHT;\n\n        // Add back to top button when scrolling up from constant defined scroll point\n        // if there not live data notification\n        if (this.props.countLiveDatas === 0) {\n            if (scrollingUp && this.scrollTop >= cst.NB_ROWS_BACK_TO_TOP * rowHeight) {\n                this.backToTopButton.style.top = `${rowHeight * 1.5} px`;\n            } else {\n                this.backToTopButton.style.top = `${-99999}px`;\n            }\n        }\n\n        this.handleStickyRowPositions();\n\n        this.isScrollToBottom(\n            this.scrollTop === event.target.scrollHeight - this.tBody.offsetHeight,\n        );\n    }\n\n    handleStickyRowPositions() {\n        const tableBody = document.getElementById(`${this.props.tabId}-body`);\n        const stickyRows = tableBody.getElementsByClassName('stickyGroupBy');\n        const rowHeight = this.props.dense ? cst.CELL_HEIGHT_DENSE : cst.CELL_HEIGHT;\n        if (stickyRows.length > 0) {\n            Array.prototype.filter.call(stickyRows, (stickyRow, index) => {\n                const fakeTr = stickyRow.nextSibling;\n                if (tableBody.scrollTop > this.groupByRowsPositions[index]) {\n                    // Calcul de la position du 'pinned' item\n                    // positionnement juste en dessous du header\n                    if (\n                        typeof stickyRows[index + 1] === 'undefined' ||\n                        tableBody.scrollTop < stickyRows[index + 1].offsetTop\n                    ) {\n                        // Si la prochaine ligne est aussi un 'pinned' item,\n                        // il pousse le précédent vers le haut\n                        if (\n                            typeof this.groupByRowsPositions[index + 1] !== 'undefined' &&\n                            this.groupByRowsPositions[index + 1] - tableBody.scrollTop <\n                            rowHeight - 10\n                        ) {\n                            stickyRow.style.top = `${tableBody.scrollTop +\n                            this.groupByRowsPositions[index + 1] -\n                            tableBody.scrollTop -\n                            rowHeight}\n                                px`;\n                        } else {\n                            stickyRow.style.top = `${tableBody.scrollTop}px`;\n                        }\n\n                        if (stickyRow.style.position !== 'absolute') {\n                            // Repositionnement des éléments dans une row en position absolute\n                            stickyRow.style.position = 'absolute';\n                            fakeTr.style.display = 'inline-block';\n                            stickyRow.style.height = this.props.dense\n                                ? `${cst.CELL_HEIGHT_DENSE - 8}px`\n                                : `${cst.CELL_HEIGHT - 8}px`;\n                            stickyRow.querySelector('button').style.maxHeight = this.props.dense\n                                ? `${cst.CELL_HEIGHT_DENSE - 16}px`\n                                : `${cst.CELL_HEIGHT - 16}px`;\n                            stickyRow.querySelector('button').style.minHeight = this.props.dense\n                                ? `${cst.CELL_HEIGHT_DENSE - 16}px`\n                                : `${cst.CELL_HEIGHT - 16}px`;\n                            stickyRow.querySelector('button').style.top = '-3px';\n                            stickyRow.querySelector('#stickyRowContent').style.top = !this.props\n                                .dense\n                                ? '4px'\n                                : '-3px';\n                            stickyRow.querySelector('td').style.height = this.props.dense\n                                ? `${cst.CELL_HEIGHT_DENSE - 8}px`\n                                : `${cst.CELL_HEIGHT - 8}px`;\n                            if (this.props.dense) {\n                                stickyRow.querySelector('button').style.top = '0px';\n                                stickyRow.querySelector('button span').style.position = 'relative';\n                                stickyRow.querySelector('button span').style.top = '-4px';\n                            }\n                        }\n                    }\n                } else if (stickyRow.style.position !== 'relative') {\n                    // Repositionnement normal\n                    stickyRow.style.position = 'relative';\n                    stickyRow.style.top = '0px';\n                    fakeTr.style.display = 'none';\n                    stickyRow.style.height = this.props.dense\n                        ? `${cst.CELL_HEIGHT_DENSE}px`\n                        : `${cst.CELL_HEIGHT}px`;\n                    stickyRow.querySelector('#sticky-badge').style.top = '0px';\n                    stickyRow.querySelector('#stickyRowContent').style.top = '2px';\n                    stickyRow.querySelector('td').style.height = this.props.dense\n                        ? `${cst.CELL_HEIGHT_DENSE}px`\n                        : `${cst.CELL_HEIGHT}px`;\n                    stickyRow.querySelector('button').style.maxHeight = this.props.dense\n                        ? `${cst.CELL_HEIGHT_DENSE - 2}px`\n                        : `${cst.CELL_HEIGHT - 8}px`;\n                    stickyRow.querySelector('button').style.minHeight = this.props.dense\n                        ? `${cst.CELL_HEIGHT_DENSE - 2}px`\n                        : `${cst.CELL_HEIGHT - 8}px`;\n                    if (this.props.dense) {\n                        stickyRow.querySelector('button span').style.top = '0px';\n                    }\n                }\n            });\n        }\n    }\n\n    /**\n     * Some element must be replace \"manually\"\n     */\n    placeHorizontalFloatingElement() {\n        // live datas notification\n        if (this.liveDataSpan) {\n            this.liveDataSpan.style.left =\n                this.wrapperDiv.clientWidth / 2 - 100 + this.scrollLeft + 'px';\n        }\n\n        // Replace left padding cells\n        [...this.tBodyLeftPaddingElements, this.tHeadLeftPadding].forEach(element => {\n            element.style.left = this.scrollLeft + 'px';\n        });\n\n        // TODO - FIX\n        // Les éléments de droite sont décalés de 22px lorsque de nouvelles lignes sont\n        // visible (children ou details)\n\n        // Replace right padding cells\n        [...this.tBodyRightPaddingElements, this.tHeadRightPadding].forEach(element => {\n            element.style.right =\n                Math.max(0, this.wrapperScrollOffset - this.scrollLeft - this.tBodyScrollbarWidth) + 'px';\n        });\n\n        // Replace first cells & add right shadows\n        if (this.props.sticky) {\n            const shadowRight = '1px 0px 0px 0px rgba(128, 128, 128, 0.32)';\n            [...this.tBodyFirstElements, this.tHeadFirst].forEach(element => {\n                element.style.left = this.scrollLeft + 'px';\n                element.style['box-shadow'] = this.scrollLeft > 0 ? shadowRight : 'none';\n            });\n        }\n\n        // Replace centered elements (elements width should be 50% of wrapper)\n        if (this.tFootCenteredDiv) {\n            this.tFootCenteredDiv.style.left =\n                Math.round(this.wrapperDiv.offsetWidth / 4) + this.scrollLeft + 'px';\n        }\n\n        // Replace stickyRowContent\n        const tableBody = document.getElementById(`${this.props.tabId}-body`);\n        const stickyRowContentDiv = tableBody.getElementsByClassName('stickyRowContent');\n        if (stickyRowContentDiv.length > 0) {\n            Array.prototype.filter.call(stickyRowContentDiv, div => {\n                div.style.left = `${this.wrapperDiv.scrollLeft +\n                    (this.props.selectable ? 25 : 0)}px`;\n            });\n        }\n    }\n\n    handleRequestLiveDatas() {\n        this.scrollToTop();\n        this.props.requestLiveDatas();\n    }\n\n    /**\n     * Scroll back to table top\n     */\n    scrollToTop() {\n        // Hide back to top button\n        this.backToTopButton['style'].top = -99999 + 'px';\n\n        // Set scroll top to 0\n        this.tBody.scrollTop = 0;\n        this.scrollTop = 0;\n    }\n\n    openOrderColumnsMenu(event) {\n        this.setState({\n            orderColumnsAnchor: event.currentTarget,\n            orderColumnsMenuOpen: true,\n        });\n    }\n\n    closeOrderColumnsMenu() {\n        this.setState({\n            orderColumnsAnchor: null,\n            orderColumnsMenuOpen: false,\n        });\n    }\n\n    /**\n     * This function is pass to table body to be advised when new rows are dynamically added (ex detail rows)\n     * we can then update our list of floating body elements refs\n     **/\n    addNewRowRefs = () => {\n        // delayed refs getting to let time at new rows to build up\n        setTimeout(() => {\n            this.updateFloatingBodyElementRefs();\n            this.placeHorizontalFloatingElement();\n        }, 10);\n    };\n\n    /**\n     * Scroll jusqu'au prochain stickRow\n     *\n     * @param stickyRowIndex\n     */\n    handleNextStickyRow(stickyRowIndex) {\n        if (this.groupByRowsPositions.length - 1 > stickyRowIndex) {\n            const tableBody = document.getElementById(`${this.props.tabId}-body`);\n            tableBody.scrollTop = this.groupByRowsPositions[stickyRowIndex + 1];\n        }\n    }\n\n    render() {\n        const {\n            classes,\n            tabId,\n            columns,\n            orderedColumns,\n            dataSource,\n            orderable,\n            onColumnsOrderUpdate,\n            mandatoryColumnId,\n            selectable,\n            selectedIdList,\n            onRowClick,\n            sortable,\n            sortedColumnId,\n            sortDirection,\n            onSort,\n            filterable,\n            onFilterChange,\n            infiniteScroll,\n            hasNextDatas,\n            requestNextDatas,\n            countLiveDatas,\n            dateLocale,\n            numberLocale,\n            dense,\n            height,\n            sticky,\n            translations,\n            view,\n            groupBy,\n            lookupColumns,\n            loading,\n        } = this.props;\n\n        const { dateUpdate, isScrollToBottom, groupByIds } = this.state;\n\n        const headerHeight = dense ? cst.CELL_HEADER_HEIGHT_DENSE : cst.CELL_HEADER_HEIGHT;\n\n        return (\n            <div className={classes.root}>\n                <div\n                    id={tabId}\n                    className={classes.tableWrapper}\n                    ref={div => this.wrapperDiv = div}\n                    onScroll={this.handleHorizontalScroll}\n                >\n                    <Table className={classes.table} style={{ height: height }}>\n                        <HiTableHead\n                            columns={columns}\n                            orderedColumns={orderedColumns}\n                            dataSource={dataSource}\n                            selectable={selectable}\n                            selectedIdList={selectedIdList}\n                            onSelect={this.toggleAll}\n                            sortable={sortable}\n                            sortedColumnId={sortedColumnId}\n                            sortDirection={sortDirection}\n                            onSort={onSort}\n                            filterable={filterable}\n                            onFilterChange={onFilterChange}\n                            orderable={orderable}\n                            onColumnsOrderUpdate={onColumnsOrderUpdate}\n                            mandatoryColumnId={mandatoryColumnId}\n                            onRequestLiveDatas={this.handleRequestLiveDatas}\n                            countLiveDatas={countLiveDatas}\n                            dateLocale={dateLocale}\n                            numberLocale={numberLocale}\n                            dense={dense}\n                            height={headerHeight}\n                            sticky={sticky}\n                            view={view}\n                            translations={translations}\n                            lookupColumns={lookupColumns}\n                        />\n                        <HiTableBody\n                            tabId={tabId}\n                            columns={columns}\n                            orderedColumns={orderedColumns}\n                            dataSource={dataSource}\n                            selectable={selectable}\n                            selectedIdList={selectedIdList}\n                            sortedColumnId={sortedColumnId}\n                            onSelect={this.toggleItem}\n                            dateUpdate={dateUpdate}\n                            dateLocale={dateLocale}\n                            numberLocale={numberLocale}\n                            dense={dense}\n                            height={height - headerHeight}\n                            sticky={sticky}\n                            view={view}\n                            onRowClick={onRowClick}\n                            onScroll={this.handleVerticalScroll}\n                            addNewRowRefs={this.addNewRowRefs}\n                            translations={translations}\n                            groupBy={groupBy}\n                            onClickNext={this.handleNextStickyRow}\n                            groupByIds={groupByIds}\n                            lookupColumns={lookupColumns}\n                            loading={loading}\n                        />\n                        {infiniteScroll && (\n                            <HiTableFooterScroll\n                                tabId={tabId}\n                                hasNextDatas={hasNextDatas}\n                                requestNextDatas={requestNextDatas}\n                                maxAutoRequest={3}\n                                isScrollToBottom={isScrollToBottom}\n                                translations={translations}\n                            />\n                        )}\n                    </Table>\n\n                    <HiTableContextMenu\n                        tabId={tabId}\n                        onSearch={this.props.onSearch}\n                        onRedirect={this.props.onRedirect}\n                    />\n\n                    <div className={`back-to-top-button ${classes.backToTopButtonContainer}`}>\n                        <HiButton\n                            variant=\"raised\"\n                            color=\"primary\"\n                            className={classes.backToTopButton}\n                            onClick={() => this.scrollToTop()}\n                        >\n                            <ArrowUp className={classes.backToTopButtonArrow} />\n                            {translations.back_to_top}\n                            <ArrowUp className={classes.backToTopButtonArrow} />\n                        </HiButton>\n                    </div>\n                </div>\n            </div>\n        );\n    }\n}\n\nexport default withStyles(styles, { withTheme: true, name: 'HmuiHiTable' })(HiTable);\n"]}
31046
31045
 
31047
31046
  /***/ }),
31048
31047
  /* 291 */
@@ -32860,7 +32859,8 @@ var styles = exports.styles = function styles(theme) {
32860
32859
  return {
32861
32860
  listItem: {
32862
32861
  padding: 9 + 'px 0px',
32863
- fontWeight: theme.typography.fontWeightRegular
32862
+ fontWeight: theme.typography.fontWeightRegular,
32863
+ maxHeight: 40
32864
32864
  },
32865
32865
  listItemTitle: {
32866
32866
  padding: 9 + 'px 0px',
@@ -32951,6 +32951,11 @@ var styles = exports.styles = function styles(theme) {
32951
32951
  color: '#000000'
32952
32952
  }
32953
32953
  },
32954
+ labelHighlightColored: {
32955
+ '&>strong': {
32956
+ fontWeight: theme.typography.fontWeightMedium
32957
+ }
32958
+ },
32954
32959
  primaryHighlight: {
32955
32960
  fontWeight: theme.typography.fontWeightMedium,
32956
32961
  color: theme.palette.business.primary.normal,
@@ -33042,13 +33047,7 @@ var HiSelectableListItem = function (_React$Component) {
33042
33047
  return _react2.default.createElement(
33043
33048
  'div',
33044
33049
  { className: itemTextClass, 'data-id': item.id },
33045
- item.labelHighlight && _react2.default.createElement('span', {
33046
- className: classes.labelHighlight,
33047
- dangerouslySetInnerHTML: {
33048
- __html: (0, _hiHelpers.escapeHTML)(item.labelHighlight)
33049
- }
33050
- }),
33051
- !item.labelHighlight && _this.getItemLabel(item),
33050
+ _this.getItemLabel(item),
33052
33051
  _react2.default.createElement(
33053
33052
  'span',
33054
33053
  { className: classes.listItemSecondaryText },
@@ -33076,8 +33075,21 @@ var HiSelectableListItem = function (_React$Component) {
33076
33075
  }, {
33077
33076
  key: 'getItemLabel',
33078
33077
  value: function getItemLabel(item) {
33079
- if (item.color) {
33078
+ var classes = this.props.classes;
33079
+
33080
+ if (!item.labelHighlight && item.color && this.props.selected) {
33080
33081
  return _react2.default.createElement(_HiColoredLabel2.default, { color: item.color, label: item.label });
33082
+ } else if (item.labelHighlight) {
33083
+ var mLabel = _react2.default.createElement('span', {
33084
+ className: item.color ? classes.labelHighlightColored : classes.labelHighlight,
33085
+ dangerouslySetInnerHTML: {
33086
+ __html: (0, _hiHelpers.escapeHTML)(item.labelHighlight)
33087
+ }
33088
+ });
33089
+ if (item.color && this.props.selected) {
33090
+ return _react2.default.createElement(_HiColoredLabel2.default, { color: item.color, label: mLabel });
33091
+ }
33092
+ return mLabel;
33081
33093
  }
33082
33094
  return item.label;
33083
33095
  }
@@ -33329,7 +33341,7 @@ HiSelectableListItem.defaultProps = {
33329
33341
  }
33330
33342
  };
33331
33343
  exports.default = (0, _withStyles2.default)(styles, { name: 'HmuiHiSelectableList' })(HiSelectableListItem);
33332
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["src/HiSelectableList/HiSelectableListItem.js"],"names":["styles","listItem","padding","fontWeight","theme","typography","fontWeightRegular","listItemTitle","fontWeightLight","listItemHover","backgroundColor","palette","hover","fontWeightMedium","disabled","color","neutral","light","centered","textAlign","width","selected","childListItem","paddingLeft","spacing","unit","listItemIconChecked","business","primary","normal","listItemContent","whiteSpace","overflow","textOverflow","body1","listItemSecondaryText","body5","marginLeft","listItemInfoText","body4","margin","checkbox","height","fontSize","marginRight","imgListItem","verticalAlign","checkboxIcon","text","icon","nbChildrenIndicator","position","right","body3","labelHighlight","primaryHighlight","textTransform","HiSelectableListItem","props","buildListItem","classes","type","item","nbChildren","translations","effectiveType","childrenIndicator","one_child","replace","n_children","effectiveCheckbox","id","getItemLabel","secondaryLabel","img","itemPrimaryHighlightClass","itemTextClass","__html","state","bind","toggleHover","setState","label","onSelect","indeterminate","parentItemSelectable","parentIcon","hoverIcon","checkedIcon","level","hierarchic","leftPadding","effectiveDisabled","listItemClass","hasChildren","listItemProps","key","className","onMouseEnter","onMouseLeave","button","component","onClick","event","selectable","iconAll","style","iconDisplay","checked","info","Component","propTypes","bool","node","object","isRequired","number","func","parentItem","string","defaultProps","name"],"mappings":"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","file":"HiSelectableListItem.js","sourceRoot":"/home/mfazio/dev/projects/hipay-material-ui","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport classNames from 'classnames';\nimport warning from 'warning';\nimport { CheckboxBlankOutline, CheckboxMarked } from 'mdi-material-ui';\nimport ListItem from 'material-ui/List/ListItem';\nimport HiCheckbox from '../HiCheckbox';\nimport withStyles from '../styles/withStyles';\nimport { escapeHTML } from '../utils/hiHelpers';\nimport HiIconBuilder from '../utils/HiIconBuilder';\nimport HiColoredLabel from '../HiColoredLabel';\n\nexport const styles = theme => ({\n    listItem: {\n        padding: `${9}px 0px`,\n        fontWeight: theme.typography.fontWeightRegular,\n    },\n    listItemTitle: {\n        padding: `${9}px 0px`,\n        fontWeight: theme.typography.fontWeightLight,\n    },\n    listItemHover: {\n        '&:hover:not($disabled)': {\n            backgroundColor: theme.palette.hover,\n            fontWeight: theme.typography.fontWeightMedium,\n        },\n    },\n    disabled: {\n        color: theme.palette.neutral.light,\n        fontWeight: theme.typography.fontWeightLight,\n    },\n    centered: {\n        textAlign: 'center',\n        width: '100%',\n    },\n    selected: {\n        backgroundColor: theme.palette.selected,\n    },\n    childListItem: {\n        paddingLeft: theme.spacing.unit * 2,\n    },\n    listItemIconChecked: {\n        color: theme.palette.business.primary.normal,\n    },\n    listItemContent: {\n        whiteSpace: 'nowrap',\n        overflow: 'hidden',\n        textOverflow: 'ellipsis',\n        ...theme.typography.body1,\n        fontWeight: 'inherit',\n        width: '100%',\n    },\n    listItemSecondaryText: {\n        ...theme.typography.body5,\n        fontWeight: theme.typography.fontWeightLight,\n        marginLeft: theme.spacing.unit,\n        color: theme.palette.neutral.normal,\n    },\n    listItemInfoText: {\n        whiteSpace: 'nowrap',\n        overflow: 'hidden',\n        textOverflow: 'ellipsis',\n        color: theme.palette.neutral.normal,\n        ...theme.typography.body4,\n        fontWeight: theme.typography.fontWeightRegular,\n        textAlign: 'right',\n        margin: '0 8px',\n        width: '-webkit-fill-available',\n    },\n    checkbox: {\n        width: 20,\n        height: 20,\n        fontSize: 20,\n        marginRight: 20,\n        marginLeft: 20,\n    },\n    imgListItem: {\n        width: 24,\n        height: 'auto',\n        marginRight: 8,\n        verticalAlign: 'middle',\n    },\n    checkboxIcon: {\n        width: 20,\n        height: 20,\n        marginLeft: 2,\n        verticalAlign: 'middle',\n        color: theme.palette.text.icon,\n    },\n    icon: {\n        width: 20,\n        height: 20,\n        marginRight: 8,\n        verticalAlign: 'middle',\n        color: theme.palette.text.icon,\n    },\n    nbChildrenIndicator: {\n        position: 'absolute',\n        right: 10,\n        color: theme.palette.neutral.normal,\n        ...theme.typography.body3,\n    },\n    labelHighlight: {\n        '&>strong': {\n            fontWeight: theme.typography.fontWeightMedium,\n            color: '#000000',\n        },\n    },\n    primaryHighlight: {\n        fontWeight: theme.typography.fontWeightMedium,\n        color: theme.palette.business.primary.normal,\n        textTransform: 'uppercase',\n    },\n});\n\n/**\n * Construit un élément de liste sélectionnable (avec checkbox)\n */\nclass HiSelectableListItem extends React.Component {\n    static propTypes = {\n        /**\n         * Affiche une checkbox\n         */\n        checkbox: PropTypes.bool,\n        /**\n         * Icon affiché lorsque l'item est sélectionné\n         */\n        checkedIcon: PropTypes.node,\n        /**\n         * Useful to extend the style applied to components.\n         */\n        classes: PropTypes.object,\n        /**\n         * Applique le style et désactive le click\n         */\n        disabled: PropTypes.bool,\n        /**\n         * Si \"true\", liste avec hierarchie\n         */\n        hierarchic: PropTypes.bool,\n        /**\n         * Icon affiché lorsque l'item n'est pas sélectionné et qu'on le survole\n         */\n        hoverIcon: PropTypes.node,\n        /**\n         * Icon affiché lorsque l'item n'est pas sélectionné\n         */\n        icon: PropTypes.node,\n        /**\n         * Items sélectionné partiellement\n         */\n        indeterminate: PropTypes.bool,\n        /**\n         * Élément dont la structure attendue dépend du type\n         * paramètres requis:\n         * - id: string/number\n         * - label: string\n         */\n        item: PropTypes.object.isRequired,\n        /**\n         * Padding par défaut des éléments\n         */\n        leftPadding: PropTypes.number,\n        /**\n         * Niveau de l'item\n         */\n        level: PropTypes.number,\n        /**\n         * Nombre d'items enfants\n         */\n        nbChildren: PropTypes.number,\n        /**\n         * Fonction de callback à la sélection de l'élément\n         */\n        onSelect: PropTypes.func,\n        /**\n         * Icon affiché lorsqu'un item parent n'est pas sélectionné\n         */\n        parentIcon: PropTypes.node,\n        /**\n         * Affiche l'item en tant qu'item parent d'un groupe\n         */\n        parentItem: PropTypes.bool,\n        /**\n         * Les items parents sont sélectionnables\n         */\n        parentItemSelectable: PropTypes.bool,\n        /**\n         * État de l'élément\n         */\n        selected: PropTypes.bool,\n        /**\n         * Traductions (par défaut en anglais)\n         */\n        translations: PropTypes.object,\n        /**\n         * Type de l'élément\n         */\n        type: PropTypes.string,\n    };\n\n    static defaultProps = {\n        type: 'text',\n        checkbox: false,\n        parentItem: false,\n        selected: false,\n        indeterminate: false,\n        disabled: false,\n        parentItemSelectable: false,\n        nbChildren: 0,\n        icon: <CheckboxBlankOutline style={{ width: 20, height: 20 }} />,\n        parentIcon: <CheckboxBlankOutline style={{ width: 20, height: 20 }} />,\n        hoverIcon: <CheckboxBlankOutline style={{ width: 20, height: 20 }} />,\n        checkedIcon: <CheckboxMarked style={{ width: 20, height: 20 }} />,\n        hierarchic: false,\n        translations: {\n            n_children: '%s items',\n            one_child: '%s item',\n        },\n    };\n\n    constructor(props) {\n        super(props);\n\n        this.state = {\n            hover: false,\n        };\n\n        this.buildListItem = this.buildListItem.bind(this);\n        this.toggleHover = this.toggleHover.bind(this);\n    }\n\n    toggleHover() {\n        this.setState({ hover: !this.state.hover });\n    }\n\n    getItemLabel(item) {\n        if (item.color) {\n            return <HiColoredLabel color={item.color} label={item.label} />;\n        }\n        return item.label;\n    }\n\n    /**\n     * Build list item from type\n     */\n    buildListItem = () => {\n        const { classes, type, item, nbChildren, translations, checkbox } = this.props;\n        const effectiveType = typeof item.type !== 'undefined' ? item.type : type;\n\n        let childrenIndicator = '';\n        if (nbChildren > 0) {\n            childrenIndicator = (\n                <span className={classes.nbChildrenIndicator}>\n                    {nbChildren < 2\n                        ? translations.one_child.replace('%s', nbChildren)\n                        : translations.n_children.replace('%s', nbChildren)}\n                </span>\n            );\n        }\n        switch (effectiveType) {\n            case 'icon':\n                warning(\n                    typeof item.icon !== 'undefined',\n                    'Hipay-Material-UI: item with type icon should have icon parameter',\n                );\n\n                const effectiveCheckbox =\n                    typeof item.checkbox !== 'undefined' ? item.checkbox : checkbox;\n                return (\n                    <div className={classes.listItemContent} data-id={item.id}>\n                        {!effectiveCheckbox && (\n                            <HiIconBuilder icon={item.icon} className={classes.icon} />\n                        )}\n                        {this.getItemLabel(item)}\n                        <span className={classes.listItemSecondaryText}>\n                            {item.secondaryLabel}\n                        </span>\n                        {childrenIndicator}\n                    </div>\n                );\n            case 'image':\n                let img = '';\n                if (typeof item.img !== 'undefined') {\n\n                    img = <img src={item.img} className={classes.imgListItem} />;\n                }\n\n                return (\n                    <div className={classes.listItemContent} data-id={item.id}>\n                        {img}\n                        {this.getItemLabel(item)}\n                        <span className={classes.listItemSecondaryText}>\n                            {item.secondaryLabel}\n                        </span>\n                        {childrenIndicator}\n                    </div>\n                );\n            case 'primary-highlight': // used in DateRangeSelector for Custom item\n                const itemPrimaryHighlightClass = classNames(\n                    classes.listItemContent,\n                    classes.primaryHighlight,\n                );\n\n                return (\n                    <div className={itemPrimaryHighlightClass} data-id={item.id}>\n                        {this.getItemLabel(item)}\n                    </div>\n                );\n            case 'text':\n            default:\n                const itemTextClass = classNames(classes.listItemContent, {\n                    [classes.centered]: item.centered,\n                });\n\n                return (\n                    <div className={itemTextClass} data-id={item.id}>\n                        {item.labelHighlight && (\n                            <span\n                                className={classes.labelHighlight}\n                                dangerouslySetInnerHTML={{\n                                    __html: escapeHTML(item.labelHighlight),\n                                }}\n                            />\n                        )}\n                        {!item.labelHighlight && this.getItemLabel(item)}\n                        <span className={classes.listItemSecondaryText}>\n                            {item.secondaryLabel}\n                        </span>\n                        {childrenIndicator}\n                    </div>\n                );\n        }\n    };\n\n    render() {\n        const {\n            classes,\n            selected,\n            item,\n            onSelect,\n            checkbox,\n            disabled,\n            indeterminate,\n            parentItemSelectable,\n            icon,\n            parentIcon,\n            hoverIcon,\n            checkedIcon,\n            level,\n            hierarchic,\n            leftPadding,\n        } = this.props;\n\n        /**\n         * Item params override inherited props\n         */\n        const effectiveCheckbox = typeof item.checkbox !== 'undefined' ? item.checkbox : checkbox;\n        const effectiveDisabled = typeof item.disabled !== 'undefined' ? item.disabled : disabled;\n\n        // build class\n        let listItemClass = classNames(classes.listItem, classes.listItemHover, {\n            [classes.disabled]: effectiveDisabled,\n            [classes.selected]: selected,\n        });\n        if (item.hasChildren && parentItemSelectable === false) {\n            listItemClass = classNames(classes.listItemTitle);\n        }\n\n        // build props\n        let listItemProps = {\n            key: item.id,\n            className: listItemClass,\n            onMouseEnter: this.toggleHover,\n            onMouseLeave: this.toggleHover,\n        };\n\n        if (!effectiveDisabled) {\n            listItemProps = {\n                ...listItemProps,\n                button: true,\n                component: 'li',\n                onClick: event => onSelect(event, item),\n            };\n        }\n\n        let selectable = true;\n        if (item.hasChildren && parentItemSelectable === false) {\n            selectable = false;\n            listItemProps.onClick = () => {};\n            listItemProps.button = false;\n        }\n\n        let iconAll;\n        if (item.id === '_all' && item.icon) {\n            iconAll = <HiIconBuilder icon={item.icon} className={classes.checkboxIcon} />;\n        }\n\n        // calcul du padding left\n        let paddingLeft = 0;\n\n        if (leftPadding) {\n            paddingLeft = leftPadding;\n        } else {\n            // Si pas de hiérarchie, padding de 8px\n            if (!hierarchic) {\n                if (!effectiveCheckbox) {\n                    paddingLeft = 8;\n                }\n            } else if (selectable) {\n                // Si item selectionnable\n                // Si parent selectionnable\n                if (parentItemSelectable) {\n                    // Si l'item contient une checkbox\n                    if (effectiveCheckbox) {\n                        paddingLeft = 16 * level;\n                    } else {\n                        paddingLeft = 16 * (level + 1);\n                    }\n                } else if (level > 0) {\n                    if (effectiveCheckbox) {\n                        paddingLeft = 16 * (level - 1);\n                    } else {\n                        paddingLeft = 16 * level;\n                    }\n                } else if (!effectiveCheckbox) {\n                    if (item.id === '_all') {\n                        paddingLeft = 16;\n                    } else {\n                        paddingLeft = 16 * level;\n                    }\n                }\n            } else {\n                paddingLeft = 16; // Padding de 16 par défaut\n                if (level > 0) {\n                    paddingLeft = 16 * level;\n                }\n            }\n        }\n\n        listItemProps.style = { paddingLeft: `${paddingLeft}px` };\n\n        let iconDisplay = icon;\n        if (this.state.hover) {\n            iconDisplay = hoverIcon;\n        } else if (item.hasChildren) {\n            iconDisplay = parentIcon;\n        } else if (item.id === '_all') {\n            iconDisplay = iconAll;\n        }\n\n        return (\n            <ListItem {...listItemProps}>\n                {effectiveCheckbox &&\n                    selectable && (\n                        <HiCheckbox\n                            checked={selected}\n                            icon={iconDisplay}\n                            checkedIcon={checkedIcon}\n                            indeterminate={indeterminate}\n                            classes={{ checked: classes.listItemIconChecked }}\n                            className={classes.checkbox}\n                        />\n                    )}\n                {this.buildListItem()}\n                {!!item.info && <span className={classes.listItemInfoText}>{item.info}</span>}\n            </ListItem>\n        );\n    }\n}\n\nexport default withStyles(styles, { name: 'HmuiHiSelectableList' })(HiSelectableListItem);\n"]}
33344
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["src/HiSelectableList/HiSelectableListItem.js"],"names":["styles","listItem","padding","fontWeight","theme","typography","fontWeightRegular","maxHeight","listItemTitle","fontWeightLight","listItemHover","backgroundColor","palette","hover","fontWeightMedium","disabled","color","neutral","light","centered","textAlign","width","selected","childListItem","paddingLeft","spacing","unit","listItemIconChecked","business","primary","normal","listItemContent","whiteSpace","overflow","textOverflow","body1","listItemSecondaryText","body5","marginLeft","listItemInfoText","body4","margin","checkbox","height","fontSize","marginRight","imgListItem","verticalAlign","checkboxIcon","text","icon","nbChildrenIndicator","position","right","body3","labelHighlight","labelHighlightColored","primaryHighlight","textTransform","HiSelectableListItem","props","buildListItem","classes","type","item","nbChildren","translations","effectiveType","childrenIndicator","one_child","replace","n_children","effectiveCheckbox","id","getItemLabel","secondaryLabel","img","itemPrimaryHighlightClass","itemTextClass","state","bind","toggleHover","setState","label","mLabel","__html","onSelect","indeterminate","parentItemSelectable","parentIcon","hoverIcon","checkedIcon","level","hierarchic","leftPadding","effectiveDisabled","listItemClass","hasChildren","listItemProps","key","className","onMouseEnter","onMouseLeave","button","component","onClick","event","selectable","iconAll","style","iconDisplay","checked","info","Component","propTypes","bool","node","object","isRequired","number","func","parentItem","string","defaultProps","name"],"mappings":"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","file":"HiSelectableListItem.js","sourceRoot":"/home/mfazio/dev/projects/hipay-material-ui","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport classNames from 'classnames';\nimport warning from 'warning';\nimport { CheckboxBlankOutline, CheckboxMarked } from 'mdi-material-ui';\nimport ListItem from 'material-ui/List/ListItem';\nimport HiCheckbox from '../HiCheckbox';\nimport withStyles from '../styles/withStyles';\nimport { escapeHTML } from '../utils/hiHelpers';\nimport HiIconBuilder from '../utils/HiIconBuilder';\nimport HiColoredLabel from '../HiColoredLabel';\n\nexport const styles = theme => ({\n    listItem: {\n        padding: `${9}px 0px`,\n        fontWeight: theme.typography.fontWeightRegular,\n        maxHeight: 40,\n    },\n    listItemTitle: {\n        padding: `${9}px 0px`,\n        fontWeight: theme.typography.fontWeightLight,\n    },\n    listItemHover: {\n        '&:hover:not($disabled)': {\n            backgroundColor: theme.palette.hover,\n            fontWeight: theme.typography.fontWeightMedium,\n        },\n    },\n    disabled: {\n        color: theme.palette.neutral.light,\n        fontWeight: theme.typography.fontWeightLight,\n    },\n    centered: {\n        textAlign: 'center',\n        width: '100%',\n    },\n    selected: {\n        backgroundColor: theme.palette.selected,\n    },\n    childListItem: {\n        paddingLeft: theme.spacing.unit * 2,\n    },\n    listItemIconChecked: {\n        color: theme.palette.business.primary.normal,\n    },\n    listItemContent: {\n        whiteSpace: 'nowrap',\n        overflow: 'hidden',\n        textOverflow: 'ellipsis',\n        ...theme.typography.body1,\n        fontWeight: 'inherit',\n        width: '100%',\n    },\n    listItemSecondaryText: {\n        ...theme.typography.body5,\n        fontWeight: theme.typography.fontWeightLight,\n        marginLeft: theme.spacing.unit,\n        color: theme.palette.neutral.normal,\n    },\n    listItemInfoText: {\n        whiteSpace: 'nowrap',\n        overflow: 'hidden',\n        textOverflow: 'ellipsis',\n        color: theme.palette.neutral.normal,\n        ...theme.typography.body4,\n        fontWeight: theme.typography.fontWeightRegular,\n        textAlign: 'right',\n        margin: '0 8px',\n        width: '-webkit-fill-available',\n    },\n    checkbox: {\n        width: 20,\n        height: 20,\n        fontSize: 20,\n        marginRight: 20,\n        marginLeft: 20,\n    },\n    imgListItem: {\n        width: 24,\n        height: 'auto',\n        marginRight: 8,\n        verticalAlign: 'middle',\n    },\n    checkboxIcon: {\n        width: 20,\n        height: 20,\n        marginLeft: 2,\n        verticalAlign: 'middle',\n        color: theme.palette.text.icon,\n    },\n    icon: {\n        width: 20,\n        height: 20,\n        marginRight: 8,\n        verticalAlign: 'middle',\n        color: theme.palette.text.icon,\n    },\n    nbChildrenIndicator: {\n        position: 'absolute',\n        right: 10,\n        color: theme.palette.neutral.normal,\n        ...theme.typography.body3,\n    },\n    labelHighlight: {\n        '&>strong': {\n            fontWeight: theme.typography.fontWeightMedium,\n            color: '#000000',\n        },\n    },\n    labelHighlightColored: {\n        '&>strong': {\n            fontWeight: theme.typography.fontWeightMedium,\n        },\n    },\n    primaryHighlight: {\n        fontWeight: theme.typography.fontWeightMedium,\n        color: theme.palette.business.primary.normal,\n        textTransform: 'uppercase',\n    },\n});\n\n/**\n * Construit un élément de liste sélectionnable (avec checkbox)\n */\nclass HiSelectableListItem extends React.Component {\n    static propTypes = {\n        /**\n         * Affiche une checkbox\n         */\n        checkbox: PropTypes.bool,\n        /**\n         * Icon affiché lorsque l'item est sélectionné\n         */\n        checkedIcon: PropTypes.node,\n        /**\n         * Useful to extend the style applied to components.\n         */\n        classes: PropTypes.object,\n        /**\n         * Applique le style et désactive le click\n         */\n        disabled: PropTypes.bool,\n        /**\n         * Si \"true\", liste avec hierarchie\n         */\n        hierarchic: PropTypes.bool,\n        /**\n         * Icon affiché lorsque l'item n'est pas sélectionné et qu'on le survole\n         */\n        hoverIcon: PropTypes.node,\n        /**\n         * Icon affiché lorsque l'item n'est pas sélectionné\n         */\n        icon: PropTypes.node,\n        /**\n         * Items sélectionné partiellement\n         */\n        indeterminate: PropTypes.bool,\n        /**\n         * Élément dont la structure attendue dépend du type\n         * paramètres requis:\n         * - id: string/number\n         * - label: string\n         */\n        item: PropTypes.object.isRequired,\n        /**\n         * Padding par défaut des éléments\n         */\n        leftPadding: PropTypes.number,\n        /**\n         * Niveau de l'item\n         */\n        level: PropTypes.number,\n        /**\n         * Nombre d'items enfants\n         */\n        nbChildren: PropTypes.number,\n        /**\n         * Fonction de callback à la sélection de l'élément\n         */\n        onSelect: PropTypes.func,\n        /**\n         * Icon affiché lorsqu'un item parent n'est pas sélectionné\n         */\n        parentIcon: PropTypes.node,\n        /**\n         * Affiche l'item en tant qu'item parent d'un groupe\n         */\n        parentItem: PropTypes.bool,\n        /**\n         * Les items parents sont sélectionnables\n         */\n        parentItemSelectable: PropTypes.bool,\n        /**\n         * État de l'élément\n         */\n        selected: PropTypes.bool,\n        /**\n         * Traductions (par défaut en anglais)\n         */\n        translations: PropTypes.object,\n        /**\n         * Type de l'élément\n         */\n        type: PropTypes.string,\n    };\n\n    static defaultProps = {\n        type: 'text',\n        checkbox: false,\n        parentItem: false,\n        selected: false,\n        indeterminate: false,\n        disabled: false,\n        parentItemSelectable: false,\n        nbChildren: 0,\n        icon: <CheckboxBlankOutline style={{ width: 20, height: 20 }} />,\n        parentIcon: <CheckboxBlankOutline style={{ width: 20, height: 20 }} />,\n        hoverIcon: <CheckboxBlankOutline style={{ width: 20, height: 20 }} />,\n        checkedIcon: <CheckboxMarked style={{ width: 20, height: 20 }} />,\n        hierarchic: false,\n        translations: {\n            n_children: '%s items',\n            one_child: '%s item',\n        },\n    };\n\n    constructor(props) {\n        super(props);\n\n        this.state = {\n            hover: false,\n        };\n\n        this.buildListItem = this.buildListItem.bind(this);\n        this.toggleHover = this.toggleHover.bind(this);\n    }\n\n    toggleHover() {\n        this.setState({ hover: !this.state.hover });\n    }\n\n    getItemLabel(item) {\n        const { classes } = this.props;\n        if (!item.labelHighlight && item.color && this.props.selected) {\n            return <HiColoredLabel color={item.color} label={item.label} />;\n        } else if (item.labelHighlight) {\n            const mLabel = (\n                <span\n                    className={item.color ? classes.labelHighlightColored : classes.labelHighlight}\n                    dangerouslySetInnerHTML={{\n                        __html: escapeHTML(item.labelHighlight),\n                    }}\n                />\n            );\n            if (item.color && this.props.selected) {\n                return <HiColoredLabel color={item.color} label={mLabel} />;\n            }\n            return mLabel;\n        }\n        return item.label;\n    }\n\n    /**\n     * Build list item from type\n     */\n    buildListItem = () => {\n        const { classes, type, item, nbChildren, translations, checkbox } = this.props;\n        const effectiveType = typeof item.type !== 'undefined' ? item.type : type;\n\n        let childrenIndicator = '';\n        if (nbChildren > 0) {\n            childrenIndicator = (\n                <span className={classes.nbChildrenIndicator}>\n                    {nbChildren < 2\n                        ? translations.one_child.replace('%s', nbChildren)\n                        : translations.n_children.replace('%s', nbChildren)}\n                </span>\n            );\n        }\n        switch (effectiveType) {\n            case 'icon':\n                warning(\n                    typeof item.icon !== 'undefined',\n                    'Hipay-Material-UI: item with type icon should have icon parameter',\n                );\n\n                const effectiveCheckbox =\n                    typeof item.checkbox !== 'undefined' ? item.checkbox : checkbox;\n                return (\n                    <div className={classes.listItemContent} data-id={item.id}>\n                        {!effectiveCheckbox && (\n                            <HiIconBuilder icon={item.icon} className={classes.icon} />\n                        )}\n                        {this.getItemLabel(item)}\n                        <span className={classes.listItemSecondaryText}>\n                            {item.secondaryLabel}\n                        </span>\n                        {childrenIndicator}\n                    </div>\n                );\n            case 'image':\n                let img = '';\n                if (typeof item.img !== 'undefined') {\n\n                    img = <img src={item.img} className={classes.imgListItem} />;\n                }\n\n                return (\n                    <div className={classes.listItemContent} data-id={item.id}>\n                        {img}\n                        {this.getItemLabel(item)}\n                        <span className={classes.listItemSecondaryText}>\n                            {item.secondaryLabel}\n                        </span>\n                        {childrenIndicator}\n                    </div>\n                );\n            case 'primary-highlight': // used in DateRangeSelector for Custom item\n                const itemPrimaryHighlightClass = classNames(\n                    classes.listItemContent,\n                    classes.primaryHighlight,\n                );\n\n                return (\n                    <div className={itemPrimaryHighlightClass} data-id={item.id}>\n                        {this.getItemLabel(item)}\n                    </div>\n                );\n            case 'text':\n            default:\n                const itemTextClass = classNames(classes.listItemContent, {\n                    [classes.centered]: item.centered,\n                });\n\n                return (\n                    <div className={itemTextClass} data-id={item.id}>\n                        {this.getItemLabel(item)}\n                        <span className={classes.listItemSecondaryText}>\n                            {item.secondaryLabel}\n                        </span>\n                        {childrenIndicator}\n                    </div>\n                );\n        }\n    };\n\n    render() {\n        const {\n            classes,\n            selected,\n            item,\n            onSelect,\n            checkbox,\n            disabled,\n            indeterminate,\n            parentItemSelectable,\n            icon,\n            parentIcon,\n            hoverIcon,\n            checkedIcon,\n            level,\n            hierarchic,\n            leftPadding,\n        } = this.props;\n\n        /**\n         * Item params override inherited props\n         */\n        const effectiveCheckbox = typeof item.checkbox !== 'undefined' ? item.checkbox : checkbox;\n        const effectiveDisabled = typeof item.disabled !== 'undefined' ? item.disabled : disabled;\n\n        // build class\n        let listItemClass = classNames(classes.listItem, classes.listItemHover, {\n            [classes.disabled]: effectiveDisabled,\n            [classes.selected]: selected,\n        });\n        if (item.hasChildren && parentItemSelectable === false) {\n            listItemClass = classNames(classes.listItemTitle);\n        }\n\n        // build props\n        let listItemProps = {\n            key: item.id,\n            className: listItemClass,\n            onMouseEnter: this.toggleHover,\n            onMouseLeave: this.toggleHover,\n        };\n\n        if (!effectiveDisabled) {\n            listItemProps = {\n                ...listItemProps,\n                button: true,\n                component: 'li',\n                onClick: event => onSelect(event, item),\n            };\n        }\n\n        let selectable = true;\n        if (item.hasChildren && parentItemSelectable === false) {\n            selectable = false;\n            listItemProps.onClick = () => {};\n            listItemProps.button = false;\n        }\n\n        let iconAll;\n        if (item.id === '_all' && item.icon) {\n            iconAll = <HiIconBuilder icon={item.icon} className={classes.checkboxIcon} />;\n        }\n\n        // calcul du padding left\n        let paddingLeft = 0;\n\n        if (leftPadding) {\n            paddingLeft = leftPadding;\n        } else {\n            // Si pas de hiérarchie, padding de 8px\n            if (!hierarchic) {\n                if (!effectiveCheckbox) {\n                    paddingLeft = 8;\n                }\n            } else if (selectable) {\n                // Si item selectionnable\n                // Si parent selectionnable\n                if (parentItemSelectable) {\n                    // Si l'item contient une checkbox\n                    if (effectiveCheckbox) {\n                        paddingLeft = 16 * level;\n                    } else {\n                        paddingLeft = 16 * (level + 1);\n                    }\n                } else if (level > 0) {\n                    if (effectiveCheckbox) {\n                        paddingLeft = 16 * (level - 1);\n                    } else {\n                        paddingLeft = 16 * level;\n                    }\n                } else if (!effectiveCheckbox) {\n                    if (item.id === '_all') {\n                        paddingLeft = 16;\n                    } else {\n                        paddingLeft = 16 * level;\n                    }\n                }\n            } else {\n                paddingLeft = 16; // Padding de 16 par défaut\n                if (level > 0) {\n                    paddingLeft = 16 * level;\n                }\n            }\n        }\n\n        listItemProps.style = { paddingLeft: `${paddingLeft}px` };\n\n        let iconDisplay = icon;\n        if (this.state.hover) {\n            iconDisplay = hoverIcon;\n        } else if (item.hasChildren) {\n            iconDisplay = parentIcon;\n        } else if (item.id === '_all') {\n            iconDisplay = iconAll;\n        }\n\n        return (\n            <ListItem {...listItemProps}>\n                {effectiveCheckbox &&\n                    selectable && (\n                        <HiCheckbox\n                            checked={selected}\n                            icon={iconDisplay}\n                            checkedIcon={checkedIcon}\n                            indeterminate={indeterminate}\n                            classes={{ checked: classes.listItemIconChecked }}\n                            className={classes.checkbox}\n                        />\n                    )}\n                {this.buildListItem()}\n                {!!item.info && <span className={classes.listItemInfoText}>{item.info}</span>}\n            </ListItem>\n        );\n    }\n}\n\nexport default withStyles(styles, { name: 'HmuiHiSelectableList' })(HiSelectableListItem);\n"]}
33333
33345
 
33334
33346
  /***/ }),
33335
33347
  /* 304 */
@@ -35897,6 +35909,10 @@ var styles = exports.styles = function styles(theme) {
35897
35909
  lookedUp: {
35898
35910
  background: 'linear-gradient(0deg, transparent 25%, #FFFF8D 10%, #FFFF8D 75%, transparent 30%)',
35899
35911
  borderRadius: '45%'
35912
+ },
35913
+ pins: {
35914
+ position: 'relative',
35915
+ top: 3
35900
35916
  }
35901
35917
  };
35902
35918
  };
@@ -36011,7 +36027,7 @@ var CellLayout = function (_React$Component) {
36011
36027
  },
36012
36028
  _react2.default.createElement(
36013
36029
  _HiPins2.default,
36014
- { color: theme.palette.business.primary.normal },
36030
+ { color: theme.palette.business.primary.normal, className: classes.pins },
36015
36031
  childrenCount
36016
36032
  )
36017
36033
  )
@@ -36095,7 +36111,7 @@ CellLayout.defaultProps = {
36095
36111
  padding: 8
36096
36112
  };
36097
36113
  exports.default = (0, _styles.withStyles)(styles, { withTheme: true, name: 'HmuiCellLayout' })(CellLayout);
36098
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["src/HiTable/BodyCells/CellLayout.js"],"names":["cst","styles","root","padding","backgroundColor","border","flexContent","display","flexDirection","justifyContent","position","checkbox","float","lookedUp","background","borderRadius","CellLayout","nextProps","nextState","nextContext","selected","props","selectable","classes","type","children","align","ALIGN_RIGHT_TYPES","includes","view","dense","width","DEFAULT_WIDTHS","fixedWidth","sticky","onSelect","childrenCount","theme","offset","_width","lookedUpClassName","maxWidth","minWidth","zIndex","textAlign","height","CELL_HEIGHT_DENSE","CELL_HEIGHT","margin","paddingLeft","paddingRight","top","right","palette","business","primary","normal","Component","propTypes","element","object","bool","string","isRequired","oneOf","number","func","defaultProps","withTheme","name"],"mappings":"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","file":"CellLayout.js","sourceRoot":"/home/mfazio/dev/projects/hipay-material-ui","sourcesContent":["\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport TableCell from 'material-ui/Table/TableCell';\nimport classNames from 'classnames';\n\nimport HiCheckbox from '../../HiCheckbox';\nimport { withStyles } from '../../styles';\nimport * as cst from '../constants';\nimport HiPins from '../../HiPins';\n\nexport const styles = theme => ({\n    root: {\n        padding: 0,\n        backgroundColor: 'inherit',\n        border: 'none',\n    },\n    flexContent: {\n        display: 'flex',\n        flexDirection: 'column',\n        justifyContent: 'center',\n        position: 'relative',\n    },\n    checkbox: {\n        float: 'left',\n        position: 'relative',\n    },\n    lookedUp: {\n        background: `linear-gradient(0deg, transparent 25%, #FFFF8D 10%, #FFFF8D 75%, transparent 30%)`,\n        borderRadius: '45%',\n    },\n});\n\n/**\n * Construit une cellule du body d'AdvancedTable\n * Définit la largeur et le padding effectif\n * Intègre la checkbox de sélection si besoin\n * Gère le comportement sticky\n */\nclass CellLayout extends React.Component {\n\n    static propTypes = {\n        /**\n         * Contenu de la cellule\n         */\n        children: PropTypes.element,\n        /**\n         * Useful to extend the style applied to components.\n         */\n        classes: PropTypes.object,\n        /**\n         * Densité, défini la hauteur de la ligne\n         */\n        dense: PropTypes.bool,\n        /**\n         * Recherche lookup sur cette colonne\n         */\n        lookedUp: PropTypes.bool,\n        /**\n         * Type de cellule\n         */\n        type: PropTypes.string.isRequired,\n        /**\n         * View (L/M/S)\n         */\n        view: PropTypes.oneOf(['l', 'm', 's']),\n        /**\n         * Largeur de la cellule (hors padding), est déduit de view par défaut\n         */\n        width: PropTypes.number,\n        /**\n         * La largeur de la cellule est fixé (toutes les colonnes sauf une)\n         */\n        fixedWidth: PropTypes.bool,\n        /**\n         * Title alignement, est déduit de type par défaut\n         */\n        align: PropTypes.string,\n        /**\n         * Padding de la cellule (px)\n         */\n        padding: PropTypes.number,\n        /**\n         * True si la colonne est la première colonne et doit avoir un comportement \"sticky\" lors du scroll horizontal\n         */\n        sticky: PropTypes.bool,\n        /**\n         * Ajoute une checkbox\n         */\n        selectable: PropTypes.bool,\n        /**\n         * État de la checkbox\n         */\n        selected: PropTypes.oneOf([true, false, 'mixed']),\n        /**\n         * Fonction de callback au click du select\n         */\n        onSelect: PropTypes.func,\n        /**\n         * Nombre d'enfants\n         */\n        childrenCount: PropTypes.number,\n    };\n\n    static defaultProps = {\n        view: 'l',\n        selectable: false,\n        selected: false,\n        dense: false,\n        fixedWidth: false,\n        sticky: false,\n        padding: 8,\n    };\n\n    /**\n     * * Should not update if selected has changed but cell isn't selectable anyway\n     * @param nextProps\n     * @param nextState\n     * @param nextContext\n     * @returns {boolean}\n     */\n    shouldComponentUpdate(nextProps, nextState, nextContext) {\n        if ( nextProps.selected === !this.props.selected && !this.props.selectable && !nextProps.selectable ) {\n            return false;\n        }\n        return true;\n    }\n\n    render () {\n        const {\n            classes, type, children,\n            align = cst.ALIGN_RIGHT_TYPES.includes(type) ? 'right' : 'left',\n            view, dense, width = cst.DEFAULT_WIDTHS[type][view], fixedWidth, sticky,\n            selectable, selected, onSelect, childrenCount, theme, padding,\n            lookedUp\n        } = this.props;\n\n        let offset = selectable ? dense ? 32 : 40 : 0;\n\n        // Inclus le padding et/ou la checkbox dans la largeur de la cellule\n        let _width = width + offset + (selectable ? padding : 2 * padding);\n\n        const lookedUpClassName = classNames(classes.flexContent, { [classes.lookedUp]: lookedUp });\n\n        return (\n            <TableCell\n                className={classes.root}\n                style={{\n                    maxWidth: _width,\n                    minWidth: _width,\n                    width: _width,\n                    // la cellule sticky doit être au dessus des autres cellules du body\n                    zIndex: sticky ? 12 : 11,\n                    textAlign: align,\n                    position: sticky ? 'relative' : 'inherit',\n                    border: 'none',\n                    height: dense ? cst.CELL_HEIGHT_DENSE : cst.CELL_HEIGHT,\n                }}\n            >\n                {!!selectable && (\n                    <HiCheckbox\n                        classes={{ root: classes.checkbox }}\n                        style={{ margin: dense ? 6 : 10 }}\n                        size={18}\n                        onChange={onSelect}\n                        checked={selected}\n                    />\n                )}\n\n                <div\n                    className={lookedUpClassName}\n                    style={{\n                        width: `calc(100% - ${offset}px)`,\n                        paddingLeft: selectable ? 0 : padding,\n                        paddingRight: padding,\n                        height: dense ? cst.CELL_HEIGHT_DENSE : cst.CELL_HEIGHT,\n                    }}\n                >\n                    {children}\n                    {childrenCount && (\n                        <div\n                            style={{\n                                position: 'absolute',\n                                top: dense ? 2 : 6,\n                                right: 0,\n                            }}\n                        >\n                            <HiPins color={theme.palette.business.primary.normal}>{childrenCount}</HiPins>\n                        </div>\n                    )}\n                </div>\n            </TableCell>\n        );\n    }\n}\n\nexport default withStyles(styles, { withTheme: true, name: 'HmuiCellLayout' })(CellLayout);\n"]}
36114
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["src/HiTable/BodyCells/CellLayout.js"],"names":["cst","styles","root","padding","backgroundColor","border","flexContent","display","flexDirection","justifyContent","position","checkbox","float","lookedUp","background","borderRadius","pins","top","CellLayout","nextProps","nextState","nextContext","selected","props","selectable","classes","type","children","align","ALIGN_RIGHT_TYPES","includes","view","dense","width","DEFAULT_WIDTHS","fixedWidth","sticky","onSelect","childrenCount","theme","offset","_width","lookedUpClassName","maxWidth","minWidth","zIndex","textAlign","height","CELL_HEIGHT_DENSE","CELL_HEIGHT","margin","paddingLeft","paddingRight","right","palette","business","primary","normal","Component","propTypes","element","object","bool","string","isRequired","oneOf","number","func","defaultProps","withTheme","name"],"mappings":"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","file":"CellLayout.js","sourceRoot":"/home/mfazio/dev/projects/hipay-material-ui","sourcesContent":["\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport TableCell from 'material-ui/Table/TableCell';\nimport classNames from 'classnames';\n\nimport HiCheckbox from '../../HiCheckbox';\nimport { withStyles } from '../../styles';\nimport * as cst from '../constants';\nimport HiPins from '../../HiPins';\n\nexport const styles = theme => ({\n    root: {\n        padding: 0,\n        backgroundColor: 'inherit',\n        border: 'none',\n    },\n    flexContent: {\n        display: 'flex',\n        flexDirection: 'column',\n        justifyContent: 'center',\n        position: 'relative',\n    },\n    checkbox: {\n        float: 'left',\n        position: 'relative',\n    },\n    lookedUp: {\n        background: `linear-gradient(0deg, transparent 25%, #FFFF8D 10%, #FFFF8D 75%, transparent 30%)`,\n        borderRadius: '45%',\n    },\n    pins: {\n        position: 'relative',\n        top: 3,\n    }\n});\n\n/**\n * Construit une cellule du body d'AdvancedTable\n * Définit la largeur et le padding effectif\n * Intègre la checkbox de sélection si besoin\n * Gère le comportement sticky\n */\nclass CellLayout extends React.Component {\n\n    static propTypes = {\n        /**\n         * Contenu de la cellule\n         */\n        children: PropTypes.element,\n        /**\n         * Useful to extend the style applied to components.\n         */\n        classes: PropTypes.object,\n        /**\n         * Densité, défini la hauteur de la ligne\n         */\n        dense: PropTypes.bool,\n        /**\n         * Recherche lookup sur cette colonne\n         */\n        lookedUp: PropTypes.bool,\n        /**\n         * Type de cellule\n         */\n        type: PropTypes.string.isRequired,\n        /**\n         * View (L/M/S)\n         */\n        view: PropTypes.oneOf(['l', 'm', 's']),\n        /**\n         * Largeur de la cellule (hors padding), est déduit de view par défaut\n         */\n        width: PropTypes.number,\n        /**\n         * La largeur de la cellule est fixé (toutes les colonnes sauf une)\n         */\n        fixedWidth: PropTypes.bool,\n        /**\n         * Title alignement, est déduit de type par défaut\n         */\n        align: PropTypes.string,\n        /**\n         * Padding de la cellule (px)\n         */\n        padding: PropTypes.number,\n        /**\n         * True si la colonne est la première colonne et doit avoir un comportement \"sticky\" lors du scroll horizontal\n         */\n        sticky: PropTypes.bool,\n        /**\n         * Ajoute une checkbox\n         */\n        selectable: PropTypes.bool,\n        /**\n         * État de la checkbox\n         */\n        selected: PropTypes.oneOf([true, false, 'mixed']),\n        /**\n         * Fonction de callback au click du select\n         */\n        onSelect: PropTypes.func,\n        /**\n         * Nombre d'enfants\n         */\n        childrenCount: PropTypes.number,\n    };\n\n    static defaultProps = {\n        view: 'l',\n        selectable: false,\n        selected: false,\n        dense: false,\n        fixedWidth: false,\n        sticky: false,\n        padding: 8,\n    };\n\n    /**\n     * * Should not update if selected has changed but cell isn't selectable anyway\n     * @param nextProps\n     * @param nextState\n     * @param nextContext\n     * @returns {boolean}\n     */\n    shouldComponentUpdate(nextProps, nextState, nextContext) {\n        if ( nextProps.selected === !this.props.selected && !this.props.selectable && !nextProps.selectable ) {\n            return false;\n        }\n        return true;\n    }\n\n    render () {\n        const {\n            classes, type, children,\n            align = cst.ALIGN_RIGHT_TYPES.includes(type) ? 'right' : 'left',\n            view, dense, width = cst.DEFAULT_WIDTHS[type][view], fixedWidth, sticky,\n            selectable, selected, onSelect, childrenCount, theme, padding,\n            lookedUp\n        } = this.props;\n\n        let offset = selectable ? dense ? 32 : 40 : 0;\n\n        // Inclus le padding et/ou la checkbox dans la largeur de la cellule\n        let _width = width + offset + (selectable ? padding : 2 * padding);\n\n        const lookedUpClassName = classNames(classes.flexContent, { [classes.lookedUp]: lookedUp });\n\n        return (\n            <TableCell\n                className={classes.root}\n                style={{\n                    maxWidth: _width,\n                    minWidth: _width,\n                    width: _width,\n                    // la cellule sticky doit être au dessus des autres cellules du body\n                    zIndex: sticky ? 12 : 11,\n                    textAlign: align,\n                    position: sticky ? 'relative' : 'inherit',\n                    border: 'none',\n                    height: dense ? cst.CELL_HEIGHT_DENSE : cst.CELL_HEIGHT,\n                }}\n            >\n                {!!selectable && (\n                    <HiCheckbox\n                        classes={{ root: classes.checkbox }}\n                        style={{ margin: dense ? 6 : 10 }}\n                        size={18}\n                        onChange={onSelect}\n                        checked={selected}\n                    />\n                )}\n\n                <div\n                    className={lookedUpClassName}\n                    style={{\n                        width: `calc(100% - ${offset}px)`,\n                        paddingLeft: selectable ? 0 : padding,\n                        paddingRight: padding,\n                        height: dense ? cst.CELL_HEIGHT_DENSE : cst.CELL_HEIGHT,\n                    }}\n                >\n                    {children}\n                    {childrenCount && (\n                        <div\n                            style={{\n                                position: 'absolute',\n                                top: dense ? 2 : 6,\n                                right: 0,\n                            }}\n                        >\n                            <HiPins color={theme.palette.business.primary.normal} className={classes.pins}>{childrenCount}</HiPins>\n                        </div>\n                    )}\n                </div>\n            </TableCell>\n        );\n    }\n}\n\nexport default withStyles(styles, { withTheme: true, name: 'HmuiCellLayout' })(CellLayout);\n"]}
36099
36115
 
36100
36116
  /***/ }),
36101
36117
  /* 338 */
@@ -91247,7 +91263,11 @@ var ColumnFilter = function (_React$Component) {
91247
91263
  _react2.default.createElement(
91248
91264
  'div',
91249
91265
  { className: classes.menuItemFilter },
91250
- translations.filter,
91266
+ _react2.default.createElement(
91267
+ 'span',
91268
+ { style: { marginRight: 4 } },
91269
+ translations.filter
91270
+ ),
91251
91271
  _react2.default.createElement(
91252
91272
  _HiPins2.default,
91253
91273
  {
@@ -91391,7 +91411,7 @@ ColumnFilter.defaultProps = {
91391
91411
  sortable: false
91392
91412
  };
91393
91413
  exports.default = (0, _withStyles2.default)(styles, { withTheme: true, name: 'HmuiColumnFilter' })(ColumnFilter);
91394
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["src/HiTable/ColumnFilter.js"],"names":["styles","menu","width","paddingTop","menuTitle","theme","typography","h2","fontWeight","fontWeightLight","marginLeft","whiteSpace","overflow","textOverflow","marginBottom","menuItemIcon","height","padding","color","palette","neutral","normal","menuItemSortable","paddingLeft","menuItemFilter","body1","dark","fontWeightMedium","lineHeight","display","alignItems","closeMenu","cursor","float","marginRight","marginTop","arrowRight","position","top","menuItemBorderBottom","borderBottom","line","stepper","buttonGroup","buttonGroupSubmit","textAlign","margin","submitButton","fontSize","button","buttonDisabled","action","disabled","asc","transform","ColumnFilter","props","sortNone","handleSort","sortAsc","sortDesc","state","selectedIdList","filterValueList","map","item","id","suggestions","bind","toggleSelectItem","selectAllFilters","deselectAllFilters","event","includes","setState","prevState","filter","itemId","splice","indexOf","direction","onSort","onClose","classes","translations","anchorEl","type","title","isOpen","sortable","onFilterChange","paper","root","default_sort","sort_from","length","business","primary","chipBackground","select_all","deselect_all","filteredList","search","apply","cancel","Component","propTypes","object","string","bool","isRequired","func","array","defaultProps","withTheme","name"],"mappings":"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","file":"ColumnFilter.js","sourceRoot":"/home/mfazio/dev/projects/hipay-material-ui","sourcesContent":["import React from 'react';\nimport Popover from 'material-ui/Popover';\nimport MenuItem from 'material-ui/Menu/MenuItem';\nimport PropTypes from 'prop-types';\nimport {\n    Close,\n    ArrowRight as ArrowRightIcon,\n    FilterVariant as FilterVariantIcon,\n    Menu as MenuIcon,\n} from 'mdi-material-ui';\nimport HiButton from '../HiButton';\nimport HiSelectableList from '../HiSelectableList';\nimport { HiSearchField } from '../HiForm';\nimport HiPins from '../HiPins';\nimport withStyles from '../styles/withStyles';\n\nexport const styles = theme => ({\n    menu: {\n        width: 300,\n        paddingTop: 16,\n    },\n    menuTitle: {\n        ...theme.typography.h2,\n        fontWeight: theme.typography.fontWeightLight,\n        marginLeft: 12,\n        whiteSpace: 'nowrap',\n        overflow: 'hidden',\n        textOverflow: 'ellipsis',\n        marginBottom: 16,\n    },\n    menuItemIcon: {\n        width: 20,\n        height: 20,\n        padding: 10,\n        color: theme.palette.neutral.normal,\n    },\n    menuItemSortable: {\n        paddingLeft: 8,\n    },\n    menuItemFilter: {\n        ...theme.typography.body1,\n        color: theme.palette.neutral.dark,\n        fontWeight: theme.typography.fontWeightMedium,\n        height: 40,\n        lineHeight: '40px',\n        paddingLeft: 28,\n        width: '100%',\n        display: 'flex',\n        alignItems: 'center',\n    },\n    closeMenu: {\n        width: '24px',\n        height: '24px',\n        color: theme.palette.neutral.normal,\n        cursor: 'pointer',\n        float: 'right',\n        marginRight: 10,\n        marginTop: -5,\n    },\n    arrowRight: {\n        position: 'relative',\n        top: 2,\n        width: '15px',\n        height: '15px',\n    },\n    menuItemBorderBottom: {\n        borderBottom: `1px solid ${theme.palette.line.stepper}`,\n    },\n    buttonGroup: {\n        padding: 0,\n    },\n    buttonGroupSubmit: {\n        textAlign: 'center',\n        margin: '20px auto',\n    },\n    submitButton: {\n        height: 40,\n        fontSize: 14,\n    },\n    button: {\n        height: 40,\n        fontSize: 14,\n        width: '50%',\n    },\n    buttonDisabled: {\n        color: theme.palette.action.disabled,\n    },\n    asc: {\n        transform: 'scale(1,-1)',\n    },\n});\n\n/**\n * Construit le menu de filtre d'une colonne avec les options de tri et un multi-select des valeurs possible\n * (uniquement pour les colonnes ayant une liste fermé de valeurs possibles)\n */\nclass ColumnFilter extends React.Component {\n    static propTypes = {\n        /**\n         * Useful to extend the style applied to components.\n         */\n        classes: PropTypes.object,\n        /**\n         * Traductions (par défaut en anglais)\n         */\n        translations: PropTypes.object,\n        /**\n         * Type des données de la colonne\n         */\n        type: PropTypes.string,\n        /**\n         * Titre de la colonne\n         */\n        title: PropTypes.string,\n        /**\n         * Affiche / Cache l'élément\n         */\n        isOpen: PropTypes.bool.isRequired,\n        /**\n         * Fonction de callback pour la fermeture du menu\n         */\n        onClose: PropTypes.func.isRequired,\n        /**\n         * Élément de référence sur lequelle positionner le menu\n         */\n        anchorEl: PropTypes.object.isRequired,\n        /**\n         * Ajoute les options de tri dans le menu\n         */\n        sortable: PropTypes.bool,\n        /**\n         * Fonction de callback au tri - passe la direction du tri\n         */\n        onSort: PropTypes.func,\n        /**\n         * Liste fermé des valeurs disponibles sur lesquelles filtrer (inclure/exclure)\n         */\n        filterValueList: PropTypes.array.isRequired,\n        /**\n         * Liste des id des valeurs sélectionnées\n         */\n        selectedIdList: PropTypes.array,\n        /**\n         * Fonction de callback au changement du filtre - passe la liste des valeurs incluses\n         */\n        onFilterChange: PropTypes.func,\n    };\n\n    static defaultProps = {\n        translations: {\n            default_sort: 'Default sort',\n            sort_from: 'Sort from',\n            filter: 'Filter',\n            select_all: 'Select all',\n            deselect_all: 'Deselect all',\n            search: 'Search',\n            apply: 'Apply',\n            cancel: 'Cancel',\n        },\n        sortable: false,\n    };\n\n    constructor(props) {\n        super();\n\n        this.state = {\n            // by default all filters are selected\n            selectedIdList:\n                props.selectedIdList ||\n                props.filterValueList.map(item => {\n                    return item.id;\n                }),\n            suggestions: props.filterValueList,\n        };\n\n        this.handleSort = this.handleSort.bind(this);\n        this.toggleSelectItem = this.toggleSelectItem.bind(this);\n        this.selectAllFilters = this.selectAllFilters.bind(this);\n        this.deselectAllFilters = this.deselectAllFilters.bind(this);\n    }\n\n    /**\n     * Ajoute / Supprime l'id de l'item du selectedIdList\n     * @param event\n     * @param item\n     */\n    toggleSelectItem(event, item) {\n        if (this.state.selectedIdList.includes(item.id)) {\n            this.setState(prevState => ({\n                selectedIdList: prevState.selectedIdList.filter(itemId => {\n                    return itemId !== item.id;\n                }),\n            }));\n        } else {\n            this.setState(prevState => ({\n                selectedIdList: [...prevState.selectedIdList, item.id],\n            }));\n        }\n    }\n\n    /**\n     * Sélectionne tous les items filtrés\n     */\n    selectAllFilters() {\n        this.setState({ selectedIdList: this.state.suggestions.map(item => item.id) });\n    }\n\n    /**\n     * Désélectionne tous les items filtrés\n     */\n    deselectAllFilters() {\n        const selectedIdList = this.state.selectedIdList;\n        this.state.suggestions.map(item => {\n            if (this.state.selectedIdList.includes(item.id)) {\n                selectedIdList.splice(this.state.selectedIdList.indexOf(item.id), 1);\n            }\n        });\n        this.setState({ selectedIdList });\n    }\n\n    handleSort(direction) {\n        this.props.onSort(direction);\n        this.props.onClose();\n    }\n\n    sortNone = () => {\n        this.handleSort(false);\n    };\n    sortAsc = () => {\n        this.handleSort('asc');\n    };\n    sortDesc = () => {\n        this.handleSort('desc');\n    };\n\n    render() {\n        const {\n            classes,\n            translations,\n            anchorEl,\n            type,\n            title,\n            filterValueList,\n            isOpen,\n            onClose,\n            sortable,\n            onFilterChange,\n        } = this.props;\n        const { selectedIdList, suggestions } = this.state;\n\n        return (\n            <Popover\n                id=\"column-filter-menu\"\n                anchorEl={anchorEl}\n                open={isOpen}\n                classes={{ paper: classes.menu }}\n                onClose={onClose}\n            >\n                <div className={classes.menuTitle}>\n                    <span>{title}</span>\n                    <Close classes={{ root: classes.closeMenu }} onClick={onClose} />\n                </div>\n\n                {!!sortable && (\n                    <div className={classes.menuItemSortable}>\n                        <MenuItem\n                            key={'sort-none'}\n                            classes={{ root: classes.menuItemBorderBottom }}\n                            onClick={this.sortNone}\n                        >\n                            <MenuIcon classes={{ root: classes.menuItemIcon }} />\n                            <span>{translations.default_sort}</span>\n                        </MenuItem>\n                        <MenuItem key={'sort-asc'} onClick={this.sortAsc}>\n                            <FilterVariantIcon\n                                className={classes.asc}\n                                classes={{ root: classes.menuItemIcon }}\n                            />\n                            <span>\n                                {translations.sort_from} A{' '}\n                                <ArrowRightIcon className={classes.arrowRight} /> Z\n                            </span>\n                        </MenuItem>\n                        <MenuItem\n                            key={'sort-desc'}\n                            onClick={this.sortDesc}\n                            classes={{ root: classes.menuItemBorderBottom }}\n                        >\n                            <FilterVariantIcon classes={{ root: classes.menuItemIcon }} />\n                            <span>\n                                {translations.sort_from} Z{' '}\n                                <ArrowRightIcon className={classes.arrowRight} /> A\n                            </span>\n                        </MenuItem>\n                    </div>\n                )}\n\n                <div className={classes.menuItemFilter}>\n                    {translations.filter}\n                    <HiPins\n                        color={\n                            selectedIdList.length > 0\n                                ? this.props.theme.palette.business.primary.normal\n                                : this.props.theme.palette.chipBackground\n                        }\n                    >\n                        {selectedIdList.length}\n                    </HiPins>\n                </div>\n\n                <div className={classes.buttonGroup}>\n                    <HiButton\n                        className={classes.button}\n                        classes={{ disabled: classes.buttonDisabled }}\n                        disabled={selectedIdList.length === filterValueList.length}\n                        onClick={this.selectAllFilters}\n                    >\n                        {translations.select_all}\n                    </HiButton>\n                    <HiButton\n                        className={classes.button}\n                        classes={{ disabled: classes.buttonDisabled }}\n                        disabled={selectedIdList.length === 0}\n                        onClick={this.deselectAllFilters}\n                    >\n                        {translations.deselect_all}\n                    </HiButton>\n                </div>\n\n                <HiSearchField\n                    itemList={filterValueList}\n                    filterPropertyList={['label']}\n                    callbackFilteredList={filteredList =>\n                        this.setState({ suggestions: filteredList })\n                    }\n                    placeholder={translations.search}\n                />\n\n                <HiSelectableList\n                    type={type}\n                    itemList={suggestions}\n                    selectedIdList={selectedIdList}\n                    onSelect={this.toggleSelectItem}\n                    leftPadding={28}\n                />\n\n                <div className={classes.buttonGroupSubmit}>\n                    <HiButton\n                        variant=\"raised\"\n                        color={'primary'}\n                        classes={{root: classes.submitButton}}\n                        onClick={() => {onFilterChange(selectedIdList); onClose()}}\n                    >{translations.apply}</HiButton>\n                    <HiButton\n                        classes={{root: classes.submitButton}}\n                        onClick={onClose}\n                        color={'primary'}\n                    >{translations.cancel}</HiButton>\n                </div>\n            </Popover>\n        );\n    }\n}\n\nexport default withStyles(styles, { withTheme: true, name: 'HmuiColumnFilter' })(ColumnFilter);\n"]}
91414
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["src/HiTable/ColumnFilter.js"],"names":["styles","menu","width","paddingTop","menuTitle","theme","typography","h2","fontWeight","fontWeightLight","marginLeft","whiteSpace","overflow","textOverflow","marginBottom","menuItemIcon","height","padding","color","palette","neutral","normal","menuItemSortable","paddingLeft","menuItemFilter","body1","dark","fontWeightMedium","lineHeight","display","alignItems","closeMenu","cursor","float","marginRight","marginTop","arrowRight","position","top","menuItemBorderBottom","borderBottom","line","stepper","buttonGroup","buttonGroupSubmit","textAlign","margin","submitButton","fontSize","button","buttonDisabled","action","disabled","asc","transform","ColumnFilter","props","sortNone","handleSort","sortAsc","sortDesc","state","selectedIdList","filterValueList","map","item","id","suggestions","bind","toggleSelectItem","selectAllFilters","deselectAllFilters","event","includes","setState","prevState","filter","itemId","splice","indexOf","direction","onSort","onClose","classes","translations","anchorEl","type","title","isOpen","sortable","onFilterChange","paper","root","default_sort","sort_from","length","business","primary","chipBackground","select_all","deselect_all","filteredList","search","apply","cancel","Component","propTypes","object","string","bool","isRequired","func","array","defaultProps","withTheme","name"],"mappings":";;;;;;;;;;;AAAA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;AAMA;;;;AACA;;;;AACA;;AACA;;;;AACA;;;;;;;;;;;;;;AAEO,IAAMA,0BAAS,SAATA,MAAS;AAAA,WAAU;AAC5BC,cAAM;AACFC,mBAAO,GADL;AAEFC,wBAAY;AAFV,SADsB;AAK5BC,gCACOC,MAAMC,UAAN,CAAiBC,EADxB;AAEIC,wBAAYH,MAAMC,UAAN,CAAiBG,eAFjC;AAGIC,wBAAY,EAHhB;AAIIC,wBAAY,QAJhB;AAKIC,sBAAU,QALd;AAMIC,0BAAc,UANlB;AAOIC,0BAAc;AAPlB,UAL4B;AAc5BC,sBAAc;AACVb,mBAAO,EADG;AAEVc,oBAAQ,EAFE;AAGVC,qBAAS,EAHC;AAIVC,mBAAOb,MAAMc,OAAN,CAAcC,OAAd,CAAsBC;AAJnB,SAdc;AAoB5BC,0BAAkB;AACdC,yBAAa;AADC,SApBU;AAuB5BC,qCACOnB,MAAMC,UAAN,CAAiBmB,KADxB;AAEIP,mBAAOb,MAAMc,OAAN,CAAcC,OAAd,CAAsBM,IAFjC;AAGIlB,wBAAYH,MAAMC,UAAN,CAAiBqB,gBAHjC;AAIIX,oBAAQ,EAJZ;AAKIY,wBAAY,MALhB;AAMIL,yBAAa,EANjB;AAOIrB,mBAAO,MAPX;AAQI2B,qBAAS,MARb;AASIC,wBAAY;AAThB,UAvB4B;AAkC5BC,mBAAW;AACP7B,mBAAO,MADA;AAEPc,oBAAQ,MAFD;AAGPE,mBAAOb,MAAMc,OAAN,CAAcC,OAAd,CAAsBC,MAHtB;AAIPW,oBAAQ,SAJD;AAKPC,mBAAO,OALA;AAMPC,yBAAa,EANN;AAOPC,uBAAW,CAAC;AAPL,SAlCiB;AA2C5BC,oBAAY;AACRC,sBAAU,UADF;AAERC,iBAAK,CAFG;AAGRpC,mBAAO,MAHC;AAIRc,oBAAQ;AAJA,SA3CgB;AAiD5BuB,8BAAsB;AAClBC,yCAA2BnC,MAAMc,OAAN,CAAcsB,IAAd,CAAmBC;AAD5B,SAjDM;AAoD5BC,qBAAa;AACT1B,qBAAS;AADA,SApDe;AAuD5B2B,2BAAmB;AACfC,uBAAW,QADI;AAEfC,oBAAQ;AAFO,SAvDS;AA2D5BC,sBAAc;AACV/B,oBAAQ,EADE;AAEVgC,sBAAU;AAFA,SA3Dc;AA+D5BC,gBAAQ;AACJjC,oBAAQ,EADJ;AAEJgC,sBAAU,EAFN;AAGJ9C,mBAAO;AAHH,SA/DoB;AAoE5BgD,wBAAgB;AACZhC,mBAAOb,MAAMc,OAAN,CAAcgC,MAAd,CAAqBC;AADhB,SApEY;AAuE5BC,aAAK;AACDC,uBAAW;AADV;AAvEuB,KAAV;AAAA,CAAf;;AA4EP;;;;;IAIMC,Y;;;AAkEF,0BAAYC,KAAZ,EAAmB;AAAA;;AAAA;;AAAA,cA+DnBC,QA/DmB,GA+DR,YAAM;AACb,kBAAKC,UAAL,CAAgB,KAAhB;AACH,SAjEkB;;AAAA,cAkEnBC,OAlEmB,GAkET,YAAM;AACZ,kBAAKD,UAAL,CAAgB,KAAhB;AACH,SApEkB;;AAAA,cAqEnBE,QArEmB,GAqER,YAAM;AACb,kBAAKF,UAAL,CAAgB,MAAhB;AACH,SAvEkB;;AAGf,cAAKG,KAAL,GAAa;AACT;AACAC,4BACIN,MAAMM,cAAN,IACAN,MAAMO,eAAN,CAAsBC,GAAtB,CAA0B,gBAAQ;AAC9B,uBAAOC,KAAKC,EAAZ;AACH,aAFD,CAJK;AAOTC,yBAAaX,MAAMO;AAPV,SAAb;;AAUA,cAAKL,UAAL,GAAkB,MAAKA,UAAL,CAAgBU,IAAhB,OAAlB;AACA,cAAKC,gBAAL,GAAwB,MAAKA,gBAAL,CAAsBD,IAAtB,OAAxB;AACA,cAAKE,gBAAL,GAAwB,MAAKA,gBAAL,CAAsBF,IAAtB,OAAxB;AACA,cAAKG,kBAAL,GAA0B,MAAKA,kBAAL,CAAwBH,IAAxB,OAA1B;AAhBe;AAiBlB;;AAED;;;;;;;;;yCAKiBI,K,EAAOP,I,EAAM;AAC1B,gBAAI,KAAKJ,KAAL,CAAWC,cAAX,CAA0BW,QAA1B,CAAmCR,KAAKC,EAAxC,CAAJ,EAAiD;AAC7C,qBAAKQ,QAAL,CAAc;AAAA,2BAAc;AACxBZ,wCAAgBa,UAAUb,cAAV,CAAyBc,MAAzB,CAAgC,kBAAU;AACtD,mCAAOC,WAAWZ,KAAKC,EAAvB;AACH,yBAFe;AADQ,qBAAd;AAAA,iBAAd;AAKH,aAND,MAMO;AACH,qBAAKQ,QAAL,CAAc;AAAA,2BAAc;AACxBZ,qEAAoBa,UAAUb,cAA9B,IAA8CG,KAAKC,EAAnD;AADwB,qBAAd;AAAA,iBAAd;AAGH;AACJ;;AAED;;;;;;2CAGmB;AACf,iBAAKQ,QAAL,CAAc,EAAEZ,gBAAgB,KAAKD,KAAL,CAAWM,WAAX,CAAuBH,GAAvB,CAA2B;AAAA,2BAAQC,KAAKC,EAAb;AAAA,iBAA3B,CAAlB,EAAd;AACH;;AAED;;;;;;6CAGqB;AAAA;;AACjB,gBAAMJ,iBAAiB,KAAKD,KAAL,CAAWC,cAAlC;AACA,iBAAKD,KAAL,CAAWM,WAAX,CAAuBH,GAAvB,CAA2B,gBAAQ;AAC/B,oBAAI,OAAKH,KAAL,CAAWC,cAAX,CAA0BW,QAA1B,CAAmCR,KAAKC,EAAxC,CAAJ,EAAiD;AAC7CJ,mCAAegB,MAAf,CAAsB,OAAKjB,KAAL,CAAWC,cAAX,CAA0BiB,OAA1B,CAAkCd,KAAKC,EAAvC,CAAtB,EAAkE,CAAlE;AACH;AACJ,aAJD;AAKA,iBAAKQ,QAAL,CAAc,EAAEZ,8BAAF,EAAd;AACH;;;mCAEUkB,S,EAAW;AAClB,iBAAKxB,KAAL,CAAWyB,MAAX,CAAkBD,SAAlB;AACA,iBAAKxB,KAAL,CAAW0B,OAAX;AACH;;;iCAYQ;AAAA;;AAAA,yBAYD,KAAK1B,KAZJ;AAAA,gBAED2B,OAFC,UAEDA,OAFC;AAAA,gBAGDC,YAHC,UAGDA,YAHC;AAAA,gBAIDC,QAJC,UAIDA,QAJC;AAAA,gBAKDC,IALC,UAKDA,IALC;AAAA,gBAMDC,KANC,UAMDA,KANC;AAAA,gBAODxB,eAPC,UAODA,eAPC;AAAA,gBAQDyB,MARC,UAQDA,MARC;AAAA,gBASDN,OATC,UASDA,OATC;AAAA,gBAUDO,QAVC,UAUDA,QAVC;AAAA,gBAWDC,cAXC,UAWDA,cAXC;AAAA,yBAamC,KAAK7B,KAbxC;AAAA,gBAaGC,cAbH,UAaGA,cAbH;AAAA,gBAamBK,WAbnB,UAamBA,WAbnB;;;AAeL,mBACI;AAAA;AAAA;AACI,wBAAG,oBADP;AAEI,8BAAUkB,QAFd;AAGI,0BAAMG,MAHV;AAII,6BAAS,EAAEG,OAAOR,QAAQlF,IAAjB,EAJb;AAKI,6BAASiF;AALb;AAOI;AAAA;AAAA,sBAAK,WAAWC,QAAQ/E,SAAxB;AACI;AAAA;AAAA;AAAOmF;AAAP,qBADJ;AAEI,0EAAO,SAAS,EAAEK,MAAMT,QAAQpD,SAAhB,EAAhB,EAA6C,SAASmD,OAAtD;AAFJ,iBAPJ;AAYK,iBAAC,CAACO,QAAF,IACG;AAAA;AAAA,sBAAK,WAAWN,QAAQ7D,gBAAxB;AACI;AAAA;AAAA;AACI,iCAAK,WADT;AAEI,qCAAS,EAAEsE,MAAMT,QAAQ5C,oBAAhB,EAFb;AAGI,qCAAS,KAAKkB;AAHlB;AAKI,6EAAU,SAAS,EAAEmC,MAAMT,QAAQpE,YAAhB,EAAnB,GALJ;AAMI;AAAA;AAAA;AAAOqE,yCAAaS;AAApB;AANJ,qBADJ;AASI;AAAA;AAAA,0BAAU,KAAK,UAAf,EAA2B,SAAS,KAAKlC,OAAzC;AACI;AACI,uCAAWwB,QAAQ9B,GADvB;AAEI,qCAAS,EAAEuC,MAAMT,QAAQpE,YAAhB;AAFb,0BADJ;AAKI;AAAA;AAAA;AACKqE,yCAAaU,SADlB;AAAA;AAC+B,+BAD/B;AAEI,uFAAgB,WAAWX,QAAQ/C,UAAnC,GAFJ;AAAA;AAAA;AALJ,qBATJ;AAmBI;AAAA;AAAA;AACI,iCAAK,WADT;AAEI,qCAAS,KAAKwB,QAFlB;AAGI,qCAAS,EAAEgC,MAAMT,QAAQ5C,oBAAhB;AAHb;AAKI,sFAAmB,SAAS,EAAEqD,MAAMT,QAAQpE,YAAhB,EAA5B,GALJ;AAMI;AAAA;AAAA;AACKqE,yCAAaU,SADlB;AAAA;AAC+B,+BAD/B;AAEI,uFAAgB,WAAWX,QAAQ/C,UAAnC,GAFJ;AAAA;AAAA;AANJ;AAnBJ,iBAbR;AA8CI;AAAA;AAAA,sBAAK,WAAW+C,QAAQ3D,cAAxB;AACI;AAAA;AAAA,0BAAM,OAAO,EAACU,aAAa,CAAd,EAAb;AAAgCkD,qCAAaR;AAA7C,qBADJ;AAEI;AAAA;AAAA;AACI,mCACId,eAAeiC,MAAf,GAAwB,CAAxB,GACM,KAAKvC,KAAL,CAAWnD,KAAX,CAAiBc,OAAjB,CAAyB6E,QAAzB,CAAkCC,OAAlC,CAA0C5E,MADhD,GAEM,KAAKmC,KAAL,CAAWnD,KAAX,CAAiBc,OAAjB,CAAyB+E;AAJvC;AAOKpC,uCAAeiC;AAPpB;AAFJ,iBA9CJ;AA2DI;AAAA;AAAA,sBAAK,WAAWZ,QAAQxC,WAAxB;AACI;AAAA;AAAA;AACI,uCAAWwC,QAAQlC,MADvB;AAEI,qCAAS,EAAEG,UAAU+B,QAAQjC,cAApB,EAFb;AAGI,sCAAUY,eAAeiC,MAAf,KAA0BhC,gBAAgBgC,MAHxD;AAII,qCAAS,KAAKzB;AAJlB;AAMKc,qCAAae;AANlB,qBADJ;AASI;AAAA;AAAA;AACI,uCAAWhB,QAAQlC,MADvB;AAEI,qCAAS,EAAEG,UAAU+B,QAAQjC,cAApB,EAFb;AAGI,sCAAUY,eAAeiC,MAAf,KAA0B,CAHxC;AAII,qCAAS,KAAKxB;AAJlB;AAMKa,qCAAagB;AANlB;AATJ,iBA3DJ;AA8EI;AACI,8BAAUrC,eADd;AAEI,wCAAoB,CAAC,OAAD,CAFxB;AAGI,0CAAsB;AAAA,+BAClB,OAAKW,QAAL,CAAc,EAAEP,aAAakC,YAAf,EAAd,CADkB;AAAA,qBAH1B;AAMI,iCAAajB,aAAakB;AAN9B,kBA9EJ;AAuFI;AACI,0BAAMhB,IADV;AAEI,8BAAUnB,WAFd;AAGI,oCAAgBL,cAHpB;AAII,8BAAU,KAAKO,gBAJnB;AAKI,iCAAa;AALjB,kBAvFJ;AA+FI;AAAA;AAAA,sBAAK,WAAWc,QAAQvC,iBAAxB;AACI;AAAA;AAAA;AACI,qCAAQ,QADZ;AAEI,mCAAO,SAFX;AAGI,qCAAS,EAACgD,MAAMT,QAAQpC,YAAf,EAHb;AAII,qCAAS,mBAAM;AAAC2C,+CAAe5B,cAAf,EAAgCoB;AAAU;AAJ9D;AAKEE,qCAAamB;AALf,qBADJ;AAOI;AAAA;AAAA;AACI,qCAAS,EAACX,MAAMT,QAAQpC,YAAf,EADb;AAEI,qCAASmC,OAFb;AAGI,mCAAO;AAHX;AAIEE,qCAAaoB;AAJf;AAPJ;AA/FJ,aADJ;AA+GH;;;;EAzQsB,gBAAMC,S;;AAA3BlD,Y,CACKmD,S,GAAY;AACf;;;AAGAvB,aAAS,oBAAUwB,MAJJ;AAKf;;;AAGAvB,kBAAc,oBAAUuB,MART;AASf;;;AAGArB,UAAM,oBAAUsB,MAZD;AAaf;;;AAGArB,WAAO,oBAAUqB,MAhBF;AAiBf;;;AAGApB,YAAQ,oBAAUqB,IAAV,CAAeC,UApBR;AAqBf;;;AAGA5B,aAAS,oBAAU6B,IAAV,CAAeD,UAxBT;AAyBf;;;AAGAzB,cAAU,oBAAUsB,MAAV,CAAiBG,UA5BZ;AA6Bf;;;AAGArB,cAAU,oBAAUoB,IAhCL;AAiCf;;;AAGA5B,YAAQ,oBAAU8B,IApCH;AAqCf;;;AAGAhD,qBAAiB,oBAAUiD,KAAV,CAAgBF,UAxClB;AAyCf;;;AAGAhD,oBAAgB,oBAAUkD,KA5CX;AA6Cf;;;AAGAtB,oBAAgB,oBAAUqB;AAhDX,C;AADjBxD,Y,CAoDK0D,Y,GAAe;AAClB7B,kBAAc;AACVS,sBAAc,cADJ;AAEVC,mBAAW,WAFD;AAGVlB,gBAAQ,QAHE;AAIVuB,oBAAY,YAJF;AAKVC,sBAAc,cALJ;AAMVE,gBAAQ,QANE;AAOVC,eAAO,OAPG;AAQVC,gBAAQ;AARE,KADI;AAWlBf,cAAU;AAXQ,C;kBAwNX,0BAAWzF,MAAX,EAAmB,EAAEkH,WAAW,IAAb,EAAmBC,MAAM,kBAAzB,EAAnB,EAAkE5D,YAAlE,C","file":"ColumnFilter.js","sourceRoot":"/home/mfazio/dev/projects/hipay-material-ui","sourcesContent":["import React from 'react';\nimport Popover from 'material-ui/Popover';\nimport MenuItem from 'material-ui/Menu/MenuItem';\nimport PropTypes from 'prop-types';\nimport {\n    Close,\n    ArrowRight as ArrowRightIcon,\n    FilterVariant as FilterVariantIcon,\n    Menu as MenuIcon,\n} from 'mdi-material-ui';\nimport HiButton from '../HiButton';\nimport HiSelectableList from '../HiSelectableList';\nimport { HiSearchField } from '../HiForm';\nimport HiPins from '../HiPins';\nimport withStyles from '../styles/withStyles';\n\nexport const styles = theme => ({\n    menu: {\n        width: 300,\n        paddingTop: 16,\n    },\n    menuTitle: {\n        ...theme.typography.h2,\n        fontWeight: theme.typography.fontWeightLight,\n        marginLeft: 12,\n        whiteSpace: 'nowrap',\n        overflow: 'hidden',\n        textOverflow: 'ellipsis',\n        marginBottom: 16,\n    },\n    menuItemIcon: {\n        width: 20,\n        height: 20,\n        padding: 10,\n        color: theme.palette.neutral.normal,\n    },\n    menuItemSortable: {\n        paddingLeft: 8,\n    },\n    menuItemFilter: {\n        ...theme.typography.body1,\n        color: theme.palette.neutral.dark,\n        fontWeight: theme.typography.fontWeightMedium,\n        height: 40,\n        lineHeight: '40px',\n        paddingLeft: 28,\n        width: '100%',\n        display: 'flex',\n        alignItems: 'center',\n    },\n    closeMenu: {\n        width: '24px',\n        height: '24px',\n        color: theme.palette.neutral.normal,\n        cursor: 'pointer',\n        float: 'right',\n        marginRight: 10,\n        marginTop: -5,\n    },\n    arrowRight: {\n        position: 'relative',\n        top: 2,\n        width: '15px',\n        height: '15px',\n    },\n    menuItemBorderBottom: {\n        borderBottom: `1px solid ${theme.palette.line.stepper}`,\n    },\n    buttonGroup: {\n        padding: 0,\n    },\n    buttonGroupSubmit: {\n        textAlign: 'center',\n        margin: '20px auto',\n    },\n    submitButton: {\n        height: 40,\n        fontSize: 14,\n    },\n    button: {\n        height: 40,\n        fontSize: 14,\n        width: '50%',\n    },\n    buttonDisabled: {\n        color: theme.palette.action.disabled,\n    },\n    asc: {\n        transform: 'scale(1,-1)',\n    },\n});\n\n/**\n * Construit le menu de filtre d'une colonne avec les options de tri et un multi-select des valeurs possible\n * (uniquement pour les colonnes ayant une liste fermé de valeurs possibles)\n */\nclass ColumnFilter extends React.Component {\n    static propTypes = {\n        /**\n         * Useful to extend the style applied to components.\n         */\n        classes: PropTypes.object,\n        /**\n         * Traductions (par défaut en anglais)\n         */\n        translations: PropTypes.object,\n        /**\n         * Type des données de la colonne\n         */\n        type: PropTypes.string,\n        /**\n         * Titre de la colonne\n         */\n        title: PropTypes.string,\n        /**\n         * Affiche / Cache l'élément\n         */\n        isOpen: PropTypes.bool.isRequired,\n        /**\n         * Fonction de callback pour la fermeture du menu\n         */\n        onClose: PropTypes.func.isRequired,\n        /**\n         * Élément de référence sur lequelle positionner le menu\n         */\n        anchorEl: PropTypes.object.isRequired,\n        /**\n         * Ajoute les options de tri dans le menu\n         */\n        sortable: PropTypes.bool,\n        /**\n         * Fonction de callback au tri - passe la direction du tri\n         */\n        onSort: PropTypes.func,\n        /**\n         * Liste fermé des valeurs disponibles sur lesquelles filtrer (inclure/exclure)\n         */\n        filterValueList: PropTypes.array.isRequired,\n        /**\n         * Liste des id des valeurs sélectionnées\n         */\n        selectedIdList: PropTypes.array,\n        /**\n         * Fonction de callback au changement du filtre - passe la liste des valeurs incluses\n         */\n        onFilterChange: PropTypes.func,\n    };\n\n    static defaultProps = {\n        translations: {\n            default_sort: 'Default sort',\n            sort_from: 'Sort from',\n            filter: 'Filter',\n            select_all: 'Select all',\n            deselect_all: 'Deselect all',\n            search: 'Search',\n            apply: 'Apply',\n            cancel: 'Cancel',\n        },\n        sortable: false,\n    };\n\n    constructor(props) {\n        super();\n\n        this.state = {\n            // by default all filters are selected\n            selectedIdList:\n                props.selectedIdList ||\n                props.filterValueList.map(item => {\n                    return item.id;\n                }),\n            suggestions: props.filterValueList,\n        };\n\n        this.handleSort = this.handleSort.bind(this);\n        this.toggleSelectItem = this.toggleSelectItem.bind(this);\n        this.selectAllFilters = this.selectAllFilters.bind(this);\n        this.deselectAllFilters = this.deselectAllFilters.bind(this);\n    }\n\n    /**\n     * Ajoute / Supprime l'id de l'item du selectedIdList\n     * @param event\n     * @param item\n     */\n    toggleSelectItem(event, item) {\n        if (this.state.selectedIdList.includes(item.id)) {\n            this.setState(prevState => ({\n                selectedIdList: prevState.selectedIdList.filter(itemId => {\n                    return itemId !== item.id;\n                }),\n            }));\n        } else {\n            this.setState(prevState => ({\n                selectedIdList: [...prevState.selectedIdList, item.id],\n            }));\n        }\n    }\n\n    /**\n     * Sélectionne tous les items filtrés\n     */\n    selectAllFilters() {\n        this.setState({ selectedIdList: this.state.suggestions.map(item => item.id) });\n    }\n\n    /**\n     * Désélectionne tous les items filtrés\n     */\n    deselectAllFilters() {\n        const selectedIdList = this.state.selectedIdList;\n        this.state.suggestions.map(item => {\n            if (this.state.selectedIdList.includes(item.id)) {\n                selectedIdList.splice(this.state.selectedIdList.indexOf(item.id), 1);\n            }\n        });\n        this.setState({ selectedIdList });\n    }\n\n    handleSort(direction) {\n        this.props.onSort(direction);\n        this.props.onClose();\n    }\n\n    sortNone = () => {\n        this.handleSort(false);\n    };\n    sortAsc = () => {\n        this.handleSort('asc');\n    };\n    sortDesc = () => {\n        this.handleSort('desc');\n    };\n\n    render() {\n        const {\n            classes,\n            translations,\n            anchorEl,\n            type,\n            title,\n            filterValueList,\n            isOpen,\n            onClose,\n            sortable,\n            onFilterChange,\n        } = this.props;\n        const { selectedIdList, suggestions } = this.state;\n\n        return (\n            <Popover\n                id=\"column-filter-menu\"\n                anchorEl={anchorEl}\n                open={isOpen}\n                classes={{ paper: classes.menu }}\n                onClose={onClose}\n            >\n                <div className={classes.menuTitle}>\n                    <span>{title}</span>\n                    <Close classes={{ root: classes.closeMenu }} onClick={onClose} />\n                </div>\n\n                {!!sortable && (\n                    <div className={classes.menuItemSortable}>\n                        <MenuItem\n                            key={'sort-none'}\n                            classes={{ root: classes.menuItemBorderBottom }}\n                            onClick={this.sortNone}\n                        >\n                            <MenuIcon classes={{ root: classes.menuItemIcon }} />\n                            <span>{translations.default_sort}</span>\n                        </MenuItem>\n                        <MenuItem key={'sort-asc'} onClick={this.sortAsc}>\n                            <FilterVariantIcon\n                                className={classes.asc}\n                                classes={{ root: classes.menuItemIcon }}\n                            />\n                            <span>\n                                {translations.sort_from} A{' '}\n                                <ArrowRightIcon className={classes.arrowRight} /> Z\n                            </span>\n                        </MenuItem>\n                        <MenuItem\n                            key={'sort-desc'}\n                            onClick={this.sortDesc}\n                            classes={{ root: classes.menuItemBorderBottom }}\n                        >\n                            <FilterVariantIcon classes={{ root: classes.menuItemIcon }} />\n                            <span>\n                                {translations.sort_from} Z{' '}\n                                <ArrowRightIcon className={classes.arrowRight} /> A\n                            </span>\n                        </MenuItem>\n                    </div>\n                )}\n\n                <div className={classes.menuItemFilter}>\n                    <span style={{marginRight: 4}}>{translations.filter}</span>\n                    <HiPins\n                        color={\n                            selectedIdList.length > 0\n                                ? this.props.theme.palette.business.primary.normal\n                                : this.props.theme.palette.chipBackground\n                        }\n                    >\n                        {selectedIdList.length}\n                    </HiPins>\n                </div>\n\n                <div className={classes.buttonGroup}>\n                    <HiButton\n                        className={classes.button}\n                        classes={{ disabled: classes.buttonDisabled }}\n                        disabled={selectedIdList.length === filterValueList.length}\n                        onClick={this.selectAllFilters}\n                    >\n                        {translations.select_all}\n                    </HiButton>\n                    <HiButton\n                        className={classes.button}\n                        classes={{ disabled: classes.buttonDisabled }}\n                        disabled={selectedIdList.length === 0}\n                        onClick={this.deselectAllFilters}\n                    >\n                        {translations.deselect_all}\n                    </HiButton>\n                </div>\n\n                <HiSearchField\n                    itemList={filterValueList}\n                    filterPropertyList={['label']}\n                    callbackFilteredList={filteredList =>\n                        this.setState({ suggestions: filteredList })\n                    }\n                    placeholder={translations.search}\n                />\n\n                <HiSelectableList\n                    type={type}\n                    itemList={suggestions}\n                    selectedIdList={selectedIdList}\n                    onSelect={this.toggleSelectItem}\n                    leftPadding={28}\n                />\n\n                <div className={classes.buttonGroupSubmit}>\n                    <HiButton\n                        variant=\"raised\"\n                        color={'primary'}\n                        classes={{root: classes.submitButton}}\n                        onClick={() => {onFilterChange(selectedIdList); onClose()}}\n                    >{translations.apply}</HiButton>\n                    <HiButton\n                        classes={{root: classes.submitButton}}\n                        onClick={onClose}\n                        color={'primary'}\n                    >{translations.cancel}</HiButton>\n                </div>\n            </Popover>\n        );\n    }\n}\n\nexport default withStyles(styles, { withTheme: true, name: 'HmuiColumnFilter' })(ColumnFilter);\n"]}
91395
91415
 
91396
91416
  /***/ }),
91397
91417
  /* 2624 */
@@ -96132,7 +96152,7 @@ var HiSearchField = function (_React$Component) {
96132
96152
  if (typeof this.props.onSearch === 'undefined') {
96133
96153
  this.props.callbackFilteredList(this.props.itemList);
96134
96154
  } else {
96135
- this.props.onSearch('');
96155
+ this.props.onSearch(undefined, '');
96136
96156
  }
96137
96157
  }
96138
96158
  }, {
@@ -96185,7 +96205,7 @@ HiSearchField.defaultProps = {
96185
96205
  placeholder: 'Search'
96186
96206
  };
96187
96207
  exports.default = HiSearchField;
96188
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["src/HiForm/HiSearchField.js"],"names":["HiSearchField","props","state","inputValue","handleChange","bind","handleReset","item","search","properties","length","toString","toLowerCase","searchSucceed","forEach","itemProperty","filter","indexOf","split","event","searchedValue","target","value","setState","onSearch","currentParent","filteredList","itemList","add","filterOnProperties","filterPropertyList","hasChildren","parentId","id","push","callbackFilteredList","placeholder","others","Component","propTypes","func","isRequired","array","string","defaultProps"],"mappings":"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","file":"HiSearchField.js","sourceRoot":"/home/mfazio/dev/projects/hipay-material-ui","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport HiInput from '../HiForm/HiInput';\n\n/**\n * Construit une barre de recherche avec icône Search (Magnify),\n * permet de filtrer une liste d'éléments en spécifiant le nom de la/les propriétés sur lesquelles filtrer,\n * retour la liste d'élément filtré.\n * Un bouton reset s'affiche à la saisie permettant de réinitialiser l'input.\n */\nclass HiSearchField extends React.Component {\n    static propTypes = {\n        /**\n         * Fonction de callback qui renvoie la liste d'éléments filtrée\n         *\n         * @param {array} suggestions\n         */\n        callbackFilteredList: PropTypes.func.isRequired,\n        /**\n         * Liste des propriété de l'élément sur lesquelles filtrer (par défaut l'item lui même)\n         */\n        filterPropertyList: PropTypes.array,\n        /**\n         * Liste d'éléments\n         */\n        itemList: PropTypes.array.isRequired,\n        /**\n         * Fonction de callback qui renvoit le texte saisi\n         *\n         * @param {string} value\n         */\n        onSearch: PropTypes.func,\n        /**\n         * Placeholder\n         */\n        placeholder: PropTypes.string,\n    };\n\n    static defaultProps = {\n        placeholder: 'Search',\n    };\n\n    constructor(props) {\n        super(props);\n\n        this.state = {\n            inputValue: '',\n        };\n\n        this.handleChange = this.handleChange.bind(this);\n        this.handleReset = this.handleReset.bind(this);\n    }\n\n    filterOnProperties(item, search, properties) {\n        if (typeof properties === 'undefined' || properties.length < 1) {\n            // If no properties specify, search on item\n            return (\n                item\n                    .toString()\n                    .toLowerCase()\n                    .search(search.toLowerCase()) !== -1\n            );\n        }\n        let searchSucceed = false;\n        properties.forEach(filter => {\n            let itemProperty = null;\n            if (filter.indexOf('.') > 0) {\n                itemProperty = item[filter.split('.')[0]][filter.split('.')[1]];\n            } else {\n                itemProperty = item[filter];\n            }\n            if (\n                itemProperty\n                    .toString()\n                    .toLowerCase()\n                    .search(search.toLowerCase()) !== -1\n            ) {\n                searchSucceed = true;\n            }\n        });\n        return searchSucceed;\n    }\n\n    handleChange(event, inputValue) {\n        let searchedValue;\n        if (typeof inputValue !== 'undefined' && typeof event.target.value === 'undefined') {\n            searchedValue = inputValue;\n        } else {\n            searchedValue = event.target.value;\n        }\n        this.setState({\n            inputValue: searchedValue,\n        });\n\n        if (typeof this.props.onSearch === 'undefined') {\n            let currentParent = null;\n            const filteredList = [];\n            this.props.itemList.forEach(item => {\n                const add = this.filterOnProperties(\n                    item,\n                    searchedValue,\n                    this.props.filterPropertyList,\n                );\n                if (item.hasChildren === true && add === false) {\n                    currentParent = item;\n                }\n                if (add === true) {\n                    if (currentParent !== null && item.parentId === currentParent.id) {\n                        filteredList.push(currentParent);\n                        currentParent = null;\n                    }\n                    filteredList.push(item);\n                }\n            });\n\n            this.props.callbackFilteredList(filteredList);\n        } else {\n            this.props.onSearch(event, searchedValue);\n        }\n    }\n\n    handleReset() {\n        this.setState({\n            inputValue: '',\n        });\n\n        if (typeof this.props.onSearch === 'undefined') {\n            this.props.callbackFilteredList(this.props.itemList);\n        } else {\n            this.props.onSearch('');\n        }\n    }\n\n    render() {\n        const { placeholder, ...others } = this.props;\n\n        return (\n            <HiInput\n                placeholder={placeholder}\n                onReset={this.handleReset}\n                onChange={this.handleChange}\n                value={this.state.inputValue}\n                startAdornment={'Magnify'}\n                {...others}\n            />\n        );\n    }\n}\nexport default HiSearchField;\n"]}
96208
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["src/HiForm/HiSearchField.js"],"names":["HiSearchField","props","state","inputValue","handleChange","bind","handleReset","item","search","properties","length","toString","toLowerCase","searchSucceed","forEach","itemProperty","filter","indexOf","split","event","searchedValue","target","value","setState","onSearch","currentParent","filteredList","itemList","add","filterOnProperties","filterPropertyList","hasChildren","parentId","id","push","callbackFilteredList","undefined","placeholder","others","Component","propTypes","func","isRequired","array","string","defaultProps"],"mappings":"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","file":"HiSearchField.js","sourceRoot":"/home/mfazio/dev/projects/hipay-material-ui","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport HiInput from '../HiForm/HiInput';\n\n/**\n * Construit une barre de recherche avec icône Search (Magnify),\n * permet de filtrer une liste d'éléments en spécifiant le nom de la/les propriétés sur lesquelles filtrer,\n * retour la liste d'élément filtré.\n * Un bouton reset s'affiche à la saisie permettant de réinitialiser l'input.\n */\nclass HiSearchField extends React.Component {\n    static propTypes = {\n        /**\n         * Fonction de callback qui renvoie la liste d'éléments filtrée\n         *\n         * @param {array} suggestions\n         */\n        callbackFilteredList: PropTypes.func.isRequired,\n        /**\n         * Liste des propriété de l'élément sur lesquelles filtrer (par défaut l'item lui même)\n         */\n        filterPropertyList: PropTypes.array,\n        /**\n         * Liste d'éléments\n         */\n        itemList: PropTypes.array.isRequired,\n        /**\n         * Fonction de callback qui renvoit le texte saisi\n         *\n         * @param {string} value\n         */\n        onSearch: PropTypes.func,\n        /**\n         * Placeholder\n         */\n        placeholder: PropTypes.string,\n    };\n\n    static defaultProps = {\n        placeholder: 'Search',\n    };\n\n    constructor(props) {\n        super(props);\n\n        this.state = {\n            inputValue: '',\n        };\n\n        this.handleChange = this.handleChange.bind(this);\n        this.handleReset = this.handleReset.bind(this);\n    }\n\n    filterOnProperties(item, search, properties) {\n        if (typeof properties === 'undefined' || properties.length < 1) {\n            // If no properties specify, search on item\n            return (\n                item\n                    .toString()\n                    .toLowerCase()\n                    .search(search.toLowerCase()) !== -1\n            );\n        }\n        let searchSucceed = false;\n        properties.forEach(filter => {\n            let itemProperty = null;\n            if (filter.indexOf('.') > 0) {\n                itemProperty = item[filter.split('.')[0]][filter.split('.')[1]];\n            } else {\n                itemProperty = item[filter];\n            }\n            if (\n                itemProperty\n                    .toString()\n                    .toLowerCase()\n                    .search(search.toLowerCase()) !== -1\n            ) {\n                searchSucceed = true;\n            }\n        });\n        return searchSucceed;\n    }\n\n    handleChange(event, inputValue) {\n        let searchedValue;\n        if (typeof inputValue !== 'undefined' && typeof event.target.value === 'undefined') {\n            searchedValue = inputValue;\n        } else {\n            searchedValue = event.target.value;\n        }\n        this.setState({\n            inputValue: searchedValue,\n        });\n\n        if (typeof this.props.onSearch === 'undefined') {\n            let currentParent = null;\n            const filteredList = [];\n            this.props.itemList.forEach(item => {\n                const add = this.filterOnProperties(\n                    item,\n                    searchedValue,\n                    this.props.filterPropertyList,\n                );\n                if (item.hasChildren === true && add === false) {\n                    currentParent = item;\n                }\n                if (add === true) {\n                    if (currentParent !== null && item.parentId === currentParent.id) {\n                        filteredList.push(currentParent);\n                        currentParent = null;\n                    }\n                    filteredList.push(item);\n                }\n            });\n\n            this.props.callbackFilteredList(filteredList);\n        } else {\n            this.props.onSearch(event, searchedValue);\n        }\n    }\n\n    handleReset() {\n        this.setState({\n            inputValue: '',\n        });\n\n        if (typeof this.props.onSearch === 'undefined') {\n            this.props.callbackFilteredList(this.props.itemList);\n        } else {\n            this.props.onSearch(undefined, '');\n        }\n    }\n\n    render() {\n        const { placeholder, ...others } = this.props;\n\n        return (\n            <HiInput\n                placeholder={placeholder}\n                onReset={this.handleReset}\n                onChange={this.handleChange}\n                value={this.state.inputValue}\n                startAdornment={'Magnify'}\n                {...others}\n            />\n        );\n    }\n}\nexport default HiSearchField;\n"]}
96189
96209
 
96190
96210
  /***/ }),
96191
96211
  /* 2699 */
@@ -96232,7 +96252,6 @@ var styles = exports.styles = function styles(theme) {
96232
96252
  textAlign: 'center',
96233
96253
  borderRadius: '45px',
96234
96254
  verticalAlign: 'middle',
96235
- margin: 0.5 * theme.spacing.unit,
96236
96255
  fontSize: 11,
96237
96256
  fontWeight: theme.typography.fontWeightMedium,
96238
96257
  fontFamily: theme.typography.fontFamily
@@ -96285,7 +96304,7 @@ HiPins.propTypes = {
96285
96304
  onClick: _propTypes2.default.func
96286
96305
  };
96287
96306
  exports.default = (0, _styles.withStyles)(styles, { withTheme: true, name: 'HmuiHiPins' })(HiPins);
96288
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9IaVBpbnMvSGlQaW5zLmpzIl0sIm5hbWVzIjpbInN0eWxlcyIsInJvb3QiLCJkaXNwbGF5IiwicGFkZGluZyIsImhlaWdodCIsImxpbmVIZWlnaHQiLCJtaW5XaWR0aCIsInRleHRBbGlnbiIsImJvcmRlclJhZGl1cyIsInZlcnRpY2FsQWxpZ24iLCJtYXJnaW4iLCJ0aGVtZSIsInNwYWNpbmciLCJ1bml0IiwiZm9udFNpemUiLCJmb250V2VpZ2h0IiwidHlwb2dyYXBoeSIsImZvbnRXZWlnaHRNZWRpdW0iLCJmb250RmFtaWx5IiwiY2xpY2FibGUiLCJjdXJzb3IiLCJIaVBpbnMiLCJwcm9wcyIsImNsYXNzZXMiLCJjaGlsZHJlbiIsImNvbG9yIiwib25DbGljayIsImNsYXNzTmFtZSIsInRleHRDb2xvciIsInBhbGV0dGUiLCJuZXV0cmFsIiwiZGFyayIsImRpdlByb3BzIiwic3R5bGUiLCJiYWNrZ3JvdW5kQ29sb3IiLCJyb2xlIiwicHJvcFR5cGVzIiwibm9kZSIsImlzUmVxdWlyZWQiLCJvYmplY3QiLCJzdHJpbmciLCJmdW5jIiwid2l0aFRoZW1lIiwibmFtZSJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBRUE7Ozs7QUFDQTs7OztBQUNBOzs7O0FBQ0E7O0FBQ0E7Ozs7OztBQUVPLElBQU1BLDBCQUFTLFNBQVRBLE1BQVM7QUFBQSxXQUFVO0FBQzVCQyxjQUFNO0FBQ0ZDLHFCQUFTLGNBRFA7QUFFRkMscUJBQVMsT0FGUDtBQUdGQyxvQkFBUSxFQUhOO0FBSUZDLHdCQUFZLE1BSlY7QUFLRkMsc0JBQVUsRUFMUjtBQU1GQyx1QkFBVyxRQU5UO0FBT0ZDLDBCQUFjLE1BUFo7QUFRRkMsMkJBQWUsUUFSYjtBQVNGQyxvQkFBUSxNQUFNQyxNQUFNQyxPQUFOLENBQWNDLElBVDFCO0FBVUZDLHNCQUFVLEVBVlI7QUFXRkMsd0JBQVlKLE1BQU1LLFVBQU4sQ0FBaUJDLGdCQVgzQjtBQVlGQyx3QkFBWVAsTUFBTUssVUFBTixDQUFpQkU7QUFaM0IsU0FEc0I7QUFlNUJDLGtCQUFVO0FBQ05DLG9CQUFRO0FBREY7QUFma0IsS0FBVjtBQUFBLENBQWY7O0FBb0JQOzs7Ozs7OztBQVFBLFNBQVNDLE1BQVQsQ0FBZ0JDLEtBQWhCLEVBQXVCO0FBQUEsUUFDWEMsT0FEVyxHQUNzQ0QsS0FEdEMsQ0FDWEMsT0FEVztBQUFBLFFBQ0ZDLFFBREUsR0FDc0NGLEtBRHRDLENBQ0ZFLFFBREU7QUFBQSxRQUNRQyxLQURSLEdBQ3NDSCxLQUR0QyxDQUNRRyxLQURSO0FBQUEsUUFDZUMsT0FEZixHQUNzQ0osS0FEdEMsQ0FDZUksT0FEZjtBQUFBLFFBQ3dCQyxTQUR4QixHQUNzQ0wsS0FEdEMsQ0FDd0JLLFNBRHhCOzs7QUFHbkIsUUFBTUMsWUFBWSw4Q0FBdUJILEtBQXZCLEVBQThCSCxNQUFNWCxLQUFOLENBQVlrQixPQUFaLENBQW9CQyxPQUFwQixDQUE0QkMsSUFBMUQsRUFBZ0UsTUFBaEUsQ0FBbEI7O0FBRUEsUUFBTUMsV0FBVztBQUNiQyxlQUFPLEVBQUVDLGlCQUFpQlQsS0FBbkIsRUFBMEJBLE9BQU9HLFNBQWpDO0FBRE0sS0FBakI7QUFHQSxRQUFJRixPQUFKLEVBQWE7QUFDVE0saUJBQVNOLE9BQVQsR0FBbUJBLE9BQW5CO0FBQ0FNLGlCQUFTRyxJQUFULEdBQWdCLFFBQWhCO0FBQ0g7QUFDRCxXQUNJO0FBQUE7QUFBQTtBQUNJLHVCQUFXLDBCQUNQWixRQUFRdEIsSUFERCxzQkFHRnNCLFFBQVFKLFFBSE4sRUFHaUJPLE9BSGpCLEdBS1BDLFNBTE87QUFEZixXQVFRSyxRQVJSO0FBVUtSO0FBVkwsS0FESjtBQWNIOztBQUVESCxPQUFPZSxTQUFQLEdBQW1CO0FBQ2ZaLGNBQVUsb0JBQVVhLElBQVYsQ0FBZUMsVUFEVjtBQUVmZixhQUFTLG9CQUFVZ0IsTUFBVixDQUFpQkQsVUFGWDtBQUdmWCxlQUFXLG9CQUFVYSxNQUhOO0FBSWZmLFdBQU8sb0JBQVVlLE1BQVYsQ0FBaUJGLFVBSlQ7QUFLZlosYUFBUyxvQkFBVWU7QUFMSixDQUFuQjtrQkFPZSx3QkFBV3pDLE1BQVgsRUFBbUIsRUFBRTBDLFdBQVcsSUFBYixFQUFtQkMsTUFBTSxZQUF6QixFQUFuQixFQUE0RHRCLE1BQTVELEMiLCJmaWxlIjoiSGlQaW5zLmpzIiwic291cmNlUm9vdCI6Ii9ob21lL21mYXppby9kZXYvcHJvamVjdHMvaGlwYXktbWF0ZXJpYWwtdWkiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBAZmxvd1xuXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IFByb3BUeXBlcyBmcm9tICdwcm9wLXR5cGVzJztcbmltcG9ydCBjbGFzc05hbWVzIGZyb20gJ2NsYXNzbmFtZXMnO1xuaW1wb3J0IHsgd2l0aFN0eWxlcyB9IGZyb20gJy4uL3N0eWxlcyc7XG5pbXBvcnQgeyBnZXRDb250cmFzdGVkVGV4dENvbG9yIH0gZnJvbSAnLi4vc3R5bGVzL2NvbG9yTWFuaXB1bGF0b3InO1xuXG5leHBvcnQgY29uc3Qgc3R5bGVzID0gdGhlbWUgPT4gKHtcbiAgICByb290OiB7XG4gICAgICAgIGRpc3BsYXk6ICdpbmxpbmUtYmxvY2snLFxuICAgICAgICBwYWRkaW5nOiAnMCA5cHgnLFxuICAgICAgICBoZWlnaHQ6IDE2LFxuICAgICAgICBsaW5lSGVpZ2h0OiAnMTZweCcsXG4gICAgICAgIG1pbldpZHRoOiAyNSxcbiAgICAgICAgdGV4dEFsaWduOiAnY2VudGVyJyxcbiAgICAgICAgYm9yZGVyUmFkaXVzOiAnNDVweCcsXG4gICAgICAgIHZlcnRpY2FsQWxpZ246ICdtaWRkbGUnLFxuICAgICAgICBtYXJnaW46IDAuNSAqIHRoZW1lLnNwYWNpbmcudW5pdCxcbiAgICAgICAgZm9udFNpemU6IDExLFxuICAgICAgICBmb250V2VpZ2h0OiB0aGVtZS50eXBvZ3JhcGh5LmZvbnRXZWlnaHRNZWRpdW0sXG4gICAgICAgIGZvbnRGYW1pbHk6IHRoZW1lLnR5cG9ncmFwaHkuZm9udEZhbWlseSxcbiAgICB9LFxuICAgIGNsaWNhYmxlOiB7XG4gICAgICAgIGN1cnNvcjogJ3BvaW50ZXInLFxuICAgIH0sXG59KTtcblxuLyoqXG4gKiBIaVBpbnNcbiAqXG4gKiBUaW55IHJhaXNlZCBidXR0b24gdXNlZCB0byBkaXNwbGF5IHN1YnNpZGlhcnkgZGF0YXMgbGlrZSBpdGVtIGNvdW50LCAoLi4uKSwgYW5kIHRocm93IGFuIG9uQ2xpY2sgZXZlbnQuXG4gKiBVc2VkIGluOlxuICogLSBDZWxsU3RhdHVzIHRvIGRpc3BsYXkgb3BlcmF0aW9ucyBjb3VudCBhbmQgdG8gZGVwbG95IG9wZXJhdGlvbiByb3dzIG9uIGNsaWNrLlxuICpcbiAqL1xuZnVuY3Rpb24gSGlQaW5zKHByb3BzKSB7XG4gICAgY29uc3QgeyBjbGFzc2VzLCBjaGlsZHJlbiwgY29sb3IsIG9uQ2xpY2ssIGNsYXNzTmFtZSB9ID0gcHJvcHM7XG5cbiAgICBjb25zdCB0ZXh0Q29sb3IgPSBnZXRDb250cmFzdGVkVGV4dENvbG9yKGNvbG9yLCBwcm9wcy50aGVtZS5wYWxldHRlLm5ldXRyYWwuZGFyaywgJyNGRkYnKTtcblxuICAgIGNvbnN0IGRpdlByb3BzID0ge1xuICAgICAgICBzdHlsZTogeyBiYWNrZ3JvdW5kQ29sb3I6IGNvbG9yLCBjb2xvcjogdGV4dENvbG9yIH0sXG4gICAgfTtcbiAgICBpZiAob25DbGljaykge1xuICAgICAgICBkaXZQcm9wcy5vbkNsaWNrID0gb25DbGljaztcbiAgICAgICAgZGl2UHJvcHMucm9sZSA9ICdidXR0b24nO1xuICAgIH1cbiAgICByZXR1cm4gKFxuICAgICAgICA8ZGl2XG4gICAgICAgICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZXMoXG4gICAgICAgICAgICAgICAgY2xhc3Nlcy5yb290LFxuICAgICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICAgICAgW2NsYXNzZXMuY2xpY2FibGVdOiBvbkNsaWNrLFxuICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgICAgY2xhc3NOYW1lLFxuICAgICAgICAgICAgKX1cbiAgICAgICAgICAgIHsuLi5kaXZQcm9wc31cbiAgICAgICAgPlxuICAgICAgICAgICAge2NoaWxkcmVufVxuICAgICAgICA8L2Rpdj5cbiAgICApO1xufVxuXG5IaVBpbnMucHJvcFR5cGVzID0ge1xuICAgIGNoaWxkcmVuOiBQcm9wVHlwZXMubm9kZS5pc1JlcXVpcmVkLFxuICAgIGNsYXNzZXM6IFByb3BUeXBlcy5vYmplY3QuaXNSZXF1aXJlZCxcbiAgICBjbGFzc05hbWU6IFByb3BUeXBlcy5zdHJpbmcsXG4gICAgY29sb3I6IFByb3BUeXBlcy5zdHJpbmcuaXNSZXF1aXJlZCxcbiAgICBvbkNsaWNrOiBQcm9wVHlwZXMuZnVuYyxcbn07XG5leHBvcnQgZGVmYXVsdCB3aXRoU3R5bGVzKHN0eWxlcywgeyB3aXRoVGhlbWU6IHRydWUsIG5hbWU6ICdIbXVpSGlQaW5zJyB9KShIaVBpbnMpO1xuIl19
96307
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9IaVBpbnMvSGlQaW5zLmpzIl0sIm5hbWVzIjpbInN0eWxlcyIsInJvb3QiLCJkaXNwbGF5IiwicGFkZGluZyIsImhlaWdodCIsImxpbmVIZWlnaHQiLCJtaW5XaWR0aCIsInRleHRBbGlnbiIsImJvcmRlclJhZGl1cyIsInZlcnRpY2FsQWxpZ24iLCJmb250U2l6ZSIsImZvbnRXZWlnaHQiLCJ0aGVtZSIsInR5cG9ncmFwaHkiLCJmb250V2VpZ2h0TWVkaXVtIiwiZm9udEZhbWlseSIsImNsaWNhYmxlIiwiY3Vyc29yIiwiSGlQaW5zIiwicHJvcHMiLCJjbGFzc2VzIiwiY2hpbGRyZW4iLCJjb2xvciIsIm9uQ2xpY2siLCJjbGFzc05hbWUiLCJ0ZXh0Q29sb3IiLCJwYWxldHRlIiwibmV1dHJhbCIsImRhcmsiLCJkaXZQcm9wcyIsInN0eWxlIiwiYmFja2dyb3VuZENvbG9yIiwicm9sZSIsInByb3BUeXBlcyIsIm5vZGUiLCJpc1JlcXVpcmVkIiwib2JqZWN0Iiwic3RyaW5nIiwiZnVuYyIsIndpdGhUaGVtZSIsIm5hbWUiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7OztBQUVBOzs7O0FBQ0E7Ozs7QUFDQTs7OztBQUNBOztBQUNBOzs7Ozs7QUFFTyxJQUFNQSwwQkFBUyxTQUFUQSxNQUFTO0FBQUEsV0FBVTtBQUM1QkMsY0FBTTtBQUNGQyxxQkFBUyxjQURQO0FBRUZDLHFCQUFTLE9BRlA7QUFHRkMsb0JBQVEsRUFITjtBQUlGQyx3QkFBWSxNQUpWO0FBS0ZDLHNCQUFVLEVBTFI7QUFNRkMsdUJBQVcsUUFOVDtBQU9GQywwQkFBYyxNQVBaO0FBUUZDLDJCQUFlLFFBUmI7QUFTRkMsc0JBQVUsRUFUUjtBQVVGQyx3QkFBWUMsTUFBTUMsVUFBTixDQUFpQkMsZ0JBVjNCO0FBV0ZDLHdCQUFZSCxNQUFNQyxVQUFOLENBQWlCRTtBQVgzQixTQURzQjtBQWM1QkMsa0JBQVU7QUFDTkMsb0JBQVE7QUFERjtBQWRrQixLQUFWO0FBQUEsQ0FBZjs7QUFtQlA7Ozs7Ozs7O0FBUUEsU0FBU0MsTUFBVCxDQUFnQkMsS0FBaEIsRUFBdUI7QUFBQSxRQUNYQyxPQURXLEdBQ3NDRCxLQUR0QyxDQUNYQyxPQURXO0FBQUEsUUFDRkMsUUFERSxHQUNzQ0YsS0FEdEMsQ0FDRkUsUUFERTtBQUFBLFFBQ1FDLEtBRFIsR0FDc0NILEtBRHRDLENBQ1FHLEtBRFI7QUFBQSxRQUNlQyxPQURmLEdBQ3NDSixLQUR0QyxDQUNlSSxPQURmO0FBQUEsUUFDd0JDLFNBRHhCLEdBQ3NDTCxLQUR0QyxDQUN3QkssU0FEeEI7OztBQUduQixRQUFNQyxZQUFZLDhDQUF1QkgsS0FBdkIsRUFBOEJILE1BQU1QLEtBQU4sQ0FBWWMsT0FBWixDQUFvQkMsT0FBcEIsQ0FBNEJDLElBQTFELEVBQWdFLE1BQWhFLENBQWxCOztBQUVBLFFBQU1DLFdBQVc7QUFDYkMsZUFBTyxFQUFFQyxpQkFBaUJULEtBQW5CLEVBQTBCQSxPQUFPRyxTQUFqQztBQURNLEtBQWpCO0FBR0EsUUFBSUYsT0FBSixFQUFhO0FBQ1RNLGlCQUFTTixPQUFULEdBQW1CQSxPQUFuQjtBQUNBTSxpQkFBU0csSUFBVCxHQUFnQixRQUFoQjtBQUNIO0FBQ0QsV0FDSTtBQUFBO0FBQUE7QUFDSSx1QkFBVywwQkFDUFosUUFBUW5CLElBREQsc0JBR0ZtQixRQUFRSixRQUhOLEVBR2lCTyxPQUhqQixHQUtQQyxTQUxPO0FBRGYsV0FRUUssUUFSUjtBQVVLUjtBQVZMLEtBREo7QUFjSDs7QUFFREgsT0FBT2UsU0FBUCxHQUFtQjtBQUNmWixjQUFVLG9CQUFVYSxJQUFWLENBQWVDLFVBRFY7QUFFZmYsYUFBUyxvQkFBVWdCLE1BQVYsQ0FBaUJELFVBRlg7QUFHZlgsZUFBVyxvQkFBVWEsTUFITjtBQUlmZixXQUFPLG9CQUFVZSxNQUFWLENBQWlCRixVQUpUO0FBS2ZaLGFBQVMsb0JBQVVlO0FBTEosQ0FBbkI7a0JBT2Usd0JBQVd0QyxNQUFYLEVBQW1CLEVBQUV1QyxXQUFXLElBQWIsRUFBbUJDLE1BQU0sWUFBekIsRUFBbkIsRUFBNER0QixNQUE1RCxDIiwiZmlsZSI6IkhpUGlucy5qcyIsInNvdXJjZVJvb3QiOiIvaG9tZS9tZmF6aW8vZGV2L3Byb2plY3RzL2hpcGF5LW1hdGVyaWFsLXVpIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQGZsb3dcblxuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgY2xhc3NOYW1lcyBmcm9tICdjbGFzc25hbWVzJztcbmltcG9ydCB7IHdpdGhTdHlsZXMgfSBmcm9tICcuLi9zdHlsZXMnO1xuaW1wb3J0IHsgZ2V0Q29udHJhc3RlZFRleHRDb2xvciB9IGZyb20gJy4uL3N0eWxlcy9jb2xvck1hbmlwdWxhdG9yJztcblxuZXhwb3J0IGNvbnN0IHN0eWxlcyA9IHRoZW1lID0+ICh7XG4gICAgcm9vdDoge1xuICAgICAgICBkaXNwbGF5OiAnaW5saW5lLWJsb2NrJyxcbiAgICAgICAgcGFkZGluZzogJzAgOXB4JyxcbiAgICAgICAgaGVpZ2h0OiAxNixcbiAgICAgICAgbGluZUhlaWdodDogJzE2cHgnLFxuICAgICAgICBtaW5XaWR0aDogMjUsXG4gICAgICAgIHRleHRBbGlnbjogJ2NlbnRlcicsXG4gICAgICAgIGJvcmRlclJhZGl1czogJzQ1cHgnLFxuICAgICAgICB2ZXJ0aWNhbEFsaWduOiAnbWlkZGxlJyxcbiAgICAgICAgZm9udFNpemU6IDExLFxuICAgICAgICBmb250V2VpZ2h0OiB0aGVtZS50eXBvZ3JhcGh5LmZvbnRXZWlnaHRNZWRpdW0sXG4gICAgICAgIGZvbnRGYW1pbHk6IHRoZW1lLnR5cG9ncmFwaHkuZm9udEZhbWlseSxcbiAgICB9LFxuICAgIGNsaWNhYmxlOiB7XG4gICAgICAgIGN1cnNvcjogJ3BvaW50ZXInLFxuICAgIH0sXG59KTtcblxuLyoqXG4gKiBIaVBpbnNcbiAqXG4gKiBUaW55IHJhaXNlZCBidXR0b24gdXNlZCB0byBkaXNwbGF5IHN1YnNpZGlhcnkgZGF0YXMgbGlrZSBpdGVtIGNvdW50LCAoLi4uKSwgYW5kIHRocm93IGFuIG9uQ2xpY2sgZXZlbnQuXG4gKiBVc2VkIGluOlxuICogLSBDZWxsU3RhdHVzIHRvIGRpc3BsYXkgb3BlcmF0aW9ucyBjb3VudCBhbmQgdG8gZGVwbG95IG9wZXJhdGlvbiByb3dzIG9uIGNsaWNrLlxuICpcbiAqL1xuZnVuY3Rpb24gSGlQaW5zKHByb3BzKSB7XG4gICAgY29uc3QgeyBjbGFzc2VzLCBjaGlsZHJlbiwgY29sb3IsIG9uQ2xpY2ssIGNsYXNzTmFtZSB9ID0gcHJvcHM7XG5cbiAgICBjb25zdCB0ZXh0Q29sb3IgPSBnZXRDb250cmFzdGVkVGV4dENvbG9yKGNvbG9yLCBwcm9wcy50aGVtZS5wYWxldHRlLm5ldXRyYWwuZGFyaywgJyNGRkYnKTtcblxuICAgIGNvbnN0IGRpdlByb3BzID0ge1xuICAgICAgICBzdHlsZTogeyBiYWNrZ3JvdW5kQ29sb3I6IGNvbG9yLCBjb2xvcjogdGV4dENvbG9yIH0sXG4gICAgfTtcbiAgICBpZiAob25DbGljaykge1xuICAgICAgICBkaXZQcm9wcy5vbkNsaWNrID0gb25DbGljaztcbiAgICAgICAgZGl2UHJvcHMucm9sZSA9ICdidXR0b24nO1xuICAgIH1cbiAgICByZXR1cm4gKFxuICAgICAgICA8ZGl2XG4gICAgICAgICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZXMoXG4gICAgICAgICAgICAgICAgY2xhc3Nlcy5yb290LFxuICAgICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICAgICAgW2NsYXNzZXMuY2xpY2FibGVdOiBvbkNsaWNrLFxuICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgICAgY2xhc3NOYW1lLFxuICAgICAgICAgICAgKX1cbiAgICAgICAgICAgIHsuLi5kaXZQcm9wc31cbiAgICAgICAgPlxuICAgICAgICAgICAge2NoaWxkcmVufVxuICAgICAgICA8L2Rpdj5cbiAgICApO1xufVxuXG5IaVBpbnMucHJvcFR5cGVzID0ge1xuICAgIGNoaWxkcmVuOiBQcm9wVHlwZXMubm9kZS5pc1JlcXVpcmVkLFxuICAgIGNsYXNzZXM6IFByb3BUeXBlcy5vYmplY3QuaXNSZXF1aXJlZCxcbiAgICBjbGFzc05hbWU6IFByb3BUeXBlcy5zdHJpbmcsXG4gICAgY29sb3I6IFByb3BUeXBlcy5zdHJpbmcuaXNSZXF1aXJlZCxcbiAgICBvbkNsaWNrOiBQcm9wVHlwZXMuZnVuYyxcbn07XG5leHBvcnQgZGVmYXVsdCB3aXRoU3R5bGVzKHN0eWxlcywgeyB3aXRoVGhlbWU6IHRydWUsIG5hbWU6ICdIbXVpSGlQaW5zJyB9KShIaVBpbnMpO1xuIl19
96289
96308
 
96290
96309
  /***/ }),
96291
96310
  /* 2700 */
@@ -96421,7 +96440,8 @@ var styles = exports.styles = function styles(theme) {
96421
96440
  controlLabelRoot: {
96422
96441
  marginLeft: 6,
96423
96442
  marginBottom: 8,
96424
- fontSize: 15
96443
+ fontSize: 15,
96444
+ width: 160
96425
96445
  },
96426
96446
  switchLabelRoot: {
96427
96447
  marginLeft: 15,
@@ -96430,7 +96450,10 @@ var styles = exports.styles = function styles(theme) {
96430
96450
  columnLabel: {
96431
96451
  position: 'relative',
96432
96452
  top: 5,
96433
- left: 5
96453
+ left: 5,
96454
+ overflow: 'hidden',
96455
+ textOverflow: 'ellipsis',
96456
+ whiteSpace: 'nowrap'
96434
96457
  },
96435
96458
  label: {
96436
96459
  fontWeight: 'inherit'
@@ -96836,7 +96859,7 @@ OrderColumns.defaultProps = {
96836
96859
  }
96837
96860
  };
96838
96861
  exports.default = (0, _withStyles2.default)(styles, { name: 'HmuiOrderColumns' })(OrderColumns);
96839
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["src/HiTable/OrderColumns.js"],"names":["cst","styles","menu","width","paddingTop","menuTitle","fontSize","fontWeight","paddingLeft","fontFamily","marginBottom","closeMenu","height","color","theme","palette","neutral","normal","cursor","float","marginRight","marginTop","itemFilter","backgroundColor","hover","typography","fontWeightMedium","itemFilterDate","checkbox","position","top","columnList","maxHeight","controlLabelRoot","marginLeft","switchLabelRoot","columnLabel","left","label","dragIcon","helperClass","zIndex","svgIcon","right","fill","business","primary","iconDisabled","reducedLabel","textTransform","fontWeightLight","switchChecked","OrderColumns","props","state","searchValue","suggestions","orderedColumns","handleSearch","bind","handleReset","handleSortEnd","handleChangeView","getFilteredSuggestions","toggleDisplay","toggleDisplayTime","nextProps","nextContext","setState","filter","columns","item","colId","toLowerCase","search","trim","event","value","target","oldIndex","newIndex","reorderedColumns","updateOrderedColumns","index","findIndex","newOrderedColumns","$merge","displayed","hasOwnProperty","type","TYPE_DATE","displayTime","newView","view","VIEWS","SMALL","MEDIUM","LARGE","classes","anchorEl","isOpen","onClose","mandatoryColumnId","translations","DragHandle","root","SortableItem","sortIndex","dragDisabled","column","rootIconClass","onClick","viewIcon","fixedWidth","checked","time","SortableList","items","map","paper","choose_and_organize_columns","length","Component","propTypes","object","isRequired","bool","string","func","array","defaultProps","name"],"mappings":"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","file":"OrderColumns.js","sourceRoot":"/home/mfazio/dev/projects/hipay-material-ui","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport classNames from 'classnames';\nimport update from 'react-addons-update';\nimport Popover from 'material-ui/Popover';\nimport { Close, Drag } from 'mdi-material-ui';\nimport { SortableContainer, SortableElement, SortableHandle, arrayMove } from 'react-sortable-hoc';\nimport { FormControlLabel } from 'material-ui/Form';\nimport { grey } from 'material-ui/colors';\nimport HiSizeMediumIcon from '../svg-icons/HiSizeMedium';\nimport HiSizeLargeIcon from '../svg-icons/HiSizeLarge';\nimport HiSizeSmallIcon from '../svg-icons/HiSizeSmall';\nimport HiCheckbox from '../HiCheckbox';\nimport HiInput from '../HiForm/HiInput';\nimport HiSwitch from '../HiSwitch';\n\nimport withStyles from '../styles/withStyles';\nimport * as cst from './constants';\nimport { Scrollbars } from 'react-custom-scrollbars';\n\nexport const styles = theme => ({\n    menu: {\n        width: 300,\n        paddingTop: 15,\n    },\n    menuTitle: {\n        fontSize: 20,\n        fontWeight: 300,\n        paddingLeft: 12,\n        fontFamily: 'Roboto, Helvetica, Arial, sans-serif',\n        marginBottom: 16,\n    },\n    closeMenu: {\n        width: 24,\n        height: 24,\n        color: theme.palette.neutral.normal,\n        cursor: 'pointer',\n        float: 'right',\n        marginRight: 10,\n        marginTop: -5,\n    },\n    itemFilter: {\n        '&:hover': {\n            backgroundColor: theme.palette.hover,\n            fontWeight: theme.typography.fontWeightMedium,\n        },\n        height: 40,\n        width: '100%',\n        paddingLeft: 3,\n        fontFamily: 'Roboto, Helvetica, Arial, sans-serif',\n    },\n    itemFilterDate: {\n        height: 80,\n    },\n    checkbox: {\n        position: 'relative',\n        top: 2,\n    },\n    columnList: {\n        maxHeight: 440,\n        marginTop: 15,\n    },\n    controlLabelRoot: {\n        marginLeft: 6,\n        marginBottom: 8,\n        fontSize: 15,\n    },\n    switchLabelRoot: {\n        marginLeft: 15,\n        fontSize: 15,\n    },\n    columnLabel: {\n        position: 'relative',\n        top: 5,\n        left: 5,\n    },\n    label: {\n        fontWeight: 'inherit',\n    },\n    dragIcon: {\n        cursor: 'move',\n        position: 'relative',\n        top: 6,\n    },\n    helperClass: {\n        zIndex: 1550,\n    },\n    svgIcon: {\n        position: 'relative',\n        top: 10,\n        right: 25,\n        float: 'right',\n        cursor: 'pointer',\n        fill: theme.palette.business.primary.normal,\n    },\n    iconDisabled: {\n        fill: grey[300],\n        cursor: 'inherit',\n    },\n    reducedLabel: {\n        textTransform: 'uppercase',\n        fontSize: 11,\n        fontWeight: theme.typography.fontWeightLight,\n        color: theme.palette.neutral.normal,\n    },\n    switchChecked: {\n        color: theme.palette.neutral.normal,\n    },\n});\n\n/**\n * Construit une popover listant les colonnes du tableaux,\n * afin de les masquer / afficher / ordonner.\n */\nclass OrderColumns extends React.Component {\n    static propTypes = {\n        /**\n         * Ancre de l'élément sur lequel le click a été déclenché\n         * Utilisé pour positionner le composant.\n         */\n        anchorEl: PropTypes.object,\n        /**\n         * Useful to extend the style applied to components.\n         */\n        classes: PropTypes.object,\n        /**\n         * Tableau des colonnes utilisées par le tableau\n         */\n        columns: PropTypes.object.isRequired,\n        /**\n         * Détermine si le menu de configuration des colonnes est ouvert ou non\n         */\n        isOpen: PropTypes.bool.isRequired,\n        /**\n         * Id de la colonne obligatoire, ne pourra être cachée\n         */\n        mandatoryColumnId: PropTypes.string.isRequired,\n        /**\n         * Fonction de callback pour fermer, agit sur la propriété 'isOpen'\n         */\n        onClose: PropTypes.func.isRequired,\n        /**\n         * Tableau des colonnes affichées (ordonnées, visibles/cachées, l/m/s)\n         */\n        orderedColumns: PropTypes.array.isRequired,\n        /**\n         * Traduction des chaînes affichées\n         */\n        translations: PropTypes.object,\n        /**\n         * Fonction de callback qui prend en paramètre le tableau des colonnes mis à jour.\n         */\n        updateOrderedColumns: PropTypes.func,\n    };\n\n    static defaultProps = {\n        translations: {\n            choose_and_organize_columns: 'Choose & organize columns',\n            search: 'Search',\n            time: 'Time',\n        },\n    };\n\n    constructor(props) {\n        super();\n\n        this.state = {\n            searchValue: '',\n            suggestions: props.orderedColumns,\n        };\n\n        this.handleSearch = this.handleSearch.bind(this);\n        this.handleReset = this.handleReset.bind(this);\n        this.handleSortEnd = this.handleSortEnd.bind(this);\n        this.handleChangeView = this.handleChangeView.bind(this);\n        this.getFilteredSuggestions = this.getFilteredSuggestions.bind(this);\n        this.toggleDisplay = this.toggleDisplay.bind(this);\n        this.toggleDisplayTime = this.toggleDisplayTime.bind(this);\n    }\n\n    /**\n     * Update suggestion list\n     * @param nextProps\n     * @param nextContext\n     */\n    componentWillReceiveProps(nextProps, nextContext) {\n        if (this.props.orderedColumns !== nextProps.orderedColumns) {\n            this.setState({\n                suggestions: this.getFilteredSuggestions(\n                    nextProps.orderedColumns,\n                    this.state.searchValue,\n                ),\n            });\n        }\n    }\n\n    getFilteredSuggestions(orderedColumns, searchValue) {\n        if (searchValue === '') {\n            return orderedColumns;\n        }\n        return orderedColumns.filter(\n            item =>\n                this.props.columns[item.colId].label\n                    .toLowerCase()\n                    .search(searchValue.trim().toLowerCase()) !== -1,\n        );\n    }\n\n    handleReset() {\n        this.setState({ searchValue: '', suggestions: this.props.orderedColumns });\n    }\n\n    handleSearch(event) {\n        const value = event.target.value;\n        this.setState({\n            searchValue: value,\n            suggestions: this.getFilteredSuggestions(this.props.orderedColumns, value),\n        });\n    }\n\n    handleSortEnd({ oldIndex, newIndex }) {\n        const reorderedColumns = arrayMove(this.props.orderedColumns, oldIndex, newIndex);\n\n        if (typeof this.props.updateOrderedColumns !== 'undefined') {\n            this.props.updateOrderedColumns(reorderedColumns);\n        }\n    }\n\n    toggleDisplay(colId) {\n        const index = this.props.orderedColumns.findIndex(item => item.colId === colId);\n\n        // use Immutability to update array as new array\n        const newOrderedColumns = update(this.props.orderedColumns, {\n            [index]: {\n                $merge: {\n                    displayed: this.props.orderedColumns[index].hasOwnProperty('displayed')\n                        ? !this.props.orderedColumns[index].displayed\n                        : false,\n                },\n            },\n        });\n\n        if (typeof this.props.updateOrderedColumns !== 'undefined') {\n            this.props.updateOrderedColumns(newOrderedColumns);\n        }\n    }\n\n    /**\n     * Pour les colonnes de type date, affiche l'heure en plus de la date\n     *\n     * @param colId\n     */\n    toggleDisplayTime(colId) {\n        if (this.props.columns[colId].type === cst.TYPE_DATE) {\n            const index = this.props.orderedColumns.findIndex(item => item.colId === colId);\n\n            // use Immutability to update array as new array\n            const newOrderedColumns = update(this.props.orderedColumns, {\n                [index]: {\n                    $merge: {\n                        displayTime: this.props.orderedColumns[index].hasOwnProperty('displayTime')\n                            ? !this.props.orderedColumns[index].displayTime\n                            : false,\n                    },\n                },\n            });\n\n            if (typeof this.props.updateOrderedColumns !== 'undefined') {\n                this.props.updateOrderedColumns(newOrderedColumns);\n            }\n        }\n    }\n\n    handleChangeView(item, index) {\n        let newView;\n        switch (item.view) {\n            case cst.VIEWS.SMALL:\n                newView = cst.VIEWS.MEDIUM;\n                break;\n            case cst.VIEWS.MEDIUM:\n                newView = cst.VIEWS.LARGE;\n                break;\n            case cst.VIEWS.LARGE:\n            default:\n                newView = cst.VIEWS.SMALL;\n                break;\n        }\n\n        // use Immutability to update array as new array\n        const newOrderedColumns = update(this.props.orderedColumns, {\n            [index]: { $merge: { view: newView } },\n        });\n\n        if (typeof this.props.updateOrderedColumns !== 'undefined') {\n            this.props.updateOrderedColumns(newOrderedColumns);\n        }\n    }\n\n    render() {\n        const {\n            classes,\n            anchorEl,\n            isOpen,\n            onClose,\n            columns,\n            mandatoryColumnId,\n            translations,\n        } = this.props;\n        const { searchValue, suggestions } = this.state;\n\n        const DragHandle = SortableHandle(() => <Drag classes={{ root: classes.dragIcon }} />);\n\n        const SortableItem = SortableElement(({ item, sortIndex, dragDisabled }) => {\n            const column = columns[item.colId];\n            const rootIconClass = classNames(classes.svgIcon, {\n                [classes.iconDisabled]: item.displayed === false,\n            });\n            const onClick =\n                item.displayed === false ? null : () => this.handleChangeView(item, sortIndex);\n\n            let viewIcon;\n            if (column.fixedWidth !== true) {\n                switch (item.view) {\n                    case cst.VIEWS.SMALL:\n                        viewIcon = (\n                            <HiSizeSmallIcon\n                                classes={{ root: rootIconClass }}\n                                onClick={onClick}\n                                className={'viewIconSmall'}\n                            />\n                        );\n                        break;\n                    case cst.VIEWS.MEDIUM:\n                        viewIcon = (\n                            <HiSizeMediumIcon\n                                classes={{ root: rootIconClass }}\n                                onClick={onClick}\n                                className={'viewIconMedium'}\n                            />\n                        );\n                        break;\n                    default:\n                        viewIcon = (\n                            <HiSizeLargeIcon\n                                classes={{ root: rootIconClass }}\n                                onClick={onClick}\n                                className={'viewIconLarge'}\n                            />\n                        );\n                        break;\n                }\n            }\n\n            return (\n                <div\n                    className={classNames(classes.itemFilter, {\n                        [classes.itemFilterDate]: column.type === 'date',\n                    })}\n                >\n                    {dragDisabled || <DragHandle classes={{ root: classes.dragIcon }} />}\n                    <FormControlLabel\n                        classes={{\n                            root: classes.controlLabelRoot,\n                            label: classNames(classes.columnLabel, classes.label),\n                        }}\n                        control={\n                            <HiCheckbox\n                                classes={{ root: classes.checkbox }}\n                                checked={item.displayed !== false}\n                                onChange={() => this.toggleDisplay(item.colId)}\n                                disabled={mandatoryColumnId === item.colId}\n                            />\n                        }\n                        label={column.label}\n                    />\n                    {item.view === cst.VIEWS.SMALL &&\n                        typeof column.reducedLabel !== 'undefined' && (\n                            <span className={classes.reducedLabel}>{column.reducedLabel}</span>\n                        )}\n                    {viewIcon}\n                    {column.type === cst.TYPE_DATE && (\n                        <div>\n                            <FormControlLabel\n                                classes={{ root: classes.switchLabelRoot, label: classes.label }}\n                                control={\n                                    <HiSwitch\n                                        checked={item.displayTime}\n                                        classes={{ checked: classes.switchChecked }}\n                                        onChange={() => this.toggleDisplayTime(item.colId)}\n                                    />\n                                }\n                                disabled={item.displayed === false}\n                                label={translations.time}\n                            />\n                        </div>\n                    )}\n                </div>\n            );\n        });\n\n        const SortableList = SortableContainer(({ items, dragDisabled }) => {\n            return (\n                <div className={classes.columnList}>\n                    {items.map((item, index) => {\n                        return (\n                            <SortableItem\n                                key={`sortable-item-${item.colId}`}\n                                item={item}\n                                index={index}\n                                sortIndex={index}\n                                dragDisabled={dragDisabled}\n                            />\n                        );\n                    })}\n                </div>\n            );\n        });\n\n        return (\n            <Popover\n                id=\"order-columns-menu\"\n                anchorEl={anchorEl}\n                anchorReference={'anchorEl'}\n                open={isOpen}\n                classes={{ paper: classes.menu }}\n                onClose={onClose}\n            >\n                <div className={classes.menuTitle}>\n                    <span>{translations.choose_and_organize_columns}</span>\n                    <Close classes={{ root: classes.closeMenu }} onClick={onClose} />\n                </div>\n                <HiInput\n                    value={searchValue}\n                    onChange={this.handleSearch}\n                    onReset={this.handleReset}\n                    placeholder={translations.search}\n                    startAdornment={\"Magnify\"}\n                />\n                <Scrollbars autoHeight autoHeightMax={440}>\n                    <SortableList\n                        items={suggestions}\n                        onSortEnd={this.handleSortEnd}\n                        useDragHandle\n                        helperClass={classes.helperClass}\n                        lockAxis={'y'}\n                        dragDisabled={searchValue.length > 0}\n                    />\n                </Scrollbars>\n            </Popover>\n        );\n    }\n}\n\nexport default withStyles(styles, { name: 'HmuiOrderColumns' })(OrderColumns);\n"]}
96862
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["src/HiTable/OrderColumns.js"],"names":["cst","styles","menu","width","paddingTop","menuTitle","fontSize","fontWeight","paddingLeft","fontFamily","marginBottom","closeMenu","height","color","theme","palette","neutral","normal","cursor","float","marginRight","marginTop","itemFilter","backgroundColor","hover","typography","fontWeightMedium","itemFilterDate","checkbox","position","top","columnList","maxHeight","controlLabelRoot","marginLeft","switchLabelRoot","columnLabel","left","overflow","textOverflow","whiteSpace","label","dragIcon","helperClass","zIndex","svgIcon","right","fill","business","primary","iconDisabled","reducedLabel","textTransform","fontWeightLight","switchChecked","OrderColumns","props","state","searchValue","suggestions","orderedColumns","handleSearch","bind","handleReset","handleSortEnd","handleChangeView","getFilteredSuggestions","toggleDisplay","toggleDisplayTime","nextProps","nextContext","setState","filter","columns","item","colId","toLowerCase","search","trim","event","value","target","oldIndex","newIndex","reorderedColumns","updateOrderedColumns","index","findIndex","newOrderedColumns","$merge","displayed","hasOwnProperty","type","TYPE_DATE","displayTime","newView","view","VIEWS","SMALL","MEDIUM","LARGE","classes","anchorEl","isOpen","onClose","mandatoryColumnId","translations","DragHandle","root","SortableItem","sortIndex","dragDisabled","column","rootIconClass","onClick","viewIcon","fixedWidth","checked","time","SortableList","items","map","paper","choose_and_organize_columns","length","Component","propTypes","object","isRequired","bool","string","func","array","defaultProps","name"],"mappings":"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","file":"OrderColumns.js","sourceRoot":"/home/mfazio/dev/projects/hipay-material-ui","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport classNames from 'classnames';\nimport update from 'react-addons-update';\nimport Popover from 'material-ui/Popover';\nimport { Close, Drag } from 'mdi-material-ui';\nimport { SortableContainer, SortableElement, SortableHandle, arrayMove } from 'react-sortable-hoc';\nimport { FormControlLabel } from 'material-ui/Form';\nimport { grey } from 'material-ui/colors';\nimport HiSizeMediumIcon from '../svg-icons/HiSizeMedium';\nimport HiSizeLargeIcon from '../svg-icons/HiSizeLarge';\nimport HiSizeSmallIcon from '../svg-icons/HiSizeSmall';\nimport HiCheckbox from '../HiCheckbox';\nimport HiInput from '../HiForm/HiInput';\nimport HiSwitch from '../HiSwitch';\n\nimport withStyles from '../styles/withStyles';\nimport * as cst from './constants';\nimport { Scrollbars } from 'react-custom-scrollbars';\n\nexport const styles = theme => ({\n    menu: {\n        width: 300,\n        paddingTop: 15,\n    },\n    menuTitle: {\n        fontSize: 20,\n        fontWeight: 300,\n        paddingLeft: 12,\n        fontFamily: 'Roboto, Helvetica, Arial, sans-serif',\n        marginBottom: 16,\n    },\n    closeMenu: {\n        width: 24,\n        height: 24,\n        color: theme.palette.neutral.normal,\n        cursor: 'pointer',\n        float: 'right',\n        marginRight: 10,\n        marginTop: -5,\n    },\n    itemFilter: {\n        '&:hover': {\n            backgroundColor: theme.palette.hover,\n            fontWeight: theme.typography.fontWeightMedium,\n        },\n        height: 40,\n        width: '100%',\n        paddingLeft: 3,\n        fontFamily: 'Roboto, Helvetica, Arial, sans-serif',\n    },\n    itemFilterDate: {\n        height: 80,\n    },\n    checkbox: {\n        position: 'relative',\n        top: 2,\n    },\n    columnList: {\n        maxHeight: 440,\n        marginTop: 15,\n    },\n    controlLabelRoot: {\n        marginLeft: 6,\n        marginBottom: 8,\n        fontSize: 15,\n        width: 160,\n    },\n    switchLabelRoot: {\n        marginLeft: 15,\n        fontSize: 15,\n    },\n    columnLabel: {\n        position: 'relative',\n        top: 5,\n        left: 5,\n        overflow: 'hidden',\n        textOverflow: 'ellipsis',\n        whiteSpace: 'nowrap',\n    },\n    label: {\n        fontWeight: 'inherit',\n    },\n    dragIcon: {\n        cursor: 'move',\n        position: 'relative',\n        top: 6,\n    },\n    helperClass: {\n        zIndex: 1550,\n    },\n    svgIcon: {\n        position: 'relative',\n        top: 10,\n        right: 25,\n        float: 'right',\n        cursor: 'pointer',\n        fill: theme.palette.business.primary.normal,\n    },\n    iconDisabled: {\n        fill: grey[300],\n        cursor: 'inherit',\n    },\n    reducedLabel: {\n        textTransform: 'uppercase',\n        fontSize: 11,\n        fontWeight: theme.typography.fontWeightLight,\n        color: theme.palette.neutral.normal,\n    },\n    switchChecked: {\n        color: theme.palette.neutral.normal,\n    },\n});\n\n/**\n * Construit une popover listant les colonnes du tableaux,\n * afin de les masquer / afficher / ordonner.\n */\nclass OrderColumns extends React.Component {\n    static propTypes = {\n        /**\n         * Ancre de l'élément sur lequel le click a été déclenché\n         * Utilisé pour positionner le composant.\n         */\n        anchorEl: PropTypes.object,\n        /**\n         * Useful to extend the style applied to components.\n         */\n        classes: PropTypes.object,\n        /**\n         * Tableau des colonnes utilisées par le tableau\n         */\n        columns: PropTypes.object.isRequired,\n        /**\n         * Détermine si le menu de configuration des colonnes est ouvert ou non\n         */\n        isOpen: PropTypes.bool.isRequired,\n        /**\n         * Id de la colonne obligatoire, ne pourra être cachée\n         */\n        mandatoryColumnId: PropTypes.string.isRequired,\n        /**\n         * Fonction de callback pour fermer, agit sur la propriété 'isOpen'\n         */\n        onClose: PropTypes.func.isRequired,\n        /**\n         * Tableau des colonnes affichées (ordonnées, visibles/cachées, l/m/s)\n         */\n        orderedColumns: PropTypes.array.isRequired,\n        /**\n         * Traduction des chaînes affichées\n         */\n        translations: PropTypes.object,\n        /**\n         * Fonction de callback qui prend en paramètre le tableau des colonnes mis à jour.\n         */\n        updateOrderedColumns: PropTypes.func,\n    };\n\n    static defaultProps = {\n        translations: {\n            choose_and_organize_columns: 'Choose & organize columns',\n            search: 'Search',\n            time: 'Time',\n        },\n    };\n\n    constructor(props) {\n        super();\n\n        this.state = {\n            searchValue: '',\n            suggestions: props.orderedColumns,\n        };\n\n        this.handleSearch = this.handleSearch.bind(this);\n        this.handleReset = this.handleReset.bind(this);\n        this.handleSortEnd = this.handleSortEnd.bind(this);\n        this.handleChangeView = this.handleChangeView.bind(this);\n        this.getFilteredSuggestions = this.getFilteredSuggestions.bind(this);\n        this.toggleDisplay = this.toggleDisplay.bind(this);\n        this.toggleDisplayTime = this.toggleDisplayTime.bind(this);\n    }\n\n    /**\n     * Update suggestion list\n     * @param nextProps\n     * @param nextContext\n     */\n    componentWillReceiveProps(nextProps, nextContext) {\n        if (this.props.orderedColumns !== nextProps.orderedColumns) {\n            this.setState({\n                suggestions: this.getFilteredSuggestions(\n                    nextProps.orderedColumns,\n                    this.state.searchValue,\n                ),\n            });\n        }\n    }\n\n    getFilteredSuggestions(orderedColumns, searchValue) {\n        if (searchValue === '') {\n            return orderedColumns;\n        }\n        return orderedColumns.filter(\n            item =>\n                this.props.columns[item.colId].label\n                    .toLowerCase()\n                    .search(searchValue.trim().toLowerCase()) !== -1,\n        );\n    }\n\n    handleReset() {\n        this.setState({ searchValue: '', suggestions: this.props.orderedColumns });\n    }\n\n    handleSearch(event) {\n        const value = event.target.value;\n        this.setState({\n            searchValue: value,\n            suggestions: this.getFilteredSuggestions(this.props.orderedColumns, value),\n        });\n    }\n\n    handleSortEnd({ oldIndex, newIndex }) {\n        const reorderedColumns = arrayMove(this.props.orderedColumns, oldIndex, newIndex);\n\n        if (typeof this.props.updateOrderedColumns !== 'undefined') {\n            this.props.updateOrderedColumns(reorderedColumns);\n        }\n    }\n\n    toggleDisplay(colId) {\n        const index = this.props.orderedColumns.findIndex(item => item.colId === colId);\n\n        // use Immutability to update array as new array\n        const newOrderedColumns = update(this.props.orderedColumns, {\n            [index]: {\n                $merge: {\n                    displayed: this.props.orderedColumns[index].hasOwnProperty('displayed')\n                        ? !this.props.orderedColumns[index].displayed\n                        : false,\n                },\n            },\n        });\n\n        if (typeof this.props.updateOrderedColumns !== 'undefined') {\n            this.props.updateOrderedColumns(newOrderedColumns);\n        }\n    }\n\n    /**\n     * Pour les colonnes de type date, affiche l'heure en plus de la date\n     *\n     * @param colId\n     */\n    toggleDisplayTime(colId) {\n        if (this.props.columns[colId].type === cst.TYPE_DATE) {\n            const index = this.props.orderedColumns.findIndex(item => item.colId === colId);\n\n            // use Immutability to update array as new array\n            const newOrderedColumns = update(this.props.orderedColumns, {\n                [index]: {\n                    $merge: {\n                        displayTime: this.props.orderedColumns[index].hasOwnProperty('displayTime')\n                            ? !this.props.orderedColumns[index].displayTime\n                            : false,\n                    },\n                },\n            });\n\n            if (typeof this.props.updateOrderedColumns !== 'undefined') {\n                this.props.updateOrderedColumns(newOrderedColumns);\n            }\n        }\n    }\n\n    handleChangeView(item, index) {\n        let newView;\n        switch (item.view) {\n            case cst.VIEWS.SMALL:\n                newView = cst.VIEWS.MEDIUM;\n                break;\n            case cst.VIEWS.MEDIUM:\n                newView = cst.VIEWS.LARGE;\n                break;\n            case cst.VIEWS.LARGE:\n            default:\n                newView = cst.VIEWS.SMALL;\n                break;\n        }\n\n        // use Immutability to update array as new array\n        const newOrderedColumns = update(this.props.orderedColumns, {\n            [index]: { $merge: { view: newView } },\n        });\n\n        if (typeof this.props.updateOrderedColumns !== 'undefined') {\n            this.props.updateOrderedColumns(newOrderedColumns);\n        }\n    }\n\n    render() {\n        const {\n            classes,\n            anchorEl,\n            isOpen,\n            onClose,\n            columns,\n            mandatoryColumnId,\n            translations,\n        } = this.props;\n        const { searchValue, suggestions } = this.state;\n\n        const DragHandle = SortableHandle(() => <Drag classes={{ root: classes.dragIcon }} />);\n\n        const SortableItem = SortableElement(({ item, sortIndex, dragDisabled }) => {\n            const column = columns[item.colId];\n            const rootIconClass = classNames(classes.svgIcon, {\n                [classes.iconDisabled]: item.displayed === false,\n            });\n            const onClick =\n                item.displayed === false ? null : () => this.handleChangeView(item, sortIndex);\n\n            let viewIcon;\n            if (column.fixedWidth !== true) {\n                switch (item.view) {\n                    case cst.VIEWS.SMALL:\n                        viewIcon = (\n                            <HiSizeSmallIcon\n                                classes={{ root: rootIconClass }}\n                                onClick={onClick}\n                                className={'viewIconSmall'}\n                            />\n                        );\n                        break;\n                    case cst.VIEWS.MEDIUM:\n                        viewIcon = (\n                            <HiSizeMediumIcon\n                                classes={{ root: rootIconClass }}\n                                onClick={onClick}\n                                className={'viewIconMedium'}\n                            />\n                        );\n                        break;\n                    default:\n                        viewIcon = (\n                            <HiSizeLargeIcon\n                                classes={{ root: rootIconClass }}\n                                onClick={onClick}\n                                className={'viewIconLarge'}\n                            />\n                        );\n                        break;\n                }\n            }\n\n            return (\n                <div\n                    className={classNames(classes.itemFilter, {\n                        [classes.itemFilterDate]: column.type === 'date',\n                    })}\n                >\n                    {dragDisabled || <DragHandle classes={{ root: classes.dragIcon }} />}\n                    <FormControlLabel\n                        classes={{\n                            root: classes.controlLabelRoot,\n                            label: classNames(classes.columnLabel, classes.label),\n                        }}\n                        control={\n                            <HiCheckbox\n                                classes={{ root: classes.checkbox }}\n                                checked={item.displayed !== false}\n                                onChange={() => this.toggleDisplay(item.colId)}\n                                disabled={mandatoryColumnId === item.colId}\n                            />\n                        }\n                        label={column.label}\n                    />\n                    {item.view === cst.VIEWS.SMALL &&\n                        typeof column.reducedLabel !== 'undefined' && (\n                            <span className={classes.reducedLabel}>{column.reducedLabel}</span>\n                        )}\n                    {viewIcon}\n                    {column.type === cst.TYPE_DATE && (\n                        <div>\n                            <FormControlLabel\n                                classes={{ root: classes.switchLabelRoot, label: classes.label }}\n                                control={\n                                    <HiSwitch\n                                        checked={item.displayTime}\n                                        classes={{ checked: classes.switchChecked }}\n                                        onChange={() => this.toggleDisplayTime(item.colId)}\n                                    />\n                                }\n                                disabled={item.displayed === false}\n                                label={translations.time}\n                            />\n                        </div>\n                    )}\n                </div>\n            );\n        });\n\n        const SortableList = SortableContainer(({ items, dragDisabled }) => {\n            return (\n                <div className={classes.columnList}>\n                    {items.map((item, index) => {\n                        return (\n                            <SortableItem\n                                key={`sortable-item-${item.colId}`}\n                                item={item}\n                                index={index}\n                                sortIndex={index}\n                                dragDisabled={dragDisabled}\n                            />\n                        );\n                    })}\n                </div>\n            );\n        });\n\n        return (\n            <Popover\n                id=\"order-columns-menu\"\n                anchorEl={anchorEl}\n                anchorReference={'anchorEl'}\n                open={isOpen}\n                classes={{ paper: classes.menu }}\n                onClose={onClose}\n            >\n                <div className={classes.menuTitle}>\n                    <span>{translations.choose_and_organize_columns}</span>\n                    <Close classes={{ root: classes.closeMenu }} onClick={onClose} />\n                </div>\n                <HiInput\n                    value={searchValue}\n                    onChange={this.handleSearch}\n                    onReset={this.handleReset}\n                    placeholder={translations.search}\n                    startAdornment={\"Magnify\"}\n                />\n                <Scrollbars autoHeight autoHeightMax={440}>\n                    <SortableList\n                        items={suggestions}\n                        onSortEnd={this.handleSortEnd}\n                        useDragHandle\n                        helperClass={classes.helperClass}\n                        lockAxis={'y'}\n                        dragDisabled={searchValue.length > 0}\n                    />\n                </Scrollbars>\n            </Popover>\n        );\n    }\n}\n\nexport default withStyles(styles, { name: 'HmuiOrderColumns' })(OrderColumns);\n"]}
96840
96863
 
96841
96864
  /***/ }),
96842
96865
  /* 2701 */
@@ -102788,7 +102811,8 @@ var HiTableBody = function (_React$Component) {
102788
102811
  numberLocale = _props.numberLocale,
102789
102812
  groupByIds = _props.groupByIds,
102790
102813
  sortedColumnId = _props.sortedColumnId,
102791
- lookupColumns = _props.lookupColumns;
102814
+ lookupColumns = _props.lookupColumns,
102815
+ loading = _props.loading;
102792
102816
  var _state = this.state,
102793
102817
  openedParentRowId = _state.openedParentRowId,
102794
102818
  openedDetailsRowIdList = _state.openedDetailsRowIdList;
@@ -102928,7 +102952,11 @@ var HiTableBody = function (_React$Component) {
102928
102952
  {
102929
102953
  id: tabId + '-body',
102930
102954
  className: classes.tbody,
102931
- style: { height: height },
102955
+ style: _extends({
102956
+ height: height
102957
+ }, loading && {
102958
+ opacity: 0.6
102959
+ }),
102932
102960
  onScroll: onScroll
102933
102961
  },
102934
102962
  tableRows.map(function (tableRow) {
@@ -102971,6 +102999,10 @@ HiTableBody.propTypes = {
102971
102999
  * Hauteur du tableau (px)
102972
103000
  */
102973
103001
  height: _propTypes2.default.number,
103002
+ /**
103003
+ * État du tableau en cours de chargement des données
103004
+ */
103005
+ loading: _propTypes2.default.bool,
102974
103006
  /**
102975
103007
  * Identifiant de la ou des colonnes sur la/lesquelles il y a une 'lookup' search
102976
103008
  */
@@ -103050,10 +103082,11 @@ HiTableBody.defaultProps = {
103050
103082
  dense: false,
103051
103083
  height: 450,
103052
103084
  sticky: true,
103053
- view: 'l'
103085
+ view: 'l',
103086
+ loading: false
103054
103087
  };
103055
103088
  exports.default = (0, _styles.withStyles)(styles, { withTheme: true, name: 'HmuiHiTableBody' })(HiTableBody);
103056
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["src/HiTable/HiTableBody.js"],"names":["cst","styles","tbody","position","display","width","overflowX","overflowY","zIndex","tbodyRows","backgroundColor","theme","palette","background3","tbodyRowsHover","hover","fontWeight","typography","fontWeightMedium","rightShadow","borderWidth","borderStyle","webkitBorderImage","mozBorderImage","oBorderImage","borderImage","bottomShadow","patchDiv","height","top","HiTableBody","props","buildIndicator","columns","dateLocale","indicator","indicatorColumn","row","parentIndicatorColumn","type","options","year","month","day","hour","minute","date","Date","datas","value","toLocaleString","state","openedParentRowId","openedDetailsRowIdList","bind","setOpenedParentRowId","toggleOpenedDetailsRowId","positionStickyRowNextButton","prevProps","prevState","prevContext","setState","rowId","addNewRowRefs","tableContainer","document","getElementById","tabId","stickyRowNextButtons","getElementsByClassName","length","Array","prototype","filter","call","button","index","style","parentElement","previousSibling","dense","CELL_HEIGHT_DENSE","CELL_HEIGHT","label","left","offsetWidth","includes","id","classes","orderedColumns","dataSource","onRowClick","selectable","onSelect","selectedIdList","onScroll","dateUpdate","sticky","view","groupBy","translations","numberLocale","groupByIds","sortedColumnId","lookupColumns","nbColumnsDisplayed","forEach","column","displayed","tableRows","stickyRowValue","stickyRowIndex","currentGroupByValue","isFinite","substr","TYPE_DATE","weekday","charAt","toUpperCase","push","stickyRow","onClickNext","hasChildren","hasOwnProperty","children","hasDetailRows","detailRows","BodyRowProps","live","ts","onClick","openedAsParent","onOpenRowDetails","selected","parentLabel","parentLabelIcon","detailRowProps","detailRow","isDetail","map","tableRow","Component","propTypes","object","isRequired","array","string","number","bool","func","oneOf","defaultProps","withTheme","name"],"mappings":"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","file":"HiTableBody.js","sourceRoot":"/home/mfazio/dev/projects/hipay-material-ui","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport { TableBody, TableRow } from 'material-ui/Table';\nimport { withStyles, withTheme } from '../styles';\nimport BodyRow from './BodyRow';\nimport ChildRow from './ChildRow';\nimport HiStickyRow from './HiStickyRow';\nimport * as cst from './constants';\nimport { SORTED_COLUMN_ERROR_MESSAGE } from './HiTableHead';\nimport isRequiredIf from 'react-proptype-conditional-require';\n\nexport const styles = theme => ({\n    tbody: {\n        position: 'relative',\n        display: 'block' /* seperates the tbody from the header */,\n        width: '100%',\n        overflowX: 'hidden',\n        overflowY: 'auto',\n        zIndex: 11,\n    },\n    tbodyRows: {\n        backgroundColor: theme.palette.background3,\n    },\n    tbodyRowsHover: {\n        '&:hover': {\n            backgroundColor: theme.palette.hover,\n            fontWeight: theme.typography.fontWeightMedium,\n        },\n    },\n    rightShadow: {\n        borderWidth: '4px 4px 4px 0',\n        borderStyle: 'solid',\n        webkitBorderImage:\n            '-webkit-linear-gradient(right, rgba(42, 42, 42, 0.1), rgba(0, 0, 0, 0)) 1 100%',\n        mozBorderImage:\n            '-moz-linear-gradient(right, rgba(42, 42, 42, 0.1), rgba(0, 0, 0, 0)) 1 100%',\n        oBorderImage: '-o-linear-gradient(right, rgba(42, 42, 42, 0.1), rgba(0, 0, 0, 0)) 1 100%',\n        borderImage: 'linear-gradient(to right, rgba(42, 42, 42, 0.1), rgba(0, 0, 0, 0)) 1 100%',\n    },\n    bottomShadow: {\n        borderWidth: '0 0 4px 0',\n        borderStyle: 'solid',\n        webkitBorderImage:\n            '-webkit-linear-gradient(top, rgba(0,0,0, 0.08) 0%, rgba(0,0,0, 0) 100%)',\n        mozBorderImage: '-moz-linear-gradient(top, rgba(0,0,0, 0.08), rgba(0,0,0, 0) 1 100%)',\n        oBorderImage: '-o-linear-gradient(top, rgba(0,0,0, 0.08), rgba(0, 0, 0, 0)) 1 100%',\n        borderImage: 'linear-gradient(to top, rgba(0, 0, 0, 0.08), rgba(0, 0, 0, 0)) 1 100%',\n    },\n    patchDiv: {\n        position: 'absolute',\n        width: 24,\n        height: 50,\n        top: 0,\n        zIndex: 15,\n        backgroundColor: theme.palette.background3,\n    },\n});\n\n/**\n * HiTable Body\n * Handle rows creation and update from datasource\n */\nclass HiTableBody extends React.Component {\n    static propTypes = {\n        /**\n         * Useful to extend the style applied to components.\n         */\n        classes: PropTypes.object,\n        /**\n         * Colonnes du tableau (label, largeur, données, ... )\n         */\n        columns: PropTypes.object.isRequired,\n        /**\n         * Tableau des données\n         */\n        dataSource: PropTypes.array.isRequired,\n        /**\n         * Locale utilisée pour le format des dates\n         */\n        dateLocale: PropTypes.string,\n        /**\n         * Timestamp de la dernière mise à jour du tableau\n         * permet d'animer les nouvelles lignes\n         */\n        dateUpdate: PropTypes.number,\n        /**\n         * Densité d'affichage (joue sur la hauteur des lignes)\n         */\n        dense: PropTypes.bool,\n        /**\n         * Hauteur du tableau (px)\n         */\n        height: PropTypes.number,\n        /**\n         * Identifiant de la ou des colonnes sur la/lesquelles il y a une 'lookup' search\n         */\n        lookupColumns: PropTypes.array,\n        /**\n         *  Locale utilisée pour le format des nombres\n         */\n        numberLocale: PropTypes.string,\n        /**\n         * Fonction de callback au click sur une ligne\n         * Passe l'id de la ligne (rowId)\n         */\n        onRowClick: PropTypes.func,\n        /**\n         * Fonction de callback au scroll sur le body du tableau\n         */\n        onScroll: PropTypes.func,\n        /**\n         * Fonction de callback sur la sélection d'une ligne\n         * (ou sélection/déselection de tous dans le header)\n         * Passe l'id de la ligne sélectionnée (rowId)\n         */\n        onSelect: PropTypes.func,\n        /**\n         * Tableau des colonnes affichées (ordonnées, visibles/cachées, l/m/s)\n         */\n        orderedColumns: PropTypes.array.isRequired,\n        /**\n         * [v2 - à venir] Les lignes sont sélectionnables (affichage d'une checkbox)\n         */\n        selectable: PropTypes.bool,\n        /**\n         * Liste des id des lignes sélectionnées\n         */\n        selectedIdList: PropTypes.array,\n        /**\n         * Fixe la première colonne\n         */\n        sticky: PropTypes.bool,\n        /**\n         * Identifiant unique à spécifier si on utilise plusieurs composants HiTable\n         */\n        tabId: PropTypes.string.isRequired,\n        /**\n         * Taille du tableau (L/M/S),\n         * définit l'espace entre les cellules et leurs tailles par default\n         */\n        view: PropTypes.oneOf(['l', 'm', 's']),\n        /**\n         * Id de la colonne par laquelle sont regroupé les éléments\n         */\n        groupBy: PropTypes.string,\n        /**\n         * Tableau associatif (parentGroupBy => id contenus)\n         */\n        groupByIds: PropTypes.object,\n        /**\n         * Id de la colonne trié\n         */\n        sortedColumnId: PropTypes.string,\n        /**\n         * Traduction des chaînes affichées\n         */\n        translations: PropTypes.object,\n        /**\n         * Callback lors d'un clic sur le bouton 'Next' d'une stickRow\n         * @param {int} index du stickyRow\n         */\n        onClickNext: PropTypes.func,\n    };\n\n    static defaultProps = {\n        selectable: false,\n        selectedIdList: [],\n        dateUpdate: null,\n        dateLocale: 'en-EN',\n        numberLocale: 'en-EN',\n        dense: false,\n        height: 450,\n        sticky: true,\n        view: 'l',\n    };\n\n    constructor(props) {\n        super();\n\n        this.state = {\n            openedParentRowId: null,\n            openedDetailsRowIdList: [],\n        };\n\n        this.buildIndicator = this.buildIndicator.bind(this);\n        this.setOpenedParentRowId = this.setOpenedParentRowId.bind(this);\n        this.toggleOpenedDetailsRowId = this.toggleOpenedDetailsRowId.bind(this);\n        this.positionStickyRowNextButton = this.positionStickyRowNextButton.bind(this);\n    }\n\n    componentDidMount() {\n        this.positionStickyRowNextButton();\n    }\n\n    componentDidUpdate(prevProps, prevState, prevContext) {\n        this.positionStickyRowNextButton();\n    }\n\n    /**\n     * Définit l'id de la ligne parente \"ouverte\" ou null\n     * (remplace la ligne par un sous-tableau)\n     * Il ne peut y avoir qu'une seule ligne parente \"ouverte\" à la fois\n     *\n     * @param row\n     */\n    setOpenedParentRowId(row) {\n        this.setState(prevState => ({\n            openedParentRowId:\n                prevState.openedParentRowId === null || prevState.openedParentRowId !== row.rowId\n                    ? row.rowId\n                    : null,\n        }));\n        this.props.addNewRowRefs();\n    }\n\n    positionStickyRowNextButton() {\n        // handle stickyRow next buttons position\n        const tableContainer = document.getElementById(this.props.tabId);\n        const stickyRowNextButtons = tableContainer.getElementsByClassName('stickyRowNextButton');\n        if (stickyRowNextButtons.length > 0) {\n            Array.prototype.filter.call(stickyRowNextButtons, (button, index) => {\n                if (index === stickyRowNextButtons.length - 1) {\n                    button.style.display = 'none';\n                    button.parentElement.style.top = '0px';\n                } else {\n                    if (button.style.display === 'none') {\n                        button.style.display = 'inline-block';\n                        if (\n                            button.parentElement.parentElement.parentElement.style.position ===\n                            'absolute'\n                        ) {\n                            button.parentElement.parentElement.previousSibling.style.height = this\n                                .props.dense\n                                ? `${cst.CELL_HEIGHT_DENSE - 8}px`\n                                : `${cst.CELL_HEIGHT - 8}px`;\n                        }\n                        button.parentElement.style.top = '4px';\n                    }\n                    const label = button.previousSibling.previousSibling;\n                    button.style.left = `${tableContainer.offsetWidth -\n                        label.offsetWidth -\n                        48 -\n                        160}px`;\n                }\n            });\n        }\n    }\n\n    /**\n     * Définit les id des lignes dont les détails sont affichés ou null\n     * (ajoute une ligne pour chaque détails)\n     *\n     * @param rowId\n     */\n    toggleOpenedDetailsRowId(rowId) {\n        this.setState(prevState => ({\n            openedDetailsRowIdList: prevState.openedDetailsRowIdList.includes(rowId)\n                ? prevState.openedDetailsRowIdList.filter(id => {\n                      return id !== rowId;\n                  })\n                : [...prevState.openedDetailsRowIdList, rowId],\n        }));\n        this.props.addNewRowRefs();\n    }\n\n    /**\n     * Build children sub-table indicator\n     * @param row\n     * @returns {*}\n     */\n    buildIndicator = row => {\n        const { columns, dateLocale } = this.props;\n\n        let indicator;\n        const indicatorColumn = columns[row.parentIndicatorColumn];\n        switch (indicatorColumn.type) {\n            case 'date':\n                const options = {\n                    year: 'numeric',\n                    month: '2-digit',\n                    day: '2-digit',\n                    hour: '2-digit',\n                    minute: '2-digit',\n                };\n                const date = new Date(row.datas[row.parentIndicatorColumn].value);\n                indicator = date.toLocaleString(dateLocale, options);\n                break;\n            case 'text':\n            default:\n                indicator = row.datas[row.parentIndicatorColumn].value;\n                break;\n        }\n\n        return indicator;\n    };\n\n    render() {\n        const {\n            classes,\n            tabId,\n            columns,\n            orderedColumns,\n            dataSource,\n            onRowClick,\n            selectable,\n            onSelect,\n            selectedIdList,\n            onScroll,\n            dateUpdate,\n            dense,\n            height,\n            sticky,\n            view,\n            groupBy,\n            translations,\n            dateLocale,\n            numberLocale,\n            groupByIds,\n            sortedColumnId,\n            lookupColumns,\n        } = this.props;\n\n        const { openedParentRowId, openedDetailsRowIdList } = this.state;\n\n        let nbColumnsDisplayed = 0;\n        orderedColumns.forEach(column => {\n            if (column.displayed !== false) {\n                nbColumnsDisplayed += 1;\n            }\n        });\n\n        // build components list\n        const tableRows = [];\n        let stickyRowValue;\n        let stickyRowIndex = 0;\n        dataSource.forEach((row, index) => {\n\n            // Gestion du sticky group by\n            if (typeof groupBy !== 'undefined' && groupBy === sortedColumnId) {\n                let currentGroupByValue = row.datas[groupBy].value;\n                const date = new Date(currentGroupByValue);\n                if (date instanceof Date && isFinite(date)) {\n                    currentGroupByValue = currentGroupByValue.substr(0, 10);\n                }\n                // TODO => condition for other columns type\n                if (columns[groupBy].type === cst.TYPE_DATE) {\n                    if (index === 0 || currentGroupByValue !== stickyRowValue) {\n                        stickyRowValue = currentGroupByValue;\n                        let label = stickyRowValue;\n                        if (date instanceof Date && isFinite(date)) {\n                            label = new Date(label);\n                            const options = {\n                                year: 'numeric',\n                                month: 'long',\n                                weekday: 'long',\n                                day: 'numeric',\n                            };\n                            label = label.toLocaleString(dateLocale, options);\n                            label = label.charAt(0).toUpperCase() + label.substr(1);\n                        }\n\n                        tableRows.push(\n                            <HiStickyRow\n                                key={`sticky_row_${row.rowId}`}\n                                dense={dense}\n                                value={stickyRowValue}\n                                label={label}\n                                length={groupByIds[currentGroupByValue].length}\n                                colSpan={nbColumnsDisplayed}\n                                index={stickyRowIndex}\n                                translations={translations.stickyRow}\n                                view={view}\n                                onClickNext={this.props.onClickNext}\n                            />,\n                        );\n\n                        tableRows.push(\n                            <TableRow\n                                key={`ghost_sticky_row_${row.rowId}`}\n                                className={'fakeStickyGroupBy'}\n                                style={{\n                                    height: dense ? cst.CELL_HEIGHT_DENSE : cst.CELL_HEIGHT,\n                                    display: 'none',\n                                }}\n                            />,\n                        );\n                        stickyRowIndex++;\n                    }\n                }\n            }\n\n            // has children\n            const hasChildren = row.hasOwnProperty('children') && row.children.length > 0;\n\n            // has detail rows\n            const hasDetailRows = row.hasOwnProperty('detailRows') && row.detailRows.length > 0;\n\n            const BodyRowProps = {\n                columns,\n                dateLocale,\n                numberLocale,\n                dense,\n                live: row.ts >= dateUpdate,\n                lookupColumns,\n                onClick: onRowClick,\n                ...(hasChildren && {\n                    openedAsParent: openedParentRowId === row.rowId,\n                    onClick: this.setOpenedParentRowId, // if row has children, onClick display the children\n                }),\n                ...(hasDetailRows && {\n                    onOpenRowDetails: this.toggleOpenedDetailsRowId,\n                }),\n                orderedColumns,\n                ...(selectable && {\n                    selectable,\n                    selected: selectedIdList.includes(row.rowId),\n                    onSelect,\n                }),\n                row,\n                sticky,\n                tabId,\n                view,\n            };\n\n            if (hasChildren && openedParentRowId === row.rowId) {\n                tableRows.push(\n                    <ChildRow\n                        key={`children-${row.rowId}`}\n                        parentRowId={row.rowId}\n                        parentRowDatas={row.datas}\n                        parentIndicatorColumn={row.parentIndicatorColumn}\n                        parentLabel={row.parentLabel}\n                        parentLabelIcon={row.parentLabelIcon}\n                        parentDetailRows={row.detailRows}\n                        children={row.children}\n                        onClose={this.setOpenedParentRowId}\n                        {...BodyRowProps}\n                    />,\n                );\n            } else {\n                tableRows.push(<BodyRow key={row.rowId} {...BodyRowProps} />);\n            }\n\n            // add opened detail rows\n            if (hasDetailRows && openedDetailsRowIdList.includes(row.rowId)) {\n                row.detailRows.forEach(detailRow => {\n                    const detailRowProps = {\n                        row: detailRow,\n                        columns,\n                        orderedColumns,\n                        view,\n                        dense,\n                        sticky,\n                        isDetail: true,\n                    };\n\n                    tableRows.push(\n                        <BodyRow key={`${row.rowId}-${detailRow.rowId}`} {...detailRowProps} />,\n                    );\n                });\n            }\n        });\n\n        return (\n            <TableBody\n                id={`${tabId}-body`}\n                className={classes.tbody}\n                style={{ height }}\n                onScroll={onScroll}\n            >\n                {tableRows.map(tableRow => {\n                    return tableRow;\n                })}\n            </TableBody>\n        );\n    }\n}\n\n\nexport default withStyles(styles, { withTheme: true, name: 'HmuiHiTableBody' })(HiTableBody);\n"]}
103089
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["src/HiTable/HiTableBody.js"],"names":["cst","styles","tbody","position","display","width","overflowX","overflowY","zIndex","tbodyRows","backgroundColor","theme","palette","background3","tbodyRowsHover","hover","fontWeight","typography","fontWeightMedium","rightShadow","borderWidth","borderStyle","webkitBorderImage","mozBorderImage","oBorderImage","borderImage","bottomShadow","patchDiv","height","top","HiTableBody","props","buildIndicator","columns","dateLocale","indicator","indicatorColumn","row","parentIndicatorColumn","type","options","year","month","day","hour","minute","date","Date","datas","value","toLocaleString","state","openedParentRowId","openedDetailsRowIdList","bind","setOpenedParentRowId","toggleOpenedDetailsRowId","positionStickyRowNextButton","prevProps","prevState","prevContext","setState","rowId","addNewRowRefs","tableContainer","document","getElementById","tabId","stickyRowNextButtons","getElementsByClassName","length","Array","prototype","filter","call","button","index","style","parentElement","previousSibling","dense","CELL_HEIGHT_DENSE","CELL_HEIGHT","label","left","offsetWidth","includes","id","classes","orderedColumns","dataSource","onRowClick","selectable","onSelect","selectedIdList","onScroll","dateUpdate","sticky","view","groupBy","translations","numberLocale","groupByIds","sortedColumnId","lookupColumns","loading","nbColumnsDisplayed","forEach","column","displayed","tableRows","stickyRowValue","stickyRowIndex","currentGroupByValue","isFinite","substr","TYPE_DATE","weekday","charAt","toUpperCase","push","stickyRow","onClickNext","hasChildren","hasOwnProperty","children","hasDetailRows","detailRows","BodyRowProps","live","ts","onClick","openedAsParent","onOpenRowDetails","selected","parentLabel","parentLabelIcon","detailRowProps","detailRow","isDetail","opacity","map","tableRow","Component","propTypes","object","isRequired","array","string","number","bool","func","oneOf","defaultProps","withTheme","name"],"mappings":"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","file":"HiTableBody.js","sourceRoot":"/home/mfazio/dev/projects/hipay-material-ui","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport { TableBody, TableRow } from 'material-ui/Table';\nimport { withStyles, withTheme } from '../styles';\nimport BodyRow from './BodyRow';\nimport ChildRow from './ChildRow';\nimport HiStickyRow from './HiStickyRow';\nimport * as cst from './constants';\nimport { SORTED_COLUMN_ERROR_MESSAGE } from './HiTableHead';\nimport isRequiredIf from 'react-proptype-conditional-require';\n\nexport const styles = theme => ({\n    tbody: {\n        position: 'relative',\n        display: 'block' /* seperates the tbody from the header */,\n        width: '100%',\n        overflowX: 'hidden',\n        overflowY: 'auto',\n        zIndex: 11,\n    },\n    tbodyRows: {\n        backgroundColor: theme.palette.background3,\n    },\n    tbodyRowsHover: {\n        '&:hover': {\n            backgroundColor: theme.palette.hover,\n            fontWeight: theme.typography.fontWeightMedium,\n        },\n    },\n    rightShadow: {\n        borderWidth: '4px 4px 4px 0',\n        borderStyle: 'solid',\n        webkitBorderImage:\n            '-webkit-linear-gradient(right, rgba(42, 42, 42, 0.1), rgba(0, 0, 0, 0)) 1 100%',\n        mozBorderImage:\n            '-moz-linear-gradient(right, rgba(42, 42, 42, 0.1), rgba(0, 0, 0, 0)) 1 100%',\n        oBorderImage: '-o-linear-gradient(right, rgba(42, 42, 42, 0.1), rgba(0, 0, 0, 0)) 1 100%',\n        borderImage: 'linear-gradient(to right, rgba(42, 42, 42, 0.1), rgba(0, 0, 0, 0)) 1 100%',\n    },\n    bottomShadow: {\n        borderWidth: '0 0 4px 0',\n        borderStyle: 'solid',\n        webkitBorderImage:\n            '-webkit-linear-gradient(top, rgba(0,0,0, 0.08) 0%, rgba(0,0,0, 0) 100%)',\n        mozBorderImage: '-moz-linear-gradient(top, rgba(0,0,0, 0.08), rgba(0,0,0, 0) 1 100%)',\n        oBorderImage: '-o-linear-gradient(top, rgba(0,0,0, 0.08), rgba(0, 0, 0, 0)) 1 100%',\n        borderImage: 'linear-gradient(to top, rgba(0, 0, 0, 0.08), rgba(0, 0, 0, 0)) 1 100%',\n    },\n    patchDiv: {\n        position: 'absolute',\n        width: 24,\n        height: 50,\n        top: 0,\n        zIndex: 15,\n        backgroundColor: theme.palette.background3,\n    },\n});\n\n/**\n * HiTable Body\n * Handle rows creation and update from datasource\n */\nclass HiTableBody extends React.Component {\n    static propTypes = {\n        /**\n         * Useful to extend the style applied to components.\n         */\n        classes: PropTypes.object,\n        /**\n         * Colonnes du tableau (label, largeur, données, ... )\n         */\n        columns: PropTypes.object.isRequired,\n        /**\n         * Tableau des données\n         */\n        dataSource: PropTypes.array.isRequired,\n        /**\n         * Locale utilisée pour le format des dates\n         */\n        dateLocale: PropTypes.string,\n        /**\n         * Timestamp de la dernière mise à jour du tableau\n         * permet d'animer les nouvelles lignes\n         */\n        dateUpdate: PropTypes.number,\n        /**\n         * Densité d'affichage (joue sur la hauteur des lignes)\n         */\n        dense: PropTypes.bool,\n        /**\n         * Hauteur du tableau (px)\n         */\n        height: PropTypes.number,\n        /**\n         * État du tableau en cours de chargement des données\n         */\n        loading: PropTypes.bool,\n        /**\n         * Identifiant de la ou des colonnes sur la/lesquelles il y a une 'lookup' search\n         */\n        lookupColumns: PropTypes.array,\n        /**\n         *  Locale utilisée pour le format des nombres\n         */\n        numberLocale: PropTypes.string,\n        /**\n         * Fonction de callback au click sur une ligne\n         * Passe l'id de la ligne (rowId)\n         */\n        onRowClick: PropTypes.func,\n        /**\n         * Fonction de callback au scroll sur le body du tableau\n         */\n        onScroll: PropTypes.func,\n        /**\n         * Fonction de callback sur la sélection d'une ligne\n         * (ou sélection/déselection de tous dans le header)\n         * Passe l'id de la ligne sélectionnée (rowId)\n         */\n        onSelect: PropTypes.func,\n        /**\n         * Tableau des colonnes affichées (ordonnées, visibles/cachées, l/m/s)\n         */\n        orderedColumns: PropTypes.array.isRequired,\n        /**\n         * [v2 - à venir] Les lignes sont sélectionnables (affichage d'une checkbox)\n         */\n        selectable: PropTypes.bool,\n        /**\n         * Liste des id des lignes sélectionnées\n         */\n        selectedIdList: PropTypes.array,\n        /**\n         * Fixe la première colonne\n         */\n        sticky: PropTypes.bool,\n        /**\n         * Identifiant unique à spécifier si on utilise plusieurs composants HiTable\n         */\n        tabId: PropTypes.string.isRequired,\n        /**\n         * Taille du tableau (L/M/S),\n         * définit l'espace entre les cellules et leurs tailles par default\n         */\n        view: PropTypes.oneOf(['l', 'm', 's']),\n        /**\n         * Id de la colonne par laquelle sont regroupé les éléments\n         */\n        groupBy: PropTypes.string,\n        /**\n         * Tableau associatif (parentGroupBy => id contenus)\n         */\n        groupByIds: PropTypes.object,\n        /**\n         * Id de la colonne trié\n         */\n        sortedColumnId: PropTypes.string,\n        /**\n         * Traduction des chaînes affichées\n         */\n        translations: PropTypes.object,\n        /**\n         * Callback lors d'un clic sur le bouton 'Next' d'une stickRow\n         * @param {int} index du stickyRow\n         */\n        onClickNext: PropTypes.func,\n    };\n\n    static defaultProps = {\n        selectable: false,\n        selectedIdList: [],\n        dateUpdate: null,\n        dateLocale: 'en-EN',\n        numberLocale: 'en-EN',\n        dense: false,\n        height: 450,\n        sticky: true,\n        view: 'l',\n        loading: false,\n    };\n\n    constructor(props) {\n        super();\n\n        this.state = {\n            openedParentRowId: null,\n            openedDetailsRowIdList: [],\n        };\n\n        this.buildIndicator = this.buildIndicator.bind(this);\n        this.setOpenedParentRowId = this.setOpenedParentRowId.bind(this);\n        this.toggleOpenedDetailsRowId = this.toggleOpenedDetailsRowId.bind(this);\n        this.positionStickyRowNextButton = this.positionStickyRowNextButton.bind(this);\n    }\n\n    componentDidMount() {\n        this.positionStickyRowNextButton();\n    }\n\n    componentDidUpdate(prevProps, prevState, prevContext) {\n        this.positionStickyRowNextButton();\n    }\n\n    /**\n     * Définit l'id de la ligne parente \"ouverte\" ou null\n     * (remplace la ligne par un sous-tableau)\n     * Il ne peut y avoir qu'une seule ligne parente \"ouverte\" à la fois\n     *\n     * @param row\n     */\n    setOpenedParentRowId(row) {\n        this.setState(prevState => ({\n            openedParentRowId:\n                prevState.openedParentRowId === null || prevState.openedParentRowId !== row.rowId\n                    ? row.rowId\n                    : null,\n        }));\n        this.props.addNewRowRefs();\n    }\n\n    positionStickyRowNextButton() {\n        // handle stickyRow next buttons position\n        const tableContainer = document.getElementById(this.props.tabId);\n        const stickyRowNextButtons = tableContainer.getElementsByClassName('stickyRowNextButton');\n        if (stickyRowNextButtons.length > 0) {\n            Array.prototype.filter.call(stickyRowNextButtons, (button, index) => {\n                if (index === stickyRowNextButtons.length - 1) {\n                    button.style.display = 'none';\n                    button.parentElement.style.top = '0px';\n                } else {\n                    if (button.style.display === 'none') {\n                        button.style.display = 'inline-block';\n                        if (\n                            button.parentElement.parentElement.parentElement.style.position ===\n                            'absolute'\n                        ) {\n                            button.parentElement.parentElement.previousSibling.style.height = this\n                                .props.dense\n                                ? `${cst.CELL_HEIGHT_DENSE - 8}px`\n                                : `${cst.CELL_HEIGHT - 8}px`;\n                        }\n                        button.parentElement.style.top = '4px';\n                    }\n                    const label = button.previousSibling.previousSibling;\n                    button.style.left = `${tableContainer.offsetWidth -\n                        label.offsetWidth -\n                        48 -\n                        160}px`;\n                }\n            });\n        }\n    }\n\n    /**\n     * Définit les id des lignes dont les détails sont affichés ou null\n     * (ajoute une ligne pour chaque détails)\n     *\n     * @param rowId\n     */\n    toggleOpenedDetailsRowId(rowId) {\n        this.setState(prevState => ({\n            openedDetailsRowIdList: prevState.openedDetailsRowIdList.includes(rowId)\n                ? prevState.openedDetailsRowIdList.filter(id => {\n                      return id !== rowId;\n                  })\n                : [...prevState.openedDetailsRowIdList, rowId],\n        }));\n        this.props.addNewRowRefs();\n    }\n\n    /**\n     * Build children sub-table indicator\n     * @param row\n     * @returns {*}\n     */\n    buildIndicator = row => {\n        const { columns, dateLocale } = this.props;\n\n        let indicator;\n        const indicatorColumn = columns[row.parentIndicatorColumn];\n        switch (indicatorColumn.type) {\n            case 'date':\n                const options = {\n                    year: 'numeric',\n                    month: '2-digit',\n                    day: '2-digit',\n                    hour: '2-digit',\n                    minute: '2-digit',\n                };\n                const date = new Date(row.datas[row.parentIndicatorColumn].value);\n                indicator = date.toLocaleString(dateLocale, options);\n                break;\n            case 'text':\n            default:\n                indicator = row.datas[row.parentIndicatorColumn].value;\n                break;\n        }\n\n        return indicator;\n    };\n\n    render() {\n        const {\n            classes,\n            tabId,\n            columns,\n            orderedColumns,\n            dataSource,\n            onRowClick,\n            selectable,\n            onSelect,\n            selectedIdList,\n            onScroll,\n            dateUpdate,\n            dense,\n            height,\n            sticky,\n            view,\n            groupBy,\n            translations,\n            dateLocale,\n            numberLocale,\n            groupByIds,\n            sortedColumnId,\n            lookupColumns,\n            loading,\n        } = this.props;\n\n        const { openedParentRowId, openedDetailsRowIdList } = this.state;\n\n        let nbColumnsDisplayed = 0;\n        orderedColumns.forEach(column => {\n            if (column.displayed !== false) {\n                nbColumnsDisplayed += 1;\n            }\n        });\n\n        // build components list\n        const tableRows = [];\n        let stickyRowValue;\n        let stickyRowIndex = 0;\n        dataSource.forEach((row, index) => {\n\n            // Gestion du sticky group by\n            if (typeof groupBy !== 'undefined' && groupBy === sortedColumnId) {\n                let currentGroupByValue = row.datas[groupBy].value;\n                const date = new Date(currentGroupByValue);\n                if (date instanceof Date && isFinite(date)) {\n                    currentGroupByValue = currentGroupByValue.substr(0, 10);\n                }\n                // TODO => condition for other columns type\n                if (columns[groupBy].type === cst.TYPE_DATE) {\n                    if (index === 0 || currentGroupByValue !== stickyRowValue) {\n                        stickyRowValue = currentGroupByValue;\n                        let label = stickyRowValue;\n                        if (date instanceof Date && isFinite(date)) {\n                            label = new Date(label);\n                            const options = {\n                                year: 'numeric',\n                                month: 'long',\n                                weekday: 'long',\n                                day: 'numeric',\n                            };\n                            label = label.toLocaleString(dateLocale, options);\n                            label = label.charAt(0).toUpperCase() + label.substr(1);\n                        }\n\n                        tableRows.push(\n                            <HiStickyRow\n                                key={`sticky_row_${row.rowId}`}\n                                dense={dense}\n                                value={stickyRowValue}\n                                label={label}\n                                length={groupByIds[currentGroupByValue].length}\n                                colSpan={nbColumnsDisplayed}\n                                index={stickyRowIndex}\n                                translations={translations.stickyRow}\n                                view={view}\n                                onClickNext={this.props.onClickNext}\n                            />,\n                        );\n\n                        tableRows.push(\n                            <TableRow\n                                key={`ghost_sticky_row_${row.rowId}`}\n                                className={'fakeStickyGroupBy'}\n                                style={{\n                                    height: dense ? cst.CELL_HEIGHT_DENSE : cst.CELL_HEIGHT,\n                                    display: 'none',\n                                }}\n                            />,\n                        );\n                        stickyRowIndex++;\n                    }\n                }\n            }\n\n            // has children\n            const hasChildren = row.hasOwnProperty('children') && row.children.length > 0;\n\n            // has detail rows\n            const hasDetailRows = row.hasOwnProperty('detailRows') && row.detailRows.length > 0;\n\n            const BodyRowProps = {\n                columns,\n                dateLocale,\n                numberLocale,\n                dense,\n                live: row.ts >= dateUpdate,\n                lookupColumns,\n                onClick: onRowClick,\n                ...(hasChildren && {\n                    openedAsParent: openedParentRowId === row.rowId,\n                    onClick: this.setOpenedParentRowId, // if row has children, onClick display the children\n                }),\n                ...(hasDetailRows && {\n                    onOpenRowDetails: this.toggleOpenedDetailsRowId,\n                }),\n                orderedColumns,\n                ...(selectable && {\n                    selectable,\n                    selected: selectedIdList.includes(row.rowId),\n                    onSelect,\n                }),\n                row,\n                sticky,\n                tabId,\n                view,\n            };\n\n            if (hasChildren && openedParentRowId === row.rowId) {\n                tableRows.push(\n                    <ChildRow\n                        key={`children-${row.rowId}`}\n                        parentRowId={row.rowId}\n                        parentRowDatas={row.datas}\n                        parentIndicatorColumn={row.parentIndicatorColumn}\n                        parentLabel={row.parentLabel}\n                        parentLabelIcon={row.parentLabelIcon}\n                        parentDetailRows={row.detailRows}\n                        children={row.children}\n                        onClose={this.setOpenedParentRowId}\n                        {...BodyRowProps}\n                    />,\n                );\n            } else {\n                tableRows.push(<BodyRow key={row.rowId} {...BodyRowProps} />);\n            }\n\n            // add opened detail rows\n            if (hasDetailRows && openedDetailsRowIdList.includes(row.rowId)) {\n                row.detailRows.forEach(detailRow => {\n                    const detailRowProps = {\n                        row: detailRow,\n                        columns,\n                        orderedColumns,\n                        view,\n                        dense,\n                        sticky,\n                        isDetail: true,\n                    };\n\n                    tableRows.push(\n                        <BodyRow key={`${row.rowId}-${detailRow.rowId}`} {...detailRowProps} />,\n                    );\n                });\n            }\n        });\n\n        return (\n            <TableBody\n                id={`${tabId}-body`}\n                className={classes.tbody}\n                style={{\n                    height,\n                    ...(loading && {\n                        opacity: 0.6,\n                    }),\n                }}\n                onScroll={onScroll}\n            >\n                {tableRows.map(tableRow => {\n                    return tableRow;\n                })}\n            </TableBody>\n        );\n    }\n}\n\n\nexport default withStyles(styles, { withTheme: true, name: 'HmuiHiTableBody' })(HiTableBody);\n"]}
103057
103090
 
103058
103091
  /***/ }),
103059
103092
  /* 2830 */
@@ -105282,6 +105315,10 @@ var styles = exports.styles = function styles(theme) {
105282
105315
  display: 'inline-flex',
105283
105316
  alignItems: 'baseline',
105284
105317
  maxWidth: 'calc(100% - 36px)'
105318
+ },
105319
+ pins: {
105320
+ position: 'relative',
105321
+ bottom: 1
105285
105322
  }
105286
105323
  };
105287
105324
  };
@@ -105321,7 +105358,7 @@ var CellStatus = function (_React$PureComponent) {
105321
105358
  _react2.default.createElement(_HiColoredLabel2.default, { label: value, color: color }),
105322
105359
  _react2.default.createElement(
105323
105360
  _HiPins2.default,
105324
- { color: color, onClick: onOpenDetails },
105361
+ { color: color, onClick: onOpenDetails, className: classes.pins },
105325
105362
  nbOperations
105326
105363
  )
105327
105364
  ) : _react2.default.createElement(_HiColoredLabel2.default, { label: value, color: color })
@@ -105363,7 +105400,7 @@ CellStatus.defaultProps = {
105363
105400
  nbOperations: 0
105364
105401
  };
105365
105402
  exports.default = (0, _styles.withStyles)(styles, { withTheme: true, name: 'HmuiCellStatus' })(CellStatus);
105366
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9IaVRhYmxlL0JvZHlDZWxscy9DZWxsU3RhdHVzLmpzIl0sIm5hbWVzIjpbInN0eWxlcyIsImxhYmVsRGl2IiwiZGlzcGxheSIsImFsaWduSXRlbXMiLCJtYXhXaWR0aCIsIkNlbGxTdGF0dXMiLCJwcm9wcyIsImNsYXNzZXMiLCJ0aGVtZSIsIm5iT3BlcmF0aW9ucyIsInZhbHVlIiwiY29kZSIsIm9uT3BlbkRldGFpbHMiLCJjb2xvciIsInBhbGV0dGUiLCJzdGF0dXMiLCJuZXV0cmFsIiwibm9ybWFsIiwic3RpY2t5IiwiUHVyZUNvbXBvbmVudCIsInByb3BUeXBlcyIsIm9iamVjdCIsIm51bWJlciIsImlzUmVxdWlyZWQiLCJzdHJpbmciLCJmdW5jIiwiZGVmYXVsdFByb3BzIiwid2l0aFRoZW1lIiwibmFtZSJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBQUE7Ozs7QUFDQTs7OztBQUVBOzs7O0FBQ0E7Ozs7QUFDQTs7QUFDQTs7Ozs7Ozs7Ozs7O0FBRU8sSUFBTUEsMEJBQVMsU0FBVEEsTUFBUztBQUFBLFdBQVU7QUFDNUJDLGtCQUFVO0FBQ05DLHFCQUFTLGFBREg7QUFFTkMsd0JBQVksVUFGTjtBQUdOQyxzQkFBVTtBQUhKO0FBRGtCLEtBQVY7QUFBQSxDQUFmOztJQVFEQyxVOzs7Ozs7Ozs7OztpQ0FnQ1E7QUFBQSx5QkFDK0QsS0FBS0MsS0FEcEU7QUFBQSxnQkFDRUMsT0FERixVQUNFQSxPQURGO0FBQUEsZ0JBQ1dDLEtBRFgsVUFDV0EsS0FEWDtBQUFBLGdCQUNrQkMsWUFEbEIsVUFDa0JBLFlBRGxCO0FBQUEsZ0JBQ2dDQyxLQURoQyxVQUNnQ0EsS0FEaEM7QUFBQSxnQkFDdUNDLElBRHZDLFVBQ3VDQSxJQUR2QztBQUFBLGdCQUM2Q0MsYUFEN0MsVUFDNkNBLGFBRDdDOzs7QUFHTixnQkFBTUMsUUFBUSxPQUFPTCxNQUFNTSxPQUFOLENBQWNDLE1BQWQsQ0FBcUJKLElBQXJCLENBQVAsS0FBc0MsV0FBdEMsR0FBb0RILE1BQU1NLE9BQU4sQ0FBY0MsTUFBZCxDQUFxQkosSUFBckIsQ0FBcEQsR0FBaUZILE1BQU1NLE9BQU4sQ0FBY0UsT0FBZCxDQUFzQkMsTUFBckg7O0FBRUEsbUJBQ0k7QUFBQTtBQUFBLGtCQUFTLE9BQU9QLEtBQWhCLEVBQXVCLFdBQVcsS0FBS0osS0FBTCxDQUFXWSxNQUFYLEdBQW9CLE9BQXBCLEdBQThCLFFBQWhFO0FBQ0k7QUFBQTtBQUFBO0FBQ0tULG1DQUFlLENBQWYsR0FDRztBQUFBO0FBQUEsMEJBQUssV0FBV0YsUUFBUU4sUUFBeEI7QUFDSSxrRkFBZ0IsT0FBT1MsS0FBdkIsRUFBOEIsT0FBT0csS0FBckMsR0FESjtBQUVJO0FBQUE7QUFBQSw4QkFBUSxPQUFPQSxLQUFmLEVBQXNCLFNBQVNELGFBQS9CO0FBQ0tIO0FBREw7QUFGSixxQkFESCxHQVFHLDBEQUFnQixPQUFPQyxLQUF2QixFQUE4QixPQUFPRyxLQUFyQztBQVRSO0FBREosYUFESjtBQWdCSDs7OztFQXJEb0IsZ0JBQU1NLGE7O0FBQXpCZCxVLENBQ0tlLFMsR0FBWTtBQUNmOzs7QUFHQWIsYUFBUyxvQkFBVWMsTUFKSjtBQUtmOzs7QUFHQWIsV0FBTyxvQkFBVWEsTUFSRjtBQVNmOzs7QUFHQVosa0JBQWMsb0JBQVVhLE1BQVYsQ0FBaUJDLFVBWmhCO0FBYWY7OztBQUdBYixXQUFPLG9CQUFVYyxNQUFWLENBQWlCRCxVQWhCVDtBQWlCZjs7O0FBR0FaLFVBQU0sb0JBQVVXLE1BQVYsQ0FBaUJDLFVBcEJSO0FBcUJmOzs7QUFHQVgsbUJBQWUsb0JBQVVhO0FBeEJWLEM7QUFEakJwQixVLENBNEJLcUIsWSxHQUFlO0FBQ2xCakIsa0JBQWM7QUFESSxDO2tCQTJCWCx3QkFBV1QsTUFBWCxFQUFtQixFQUFFMkIsV0FBVyxJQUFiLEVBQW1CQyxNQUFNLGdCQUF6QixFQUFuQixFQUFnRXZCLFVBQWhFLEMiLCJmaWxlIjoiQ2VsbFN0YXR1cy5qcyIsInNvdXJjZVJvb3QiOiIvaG9tZS9tZmF6aW8vZGV2L3Byb2plY3RzL2hpcGF5LW1hdGVyaWFsLXVpIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5cbmltcG9ydCBIaUNvbG9yZWRMYWJlbCBmcm9tICcuLi8uLi9IaUNvbG9yZWRMYWJlbCc7XG5pbXBvcnQgSGlQaW5zIGZyb20gJy4uLy4uL0hpUGlucyc7XG5pbXBvcnQgeyB3aXRoU3R5bGVzIH0gZnJvbSAnLi4vLi4vc3R5bGVzJztcbmltcG9ydCBUb29sdGlwIGZyb20gJy4uLy4uL1Rvb2x0aXAnO1xuXG5leHBvcnQgY29uc3Qgc3R5bGVzID0gdGhlbWUgPT4gKHtcbiAgICBsYWJlbERpdjoge1xuICAgICAgICBkaXNwbGF5OiAnaW5saW5lLWZsZXgnLFxuICAgICAgICBhbGlnbkl0ZW1zOiAnYmFzZWxpbmUnLFxuICAgICAgICBtYXhXaWR0aDogJ2NhbGMoMTAwJSAtIDM2cHgpJyxcbiAgICB9LFxufSk7XG5cbmNsYXNzIENlbGxTdGF0dXMgZXh0ZW5kcyBSZWFjdC5QdXJlQ29tcG9uZW50IHtcbiAgICBzdGF0aWMgcHJvcFR5cGVzID0ge1xuICAgICAgICAvKipcbiAgICAgICAgICogVXNlZnVsIHRvIGV4dGVuZCB0aGUgc3R5bGUgYXBwbGllZCB0byBjb21wb25lbnRzLlxuICAgICAgICAgKi9cbiAgICAgICAgY2xhc3NlczogUHJvcFR5cGVzLm9iamVjdCxcbiAgICAgICAgLyoqXG4gICAgICAgICAqIFtPUFRJT05BTF0gVXNlZnVsIHRvIG1vZGlmeSB0aGUgdGhlbWUgdXNlZCBieSBjb21wb25lbnRzLlxuICAgICAgICAgKi9cbiAgICAgICAgdGhlbWU6IFByb3BUeXBlcy5vYmplY3QsXG4gICAgICAgIC8qKlxuICAgICAgICAgKiBOb21icmUgZCdvcMOpcmF0aW9ucyBmaW5hbmNpw6hyZXNcbiAgICAgICAgICovXG4gICAgICAgIG5iT3BlcmF0aW9uczogUHJvcFR5cGVzLm51bWJlci5pc1JlcXVpcmVkLFxuICAgICAgICAvKipcbiAgICAgICAgICogU3RhdHV0IGNvdXJhbnQgZGUgbGEgdHJhbnNhY3Rpb25cbiAgICAgICAgICovXG4gICAgICAgIHZhbHVlOiBQcm9wVHlwZXMuc3RyaW5nLmlzUmVxdWlyZWQsXG4gICAgICAgIC8qKlxuICAgICAgICAgKiBDb2RlIGR1IHN0YXR1dCBjb3VyYW50IGRlIGxhIHRyYW5zYWN0aW9uIChkw6l0ZXJtaW5lIGxhIGNvdWxldXIgZHUgbGFiZWwpXG4gICAgICAgICAqL1xuICAgICAgICBjb2RlOiBQcm9wVHlwZXMubnVtYmVyLmlzUmVxdWlyZWQsXG4gICAgICAgIC8qKlxuICAgICAgICAgKiBGb25jdGlvbiBkZSBjYWxsYmFjayBhcHBlbMOpZSBwb3VyIG91dnJpciBsZXMgbGlnbmVzIGRlIGTDqXRhaWxzXG4gICAgICAgICAqL1xuICAgICAgICBvbk9wZW5EZXRhaWxzOiBQcm9wVHlwZXMuZnVuYyxcbiAgICB9O1xuXG4gICAgc3RhdGljIGRlZmF1bHRQcm9wcyA9IHtcbiAgICAgICAgbmJPcGVyYXRpb25zOiAwXG4gICAgfTtcblxuICAgIHJlbmRlciAoKSB7XG4gICAgICAgIGNvbnN0IHsgY2xhc3NlcywgdGhlbWUsIG5iT3BlcmF0aW9ucywgdmFsdWUsIGNvZGUsIG9uT3BlbkRldGFpbHMgfSA9IHRoaXMucHJvcHM7XG5cbiAgICAgICAgY29uc3QgY29sb3IgPSB0eXBlb2YgdGhlbWUucGFsZXR0ZS5zdGF0dXNbY29kZV0gIT09ICd1bmRlZmluZWQnID8gdGhlbWUucGFsZXR0ZS5zdGF0dXNbY29kZV0gOiB0aGVtZS5wYWxldHRlLm5ldXRyYWwubm9ybWFsO1xuXG4gICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICA8VG9vbHRpcCB0aXRsZT17dmFsdWV9IHBsYWNlbWVudD17dGhpcy5wcm9wcy5zdGlja3kgPyAncmlnaHQnIDogJ2JvdHRvbSd9PlxuICAgICAgICAgICAgICAgIDxkaXY+XG4gICAgICAgICAgICAgICAgICAgIHtuYk9wZXJhdGlvbnMgPiAwID8gKFxuICAgICAgICAgICAgICAgICAgICAgICAgPGRpdiBjbGFzc05hbWU9e2NsYXNzZXMubGFiZWxEaXZ9PlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxIaUNvbG9yZWRMYWJlbCBsYWJlbD17dmFsdWV9IGNvbG9yPXtjb2xvcn0gLz5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8SGlQaW5zIGNvbG9yPXtjb2xvcn0gb25DbGljaz17b25PcGVuRGV0YWlsc30+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHtuYk9wZXJhdGlvbnN9XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgPC9IaVBpbnM+XG4gICAgICAgICAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgICAgICAgICAgKSA6IChcbiAgICAgICAgICAgICAgICAgICAgICAgIDxIaUNvbG9yZWRMYWJlbCBsYWJlbD17dmFsdWV9IGNvbG9yPXtjb2xvcn0gLz5cbiAgICAgICAgICAgICAgICAgICAgKX1cbiAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgIDwvVG9vbHRpcD5cbiAgICAgICAgKTtcbiAgICB9XG59XG5leHBvcnQgZGVmYXVsdCB3aXRoU3R5bGVzKHN0eWxlcywgeyB3aXRoVGhlbWU6IHRydWUsIG5hbWU6ICdIbXVpQ2VsbFN0YXR1cycgfSkoQ2VsbFN0YXR1cyk7XG4iXX0=
105403
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9IaVRhYmxlL0JvZHlDZWxscy9DZWxsU3RhdHVzLmpzIl0sIm5hbWVzIjpbInN0eWxlcyIsImxhYmVsRGl2IiwiZGlzcGxheSIsImFsaWduSXRlbXMiLCJtYXhXaWR0aCIsInBpbnMiLCJwb3NpdGlvbiIsImJvdHRvbSIsIkNlbGxTdGF0dXMiLCJwcm9wcyIsImNsYXNzZXMiLCJ0aGVtZSIsIm5iT3BlcmF0aW9ucyIsInZhbHVlIiwiY29kZSIsIm9uT3BlbkRldGFpbHMiLCJjb2xvciIsInBhbGV0dGUiLCJzdGF0dXMiLCJuZXV0cmFsIiwibm9ybWFsIiwic3RpY2t5IiwiUHVyZUNvbXBvbmVudCIsInByb3BUeXBlcyIsIm9iamVjdCIsIm51bWJlciIsImlzUmVxdWlyZWQiLCJzdHJpbmciLCJmdW5jIiwiZGVmYXVsdFByb3BzIiwid2l0aFRoZW1lIiwibmFtZSJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBQUE7Ozs7QUFDQTs7OztBQUVBOzs7O0FBQ0E7Ozs7QUFDQTs7QUFDQTs7Ozs7Ozs7Ozs7O0FBRU8sSUFBTUEsMEJBQVMsU0FBVEEsTUFBUztBQUFBLFdBQVU7QUFDNUJDLGtCQUFVO0FBQ05DLHFCQUFTLGFBREg7QUFFTkMsd0JBQVksVUFGTjtBQUdOQyxzQkFBVTtBQUhKLFNBRGtCO0FBTTVCQyxjQUFNO0FBQ0ZDLHNCQUFVLFVBRFI7QUFFRkMsb0JBQVE7QUFGTjtBQU5zQixLQUFWO0FBQUEsQ0FBZjs7SUFZREMsVTs7Ozs7Ozs7Ozs7aUNBZ0NRO0FBQUEseUJBQytELEtBQUtDLEtBRHBFO0FBQUEsZ0JBQ0VDLE9BREYsVUFDRUEsT0FERjtBQUFBLGdCQUNXQyxLQURYLFVBQ1dBLEtBRFg7QUFBQSxnQkFDa0JDLFlBRGxCLFVBQ2tCQSxZQURsQjtBQUFBLGdCQUNnQ0MsS0FEaEMsVUFDZ0NBLEtBRGhDO0FBQUEsZ0JBQ3VDQyxJQUR2QyxVQUN1Q0EsSUFEdkM7QUFBQSxnQkFDNkNDLGFBRDdDLFVBQzZDQSxhQUQ3Qzs7O0FBR04sZ0JBQU1DLFFBQVEsT0FBT0wsTUFBTU0sT0FBTixDQUFjQyxNQUFkLENBQXFCSixJQUFyQixDQUFQLEtBQXNDLFdBQXRDLEdBQW9ESCxNQUFNTSxPQUFOLENBQWNDLE1BQWQsQ0FBcUJKLElBQXJCLENBQXBELEdBQWlGSCxNQUFNTSxPQUFOLENBQWNFLE9BQWQsQ0FBc0JDLE1BQXJIOztBQUVBLG1CQUNJO0FBQUE7QUFBQSxrQkFBUyxPQUFPUCxLQUFoQixFQUF1QixXQUFXLEtBQUtKLEtBQUwsQ0FBV1ksTUFBWCxHQUFvQixPQUFwQixHQUE4QixRQUFoRTtBQUNJO0FBQUE7QUFBQTtBQUNLVCxtQ0FBZSxDQUFmLEdBQ0c7QUFBQTtBQUFBLDBCQUFLLFdBQVdGLFFBQVFULFFBQXhCO0FBQ0ksa0ZBQWdCLE9BQU9ZLEtBQXZCLEVBQThCLE9BQU9HLEtBQXJDLEdBREo7QUFFSTtBQUFBO0FBQUEsOEJBQVEsT0FBT0EsS0FBZixFQUFzQixTQUFTRCxhQUEvQixFQUE4QyxXQUFXTCxRQUFRTCxJQUFqRTtBQUNLTztBQURMO0FBRkoscUJBREgsR0FRRywwREFBZ0IsT0FBT0MsS0FBdkIsRUFBOEIsT0FBT0csS0FBckM7QUFUUjtBQURKLGFBREo7QUFnQkg7Ozs7RUFyRG9CLGdCQUFNTSxhOztBQUF6QmQsVSxDQUNLZSxTLEdBQVk7QUFDZjs7O0FBR0FiLGFBQVMsb0JBQVVjLE1BSko7QUFLZjs7O0FBR0FiLFdBQU8sb0JBQVVhLE1BUkY7QUFTZjs7O0FBR0FaLGtCQUFjLG9CQUFVYSxNQUFWLENBQWlCQyxVQVpoQjtBQWFmOzs7QUFHQWIsV0FBTyxvQkFBVWMsTUFBVixDQUFpQkQsVUFoQlQ7QUFpQmY7OztBQUdBWixVQUFNLG9CQUFVVyxNQUFWLENBQWlCQyxVQXBCUjtBQXFCZjs7O0FBR0FYLG1CQUFlLG9CQUFVYTtBQXhCVixDO0FBRGpCcEIsVSxDQTRCS3FCLFksR0FBZTtBQUNsQmpCLGtCQUFjO0FBREksQztrQkEyQlgsd0JBQVdaLE1BQVgsRUFBbUIsRUFBRThCLFdBQVcsSUFBYixFQUFtQkMsTUFBTSxnQkFBekIsRUFBbkIsRUFBZ0V2QixVQUFoRSxDIiwiZmlsZSI6IkNlbGxTdGF0dXMuanMiLCJzb3VyY2VSb290IjoiL2hvbWUvbWZhemlvL2Rldi9wcm9qZWN0cy9oaXBheS1tYXRlcmlhbC11aSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuXG5pbXBvcnQgSGlDb2xvcmVkTGFiZWwgZnJvbSAnLi4vLi4vSGlDb2xvcmVkTGFiZWwnO1xuaW1wb3J0IEhpUGlucyBmcm9tICcuLi8uLi9IaVBpbnMnO1xuaW1wb3J0IHsgd2l0aFN0eWxlcyB9IGZyb20gJy4uLy4uL3N0eWxlcyc7XG5pbXBvcnQgVG9vbHRpcCBmcm9tICcuLi8uLi9Ub29sdGlwJztcblxuZXhwb3J0IGNvbnN0IHN0eWxlcyA9IHRoZW1lID0+ICh7XG4gICAgbGFiZWxEaXY6IHtcbiAgICAgICAgZGlzcGxheTogJ2lubGluZS1mbGV4JyxcbiAgICAgICAgYWxpZ25JdGVtczogJ2Jhc2VsaW5lJyxcbiAgICAgICAgbWF4V2lkdGg6ICdjYWxjKDEwMCUgLSAzNnB4KScsXG4gICAgfSxcbiAgICBwaW5zOiB7XG4gICAgICAgIHBvc2l0aW9uOiAncmVsYXRpdmUnLFxuICAgICAgICBib3R0b206IDEsXG4gICAgfVxufSk7XG5cbmNsYXNzIENlbGxTdGF0dXMgZXh0ZW5kcyBSZWFjdC5QdXJlQ29tcG9uZW50IHtcbiAgICBzdGF0aWMgcHJvcFR5cGVzID0ge1xuICAgICAgICAvKipcbiAgICAgICAgICogVXNlZnVsIHRvIGV4dGVuZCB0aGUgc3R5bGUgYXBwbGllZCB0byBjb21wb25lbnRzLlxuICAgICAgICAgKi9cbiAgICAgICAgY2xhc3NlczogUHJvcFR5cGVzLm9iamVjdCxcbiAgICAgICAgLyoqXG4gICAgICAgICAqIFtPUFRJT05BTF0gVXNlZnVsIHRvIG1vZGlmeSB0aGUgdGhlbWUgdXNlZCBieSBjb21wb25lbnRzLlxuICAgICAgICAgKi9cbiAgICAgICAgdGhlbWU6IFByb3BUeXBlcy5vYmplY3QsXG4gICAgICAgIC8qKlxuICAgICAgICAgKiBOb21icmUgZCdvcMOpcmF0aW9ucyBmaW5hbmNpw6hyZXNcbiAgICAgICAgICovXG4gICAgICAgIG5iT3BlcmF0aW9uczogUHJvcFR5cGVzLm51bWJlci5pc1JlcXVpcmVkLFxuICAgICAgICAvKipcbiAgICAgICAgICogU3RhdHV0IGNvdXJhbnQgZGUgbGEgdHJhbnNhY3Rpb25cbiAgICAgICAgICovXG4gICAgICAgIHZhbHVlOiBQcm9wVHlwZXMuc3RyaW5nLmlzUmVxdWlyZWQsXG4gICAgICAgIC8qKlxuICAgICAgICAgKiBDb2RlIGR1IHN0YXR1dCBjb3VyYW50IGRlIGxhIHRyYW5zYWN0aW9uIChkw6l0ZXJtaW5lIGxhIGNvdWxldXIgZHUgbGFiZWwpXG4gICAgICAgICAqL1xuICAgICAgICBjb2RlOiBQcm9wVHlwZXMubnVtYmVyLmlzUmVxdWlyZWQsXG4gICAgICAgIC8qKlxuICAgICAgICAgKiBGb25jdGlvbiBkZSBjYWxsYmFjayBhcHBlbMOpZSBwb3VyIG91dnJpciBsZXMgbGlnbmVzIGRlIGTDqXRhaWxzXG4gICAgICAgICAqL1xuICAgICAgICBvbk9wZW5EZXRhaWxzOiBQcm9wVHlwZXMuZnVuYyxcbiAgICB9O1xuXG4gICAgc3RhdGljIGRlZmF1bHRQcm9wcyA9IHtcbiAgICAgICAgbmJPcGVyYXRpb25zOiAwXG4gICAgfTtcblxuICAgIHJlbmRlciAoKSB7XG4gICAgICAgIGNvbnN0IHsgY2xhc3NlcywgdGhlbWUsIG5iT3BlcmF0aW9ucywgdmFsdWUsIGNvZGUsIG9uT3BlbkRldGFpbHMgfSA9IHRoaXMucHJvcHM7XG5cbiAgICAgICAgY29uc3QgY29sb3IgPSB0eXBlb2YgdGhlbWUucGFsZXR0ZS5zdGF0dXNbY29kZV0gIT09ICd1bmRlZmluZWQnID8gdGhlbWUucGFsZXR0ZS5zdGF0dXNbY29kZV0gOiB0aGVtZS5wYWxldHRlLm5ldXRyYWwubm9ybWFsO1xuXG4gICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICA8VG9vbHRpcCB0aXRsZT17dmFsdWV9IHBsYWNlbWVudD17dGhpcy5wcm9wcy5zdGlja3kgPyAncmlnaHQnIDogJ2JvdHRvbSd9PlxuICAgICAgICAgICAgICAgIDxkaXY+XG4gICAgICAgICAgICAgICAgICAgIHtuYk9wZXJhdGlvbnMgPiAwID8gKFxuICAgICAgICAgICAgICAgICAgICAgICAgPGRpdiBjbGFzc05hbWU9e2NsYXNzZXMubGFiZWxEaXZ9PlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxIaUNvbG9yZWRMYWJlbCBsYWJlbD17dmFsdWV9IGNvbG9yPXtjb2xvcn0gLz5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8SGlQaW5zIGNvbG9yPXtjb2xvcn0gb25DbGljaz17b25PcGVuRGV0YWlsc30gY2xhc3NOYW1lPXtjbGFzc2VzLnBpbnN9PlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB7bmJPcGVyYXRpb25zfVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIDwvSGlQaW5zPlxuICAgICAgICAgICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICAgICAgICAgICkgOiAoXG4gICAgICAgICAgICAgICAgICAgICAgICA8SGlDb2xvcmVkTGFiZWwgbGFiZWw9e3ZhbHVlfSBjb2xvcj17Y29sb3J9IC8+XG4gICAgICAgICAgICAgICAgICAgICl9XG4gICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICA8L1Rvb2x0aXA+XG4gICAgICAgICk7XG4gICAgfVxufVxuZXhwb3J0IGRlZmF1bHQgd2l0aFN0eWxlcyhzdHlsZXMsIHsgd2l0aFRoZW1lOiB0cnVlLCBuYW1lOiAnSG11aUNlbGxTdGF0dXMnIH0pKENlbGxTdGF0dXMpO1xuIl19
105367
105404
 
105368
105405
  /***/ }),
105369
105406
  /* 2843 */
@@ -105633,7 +105670,8 @@ var styles = exports.styles = function styles(theme) {
105633
105670
  display: 'inline-block',
105634
105671
  overflow: 'hidden',
105635
105672
  textOverflow: 'ellipsis',
105636
- whiteSpace: 'pre'
105673
+ whiteSpace: 'pre',
105674
+ width: '100%'
105637
105675
  },
105638
105676
  noEllipsisSpan: {
105639
105677
  display: 'inline-block',
@@ -105833,7 +105871,7 @@ CellText.propTypes = {
105833
105871
  ellipsis: _propTypes2.default.oneOf(['left', 'right', 'middle', 'name', 'after-first-word'])
105834
105872
  };
105835
105873
  exports.default = (0, _withStyles2.default)(styles, { name: 'HmuiCellText' })(CellText);
105836
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["src/HiTable/BodyCells/CellText.js"],"names":["cst","styles","leftEllipsisSpan","display","overflow","textOverflow","whiteSpace","direction","rightEllipsisSpan","noEllipsisSpan","CellText","props","cellText","buildEllipsis","bind","ellipsis","ELLIPSIS_AFTER_FIRST_WORD","getElementsByTagName","startSpan","endSpan","availableEndSpace","offsetWidth","style","width","ELLIPSIS_MIDDLE","classes","value","start","end","valueElement","valueString","toString","substr","indexOf","div","Math","round","length","ELLIPSIS_LEFT","ELLIPSIS_RIGHT","sticky","PureComponent","propTypes","object","oneOfType","string","number","isRequired","oneOf","name"],"mappings":"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","file":"CellText.js","sourceRoot":"/home/mfazio/dev/projects/hipay-material-ui","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\n\nimport Tooltip from '../../Tooltip';\nimport withStyles from '../../styles/withStyles';\nimport * as cst from '../constants';\n\nexport const styles = theme => ({\n    leftEllipsisSpan: {\n        display: 'inline-block',\n        overflow: 'hidden',\n        textOverflow: 'ellipsis',\n        whiteSpace: 'pre',\n        direction: 'rtl',\n    },\n    rightEllipsisSpan: {\n        display: 'inline-block',\n        overflow: 'hidden',\n        textOverflow: 'ellipsis',\n        whiteSpace: 'pre',\n    },\n    noEllipsisSpan: {\n        display: 'inline-block',\n        overflow: 'hidden',\n        whiteSpace: 'pre',\n    },\n});\n\nclass CellText extends React.PureComponent {\n\n    static propTypes = {\n        /**\n         * Useful to extend the style applied to components.\n         */\n        classes: PropTypes.object,\n        /**\n         * Valeur à afficher\n         */\n        value: PropTypes.oneOfType([PropTypes.string, PropTypes.number]).isRequired,\n        /**\n         * Ellipsis\n         */\n        ellipsis: PropTypes.oneOf(['left', 'right', 'middle', 'name', 'after-first-word']),\n    };\n\n    constructor(props) {\n        super(props);\n\n        this.buildEllipsis = this.buildEllipsis.bind(this);\n    }\n\n    /**\n     * TODO - Ellipsis (middle, after-first-word)\n     */\n    componentDidMount() {\n        this.buildEllipsis();\n    }\n\n    componentDidUpdate() {\n        this.buildEllipsis();\n    }\n\n    buildEllipsis() {\n        /**\n         * Calcul l'espace disponible dans la cellule en plus du premier mot\n         * si il reste de l'espace, définit la largeur du span pour le reste du texte\n         */\n        if (this.props.ellipsis === cst.ELLIPSIS_AFTER_FIRST_WORD) {\n            if (this.cellText !== null) {\n                const [startSpan, endSpan] = this.cellText.getElementsByTagName('span');\n                if (typeof startSpan !== 'undefined' && typeof endSpan !== 'undefined') {\n                    const availableEndSpace = this.cellText.offsetWidth - startSpan.offsetWidth - 2;\n                    if (availableEndSpace > 0) {\n                        endSpan.style.width = `${availableEndSpace}px`;\n                    } else {\n                        startSpan.style.width = '100%';\n                    }\n                }\n            }\n        }\n\n        /**\n         * Calcul l'espace pris par les 2 spans (les 2 moitiés du texte),\n         * si ils dépassent la largeur de la cellule, diminue d'autant et proportionnellement chaque span\n         * ajoute l'ellipse à gauche de la deuxième moitié du texte.\n         */\n        if (this.props.ellipsis === cst.ELLIPSIS_MIDDLE) {\n            if (this.cellText !== null) {\n                const [startSpan, endSpan] = this.cellText.getElementsByTagName('span');\n                if (typeof startSpan !== 'undefined' && typeof endSpan !== 'undefined') {\n                    const availableEndSpace = this.cellText.offsetWidth - startSpan.offsetWidth - endSpan.offsetWidth;\n                    if (availableEndSpace < 0) {\n                        startSpan.style.width = '50%';\n                        endSpan.style.width = '49%';\n                    } else {\n                        startSpan.style.width = 'initial';\n                        endSpan.style.width = 'initial';\n                    }\n                }\n            }\n        }\n    }\n\n    cellText = null;\n\n    render () {\n        const { classes, value, ellipsis } = this.props;\n\n        let start, end, valueElement = '';\n\n        let valueString = value.toString();\n\n        switch (ellipsis) {\n            case cst.ELLIPSIS_AFTER_FIRST_WORD:\n                // Split value in 2 strings around first whitespace\n                start = valueString.substr(0,valueString.indexOf(' '));\n                end = valueString.substr(valueString.indexOf(' ')+1);\n                if (start === '') {\n                    start = end;\n                    end = '';\n                }\n                valueElement = (\n                    <div ref={div => { this.cellText = div; }}>\n                        <span className={classes.rightEllipsisSpan}>{start + ' '}</span>\n                        <span className={classes.leftEllipsisSpan}>{end}</span>\n                    </div>\n                );\n                break;\n\n            case cst.ELLIPSIS_MIDDLE:\n                // Split value in 2 strings\n                start = valueString.substr(0,Math.round(valueString.length/2));\n                end = valueString.substr(Math.round(valueString.length/2));\n                valueElement = (\n                    <div ref={div => { this.cellText = div; }}>\n                        <span className={classes.noEllipsisSpan}>{start}</span>\n                        <span className={classes.leftEllipsisSpan}>{end}</span>\n                    </div>\n                );\n                break;\n\n            case cst.ELLIPSIS_LEFT:\n                valueElement = (\n                    <div className={classes.leftEllipsisSpan} style={{width: '100%'}}>{valueString}</div>\n                );\n                break;\n\n            case  cst.ELLIPSIS_RIGHT:\n            default:\n                valueElement = (\n                    <div className={classes.rightEllipsisSpan} style={{width: '100%'}}>{valueString}</div>\n                );\n                break;\n        }\n\n        return (\n            <Tooltip title={value} placement={this.props.sticky ? 'right' : 'bottom'}>\n                {valueElement}\n            </Tooltip>\n        );\n    }\n}\n\nexport default withStyles(styles, { name: 'HmuiCellText' })(CellText);"]}
105874
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["src/HiTable/BodyCells/CellText.js"],"names":["cst","styles","leftEllipsisSpan","display","overflow","textOverflow","whiteSpace","direction","rightEllipsisSpan","width","noEllipsisSpan","CellText","props","cellText","buildEllipsis","bind","ellipsis","ELLIPSIS_AFTER_FIRST_WORD","getElementsByTagName","startSpan","endSpan","availableEndSpace","offsetWidth","style","ELLIPSIS_MIDDLE","classes","value","start","end","valueElement","valueString","toString","substr","indexOf","div","Math","round","length","ELLIPSIS_LEFT","ELLIPSIS_RIGHT","sticky","PureComponent","propTypes","object","oneOfType","string","number","isRequired","oneOf","name"],"mappings":"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","file":"CellText.js","sourceRoot":"/home/mfazio/dev/projects/hipay-material-ui","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\n\nimport Tooltip from '../../Tooltip';\nimport withStyles from '../../styles/withStyles';\nimport * as cst from '../constants';\n\nexport const styles = theme => ({\n    leftEllipsisSpan: {\n        display: 'inline-block',\n        overflow: 'hidden',\n        textOverflow: 'ellipsis',\n        whiteSpace: 'pre',\n        direction: 'rtl',\n    },\n    rightEllipsisSpan: {\n        display: 'inline-block',\n        overflow: 'hidden',\n        textOverflow: 'ellipsis',\n        whiteSpace: 'pre',\n        width: '100%',\n    },\n    noEllipsisSpan: {\n        display: 'inline-block',\n        overflow: 'hidden',\n        whiteSpace: 'pre',\n    },\n});\n\nclass CellText extends React.PureComponent {\n\n    static propTypes = {\n        /**\n         * Useful to extend the style applied to components.\n         */\n        classes: PropTypes.object,\n        /**\n         * Valeur à afficher\n         */\n        value: PropTypes.oneOfType([PropTypes.string, PropTypes.number]).isRequired,\n        /**\n         * Ellipsis\n         */\n        ellipsis: PropTypes.oneOf(['left', 'right', 'middle', 'name', 'after-first-word']),\n    };\n\n    constructor(props) {\n        super(props);\n\n        this.buildEllipsis = this.buildEllipsis.bind(this);\n    }\n\n    /**\n     * TODO - Ellipsis (middle, after-first-word)\n     */\n    componentDidMount() {\n        this.buildEllipsis();\n    }\n\n    componentDidUpdate() {\n        this.buildEllipsis();\n    }\n\n    buildEllipsis() {\n        /**\n         * Calcul l'espace disponible dans la cellule en plus du premier mot\n         * si il reste de l'espace, définit la largeur du span pour le reste du texte\n         */\n        if (this.props.ellipsis === cst.ELLIPSIS_AFTER_FIRST_WORD) {\n            if (this.cellText !== null) {\n                const [startSpan, endSpan] = this.cellText.getElementsByTagName('span');\n                if (typeof startSpan !== 'undefined' && typeof endSpan !== 'undefined') {\n                    const availableEndSpace = this.cellText.offsetWidth - startSpan.offsetWidth - 2;\n                    if (availableEndSpace > 0) {\n                        endSpan.style.width = `${availableEndSpace}px`;\n                    } else {\n                        startSpan.style.width = '100%';\n                    }\n                }\n            }\n        }\n\n        /**\n         * Calcul l'espace pris par les 2 spans (les 2 moitiés du texte),\n         * si ils dépassent la largeur de la cellule, diminue d'autant et proportionnellement chaque span\n         * ajoute l'ellipse à gauche de la deuxième moitié du texte.\n         */\n        if (this.props.ellipsis === cst.ELLIPSIS_MIDDLE) {\n            if (this.cellText !== null) {\n                const [startSpan, endSpan] = this.cellText.getElementsByTagName('span');\n                if (typeof startSpan !== 'undefined' && typeof endSpan !== 'undefined') {\n                    const availableEndSpace = this.cellText.offsetWidth - startSpan.offsetWidth - endSpan.offsetWidth;\n                    if (availableEndSpace < 0) {\n                        startSpan.style.width = '50%';\n                        endSpan.style.width = '49%';\n                    } else {\n                        startSpan.style.width = 'initial';\n                        endSpan.style.width = 'initial';\n                    }\n                }\n            }\n        }\n    }\n\n    cellText = null;\n\n    render () {\n        const { classes, value, ellipsis } = this.props;\n\n        let start, end, valueElement = '';\n\n        let valueString = value.toString();\n\n        switch (ellipsis) {\n            case cst.ELLIPSIS_AFTER_FIRST_WORD:\n                // Split value in 2 strings around first whitespace\n                start = valueString.substr(0,valueString.indexOf(' '));\n                end = valueString.substr(valueString.indexOf(' ')+1);\n                if (start === '') {\n                    start = end;\n                    end = '';\n                }\n                valueElement = (\n                    <div ref={div => { this.cellText = div; }}>\n                        <span className={classes.rightEllipsisSpan}>{start + ' '}</span>\n                        <span className={classes.leftEllipsisSpan}>{end}</span>\n                    </div>\n                );\n                break;\n\n            case cst.ELLIPSIS_MIDDLE:\n                // Split value in 2 strings\n                start = valueString.substr(0,Math.round(valueString.length/2));\n                end = valueString.substr(Math.round(valueString.length/2));\n                valueElement = (\n                    <div ref={div => { this.cellText = div; }}>\n                        <span className={classes.noEllipsisSpan}>{start}</span>\n                        <span className={classes.leftEllipsisSpan}>{end}</span>\n                    </div>\n                );\n                break;\n\n            case cst.ELLIPSIS_LEFT:\n                valueElement = (\n                    <div className={classes.leftEllipsisSpan} style={{width: '100%'}}>{valueString}</div>\n                );\n                break;\n\n            case  cst.ELLIPSIS_RIGHT:\n            default:\n                valueElement = (\n                    <div className={classes.rightEllipsisSpan} style={{width: '100%'}}>{valueString}</div>\n                );\n                break;\n        }\n\n        return (\n            <Tooltip title={value} placement={this.props.sticky ? 'right' : 'bottom'}>\n                {valueElement}\n            </Tooltip>\n        );\n    }\n}\n\nexport default withStyles(styles, { name: 'HmuiCellText' })(CellText);"]}
105837
105875
 
105838
105876
  /***/ }),
105839
105877
  /* 2845 */