UNPKG

@procraft/widget-order

Version:

Order widget for landing

164 lines 8.69 kB
"use strict"; var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { if (k2 === undefined) k2 = k; Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); }) : (function(o, m, k, k2) { if (k2 === undefined) k2 = k; o[k2] = m[k]; })); var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { Object.defineProperty(o, "default", { enumerable: true, value: v }); }) : function(o, v) { o["default"] = v; }); var __importStar = (this && this.__importStar) || function (mod) { if (mod && mod.__esModule) return mod; var result = {}; if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); __setModuleDefault(result, mod); return result; }; var __rest = (this && this.__rest) || function (s, e) { var t = {}; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p]; if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) { if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]]; } return t; }; var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.ProlongationWidget = void 0; const react_1 = __importStar(require("react")); const Typography_1 = __importDefault(require("../Typography")); const styles_1 = require("../../CourseItem/styles"); const styles_2 = require("./styles"); const styles_3 = require("../Container/styles"); const Button_1 = __importDefault(require("../Button")); const react_number_format_1 = __importDefault(require("react-number-format")); const RadioGroup_1 = require("../RadioGroup"); /** * Виджет заказа продления курса */ const ProlongationWidget = (_a) => { var _b, _c; var { course, catalogItems } = _a, other = __rest(_a, ["course", "catalogItems"]); const tariffs = (0, react_1.useMemo)(() => { return (course.tariffs || []).filter((n) => catalogItems.findIndex((c) => { var _a; return ((_a = c.course) === null || _a === void 0 ? void 0 : _a.tariffId) === n.uid; }) !== -1); }, [catalogItems, course.tariffs]); /** * Выбранный курс (по умолчанию первый в списке) */ const [tariffId, tariffIdSetter] = (0, react_1.useState)((_b = tariffs[0]) === null || _b === void 0 ? void 0 : _b.uid); // const onClickCourse = useCallback( // (event: React.MouseEvent<HTMLDivElement>) => { // const value = event.currentTarget.dataset.value // value && tariffIdSetter(parseInt(value)) // }, // [] // ) const onClickCourse = (0, react_1.useCallback)((value) => { value && tariffIdSetter(parseInt(value)); }, []); /** * Непосредственно заказываемые элементы */ const prolongationCatalogItems = (0, react_1.useMemo)(() => { return catalogItems.filter((n) => { var _a; return ((_a = n.course) === null || _a === void 0 ? void 0 : _a.tariffId) === tariffId; }); }, [catalogItems, tariffId]); /** * Выбранный CatalogItem (по умолчанию первый в списке в первом курсе) */ const [itemId, itemIdSetter] = (0, react_1.useState)((_c = prolongationCatalogItems[0]) === null || _c === void 0 ? void 0 : _c.uid); (0, react_1.useEffect)(() => { var _a; itemIdSetter((_a = prolongationCatalogItems[0]) === null || _a === void 0 ? void 0 : _a.uid); }, [prolongationCatalogItems]); // const onClickCatalogItem = useCallback( // (event: React.MouseEvent<HTMLDivElement>) => { // const value = event.currentTarget.dataset.value // value && itemIdSetter(parseInt(value)) // }, // [] // ) const onClickCatalogItem = (0, react_1.useCallback)((value) => { value && itemIdSetter(parseInt(value)); }, []); const itemsContent = (0, react_1.useMemo)(() => { const items = []; prolongationCatalogItems.forEach((n) => { var _a, _b; items.push({ uid: n.uid, label: (react_1.default.createElement(Typography_1.default, { variant: "grey-sm", component: "label", className: "altItemText" }, ((_a = n.course) === null || _a === void 0 ? void 0 : _a.prolongationDays) ? `Продление на ${(_b = n.course) === null || _b === void 0 ? void 0 : _b.prolongationDays} дней` : n.name, ' ', "-", ' ', react_1.default.createElement(react_number_format_1.default, { value: n.unitPrice, displayType: "text", thousandSeparator: ' ' }), ' ', "\u20BD")), }); }); return (react_1.default.createElement(RadioGroup_1.RadioGroup, { items: items, value: itemId, onChangeIndex: onClickCatalogItem })); }, [itemId, prolongationCatalogItems, onClickCatalogItem]); const contentCatalogItems = (0, react_1.useMemo)(() => { return (react_1.default.createElement(react_1.default.Fragment, null, react_1.default.createElement(styles_3.ContainerStyled, { variant: "white" }, react_1.default.createElement(Typography_1.default, { className: "subtitle" }, "\u0421\u0440\u043E\u043A\u0438 \u043F\u0440\u043E\u0434\u043B\u0435\u043D\u0438\u044F"), itemsContent))); }, [itemsContent]); const tariffsContent = (0, react_1.useMemo)(() => { const items = []; tariffs.forEach((tariff) => { // const checked = tariffId === tariff.uid // return ( // <ProlongationWidgetRadioInputRowStyled // key={id} // className="option" // data-value={tariff.uid} // onClick={onClickCourse} // checked={checked} // > // <input type="radio" checked={checked} onChange={onChange} />{' '} // <Typography // variant="grey-sm" // component="label" // className="altItemText" // > // {name} // </Typography> // </ProlongationWidgetRadioInputRowStyled> // ) items.push({ uid: tariff.uid, label: (react_1.default.createElement(Typography_1.default, { variant: "grey-sm", component: "label", className: "altItemText" }, tariff.name)), }); }); const courses = (react_1.default.createElement(RadioGroup_1.RadioGroup, { items: items, value: tariffId, onChangeIndex: onClickCourse })); return (react_1.default.createElement(styles_3.ContainerStyled, { variant: "white" }, react_1.default.createElement(Typography_1.default, { className: "subtitle" }, "\u0414\u043E\u0441\u0442\u0443\u043F\u043D\u044B\u0435 \u043F\u0430\u043A\u0435\u0442\u044B"), courses)); }, [onClickCourse, tariffId, tariffs]); return (react_1.default.createElement(styles_2.ProlongationWidgetStyled, Object.assign({}, other), react_1.default.createElement(styles_1.WidgetStyled, null, react_1.default.createElement(styles_1.NavigationStyled, null, react_1.default.createElement(Typography_1.default, null, "\u041F\u043E\u0441\u0442\u043E\u044F\u043D\u043D\u044B\u0439 \u043D\u0430\u0431\u043E\u0440")), react_1.default.createElement(styles_1.BoxStyled, null, react_1.default.createElement(Typography_1.default, { className: "title" }, "\u041F\u0440\u043E\u0434\u043B\u0435\u043D\u0438\u0435"), tariffsContent, contentCatalogItems, react_1.default.createElement("div", { className: "flex-1" }), react_1.default.createElement(styles_3.ContainerStyled, { variant: "white" }, react_1.default.createElement("a", { href: `/order/${itemId}` }, react_1.default.createElement(Button_1.default, null, "\u041F\u0440\u043E\u0434\u043B\u0438\u0442\u044C"))))))); }; exports.ProlongationWidget = ProlongationWidget; //# sourceMappingURL=index.js.map