@skyux/core
Version:
This library was generated with [Nx](https://nx.dev).
1 lines • 848 kB
Source Map (JSON)
{"version":3,"file":"skyux-core.mjs","sources":["../tmp-esm2022/lib/modules/adapter-service/adapter.module.js","../tmp-esm2022/lib/modules/breakpoint-observer/breakpoint.js","../tmp-esm2022/lib/modules/media-query/media-breakpoints.js","../tmp-esm2022/lib/modules/breakpoint-observer/breakpoint-utils.js","../tmp-esm2022/lib/modules/adapter-service/adapter.service.js","../tmp-esm2022/lib/modules/affix/affix-auto-fit-context.js","../tmp-esm2022/lib/modules/affix/affix-utils.js","../tmp-esm2022/lib/modules/affix/dom-utils.js","../tmp-esm2022/lib/modules/affix/affixer.js","../tmp-esm2022/lib/modules/affix/affix.service.js","../tmp-esm2022/lib/modules/affix/affix.directive.js","../tmp-esm2022/lib/modules/affix/affix.module.js","../tmp-esm2022/lib/modules/content-info-provider/content-info-provider.js","../tmp-esm2022/lib/modules/default-input-provider/default-input-provider.js","../tmp-esm2022/lib/modules/dock/dock-item.js","../tmp-esm2022/lib/modules/dock/dock-location.js","../tmp-esm2022/lib/modules/dock/dock.module.js","../tmp-esm2022/lib/modules/dynamic-component/dynamic-component-location.js","../tmp-esm2022/lib/modules/window/window-ref.js","../tmp-esm2022/lib/modules/dynamic-component/dynamic-component.service.js","../tmp-esm2022/lib/modules/mutation/mutation-observer-service.js","../tmp-esm2022/lib/modules/dock/dock-dom-adapter.service.js","../tmp-esm2022/lib/modules/dock/sort-by-stack-order.js","../tmp-esm2022/lib/modules/dock/dock.component.js","../tmp-esm2022/lib/modules/dock/dock.service.js","../tmp-esm2022/lib/modules/dynamic-component/dynamic-component.module.js","../tmp-esm2022/lib/modules/file-reader/file-reader.service.js","../tmp-esm2022/lib/modules/format/app-format.js","../tmp-esm2022/lib/modules/help/help-global-options-token.js","../tmp-esm2022/lib/modules/help/help.service.js","../tmp-esm2022/lib/modules/id/id.service.js","../tmp-esm2022/lib/modules/id/id.directive.js","../tmp-esm2022/lib/modules/id/id.module.js","../tmp-esm2022/lib/modules/layout-host/layout-host.service.js","../tmp-esm2022/lib/modules/layout-host/layout-host.directive.js","../tmp-esm2022/lib/modules/live-announcer/live-announcer.service.js","../tmp-esm2022/lib/modules/log/log.module.js","../tmp-esm2022/lib/modules/log/types/log-level.js","../tmp-esm2022/lib/modules/log/types/log-level-token.js","../tmp-esm2022/lib/modules/log/log.service.js","../tmp-esm2022/lib/modules/breakpoint-observer/breakpoint-observer.token.js","../tmp-esm2022/lib/modules/resize-observer/resize-observer.service.js","../tmp-esm2022/lib/modules/breakpoint-observer/container-breakpoint-observer.js","../tmp-esm2022/lib/modules/breakpoint-observer/media-breakpoint-observer.js","../tmp-esm2022/lib/modules/media-query/media-query.service.js","../tmp-esm2022/lib/modules/breakpoint-observer/provide-breakpoint-observer.js","../tmp-esm2022/lib/modules/breakpoint-observer/responsive-host.directive.js","../tmp-esm2022/lib/modules/media-query/media-query.module.js","../tmp-esm2022/lib/modules/shared/sky-core-resources.module.js","../tmp-esm2022/lib/modules/numeric/numeric.options.js","../tmp-esm2022/lib/modules/shared/number-format/number-format-utility.js","../tmp-esm2022/lib/modules/numeric/numeric.service.js","../tmp-esm2022/lib/modules/numeric/numeric.pipe.js","../tmp-esm2022/lib/modules/numeric/numeric.module.js","../tmp-esm2022/lib/modules/overlay/overlay-instance.js","../tmp-esm2022/lib/modules/overlay/overlay.module.js","../tmp-esm2022/lib/modules/overlay/overlay-adapter.service.js","../tmp-esm2022/lib/modules/overlay/overlay-context.js","../tmp-esm2022/lib/modules/stacking-context/stacking-context-token.js","../tmp-esm2022/lib/modules/overlay/overlay.component.js","../tmp-esm2022/lib/modules/overlay/overlay.service.js","../tmp-esm2022/lib/modules/percent-pipe/percent.pipe.js","../tmp-esm2022/lib/modules/percent-pipe/percent-pipe.module.js","../tmp-esm2022/lib/modules/resize-observer/resize-observer-media-query.service.js","../tmp-esm2022/lib/modules/screen-reader-label/screen-reader-label.directive.js","../tmp-esm2022/lib/modules/scroll-shadow/scroll-shadow.directive.js","../tmp-esm2022/lib/modules/scrollable-host/scrollable-host.service.js","../tmp-esm2022/lib/modules/title/title.service.js","../tmp-esm2022/lib/modules/trim/trim.directive.js","../tmp-esm2022/lib/modules/trim/trim.module.js","../tmp-esm2022/lib/modules/ui-config/ui-config.service.js","../tmp-esm2022/lib/modules/viewkeeper/viewkeeper.js","../tmp-esm2022/lib/modules/viewkeeper/viewkeeper-host-options.js","../tmp-esm2022/lib/modules/viewkeeper/viewkeeper.service.js","../tmp-esm2022/lib/modules/viewkeeper/viewkeeper.directive.js","../tmp-esm2022/lib/modules/viewkeeper/viewkeeper.module.js","../tmp-esm2022/version.js","../tmp-esm2022/skyux-core.js"],"sourcesContent":["import { NgModule } from '@angular/core';\nimport * as i0 from \"@angular/core\";\n/**\n * @deprecated The `SkyCoreAdapterService` no longer needs the `SkyCoreAdapterModule`.\n * The `SkyCoreAdapterModule` can be removed from your project.\n */\nexport class SkyCoreAdapterModule {\n static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.3.0\", ngImport: i0, type: SkyCoreAdapterModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }\n static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: \"14.0.0\", version: \"20.3.0\", ngImport: i0, type: SkyCoreAdapterModule }); }\n static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: \"12.0.0\", version: \"20.3.0\", ngImport: i0, type: SkyCoreAdapterModule }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.3.0\", ngImport: i0, type: SkyCoreAdapterModule, decorators: [{\n type: NgModule,\n args: [{}]\n }] });\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWRhcHRlci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvY29yZS9zcmMvbGliL21vZHVsZXMvYWRhcHRlci1zZXJ2aWNlL2FkYXB0ZXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBRXpDOzs7R0FHRztBQUVILE1BQU0sT0FBTyxvQkFBb0I7OEdBQXBCLG9CQUFvQjsrR0FBcEIsb0JBQW9COytHQUFwQixvQkFBb0I7OzJGQUFwQixvQkFBb0I7a0JBRGhDLFFBQVE7bUJBQUMsRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbi8qKlxuICogQGRlcHJlY2F0ZWQgVGhlIGBTa3lDb3JlQWRhcHRlclNlcnZpY2VgIG5vIGxvbmdlciBuZWVkcyB0aGUgYFNreUNvcmVBZGFwdGVyTW9kdWxlYC5cbiAqIFRoZSBgU2t5Q29yZUFkYXB0ZXJNb2R1bGVgIGNhbiBiZSByZW1vdmVkIGZyb20geW91ciBwcm9qZWN0LlxuICovXG5ATmdNb2R1bGUoe30pXG5leHBvcnQgY2xhc3MgU2t5Q29yZUFkYXB0ZXJNb2R1bGUge31cbiJdfQ==","/**\n * A list of all breakpoints.\n * @internal\n */\nexport const SKY_BREAKPOINTS = ['xs', 'sm', 'md', 'lg'];\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnJlYWtwb2ludC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9jb3JlL3NyYy9saWIvbW9kdWxlcy9icmVha3BvaW50LW9ic2VydmVyL2JyZWFrcG9pbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7OztHQUdHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sZUFBZSxHQUFHLENBQUMsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxDQUFVLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEEgbGlzdCBvZiBhbGwgYnJlYWtwb2ludHMuXG4gKiBAaW50ZXJuYWxcbiAqL1xuZXhwb3J0IGNvbnN0IFNLWV9CUkVBS1BPSU5UUyA9IFsneHMnLCAnc20nLCAnbWQnLCAnbGcnXSBhcyBjb25zdDtcblxuLyoqXG4gKiBUaGUgbmFtZSBvZiBhIHZpZXdwb3J0IG9yIGNvbnRhaW5lciBicmVha3BvaW50LlxuICovXG5leHBvcnQgdHlwZSBTa3lCcmVha3BvaW50ID0gKHR5cGVvZiBTS1lfQlJFQUtQT0lOVFMpW251bWJlcl07XG4iXX0=","/**\n * Represents all available media breakpoints.\n * @deprecated Use `SkyBreakpoint` instead.\n */\nexport var SkyMediaBreakpoints;\n(function (SkyMediaBreakpoints) {\n /**\n * Screen widths of 767px or less.\n */\n SkyMediaBreakpoints[SkyMediaBreakpoints[\"xs\"] = 1] = \"xs\";\n /**\n * Screen widths of 768px to 991px.\n */\n SkyMediaBreakpoints[SkyMediaBreakpoints[\"sm\"] = 2] = \"sm\";\n /**\n * Screen widths of 992px to 1199px.\n */\n SkyMediaBreakpoints[SkyMediaBreakpoints[\"md\"] = 3] = \"md\";\n /**\n * Screen widths of 1200px or greater.\n */\n SkyMediaBreakpoints[SkyMediaBreakpoints[\"lg\"] = 4] = \"lg\";\n})(SkyMediaBreakpoints || (SkyMediaBreakpoints = {}));\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVkaWEtYnJlYWtwb2ludHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvY29yZS9zcmMvbGliL21vZHVsZXMvbWVkaWEtcXVlcnkvbWVkaWEtYnJlYWtwb2ludHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7OztHQUdHO0FBQ0gsTUFBTSxDQUFOLElBQVksbUJBb0JYO0FBcEJELFdBQVksbUJBQW1CO0lBQzdCOztPQUVHO0lBQ0gseURBQU0sQ0FBQTtJQUVOOztPQUVHO0lBQ0gseURBQUUsQ0FBQTtJQUVGOztPQUVHO0lBQ0gseURBQUUsQ0FBQTtJQUVGOztPQUVHO0lBQ0gseURBQUUsQ0FBQTtBQUNKLENBQUMsRUFwQlcsbUJBQW1CLEtBQW5CLG1CQUFtQixRQW9COUIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFJlcHJlc2VudHMgYWxsIGF2YWlsYWJsZSBtZWRpYSBicmVha3BvaW50cy5cbiAqIEBkZXByZWNhdGVkIFVzZSBgU2t5QnJlYWtwb2ludGAgaW5zdGVhZC5cbiAqL1xuZXhwb3J0IGVudW0gU2t5TWVkaWFCcmVha3BvaW50cyB7XG4gIC8qKlxuICAgKiBTY3JlZW4gd2lkdGhzIG9mIDc2N3B4IG9yIGxlc3MuXG4gICAqL1xuICB4cyA9IDEsXG5cbiAgLyoqXG4gICAqIFNjcmVlbiB3aWR0aHMgb2YgNzY4cHggdG8gOTkxcHguXG4gICAqL1xuICBzbSxcblxuICAvKipcbiAgICogU2NyZWVuIHdpZHRocyBvZiA5OTJweCB0byAxMTk5cHguXG4gICAqL1xuICBtZCxcblxuICAvKipcbiAgICogU2NyZWVuIHdpZHRocyBvZiAxMjAwcHggb3IgZ3JlYXRlci5cbiAgICovXG4gIGxnLFxufVxuIl19","import { SkyMediaBreakpoints } from '../media-query/media-breakpoints';\nimport { SKY_BREAKPOINTS } from './breakpoint';\nconst breakpointLookup = new Map([\n [SkyMediaBreakpoints.xs, 'xs'],\n [SkyMediaBreakpoints.sm, 'sm'],\n [SkyMediaBreakpoints.md, 'md'],\n [SkyMediaBreakpoints.lg, 'lg'],\n]);\nconst legacyLookup = new Map([\n ['xs', SkyMediaBreakpoints.xs],\n ['sm', SkyMediaBreakpoints.sm],\n ['md', SkyMediaBreakpoints.md],\n ['lg', SkyMediaBreakpoints.lg],\n]);\n/**\n * Whether the value is of type `SkyBreakpoint`.\n * @internal\n */\nexport function isSkyBreakpoint(value) {\n return (value !== null &&\n value !== undefined &&\n SKY_BREAKPOINTS.includes(value));\n}\n/**\n * Transforms a `SkyMediaBreakpoints` value to `SkyBreakpoint`.\n * @internal\n */\nexport function toSkyBreakpoint(breakpoint) {\n return breakpointLookup.get(breakpoint);\n}\n/**\n * Transforms a `SkyBreakpoint` value to `SkyMediaBreakpoints`.\n * @internal\n */\nexport function toSkyMediaBreakpoints(breakpoint) {\n return legacyLookup.get(breakpoint);\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnJlYWtwb2ludC11dGlscy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9jb3JlL3NyYy9saWIvbW9kdWxlcy9icmVha3BvaW50LW9ic2VydmVyL2JyZWFrcG9pbnQtdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sa0NBQWtDLENBQUM7QUFFdkUsT0FBTyxFQUFFLGVBQWUsRUFBaUIsTUFBTSxjQUFjLENBQUM7QUFFOUQsTUFBTSxnQkFBZ0IsR0FBRyxJQUFJLEdBQUcsQ0FBcUM7SUFDbkUsQ0FBQyxtQkFBbUIsQ0FBQyxFQUFFLEVBQUUsSUFBSSxDQUFDO0lBQzlCLENBQUMsbUJBQW1CLENBQUMsRUFBRSxFQUFFLElBQUksQ0FBQztJQUM5QixDQUFDLG1CQUFtQixDQUFDLEVBQUUsRUFBRSxJQUFJLENBQUM7SUFDOUIsQ0FBQyxtQkFBbUIsQ0FBQyxFQUFFLEVBQUUsSUFBSSxDQUFDO0NBQy9CLENBQUMsQ0FBQztBQUVILE1BQU0sWUFBWSxHQUFHLElBQUksR0FBRyxDQUFxQztJQUMvRCxDQUFDLElBQUksRUFBRSxtQkFBbUIsQ0FBQyxFQUFFLENBQUM7SUFDOUIsQ0FBQyxJQUFJLEVBQUUsbUJBQW1CLENBQUMsRUFBRSxDQUFDO0lBQzlCLENBQUMsSUFBSSxFQUFFLG1CQUFtQixDQUFDLEVBQUUsQ0FBQztJQUM5QixDQUFDLElBQUksRUFBRSxtQkFBbUIsQ0FBQyxFQUFFLENBQUM7Q0FDL0IsQ0FBQyxDQUFDO0FBRUg7OztHQUdHO0FBQ0gsTUFBTSxVQUFVLGVBQWUsQ0FDN0IsS0FBNkQ7SUFFN0QsT0FBTyxDQUNMLEtBQUssS0FBSyxJQUFJO1FBQ2QsS0FBSyxLQUFLLFNBQVM7UUFDbkIsZUFBZSxDQUFDLFFBQVEsQ0FBQyxLQUFzQixDQUFDLENBQ2pELENBQUM7QUFDSixDQUFDO0FBRUQ7OztHQUdHO0FBQ0gsTUFBTSxVQUFVLGVBQWUsQ0FDN0IsVUFBK0I7SUFFL0IsT0FBTyxnQkFBZ0IsQ0FBQyxHQUFHLENBQUMsVUFBVSxDQUFrQixDQUFDO0FBQzNELENBQUM7QUFFRDs7O0dBR0c7QUFDSCxNQUFNLFVBQVUscUJBQXFCLENBQ25DLFVBQXlCO0lBRXpCLE9BQU8sWUFBWSxDQUFDLEdBQUcsQ0FBQyxVQUFVLENBQXdCLENBQUM7QUFDN0QsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNreU1lZGlhQnJlYWtwb2ludHMgfSBmcm9tICcuLi9tZWRpYS1xdWVyeS9tZWRpYS1icmVha3BvaW50cyc7XG5cbmltcG9ydCB7IFNLWV9CUkVBS1BPSU5UUywgU2t5QnJlYWtwb2ludCB9IGZyb20gJy4vYnJlYWtwb2ludCc7XG5cbmNvbnN0IGJyZWFrcG9pbnRMb29rdXAgPSBuZXcgTWFwPFNreU1lZGlhQnJlYWtwb2ludHMsIFNreUJyZWFrcG9pbnQ+KFtcbiAgW1NreU1lZGlhQnJlYWtwb2ludHMueHMsICd4cyddLFxuICBbU2t5TWVkaWFCcmVha3BvaW50cy5zbSwgJ3NtJ10sXG4gIFtTa3lNZWRpYUJyZWFrcG9pbnRzLm1kLCAnbWQnXSxcbiAgW1NreU1lZGlhQnJlYWtwb2ludHMubGcsICdsZyddLFxuXSk7XG5cbmNvbnN0IGxlZ2FjeUxvb2t1cCA9IG5ldyBNYXA8U2t5QnJlYWtwb2ludCwgU2t5TWVkaWFCcmVha3BvaW50cz4oW1xuICBbJ3hzJywgU2t5TWVkaWFCcmVha3BvaW50cy54c10sXG4gIFsnc20nLCBTa3lNZWRpYUJyZWFrcG9pbnRzLnNtXSxcbiAgWydtZCcsIFNreU1lZGlhQnJlYWtwb2ludHMubWRdLFxuICBbJ2xnJywgU2t5TWVkaWFCcmVha3BvaW50cy5sZ10sXG5dKTtcblxuLyoqXG4gKiBXaGV0aGVyIHRoZSB2YWx1ZSBpcyBvZiB0eXBlIGBTa3lCcmVha3BvaW50YC5cbiAqIEBpbnRlcm5hbFxuICovXG5leHBvcnQgZnVuY3Rpb24gaXNTa3lCcmVha3BvaW50KFxuICB2YWx1ZTogU2t5QnJlYWtwb2ludCB8IFNreU1lZGlhQnJlYWtwb2ludHMgfCBudWxsIHwgdW5kZWZpbmVkLFxuKTogdmFsdWUgaXMgU2t5QnJlYWtwb2ludCB7XG4gIHJldHVybiAoXG4gICAgdmFsdWUgIT09IG51bGwgJiZcbiAgICB2YWx1ZSAhPT0gdW5kZWZpbmVkICYmXG4gICAgU0tZX0JSRUFLUE9JTlRTLmluY2x1ZGVzKHZhbHVlIGFzIFNreUJyZWFrcG9pbnQpXG4gICk7XG59XG5cbi8qKlxuICogVHJhbnNmb3JtcyBhIGBTa3lNZWRpYUJyZWFrcG9pbnRzYCB2YWx1ZSB0byBgU2t5QnJlYWtwb2ludGAuXG4gKiBAaW50ZXJuYWxcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHRvU2t5QnJlYWtwb2ludChcbiAgYnJlYWtwb2ludDogU2t5TWVkaWFCcmVha3BvaW50cyxcbik6IFNreUJyZWFrcG9pbnQge1xuICByZXR1cm4gYnJlYWtwb2ludExvb2t1cC5nZXQoYnJlYWtwb2ludCkgYXMgU2t5QnJlYWtwb2ludDtcbn1cblxuLyoqXG4gKiBUcmFuc2Zvcm1zIGEgYFNreUJyZWFrcG9pbnRgIHZhbHVlIHRvIGBTa3lNZWRpYUJyZWFrcG9pbnRzYC5cbiAqIEBpbnRlcm5hbFxuICovXG5leHBvcnQgZnVuY3Rpb24gdG9Ta3lNZWRpYUJyZWFrcG9pbnRzKFxuICBicmVha3BvaW50OiBTa3lCcmVha3BvaW50LFxuKTogU2t5TWVkaWFCcmVha3BvaW50cyB7XG4gIHJldHVybiBsZWdhY3lMb29rdXAuZ2V0KGJyZWFrcG9pbnQpIGFzIFNreU1lZGlhQnJlYWtwb2ludHM7XG59XG4iXX0=","import { Injectable, } from '@angular/core';\nimport { SKY_BREAKPOINTS, } from '../breakpoint-observer/breakpoint';\nimport { isSkyBreakpoint, toSkyBreakpoint, } from '../breakpoint-observer/breakpoint-utils';\nimport * as i0 from \"@angular/core\";\nconst SKY_TABBABLE_SELECTOR = [\n 'a[href]',\n 'area[href]',\n 'input:not([disabled])',\n 'button:not([disabled])',\n 'select:not([disabled])',\n 'textarea:not([disabled])',\n 'iframe',\n 'object',\n 'embed',\n '*[contenteditable=true]:not([disabled])',\n '*[tabindex]:not([disabled])',\n].join(', ');\nexport class SkyCoreAdapterService {\n #renderer;\n constructor(rendererFactory) {\n this.#renderer = rendererFactory.createRenderer(undefined, null);\n }\n /**\n * Set the responsive container CSS class for a given element.\n *\n * @param elementRef - The element that will receive the new CSS class.\n * @param breakpoint - The breakpoint to determine which class gets set.\n * For example a breakpoint of \"xs\" will set a CSS class of \"sky-responsive-container-xs\".\n * @deprecated Use the `SkyResponsiveHostDirective` instead.\n */\n setResponsiveContainerClass(elementRef, breakpoint) {\n const nativeEl = elementRef.nativeElement;\n for (const breakpointType of SKY_BREAKPOINTS) {\n this.#renderer.removeClass(nativeEl, `sky-responsive-container-${breakpointType}`);\n }\n if (!isSkyBreakpoint(breakpoint)) {\n breakpoint = toSkyBreakpoint(breakpoint);\n }\n this.#renderer.addClass(nativeEl, `sky-responsive-container-${breakpoint}`);\n }\n /**\n * This method temporarily enables/disables pointer events.\n * This is helpful to prevent iFrames from interfering with drag events.\n *\n * @param enable - Set to `true` to enable pointer events. Set to `false` to disable.\n */\n toggleIframePointerEvents(enable) {\n const iframes = Array.from(document.querySelectorAll('iframe'));\n for (const iframe of iframes) {\n this.#renderer.setStyle(iframe, 'pointer-events', enable ? '' : 'none');\n }\n }\n /**\n * Focuses on the first element found with an `autofocus` attribute inside the supplied `elementRef`.\n *\n * @param elementRef - The element to search within.\n * @return Returns `true` if a child element with autofocus is found.\n */\n applyAutoFocus(elementRef) {\n if (!elementRef) {\n return false;\n }\n const elementWithAutoFocus = elementRef.nativeElement.querySelector('[autofocus]');\n // Child was found with the autofocus property. Set focus and return true.\n if (elementWithAutoFocus) {\n elementWithAutoFocus.focus();\n return true;\n }\n // No children were found with autofocus property. Return false.\n return false;\n }\n /**\n * Sets focus on the first focusable child of the `elementRef` parameter.\n * If no focusable children are found, and `focusOnContainerIfNoChildrenFound` is `true`,\n * focus will be set on the container element.\n *\n * @param elementRef - The element to search within.\n * @param containerSelector - A CSS selector indicating the container that should\n * receive focus if no focusable children are found.\n * @param focusOnContainerIfNoChildrenFound - It set to `true`, the container will\n * receive focus if no focusable children are found.\n */\n getFocusableChildrenAndApplyFocus(elementRef, containerSelector, focusOnContainerIfNoChildrenFound = false) {\n const containerElement = elementRef.nativeElement.querySelector(containerSelector);\n if (containerElement) {\n const focusableChildren = this.getFocusableChildren(containerElement);\n // Focus first focusable child if available. Otherwise, set focus on container.\n if (!this.#focusFirstElement(focusableChildren) &&\n focusOnContainerIfNoChildrenFound) {\n containerElement.focus();\n }\n }\n }\n /**\n * Returns an array of all focusable children of provided `element`.\n *\n * @param element - The HTMLElement to search within.\n * @param options - Options for getting focusable children.\n */\n getFocusableChildren(element, options) {\n if (!element) {\n return [];\n }\n let elements = Array.prototype.slice.call(element.querySelectorAll(SKY_TABBABLE_SELECTOR));\n // Unless ignoreTabIndex = true, filter out elements with tabindex = -1.\n if (!options || !options.ignoreTabIndex) {\n elements = elements.filter((el) => {\n return el.tabIndex !== -1;\n });\n }\n // Unless ignoreVisibility = true, filter out elements that are not visible.\n if (!options || !options.ignoreVisibility) {\n elements = elements.filter((el) => {\n return this.#isVisible(el);\n });\n }\n return elements;\n }\n /**\n * Returns the clientWidth of the provided elementRef.\n * @param elementRef - The element to calculate width from.\n */\n getWidth(elementRef) {\n return elementRef.nativeElement.clientWidth;\n }\n /**\n * Checks if an event target has a higher z-index than a given element.\n * @param target The event target element.\n * @param element The element to test against. A z-index must be explicitly set for this element.\n */\n isTargetAboveElement(target, element) {\n const zIndex = getComputedStyle(element).zIndex;\n let el = target;\n while (el) {\n // Getting the computed style only works for elements that exist in the DOM.\n // In certain scenarios, an element is removed after a click event; by the time the event\n // bubbles up to other elements, however, the element has been removed and the computed style returns empty.\n // In this case, we'll need to check the z-index directly, via the style property.\n const targetZIndex = getComputedStyle(el).zIndex || el.style.zIndex;\n if (targetZIndex !== '' &&\n targetZIndex !== 'auto' &&\n +targetZIndex > +zIndex) {\n return true;\n }\n el = el.parentElement;\n }\n return false;\n }\n /**\n * Remove inline height styles from the provided elements.\n * @param elementRef - The element to search within.\n * @param selector - The CSS selector to use when finding elements for removing height.\n */\n resetHeight(elementRef, selector) {\n const children = Array.from(elementRef.nativeElement.querySelectorAll(selector));\n for (const child of children) {\n this.#renderer.removeStyle(child, 'height');\n }\n }\n /**\n * Sets all element heights to match the height of the tallest element.\n * @param elementRef - The element to search within.\n * @param selector - The CSS selector to use when finding elements for syncing height.\n */\n syncMaxHeight(elementRef, selector) {\n const children = Array.from(elementRef.nativeElement.querySelectorAll(selector));\n /* istanbul ignore else */\n if (children.length > 0) {\n let maxHeight = 0;\n for (const child of children) {\n maxHeight = Math.max(maxHeight, child.offsetHeight);\n }\n for (const child of children) {\n this.#renderer.setStyle(child, 'height', `${maxHeight}px`);\n }\n }\n }\n #focusFirstElement(list) {\n if (list.length > 0) {\n list[0].focus();\n return true;\n }\n return false;\n }\n #isVisible(element) {\n const style = window.getComputedStyle(element);\n const isHidden = style.display === 'none' || style.visibility === 'hidden';\n if (isHidden) {\n return false;\n }\n const hasBounds = !!(element.offsetWidth ||\n element.offsetHeight ||\n element.getClientRects().length);\n return hasBounds;\n }\n static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.3.0\", ngImport: i0, type: SkyCoreAdapterService, deps: [{ token: i0.RendererFactory2 }], target: i0.ɵɵFactoryTarget.Injectable }); }\n static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: \"12.0.0\", version: \"20.3.0\", ngImport: i0, type: SkyCoreAdapterService, providedIn: 'root' }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.3.0\", ngImport: i0, type: SkyCoreAdapterService, decorators: [{\n type: Injectable,\n args: [{\n providedIn: 'root',\n }]\n }], ctorParameters: () => [{ type: i0.RendererFactory2 }] });\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"adapter.service.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/adapter-service/adapter.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,UAAU,GAGX,MAAM,eAAe,CAAC;AAEvB,OAAO,EACL,eAAe,GAEhB,MAAM,mCAAmC,CAAC;AAC3C,OAAO,EACL,eAAe,EACf,eAAe,GAChB,MAAM,yCAAyC,CAAC;;AAKjD,MAAM,qBAAqB,GAAG;IAC5B,SAAS;IACT,YAAY;IACZ,uBAAuB;IACvB,wBAAwB;IACxB,wBAAwB;IACxB,0BAA0B;IAC1B,QAAQ;IACR,QAAQ;IACR,OAAO;IACP,yCAAyC;IACzC,6BAA6B;CAC9B,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AAKb,MAAM,OAAO,qBAAqB;IAChC,SAAS,CAAY;IAErB,YAAY,eAAiC;QAC3C,IAAI,CAAC,SAAS,GAAG,eAAe,CAAC,cAAc,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;IACnE,CAAC;IAED;;;;;;;OAOG;IACI,2BAA2B,CAChC,UAAsB,EACtB,UAA+C;QAE/C,MAAM,QAAQ,GAAG,UAAU,CAAC,aAAa,CAAC;QAE1C,KAAK,MAAM,cAAc,IAAI,eAAe,EAAE,CAAC;YAC7C,IAAI,CAAC,SAAS,CAAC,WAAW,CACxB,QAAQ,EACR,4BAA4B,cAAc,EAAE,CAC7C,CAAC;QACJ,CAAC;QAED,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,EAAE,CAAC;YACjC,UAAU,GAAG,eAAe,CAAC,UAAU,CAAC,CAAC;QAC3C,CAAC;QAED,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,QAAQ,EAAE,4BAA4B,UAAU,EAAE,CAAC,CAAC;IAC9E,CAAC;IAED;;;;;OAKG;IACI,yBAAyB,CAAC,MAAe;QAC9C,MAAM,OAAO,GAAG,KAAK,CAAC,IAAI,CACxB,QAAQ,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CACpC,CAAC;QACF,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;YAC7B,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,MAAM,EAAE,gBAAgB,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;QAC1E,CAAC;IACH,CAAC;IAED;;;;;OAKG;IACI,cAAc,CAAC,UAAuB;QAC3C,IAAI,CAAC,UAAU,EAAE,CAAC;YAChB,OAAO,KAAK,CAAC;QACf,CAAC;QAED,MAAM,oBAAoB,GACxB,UAAU,CAAC,aAAa,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC;QAExD,0EAA0E;QAC1E,IAAI,oBAAoB,EAAE,CAAC;YACzB,oBAAoB,CAAC,KAAK,EAAE,CAAC;YAC7B,OAAO,IAAI,CAAC;QACd,CAAC;QAED,gEAAgE;QAChE,OAAO,KAAK,CAAC;IACf,CAAC;IAED;;;;;;;;;;OAUG;IACI,iCAAiC,CACtC,UAAsB,EACtB,iBAA0B,EAC1B,iCAAiC,GAAG,KAAK;QAEzC,MAAM,gBAAgB,GACpB,UAAU,CAAC,aAAa,CAAC,aAAa,CAAC,iBAAiB,CAAC,CAAC;QAE5D,IAAI,gBAAgB,EAAE,CAAC;YACrB,MAAM,iBAAiB,GAAG,IAAI,CAAC,oBAAoB,CAAC,gBAAgB,CAAC,CAAC;YAEtE,+EAA+E;YAC/E,IACE,CAAC,IAAI,CAAC,kBAAkB,CAAC,iBAAiB,CAAC;gBAC3C,iCAAiC,EACjC,CAAC;gBACD,gBAAgB,CAAC,KAAK,EAAE,CAAC;YAC3B,CAAC;QACH,CAAC;IACH,CAAC;IAED;;;;;OAKG;IACI,oBAAoB,CACzB,OAAqB,EACrB,OAAqC;QAErC,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,IAAI,QAAQ,GAAG,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CACvC,OAAO,CAAC,gBAAgB,CAAC,qBAAqB,CAAC,CAChD,CAAC;QAEF,wEAAwE;QACxE,IAAI,CAAC,OAAO,IAAI,CAAC,OAAO,CAAC,cAAc,EAAE,CAAC;YACxC,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,EAAe,EAAE,EAAE;gBAC7C,OAAO,EAAE,CAAC,QAAQ,KAAK,CAAC,CAAC,CAAC;YAC5B,CAAC,CAAC,CAAC;QACL,CAAC;QAED,4EAA4E;QAC5E,IAAI,CAAC,OAAO,IAAI,CAAC,OAAO,CAAC,gBAAgB,EAAE,CAAC;YAC1C,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,EAAe,EAAE,EAAE;gBAC7C,OAAO,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;YAC7B,CAAC,CAAC,CAAC;QACL,CAAC;QAED,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED;;;OAGG;IACI,QAAQ,CAAC,UAAsB;QACpC,OAAO,UAAU,CAAC,aAAa,CAAC,WAAW,CAAC;IAC9C,CAAC;IAED;;;;OAIG;IACI,oBAAoB,CACzB,MAAmB,EACnB,OAAoB;QAEpB,MAAM,MAAM,GAAG,gBAAgB,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC;QAEhD,IAAI,EAAE,GAAG,MAAqB,CAAC;QAE/B,OAAO,EAAE,EAAE,CAAC;YACV,4EAA4E;YAC5E,yFAAyF;YACzF,4GAA4G;YAC5G,kFAAkF;YAClF,MAAM,YAAY,GAAG,gBAAgB,CAAC,EAAE,CAAC,CAAC,MAAM,IAAI,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC;YACpE,IACE,YAAY,KAAK,EAAE;gBACnB,YAAY,KAAK,MAAM;gBACvB,CAAC,YAAY,GAAG,CAAC,MAAM,EACvB,CAAC;gBACD,OAAO,IAAI,CAAC;YACd,CAAC;YAED,EAAE,GAAG,EAAE,CAAC,aAA4B,CAAC;QACvC,CAAC;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAED;;;;OAIG;IACI,WAAW,CAAC,UAAsB,EAAE,QAAgB;QACzD,MAAM,QAAQ,GAAG,KAAK,CAAC,IAAI,CACzB,UAAU,CAAC,aAAa,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CACpD,CAAC;QACF,KAAK,MAAM,KAAK,IAAI,QAAQ,EAAE,CAAC;YAC7B,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;QAC9C,CAAC;IACH,CAAC;IAED;;;;OAIG;IACI,aAAa,CAAC,UAAsB,EAAE,QAAgB;QAC3D,MAAM,QAAQ,GAAG,KAAK,CAAC,IAAI,CACzB,UAAU,CAAC,aAAa,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CACpD,CAAC;QACF,0BAA0B;QAC1B,IAAI,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACxB,IAAI,SAAS,GAAG,CAAC,CAAC;YAClB,KAAK,MAAM,KAAK,IAAI,QAAQ,EAAE,CAAC;gBAC7B,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,EAAE,KAAK,CAAC,YAAY,CAAC,CAAC;YACtD,CAAC;YACD,KAAK,MAAM,KAAK,IAAI,QAAQ,EAAE,CAAC;gBAC7B,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,KAAK,EAAE,QAAQ,EAAE,GAAG,SAAS,IAAI,CAAC,CAAC;YAC7D,CAAC;QACH,CAAC;IACH,CAAC;IAED,kBAAkB,CAAC,IAAmB;QACpC,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACpB,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC;YAChB,OAAO,IAAI,CAAC;QACd,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAED,UAAU,CAAC,OAAoB;QAC7B,MAAM,KAAK,GAAG,MAAM,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC;QAC/C,MAAM,QAAQ,GAAG,KAAK,CAAC,OAAO,KAAK,MAAM,IAAI,KAAK,CAAC,UAAU,KAAK,QAAQ,CAAC;QAC3E,IAAI,QAAQ,EAAE,CAAC;YACb,OAAO,KAAK,CAAC;QACf,CAAC;QAED,MAAM,SAAS,GAAG,CAAC,CAAC,CAClB,OAAO,CAAC,WAAW;YACnB,OAAO,CAAC,YAAY;YACpB,OAAO,CAAC,cAAc,EAAE,CAAC,MAAM,CAChC,CAAC;QACF,OAAO,SAAS,CAAC;IACnB,CAAC;8GA9OU,qBAAqB;kHAArB,qBAAqB,cAFpB,MAAM;;2FAEP,qBAAqB;kBAHjC,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB","sourcesContent":["import {\n  ElementRef,\n  Injectable,\n  Renderer2,\n  RendererFactory2,\n} from '@angular/core';\n\nimport {\n  SKY_BREAKPOINTS,\n  SkyBreakpoint,\n} from '../breakpoint-observer/breakpoint';\nimport {\n  isSkyBreakpoint,\n  toSkyBreakpoint,\n} from '../breakpoint-observer/breakpoint-utils';\nimport { SkyMediaBreakpoints } from '../media-query/media-breakpoints';\n\nimport { SkyFocusableChildrenOptions } from './focusable-children-options';\n\nconst SKY_TABBABLE_SELECTOR = [\n  'a[href]',\n  'area[href]',\n  'input:not([disabled])',\n  'button:not([disabled])',\n  'select:not([disabled])',\n  'textarea:not([disabled])',\n  'iframe',\n  'object',\n  'embed',\n  '*[contenteditable=true]:not([disabled])',\n  '*[tabindex]:not([disabled])',\n].join(', ');\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class SkyCoreAdapterService {\n  #renderer: Renderer2;\n\n  constructor(rendererFactory: RendererFactory2) {\n    this.#renderer = rendererFactory.createRenderer(undefined, null);\n  }\n\n  /**\n   * Set the responsive container CSS class for a given element.\n   *\n   * @param elementRef - The element that will receive the new CSS class.\n   * @param breakpoint - The breakpoint to determine which class gets set.\n   * For example a breakpoint of \"xs\" will set a CSS class of \"sky-responsive-container-xs\".\n   * @deprecated Use the `SkyResponsiveHostDirective` instead.\n   */\n  public setResponsiveContainerClass(\n    elementRef: ElementRef,\n    breakpoint: SkyBreakpoint | SkyMediaBreakpoints,\n  ): void {\n    const nativeEl = elementRef.nativeElement;\n\n    for (const breakpointType of SKY_BREAKPOINTS) {\n      this.#renderer.removeClass(\n        nativeEl,\n        `sky-responsive-container-${breakpointType}`,\n      );\n    }\n\n    if (!isSkyBreakpoint(breakpoint)) {\n      breakpoint = toSkyBreakpoint(breakpoint);\n    }\n\n    this.#renderer.addClass(nativeEl, `sky-responsive-container-${breakpoint}`);\n  }\n\n  /**\n   * This method temporarily enables/disables pointer events.\n   * This is helpful to prevent iFrames from interfering with drag events.\n   *\n   * @param enable - Set to `true` to enable pointer events. Set to `false` to disable.\n   */\n  public toggleIframePointerEvents(enable: boolean): void {\n    const iframes = Array.from<HTMLElement>(\n      document.querySelectorAll('iframe'),\n    );\n    for (const iframe of iframes) {\n      this.#renderer.setStyle(iframe, 'pointer-events', enable ? '' : 'none');\n    }\n  }\n\n  /**\n   * Focuses on the first element found with an `autofocus` attribute inside the supplied `elementRef`.\n   *\n   * @param elementRef - The element to search within.\n   * @return Returns `true` if a child element with autofocus is found.\n   */\n  public applyAutoFocus(elementRef?: ElementRef): boolean {\n    if (!elementRef) {\n      return false;\n    }\n\n    const elementWithAutoFocus =\n      elementRef.nativeElement.querySelector('[autofocus]');\n\n    // Child was found with the autofocus property. Set focus and return true.\n    if (elementWithAutoFocus) {\n      elementWithAutoFocus.focus();\n      return true;\n    }\n\n    // No children were found with autofocus property. Return false.\n    return false;\n  }\n\n  /**\n   * Sets focus on the first focusable child of the `elementRef` parameter.\n   * If no focusable children are found, and `focusOnContainerIfNoChildrenFound` is `true`,\n   * focus will be set on the container element.\n   *\n   * @param elementRef - The element to search within.\n   * @param containerSelector - A CSS selector indicating the container that should\n   * receive focus if no focusable children are found.\n   * @param focusOnContainerIfNoChildrenFound - It set to `true`, the container will\n   * receive focus if no focusable children are found.\n   */\n  public getFocusableChildrenAndApplyFocus(\n    elementRef: ElementRef,\n    containerSelector?: string,\n    focusOnContainerIfNoChildrenFound = false,\n  ): void {\n    const containerElement =\n      elementRef.nativeElement.querySelector(containerSelector);\n\n    if (containerElement) {\n      const focusableChildren = this.getFocusableChildren(containerElement);\n\n      // Focus first focusable child if available. Otherwise, set focus on container.\n      if (\n        !this.#focusFirstElement(focusableChildren) &&\n        focusOnContainerIfNoChildrenFound\n      ) {\n        containerElement.focus();\n      }\n    }\n  }\n\n  /**\n   * Returns an array of all focusable children of provided `element`.\n   *\n   * @param element - The HTMLElement to search within.\n   * @param options - Options for getting focusable children.\n   */\n  public getFocusableChildren(\n    element?: HTMLElement,\n    options?: SkyFocusableChildrenOptions,\n  ): HTMLElement[] {\n    if (!element) {\n      return [];\n    }\n\n    let elements = Array.prototype.slice.call(\n      element.querySelectorAll(SKY_TABBABLE_SELECTOR),\n    );\n\n    // Unless ignoreTabIndex = true, filter out elements with tabindex = -1.\n    if (!options || !options.ignoreTabIndex) {\n      elements = elements.filter((el: HTMLElement) => {\n        return el.tabIndex !== -1;\n      });\n    }\n\n    // Unless ignoreVisibility = true, filter out elements that are not visible.\n    if (!options || !options.ignoreVisibility) {\n      elements = elements.filter((el: HTMLElement) => {\n        return this.#isVisible(el);\n      });\n    }\n\n    return elements;\n  }\n\n  /**\n   * Returns the clientWidth of the provided elementRef.\n   * @param elementRef - The element to calculate width from.\n   */\n  public getWidth(elementRef: ElementRef): number {\n    return elementRef.nativeElement.clientWidth;\n  }\n\n  /**\n   * Checks if an event target has a higher z-index than a given element.\n   * @param target The event target element.\n   * @param element The element to test against. A z-index must be explicitly set for this element.\n   */\n  public isTargetAboveElement(\n    target: EventTarget,\n    element: HTMLElement,\n  ): boolean {\n    const zIndex = getComputedStyle(element).zIndex;\n\n    let el = target as HTMLElement;\n\n    while (el) {\n      // Getting the computed style only works for elements that exist in the DOM.\n      // In certain scenarios, an element is removed after a click event; by the time the event\n      // bubbles up to other elements, however, the element has been removed and the computed style returns empty.\n      // In this case, we'll need to check the z-index directly, via the style property.\n      const targetZIndex = getComputedStyle(el).zIndex || el.style.zIndex;\n      if (\n        targetZIndex !== '' &&\n        targetZIndex !== 'auto' &&\n        +targetZIndex > +zIndex\n      ) {\n        return true;\n      }\n\n      el = el.parentElement as HTMLElement;\n    }\n\n    return false;\n  }\n\n  /**\n   * Remove inline height styles from the provided elements.\n   * @param elementRef - The element to search within.\n   * @param selector - The CSS selector to use when finding elements for removing height.\n   */\n  public resetHeight(elementRef: ElementRef, selector: string): void {\n    const children = Array.from<HTMLElement>(\n      elementRef.nativeElement.querySelectorAll(selector),\n    );\n    for (const child of children) {\n      this.#renderer.removeStyle(child, 'height');\n    }\n  }\n\n  /**\n   * Sets all element heights to match the height of the tallest element.\n   * @param elementRef - The element to search within.\n   * @param selector - The CSS selector to use when finding elements for syncing height.\n   */\n  public syncMaxHeight(elementRef: ElementRef, selector: string): void {\n    const children = Array.from<HTMLElement>(\n      elementRef.nativeElement.querySelectorAll(selector),\n    );\n    /* istanbul ignore else */\n    if (children.length > 0) {\n      let maxHeight = 0;\n      for (const child of children) {\n        maxHeight = Math.max(maxHeight, child.offsetHeight);\n      }\n      for (const child of children) {\n        this.#renderer.setStyle(child, 'height', `${maxHeight}px`);\n      }\n    }\n  }\n\n  #focusFirstElement(list: HTMLElement[]): boolean {\n    if (list.length > 0) {\n      list[0].focus();\n      return true;\n    }\n    return false;\n  }\n\n  #isVisible(element: HTMLElement): boolean {\n    const style = window.getComputedStyle(element);\n    const isHidden = style.display === 'none' || style.visibility === 'hidden';\n    if (isHidden) {\n      return false;\n    }\n\n    const hasBounds = !!(\n      element.offsetWidth ||\n      element.offsetHeight ||\n      element.getClientRects().length\n    );\n    return hasBounds;\n  }\n}\n"]}","export var SkyAffixAutoFitContext;\n(function (SkyAffixAutoFitContext) {\n /**\n * Auto-fit functionality will respect the nearest overflow parent element's dimensions.\n */\n SkyAffixAutoFitContext[SkyAffixAutoFitContext[\"OverflowParent\"] = 0] = \"OverflowParent\";\n /**\n * Auto-fit functionality will respect the browser viewport dimensions.\n */\n SkyAffixAutoFitContext[SkyAffixAutoFitContext[\"Viewport\"] = 1] = \"Viewport\";\n})(SkyAffixAutoFitContext || (SkyAffixAutoFitContext = {}));\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWZmaXgtYXV0by1maXQtY29udGV4dC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9jb3JlL3NyYy9saWIvbW9kdWxlcy9hZmZpeC9hZmZpeC1hdXRvLWZpdC1jb250ZXh0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBTixJQUFZLHNCQVVYO0FBVkQsV0FBWSxzQkFBc0I7SUFDaEM7O09BRUc7SUFDSCx1RkFBa0IsQ0FBQTtJQUVsQjs7T0FFRztJQUNILDJFQUFZLENBQUE7QUFDZCxDQUFDLEVBVlcsc0JBQXNCLEtBQXRCLHNCQUFzQixRQVVqQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBlbnVtIFNreUFmZml4QXV0b0ZpdENvbnRleHQge1xuICAvKipcbiAgICogQXV0by1maXQgZnVuY3Rpb25hbGl0eSB3aWxsIHJlc3BlY3QgdGhlIG5lYXJlc3Qgb3ZlcmZsb3cgcGFyZW50IGVsZW1lbnQncyBkaW1lbnNpb25zLlxuICAgKi9cbiAgT3ZlcmZsb3dQYXJlbnQgPSAwLFxuXG4gIC8qKlxuICAgKiBBdXRvLWZpdCBmdW5jdGlvbmFsaXR5IHdpbGwgcmVzcGVjdCB0aGUgYnJvd3NlciB2aWV3cG9ydCBkaW1lbnNpb25zLlxuICAgKi9cbiAgVmlld3BvcnQgPSAxLFxufVxuIl19","export function getNextPlacement(placement) {\n const placements = ['above', 'right', 'below', 'left'];\n let index = placements.indexOf(placement) + 1;\n if (index >= placements.length) {\n index = 0;\n }\n return placements[index];\n}\nexport function getInversePlacement(placement) {\n const pairings = {\n above: 'below',\n below: 'above',\n right: 'left',\n left: 'right',\n };\n return pairings[placement];\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWZmaXgtdXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvY29yZS9zcmMvbGliL21vZHVsZXMvYWZmaXgvYWZmaXgtdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxVQUFVLGdCQUFnQixDQUM5QixTQUE0QjtJQUU1QixNQUFNLFVBQVUsR0FBd0IsQ0FBQyxPQUFPLEVBQUUsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLENBQUMsQ0FBQztJQUU1RSxJQUFJLEtBQUssR0FBRyxVQUFVLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUM5QyxJQUFJLEtBQUssSUFBSSxVQUFVLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDL0IsS0FBSyxHQUFHLENBQUMsQ0FBQztJQUNaLENBQUM7SUFFRCxPQUFPLFVBQVUsQ0FBQyxLQUFLLENBQUMsQ0FBQztBQUMzQixDQUFDO0FBRUQsTUFBTSxVQUFVLG1CQUFtQixDQUNqQyxTQUE0QjtJQUU1QixNQUFNLFFBQVEsR0FBc0M7UUFDbEQsS0FBSyxFQUFFLE9BQU87UUFDZCxLQUFLLEVBQUUsT0FBTztRQUNkLEtBQUssRUFBRSxNQUFNO1FBQ2IsSUFBSSxFQUFFLE9BQU87S0FDZCxDQUFDO0lBRUYsT0FBTyxRQUFRLENBQUMsU0FBUyxDQUFDLENBQUM7QUFDN0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNreUFmZml4UGxhY2VtZW50IH0gZnJvbSAnLi9hZmZpeC1wbGFjZW1lbnQnO1xuXG5leHBvcnQgZnVuY3Rpb24gZ2V0TmV4dFBsYWNlbWVudChcbiAgcGxhY2VtZW50OiBTa3lBZmZpeFBsYWNlbWVudCxcbik6IFNreUFmZml4UGxhY2VtZW50IHtcbiAgY29uc3QgcGxhY2VtZW50czogU2t5QWZmaXhQbGFjZW1lbnRbXSA9IFsnYWJvdmUnLCAncmlnaHQnLCAnYmVsb3cnLCAnbGVmdCddO1xuXG4gIGxldCBpbmRleCA9IHBsYWNlbWVudHMuaW5kZXhPZihwbGFjZW1lbnQpICsgMTtcbiAgaWYgKGluZGV4ID49IHBsYWNlbWVudHMubGVuZ3RoKSB7XG4gICAgaW5kZXggPSAwO1xuICB9XG5cbiAgcmV0dXJuIHBsYWNlbWVudHNbaW5kZXhdO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZ2V0SW52ZXJzZVBsYWNlbWVudChcbiAgcGxhY2VtZW50OiBTa3lBZmZpeFBsYWNlbWVudCxcbik6IFNreUFmZml4UGxhY2VtZW50IHtcbiAgY29uc3QgcGFpcmluZ3M6IFJlY29yZDxzdHJpbmcsIFNreUFmZml4UGxhY2VtZW50PiA9IHtcbiAgICBhYm92ZTogJ2JlbG93JyxcbiAgICBiZWxvdzogJ2Fib3ZlJyxcbiAgICByaWdodDogJ2xlZnQnLFxuICAgIGxlZnQ6ICdyaWdodCcsXG4gIH07XG5cbiAgcmV0dXJuIHBhaXJpbmdzW3BsYWNlbWVudF07XG59XG4iXX0=","function useViewportForBounds(element) {\n return 'BODY' === element.tagName;\n}\n/**\n * Returns the offset values of a given element.\n * @param element The HTML element.\n * @param bufferOffset An optional offset to add/subtract to the element's actual offset.\n */\nexport function getElementOffset(element, bufferOffset) {\n const bufferOffsetBottom = bufferOffset?.bottom || 0;\n const bufferOffsetLeft = bufferOffset?.left || 0;\n const bufferOffsetRight = bufferOffset?.right || 0;\n const bufferOffsetTop = bufferOffset?.top || 0;\n let top;\n let left;\n let right;\n let bottom;\n const clientRect = element.getBoundingClientRect();\n left = clientRect.left;\n top = clientRect.top;\n right = clientRect.right;\n bottom = clientRect.bottom;\n bottom -= bufferOffsetBottom;\n left += bufferOffsetLeft;\n right -= bufferOffsetRight;\n top += bufferOffsetTop;\n return {\n bottom,\n left,\n right,\n top,\n };\n}\n/**\n * Returns an AffixRect that represents the outer dimensions of a given element.\n */\nexport function getOuterRect(element) {\n const rect = element.getBoundingClientRect();\n const computedStyle = window.getComputedStyle(element, undefined);\n const marginTop = parseFloat(computedStyle.marginTop);\n const marginLeft = parseFloat(computedStyle.marginLeft);\n const marginRight = parseFloat(computedStyle.marginRight);\n const marginBottom = parseFloat(computedStyle.marginBottom);\n return {\n top: rect.top - marginTop,\n left: rect.left - marginLeft,\n bottom: rect.top + rect.height + marginBottom,\n right: rect.left + rect.width + marginLeft + marginRight,\n width: rect.width + marginLeft + marginRight,\n height: rect.height + marginTop + marginBottom,\n };\n}\n/**\n * Returns the visible rect for a given element.\n */\nexport function getVisibleRectForElement(viewportRuler, element) {\n const elementRect = getOuterRect(element);\n const viewportRect = viewportRuler.getViewportRect();\n const visibleRect = {\n top: Math.max(elementRect.top, 0),\n left: Math.max(elementRect.left, 0),\n bottom: Math.min(elementRect.bottom, viewportRect.height),\n right: Math.min(elementRect.right, viewportRect.width),\n };\n return {\n ...visibleRect,\n width: visibleRect.right - visibleRect.left,\n height: visibleRect.bottom - visibleRect.top,\n };\n}\nexport function getOverflowParents(child) {\n const bodyElement = window.document.body;\n const results = [];\n let parentElement = child?.parentNode;\n while (parentElement !== undefined && parentElement instanceof HTMLElement) {\n if (parentElement.matches('body')) {\n break;\n }\n const computedStyle = window.getComputedStyle(parentElement, undefined);\n const overflowY = computedStyle.overflowY.toLowerCase();\n const largerThanTheDocumentElement = window.document.documentElement.scrollWidth < parentElement.scrollWidth ||\n window.document.documentElement.scrollHeight < parentElement.scrollHeight;\n const hasOverflowRules = overflowY === 'auto' || overflowY === 'hidden' || overflowY === 'scroll';\n if (largerThanTheDocumentElement || hasOverflowRules) {\n results.push(parentElement);\n }\n if (computedStyle.position === 'fixed') {\n break;\n }\n parentElement = parentElement.parentNode;\n }\n results.push(bodyElement);\n return results;\n}\n/**\n * Confirms offset is fully visible within a parent element.\n */\nexport function isOffsetFullyVisibleWithinParent(viewportRuler, parent, offset, bufferOffset) {\n let parentOffset;\n if (useViewportForBounds(parent)) {\n const viewportRect = viewportRuler.getViewportRect();\n parentOffset = {\n top: 0,\n left: 0,\n right: viewportRect.width,\n bottom: viewportRect.height,\n };\n }\n else if (bufferOffset) {\n parentOffset = getElementOffset(parent, bufferOffset);\n }\n else {\n parentOffset = getVisibleRectForElement(viewportRuler, parent);\n }\n return (parentOffset.top <= offset.top &&\n parentOffset.right >= offset.right &&\n parentOffset.bottom >= offset.bottom &&\n parentOffset.left <= offset.left);\n}\nexport function isOffsetPartiallyVisibleWithinParent(viewportRuler, parent, offset, bufferOffset) {\n let parentOffset;\n if (useViewportForBounds(parent)) {\n const viewportRect = viewportRuler.getViewportRect();\n parentOffset = {\n top: 0,\n left: 0,\n right: viewportRect.width,\n bottom: viewportRect.height,\n };\n }\n else if (bufferOffset) {\n parentOffset = getElementOffset(parent, bufferOffset);\n }\n else {\n parentOffset = getVisibleRectForElement(viewportRuler, parent);\n }\n return !(parentOffset.top >= offset.bottom ||\n parentOffset.right <= offset.left ||\n parentOffset.bottom <= offset.top ||\n parentOffset.left >= offset.right);\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9tLXV0aWxzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiO