@villedemontreal/angular-ui 17.0.0 → 17.1.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.
@@ -0,0 +1,217 @@
1
+ /*
2
+ * Copyright (c) 2025 Ville de Montreal. All rights reserved.
3
+ * Licensed under the MIT license.
4
+ * See LICENSE file in the project root for full license information.
5
+ */
6
+ import { Component, EventEmitter, Input, Output, ViewEncapsulation } from '@angular/core';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "@angular/common";
9
+ import * as i2 from "../icon/icon.component";
10
+ import * as i3 from "@angular/forms";
11
+ export class BaoPaginationComponent {
12
+ constructor(cdr) {
13
+ this.cdr = cdr;
14
+ /**
15
+ * The number of items per page as selected.
16
+ */
17
+ this.itemsPerPage = 10;
18
+ /**
19
+ * The current page number.
20
+ */
21
+ this.currentPage = 1;
22
+ /**
23
+ * The different page size options.
24
+ */
25
+ this.pageSizeOptions = [10, 25, 50, 100];
26
+ /**
27
+ * The label for the type of items that are displayed on the page
28
+ */
29
+ this.itemLabel = 'items';
30
+ /**
31
+ * If selector for number of items per page should be displayed or not
32
+ */
33
+ this.showItemsPerPageSelector = true;
34
+ /**
35
+ * EventEmitter that triggers when there is a page change and emits page number (index adjusted)
36
+ */
37
+ this.pageChanged = new EventEmitter();
38
+ /**
39
+ * EventEmitter that triggers when the number of items per page is changed.
40
+ */
41
+ this.itemsPerPageChanged = new EventEmitter();
42
+ /**
43
+ * Max number of pages to display
44
+ */
45
+ this._maxPages = 5;
46
+ this.displayedPages = [];
47
+ }
48
+ get totalPages() {
49
+ return this._totalPages;
50
+ }
51
+ set totalPages(value) {
52
+ this._totalPages = value;
53
+ }
54
+ get startItem() {
55
+ return this._startItem;
56
+ }
57
+ set startItem(value) {
58
+ this._startItem = value;
59
+ }
60
+ get endItem() {
61
+ return this._endItem;
62
+ }
63
+ set endItem(value) {
64
+ this._endItem = value;
65
+ }
66
+ get rangeLabel() {
67
+ return `${this.startItem} à ${this.endItem} sur ${this.totalItems} ${this.itemLabel}`;
68
+ }
69
+ /**
70
+ * Flag that indicates if a previous page exists for the current list
71
+ */
72
+ get hasPrevious() {
73
+ return this.currentPage !== 1;
74
+ }
75
+ /**
76
+ * Flag that indicates if a next page exists for the current list
77
+ */
78
+ get hasNext() {
79
+ return this.currentPage < this.totalPages;
80
+ }
81
+ ngOnInit() {
82
+ this.startItem = this.updateStartItem();
83
+ this.endItem = this.updateEndItem();
84
+ this.totalPages = this.updateTotalPages();
85
+ this.displayedPages = this.buildPageNumbers();
86
+ this.cdr.detectChanges();
87
+ }
88
+ /**
89
+ * Update list of displayed pages when current page is changed.
90
+ */
91
+ ngOnChanges(changes) {
92
+ if (changes.hasOwnProperty('currentPage')) {
93
+ this.displayedPages = this.buildPageNumbers();
94
+ }
95
+ if (changes.hasOwnProperty('totalItems')) {
96
+ this.startItem = this.updateStartItem();
97
+ this.endItem = this.updateEndItem();
98
+ this.totalPages = this.updateTotalPages();
99
+ this.displayedPages = this.buildPageNumbers();
100
+ }
101
+ }
102
+ /**
103
+ * Navigate to specific page
104
+ */
105
+ goTo(page) {
106
+ this.currentPage = page;
107
+ this.startItem = this.updateStartItem();
108
+ this.endItem = this.updateEndItem();
109
+ this.displayedPages = this.buildPageNumbers();
110
+ this.pageChanged.emit(page - 1);
111
+ }
112
+ /**
113
+ * Navigate to previous page
114
+ */
115
+ handlePreviousClick() {
116
+ if (this.hasPrevious) {
117
+ this.goTo(this.currentPage - 1);
118
+ }
119
+ }
120
+ /**
121
+ * Navigate to next page
122
+ */
123
+ handleNextClick() {
124
+ if (this.hasNext) {
125
+ this.goTo(this.currentPage + 1);
126
+ }
127
+ }
128
+ /**
129
+ * Update all required variables whenever the number of items displayed per page is changed.
130
+ * @param value New amount of items per page
131
+ */
132
+ handlePageSizeChange(value) {
133
+ this.currentPage = 1;
134
+ this.startItem = this.updateStartItem();
135
+ this.endItem = this.updateEndItem();
136
+ this.totalPages = this.updateTotalPages();
137
+ this.displayedPages = this.buildPageNumbers();
138
+ this.itemsPerPageChanged.emit(value);
139
+ }
140
+ updateTotalPages() {
141
+ return Math.ceil(this.totalItems / this.itemsPerPage);
142
+ }
143
+ updateStartItem() {
144
+ const startItem = Math.min((this.currentPage - 1) * this.itemsPerPage + 1, Math.floor(this.totalItems / 10) * 10);
145
+ return startItem || 1;
146
+ }
147
+ updateEndItem() {
148
+ return Math.min(this.startItem + Number(this.itemsPerPage) - 1, this.totalItems);
149
+ }
150
+ /**
151
+ * Generate series of page numbers to display. The list always starts with page 1
152
+ * and ends with last page.
153
+ * Adds negative numbers for ellipsis.
154
+ */
155
+ buildPageNumbers() {
156
+ const pages = [];
157
+ // If total pages are 5 or less, include all pages
158
+ if (this.totalPages <= this._maxPages) {
159
+ for (let i = 1; i <= this.totalPages; i++) {
160
+ pages.push(i);
161
+ }
162
+ }
163
+ else {
164
+ pages.push(1);
165
+ // Determine middle pages
166
+ let middlePages = [];
167
+ if (this.currentPage <= 3) {
168
+ middlePages = [2, 3, 4, -1];
169
+ }
170
+ else if (this.currentPage >= this.totalPages - 2) {
171
+ middlePages = [
172
+ -1,
173
+ this.totalPages - 3,
174
+ this.totalPages - 2,
175
+ this.totalPages - 1
176
+ ];
177
+ }
178
+ else {
179
+ middlePages = [
180
+ -1,
181
+ this.currentPage - 1,
182
+ this.currentPage,
183
+ this.currentPage + 1,
184
+ -1
185
+ ];
186
+ }
187
+ pages.push(...middlePages);
188
+ pages.push(this.totalPages);
189
+ }
190
+ return pages;
191
+ }
192
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: BaoPaginationComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
193
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: BaoPaginationComponent, selector: "bao-pagination", inputs: { totalItems: "totalItems", itemsPerPage: "itemsPerPage", currentPage: "currentPage", pageSizeOptions: "pageSizeOptions", itemLabel: "itemLabel", showItemsPerPageSelector: "showItemsPerPageSelector" }, outputs: { pageChanged: "pageChanged", itemsPerPageChanged: "itemsPerPageChanged" }, host: { classAttribute: "bao-pagination" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"items-diplayed-controls\">\n <span class=\"range-display\">\n {{ rangeLabel }}\n </span>\n <div *ngIf=\"showItemsPerPageSelector\" class=\"items-per-page\">\n <label for=\"items-per-page-select\" class=\"select-label\"\n >Items par page\n </label>\n <select\n [(ngModel)]=\"itemsPerPage\"\n (ngModelChange)=\"handlePageSizeChange($event)\"\n name=\"items-per-page\"\n id=\"items-per-page-select\"\n class=\"dropdown-select\"\n >\n <option *ngFor=\"let size of pageSizeOptions\" [value]=\"size\">\n {{ size }}\n </option>\n </select>\n </div>\n</div>\n<nav aria-label=\"Pagination\" class=\"page-controls\">\n <ul>\n <li\n class=\"page-item\"\n [ngClass]=\"{ disabled: !hasPrevious }\"\n [attr.aria-disabled]=\"!hasPrevious ? 'true' : null\"\n >\n <a\n class=\"page-link\"\n (click)=\"$event.preventDefault(); handlePreviousClick()\"\n (keydown.enter)=\"$event.preventDefault(); handlePreviousClick()\"\n (keydown.space)=\"$event.preventDefault(); handlePreviousClick()\"\n tabindex=\"0\"\n >\n <bao-icon title=\"Page pr\u00E9c\u00E9dente\" svgIcon=\"icon-chevron-left\"></bao-icon\n ></a>\n </li>\n <li\n class=\"page-item\"\n *ngFor=\"let page of displayedPages\"\n [ngClass]=\"{ active: page === currentPage }\"\n [attr.aria-current]=\"page === currentPage ? 'page' : null\"\n >\n <ng-container *ngIf=\"page > 0; else ellipsis\">\n <span class=\"sr-only\">{{ page }}</span>\n <a\n class=\"page-link\"\n (click)=\"$event.preventDefault(); goTo(page)\"\n (keydown.enter)=\"$event.preventDefault(); goTo(page)\"\n (keydown.space)=\"$event.preventDefault(); goTo(page)\"\n tabindex=\"0\"\n >{{ page }}</a\n >\n </ng-container>\n <ng-template #ellipsis>\n <span class=\"page-link ellipsis\" aria-hidden=\"true\">...</span>\n </ng-template>\n </li>\n\n <li\n class=\"page-item\"\n [ngClass]=\"{ disabled: !hasNext }\"\n [attr.aria-disabled]=\"!hasNext ? 'true' : null\"\n >\n <a\n class=\"page-link\"\n (click)=\"$event.preventDefault(); handleNextClick()\"\n (keydown.enter)=\"$event.preventDefault(); handleNextClick()\"\n (keydown.space)=\"$event.preventDefault(); handleNextClick()\"\n tabindex=\"0\"\n >\n <bao-icon title=\"Page suivante\" svgIcon=\"icon-chevron-right\"></bao-icon\n ></a>\n </li>\n </ul>\n</nav>\n", styles: [".bao-container{padding-right:16px;padding-left:16px;margin-right:auto;margin-left:auto;width:100%}@media (min-width: 576px){.bao-container{max-width:576px}}@media (min-width: 768px){.bao-container{max-width:768px}}@media (min-width: 992px){.bao-container{max-width:992px}}@media (min-width: 1200px){.bao-container{max-width:1200px}}.bao-row{display:flex;flex-wrap:wrap;margin-right:-16px;margin-left:-16px}.bao-col-12,.bao-col-lg-7{position:relative;width:100%;padding-right:1rem;padding-left:1rem}@media (min-width: 992px){.bao-col-lg-7{flex:0 0 58.33333%;max-width:58.33333%}}.bao-pagination{display:flex;flex-direction:column;justify-content:center}@media (min-width: 768px){.bao-pagination{justify-content:flex-start}}.bao-pagination>.items-diplayed-controls{display:flex;flex-direction:column;justify-content:center;align-self:center}@media (min-width: 768px){.bao-pagination>.items-diplayed-controls{flex-direction:row;justify-content:space-between;align-self:auto;margin-bottom:1rem}}.bao-pagination>.items-diplayed-controls .range-display{font-weight:700;font-size:.875rem;line-height:1.25rem;margin-bottom:1rem}@media (min-width: 768px){.bao-pagination>.items-diplayed-controls .range-display{margin-bottom:0rem}}.bao-pagination>.items-diplayed-controls>.items-per-page{display:flex;align-items:baseline;margin-bottom:2rem}@media (min-width: 768px){.bao-pagination>.items-diplayed-controls>.items-per-page{margin-bottom:0rem}}.bao-pagination>.items-diplayed-controls>.items-per-page>.select-label{font-weight:700;font-size:.875rem;line-height:1.25rem;color:#637381;margin-right:1rem}.bao-pagination>.items-diplayed-controls>.items-per-page>.dropdown-select{background-color:#fff;border-radius:.25rem;border-color:#ced4da;border-style:solid;border-width:thin;padding:.4375rem 2.4375rem .4375rem .4375rem;font-weight:400;font-size:1rem;line-height:1.5rem;color:#212529;appearance:none;background:#fff url(\"data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3e%3cpath fill='%23adb2bd' d='M12 12.586l3.293-3.293a1 1 0 011.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 011.414-1.414L12 12.586z'/%3e%3c/svg%3e\") right .4375rem center/24px 24px no-repeat}.bao-pagination .page-controls{align-self:center}.bao-pagination .page-controls>ul{display:flex;padding-left:0;margin-bottom:0}.bao-pagination .page-controls>ul>.page-item.disabled>.page-link>.bao-icon{color:#adb2bd}.bao-pagination .page-controls>ul>.page-item>.page-link{border-style:none}.bao-pagination .page-controls>ul>.page-item.active>.page-link{background-color:#eefaf8;border:1px solid #097d6c;border-radius:.25rem}.bao-pagination .page-controls>ul>.page-item>.page-link{font-size:.875rem}.bao-pagination .page-controls>ul>.page-item>.page-link:focus{box-shadow:inset 0 0 0 2px #0079c4}.bao-pagination .page-controls>ul>.page-item>.ellipsis{font-weight:700}.bao-pagination .page-controls>ul>.page-item>.ellipsis:hover{background-color:#fff}\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.BaoIconComponent, selector: "bao-icon", inputs: ["color", "size", "svgIcon", "title"], exportAs: ["baoIcon"] }, { kind: "directive", type: i3.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i3.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i3.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], encapsulation: i0.ViewEncapsulation.None }); }
194
+ }
195
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: BaoPaginationComponent, decorators: [{
196
+ type: Component,
197
+ args: [{ selector: 'bao-pagination', encapsulation: ViewEncapsulation.None, host: {
198
+ class: 'bao-pagination'
199
+ }, template: "<div class=\"items-diplayed-controls\">\n <span class=\"range-display\">\n {{ rangeLabel }}\n </span>\n <div *ngIf=\"showItemsPerPageSelector\" class=\"items-per-page\">\n <label for=\"items-per-page-select\" class=\"select-label\"\n >Items par page\n </label>\n <select\n [(ngModel)]=\"itemsPerPage\"\n (ngModelChange)=\"handlePageSizeChange($event)\"\n name=\"items-per-page\"\n id=\"items-per-page-select\"\n class=\"dropdown-select\"\n >\n <option *ngFor=\"let size of pageSizeOptions\" [value]=\"size\">\n {{ size }}\n </option>\n </select>\n </div>\n</div>\n<nav aria-label=\"Pagination\" class=\"page-controls\">\n <ul>\n <li\n class=\"page-item\"\n [ngClass]=\"{ disabled: !hasPrevious }\"\n [attr.aria-disabled]=\"!hasPrevious ? 'true' : null\"\n >\n <a\n class=\"page-link\"\n (click)=\"$event.preventDefault(); handlePreviousClick()\"\n (keydown.enter)=\"$event.preventDefault(); handlePreviousClick()\"\n (keydown.space)=\"$event.preventDefault(); handlePreviousClick()\"\n tabindex=\"0\"\n >\n <bao-icon title=\"Page pr\u00E9c\u00E9dente\" svgIcon=\"icon-chevron-left\"></bao-icon\n ></a>\n </li>\n <li\n class=\"page-item\"\n *ngFor=\"let page of displayedPages\"\n [ngClass]=\"{ active: page === currentPage }\"\n [attr.aria-current]=\"page === currentPage ? 'page' : null\"\n >\n <ng-container *ngIf=\"page > 0; else ellipsis\">\n <span class=\"sr-only\">{{ page }}</span>\n <a\n class=\"page-link\"\n (click)=\"$event.preventDefault(); goTo(page)\"\n (keydown.enter)=\"$event.preventDefault(); goTo(page)\"\n (keydown.space)=\"$event.preventDefault(); goTo(page)\"\n tabindex=\"0\"\n >{{ page }}</a\n >\n </ng-container>\n <ng-template #ellipsis>\n <span class=\"page-link ellipsis\" aria-hidden=\"true\">...</span>\n </ng-template>\n </li>\n\n <li\n class=\"page-item\"\n [ngClass]=\"{ disabled: !hasNext }\"\n [attr.aria-disabled]=\"!hasNext ? 'true' : null\"\n >\n <a\n class=\"page-link\"\n (click)=\"$event.preventDefault(); handleNextClick()\"\n (keydown.enter)=\"$event.preventDefault(); handleNextClick()\"\n (keydown.space)=\"$event.preventDefault(); handleNextClick()\"\n tabindex=\"0\"\n >\n <bao-icon title=\"Page suivante\" svgIcon=\"icon-chevron-right\"></bao-icon\n ></a>\n </li>\n </ul>\n</nav>\n", styles: [".bao-container{padding-right:16px;padding-left:16px;margin-right:auto;margin-left:auto;width:100%}@media (min-width: 576px){.bao-container{max-width:576px}}@media (min-width: 768px){.bao-container{max-width:768px}}@media (min-width: 992px){.bao-container{max-width:992px}}@media (min-width: 1200px){.bao-container{max-width:1200px}}.bao-row{display:flex;flex-wrap:wrap;margin-right:-16px;margin-left:-16px}.bao-col-12,.bao-col-lg-7{position:relative;width:100%;padding-right:1rem;padding-left:1rem}@media (min-width: 992px){.bao-col-lg-7{flex:0 0 58.33333%;max-width:58.33333%}}.bao-pagination{display:flex;flex-direction:column;justify-content:center}@media (min-width: 768px){.bao-pagination{justify-content:flex-start}}.bao-pagination>.items-diplayed-controls{display:flex;flex-direction:column;justify-content:center;align-self:center}@media (min-width: 768px){.bao-pagination>.items-diplayed-controls{flex-direction:row;justify-content:space-between;align-self:auto;margin-bottom:1rem}}.bao-pagination>.items-diplayed-controls .range-display{font-weight:700;font-size:.875rem;line-height:1.25rem;margin-bottom:1rem}@media (min-width: 768px){.bao-pagination>.items-diplayed-controls .range-display{margin-bottom:0rem}}.bao-pagination>.items-diplayed-controls>.items-per-page{display:flex;align-items:baseline;margin-bottom:2rem}@media (min-width: 768px){.bao-pagination>.items-diplayed-controls>.items-per-page{margin-bottom:0rem}}.bao-pagination>.items-diplayed-controls>.items-per-page>.select-label{font-weight:700;font-size:.875rem;line-height:1.25rem;color:#637381;margin-right:1rem}.bao-pagination>.items-diplayed-controls>.items-per-page>.dropdown-select{background-color:#fff;border-radius:.25rem;border-color:#ced4da;border-style:solid;border-width:thin;padding:.4375rem 2.4375rem .4375rem .4375rem;font-weight:400;font-size:1rem;line-height:1.5rem;color:#212529;appearance:none;background:#fff url(\"data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3e%3cpath fill='%23adb2bd' d='M12 12.586l3.293-3.293a1 1 0 011.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 011.414-1.414L12 12.586z'/%3e%3c/svg%3e\") right .4375rem center/24px 24px no-repeat}.bao-pagination .page-controls{align-self:center}.bao-pagination .page-controls>ul{display:flex;padding-left:0;margin-bottom:0}.bao-pagination .page-controls>ul>.page-item.disabled>.page-link>.bao-icon{color:#adb2bd}.bao-pagination .page-controls>ul>.page-item>.page-link{border-style:none}.bao-pagination .page-controls>ul>.page-item.active>.page-link{background-color:#eefaf8;border:1px solid #097d6c;border-radius:.25rem}.bao-pagination .page-controls>ul>.page-item>.page-link{font-size:.875rem}.bao-pagination .page-controls>ul>.page-item>.page-link:focus{box-shadow:inset 0 0 0 2px #0079c4}.bao-pagination .page-controls>ul>.page-item>.ellipsis{font-weight:700}.bao-pagination .page-controls>ul>.page-item>.ellipsis:hover{background-color:#fff}\n"] }]
200
+ }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { totalItems: [{
201
+ type: Input
202
+ }], itemsPerPage: [{
203
+ type: Input
204
+ }], currentPage: [{
205
+ type: Input
206
+ }], pageSizeOptions: [{
207
+ type: Input
208
+ }], itemLabel: [{
209
+ type: Input
210
+ }], showItemsPerPageSelector: [{
211
+ type: Input
212
+ }], pageChanged: [{
213
+ type: Output
214
+ }], itemsPerPageChanged: [{
215
+ type: Output
216
+ }] } });
217
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pagination.component.js","sourceRoot":"","sources":["../../../../../projects/angular-ui/src/lib/pagination/pagination.component.ts","../../../../../projects/angular-ui/src/lib/pagination/pagination.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright (c) 2025 Ville de Montreal. All rights reserved.\n * Licensed under the MIT license.\n * See LICENSE file in the project root for full license information.\n */\nimport {\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges,\n  ViewEncapsulation\n} from '@angular/core';\n\n@Component({\n  selector: 'bao-pagination',\n  templateUrl: './pagination.component.html',\n  styleUrls: ['./pagination.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  host: {\n    class: 'bao-pagination'\n  }\n})\nexport class BaoPaginationComponent implements OnChanges, OnInit {\n  /**\n   * The total number of items.\n   */\n  @Input()\n  public totalItems: number;\n  /**\n   * The number of items per page as selected.\n   */\n  @Input()\n  public itemsPerPage: number = 10;\n  /**\n   * The current page number.\n   */\n  @Input()\n  public currentPage: number = 1;\n  /**\n   * The different page size options.\n   */\n  @Input()\n  public pageSizeOptions: number[] = [10, 25, 50, 100];\n  /**\n   * The label for the type of items that are displayed on the page\n   */\n  @Input()\n  public itemLabel: string = 'items';\n  /**\n   * If selector for number of items per page should be displayed or not\n   */\n  @Input()\n  public showItemsPerPageSelector: boolean = true;\n  /**\n   * EventEmitter that triggers when there is a page change and emits page number (index adjusted)\n   */\n  @Output()\n  public pageChanged = new EventEmitter<number>();\n  /**\n   * EventEmitter that triggers when the number of items per page is changed.\n   */\n  @Output()\n  public itemsPerPageChanged = new EventEmitter<number>();\n  /**\n   * Page number list to display\n   */\n  public displayedPages: number[];\n  /**\n   * Max number of pages to display\n   */\n  private _maxPages: number = 5;\n  /**\n   * Number of pages in total.\n   */\n  private _totalPages: number;\n  /**\n   * Position of first item being displayed on current page.\n   */\n  private _startItem: number;\n  /**\n   * Position of last item being displayed on current page.\n   */\n  private _endItem: number;\n\n  constructor(private cdr: ChangeDetectorRef) {\n    this.displayedPages = [];\n  }\n\n  public get totalPages(): number {\n    return this._totalPages;\n  }\n\n  public set totalPages(value: number) {\n    this._totalPages = value;\n  }\n\n  public get startItem(): number {\n    return this._startItem;\n  }\n\n  public set startItem(value: number) {\n    this._startItem = value;\n  }\n\n  public get endItem(): number {\n    return this._endItem;\n  }\n\n  public set endItem(value: number) {\n    this._endItem = value;\n  }\n\n  public get rangeLabel(): string {\n    return `${this.startItem} à ${this.endItem} sur ${this.totalItems} ${this.itemLabel}`;\n  }\n\n  /**\n   * Flag that indicates if a previous page exists for the current list\n   */\n  public get hasPrevious(): boolean {\n    return this.currentPage !== 1;\n  }\n  /**\n   * Flag that indicates if a next page exists for the current list\n   */\n  public get hasNext(): boolean {\n    return this.currentPage < this.totalPages;\n  }\n\n  public ngOnInit(): void {\n    this.startItem = this.updateStartItem();\n    this.endItem = this.updateEndItem();\n    this.totalPages = this.updateTotalPages();\n    this.displayedPages = this.buildPageNumbers();\n    this.cdr.detectChanges();\n  }\n\n  /**\n   * Update list of displayed pages when current page is changed.\n   */\n  public ngOnChanges(changes: SimpleChanges): void {\n    if (changes.hasOwnProperty('currentPage')) {\n      this.displayedPages = this.buildPageNumbers();\n    }\n    if (changes.hasOwnProperty('totalItems')) {\n      this.startItem = this.updateStartItem();\n      this.endItem = this.updateEndItem();\n      this.totalPages = this.updateTotalPages();\n      this.displayedPages = this.buildPageNumbers();\n    }\n  }\n  /**\n   * Navigate to specific page\n   */\n  public goTo(page: number): void {\n    this.currentPage = page;\n    this.startItem = this.updateStartItem();\n    this.endItem = this.updateEndItem();\n    this.displayedPages = this.buildPageNumbers();\n    this.pageChanged.emit(page - 1);\n  }\n  /**\n   * Navigate to previous page\n   */\n  public handlePreviousClick() {\n    if (this.hasPrevious) {\n      this.goTo(this.currentPage - 1);\n    }\n  }\n  /**\n   * Navigate to next page\n   */\n  public handleNextClick(): void {\n    if (this.hasNext) {\n      this.goTo(this.currentPage + 1);\n    }\n  }\n\n  /**\n   * Update all required variables whenever the number of items displayed per page is changed.\n   * @param value New amount of items per page\n   */\n  public handlePageSizeChange(value: number) {\n    this.currentPage = 1;\n    this.startItem = this.updateStartItem();\n    this.endItem = this.updateEndItem();\n    this.totalPages = this.updateTotalPages();\n    this.displayedPages = this.buildPageNumbers();\n    this.itemsPerPageChanged.emit(value);\n  }\n\n  private updateTotalPages(): number {\n    return Math.ceil(this.totalItems / this.itemsPerPage);\n  }\n\n  private updateStartItem(): number {\n    const startItem = Math.min(\n      (this.currentPage - 1) * this.itemsPerPage + 1,\n      Math.floor(this.totalItems / 10) * 10\n    );\n    return startItem || 1;\n  }\n\n  private updateEndItem(): number {\n    return Math.min(\n      this.startItem + Number(this.itemsPerPage) - 1,\n      this.totalItems\n    );\n  }\n\n  /**\n   * Generate series of page numbers to display. The list always starts with page 1\n   * and ends with last page.\n   * Adds negative numbers for ellipsis.\n   */\n  private buildPageNumbers(): number[] {\n    const pages = [];\n    // If total pages are 5 or less, include all pages\n    if (this.totalPages <= this._maxPages) {\n      for (let i = 1; i <= this.totalPages; i++) {\n        pages.push(i);\n      }\n    } else {\n      pages.push(1);\n      // Determine middle pages\n      let middlePages = [];\n      if (this.currentPage <= 3) {\n        middlePages = [2, 3, 4, -1];\n      } else if (this.currentPage >= this.totalPages - 2) {\n        middlePages = [\n          -1,\n          this.totalPages - 3,\n          this.totalPages - 2,\n          this.totalPages - 1\n        ];\n      } else {\n        middlePages = [\n          -1,\n          this.currentPage - 1,\n          this.currentPage,\n          this.currentPage + 1,\n          -1\n        ];\n      }\n      pages.push(...middlePages);\n      pages.push(this.totalPages);\n    }\n    return pages;\n  }\n}\n","<div class=\"items-diplayed-controls\">\n  <span class=\"range-display\">\n    {{ rangeLabel }}\n  </span>\n  <div *ngIf=\"showItemsPerPageSelector\" class=\"items-per-page\">\n    <label for=\"items-per-page-select\" class=\"select-label\"\n      >Items par page\n    </label>\n    <select\n      [(ngModel)]=\"itemsPerPage\"\n      (ngModelChange)=\"handlePageSizeChange($event)\"\n      name=\"items-per-page\"\n      id=\"items-per-page-select\"\n      class=\"dropdown-select\"\n    >\n      <option *ngFor=\"let size of pageSizeOptions\" [value]=\"size\">\n        {{ size }}\n      </option>\n    </select>\n  </div>\n</div>\n<nav aria-label=\"Pagination\" class=\"page-controls\">\n  <ul>\n    <li\n      class=\"page-item\"\n      [ngClass]=\"{ disabled: !hasPrevious }\"\n      [attr.aria-disabled]=\"!hasPrevious ? 'true' : null\"\n    >\n      <a\n        class=\"page-link\"\n        (click)=\"$event.preventDefault(); handlePreviousClick()\"\n        (keydown.enter)=\"$event.preventDefault(); handlePreviousClick()\"\n        (keydown.space)=\"$event.preventDefault(); handlePreviousClick()\"\n        tabindex=\"0\"\n      >\n        <bao-icon title=\"Page précédente\" svgIcon=\"icon-chevron-left\"></bao-icon\n      ></a>\n    </li>\n    <li\n      class=\"page-item\"\n      *ngFor=\"let page of displayedPages\"\n      [ngClass]=\"{ active: page === currentPage }\"\n      [attr.aria-current]=\"page === currentPage ? 'page' : null\"\n    >\n      <ng-container *ngIf=\"page > 0; else ellipsis\">\n        <span class=\"sr-only\">{{ page }}</span>\n        <a\n          class=\"page-link\"\n          (click)=\"$event.preventDefault(); goTo(page)\"\n          (keydown.enter)=\"$event.preventDefault(); goTo(page)\"\n          (keydown.space)=\"$event.preventDefault(); goTo(page)\"\n          tabindex=\"0\"\n          >{{ page }}</a\n        >\n      </ng-container>\n      <ng-template #ellipsis>\n        <span class=\"page-link ellipsis\" aria-hidden=\"true\">...</span>\n      </ng-template>\n    </li>\n\n    <li\n      class=\"page-item\"\n      [ngClass]=\"{ disabled: !hasNext }\"\n      [attr.aria-disabled]=\"!hasNext ? 'true' : null\"\n    >\n      <a\n        class=\"page-link\"\n        (click)=\"$event.preventDefault(); handleNextClick()\"\n        (keydown.enter)=\"$event.preventDefault(); handleNextClick()\"\n        (keydown.space)=\"$event.preventDefault(); handleNextClick()\"\n        tabindex=\"0\"\n      >\n        <bao-icon title=\"Page suivante\" svgIcon=\"icon-chevron-right\"></bao-icon\n      ></a>\n    </li>\n  </ul>\n</nav>\n"]}
@@ -3,28 +3,29 @@
3
3
  * Licensed under the MIT license.
4
4
  * See LICENSE file in the project root for full license information.
5
5
  */
6
- export * from './lib/bao.module';
7
- export * from './lib/button/index';
8
- export * from './lib/icon/index';
9
6
  export * from './lib/alert/index';
7
+ export * from './lib/avatar';
8
+ export * from './lib/badge/index';
9
+ export * from './lib/bao.module';
10
10
  export * from './lib/breadcrumb/index';
11
+ export * from './lib/button/index';
11
12
  export * from './lib/card/index';
12
- export * from './lib/badge/index';
13
- export * from './lib/tag/index';
14
- export * from './lib/header-info/index';
15
- export * from './lib/list/index';
16
13
  export * from './lib/checkbox/index';
17
- export * from './lib/radio/index';
18
14
  export * from './lib/common-components/index';
19
- export * from './lib/summary/index';
20
- export * from './lib/shared';
21
- export * from './lib/avatar';
22
- export * from './lib/tabs';
23
- export * from './lib/modal';
24
- export * from './lib/hyperlink';
25
15
  export * from './lib/dropdown-menu';
26
16
  export * from './lib/file';
17
+ export * from './lib/header-info/index';
18
+ export * from './lib/hyperlink';
19
+ export * from './lib/icon/index';
20
+ export * from './lib/list/index';
21
+ export * from './lib/message-bar';
22
+ export * from './lib/modal';
23
+ export * from './lib/pagination/index';
24
+ export * from './lib/radio/index';
25
+ export * from './lib/shared';
27
26
  export * from './lib/snack-bar';
27
+ export * from './lib/summary/index';
28
28
  export * from './lib/system-header';
29
- export * from './lib/message-bar';
30
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdWkvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7R0FJRztBQUNILGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxpQkFBaUIsQ0FBQztBQUNoQyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLGlCQUFpQixDQUFDO0FBQ2hDLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyxZQUFZLENBQUM7QUFDM0IsY0FBYyxpQkFBaUIsQ0FBQztBQUNoQyxjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMsbUJBQW1CLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogQ29weXJpZ2h0IChjKSAyMDI1IFZpbGxlIGRlIE1vbnRyZWFsLiBBbGwgcmlnaHRzIHJlc2VydmVkLlxuICogTGljZW5zZWQgdW5kZXIgdGhlIE1JVCBsaWNlbnNlLlxuICogU2VlIExJQ0VOU0UgZmlsZSBpbiB0aGUgcHJvamVjdCByb290IGZvciBmdWxsIGxpY2Vuc2UgaW5mb3JtYXRpb24uXG4gKi9cbmV4cG9ydCAqIGZyb20gJy4vbGliL2Jhby5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYnV0dG9uL2luZGV4JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ljb24vaW5kZXgnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYWxlcnQvaW5kZXgnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYnJlYWRjcnVtYi9pbmRleCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jYXJkL2luZGV4JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2JhZGdlL2luZGV4JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RhZy9pbmRleCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9oZWFkZXItaW5mby9pbmRleCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9saXN0L2luZGV4JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NoZWNrYm94L2luZGV4JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3JhZGlvL2luZGV4JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbW1vbi1jb21wb25lbnRzL2luZGV4JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3N1bW1hcnkvaW5kZXgnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc2hhcmVkJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2F2YXRhcic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90YWJzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGFsJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2h5cGVybGluayc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kcm9wZG93bi1tZW51JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ZpbGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc25hY2stYmFyJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3N5c3RlbS1oZWFkZXInO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbWVzc2FnZS1iYXInO1xuIl19
29
+ export * from './lib/tabs';
30
+ export * from './lib/tag/index';
31
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdWkvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7R0FJRztBQUNILGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyxpQkFBaUIsQ0FBQztBQUNoQyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxpQkFBaUIsQ0FBQztBQUNoQyxjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyxZQUFZLENBQUM7QUFDM0IsY0FBYyxpQkFBaUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjUgVmlsbGUgZGUgTW9udHJlYWwuIEFsbCByaWdodHMgcmVzZXJ2ZWQuXG4gKiBMaWNlbnNlZCB1bmRlciB0aGUgTUlUIGxpY2Vuc2UuXG4gKiBTZWUgTElDRU5TRSBmaWxlIGluIHRoZSBwcm9qZWN0IHJvb3QgZm9yIGZ1bGwgbGljZW5zZSBpbmZvcm1hdGlvbi5cbiAqL1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYWxlcnQvaW5kZXgnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYXZhdGFyJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2JhZGdlL2luZGV4JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Jhby5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYnJlYWRjcnVtYi9pbmRleCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9idXR0b24vaW5kZXgnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY2FyZC9pbmRleCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaGVja2JveC9pbmRleCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21tb24tY29tcG9uZW50cy9pbmRleCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kcm9wZG93bi1tZW51JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ZpbGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvaGVhZGVyLWluZm8vaW5kZXgnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvaHlwZXJsaW5rJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ljb24vaW5kZXgnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbGlzdC9pbmRleCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tZXNzYWdlLWJhcic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2RhbCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9wYWdpbmF0aW9uL2luZGV4JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3JhZGlvL2luZGV4JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NoYXJlZCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zbmFjay1iYXInO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc3VtbWFyeS9pbmRleCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zeXN0ZW0taGVhZGVyJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RhYnMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdGFnL2luZGV4JztcbiJdfQ==