{"version":3,"sources":["webpack:///node_modules/@ionic/core/dist/esm/ion-infinite-scroll_2.entry.js"],"names":["infiniteScrollCss","InfiniteScroll","hostRef","ionInfinite","thrPx","thrPc","didFire","isBusy","isLoading","threshold","disabled","position","onScroll","scrollEl","canStart","infiniteHeight","el","offsetHeight","scrollTop","scrollHeight","height","distanceFromInfinite","emit","val","lastIndexOf","parseFloat","enableScrollEvents","contentEl","closest","console","error","getScrollElement","thresholdChanged","disabledChanged","clientHeight","undefined","prev","requestAnimationFrame","newScrollTop","shouldListen","addEventListener","removeEventListener","mode","style","infiniteScrollContentIosCss","infiniteScrollContentMdCss","InfiniteScrollContent","loadingSpinner","get","name","loadingText","innerHTML","ios","md"],"mappings":"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","file":"14-es5.js","sourcesContent":["import { r as registerInstance, e as createEvent, c as writeTask, f as readTask, h, i as getElement, H as Host } from './index-92848855.js';\nimport { b as getIonMode, c as config } from './ionic-global-23e7365a.js';\nimport { s as sanitizeDOMString } from './index-79d74e0b.js';\n\nconst infiniteScrollCss = \"ion-infinite-scroll{display:none;width:100%}.infinite-scroll-enabled{display:block}\";\n\nconst InfiniteScroll = class {\n constructor(hostRef) {\n registerInstance(this, hostRef);\n this.ionInfinite = createEvent(this, \"ionInfinite\", 7);\n this.thrPx = 0;\n this.thrPc = 0;\n this.didFire = false;\n this.isBusy = false;\n this.isLoading = false;\n /**\n * The threshold distance from the bottom\n * of the content to call the `infinite` output event when scrolled.\n * The threshold value can be either a percent, or\n * in pixels. For example, use the value of `10%` for the `infinite`\n * output event to get called when the user has scrolled 10%\n * from the bottom of the page. Use the value `100px` when the\n * scroll is within 100 pixels from the bottom of the page.\n */\n this.threshold = '15%';\n /**\n * If `true`, the infinite scroll will be hidden and scroll event listeners\n * will be removed.\n *\n * Set this to true to disable the infinite scroll from actively\n * trying to receive new data while scrolling. This is useful\n * when it is known that there is no more data that can be added, and\n * the infinite scroll is no longer needed.\n */\n this.disabled = false;\n /**\n * The position of the infinite scroll element.\n * The value can be either `top` or `bottom`.\n */\n this.position = 'bottom';\n this.onScroll = () => {\n const scrollEl = this.scrollEl;\n if (!scrollEl || !this.canStart()) {\n return 1;\n }\n const infiniteHeight = this.el.offsetHeight;\n if (infiniteHeight === 0) {\n // if there is no height of this element then do nothing\n return 2;\n }\n const scrollTop = scrollEl.scrollTop;\n const scrollHeight = scrollEl.scrollHeight;\n const height = scrollEl.offsetHeight;\n const threshold = this.thrPc !== 0 ? (height * this.thrPc) : this.thrPx;\n const distanceFromInfinite = (this.position === 'bottom')\n ? scrollHeight - infiniteHeight - scrollTop - threshold - height\n : scrollTop - infiniteHeight - threshold;\n if (distanceFromInfinite < 0) {\n if (!this.didFire) {\n this.isLoading = true;\n this.didFire = true;\n this.ionInfinite.emit();\n return 3;\n }\n }\n else {\n this.didFire = false;\n }\n return 4;\n };\n }\n thresholdChanged() {\n const val = this.threshold;\n if (val.lastIndexOf('%') > -1) {\n this.thrPx = 0;\n this.thrPc = (parseFloat(val) / 100);\n }\n else {\n this.thrPx = parseFloat(val);\n this.thrPc = 0;\n }\n }\n disabledChanged() {\n const disabled = this.disabled;\n if (disabled) {\n this.isLoading = false;\n this.isBusy = false;\n }\n this.enableScrollEvents(!disabled);\n }\n async connectedCallback() {\n const contentEl = this.el.closest('ion-content');\n if (!contentEl) {\n console.error(' must be used inside an ');\n return;\n }\n this.scrollEl = await contentEl.getScrollElement();\n this.thresholdChanged();\n this.disabledChanged();\n if (this.position === 'top') {\n writeTask(() => {\n if (this.scrollEl) {\n this.scrollEl.scrollTop = this.scrollEl.scrollHeight - this.scrollEl.clientHeight;\n }\n });\n }\n }\n disconnectedCallback() {\n this.enableScrollEvents(false);\n this.scrollEl = undefined;\n }\n /**\n * Call `complete()` within the `ionInfinite` output event handler when\n * your async operation has completed. For example, the `loading`\n * state is while the app is performing an asynchronous operation,\n * such as receiving more data from an AJAX request to add more items\n * to a data list. Once the data has been received and UI updated, you\n * then call this method to signify that the loading has completed.\n * This method will change the infinite scroll's state from `loading`\n * to `enabled`.\n */\n async complete() {\n const scrollEl = this.scrollEl;\n if (!this.isLoading || !scrollEl) {\n return;\n }\n this.isLoading = false;\n if (this.position === 'top') {\n /**\n * New content is being added at the top, but the scrollTop position stays the same,\n * which causes a scroll jump visually. This algorithm makes sure to prevent this.\n * (Frame 1)\n * - complete() is called, but the UI hasn't had time to update yet.\n * - Save the current content dimensions.\n * - Wait for the next frame using _dom.read, so the UI will be updated.\n * (Frame 2)\n * - Read the new content dimensions.\n * - Calculate the height difference and the new scroll position.\n * - Delay the scroll position change until other possible dom reads are done using _dom.write to be performant.\n * (Still frame 2, if I'm correct)\n * - Change the scroll position (= visually maintain the scroll position).\n * - Change the state to re-enable the InfiniteScroll.\n * - This should be after changing the scroll position, or it could\n * cause the InfiniteScroll to be triggered again immediately.\n * (Frame 3)\n * Done.\n */\n this.isBusy = true;\n // ******** DOM READ ****************\n // Save the current content dimensions before the UI updates\n const prev = scrollEl.scrollHeight - scrollEl.scrollTop;\n // ******** DOM READ ****************\n requestAnimationFrame(() => {\n readTask(() => {\n // UI has updated, save the new content dimensions\n const scrollHeight = scrollEl.scrollHeight;\n // New content was added on top, so the scroll position should be changed immediately to prevent it from jumping around\n const newScrollTop = scrollHeight - prev;\n // ******** DOM WRITE ****************\n requestAnimationFrame(() => {\n writeTask(() => {\n scrollEl.scrollTop = newScrollTop;\n this.isBusy = false;\n });\n });\n });\n });\n }\n }\n canStart() {\n return (!this.disabled &&\n !this.isBusy &&\n !!this.scrollEl &&\n !this.isLoading);\n }\n enableScrollEvents(shouldListen) {\n if (this.scrollEl) {\n if (shouldListen) {\n this.scrollEl.addEventListener('scroll', this.onScroll);\n }\n else {\n this.scrollEl.removeEventListener('scroll', this.onScroll);\n }\n }\n }\n render() {\n const mode = getIonMode(this);\n const disabled = this.disabled;\n return (h(Host, { class: {\n [mode]: true,\n 'infinite-scroll-loading': this.isLoading,\n 'infinite-scroll-enabled': !disabled\n } }));\n }\n get el() { return getElement(this); }\n static get watchers() { return {\n \"threshold\": [\"thresholdChanged\"],\n \"disabled\": [\"disabledChanged\"]\n }; }\n};\nInfiniteScroll.style = infiniteScrollCss;\n\nconst infiniteScrollContentIosCss = \"ion-infinite-scroll-content{display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;-ms-flex-pack:center;justify-content:center;min-height:84px;text-align:center;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.infinite-loading{margin-left:0;margin-right:0;margin-top:0;margin-bottom:32px;display:none;width:100%}.infinite-loading-text{margin-left:32px;margin-right:32px;margin-top:4px;margin-bottom:0}@supports ((-webkit-margin-start: 0) or (margin-inline-start: 0)) or (-webkit-margin-start: 0){.infinite-loading-text{margin-left:unset;margin-right:unset;-webkit-margin-start:32px;margin-inline-start:32px;-webkit-margin-end:32px;margin-inline-end:32px}}.infinite-scroll-loading ion-infinite-scroll-content>.infinite-loading{display:block}.infinite-scroll-content-ios .infinite-loading-text{color:var(--ion-color-step-600, #666666)}.infinite-scroll-content-ios .infinite-loading-spinner .spinner-lines-ios line,.infinite-scroll-content-ios .infinite-loading-spinner .spinner-lines-small-ios line,.infinite-scroll-content-ios .infinite-loading-spinner .spinner-crescent circle{stroke:var(--ion-color-step-600, #666666)}.infinite-scroll-content-ios .infinite-loading-spinner .spinner-bubbles circle,.infinite-scroll-content-ios .infinite-loading-spinner .spinner-circles circle,.infinite-scroll-content-ios .infinite-loading-spinner .spinner-dots circle{fill:var(--ion-color-step-600, #666666)}\";\n\nconst infiniteScrollContentMdCss = \"ion-infinite-scroll-content{display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;-ms-flex-pack:center;justify-content:center;min-height:84px;text-align:center;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.infinite-loading{margin-left:0;margin-right:0;margin-top:0;margin-bottom:32px;display:none;width:100%}.infinite-loading-text{margin-left:32px;margin-right:32px;margin-top:4px;margin-bottom:0}@supports ((-webkit-margin-start: 0) or (margin-inline-start: 0)) or (-webkit-margin-start: 0){.infinite-loading-text{margin-left:unset;margin-right:unset;-webkit-margin-start:32px;margin-inline-start:32px;-webkit-margin-end:32px;margin-inline-end:32px}}.infinite-scroll-loading ion-infinite-scroll-content>.infinite-loading{display:block}.infinite-scroll-content-md .infinite-loading-text{color:var(--ion-color-step-600, #666666)}.infinite-scroll-content-md .infinite-loading-spinner .spinner-lines-md line,.infinite-scroll-content-md .infinite-loading-spinner .spinner-lines-small-md line,.infinite-scroll-content-md .infinite-loading-spinner .spinner-crescent circle{stroke:var(--ion-color-step-600, #666666)}.infinite-scroll-content-md .infinite-loading-spinner .spinner-bubbles circle,.infinite-scroll-content-md .infinite-loading-spinner .spinner-circles circle,.infinite-scroll-content-md .infinite-loading-spinner .spinner-dots circle{fill:var(--ion-color-step-600, #666666)}\";\n\nconst InfiniteScrollContent = class {\n constructor(hostRef) {\n registerInstance(this, hostRef);\n }\n componentDidLoad() {\n if (this.loadingSpinner === undefined) {\n const mode = getIonMode(this);\n this.loadingSpinner = config.get('infiniteLoadingSpinner', config.get('spinner', mode === 'ios' ? 'lines' : 'crescent'));\n }\n }\n render() {\n const mode = getIonMode(this);\n return (h(Host, { class: {\n [mode]: true,\n // Used internally for styling\n [`infinite-scroll-content-${mode}`]: true\n } }, h(\"div\", { class: \"infinite-loading\" }, this.loadingSpinner && (h(\"div\", { class: \"infinite-loading-spinner\" }, h(\"ion-spinner\", { name: this.loadingSpinner }))), this.loadingText && (h(\"div\", { class: \"infinite-loading-text\", innerHTML: sanitizeDOMString(this.loadingText) })))));\n }\n};\nInfiniteScrollContent.style = {\n ios: infiniteScrollContentIosCss,\n md: infiniteScrollContentMdCss\n};\n\nexport { InfiniteScroll as ion_infinite_scroll, InfiniteScrollContent as ion_infinite_scroll_content };\n"]}