UNPKG

@hackplan/polaris

Version:

Shopify’s product component library

1,393 lines (1,203 loc) 752 kB
'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); function _interopDefault (ex) { return (ex && (typeof ex === 'object') && 'default' in ex) ? ex['default'] : ex; } var React = require('react'); var React__default = _interopDefault(React); var hoistStatics = _interopDefault(require('hoist-non-react-statics')); var debounce = _interopDefault(require('lodash/debounce')); var geometry = require('@shopify/javascript-utilities/geometry'); var events = require('@shopify/javascript-utilities/events'); var tokens = require('@shopify/polaris-tokens'); var tokens__default = _interopDefault(tokens); var createApp = require('@shopify/app-bridge'); var createApp__default = _interopDefault(createApp); var tslib_1 = require('tslib'); var polarisIcons = require('@shopify/polaris-icons'); var dom = require('@shopify/javascript-utilities/dom'); var other = require('@shopify/javascript-utilities/other'); var focus = require('@shopify/javascript-utilities/focus'); var reactDom = require('react-dom'); var fastdom = require('@shopify/javascript-utilities/fastdom'); var isEqual = _interopDefault(require('lodash/isEqual')); var math = require('@shopify/javascript-utilities/math'); var dates = require('@shopify/javascript-utilities/dates'); var reactTransitionGroup = require('@material-ui/react-transition-group'); var actions = require('@shopify/app-bridge/actions'); var range = _interopDefault(require('lodash/range')); var reactBeautifulDnd = require('react-beautiful-dnd'); if (typeof window !== 'undefined') { window.Polaris = window.Polaris || {}; window.Polaris.VERSION = '4.1.9'; } var polarisVersion = '4.1.9'; (function (Key) { Key[Key["Backspace"] = 8] = "Backspace"; Key[Key["Tab"] = 9] = "Tab"; Key[Key["Enter"] = 13] = "Enter"; Key[Key["Shift"] = 16] = "Shift"; Key[Key["Ctrl"] = 17] = "Ctrl"; Key[Key["Alt"] = 18] = "Alt"; Key[Key["Pause"] = 19] = "Pause"; Key[Key["CapsLock"] = 20] = "CapsLock"; Key[Key["Escape"] = 27] = "Escape"; Key[Key["Space"] = 32] = "Space"; Key[Key["PageUp"] = 33] = "PageUp"; Key[Key["PageDown"] = 34] = "PageDown"; Key[Key["End"] = 35] = "End"; Key[Key["Home"] = 36] = "Home"; Key[Key["LeftArrow"] = 37] = "LeftArrow"; Key[Key["UpArrow"] = 38] = "UpArrow"; Key[Key["RightArrow"] = 39] = "RightArrow"; Key[Key["DownArrow"] = 40] = "DownArrow"; Key[Key["Insert"] = 45] = "Insert"; Key[Key["Delete"] = 46] = "Delete"; Key[Key["Key0"] = 48] = "Key0"; Key[Key["Key1"] = 49] = "Key1"; Key[Key["Key2"] = 50] = "Key2"; Key[Key["Key3"] = 51] = "Key3"; Key[Key["Key4"] = 52] = "Key4"; Key[Key["Key5"] = 53] = "Key5"; Key[Key["Key6"] = 54] = "Key6"; Key[Key["Key7"] = 55] = "Key7"; Key[Key["Key8"] = 56] = "Key8"; Key[Key["Key9"] = 57] = "Key9"; Key[Key["KeyA"] = 65] = "KeyA"; Key[Key["KeyB"] = 66] = "KeyB"; Key[Key["KeyC"] = 67] = "KeyC"; Key[Key["KeyD"] = 68] = "KeyD"; Key[Key["KeyE"] = 69] = "KeyE"; Key[Key["KeyF"] = 70] = "KeyF"; Key[Key["KeyG"] = 71] = "KeyG"; Key[Key["KeyH"] = 72] = "KeyH"; Key[Key["KeyI"] = 73] = "KeyI"; Key[Key["KeyJ"] = 74] = "KeyJ"; Key[Key["KeyK"] = 75] = "KeyK"; Key[Key["KeyL"] = 76] = "KeyL"; Key[Key["KeyM"] = 77] = "KeyM"; Key[Key["KeyN"] = 78] = "KeyN"; Key[Key["KeyO"] = 79] = "KeyO"; Key[Key["KeyP"] = 80] = "KeyP"; Key[Key["KeyQ"] = 81] = "KeyQ"; Key[Key["KeyR"] = 82] = "KeyR"; Key[Key["KeyS"] = 83] = "KeyS"; Key[Key["KeyT"] = 84] = "KeyT"; Key[Key["KeyU"] = 85] = "KeyU"; Key[Key["KeyV"] = 86] = "KeyV"; Key[Key["KeyW"] = 87] = "KeyW"; Key[Key["KeyX"] = 88] = "KeyX"; Key[Key["KeyY"] = 89] = "KeyY"; Key[Key["KeyZ"] = 90] = "KeyZ"; Key[Key["LeftMeta"] = 91] = "LeftMeta"; Key[Key["RightMeta"] = 92] = "RightMeta"; Key[Key["Select"] = 93] = "Select"; Key[Key["Numpad0"] = 96] = "Numpad0"; Key[Key["Numpad1"] = 97] = "Numpad1"; Key[Key["Numpad2"] = 98] = "Numpad2"; Key[Key["Numpad3"] = 99] = "Numpad3"; Key[Key["Numpad4"] = 100] = "Numpad4"; Key[Key["Numpad5"] = 101] = "Numpad5"; Key[Key["Numpad6"] = 102] = "Numpad6"; Key[Key["Numpad7"] = 103] = "Numpad7"; Key[Key["Numpad8"] = 104] = "Numpad8"; Key[Key["Numpad9"] = 105] = "Numpad9"; Key[Key["Multiply"] = 106] = "Multiply"; Key[Key["Add"] = 107] = "Add"; Key[Key["Subtract"] = 109] = "Subtract"; Key[Key["Decimal"] = 110] = "Decimal"; Key[Key["Divide"] = 111] = "Divide"; Key[Key["F1"] = 112] = "F1"; Key[Key["F2"] = 113] = "F2"; Key[Key["F3"] = 114] = "F3"; Key[Key["F4"] = 115] = "F4"; Key[Key["F5"] = 116] = "F5"; Key[Key["F6"] = 117] = "F6"; Key[Key["F7"] = 118] = "F7"; Key[Key["F8"] = 119] = "F8"; Key[Key["F9"] = 120] = "F9"; Key[Key["F10"] = 121] = "F10"; Key[Key["F11"] = 122] = "F11"; Key[Key["F12"] = 123] = "F12"; Key[Key["NumLock"] = 144] = "NumLock"; Key[Key["ScrollLock"] = 145] = "ScrollLock"; Key[Key["Semicolon"] = 186] = "Semicolon"; Key[Key["Equals"] = 187] = "Equals"; Key[Key["Comma"] = 188] = "Comma"; Key[Key["Dash"] = 189] = "Dash"; Key[Key["Period"] = 190] = "Period"; Key[Key["ForwardSlash"] = 191] = "ForwardSlash"; Key[Key["GraveAccent"] = 192] = "GraveAccent"; Key[Key["OpenBracket"] = 219] = "OpenBracket"; Key[Key["BackSlash"] = 220] = "BackSlash"; Key[Key["CloseBracket"] = 221] = "CloseBracket"; Key[Key["SingleQuote"] = 222] = "SingleQuote"; })(exports.Key || (exports.Key = {})); (function (TypeOf) { TypeOf["Undefined"] = "undefined"; TypeOf["Object"] = "object"; TypeOf["Boolean"] = "boolean"; TypeOf["Number"] = "number"; TypeOf["String"] = "string"; TypeOf["Symbol"] = "symbol"; TypeOf["Function"] = "function"; })(exports.TypeOf || (exports.TypeOf = {})); function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function (obj) { return typeof obj; }; } else { _typeof = function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } function _possibleConstructorReturn(self, call) { if (call && (typeof call === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _nonIterableRest(); } function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _nonIterableSpread(); } function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = new Array(arr.length); i < arr.length; i++) arr2[i] = arr[i]; return arr2; } } function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } function _iterableToArray(iter) { if (Symbol.iterator in Object(iter) || Object.prototype.toString.call(iter) === "[object Arguments]") return Array.from(iter); } function _iterableToArrayLimit(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance"); } function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance"); } function classNames() { for (var _len = arguments.length, classes = new Array(_len), _key = 0; _key < _len; _key++) { classes[_key] = arguments[_key]; } return classes.filter(Boolean).join(' '); } function variationName(name, value) { return "".concat(name).concat(value.charAt(0).toUpperCase()).concat(value.slice(1)); } var isServer = typeof window === 'undefined' || typeof document === 'undefined'; var I18nContext = React__default.createContext(undefined); function useI18n() { var i18n = React.useContext(I18nContext); if (!i18n) { throw new Error('No i18n was provided. Your application must be wrapped in an <AppProvider> component. See https://polaris.shopify.com/components/structure/app-provider for implementation instructions.'); } return i18n; } var OBJECT_NOTATION_MATCHER = /\[(.*?)\]|(\w+)/g; function get(obj, keypath, defaultValue) { if (obj == null) return undefined; var keys = Array.isArray(keypath) ? keypath : getKeypath(keypath); var acc = obj; for (var i = 0; i < keys.length; i++) { var val = acc[keys[i]]; if (val === undefined) return defaultValue; acc = val; } return acc; } function getKeypath(str) { var path = []; var result; while (result = OBJECT_NOTATION_MATCHER.exec(str)) { var _result = result, _result2 = _slicedToArray(_result, 3), first = _result2[1], second = _result2[2]; path.push(first || second); } return path; } function merge() { var _final = {}; for (var _len = arguments.length, objs = new Array(_len), _key = 0; _key < _len; _key++) { objs[_key] = arguments[_key]; } for (var _i = 0, _objs = objs; _i < _objs.length; _i++) { var obj = _objs[_i]; mergeRecursively(_final, obj); } return _final; } function mergeRecursively(objA, objB) { for (var key in objB) { if (!objB.hasOwnProperty(key)) { continue; } else if (isMergeableValue(objB[key]) && isMergeableValue(objA[key])) { objA[key] = mergeRecursively(objA[key], objB[key]); } else { objA[key] = objB[key]; } } return objA; } function isMergeableValue(value) { return value !== null && _typeof(value) === 'object'; } var REPLACE_REGEX = /{([^}]*)}/g; var I18n = /*#__PURE__*/ function () { function I18n(translation) { var _this = this; _classCallCheck(this, I18n); this.translation = translation; this.translate = function (id, replacements) { return translate(id, _this.translation, replacements); }; this.setTranslation(translation); } _createClass(I18n, [{ key: "setTranslation", value: function setTranslation(translation) { this.translation = Array.isArray(translation) ? merge.apply(void 0, _toConsumableArray(translation)) : translation; } }, { key: "translationKeyExists", value: function translationKeyExists(path) { return Boolean(get(this.translation, path)); } }]); return I18n; }(); function translate(id, translations, replacements) { var text = get(translations, id); if (!text) { return ''; } if (replacements) { return text.replace(REPLACE_REGEX, function (match) { var replacement = match.substring(1, match.length - 1); if (!replacements.hasOwnProperty(replacement)) { throw new Error("No replacement found for key '".concat(replacement, "'. The following replacements were passed: ").concat(Object.keys(replacements).map(function (key) { return "'".concat(key, "'"); }).join(', '))); } return replacements[replacement]; }); } return text; } var LinkContext = React__default.createContext(undefined); function useLink() { return React__default.useContext(LinkContext); } var ScrollLockManagerContext = React__default.createContext(undefined); function useScrollLockManager() { var scrollLockManager = React.useContext(ScrollLockManagerContext); if (!scrollLockManager) { throw new Error('No ScrollLockManager was provided. Your application must be wrapped in an <AppProvider> component. See https://polaris.shopify.com/components/structure/app-provider for implementation instructions.'); } return scrollLockManager; } var SCROLL_LOCKING_ATTRIBUTE = 'data-lock-scrolling'; var SCROLL_LOCKING_WRAPPER_ATTRIBUTE = 'data-lock-scrolling-wrapper'; var scrollPosition = 0; var ScrollLockManager = /*#__PURE__*/ function () { function ScrollLockManager() { _classCallCheck(this, ScrollLockManager); this.scrollLocks = 0; this.locked = false; } _createClass(ScrollLockManager, [{ key: "registerScrollLock", value: function registerScrollLock() { this.scrollLocks += 1; this.handleScrollLocking(); } }, { key: "unregisterScrollLock", value: function unregisterScrollLock() { this.scrollLocks -= 1; this.handleScrollLocking(); } }, { key: "handleScrollLocking", value: function handleScrollLocking() { if (isServer) return; var scrollLocks = this.scrollLocks; var _document = document, body = _document.body; var wrapper = body.firstElementChild; if (scrollLocks === 0) { body.removeAttribute(SCROLL_LOCKING_ATTRIBUTE); if (wrapper) { wrapper.removeAttribute(SCROLL_LOCKING_WRAPPER_ATTRIBUTE); } window.scroll(0, scrollPosition); this.locked = false; } else if (scrollLocks > 0 && !this.locked) { scrollPosition = window.pageYOffset; body.setAttribute(SCROLL_LOCKING_ATTRIBUTE, ''); if (wrapper) { wrapper.setAttribute(SCROLL_LOCKING_WRAPPER_ATTRIBUTE, ''); wrapper.scrollTop = scrollPosition; } this.locked = true; } } }, { key: "resetScrollPosition", value: function resetScrollPosition() { scrollPosition = 0; } }]); return ScrollLockManager; }(); var ThemeContext = React__default.createContext(undefined); function useTheme() { var theme = React.useContext(ThemeContext); if (!theme) { throw new Error('No Theme was provided. Your application must be wrapped in an <AppProvider> component. See https://polaris.shopify.com/components/structure/app-provider for implementation instructions.'); } return theme; } var StickyManagerContext = React__default.createContext(undefined); function useStickyManager() { var stickyManager = React.useContext(StickyManagerContext); if (!stickyManager) { throw new Error('No StickyManager was provided. Your application must be wrapped in an <AppProvider> component. See https://polaris.shopify.com/components/structure/app-provider for implementation instructions.'); } return stickyManager; } var scrollable = { props: { 'data-polaris-scrollable': true }, selector: '[data-polaris-scrollable]' }; var overlay = { props: { 'data-polaris-overlay': true }, selector: '[data-polaris-overlay]' }; var layer = { props: { 'data-polaris-layer': true }, selector: '[data-polaris-layer]' }; var unstyled = { props: { 'data-polaris-unstyled': true }, selector: '[data-polaris-unstyled]' }; var dataPolarisTopBar = { props: { 'data-polaris-top-bar': true }, selector: '[data-polaris-top-bar]' }; var headerCell = { props: { 'data-polaris-header-cell': true }, selector: '[data-polaris-header-cell]' }; var DATA_ATTRIBUTE = { overlay: overlay, layer: layer }; // these match our values in duration.scss var Duration; (function (Duration) { Duration[Duration["Instant"] = 0] = "Instant"; Duration[Duration["Fast"] = 100] = "Fast"; Duration[Duration["Base"] = 200] = "Base"; Duration[Duration["Slow"] = 300] = "Slow"; Duration[Duration["Slower"] = 400] = "Slower"; Duration[Duration["Slowest"] = 500] = "Slowest"; })(Duration || (Duration = {})); var Breakpoints = { navigationBarCollapsed: '768px', stackedContent: '1043px' }; var noWindowMatches = { media: '', addListener: noop, removeListener: noop, matches: false, onchange: noop, addEventListener: noop, removeEventListener: noop, dispatchEvent: function dispatchEvent(_) { return true; } }; function noop() {} function navigationBarCollapsed() { return typeof window === 'undefined' ? noWindowMatches : window.matchMedia("(max-width: ".concat(Breakpoints.navigationBarCollapsed, ")")); } function stackedContent() { return typeof window === 'undefined' ? noWindowMatches : window.matchMedia("(max-width: ".concat(Breakpoints.stackedContent, ")")); } var StickyManager = /*#__PURE__*/ function () { function StickyManager(container) { var _this = this; _classCallCheck(this, StickyManager); this.stickyItems = []; this.stuckItems = []; this.topBarOffset = 0; this.handleResize = debounce(function () { _this.manageStickyItems(); }, 40, { leading: true, trailing: true, maxWait: 40 }); this.handleScroll = debounce(function () { _this.manageStickyItems(); }, 40, { leading: true, trailing: true, maxWait: 40 }); if (container) { this.setContainer(container); } } _createClass(StickyManager, [{ key: "registerStickyItem", value: function registerStickyItem(stickyItem) { this.stickyItems.push(stickyItem); } }, { key: "unregisterStickyItem", value: function unregisterStickyItem(nodeToRemove) { var nodeIndex = this.stickyItems.findIndex(function (_ref) { var stickyNode = _ref.stickyNode; return nodeToRemove === stickyNode; }); this.stickyItems.splice(nodeIndex, 1); } }, { key: "setContainer", value: function setContainer(el) { this.container = el; if (isDocument(el)) { this.setTopBarOffset(); } events.addEventListener(this.container, 'scroll', this.handleScroll); events.addEventListener(window, 'resize', this.handleResize); this.manageStickyItems(); } }, { key: "removeScrollListener", value: function removeScrollListener() { if (this.container) { events.removeEventListener(this.container, 'scroll', this.handleScroll); events.removeEventListener(window, 'resize', this.handleResize); } } }, { key: "manageStickyItems", value: function manageStickyItems() { var _this2 = this; if (this.stickyItems.length <= 0) { return; } var scrollTop = scrollTopFor(this.container); var containerTop = geometry.getRectForNode(this.container).top + this.topBarOffset; this.stickyItems.forEach(function (stickyItem) { var handlePositioning = stickyItem.handlePositioning; var _this2$evaluateSticky = _this2.evaluateStickyItem(stickyItem, scrollTop, containerTop), sticky = _this2$evaluateSticky.sticky, top = _this2$evaluateSticky.top, left = _this2$evaluateSticky.left, width = _this2$evaluateSticky.width; _this2.updateStuckItems(stickyItem, sticky); handlePositioning(sticky, top, left, width); }); } }, { key: "evaluateStickyItem", value: function evaluateStickyItem(stickyItem, scrollTop, containerTop) { var stickyNode = stickyItem.stickyNode, placeHolderNode = stickyItem.placeHolderNode, boundingElement = stickyItem.boundingElement, offset = stickyItem.offset, disableWhenStacked = stickyItem.disableWhenStacked; if (disableWhenStacked && stackedContent().matches) { return { sticky: false, top: 0, left: 0, width: 'auto' }; } var stickyOffset = offset ? this.getOffset(stickyNode) + parseInt(tokens__default.spacingLoose, 10) : this.getOffset(stickyNode); var scrollPosition = scrollTop + stickyOffset; var placeHolderNodeCurrentTop = placeHolderNode.getBoundingClientRect().top - containerTop + scrollTop; var top = containerTop + stickyOffset; var width = placeHolderNode.getBoundingClientRect().width; var left = placeHolderNode.getBoundingClientRect().left; var sticky; if (boundingElement == null) { sticky = scrollPosition >= placeHolderNodeCurrentTop; } else { var stickyItemHeight = stickyNode.getBoundingClientRect().height; var stickyItemBottomPosition = boundingElement.getBoundingClientRect().bottom - stickyItemHeight + scrollTop - containerTop; sticky = scrollPosition >= placeHolderNodeCurrentTop && scrollPosition < stickyItemBottomPosition; } return { sticky: sticky, top: top, left: left, width: width }; } }, { key: "updateStuckItems", value: function updateStuckItems(item, sticky) { var stickyNode = item.stickyNode; if (sticky && !this.isNodeStuck(stickyNode)) { this.addStuckItem(item); } else if (!sticky && this.isNodeStuck(stickyNode)) { this.removeStuckItem(item); } } }, { key: "addStuckItem", value: function addStuckItem(stickyItem) { this.stuckItems.push(stickyItem); } }, { key: "removeStuckItem", value: function removeStuckItem(stickyItem) { var nodeToRemove = stickyItem.stickyNode; var nodeIndex = this.stuckItems.findIndex(function (_ref2) { var stickyNode = _ref2.stickyNode; return nodeToRemove === stickyNode; }); this.stuckItems.splice(nodeIndex, 1); } }, { key: "getOffset", value: function getOffset(node) { if (this.stuckItems.length === 0) { return 0; } var offset = 0; var count = 0; var stuckNodesLength = this.stuckItems.length; var nodeRect = geometry.getRectForNode(node); while (count < stuckNodesLength) { var stuckNode = this.stuckItems[count].stickyNode; if (stuckNode !== node) { var stuckNodeRect = geometry.getRectForNode(stuckNode); if (!horizontallyOverlaps(nodeRect, stuckNodeRect)) { offset += geometry.getRectForNode(stuckNode).height; } } else { break; } count++; } return offset; } }, { key: "isNodeStuck", value: function isNodeStuck(node) { var nodeFound = this.stuckItems.findIndex(function (_ref3) { var stickyNode = _ref3.stickyNode; return node === stickyNode; }); return nodeFound >= 0; } }, { key: "setTopBarOffset", value: function setTopBarOffset() { var topbarElement = this.container.querySelector(":not(".concat(scrollable.selector, ") ").concat(dataPolarisTopBar.selector)); this.topBarOffset = topbarElement ? topbarElement.clientHeight : 0; } }]); return StickyManager; }(); function isDocument(node) { return node === document; } function scrollTopFor(container) { return isDocument(container) ? document.body.scrollTop || document.documentElement.scrollTop : container.scrollTop; } function horizontallyOverlaps(rect1, rect2) { var rect1Left = rect1.left; var rect1Right = rect1.left + rect1.width; var rect2Left = rect2.left; var rect2Right = rect2.left + rect2.width; return rect2Right < rect1Left || rect1Right < rect2Left; } var AppBridgeContext = React__default.createContext(undefined); function useAppBridge() { return React.useContext(AppBridgeContext); } function createAppBridge(_ref) { var apiKey = _ref.apiKey, shopOrigin = _ref.shopOrigin, forceRedirect = _ref.forceRedirect; var appBridge = apiKey ? createApp__default({ apiKey: apiKey, shopOrigin: shopOrigin || createApp.getShopOrigin(), forceRedirect: forceRedirect }) : undefined; if (appBridge !== undefined) { // eslint-disable-next-line no-console console.warn('Deprecation: Using `apiKey` and `shopOrigin` on `AppProvider` to initialize the Shopify App Bridge is deprecated. Support for this will be removed in v5.0. Use `Provider` from `@shopify/app-bridge-react` instead: https://help.shopify.com/en/api/embedded-apps/app-bridge/react-components/provider'); } if (appBridge && appBridge.hooks) { appBridge.hooks.set(createApp.LifecycleHook.DispatchAction, setClientInterfaceHook); } return appBridge; } var setClientInterfaceHook = function setClientInterfaceHook(next) { return function (action) { action.clientInterface = { name: '@shopify/polaris', version: polarisVersion }; return next(action); }; }; function withAppProvider() { return function addProvider(WrappedComponent) { var WithProvider = function WithProvider(props) { var polaris = { link: useLink(), theme: useTheme(), intl: useI18n(), scrollLockManager: useScrollLockManager(), stickyManager: useStickyManager(), appBridge: useAppBridge() }; return React__default.createElement(WrappedComponent, Object.assign({}, props, { polaris: polaris })); }; var FinalComponent = hoistStatics(WithProvider, WrappedComponent); return FinalComponent; }; } function Image(_a) { var sourceSet = _a.sourceSet, source = _a.source, crossOrigin = _a.crossOrigin, rest = tslib_1.__rest(_a, ["sourceSet", "source", "crossOrigin"]); var finalSourceSet = sourceSet ? sourceSet.map(function (_ref) { var subSource = _ref.source, descriptor = _ref.descriptor; return "".concat(subSource, " ").concat(descriptor); }).join(',') : null; return finalSourceSet ? // eslint-disable-next-line jsx-a11y/alt-text React__default.createElement("img", Object.assign({ src: source, srcSet: finalSourceSet, crossOrigin: crossOrigin }, rest)) : // eslint-disable-next-line jsx-a11y/alt-text React__default.createElement("img", Object.assign({ src: source }, rest, { crossOrigin: crossOrigin })); } var styles = { "Avatar": "Polaris-Avatar", "hidden": "Polaris-Avatar--hidden", "sizeSmall": "Polaris-Avatar--sizeSmall", "sizeMedium": "Polaris-Avatar--sizeMedium", "sizeLarge": "Polaris-Avatar--sizeLarge", "styleOne": "Polaris-Avatar--styleOne", "styleTwo": "Polaris-Avatar--styleTwo", "styleThree": "Polaris-Avatar--styleThree", "styleFour": "Polaris-Avatar--styleFour", "styleFive": "Polaris-Avatar--styleFive", "styleSix": "Polaris-Avatar--styleSix", "hasImage": "Polaris-Avatar--hasImage", "Image": "Polaris-Avatar__Image", "Initials": "Polaris-Avatar__Initials", "Svg": "Polaris-Avatar__Svg" }; var avatar1 = ''; var avatar2 = ''; var avatar3 = ''; var avatar4 = ''; var avatar5 = ''; var avatar6 = ''; var avatar7 = ''; var avatar8 = ''; var avatar9 = ''; var avatars = /*#__PURE__*/Object.freeze({ avatarOne: avatar1, avatarTwo: avatar2, avatarThree: avatar3, avatarFour: avatar4, avatarFive: avatar5, avatarSix: avatar6, avatarSeven: avatar7, avatarEight: avatar8, avatarNine: avatar9 }); var STYLE_CLASSES = ['one', 'two', 'three', 'four', 'five', 'six']; var AVATAR_IMAGES = Object.keys(avatars).map( // import/namespace does not allow computed values by default // eslint-disable-next-line import/namespace function (key) { return avatars[key]; }); var Avatar = /*#__PURE__*/ function (_React$PureComponent) { _inherits(Avatar, _React$PureComponent); function Avatar() { var _this; _classCallCheck(this, Avatar); _this = _possibleConstructorReturn(this, _getPrototypeOf(Avatar).apply(this, arguments)); _this.state = { hasError: false, hasLoaded: false }; _this.handleError = function () { _this.setState({ hasError: true, hasLoaded: false }); }; _this.handleLoad = function () { _this.setState({ hasLoaded: true, hasError: false }); }; return _this; } _createClass(Avatar, [{ key: "render", value: function render() { var _this$props = this.props, name = _this$props.name, source = _this$props.source, initials = _this$props.initials, customer = _this$props.customer, _this$props$size = _this$props.size, size = _this$props$size === void 0 ? 'medium' : _this$props$size, accessibilityLabel = _this$props.accessibilityLabel, intl = _this$props.polaris.intl; var _this$state = this.state, hasError = _this$state.hasError, hasLoaded = _this$state.hasLoaded; var hasImage = (source || customer) && !hasError; var nameString = name || initials; var finalSource; var label; if (accessibilityLabel) { label = accessibilityLabel; } else if (name) { label = name; } else if (initials) { var splitInitials = initials.split('').join(' '); label = intl.translate('Polaris.Avatar.labelWithInitials', { initials: splitInitials }); } else { label = intl.translate('Polaris.Avatar.label'); } if (source) { finalSource = source; } else if (customer) { finalSource = customerPlaceholder(nameString); } var className = classNames(styles.Avatar, styles[variationName('style', styleClass(nameString))], size && styles[variationName('size', size)], hasImage && !hasLoaded && styles.hidden, hasImage && styles.hasImage); var imageMarkUp = finalSource && !isServer && !hasError ? React__default.createElement(Image, { className: styles.Image, source: finalSource, alt: "", role: "presentation", onLoad: this.handleLoad, onError: this.handleError }) : null; // Use `dominant-baseline: central` instead of `dy` when Edge supports it. var verticalOffset = '0.35em'; var initialsMarkup = initials && !hasImage ? React__default.createElement("span", { className: styles.Initials }, React__default.createElement("svg", { className: styles.Svg, viewBox: "0 0 48 48" }, React__default.createElement("text", { x: "50%", y: "50%", dy: verticalOffset, fill: "currentColor", fontSize: "26", textAnchor: "middle" }, initials))) : null; return React__default.createElement("span", { "aria-label": label, role: "img", className: className }, initialsMarkup, imageMarkUp); } }], [{ key: "getDerivedStateFromProps", value: function getDerivedStateFromProps(props, state) { if (props.source !== state.prevSource) { return { prevSource: props.source, hasError: false, hasLoaded: false }; } return null; } }]); return Avatar; }(React__default.PureComponent); function styleClass(name) { return name ? STYLE_CLASSES[name.charCodeAt(0) % STYLE_CLASSES.length] : STYLE_CLASSES[0]; } function customerPlaceholder(name) { return name ? AVATAR_IMAGES[name.charCodeAt(0) % AVATAR_IMAGES.length] : AVATAR_IMAGES[0]; } var Avatar$1 = withAppProvider()(Avatar); function handleMouseUpByBlurring(_ref) { var currentTarget = _ref.currentTarget; currentTarget.blur(); } function UnstyledLink(props, _ref) { var LinkComponent = useLink(); if (LinkComponent) { return React__default.createElement(LinkComponent, Object.assign({}, unstyled.props, props)); } var external = props.external, url = props.url, rest = tslib_1.__rest(props, ["external", "url"]); var target = external ? '_blank' : undefined; var rel = external ? 'noopener noreferrer' : undefined; return React__default.createElement("a", Object.assign({ target: target }, rest, { href: url, rel: rel }, unstyled.props)); } var UnstyledLink$1 = React__default.memo(React__default.forwardRef(UnstyledLink)); var styles$1 = { "Icon": "Polaris-Icon", "hasBackdrop": "Polaris-Icon--hasBackdrop", "isColored": "Polaris-Icon--isColored", "colorWhite": "Polaris-Icon--colorWhite", "colorBlack": "Polaris-Icon--colorBlack", "colorSkyLighter": "Polaris-Icon--colorSkyLighter", "colorSkyLight": "Polaris-Icon--colorSkyLight", "colorSky": "Polaris-Icon--colorSky", "colorSkyDark": "Polaris-Icon--colorSkyDark", "colorInkLightest": "Polaris-Icon--colorInkLightest", "colorInkLighter": "Polaris-Icon--colorInkLighter", "colorInkLight": "Polaris-Icon--colorInkLight", "colorInk": "Polaris-Icon--colorInk", "colorBlueLighter": "Polaris-Icon--colorBlueLighter", "colorBlueLight": "Polaris-Icon--colorBlueLight", "colorBlue": "Polaris-Icon--colorBlue", "colorBlueDark": "Polaris-Icon--colorBlueDark", "colorBlueDarker": "Polaris-Icon--colorBlueDarker", "colorIndigoLighter": "Polaris-Icon--colorIndigoLighter", "colorIndigoLight": "Polaris-Icon--colorIndigoLight", "colorIndigo": "Polaris-Icon--colorIndigo", "colorIndigoDark": "Polaris-Icon--colorIndigoDark", "colorIndigoDarker": "Polaris-Icon--colorIndigoDarker", "colorTealLighter": "Polaris-Icon--colorTealLighter", "colorTealLight": "Polaris-Icon--colorTealLight", "colorTeal": "Polaris-Icon--colorTeal", "colorTealDark": "Polaris-Icon--colorTealDark", "colorTealDarker": "Polaris-Icon--colorTealDarker", "colorGreenLighter": "Polaris-Icon--colorGreenLighter", "colorGreen": "Polaris-Icon--colorGreen", "colorGreenDark": "Polaris-Icon--colorGreenDark", "colorYellowLighter": "Polaris-Icon--colorYellowLighter", "colorYellow": "Polaris-Icon--colorYellow", "colorYellowDark": "Polaris-Icon--colorYellowDark", "colorOrange": "Polaris-Icon--colorOrange", "colorOrangeDark": "Polaris-Icon--colorOrangeDark", "colorRedLighter": "Polaris-Icon--colorRedLighter", "colorRed": "Polaris-Icon--colorRed", "colorRedDark": "Polaris-Icon--colorRedDark", "colorPurple": "Polaris-Icon--colorPurple", "Svg": "Polaris-Icon__Svg", "Img": "Polaris-Icon__Img", "Placeholder": "Polaris-Icon__Placeholder" }; var COLORS_WITH_BACKDROPS = ['teal', 'tealDark', 'greenDark', 'redDark', 'yellowDark', 'ink', 'inkLighter']; function Icon(_ref) { var source = _ref.source, color = _ref.color, backdrop = _ref.backdrop, accessibilityLabel = _ref.accessibilityLabel; var intl = useI18n(); if (color && backdrop && COLORS_WITH_BACKDROPS.indexOf(color) < 0) { // eslint-disable-next-line no-console console.warn(intl.translate('Polaris.Icon.backdropWarning', { color: color, colorsWithBackDrops: COLORS_WITH_BACKDROPS.join(', ') })); } var className = classNames(styles$1.Icon, color && styles$1[variationName('color', color)], color && color !== 'white' && styles$1.isColored, backdrop && styles$1.hasBackdrop); var contentMarkup; if (typeof source === 'function') { var SourceComponent = source; contentMarkup = React__default.createElement(SourceComponent, { className: styles$1.Svg, focusable: "false", "aria-hidden": "true" }); } else if (source === 'placeholder') { contentMarkup = React__default.createElement("div", { className: styles$1.Placeholder }); } else { contentMarkup = React__default.createElement("img", { className: styles$1.Img, src: "data:image/svg+xml;utf8,".concat(source), alt: "", "aria-hidden": "true" }); } return React__default.createElement("span", { className: className, "aria-label": accessibilityLabel }, contentMarkup); } var styles$2 = { "Spinner": "Polaris-Spinner", "loading": "Polaris-Spinner--loading", "sizeSmall": "Polaris-Spinner--sizeSmall", "sizeLarge": "Polaris-Spinner--sizeLarge", "colorWhite": "Polaris-Spinner--colorWhite", "colorTeal": "Polaris-Spinner--colorTeal", "colorInkLightest": "Polaris-Spinner--colorInkLightest" }; var spinnerLarge = ''; var spinnerSmall = ''; var COLORS_FOR_LARGE_SPINNER = ['teal', 'inkLightest']; function Spinner(_ref) { var _ref$size = _ref.size, size = _ref$size === void 0 ? 'large' : _ref$size, _ref$color = _ref.color, color = _ref$color === void 0 ? 'teal' : _ref$color, accessibilityLabel = _ref.accessibilityLabel; var intl = useI18n(); if (size === 'large' && COLORS_FOR_LARGE_SPINNER.indexOf(color) < 0) { if (process.env.NODE_ENV === 'development') { // eslint-disable-next-line no-console console.warn(intl.translate('Polaris.Spinner.warningMessage', { color: color, size: size, colors: COLORS_FOR_LARGE_SPINNER.join(', ') })); } // eslint-disable-next-line no-param-reassign size = 'small'; } var className = classNames(styles$2.Spinner, color && styles$2[variationName('color', color)], size && styles$2[variationName('size', size)]); var spinnerSVG = size === 'large' ? spinnerLarge : spinnerSmall; return React__default.createElement(Image, { alt: "", source: spinnerSVG, className: className, draggable: false, role: "status", "aria-label": accessibilityLabel }); } var styles$3 = { "Button": "Polaris-Button", "disabled": "Polaris-Button--disabled", "Content": "Polaris-Button__Content", "textAlignLeft": "Polaris-Button--textAlignLeft", "textAlignCenter": "Polaris-Button--textAlignCenter", "textAlignRight": "Polaris-Button--textAlignRight", "Icon": "Polaris-Button__Icon", "Spinner": "Polaris-Button__Spinner", "primary": "Polaris-Button--primary", "destructive": "Polaris-Button--destructive", "outline": "Polaris-Button--outline", "loading": "Polaris-Button--loading", "plain": "Polaris-Button--plain", "iconOnly": "Polaris-Button--iconOnly", "fullWidth": "Polaris-Button--fullWidth", "sizeSlim": "Polaris-Button--sizeSlim", "sizeLarge": "Polaris-Button--sizeLarge", "monochrome": "Polaris-Button--monochrome", "Text": "Polaris-Button__Text" }; var DEFAULT_SIZE = 'medium'; function Button(_ref) { var id = _ref.id, url = _ref.url, disabled = _ref.disabled, loading = _ref.loading, children = _ref.children, accessibilityLabel = _ref.accessibilityLabel, ariaControls = _ref.ariaControls, ariaExpanded = _ref.ariaExpanded, ariaPressed = _ref.ariaPressed, onClick = _ref.onClick, onFocus = _ref.onFocus, onBlur = _ref.onBlur, onKeyDown = _ref.onKeyDown, onKeyPress = _ref.onKeyPress, onKeyUp = _ref.onKeyUp, external = _ref.external, download = _ref.download, icon = _ref.icon, primary = _ref.primary, outline = _ref.outline, destructive = _ref.destructive, disclosure = _ref.disclosure, plain = _ref.plain, monochrome = _ref.monochrome, submit = _ref.submit, _ref$size = _ref.size, size = _ref$size === void 0 ? DEFAULT_SIZE : _ref$size, textAlign = _ref.textAlign, fullWidth = _ref.fullWidth, circle = _ref.circle, width = _ref.width, height = _ref.height; var intl = useI18n(); var isDisabled = disabled || loading; var className = classNames(styles$3.Button, primary && styles$3.primary, outline && styles$3.outline, destructive && styles$3.destructive, isDisabled && styles$3.disabled, loading && styles$3.loading, plain && styles$3.plain, monochrome && styles$3.monochrome, size && size !== DEFAULT_SIZE && styles$3[variationName('size', size)], textAlign && styles$3[variationName('textAlign', textAlign)], fullWidth && styles$3.fullWidth, icon && children == null && styles$3.iconOnly); var disclosureIconMarkup = disclosure ? React__default.createElement(IconWrapper, null, React__default.createElement(Icon, { source: loading ? 'placeholder' : polarisIcons.CaretDownMinor })) : null; var iconMarkup; if (icon) { var iconInner = isIconSource(icon) ? React__default.createElement(Icon, { source: loading ? 'placeholder' : icon }) : icon; iconMarkup = React__default.createElement(IconWrapper, null, iconInner); } var childMarkup = children ? React__default.createElement("span", { className: styles$3.Text }, children) : null; var spinnerColor = primary || destructive ? 'white' : 'inkLightest'; var spinnerSVGMarkup = loading ? React__default.createElement("span", { className: styles$3.Spinner }, React__default.createElement(Spinner, { size: "small", color: spinnerColor, accessibilityLabel: intl.translate('Polaris.Button.spinnerAccessibilityLabel') })) : null; var content = iconMarkup || disclosureIconMarkup ? React__default.createElement("span", { className: styles$3.Content }, spinnerSVGMarkup, iconMarkup, childMarkup, disclosureIconMarkup) : React__default.createElement("span", { className: styles$3.Content }, spinnerSVGMarkup, childMarkup); var type = submit ? 'submit' : 'button'; if (url) { return isDisabled ? // Render an `<a>` so toggling disabled/enabled state changes only the // `href` attribute instead of replacing the whole element. // eslint-disable-next-line jsx-a11y/anchor-is-valid React__default.createElement("a", { id: id, c