@villedemontreal/angular-ui 16.1.2 → 16.2.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/esm2022/lib/bao.module.mjs +8 -9
- package/esm2022/lib/pagination/index.mjs +8 -0
- package/esm2022/lib/pagination/module.mjs +25 -0
- package/esm2022/lib/pagination/pagination.component.mjs +211 -0
- package/esm2022/public-api.mjs +17 -16
- package/fesm2022/villedemontreal-angular-ui.mjs +292 -62
- package/fesm2022/villedemontreal-angular-ui.mjs.map +1 -1
- package/lib/bao.module.d.ts +2 -1
- package/lib/pagination/index.d.ts +2 -0
- package/lib/pagination/module.d.ts +10 -0
- package/lib/pagination/pagination.component.d.ts +106 -0
- package/package.json +1 -1
- package/public-api.d.ts +16 -15
|
@@ -19,6 +19,7 @@ import { BaoIconModule } from './icon';
|
|
|
19
19
|
import { BaoListModule } from './list';
|
|
20
20
|
import { BaoMessageBarModule } from './message-bar';
|
|
21
21
|
import { BaoModalModule } from './modal/module';
|
|
22
|
+
import { BaoPaginationModule } from './pagination';
|
|
22
23
|
import { BaoRadioModule } from './radio';
|
|
23
24
|
import { BaoSnackBarModule } from './snack-bar/module';
|
|
24
25
|
import { BaoSummaryModule } from './summary';
|
|
@@ -53,9 +54,8 @@ export class BaoModule {
|
|
|
53
54
|
BaoFileModule,
|
|
54
55
|
BaoSnackBarModule,
|
|
55
56
|
BaoSystemHeaderModule,
|
|
56
|
-
BaoMessageBarModule
|
|
57
|
-
|
|
58
|
-
] }); }
|
|
57
|
+
BaoMessageBarModule,
|
|
58
|
+
BaoPaginationModule] }); }
|
|
59
59
|
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: BaoModule, imports: [BaoIconModule,
|
|
60
60
|
BaoButtonModule,
|
|
61
61
|
BaoAlertModule,
|
|
@@ -81,9 +81,8 @@ export class BaoModule {
|
|
|
81
81
|
BaoFileModule,
|
|
82
82
|
BaoSnackBarModule,
|
|
83
83
|
BaoSystemHeaderModule,
|
|
84
|
-
BaoMessageBarModule
|
|
85
|
-
|
|
86
|
-
] }); }
|
|
84
|
+
BaoMessageBarModule,
|
|
85
|
+
BaoPaginationModule] }); }
|
|
87
86
|
}
|
|
88
87
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: BaoModule, decorators: [{
|
|
89
88
|
type: NgModule,
|
|
@@ -117,9 +116,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImpor
|
|
|
117
116
|
BaoFileModule,
|
|
118
117
|
BaoSnackBarModule,
|
|
119
118
|
BaoSystemHeaderModule,
|
|
120
|
-
BaoMessageBarModule
|
|
121
|
-
|
|
119
|
+
BaoMessageBarModule,
|
|
120
|
+
BaoPaginationModule
|
|
122
121
|
]
|
|
123
122
|
}]
|
|
124
123
|
}] });
|
|
125
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
124
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFvLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdWkvc3JjL2xpYi9iYW8ubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7O0dBSUc7QUFDSCxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxTQUFTLENBQUM7QUFDekMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUMzQyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDbkQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUMzQyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sUUFBUSxDQUFDO0FBQ3ZDLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLFlBQVksQ0FBQztBQUMvQyxPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUNoRSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUN4RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzlDLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNwRCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDakQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLFFBQVEsQ0FBQztBQUN2QyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sUUFBUSxDQUFDO0FBQ3ZDLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNwRCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDaEQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sY0FBYyxDQUFDO0FBQ25ELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxTQUFTLENBQUM7QUFDekMsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDdkQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sV0FBVyxDQUFDO0FBQzdDLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ3hELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxRQUFRLENBQUM7QUFDdkMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLE9BQU8sQ0FBQzs7QUFvQ3JDLE1BQU0sT0FBTyxTQUFTOzhHQUFULFNBQVM7K0dBQVQsU0FBUyxZQWhDbEIsYUFBYTtZQUNiLGVBQWU7WUFDZixjQUFjO1lBQ2QsYUFBYTtZQUNiLG1CQUFtQjtZQUNuQixjQUFjLGFBR2QsYUFBYTtZQUNiLGVBQWU7WUFDZixjQUFjO1lBQ2QsbUJBQW1CO1lBQ25CLGFBQWE7WUFDYixZQUFZO1lBQ1osbUJBQW1CO1lBQ25CLGFBQWE7WUFDYix5QkFBeUI7WUFDekIsaUJBQWlCO1lBQ2pCLGNBQWM7WUFDZCxnQkFBZ0I7WUFDaEIsZUFBZTtZQUNmLGFBQWE7WUFDYixjQUFjO1lBQ2Qsa0JBQWtCO1lBQ2xCLHFCQUFxQjtZQUNyQixhQUFhO1lBQ2IsaUJBQWlCO1lBQ2pCLHFCQUFxQjtZQUNyQixtQkFBbUI7WUFDbkIsbUJBQW1COytHQUdWLFNBQVMsWUFoQ2xCLGFBQWE7WUFDYixlQUFlO1lBQ2YsY0FBYztZQUNkLGFBQWE7WUFDYixtQkFBbUI7WUFDbkIsY0FBYyxFQUdkLGFBQWE7WUFDYixlQUFlO1lBQ2YsY0FBYztZQUNkLG1CQUFtQjtZQUNuQixhQUFhO1lBQ2IsWUFBWTtZQUNaLG1CQUFtQjtZQUNuQixhQUFhO1lBQ2IseUJBQXlCO1lBQ3pCLGlCQUFpQjtZQUNqQixjQUFjO1lBQ2QsZ0JBQWdCO1lBQ2hCLGVBQWU7WUFDZixhQUFhO1lBQ2IsY0FBYztZQUNkLGtCQUFrQjtZQUNsQixxQkFBcUI7WUFDckIsYUFBYTtZQUNiLGlCQUFpQjtZQUNqQixxQkFBcUI7WUFDckIsbUJBQW1CO1lBQ25CLG1CQUFtQjs7MkZBR1YsU0FBUztrQkFsQ3JCLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFO3dCQUNQLGFBQWE7d0JBQ2IsZUFBZTt3QkFDZixjQUFjO3dCQUNkLGFBQWE7d0JBQ2IsbUJBQW1CO3dCQUNuQixjQUFjO3FCQUNmO29CQUNELE9BQU8sRUFBRTt3QkFDUCxhQUFhO3dCQUNiLGVBQWU7d0JBQ2YsY0FBYzt3QkFDZCxtQkFBbUI7d0JBQ25CLGFBQWE7d0JBQ2IsWUFBWTt3QkFDWixtQkFBbUI7d0JBQ25CLGFBQWE7d0JBQ2IseUJBQXlCO3dCQUN6QixpQkFBaUI7d0JBQ2pCLGNBQWM7d0JBQ2QsZ0JBQWdCO3dCQUNoQixlQUFlO3dCQUNmLGFBQWE7d0JBQ2IsY0FBYzt3QkFDZCxrQkFBa0I7d0JBQ2xCLHFCQUFxQjt3QkFDckIsYUFBYTt3QkFDYixpQkFBaUI7d0JBQ2pCLHFCQUFxQjt3QkFDckIsbUJBQW1CO3dCQUNuQixtQkFBbUI7cUJBQ3BCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIENvcHlyaWdodCAoYykgMjAyNSBWaWxsZSBkZSBNb250cmVhbC4gQWxsIHJpZ2h0cyByZXNlcnZlZC5cbiAqIExpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgbGljZW5zZS5cbiAqIFNlZSBMSUNFTlNFIGZpbGUgaW4gdGhlIHByb2plY3Qgcm9vdCBmb3IgZnVsbCBsaWNlbnNlIGluZm9ybWF0aW9uLlxuICovXG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQmFvQWxlcnRNb2R1bGUgfSBmcm9tICcuL2FsZXJ0JztcbmltcG9ydCB7IEJhb0F2YXRhck1vZHVsZSB9IGZyb20gJy4vYXZhdGFyJztcbmltcG9ydCB7IEJhb0JyZWFkY3J1bWJNb2R1bGUgfSBmcm9tICcuL2JyZWFkY3J1bWInO1xuaW1wb3J0IHsgQmFvQnV0dG9uTW9kdWxlIH0gZnJvbSAnLi9idXR0b24nO1xuaW1wb3J0IHsgQmFvQ2FyZE1vZHVsZSB9IGZyb20gJy4vY2FyZCc7XG5pbXBvcnQgeyBCYW9DaGVja2JveE1vZHVsZSB9IGZyb20gJy4vY2hlY2tib3gnO1xuaW1wb3J0IHsgQmFvQ29tbW9uQ29tcG9uZW50c01vZHVsZSB9IGZyb20gJy4vY29tbW9uLWNvbXBvbmVudHMnO1xuaW1wb3J0IHsgQmFvRHJvcGRvd25NZW51TW9kdWxlIH0gZnJvbSAnLi9kcm9wZG93bi1tZW51JztcbmltcG9ydCB7IEJhb0ZpbGVNb2R1bGUgfSBmcm9tICcuL2ZpbGUvbW9kdWxlJztcbmltcG9ydCB7IEJhb0hlYWRlckluZm9Nb2R1bGUgfSBmcm9tICcuL2hlYWRlci1pbmZvJztcbmltcG9ydCB7IEJhb0h5cGVybGlua01vZHVsZSB9IGZyb20gJy4vaHlwZXJsaW5rJztcbmltcG9ydCB7IEJhb0ljb25Nb2R1bGUgfSBmcm9tICcuL2ljb24nO1xuaW1wb3J0IHsgQmFvTGlzdE1vZHVsZSB9IGZyb20gJy4vbGlzdCc7XG5pbXBvcnQgeyBCYW9NZXNzYWdlQmFyTW9kdWxlIH0gZnJvbSAnLi9tZXNzYWdlLWJhcic7XG5pbXBvcnQgeyBCYW9Nb2RhbE1vZHVsZSB9IGZyb20gJy4vbW9kYWwvbW9kdWxlJztcbmltcG9ydCB7IEJhb1BhZ2luYXRpb25Nb2R1bGUgfSBmcm9tICcuL3BhZ2luYXRpb24nO1xuaW1wb3J0IHsgQmFvUmFkaW9Nb2R1bGUgfSBmcm9tICcuL3JhZGlvJztcbmltcG9ydCB7IEJhb1NuYWNrQmFyTW9kdWxlIH0gZnJvbSAnLi9zbmFjay1iYXIvbW9kdWxlJztcbmltcG9ydCB7IEJhb1N1bW1hcnlNb2R1bGUgfSBmcm9tICcuL3N1bW1hcnknO1xuaW1wb3J0IHsgQmFvU3lzdGVtSGVhZGVyTW9kdWxlIH0gZnJvbSAnLi9zeXN0ZW0taGVhZGVyJztcbmltcG9ydCB7IEJhb1RhYnNNb2R1bGUgfSBmcm9tICcuL3RhYnMnO1xuaW1wb3J0IHsgQmFvVGFnTW9kdWxlIH0gZnJvbSAnLi90YWcnO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbXG4gICAgQmFvSWNvbk1vZHVsZSxcbiAgICBCYW9CdXR0b25Nb2R1bGUsXG4gICAgQmFvQWxlcnRNb2R1bGUsXG4gICAgQmFvQ2FyZE1vZHVsZSxcbiAgICBCYW9CcmVhZGNydW1iTW9kdWxlLFxuICAgIEJhb01vZGFsTW9kdWxlXG4gIF0sXG4gIGV4cG9ydHM6IFtcbiAgICBCYW9JY29uTW9kdWxlLFxuICAgIEJhb0J1dHRvbk1vZHVsZSxcbiAgICBCYW9BbGVydE1vZHVsZSxcbiAgICBCYW9CcmVhZGNydW1iTW9kdWxlLFxuICAgIEJhb0NhcmRNb2R1bGUsXG4gICAgQmFvVGFnTW9kdWxlLFxuICAgIEJhb0hlYWRlckluZm9Nb2R1bGUsXG4gICAgQmFvTGlzdE1vZHVsZSxcbiAgICBCYW9Db21tb25Db21wb25lbnRzTW9kdWxlLFxuICAgIEJhb0NoZWNrYm94TW9kdWxlLFxuICAgIEJhb1JhZGlvTW9kdWxlLFxuICAgIEJhb1N1bW1hcnlNb2R1bGUsXG4gICAgQmFvQXZhdGFyTW9kdWxlLFxuICAgIEJhb1RhYnNNb2R1bGUsXG4gICAgQmFvTW9kYWxNb2R1bGUsXG4gICAgQmFvSHlwZXJsaW5rTW9kdWxlLFxuICAgIEJhb0Ryb3Bkb3duTWVudU1vZHVsZSxcbiAgICBCYW9GaWxlTW9kdWxlLFxuICAgIEJhb1NuYWNrQmFyTW9kdWxlLFxuICAgIEJhb1N5c3RlbUhlYWRlck1vZHVsZSxcbiAgICBCYW9NZXNzYWdlQmFyTW9kdWxlLFxuICAgIEJhb1BhZ2luYXRpb25Nb2R1bGVcbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBCYW9Nb2R1bGUge31cbiJdfQ==
|
|
@@ -0,0 +1,8 @@
|
|
|
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
|
+
export * from './module';
|
|
7
|
+
export * from './pagination.component';
|
|
8
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLXVpL3NyYy9saWIvcGFnaW5hdGlvbi9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7OztHQUlHO0FBQ0gsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyx3QkFBd0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjUgVmlsbGUgZGUgTW9udHJlYWwuIEFsbCByaWdodHMgcmVzZXJ2ZWQuXG4gKiBMaWNlbnNlZCB1bmRlciB0aGUgTUlUIGxpY2Vuc2UuXG4gKiBTZWUgTElDRU5TRSBmaWxlIGluIHRoZSBwcm9qZWN0IHJvb3QgZm9yIGZ1bGwgbGljZW5zZSBpbmZvcm1hdGlvbi5cbiAqL1xuZXhwb3J0ICogZnJvbSAnLi9tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9wYWdpbmF0aW9uLmNvbXBvbmVudCc7XG4iXX0=
|
|
@@ -0,0 +1,25 @@
|
|
|
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 { CommonModule } from '@angular/common';
|
|
7
|
+
import { NgModule } from '@angular/core';
|
|
8
|
+
import { FormsModule } from '@angular/forms';
|
|
9
|
+
import { BaoIconModule } from '../icon';
|
|
10
|
+
import { BaoPaginationComponent } from './pagination.component';
|
|
11
|
+
import * as i0 from "@angular/core";
|
|
12
|
+
export class BaoPaginationModule {
|
|
13
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: BaoPaginationModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
14
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.6", ngImport: i0, type: BaoPaginationModule, declarations: [BaoPaginationComponent], imports: [CommonModule, BaoIconModule, FormsModule], exports: [BaoPaginationComponent] }); }
|
|
15
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: BaoPaginationModule, imports: [CommonModule, BaoIconModule, FormsModule] }); }
|
|
16
|
+
}
|
|
17
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: BaoPaginationModule, decorators: [{
|
|
18
|
+
type: NgModule,
|
|
19
|
+
args: [{
|
|
20
|
+
imports: [CommonModule, BaoIconModule, FormsModule],
|
|
21
|
+
declarations: [BaoPaginationComponent],
|
|
22
|
+
exports: [BaoPaginationComponent]
|
|
23
|
+
}]
|
|
24
|
+
}] });
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci11aS9zcmMvbGliL3BhZ2luYXRpb24vbW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7O0dBSUc7QUFDSCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDN0MsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLFNBQVMsQ0FBQztBQUN4QyxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQzs7QUFPaEUsTUFBTSxPQUFPLG1CQUFtQjs4R0FBbkIsbUJBQW1COytHQUFuQixtQkFBbUIsaUJBSGYsc0JBQXNCLGFBRDNCLFlBQVksRUFBRSxhQUFhLEVBQUUsV0FBVyxhQUV4QyxzQkFBc0I7K0dBRXJCLG1CQUFtQixZQUpwQixZQUFZLEVBQUUsYUFBYSxFQUFFLFdBQVc7OzJGQUl2QyxtQkFBbUI7a0JBTC9CLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLGFBQWEsRUFBRSxXQUFXLENBQUM7b0JBQ25ELFlBQVksRUFBRSxDQUFDLHNCQUFzQixDQUFDO29CQUN0QyxPQUFPLEVBQUUsQ0FBQyxzQkFBc0IsQ0FBQztpQkFDbEMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogQ29weXJpZ2h0IChjKSAyMDI1IFZpbGxlIGRlIE1vbnRyZWFsLiBBbGwgcmlnaHRzIHJlc2VydmVkLlxuICogTGljZW5zZWQgdW5kZXIgdGhlIE1JVCBsaWNlbnNlLlxuICogU2VlIExJQ0VOU0UgZmlsZSBpbiB0aGUgcHJvamVjdCByb290IGZvciBmdWxsIGxpY2Vuc2UgaW5mb3JtYXRpb24uXG4gKi9cbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBCYW9JY29uTW9kdWxlIH0gZnJvbSAnLi4vaWNvbic7XG5pbXBvcnQgeyBCYW9QYWdpbmF0aW9uQ29tcG9uZW50IH0gZnJvbSAnLi9wYWdpbmF0aW9uLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIEJhb0ljb25Nb2R1bGUsIEZvcm1zTW9kdWxlXSxcbiAgZGVjbGFyYXRpb25zOiBbQmFvUGFnaW5hdGlvbkNvbXBvbmVudF0sXG4gIGV4cG9ydHM6IFtCYW9QYWdpbmF0aW9uQ29tcG9uZW50XVxufSlcbmV4cG9ydCBjbGFzcyBCYW9QYWdpbmF0aW9uTW9kdWxlIHt9XG4iXX0=
|
|
@@ -0,0 +1,211 @@
|
|
|
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
|
+
}
|
|
96
|
+
/**
|
|
97
|
+
* Navigate to specific page
|
|
98
|
+
*/
|
|
99
|
+
goTo(page) {
|
|
100
|
+
this.currentPage = page;
|
|
101
|
+
this.startItem = this.updateStartItem();
|
|
102
|
+
this.endItem = this.updateEndItem();
|
|
103
|
+
this.displayedPages = this.buildPageNumbers();
|
|
104
|
+
this.pageChanged.emit(page - 1);
|
|
105
|
+
}
|
|
106
|
+
/**
|
|
107
|
+
* Navigate to previous page
|
|
108
|
+
*/
|
|
109
|
+
handlePreviousClick() {
|
|
110
|
+
if (this.hasPrevious) {
|
|
111
|
+
this.goTo(this.currentPage - 1);
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
/**
|
|
115
|
+
* Navigate to next page
|
|
116
|
+
*/
|
|
117
|
+
handleNextClick() {
|
|
118
|
+
if (this.hasNext) {
|
|
119
|
+
this.goTo(this.currentPage + 1);
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
/**
|
|
123
|
+
* Update all required variables whenever the number of items displayed per page is changed.
|
|
124
|
+
* @param value New amount of items per page
|
|
125
|
+
*/
|
|
126
|
+
handlePageSizeChange(value) {
|
|
127
|
+
this.currentPage = 1;
|
|
128
|
+
this.startItem = this.updateStartItem();
|
|
129
|
+
this.endItem = this.updateEndItem();
|
|
130
|
+
this.totalPages = this.updateTotalPages();
|
|
131
|
+
this.displayedPages = this.buildPageNumbers();
|
|
132
|
+
this.itemsPerPageChanged.emit(value);
|
|
133
|
+
}
|
|
134
|
+
updateTotalPages() {
|
|
135
|
+
return Math.ceil(this.totalItems / this.itemsPerPage);
|
|
136
|
+
}
|
|
137
|
+
updateStartItem() {
|
|
138
|
+
const startItem = Math.min((this.currentPage - 1) * this.itemsPerPage + 1, Math.floor(this.totalItems / 10) * 10);
|
|
139
|
+
return startItem || 1;
|
|
140
|
+
}
|
|
141
|
+
updateEndItem() {
|
|
142
|
+
return Math.min(this.startItem + Number(this.itemsPerPage) - 1, this.totalItems);
|
|
143
|
+
}
|
|
144
|
+
/**
|
|
145
|
+
* Generate series of page numbers to display. The list always starts with page 1
|
|
146
|
+
* and ends with last page.
|
|
147
|
+
* Adds negative numbers for ellipsis.
|
|
148
|
+
*/
|
|
149
|
+
buildPageNumbers() {
|
|
150
|
+
const pages = [];
|
|
151
|
+
// If total pages are 5 or less, include all pages
|
|
152
|
+
if (this.totalPages <= this._maxPages) {
|
|
153
|
+
for (let i = 1; i <= this.totalPages; i++) {
|
|
154
|
+
pages.push(i);
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
else {
|
|
158
|
+
pages.push(1);
|
|
159
|
+
// Determine middle pages
|
|
160
|
+
let middlePages = [];
|
|
161
|
+
if (this.currentPage <= 3) {
|
|
162
|
+
middlePages = [2, 3, 4, -1];
|
|
163
|
+
}
|
|
164
|
+
else if (this.currentPage >= this.totalPages - 2) {
|
|
165
|
+
middlePages = [
|
|
166
|
+
-1,
|
|
167
|
+
this.totalPages - 3,
|
|
168
|
+
this.totalPages - 2,
|
|
169
|
+
this.totalPages - 1
|
|
170
|
+
];
|
|
171
|
+
}
|
|
172
|
+
else {
|
|
173
|
+
middlePages = [
|
|
174
|
+
-1,
|
|
175
|
+
this.currentPage - 1,
|
|
176
|
+
this.currentPage,
|
|
177
|
+
this.currentPage + 1,
|
|
178
|
+
-1
|
|
179
|
+
];
|
|
180
|
+
}
|
|
181
|
+
pages.push(...middlePages);
|
|
182
|
+
pages.push(this.totalPages);
|
|
183
|
+
}
|
|
184
|
+
return pages;
|
|
185
|
+
}
|
|
186
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: BaoPaginationComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
187
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.6", 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;-webkit-appearance:none;appearance:none;background:#ffffff 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 }); }
|
|
188
|
+
}
|
|
189
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: BaoPaginationComponent, decorators: [{
|
|
190
|
+
type: Component,
|
|
191
|
+
args: [{ selector: 'bao-pagination', encapsulation: ViewEncapsulation.None, host: {
|
|
192
|
+
class: 'bao-pagination'
|
|
193
|
+
}, 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;-webkit-appearance:none;appearance:none;background:#ffffff 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"] }]
|
|
194
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { totalItems: [{
|
|
195
|
+
type: Input
|
|
196
|
+
}], itemsPerPage: [{
|
|
197
|
+
type: Input
|
|
198
|
+
}], currentPage: [{
|
|
199
|
+
type: Input
|
|
200
|
+
}], pageSizeOptions: [{
|
|
201
|
+
type: Input
|
|
202
|
+
}], itemLabel: [{
|
|
203
|
+
type: Input
|
|
204
|
+
}], showItemsPerPageSelector: [{
|
|
205
|
+
type: Input
|
|
206
|
+
}], pageChanged: [{
|
|
207
|
+
type: Output
|
|
208
|
+
}], itemsPerPageChanged: [{
|
|
209
|
+
type: Output
|
|
210
|
+
}] } });
|
|
211
|
+
//# 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  }\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"]}
|
package/esm2022/public-api.mjs
CHANGED
|
@@ -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/
|
|
30
|
-
|
|
29
|
+
export * from './lib/tabs';
|
|
30
|
+
export * from './lib/tag/index';
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdWkvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7R0FJRztBQUNILGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyxpQkFBaUIsQ0FBQztBQUNoQyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxpQkFBaUIsQ0FBQztBQUNoQyxjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyxZQUFZLENBQUM7QUFDM0IsY0FBYyxpQkFBaUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjUgVmlsbGUgZGUgTW9udHJlYWwuIEFsbCByaWdodHMgcmVzZXJ2ZWQuXG4gKiBMaWNlbnNlZCB1bmRlciB0aGUgTUlUIGxpY2Vuc2UuXG4gKiBTZWUgTElDRU5TRSBmaWxlIGluIHRoZSBwcm9qZWN0IHJvb3QgZm9yIGZ1bGwgbGljZW5zZSBpbmZvcm1hdGlvbi5cbiAqL1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYWxlcnQvaW5kZXgnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYXZhdGFyJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2JhZGdlL2luZGV4JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Jhby5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYnJlYWRjcnVtYi9pbmRleCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9idXR0b24vaW5kZXgnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY2FyZC9pbmRleCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaGVja2JveC9pbmRleCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21tb24tY29tcG9uZW50cy9pbmRleCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kcm9wZG93bi1tZW51JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ZpbGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvaGVhZGVyLWluZm8vaW5kZXgnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvaHlwZXJsaW5rJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ljb24vaW5kZXgnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbGlzdC9pbmRleCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tZXNzYWdlLWJhcic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2RhbCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9wYWdpbmF0aW9uL2luZGV4JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3JhZGlvL2luZGV4JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NoYXJlZCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zbmFjay1iYXInO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc3VtbWFyeS9pbmRleCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zeXN0ZW0taGVhZGVyJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RhYnMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdGFnL2luZGV4JztcbiJdfQ==
|