Repository URL to install this package:
|
Version:
2.8.4 ▾
|
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
const tslib_1 = require("tslib");
const react_1 = tslib_1.__importDefault(require("react"));
const exotic_1 = require("exotic");
const mobx_react_1 = require("xmobx/mobx-react");
const RadioOption_1 = tslib_1.__importDefault(require("./RadioOption"));
const SelectOption_1 = tslib_1.__importDefault(require("./SelectOption"));
const SquareOption_1 = tslib_1.__importDefault(require("./SquareOption"));
const styled_1 = tslib_1.__importStar(require("./styled"));
const Wrap = props => {
return react_1.default.createElement(react_1.default.Fragment, null, props.children);
}; // @todo reuse
const EMPTY_OPTION_ITEM = Object.freeze({
name: '',
image: '',
isSelected: true,
isDisabled: false
});
const isProductDetailsPage = () => true;
/**
* @type {Organism}
*/
// @styledComponent()
let ProductOptions = class ProductOptions extends react_1.default.Component {
/**
* @type {Organism}
*/
// @styledComponent()
constructor() {
super(...arguments);
this.handleClick = (event, item = exotic_1.EMPTY_OBJ, state) => {
console.debug('[ProductOptions] onClick option / onChange select'); // @todo @fixme @cleanup split this out into the selectdropdown or rethink the type
// this is because `value` is an `image url` for color...
const value = item.type === 'color' ? item.label : item.value;
const {
type,
onChange
} = this.props;
onChange(type, value);
};
}
get View() {
const {
type,
isDropdown
} = this.props;
if (isDropdown) {
return SelectOption_1.default;
} else if (isProductDetailsPage()) {
switch (type) {
case 'color':
return RadioOption_1.default;
case 'style':
return SquareOption_1.default;
case 'size1':
return SquareOption_1.default;
default:
return SquareOption_1.default;
}
} else {
switch (type) {
case 'style':
return SelectOption_1.default;
case 'color':
return RadioOption_1.default;
case 'size1':
return SelectOption_1.default;
default:
return SelectOption_1.default;
}
}
}
get attributes() {
const {
handleClick
} = this; // selected not used...
const {
list,
type,
selectedValue
} = this.props;
return {
list,
type,
selectedValue,
// should be on change eh
onClick: handleClick
};
}
render() {
const {
props,
View,
attributes
} = this;
const {
type
} = props;
const label = type === 'size1' ? 'size' : type === 'style' ? 'fit' : type;
const qa = `qa-select-` + label;
return react_1.default.createElement(Wrap, null, isProductDetailsPage() && react_1.default.createElement(styled_1.StyledLabelHeader, null, label), react_1.default.createElement(styled_1.OptionListWrap, {
"data-qa": qa,
type: type
}, react_1.default.createElement(View, Object.assign({}, attributes))));
}
};
ProductOptions.defaultProps = {
list: [EMPTY_OPTION_ITEM],
isDropdown: false,
type: '',
onChange(...params) {
console.log(params);
return {};
}
};
ProductOptions = tslib_1.__decorate([styled_1.default(), mobx_react_1.observer], ProductOptions);
exports.default = ProductOptions; //# sourceMappingURL=ProductOptions.js.map