UNPKG

@shopify/app-bridge

Version:

**Shopify is doubling our engineering staff in 2021! [Join our team and work on libraries like this one.](https://smrtr.io/5GGrc)**

152 lines (151 loc) 5.8 kB
"use strict"; var __extends = (this && this.__extends) || (function () { var extendStatics = function (d, b) { extendStatics = Object.setPrototypeOf || ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; return extendStatics(d, b); }; return function (d, b) { extendStatics(d, b); function __() { this.constructor = d; } d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); var __assign = (this && this.__assign) || function () { __assign = Object.assign || function(t) { for (var s, i = 1, n = arguments.length; i < n; i++) { s = arguments[i]; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; } return t; }; return __assign.apply(this, arguments); }; Object.defineProperty(exports, "__esModule", { value: true }); exports.create = exports.ButtonGroup = exports.isGroupedButtonPayload = exports.isGroupedButton = exports.update = exports.Action = void 0; var buttonHelper_1 = require("../buttonHelper"); var helper_1 = require("../helper"); var types_1 = require("../types"); var Action; (function (Action) { Action["UPDATE"] = "UPDATE"; })(Action = exports.Action || (exports.Action = {})); function update(group, component, props) { return buttonActionWrapper(group, component, Action.UPDATE, props); } exports.update = update; function isGroupedButton(options) { var castOptions = options; return castOptions.buttons && castOptions.buttons.length > 0 && castOptions.label !== undefined; } exports.isGroupedButton = isGroupedButton; function isGroupedButtonPayload(payload) { var castOptions = payload; return (Array.isArray(castOptions.buttons) && typeof castOptions.id === 'string' && typeof castOptions.label === 'string'); } exports.isGroupedButtonPayload = isGroupedButtonPayload; var ButtonGroup = /** @class */ (function (_super) { __extends(ButtonGroup, _super); function ButtonGroup(app, options) { var _this = _super.call(this, app, types_1.ComponentType.ButtonGroup, types_1.Group.ButtonGroup) || this; _this.disabled = false; _this.plain = false; _this.buttonsOptions = []; _this.buttons = []; _this.set(options, false); return _this; } Object.defineProperty(ButtonGroup.prototype, "options", { get: function () { return { buttons: this.buttonsOptions, disabled: this.disabled, label: this.label, plain: this.plain, }; }, enumerable: false, configurable: true }); Object.defineProperty(ButtonGroup.prototype, "payload", { get: function () { return __assign(__assign({}, this.options), { buttons: this.buttons, id: this.id }); }, enumerable: false, configurable: true }); ButtonGroup.prototype.set = function (options, shouldUpdate) { if (shouldUpdate === void 0) { shouldUpdate = true; } var mergedOptions = helper_1.getMergedProps(this.options, options); var label = mergedOptions.label, disabled = mergedOptions.disabled, buttons = mergedOptions.buttons, plain = mergedOptions.plain; this.label = label; this.disabled = Boolean(disabled); this.buttons = this.getButtons(buttons); this.plain = Boolean(plain); if (shouldUpdate) { this.dispatch(Action.UPDATE); } return this; }; ButtonGroup.prototype.dispatch = function (action) { switch (action) { case Action.UPDATE: { var updateAction = update(this.group, this.component, this.payload); this.app.dispatch(updateAction); break; } } return this; }; ButtonGroup.prototype.updateButtons = function (newPayload) { if (!this.buttons || this.buttons.length === 0) { return; } var updated; for (var _i = 0, _a = this.buttons; _i < _a.length; _i++) { var action = _a[_i]; updated = helper_1.updateActionFromPayload(action, newPayload); if (updated) { break; } } if (updated) { this.dispatch(Action.UPDATE); } }; ButtonGroup.prototype.getSingleButton = function (button) { return buttonHelper_1.getSingleButton(this, button, this.subgroups, this.updateButtons); }; ButtonGroup.prototype.getButtons = function (buttonOptions) { var _this = this; var buttons = []; if (!buttonOptions) { return []; } buttonOptions.forEach(function (button) { var singleButton = buttonHelper_1.getSingleButton(_this, button, _this.subgroups, _this.updateButtons); buttons.push(singleButton); }); this.buttonsOptions = buttonOptions; return buttons; }; return ButtonGroup; }(helper_1.ActionSetWithChildren)); exports.ButtonGroup = ButtonGroup; function create(app, options) { return new ButtonGroup(app, options); } exports.create = create; function buttonActionWrapper(group, component, eventName, props, payload) { var id = component.id; var label = props.label; var action = helper_1.getEventNameSpace(group, eventName, component); var buttonPayload = __assign(__assign({}, props), { id: id, label: label, payload: payload }); return helper_1.actionWrapper({ type: action, group: group, payload: buttonPayload }); }