@agorapulse/ui-components 15.1.2 → 15.1.4

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.
Files changed (34) hide show
  1. package/agorapulse-ui-components-15.1.4.tgz +0 -0
  2. package/esm2020/avatar/avatar.component.mjs +3 -2
  3. package/esm2020/index.mjs +2 -1
  4. package/esm2020/paginator/paginator-button/paginator-button.component.mjs +2 -2
  5. package/esm2020/paginator/paginator.component.mjs +92 -29
  6. package/esm2020/radio/agorapulse-ui-components-radio.mjs +5 -0
  7. package/esm2020/radio/public_api.mjs +3 -0
  8. package/esm2020/radio/radio-control.registry.mjs +104 -0
  9. package/esm2020/radio/radio.component.mjs +199 -0
  10. package/fesm2015/agorapulse-ui-components-avatar.mjs +2 -1
  11. package/fesm2015/agorapulse-ui-components-avatar.mjs.map +1 -1
  12. package/fesm2015/agorapulse-ui-components-paginator.mjs +93 -30
  13. package/fesm2015/agorapulse-ui-components-paginator.mjs.map +1 -1
  14. package/fesm2015/agorapulse-ui-components-radio.mjs +306 -0
  15. package/fesm2015/agorapulse-ui-components-radio.mjs.map +1 -0
  16. package/fesm2015/agorapulse-ui-components.mjs +1 -0
  17. package/fesm2015/agorapulse-ui-components.mjs.map +1 -1
  18. package/fesm2020/agorapulse-ui-components-avatar.mjs +2 -1
  19. package/fesm2020/agorapulse-ui-components-avatar.mjs.map +1 -1
  20. package/fesm2020/agorapulse-ui-components-paginator.mjs +93 -30
  21. package/fesm2020/agorapulse-ui-components-paginator.mjs.map +1 -1
  22. package/fesm2020/agorapulse-ui-components-radio.mjs +305 -0
  23. package/fesm2020/agorapulse-ui-components-radio.mjs.map +1 -0
  24. package/fesm2020/agorapulse-ui-components.mjs +1 -0
  25. package/fesm2020/agorapulse-ui-components.mjs.map +1 -1
  26. package/index.d.ts +1 -0
  27. package/package.json +9 -1
  28. package/paginator/paginator.component.d.ts +26 -8
  29. package/radio/index.d.ts +5 -0
  30. package/radio/public_api.d.ts +2 -0
  31. package/radio/radio-control.registry.d.ts +22 -0
  32. package/radio/radio.component.d.ts +57 -0
  33. package/snackbars-thread/component/snackbars-thread.component.d.ts +1 -1
  34. package/agorapulse-ui-components-15.1.2.tgz +0 -0
@@ -97,7 +97,8 @@ export class AvatarComponent {
97
97
  this.username$ = new BehaviorSubject('');
98
98
  this.online$ = new BehaviorSubject(false);
99
99
  this.showInitials$ = new BehaviorSubject(false);
100
- this.rounded$ = new BehaviorSubject(false);
100
+ this.rounded$ = new BehaviorSubject(true);
101
+ this.roundedAvatar = true;
101
102
  this.displayProfilePicture$ = new Observable();
102
103
  this.displaySingleNeutralSvg$ = new Observable();
103
104
  this.displayInitials$ = new Observable();
@@ -209,4 +210,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.2", ngImpor
209
210
  }], size: [{
210
211
  type: Input
211
212
  }] } });
212
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"avatar.component.js","sourceRoot":"","sources":["../../../../libs/ui-components/avatar/src/avatar.component.ts","../../../../libs/ui-components/avatar/src/avatar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    apFacebookOfficial,\n    apGoogleMyBusinessOfficial,\n    apLinkedinOfficial,\n    apShowTheaterMaskHappy,\n    apSingleNeutral,\n    apTiktokOfficial,\n    apTwitterOfficial,\n    apYoutubeOfficial,\n    apPinterestOfficial,\n    SymbolComponent,\n    SymbolRegistry,\n} from '@agorapulse/ui-symbol';\nimport {NgForOf, NgIf, NgOptimizedImage} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    HostBinding,\n    Input,\n    OnInit,\n    ViewEncapsulation,\n} from '@angular/core';\nimport {BehaviorSubject, combineLatest, map, Observable, of} from 'rxjs';\nimport {LetModule} from '@ngrx/component';\n\nexport type AvatarSize = 56 | 48 | 40 | 36 | 32 | 24 | 16;\nexport type AvatarNetwork =\n    | 'facebook'\n    | 'instagram'\n    | 'twitter'\n    | 'linkedin'\n    | 'tiktok'\n    | 'youtube'\n    | 'pinterest'\n    | 'googleMyBusiness';\n\nconst onlineIconSizeByAvatarSize: Record<AvatarSize, number> = {\n    56: 16,\n    48: 12,\n    40: 12,\n    36: 8,\n    32: 8,\n    24: 6,\n    16: 6,\n};\n\nconst symbolSizeByAvatarSize: Record<AvatarSize, number> = {\n    56: 28,\n    48: 24,\n    40: 20,\n    36: 18,\n    32: 16,\n    24: 12,\n    16: 8,\n};\n\nconst networkSizeByAvatarSize: Record<AvatarSize, number> = {\n    56: 16,\n    48: 16,\n    40: 16,\n    36: 16,\n    32: 12,\n    24: 12,\n    16: 8,\n};\n\nconst initialSizeByAvatarSize: Record<AvatarSize, number> = {\n    56: 28,\n    48: 24,\n    40: 22,\n    36: 18,\n    32: 18,\n    24: 14,\n    16: 10,\n};\n\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    selector: 'ap-avatar',\n    styleUrls: ['./avatar.component.scss'],\n    standalone: true,\n    imports: [NgIf, NgForOf, NgOptimizedImage, SymbolComponent, LetModule],\n    templateUrl: './avatar.component.html',\n    encapsulation: ViewEncapsulation.None,\n})\nexport class AvatarComponent implements OnInit {\n    readonly networkSymbolByNetwork: Record<AvatarNetwork, string> = {\n        facebook: 'facebook-official',\n        instagram: 'instagram-official',\n        twitter: 'twitter-official',\n        linkedin: 'linkedin-official',\n        tiktok: 'tiktok-official',\n        youtube: 'youtube-official',\n        pinterest: 'pinterest-official',\n        googleMyBusiness: 'google-my-business-official',\n    };\n\n    size$: BehaviorSubject<AvatarSize> = new BehaviorSubject<AvatarSize>(40);\n    profilePicture$: BehaviorSubject<string | undefined> = new BehaviorSubject<string>('');\n    network$: BehaviorSubject<AvatarNetwork> = new BehaviorSubject<AvatarNetwork>('facebook');\n\n    private alternativeText$: BehaviorSubject<string> = new BehaviorSubject<string>('');\n    private anonymous$: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false);\n    private username$: BehaviorSubject<string> = new BehaviorSubject<string>('');\n    private online$: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false);\n    private showInitials$: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false);\n    private rounded$: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false);\n\n    @Input() set alternativeText(alternativeText: string) {\n        this.alternativeText$.next(alternativeText);\n    }\n\n    @Input() set anonymous(anonymous: boolean) {\n        this.anonymous$.next(anonymous);\n    }\n\n    @Input() set username(username: string) {\n        this.username$.next(username);\n    }\n\n    @Input() set network(network: AvatarNetwork) {\n        this.network$.next(network);\n        this.elementRef.nativeElement.style.setProperty(\n            '--ap-avatar-network-size',\n            `${networkSizeByAvatarSize[this.size$.value]}px`\n        );\n    }\n\n    @Input() set online(online: boolean) {\n        this.online$.next(online);\n    }\n\n    @Input() set profilePicture(profilePicture: string | undefined) {\n        this.profilePicture$.next(profilePicture);\n        this.imageError$.next(false);\n    }\n\n    @Input() set showInitials(showInitials: boolean) {\n        this.showInitials$.next(showInitials);\n    }\n    @Input() alt: string;\n\n    @HostBinding('class.rounded-avatar')\n    roundedAvatar: boolean;\n\n    @Input()\n    set rounded(rounded: boolean) {\n        this.roundedAvatar = rounded;\n        this.rounded$.next(rounded);\n    }\n\n    @Input() set size(size: AvatarSize) {\n        this.size$.next(size);\n        this.elementRef.nativeElement.style.setProperty('--ap-avatar-size', `${size}px`);\n        this.elementRef.nativeElement.style.setProperty('--ap-avatar-symbol-size', `${symbolSizeByAvatarSize[size]}px`);\n        this.elementRef.nativeElement.style.setProperty(\n            '--ap-avatar-online-icon-size',\n            `${onlineIconSizeByAvatarSize[size]}px`\n        );\n    }\n\n    displayProfilePicture$: Observable<boolean> = new Observable<boolean>();\n    displaySingleNeutralSvg$: Observable<boolean> = new Observable<boolean>();\n    displayInitials$: Observable<boolean> = new Observable<boolean>();\n    displayAnonymous$: Observable<boolean> = new Observable<boolean>();\n    displayNetwork$: Observable<boolean> = new Observable<boolean>();\n    displayOnline$: Observable<boolean> = new Observable<boolean>();\n    imageError$: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false);\n    initials$: Observable<string> = new Observable<string>();\n    initialsAvailable$: Observable<boolean> = of(false);\n\n    constructor(private symbolRegistry: SymbolRegistry, private elementRef: ElementRef) {\n        this.symbolRegistry.registerSymbols([\n            apSingleNeutral,\n            apShowTheaterMaskHappy,\n            apFacebookOfficial,\n            apTwitterOfficial,\n            apLinkedinOfficial,\n            apYoutubeOfficial,\n            apTiktokOfficial,\n            apGoogleMyBusinessOfficial,\n            apPinterestOfficial,\n        ]);\n        this.elementRef.nativeElement.style.setProperty('--ap-avatar-size', `40px`);\n        this.elementRef.nativeElement.style.setProperty(\n            '--ap-avatar-symbol-size',\n            `${symbolSizeByAvatarSize[this.size$.value]}px`\n        );\n    }\n\n    ngOnInit(): void {\n        this.initialsAvailable$ = this.username$.pipe(\n            map(username => {\n                return !!username;\n            })\n        );\n\n        this.displayProfilePicture$ = combineLatest([\n            this.profilePicture$,\n            this.anonymous$,\n            this.imageError$,\n            this.showInitials$,\n        ]).pipe(\n            map(([profilePicture, anonymous, imageError]) => {\n                return !!profilePicture && !anonymous && !imageError;\n            })\n        );\n\n        this.displayInitials$ = combineLatest([\n            this.showInitials$,\n            this.anonymous$,\n            this.initialsAvailable$,\n            this.displayProfilePicture$,\n        ]).pipe(\n            map(([showInitials, anonymous, initialsAvailable, displayProfilePicture]) => {\n                return showInitials && !anonymous && initialsAvailable && !displayProfilePicture;\n            })\n        );\n\n        this.displaySingleNeutralSvg$ = combineLatest([\n            this.profilePicture$,\n            this.imageError$,\n            this.initialsAvailable$,\n            this.showInitials$,\n            this.anonymous$,\n            this.displayInitials$,\n            this.displayProfilePicture$,\n        ]).pipe(\n            map(\n                ([\n                    profilePicture,\n                    imageError,\n                    initialsAvailable,\n                    showInitials,\n                    anonymous,\n                    displayInitials,\n                    displayProfilePicture,\n                ]) => {\n                    return (\n                        (!profilePicture || imageError || !initialsAvailable || (initialsAvailable && !showInitials)) &&\n                        !anonymous &&\n                        !displayInitials &&\n                        !displayProfilePicture\n                    );\n                }\n            )\n        );\n\n        this.displayAnonymous$ = combineLatest([this.anonymous$, this.rounded$]).pipe(\n            map(([anonymous, rounded]) => {\n                return anonymous && rounded;\n            })\n        );\n\n        this.displayOnline$ = combineLatest([this.online$, this.rounded$]).pipe(\n            map(([online, rounded]) => {\n                return online && rounded;\n            })\n        );\n\n        this.displayNetwork$ = combineLatest([this.network$, this.rounded$]).pipe(\n            map(([network, rounded]) => {\n                return !!network && rounded;\n            })\n        );\n\n        this.initials$ = combineLatest([this.displayInitials$, this.username$]).pipe(\n            map(([displayInitials, username]) => {\n                if (displayInitials && !username) {\n                    return '';\n                }\n                this.elementRef.nativeElement.style.setProperty(\n                    '--ap-avatar-initials-size',\n                    `${initialSizeByAvatarSize[this.size$.value]}px`\n                );\n                const names = username.split(' ');\n                if (names.length === 1) {\n                    return `${names[0].charAt(0).toUpperCase()}${names[0].charAt(1).toUpperCase()}`;\n                }\n                return `${names[0].charAt(0).toUpperCase()}${names[names.length - 1].charAt(0).toUpperCase()}`;\n            })\n        );\n    }\n\n    onImageError(): void {\n        this.imageError$.next(true);\n    }\n}\n","<ng-container\n    *ngrxLet=\"{\n        displayProfilePicture: displayProfilePicture$,\n        displaySingleNeutralSvg: displaySingleNeutralSvg$,\n        displayInitials: displayInitials$,\n        displayAnonymous: displayAnonymous$,\n        displayOnline: displayOnline$,\n        displayNetwork: displayNetwork$,\n        initials: initials$,\n        profilePicture: profilePicture$,\n        size: size$,\n        network: network$\n    } as avatarViewModel\">\n    <img\n        *ngIf=\"avatarViewModel.displayProfilePicture\"\n        [ngSrc]=\"avatarViewModel.profilePicture\"\n        [width]=\"avatarViewModel.size\"\n        [height]=\"avatarViewModel.size\"\n        [alt]=\"alt\"\n        (error)=\"onImageError()\" />\n    <div *ngIf=\"avatarViewModel.displaySingleNeutralSvg\" class=\"no-profile-picture\">\n        <ap-symbol symbolId=\"single-neutral\"></ap-symbol>\n    </div>\n\n    <div *ngIf=\"avatarViewModel.displayAnonymous\" class=\"anonymous\">\n        <ap-symbol symbolId=\"show-theater-mask-happy\"></ap-symbol>\n    </div>\n    <div *ngIf=\"avatarViewModel.displayOnline\" class=\"online\"></div>\n    <div\n        *ngIf=\"avatarViewModel.displayNetwork\"\n        class=\"network\"\n        [class.facebook]=\"avatarViewModel.network === 'facebook'\"\n        [class.linkedin]=\"avatarViewModel.network === 'linkedin'\"\n        [class.twitter]=\"avatarViewModel.network === 'twitter'\"\n        [class.youtube]=\"avatarViewModel.network === 'youtube'\"\n        [class.googleMyBusiness]=\"avatarViewModel.network === 'googleMyBusiness'\"\n        [class.instagram]=\"avatarViewModel.network === 'instagram'\"\n        [class.tiktok]=\"avatarViewModel.network === 'tiktok'\">\n        <ap-symbol [symbolId]=\"networkSymbolByNetwork[avatarViewModel.network]\"></ap-symbol>\n    </div>\n\n    <div *ngIf=\"avatarViewModel.displayInitials\" class=\"initials\">\n        {{ avatarViewModel.initials }}\n    </div>\n</ng-container>\n"]}
213
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"avatar.component.js","sourceRoot":"","sources":["../../../../libs/ui-components/avatar/src/avatar.component.ts","../../../../libs/ui-components/avatar/src/avatar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    apFacebookOfficial,\n    apGoogleMyBusinessOfficial,\n    apLinkedinOfficial,\n    apShowTheaterMaskHappy,\n    apSingleNeutral,\n    apTiktokOfficial,\n    apTwitterOfficial,\n    apYoutubeOfficial,\n    apPinterestOfficial,\n    SymbolComponent,\n    SymbolRegistry,\n} from '@agorapulse/ui-symbol';\nimport {NgForOf, NgIf, NgOptimizedImage} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    HostBinding,\n    Input,\n    OnInit,\n    ViewEncapsulation,\n} from '@angular/core';\nimport {BehaviorSubject, combineLatest, map, Observable, of} from 'rxjs';\nimport {LetModule} from '@ngrx/component';\n\nexport type AvatarSize = 56 | 48 | 40 | 36 | 32 | 24 | 16;\nexport type AvatarNetwork =\n    | 'facebook'\n    | 'instagram'\n    | 'twitter'\n    | 'linkedin'\n    | 'tiktok'\n    | 'youtube'\n    | 'pinterest'\n    | 'googleMyBusiness';\n\nconst onlineIconSizeByAvatarSize: Record<AvatarSize, number> = {\n    56: 16,\n    48: 12,\n    40: 12,\n    36: 8,\n    32: 8,\n    24: 6,\n    16: 6,\n};\n\nconst symbolSizeByAvatarSize: Record<AvatarSize, number> = {\n    56: 28,\n    48: 24,\n    40: 20,\n    36: 18,\n    32: 16,\n    24: 12,\n    16: 8,\n};\n\nconst networkSizeByAvatarSize: Record<AvatarSize, number> = {\n    56: 16,\n    48: 16,\n    40: 16,\n    36: 16,\n    32: 12,\n    24: 12,\n    16: 8,\n};\n\nconst initialSizeByAvatarSize: Record<AvatarSize, number> = {\n    56: 28,\n    48: 24,\n    40: 22,\n    36: 18,\n    32: 18,\n    24: 14,\n    16: 10,\n};\n\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    selector: 'ap-avatar',\n    styleUrls: ['./avatar.component.scss'],\n    standalone: true,\n    imports: [NgIf, NgForOf, NgOptimizedImage, SymbolComponent, LetModule],\n    templateUrl: './avatar.component.html',\n    encapsulation: ViewEncapsulation.None,\n})\nexport class AvatarComponent implements OnInit {\n    readonly networkSymbolByNetwork: Record<AvatarNetwork, string> = {\n        facebook: 'facebook-official',\n        instagram: 'instagram-official',\n        twitter: 'twitter-official',\n        linkedin: 'linkedin-official',\n        tiktok: 'tiktok-official',\n        youtube: 'youtube-official',\n        pinterest: 'pinterest-official',\n        googleMyBusiness: 'google-my-business-official',\n    };\n\n    size$: BehaviorSubject<AvatarSize> = new BehaviorSubject<AvatarSize>(40);\n    profilePicture$: BehaviorSubject<string | undefined> = new BehaviorSubject<string>('');\n    network$: BehaviorSubject<AvatarNetwork> = new BehaviorSubject<AvatarNetwork>('facebook');\n\n    private alternativeText$: BehaviorSubject<string> = new BehaviorSubject<string>('');\n    private anonymous$: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false);\n    private username$: BehaviorSubject<string> = new BehaviorSubject<string>('');\n    private online$: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false);\n    private showInitials$: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false);\n    private rounded$: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(true);\n\n    @Input() set alternativeText(alternativeText: string) {\n        this.alternativeText$.next(alternativeText);\n    }\n\n    @Input() set anonymous(anonymous: boolean) {\n        this.anonymous$.next(anonymous);\n    }\n\n    @Input() set username(username: string) {\n        this.username$.next(username);\n    }\n\n    @Input() set network(network: AvatarNetwork) {\n        this.network$.next(network);\n        this.elementRef.nativeElement.style.setProperty(\n            '--ap-avatar-network-size',\n            `${networkSizeByAvatarSize[this.size$.value]}px`\n        );\n    }\n\n    @Input() set online(online: boolean) {\n        this.online$.next(online);\n    }\n\n    @Input() set profilePicture(profilePicture: string | undefined) {\n        this.profilePicture$.next(profilePicture);\n        this.imageError$.next(false);\n    }\n\n    @Input() set showInitials(showInitials: boolean) {\n        this.showInitials$.next(showInitials);\n    }\n    @Input() alt: string;\n\n    @HostBinding('class.rounded-avatar')\n    roundedAvatar: boolean = true;\n\n    @Input()\n    set rounded(rounded: boolean) {\n        this.roundedAvatar = rounded;\n        this.rounded$.next(rounded);\n    }\n\n    @Input() set size(size: AvatarSize) {\n        this.size$.next(size);\n        this.elementRef.nativeElement.style.setProperty('--ap-avatar-size', `${size}px`);\n        this.elementRef.nativeElement.style.setProperty('--ap-avatar-symbol-size', `${symbolSizeByAvatarSize[size]}px`);\n        this.elementRef.nativeElement.style.setProperty(\n            '--ap-avatar-online-icon-size',\n            `${onlineIconSizeByAvatarSize[size]}px`\n        );\n    }\n\n    displayProfilePicture$: Observable<boolean> = new Observable<boolean>();\n    displaySingleNeutralSvg$: Observable<boolean> = new Observable<boolean>();\n    displayInitials$: Observable<boolean> = new Observable<boolean>();\n    displayAnonymous$: Observable<boolean> = new Observable<boolean>();\n    displayNetwork$: Observable<boolean> = new Observable<boolean>();\n    displayOnline$: Observable<boolean> = new Observable<boolean>();\n    imageError$: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false);\n    initials$: Observable<string> = new Observable<string>();\n    initialsAvailable$: Observable<boolean> = of(false);\n\n    constructor(private symbolRegistry: SymbolRegistry, private elementRef: ElementRef) {\n        this.symbolRegistry.registerSymbols([\n            apSingleNeutral,\n            apShowTheaterMaskHappy,\n            apFacebookOfficial,\n            apTwitterOfficial,\n            apLinkedinOfficial,\n            apYoutubeOfficial,\n            apTiktokOfficial,\n            apGoogleMyBusinessOfficial,\n            apPinterestOfficial,\n        ]);\n        this.elementRef.nativeElement.style.setProperty('--ap-avatar-size', `40px`);\n        this.elementRef.nativeElement.style.setProperty(\n            '--ap-avatar-symbol-size',\n            `${symbolSizeByAvatarSize[this.size$.value]}px`\n        );\n    }\n\n    ngOnInit(): void {\n        this.initialsAvailable$ = this.username$.pipe(\n            map(username => {\n                return !!username;\n            })\n        );\n\n        this.displayProfilePicture$ = combineLatest([\n            this.profilePicture$,\n            this.anonymous$,\n            this.imageError$,\n            this.showInitials$,\n        ]).pipe(\n            map(([profilePicture, anonymous, imageError]) => {\n                return !!profilePicture && !anonymous && !imageError;\n            })\n        );\n\n        this.displayInitials$ = combineLatest([\n            this.showInitials$,\n            this.anonymous$,\n            this.initialsAvailable$,\n            this.displayProfilePicture$,\n        ]).pipe(\n            map(([showInitials, anonymous, initialsAvailable, displayProfilePicture]) => {\n                return showInitials && !anonymous && initialsAvailable && !displayProfilePicture;\n            })\n        );\n\n        this.displaySingleNeutralSvg$ = combineLatest([\n            this.profilePicture$,\n            this.imageError$,\n            this.initialsAvailable$,\n            this.showInitials$,\n            this.anonymous$,\n            this.displayInitials$,\n            this.displayProfilePicture$,\n        ]).pipe(\n            map(\n                ([\n                    profilePicture,\n                    imageError,\n                    initialsAvailable,\n                    showInitials,\n                    anonymous,\n                    displayInitials,\n                    displayProfilePicture,\n                ]) => {\n                    return (\n                        (!profilePicture || imageError || !initialsAvailable || (initialsAvailable && !showInitials)) &&\n                        !anonymous &&\n                        !displayInitials &&\n                        !displayProfilePicture\n                    );\n                }\n            )\n        );\n\n        this.displayAnonymous$ = combineLatest([this.anonymous$, this.rounded$]).pipe(\n            map(([anonymous, rounded]) => {\n                return anonymous && rounded;\n            })\n        );\n\n        this.displayOnline$ = combineLatest([this.online$, this.rounded$]).pipe(\n            map(([online, rounded]) => {\n                return online && rounded;\n            })\n        );\n\n        this.displayNetwork$ = combineLatest([this.network$, this.rounded$]).pipe(\n            map(([network, rounded]) => {\n                return !!network && rounded;\n            })\n        );\n\n        this.initials$ = combineLatest([this.displayInitials$, this.username$]).pipe(\n            map(([displayInitials, username]) => {\n                if (displayInitials && !username) {\n                    return '';\n                }\n                this.elementRef.nativeElement.style.setProperty(\n                    '--ap-avatar-initials-size',\n                    `${initialSizeByAvatarSize[this.size$.value]}px`\n                );\n                const names = username.split(' ');\n                if (names.length === 1) {\n                    return `${names[0].charAt(0).toUpperCase()}${names[0].charAt(1).toUpperCase()}`;\n                }\n                return `${names[0].charAt(0).toUpperCase()}${names[names.length - 1].charAt(0).toUpperCase()}`;\n            })\n        );\n    }\n\n    onImageError(): void {\n        this.imageError$.next(true);\n    }\n}\n","<ng-container\n    *ngrxLet=\"{\n        displayProfilePicture: displayProfilePicture$,\n        displaySingleNeutralSvg: displaySingleNeutralSvg$,\n        displayInitials: displayInitials$,\n        displayAnonymous: displayAnonymous$,\n        displayOnline: displayOnline$,\n        displayNetwork: displayNetwork$,\n        initials: initials$,\n        profilePicture: profilePicture$,\n        size: size$,\n        network: network$\n    } as avatarViewModel\">\n    <img\n        *ngIf=\"avatarViewModel.displayProfilePicture\"\n        [ngSrc]=\"avatarViewModel.profilePicture\"\n        [width]=\"avatarViewModel.size\"\n        [height]=\"avatarViewModel.size\"\n        [alt]=\"alt\"\n        (error)=\"onImageError()\" />\n    <div *ngIf=\"avatarViewModel.displaySingleNeutralSvg\" class=\"no-profile-picture\">\n        <ap-symbol symbolId=\"single-neutral\"></ap-symbol>\n    </div>\n\n    <div *ngIf=\"avatarViewModel.displayAnonymous\" class=\"anonymous\">\n        <ap-symbol symbolId=\"show-theater-mask-happy\"></ap-symbol>\n    </div>\n    <div *ngIf=\"avatarViewModel.displayOnline\" class=\"online\"></div>\n    <div\n        *ngIf=\"avatarViewModel.displayNetwork\"\n        class=\"network\"\n        [class.facebook]=\"avatarViewModel.network === 'facebook'\"\n        [class.linkedin]=\"avatarViewModel.network === 'linkedin'\"\n        [class.twitter]=\"avatarViewModel.network === 'twitter'\"\n        [class.youtube]=\"avatarViewModel.network === 'youtube'\"\n        [class.googleMyBusiness]=\"avatarViewModel.network === 'googleMyBusiness'\"\n        [class.instagram]=\"avatarViewModel.network === 'instagram'\"\n        [class.tiktok]=\"avatarViewModel.network === 'tiktok'\">\n        <ap-symbol [symbolId]=\"networkSymbolByNetwork[avatarViewModel.network]\"></ap-symbol>\n    </div>\n\n    <div *ngIf=\"avatarViewModel.displayInitials\" class=\"initials\">\n        {{ avatarViewModel.initials }}\n    </div>\n</ng-container>\n"]}
package/esm2020/index.mjs CHANGED
@@ -35,7 +35,8 @@ export { IconButtonComponent } from '@agorapulse/ui-components/icon-button';
35
35
  export { ToggleComponent } from '@agorapulse/ui-components/toggle';
36
36
  export { ButtonComponent } from '@agorapulse/ui-components/button';
37
37
  export { SocialButtonComponent } from '@agorapulse/ui-components/social-button';
38
+ export { RadioComponent } from '@agorapulse/ui-components/radio';
38
39
  // Service
39
40
  export { SnackbarsThreadService } from '@agorapulse/ui-components/snackbars-thread';
40
41
  export { generateCodeStatus, CodeStatus, } from '@agorapulse/ui-components/snackbars-thread';
41
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9saWJzL3VpLWNvbXBvbmVudHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxTQUFTO0FBQ1QsT0FBTyxFQUFDLDRCQUE0QixFQUFDLE1BQU0sMkNBQTJDLENBQUM7QUFDdkYsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLG1DQUFtQyxDQUFDO0FBRWhFLFlBQVk7QUFDWixPQUFPLEVBQ0gseUJBQXlCLEVBQ3pCLHFCQUFxQixFQUNyQixpQkFBaUIsRUFDakIsa0JBQWtCLEVBQ2xCLHVCQUF1QixFQUN2Qix1QkFBdUIsRUFDdkIsd0JBQXdCLEdBQzNCLE1BQU0sc0NBQXNDLENBQUM7QUFDOUMsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sbUNBQW1DLENBQUM7QUFDbkUsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0sdUNBQXVDLENBQUM7QUFFMUUsWUFBWTtBQUNaLE9BQU8sRUFBQyxtQkFBbUIsRUFBQyxNQUFNLHVDQUF1QyxDQUFDO0FBQzFFLE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSxrQ0FBa0MsQ0FBQztBQUNqRSxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxtQ0FBbUMsQ0FBQztBQUNuRSxPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSx5Q0FBeUMsQ0FBQztBQUM5RSxPQUFPLEVBQUMsbUJBQW1CLEVBQUUsY0FBYyxFQUF5QixNQUFNLHNDQUFzQyxDQUFDO0FBQ2pILE9BQU8sRUFDSCxzQkFBc0IsRUFJdEIsZUFBZSxHQUNsQixNQUFNLDBDQUEwQyxDQUFDO0FBQ2xELE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLHdDQUF3QyxDQUFDO0FBQzVFLE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLG1DQUFtQyxDQUFDO0FBQ25FLE9BQU8sRUFBQyxjQUFjLEVBQUMsTUFBTSxrQ0FBa0MsQ0FBQztBQUNoRSxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSxrQ0FBa0MsQ0FBQztBQUNwRSxPQUFPLEVBQUMsdUJBQXVCLEVBQUMsTUFBTSwyQ0FBMkMsQ0FBQztBQUNsRixPQUFPLEVBQUMsa0NBQWtDLEVBQUMsTUFBTSxpREFBaUQsQ0FBQztBQUNuRyxPQUFPLEVBQUMsY0FBYyxFQUFjLE1BQU0saUNBQWlDLENBQUM7QUFDNUUsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0scUNBQXFDLENBQUM7QUFDdkUsT0FBTyxFQUFDLHNCQUFzQixFQUFDLE1BQU0sMENBQTBDLENBQUM7QUFDaEYsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sbUNBQW1DLENBQUM7QUFDbkUsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0sb0NBQW9DLENBQUM7QUFDckUsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0sd0NBQXdDLENBQUM7QUFDN0UsT0FBTyxFQUFDLHdCQUF3QixFQUFDLE1BQU0scUNBQXFDLENBQUM7QUFDN0UsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sd0NBQXdDLENBQUM7QUFDNUUsT0FBTyxFQUFDLHdCQUF3QixFQUFDLE1BQU0sNENBQTRDLENBQUM7QUFDcEYsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0sb0NBQW9DLENBQUM7QUFDckUsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0sdUNBQXVDLENBQUM7QUFDMUUsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLGtDQUFrQyxDQUFDO0FBQ2pFLE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSxrQ0FBa0MsQ0FBQztBQUNqRSxPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSx5Q0FBeUMsQ0FBQztBQUU5RSxVQUFVO0FBQ1YsT0FBTyxFQUFDLHNCQUFzQixFQUFDLE1BQU0sNENBQTRDLENBQUM7QUFLbEYsT0FBTyxFQUNILGtCQUFrQixFQUNsQixVQUFVLEdBSWIsTUFBTSw0Q0FBNEMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgdWlcbiAqL1xuXG4vLyBNb2R1bGVcbmV4cG9ydCB7QWdvcmFwdWxzZVVpQ29tcG9uZW50c01vZHVsZX0gZnJvbSAnLi9zcmMvbGliL2Fnb3JhcHVsc2UtdWktY29tcG9uZW50cy5tb2R1bGUnO1xuZXhwb3J0IHtQb3BtZW51TW9kdWxlfSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL3BvcG1lbnUnO1xuXG4vLyBEaXJlY3RpdmVcbmV4cG9ydCB7XG4gICAgQXV0b3NpemVUZXh0YXJlYURpcmVjdGl2ZSxcbiAgICBEZWZhdWx0SW1hZ2VEaXJlY3RpdmUsXG4gICAgRWxsaXBzaXNEaXJlY3RpdmUsXG4gICAgRnJvemVuR2lmRGlyZWN0aXZlLFxuICAgIEVxdWFsVmFsaWRhdG9yRGlyZWN0aXZlLFxuICAgIE11bHRpU3R5bGVUZXh0RGlyZWN0aXZlLFxuICAgIFRydW5jYXRlVG9vbHRpcERpcmVjdGl2ZSxcbn0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9kaXJlY3RpdmVzJztcbmV4cG9ydCB7UG9wbWVudURpcmVjdGl2ZX0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9wb3BtZW51JztcbmV4cG9ydCB7VG9vbHRpcE5lb0RpcmVjdGl2ZX0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy90b29sdGlwLW5lbyc7XG5cbi8vIENvbXBvbmVudFxuZXhwb3J0IHtBZGRDb21tZW50Q29tcG9uZW50fSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL2FkZC1jb21tZW50JztcbmV4cG9ydCB7QXZhdGFyQ29tcG9uZW50fSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL2F2YXRhcic7XG5leHBvcnQge1N0ZXBwZXJDb21wb25lbnR9IGZyb20gJ0BhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvc3RlcHBlcic7XG5leHBvcnQge0NvbmZpcm1Nb2RhbENvbXBvbmVudH0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9jb25maXJtLW1vZGFsJztcbmV4cG9ydCB7RGF0ZXBpY2tlckNvbXBvbmVudCwgRGF0ZXBpY2tlck1vZGUsIEkxOG5EYXRlUGlja2VyLCBQZXJpb2R9IGZyb20gJ0BhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvZGF0ZXBpY2tlcic7XG5leHBvcnQge1xuICAgIE5lb0RhdGVwaWNrZXJDb21wb25lbnQsXG4gICAgTmVvRGF0ZVBpY2tlclN0YXJ0c09uLFxuICAgIE5lb0RhdGVQaWNrZXJNb2RlLFxuICAgIE5lb0RhdGVQaWNrZXJMb2NhbGUsXG4gICAgRGF5RGlzYWJsZWRQaXBlLFxufSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL25lby1kYXRlcGlja2VyJztcbmV4cG9ydCB7RG90c1N0ZXBwZXJDb21wb25lbnR9IGZyb20gJ0BhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvZG90cy1zdGVwcGVyJztcbmV4cG9ydCB7SW5mb2JveENvbXBvbmVudH0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9pbmZvYm94JztcbmV4cG9ydCB7TGFiZWxDb21wb25lbnR9IGZyb20gJ0BhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvbGFiZWxzJztcbmV4cG9ydCB7TGFiZWxMaXN0Q29tcG9uZW50fSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL2xhYmVscyc7XG5leHBvcnQge0xhYmVsc1NlbGVjdG9yQ29tcG9uZW50fSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL2xhYmVscy1zZWxlY3Rvcic7XG5leHBvcnQge01lZGlhRGlzcGxheU92ZXJsYXlEaWFsb2dDb21wb25lbnR9IGZyb20gJ0BhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvbWVkaWEtZGlzcGxheS1vdmVybGF5JztcbmV4cG9ydCB7TW9kYWxDb21wb25lbnQsIE1vZGFsQ29uZmlnfSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL21vZGFsJztcbmV4cG9ydCB7UGFnaW5hdG9yQ29tcG9uZW50fSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL3BhZ2luYXRvcic7XG5leHBvcnQge1Bhc3N3b3JkSW5wdXRDb21wb25lbnR9IGZyb20gJ0BhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvcGFzc3dvcmQtaW5wdXQnO1xuZXhwb3J0IHtQb3BtZW51Q29tcG9uZW50fSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL3BvcG1lbnUnO1xuZXhwb3J0IHtTbmFja0JhckNvbXBvbmVudH0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9zbmFja2Jhcic7XG5leHBvcnQge05vdGlmaWNhdGlvbkNvbXBvbmVudH0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9ub3RpZmljYXRpb24nO1xuZXhwb3J0IHtQYWdpbmF0b3JCdXR0b25Db21wb25lbnR9IGZyb20gJ0BhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvcGFnaW5hdG9yJztcbmV4cG9ydCB7U2xpZGVUb2dnbGVDb21wb25lbnR9IGZyb20gJ0BhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvc2xpZGUtdG9nZ2xlJztcbmV4cG9ydCB7U25hY2tiYXJzVGhyZWFkQ29tcG9uZW50fSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL3NuYWNrYmFycy10aHJlYWQnO1xuZXhwb3J0IHtDaGVja2JveENvbXBvbmVudH0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9jaGVja2JveCc7XG5leHBvcnQge0ljb25CdXR0b25Db21wb25lbnR9IGZyb20gJ0BhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvaWNvbi1idXR0b24nO1xuZXhwb3J0IHtUb2dnbGVDb21wb25lbnR9IGZyb20gJ0BhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvdG9nZ2xlJztcbmV4cG9ydCB7QnV0dG9uQ29tcG9uZW50fSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL2J1dHRvbic7XG5leHBvcnQge1NvY2lhbEJ1dHRvbkNvbXBvbmVudH0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9zb2NpYWwtYnV0dG9uJztcblxuLy8gU2VydmljZVxuZXhwb3J0IHtTbmFja2JhcnNUaHJlYWRTZXJ2aWNlfSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL3NuYWNrYmFycy10aHJlYWQnO1xuXG4vLyBNb2RlbFxuZXhwb3J0IHtTdGVwfSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL3N0ZXBwZXInO1xuZXhwb3J0IHtDb25maXJtTW9kYWxUZXh0c30gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9jb25maXJtLW1vZGFsJztcbmV4cG9ydCB7XG4gICAgZ2VuZXJhdGVDb2RlU3RhdHVzLFxuICAgIENvZGVTdGF0dXMsXG4gICAgU25hY2tiYXJzVGhyZWFkQmFzZSxcbiAgICBTbmFja2JhclR5cGVWYWx1ZXMsXG4gICAgZXh0ZXJuYWxTbmFja2JhclR5cGVBbGxvd2VkLFxufSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL3NuYWNrYmFycy10aHJlYWQnO1xuIl19
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9saWJzL3VpLWNvbXBvbmVudHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxTQUFTO0FBQ1QsT0FBTyxFQUFDLDRCQUE0QixFQUFDLE1BQU0sMkNBQTJDLENBQUM7QUFDdkYsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLG1DQUFtQyxDQUFDO0FBRWhFLFlBQVk7QUFDWixPQUFPLEVBQ0gseUJBQXlCLEVBQ3pCLHFCQUFxQixFQUNyQixpQkFBaUIsRUFDakIsa0JBQWtCLEVBQ2xCLHVCQUF1QixFQUN2Qix1QkFBdUIsRUFDdkIsd0JBQXdCLEdBQzNCLE1BQU0sc0NBQXNDLENBQUM7QUFDOUMsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sbUNBQW1DLENBQUM7QUFDbkUsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0sdUNBQXVDLENBQUM7QUFFMUUsWUFBWTtBQUNaLE9BQU8sRUFBQyxtQkFBbUIsRUFBQyxNQUFNLHVDQUF1QyxDQUFDO0FBQzFFLE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSxrQ0FBa0MsQ0FBQztBQUNqRSxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxtQ0FBbUMsQ0FBQztBQUNuRSxPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSx5Q0FBeUMsQ0FBQztBQUM5RSxPQUFPLEVBQUMsbUJBQW1CLEVBQUUsY0FBYyxFQUF5QixNQUFNLHNDQUFzQyxDQUFDO0FBQ2pILE9BQU8sRUFDSCxzQkFBc0IsRUFJdEIsZUFBZSxHQUNsQixNQUFNLDBDQUEwQyxDQUFDO0FBQ2xELE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLHdDQUF3QyxDQUFDO0FBQzVFLE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLG1DQUFtQyxDQUFDO0FBQ25FLE9BQU8sRUFBQyxjQUFjLEVBQUMsTUFBTSxrQ0FBa0MsQ0FBQztBQUNoRSxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSxrQ0FBa0MsQ0FBQztBQUNwRSxPQUFPLEVBQUMsdUJBQXVCLEVBQUMsTUFBTSwyQ0FBMkMsQ0FBQztBQUNsRixPQUFPLEVBQUMsa0NBQWtDLEVBQUMsTUFBTSxpREFBaUQsQ0FBQztBQUNuRyxPQUFPLEVBQUMsY0FBYyxFQUFjLE1BQU0saUNBQWlDLENBQUM7QUFDNUUsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0scUNBQXFDLENBQUM7QUFDdkUsT0FBTyxFQUFDLHNCQUFzQixFQUFDLE1BQU0sMENBQTBDLENBQUM7QUFDaEYsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sbUNBQW1DLENBQUM7QUFDbkUsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0sb0NBQW9DLENBQUM7QUFDckUsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0sd0NBQXdDLENBQUM7QUFDN0UsT0FBTyxFQUFDLHdCQUF3QixFQUFDLE1BQU0scUNBQXFDLENBQUM7QUFDN0UsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sd0NBQXdDLENBQUM7QUFDNUUsT0FBTyxFQUFDLHdCQUF3QixFQUFDLE1BQU0sNENBQTRDLENBQUM7QUFDcEYsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0sb0NBQW9DLENBQUM7QUFDckUsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0sdUNBQXVDLENBQUM7QUFDMUUsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLGtDQUFrQyxDQUFDO0FBQ2pFLE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSxrQ0FBa0MsQ0FBQztBQUNqRSxPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSx5Q0FBeUMsQ0FBQztBQUM5RSxPQUFPLEVBQUMsY0FBYyxFQUFDLE1BQU0saUNBQWlDLENBQUM7QUFFL0QsVUFBVTtBQUNWLE9BQU8sRUFBQyxzQkFBc0IsRUFBQyxNQUFNLDRDQUE0QyxDQUFDO0FBS2xGLE9BQU8sRUFDSCxrQkFBa0IsRUFDbEIsVUFBVSxHQUliLE1BQU0sNENBQTRDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIHVpXG4gKi9cblxuLy8gTW9kdWxlXG5leHBvcnQge0Fnb3JhcHVsc2VVaUNvbXBvbmVudHNNb2R1bGV9IGZyb20gJy4vc3JjL2xpYi9hZ29yYXB1bHNlLXVpLWNvbXBvbmVudHMubW9kdWxlJztcbmV4cG9ydCB7UG9wbWVudU1vZHVsZX0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9wb3BtZW51JztcblxuLy8gRGlyZWN0aXZlXG5leHBvcnQge1xuICAgIEF1dG9zaXplVGV4dGFyZWFEaXJlY3RpdmUsXG4gICAgRGVmYXVsdEltYWdlRGlyZWN0aXZlLFxuICAgIEVsbGlwc2lzRGlyZWN0aXZlLFxuICAgIEZyb3plbkdpZkRpcmVjdGl2ZSxcbiAgICBFcXVhbFZhbGlkYXRvckRpcmVjdGl2ZSxcbiAgICBNdWx0aVN0eWxlVGV4dERpcmVjdGl2ZSxcbiAgICBUcnVuY2F0ZVRvb2x0aXBEaXJlY3RpdmUsXG59IGZyb20gJ0BhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvZGlyZWN0aXZlcyc7XG5leHBvcnQge1BvcG1lbnVEaXJlY3RpdmV9IGZyb20gJ0BhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvcG9wbWVudSc7XG5leHBvcnQge1Rvb2x0aXBOZW9EaXJlY3RpdmV9IGZyb20gJ0BhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvdG9vbHRpcC1uZW8nO1xuXG4vLyBDb21wb25lbnRcbmV4cG9ydCB7QWRkQ29tbWVudENvbXBvbmVudH0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9hZGQtY29tbWVudCc7XG5leHBvcnQge0F2YXRhckNvbXBvbmVudH0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9hdmF0YXInO1xuZXhwb3J0IHtTdGVwcGVyQ29tcG9uZW50fSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL3N0ZXBwZXInO1xuZXhwb3J0IHtDb25maXJtTW9kYWxDb21wb25lbnR9IGZyb20gJ0BhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvY29uZmlybS1tb2RhbCc7XG5leHBvcnQge0RhdGVwaWNrZXJDb21wb25lbnQsIERhdGVwaWNrZXJNb2RlLCBJMThuRGF0ZVBpY2tlciwgUGVyaW9kfSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL2RhdGVwaWNrZXInO1xuZXhwb3J0IHtcbiAgICBOZW9EYXRlcGlja2VyQ29tcG9uZW50LFxuICAgIE5lb0RhdGVQaWNrZXJTdGFydHNPbixcbiAgICBOZW9EYXRlUGlja2VyTW9kZSxcbiAgICBOZW9EYXRlUGlja2VyTG9jYWxlLFxuICAgIERheURpc2FibGVkUGlwZSxcbn0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9uZW8tZGF0ZXBpY2tlcic7XG5leHBvcnQge0RvdHNTdGVwcGVyQ29tcG9uZW50fSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL2RvdHMtc3RlcHBlcic7XG5leHBvcnQge0luZm9ib3hDb21wb25lbnR9IGZyb20gJ0BhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvaW5mb2JveCc7XG5leHBvcnQge0xhYmVsQ29tcG9uZW50fSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL2xhYmVscyc7XG5leHBvcnQge0xhYmVsTGlzdENvbXBvbmVudH0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9sYWJlbHMnO1xuZXhwb3J0IHtMYWJlbHNTZWxlY3RvckNvbXBvbmVudH0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9sYWJlbHMtc2VsZWN0b3InO1xuZXhwb3J0IHtNZWRpYURpc3BsYXlPdmVybGF5RGlhbG9nQ29tcG9uZW50fSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL21lZGlhLWRpc3BsYXktb3ZlcmxheSc7XG5leHBvcnQge01vZGFsQ29tcG9uZW50LCBNb2RhbENvbmZpZ30gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9tb2RhbCc7XG5leHBvcnQge1BhZ2luYXRvckNvbXBvbmVudH0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9wYWdpbmF0b3InO1xuZXhwb3J0IHtQYXNzd29yZElucHV0Q29tcG9uZW50fSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL3Bhc3N3b3JkLWlucHV0JztcbmV4cG9ydCB7UG9wbWVudUNvbXBvbmVudH0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9wb3BtZW51JztcbmV4cG9ydCB7U25hY2tCYXJDb21wb25lbnR9IGZyb20gJ0BhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvc25hY2tiYXInO1xuZXhwb3J0IHtOb3RpZmljYXRpb25Db21wb25lbnR9IGZyb20gJ0BhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvbm90aWZpY2F0aW9uJztcbmV4cG9ydCB7UGFnaW5hdG9yQnV0dG9uQ29tcG9uZW50fSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL3BhZ2luYXRvcic7XG5leHBvcnQge1NsaWRlVG9nZ2xlQ29tcG9uZW50fSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL3NsaWRlLXRvZ2dsZSc7XG5leHBvcnQge1NuYWNrYmFyc1RocmVhZENvbXBvbmVudH0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9zbmFja2JhcnMtdGhyZWFkJztcbmV4cG9ydCB7Q2hlY2tib3hDb21wb25lbnR9IGZyb20gJ0BhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvY2hlY2tib3gnO1xuZXhwb3J0IHtJY29uQnV0dG9uQ29tcG9uZW50fSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL2ljb24tYnV0dG9uJztcbmV4cG9ydCB7VG9nZ2xlQ29tcG9uZW50fSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL3RvZ2dsZSc7XG5leHBvcnQge0J1dHRvbkNvbXBvbmVudH0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9idXR0b24nO1xuZXhwb3J0IHtTb2NpYWxCdXR0b25Db21wb25lbnR9IGZyb20gJ0BhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvc29jaWFsLWJ1dHRvbic7XG5leHBvcnQge1JhZGlvQ29tcG9uZW50fSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL3JhZGlvJztcblxuLy8gU2VydmljZVxuZXhwb3J0IHtTbmFja2JhcnNUaHJlYWRTZXJ2aWNlfSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL3NuYWNrYmFycy10aHJlYWQnO1xuXG4vLyBNb2RlbFxuZXhwb3J0IHtTdGVwfSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL3N0ZXBwZXInO1xuZXhwb3J0IHtDb25maXJtTW9kYWxUZXh0c30gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9jb25maXJtLW1vZGFsJztcbmV4cG9ydCB7XG4gICAgZ2VuZXJhdGVDb2RlU3RhdHVzLFxuICAgIENvZGVTdGF0dXMsXG4gICAgU25hY2tiYXJzVGhyZWFkQmFzZSxcbiAgICBTbmFja2JhclR5cGVWYWx1ZXMsXG4gICAgZXh0ZXJuYWxTbmFja2JhclR5cGVBbGxvd2VkLFxufSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL3NuYWNrYmFycy10aHJlYWQnO1xuIl19
@@ -27,10 +27,10 @@ export class PaginatorButtonComponent {
27
27
  }
28
28
  }
29
29
  PaginatorButtonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.2", ngImport: i0, type: PaginatorButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
30
- PaginatorButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.2", type: PaginatorButtonComponent, isStandalone: true, selector: "ap-paginator-button", inputs: { ariaLabel: "ariaLabel", disabled: "disabled", pageIndex: "pageIndex", selectedPageIndex: "selectedPageIndex" }, outputs: { selectPage: "selectPage" }, host: { listeners: { "window:keyup.space": "onSpaceKeyUp($event)" } }, viewQueries: [{ propertyName: "button", first: true, predicate: ["button"], descendants: true }], ngImport: i0, template: "<button #button\n class=\"square-button\"\n role=\"button\"\n type=\"button\"\n [id]=\"'paginator-button-' + pageIndex\"\n [class.active]=\"selectedPageIndex === pageIndex\"\n [attr.aria-label]=\"ariaLabel || null\"\n (click)=\"onClickHandle(pageIndex)\"\n (blur)=\"onBlurHandle()\"\n (focus)=\"onFocusHandle()\">\n <span>\n {{pageIndex + 1}}\n </span>\n</button>\n", styles: ["[color=facebook]{color:#1877f2}[bgcolor=facebook],[hcolor=facebook]:hover{background-color:#1877f2}[border=facebook]{border:1px solid #1877f2}[color=google]{color:#4e85e8}[bgcolor=google],[hcolor=google]:hover{background-color:#4e85e8}[border=google]{border:1px solid #4e85e8}[color=instagram]{color:#e1306c}[bgcolor=instagram],[hcolor=instagram]:hover{background-color:#e1306c}[border=instagram]{border:1px solid #e1306c}[color=instagrammagenta]{color:#c13584}[bgcolor=instagrammagenta],[hcolor=instagrammagenta]:hover{background-color:#c13584}[border=instagrammagenta]{border:1px solid #c13584}[color=instagramblue]{color:#5851db}[bgcolor=instagramblue],[hcolor=instagramblue]:hover{background-color:#5851db}[border=instagramblue]{border:1px solid #5851db}[color=instagrampurple]{color:#833ab4}[bgcolor=instagrampurple],[hcolor=instagrampurple]:hover{background-color:#833ab4}[border=instagrampurple]{border:1px solid #833ab4}[color=instagramorange]{color:#f56040}[bgcolor=instagramorange],[hcolor=instagramorange]:hover{background-color:#f56040}[border=instagramorange]{border:1px solid #f56040}[color=instagramyellow]{color:#ffdc80}[bgcolor=instagramyellow],[hcolor=instagramyellow]:hover{background-color:#ffdc80}[border=instagramyellow]{border:1px solid #ffdc80}[color=linkedin]{color:#2c67bc}[bgcolor=linkedin],[hcolor=linkedin]:hover{background-color:#2c67bc}[border=linkedin]{border:1px solid #2c67bc}[color=twitter]{color:#55acee}[bgcolor=twitter],[hcolor=twitter]:hover{background-color:#55acee}[border=twitter]{border:1px solid #55acee}[color=youtube]{color:red}[bgcolor=youtube],[hcolor=youtube]:hover{background-color:red}[border=youtube]{border:1px solid #ff0000}[color=blood-orange]{color:#ff4d00}[bgcolor=blood-orange],[hcolor=blood-orange]:hover{background-color:#ff4d00}[border=blood-orange]{border:1px solid #ff4d00}[color=pinkish-orange]{color:#ff7b49}[bgcolor=pinkish-orange],[hcolor=pinkish-orange]:hover{background-color:#ff7b49}[border=pinkish-orange]{border:1px solid #ff7b49}[color=charcoal-grey]{color:#2a2f34}[bgcolor=charcoal-grey],[hcolor=charcoal-grey]:hover{background-color:#2a2f34}[border=charcoal-grey]{border:1px solid #2a2f34}[color=azure]{color:#00aeef}[bgcolor=azure],[hcolor=azure]:hover{background-color:#00aeef}[border=azure]{border:1px solid #00aeef}[color=light-azure]{color:#eaf5fd}[bgcolor=light-azure],[hcolor=light-azure]:hover{background-color:#eaf5fd}[border=light-azure]{border:1px solid #eaf5fd}[color=blue-grey]{color:#8d98a9}[bgcolor=blue-grey],[hcolor=blue-grey]:hover{background-color:#8d98a9}[border=blue-grey]{border:1px solid #8d98a9}[color=silver]{color:#ced0da}[bgcolor=silver],[hcolor=silver]:hover{background-color:#ced0da}[border=silver]{border:1px solid #ced0da}[color=pale-grey]{color:#dfe3e9}[bgcolor=pale-grey],[hcolor=pale-grey]:hover{background-color:#dfe3e9}[border=pale-grey]{border:1px solid #dfe3e9}[color=grey-white]{color:#f5f7f8}[bgcolor=grey-white],[hcolor=grey-white]:hover{background-color:#f5f7f8}[border=grey-white]{border:1px solid #f5f7f8}[color=cool-grey]{color:#b4bbc6}[bgcolor=cool-grey],[hcolor=cool-grey]:hover{background-color:#b4bbc6}[border=cool-grey]{border:1px solid #b4bbc6}[color=black]{color:#344563}[bgcolor=black],[hcolor=black]:hover{background-color:#344563}[border=black]{border:1px solid #344563}[color=grey-blue]{color:#68768c}[bgcolor=grey-blue],[hcolor=grey-blue]:hover{background-color:#68768c}[border=grey-blue]{border:1px solid #68768c}[color=strawberry]{color:#f4282d}[bgcolor=strawberry],[hcolor=strawberry]:hover{background-color:#f4282d}[border=strawberry]{border:1px solid #f4282d}[color=light-strawberry]{color:#f8eded}[bgcolor=light-strawberry],[hcolor=light-strawberry]:hover{background-color:#f8eded}[border=light-strawberry]{border:1px solid #f8eded}[color=white]{color:#fff}[bgcolor=white],[hcolor=white]:hover{background-color:#fff}[border=white]{border:1px solid #ffffff}[color=cool-green]{color:#33c15d}[bgcolor=cool-green],[hcolor=cool-green]:hover{background-color:#33c15d}[border=cool-green]{border:1px solid #33c15d}[color=light-green]{color:#ebfaef}[bgcolor=light-green],[hcolor=light-green]:hover{background-color:#ebfaef}[border=light-green]{border:1px solid #ebfaef}[color=transparent]{color:transparent}[bgcolor=transparent],[hcolor=transparent]:hover{background-color:transparent}[border=transparent]{border:1px solid transparent}[color=c0]{color:#a566a5}[bgcolor=c0],[hcolor=c0]:hover{background-color:#a566a5}[border=c0]{border:1px solid #A566A5}[color=c1]{color:#c7ab82}[bgcolor=c1],[hcolor=c1]:hover{background-color:#c7ab82}[border=c1]{border:1px solid #C7AB82}[color=c2]{color:#f2713c}[bgcolor=c2],[hcolor=c2]:hover{background-color:#f2713c}[border=c2]{border:1px solid #F2713C}[color=c3]{color:#ffd006}[bgcolor=c3],[hcolor=c3]:hover{background-color:#ffd006}[border=c3]{border:1px solid #FFD006}[color=c4]{color:#94c5aa}[bgcolor=c4],[hcolor=c4]:hover{background-color:#94c5aa}[border=c4]{border:1px solid #94C5AA}[color=c5]{color:#2a9d8f}[bgcolor=c5],[hcolor=c5]:hover{background-color:#2a9d8f}[border=c5]{border:1px solid #2A9D8F}[color=c6]{color:#78acd8}[bgcolor=c6],[hcolor=c6]:hover{background-color:#78acd8}[border=c6]{border:1px solid #78ACD8}[color=c7]{color:#525a9e}[bgcolor=c7],[hcolor=c7]:hover{background-color:#525a9e}[border=c7]{border:1px solid #525A9E}[color=c8]{color:#6a2459}[bgcolor=c8],[hcolor=c8]:hover{background-color:#6a2459}[border=c8]{border:1px solid #6A2459}[color=c9]{color:#74729e}[bgcolor=c9],[hcolor=c9]:hover{background-color:#74729e}[border=c9]{border:1px solid #74729E}.square-button{width:36px;height:36px;max-width:36px;max-height:36px;min-width:36px;min-height:36px;border-radius:var(--ref-border-radius-sm);background:transparent;display:flex;align-items:center;justify-content:center;border:none;box-sizing:border-box}.square-button.active{background-color:var(--ref-color-electric-blue-100)}.square-button.active span{color:var(--ref-color-white)}.square-button:hover{cursor:pointer}.square-button:hover:not(.active){background-color:var(--ref-color-electric-blue-10)}.square-button:active{background-color:var(--ref-color-electric-blue-20)}@media (hover: hover){.square-button:focus:not(.disabled):not(:active){outline:2px solid var(--ref-color-electric-blue-100);outline-offset:1px}}.square-button span{color:var(--ref-color-electric-blue-100);font-family:var(--ref-font-family);font-weight:var(--ref-font-weight-regular);font-size:var(--ref-font-size-sm);line-height:var(--ref-line-height-sm)}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush });
30
+ PaginatorButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.2", type: PaginatorButtonComponent, isStandalone: true, selector: "ap-paginator-button", inputs: { ariaLabel: "ariaLabel", disabled: "disabled", pageIndex: "pageIndex", selectedPageIndex: "selectedPageIndex" }, outputs: { selectPage: "selectPage" }, host: { listeners: { "window:keyup.space": "onSpaceKeyUp($event)" } }, viewQueries: [{ propertyName: "button", first: true, predicate: ["button"], descendants: true }], ngImport: i0, template: "<button #button\n class=\"square-button\"\n role=\"button\"\n type=\"button\"\n [id]=\"'paginator-button-' + pageIndex\"\n [class.active]=\"selectedPageIndex === pageIndex\"\n [attr.aria-label]=\"ariaLabel || null\"\n (click)=\"onClickHandle(pageIndex)\"\n (blur)=\"onBlurHandle()\"\n (focus)=\"onFocusHandle()\">\n <span>\n {{pageIndex + 1}}\n </span>\n</button>\n", styles: ["[color=facebook]{color:#1877f2}[bgcolor=facebook],[hcolor=facebook]:hover{background-color:#1877f2}[border=facebook]{border:1px solid #1877f2}[color=google]{color:#4e85e8}[bgcolor=google],[hcolor=google]:hover{background-color:#4e85e8}[border=google]{border:1px solid #4e85e8}[color=instagram]{color:#e1306c}[bgcolor=instagram],[hcolor=instagram]:hover{background-color:#e1306c}[border=instagram]{border:1px solid #e1306c}[color=instagrammagenta]{color:#c13584}[bgcolor=instagrammagenta],[hcolor=instagrammagenta]:hover{background-color:#c13584}[border=instagrammagenta]{border:1px solid #c13584}[color=instagramblue]{color:#5851db}[bgcolor=instagramblue],[hcolor=instagramblue]:hover{background-color:#5851db}[border=instagramblue]{border:1px solid #5851db}[color=instagrampurple]{color:#833ab4}[bgcolor=instagrampurple],[hcolor=instagrampurple]:hover{background-color:#833ab4}[border=instagrampurple]{border:1px solid #833ab4}[color=instagramorange]{color:#f56040}[bgcolor=instagramorange],[hcolor=instagramorange]:hover{background-color:#f56040}[border=instagramorange]{border:1px solid #f56040}[color=instagramyellow]{color:#ffdc80}[bgcolor=instagramyellow],[hcolor=instagramyellow]:hover{background-color:#ffdc80}[border=instagramyellow]{border:1px solid #ffdc80}[color=linkedin]{color:#2c67bc}[bgcolor=linkedin],[hcolor=linkedin]:hover{background-color:#2c67bc}[border=linkedin]{border:1px solid #2c67bc}[color=twitter]{color:#55acee}[bgcolor=twitter],[hcolor=twitter]:hover{background-color:#55acee}[border=twitter]{border:1px solid #55acee}[color=youtube]{color:red}[bgcolor=youtube],[hcolor=youtube]:hover{background-color:red}[border=youtube]{border:1px solid #ff0000}[color=blood-orange]{color:#ff4d00}[bgcolor=blood-orange],[hcolor=blood-orange]:hover{background-color:#ff4d00}[border=blood-orange]{border:1px solid #ff4d00}[color=pinkish-orange]{color:#ff7b49}[bgcolor=pinkish-orange],[hcolor=pinkish-orange]:hover{background-color:#ff7b49}[border=pinkish-orange]{border:1px solid #ff7b49}[color=charcoal-grey]{color:#2a2f34}[bgcolor=charcoal-grey],[hcolor=charcoal-grey]:hover{background-color:#2a2f34}[border=charcoal-grey]{border:1px solid #2a2f34}[color=azure]{color:#00aeef}[bgcolor=azure],[hcolor=azure]:hover{background-color:#00aeef}[border=azure]{border:1px solid #00aeef}[color=light-azure]{color:#eaf5fd}[bgcolor=light-azure],[hcolor=light-azure]:hover{background-color:#eaf5fd}[border=light-azure]{border:1px solid #eaf5fd}[color=blue-grey]{color:#8d98a9}[bgcolor=blue-grey],[hcolor=blue-grey]:hover{background-color:#8d98a9}[border=blue-grey]{border:1px solid #8d98a9}[color=silver]{color:#ced0da}[bgcolor=silver],[hcolor=silver]:hover{background-color:#ced0da}[border=silver]{border:1px solid #ced0da}[color=pale-grey]{color:#dfe3e9}[bgcolor=pale-grey],[hcolor=pale-grey]:hover{background-color:#dfe3e9}[border=pale-grey]{border:1px solid #dfe3e9}[color=grey-white]{color:#f5f7f8}[bgcolor=grey-white],[hcolor=grey-white]:hover{background-color:#f5f7f8}[border=grey-white]{border:1px solid #f5f7f8}[color=cool-grey]{color:#b4bbc6}[bgcolor=cool-grey],[hcolor=cool-grey]:hover{background-color:#b4bbc6}[border=cool-grey]{border:1px solid #b4bbc6}[color=black]{color:#344563}[bgcolor=black],[hcolor=black]:hover{background-color:#344563}[border=black]{border:1px solid #344563}[color=grey-blue]{color:#68768c}[bgcolor=grey-blue],[hcolor=grey-blue]:hover{background-color:#68768c}[border=grey-blue]{border:1px solid #68768c}[color=strawberry]{color:#f4282d}[bgcolor=strawberry],[hcolor=strawberry]:hover{background-color:#f4282d}[border=strawberry]{border:1px solid #f4282d}[color=light-strawberry]{color:#f8eded}[bgcolor=light-strawberry],[hcolor=light-strawberry]:hover{background-color:#f8eded}[border=light-strawberry]{border:1px solid #f8eded}[color=white]{color:#fff}[bgcolor=white],[hcolor=white]:hover{background-color:#fff}[border=white]{border:1px solid #ffffff}[color=cool-green]{color:#33c15d}[bgcolor=cool-green],[hcolor=cool-green]:hover{background-color:#33c15d}[border=cool-green]{border:1px solid #33c15d}[color=light-green]{color:#ebfaef}[bgcolor=light-green],[hcolor=light-green]:hover{background-color:#ebfaef}[border=light-green]{border:1px solid #ebfaef}[color=transparent]{color:transparent}[bgcolor=transparent],[hcolor=transparent]:hover{background-color:transparent}[border=transparent]{border:1px solid transparent}[color=c0]{color:#a566a5}[bgcolor=c0],[hcolor=c0]:hover{background-color:#a566a5}[border=c0]{border:1px solid #A566A5}[color=c1]{color:#c7ab82}[bgcolor=c1],[hcolor=c1]:hover{background-color:#c7ab82}[border=c1]{border:1px solid #C7AB82}[color=c2]{color:#f2713c}[bgcolor=c2],[hcolor=c2]:hover{background-color:#f2713c}[border=c2]{border:1px solid #F2713C}[color=c3]{color:#ffd006}[bgcolor=c3],[hcolor=c3]:hover{background-color:#ffd006}[border=c3]{border:1px solid #FFD006}[color=c4]{color:#94c5aa}[bgcolor=c4],[hcolor=c4]:hover{background-color:#94c5aa}[border=c4]{border:1px solid #94C5AA}[color=c5]{color:#2a9d8f}[bgcolor=c5],[hcolor=c5]:hover{background-color:#2a9d8f}[border=c5]{border:1px solid #2A9D8F}[color=c6]{color:#78acd8}[bgcolor=c6],[hcolor=c6]:hover{background-color:#78acd8}[border=c6]{border:1px solid #78ACD8}[color=c7]{color:#525a9e}[bgcolor=c7],[hcolor=c7]:hover{background-color:#525a9e}[border=c7]{border:1px solid #525A9E}[color=c8]{color:#6a2459}[bgcolor=c8],[hcolor=c8]:hover{background-color:#6a2459}[border=c8]{border:1px solid #6A2459}[color=c9]{color:#74729e}[bgcolor=c9],[hcolor=c9]:hover{background-color:#74729e}[border=c9]{border:1px solid #74729E}.square-button{width:36px;height:36px;max-width:36px;max-height:36px;min-width:36px;min-height:36px;border-radius:var(--ref-border-radius-sm);background:transparent;display:flex;align-items:center;justify-content:center;border:none;box-sizing:border-box}.square-button:hover{cursor:pointer}.square-button:hover:not(.active){background-color:var(--ref-color-electric-blue-10)}@media (hover: hover){.square-button:focus:not(.disabled):not(:active){outline:2px solid var(--ref-color-electric-blue-100);outline-offset:1px}}.square-button:active{background-color:var(--ref-color-electric-blue-20)!important}.square-button.active{background-color:var(--ref-color-electric-blue-100)}.square-button.active span{color:var(--ref-color-white)}.square-button span{color:var(--ref-color-electric-blue-100);font-family:var(--ref-font-family);font-weight:var(--ref-font-weight-regular);font-size:var(--ref-font-size-sm);line-height:var(--ref-line-height-sm)}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush });
31
31
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.2", ngImport: i0, type: PaginatorButtonComponent, decorators: [{
32
32
  type: Component,
33
- args: [{ selector: 'ap-paginator-button', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, template: "<button #button\n class=\"square-button\"\n role=\"button\"\n type=\"button\"\n [id]=\"'paginator-button-' + pageIndex\"\n [class.active]=\"selectedPageIndex === pageIndex\"\n [attr.aria-label]=\"ariaLabel || null\"\n (click)=\"onClickHandle(pageIndex)\"\n (blur)=\"onBlurHandle()\"\n (focus)=\"onFocusHandle()\">\n <span>\n {{pageIndex + 1}}\n </span>\n</button>\n", styles: ["[color=facebook]{color:#1877f2}[bgcolor=facebook],[hcolor=facebook]:hover{background-color:#1877f2}[border=facebook]{border:1px solid #1877f2}[color=google]{color:#4e85e8}[bgcolor=google],[hcolor=google]:hover{background-color:#4e85e8}[border=google]{border:1px solid #4e85e8}[color=instagram]{color:#e1306c}[bgcolor=instagram],[hcolor=instagram]:hover{background-color:#e1306c}[border=instagram]{border:1px solid #e1306c}[color=instagrammagenta]{color:#c13584}[bgcolor=instagrammagenta],[hcolor=instagrammagenta]:hover{background-color:#c13584}[border=instagrammagenta]{border:1px solid #c13584}[color=instagramblue]{color:#5851db}[bgcolor=instagramblue],[hcolor=instagramblue]:hover{background-color:#5851db}[border=instagramblue]{border:1px solid #5851db}[color=instagrampurple]{color:#833ab4}[bgcolor=instagrampurple],[hcolor=instagrampurple]:hover{background-color:#833ab4}[border=instagrampurple]{border:1px solid #833ab4}[color=instagramorange]{color:#f56040}[bgcolor=instagramorange],[hcolor=instagramorange]:hover{background-color:#f56040}[border=instagramorange]{border:1px solid #f56040}[color=instagramyellow]{color:#ffdc80}[bgcolor=instagramyellow],[hcolor=instagramyellow]:hover{background-color:#ffdc80}[border=instagramyellow]{border:1px solid #ffdc80}[color=linkedin]{color:#2c67bc}[bgcolor=linkedin],[hcolor=linkedin]:hover{background-color:#2c67bc}[border=linkedin]{border:1px solid #2c67bc}[color=twitter]{color:#55acee}[bgcolor=twitter],[hcolor=twitter]:hover{background-color:#55acee}[border=twitter]{border:1px solid #55acee}[color=youtube]{color:red}[bgcolor=youtube],[hcolor=youtube]:hover{background-color:red}[border=youtube]{border:1px solid #ff0000}[color=blood-orange]{color:#ff4d00}[bgcolor=blood-orange],[hcolor=blood-orange]:hover{background-color:#ff4d00}[border=blood-orange]{border:1px solid #ff4d00}[color=pinkish-orange]{color:#ff7b49}[bgcolor=pinkish-orange],[hcolor=pinkish-orange]:hover{background-color:#ff7b49}[border=pinkish-orange]{border:1px solid #ff7b49}[color=charcoal-grey]{color:#2a2f34}[bgcolor=charcoal-grey],[hcolor=charcoal-grey]:hover{background-color:#2a2f34}[border=charcoal-grey]{border:1px solid #2a2f34}[color=azure]{color:#00aeef}[bgcolor=azure],[hcolor=azure]:hover{background-color:#00aeef}[border=azure]{border:1px solid #00aeef}[color=light-azure]{color:#eaf5fd}[bgcolor=light-azure],[hcolor=light-azure]:hover{background-color:#eaf5fd}[border=light-azure]{border:1px solid #eaf5fd}[color=blue-grey]{color:#8d98a9}[bgcolor=blue-grey],[hcolor=blue-grey]:hover{background-color:#8d98a9}[border=blue-grey]{border:1px solid #8d98a9}[color=silver]{color:#ced0da}[bgcolor=silver],[hcolor=silver]:hover{background-color:#ced0da}[border=silver]{border:1px solid #ced0da}[color=pale-grey]{color:#dfe3e9}[bgcolor=pale-grey],[hcolor=pale-grey]:hover{background-color:#dfe3e9}[border=pale-grey]{border:1px solid #dfe3e9}[color=grey-white]{color:#f5f7f8}[bgcolor=grey-white],[hcolor=grey-white]:hover{background-color:#f5f7f8}[border=grey-white]{border:1px solid #f5f7f8}[color=cool-grey]{color:#b4bbc6}[bgcolor=cool-grey],[hcolor=cool-grey]:hover{background-color:#b4bbc6}[border=cool-grey]{border:1px solid #b4bbc6}[color=black]{color:#344563}[bgcolor=black],[hcolor=black]:hover{background-color:#344563}[border=black]{border:1px solid #344563}[color=grey-blue]{color:#68768c}[bgcolor=grey-blue],[hcolor=grey-blue]:hover{background-color:#68768c}[border=grey-blue]{border:1px solid #68768c}[color=strawberry]{color:#f4282d}[bgcolor=strawberry],[hcolor=strawberry]:hover{background-color:#f4282d}[border=strawberry]{border:1px solid #f4282d}[color=light-strawberry]{color:#f8eded}[bgcolor=light-strawberry],[hcolor=light-strawberry]:hover{background-color:#f8eded}[border=light-strawberry]{border:1px solid #f8eded}[color=white]{color:#fff}[bgcolor=white],[hcolor=white]:hover{background-color:#fff}[border=white]{border:1px solid #ffffff}[color=cool-green]{color:#33c15d}[bgcolor=cool-green],[hcolor=cool-green]:hover{background-color:#33c15d}[border=cool-green]{border:1px solid #33c15d}[color=light-green]{color:#ebfaef}[bgcolor=light-green],[hcolor=light-green]:hover{background-color:#ebfaef}[border=light-green]{border:1px solid #ebfaef}[color=transparent]{color:transparent}[bgcolor=transparent],[hcolor=transparent]:hover{background-color:transparent}[border=transparent]{border:1px solid transparent}[color=c0]{color:#a566a5}[bgcolor=c0],[hcolor=c0]:hover{background-color:#a566a5}[border=c0]{border:1px solid #A566A5}[color=c1]{color:#c7ab82}[bgcolor=c1],[hcolor=c1]:hover{background-color:#c7ab82}[border=c1]{border:1px solid #C7AB82}[color=c2]{color:#f2713c}[bgcolor=c2],[hcolor=c2]:hover{background-color:#f2713c}[border=c2]{border:1px solid #F2713C}[color=c3]{color:#ffd006}[bgcolor=c3],[hcolor=c3]:hover{background-color:#ffd006}[border=c3]{border:1px solid #FFD006}[color=c4]{color:#94c5aa}[bgcolor=c4],[hcolor=c4]:hover{background-color:#94c5aa}[border=c4]{border:1px solid #94C5AA}[color=c5]{color:#2a9d8f}[bgcolor=c5],[hcolor=c5]:hover{background-color:#2a9d8f}[border=c5]{border:1px solid #2A9D8F}[color=c6]{color:#78acd8}[bgcolor=c6],[hcolor=c6]:hover{background-color:#78acd8}[border=c6]{border:1px solid #78ACD8}[color=c7]{color:#525a9e}[bgcolor=c7],[hcolor=c7]:hover{background-color:#525a9e}[border=c7]{border:1px solid #525A9E}[color=c8]{color:#6a2459}[bgcolor=c8],[hcolor=c8]:hover{background-color:#6a2459}[border=c8]{border:1px solid #6A2459}[color=c9]{color:#74729e}[bgcolor=c9],[hcolor=c9]:hover{background-color:#74729e}[border=c9]{border:1px solid #74729E}.square-button{width:36px;height:36px;max-width:36px;max-height:36px;min-width:36px;min-height:36px;border-radius:var(--ref-border-radius-sm);background:transparent;display:flex;align-items:center;justify-content:center;border:none;box-sizing:border-box}.square-button.active{background-color:var(--ref-color-electric-blue-100)}.square-button.active span{color:var(--ref-color-white)}.square-button:hover{cursor:pointer}.square-button:hover:not(.active){background-color:var(--ref-color-electric-blue-10)}.square-button:active{background-color:var(--ref-color-electric-blue-20)}@media (hover: hover){.square-button:focus:not(.disabled):not(:active){outline:2px solid var(--ref-color-electric-blue-100);outline-offset:1px}}.square-button span{color:var(--ref-color-electric-blue-100);font-family:var(--ref-font-family);font-weight:var(--ref-font-weight-regular);font-size:var(--ref-font-size-sm);line-height:var(--ref-line-height-sm)}\n"] }]
33
+ args: [{ selector: 'ap-paginator-button', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, template: "<button #button\n class=\"square-button\"\n role=\"button\"\n type=\"button\"\n [id]=\"'paginator-button-' + pageIndex\"\n [class.active]=\"selectedPageIndex === pageIndex\"\n [attr.aria-label]=\"ariaLabel || null\"\n (click)=\"onClickHandle(pageIndex)\"\n (blur)=\"onBlurHandle()\"\n (focus)=\"onFocusHandle()\">\n <span>\n {{pageIndex + 1}}\n </span>\n</button>\n", styles: ["[color=facebook]{color:#1877f2}[bgcolor=facebook],[hcolor=facebook]:hover{background-color:#1877f2}[border=facebook]{border:1px solid #1877f2}[color=google]{color:#4e85e8}[bgcolor=google],[hcolor=google]:hover{background-color:#4e85e8}[border=google]{border:1px solid #4e85e8}[color=instagram]{color:#e1306c}[bgcolor=instagram],[hcolor=instagram]:hover{background-color:#e1306c}[border=instagram]{border:1px solid #e1306c}[color=instagrammagenta]{color:#c13584}[bgcolor=instagrammagenta],[hcolor=instagrammagenta]:hover{background-color:#c13584}[border=instagrammagenta]{border:1px solid #c13584}[color=instagramblue]{color:#5851db}[bgcolor=instagramblue],[hcolor=instagramblue]:hover{background-color:#5851db}[border=instagramblue]{border:1px solid #5851db}[color=instagrampurple]{color:#833ab4}[bgcolor=instagrampurple],[hcolor=instagrampurple]:hover{background-color:#833ab4}[border=instagrampurple]{border:1px solid #833ab4}[color=instagramorange]{color:#f56040}[bgcolor=instagramorange],[hcolor=instagramorange]:hover{background-color:#f56040}[border=instagramorange]{border:1px solid #f56040}[color=instagramyellow]{color:#ffdc80}[bgcolor=instagramyellow],[hcolor=instagramyellow]:hover{background-color:#ffdc80}[border=instagramyellow]{border:1px solid #ffdc80}[color=linkedin]{color:#2c67bc}[bgcolor=linkedin],[hcolor=linkedin]:hover{background-color:#2c67bc}[border=linkedin]{border:1px solid #2c67bc}[color=twitter]{color:#55acee}[bgcolor=twitter],[hcolor=twitter]:hover{background-color:#55acee}[border=twitter]{border:1px solid #55acee}[color=youtube]{color:red}[bgcolor=youtube],[hcolor=youtube]:hover{background-color:red}[border=youtube]{border:1px solid #ff0000}[color=blood-orange]{color:#ff4d00}[bgcolor=blood-orange],[hcolor=blood-orange]:hover{background-color:#ff4d00}[border=blood-orange]{border:1px solid #ff4d00}[color=pinkish-orange]{color:#ff7b49}[bgcolor=pinkish-orange],[hcolor=pinkish-orange]:hover{background-color:#ff7b49}[border=pinkish-orange]{border:1px solid #ff7b49}[color=charcoal-grey]{color:#2a2f34}[bgcolor=charcoal-grey],[hcolor=charcoal-grey]:hover{background-color:#2a2f34}[border=charcoal-grey]{border:1px solid #2a2f34}[color=azure]{color:#00aeef}[bgcolor=azure],[hcolor=azure]:hover{background-color:#00aeef}[border=azure]{border:1px solid #00aeef}[color=light-azure]{color:#eaf5fd}[bgcolor=light-azure],[hcolor=light-azure]:hover{background-color:#eaf5fd}[border=light-azure]{border:1px solid #eaf5fd}[color=blue-grey]{color:#8d98a9}[bgcolor=blue-grey],[hcolor=blue-grey]:hover{background-color:#8d98a9}[border=blue-grey]{border:1px solid #8d98a9}[color=silver]{color:#ced0da}[bgcolor=silver],[hcolor=silver]:hover{background-color:#ced0da}[border=silver]{border:1px solid #ced0da}[color=pale-grey]{color:#dfe3e9}[bgcolor=pale-grey],[hcolor=pale-grey]:hover{background-color:#dfe3e9}[border=pale-grey]{border:1px solid #dfe3e9}[color=grey-white]{color:#f5f7f8}[bgcolor=grey-white],[hcolor=grey-white]:hover{background-color:#f5f7f8}[border=grey-white]{border:1px solid #f5f7f8}[color=cool-grey]{color:#b4bbc6}[bgcolor=cool-grey],[hcolor=cool-grey]:hover{background-color:#b4bbc6}[border=cool-grey]{border:1px solid #b4bbc6}[color=black]{color:#344563}[bgcolor=black],[hcolor=black]:hover{background-color:#344563}[border=black]{border:1px solid #344563}[color=grey-blue]{color:#68768c}[bgcolor=grey-blue],[hcolor=grey-blue]:hover{background-color:#68768c}[border=grey-blue]{border:1px solid #68768c}[color=strawberry]{color:#f4282d}[bgcolor=strawberry],[hcolor=strawberry]:hover{background-color:#f4282d}[border=strawberry]{border:1px solid #f4282d}[color=light-strawberry]{color:#f8eded}[bgcolor=light-strawberry],[hcolor=light-strawberry]:hover{background-color:#f8eded}[border=light-strawberry]{border:1px solid #f8eded}[color=white]{color:#fff}[bgcolor=white],[hcolor=white]:hover{background-color:#fff}[border=white]{border:1px solid #ffffff}[color=cool-green]{color:#33c15d}[bgcolor=cool-green],[hcolor=cool-green]:hover{background-color:#33c15d}[border=cool-green]{border:1px solid #33c15d}[color=light-green]{color:#ebfaef}[bgcolor=light-green],[hcolor=light-green]:hover{background-color:#ebfaef}[border=light-green]{border:1px solid #ebfaef}[color=transparent]{color:transparent}[bgcolor=transparent],[hcolor=transparent]:hover{background-color:transparent}[border=transparent]{border:1px solid transparent}[color=c0]{color:#a566a5}[bgcolor=c0],[hcolor=c0]:hover{background-color:#a566a5}[border=c0]{border:1px solid #A566A5}[color=c1]{color:#c7ab82}[bgcolor=c1],[hcolor=c1]:hover{background-color:#c7ab82}[border=c1]{border:1px solid #C7AB82}[color=c2]{color:#f2713c}[bgcolor=c2],[hcolor=c2]:hover{background-color:#f2713c}[border=c2]{border:1px solid #F2713C}[color=c3]{color:#ffd006}[bgcolor=c3],[hcolor=c3]:hover{background-color:#ffd006}[border=c3]{border:1px solid #FFD006}[color=c4]{color:#94c5aa}[bgcolor=c4],[hcolor=c4]:hover{background-color:#94c5aa}[border=c4]{border:1px solid #94C5AA}[color=c5]{color:#2a9d8f}[bgcolor=c5],[hcolor=c5]:hover{background-color:#2a9d8f}[border=c5]{border:1px solid #2A9D8F}[color=c6]{color:#78acd8}[bgcolor=c6],[hcolor=c6]:hover{background-color:#78acd8}[border=c6]{border:1px solid #78ACD8}[color=c7]{color:#525a9e}[bgcolor=c7],[hcolor=c7]:hover{background-color:#525a9e}[border=c7]{border:1px solid #525A9E}[color=c8]{color:#6a2459}[bgcolor=c8],[hcolor=c8]:hover{background-color:#6a2459}[border=c8]{border:1px solid #6A2459}[color=c9]{color:#74729e}[bgcolor=c9],[hcolor=c9]:hover{background-color:#74729e}[border=c9]{border:1px solid #74729E}.square-button{width:36px;height:36px;max-width:36px;max-height:36px;min-width:36px;min-height:36px;border-radius:var(--ref-border-radius-sm);background:transparent;display:flex;align-items:center;justify-content:center;border:none;box-sizing:border-box}.square-button:hover{cursor:pointer}.square-button:hover:not(.active){background-color:var(--ref-color-electric-blue-10)}@media (hover: hover){.square-button:focus:not(.disabled):not(:active){outline:2px solid var(--ref-color-electric-blue-100);outline-offset:1px}}.square-button:active{background-color:var(--ref-color-electric-blue-20)!important}.square-button.active{background-color:var(--ref-color-electric-blue-100)}.square-button.active span{color:var(--ref-color-white)}.square-button span{color:var(--ref-color-electric-blue-100);font-family:var(--ref-font-family);font-weight:var(--ref-font-weight-regular);font-size:var(--ref-font-size-sm);line-height:var(--ref-line-height-sm)}\n"] }]
34
34
  }], propDecorators: { button: [{
35
35
  type: ViewChild,
36
36
  args: ['button']
@@ -1,61 +1,124 @@
1
- import { AgorapulseUiSymbolModule, apArrowLeft1, apArrowRight1 } from '@agorapulse/ui-symbol';
1
+ import { ButtonComponent } from '@agorapulse/ui-components/button';
2
+ import { IconButtonComponent } from '@agorapulse/ui-components/icon-button';
3
+ import { AgorapulseUiSymbolModule, apChevronLeft, apChevronRight } from '@agorapulse/ui-symbol';
2
4
  import { NgForOf, NgIf } from '@angular/common';
3
- import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
5
+ import { ChangeDetectionStrategy, Component, EventEmitter, HostListener, Input, Output, ViewEncapsulation, } from '@angular/core';
6
+ import { FormsModule, ReactiveFormsModule } from '@angular/forms';
7
+ import { BehaviorSubject, combineLatest, distinctUntilChanged, Subject, takeUntil } from 'rxjs';
4
8
  import { PaginatorButtonComponent } from './paginator-button/paginator-button.component';
5
- import { IconButtonComponent } from "@agorapulse/ui-components/icon-button";
6
- import { ButtonComponent } from "@agorapulse/ui-components/button";
7
9
  import * as i0 from "@angular/core";
8
10
  import * as i1 from "@agorapulse/ui-symbol";
11
+ import * as i2 from "@angular/forms";
9
12
  export class PaginatorComponent {
13
+ set currentPageIndex(value) {
14
+ this._currentPageIndex.next(value ?? this.DEFAULT_CURRENT_PAGE_INDEX);
15
+ }
16
+ get currentPageIndex() {
17
+ return this._currentPageIndex.getValue();
18
+ }
19
+ set itemCount(value) {
20
+ this._itemCount.next(value ?? this.DEFAULT_ITEM_COUNT);
21
+ }
22
+ get itemCount() {
23
+ return this._itemCount.getValue();
24
+ }
25
+ set itemCountPerPage(value) {
26
+ this._itemCountPerPage.next(value ?? this.DEFAULT_ITEM_COUNT_PER_PAGE);
27
+ }
28
+ get itemCountPerPage() {
29
+ return this._itemCountPerPage.getValue();
30
+ }
31
+ set middleSize(value) {
32
+ // make sure middle size is an odd number
33
+ if (value && value % 2 === 0) {
34
+ value++;
35
+ }
36
+ this._middleSize = value ?? this.DEFAULT_MIDDLE_SIZE;
37
+ }
38
+ get middleSize() {
39
+ return this._middleSize;
40
+ }
10
41
  constructor(symbolRegistry) {
11
42
  this.symbolRegistry = symbolRegistry;
12
- this.itemCount = 0;
13
- this.itemCountPerPage = 10;
14
- this.edgeSize = 5;
15
- this.middleSize = 3;
16
- this.currentPageIndex = 0;
43
+ this.DEFAULT_MIDDLE_SIZE = 3;
44
+ this.DEFAULT_ITEM_COUNT = 0;
45
+ this.DEFAULT_ITEM_COUNT_PER_PAGE = 10;
46
+ this.DEFAULT_CURRENT_PAGE_INDEX = 0;
47
+ this.DEFAULT_EDGE_SIZE = 5;
48
+ this.displayGoTo = false;
49
+ this.edgeSize = this.DEFAULT_EDGE_SIZE;
50
+ this.goToLabel = 'Go to';
17
51
  this.currentPageIndexChange = new EventEmitter();
52
+ this.pageInput = '';
18
53
  this.pageCount = 0;
19
54
  this.firstPageDisplayed = true;
20
55
  this.lastPageDisplayed = true;
21
- this.symbolRegistry.registerSymbols([
22
- apArrowLeft1,
23
- apArrowRight1
24
- ]);
25
- }
26
- ngOnChanges(changes) {
27
- // make sure middle size is an odd number
28
- if (changes.middleSize && this.middleSize % 2 === 0) {
29
- this.middleSize++;
30
- }
31
- if ((this.itemCountPerPage && (changes.itemCount || changes.itemCountPerPage)) || changes.currentPageIndex) {
32
- this.pageCount = Math.ceil(this.itemCount / this.itemCountPerPage);
56
+ this.destroy$ = new Subject();
57
+ this._itemCount = new BehaviorSubject(this.DEFAULT_ITEM_COUNT);
58
+ this._itemCountPerPage = new BehaviorSubject(this.DEFAULT_ITEM_COUNT_PER_PAGE);
59
+ this._currentPageIndex = new BehaviorSubject(this.DEFAULT_CURRENT_PAGE_INDEX);
60
+ this.symbolRegistry.registerSymbols([apChevronLeft, apChevronRight]);
61
+ combineLatest([this._itemCount, this._itemCountPerPage, this._currentPageIndex])
62
+ .pipe(distinctUntilChanged(([previousItemCount, previousItemCountPerPage, previousCurrentPageIndex], [itemCount, itemCountPerPage, currentPageIndex]) => {
63
+ return (previousItemCount === itemCount &&
64
+ previousItemCountPerPage === itemCountPerPage &&
65
+ previousCurrentPageIndex === currentPageIndex);
66
+ }), takeUntil(this.destroy$))
67
+ .subscribe(([itemCount, itemCountPerPage, currentPageIndex]) => {
68
+ this.pageCount = Math.ceil(itemCount / itemCountPerPage);
33
69
  // make sure page index is between min and max page index
34
- this.currentPageIndex = Math.max(0, Math.min(this.pageCount - 1, this.currentPageIndex));
70
+ this._currentPageIndex.next(Math.max(0, Math.min(this.pageCount - 1, currentPageIndex)));
35
71
  this.firstPageDisplayed = this.currentPageIndex === 0;
36
72
  this.lastPageDisplayed = this.currentPageIndex === this.pageCount - 1;
73
+ });
74
+ }
75
+ ngOnDestroy() {
76
+ this.destroy$.next();
77
+ this.destroy$.complete();
78
+ }
79
+ onEnterKeydownPressed() {
80
+ if (this.pageInput && !isNaN(+this.pageInput) && +this.pageInput > 0 && +this.pageInput <= this.pageCount) {
81
+ this.onSelectPage(+this.pageInput - 1);
37
82
  }
83
+ this.pageInput = '';
38
84
  }
39
85
  onSelectPage(pageIndex) {
86
+ this._currentPageIndex.next(pageIndex);
40
87
  this.currentPageIndexChange.emit(pageIndex);
41
88
  }
42
89
  }
43
90
  PaginatorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.2", ngImport: i0, type: PaginatorComponent, deps: [{ token: i1.SymbolRegistry }], target: i0.ɵɵFactoryTarget.Component });
44
- PaginatorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.2", type: PaginatorComponent, isStandalone: true, selector: "ap-paginator", inputs: { itemCount: "itemCount", itemCountPerPage: "itemCountPerPage", edgeSize: "edgeSize", middleSize: "middleSize", currentPageIndex: "currentPageIndex" }, outputs: { currentPageIndexChange: "currentPageIndexChange" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"item-index-overview\">\n {{(currentPageIndex * itemCountPerPage) + 1}}\n -{{lastPageDisplayed ? itemCount : (currentPageIndex + 1) * itemCountPerPage}}\n of {{itemCount}}\n</div>\n\n<div class=\"pages\">\n <ap-icon-button\n ariaLabel=\"Select Previous Page button\"\n name=\"select-previous-page-button\"\n color=\"blue\"\n [disabled]=\"firstPageDisplayed\"\n (onClick)=\"onSelectPage(currentPageIndex - 1)\"\n type=\"flat\"\n >\n <ap-symbol symbolId=\"arrow-left-1\"></ap-symbol>\n </ap-icon-button>\n <ng-container *ngIf=\"pageCount > edgeSize + 1; else allPagesDisplayed\">\n <ng-container *ngIf=\"currentPageIndex >= edgeSize - 1; else oneOfFirstPagesDisplayed\">\n <ng-container *ngIf=\"currentPageIndex <= pageCount - edgeSize; else oneOfLastPagesDisplayed\">\n <ap-paginator-button [pageIndex]=\"0\"\n [selectedPageIndex]=\"currentPageIndex\"\n (selectPage)=\"onSelectPage($event)\">\n </ap-paginator-button>\n <span class=\"ellipsis\">...</span>\n <ng-container *ngFor=\"let dummy of [].constructor(middleSize); let i = index\">\n <ap-paginator-button [pageIndex]=\"currentPageIndex + i - (middleSize - 1) / 2\"\n [selectedPageIndex]=\"currentPageIndex\"\n (selectPage)=\"onSelectPage($event)\">\n </ap-paginator-button>\n </ng-container>\n <span class=\"ellipsis\">...</span>\n <ap-paginator-button [pageIndex]=\"pageCount - 1\"\n [selectedPageIndex]=\"currentPageIndex\"\n (selectPage)=\"onSelectPage($event)\">\n </ap-paginator-button>\n </ng-container>\n </ng-container>\n <ng-template #oneOfFirstPagesDisplayed>\n <ng-container *ngFor=\"let dummy of [].constructor(edgeSize); let i = index\">\n <ap-paginator-button [pageIndex]=\"i\"\n [selectedPageIndex]=\"currentPageIndex\"\n (selectPage)=\"onSelectPage($event)\">\n </ap-paginator-button>\n </ng-container>\n <span class=\"ellipsis\">...</span>\n <ap-paginator-button [pageIndex]=\"pageCount - 1\"\n [selectedPageIndex]=\"currentPageIndex\"\n (selectPage)=\"onSelectPage($event)\">\n </ap-paginator-button>\n </ng-template>\n <ng-template #oneOfLastPagesDisplayed>\n <ap-paginator-button [pageIndex]=\"0\"\n [selectedPageIndex]=\"currentPageIndex\"\n (selectPage)=\"onSelectPage($event)\">\n </ap-paginator-button>\n <span class=\"ellipsis\">...</span>\n <ng-container *ngFor=\"let dummy of [].constructor(edgeSize); let i = index\">\n <ap-paginator-button [pageIndex]=\"pageCount - edgeSize + i\"\n [selectedPageIndex]=\"currentPageIndex\"\n (selectPage)=\"onSelectPage($event)\">\n </ap-paginator-button>\n </ng-container>\n </ng-template>\n </ng-container>\n <ng-template #allPagesDisplayed>\n <ng-container *ngFor=\"let dummy of [].constructor(pageCount); let i = index\">\n <ap-paginator-button [pageIndex]=\"i\"\n [selectedPageIndex]=\"currentPageIndex\"\n (selectPage)=\"onSelectPage($event)\">\n </ap-paginator-button>\n </ng-container>\n </ng-template>\n <ap-icon-button\n ariaLabel=\"Select Next Page button\"\n name=\"select-next-page-button\"\n color=\"blue\"\n [disabled]=\"lastPageDisplayed\"\n (onClick)=\"onSelectPage(currentPageIndex + 1)\"\n type=\"flat\"\n >\n <ap-symbol symbolId=\"arrow-right-1\"></ap-symbol>\n </ap-icon-button>\n</div>\n", styles: ["[color=facebook]{color:#1877f2}[bgcolor=facebook],[hcolor=facebook]:hover{background-color:#1877f2}[border=facebook]{border:1px solid #1877f2}[color=google]{color:#4e85e8}[bgcolor=google],[hcolor=google]:hover{background-color:#4e85e8}[border=google]{border:1px solid #4e85e8}[color=instagram]{color:#e1306c}[bgcolor=instagram],[hcolor=instagram]:hover{background-color:#e1306c}[border=instagram]{border:1px solid #e1306c}[color=instagrammagenta]{color:#c13584}[bgcolor=instagrammagenta],[hcolor=instagrammagenta]:hover{background-color:#c13584}[border=instagrammagenta]{border:1px solid #c13584}[color=instagramblue]{color:#5851db}[bgcolor=instagramblue],[hcolor=instagramblue]:hover{background-color:#5851db}[border=instagramblue]{border:1px solid #5851db}[color=instagrampurple]{color:#833ab4}[bgcolor=instagrampurple],[hcolor=instagrampurple]:hover{background-color:#833ab4}[border=instagrampurple]{border:1px solid #833ab4}[color=instagramorange]{color:#f56040}[bgcolor=instagramorange],[hcolor=instagramorange]:hover{background-color:#f56040}[border=instagramorange]{border:1px solid #f56040}[color=instagramyellow]{color:#ffdc80}[bgcolor=instagramyellow],[hcolor=instagramyellow]:hover{background-color:#ffdc80}[border=instagramyellow]{border:1px solid #ffdc80}[color=linkedin]{color:#2c67bc}[bgcolor=linkedin],[hcolor=linkedin]:hover{background-color:#2c67bc}[border=linkedin]{border:1px solid #2c67bc}[color=twitter]{color:#55acee}[bgcolor=twitter],[hcolor=twitter]:hover{background-color:#55acee}[border=twitter]{border:1px solid #55acee}[color=youtube]{color:red}[bgcolor=youtube],[hcolor=youtube]:hover{background-color:red}[border=youtube]{border:1px solid #ff0000}[color=blood-orange]{color:#ff4d00}[bgcolor=blood-orange],[hcolor=blood-orange]:hover{background-color:#ff4d00}[border=blood-orange]{border:1px solid #ff4d00}[color=pinkish-orange]{color:#ff7b49}[bgcolor=pinkish-orange],[hcolor=pinkish-orange]:hover{background-color:#ff7b49}[border=pinkish-orange]{border:1px solid #ff7b49}[color=charcoal-grey]{color:#2a2f34}[bgcolor=charcoal-grey],[hcolor=charcoal-grey]:hover{background-color:#2a2f34}[border=charcoal-grey]{border:1px solid #2a2f34}[color=azure]{color:#00aeef}[bgcolor=azure],[hcolor=azure]:hover{background-color:#00aeef}[border=azure]{border:1px solid #00aeef}[color=light-azure]{color:#eaf5fd}[bgcolor=light-azure],[hcolor=light-azure]:hover{background-color:#eaf5fd}[border=light-azure]{border:1px solid #eaf5fd}[color=blue-grey]{color:#8d98a9}[bgcolor=blue-grey],[hcolor=blue-grey]:hover{background-color:#8d98a9}[border=blue-grey]{border:1px solid #8d98a9}[color=silver]{color:#ced0da}[bgcolor=silver],[hcolor=silver]:hover{background-color:#ced0da}[border=silver]{border:1px solid #ced0da}[color=pale-grey]{color:#dfe3e9}[bgcolor=pale-grey],[hcolor=pale-grey]:hover{background-color:#dfe3e9}[border=pale-grey]{border:1px solid #dfe3e9}[color=grey-white]{color:#f5f7f8}[bgcolor=grey-white],[hcolor=grey-white]:hover{background-color:#f5f7f8}[border=grey-white]{border:1px solid #f5f7f8}[color=cool-grey]{color:#b4bbc6}[bgcolor=cool-grey],[hcolor=cool-grey]:hover{background-color:#b4bbc6}[border=cool-grey]{border:1px solid #b4bbc6}[color=black]{color:#344563}[bgcolor=black],[hcolor=black]:hover{background-color:#344563}[border=black]{border:1px solid #344563}[color=grey-blue]{color:#68768c}[bgcolor=grey-blue],[hcolor=grey-blue]:hover{background-color:#68768c}[border=grey-blue]{border:1px solid #68768c}[color=strawberry]{color:#f4282d}[bgcolor=strawberry],[hcolor=strawberry]:hover{background-color:#f4282d}[border=strawberry]{border:1px solid #f4282d}[color=light-strawberry]{color:#f8eded}[bgcolor=light-strawberry],[hcolor=light-strawberry]:hover{background-color:#f8eded}[border=light-strawberry]{border:1px solid #f8eded}[color=white]{color:#fff}[bgcolor=white],[hcolor=white]:hover{background-color:#fff}[border=white]{border:1px solid #ffffff}[color=cool-green]{color:#33c15d}[bgcolor=cool-green],[hcolor=cool-green]:hover{background-color:#33c15d}[border=cool-green]{border:1px solid #33c15d}[color=light-green]{color:#ebfaef}[bgcolor=light-green],[hcolor=light-green]:hover{background-color:#ebfaef}[border=light-green]{border:1px solid #ebfaef}[color=transparent]{color:transparent}[bgcolor=transparent],[hcolor=transparent]:hover{background-color:transparent}[border=transparent]{border:1px solid transparent}[color=c0]{color:#a566a5}[bgcolor=c0],[hcolor=c0]:hover{background-color:#a566a5}[border=c0]{border:1px solid #A566A5}[color=c1]{color:#c7ab82}[bgcolor=c1],[hcolor=c1]:hover{background-color:#c7ab82}[border=c1]{border:1px solid #C7AB82}[color=c2]{color:#f2713c}[bgcolor=c2],[hcolor=c2]:hover{background-color:#f2713c}[border=c2]{border:1px solid #F2713C}[color=c3]{color:#ffd006}[bgcolor=c3],[hcolor=c3]:hover{background-color:#ffd006}[border=c3]{border:1px solid #FFD006}[color=c4]{color:#94c5aa}[bgcolor=c4],[hcolor=c4]:hover{background-color:#94c5aa}[border=c4]{border:1px solid #94C5AA}[color=c5]{color:#2a9d8f}[bgcolor=c5],[hcolor=c5]:hover{background-color:#2a9d8f}[border=c5]{border:1px solid #2A9D8F}[color=c6]{color:#78acd8}[bgcolor=c6],[hcolor=c6]:hover{background-color:#78acd8}[border=c6]{border:1px solid #78ACD8}[color=c7]{color:#525a9e}[bgcolor=c7],[hcolor=c7]:hover{background-color:#525a9e}[border=c7]{border:1px solid #525A9E}[color=c8]{color:#6a2459}[bgcolor=c8],[hcolor=c8]:hover{background-color:#6a2459}[border=c8]{border:1px solid #6A2459}[color=c9]{color:#74729e}[bgcolor=c9],[hcolor=c9]:hover{background-color:#74729e}[border=c9]{border:1px solid #74729E}.item-index-overview{position:absolute;line-height:36px}.pages{display:flex;justify-content:center;color:#178dfe;gap:var(--ref-spacing-xxxs)}.pages ap-paginator-button,.pages button.mat-flat-button{vertical-align:middle}.pages button.mat-flat-button:not(.mat-accent):not([disabled]){color:#178dfe}.pages button.mat-flat-button:not(.mat-accent):not([disabled]):hover{background-color:#e8f4ff}.pages .ellipsis{display:inline-block;width:36px;line-height:36px;text-align:center;vertical-align:bottom}\n"], dependencies: [{ kind: "ngmodule", type: AgorapulseUiSymbolModule }, { kind: "component", type: i1.SymbolComponent, selector: "ap-symbol[symbolId]", inputs: ["color", "symbolId", "size", "state"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: PaginatorButtonComponent, selector: "ap-paginator-button", inputs: ["ariaLabel", "disabled", "pageIndex", "selectedPageIndex"], outputs: ["selectPage"] }, { kind: "directive", type: NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: IconButtonComponent, selector: "ap-icon-button", inputs: ["ariaLabel", "name", "color", "disabled", "menuTrigger", "locked", "loading", "type"], outputs: ["onClick", "onFocus", "onBlur", "menuOpened", "menuClosed"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
91
+ PaginatorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.2", type: PaginatorComponent, isStandalone: true, selector: "ap-paginator", inputs: { currentPageIndex: "currentPageIndex", displayGoTo: "displayGoTo", edgeSize: "edgeSize", goToLabel: "goToLabel", itemCount: "itemCount", itemCountPerPage: "itemCountPerPage", middleSize: "middleSize" }, outputs: { currentPageIndexChange: "currentPageIndexChange" }, host: { listeners: { "keydown.enter": "onEnterKeydownPressed()" } }, ngImport: i0, template: "<div class=\"item-index-overview\">\n {{ currentPageIndex * itemCountPerPage + 1 }}\n - {{ lastPageDisplayed ? itemCount : (currentPageIndex + 1) * itemCountPerPage }} of {{ itemCount }}\n</div>\n\n<div class=\"pages\">\n <button\n class=\"navigation-button\"\n ariaLabel=\"Select Previous Page button\"\n [disabled]=\"firstPageDisplayed\"\n (click)=\"onSelectPage(currentPageIndex - 1)\">\n <ap-symbol symbolId=\"chevron-left\"></ap-symbol>\n </button>\n <ng-container *ngIf=\"pageCount > edgeSize + 1; else allPagesDisplayed\">\n <ng-container *ngIf=\"currentPageIndex >= edgeSize - 1; else oneOfFirstPagesDisplayed\">\n <ng-container *ngIf=\"currentPageIndex <= pageCount - edgeSize; else oneOfLastPagesDisplayed\">\n <ap-paginator-button\n [pageIndex]=\"0\"\n [selectedPageIndex]=\"currentPageIndex\"\n (selectPage)=\"onSelectPage($event)\">\n </ap-paginator-button>\n <span class=\"ellipsis\">...</span>\n <ng-container *ngFor=\"let dummy of [].constructor(middleSize); let i = index\">\n <ap-paginator-button\n [pageIndex]=\"currentPageIndex + i - (middleSize - 1) / 2\"\n [selectedPageIndex]=\"currentPageIndex\"\n (selectPage)=\"onSelectPage($event)\">\n </ap-paginator-button>\n </ng-container>\n <span class=\"ellipsis\">...</span>\n <ap-paginator-button\n [pageIndex]=\"pageCount - 1\"\n [selectedPageIndex]=\"currentPageIndex\"\n (selectPage)=\"onSelectPage($event)\">\n </ap-paginator-button>\n </ng-container>\n </ng-container>\n <ng-template #oneOfFirstPagesDisplayed>\n <ng-container *ngFor=\"let dummy of [].constructor(edgeSize); let i = index\">\n <ap-paginator-button\n [pageIndex]=\"i\"\n [selectedPageIndex]=\"currentPageIndex\"\n (selectPage)=\"onSelectPage($event)\">\n </ap-paginator-button>\n </ng-container>\n <span class=\"ellipsis\">...</span>\n <ap-paginator-button\n [pageIndex]=\"pageCount - 1\"\n [selectedPageIndex]=\"currentPageIndex\"\n (selectPage)=\"onSelectPage($event)\">\n </ap-paginator-button>\n </ng-template>\n <ng-template #oneOfLastPagesDisplayed>\n <ap-paginator-button\n [pageIndex]=\"0\"\n [selectedPageIndex]=\"currentPageIndex\"\n (selectPage)=\"onSelectPage($event)\">\n </ap-paginator-button>\n <span class=\"ellipsis\">...</span>\n <ng-container *ngFor=\"let dummy of [].constructor(edgeSize); let i = index\">\n <ap-paginator-button\n [pageIndex]=\"pageCount - edgeSize + i\"\n [selectedPageIndex]=\"currentPageIndex\"\n (selectPage)=\"onSelectPage($event)\">\n </ap-paginator-button>\n </ng-container>\n </ng-template>\n </ng-container>\n <ng-template #allPagesDisplayed>\n <ng-container *ngFor=\"let dummy of [].constructor(pageCount); let i = index\">\n <ap-paginator-button\n [pageIndex]=\"i\"\n [selectedPageIndex]=\"currentPageIndex\"\n (selectPage)=\"onSelectPage($event)\">\n </ap-paginator-button>\n </ng-container>\n </ng-template>\n <button\n class=\"navigation-button\"\n ariaLabel=\"Select Next Page button\"\n [disabled]=\"lastPageDisplayed\"\n (click)=\"onSelectPage(currentPageIndex + 1)\">\n <ap-symbol symbolId=\"chevron-right\"></ap-symbol>\n </button>\n</div>\n<div *ngIf=\"displayGoTo\" class=\"go-to\">\n <span>{{ goToLabel }}</span>\n <input type=\"number\" [(ngModel)]=\"pageInput\" />\n</div>\n", styles: ["ap-paginator{display:flex;align-items:center;gap:var(--ref-spacing-lg);--paginator-button-height: 36px}ap-paginator .item-index-overview{font-weight:var(--ref-font-weight-regular);font-size:var(--ref-font-size-sm);line-height:var(--ref-line-height-sm);color:var(--ref-color-grey-60);white-space:nowrap}ap-paginator .navigation-button{display:grid;place-content:center;height:var(--paginator-button-height);width:var(--paginator-button-height);min-height:var(--paginator-button-height);min-width:var(--paginator-button-height);max-height:var(--paginator-button-height);max-width:var(--paginator-button-height);border-radius:var(--ref-border-radius-sm);background:transparent;border:none}ap-paginator .navigation-button ap-symbol{color:var(--ref-color-electric-blue-100)}ap-paginator .navigation-button:disabled{pointer-events:none}ap-paginator .navigation-button:disabled ap-symbol{color:var(--ref-color-grey-40)}ap-paginator .navigation-button:not(:disabled){cursor:pointer}ap-paginator .navigation-button:hover:not(:disabled){background:var(--ref-color-electric-blue-10)}ap-paginator .navigation-button:active{background:var(--ref-color-electric-blue-20)}@media (hover: hover){ap-paginator .navigation-button:focus:not(.disabled):not(:active){outline:2px solid var(--ref-color-electric-blue-100);outline-offset:1px}}ap-paginator .pages{display:flex;justify-self:center;color:var(--ref-color-electric-blue-100);gap:var(--ref-spacing-xxxs)}ap-paginator .pages ap-paginator-button,ap-paginator .pages button.mat-flat-button{vertical-align:middle}ap-paginator .pages button.mat-flat-button:not(.mat-accent):not([disabled]){color:var(--ref-color-electric-blue-100)}ap-paginator .pages button.mat-flat-button:not(.mat-accent):not([disabled]):hover{background-color:var(--ref-color-electric-blue-10)}ap-paginator .pages .ellipsis{display:inline-block;width:var(--paginator-button-height);line-height:var(--paginator-button-height);text-align:center;vertical-align:bottom}ap-paginator .go-to{display:flex;align-items:center;gap:var(--ref-spacing-xs)}ap-paginator .go-to span{font-weight:var(--ref-font-weight-standard);font-size:var(--ref-font-size-sm);line-height:var(--ref-line-height-sm);color:var(--ref-color-grey-60)}ap-paginator .go-to input{box-sizing:border-box;background:var(--ref-color-white);width:48px;height:var(--paginator-button-height);border-radius:var(--ref-border-radius-sm);border:1px solid var(--ref-color-grey-20);padding:var(--ref-spacing-xs) var(--ref-spacing-sm)}\n"], dependencies: [{ kind: "ngmodule", type: AgorapulseUiSymbolModule }, { kind: "component", type: i1.SymbolComponent, selector: "ap-symbol[symbolId]", inputs: ["color", "symbolId", "size", "state"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: PaginatorButtonComponent, selector: "ap-paginator-button", inputs: ["ariaLabel", "disabled", "pageIndex", "selectedPageIndex"], outputs: ["selectPage"] }, { kind: "directive", type: NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
45
92
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.2", ngImport: i0, type: PaginatorComponent, decorators: [{
46
93
  type: Component,
47
- args: [{ selector: 'ap-paginator', changeDetection: ChangeDetectionStrategy.OnPush, imports: [AgorapulseUiSymbolModule, ButtonComponent, NgIf, PaginatorButtonComponent, NgForOf, IconButtonComponent], standalone: true, template: "<div class=\"item-index-overview\">\n {{(currentPageIndex * itemCountPerPage) + 1}}\n -{{lastPageDisplayed ? itemCount : (currentPageIndex + 1) * itemCountPerPage}}\n of {{itemCount}}\n</div>\n\n<div class=\"pages\">\n <ap-icon-button\n ariaLabel=\"Select Previous Page button\"\n name=\"select-previous-page-button\"\n color=\"blue\"\n [disabled]=\"firstPageDisplayed\"\n (onClick)=\"onSelectPage(currentPageIndex - 1)\"\n type=\"flat\"\n >\n <ap-symbol symbolId=\"arrow-left-1\"></ap-symbol>\n </ap-icon-button>\n <ng-container *ngIf=\"pageCount > edgeSize + 1; else allPagesDisplayed\">\n <ng-container *ngIf=\"currentPageIndex >= edgeSize - 1; else oneOfFirstPagesDisplayed\">\n <ng-container *ngIf=\"currentPageIndex <= pageCount - edgeSize; else oneOfLastPagesDisplayed\">\n <ap-paginator-button [pageIndex]=\"0\"\n [selectedPageIndex]=\"currentPageIndex\"\n (selectPage)=\"onSelectPage($event)\">\n </ap-paginator-button>\n <span class=\"ellipsis\">...</span>\n <ng-container *ngFor=\"let dummy of [].constructor(middleSize); let i = index\">\n <ap-paginator-button [pageIndex]=\"currentPageIndex + i - (middleSize - 1) / 2\"\n [selectedPageIndex]=\"currentPageIndex\"\n (selectPage)=\"onSelectPage($event)\">\n </ap-paginator-button>\n </ng-container>\n <span class=\"ellipsis\">...</span>\n <ap-paginator-button [pageIndex]=\"pageCount - 1\"\n [selectedPageIndex]=\"currentPageIndex\"\n (selectPage)=\"onSelectPage($event)\">\n </ap-paginator-button>\n </ng-container>\n </ng-container>\n <ng-template #oneOfFirstPagesDisplayed>\n <ng-container *ngFor=\"let dummy of [].constructor(edgeSize); let i = index\">\n <ap-paginator-button [pageIndex]=\"i\"\n [selectedPageIndex]=\"currentPageIndex\"\n (selectPage)=\"onSelectPage($event)\">\n </ap-paginator-button>\n </ng-container>\n <span class=\"ellipsis\">...</span>\n <ap-paginator-button [pageIndex]=\"pageCount - 1\"\n [selectedPageIndex]=\"currentPageIndex\"\n (selectPage)=\"onSelectPage($event)\">\n </ap-paginator-button>\n </ng-template>\n <ng-template #oneOfLastPagesDisplayed>\n <ap-paginator-button [pageIndex]=\"0\"\n [selectedPageIndex]=\"currentPageIndex\"\n (selectPage)=\"onSelectPage($event)\">\n </ap-paginator-button>\n <span class=\"ellipsis\">...</span>\n <ng-container *ngFor=\"let dummy of [].constructor(edgeSize); let i = index\">\n <ap-paginator-button [pageIndex]=\"pageCount - edgeSize + i\"\n [selectedPageIndex]=\"currentPageIndex\"\n (selectPage)=\"onSelectPage($event)\">\n </ap-paginator-button>\n </ng-container>\n </ng-template>\n </ng-container>\n <ng-template #allPagesDisplayed>\n <ng-container *ngFor=\"let dummy of [].constructor(pageCount); let i = index\">\n <ap-paginator-button [pageIndex]=\"i\"\n [selectedPageIndex]=\"currentPageIndex\"\n (selectPage)=\"onSelectPage($event)\">\n </ap-paginator-button>\n </ng-container>\n </ng-template>\n <ap-icon-button\n ariaLabel=\"Select Next Page button\"\n name=\"select-next-page-button\"\n color=\"blue\"\n [disabled]=\"lastPageDisplayed\"\n (onClick)=\"onSelectPage(currentPageIndex + 1)\"\n type=\"flat\"\n >\n <ap-symbol symbolId=\"arrow-right-1\"></ap-symbol>\n </ap-icon-button>\n</div>\n", styles: ["[color=facebook]{color:#1877f2}[bgcolor=facebook],[hcolor=facebook]:hover{background-color:#1877f2}[border=facebook]{border:1px solid #1877f2}[color=google]{color:#4e85e8}[bgcolor=google],[hcolor=google]:hover{background-color:#4e85e8}[border=google]{border:1px solid #4e85e8}[color=instagram]{color:#e1306c}[bgcolor=instagram],[hcolor=instagram]:hover{background-color:#e1306c}[border=instagram]{border:1px solid #e1306c}[color=instagrammagenta]{color:#c13584}[bgcolor=instagrammagenta],[hcolor=instagrammagenta]:hover{background-color:#c13584}[border=instagrammagenta]{border:1px solid #c13584}[color=instagramblue]{color:#5851db}[bgcolor=instagramblue],[hcolor=instagramblue]:hover{background-color:#5851db}[border=instagramblue]{border:1px solid #5851db}[color=instagrampurple]{color:#833ab4}[bgcolor=instagrampurple],[hcolor=instagrampurple]:hover{background-color:#833ab4}[border=instagrampurple]{border:1px solid #833ab4}[color=instagramorange]{color:#f56040}[bgcolor=instagramorange],[hcolor=instagramorange]:hover{background-color:#f56040}[border=instagramorange]{border:1px solid #f56040}[color=instagramyellow]{color:#ffdc80}[bgcolor=instagramyellow],[hcolor=instagramyellow]:hover{background-color:#ffdc80}[border=instagramyellow]{border:1px solid #ffdc80}[color=linkedin]{color:#2c67bc}[bgcolor=linkedin],[hcolor=linkedin]:hover{background-color:#2c67bc}[border=linkedin]{border:1px solid #2c67bc}[color=twitter]{color:#55acee}[bgcolor=twitter],[hcolor=twitter]:hover{background-color:#55acee}[border=twitter]{border:1px solid #55acee}[color=youtube]{color:red}[bgcolor=youtube],[hcolor=youtube]:hover{background-color:red}[border=youtube]{border:1px solid #ff0000}[color=blood-orange]{color:#ff4d00}[bgcolor=blood-orange],[hcolor=blood-orange]:hover{background-color:#ff4d00}[border=blood-orange]{border:1px solid #ff4d00}[color=pinkish-orange]{color:#ff7b49}[bgcolor=pinkish-orange],[hcolor=pinkish-orange]:hover{background-color:#ff7b49}[border=pinkish-orange]{border:1px solid #ff7b49}[color=charcoal-grey]{color:#2a2f34}[bgcolor=charcoal-grey],[hcolor=charcoal-grey]:hover{background-color:#2a2f34}[border=charcoal-grey]{border:1px solid #2a2f34}[color=azure]{color:#00aeef}[bgcolor=azure],[hcolor=azure]:hover{background-color:#00aeef}[border=azure]{border:1px solid #00aeef}[color=light-azure]{color:#eaf5fd}[bgcolor=light-azure],[hcolor=light-azure]:hover{background-color:#eaf5fd}[border=light-azure]{border:1px solid #eaf5fd}[color=blue-grey]{color:#8d98a9}[bgcolor=blue-grey],[hcolor=blue-grey]:hover{background-color:#8d98a9}[border=blue-grey]{border:1px solid #8d98a9}[color=silver]{color:#ced0da}[bgcolor=silver],[hcolor=silver]:hover{background-color:#ced0da}[border=silver]{border:1px solid #ced0da}[color=pale-grey]{color:#dfe3e9}[bgcolor=pale-grey],[hcolor=pale-grey]:hover{background-color:#dfe3e9}[border=pale-grey]{border:1px solid #dfe3e9}[color=grey-white]{color:#f5f7f8}[bgcolor=grey-white],[hcolor=grey-white]:hover{background-color:#f5f7f8}[border=grey-white]{border:1px solid #f5f7f8}[color=cool-grey]{color:#b4bbc6}[bgcolor=cool-grey],[hcolor=cool-grey]:hover{background-color:#b4bbc6}[border=cool-grey]{border:1px solid #b4bbc6}[color=black]{color:#344563}[bgcolor=black],[hcolor=black]:hover{background-color:#344563}[border=black]{border:1px solid #344563}[color=grey-blue]{color:#68768c}[bgcolor=grey-blue],[hcolor=grey-blue]:hover{background-color:#68768c}[border=grey-blue]{border:1px solid #68768c}[color=strawberry]{color:#f4282d}[bgcolor=strawberry],[hcolor=strawberry]:hover{background-color:#f4282d}[border=strawberry]{border:1px solid #f4282d}[color=light-strawberry]{color:#f8eded}[bgcolor=light-strawberry],[hcolor=light-strawberry]:hover{background-color:#f8eded}[border=light-strawberry]{border:1px solid #f8eded}[color=white]{color:#fff}[bgcolor=white],[hcolor=white]:hover{background-color:#fff}[border=white]{border:1px solid #ffffff}[color=cool-green]{color:#33c15d}[bgcolor=cool-green],[hcolor=cool-green]:hover{background-color:#33c15d}[border=cool-green]{border:1px solid #33c15d}[color=light-green]{color:#ebfaef}[bgcolor=light-green],[hcolor=light-green]:hover{background-color:#ebfaef}[border=light-green]{border:1px solid #ebfaef}[color=transparent]{color:transparent}[bgcolor=transparent],[hcolor=transparent]:hover{background-color:transparent}[border=transparent]{border:1px solid transparent}[color=c0]{color:#a566a5}[bgcolor=c0],[hcolor=c0]:hover{background-color:#a566a5}[border=c0]{border:1px solid #A566A5}[color=c1]{color:#c7ab82}[bgcolor=c1],[hcolor=c1]:hover{background-color:#c7ab82}[border=c1]{border:1px solid #C7AB82}[color=c2]{color:#f2713c}[bgcolor=c2],[hcolor=c2]:hover{background-color:#f2713c}[border=c2]{border:1px solid #F2713C}[color=c3]{color:#ffd006}[bgcolor=c3],[hcolor=c3]:hover{background-color:#ffd006}[border=c3]{border:1px solid #FFD006}[color=c4]{color:#94c5aa}[bgcolor=c4],[hcolor=c4]:hover{background-color:#94c5aa}[border=c4]{border:1px solid #94C5AA}[color=c5]{color:#2a9d8f}[bgcolor=c5],[hcolor=c5]:hover{background-color:#2a9d8f}[border=c5]{border:1px solid #2A9D8F}[color=c6]{color:#78acd8}[bgcolor=c6],[hcolor=c6]:hover{background-color:#78acd8}[border=c6]{border:1px solid #78ACD8}[color=c7]{color:#525a9e}[bgcolor=c7],[hcolor=c7]:hover{background-color:#525a9e}[border=c7]{border:1px solid #525A9E}[color=c8]{color:#6a2459}[bgcolor=c8],[hcolor=c8]:hover{background-color:#6a2459}[border=c8]{border:1px solid #6A2459}[color=c9]{color:#74729e}[bgcolor=c9],[hcolor=c9]:hover{background-color:#74729e}[border=c9]{border:1px solid #74729E}.item-index-overview{position:absolute;line-height:36px}.pages{display:flex;justify-content:center;color:#178dfe;gap:var(--ref-spacing-xxxs)}.pages ap-paginator-button,.pages button.mat-flat-button{vertical-align:middle}.pages button.mat-flat-button:not(.mat-accent):not([disabled]){color:#178dfe}.pages button.mat-flat-button:not(.mat-accent):not([disabled]):hover{background-color:#e8f4ff}.pages .ellipsis{display:inline-block;width:36px;line-height:36px;text-align:center;vertical-align:bottom}\n"] }]
48
- }], ctorParameters: function () { return [{ type: i1.SymbolRegistry }]; }, propDecorators: { itemCount: [{
94
+ args: [{ selector: 'ap-paginator', changeDetection: ChangeDetectionStrategy.OnPush, imports: [
95
+ AgorapulseUiSymbolModule,
96
+ ButtonComponent,
97
+ NgIf,
98
+ PaginatorButtonComponent,
99
+ NgForOf,
100
+ IconButtonComponent,
101
+ ReactiveFormsModule,
102
+ FormsModule,
103
+ ], standalone: true, encapsulation: ViewEncapsulation.None, template: "<div class=\"item-index-overview\">\n {{ currentPageIndex * itemCountPerPage + 1 }}\n - {{ lastPageDisplayed ? itemCount : (currentPageIndex + 1) * itemCountPerPage }} of {{ itemCount }}\n</div>\n\n<div class=\"pages\">\n <button\n class=\"navigation-button\"\n ariaLabel=\"Select Previous Page button\"\n [disabled]=\"firstPageDisplayed\"\n (click)=\"onSelectPage(currentPageIndex - 1)\">\n <ap-symbol symbolId=\"chevron-left\"></ap-symbol>\n </button>\n <ng-container *ngIf=\"pageCount > edgeSize + 1; else allPagesDisplayed\">\n <ng-container *ngIf=\"currentPageIndex >= edgeSize - 1; else oneOfFirstPagesDisplayed\">\n <ng-container *ngIf=\"currentPageIndex <= pageCount - edgeSize; else oneOfLastPagesDisplayed\">\n <ap-paginator-button\n [pageIndex]=\"0\"\n [selectedPageIndex]=\"currentPageIndex\"\n (selectPage)=\"onSelectPage($event)\">\n </ap-paginator-button>\n <span class=\"ellipsis\">...</span>\n <ng-container *ngFor=\"let dummy of [].constructor(middleSize); let i = index\">\n <ap-paginator-button\n [pageIndex]=\"currentPageIndex + i - (middleSize - 1) / 2\"\n [selectedPageIndex]=\"currentPageIndex\"\n (selectPage)=\"onSelectPage($event)\">\n </ap-paginator-button>\n </ng-container>\n <span class=\"ellipsis\">...</span>\n <ap-paginator-button\n [pageIndex]=\"pageCount - 1\"\n [selectedPageIndex]=\"currentPageIndex\"\n (selectPage)=\"onSelectPage($event)\">\n </ap-paginator-button>\n </ng-container>\n </ng-container>\n <ng-template #oneOfFirstPagesDisplayed>\n <ng-container *ngFor=\"let dummy of [].constructor(edgeSize); let i = index\">\n <ap-paginator-button\n [pageIndex]=\"i\"\n [selectedPageIndex]=\"currentPageIndex\"\n (selectPage)=\"onSelectPage($event)\">\n </ap-paginator-button>\n </ng-container>\n <span class=\"ellipsis\">...</span>\n <ap-paginator-button\n [pageIndex]=\"pageCount - 1\"\n [selectedPageIndex]=\"currentPageIndex\"\n (selectPage)=\"onSelectPage($event)\">\n </ap-paginator-button>\n </ng-template>\n <ng-template #oneOfLastPagesDisplayed>\n <ap-paginator-button\n [pageIndex]=\"0\"\n [selectedPageIndex]=\"currentPageIndex\"\n (selectPage)=\"onSelectPage($event)\">\n </ap-paginator-button>\n <span class=\"ellipsis\">...</span>\n <ng-container *ngFor=\"let dummy of [].constructor(edgeSize); let i = index\">\n <ap-paginator-button\n [pageIndex]=\"pageCount - edgeSize + i\"\n [selectedPageIndex]=\"currentPageIndex\"\n (selectPage)=\"onSelectPage($event)\">\n </ap-paginator-button>\n </ng-container>\n </ng-template>\n </ng-container>\n <ng-template #allPagesDisplayed>\n <ng-container *ngFor=\"let dummy of [].constructor(pageCount); let i = index\">\n <ap-paginator-button\n [pageIndex]=\"i\"\n [selectedPageIndex]=\"currentPageIndex\"\n (selectPage)=\"onSelectPage($event)\">\n </ap-paginator-button>\n </ng-container>\n </ng-template>\n <button\n class=\"navigation-button\"\n ariaLabel=\"Select Next Page button\"\n [disabled]=\"lastPageDisplayed\"\n (click)=\"onSelectPage(currentPageIndex + 1)\">\n <ap-symbol symbolId=\"chevron-right\"></ap-symbol>\n </button>\n</div>\n<div *ngIf=\"displayGoTo\" class=\"go-to\">\n <span>{{ goToLabel }}</span>\n <input type=\"number\" [(ngModel)]=\"pageInput\" />\n</div>\n", styles: ["ap-paginator{display:flex;align-items:center;gap:var(--ref-spacing-lg);--paginator-button-height: 36px}ap-paginator .item-index-overview{font-weight:var(--ref-font-weight-regular);font-size:var(--ref-font-size-sm);line-height:var(--ref-line-height-sm);color:var(--ref-color-grey-60);white-space:nowrap}ap-paginator .navigation-button{display:grid;place-content:center;height:var(--paginator-button-height);width:var(--paginator-button-height);min-height:var(--paginator-button-height);min-width:var(--paginator-button-height);max-height:var(--paginator-button-height);max-width:var(--paginator-button-height);border-radius:var(--ref-border-radius-sm);background:transparent;border:none}ap-paginator .navigation-button ap-symbol{color:var(--ref-color-electric-blue-100)}ap-paginator .navigation-button:disabled{pointer-events:none}ap-paginator .navigation-button:disabled ap-symbol{color:var(--ref-color-grey-40)}ap-paginator .navigation-button:not(:disabled){cursor:pointer}ap-paginator .navigation-button:hover:not(:disabled){background:var(--ref-color-electric-blue-10)}ap-paginator .navigation-button:active{background:var(--ref-color-electric-blue-20)}@media (hover: hover){ap-paginator .navigation-button:focus:not(.disabled):not(:active){outline:2px solid var(--ref-color-electric-blue-100);outline-offset:1px}}ap-paginator .pages{display:flex;justify-self:center;color:var(--ref-color-electric-blue-100);gap:var(--ref-spacing-xxxs)}ap-paginator .pages ap-paginator-button,ap-paginator .pages button.mat-flat-button{vertical-align:middle}ap-paginator .pages button.mat-flat-button:not(.mat-accent):not([disabled]){color:var(--ref-color-electric-blue-100)}ap-paginator .pages button.mat-flat-button:not(.mat-accent):not([disabled]):hover{background-color:var(--ref-color-electric-blue-10)}ap-paginator .pages .ellipsis{display:inline-block;width:var(--paginator-button-height);line-height:var(--paginator-button-height);text-align:center;vertical-align:bottom}ap-paginator .go-to{display:flex;align-items:center;gap:var(--ref-spacing-xs)}ap-paginator .go-to span{font-weight:var(--ref-font-weight-standard);font-size:var(--ref-font-size-sm);line-height:var(--ref-line-height-sm);color:var(--ref-color-grey-60)}ap-paginator .go-to input{box-sizing:border-box;background:var(--ref-color-white);width:48px;height:var(--paginator-button-height);border-radius:var(--ref-border-radius-sm);border:1px solid var(--ref-color-grey-20);padding:var(--ref-spacing-xs) var(--ref-spacing-sm)}\n"] }]
104
+ }], ctorParameters: function () { return [{ type: i1.SymbolRegistry }]; }, propDecorators: { currentPageIndex: [{
49
105
  type: Input
50
- }], itemCountPerPage: [{
106
+ }], displayGoTo: [{
51
107
  type: Input
52
108
  }], edgeSize: [{
53
109
  type: Input
54
- }], middleSize: [{
110
+ }], goToLabel: [{
111
+ type: Input
112
+ }], itemCount: [{
55
113
  type: Input
56
- }], currentPageIndex: [{
114
+ }], itemCountPerPage: [{
115
+ type: Input
116
+ }], middleSize: [{
57
117
  type: Input
58
118
  }], currentPageIndexChange: [{
59
119
  type: Output
120
+ }], onEnterKeydownPressed: [{
121
+ type: HostListener,
122
+ args: ['keydown.enter']
60
123
  }] } });
61
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"paginator.component.js","sourceRoot":"","sources":["../../../../libs/ui-components/paginator/src/paginator.component.ts","../../../../libs/ui-components/paginator/src/paginator.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,wBAAwB,EAAE,YAAY,EAAE,aAAa,EAAiB,MAAM,uBAAuB,CAAC;AAC5G,OAAO,EAAC,OAAO,EAAE,IAAI,EAAC,MAAM,iBAAiB,CAAC;AAC9C,OAAO,EAAC,uBAAuB,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAa,MAAM,EAAgB,MAAM,eAAe,CAAC;AACxH,OAAO,EAAC,wBAAwB,EAAC,MAAM,+CAA+C,CAAC;AACvF,OAAO,EAAC,mBAAmB,EAAC,MAAM,uCAAuC,CAAC;AAC1E,OAAO,EAAC,eAAe,EAAC,MAAM,kCAAkC,CAAC;;;AAUjE,MAAM,OAAO,kBAAkB;IAa3B,YAAmB,cAA8B;QAA9B,mBAAc,GAAd,cAAc,CAAgB;QAZxC,cAAS,GAAG,CAAC,CAAC;QACd,qBAAgB,GAAG,EAAE,CAAC;QACtB,aAAQ,GAAG,CAAC,CAAC;QACb,eAAU,GAAG,CAAC,CAAC;QAEf,qBAAgB,GAAG,CAAC,CAAC;QACpB,2BAAsB,GAAG,IAAI,YAAY,EAAU,CAAC;QAEvD,cAAS,GAAG,CAAC,CAAC;QACd,uBAAkB,GAAG,IAAI,CAAC;QAC1B,sBAAiB,GAAG,IAAI,CAAC;QAG5B,IAAI,CAAC,cAAc,CAAC,eAAe,CAAC;YAChC,YAAY;YACZ,aAAa;SAChB,CAAC,CAAC;IACP,CAAC;IAED,WAAW,CAAC,OAAsB;QAC9B,yCAAyC;QACzC,IAAI,OAAO,CAAC,UAAU,IAAI,IAAI,CAAC,UAAU,GAAG,CAAC,KAAK,CAAC,EAAE;YACjD,IAAI,CAAC,UAAU,EAAE,CAAC;SACrB;QACD,IAAI,CAAC,IAAI,CAAC,gBAAgB,IAAI,CAAC,OAAO,CAAC,SAAS,IAAI,OAAO,CAAC,gBAAgB,CAAC,CAAC,IAAI,OAAO,CAAC,gBAAgB,EAAE;YACxG,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,gBAAgB,CAAC,CAAC;YACnE,yDAAyD;YACzD,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,GAAG,CAAC,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC;YACzF,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,gBAAgB,KAAK,CAAC,CAAC;YACtD,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,gBAAgB,KAAK,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;SACzE;IACL,CAAC;IAED,YAAY,CAAC,SAAiB;QAC1B,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAChD,CAAC;;+GApCQ,kBAAkB;mGAAlB,kBAAkB,4TCf/B,2qIAoFA,o9LDxEc,wBAAwB,iKAAmB,IAAI,6FAAE,wBAAwB,8JAAE,OAAO,mHAAE,mBAAmB;2FAGxG,kBAAkB;kBAR9B,SAAS;+BACI,cAAc,mBAGP,uBAAuB,CAAC,MAAM,WACtC,CAAC,wBAAwB,EAAE,eAAe,EAAE,IAAI,EAAE,wBAAwB,EAAE,OAAO,EAAE,mBAAmB,CAAC,cACtG,IAAI;qGAGP,SAAS;sBAAjB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBAEG,gBAAgB;sBAAxB,KAAK;gBACI,sBAAsB;sBAA/B,MAAM","sourcesContent":["import {AgorapulseUiSymbolModule, apArrowLeft1, apArrowRight1, SymbolRegistry} from '@agorapulse/ui-symbol';\nimport {NgForOf, NgIf} from '@angular/common';\nimport {ChangeDetectionStrategy, Component, EventEmitter, Input, OnChanges, Output, SimpleChanges} from '@angular/core';\nimport {PaginatorButtonComponent} from './paginator-button/paginator-button.component';\nimport {IconButtonComponent} from \"@agorapulse/ui-components/icon-button\";\nimport {ButtonComponent} from \"@agorapulse/ui-components/button\";\n\n@Component({\n    selector: 'ap-paginator',\n    templateUrl: './paginator.component.html',\n    styleUrls: ['./paginator.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    imports: [AgorapulseUiSymbolModule, ButtonComponent, NgIf, PaginatorButtonComponent, NgForOf, IconButtonComponent],\n    standalone: true,\n})\nexport class PaginatorComponent implements OnChanges {\n    @Input() itemCount = 0;\n    @Input() itemCountPerPage = 10;\n    @Input() edgeSize = 5;\n    @Input() middleSize = 3;\n\n    @Input() currentPageIndex = 0;\n    @Output() currentPageIndexChange = new EventEmitter<number>();\n\n    public pageCount = 0;\n    public firstPageDisplayed = true;\n    public lastPageDisplayed = true;\n\n    constructor(public symbolRegistry: SymbolRegistry) {\n        this.symbolRegistry.registerSymbols([\n            apArrowLeft1,\n            apArrowRight1\n        ]);\n    }\n\n    ngOnChanges(changes: SimpleChanges) {\n        // make sure middle size is an odd number\n        if (changes.middleSize && this.middleSize % 2 === 0) {\n            this.middleSize++;\n        }\n        if ((this.itemCountPerPage && (changes.itemCount || changes.itemCountPerPage)) || changes.currentPageIndex) {\n            this.pageCount = Math.ceil(this.itemCount / this.itemCountPerPage);\n            // make sure page index is between min and max page index\n            this.currentPageIndex = Math.max(0, Math.min(this.pageCount - 1, this.currentPageIndex));\n            this.firstPageDisplayed = this.currentPageIndex === 0;\n            this.lastPageDisplayed = this.currentPageIndex === this.pageCount - 1;\n        }\n    }\n\n    onSelectPage(pageIndex: number): void {\n        this.currentPageIndexChange.emit(pageIndex);\n    }\n}\n","<div class=\"item-index-overview\">\n    {{(currentPageIndex * itemCountPerPage) + 1}}\n    -{{lastPageDisplayed ? itemCount : (currentPageIndex + 1) * itemCountPerPage}}\n    of {{itemCount}}\n</div>\n\n<div class=\"pages\">\n    <ap-icon-button\n        ariaLabel=\"Select Previous Page button\"\n        name=\"select-previous-page-button\"\n        color=\"blue\"\n        [disabled]=\"firstPageDisplayed\"\n        (onClick)=\"onSelectPage(currentPageIndex - 1)\"\n        type=\"flat\"\n    >\n        <ap-symbol symbolId=\"arrow-left-1\"></ap-symbol>\n    </ap-icon-button>\n    <ng-container *ngIf=\"pageCount > edgeSize + 1; else allPagesDisplayed\">\n        <ng-container *ngIf=\"currentPageIndex >= edgeSize - 1; else oneOfFirstPagesDisplayed\">\n            <ng-container *ngIf=\"currentPageIndex <= pageCount - edgeSize; else oneOfLastPagesDisplayed\">\n                <ap-paginator-button [pageIndex]=\"0\"\n                                     [selectedPageIndex]=\"currentPageIndex\"\n                                     (selectPage)=\"onSelectPage($event)\">\n                </ap-paginator-button>\n                <span class=\"ellipsis\">...</span>\n                <ng-container *ngFor=\"let dummy of [].constructor(middleSize); let i = index\">\n                    <ap-paginator-button [pageIndex]=\"currentPageIndex + i - (middleSize - 1) / 2\"\n                                         [selectedPageIndex]=\"currentPageIndex\"\n                                         (selectPage)=\"onSelectPage($event)\">\n                    </ap-paginator-button>\n                </ng-container>\n                <span class=\"ellipsis\">...</span>\n                <ap-paginator-button [pageIndex]=\"pageCount - 1\"\n                                     [selectedPageIndex]=\"currentPageIndex\"\n                                     (selectPage)=\"onSelectPage($event)\">\n                </ap-paginator-button>\n            </ng-container>\n        </ng-container>\n        <ng-template #oneOfFirstPagesDisplayed>\n            <ng-container *ngFor=\"let dummy of [].constructor(edgeSize); let i = index\">\n                <ap-paginator-button [pageIndex]=\"i\"\n                                     [selectedPageIndex]=\"currentPageIndex\"\n                                     (selectPage)=\"onSelectPage($event)\">\n                </ap-paginator-button>\n            </ng-container>\n            <span class=\"ellipsis\">...</span>\n            <ap-paginator-button [pageIndex]=\"pageCount - 1\"\n                                 [selectedPageIndex]=\"currentPageIndex\"\n                                 (selectPage)=\"onSelectPage($event)\">\n            </ap-paginator-button>\n        </ng-template>\n        <ng-template #oneOfLastPagesDisplayed>\n            <ap-paginator-button [pageIndex]=\"0\"\n                                 [selectedPageIndex]=\"currentPageIndex\"\n                                 (selectPage)=\"onSelectPage($event)\">\n            </ap-paginator-button>\n            <span class=\"ellipsis\">...</span>\n            <ng-container *ngFor=\"let dummy of [].constructor(edgeSize); let i = index\">\n                <ap-paginator-button [pageIndex]=\"pageCount - edgeSize + i\"\n                                     [selectedPageIndex]=\"currentPageIndex\"\n                                     (selectPage)=\"onSelectPage($event)\">\n                </ap-paginator-button>\n            </ng-container>\n        </ng-template>\n    </ng-container>\n    <ng-template #allPagesDisplayed>\n        <ng-container *ngFor=\"let dummy of [].constructor(pageCount); let i = index\">\n            <ap-paginator-button [pageIndex]=\"i\"\n                                 [selectedPageIndex]=\"currentPageIndex\"\n                                 (selectPage)=\"onSelectPage($event)\">\n            </ap-paginator-button>\n        </ng-container>\n    </ng-template>\n    <ap-icon-button\n        ariaLabel=\"Select Next Page button\"\n        name=\"select-next-page-button\"\n        color=\"blue\"\n        [disabled]=\"lastPageDisplayed\"\n        (onClick)=\"onSelectPage(currentPageIndex + 1)\"\n        type=\"flat\"\n    >\n        <ap-symbol symbolId=\"arrow-right-1\"></ap-symbol>\n    </ap-icon-button>\n</div>\n"]}
124
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"paginator.component.js","sourceRoot":"","sources":["../../../../libs/ui-components/paginator/src/paginator.component.ts","../../../../libs/ui-components/paginator/src/paginator.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ButtonComponent} from '@agorapulse/ui-components/button';\nimport {IconButtonComponent} from '@agorapulse/ui-components/icon-button';\nimport {AgorapulseUiSymbolModule, apChevronLeft, apChevronRight, SymbolRegistry} from '@agorapulse/ui-symbol';\nimport {NgForOf, NgIf} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    EventEmitter,\n    HostListener,\n    Input,\n    OnDestroy,\n    Output,\n    ViewEncapsulation,\n} from '@angular/core';\nimport {FormsModule, ReactiveFormsModule} from '@angular/forms';\nimport {BehaviorSubject, combineLatest, distinctUntilChanged, Subject, takeUntil} from 'rxjs';\nimport {PaginatorButtonComponent} from './paginator-button/paginator-button.component';\n\n@Component({\n    selector: 'ap-paginator',\n    templateUrl: './paginator.component.html',\n    styleUrls: ['./paginator.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    imports: [\n        AgorapulseUiSymbolModule,\n        ButtonComponent,\n        NgIf,\n        PaginatorButtonComponent,\n        NgForOf,\n        IconButtonComponent,\n        ReactiveFormsModule,\n        FormsModule,\n    ],\n    standalone: true,\n    encapsulation: ViewEncapsulation.None,\n})\nexport class PaginatorComponent implements OnDestroy {\n    readonly DEFAULT_MIDDLE_SIZE = 3;\n    readonly DEFAULT_ITEM_COUNT = 0;\n    readonly DEFAULT_ITEM_COUNT_PER_PAGE = 10;\n    readonly DEFAULT_CURRENT_PAGE_INDEX = 0;\n    readonly DEFAULT_EDGE_SIZE = 5;\n\n    @Input() set currentPageIndex(value: number) {\n        this._currentPageIndex.next(value ?? this.DEFAULT_CURRENT_PAGE_INDEX);\n    }\n\n    get currentPageIndex(): number {\n        return this._currentPageIndex.getValue();\n    }\n\n    @Input() displayGoTo = false;\n    @Input() edgeSize: number = this.DEFAULT_EDGE_SIZE;\n    @Input() goToLabel: string = 'Go to';\n    @Input() set itemCount(value: number) {\n        this._itemCount.next(value ?? this.DEFAULT_ITEM_COUNT);\n    }\n\n    get itemCount(): number {\n        return this._itemCount.getValue();\n    }\n    @Input() set itemCountPerPage(value: number) {\n        this._itemCountPerPage.next(value ?? this.DEFAULT_ITEM_COUNT_PER_PAGE);\n    }\n\n    get itemCountPerPage(): number {\n        return this._itemCountPerPage.getValue();\n    }\n\n    private _middleSize: number;\n    @Input() set middleSize(value: number) {\n        // make sure middle size is an odd number\n        if (value && value % 2 === 0) {\n            value++;\n        }\n        this._middleSize = value ?? this.DEFAULT_MIDDLE_SIZE;\n    }\n\n    get middleSize(): number {\n        return this._middleSize;\n    }\n\n    @Output() currentPageIndexChange = new EventEmitter<number>();\n\n    pageInput: string = '';\n    pageCount = 0;\n    firstPageDisplayed = true;\n    lastPageDisplayed = true;\n    private destroy$: Subject<void> = new Subject<void>();\n\n    private _itemCount: BehaviorSubject<number> = new BehaviorSubject<number>(this.DEFAULT_ITEM_COUNT);\n    private _itemCountPerPage: BehaviorSubject<number> = new BehaviorSubject<number>(this.DEFAULT_ITEM_COUNT_PER_PAGE);\n    private _currentPageIndex: BehaviorSubject<number> = new BehaviorSubject<number>(this.DEFAULT_CURRENT_PAGE_INDEX);\n\n    constructor(public symbolRegistry: SymbolRegistry) {\n        this.symbolRegistry.registerSymbols([apChevronLeft, apChevronRight]);\n        combineLatest([this._itemCount, this._itemCountPerPage, this._currentPageIndex])\n            .pipe(\n                distinctUntilChanged(\n                    (\n                        [previousItemCount, previousItemCountPerPage, previousCurrentPageIndex],\n                        [itemCount, itemCountPerPage, currentPageIndex]\n                    ) => {\n                        return (\n                            previousItemCount === itemCount &&\n                            previousItemCountPerPage === itemCountPerPage &&\n                            previousCurrentPageIndex === currentPageIndex\n                        );\n                    }\n                ),\n                takeUntil(this.destroy$)\n            )\n            .subscribe(([itemCount, itemCountPerPage, currentPageIndex]) => {\n                this.pageCount = Math.ceil(itemCount / itemCountPerPage);\n                // make sure page index is between min and max page index\n                this._currentPageIndex.next(Math.max(0, Math.min(this.pageCount - 1, currentPageIndex)));\n                this.firstPageDisplayed = this.currentPageIndex === 0;\n                this.lastPageDisplayed = this.currentPageIndex === this.pageCount - 1;\n            });\n    }\n    ngOnDestroy(): void {\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n\n    @HostListener('keydown.enter')\n    onEnterKeydownPressed() {\n        if (this.pageInput && !isNaN(+this.pageInput) && +this.pageInput > 0 && +this.pageInput <= this.pageCount) {\n            this.onSelectPage(+this.pageInput - 1);\n        }\n        this.pageInput = '';\n    }\n\n    onSelectPage(pageIndex: number): void {\n        this._currentPageIndex.next(pageIndex);\n        this.currentPageIndexChange.emit(pageIndex);\n    }\n}\n","<div class=\"item-index-overview\">\n    {{ currentPageIndex * itemCountPerPage + 1 }}\n    - {{ lastPageDisplayed ? itemCount : (currentPageIndex + 1) * itemCountPerPage }} of {{ itemCount }}\n</div>\n\n<div class=\"pages\">\n    <button\n        class=\"navigation-button\"\n        ariaLabel=\"Select Previous Page button\"\n        [disabled]=\"firstPageDisplayed\"\n        (click)=\"onSelectPage(currentPageIndex - 1)\">\n        <ap-symbol symbolId=\"chevron-left\"></ap-symbol>\n    </button>\n    <ng-container *ngIf=\"pageCount > edgeSize + 1; else allPagesDisplayed\">\n        <ng-container *ngIf=\"currentPageIndex >= edgeSize - 1; else oneOfFirstPagesDisplayed\">\n            <ng-container *ngIf=\"currentPageIndex <= pageCount - edgeSize; else oneOfLastPagesDisplayed\">\n                <ap-paginator-button\n                    [pageIndex]=\"0\"\n                    [selectedPageIndex]=\"currentPageIndex\"\n                    (selectPage)=\"onSelectPage($event)\">\n                </ap-paginator-button>\n                <span class=\"ellipsis\">...</span>\n                <ng-container *ngFor=\"let dummy of [].constructor(middleSize); let i = index\">\n                    <ap-paginator-button\n                        [pageIndex]=\"currentPageIndex + i - (middleSize - 1) / 2\"\n                        [selectedPageIndex]=\"currentPageIndex\"\n                        (selectPage)=\"onSelectPage($event)\">\n                    </ap-paginator-button>\n                </ng-container>\n                <span class=\"ellipsis\">...</span>\n                <ap-paginator-button\n                    [pageIndex]=\"pageCount - 1\"\n                    [selectedPageIndex]=\"currentPageIndex\"\n                    (selectPage)=\"onSelectPage($event)\">\n                </ap-paginator-button>\n            </ng-container>\n        </ng-container>\n        <ng-template #oneOfFirstPagesDisplayed>\n            <ng-container *ngFor=\"let dummy of [].constructor(edgeSize); let i = index\">\n                <ap-paginator-button\n                    [pageIndex]=\"i\"\n                    [selectedPageIndex]=\"currentPageIndex\"\n                    (selectPage)=\"onSelectPage($event)\">\n                </ap-paginator-button>\n            </ng-container>\n            <span class=\"ellipsis\">...</span>\n            <ap-paginator-button\n                [pageIndex]=\"pageCount - 1\"\n                [selectedPageIndex]=\"currentPageIndex\"\n                (selectPage)=\"onSelectPage($event)\">\n            </ap-paginator-button>\n        </ng-template>\n        <ng-template #oneOfLastPagesDisplayed>\n            <ap-paginator-button\n                [pageIndex]=\"0\"\n                [selectedPageIndex]=\"currentPageIndex\"\n                (selectPage)=\"onSelectPage($event)\">\n            </ap-paginator-button>\n            <span class=\"ellipsis\">...</span>\n            <ng-container *ngFor=\"let dummy of [].constructor(edgeSize); let i = index\">\n                <ap-paginator-button\n                    [pageIndex]=\"pageCount - edgeSize + i\"\n                    [selectedPageIndex]=\"currentPageIndex\"\n                    (selectPage)=\"onSelectPage($event)\">\n                </ap-paginator-button>\n            </ng-container>\n        </ng-template>\n    </ng-container>\n    <ng-template #allPagesDisplayed>\n        <ng-container *ngFor=\"let dummy of [].constructor(pageCount); let i = index\">\n            <ap-paginator-button\n                [pageIndex]=\"i\"\n                [selectedPageIndex]=\"currentPageIndex\"\n                (selectPage)=\"onSelectPage($event)\">\n            </ap-paginator-button>\n        </ng-container>\n    </ng-template>\n    <button\n        class=\"navigation-button\"\n        ariaLabel=\"Select Next Page button\"\n        [disabled]=\"lastPageDisplayed\"\n        (click)=\"onSelectPage(currentPageIndex + 1)\">\n        <ap-symbol symbolId=\"chevron-right\"></ap-symbol>\n    </button>\n</div>\n<div *ngIf=\"displayGoTo\" class=\"go-to\">\n    <span>{{ goToLabel }}</span>\n    <input type=\"number\" [(ngModel)]=\"pageInput\" />\n</div>\n"]}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './public_api';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWdvcmFwdWxzZS11aS1jb21wb25lbnRzLXJhZGlvLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vbGlicy91aS1jb21wb25lbnRzL3JhZGlvL3NyYy9hZ29yYXB1bHNlLXVpLWNvbXBvbmVudHMtcmFkaW8udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWNfYXBpJztcbiJdfQ==
@@ -0,0 +1,3 @@
1
+ export * from './radio.component';
2
+ export * from './radio-control.registry';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2xpYnMvdWktY29tcG9uZW50cy9yYWRpby9zcmMvcHVibGljX2FwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsMEJBQTBCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3JhZGlvLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3JhZGlvLWNvbnRyb2wucmVnaXN0cnknO1xuIl19