@skyux/lists 5.7.0 → 6.0.0-beta.1
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/documentation.json +1 -1
- package/esm2020/index.mjs +22 -0
- package/esm2020/lib/modules/filter/filter-button.component.mjs +62 -0
- package/esm2020/lib/modules/filter/filter-inline-item.component.mjs +14 -0
- package/esm2020/lib/modules/filter/filter-inline.component.mjs +14 -0
- package/esm2020/lib/modules/filter/filter-summary-item.component.mjs +45 -0
- package/esm2020/lib/modules/filter/filter-summary.component.mjs +15 -0
- package/esm2020/lib/modules/filter/filter.module.mjs +61 -0
- package/esm2020/lib/modules/infinite-scroll/infinite-scroll-dom-adapter.service.mjs +93 -0
- package/esm2020/lib/modules/infinite-scroll/infinite-scroll.component.mjs +109 -0
- package/esm2020/lib/modules/infinite-scroll/infinite-scroll.module.mjs +20 -0
- package/esm2020/lib/modules/paging/paging.component.mjs +122 -0
- package/esm2020/lib/modules/paging/paging.module.mjs +34 -0
- package/esm2020/lib/modules/repeater/repeater-adapter.service.mjs +69 -0
- package/esm2020/lib/modules/repeater/repeater-item-content.component.mjs +14 -0
- package/esm2020/lib/modules/repeater/repeater-item-context-menu.component.mjs +17 -0
- package/esm2020/lib/modules/repeater/repeater-item-title.component.mjs +14 -0
- package/esm2020/lib/modules/repeater/repeater-item.component.mjs +383 -0
- package/esm2020/lib/modules/repeater/repeater.component.mjs +256 -0
- package/esm2020/lib/modules/repeater/repeater.module.mjs +69 -0
- package/esm2020/lib/modules/repeater/repeater.service.mjs +72 -0
- package/esm2020/lib/modules/shared/sky-lists-resources.module.mjs +80 -0
- package/esm2020/lib/modules/sort/sort-item.component.mjs +60 -0
- package/esm2020/lib/modules/sort/sort-menu-heading.component.mjs +13 -0
- package/esm2020/lib/modules/sort/sort.component.mjs +35 -0
- package/esm2020/lib/modules/sort/sort.module.mjs +50 -0
- package/esm2020/lib/modules/sort/sort.service.mjs +20 -0
- package/esm2020/skyux-lists.mjs +5 -0
- package/esm2020/testing/filter/filter-fixture-button.mjs +46 -0
- package/esm2020/testing/filter/filter-fixture-summary.mjs +28 -0
- package/esm2020/testing/filter/filter-testing.module.mjs +15 -0
- package/esm2020/testing/filter/lists-filter-fixture-button.mjs +2 -0
- package/esm2020/testing/infinite-scroll/infinite-scroll-fixture.mjs +27 -0
- package/esm2020/testing/infinite-scroll/infinite-scroll-testing.module.mjs +15 -0
- package/esm2020/testing/paging/paging-fixture-button.mjs +2 -0
- package/esm2020/testing/paging/paging-fixture.mjs +93 -0
- package/esm2020/testing/paging/paging-testing.module.mjs +15 -0
- package/esm2020/testing/public-api.mjs +13 -0
- package/esm2020/testing/skyux-lists-testing.mjs +5 -0
- package/esm2020/testing/sort/sort-fixture-menu-item.mjs +2 -0
- package/esm2020/testing/sort/sort-fixture-menu.mjs +2 -0
- package/esm2020/testing/sort/sort-fixture.mjs +140 -0
- package/esm2020/testing/sort/sort-testing.module.mjs +17 -0
- package/fesm2015/{skyux-lists-testing.js → skyux-lists-testing.mjs} +17 -17
- package/fesm2015/skyux-lists-testing.mjs.map +1 -0
- package/fesm2015/skyux-lists.mjs +1615 -0
- package/fesm2015/skyux-lists.mjs.map +1 -0
- package/fesm2020/skyux-lists-testing.mjs +389 -0
- package/fesm2020/skyux-lists-testing.mjs.map +1 -0
- package/fesm2020/skyux-lists.mjs +1615 -0
- package/fesm2020/skyux-lists.mjs.map +1 -0
- package/package.json +39 -18
- package/testing/package.json +5 -5
- package/bundles/skyux-lists-testing.umd.js +0 -887
- package/bundles/skyux-lists.umd.js +0 -2149
- package/esm2015/index.js +0 -22
- package/esm2015/index.js.map +0 -1
- package/esm2015/lib/modules/filter/filter-button.component.js +0 -67
- package/esm2015/lib/modules/filter/filter-button.component.js.map +0 -1
- package/esm2015/lib/modules/filter/filter-inline-item.component.js +0 -18
- package/esm2015/lib/modules/filter/filter-inline-item.component.js.map +0 -1
- package/esm2015/lib/modules/filter/filter-inline.component.js +0 -18
- package/esm2015/lib/modules/filter/filter-inline.component.js.map +0 -1
- package/esm2015/lib/modules/filter/filter-summary-item.component.js +0 -50
- package/esm2015/lib/modules/filter/filter-summary-item.component.js.map +0 -1
- package/esm2015/lib/modules/filter/filter-summary.component.js +0 -20
- package/esm2015/lib/modules/filter/filter-summary.component.js.map +0 -1
- package/esm2015/lib/modules/filter/filter.module.js +0 -61
- package/esm2015/lib/modules/filter/filter.module.js.map +0 -1
- package/esm2015/lib/modules/infinite-scroll/infinite-scroll-dom-adapter.service.js +0 -93
- package/esm2015/lib/modules/infinite-scroll/infinite-scroll-dom-adapter.service.js.map +0 -1
- package/esm2015/lib/modules/infinite-scroll/infinite-scroll.component.js +0 -115
- package/esm2015/lib/modules/infinite-scroll/infinite-scroll.component.js.map +0 -1
- package/esm2015/lib/modules/infinite-scroll/infinite-scroll.module.js +0 -20
- package/esm2015/lib/modules/infinite-scroll/infinite-scroll.module.js.map +0 -1
- package/esm2015/lib/modules/paging/paging.component.js +0 -127
- package/esm2015/lib/modules/paging/paging.component.js.map +0 -1
- package/esm2015/lib/modules/paging/paging.module.js +0 -34
- package/esm2015/lib/modules/paging/paging.module.js.map +0 -1
- package/esm2015/lib/modules/repeater/repeater-adapter.service.js +0 -69
- package/esm2015/lib/modules/repeater/repeater-adapter.service.js.map +0 -1
- package/esm2015/lib/modules/repeater/repeater-item-content.component.js +0 -17
- package/esm2015/lib/modules/repeater/repeater-item-content.component.js.map +0 -1
- package/esm2015/lib/modules/repeater/repeater-item-context-menu.component.js +0 -20
- package/esm2015/lib/modules/repeater/repeater-item-context-menu.component.js.map +0 -1
- package/esm2015/lib/modules/repeater/repeater-item-title.component.js +0 -17
- package/esm2015/lib/modules/repeater/repeater-item-title.component.js.map +0 -1
- package/esm2015/lib/modules/repeater/repeater-item.component.js +0 -389
- package/esm2015/lib/modules/repeater/repeater-item.component.js.map +0 -1
- package/esm2015/lib/modules/repeater/repeater.component.js +0 -262
- package/esm2015/lib/modules/repeater/repeater.component.js.map +0 -1
- package/esm2015/lib/modules/repeater/repeater.module.js +0 -69
- package/esm2015/lib/modules/repeater/repeater.module.js.map +0 -1
- package/esm2015/lib/modules/repeater/repeater.service.js +0 -72
- package/esm2015/lib/modules/repeater/repeater.service.js.map +0 -1
- package/esm2015/lib/modules/shared/sky-lists-resources.module.js +0 -80
- package/esm2015/lib/modules/shared/sky-lists-resources.module.js.map +0 -1
- package/esm2015/lib/modules/sort/sort-item.component.js +0 -65
- package/esm2015/lib/modules/sort/sort-item.component.js.map +0 -1
- package/esm2015/lib/modules/sort/sort-menu-heading.component.js +0 -17
- package/esm2015/lib/modules/sort/sort-menu-heading.component.js.map +0 -1
- package/esm2015/lib/modules/sort/sort.component.js +0 -41
- package/esm2015/lib/modules/sort/sort.component.js.map +0 -1
- package/esm2015/lib/modules/sort/sort.module.js +0 -50
- package/esm2015/lib/modules/sort/sort.module.js.map +0 -1
- package/esm2015/lib/modules/sort/sort.service.js +0 -20
- package/esm2015/lib/modules/sort/sort.service.js.map +0 -1
- package/esm2015/skyux-lists.js +0 -5
- package/esm2015/skyux-lists.js.map +0 -1
- package/esm2015/testing/filter/filter-fixture-button.js +0 -50
- package/esm2015/testing/filter/filter-fixture-button.js.map +0 -1
- package/esm2015/testing/filter/filter-fixture-summary.js +0 -31
- package/esm2015/testing/filter/filter-fixture-summary.js.map +0 -1
- package/esm2015/testing/filter/filter-testing.module.js +0 -15
- package/esm2015/testing/filter/filter-testing.module.js.map +0 -1
- package/esm2015/testing/filter/lists-filter-fixture-button.js +0 -2
- package/esm2015/testing/filter/lists-filter-fixture-button.js.map +0 -1
- package/esm2015/testing/infinite-scroll/infinite-scroll-fixture.js +0 -30
- package/esm2015/testing/infinite-scroll/infinite-scroll-fixture.js.map +0 -1
- package/esm2015/testing/infinite-scroll/infinite-scroll-testing.module.js +0 -15
- package/esm2015/testing/infinite-scroll/infinite-scroll-testing.module.js.map +0 -1
- package/esm2015/testing/paging/paging-fixture-button.js +0 -2
- package/esm2015/testing/paging/paging-fixture-button.js.map +0 -1
- package/esm2015/testing/paging/paging-fixture.js +0 -104
- package/esm2015/testing/paging/paging-fixture.js.map +0 -1
- package/esm2015/testing/paging/paging-testing.module.js +0 -15
- package/esm2015/testing/paging/paging-testing.module.js.map +0 -1
- package/esm2015/testing/public-api.js +0 -13
- package/esm2015/testing/public-api.js.map +0 -1
- package/esm2015/testing/skyux-lists-testing.js +0 -5
- package/esm2015/testing/skyux-lists-testing.js.map +0 -1
- package/esm2015/testing/sort/sort-fixture-menu-item.js +0 -2
- package/esm2015/testing/sort/sort-fixture-menu-item.js.map +0 -1
- package/esm2015/testing/sort/sort-fixture-menu.js +0 -2
- package/esm2015/testing/sort/sort-fixture-menu.js.map +0 -1
- package/esm2015/testing/sort/sort-fixture.js +0 -152
- package/esm2015/testing/sort/sort-fixture.js.map +0 -1
- package/esm2015/testing/sort/sort-testing.module.js +0 -17
- package/esm2015/testing/sort/sort-testing.module.js.map +0 -1
- package/fesm2015/skyux-lists-testing.js.map +0 -1
- package/fesm2015/skyux-lists.js +0 -1685
- package/fesm2015/skyux-lists.js.map +0 -1
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@skyux/indicators";
|
|
4
|
+
import * as i2 from "@angular/common";
|
|
5
|
+
import * as i3 from "@skyux/theme";
|
|
6
|
+
import * as i4 from "@skyux/i18n";
|
|
7
|
+
export class SkyPagingComponent {
|
|
8
|
+
constructor() {
|
|
9
|
+
/**
|
|
10
|
+
* Specifies the page number of the current page. Page numbers start at 1 and increment.
|
|
11
|
+
*/
|
|
12
|
+
this.currentPage = 1;
|
|
13
|
+
/**
|
|
14
|
+
* Specifies the total number of items across all pages.
|
|
15
|
+
*/
|
|
16
|
+
this.itemCount = 0;
|
|
17
|
+
/**
|
|
18
|
+
* Specifies the maximum number of pages to display in the pagination control.
|
|
19
|
+
*/
|
|
20
|
+
this.maxPages = 5;
|
|
21
|
+
/**
|
|
22
|
+
* Specifies the number of items to display per page.
|
|
23
|
+
*/
|
|
24
|
+
this.pageSize = 10;
|
|
25
|
+
/**
|
|
26
|
+
* Fires when the current page changes and emits the new current page.
|
|
27
|
+
*/
|
|
28
|
+
this.currentPageChange = new EventEmitter();
|
|
29
|
+
this.displayedPages = [];
|
|
30
|
+
this.pageCount = 0;
|
|
31
|
+
}
|
|
32
|
+
ngOnChanges(changes) {
|
|
33
|
+
this.setPage(this.currentPage);
|
|
34
|
+
}
|
|
35
|
+
setPage(pageNumber) {
|
|
36
|
+
const previousPage = this.currentPage;
|
|
37
|
+
this.setPageCount();
|
|
38
|
+
if (pageNumber < 1 || this.pageCount < 1) {
|
|
39
|
+
this.currentPage = 1;
|
|
40
|
+
}
|
|
41
|
+
else if (pageNumber > this.pageCount) {
|
|
42
|
+
this.currentPage = this.pageCount;
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
this.currentPage = pageNumber;
|
|
46
|
+
}
|
|
47
|
+
this.setDisplayedPages();
|
|
48
|
+
if (previousPage !== this.currentPage) {
|
|
49
|
+
this.currentPageChange.emit(this.currentPage);
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
nextPage() {
|
|
53
|
+
this.setPage(this.currentPage + 1);
|
|
54
|
+
}
|
|
55
|
+
previousPage() {
|
|
56
|
+
this.setPage(this.currentPage - 1);
|
|
57
|
+
}
|
|
58
|
+
get isPreviousButtonDisabled() {
|
|
59
|
+
return this.currentPage === 1;
|
|
60
|
+
}
|
|
61
|
+
get isNextButtonDisabled() {
|
|
62
|
+
return this.currentPage === this.pageCount;
|
|
63
|
+
}
|
|
64
|
+
getDisplayedPageNumbers(pageCount, maxDisplayedPages, pageNumber) {
|
|
65
|
+
const pageIndex = pageNumber - 1;
|
|
66
|
+
const pageBounds = Math.floor(maxDisplayedPages / 2);
|
|
67
|
+
let upperBound = pageIndex + pageBounds;
|
|
68
|
+
let lowerBound = pageIndex - pageBounds;
|
|
69
|
+
if (maxDisplayedPages % 2 !== 0) {
|
|
70
|
+
upperBound += 1;
|
|
71
|
+
}
|
|
72
|
+
// Wrap negative values to increase the upperbound
|
|
73
|
+
if (lowerBound < 0) {
|
|
74
|
+
upperBound -= lowerBound;
|
|
75
|
+
lowerBound = 0;
|
|
76
|
+
}
|
|
77
|
+
// Wrap overflow to decrease the lowerbound
|
|
78
|
+
if (upperBound > pageCount) {
|
|
79
|
+
lowerBound -= upperBound - pageCount;
|
|
80
|
+
upperBound = pageCount;
|
|
81
|
+
}
|
|
82
|
+
// If both are the same ignore everything else and just display it all
|
|
83
|
+
if (pageCount < maxDisplayedPages) {
|
|
84
|
+
lowerBound = 0;
|
|
85
|
+
upperBound = pageCount;
|
|
86
|
+
}
|
|
87
|
+
const displayedPageNumbers = [];
|
|
88
|
+
for (let i = lowerBound; i < upperBound; i++) {
|
|
89
|
+
displayedPageNumbers.push(i + 1);
|
|
90
|
+
}
|
|
91
|
+
return displayedPageNumbers;
|
|
92
|
+
}
|
|
93
|
+
setPageCount() {
|
|
94
|
+
if (this.itemCount === 0 || this.pageSize === 0) {
|
|
95
|
+
this.pageCount = 0;
|
|
96
|
+
return;
|
|
97
|
+
}
|
|
98
|
+
this.pageCount = Math.ceil(this.itemCount / this.pageSize);
|
|
99
|
+
}
|
|
100
|
+
setDisplayedPages() {
|
|
101
|
+
this.displayedPages = this.getDisplayedPageNumbers(this.pageCount, this.maxPages, this.currentPage);
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
SkyPagingComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyPagingComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
105
|
+
SkyPagingComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", 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\"></sky-icon>\n <sky-icon\n *skyThemeIf=\"'modern'\"\n icon=\"chevron-left\"\n iconType=\"skyux\"\n ></sky-icon>\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 [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\"></sky-icon>\n <sky-icon\n *skyThemeIf=\"'modern'\"\n icon=\"chevron-right\"\n iconType=\"skyux\"\n ></sky-icon>\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:#c1e8fb;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:#c1e8fb;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"], components: [{ type: i1.λ4, selector: "sky-icon", inputs: ["icon", "iconType", "size", "fixedWidth", "variant"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.λ3, selector: "[skyThemeIf]", inputs: ["skyThemeIf"] }, { type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], pipes: { "skyLibResources": i4.SkyLibResourcesPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
106
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyPagingComponent, decorators: [{
|
|
107
|
+
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\"></sky-icon>\n <sky-icon\n *skyThemeIf=\"'modern'\"\n icon=\"chevron-left\"\n iconType=\"skyux\"\n ></sky-icon>\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 [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\"></sky-icon>\n <sky-icon\n *skyThemeIf=\"'modern'\"\n icon=\"chevron-right\"\n iconType=\"skyux\"\n ></sky-icon>\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:#c1e8fb;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:#c1e8fb;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
|
+
}], propDecorators: { currentPage: [{
|
|
110
|
+
type: Input
|
|
111
|
+
}], itemCount: [{
|
|
112
|
+
type: Input
|
|
113
|
+
}], maxPages: [{
|
|
114
|
+
type: Input
|
|
115
|
+
}], pageSize: [{
|
|
116
|
+
type: Input
|
|
117
|
+
}], pagingLabel: [{
|
|
118
|
+
type: Input
|
|
119
|
+
}], currentPageChange: [{
|
|
120
|
+
type: Output
|
|
121
|
+
}] } });
|
|
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   * Specifies the page number of the current page. Page numbers start at 1 and increment.\n   */\n  @Input()\n  public currentPage = 1;\n\n  /**\n   * Specifies the total number of items across all pages.\n   */\n  @Input()\n  public itemCount = 0;\n\n  /**\n   * Specifies the maximum number of pages to display in the pagination control.\n   */\n  @Input()\n  public maxPages = 5;\n\n  /**\n   * Specifies the number of items to display per page.\n   */\n  @Input()\n  public pageSize = 10;\n\n  /**\n   * Specifies a 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;\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  private 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 upperbound\n    if (lowerBound < 0) {\n      upperBound -= lowerBound;\n      lowerBound = 0;\n    }\n    // Wrap overflow to decrease the lowerbound\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  private 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  private 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\"></sky-icon>\n        <sky-icon\n          *skyThemeIf=\"'modern'\"\n          icon=\"chevron-left\"\n          iconType=\"skyux\"\n        ></sky-icon>\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        [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\"></sky-icon>\n        <sky-icon\n          *skyThemeIf=\"'modern'\"\n          icon=\"chevron-right\"\n          iconType=\"skyux\"\n        ></sky-icon>\n      </button>\n    </li>\n  </ul>\n</nav>\n"]}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { NgModule } from '@angular/core';
|
|
3
|
+
import { SkyIconModule } from '@skyux/indicators';
|
|
4
|
+
import { SkyThemeModule } from '@skyux/theme';
|
|
5
|
+
import { SkyListsResourcesModule } from '../shared/sky-lists-resources.module';
|
|
6
|
+
import { SkyPagingComponent } from './paging.component';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
export class SkyPagingModule {
|
|
9
|
+
}
|
|
10
|
+
SkyPagingModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyPagingModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
11
|
+
SkyPagingModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyPagingModule, declarations: [SkyPagingComponent], imports: [CommonModule,
|
|
12
|
+
SkyIconModule,
|
|
13
|
+
SkyListsResourcesModule,
|
|
14
|
+
SkyThemeModule], exports: [SkyPagingComponent] });
|
|
15
|
+
SkyPagingModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyPagingModule, imports: [[
|
|
16
|
+
CommonModule,
|
|
17
|
+
SkyIconModule,
|
|
18
|
+
SkyListsResourcesModule,
|
|
19
|
+
SkyThemeModule,
|
|
20
|
+
]] });
|
|
21
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyPagingModule, decorators: [{
|
|
22
|
+
type: NgModule,
|
|
23
|
+
args: [{
|
|
24
|
+
declarations: [SkyPagingComponent],
|
|
25
|
+
imports: [
|
|
26
|
+
CommonModule,
|
|
27
|
+
SkyIconModule,
|
|
28
|
+
SkyListsResourcesModule,
|
|
29
|
+
SkyThemeModule,
|
|
30
|
+
],
|
|
31
|
+
exports: [SkyPagingComponent],
|
|
32
|
+
}]
|
|
33
|
+
}] });
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnaW5nLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9saXN0cy9zcmMvbGliL21vZHVsZXMvcGFnaW5nL3BhZ2luZy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ2xELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFFOUMsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFFL0UsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7O0FBWXhELE1BQU0sT0FBTyxlQUFlOzs0R0FBZixlQUFlOzZHQUFmLGVBQWUsaUJBVFgsa0JBQWtCLGFBRS9CLFlBQVk7UUFDWixhQUFhO1FBQ2IsdUJBQXVCO1FBQ3ZCLGNBQWMsYUFFTixrQkFBa0I7NkdBRWpCLGVBQWUsWUFSakI7WUFDUCxZQUFZO1lBQ1osYUFBYTtZQUNiLHVCQUF1QjtZQUN2QixjQUFjO1NBQ2Y7MkZBR1UsZUFBZTtrQkFWM0IsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQztvQkFDbEMsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osYUFBYTt3QkFDYix1QkFBdUI7d0JBQ3ZCLGNBQWM7cUJBQ2Y7b0JBQ0QsT0FBTyxFQUFFLENBQUMsa0JBQWtCLENBQUM7aUJBQzlCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTa3lJY29uTW9kdWxlIH0gZnJvbSAnQHNreXV4L2luZGljYXRvcnMnO1xuaW1wb3J0IHsgU2t5VGhlbWVNb2R1bGUgfSBmcm9tICdAc2t5dXgvdGhlbWUnO1xuXG5pbXBvcnQgeyBTa3lMaXN0c1Jlc291cmNlc01vZHVsZSB9IGZyb20gJy4uL3NoYXJlZC9za3ktbGlzdHMtcmVzb3VyY2VzLm1vZHVsZSc7XG5cbmltcG9ydCB7IFNreVBhZ2luZ0NvbXBvbmVudCB9IGZyb20gJy4vcGFnaW5nLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW1NreVBhZ2luZ0NvbXBvbmVudF0sXG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgU2t5SWNvbk1vZHVsZSxcbiAgICBTa3lMaXN0c1Jlc291cmNlc01vZHVsZSxcbiAgICBTa3lUaGVtZU1vZHVsZSxcbiAgXSxcbiAgZXhwb3J0czogW1NreVBhZ2luZ0NvbXBvbmVudF0sXG59KVxuZXhwb3J0IGNsYXNzIFNreVBhZ2luZ01vZHVsZSB7fVxuIl19
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
import { ElementRef, Injectable } from '@angular/core';
|
|
2
|
+
import { SkyRepeaterService } from './repeater.service';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "./repeater.service";
|
|
5
|
+
/**
|
|
6
|
+
* @internal
|
|
7
|
+
*/
|
|
8
|
+
export class SkyRepeaterAdapterService {
|
|
9
|
+
constructor(repeaterService) {
|
|
10
|
+
this.repeaterService = repeaterService;
|
|
11
|
+
}
|
|
12
|
+
get repeaterItemGroupSelector() {
|
|
13
|
+
return '.sky-repeater-item-group-' + this.repeaterService.repeaterGroupId;
|
|
14
|
+
}
|
|
15
|
+
focusElement(element) {
|
|
16
|
+
if (element instanceof ElementRef) {
|
|
17
|
+
element.nativeElement.focus();
|
|
18
|
+
}
|
|
19
|
+
else {
|
|
20
|
+
element.focus();
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
setRepeaterHost(hostRef) {
|
|
24
|
+
this.host = hostRef;
|
|
25
|
+
}
|
|
26
|
+
getRepeaterItemIndex(element) {
|
|
27
|
+
return this.getRepeaterItemArray().indexOf(element);
|
|
28
|
+
}
|
|
29
|
+
moveItemUp(element, top = false, steps = 1) {
|
|
30
|
+
const index = this.getRepeaterItemIndex(element);
|
|
31
|
+
if (index === 0) {
|
|
32
|
+
return;
|
|
33
|
+
}
|
|
34
|
+
let newIndex = index - steps;
|
|
35
|
+
if (top || newIndex < 0) {
|
|
36
|
+
newIndex = 0;
|
|
37
|
+
}
|
|
38
|
+
return this.moveItem(element, index, newIndex);
|
|
39
|
+
}
|
|
40
|
+
moveItemDown(element, steps = 1) {
|
|
41
|
+
const itemArray = this.getRepeaterItemArray();
|
|
42
|
+
const index = this.getRepeaterItemIndex(element);
|
|
43
|
+
if (index === itemArray.length - steps) {
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
46
|
+
const newIndex = index + steps;
|
|
47
|
+
return this.moveItem(element, index, newIndex);
|
|
48
|
+
}
|
|
49
|
+
moveItem(element, oldIndex, newIndex) {
|
|
50
|
+
const repeaterDiv = this.host.nativeElement.querySelector('.sky-repeater');
|
|
51
|
+
repeaterDiv.removeChild(element);
|
|
52
|
+
const nextSibling = repeaterDiv.querySelectorAll(this.repeaterItemGroupSelector)[newIndex];
|
|
53
|
+
repeaterDiv.insertBefore(element, nextSibling);
|
|
54
|
+
this.repeaterService.reorderItem(oldIndex, newIndex);
|
|
55
|
+
return newIndex;
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* Returns an array of the immediate repeater item descendants. Excludes nested repeater items.
|
|
59
|
+
*/
|
|
60
|
+
getRepeaterItemArray() {
|
|
61
|
+
return Array.from(this.host.nativeElement.querySelectorAll(this.repeaterItemGroupSelector));
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
SkyRepeaterAdapterService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyRepeaterAdapterService, deps: [{ token: i1.SkyRepeaterService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
65
|
+
SkyRepeaterAdapterService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyRepeaterAdapterService });
|
|
66
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyRepeaterAdapterService, decorators: [{
|
|
67
|
+
type: Injectable
|
|
68
|
+
}], ctorParameters: function () { return [{ type: i1.SkyRepeaterService }]; } });
|
|
69
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVwZWF0ZXItYWRhcHRlci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2xpc3RzL3NyYy9saWIvbW9kdWxlcy9yZXBlYXRlci9yZXBlYXRlci1hZGFwdGVyLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFdkQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7OztBQUV4RDs7R0FFRztBQUVILE1BQU0sT0FBTyx5QkFBeUI7SUFPcEMsWUFBb0IsZUFBbUM7UUFBbkMsb0JBQWUsR0FBZixlQUFlLENBQW9CO0lBQUcsQ0FBQztJQU4zRCxJQUFZLHlCQUF5QjtRQUNuQyxPQUFPLDJCQUEyQixHQUFHLElBQUksQ0FBQyxlQUFlLENBQUMsZUFBZSxDQUFDO0lBQzVFLENBQUM7SUFNTSxZQUFZLENBQUMsT0FBaUM7UUFDbkQsSUFBSSxPQUFPLFlBQVksVUFBVSxFQUFFO1lBQ2pDLE9BQU8sQ0FBQyxhQUFhLENBQUMsS0FBSyxFQUFFLENBQUM7U0FDL0I7YUFBTTtZQUNMLE9BQU8sQ0FBQyxLQUFLLEVBQUUsQ0FBQztTQUNqQjtJQUNILENBQUM7SUFFTSxlQUFlLENBQUMsT0FBbUI7UUFDeEMsSUFBSSxDQUFDLElBQUksR0FBRyxPQUFPLENBQUM7SUFDdEIsQ0FBQztJQUVNLG9CQUFvQixDQUFDLE9BQW9CO1FBQzlDLE9BQU8sSUFBSSxDQUFDLG9CQUFvQixFQUFFLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ3RELENBQUM7SUFFTSxVQUFVLENBQUMsT0FBb0IsRUFBRSxHQUFHLEdBQUcsS0FBSyxFQUFFLEtBQUssR0FBRyxDQUFDO1FBQzVELE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUVqRCxJQUFJLEtBQUssS0FBSyxDQUFDLEVBQUU7WUFDZixPQUFPO1NBQ1I7UUFFRCxJQUFJLFFBQVEsR0FBRyxLQUFLLEdBQUcsS0FBSyxDQUFDO1FBRTdCLElBQUksR0FBRyxJQUFJLFFBQVEsR0FBRyxDQUFDLEVBQUU7WUFDdkIsUUFBUSxHQUFHLENBQUMsQ0FBQztTQUNkO1FBRUQsT0FBTyxJQUFJLENBQUMsUUFBUSxDQUFDLE9BQU8sRUFBRSxLQUFLLEVBQUUsUUFBUSxDQUFDLENBQUM7SUFDakQsQ0FBQztJQUVNLFlBQVksQ0FBQyxPQUFvQixFQUFFLEtBQUssR0FBRyxDQUFDO1FBQ2pELE1BQU0sU0FBUyxHQUFHLElBQUksQ0FBQyxvQkFBb0IsRUFBRSxDQUFDO1FBQzlDLE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUVqRCxJQUFJLEtBQUssS0FBSyxTQUFTLENBQUMsTUFBTSxHQUFHLEtBQUssRUFBRTtZQUN0QyxPQUFPO1NBQ1I7UUFFRCxNQUFNLFFBQVEsR0FBRyxLQUFLLEdBQUcsS0FBSyxDQUFDO1FBRS9CLE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQyxPQUFPLEVBQUUsS0FBSyxFQUFFLFFBQVEsQ0FBQyxDQUFDO0lBQ2pELENBQUM7SUFFTyxRQUFRLENBQ2QsT0FBb0IsRUFDcEIsUUFBZ0IsRUFDaEIsUUFBZ0I7UUFFaEIsTUFBTSxXQUFXLEdBQ2YsSUFBSSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsYUFBYSxDQUFDLGVBQWUsQ0FBQyxDQUFDO1FBRXpELFdBQVcsQ0FBQyxXQUFXLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDakMsTUFBTSxXQUFXLEdBQUcsV0FBVyxDQUFDLGdCQUFnQixDQUM5QyxJQUFJLENBQUMseUJBQXlCLENBQy9CLENBQUMsUUFBUSxDQUFDLENBQUM7UUFFWixXQUFXLENBQUMsWUFBWSxDQUFDLE9BQU8sRUFBRSxXQUFXLENBQUMsQ0FBQztRQUMvQyxJQUFJLENBQUMsZUFBZSxDQUFDLFdBQVcsQ0FBQyxRQUFRLEVBQUUsUUFBUSxDQUFDLENBQUM7UUFFckQsT0FBTyxRQUFRLENBQUM7SUFDbEIsQ0FBQztJQUVEOztPQUVHO0lBQ0ssb0JBQW9CO1FBQzFCLE9BQU8sS0FBSyxDQUFDLElBQUksQ0FDZixJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMseUJBQXlCLENBQUMsQ0FDekUsQ0FBQztJQUNKLENBQUM7O3NIQWhGVSx5QkFBeUI7MEhBQXpCLHlCQUF5QjsyRkFBekIseUJBQXlCO2tCQURyQyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRWxlbWVudFJlZiwgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBTa3lSZXBlYXRlclNlcnZpY2UgfSBmcm9tICcuL3JlcGVhdGVyLnNlcnZpY2UnO1xuXG4vKipcbiAqIEBpbnRlcm5hbFxuICovXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgU2t5UmVwZWF0ZXJBZGFwdGVyU2VydmljZSB7XG4gIHByaXZhdGUgZ2V0IHJlcGVhdGVySXRlbUdyb3VwU2VsZWN0b3IoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gJy5za3ktcmVwZWF0ZXItaXRlbS1ncm91cC0nICsgdGhpcy5yZXBlYXRlclNlcnZpY2UucmVwZWF0ZXJHcm91cElkO1xuICB9XG5cbiAgcHJpdmF0ZSBob3N0OiBFbGVtZW50UmVmO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVwZWF0ZXJTZXJ2aWNlOiBTa3lSZXBlYXRlclNlcnZpY2UpIHt9XG5cbiAgcHVibGljIGZvY3VzRWxlbWVudChlbGVtZW50OiBFbGVtZW50UmVmIHwgSFRNTEVsZW1lbnQpOiB2b2lkIHtcbiAgICBpZiAoZWxlbWVudCBpbnN0YW5jZW9mIEVsZW1lbnRSZWYpIHtcbiAgICAgIGVsZW1lbnQubmF0aXZlRWxlbWVudC5mb2N1cygpO1xuICAgIH0gZWxzZSB7XG4gICAgICBlbGVtZW50LmZvY3VzKCk7XG4gICAgfVxuICB9XG5cbiAgcHVibGljIHNldFJlcGVhdGVySG9zdChob3N0UmVmOiBFbGVtZW50UmVmKTogdm9pZCB7XG4gICAgdGhpcy5ob3N0ID0gaG9zdFJlZjtcbiAgfVxuXG4gIHB1YmxpYyBnZXRSZXBlYXRlckl0ZW1JbmRleChlbGVtZW50OiBIVE1MRWxlbWVudCk6IG51bWJlciB7XG4gICAgcmV0dXJuIHRoaXMuZ2V0UmVwZWF0ZXJJdGVtQXJyYXkoKS5pbmRleE9mKGVsZW1lbnQpO1xuICB9XG5cbiAgcHVibGljIG1vdmVJdGVtVXAoZWxlbWVudDogSFRNTEVsZW1lbnQsIHRvcCA9IGZhbHNlLCBzdGVwcyA9IDEpOiBudW1iZXIge1xuICAgIGNvbnN0IGluZGV4ID0gdGhpcy5nZXRSZXBlYXRlckl0ZW1JbmRleChlbGVtZW50KTtcblxuICAgIGlmIChpbmRleCA9PT0gMCkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGxldCBuZXdJbmRleCA9IGluZGV4IC0gc3RlcHM7XG5cbiAgICBpZiAodG9wIHx8IG5ld0luZGV4IDwgMCkge1xuICAgICAgbmV3SW5kZXggPSAwO1xuICAgIH1cblxuICAgIHJldHVybiB0aGlzLm1vdmVJdGVtKGVsZW1lbnQsIGluZGV4LCBuZXdJbmRleCk7XG4gIH1cblxuICBwdWJsaWMgbW92ZUl0ZW1Eb3duKGVsZW1lbnQ6IEhUTUxFbGVtZW50LCBzdGVwcyA9IDEpOiBudW1iZXIge1xuICAgIGNvbnN0IGl0ZW1BcnJheSA9IHRoaXMuZ2V0UmVwZWF0ZXJJdGVtQXJyYXkoKTtcbiAgICBjb25zdCBpbmRleCA9IHRoaXMuZ2V0UmVwZWF0ZXJJdGVtSW5kZXgoZWxlbWVudCk7XG5cbiAgICBpZiAoaW5kZXggPT09IGl0ZW1BcnJheS5sZW5ndGggLSBzdGVwcykge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGNvbnN0IG5ld0luZGV4ID0gaW5kZXggKyBzdGVwcztcblxuICAgIHJldHVybiB0aGlzLm1vdmVJdGVtKGVsZW1lbnQsIGluZGV4LCBuZXdJbmRleCk7XG4gIH1cblxuICBwcml2YXRlIG1vdmVJdGVtKFxuICAgIGVsZW1lbnQ6IEhUTUxFbGVtZW50LFxuICAgIG9sZEluZGV4OiBudW1iZXIsXG4gICAgbmV3SW5kZXg6IG51bWJlclxuICApOiBudW1iZXIge1xuICAgIGNvbnN0IHJlcGVhdGVyRGl2OiBIVE1MRWxlbWVudCA9XG4gICAgICB0aGlzLmhvc3QubmF0aXZlRWxlbWVudC5xdWVyeVNlbGVjdG9yKCcuc2t5LXJlcGVhdGVyJyk7XG5cbiAgICByZXBlYXRlckRpdi5yZW1vdmVDaGlsZChlbGVtZW50KTtcbiAgICBjb25zdCBuZXh0U2libGluZyA9IHJlcGVhdGVyRGl2LnF1ZXJ5U2VsZWN0b3JBbGwoXG4gICAgICB0aGlzLnJlcGVhdGVySXRlbUdyb3VwU2VsZWN0b3JcbiAgICApW25ld0luZGV4XTtcblxuICAgIHJlcGVhdGVyRGl2Lmluc2VydEJlZm9yZShlbGVtZW50LCBuZXh0U2libGluZyk7XG4gICAgdGhpcy5yZXBlYXRlclNlcnZpY2UucmVvcmRlckl0ZW0ob2xkSW5kZXgsIG5ld0luZGV4KTtcblxuICAgIHJldHVybiBuZXdJbmRleDtcbiAgfVxuXG4gIC8qKlxuICAgKiBSZXR1cm5zIGFuIGFycmF5IG9mIHRoZSBpbW1lZGlhdGUgcmVwZWF0ZXIgaXRlbSBkZXNjZW5kYW50cy4gRXhjbHVkZXMgbmVzdGVkIHJlcGVhdGVyIGl0ZW1zLlxuICAgKi9cbiAgcHJpdmF0ZSBnZXRSZXBlYXRlckl0ZW1BcnJheSgpIHtcbiAgICByZXR1cm4gQXJyYXkuZnJvbShcbiAgICAgIHRoaXMuaG9zdC5uYXRpdmVFbGVtZW50LnF1ZXJ5U2VsZWN0b3JBbGwodGhpcy5yZXBlYXRlckl0ZW1Hcm91cFNlbGVjdG9yKVxuICAgICk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Component } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
/**
|
|
4
|
+
* Displays content text when the repeater is expanded.
|
|
5
|
+
*/
|
|
6
|
+
export class SkyRepeaterItemContentComponent {
|
|
7
|
+
}
|
|
8
|
+
SkyRepeaterItemContentComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyRepeaterItemContentComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
9
|
+
SkyRepeaterItemContentComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: SkyRepeaterItemContentComponent, selector: "sky-repeater-item-content", ngImport: i0, template: "<ng-content></ng-content>\n" });
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyRepeaterItemContentComponent, decorators: [{
|
|
11
|
+
type: Component,
|
|
12
|
+
args: [{ selector: 'sky-repeater-item-content', template: "<ng-content></ng-content>\n" }]
|
|
13
|
+
}] });
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVwZWF0ZXItaXRlbS1jb250ZW50LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9saXN0cy9zcmMvbGliL21vZHVsZXMvcmVwZWF0ZXIvcmVwZWF0ZXItaXRlbS1jb250ZW50LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9saXN0cy9zcmMvbGliL21vZHVsZXMvcmVwZWF0ZXIvcmVwZWF0ZXItaXRlbS1jb250ZW50LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBRTFDOztHQUVHO0FBS0gsTUFBTSxPQUFPLCtCQUErQjs7NEhBQS9CLCtCQUErQjtnSEFBL0IsK0JBQStCLGlFQ1Q1Qyw2QkFDQTsyRkRRYSwrQkFBK0I7a0JBSjNDLFNBQVM7K0JBQ0UsMkJBQTJCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbi8qKlxuICogRGlzcGxheXMgY29udGVudCB0ZXh0IHdoZW4gdGhlIHJlcGVhdGVyIGlzIGV4cGFuZGVkLlxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdza3ktcmVwZWF0ZXItaXRlbS1jb250ZW50JyxcbiAgdGVtcGxhdGVVcmw6ICcuL3JlcGVhdGVyLWl0ZW0tY29udGVudC5jb21wb25lbnQuaHRtbCcsXG59KVxuZXhwb3J0IGNsYXNzIFNreVJlcGVhdGVySXRlbUNvbnRlbnRDb21wb25lbnQge31cbiIsIjxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiJdfQ==
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { Component } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
/**
|
|
4
|
+
* Wraps and styles a
|
|
5
|
+
* [`skyux-dropdown` component](https://developer.blackbaud.com/skyux-popovers/docs/dropdown).
|
|
6
|
+
*/
|
|
7
|
+
/* istanbul ignore next */
|
|
8
|
+
/* Code coverage having problems with no statements in classes */
|
|
9
|
+
export class SkyRepeaterItemContextMenuComponent {
|
|
10
|
+
}
|
|
11
|
+
SkyRepeaterItemContextMenuComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyRepeaterItemContextMenuComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
12
|
+
SkyRepeaterItemContextMenuComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: SkyRepeaterItemContextMenuComponent, selector: "sky-repeater-item-context-menu", ngImport: i0, template: "<ng-content></ng-content>\n" });
|
|
13
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyRepeaterItemContextMenuComponent, decorators: [{
|
|
14
|
+
type: Component,
|
|
15
|
+
args: [{ selector: 'sky-repeater-item-context-menu', template: "<ng-content></ng-content>\n" }]
|
|
16
|
+
}] });
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVwZWF0ZXItaXRlbS1jb250ZXh0LW1lbnUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2xpc3RzL3NyYy9saWIvbW9kdWxlcy9yZXBlYXRlci9yZXBlYXRlci1pdGVtLWNvbnRleHQtbWVudS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbGlzdHMvc3JjL2xpYi9tb2R1bGVzL3JlcGVhdGVyL3JlcGVhdGVyLWl0ZW0tY29udGV4dC1tZW51LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBRTFDOzs7R0FHRztBQUtILDBCQUEwQjtBQUMxQixpRUFBaUU7QUFDakUsTUFBTSxPQUFPLG1DQUFtQzs7Z0lBQW5DLG1DQUFtQztvSEFBbkMsbUNBQW1DLHNFQ1poRCw2QkFDQTsyRkRXYSxtQ0FBbUM7a0JBTi9DLFNBQVM7K0JBQ0UsZ0NBQWdDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbi8qKlxuICogV3JhcHMgYW5kIHN0eWxlcyBhXG4gKiBbYHNreXV4LWRyb3Bkb3duYCBjb21wb25lbnRdKGh0dHBzOi8vZGV2ZWxvcGVyLmJsYWNrYmF1ZC5jb20vc2t5dXgtcG9wb3ZlcnMvZG9jcy9kcm9wZG93bikuXG4gKi9cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3NreS1yZXBlYXRlci1pdGVtLWNvbnRleHQtbWVudScsXG4gIHRlbXBsYXRlVXJsOiAnLi9yZXBlYXRlci1pdGVtLWNvbnRleHQtbWVudS5jb21wb25lbnQuaHRtbCcsXG59KVxuLyogaXN0YW5idWwgaWdub3JlIG5leHQgKi9cbi8qIENvZGUgY292ZXJhZ2UgaGF2aW5nIHByb2JsZW1zIHdpdGggbm8gc3RhdGVtZW50cyBpbiBjbGFzc2VzICovXG5leHBvcnQgY2xhc3MgU2t5UmVwZWF0ZXJJdGVtQ29udGV4dE1lbnVDb21wb25lbnQge31cbiIsIjxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiJdfQ==
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Component } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
/**
|
|
4
|
+
* Displays a header inside the repeater item.
|
|
5
|
+
*/
|
|
6
|
+
export class SkyRepeaterItemTitleComponent {
|
|
7
|
+
}
|
|
8
|
+
SkyRepeaterItemTitleComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyRepeaterItemTitleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
9
|
+
SkyRepeaterItemTitleComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: SkyRepeaterItemTitleComponent, selector: "sky-repeater-item-title", ngImport: i0, template: "<ng-content></ng-content>\n" });
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyRepeaterItemTitleComponent, decorators: [{
|
|
11
|
+
type: Component,
|
|
12
|
+
args: [{ selector: 'sky-repeater-item-title', template: "<ng-content></ng-content>\n" }]
|
|
13
|
+
}] });
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVwZWF0ZXItaXRlbS10aXRsZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbGlzdHMvc3JjL2xpYi9tb2R1bGVzL3JlcGVhdGVyL3JlcGVhdGVyLWl0ZW0tdGl0bGUuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2xpc3RzL3NyYy9saWIvbW9kdWxlcy9yZXBlYXRlci9yZXBlYXRlci1pdGVtLXRpdGxlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBRTFDOztHQUVHO0FBS0gsTUFBTSxPQUFPLDZCQUE2Qjs7MEhBQTdCLDZCQUE2Qjs4R0FBN0IsNkJBQTZCLCtEQ1QxQyw2QkFDQTsyRkRRYSw2QkFBNkI7a0JBSnpDLFNBQVM7K0JBQ0UseUJBQXlCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbi8qKlxuICogRGlzcGxheXMgYSBoZWFkZXIgaW5zaWRlIHRoZSByZXBlYXRlciBpdGVtLlxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdza3ktcmVwZWF0ZXItaXRlbS10aXRsZScsXG4gIHRlbXBsYXRlVXJsOiAnLi9yZXBlYXRlci1pdGVtLXRpdGxlLmNvbXBvbmVudC5odG1sJyxcbn0pXG5leHBvcnQgY2xhc3MgU2t5UmVwZWF0ZXJJdGVtVGl0bGVDb21wb25lbnQge31cbiIsIjxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiJdfQ==
|