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)**

123 lines (122 loc) 4.52 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.ChannelMenu = exports.update = exports.Action = void 0; var AppLink_1 = require("../../Link/AppLink"); var helper_1 = require("../../helper"); var types_1 = require("../../types"); var SUBGROUPS = ['Channel_Menu']; var Action; (function (Action) { Action["UPDATE"] = "APP::MENU::CHANNEL_MENU::UPDATE"; Action["LINK_UPDATE"] = "APP::MENU::CHANNEL_MENU::LINK::UPDATE"; })(Action = exports.Action || (exports.Action = {})); function update(payload) { return helper_1.actionWrapper({ payload: payload, group: types_1.Group.Menu, type: Action.UPDATE, }); } exports.update = update; var ChannelMenu = /** @class */ (function (_super) { __extends(ChannelMenu, _super); function ChannelMenu(app, options) { var _this = _super.call(this, app, 'Channel_Menu', types_1.Group.Menu) || this; _this.items = []; // Trigger 'update' on creation _this.set(options); return _this; } Object.defineProperty(ChannelMenu.prototype, "options", { get: function () { return { items: this.itemsOptions, active: this.activeOptions, }; }, enumerable: false, configurable: true }); Object.defineProperty(ChannelMenu.prototype, "payload", { get: function () { return __assign(__assign({}, this.options), { active: this.active, items: this.items, id: this.id }); }, enumerable: false, configurable: true }); ChannelMenu.prototype.set = function (options, shouldUpdate) { if (shouldUpdate === void 0) { shouldUpdate = true; } var mergedOptions = helper_1.getMergedProps(this.options, options); var items = mergedOptions.items, active = mergedOptions.active; this.setItems(items); this.activeOptions = active; this.active = active && active.id; if (shouldUpdate) { this.dispatch(Action.UPDATE); } return this; }; ChannelMenu.prototype.dispatch = function (action) { switch (action) { case Action.UPDATE: this.app.dispatch(update(this.payload)); break; } return this; }; ChannelMenu.prototype.updateItem = function (newPayload) { if (!this.items) { return; } var itemToUpdate = this.items.find(function (action) { return action.id === newPayload.id; }); if (!itemToUpdate) { return; } if (helper_1.updateActionFromPayload(itemToUpdate, newPayload)) { this.dispatch(Action.UPDATE); } }; ChannelMenu.prototype.setItems = function (newOptions) { var _this = this; var newItems = newOptions || []; var currentItems = this.itemsOptions || []; this.itemsOptions = this.getUpdatedChildActions(newItems, currentItems); this.items = this.itemsOptions ? this.itemsOptions.map(function (action) { _this.addChild(action, _this.group, SUBGROUPS); _this.subscribeToChild(action, AppLink_1.Action.UPDATE, _this.updateItem); return action.payload; }) : []; }; return ChannelMenu; }(helper_1.ActionSetWithChildren)); exports.ChannelMenu = ChannelMenu; function create(app, options) { return new ChannelMenu(app, options); } exports.create = create;