{"version":3,"sources":["webpack:///node_modules/@ionic/core/dist/esm/ion-item-option_3.entry.js"],"names":["itemOptionIosCss","itemOptionMdCss","ItemOption","hostRef","disabled","expandable","type","onClick","ev","el","target","closest","preventDefault","href","TagType","undefined","mode","attrs","download","color","Object","assign","part","name","style","ios","md","itemOptionsIosCss","itemOptionsMdCss","ItemOptions","ionSwipe","side","emit","isEnd","itemSlidingCss","SWIPE_MARGIN","ELASTIC_FACTOR","openSlidingItem","ItemSliding","ionDrag","item","openAmount","initialOpenAmount","optsWidthRightSide","optsWidthLeftSide","sides","optsDirty","state","gesture","enable","querySelector","updateOptions","createGesture","gestureName","gesturePriority","threshold","canStart","onStart","onMove","onEnd","disabledChanged","destroy","leftOptions","rightOptions","Promise","resolve","getSlidingRatioSync","optionsToOpen","getOptions","isStartOpen","isEndOpen","closeOpened","requestAnimationFrame","calculateOptsWidth","width","setOpenAmount","close","options","querySelectorAll","i","length","componentOnReady","option","rtl","document","dir","atEdge","window","innerWidth","startX","selected","tmr","clearTimeout","transition","deltaX","Math","max","min","console","warn","optsWidth","velocity","velocityX","restingPoint","isResetDirection","isMovingFast","abs","isOnCloseZone","swipeShouldReset","fireSwipeEvent","display","offsetWidth","isFinal","setTimeout","transform","amount","ratio","isOnResetZone"],"mappings":"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","file":"16-es5.js","sourcesContent":["import { r as registerInstance, h, H as Host, i as getElement, e as createEvent } from './index-92848855.js';\nimport { b as getIonMode } from './ionic-global-23e7365a.js';\nimport { i as isEndSide } from './helpers-5c745fbd.js';\nimport { c as createColorClasses } from './theme-5641d27f.js';\n\nconst itemOptionIosCss = \":host{--background:var(--ion-color-primary, #3880ff);--color:var(--ion-color-primary-contrast, #fff);background:var(--background);color:var(--color);font-family:var(--ion-font-family, inherit)}:host(.in-list.item-options-end:last-child){padding-right:calc(.7em + var(--ion-safe-area-right))}@supports ((-webkit-margin-start: 0) or (margin-inline-start: 0)) or (-webkit-margin-start: 0){:host(.in-list.item-options-end:last-child){padding-right:unset;-webkit-padding-end:calc(.7em + var(--ion-safe-area-right));padding-inline-end:calc(.7em + var(--ion-safe-area-right))}}:host(.in-list.item-options-start:first-child){padding-left:calc(.7em + var(--ion-safe-area-left))}@supports ((-webkit-margin-start: 0) or (margin-inline-start: 0)) or (-webkit-margin-start: 0){:host(.in-list.item-options-start:first-child){padding-left:unset;-webkit-padding-start:calc(.7em + var(--ion-safe-area-left));padding-inline-start:calc(.7em + var(--ion-safe-area-left))}}:host(.ion-color){background:var(--ion-color-base);color:var(--ion-color-contrast)}.button-native{font-family:inherit;font-size:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-decoration:inherit;text-indent:inherit;text-overflow:inherit;text-transform:inherit;text-align:inherit;white-space:inherit;color:inherit;padding-left:0.7em;padding-right:0.7em;padding-top:0;padding-bottom:0;display:inline-block;position:relative;width:100%;height:100%;border:0;outline:none;background:transparent;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;-webkit-box-sizing:border-box;box-sizing:border-box}@supports ((-webkit-margin-start: 0) or (margin-inline-start: 0)) or (-webkit-margin-start: 0){.button-native{padding-left:unset;padding-right:unset;-webkit-padding-start:0.7em;padding-inline-start:0.7em;-webkit-padding-end:0.7em;padding-inline-end:0.7em}}.button-inner{display:-ms-flexbox;display:flex;-ms-flex-flow:column nowrap;flex-flow:column nowrap;-ms-flex-negative:0;flex-shrink:0;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;width:100%;height:100%}.horizontal-wrapper{display:-ms-flexbox;display:flex;-ms-flex-flow:row nowrap;flex-flow:row nowrap;-ms-flex-negative:0;flex-shrink:0;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;width:100%}::slotted(*){-ms-flex-negative:0;flex-shrink:0}::slotted([slot=start]){margin-left:0;margin-right:5px;margin-top:0;margin-bottom:0}@supports ((-webkit-margin-start: 0) or (margin-inline-start: 0)) or (-webkit-margin-start: 0){::slotted([slot=start]){margin-left:unset;margin-right:unset;-webkit-margin-start:0;margin-inline-start:0;-webkit-margin-end:5px;margin-inline-end:5px}}::slotted([slot=end]){margin-left:5px;margin-right:0;margin-top:0;margin-bottom:0}@supports ((-webkit-margin-start: 0) or (margin-inline-start: 0)) or (-webkit-margin-start: 0){::slotted([slot=end]){margin-left:unset;margin-right:unset;-webkit-margin-start:5px;margin-inline-start:5px;-webkit-margin-end:0;margin-inline-end:0}}::slotted([slot=icon-only]){padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;margin-left:10px;margin-right:10px;margin-top:0;margin-bottom:0;min-width:0.9em;font-size:1.8em}@supports ((-webkit-margin-start: 0) or (margin-inline-start: 0)) or (-webkit-margin-start: 0){::slotted([slot=icon-only]){margin-left:unset;margin-right:unset;-webkit-margin-start:10px;margin-inline-start:10px;-webkit-margin-end:10px;margin-inline-end:10px}}:host(.item-option-expandable){-ms-flex-negative:0;flex-shrink:0;-webkit-transition-duration:0;transition-duration:0;-webkit-transition-property:none;transition-property:none;-webkit-transition-timing-function:cubic-bezier(0.65, 0.05, 0.36, 1);transition-timing-function:cubic-bezier(0.65, 0.05, 0.36, 1)}:host(.item-option-disabled){pointer-events:none}:host(.item-option-disabled) .button-native{cursor:default;opacity:0.5;pointer-events:none}:host{font-size:16px}:host(.ion-activated){background:var(--ion-color-primary-shade, #3171e0)}:host(.ion-color.ion-activated){background:var(--ion-color-shade)}\";\n\nconst itemOptionMdCss = \":host{--background:var(--ion-color-primary, #3880ff);--color:var(--ion-color-primary-contrast, #fff);background:var(--background);color:var(--color);font-family:var(--ion-font-family, inherit)}:host(.in-list.item-options-end:last-child){padding-right:calc(.7em + var(--ion-safe-area-right))}@supports ((-webkit-margin-start: 0) or (margin-inline-start: 0)) or (-webkit-margin-start: 0){:host(.in-list.item-options-end:last-child){padding-right:unset;-webkit-padding-end:calc(.7em + var(--ion-safe-area-right));padding-inline-end:calc(.7em + var(--ion-safe-area-right))}}:host(.in-list.item-options-start:first-child){padding-left:calc(.7em + var(--ion-safe-area-left))}@supports ((-webkit-margin-start: 0) or (margin-inline-start: 0)) or (-webkit-margin-start: 0){:host(.in-list.item-options-start:first-child){padding-left:unset;-webkit-padding-start:calc(.7em + var(--ion-safe-area-left));padding-inline-start:calc(.7em + var(--ion-safe-area-left))}}:host(.ion-color){background:var(--ion-color-base);color:var(--ion-color-contrast)}.button-native{font-family:inherit;font-size:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-decoration:inherit;text-indent:inherit;text-overflow:inherit;text-transform:inherit;text-align:inherit;white-space:inherit;color:inherit;padding-left:0.7em;padding-right:0.7em;padding-top:0;padding-bottom:0;display:inline-block;position:relative;width:100%;height:100%;border:0;outline:none;background:transparent;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;-webkit-box-sizing:border-box;box-sizing:border-box}@supports ((-webkit-margin-start: 0) or (margin-inline-start: 0)) or (-webkit-margin-start: 0){.button-native{padding-left:unset;padding-right:unset;-webkit-padding-start:0.7em;padding-inline-start:0.7em;-webkit-padding-end:0.7em;padding-inline-end:0.7em}}.button-inner{display:-ms-flexbox;display:flex;-ms-flex-flow:column nowrap;flex-flow:column nowrap;-ms-flex-negative:0;flex-shrink:0;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;width:100%;height:100%}.horizontal-wrapper{display:-ms-flexbox;display:flex;-ms-flex-flow:row nowrap;flex-flow:row nowrap;-ms-flex-negative:0;flex-shrink:0;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;width:100%}::slotted(*){-ms-flex-negative:0;flex-shrink:0}::slotted([slot=start]){margin-left:0;margin-right:5px;margin-top:0;margin-bottom:0}@supports ((-webkit-margin-start: 0) or (margin-inline-start: 0)) or (-webkit-margin-start: 0){::slotted([slot=start]){margin-left:unset;margin-right:unset;-webkit-margin-start:0;margin-inline-start:0;-webkit-margin-end:5px;margin-inline-end:5px}}::slotted([slot=end]){margin-left:5px;margin-right:0;margin-top:0;margin-bottom:0}@supports ((-webkit-margin-start: 0) or (margin-inline-start: 0)) or (-webkit-margin-start: 0){::slotted([slot=end]){margin-left:unset;margin-right:unset;-webkit-margin-start:5px;margin-inline-start:5px;-webkit-margin-end:0;margin-inline-end:0}}::slotted([slot=icon-only]){padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;margin-left:10px;margin-right:10px;margin-top:0;margin-bottom:0;min-width:0.9em;font-size:1.8em}@supports ((-webkit-margin-start: 0) or (margin-inline-start: 0)) or (-webkit-margin-start: 0){::slotted([slot=icon-only]){margin-left:unset;margin-right:unset;-webkit-margin-start:10px;margin-inline-start:10px;-webkit-margin-end:10px;margin-inline-end:10px}}:host(.item-option-expandable){-ms-flex-negative:0;flex-shrink:0;-webkit-transition-duration:0;transition-duration:0;-webkit-transition-property:none;transition-property:none;-webkit-transition-timing-function:cubic-bezier(0.65, 0.05, 0.36, 1);transition-timing-function:cubic-bezier(0.65, 0.05, 0.36, 1)}:host(.item-option-disabled){pointer-events:none}:host(.item-option-disabled) .button-native{cursor:default;opacity:0.5;pointer-events:none}:host{font-size:14px;font-weight:500;text-transform:uppercase}\";\n\nconst ItemOption = class {\n constructor(hostRef) {\n registerInstance(this, hostRef);\n /**\n * If `true`, the user cannot interact with the item option.\n */\n this.disabled = false;\n /**\n * If `true`, the option will expand to take up the available width and cover any other options.\n */\n this.expandable = false;\n /**\n * The type of the button.\n */\n this.type = 'button';\n this.onClick = (ev) => {\n const el = ev.target.closest('ion-item-option');\n if (el) {\n ev.preventDefault();\n }\n };\n }\n render() {\n const { disabled, expandable, href } = this;\n const TagType = href === undefined ? 'button' : 'a';\n const mode = getIonMode(this);\n const attrs = (TagType === 'button')\n ? { type: this.type }\n : {\n download: this.download,\n href: this.href,\n target: this.target\n };\n return (h(Host, { onClick: this.onClick, class: createColorClasses(this.color, {\n [mode]: true,\n 'item-option-disabled': disabled,\n 'item-option-expandable': expandable,\n 'ion-activatable': true,\n }) }, h(TagType, Object.assign({}, attrs, { class: \"button-native\", part: \"native\", disabled: disabled }), h(\"span\", { class: \"button-inner\" }, h(\"slot\", { name: \"top\" }), h(\"div\", { class: \"horizontal-wrapper\" }, h(\"slot\", { name: \"start\" }), h(\"slot\", { name: \"icon-only\" }), h(\"slot\", null), h(\"slot\", { name: \"end\" })), h(\"slot\", { name: \"bottom\" })), mode === 'md' && h(\"ion-ripple-effect\", null))));\n }\n get el() { return getElement(this); }\n};\nItemOption.style = {\n ios: itemOptionIosCss,\n md: itemOptionMdCss\n};\n\nconst itemOptionsIosCss = \"ion-item-options{top:0;right:0;-ms-flex-pack:end;justify-content:flex-end;display:none;position:absolute;height:100%;font-size:14px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;z-index:1}[dir=rtl] ion-item-options,:host-context([dir=rtl]) ion-item-options{-ms-flex-pack:start;justify-content:flex-start}[dir=rtl] ion-item-options:not(.item-options-end),:host-context([dir=rtl]) ion-item-options:not(.item-options-end){right:auto;left:0;-ms-flex-pack:end;justify-content:flex-end}.item-options-start{right:auto;left:0;-ms-flex-pack:start;justify-content:flex-start}[dir=rtl] .item-options-start,:host-context([dir=rtl]) .item-options-start{-ms-flex-pack:end;justify-content:flex-end}.item-options-start ion-item-option:first-child{padding-right:var(--ion-safe-area-left)}@supports ((-webkit-margin-start: 0) or (margin-inline-start: 0)) or (-webkit-margin-start: 0){.item-options-start ion-item-option:first-child{padding-right:unset;-webkit-padding-end:var(--ion-safe-area-left);padding-inline-end:var(--ion-safe-area-left)}}.item-options-end ion-item-option:last-child{padding-right:var(--ion-safe-area-right)}@supports ((-webkit-margin-start: 0) or (margin-inline-start: 0)) or (-webkit-margin-start: 0){.item-options-end ion-item-option:last-child{padding-right:unset;-webkit-padding-end:var(--ion-safe-area-right);padding-inline-end:var(--ion-safe-area-right)}}[dir=rtl] .item-sliding-active-slide.item-sliding-active-options-start ion-item-options:not(.item-options-end),:host-context([dir=rtl]) .item-sliding-active-slide.item-sliding-active-options-start ion-item-options:not(.item-options-end){width:100%;visibility:visible}.item-sliding-active-slide ion-item-options{display:-ms-flexbox;display:flex;visibility:hidden}.item-sliding-active-slide.item-sliding-active-options-start .item-options-start,.item-sliding-active-slide.item-sliding-active-options-end ion-item-options:not(.item-options-start){width:100%;visibility:visible}.item-options-ios{border-bottom-width:0;border-bottom-style:solid;border-bottom-color:var(--ion-item-border-color, var(--ion-border-color, var(--ion-color-step-250, #c8c7cc)))}.item-options-ios.item-options-end{border-bottom-width:0.55px}.list-ios-lines-none .item-options-ios{border-bottom-width:0}.list-ios-lines-full .item-options-ios,.list-ios-lines-inset .item-options-ios.item-options-end{border-bottom-width:0.55px}\";\n\nconst itemOptionsMdCss = \"ion-item-options{top:0;right:0;-ms-flex-pack:end;justify-content:flex-end;display:none;position:absolute;height:100%;font-size:14px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;z-index:1}[dir=rtl] ion-item-options,:host-context([dir=rtl]) ion-item-options{-ms-flex-pack:start;justify-content:flex-start}[dir=rtl] ion-item-options:not(.item-options-end),:host-context([dir=rtl]) ion-item-options:not(.item-options-end){right:auto;left:0;-ms-flex-pack:end;justify-content:flex-end}.item-options-start{right:auto;left:0;-ms-flex-pack:start;justify-content:flex-start}[dir=rtl] .item-options-start,:host-context([dir=rtl]) .item-options-start{-ms-flex-pack:end;justify-content:flex-end}.item-options-start ion-item-option:first-child{padding-right:var(--ion-safe-area-left)}@supports ((-webkit-margin-start: 0) or (margin-inline-start: 0)) or (-webkit-margin-start: 0){.item-options-start ion-item-option:first-child{padding-right:unset;-webkit-padding-end:var(--ion-safe-area-left);padding-inline-end:var(--ion-safe-area-left)}}.item-options-end ion-item-option:last-child{padding-right:var(--ion-safe-area-right)}@supports ((-webkit-margin-start: 0) or (margin-inline-start: 0)) or (-webkit-margin-start: 0){.item-options-end ion-item-option:last-child{padding-right:unset;-webkit-padding-end:var(--ion-safe-area-right);padding-inline-end:var(--ion-safe-area-right)}}[dir=rtl] .item-sliding-active-slide.item-sliding-active-options-start ion-item-options:not(.item-options-end),:host-context([dir=rtl]) .item-sliding-active-slide.item-sliding-active-options-start ion-item-options:not(.item-options-end){width:100%;visibility:visible}.item-sliding-active-slide ion-item-options{display:-ms-flexbox;display:flex;visibility:hidden}.item-sliding-active-slide.item-sliding-active-options-start .item-options-start,.item-sliding-active-slide.item-sliding-active-options-end ion-item-options:not(.item-options-start){width:100%;visibility:visible}.item-options-md{border-bottom-width:0;border-bottom-style:solid;border-bottom-color:var(--ion-item-border-color, var(--ion-border-color, var(--ion-color-step-150, rgba(0, 0, 0, 0.13))))}.list-md-lines-none .item-options-md{border-bottom-width:0}.list-md-lines-full .item-options-md,.list-md-lines-inset .item-options-md.item-options-end{border-bottom-width:1px}\";\n\nconst ItemOptions = class {\n constructor(hostRef) {\n registerInstance(this, hostRef);\n this.ionSwipe = createEvent(this, \"ionSwipe\", 7);\n /**\n * The side the option button should be on. Possible values: `\"start\"` and `\"end\"`. If you have multiple `ion-item-options`, a side must be provided for each.\n *\n */\n this.side = 'end';\n }\n /** @internal */\n async fireSwipeEvent() {\n this.ionSwipe.emit({\n side: this.side\n });\n }\n render() {\n const mode = getIonMode(this);\n const isEnd = isEndSide(this.side);\n return (h(Host, { class: {\n [mode]: true,\n // Used internally for styling\n [`item-options-${mode}`]: true,\n 'item-options-start': !isEnd,\n 'item-options-end': isEnd\n } }));\n }\n get el() { return getElement(this); }\n};\nItemOptions.style = {\n ios: itemOptionsIosCss,\n md: itemOptionsMdCss\n};\n\nconst itemSlidingCss = \"ion-item-sliding{display:block;position:relative;width:100%;overflow:hidden;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}ion-item-sliding .item{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.item-sliding-active-slide .item{position:relative;-webkit-transition:-webkit-transform 500ms cubic-bezier(0.36, 0.66, 0.04, 1);transition:-webkit-transform 500ms cubic-bezier(0.36, 0.66, 0.04, 1);transition:transform 500ms cubic-bezier(0.36, 0.66, 0.04, 1);transition:transform 500ms cubic-bezier(0.36, 0.66, 0.04, 1), -webkit-transform 500ms cubic-bezier(0.36, 0.66, 0.04, 1);opacity:1;z-index:2;pointer-events:none;will-change:transform}.item-sliding-active-swipe-end .item-options-end .item-option-expandable{padding-left:100%;-ms-flex-order:1;order:1;-webkit-transition-duration:0.6s;transition-duration:0.6s;-webkit-transition-property:padding-left;transition-property:padding-left}[dir=rtl] .item-sliding-active-swipe-end .item-options-end .item-option-expandable,:host-context([dir=rtl]) .item-sliding-active-swipe-end .item-options-end .item-option-expandable{-ms-flex-order:-1;order:-1}.item-sliding-active-swipe-start .item-options-start .item-option-expandable{padding-right:100%;-ms-flex-order:-1;order:-1;-webkit-transition-duration:0.6s;transition-duration:0.6s;-webkit-transition-property:padding-right;transition-property:padding-right}[dir=rtl] .item-sliding-active-swipe-start .item-options-start .item-option-expandable,:host-context([dir=rtl]) .item-sliding-active-swipe-start .item-options-start .item-option-expandable{-ms-flex-order:1;order:1}\";\n\nconst SWIPE_MARGIN = 30;\nconst ELASTIC_FACTOR = 0.55;\nlet openSlidingItem;\nconst ItemSliding = class {\n constructor(hostRef) {\n registerInstance(this, hostRef);\n this.ionDrag = createEvent(this, \"ionDrag\", 7);\n this.item = null;\n this.openAmount = 0;\n this.initialOpenAmount = 0;\n this.optsWidthRightSide = 0;\n this.optsWidthLeftSide = 0;\n this.sides = 0 /* None */;\n this.optsDirty = true;\n this.state = 2 /* Disabled */;\n /**\n * If `true`, the user cannot interact with the sliding item.\n */\n this.disabled = false;\n }\n disabledChanged() {\n if (this.gesture) {\n this.gesture.enable(!this.disabled);\n }\n }\n async connectedCallback() {\n this.item = this.el.querySelector('ion-item');\n await this.updateOptions();\n this.gesture = (await import('./index-eea61379.js')).createGesture({\n el: this.el,\n gestureName: 'item-swipe',\n gesturePriority: 100,\n threshold: 5,\n canStart: ev => this.canStart(ev),\n onStart: () => this.onStart(),\n onMove: ev => this.onMove(ev),\n onEnd: ev => this.onEnd(ev),\n });\n this.disabledChanged();\n }\n disconnectedCallback() {\n if (this.gesture) {\n this.gesture.destroy();\n this.gesture = undefined;\n }\n this.item = null;\n this.leftOptions = this.rightOptions = undefined;\n if (openSlidingItem === this.el) {\n openSlidingItem = undefined;\n }\n }\n /**\n * Get the amount the item is open in pixels.\n */\n getOpenAmount() {\n return Promise.resolve(this.openAmount);\n }\n /**\n * Get the ratio of the open amount of the item compared to the width of the options.\n * If the number returned is positive, then the options on the right side are open.\n * If the number returned is negative, then the options on the left side are open.\n * If the absolute value of the number is greater than 1, the item is open more than\n * the width of the options.\n */\n getSlidingRatio() {\n return Promise.resolve(this.getSlidingRatioSync());\n }\n /**\n * Open the sliding item.\n *\n * @param side The side of the options to open. If a side is not provided, it will open the first set of options it finds within the item.\n */\n async open(side) {\n if (this.item === null) {\n return;\n }\n const optionsToOpen = this.getOptions(side);\n if (!optionsToOpen) {\n return;\n }\n /**\n * If side is not set, we need to infer the side\n * so we know which direction to move the options\n */\n if (side === undefined) {\n side = (optionsToOpen === this.leftOptions) ? 'start' : 'end';\n }\n // In RTL we want to switch the sides\n side = isEndSide(side) ? 'end' : 'start';\n const isStartOpen = this.openAmount < 0;\n const isEndOpen = this.openAmount > 0;\n /**\n * If a side is open and a user tries to\n * re-open the same side, we should not do anything\n */\n if (isStartOpen && optionsToOpen === this.leftOptions) {\n return;\n }\n if (isEndOpen && optionsToOpen === this.rightOptions) {\n return;\n }\n this.closeOpened();\n this.state = 4 /* Enabled */;\n requestAnimationFrame(() => {\n this.calculateOptsWidth();\n const width = (side === 'end') ? this.optsWidthRightSide : -this.optsWidthLeftSide;\n openSlidingItem = this.el;\n this.setOpenAmount(width, false);\n this.state = (side === 'end') ? 8 /* End */ : 16 /* Start */;\n });\n }\n /**\n * Close the sliding item. Items can also be closed from the [List](../list).\n */\n async close() {\n this.setOpenAmount(0, true);\n }\n /**\n * Close all of the sliding items in the list. Items can also be closed from the [List](../list).\n */\n async closeOpened() {\n if (openSlidingItem !== undefined) {\n openSlidingItem.close();\n openSlidingItem = undefined;\n return true;\n }\n return false;\n }\n /**\n * Given an optional side, return the ion-item-options element.\n *\n * @param side This side of the options to get. If a side is not provided it will\n * return the first one available.\n */\n getOptions(side) {\n if (side === undefined) {\n return this.leftOptions || this.rightOptions;\n }\n else if (side === 'start') {\n return this.leftOptions;\n }\n else {\n return this.rightOptions;\n }\n }\n async updateOptions() {\n const options = this.el.querySelectorAll('ion-item-options');\n let sides = 0;\n // Reset left and right options in case they were removed\n this.leftOptions = this.rightOptions = undefined;\n for (let i = 0; i < options.length; i++) {\n const option = await options.item(i).componentOnReady();\n const side = isEndSide(option.side) ? 'end' : 'start';\n if (side === 'start') {\n this.leftOptions = option;\n sides |= 1 /* Start */;\n }\n else {\n this.rightOptions = option;\n sides |= 2 /* End */;\n }\n }\n this.optsDirty = true;\n this.sides = sides;\n }\n canStart(gesture) {\n /**\n * If very close to start of the screen\n * do not open left side so swipe to go\n * back will still work.\n */\n const rtl = document.dir === 'rtl';\n const atEdge = (rtl) ? (window.innerWidth - gesture.startX) < 15 : gesture.startX < 15;\n if (atEdge) {\n return false;\n }\n const selected = openSlidingItem;\n if (selected && selected !== this.el) {\n this.closeOpened();\n return false;\n }\n return !!(this.rightOptions || this.leftOptions);\n }\n onStart() {\n openSlidingItem = this.el;\n if (this.tmr !== undefined) {\n clearTimeout(this.tmr);\n this.tmr = undefined;\n }\n if (this.openAmount === 0) {\n this.optsDirty = true;\n this.state = 4 /* Enabled */;\n }\n this.initialOpenAmount = this.openAmount;\n if (this.item) {\n this.item.style.transition = 'none';\n }\n }\n onMove(gesture) {\n if (this.optsDirty) {\n this.calculateOptsWidth();\n }\n let openAmount = this.initialOpenAmount - gesture.deltaX;\n switch (this.sides) {\n case 2 /* End */:\n openAmount = Math.max(0, openAmount);\n break;\n case 1 /* Start */:\n openAmount = Math.min(0, openAmount);\n break;\n case 3 /* Both */: break;\n case 0 /* None */: return;\n default:\n console.warn('invalid ItemSideFlags value', this.sides);\n break;\n }\n let optsWidth;\n if (openAmount > this.optsWidthRightSide) {\n optsWidth = this.optsWidthRightSide;\n openAmount = optsWidth + (openAmount - optsWidth) * ELASTIC_FACTOR;\n }\n else if (openAmount < -this.optsWidthLeftSide) {\n optsWidth = -this.optsWidthLeftSide;\n openAmount = optsWidth + (openAmount - optsWidth) * ELASTIC_FACTOR;\n }\n this.setOpenAmount(openAmount, false);\n }\n onEnd(gesture) {\n const velocity = gesture.velocityX;\n let restingPoint = (this.openAmount > 0)\n ? this.optsWidthRightSide\n : -this.optsWidthLeftSide;\n // Check if the drag didn't clear the buttons mid-point\n // and we aren't moving fast enough to swipe open\n const isResetDirection = (this.openAmount > 0) === !(velocity < 0);\n const isMovingFast = Math.abs(velocity) > 0.3;\n const isOnCloseZone = Math.abs(this.openAmount) < Math.abs(restingPoint / 2);\n if (swipeShouldReset(isResetDirection, isMovingFast, isOnCloseZone)) {\n restingPoint = 0;\n }\n const state = this.state;\n this.setOpenAmount(restingPoint, true);\n if ((state & 32 /* SwipeEnd */) !== 0 && this.rightOptions) {\n this.rightOptions.fireSwipeEvent();\n }\n else if ((state & 64 /* SwipeStart */) !== 0 && this.leftOptions) {\n this.leftOptions.fireSwipeEvent();\n }\n }\n calculateOptsWidth() {\n this.optsWidthRightSide = 0;\n if (this.rightOptions) {\n this.rightOptions.style.display = 'flex';\n this.optsWidthRightSide = this.rightOptions.offsetWidth;\n this.rightOptions.style.display = '';\n }\n this.optsWidthLeftSide = 0;\n if (this.leftOptions) {\n this.leftOptions.style.display = 'flex';\n this.optsWidthLeftSide = this.leftOptions.offsetWidth;\n this.leftOptions.style.display = '';\n }\n this.optsDirty = false;\n }\n setOpenAmount(openAmount, isFinal) {\n if (this.tmr !== undefined) {\n clearTimeout(this.tmr);\n this.tmr = undefined;\n }\n if (!this.item) {\n return;\n }\n const style = this.item.style;\n this.openAmount = openAmount;\n if (isFinal) {\n style.transition = '';\n }\n if (openAmount > 0) {\n this.state = (openAmount >= (this.optsWidthRightSide + SWIPE_MARGIN))\n ? 8 /* End */ | 32 /* SwipeEnd */\n : 8 /* End */;\n }\n else if (openAmount < 0) {\n this.state = (openAmount <= (-this.optsWidthLeftSide - SWIPE_MARGIN))\n ? 16 /* Start */ | 64 /* SwipeStart */\n : 16 /* Start */;\n }\n else {\n this.tmr = setTimeout(() => {\n this.state = 2 /* Disabled */;\n this.tmr = undefined;\n }, 600);\n openSlidingItem = undefined;\n style.transform = '';\n return;\n }\n style.transform = `translate3d(${-openAmount}px,0,0)`;\n this.ionDrag.emit({\n amount: openAmount,\n ratio: this.getSlidingRatioSync()\n });\n }\n getSlidingRatioSync() {\n if (this.openAmount > 0) {\n return this.openAmount / this.optsWidthRightSide;\n }\n else if (this.openAmount < 0) {\n return this.openAmount / this.optsWidthLeftSide;\n }\n else {\n return 0;\n }\n }\n render() {\n const mode = getIonMode(this);\n return (h(Host, { class: {\n [mode]: true,\n 'item-sliding-active-slide': (this.state !== 2 /* Disabled */),\n 'item-sliding-active-options-end': (this.state & 8 /* End */) !== 0,\n 'item-sliding-active-options-start': (this.state & 16 /* Start */) !== 0,\n 'item-sliding-active-swipe-end': (this.state & 32 /* SwipeEnd */) !== 0,\n 'item-sliding-active-swipe-start': (this.state & 64 /* SwipeStart */) !== 0\n } }));\n }\n get el() { return getElement(this); }\n static get watchers() { return {\n \"disabled\": [\"disabledChanged\"]\n }; }\n};\nconst swipeShouldReset = (isResetDirection, isMovingFast, isOnResetZone) => {\n // The logic required to know when the sliding item should close (openAmount=0)\n // depends on three booleans (isResetDirection, isMovingFast, isOnResetZone)\n // and it ended up being too complicated to be written manually without errors\n // so the truth table is attached below: (0=false, 1=true)\n // isResetDirection | isMovingFast | isOnResetZone || shouldClose\n // 0 | 0 | 0 || 0\n // 0 | 0 | 1 || 1\n // 0 | 1 | 0 || 0\n // 0 | 1 | 1 || 0\n // 1 | 0 | 0 || 0\n // 1 | 0 | 1 || 1\n // 1 | 1 | 0 || 1\n // 1 | 1 | 1 || 1\n // The resulting expression was generated by resolving the K-map (Karnaugh map):\n return (!isMovingFast && isOnResetZone) || (isResetDirection && isMovingFast);\n};\nItemSliding.style = itemSlidingCss;\n\nexport { ItemOption as ion_item_option, ItemOptions as ion_item_options, ItemSliding as ion_item_sliding };\n"]}