UNPKG

@eeacms/react-chart-editor

Version:

plotly.js chart editor react component UI

2 lines 3.81 kB
"use strict";Object.defineProperty(exports,"__esModule",{value:true});exports.default=void 0;var _react=_interopRequireWildcard(require("react"));var _propTypes=_interopRequireDefault(require("prop-types"));var _CheckboxGroup=_interopRequireDefault(require("./CheckboxGroup"));function _interopRequireDefault(e){return e&&e.__esModule?e:{default:e}}function _interopRequireWildcard(e,t){if("function"==typeof WeakMap)var r=new WeakMap,n=new WeakMap;return(_interopRequireWildcard=function _interopRequireWildcard(e,t){if(!t&&e&&e.__esModule)return e;var o,i,f={__proto__:null,default:e};if(null===e||"object"!=typeof e&&"function"!=typeof e)return f;if(o=t?n:r){if(o.has(e))return o.get(e);o.set(e,f)}for(const t in e)"default"!==t&&{}.hasOwnProperty.call(e,t)&&((i=(o=Object.defineProperty)&&Object.getOwnPropertyDescriptor(e,t))&&(i.get||i.set)?o(f,t,i):f[t]=e[t]);return f})(e,t)}(function(){var enterModule=typeof reactHotLoaderGlobal!=="undefined"?reactHotLoaderGlobal.enterModule:undefined;enterModule&&enterModule(module)})();var __signature__=typeof reactHotLoaderGlobal!=="undefined"?reactHotLoaderGlobal.default.signature:function(a){return a};class FlaglistCheckboxGroup extends _react.Component{constructor(props){super(props);let currentActiveOption;if(props.activeOption!==null){currentActiveOption=props.activeOption}else{currentActiveOption=""}this.state={activeOption:this.parseFlags(currentActiveOption)};this.handleChange=this.handleChange.bind(this)}parseFlags(option){let activeOption;if(option==="all"){activeOption=this.props.options.map(o=>o.value).join("+")}else if(option==="none"){activeOption=""}else{activeOption=option}return activeOption}UNSAFE_componentWillReceiveProps(nextProps){this.setState({activeOption:this.parseFlags(nextProps.activeOption)})}handleChange(newOptions){let newActiveOptions="";newOptions.map(option=>{if(option.checked===true){newActiveOptions+=option.value+"+"}});newActiveOptions=newActiveOptions.slice(0,-1);if(newActiveOptions.length===0){newActiveOptions="none"}this.setState({activeOption:newActiveOptions});this.props.onChange(newActiveOptions)}renderCheckedOption(){const activeOptions=typeof this.state.activeOption==="string"?this.state.activeOption.split("+"):[this.state.activeOption];const allOptions=this.props.options;const newOptions=[];allOptions.map(option=>{let currentChecked;if(activeOptions.indexOf(option.value)>-1){currentChecked=true}else{currentChecked=false}newOptions.push({label:option.label,value:option.value,checked:currentChecked})});return newOptions}render(){return _react.default.createElement(_CheckboxGroup.default,{options:this.renderCheckedOption(),onChange:this.handleChange,className:this.props.className,orientation:this.props.orientation})}__reactstandin__regenerateByEval(key,code){this[key]=eval(code)}}FlaglistCheckboxGroup.propTypes={options:_propTypes.default.arrayOf(_propTypes.default.shape({value:_propTypes.default.any.isRequired,label:_propTypes.default.string.isRequired})).isRequired,activeOption:_propTypes.default.any,onChange:_propTypes.default.func,className:_propTypes.default.string,orientation:_propTypes.default.string};const _default=FlaglistCheckboxGroup;var _default2=exports.default=_default;;(function(){var reactHotLoader=typeof reactHotLoaderGlobal!=="undefined"?reactHotLoaderGlobal.default:undefined;if(!reactHotLoader){return}reactHotLoader.register(FlaglistCheckboxGroup,"FlaglistCheckboxGroup","/react-chart-editor/src/components/widgets/FlaglistCheckboxGroup.js");reactHotLoader.register(_default,"default","/react-chart-editor/src/components/widgets/FlaglistCheckboxGroup.js")})();;(function(){var leaveModule=typeof reactHotLoaderGlobal!=="undefined"?reactHotLoaderGlobal.leaveModule:undefined;leaveModule&&leaveModule(module)})(); //# sourceMappingURL=FlaglistCheckboxGroup.js.map