@skyux/lists 9.19.1 → 9.20.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/esm2022/index.mjs CHANGED
@@ -19,4 +19,5 @@ export { SkyRepeaterItemComponent as λ10 } from './lib/modules/repeater/repeate
19
19
  export { SkyRepeaterComponent as λ11 } from './lib/modules/repeater/repeater.component';
20
20
  export { SkySortItemComponent as λ13 } from './lib/modules/sort/sort-item.component';
21
21
  export { SkySortComponent as λ14 } from './lib/modules/sort/sort.component';
22
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbGlzdHMvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUVyRSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxzREFBc0QsQ0FBQztBQUUvRixPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFHckUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sd0NBQXdDLENBQUM7QUFFM0UsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBRS9ELDBGQUEwRjtBQUMxRiwyRUFBMkU7QUFDM0UsT0FBTyxFQUFFLHdCQUF3QixJQUFJLEVBQUUsRUFBRSxNQUFNLDhDQUE4QyxDQUFDO0FBQzlGLE9BQU8sRUFBRSw0QkFBNEIsSUFBSSxFQUFFLEVBQUUsTUFBTSxtREFBbUQsQ0FBQztBQUN2RyxPQUFPLEVBQUUsd0JBQXdCLElBQUksRUFBRSxFQUFFLE1BQU0sOENBQThDLENBQUM7QUFDOUYsT0FBTyxFQUFFLDZCQUE2QixJQUFJLEVBQUUsRUFBRSxNQUFNLG9EQUFvRCxDQUFDO0FBQ3pHLE9BQU8sRUFBRSx5QkFBeUIsSUFBSSxFQUFFLEVBQUUsTUFBTSwrQ0FBK0MsQ0FBQztBQUNoRyxPQUFPLEVBQUUsMEJBQTBCLElBQUksRUFBRSxFQUFFLE1BQU0seURBQXlELENBQUM7QUFDM0csT0FBTyxFQUFFLGtCQUFrQixJQUFJLEVBQUUsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBQ2pGLE9BQU8sRUFBRSwrQkFBK0IsSUFBSSxFQUFFLEVBQUUsTUFBTSx3REFBd0QsQ0FBQztBQUMvRyxPQUFPLEVBQUUsbUNBQW1DLElBQUksRUFBRSxFQUFFLE1BQU0sNkRBQTZELENBQUM7QUFDeEgsT0FBTyxFQUFFLDZCQUE2QixJQUFJLEdBQUcsRUFBRSxNQUFNLHNEQUFzRCxDQUFDO0FBQzVHLE9BQU8sRUFBRSx3QkFBd0IsSUFBSSxHQUFHLEVBQUUsTUFBTSxnREFBZ0QsQ0FBQztBQUNqRyxPQUFPLEVBQUUsb0JBQW9CLElBQUksR0FBRyxFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFDeEYsT0FBTyxFQUFFLG9CQUFvQixJQUFJLEdBQUcsRUFBRSxNQUFNLHdDQUF3QyxDQUFDO0FBQ3JGLE9BQU8sRUFBRSxnQkFBZ0IsSUFBSSxHQUFHLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IFNreUZpbHRlck1vZHVsZSB9IGZyb20gJy4vbGliL21vZHVsZXMvZmlsdGVyL2ZpbHRlci5tb2R1bGUnO1xuXG5leHBvcnQgeyBTa3lJbmZpbml0ZVNjcm9sbE1vZHVsZSB9IGZyb20gJy4vbGliL21vZHVsZXMvaW5maW5pdGUtc2Nyb2xsL2luZmluaXRlLXNjcm9sbC5tb2R1bGUnO1xuXG5leHBvcnQgeyBTa3lQYWdpbmdNb2R1bGUgfSBmcm9tICcuL2xpYi9tb2R1bGVzL3BhZ2luZy9wYWdpbmcubW9kdWxlJztcblxuZXhwb3J0IHsgU2t5UmVwZWF0ZXJFeHBhbmRNb2RlVHlwZSB9IGZyb20gJy4vbGliL21vZHVsZXMvcmVwZWF0ZXIvcmVwZWF0ZXItZXhwYW5kLW1vZGUtdHlwZSc7XG5leHBvcnQgeyBTa3lSZXBlYXRlck1vZHVsZSB9IGZyb20gJy4vbGliL21vZHVsZXMvcmVwZWF0ZXIvcmVwZWF0ZXIubW9kdWxlJztcblxuZXhwb3J0IHsgU2t5U29ydE1vZHVsZSB9IGZyb20gJy4vbGliL21vZHVsZXMvc29ydC9zb3J0Lm1vZHVsZSc7XG5cbi8vIENvbXBvbmVudHMgYW5kIGRpcmVjdGl2ZXMgbXVzdCBiZSBleHBvcnRlZCB0byBzdXBwb3J0IEFuZ3VsYXIncyBcInBhcnRpYWxcIiBJdnkgY29tcGlsZXIuXG4vLyBPYnNjdXJlIG5hbWVzIGFyZSB1c2VkIHRvIGluZGljYXRlIHR5cGVzIGFyZSBub3QgcGFydCBvZiB0aGUgcHVibGljIEFQSS5cbmV4cG9ydCB7IFNreUZpbHRlckJ1dHRvbkNvbXBvbmVudCBhcyDOuzEgfSBmcm9tICcuL2xpYi9tb2R1bGVzL2ZpbHRlci9maWx0ZXItYnV0dG9uLmNvbXBvbmVudCc7XG5leHBvcnQgeyBTa3lGaWx0ZXJJbmxpbmVJdGVtQ29tcG9uZW50IGFzIM67MyB9IGZyb20gJy4vbGliL21vZHVsZXMvZmlsdGVyL2ZpbHRlci1pbmxpbmUtaXRlbS5jb21wb25lbnQnO1xuZXhwb3J0IHsgU2t5RmlsdGVySW5saW5lQ29tcG9uZW50IGFzIM67MiB9IGZyb20gJy4vbGliL21vZHVsZXMvZmlsdGVyL2ZpbHRlci1pbmxpbmUuY29tcG9uZW50JztcbmV4cG9ydCB7IFNreUZpbHRlclN1bW1hcnlJdGVtQ29tcG9uZW50IGFzIM67NCB9IGZyb20gJy4vbGliL21vZHVsZXMvZmlsdGVyL2ZpbHRlci1zdW1tYXJ5LWl0ZW0uY29tcG9uZW50JztcbmV4cG9ydCB7IFNreUZpbHRlclN1bW1hcnlDb21wb25lbnQgYXMgzrs1IH0gZnJvbSAnLi9saWIvbW9kdWxlcy9maWx0ZXIvZmlsdGVyLXN1bW1hcnkuY29tcG9uZW50JztcbmV4cG9ydCB7IFNreUluZmluaXRlU2Nyb2xsQ29tcG9uZW50IGFzIM67NiB9IGZyb20gJy4vbGliL21vZHVsZXMvaW5maW5pdGUtc2Nyb2xsL2luZmluaXRlLXNjcm9sbC5jb21wb25lbnQnO1xuZXhwb3J0IHsgU2t5UGFnaW5nQ29tcG9uZW50IGFzIM67NyB9IGZyb20gJy4vbGliL21vZHVsZXMvcGFnaW5nL3BhZ2luZy5jb21wb25lbnQnO1xuZXhwb3J0IHsgU2t5UmVwZWF0ZXJJdGVtQ29udGVudENvbXBvbmVudCBhcyDOuzggfSBmcm9tICcuL2xpYi9tb2R1bGVzL3JlcGVhdGVyL3JlcGVhdGVyLWl0ZW0tY29udGVudC5jb21wb25lbnQnO1xuZXhwb3J0IHsgU2t5UmVwZWF0ZXJJdGVtQ29udGV4dE1lbnVDb21wb25lbnQgYXMgzrs5IH0gZnJvbSAnLi9saWIvbW9kdWxlcy9yZXBlYXRlci9yZXBlYXRlci1pdGVtLWNvbnRleHQtbWVudS5jb21wb25lbnQnO1xuZXhwb3J0IHsgU2t5UmVwZWF0ZXJJdGVtVGl0bGVDb21wb25lbnQgYXMgzrsxMiB9IGZyb20gJy4vbGliL21vZHVsZXMvcmVwZWF0ZXIvcmVwZWF0ZXItaXRlbS10aXRsZS5jb21wb25lbnQnO1xuZXhwb3J0IHsgU2t5UmVwZWF0ZXJJdGVtQ29tcG9uZW50IGFzIM67MTAgfSBmcm9tICcuL2xpYi9tb2R1bGVzL3JlcGVhdGVyL3JlcGVhdGVyLWl0ZW0uY29tcG9uZW50JztcbmV4cG9ydCB7IFNreVJlcGVhdGVyQ29tcG9uZW50IGFzIM67MTEgfSBmcm9tICcuL2xpYi9tb2R1bGVzL3JlcGVhdGVyL3JlcGVhdGVyLmNvbXBvbmVudCc7XG5leHBvcnQgeyBTa3lTb3J0SXRlbUNvbXBvbmVudCBhcyDOuzEzIH0gZnJvbSAnLi9saWIvbW9kdWxlcy9zb3J0L3NvcnQtaXRlbS5jb21wb25lbnQnO1xuZXhwb3J0IHsgU2t5U29ydENvbXBvbmVudCBhcyDOuzE0IH0gZnJvbSAnLi9saWIvbW9kdWxlcy9zb3J0L3NvcnQuY29tcG9uZW50JztcbiJdfQ==
22
+ export { SkyPagingContentComponent as λ15 } from './lib/modules/paging/paging-content.component';
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbGlzdHMvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUVyRSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxzREFBc0QsQ0FBQztBQUUvRixPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFJckUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sd0NBQXdDLENBQUM7QUFFM0UsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBRS9ELDBGQUEwRjtBQUMxRiwyRUFBMkU7QUFDM0UsT0FBTyxFQUFFLHdCQUF3QixJQUFJLEVBQUUsRUFBRSxNQUFNLDhDQUE4QyxDQUFDO0FBQzlGLE9BQU8sRUFBRSw0QkFBNEIsSUFBSSxFQUFFLEVBQUUsTUFBTSxtREFBbUQsQ0FBQztBQUN2RyxPQUFPLEVBQUUsd0JBQXdCLElBQUksRUFBRSxFQUFFLE1BQU0sOENBQThDLENBQUM7QUFDOUYsT0FBTyxFQUFFLDZCQUE2QixJQUFJLEVBQUUsRUFBRSxNQUFNLG9EQUFvRCxDQUFDO0FBQ3pHLE9BQU8sRUFBRSx5QkFBeUIsSUFBSSxFQUFFLEVBQUUsTUFBTSwrQ0FBK0MsQ0FBQztBQUNoRyxPQUFPLEVBQUUsMEJBQTBCLElBQUksRUFBRSxFQUFFLE1BQU0seURBQXlELENBQUM7QUFDM0csT0FBTyxFQUFFLGtCQUFrQixJQUFJLEVBQUUsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBQ2pGLE9BQU8sRUFBRSwrQkFBK0IsSUFBSSxFQUFFLEVBQUUsTUFBTSx3REFBd0QsQ0FBQztBQUMvRyxPQUFPLEVBQUUsbUNBQW1DLElBQUksRUFBRSxFQUFFLE1BQU0sNkRBQTZELENBQUM7QUFDeEgsT0FBTyxFQUFFLDZCQUE2QixJQUFJLEdBQUcsRUFBRSxNQUFNLHNEQUFzRCxDQUFDO0FBQzVHLE9BQU8sRUFBRSx3QkFBd0IsSUFBSSxHQUFHLEVBQUUsTUFBTSxnREFBZ0QsQ0FBQztBQUNqRyxPQUFPLEVBQUUsb0JBQW9CLElBQUksR0FBRyxFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFDeEYsT0FBTyxFQUFFLG9CQUFvQixJQUFJLEdBQUcsRUFBRSxNQUFNLHdDQUF3QyxDQUFDO0FBQ3JGLE9BQU8sRUFBRSxnQkFBZ0IsSUFBSSxHQUFHLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUM1RSxPQUFPLEVBQUUseUJBQXlCLElBQUksR0FBRyxFQUFFLE1BQU0sK0NBQStDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBTa3lGaWx0ZXJNb2R1bGUgfSBmcm9tICcuL2xpYi9tb2R1bGVzL2ZpbHRlci9maWx0ZXIubW9kdWxlJztcblxuZXhwb3J0IHsgU2t5SW5maW5pdGVTY3JvbGxNb2R1bGUgfSBmcm9tICcuL2xpYi9tb2R1bGVzL2luZmluaXRlLXNjcm9sbC9pbmZpbml0ZS1zY3JvbGwubW9kdWxlJztcblxuZXhwb3J0IHsgU2t5UGFnaW5nTW9kdWxlIH0gZnJvbSAnLi9saWIvbW9kdWxlcy9wYWdpbmcvcGFnaW5nLm1vZHVsZSc7XG5leHBvcnQgeyBTa3lQYWdpbmdDb250ZW50Q2hhbmdlQXJncyB9IGZyb20gJy4vbGliL21vZHVsZXMvcGFnaW5nL3R5cGVzL3BhZ2luZy1jb250ZW50LWNoYW5nZS1hcmdzJztcblxuZXhwb3J0IHsgU2t5UmVwZWF0ZXJFeHBhbmRNb2RlVHlwZSB9IGZyb20gJy4vbGliL21vZHVsZXMvcmVwZWF0ZXIvcmVwZWF0ZXItZXhwYW5kLW1vZGUtdHlwZSc7XG5leHBvcnQgeyBTa3lSZXBlYXRlck1vZHVsZSB9IGZyb20gJy4vbGliL21vZHVsZXMvcmVwZWF0ZXIvcmVwZWF0ZXIubW9kdWxlJztcblxuZXhwb3J0IHsgU2t5U29ydE1vZHVsZSB9IGZyb20gJy4vbGliL21vZHVsZXMvc29ydC9zb3J0Lm1vZHVsZSc7XG5cbi8vIENvbXBvbmVudHMgYW5kIGRpcmVjdGl2ZXMgbXVzdCBiZSBleHBvcnRlZCB0byBzdXBwb3J0IEFuZ3VsYXIncyBcInBhcnRpYWxcIiBJdnkgY29tcGlsZXIuXG4vLyBPYnNjdXJlIG5hbWVzIGFyZSB1c2VkIHRvIGluZGljYXRlIHR5cGVzIGFyZSBub3QgcGFydCBvZiB0aGUgcHVibGljIEFQSS5cbmV4cG9ydCB7IFNreUZpbHRlckJ1dHRvbkNvbXBvbmVudCBhcyDOuzEgfSBmcm9tICcuL2xpYi9tb2R1bGVzL2ZpbHRlci9maWx0ZXItYnV0dG9uLmNvbXBvbmVudCc7XG5leHBvcnQgeyBTa3lGaWx0ZXJJbmxpbmVJdGVtQ29tcG9uZW50IGFzIM67MyB9IGZyb20gJy4vbGliL21vZHVsZXMvZmlsdGVyL2ZpbHRlci1pbmxpbmUtaXRlbS5jb21wb25lbnQnO1xuZXhwb3J0IHsgU2t5RmlsdGVySW5saW5lQ29tcG9uZW50IGFzIM67MiB9IGZyb20gJy4vbGliL21vZHVsZXMvZmlsdGVyL2ZpbHRlci1pbmxpbmUuY29tcG9uZW50JztcbmV4cG9ydCB7IFNreUZpbHRlclN1bW1hcnlJdGVtQ29tcG9uZW50IGFzIM67NCB9IGZyb20gJy4vbGliL21vZHVsZXMvZmlsdGVyL2ZpbHRlci1zdW1tYXJ5LWl0ZW0uY29tcG9uZW50JztcbmV4cG9ydCB7IFNreUZpbHRlclN1bW1hcnlDb21wb25lbnQgYXMgzrs1IH0gZnJvbSAnLi9saWIvbW9kdWxlcy9maWx0ZXIvZmlsdGVyLXN1bW1hcnkuY29tcG9uZW50JztcbmV4cG9ydCB7IFNreUluZmluaXRlU2Nyb2xsQ29tcG9uZW50IGFzIM67NiB9IGZyb20gJy4vbGliL21vZHVsZXMvaW5maW5pdGUtc2Nyb2xsL2luZmluaXRlLXNjcm9sbC5jb21wb25lbnQnO1xuZXhwb3J0IHsgU2t5UGFnaW5nQ29tcG9uZW50IGFzIM67NyB9IGZyb20gJy4vbGliL21vZHVsZXMvcGFnaW5nL3BhZ2luZy5jb21wb25lbnQnO1xuZXhwb3J0IHsgU2t5UmVwZWF0ZXJJdGVtQ29udGVudENvbXBvbmVudCBhcyDOuzggfSBmcm9tICcuL2xpYi9tb2R1bGVzL3JlcGVhdGVyL3JlcGVhdGVyLWl0ZW0tY29udGVudC5jb21wb25lbnQnO1xuZXhwb3J0IHsgU2t5UmVwZWF0ZXJJdGVtQ29udGV4dE1lbnVDb21wb25lbnQgYXMgzrs5IH0gZnJvbSAnLi9saWIvbW9kdWxlcy9yZXBlYXRlci9yZXBlYXRlci1pdGVtLWNvbnRleHQtbWVudS5jb21wb25lbnQnO1xuZXhwb3J0IHsgU2t5UmVwZWF0ZXJJdGVtVGl0bGVDb21wb25lbnQgYXMgzrsxMiB9IGZyb20gJy4vbGliL21vZHVsZXMvcmVwZWF0ZXIvcmVwZWF0ZXItaXRlbS10aXRsZS5jb21wb25lbnQnO1xuZXhwb3J0IHsgU2t5UmVwZWF0ZXJJdGVtQ29tcG9uZW50IGFzIM67MTAgfSBmcm9tICcuL2xpYi9tb2R1bGVzL3JlcGVhdGVyL3JlcGVhdGVyLWl0ZW0uY29tcG9uZW50JztcbmV4cG9ydCB7IFNreVJlcGVhdGVyQ29tcG9uZW50IGFzIM67MTEgfSBmcm9tICcuL2xpYi9tb2R1bGVzL3JlcGVhdGVyL3JlcGVhdGVyLmNvbXBvbmVudCc7XG5leHBvcnQgeyBTa3lTb3J0SXRlbUNvbXBvbmVudCBhcyDOuzEzIH0gZnJvbSAnLi9saWIvbW9kdWxlcy9zb3J0L3NvcnQtaXRlbS5jb21wb25lbnQnO1xuZXhwb3J0IHsgU2t5U29ydENvbXBvbmVudCBhcyDOuzE0IH0gZnJvbSAnLi9saWIvbW9kdWxlcy9zb3J0L3NvcnQuY29tcG9uZW50JztcbmV4cG9ydCB7IFNreVBhZ2luZ0NvbnRlbnRDb21wb25lbnQgYXMgzrsxNSB9IGZyb20gJy4vbGliL21vZHVsZXMvcGFnaW5nL3BhZ2luZy1jb250ZW50LmNvbXBvbmVudCc7XG4iXX0=
@@ -0,0 +1,17 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { Component } from '@angular/core';
3
+ import * as i0 from "@angular/core";
4
+ export class SkyPagingContentComponent {
5
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyPagingContentComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
6
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.9", type: SkyPagingContentComponent, isStandalone: true, selector: "sky-paging-content", ngImport: i0, template: `<ng-content />`, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }] }); }
7
+ }
8
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyPagingContentComponent, decorators: [{
9
+ type: Component,
10
+ args: [{
11
+ standalone: true,
12
+ imports: [CommonModule],
13
+ selector: 'sky-paging-content',
14
+ template: `<ng-content />`,
15
+ }]
16
+ }] });
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnaW5nLWNvbnRlbnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2xpc3RzL3NyYy9saWIvbW9kdWxlcy9wYWdpbmcvcGFnaW5nLWNvbnRlbnQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQVExQyxNQUFNLE9BQU8seUJBQXlCOzhHQUF6Qix5QkFBeUI7a0dBQXpCLHlCQUF5Qiw4RUFGMUIsZ0JBQWdCLDJEQUZoQixZQUFZOzsyRkFJWCx5QkFBeUI7a0JBTnJDLFNBQVM7bUJBQUM7b0JBQ1QsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLE9BQU8sRUFBRSxDQUFDLFlBQVksQ0FBQztvQkFDdkIsUUFBUSxFQUFFLG9CQUFvQjtvQkFDOUIsUUFBUSxFQUFFLGdCQUFnQjtpQkFDM0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcbiAgc2VsZWN0b3I6ICdza3ktcGFnaW5nLWNvbnRlbnQnLFxuICB0ZW1wbGF0ZTogYDxuZy1jb250ZW50IC8+YCxcbn0pXG5leHBvcnQgY2xhc3MgU2t5UGFnaW5nQ29udGVudENvbXBvbmVudCB7fVxuIl19
@@ -1,4 +1,5 @@
1
- import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, } from '@angular/core';
1
+ import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
2
+ import { BehaviorSubject } from 'rxjs';
2
3
  import * as i0 from "@angular/core";
3
4
  import * as i1 from "@angular/common";
4
5
  import * as i2 from "@skyux/indicators";
@@ -26,13 +27,22 @@ export class SkyPagingComponent {
26
27
  * Fires when the current page changes and emits the new current page.
27
28
  */
28
29
  this.currentPageChange = new EventEmitter();
30
+ /**
31
+ * Fires when the current page changes and emits the new current page with a function
32
+ * to call when loading the new page completes. Handling this event will display the
33
+ * wait component until the callback function is called, and focus will move to the top
34
+ * of the list for keyboard navigation if the list contents are placed inside the
35
+ * sky-paging-content element.
36
+ */
37
+ this.contentChange = new EventEmitter();
29
38
  this.displayedPages = [];
30
39
  this.pageCount = 0;
40
+ this.isLoading = new BehaviorSubject(false);
31
41
  }
32
42
  ngOnChanges(changes) {
33
- this.setPage(this.currentPage);
43
+ this.setPage(this.currentPage, changes['currentPage']?.isFirstChange());
34
44
  }
35
- setPage(pageNumber) {
45
+ setPage(pageNumber, forceContentChange) {
36
46
  const previousPage = this.currentPage;
37
47
  this.#setPageCount();
38
48
  if (pageNumber < 1 || this.pageCount < 1) {
@@ -45,8 +55,18 @@ export class SkyPagingComponent {
45
55
  this.currentPage = pageNumber;
46
56
  }
47
57
  this.#setDisplayedPages();
58
+ let doContentChange = forceContentChange;
48
59
  if (previousPage !== this.currentPage) {
49
60
  this.currentPageChange.emit(this.currentPage);
61
+ doContentChange = true;
62
+ }
63
+ if (doContentChange && this.contentChange.observed) {
64
+ this.#moveFocusToTop();
65
+ this.isLoading.next(true);
66
+ this.contentChange.emit({
67
+ currentPage: this.currentPage,
68
+ loadingComplete: () => this.isLoading.next(false),
69
+ });
50
70
  }
51
71
  }
52
72
  nextPage() {
@@ -100,12 +120,15 @@ export class SkyPagingComponent {
100
120
  #setDisplayedPages() {
101
121
  this.displayedPages = this.#getDisplayedPageNumbers(this.pageCount, this.maxPages, this.currentPage);
102
122
  }
123
+ #moveFocusToTop() {
124
+ this.contentWrapper?.nativeElement.focus();
125
+ }
103
126
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyPagingComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
104
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.9", type: SkyPagingComponent, selector: "sky-paging", inputs: { currentPage: "currentPage", itemCount: "itemCount", maxPages: "maxPages", pageSize: "pageSize", pagingLabel: "pagingLabel" }, outputs: { currentPageChange: "currentPageChange" }, usesOnChanges: true, ngImport: i0, template: "<nav\n *ngIf=\"pageCount > 1\"\n class=\"sky-paging\"\n [attr.aria-label]=\"pagingLabel || ('skyux_paging_label' | skyLibResources)\"\n>\n <ul>\n <li>\n <button\n class=\"sky-btn sky-btn-default sky-paging-btn sky-paging-btn-previous sky-box\"\n sky-cmp-id=\"previous\"\n type=\"button\"\n [attr.aria-label]=\"'skyux_paging_previous' | skyLibResources\"\n [disabled]=\"isPreviousButtonDisabled\"\n (click)=\"previousPage()\"\n >\n <sky-icon *skyThemeIf=\"'default'\" icon=\"caret-left\" />\n <sky-icon *skyThemeIf=\"'modern'\" icon=\"chevron-left\" />\n </button>\n </li>\n <li *ngFor=\"let pageNumber of displayedPages\" class=\"sky-list-paging-link\">\n <button\n class=\"sky-btn sky-btn-default sky-paging-btn sky-box\"\n type=\"button\"\n [attr.aria-current]=\"currentPage === pageNumber ? 'page' : null\"\n [attr.sky-cmp-id]=\"pageNumber\"\n [attr.aria-label]=\"\n 'skyux_paging_page_link_aria_label' | skyLibResources : pageNumber\n \"\n [disabled]=\"currentPage === pageNumber\"\n [ngClass]=\"{ 'sky-paging-current': currentPage === pageNumber }\"\n (click)=\"setPage(pageNumber)\"\n >\n {{ pageNumber }}\n </button>\n </li>\n <li>\n <button\n class=\"sky-btn sky-btn-default sky-paging-btn sky-paging-btn-next sky-box\"\n sky-cmp-id=\"next\"\n type=\"button\"\n [attr.aria-label]=\"'skyux_paging_next' | skyLibResources\"\n [disabled]=\"isNextButtonDisabled\"\n (click)=\"nextPage()\"\n >\n <sky-icon *skyThemeIf=\"'default'\" icon=\"caret-right\" />\n <sky-icon *skyThemeIf=\"'modern'\" icon=\"chevron-right\" />\n </button>\n </li>\n </ul>\n</nav>\n", styles: [":host{display:block}ul{margin:15px 0 0;display:inline-block;padding-left:0;border-radius:4px}li{display:inline}.sky-paging-btn{border-top:1px solid #e2e3e4;border-right:1px solid #e2e3e4;border-bottom:1px solid #e2e3e4;border-left:1px solid #e2e3e4;border-radius:0;background-color:#fff;color:inherit;float:left;margin-left:-1px;padding:4px 10px;text-decoration:none;line-height:1.428571429;font-size:15px;cursor:pointer}.sky-paging-btn.sky-paging-caret{transform:none}.sky-paging-btn.sky-paging-current,.sky-paging-btn.sky-paging-current:disabled,.sky-paging-btn.sky-paging-current[disabled]{background-color:#eeeeef;cursor:default;color:inherit;opacity:1}.sky-paging-btn:hover{background-color:#d4d4d6}.sky-paging-btn:disabled{color:#686c73;cursor:not-allowed;pointer-events:none}.sky-paging-btn.sky-paging-btn-previous,.sky-paging-btn.sky-paging-btn-next{padding-left:8.5px;padding-right:8.5px}:host-context(.sky-theme-modern) .sky-paging-btn{background-color:transparent;border:none;box-shadow:none;border-radius:6px;margin-right:10px;padding:3px 10px}:host-context(.sky-theme-modern) .sky-paging-btn:hover{background-color:transparent;border:solid 1px #1870B8;padding:2px 9px;z-index:1}:host-context(.sky-theme-modern) .sky-paging-btn:active,:host-context(.sky-theme-modern) .sky-paging-btn:focus{border:solid 2px #1870B8;color:#212327;padding:1px 8px}:host-context(.sky-theme-modern) .sky-paging-btn:focus:not(:active){outline:none;box-shadow:0 1px 3px #0000004d}:host-context(.sky-theme-modern) .sky-paging-current{background-color:var(--sky-background-color-item-selected);border:solid 1px #1870B8;padding:2px 9px}.sky-theme-modern .sky-paging-btn{background-color:transparent;border:none;box-shadow:none;border-radius:6px;margin-right:10px;padding:3px 10px}.sky-theme-modern .sky-paging-btn:hover{background-color:transparent;border:solid 1px #1870B8;padding:2px 9px;z-index:1}.sky-theme-modern .sky-paging-btn:active,.sky-theme-modern .sky-paging-btn:focus{border:solid 2px #1870B8;color:#212327;padding:1px 8px}.sky-theme-modern .sky-paging-btn:focus:not(:active){outline:none;box-shadow:0 1px 3px #0000004d}.sky-theme-modern .sky-paging-current{background-color:var(--sky-background-color-item-selected);border:solid 1px #1870B8;padding:2px 9px}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-paging-btn:active,:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-paging-btn:focus{color:#fbfcfe}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-paging-current{background-color:#1870b8}.sky-theme-modern.sky-theme-mode-dark .sky-paging-btn:active,.sky-theme-modern.sky-theme-mode-dark .sky-paging-btn:focus{color:#fbfcfe}.sky-theme-modern.sky-theme-mode-dark .sky-paging-current{background-color:#1870b8}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.λ4, selector: "sky-icon", inputs: ["icon", "iconType", "size", "fixedWidth", "variant"] }, { kind: "directive", type: i3.λ3, selector: "[skyThemeIf]", inputs: ["skyThemeIf"] }, { kind: "pipe", type: i4.SkyLibResourcesPipe, name: "skyLibResources" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
127
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.9", type: SkyPagingComponent, selector: "sky-paging", inputs: { currentPage: "currentPage", itemCount: "itemCount", maxPages: "maxPages", pageSize: "pageSize", pagingLabel: "pagingLabel" }, outputs: { currentPageChange: "currentPageChange", contentChange: "contentChange" }, viewQueries: [{ propertyName: "contentWrapper", first: true, predicate: ["contentWrapper"], descendants: true, read: ElementRef }], usesOnChanges: true, ngImport: i0, template: "<sky-wait\n [ariaLabel]=\"\n 'skyux_paging_loading' | skyLibResources : currentPage : pageCount\n \"\n [isWaiting]=\"!!(isLoading | async)\"\n [screenReaderCompletedText]=\"\n 'skyux_paging_loaded' | skyLibResources : currentPage\n \"\n/>\n<div\n class=\"sky-paging-content-wrapper\"\n role=\"group\"\n tabindex=\"-1\"\n [attr.aria-label]=\"\n 'skyux_paging_page_label' | skyLibResources : currentPage : pageCount\n \"\n #contentWrapper\n>\n <ng-content select=\"sky-paging-content\" />\n</div>\n<nav\n *ngIf=\"pageCount > 1\"\n class=\"sky-paging\"\n [attr.aria-label]=\"pagingLabel || ('skyux_paging_label' | skyLibResources)\"\n>\n <ul>\n <li>\n <button\n class=\"sky-btn sky-btn-default sky-paging-btn sky-paging-btn-previous sky-box\"\n sky-cmp-id=\"previous\"\n type=\"button\"\n [attr.aria-label]=\"'skyux_paging_previous' | skyLibResources\"\n [disabled]=\"isPreviousButtonDisabled\"\n (click)=\"previousPage()\"\n >\n <sky-icon *skyThemeIf=\"'default'\" icon=\"caret-left\" />\n <sky-icon *skyThemeIf=\"'modern'\" icon=\"chevron-left\" />\n </button>\n </li>\n <li *ngFor=\"let pageNumber of displayedPages\" class=\"sky-list-paging-link\">\n <button\n class=\"sky-btn sky-btn-default sky-paging-btn sky-box\"\n type=\"button\"\n [attr.aria-current]=\"currentPage === pageNumber ? 'page' : null\"\n [attr.sky-cmp-id]=\"pageNumber\"\n [attr.aria-label]=\"\n 'skyux_paging_page_link_aria_label' | skyLibResources : pageNumber\n \"\n [disabled]=\"currentPage === pageNumber\"\n [ngClass]=\"{ 'sky-paging-current': currentPage === pageNumber }\"\n (click)=\"setPage(pageNumber)\"\n >\n {{ pageNumber }}\n </button>\n </li>\n <li>\n <button\n class=\"sky-btn sky-btn-default sky-paging-btn sky-paging-btn-next sky-box\"\n sky-cmp-id=\"next\"\n type=\"button\"\n [attr.aria-label]=\"'skyux_paging_next' | skyLibResources\"\n [disabled]=\"isNextButtonDisabled\"\n (click)=\"nextPage()\"\n >\n <sky-icon *skyThemeIf=\"'default'\" icon=\"caret-right\" />\n <sky-icon *skyThemeIf=\"'modern'\" icon=\"chevron-right\" />\n </button>\n </li>\n </ul>\n</nav>\n", styles: [":host{display:block}.sky-paging-content-wrapper{display:none}.sky-paging-content-wrapper:not(:empty){display:block;margin-bottom:var(--sky-margin-stacked-lg)}.sky-paging-content-wrapper:focus-visible{outline:none;border:none}ul{margin:15px 0 0;display:inline-block;padding-left:0;border-radius:4px}li{display:inline}.sky-paging-btn{border-top:1px solid #e2e3e4;border-right:1px solid #e2e3e4;border-bottom:1px solid #e2e3e4;border-left:1px solid #e2e3e4;border-radius:0;background-color:#fff;color:inherit;float:left;margin-left:-1px;padding:4px 10px;text-decoration:none;line-height:1.428571429;font-size:15px;cursor:pointer}.sky-paging-btn.sky-paging-caret{transform:none}.sky-paging-btn.sky-paging-current,.sky-paging-btn.sky-paging-current:disabled,.sky-paging-btn.sky-paging-current[disabled]{background-color:#eeeeef;cursor:default;color:inherit;opacity:1}.sky-paging-btn:hover{background-color:#d4d4d6}.sky-paging-btn:disabled{color:#686c73;cursor:not-allowed;pointer-events:none}.sky-paging-btn.sky-paging-btn-previous,.sky-paging-btn.sky-paging-btn-next{padding-left:8.5px;padding-right:8.5px}:host-context(.sky-theme-modern) .sky-paging-btn{background-color:transparent;border:none;box-shadow:none;border-radius:6px;margin-right:10px;padding:3px 10px}:host-context(.sky-theme-modern) .sky-paging-btn:hover{background-color:transparent;border:solid 1px #1870B8;padding:2px 9px;z-index:1}:host-context(.sky-theme-modern) .sky-paging-btn:active,:host-context(.sky-theme-modern) .sky-paging-btn:focus{border:solid 2px #1870B8;color:#212327;padding:1px 8px}:host-context(.sky-theme-modern) .sky-paging-btn:focus:not(:active){outline:none;box-shadow:0 1px 3px #0000004d}:host-context(.sky-theme-modern) .sky-paging-current{background-color:var(--sky-background-color-item-selected);border:solid 1px #1870B8;padding:2px 9px}.sky-theme-modern .sky-paging-btn{background-color:transparent;border:none;box-shadow:none;border-radius:6px;margin-right:10px;padding:3px 10px}.sky-theme-modern .sky-paging-btn:hover{background-color:transparent;border:solid 1px #1870B8;padding:2px 9px;z-index:1}.sky-theme-modern .sky-paging-btn:active,.sky-theme-modern .sky-paging-btn:focus{border:solid 2px #1870B8;color:#212327;padding:1px 8px}.sky-theme-modern .sky-paging-btn:focus:not(:active){outline:none;box-shadow:0 1px 3px #0000004d}.sky-theme-modern .sky-paging-current{background-color:var(--sky-background-color-item-selected);border:solid 1px #1870B8;padding:2px 9px}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-paging-btn:active,:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-paging-btn:focus{color:#fbfcfe}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-paging-current{background-color:#1870b8}.sky-theme-modern.sky-theme-mode-dark .sky-paging-btn:active,.sky-theme-modern.sky-theme-mode-dark .sky-paging-btn:focus{color:#fbfcfe}.sky-theme-modern.sky-theme-mode-dark .sky-paging-current{background-color:#1870b8}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.λ4, selector: "sky-icon", inputs: ["icon", "iconType", "size", "fixedWidth", "variant"] }, { kind: "directive", type: i3.λ3, selector: "[skyThemeIf]", inputs: ["skyThemeIf"] }, { kind: "component", type: i2.λ14, selector: "sky-wait", inputs: ["ariaLabel", "isWaiting", "isFullPage", "isNonBlocking", "screenReaderCompletedText"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.SkyLibResourcesPipe, name: "skyLibResources" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
105
128
  }
106
129
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyPagingComponent, decorators: [{
107
130
  type: Component,
108
- args: [{ selector: 'sky-paging', changeDetection: ChangeDetectionStrategy.OnPush, template: "<nav\n *ngIf=\"pageCount > 1\"\n class=\"sky-paging\"\n [attr.aria-label]=\"pagingLabel || ('skyux_paging_label' | skyLibResources)\"\n>\n <ul>\n <li>\n <button\n class=\"sky-btn sky-btn-default sky-paging-btn sky-paging-btn-previous sky-box\"\n sky-cmp-id=\"previous\"\n type=\"button\"\n [attr.aria-label]=\"'skyux_paging_previous' | skyLibResources\"\n [disabled]=\"isPreviousButtonDisabled\"\n (click)=\"previousPage()\"\n >\n <sky-icon *skyThemeIf=\"'default'\" icon=\"caret-left\" />\n <sky-icon *skyThemeIf=\"'modern'\" icon=\"chevron-left\" />\n </button>\n </li>\n <li *ngFor=\"let pageNumber of displayedPages\" class=\"sky-list-paging-link\">\n <button\n class=\"sky-btn sky-btn-default sky-paging-btn sky-box\"\n type=\"button\"\n [attr.aria-current]=\"currentPage === pageNumber ? 'page' : null\"\n [attr.sky-cmp-id]=\"pageNumber\"\n [attr.aria-label]=\"\n 'skyux_paging_page_link_aria_label' | skyLibResources : pageNumber\n \"\n [disabled]=\"currentPage === pageNumber\"\n [ngClass]=\"{ 'sky-paging-current': currentPage === pageNumber }\"\n (click)=\"setPage(pageNumber)\"\n >\n {{ pageNumber }}\n </button>\n </li>\n <li>\n <button\n class=\"sky-btn sky-btn-default sky-paging-btn sky-paging-btn-next sky-box\"\n sky-cmp-id=\"next\"\n type=\"button\"\n [attr.aria-label]=\"'skyux_paging_next' | skyLibResources\"\n [disabled]=\"isNextButtonDisabled\"\n (click)=\"nextPage()\"\n >\n <sky-icon *skyThemeIf=\"'default'\" icon=\"caret-right\" />\n <sky-icon *skyThemeIf=\"'modern'\" icon=\"chevron-right\" />\n </button>\n </li>\n </ul>\n</nav>\n", styles: [":host{display:block}ul{margin:15px 0 0;display:inline-block;padding-left:0;border-radius:4px}li{display:inline}.sky-paging-btn{border-top:1px solid #e2e3e4;border-right:1px solid #e2e3e4;border-bottom:1px solid #e2e3e4;border-left:1px solid #e2e3e4;border-radius:0;background-color:#fff;color:inherit;float:left;margin-left:-1px;padding:4px 10px;text-decoration:none;line-height:1.428571429;font-size:15px;cursor:pointer}.sky-paging-btn.sky-paging-caret{transform:none}.sky-paging-btn.sky-paging-current,.sky-paging-btn.sky-paging-current:disabled,.sky-paging-btn.sky-paging-current[disabled]{background-color:#eeeeef;cursor:default;color:inherit;opacity:1}.sky-paging-btn:hover{background-color:#d4d4d6}.sky-paging-btn:disabled{color:#686c73;cursor:not-allowed;pointer-events:none}.sky-paging-btn.sky-paging-btn-previous,.sky-paging-btn.sky-paging-btn-next{padding-left:8.5px;padding-right:8.5px}:host-context(.sky-theme-modern) .sky-paging-btn{background-color:transparent;border:none;box-shadow:none;border-radius:6px;margin-right:10px;padding:3px 10px}:host-context(.sky-theme-modern) .sky-paging-btn:hover{background-color:transparent;border:solid 1px #1870B8;padding:2px 9px;z-index:1}:host-context(.sky-theme-modern) .sky-paging-btn:active,:host-context(.sky-theme-modern) .sky-paging-btn:focus{border:solid 2px #1870B8;color:#212327;padding:1px 8px}:host-context(.sky-theme-modern) .sky-paging-btn:focus:not(:active){outline:none;box-shadow:0 1px 3px #0000004d}:host-context(.sky-theme-modern) .sky-paging-current{background-color:var(--sky-background-color-item-selected);border:solid 1px #1870B8;padding:2px 9px}.sky-theme-modern .sky-paging-btn{background-color:transparent;border:none;box-shadow:none;border-radius:6px;margin-right:10px;padding:3px 10px}.sky-theme-modern .sky-paging-btn:hover{background-color:transparent;border:solid 1px #1870B8;padding:2px 9px;z-index:1}.sky-theme-modern .sky-paging-btn:active,.sky-theme-modern .sky-paging-btn:focus{border:solid 2px #1870B8;color:#212327;padding:1px 8px}.sky-theme-modern .sky-paging-btn:focus:not(:active){outline:none;box-shadow:0 1px 3px #0000004d}.sky-theme-modern .sky-paging-current{background-color:var(--sky-background-color-item-selected);border:solid 1px #1870B8;padding:2px 9px}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-paging-btn:active,:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-paging-btn:focus{color:#fbfcfe}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-paging-current{background-color:#1870b8}.sky-theme-modern.sky-theme-mode-dark .sky-paging-btn:active,.sky-theme-modern.sky-theme-mode-dark .sky-paging-btn:focus{color:#fbfcfe}.sky-theme-modern.sky-theme-mode-dark .sky-paging-current{background-color:#1870b8}\n"] }]
131
+ args: [{ selector: 'sky-paging', changeDetection: ChangeDetectionStrategy.OnPush, template: "<sky-wait\n [ariaLabel]=\"\n 'skyux_paging_loading' | skyLibResources : currentPage : pageCount\n \"\n [isWaiting]=\"!!(isLoading | async)\"\n [screenReaderCompletedText]=\"\n 'skyux_paging_loaded' | skyLibResources : currentPage\n \"\n/>\n<div\n class=\"sky-paging-content-wrapper\"\n role=\"group\"\n tabindex=\"-1\"\n [attr.aria-label]=\"\n 'skyux_paging_page_label' | skyLibResources : currentPage : pageCount\n \"\n #contentWrapper\n>\n <ng-content select=\"sky-paging-content\" />\n</div>\n<nav\n *ngIf=\"pageCount > 1\"\n class=\"sky-paging\"\n [attr.aria-label]=\"pagingLabel || ('skyux_paging_label' | skyLibResources)\"\n>\n <ul>\n <li>\n <button\n class=\"sky-btn sky-btn-default sky-paging-btn sky-paging-btn-previous sky-box\"\n sky-cmp-id=\"previous\"\n type=\"button\"\n [attr.aria-label]=\"'skyux_paging_previous' | skyLibResources\"\n [disabled]=\"isPreviousButtonDisabled\"\n (click)=\"previousPage()\"\n >\n <sky-icon *skyThemeIf=\"'default'\" icon=\"caret-left\" />\n <sky-icon *skyThemeIf=\"'modern'\" icon=\"chevron-left\" />\n </button>\n </li>\n <li *ngFor=\"let pageNumber of displayedPages\" class=\"sky-list-paging-link\">\n <button\n class=\"sky-btn sky-btn-default sky-paging-btn sky-box\"\n type=\"button\"\n [attr.aria-current]=\"currentPage === pageNumber ? 'page' : null\"\n [attr.sky-cmp-id]=\"pageNumber\"\n [attr.aria-label]=\"\n 'skyux_paging_page_link_aria_label' | skyLibResources : pageNumber\n \"\n [disabled]=\"currentPage === pageNumber\"\n [ngClass]=\"{ 'sky-paging-current': currentPage === pageNumber }\"\n (click)=\"setPage(pageNumber)\"\n >\n {{ pageNumber }}\n </button>\n </li>\n <li>\n <button\n class=\"sky-btn sky-btn-default sky-paging-btn sky-paging-btn-next sky-box\"\n sky-cmp-id=\"next\"\n type=\"button\"\n [attr.aria-label]=\"'skyux_paging_next' | skyLibResources\"\n [disabled]=\"isNextButtonDisabled\"\n (click)=\"nextPage()\"\n >\n <sky-icon *skyThemeIf=\"'default'\" icon=\"caret-right\" />\n <sky-icon *skyThemeIf=\"'modern'\" icon=\"chevron-right\" />\n </button>\n </li>\n </ul>\n</nav>\n", styles: [":host{display:block}.sky-paging-content-wrapper{display:none}.sky-paging-content-wrapper:not(:empty){display:block;margin-bottom:var(--sky-margin-stacked-lg)}.sky-paging-content-wrapper:focus-visible{outline:none;border:none}ul{margin:15px 0 0;display:inline-block;padding-left:0;border-radius:4px}li{display:inline}.sky-paging-btn{border-top:1px solid #e2e3e4;border-right:1px solid #e2e3e4;border-bottom:1px solid #e2e3e4;border-left:1px solid #e2e3e4;border-radius:0;background-color:#fff;color:inherit;float:left;margin-left:-1px;padding:4px 10px;text-decoration:none;line-height:1.428571429;font-size:15px;cursor:pointer}.sky-paging-btn.sky-paging-caret{transform:none}.sky-paging-btn.sky-paging-current,.sky-paging-btn.sky-paging-current:disabled,.sky-paging-btn.sky-paging-current[disabled]{background-color:#eeeeef;cursor:default;color:inherit;opacity:1}.sky-paging-btn:hover{background-color:#d4d4d6}.sky-paging-btn:disabled{color:#686c73;cursor:not-allowed;pointer-events:none}.sky-paging-btn.sky-paging-btn-previous,.sky-paging-btn.sky-paging-btn-next{padding-left:8.5px;padding-right:8.5px}:host-context(.sky-theme-modern) .sky-paging-btn{background-color:transparent;border:none;box-shadow:none;border-radius:6px;margin-right:10px;padding:3px 10px}:host-context(.sky-theme-modern) .sky-paging-btn:hover{background-color:transparent;border:solid 1px #1870B8;padding:2px 9px;z-index:1}:host-context(.sky-theme-modern) .sky-paging-btn:active,:host-context(.sky-theme-modern) .sky-paging-btn:focus{border:solid 2px #1870B8;color:#212327;padding:1px 8px}:host-context(.sky-theme-modern) .sky-paging-btn:focus:not(:active){outline:none;box-shadow:0 1px 3px #0000004d}:host-context(.sky-theme-modern) .sky-paging-current{background-color:var(--sky-background-color-item-selected);border:solid 1px #1870B8;padding:2px 9px}.sky-theme-modern .sky-paging-btn{background-color:transparent;border:none;box-shadow:none;border-radius:6px;margin-right:10px;padding:3px 10px}.sky-theme-modern .sky-paging-btn:hover{background-color:transparent;border:solid 1px #1870B8;padding:2px 9px;z-index:1}.sky-theme-modern .sky-paging-btn:active,.sky-theme-modern .sky-paging-btn:focus{border:solid 2px #1870B8;color:#212327;padding:1px 8px}.sky-theme-modern .sky-paging-btn:focus:not(:active){outline:none;box-shadow:0 1px 3px #0000004d}.sky-theme-modern .sky-paging-current{background-color:var(--sky-background-color-item-selected);border:solid 1px #1870B8;padding:2px 9px}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-paging-btn:active,:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-paging-btn:focus{color:#fbfcfe}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-paging-current{background-color:#1870b8}.sky-theme-modern.sky-theme-mode-dark .sky-paging-btn:active,.sky-theme-modern.sky-theme-mode-dark .sky-paging-btn:focus{color:#fbfcfe}.sky-theme-modern.sky-theme-mode-dark .sky-paging-current{background-color:#1870b8}\n"] }]
109
132
  }], propDecorators: { currentPage: [{
110
133
  type: Input
111
134
  }], itemCount: [{
@@ -118,5 +141,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.9", ngImpor
118
141
  type: Input
119
142
  }], currentPageChange: [{
120
143
  type: Output
144
+ }], contentChange: [{
145
+ type: Output
146
+ }], contentWrapper: [{
147
+ type: ViewChild,
148
+ args: ['contentWrapper', { read: ElementRef }]
121
149
  }] } });
122
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"paging.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/lists/src/lib/modules/paging/paging.component.ts","../../../../../../../../libs/components/lists/src/lib/modules/paging/paging.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  Output,\n  SimpleChanges,\n} from '@angular/core';\n\n@Component({\n  selector: 'sky-paging',\n  templateUrl: './paging.component.html',\n  styleUrls: ['./paging.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SkyPagingComponent implements OnChanges {\n  /**\n   * The page number of the current page. Page numbers start at 1 and increment.\n   */\n  @Input()\n  public currentPage = 1;\n\n  /**\n   * The total number of items across all pages.\n   */\n  @Input()\n  public itemCount = 0;\n\n  /**\n   * The maximum number of pages to display in the pagination control.\n   */\n  @Input()\n  public maxPages = 5;\n\n  /**\n   * The number of items to display per page.\n   */\n  @Input()\n  public pageSize = 10;\n\n  /**\n   * The label for the pagination control when an application includes\n   * multiple paging components on the same page. The label should be unique and descriptive\n   * to help users of assistive technology differentiate pagination controls\n   * and understand what each one does.\n   * @default \"Pagination\"\n   */\n  @Input()\n  public pagingLabel: string | undefined;\n\n  /**\n   * Fires when the current page changes and emits the new current page.\n   */\n  @Output()\n  public currentPageChange: EventEmitter<number> = new EventEmitter<number>();\n\n  public displayedPages: Array<number> = [];\n\n  public pageCount = 0;\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    this.setPage(this.currentPage);\n  }\n\n  public setPage(pageNumber: number): void {\n    const previousPage = this.currentPage;\n\n    this.#setPageCount();\n\n    if (pageNumber < 1 || this.pageCount < 1) {\n      this.currentPage = 1;\n    } else if (pageNumber > this.pageCount) {\n      this.currentPage = this.pageCount;\n    } else {\n      this.currentPage = pageNumber;\n    }\n\n    this.#setDisplayedPages();\n\n    if (previousPage !== this.currentPage) {\n      this.currentPageChange.emit(this.currentPage);\n    }\n  }\n\n  public nextPage(): void {\n    this.setPage(this.currentPage + 1);\n  }\n\n  public previousPage(): void {\n    this.setPage(this.currentPage - 1);\n  }\n\n  public get isPreviousButtonDisabled(): boolean {\n    return this.currentPage === 1;\n  }\n\n  public get isNextButtonDisabled(): boolean {\n    return this.currentPage === this.pageCount;\n  }\n\n  #getDisplayedPageNumbers(\n    pageCount: number,\n    maxDisplayedPages: number,\n    pageNumber: number,\n  ): Array<number> {\n    const pageIndex = pageNumber - 1;\n    const pageBounds = Math.floor(maxDisplayedPages / 2);\n\n    let upperBound = pageIndex + pageBounds;\n    let lowerBound = pageIndex - pageBounds;\n    if (maxDisplayedPages % 2 !== 0) {\n      upperBound += 1;\n    }\n\n    // Wrap negative values to increase the upper bound\n    if (lowerBound < 0) {\n      upperBound -= lowerBound;\n      lowerBound = 0;\n    }\n    // Wrap overflow to decrease the lower bound\n    if (upperBound > pageCount) {\n      lowerBound -= upperBound - pageCount;\n      upperBound = pageCount;\n    }\n\n    // If both are the same ignore everything else and just display it all\n    if (pageCount < maxDisplayedPages) {\n      lowerBound = 0;\n      upperBound = pageCount;\n    }\n\n    const displayedPageNumbers: Array<number> = [];\n    for (let i = lowerBound; i < upperBound; i++) {\n      displayedPageNumbers.push(i + 1);\n    }\n    return displayedPageNumbers;\n  }\n\n  #setPageCount(): void {\n    if (this.itemCount === 0 || this.pageSize === 0) {\n      this.pageCount = 0;\n      return;\n    }\n\n    this.pageCount = Math.ceil(this.itemCount / this.pageSize);\n  }\n\n  #setDisplayedPages(): void {\n    this.displayedPages = this.#getDisplayedPageNumbers(\n      this.pageCount,\n      this.maxPages,\n      this.currentPage,\n    );\n  }\n}\n","<nav\n  *ngIf=\"pageCount > 1\"\n  class=\"sky-paging\"\n  [attr.aria-label]=\"pagingLabel || ('skyux_paging_label' | skyLibResources)\"\n>\n  <ul>\n    <li>\n      <button\n        class=\"sky-btn sky-btn-default sky-paging-btn sky-paging-btn-previous sky-box\"\n        sky-cmp-id=\"previous\"\n        type=\"button\"\n        [attr.aria-label]=\"'skyux_paging_previous' | skyLibResources\"\n        [disabled]=\"isPreviousButtonDisabled\"\n        (click)=\"previousPage()\"\n      >\n        <sky-icon *skyThemeIf=\"'default'\" icon=\"caret-left\" />\n        <sky-icon *skyThemeIf=\"'modern'\" icon=\"chevron-left\" />\n      </button>\n    </li>\n    <li *ngFor=\"let pageNumber of displayedPages\" class=\"sky-list-paging-link\">\n      <button\n        class=\"sky-btn sky-btn-default sky-paging-btn sky-box\"\n        type=\"button\"\n        [attr.aria-current]=\"currentPage === pageNumber ? 'page' : null\"\n        [attr.sky-cmp-id]=\"pageNumber\"\n        [attr.aria-label]=\"\n          'skyux_paging_page_link_aria_label' | skyLibResources : pageNumber\n        \"\n        [disabled]=\"currentPage === pageNumber\"\n        [ngClass]=\"{ 'sky-paging-current': currentPage === pageNumber }\"\n        (click)=\"setPage(pageNumber)\"\n      >\n        {{ pageNumber }}\n      </button>\n    </li>\n    <li>\n      <button\n        class=\"sky-btn sky-btn-default sky-paging-btn sky-paging-btn-next sky-box\"\n        sky-cmp-id=\"next\"\n        type=\"button\"\n        [attr.aria-label]=\"'skyux_paging_next' | skyLibResources\"\n        [disabled]=\"isNextButtonDisabled\"\n        (click)=\"nextPage()\"\n      >\n        <sky-icon *skyThemeIf=\"'default'\" icon=\"caret-right\" />\n        <sky-icon *skyThemeIf=\"'modern'\" icon=\"chevron-right\" />\n      </button>\n    </li>\n  </ul>\n</nav>\n"]}
150
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"paging.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/lists/src/lib/modules/paging/paging.component.ts","../../../../../../../../libs/components/lists/src/lib/modules/paging/paging.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  Output,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core';\n\nimport { BehaviorSubject } from 'rxjs';\n\nimport { SkyPagingContentChangeArgs } from './types/paging-content-change-args';\n\n@Component({\n  selector: 'sky-paging',\n  templateUrl: './paging.component.html',\n  styleUrls: ['./paging.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SkyPagingComponent implements OnChanges {\n  /**\n   * The page number of the current page. Page numbers start at 1 and increment.\n   */\n  @Input()\n  public currentPage = 1;\n\n  /**\n   * The total number of items across all pages.\n   */\n  @Input()\n  public itemCount = 0;\n\n  /**\n   * The maximum number of pages to display in the pagination control.\n   */\n  @Input()\n  public maxPages = 5;\n\n  /**\n   * The number of items to display per page.\n   */\n  @Input()\n  public pageSize = 10;\n\n  /**\n   * The label for the pagination control when an application includes\n   * multiple paging components on the same page. The label should be unique and descriptive\n   * to help users of assistive technology differentiate pagination controls\n   * and understand what each one does.\n   * @default \"Pagination\"\n   */\n  @Input()\n  public pagingLabel: string | undefined;\n\n  /**\n   * Fires when the current page changes and emits the new current page.\n   */\n  @Output()\n  public currentPageChange = new EventEmitter<number>();\n\n  /**\n   * Fires when the current page changes and emits the new current page with a function\n   * to call when loading the new page completes. Handling this event will display the\n   * wait component until the callback function is called, and focus will move to the top\n   * of the list for keyboard navigation if the list contents are placed inside the\n   * sky-paging-content element.\n   */\n  @Output()\n  public contentChange = new EventEmitter<SkyPagingContentChangeArgs>();\n\n  @ViewChild('contentWrapper', { read: ElementRef })\n  public contentWrapper: ElementRef | undefined;\n\n  public displayedPages: Array<number> = [];\n\n  public pageCount = 0;\n\n  protected isLoading = new BehaviorSubject(false);\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    this.setPage(this.currentPage, changes['currentPage']?.isFirstChange());\n  }\n\n  public setPage(pageNumber: number, forceContentChange?: boolean): void {\n    const previousPage = this.currentPage;\n\n    this.#setPageCount();\n\n    if (pageNumber < 1 || this.pageCount < 1) {\n      this.currentPage = 1;\n    } else if (pageNumber > this.pageCount) {\n      this.currentPage = this.pageCount;\n    } else {\n      this.currentPage = pageNumber;\n    }\n\n    this.#setDisplayedPages();\n\n    let doContentChange = forceContentChange;\n\n    if (previousPage !== this.currentPage) {\n      this.currentPageChange.emit(this.currentPage);\n      doContentChange = true;\n    }\n\n    if (doContentChange && this.contentChange.observed) {\n      this.#moveFocusToTop();\n      this.isLoading.next(true);\n\n      this.contentChange.emit({\n        currentPage: this.currentPage,\n        loadingComplete: () => this.isLoading.next(false),\n      });\n    }\n  }\n\n  public nextPage(): void {\n    this.setPage(this.currentPage + 1);\n  }\n\n  public previousPage(): void {\n    this.setPage(this.currentPage - 1);\n  }\n\n  public get isPreviousButtonDisabled(): boolean {\n    return this.currentPage === 1;\n  }\n\n  public get isNextButtonDisabled(): boolean {\n    return this.currentPage === this.pageCount;\n  }\n\n  #getDisplayedPageNumbers(\n    pageCount: number,\n    maxDisplayedPages: number,\n    pageNumber: number,\n  ): Array<number> {\n    const pageIndex = pageNumber - 1;\n    const pageBounds = Math.floor(maxDisplayedPages / 2);\n\n    let upperBound = pageIndex + pageBounds;\n    let lowerBound = pageIndex - pageBounds;\n    if (maxDisplayedPages % 2 !== 0) {\n      upperBound += 1;\n    }\n\n    // Wrap negative values to increase the upper bound\n    if (lowerBound < 0) {\n      upperBound -= lowerBound;\n      lowerBound = 0;\n    }\n    // Wrap overflow to decrease the lower bound\n    if (upperBound > pageCount) {\n      lowerBound -= upperBound - pageCount;\n      upperBound = pageCount;\n    }\n\n    // If both are the same ignore everything else and just display it all\n    if (pageCount < maxDisplayedPages) {\n      lowerBound = 0;\n      upperBound = pageCount;\n    }\n\n    const displayedPageNumbers: Array<number> = [];\n    for (let i = lowerBound; i < upperBound; i++) {\n      displayedPageNumbers.push(i + 1);\n    }\n    return displayedPageNumbers;\n  }\n\n  #setPageCount(): void {\n    if (this.itemCount === 0 || this.pageSize === 0) {\n      this.pageCount = 0;\n      return;\n    }\n\n    this.pageCount = Math.ceil(this.itemCount / this.pageSize);\n  }\n\n  #setDisplayedPages(): void {\n    this.displayedPages = this.#getDisplayedPageNumbers(\n      this.pageCount,\n      this.maxPages,\n      this.currentPage,\n    );\n  }\n\n  #moveFocusToTop(): void {\n    this.contentWrapper?.nativeElement.focus();\n  }\n}\n","<sky-wait\n  [ariaLabel]=\"\n    'skyux_paging_loading' | skyLibResources : currentPage : pageCount\n  \"\n  [isWaiting]=\"!!(isLoading | async)\"\n  [screenReaderCompletedText]=\"\n    'skyux_paging_loaded' | skyLibResources : currentPage\n  \"\n/>\n<div\n  class=\"sky-paging-content-wrapper\"\n  role=\"group\"\n  tabindex=\"-1\"\n  [attr.aria-label]=\"\n    'skyux_paging_page_label' | skyLibResources : currentPage : pageCount\n  \"\n  #contentWrapper\n>\n  <ng-content select=\"sky-paging-content\" />\n</div>\n<nav\n  *ngIf=\"pageCount > 1\"\n  class=\"sky-paging\"\n  [attr.aria-label]=\"pagingLabel || ('skyux_paging_label' | skyLibResources)\"\n>\n  <ul>\n    <li>\n      <button\n        class=\"sky-btn sky-btn-default sky-paging-btn sky-paging-btn-previous sky-box\"\n        sky-cmp-id=\"previous\"\n        type=\"button\"\n        [attr.aria-label]=\"'skyux_paging_previous' | skyLibResources\"\n        [disabled]=\"isPreviousButtonDisabled\"\n        (click)=\"previousPage()\"\n      >\n        <sky-icon *skyThemeIf=\"'default'\" icon=\"caret-left\" />\n        <sky-icon *skyThemeIf=\"'modern'\" icon=\"chevron-left\" />\n      </button>\n    </li>\n    <li *ngFor=\"let pageNumber of displayedPages\" class=\"sky-list-paging-link\">\n      <button\n        class=\"sky-btn sky-btn-default sky-paging-btn sky-box\"\n        type=\"button\"\n        [attr.aria-current]=\"currentPage === pageNumber ? 'page' : null\"\n        [attr.sky-cmp-id]=\"pageNumber\"\n        [attr.aria-label]=\"\n          'skyux_paging_page_link_aria_label' | skyLibResources : pageNumber\n        \"\n        [disabled]=\"currentPage === pageNumber\"\n        [ngClass]=\"{ 'sky-paging-current': currentPage === pageNumber }\"\n        (click)=\"setPage(pageNumber)\"\n      >\n        {{ pageNumber }}\n      </button>\n    </li>\n    <li>\n      <button\n        class=\"sky-btn sky-btn-default sky-paging-btn sky-paging-btn-next sky-box\"\n        sky-cmp-id=\"next\"\n        type=\"button\"\n        [attr.aria-label]=\"'skyux_paging_next' | skyLibResources\"\n        [disabled]=\"isNextButtonDisabled\"\n        (click)=\"nextPage()\"\n      >\n        <sky-icon *skyThemeIf=\"'default'\" icon=\"caret-right\" />\n        <sky-icon *skyThemeIf=\"'modern'\" icon=\"chevron-right\" />\n      </button>\n    </li>\n  </ul>\n</nav>\n"]}
@@ -1,8 +1,9 @@
1
1
  import { CommonModule } from '@angular/common';
2
2
  import { NgModule } from '@angular/core';
3
- import { SkyIconModule } from '@skyux/indicators';
3
+ import { SkyIconModule, SkyWaitModule } from '@skyux/indicators';
4
4
  import { SkyThemeModule } from '@skyux/theme';
5
5
  import { SkyListsResourcesModule } from '../shared/sky-lists-resources.module';
6
+ import { SkyPagingContentComponent } from './paging-content.component';
6
7
  import { SkyPagingComponent } from './paging.component';
7
8
  import * as i0 from "@angular/core";
8
9
  export class SkyPagingModule {
@@ -10,11 +11,15 @@ export class SkyPagingModule {
10
11
  static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.9", ngImport: i0, type: SkyPagingModule, declarations: [SkyPagingComponent], imports: [CommonModule,
11
12
  SkyIconModule,
12
13
  SkyListsResourcesModule,
13
- SkyThemeModule], exports: [SkyPagingComponent] }); }
14
+ SkyPagingContentComponent,
15
+ SkyThemeModule,
16
+ SkyWaitModule], exports: [SkyPagingComponent, SkyPagingContentComponent] }); }
14
17
  static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyPagingModule, imports: [CommonModule,
15
18
  SkyIconModule,
16
19
  SkyListsResourcesModule,
17
- SkyThemeModule] }); }
20
+ SkyPagingContentComponent,
21
+ SkyThemeModule,
22
+ SkyWaitModule] }); }
18
23
  }
19
24
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyPagingModule, decorators: [{
20
25
  type: NgModule,
@@ -24,9 +29,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.9", ngImpor
24
29
  CommonModule,
25
30
  SkyIconModule,
26
31
  SkyListsResourcesModule,
32
+ SkyPagingContentComponent,
27
33
  SkyThemeModule,
34
+ SkyWaitModule,
28
35
  ],
29
- exports: [SkyPagingComponent],
36
+ exports: [SkyPagingComponent, SkyPagingContentComponent],
30
37
  }]
31
38
  }] });
32
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnaW5nLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9saXN0cy9zcmMvbGliL21vZHVsZXMvcGFnaW5nL3BhZ2luZy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ2xELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFFOUMsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFFL0UsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7O0FBWXhELE1BQU0sT0FBTyxlQUFlOzhHQUFmLGVBQWU7K0dBQWYsZUFBZSxpQkFUWCxrQkFBa0IsYUFFL0IsWUFBWTtZQUNaLGFBQWE7WUFDYix1QkFBdUI7WUFDdkIsY0FBYyxhQUVOLGtCQUFrQjsrR0FFakIsZUFBZSxZQVB4QixZQUFZO1lBQ1osYUFBYTtZQUNiLHVCQUF1QjtZQUN2QixjQUFjOzsyRkFJTCxlQUFlO2tCQVYzQixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLGtCQUFrQixDQUFDO29CQUNsQyxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixhQUFhO3dCQUNiLHVCQUF1Qjt3QkFDdkIsY0FBYztxQkFDZjtvQkFDRCxPQUFPLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQztpQkFDOUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFNreUljb25Nb2R1bGUgfSBmcm9tICdAc2t5dXgvaW5kaWNhdG9ycyc7XG5pbXBvcnQgeyBTa3lUaGVtZU1vZHVsZSB9IGZyb20gJ0Bza3l1eC90aGVtZSc7XG5cbmltcG9ydCB7IFNreUxpc3RzUmVzb3VyY2VzTW9kdWxlIH0gZnJvbSAnLi4vc2hhcmVkL3NreS1saXN0cy1yZXNvdXJjZXMubW9kdWxlJztcblxuaW1wb3J0IHsgU2t5UGFnaW5nQ29tcG9uZW50IH0gZnJvbSAnLi9wYWdpbmcuY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbU2t5UGFnaW5nQ29tcG9uZW50XSxcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBTa3lJY29uTW9kdWxlLFxuICAgIFNreUxpc3RzUmVzb3VyY2VzTW9kdWxlLFxuICAgIFNreVRoZW1lTW9kdWxlLFxuICBdLFxuICBleHBvcnRzOiBbU2t5UGFnaW5nQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgU2t5UGFnaW5nTW9kdWxlIHt9XG4iXX0=
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnaW5nLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9saXN0cy9zcmMvbGliL21vZHVsZXMvcGFnaW5nL3BhZ2luZy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGFBQWEsRUFBRSxhQUFhLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUNqRSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sY0FBYyxDQUFDO0FBRTlDLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBRS9FLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLG9CQUFvQixDQUFDOztBQWN4RCxNQUFNLE9BQU8sZUFBZTs4R0FBZixlQUFlOytHQUFmLGVBQWUsaUJBWFgsa0JBQWtCLGFBRS9CLFlBQVk7WUFDWixhQUFhO1lBQ2IsdUJBQXVCO1lBQ3ZCLHlCQUF5QjtZQUN6QixjQUFjO1lBQ2QsYUFBYSxhQUVMLGtCQUFrQixFQUFFLHlCQUF5QjsrR0FFNUMsZUFBZSxZQVR4QixZQUFZO1lBQ1osYUFBYTtZQUNiLHVCQUF1QjtZQUN2Qix5QkFBeUI7WUFDekIsY0FBYztZQUNkLGFBQWE7OzJGQUlKLGVBQWU7a0JBWjNCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMsa0JBQWtCLENBQUM7b0JBQ2xDLE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLGFBQWE7d0JBQ2IsdUJBQXVCO3dCQUN2Qix5QkFBeUI7d0JBQ3pCLGNBQWM7d0JBQ2QsYUFBYTtxQkFDZDtvQkFDRCxPQUFPLEVBQUUsQ0FBQyxrQkFBa0IsRUFBRSx5QkFBeUIsQ0FBQztpQkFDekQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFNreUljb25Nb2R1bGUsIFNreVdhaXRNb2R1bGUgfSBmcm9tICdAc2t5dXgvaW5kaWNhdG9ycyc7XG5pbXBvcnQgeyBTa3lUaGVtZU1vZHVsZSB9IGZyb20gJ0Bza3l1eC90aGVtZSc7XG5cbmltcG9ydCB7IFNreUxpc3RzUmVzb3VyY2VzTW9kdWxlIH0gZnJvbSAnLi4vc2hhcmVkL3NreS1saXN0cy1yZXNvdXJjZXMubW9kdWxlJztcblxuaW1wb3J0IHsgU2t5UGFnaW5nQ29udGVudENvbXBvbmVudCB9IGZyb20gJy4vcGFnaW5nLWNvbnRlbnQuY29tcG9uZW50JztcbmltcG9ydCB7IFNreVBhZ2luZ0NvbXBvbmVudCB9IGZyb20gJy4vcGFnaW5nLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW1NreVBhZ2luZ0NvbXBvbmVudF0sXG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgU2t5SWNvbk1vZHVsZSxcbiAgICBTa3lMaXN0c1Jlc291cmNlc01vZHVsZSxcbiAgICBTa3lQYWdpbmdDb250ZW50Q29tcG9uZW50LFxuICAgIFNreVRoZW1lTW9kdWxlLFxuICAgIFNreVdhaXRNb2R1bGUsXG4gIF0sXG4gIGV4cG9ydHM6IFtTa3lQYWdpbmdDb21wb25lbnQsIFNreVBhZ2luZ0NvbnRlbnRDb21wb25lbnRdLFxufSlcbmV4cG9ydCBjbGFzcyBTa3lQYWdpbmdNb2R1bGUge31cbiJdfQ==
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnaW5nLWNvbnRlbnQtY2hhbmdlLWFyZ3MuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbGlzdHMvc3JjL2xpYi9tb2R1bGVzL3BhZ2luZy90eXBlcy9wYWdpbmctY29udGVudC1jaGFuZ2UtYXJncy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBJbmZvcm1hdGlvbiBhYm91dCB0aGUgcGFnZWQgY29udGVudCB0byBsb2FkLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFNreVBhZ2luZ0NvbnRlbnRDaGFuZ2VBcmdzIHtcbiAgLyoqXG4gICAqIFRoZSBjdXJyZW50IHBhZ2UgbnVtYmVyLlxuICAgKi9cbiAgY3VycmVudFBhZ2U6IG51bWJlcjtcblxuICAvKipcbiAgICogQSBmdW5jdGlvbiB0byBjYWxsIHdoZW4gbG9hZGluZyB0aGUgcGFnZWQgY29udGVudCBjb21wbGV0ZXMuXG4gICAqL1xuICBsb2FkaW5nQ29tcGxldGU6ICgpID0+IHZvaWQ7XG59XG4iXX0=
@@ -16,7 +16,10 @@ const RESOURCES = {
16
16
  skyux_filter_summary_header: { message: 'Filter' },
17
17
  skyux_infinite_scroll_load_more_button: { message: 'Load more' },
18
18
  skyux_paging_label: { message: 'Pagination' },
19
+ skyux_paging_loaded: { message: 'Page {0} loaded.' },
20
+ skyux_paging_loading: { message: 'Loading page {0}' },
19
21
  skyux_paging_next: { message: 'Next' },
22
+ skyux_paging_page_label: { message: 'Page {0} of {1}' },
20
23
  skyux_paging_page_link_aria_label: { message: 'Page {0}' },
21
24
  skyux_paging_previous: { message: 'Previous' },
22
25
  skyux_repeater_label: { message: 'List of items' },
@@ -84,4 +87,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.9", ngImpor
84
87
  ],
85
88
  }]
86
89
  }] });
87
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2t5LWxpc3RzLXJlc291cmNlcy5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbGlzdHMvc3JjL2xpYi9tb2R1bGVzL3NoYXJlZC9za3ktbGlzdHMtcmVzb3VyY2VzLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSwwQkFBMEI7QUFFMUI7Ozs7O0dBS0c7QUFDSCxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFDTCwyQkFBMkIsRUFFM0IsYUFBYSxFQUdiLHNCQUFzQixFQUN0QixxQkFBcUIsR0FDdEIsTUFBTSxhQUFhLENBQUM7O0FBRXJCLE1BQU0sU0FBUyxHQUEwQztJQUN2RCxPQUFPLEVBQUU7UUFDUCxrQ0FBa0MsRUFBRSxFQUFFLE9BQU8sRUFBRSxZQUFZLEVBQUU7UUFDN0QseUJBQXlCLEVBQUUsRUFBRSxPQUFPLEVBQUUsUUFBUSxFQUFFO1FBQ2hELDBCQUEwQixFQUFFLEVBQUUsT0FBTyxFQUFFLGVBQWUsRUFBRTtRQUN4RCwyQkFBMkIsRUFBRSxFQUFFLE9BQU8sRUFBRSxRQUFRLEVBQUU7UUFDbEQsc0NBQXNDLEVBQUUsRUFBRSxPQUFPLEVBQUUsV0FBVyxFQUFFO1FBQ2hFLGtCQUFrQixFQUFFLEVBQUUsT0FBTyxFQUFFLFlBQVksRUFBRTtRQUM3QyxpQkFBaUIsRUFBRSxFQUFFLE9BQU8sRUFBRSxNQUFNLEVBQUU7UUFDdEMsaUNBQWlDLEVBQUUsRUFBRSxPQUFPLEVBQUUsVUFBVSxFQUFFO1FBQzFELHFCQUFxQixFQUFFLEVBQUUsT0FBTyxFQUFFLFVBQVUsRUFBRTtRQUM5QyxvQkFBb0IsRUFBRSxFQUFFLE9BQU8sRUFBRSxlQUFlLEVBQUU7UUFDbEQsNEJBQTRCLEVBQUUsRUFBRSxPQUFPLEVBQUUsY0FBYyxFQUFFO1FBQ3pELG9DQUFvQyxFQUFFLEVBQUUsT0FBTyxFQUFFLFVBQVUsRUFBRTtRQUM3RCwwQkFBMEIsRUFBRSxFQUFFLE9BQU8sRUFBRSxZQUFZLEVBQUU7UUFDckQsa0NBQWtDLEVBQUUsRUFBRSxPQUFPLEVBQUUsUUFBUSxFQUFFO1FBQ3pELGtDQUFrQyxFQUFFLEVBQUUsT0FBTyxFQUFFLFlBQVksRUFBRTtRQUM3RCwwQ0FBMEMsRUFBRSxFQUFFLE9BQU8sRUFBRSxZQUFZLEVBQUU7UUFDckUsa0NBQWtDLEVBQUU7WUFDbEMsT0FBTyxFQUNMLCtFQUErRTtTQUNsRjtRQUNELGtDQUFrQyxFQUFFO1lBQ2xDLE9BQU8sRUFBRSw4QkFBOEI7U0FDeEM7UUFDRCx3Q0FBd0MsRUFBRTtZQUN4QyxPQUFPLEVBQ0wsaUpBQWlKO1NBQ3BKO1FBQ0QsaUNBQWlDLEVBQUU7WUFDakMsT0FBTyxFQUFFLDRCQUE0QjtTQUN0QztRQUNELHlDQUF5QyxFQUFFLEVBQUUsT0FBTyxFQUFFLFNBQVMsRUFBRTtRQUNqRSxpQ0FBaUMsRUFBRSxFQUFFLE9BQU8sRUFBRSxhQUFhLEVBQUU7UUFDN0QscUNBQXFDLEVBQUU7WUFDckMsT0FBTyxFQUFFLDZDQUE2QztTQUN2RDtRQUNELCtCQUErQixFQUFFLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRTtRQUNuRCxxQ0FBcUMsRUFBRSxFQUFFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRTtRQUNyRSw2Q0FBNkMsRUFBRSxFQUFFLE9BQU8sRUFBRSxhQUFhLEVBQUU7UUFDekUsZ0NBQWdDLEVBQUUsRUFBRSxPQUFPLEVBQUUsVUFBVSxFQUFFO1FBQ3pELHVCQUF1QixFQUFFLEVBQUUsT0FBTyxFQUFFLE1BQU0sRUFBRTtRQUM1Qyx1QkFBdUIsRUFBRSxFQUFFLE9BQU8sRUFBRSxTQUFTLEVBQUU7S0FDaEQ7Q0FDRixDQUFDO0FBRUYsc0JBQXNCLENBQUMsWUFBWSxDQUFDLFNBQVMsQ0FBQyxDQUFDO0FBRS9DLE1BQU0sT0FBTyx5QkFBeUI7SUFDN0IsU0FBUyxDQUNkLFVBQTRCLEVBQzVCLElBQVk7UUFFWixPQUFPLHFCQUFxQixDQUFDLFNBQVMsRUFBRSxVQUFVLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQ25FLENBQUM7Q0FDRjtBQUVEOztHQUVHO0FBV0gsTUFBTSxPQUFPLHVCQUF1Qjs4R0FBdkIsdUJBQXVCOytHQUF2Qix1QkFBdUIsWUFUeEIsYUFBYTsrR0FTWix1QkFBdUIsYUFSdkI7WUFDVDtnQkFDRSxPQUFPLEVBQUUsMkJBQTJCO2dCQUNwQyxRQUFRLEVBQUUseUJBQXlCO2dCQUNuQyxLQUFLLEVBQUUsSUFBSTthQUNaO1NBQ0YsWUFQUyxhQUFhOzsyRkFTWix1QkFBdUI7a0JBVm5DLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFLENBQUMsYUFBYSxDQUFDO29CQUN4QixTQUFTLEVBQUU7d0JBQ1Q7NEJBQ0UsT0FBTyxFQUFFLDJCQUEyQjs0QkFDcEMsUUFBUSxFQUFFLHlCQUF5Qjs0QkFDbkMsS0FBSyxFQUFFLElBQUk7eUJBQ1o7cUJBQ0Y7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBpc3RhbmJ1bCBpZ25vcmUgZmlsZSAqL1xuXG4vKipcbiAqIE5PVElDRTogRE8gTk9UIE1PRElGWSBUSElTIEZJTEUhXG4gKiBUaGUgY29udGVudHMgb2YgdGhpcyBmaWxlIHdlcmUgYXV0b21hdGljYWxseSBnZW5lcmF0ZWQgYnlcbiAqIHRoZSAnbmcgZ2VuZXJhdGUgQHNreXV4L2kxOG46bGliLXJlc291cmNlcy1tb2R1bGUgbGliL21vZHVsZXMvc2hhcmVkL3NreS1saXN0cycgc2NoZW1hdGljLlxuICogVG8gdXBkYXRlIHRoaXMgZmlsZSwgc2ltcGx5IHJlcnVuIHRoZSBjb21tYW5kLlxuICovXG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtcbiAgU0tZX0xJQl9SRVNPVVJDRVNfUFJPVklERVJTLFxuICBTa3lBcHBMb2NhbGVJbmZvLFxuICBTa3lJMThuTW9kdWxlLFxuICBTa3lMaWJSZXNvdXJjZXMsXG4gIFNreUxpYlJlc291cmNlc1Byb3ZpZGVyLFxuICBTa3lMaWJSZXNvdXJjZXNTZXJ2aWNlLFxuICBnZXRMaWJTdHJpbmdGb3JMb2NhbGUsXG59IGZyb20gJ0Bza3l1eC9pMThuJztcblxuY29uc3QgUkVTT1VSQ0VTOiB7IFtsb2NhbGU6IHN0cmluZ106IFNreUxpYlJlc291cmNlcyB9ID0ge1xuICAnRU4tVVMnOiB7XG4gICAgc2t5dXhfZmlsdGVyX2FyaWFfbGFiZWxfZGVzY3JpcHRvcjogeyBtZXNzYWdlOiAnRmlsdGVyIHswfScgfSxcbiAgICBza3l1eF9maWx0ZXJfYnV0dG9uX3RpdGxlOiB7IG1lc3NhZ2U6ICdGaWx0ZXInIH0sXG4gICAgc2t5dXhfZmlsdGVyX3N1bW1hcnlfY2xvc2U6IHsgbWVzc2FnZTogJ1JlbW92ZSBmaWx0ZXInIH0sXG4gICAgc2t5dXhfZmlsdGVyX3N1bW1hcnlfaGVhZGVyOiB7IG1lc3NhZ2U6ICdGaWx0ZXInIH0sXG4gICAgc2t5dXhfaW5maW5pdGVfc2Nyb2xsX2xvYWRfbW9yZV9idXR0b246IHsgbWVzc2FnZTogJ0xvYWQgbW9yZScgfSxcbiAgICBza3l1eF9wYWdpbmdfbGFiZWw6IHsgbWVzc2FnZTogJ1BhZ2luYXRpb24nIH0sXG4gICAgc2t5dXhfcGFnaW5nX25leHQ6IHsgbWVzc2FnZTogJ05leHQnIH0sXG4gICAgc2t5dXhfcGFnaW5nX3BhZ2VfbGlua19hcmlhX2xhYmVsOiB7IG1lc3NhZ2U6ICdQYWdlIHswfScgfSxcbiAgICBza3l1eF9wYWdpbmdfcHJldmlvdXM6IHsgbWVzc2FnZTogJ1ByZXZpb3VzJyB9LFxuICAgIHNreXV4X3JlcGVhdGVyX2xhYmVsOiB7IG1lc3NhZ2U6ICdMaXN0IG9mIGl0ZW1zJyB9LFxuICAgIHNreXV4X3JlcGVhdGVyX2l0ZW1fY29sbGFwc2U6IHsgbWVzc2FnZTogJ0NvbGxhcHNlIHswfScgfSxcbiAgICBza3l1eF9yZXBlYXRlcl9pdGVtX2NvbGxhcHNlX2RlZmF1bHQ6IHsgbWVzc2FnZTogJ0NvbGxhcHNlJyB9LFxuICAgIHNreXV4X3JlcGVhdGVyX2l0ZW1fZXhwYW5kOiB7IG1lc3NhZ2U6ICdFeHBhbmQgezB9JyB9LFxuICAgIHNreXV4X3JlcGVhdGVyX2l0ZW1fZXhwYW5kX2RlZmF1bHQ6IHsgbWVzc2FnZTogJ0V4cGFuZCcgfSxcbiAgICBza3l1eF9yZXBlYXRlcl9pdGVtX2NoZWNrYm94X2xhYmVsOiB7IG1lc3NhZ2U6ICdTZWxlY3QgezB9JyB9LFxuICAgIHNreXV4X3JlcGVhdGVyX2l0ZW1fY2hlY2tib3hfbGFiZWxfZGVmYXVsdDogeyBtZXNzYWdlOiAnU2VsZWN0IHJvdycgfSxcbiAgICBza3l1eF9yZXBlYXRlcl9pdGVtX3Jlb3JkZXJfY2FuY2VsOiB7XG4gICAgICBtZXNzYWdlOlxuICAgICAgICAnSXRlbSByZW9yZGVyaW5nIHdhcyBjYW5jZWxlZC4gVGhlIGl0ZW0gd2FzIHJldHVybmVkIHRvIGl0cyBvcmlnaW5hbCBwb3NpdGlvbi4nLFxuICAgIH0sXG4gICAgc2t5dXhfcmVwZWF0ZXJfaXRlbV9yZW9yZGVyX2ZpbmlzaDoge1xuICAgICAgbWVzc2FnZTogJ0Ryb3BwZWQgdGhlIGl0ZW0gaW4gcG9zaXRpb24nLFxuICAgIH0sXG4gICAgc2t5dXhfcmVwZWF0ZXJfaXRlbV9yZW9yZGVyX2luc3RydWN0aW9uczoge1xuICAgICAgbWVzc2FnZTpcbiAgICAgICAgJ0l0ZW0gZ3JhYmJlZC4gUHJlc3MgdGhlIHVwIGFuZCBkb3duIGFycm93IGtleXMgdG8gY2hhbmdlIHBvc2l0aW9uLiBQcmVzcyB0aGUgc3BhY2ViYXIgb3IgZW50ZXIga2V5IHRvIGRyb3AuIEFuZCBwcmVzcyB0aGUgZXNjYXBlIGtleSB0byBjYW5jZWwuJyxcbiAgICB9LFxuICAgIHNreXV4X3JlcGVhdGVyX2l0ZW1fcmVvcmRlcl9tb3ZlZDoge1xuICAgICAgbWVzc2FnZTogJ01vdmVkIHRoZSBpdGVtIHRvIHBvc2l0aW9uJyxcbiAgICB9LFxuICAgIHNreXV4X3JlcGVhdGVyX2l0ZW1fcmVvcmRlcl9sYWJlbF9kZWZhdWx0OiB7IG1lc3NhZ2U6ICdSZW9yZGVyJyB9LFxuICAgIHNreXV4X3JlcGVhdGVyX2l0ZW1fcmVvcmRlcl9sYWJlbDogeyBtZXNzYWdlOiAnUmVvcmRlciB7MH0nIH0sXG4gICAgc2t5dXhfcmVwZWF0ZXJfaXRlbV9yZW9yZGVyX29wZXJhdGlvbjoge1xuICAgICAgbWVzc2FnZTogJ1ByZXNzIHRoZSBzcGFjZWJhciBvciBlbnRlciBrZXkgdG8gcmVvcmRlci4nLFxuICAgIH0sXG4gICAgc2t5dXhfcmVwZWF0ZXJfaXRlbV9yZW9yZGVyX3RvcDogeyBtZXNzYWdlOiAnVG9wJyB9LFxuICAgIHNreXV4X3JlcGVhdGVyX2l0ZW1fcmVvcmRlcl90b3BfbGFiZWw6IHsgbWVzc2FnZTogJ01vdmUgezB9IHRvIHRvcCcgfSxcbiAgICBza3l1eF9yZXBlYXRlcl9pdGVtX3Jlb3JkZXJfdG9wX2xhYmVsX2RlZmF1bHQ6IHsgbWVzc2FnZTogJ01vdmUgdG8gdG9wJyB9LFxuICAgIHNreXV4X3NvcnRfYXJpYV9sYWJlbF9kZXNjcmlwdG9yOiB7IG1lc3NhZ2U6ICdTb3J0IHswfScgfSxcbiAgICBza3l1eF9zb3J0X2J1dHRvbl9sYWJlbDogeyBtZXNzYWdlOiAnU29ydCcgfSxcbiAgICBza3l1eF9zb3J0X21lbnVfaGVhZGluZzogeyBtZXNzYWdlOiAnU29ydCBieScgfSxcbiAgfSxcbn07XG5cblNreUxpYlJlc291cmNlc1NlcnZpY2UuYWRkUmVzb3VyY2VzKFJFU09VUkNFUyk7XG5cbmV4cG9ydCBjbGFzcyBTa3lMaXN0c1Jlc291cmNlc1Byb3ZpZGVyIGltcGxlbWVudHMgU2t5TGliUmVzb3VyY2VzUHJvdmlkZXIge1xuICBwdWJsaWMgZ2V0U3RyaW5nKFxuICAgIGxvY2FsZUluZm86IFNreUFwcExvY2FsZUluZm8sXG4gICAgbmFtZTogc3RyaW5nLFxuICApOiBzdHJpbmcgfCB1bmRlZmluZWQge1xuICAgIHJldHVybiBnZXRMaWJTdHJpbmdGb3JMb2NhbGUoUkVTT1VSQ0VTLCBsb2NhbGVJbmZvLmxvY2FsZSwgbmFtZSk7XG4gIH1cbn1cblxuLyoqXG4gKiBJbXBvcnQgaW50byBhbnkgY29tcG9uZW50IGxpYnJhcnkgbW9kdWxlIHRoYXQgbmVlZHMgdG8gdXNlIHJlc291cmNlIHN0cmluZ3MuXG4gKi9cbkBOZ01vZHVsZSh7XG4gIGV4cG9ydHM6IFtTa3lJMThuTW9kdWxlXSxcbiAgcHJvdmlkZXJzOiBbXG4gICAge1xuICAgICAgcHJvdmlkZTogU0tZX0xJQl9SRVNPVVJDRVNfUFJPVklERVJTLFxuICAgICAgdXNlQ2xhc3M6IFNreUxpc3RzUmVzb3VyY2VzUHJvdmlkZXIsXG4gICAgICBtdWx0aTogdHJ1ZSxcbiAgICB9LFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBTa3lMaXN0c1Jlc291cmNlc01vZHVsZSB7fVxuIl19
90
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sky-lists-resources.module.js","sourceRoot":"","sources":["../../../../../../../../libs/components/lists/src/lib/modules/shared/sky-lists-resources.module.ts"],"names":[],"mappings":"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","sourcesContent":["/* istanbul ignore file */\n\n/**\n * NOTICE: DO NOT MODIFY THIS FILE!\n * The contents of this file were automatically generated by\n * the 'ng generate @skyux/i18n:lib-resources-module lib/modules/shared/sky-lists' schematic.\n * To update this file, simply rerun the command.\n */\nimport { NgModule } from '@angular/core';\nimport {\n  SKY_LIB_RESOURCES_PROVIDERS,\n  SkyAppLocaleInfo,\n  SkyI18nModule,\n  SkyLibResources,\n  SkyLibResourcesProvider,\n  SkyLibResourcesService,\n  getLibStringForLocale,\n} from '@skyux/i18n';\n\nconst RESOURCES: { [locale: string]: SkyLibResources } = {\n  'EN-US': {\n    skyux_filter_aria_label_descriptor: { message: 'Filter {0}' },\n    skyux_filter_button_title: { message: 'Filter' },\n    skyux_filter_summary_close: { message: 'Remove filter' },\n    skyux_filter_summary_header: { message: 'Filter' },\n    skyux_infinite_scroll_load_more_button: { message: 'Load more' },\n    skyux_paging_label: { message: 'Pagination' },\n    skyux_paging_loaded: { message: 'Page {0} loaded.' },\n    skyux_paging_loading: { message: 'Loading page {0}' },\n    skyux_paging_next: { message: 'Next' },\n    skyux_paging_page_label: { message: 'Page {0} of {1}' },\n    skyux_paging_page_link_aria_label: { message: 'Page {0}' },\n    skyux_paging_previous: { message: 'Previous' },\n    skyux_repeater_label: { message: 'List of items' },\n    skyux_repeater_item_collapse: { message: 'Collapse {0}' },\n    skyux_repeater_item_collapse_default: { message: 'Collapse' },\n    skyux_repeater_item_expand: { message: 'Expand {0}' },\n    skyux_repeater_item_expand_default: { message: 'Expand' },\n    skyux_repeater_item_checkbox_label: { message: 'Select {0}' },\n    skyux_repeater_item_checkbox_label_default: { message: 'Select row' },\n    skyux_repeater_item_reorder_cancel: {\n      message:\n        'Item reordering was canceled. The item was returned to its original position.',\n    },\n    skyux_repeater_item_reorder_finish: {\n      message: 'Dropped the item in position',\n    },\n    skyux_repeater_item_reorder_instructions: {\n      message:\n        'Item grabbed. Press the up and down arrow keys to change position. Press the spacebar or enter key to drop. And press the escape key to cancel.',\n    },\n    skyux_repeater_item_reorder_moved: {\n      message: 'Moved the item to position',\n    },\n    skyux_repeater_item_reorder_label_default: { message: 'Reorder' },\n    skyux_repeater_item_reorder_label: { message: 'Reorder {0}' },\n    skyux_repeater_item_reorder_operation: {\n      message: 'Press the spacebar or enter key to reorder.',\n    },\n    skyux_repeater_item_reorder_top: { message: 'Top' },\n    skyux_repeater_item_reorder_top_label: { message: 'Move {0} to top' },\n    skyux_repeater_item_reorder_top_label_default: { message: 'Move to top' },\n    skyux_sort_aria_label_descriptor: { message: 'Sort {0}' },\n    skyux_sort_button_label: { message: 'Sort' },\n    skyux_sort_menu_heading: { message: 'Sort by' },\n  },\n};\n\nSkyLibResourcesService.addResources(RESOURCES);\n\nexport class SkyListsResourcesProvider implements SkyLibResourcesProvider {\n  public getString(\n    localeInfo: SkyAppLocaleInfo,\n    name: string,\n  ): string | undefined {\n    return getLibStringForLocale(RESOURCES, localeInfo.locale, name);\n  }\n}\n\n/**\n * Import into any component library module that needs to use resource strings.\n */\n@NgModule({\n  exports: [SkyI18nModule],\n  providers: [\n    {\n      provide: SKY_LIB_RESOURCES_PROVIDERS,\n      useClass: SkyListsResourcesProvider,\n      multi: true,\n    },\n  ],\n})\nexport class SkyListsResourcesModule {}\n"]}
@@ -1,7 +1,7 @@
1
1
  import * as i1 from '@angular/common';
2
2
  import { CommonModule } from '@angular/common';
3
3
  import * as i0 from '@angular/core';
4
- import { NgModule, EventEmitter, inject, Component, ChangeDetectionStrategy, Input, Output, Injectable, ElementRef, ViewEncapsulation, ContentChild, HostBinding, ViewChild, ContentChildren, HostListener, ChangeDetectorRef, Renderer2 } from '@angular/core';
4
+ import { NgModule, EventEmitter, inject, Component, ChangeDetectionStrategy, Input, Output, Injectable, ElementRef, ViewChild, ViewEncapsulation, ContentChild, HostBinding, ContentChildren, HostListener, ChangeDetectorRef, Renderer2 } from '@angular/core';
5
5
  import * as i2 from '@skyux/indicators';
6
6
  import { SkyIconModule, SkyTokensModule, SkyWaitModule, SkyChevronModule } from '@skyux/indicators';
7
7
  import * as i3 from '@skyux/theme';
@@ -40,7 +40,10 @@ const RESOURCES = {
40
40
  skyux_filter_summary_header: { message: 'Filter' },
41
41
  skyux_infinite_scroll_load_more_button: { message: 'Load more' },
42
42
  skyux_paging_label: { message: 'Pagination' },
43
+ skyux_paging_loaded: { message: 'Page {0} loaded.' },
44
+ skyux_paging_loading: { message: 'Loading page {0}' },
43
45
  skyux_paging_next: { message: 'Next' },
46
+ skyux_paging_page_label: { message: 'Page {0} of {1}' },
44
47
  skyux_paging_page_link_aria_label: { message: 'Page {0}' },
45
48
  skyux_paging_previous: { message: 'Previous' },
46
49
  skyux_repeater_label: { message: 'List of items' },
@@ -510,6 +513,20 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.9", ngImpor
510
513
  }]
511
514
  }] });
512
515
 
516
+ class SkyPagingContentComponent {
517
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyPagingContentComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
518
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.9", type: SkyPagingContentComponent, isStandalone: true, selector: "sky-paging-content", ngImport: i0, template: `<ng-content />`, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }] }); }
519
+ }
520
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyPagingContentComponent, decorators: [{
521
+ type: Component,
522
+ args: [{
523
+ standalone: true,
524
+ imports: [CommonModule],
525
+ selector: 'sky-paging-content',
526
+ template: `<ng-content />`,
527
+ }]
528
+ }] });
529
+
513
530
  class SkyPagingComponent {
514
531
  constructor() {
515
532
  /**
@@ -532,13 +549,22 @@ class SkyPagingComponent {
532
549
  * Fires when the current page changes and emits the new current page.
533
550
  */
534
551
  this.currentPageChange = new EventEmitter();
552
+ /**
553
+ * Fires when the current page changes and emits the new current page with a function
554
+ * to call when loading the new page completes. Handling this event will display the
555
+ * wait component until the callback function is called, and focus will move to the top
556
+ * of the list for keyboard navigation if the list contents are placed inside the
557
+ * sky-paging-content element.
558
+ */
559
+ this.contentChange = new EventEmitter();
535
560
  this.displayedPages = [];
536
561
  this.pageCount = 0;
562
+ this.isLoading = new BehaviorSubject(false);
537
563
  }
538
564
  ngOnChanges(changes) {
539
- this.setPage(this.currentPage);
565
+ this.setPage(this.currentPage, changes['currentPage']?.isFirstChange());
540
566
  }
541
- setPage(pageNumber) {
567
+ setPage(pageNumber, forceContentChange) {
542
568
  const previousPage = this.currentPage;
543
569
  this.#setPageCount();
544
570
  if (pageNumber < 1 || this.pageCount < 1) {
@@ -551,8 +577,18 @@ class SkyPagingComponent {
551
577
  this.currentPage = pageNumber;
552
578
  }
553
579
  this.#setDisplayedPages();
580
+ let doContentChange = forceContentChange;
554
581
  if (previousPage !== this.currentPage) {
555
582
  this.currentPageChange.emit(this.currentPage);
583
+ doContentChange = true;
584
+ }
585
+ if (doContentChange && this.contentChange.observed) {
586
+ this.#moveFocusToTop();
587
+ this.isLoading.next(true);
588
+ this.contentChange.emit({
589
+ currentPage: this.currentPage,
590
+ loadingComplete: () => this.isLoading.next(false),
591
+ });
556
592
  }
557
593
  }
558
594
  nextPage() {
@@ -606,12 +642,15 @@ class SkyPagingComponent {
606
642
  #setDisplayedPages() {
607
643
  this.displayedPages = this.#getDisplayedPageNumbers(this.pageCount, this.maxPages, this.currentPage);
608
644
  }
645
+ #moveFocusToTop() {
646
+ this.contentWrapper?.nativeElement.focus();
647
+ }
609
648
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyPagingComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
610
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.9", type: SkyPagingComponent, selector: "sky-paging", inputs: { currentPage: "currentPage", itemCount: "itemCount", maxPages: "maxPages", pageSize: "pageSize", pagingLabel: "pagingLabel" }, outputs: { currentPageChange: "currentPageChange" }, usesOnChanges: true, ngImport: i0, template: "<nav\n *ngIf=\"pageCount > 1\"\n class=\"sky-paging\"\n [attr.aria-label]=\"pagingLabel || ('skyux_paging_label' | skyLibResources)\"\n>\n <ul>\n <li>\n <button\n class=\"sky-btn sky-btn-default sky-paging-btn sky-paging-btn-previous sky-box\"\n sky-cmp-id=\"previous\"\n type=\"button\"\n [attr.aria-label]=\"'skyux_paging_previous' | skyLibResources\"\n [disabled]=\"isPreviousButtonDisabled\"\n (click)=\"previousPage()\"\n >\n <sky-icon *skyThemeIf=\"'default'\" icon=\"caret-left\" />\n <sky-icon *skyThemeIf=\"'modern'\" icon=\"chevron-left\" />\n </button>\n </li>\n <li *ngFor=\"let pageNumber of displayedPages\" class=\"sky-list-paging-link\">\n <button\n class=\"sky-btn sky-btn-default sky-paging-btn sky-box\"\n type=\"button\"\n [attr.aria-current]=\"currentPage === pageNumber ? 'page' : null\"\n [attr.sky-cmp-id]=\"pageNumber\"\n [attr.aria-label]=\"\n 'skyux_paging_page_link_aria_label' | skyLibResources : pageNumber\n \"\n [disabled]=\"currentPage === pageNumber\"\n [ngClass]=\"{ 'sky-paging-current': currentPage === pageNumber }\"\n (click)=\"setPage(pageNumber)\"\n >\n {{ pageNumber }}\n </button>\n </li>\n <li>\n <button\n class=\"sky-btn sky-btn-default sky-paging-btn sky-paging-btn-next sky-box\"\n sky-cmp-id=\"next\"\n type=\"button\"\n [attr.aria-label]=\"'skyux_paging_next' | skyLibResources\"\n [disabled]=\"isNextButtonDisabled\"\n (click)=\"nextPage()\"\n >\n <sky-icon *skyThemeIf=\"'default'\" icon=\"caret-right\" />\n <sky-icon *skyThemeIf=\"'modern'\" icon=\"chevron-right\" />\n </button>\n </li>\n </ul>\n</nav>\n", styles: [":host{display:block}ul{margin:15px 0 0;display:inline-block;padding-left:0;border-radius:4px}li{display:inline}.sky-paging-btn{border-top:1px solid #e2e3e4;border-right:1px solid #e2e3e4;border-bottom:1px solid #e2e3e4;border-left:1px solid #e2e3e4;border-radius:0;background-color:#fff;color:inherit;float:left;margin-left:-1px;padding:4px 10px;text-decoration:none;line-height:1.428571429;font-size:15px;cursor:pointer}.sky-paging-btn.sky-paging-caret{transform:none}.sky-paging-btn.sky-paging-current,.sky-paging-btn.sky-paging-current:disabled,.sky-paging-btn.sky-paging-current[disabled]{background-color:#eeeeef;cursor:default;color:inherit;opacity:1}.sky-paging-btn:hover{background-color:#d4d4d6}.sky-paging-btn:disabled{color:#686c73;cursor:not-allowed;pointer-events:none}.sky-paging-btn.sky-paging-btn-previous,.sky-paging-btn.sky-paging-btn-next{padding-left:8.5px;padding-right:8.5px}:host-context(.sky-theme-modern) .sky-paging-btn{background-color:transparent;border:none;box-shadow:none;border-radius:6px;margin-right:10px;padding:3px 10px}:host-context(.sky-theme-modern) .sky-paging-btn:hover{background-color:transparent;border:solid 1px #1870B8;padding:2px 9px;z-index:1}:host-context(.sky-theme-modern) .sky-paging-btn:active,:host-context(.sky-theme-modern) .sky-paging-btn:focus{border:solid 2px #1870B8;color:#212327;padding:1px 8px}:host-context(.sky-theme-modern) .sky-paging-btn:focus:not(:active){outline:none;box-shadow:0 1px 3px #0000004d}:host-context(.sky-theme-modern) .sky-paging-current{background-color:var(--sky-background-color-item-selected);border:solid 1px #1870B8;padding:2px 9px}.sky-theme-modern .sky-paging-btn{background-color:transparent;border:none;box-shadow:none;border-radius:6px;margin-right:10px;padding:3px 10px}.sky-theme-modern .sky-paging-btn:hover{background-color:transparent;border:solid 1px #1870B8;padding:2px 9px;z-index:1}.sky-theme-modern .sky-paging-btn:active,.sky-theme-modern .sky-paging-btn:focus{border:solid 2px #1870B8;color:#212327;padding:1px 8px}.sky-theme-modern .sky-paging-btn:focus:not(:active){outline:none;box-shadow:0 1px 3px #0000004d}.sky-theme-modern .sky-paging-current{background-color:var(--sky-background-color-item-selected);border:solid 1px #1870B8;padding:2px 9px}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-paging-btn:active,:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-paging-btn:focus{color:#fbfcfe}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-paging-current{background-color:#1870b8}.sky-theme-modern.sky-theme-mode-dark .sky-paging-btn:active,.sky-theme-modern.sky-theme-mode-dark .sky-paging-btn:focus{color:#fbfcfe}.sky-theme-modern.sky-theme-mode-dark .sky-paging-current{background-color:#1870b8}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.λ4, selector: "sky-icon", inputs: ["icon", "iconType", "size", "fixedWidth", "variant"] }, { kind: "directive", type: i3.λ3, selector: "[skyThemeIf]", inputs: ["skyThemeIf"] }, { kind: "pipe", type: i3$1.SkyLibResourcesPipe, name: "skyLibResources" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
649
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.9", type: SkyPagingComponent, selector: "sky-paging", inputs: { currentPage: "currentPage", itemCount: "itemCount", maxPages: "maxPages", pageSize: "pageSize", pagingLabel: "pagingLabel" }, outputs: { currentPageChange: "currentPageChange", contentChange: "contentChange" }, viewQueries: [{ propertyName: "contentWrapper", first: true, predicate: ["contentWrapper"], descendants: true, read: ElementRef }], usesOnChanges: true, ngImport: i0, template: "<sky-wait\n [ariaLabel]=\"\n 'skyux_paging_loading' | skyLibResources : currentPage : pageCount\n \"\n [isWaiting]=\"!!(isLoading | async)\"\n [screenReaderCompletedText]=\"\n 'skyux_paging_loaded' | skyLibResources : currentPage\n \"\n/>\n<div\n class=\"sky-paging-content-wrapper\"\n role=\"group\"\n tabindex=\"-1\"\n [attr.aria-label]=\"\n 'skyux_paging_page_label' | skyLibResources : currentPage : pageCount\n \"\n #contentWrapper\n>\n <ng-content select=\"sky-paging-content\" />\n</div>\n<nav\n *ngIf=\"pageCount > 1\"\n class=\"sky-paging\"\n [attr.aria-label]=\"pagingLabel || ('skyux_paging_label' | skyLibResources)\"\n>\n <ul>\n <li>\n <button\n class=\"sky-btn sky-btn-default sky-paging-btn sky-paging-btn-previous sky-box\"\n sky-cmp-id=\"previous\"\n type=\"button\"\n [attr.aria-label]=\"'skyux_paging_previous' | skyLibResources\"\n [disabled]=\"isPreviousButtonDisabled\"\n (click)=\"previousPage()\"\n >\n <sky-icon *skyThemeIf=\"'default'\" icon=\"caret-left\" />\n <sky-icon *skyThemeIf=\"'modern'\" icon=\"chevron-left\" />\n </button>\n </li>\n <li *ngFor=\"let pageNumber of displayedPages\" class=\"sky-list-paging-link\">\n <button\n class=\"sky-btn sky-btn-default sky-paging-btn sky-box\"\n type=\"button\"\n [attr.aria-current]=\"currentPage === pageNumber ? 'page' : null\"\n [attr.sky-cmp-id]=\"pageNumber\"\n [attr.aria-label]=\"\n 'skyux_paging_page_link_aria_label' | skyLibResources : pageNumber\n \"\n [disabled]=\"currentPage === pageNumber\"\n [ngClass]=\"{ 'sky-paging-current': currentPage === pageNumber }\"\n (click)=\"setPage(pageNumber)\"\n >\n {{ pageNumber }}\n </button>\n </li>\n <li>\n <button\n class=\"sky-btn sky-btn-default sky-paging-btn sky-paging-btn-next sky-box\"\n sky-cmp-id=\"next\"\n type=\"button\"\n [attr.aria-label]=\"'skyux_paging_next' | skyLibResources\"\n [disabled]=\"isNextButtonDisabled\"\n (click)=\"nextPage()\"\n >\n <sky-icon *skyThemeIf=\"'default'\" icon=\"caret-right\" />\n <sky-icon *skyThemeIf=\"'modern'\" icon=\"chevron-right\" />\n </button>\n </li>\n </ul>\n</nav>\n", styles: [":host{display:block}.sky-paging-content-wrapper{display:none}.sky-paging-content-wrapper:not(:empty){display:block;margin-bottom:var(--sky-margin-stacked-lg)}.sky-paging-content-wrapper:focus-visible{outline:none;border:none}ul{margin:15px 0 0;display:inline-block;padding-left:0;border-radius:4px}li{display:inline}.sky-paging-btn{border-top:1px solid #e2e3e4;border-right:1px solid #e2e3e4;border-bottom:1px solid #e2e3e4;border-left:1px solid #e2e3e4;border-radius:0;background-color:#fff;color:inherit;float:left;margin-left:-1px;padding:4px 10px;text-decoration:none;line-height:1.428571429;font-size:15px;cursor:pointer}.sky-paging-btn.sky-paging-caret{transform:none}.sky-paging-btn.sky-paging-current,.sky-paging-btn.sky-paging-current:disabled,.sky-paging-btn.sky-paging-current[disabled]{background-color:#eeeeef;cursor:default;color:inherit;opacity:1}.sky-paging-btn:hover{background-color:#d4d4d6}.sky-paging-btn:disabled{color:#686c73;cursor:not-allowed;pointer-events:none}.sky-paging-btn.sky-paging-btn-previous,.sky-paging-btn.sky-paging-btn-next{padding-left:8.5px;padding-right:8.5px}:host-context(.sky-theme-modern) .sky-paging-btn{background-color:transparent;border:none;box-shadow:none;border-radius:6px;margin-right:10px;padding:3px 10px}:host-context(.sky-theme-modern) .sky-paging-btn:hover{background-color:transparent;border:solid 1px #1870B8;padding:2px 9px;z-index:1}:host-context(.sky-theme-modern) .sky-paging-btn:active,:host-context(.sky-theme-modern) .sky-paging-btn:focus{border:solid 2px #1870B8;color:#212327;padding:1px 8px}:host-context(.sky-theme-modern) .sky-paging-btn:focus:not(:active){outline:none;box-shadow:0 1px 3px #0000004d}:host-context(.sky-theme-modern) .sky-paging-current{background-color:var(--sky-background-color-item-selected);border:solid 1px #1870B8;padding:2px 9px}.sky-theme-modern .sky-paging-btn{background-color:transparent;border:none;box-shadow:none;border-radius:6px;margin-right:10px;padding:3px 10px}.sky-theme-modern .sky-paging-btn:hover{background-color:transparent;border:solid 1px #1870B8;padding:2px 9px;z-index:1}.sky-theme-modern .sky-paging-btn:active,.sky-theme-modern .sky-paging-btn:focus{border:solid 2px #1870B8;color:#212327;padding:1px 8px}.sky-theme-modern .sky-paging-btn:focus:not(:active){outline:none;box-shadow:0 1px 3px #0000004d}.sky-theme-modern .sky-paging-current{background-color:var(--sky-background-color-item-selected);border:solid 1px #1870B8;padding:2px 9px}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-paging-btn:active,:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-paging-btn:focus{color:#fbfcfe}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-paging-current{background-color:#1870b8}.sky-theme-modern.sky-theme-mode-dark .sky-paging-btn:active,.sky-theme-modern.sky-theme-mode-dark .sky-paging-btn:focus{color:#fbfcfe}.sky-theme-modern.sky-theme-mode-dark .sky-paging-current{background-color:#1870b8}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.λ4, selector: "sky-icon", inputs: ["icon", "iconType", "size", "fixedWidth", "variant"] }, { kind: "directive", type: i3.λ3, selector: "[skyThemeIf]", inputs: ["skyThemeIf"] }, { kind: "component", type: i2.λ14, selector: "sky-wait", inputs: ["ariaLabel", "isWaiting", "isFullPage", "isNonBlocking", "screenReaderCompletedText"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i3$1.SkyLibResourcesPipe, name: "skyLibResources" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
611
650
  }
612
651
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyPagingComponent, decorators: [{
613
652
  type: Component,
614
- args: [{ selector: 'sky-paging', changeDetection: ChangeDetectionStrategy.OnPush, template: "<nav\n *ngIf=\"pageCount > 1\"\n class=\"sky-paging\"\n [attr.aria-label]=\"pagingLabel || ('skyux_paging_label' | skyLibResources)\"\n>\n <ul>\n <li>\n <button\n class=\"sky-btn sky-btn-default sky-paging-btn sky-paging-btn-previous sky-box\"\n sky-cmp-id=\"previous\"\n type=\"button\"\n [attr.aria-label]=\"'skyux_paging_previous' | skyLibResources\"\n [disabled]=\"isPreviousButtonDisabled\"\n (click)=\"previousPage()\"\n >\n <sky-icon *skyThemeIf=\"'default'\" icon=\"caret-left\" />\n <sky-icon *skyThemeIf=\"'modern'\" icon=\"chevron-left\" />\n </button>\n </li>\n <li *ngFor=\"let pageNumber of displayedPages\" class=\"sky-list-paging-link\">\n <button\n class=\"sky-btn sky-btn-default sky-paging-btn sky-box\"\n type=\"button\"\n [attr.aria-current]=\"currentPage === pageNumber ? 'page' : null\"\n [attr.sky-cmp-id]=\"pageNumber\"\n [attr.aria-label]=\"\n 'skyux_paging_page_link_aria_label' | skyLibResources : pageNumber\n \"\n [disabled]=\"currentPage === pageNumber\"\n [ngClass]=\"{ 'sky-paging-current': currentPage === pageNumber }\"\n (click)=\"setPage(pageNumber)\"\n >\n {{ pageNumber }}\n </button>\n </li>\n <li>\n <button\n class=\"sky-btn sky-btn-default sky-paging-btn sky-paging-btn-next sky-box\"\n sky-cmp-id=\"next\"\n type=\"button\"\n [attr.aria-label]=\"'skyux_paging_next' | skyLibResources\"\n [disabled]=\"isNextButtonDisabled\"\n (click)=\"nextPage()\"\n >\n <sky-icon *skyThemeIf=\"'default'\" icon=\"caret-right\" />\n <sky-icon *skyThemeIf=\"'modern'\" icon=\"chevron-right\" />\n </button>\n </li>\n </ul>\n</nav>\n", styles: [":host{display:block}ul{margin:15px 0 0;display:inline-block;padding-left:0;border-radius:4px}li{display:inline}.sky-paging-btn{border-top:1px solid #e2e3e4;border-right:1px solid #e2e3e4;border-bottom:1px solid #e2e3e4;border-left:1px solid #e2e3e4;border-radius:0;background-color:#fff;color:inherit;float:left;margin-left:-1px;padding:4px 10px;text-decoration:none;line-height:1.428571429;font-size:15px;cursor:pointer}.sky-paging-btn.sky-paging-caret{transform:none}.sky-paging-btn.sky-paging-current,.sky-paging-btn.sky-paging-current:disabled,.sky-paging-btn.sky-paging-current[disabled]{background-color:#eeeeef;cursor:default;color:inherit;opacity:1}.sky-paging-btn:hover{background-color:#d4d4d6}.sky-paging-btn:disabled{color:#686c73;cursor:not-allowed;pointer-events:none}.sky-paging-btn.sky-paging-btn-previous,.sky-paging-btn.sky-paging-btn-next{padding-left:8.5px;padding-right:8.5px}:host-context(.sky-theme-modern) .sky-paging-btn{background-color:transparent;border:none;box-shadow:none;border-radius:6px;margin-right:10px;padding:3px 10px}:host-context(.sky-theme-modern) .sky-paging-btn:hover{background-color:transparent;border:solid 1px #1870B8;padding:2px 9px;z-index:1}:host-context(.sky-theme-modern) .sky-paging-btn:active,:host-context(.sky-theme-modern) .sky-paging-btn:focus{border:solid 2px #1870B8;color:#212327;padding:1px 8px}:host-context(.sky-theme-modern) .sky-paging-btn:focus:not(:active){outline:none;box-shadow:0 1px 3px #0000004d}:host-context(.sky-theme-modern) .sky-paging-current{background-color:var(--sky-background-color-item-selected);border:solid 1px #1870B8;padding:2px 9px}.sky-theme-modern .sky-paging-btn{background-color:transparent;border:none;box-shadow:none;border-radius:6px;margin-right:10px;padding:3px 10px}.sky-theme-modern .sky-paging-btn:hover{background-color:transparent;border:solid 1px #1870B8;padding:2px 9px;z-index:1}.sky-theme-modern .sky-paging-btn:active,.sky-theme-modern .sky-paging-btn:focus{border:solid 2px #1870B8;color:#212327;padding:1px 8px}.sky-theme-modern .sky-paging-btn:focus:not(:active){outline:none;box-shadow:0 1px 3px #0000004d}.sky-theme-modern .sky-paging-current{background-color:var(--sky-background-color-item-selected);border:solid 1px #1870B8;padding:2px 9px}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-paging-btn:active,:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-paging-btn:focus{color:#fbfcfe}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-paging-current{background-color:#1870b8}.sky-theme-modern.sky-theme-mode-dark .sky-paging-btn:active,.sky-theme-modern.sky-theme-mode-dark .sky-paging-btn:focus{color:#fbfcfe}.sky-theme-modern.sky-theme-mode-dark .sky-paging-current{background-color:#1870b8}\n"] }]
653
+ args: [{ selector: 'sky-paging', changeDetection: ChangeDetectionStrategy.OnPush, template: "<sky-wait\n [ariaLabel]=\"\n 'skyux_paging_loading' | skyLibResources : currentPage : pageCount\n \"\n [isWaiting]=\"!!(isLoading | async)\"\n [screenReaderCompletedText]=\"\n 'skyux_paging_loaded' | skyLibResources : currentPage\n \"\n/>\n<div\n class=\"sky-paging-content-wrapper\"\n role=\"group\"\n tabindex=\"-1\"\n [attr.aria-label]=\"\n 'skyux_paging_page_label' | skyLibResources : currentPage : pageCount\n \"\n #contentWrapper\n>\n <ng-content select=\"sky-paging-content\" />\n</div>\n<nav\n *ngIf=\"pageCount > 1\"\n class=\"sky-paging\"\n [attr.aria-label]=\"pagingLabel || ('skyux_paging_label' | skyLibResources)\"\n>\n <ul>\n <li>\n <button\n class=\"sky-btn sky-btn-default sky-paging-btn sky-paging-btn-previous sky-box\"\n sky-cmp-id=\"previous\"\n type=\"button\"\n [attr.aria-label]=\"'skyux_paging_previous' | skyLibResources\"\n [disabled]=\"isPreviousButtonDisabled\"\n (click)=\"previousPage()\"\n >\n <sky-icon *skyThemeIf=\"'default'\" icon=\"caret-left\" />\n <sky-icon *skyThemeIf=\"'modern'\" icon=\"chevron-left\" />\n </button>\n </li>\n <li *ngFor=\"let pageNumber of displayedPages\" class=\"sky-list-paging-link\">\n <button\n class=\"sky-btn sky-btn-default sky-paging-btn sky-box\"\n type=\"button\"\n [attr.aria-current]=\"currentPage === pageNumber ? 'page' : null\"\n [attr.sky-cmp-id]=\"pageNumber\"\n [attr.aria-label]=\"\n 'skyux_paging_page_link_aria_label' | skyLibResources : pageNumber\n \"\n [disabled]=\"currentPage === pageNumber\"\n [ngClass]=\"{ 'sky-paging-current': currentPage === pageNumber }\"\n (click)=\"setPage(pageNumber)\"\n >\n {{ pageNumber }}\n </button>\n </li>\n <li>\n <button\n class=\"sky-btn sky-btn-default sky-paging-btn sky-paging-btn-next sky-box\"\n sky-cmp-id=\"next\"\n type=\"button\"\n [attr.aria-label]=\"'skyux_paging_next' | skyLibResources\"\n [disabled]=\"isNextButtonDisabled\"\n (click)=\"nextPage()\"\n >\n <sky-icon *skyThemeIf=\"'default'\" icon=\"caret-right\" />\n <sky-icon *skyThemeIf=\"'modern'\" icon=\"chevron-right\" />\n </button>\n </li>\n </ul>\n</nav>\n", styles: [":host{display:block}.sky-paging-content-wrapper{display:none}.sky-paging-content-wrapper:not(:empty){display:block;margin-bottom:var(--sky-margin-stacked-lg)}.sky-paging-content-wrapper:focus-visible{outline:none;border:none}ul{margin:15px 0 0;display:inline-block;padding-left:0;border-radius:4px}li{display:inline}.sky-paging-btn{border-top:1px solid #e2e3e4;border-right:1px solid #e2e3e4;border-bottom:1px solid #e2e3e4;border-left:1px solid #e2e3e4;border-radius:0;background-color:#fff;color:inherit;float:left;margin-left:-1px;padding:4px 10px;text-decoration:none;line-height:1.428571429;font-size:15px;cursor:pointer}.sky-paging-btn.sky-paging-caret{transform:none}.sky-paging-btn.sky-paging-current,.sky-paging-btn.sky-paging-current:disabled,.sky-paging-btn.sky-paging-current[disabled]{background-color:#eeeeef;cursor:default;color:inherit;opacity:1}.sky-paging-btn:hover{background-color:#d4d4d6}.sky-paging-btn:disabled{color:#686c73;cursor:not-allowed;pointer-events:none}.sky-paging-btn.sky-paging-btn-previous,.sky-paging-btn.sky-paging-btn-next{padding-left:8.5px;padding-right:8.5px}:host-context(.sky-theme-modern) .sky-paging-btn{background-color:transparent;border:none;box-shadow:none;border-radius:6px;margin-right:10px;padding:3px 10px}:host-context(.sky-theme-modern) .sky-paging-btn:hover{background-color:transparent;border:solid 1px #1870B8;padding:2px 9px;z-index:1}:host-context(.sky-theme-modern) .sky-paging-btn:active,:host-context(.sky-theme-modern) .sky-paging-btn:focus{border:solid 2px #1870B8;color:#212327;padding:1px 8px}:host-context(.sky-theme-modern) .sky-paging-btn:focus:not(:active){outline:none;box-shadow:0 1px 3px #0000004d}:host-context(.sky-theme-modern) .sky-paging-current{background-color:var(--sky-background-color-item-selected);border:solid 1px #1870B8;padding:2px 9px}.sky-theme-modern .sky-paging-btn{background-color:transparent;border:none;box-shadow:none;border-radius:6px;margin-right:10px;padding:3px 10px}.sky-theme-modern .sky-paging-btn:hover{background-color:transparent;border:solid 1px #1870B8;padding:2px 9px;z-index:1}.sky-theme-modern .sky-paging-btn:active,.sky-theme-modern .sky-paging-btn:focus{border:solid 2px #1870B8;color:#212327;padding:1px 8px}.sky-theme-modern .sky-paging-btn:focus:not(:active){outline:none;box-shadow:0 1px 3px #0000004d}.sky-theme-modern .sky-paging-current{background-color:var(--sky-background-color-item-selected);border:solid 1px #1870B8;padding:2px 9px}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-paging-btn:active,:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-paging-btn:focus{color:#fbfcfe}:host-context(.sky-theme-modern.sky-theme-mode-dark) .sky-paging-current{background-color:#1870b8}.sky-theme-modern.sky-theme-mode-dark .sky-paging-btn:active,.sky-theme-modern.sky-theme-mode-dark .sky-paging-btn:focus{color:#fbfcfe}.sky-theme-modern.sky-theme-mode-dark .sky-paging-current{background-color:#1870b8}\n"] }]
615
654
  }], propDecorators: { currentPage: [{
616
655
  type: Input
617
656
  }], itemCount: [{
@@ -624,6 +663,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.9", ngImpor
624
663
  type: Input
625
664
  }], currentPageChange: [{
626
665
  type: Output
666
+ }], contentChange: [{
667
+ type: Output
668
+ }], contentWrapper: [{
669
+ type: ViewChild,
670
+ args: ['contentWrapper', { read: ElementRef }]
627
671
  }] } });
628
672
 
629
673
  class SkyPagingModule {
@@ -631,11 +675,15 @@ class SkyPagingModule {
631
675
  static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.9", ngImport: i0, type: SkyPagingModule, declarations: [SkyPagingComponent], imports: [CommonModule,
632
676
  SkyIconModule,
633
677
  SkyListsResourcesModule,
634
- SkyThemeModule], exports: [SkyPagingComponent] }); }
678
+ SkyPagingContentComponent,
679
+ SkyThemeModule,
680
+ SkyWaitModule], exports: [SkyPagingComponent, SkyPagingContentComponent] }); }
635
681
  static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyPagingModule, imports: [CommonModule,
636
682
  SkyIconModule,
637
683
  SkyListsResourcesModule,
638
- SkyThemeModule] }); }
684
+ SkyPagingContentComponent,
685
+ SkyThemeModule,
686
+ SkyWaitModule] }); }
639
687
  }
640
688
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyPagingModule, decorators: [{
641
689
  type: NgModule,
@@ -645,9 +693,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.9", ngImpor
645
693
  CommonModule,
646
694
  SkyIconModule,
647
695
  SkyListsResourcesModule,
696
+ SkyPagingContentComponent,
648
697
  SkyThemeModule,
698
+ SkyWaitModule,
649
699
  ],
650
- exports: [SkyPagingComponent],
700
+ exports: [SkyPagingComponent, SkyPagingContentComponent],
651
701
  }]
652
702
  }] });
653
703
 
@@ -1976,5 +2026,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.9", ngImpor
1976
2026
  * Generated bundle index. Do not edit.
1977
2027
  */
1978
2028
 
1979
- export { SkyFilterModule, SkyInfiniteScrollModule, SkyPagingModule, SkyRepeaterModule, SkySortModule, SkyFilterButtonComponent as λ1, SkyRepeaterItemComponent as λ10, SkyRepeaterComponent as λ11, SkyRepeaterItemTitleComponent as λ12, SkySortItemComponent as λ13, SkySortComponent as λ14, SkyFilterInlineComponent as λ2, SkyFilterInlineItemComponent as λ3, SkyFilterSummaryItemComponent as λ4, SkyFilterSummaryComponent as λ5, SkyInfiniteScrollComponent as λ6, SkyPagingComponent as λ7, SkyRepeaterItemContentComponent as λ8, SkyRepeaterItemContextMenuComponent as λ9 };
2029
+ export { SkyFilterModule, SkyInfiniteScrollModule, SkyPagingModule, SkyRepeaterModule, SkySortModule, SkyFilterButtonComponent as λ1, SkyRepeaterItemComponent as λ10, SkyRepeaterComponent as λ11, SkyRepeaterItemTitleComponent as λ12, SkySortItemComponent as λ13, SkySortComponent as λ14, SkyPagingContentComponent as λ15, SkyFilterInlineComponent as λ2, SkyFilterInlineItemComponent as λ3, SkyFilterSummaryItemComponent as λ4, SkyFilterSummaryComponent as λ5, SkyInfiniteScrollComponent as λ6, SkyPagingComponent as λ7, SkyRepeaterItemContentComponent as λ8, SkyRepeaterItemContextMenuComponent as λ9 };
1980
2030
  //# sourceMappingURL=skyux-lists.mjs.map