@agorapulse/ui-components 17.4.15 → 17.5.0-beta.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (69) hide show
  1. package/agorapulse-ui-components-1.0.0-SNAPSHOT.tgz +0 -0
  2. package/agorapulse-ui-components-17.5.0-beta.1.tgz +0 -0
  3. package/avatar/avatar.component.d.ts +145 -45
  4. package/esm2022/autocomplete/autocomplete.component.mjs +2 -2
  5. package/esm2022/avatar/avatar.component.mjs +162 -190
  6. package/esm2022/legacy/select/select.component.mjs +2 -2
  7. package/esm2022/select/dropdown-item-multiple-one-line/dropdown-item-multiple-one-line.component.mjs +2 -2
  8. package/esm2022/select/dropdown-item-multiple-two-lines/dropdown-item-multiple-two-lines.component.mjs +2 -2
  9. package/esm2022/select/dropdown-item-single-one-line/dropdown-item-single-one-line.component.mjs +2 -2
  10. package/esm2022/select/dropdown-item-single-two-lines/dropdown-item-single-two-lines.component.mjs +2 -2
  11. package/esm2022/select/select-label-multiple/select-label-multiple.component.mjs +2 -2
  12. package/esm2022/select/select-label-single/select-label-single.component.mjs +1 -1
  13. package/esm2022/toggle/toggle.component.mjs +5 -5
  14. package/fesm2022/agorapulse-ui-components-add-comment.mjs.map +1 -1
  15. package/fesm2022/agorapulse-ui-components-autocomplete.mjs +1 -1
  16. package/fesm2022/agorapulse-ui-components-autocomplete.mjs.map +1 -1
  17. package/fesm2022/agorapulse-ui-components-avatar.mjs +162 -190
  18. package/fesm2022/agorapulse-ui-components-avatar.mjs.map +1 -1
  19. package/fesm2022/agorapulse-ui-components-badge.mjs.map +1 -1
  20. package/fesm2022/agorapulse-ui-components-button.mjs.map +1 -1
  21. package/fesm2022/agorapulse-ui-components-checkbox.mjs.map +1 -1
  22. package/fesm2022/agorapulse-ui-components-confirm-modal.mjs.map +1 -1
  23. package/fesm2022/agorapulse-ui-components-counter.mjs.map +1 -1
  24. package/fesm2022/agorapulse-ui-components-datepicker.mjs.map +1 -1
  25. package/fesm2022/agorapulse-ui-components-directives.mjs.map +1 -1
  26. package/fesm2022/agorapulse-ui-components-dot-stepper.mjs.map +1 -1
  27. package/fesm2022/agorapulse-ui-components-form-field.mjs.map +1 -1
  28. package/fesm2022/agorapulse-ui-components-form-message.mjs.map +1 -1
  29. package/fesm2022/agorapulse-ui-components-icon-button.mjs.map +1 -1
  30. package/fesm2022/agorapulse-ui-components-infobox.mjs.map +1 -1
  31. package/fesm2022/agorapulse-ui-components-input-group.mjs.map +1 -1
  32. package/fesm2022/agorapulse-ui-components-input-search.mjs.map +1 -1
  33. package/fesm2022/agorapulse-ui-components-input.mjs.map +1 -1
  34. package/fesm2022/agorapulse-ui-components-labels-selector.mjs.map +1 -1
  35. package/fesm2022/agorapulse-ui-components-labels.mjs.map +1 -1
  36. package/fesm2022/agorapulse-ui-components-legacy-input.mjs.map +1 -1
  37. package/fesm2022/agorapulse-ui-components-legacy-select.mjs +1 -1
  38. package/fesm2022/agorapulse-ui-components-legacy-select.mjs.map +1 -1
  39. package/fesm2022/agorapulse-ui-components-legacy-textarea.mjs.map +1 -1
  40. package/fesm2022/agorapulse-ui-components-media-display-overlay.mjs.map +1 -1
  41. package/fesm2022/agorapulse-ui-components-modal.mjs.map +1 -1
  42. package/fesm2022/agorapulse-ui-components-neo-datepicker.mjs.map +1 -1
  43. package/fesm2022/agorapulse-ui-components-notification.mjs.map +1 -1
  44. package/fesm2022/agorapulse-ui-components-paginator.mjs.map +1 -1
  45. package/fesm2022/agorapulse-ui-components-password-input.mjs.map +1 -1
  46. package/fesm2022/agorapulse-ui-components-phone-number-input.mjs.map +1 -1
  47. package/fesm2022/agorapulse-ui-components-popmenu.mjs.map +1 -1
  48. package/fesm2022/agorapulse-ui-components-radio.mjs.map +1 -1
  49. package/fesm2022/agorapulse-ui-components-range-slider.mjs.map +1 -1
  50. package/fesm2022/agorapulse-ui-components-select.mjs +6 -6
  51. package/fesm2022/agorapulse-ui-components-select.mjs.map +1 -1
  52. package/fesm2022/agorapulse-ui-components-slide-toggle.mjs.map +1 -1
  53. package/fesm2022/agorapulse-ui-components-snackbars-thread.mjs.map +1 -1
  54. package/fesm2022/agorapulse-ui-components-social-button.mjs.map +1 -1
  55. package/fesm2022/agorapulse-ui-components-split-button.mjs.map +1 -1
  56. package/fesm2022/agorapulse-ui-components-status-card.mjs.map +1 -1
  57. package/fesm2022/agorapulse-ui-components-status.mjs.map +1 -1
  58. package/fesm2022/agorapulse-ui-components-stepper.mjs.map +1 -1
  59. package/fesm2022/agorapulse-ui-components-tag.mjs.map +1 -1
  60. package/fesm2022/agorapulse-ui-components-text-measurement.mjs.map +1 -1
  61. package/fesm2022/agorapulse-ui-components-textarea.mjs.map +1 -1
  62. package/fesm2022/agorapulse-ui-components-toggle.mjs +4 -4
  63. package/fesm2022/agorapulse-ui-components-toggle.mjs.map +1 -1
  64. package/fesm2022/agorapulse-ui-components-tooltip.mjs.map +1 -1
  65. package/fesm2022/agorapulse-ui-components.mjs.map +1 -1
  66. package/package.json +54 -54
  67. package/select/select-label-multiple/select-label-multiple.component.d.ts +1 -1
  68. package/tooltip/tooltip.directive.d.ts +1 -1
  69. package/agorapulse-ui-components-17.4.15.tgz +0 -0
@@ -1,12 +1,66 @@
1
- import { SymbolComponent, apFacebookOfficial, apGoogleMyBusinessOfficial, apLinkedinOfficial, apPinterestOfficial, apNsThreadsLogo, apShowTheaterMaskHappy, apSingleNeutral, apTiktokOfficial, apWebBlogs, apWebNews, apXOfficial, apYoutubeOfficial, apBlueskyOfficial, } from '@agorapulse/ui-symbol';
2
- import { NgClass, NgOptimizedImage } from '@angular/common';
3
- import { ChangeDetectionStrategy, Component, HostBinding, Input, ViewEncapsulation, booleanAttribute, } from '@angular/core';
4
- import { LetDirective } from '@ngrx/component';
5
- import { BehaviorSubject, Observable, combineLatest, map, of } from 'rxjs';
1
+ import { apBlueskyOfficial, apFacebookOfficial, apGoogleMyBusinessOfficial, apLinkedinOfficial, apNsThreadsLogo, apPinterestOfficial, apTiktokOfficial, apWebBlogs, apWebNews, apXOfficial, apYoutubeOfficial, SymbolComponent, } from '@agorapulse/ui-symbol';
2
+ import { NgClass, NgOptimizedImage, NgStyle } from '@angular/common';
3
+ import { booleanAttribute, ChangeDetectionStrategy, Component, computed, effect, input, signal, untracked } from '@angular/core';
6
4
  import * as i0 from "@angular/core";
7
5
  import * as i1 from "@agorapulse/ui-symbol";
8
- export const AVATAR_NETWORK_ARRAY = ['facebook', 'linkedin', 'twitter', 'X', 'youtube', 'googleMyBusiness', 'google', 'instagram', 'threads', 'tiktok', 'pinterest', 'webBlog', 'webNews', 'bluesky'];
9
- const ROUND_BORDER_AVATAR_NETWORK = ['facebook', 'twitter', 'youtube', 'tiktok', 'X', 'pinterest', 'webBlog', 'webNews', 'threads', 'bluesky'];
6
+ import * as i2 from "@angular/common";
7
+ export const networkSymbolByNetwork = {
8
+ bluesky: {
9
+ round: true,
10
+ symbol: apBlueskyOfficial,
11
+ },
12
+ facebook: {
13
+ round: true,
14
+ symbol: apFacebookOfficial,
15
+ },
16
+ google: {
17
+ round: false,
18
+ symbol: apGoogleMyBusinessOfficial,
19
+ },
20
+ instagram: {
21
+ round: false,
22
+ symbol: 'instagram-official', // embedded
23
+ },
24
+ linkedin: {
25
+ round: false,
26
+ symbol: apLinkedinOfficial,
27
+ },
28
+ pinterest: {
29
+ round: true,
30
+ symbol: apPinterestOfficial,
31
+ },
32
+ threads: {
33
+ round: true,
34
+ symbol: apNsThreadsLogo,
35
+ },
36
+ tiktok: {
37
+ round: true,
38
+ symbol: apTiktokOfficial,
39
+ },
40
+ twitter: {
41
+ round: true,
42
+ symbol: apXOfficial,
43
+ },
44
+ webBlog: {
45
+ round: true,
46
+ symbol: apWebBlogs,
47
+ },
48
+ webNews: {
49
+ round: true,
50
+ symbol: apWebNews,
51
+ },
52
+ X: {
53
+ round: true,
54
+ symbol: apXOfficial,
55
+ },
56
+ youtube: {
57
+ round: true,
58
+ symbol: apYoutubeOfficial,
59
+ },
60
+ };
61
+ function toSymbol(symbol) {
62
+ return typeof symbol == 'string' ? symbol : symbol.name;
63
+ }
10
64
  const onlineIconSizeByAvatarSize = {
11
65
  56: 16,
12
66
  48: 12,
@@ -43,198 +97,116 @@ const initialSizeByAvatarSize = {
43
97
  24: 14,
44
98
  16: 10,
45
99
  };
100
+ const automaticBigSymbolNetwork = ['youtube'];
46
101
  export class AvatarComponent {
47
- symbolRegistry;
48
- elementRef;
49
- networkSymbolByNetwork = {
50
- facebook: 'facebook-official',
51
- instagram: 'instagram-official',
52
- X: 'x-official',
53
- twitter: 'x-official',
54
- linkedin: 'linkedin-official',
55
- tiktok: 'tiktok-official',
56
- youtube: 'youtube-official',
57
- pinterest: 'pinterest-official',
58
- threads: 'ns-threads-logo',
59
- googleMyBusiness: 'google-my-business-official',
60
- google: 'google-my-business-official',
61
- webNews: 'web-news',
62
- webBlog: 'web-blogs',
63
- bluesky: 'bluesky-official'
64
- };
65
- size$ = new BehaviorSubject(40);
66
- profilePicture$ = new BehaviorSubject('');
67
- network$ = new BehaviorSubject(undefined);
68
- alternativeText$ = new BehaviorSubject('');
69
- anonymous$ = new BehaviorSubject(false);
70
- username$ = new BehaviorSubject('');
71
- online$ = new BehaviorSubject(false);
72
- showInitials$ = new BehaviorSubject(false);
73
- rounded$ = new BehaviorSubject(true);
74
- set alternativeText(alternativeText) {
75
- this.alternativeText$.next(alternativeText);
102
+ ngStyle;
103
+ profilePicture = input();
104
+ alt = input('');
105
+ network = input(undefined, {
106
+ transform: (v) => (v !== undefined ? v : v),
107
+ });
108
+ size = input(40);
109
+ username = input('');
110
+ showInitials = input();
111
+ bigNetwork = input(false);
112
+ anonymous = input(false);
113
+ online = input(false);
114
+ hideNetwork = input(false, { alias: 'youtubeAvatarMode' });
115
+ rounded = input(true, { transform: booleanAttribute });
116
+ imageError = signal(false);
117
+ backgroundView = computed(() => this.buildBackgroundView());
118
+ overlayView = computed(() => this.buildOverlayView());
119
+ useBigNetwork = computed(() => {
120
+ return (this.automaticBigSymbolNetwork() || this.bigNetwork()) && !this.hideNetwork();
121
+ });
122
+ automaticBigSymbolNetwork = computed(() => {
123
+ return automaticBigSymbolNetwork.includes(this.network());
124
+ });
125
+ constructor(symbolRegistry, ngStyle) {
126
+ this.ngStyle = ngStyle;
127
+ symbolRegistry.registerSymbols(Object.values(networkSymbolByNetwork).flatMap(({ symbol }) => (typeof symbol !== 'string' ? [symbol] : [])));
128
+ effect(() => {
129
+ this.ngStyle.ngStyle = this.buildHostStyle();
130
+ this.ngStyle.ngDoCheck();
131
+ });
132
+ effect(() => {
133
+ this.profilePicture(); // on change
134
+ untracked(() => this.imageError.set(false));
135
+ });
76
136
  }
77
- set anonymous(anonymous) {
78
- this.anonymous$.next(anonymous);
79
- }
80
- set username(username) {
81
- this.username$.next(username);
137
+ onImageError() {
138
+ this.imageError.set(true);
82
139
  }
83
- set network(network) {
84
- this.network$.next(network);
85
- if (network === 'youtube') {
86
- this.youtubeAvatar = true;
140
+ buildBackgroundView() {
141
+ let bgView = {};
142
+ if (this.useBigNetwork()) {
143
+ bgView = { mode: 'symbol', symbolId: toSymbol(networkSymbolByNetwork[this.network()].symbol), big: true };
87
144
  }
88
- this.elementRef.nativeElement.style.setProperty('--ap-avatar-network-size', `${networkSizeByAvatarSize[this.size$.value]}px`);
89
- }
90
- set online(online) {
91
- this.online$.next(online);
92
- }
93
- set profilePicture(profilePicture) {
94
- this.profilePicture$.next(profilePicture);
95
- this.imageError$.next(false);
96
- }
97
- set showInitials(showInitials) {
98
- this.showInitials$.next(showInitials);
99
- }
100
- alt = '';
101
- youtubeAvatarMode = false;
102
- roundedAvatar = true;
103
- youtubeAvatar = false;
104
- set rounded(rounded) {
105
- this.roundedAvatar = rounded;
106
- this.rounded$.next(rounded);
107
- }
108
- // TODO - migrate to signal input and remove size input
109
- set size(size) {
110
- this.size$.next(+size);
111
- this.elementRef.nativeElement.style.setProperty('--ap-avatar-size', `${size}px`);
112
- this.elementRef.nativeElement.style.setProperty('--ap-avatar-symbol-size', `${symbolSizeByAvatarSize[size]}px`);
113
- this.elementRef.nativeElement.style.setProperty('--ap-avatar-online-icon-size', `${onlineIconSizeByAvatarSize[size]}px`);
114
- }
115
- displayProfilePicture$ = new Observable();
116
- displaySingleNeutralSvg$ = new Observable();
117
- displayInitials$ = new Observable();
118
- displayAnonymous$ = new Observable();
119
- displayNetwork$ = new Observable();
120
- displayOnline$ = new Observable();
121
- imageError$ = new BehaviorSubject(false);
122
- initials$ = new Observable();
123
- initialsAvailable$ = of(false);
124
- socialNetwork$ = of(false);
125
- constructor(symbolRegistry, elementRef) {
126
- this.symbolRegistry = symbolRegistry;
127
- this.elementRef = elementRef;
128
- this.symbolRegistry.registerSymbols([
129
- apSingleNeutral,
130
- apShowTheaterMaskHappy,
131
- apFacebookOfficial,
132
- apLinkedinOfficial,
133
- apYoutubeOfficial,
134
- apTiktokOfficial,
135
- apGoogleMyBusinessOfficial,
136
- apPinterestOfficial,
137
- apNsThreadsLogo,
138
- apXOfficial,
139
- apBlueskyOfficial,
140
- apWebBlogs,
141
- apWebNews,
142
- ]);
143
- this.elementRef.nativeElement.style.setProperty('--ap-avatar-size', `40px`);
144
- this.elementRef.nativeElement.style.setProperty('--ap-avatar-symbol-size', `${symbolSizeByAvatarSize[this.size$.value]}px`);
145
+ else if (this.anonymous()) {
146
+ bgView = { mode: 'symbol', symbolId: 'show-theater-mask-happy' };
147
+ }
148
+ else {
149
+ const profilePicture = this.profilePicture();
150
+ if (profilePicture && !this.useBigNetwork() && !this.imageError()) {
151
+ bgView = {
152
+ mode: 'image',
153
+ image: {
154
+ src: profilePicture,
155
+ size: +this.size(),
156
+ alt: this.alt(),
157
+ },
158
+ };
159
+ }
160
+ else {
161
+ const initials = this.showInitials();
162
+ if (initials !== false && initials !== undefined) {
163
+ const useDefault = initials === true || initials === '';
164
+ const candidateName = (useDefault ? this.username().charAt(0) : initials.slice(0, 2)).toUpperCase();
165
+ bgView = { mode: 'initials', text: candidateName };
166
+ }
167
+ else {
168
+ if (!this.useBigNetwork()) {
169
+ bgView = { mode: 'symbol', symbolId: 'single-neutral' };
170
+ }
171
+ }
172
+ }
173
+ }
174
+ return bgView;
145
175
  }
146
- ngOnInit() {
147
- this.initialsAvailable$ = this.username$.pipe(map(username => {
148
- return !!username;
149
- }));
150
- this.displayProfilePicture$ = combineLatest([this.profilePicture$, this.anonymous$, this.imageError$, this.showInitials$]).pipe(map(([profilePicture, anonymous, imageError]) => {
151
- return !!profilePicture && !anonymous && !imageError;
152
- }));
153
- this.displayInitials$ = combineLatest([
154
- this.showInitials$,
155
- this.anonymous$,
156
- this.initialsAvailable$,
157
- this.displayProfilePicture$,
158
- ]).pipe(map(([showInitials, anonymous, initialsAvailable, displayProfilePicture]) => {
159
- return showInitials && !anonymous && initialsAvailable && !displayProfilePicture;
160
- }));
161
- this.displaySingleNeutralSvg$ = combineLatest([
162
- this.profilePicture$,
163
- this.imageError$,
164
- this.initialsAvailable$,
165
- this.showInitials$,
166
- this.anonymous$,
167
- this.displayInitials$,
168
- this.displayProfilePicture$,
169
- ]).pipe(map(([profilePicture, imageError, initialsAvailable, showInitials, anonymous, displayInitials, displayProfilePicture]) => {
170
- return ((!profilePicture || imageError || !initialsAvailable || (initialsAvailable && !showInitials)) &&
171
- !anonymous &&
172
- !displayInitials &&
173
- !displayProfilePicture);
174
- }));
175
- this.displayAnonymous$ = combineLatest([this.anonymous$, this.rounded$]).pipe(map(([anonymous, rounded]) => {
176
- return anonymous && rounded;
177
- }));
178
- this.displayOnline$ = combineLatest([this.online$, this.rounded$]).pipe(map(([online, rounded]) => {
179
- return online && rounded;
180
- }));
181
- this.displayNetwork$ = combineLatest([this.network$, this.rounded$]).pipe(map(([network, rounded]) => {
182
- return !!network && rounded;
183
- }));
184
- this.socialNetwork$ = this.network$.pipe(map(network => {
185
- if (!network) {
186
- return false;
176
+ buildOverlayView() {
177
+ let ovlView = {};
178
+ const network = this.network();
179
+ if (!this.automaticBigSymbolNetwork()) {
180
+ if (network && !this.bigNetwork() && !this.hideNetwork()) {
181
+ const { symbol, round } = networkSymbolByNetwork[network];
182
+ ovlView = { mode: 'network', network, symbolId: toSymbol(symbol), round };
187
183
  }
188
- return ROUND_BORDER_AVATAR_NETWORK.indexOf(network) > -1;
189
- }));
190
- this.initials$ = combineLatest([this.displayInitials$, this.username$]).pipe(map(([displayInitials, username]) => {
191
- if ((displayInitials && !username) || !displayInitials) {
192
- return '';
184
+ else if (this.online()) {
185
+ ovlView = { mode: 'online' };
193
186
  }
194
- this.elementRef.nativeElement.style.setProperty('--ap-avatar-initials-size', `${initialSizeByAvatarSize[this.size$.value]}px`);
195
- const names = username?.split(' ');
196
- return `${names[0].charAt(0).toUpperCase()}`;
197
- }));
187
+ }
188
+ return ovlView;
198
189
  }
199
- onImageError() {
200
- this.imageError$.next(true);
190
+ buildHostStyle() {
191
+ const bgView = this.backgroundView();
192
+ const ovlMode = this.overlayView().mode;
193
+ const size = this.size();
194
+ return {
195
+ '--ap-avatar-size': `${size}px`,
196
+ '--ap-avatar-border-radius': this.rounded() ? '100%' : 'var(--sys-border-radius-sm)',
197
+ '--ap-avatar-initials-size': bgView.mode == 'initials' ? `${initialSizeByAvatarSize[size]}px` : '',
198
+ '--ap-avatar-symbol-size': bgView.mode == 'symbol' ? `${bgView.big ? size : symbolSizeByAvatarSize[size]}px` : '',
199
+ '--ap-avatar-network-size': ovlMode == 'network' ? `${networkSizeByAvatarSize[size]}px` : '',
200
+ '--ap-avatar-online-icon-size': ovlMode == 'online' ? `${onlineIconSizeByAvatarSize[size]}px` : '',
201
+ };
201
202
  }
202
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: AvatarComponent, deps: [{ token: i1.SymbolRegistry }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
203
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.3", type: AvatarComponent, isStandalone: true, selector: "ap-avatar", inputs: { alternativeText: "alternativeText", anonymous: "anonymous", username: "username", network: "network", online: "online", profilePicture: "profilePicture", showInitials: "showInitials", alt: "alt", youtubeAvatarMode: "youtubeAvatarMode", rounded: ["rounded", "rounded", booleanAttribute], size: "size" }, host: { properties: { "class.rounded-avatar": "this.roundedAvatar", "class.youtube-avatar": "this.youtubeAvatar" } }, ngImport: i0, template: "<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 socialNetwork: socialNetwork$\n } as avatarViewModel\">\n @if (avatarViewModel.displayProfilePicture) {\n @if (avatarViewModel.network !== 'youtube' || youtubeAvatarMode) {\n <img\n [src]=\"avatarViewModel.profilePicture\"\n [width]=\"avatarViewModel.size\"\n [height]=\"avatarViewModel.size\"\n [alt]=\"alt\"\n (error)=\"onImageError()\" />\n } @else {\n <ap-symbol [symbolId]=\"networkSymbolByNetwork[avatarViewModel.network]\" />\n }\n }\n @if (avatarViewModel.displaySingleNeutralSvg) {\n <div class=\"no-profile-picture\">\n <ap-symbol symbolId=\"single-neutral\" />\n </div>\n }\n\n @if (avatarViewModel.displayAnonymous) {\n <div class=\"anonymous\">\n <ap-symbol symbolId=\"show-theater-mask-happy\" />\n </div>\n }\n @if (avatarViewModel.displayOnline) {\n <div class=\"online\"></div>\n }\n @if (avatarViewModel.displayNetwork && avatarViewModel.network && avatarViewModel.network !== 'youtube') {\n <div\n class=\"network\"\n [class.social-network]=\"avatarViewModel.socialNetwork\"\n [ngClass]=\"avatarViewModel.network\">\n <ap-symbol [symbolId]=\"networkSymbolByNetwork[avatarViewModel.network]\" />\n </div>\n }\n\n @if (avatarViewModel.displayInitials) {\n <div class=\"initials\">\n {{ avatarViewModel.initials }}\n </div>\n }\n</ng-container>\n", styles: ["ap-avatar{display:flex;justify-content:center;align-items:center;height:var(--ap-avatar-size);min-height:var(--ap-avatar-size);max-height:var(--ap-avatar-size);width:var(--ap-avatar-size);min-width:var(--ap-avatar-size);max-width:var(--ap-avatar-size);border-radius:var(--sys-border-radius-sm);background:var(--ref-color-grey-40);box-sizing:border-box;position:relative;box-shadow:0 0 0 1px var(--ref-color-grey-10)}ap-avatar.rounded-avatar{border-radius:100%}ap-avatar.rounded-avatar img,ap-avatar.rounded-avatar .no-profile-picture,ap-avatar.rounded-avatar .anonymous{border-radius:100%}ap-avatar.youtube-avatar{box-shadow:unset;background:unset}ap-avatar.youtube-avatar ap-symbol .svg.youtube-official{position:relative;top:unset!important;left:unset!important;width:104.35%!important;height:unset!important}ap-avatar img{overflow:hidden;border-radius:var(--sys-border-radius-sm);box-sizing:border-box}ap-avatar .no-profile-picture,ap-avatar .anonymous{display:flex;justify-content:center;align-items:center;background:var(--ref-color-grey-40);border-radius:var(--sys-border-radius-sm)}ap-avatar .no-profile-picture ap-symbol,ap-avatar .anonymous ap-symbol{color:var(--ref-color-white);width:var(--ap-avatar-symbol-size);min-width:var(--ap-avatar-symbol-size);max-width:var(--ap-avatar-symbol-size);height:var(--ap-avatar-symbol-size);min-height:var(--ap-avatar-symbol-size);max-height:var(--ap-avatar-symbol-size)}ap-avatar .anonymous{margin-top:7%}ap-avatar .online{position:absolute;height:var(--ap-avatar-online-icon-size);min-height:var(--ap-avatar-online-icon-size);max-height:var(--ap-avatar-online-icon-size);width:var(--ap-avatar-online-icon-size);min-width:var(--ap-avatar-online-icon-size);max-width:var(--ap-avatar-online-icon-size);border-radius:100%;overflow:hidden;background:var(--ref-color-grey-40);box-sizing:border-box;border:1px solid var(--ref-color-white);bottom:0;right:0;background:var(--ref-color-green-100)}ap-avatar .initials{font-weight:var(--ref-font-weight-bold);font-size:var(--ap-avatar-initials-size);line-height:var(--ref-font-line-height-xl);font-family:Averta;color:var(--ref-color-white)}ap-avatar .network{position:absolute;height:var(--ap-avatar-online-icon-size);min-height:var(--ap-avatar-network-size);max-height:var(--ap-avatar-network-size);width:var(--ap-avatar-network-size);min-width:var(--ap-avatar-network-size);max-width:var(--ap-avatar-network-size);overflow:hidden;box-sizing:border-box;bottom:0;right:0;box-shadow:0 0 0 1px var(--ref-color-grey-10)}ap-avatar .network.social-network{border-radius:100%}ap-avatar .network.instagram{border-radius:28%}ap-avatar .network.linkedin{border-radius:6%}ap-avatar .network.googleMyBusiness,ap-avatar .network.google{box-shadow:none;border-radius:unset}ap-avatar .network ap-symbol img{border-radius:0;border:none}\n"], dependencies: [{ kind: "component", type: SymbolComponent, selector: "ap-symbol", inputs: ["color", "symbolId", "size"] }, { kind: "directive", type: LetDirective, selector: "[ngrxLet]", inputs: ["ngrxLet", "ngrxLetSuspenseTpl"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
203
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: AvatarComponent, deps: [{ token: i1.SymbolRegistry }, { token: i2.NgStyle }], target: i0.ɵɵFactoryTarget.Component });
204
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.3", type: AvatarComponent, isStandalone: true, selector: "ap-avatar", inputs: { profilePicture: { classPropertyName: "profilePicture", publicName: "profilePicture", isSignal: true, isRequired: false, transformFunction: null }, alt: { classPropertyName: "alt", publicName: "alt", isSignal: true, isRequired: false, transformFunction: null }, network: { classPropertyName: "network", publicName: "network", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null }, username: { classPropertyName: "username", publicName: "username", isSignal: true, isRequired: false, transformFunction: null }, showInitials: { classPropertyName: "showInitials", publicName: "showInitials", isSignal: true, isRequired: false, transformFunction: null }, bigNetwork: { classPropertyName: "bigNetwork", publicName: "bigNetwork", isSignal: true, isRequired: false, transformFunction: null }, anonymous: { classPropertyName: "anonymous", publicName: "anonymous", isSignal: true, isRequired: false, transformFunction: null }, online: { classPropertyName: "online", publicName: "online", isSignal: true, isRequired: false, transformFunction: null }, hideNetwork: { classPropertyName: "hideNetwork", publicName: "youtubeAvatarMode", isSignal: true, isRequired: false, transformFunction: null }, rounded: { classPropertyName: "rounded", publicName: "rounded", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "class.background-default": "!useBigNetwork()" } }, hostDirectives: [{ directive: i2.NgStyle }], ngImport: i0, template: "<!-- background -->\n@if (backgroundView(); as bgView) {\n @switch (bgView.mode) {\n @case ('image') {\n <img\n class=\"bg-image\"\n [ngSrc]=\"bgView.image.src\"\n [width]=\"bgView.image.size\"\n [height]=\"bgView.image.size\"\n [alt]=\"bgView.image.alt\"\n (error)=\"onImageError()\" />\n }\n @case ('initials') {\n <div class=\"bg-initials\">\n {{ bgView.text }}\n </div>\n }\n @case ('symbol') {\n <div\n class=\"bg-symbol\"\n [ngClass]=\"['sym-' + bgView.symbolId, bgView.big ? 'big' : '']\">\n <ap-symbol [symbolId]=\"bgView.symbolId\" />\n </div>\n }\n }\n}\n\n<!-- overlay -->\n@if (overlayView(); as ovlView) {\n @switch (ovlView.mode) {\n @case ('network') {\n <div\n class=\"ovl-network\"\n [class.round]=\"ovlView.round\"\n [ngClass]=\"ovlView.network\">\n <ap-symbol [symbolId]=\"ovlView.symbolId\" />\n </div>\n }\n @case ('online') {\n <div class=\"ovl-online\"></div>\n }\n }\n}\n", styles: [":host{display:flex;justify-content:center;align-items:center;height:var(--ap-avatar-size);min-height:var(--ap-avatar-size);max-height:var(--ap-avatar-size);width:var(--ap-avatar-size);min-width:var(--ap-avatar-size);max-width:var(--ap-avatar-size);box-sizing:border-box;position:relative;border-radius:var(--ap-avatar-border-radius)}:host.background-default{background:var(--ref-color-grey-40);box-shadow:0 0 0 1px var(--ref-color-grey-10)}.bg-image{overflow:hidden;box-sizing:border-box;border-radius:var(--ap-avatar-border-radius)}.bg-symbol{display:flex;justify-content:center;align-items:center}.bg-symbol:not(.big) ap-symbol{color:var(--ref-color-white);width:var(--ap-avatar-symbol-size);min-width:var(--ap-avatar-symbol-size);max-width:var(--ap-avatar-symbol-size);height:var(--ap-avatar-symbol-size);min-height:var(--ap-avatar-symbol-size);max-height:var(--ap-avatar-symbol-size)}.bg-symbol.big ap-symbol ::ng-deep .svg{top:unset!important;left:unset!important;width:104.35%!important;height:unset!important}.bg-initials{font-weight:var(--ref-font-weight-bold);font-size:var(--ap-avatar-initials-size);line-height:var(--ref-font-line-height-xl);font-family:Averta;color:var(--ref-color-white)}.ovl-network{position:absolute;height:var(--ap-avatar-online-icon-size);min-height:var(--ap-avatar-network-size);max-height:var(--ap-avatar-network-size);width:var(--ap-avatar-network-size);min-width:var(--ap-avatar-network-size);max-width:var(--ap-avatar-network-size);overflow:hidden;box-sizing:border-box;bottom:0;right:0;box-shadow:0 0 0 1px var(--ref-color-grey-10)}.ovl-network.round{border-radius:100%}.ovl-network.instagram{border-radius:28%}.ovl-network.linkedin{border-radius:6%}.ovl-network.googleMyBusiness,.ovl-network.google{box-shadow:none;border-radius:unset}.ovl-network ap-symbol ::ng-deep img{border-radius:0;border:none}.ovl-online{position:absolute;height:var(--ap-avatar-online-icon-size);min-height:var(--ap-avatar-online-icon-size);max-height:var(--ap-avatar-online-icon-size);width:var(--ap-avatar-online-icon-size);min-width:var(--ap-avatar-online-icon-size);max-width:var(--ap-avatar-online-icon-size);border-radius:100%;overflow:hidden;background:var(--ref-color-grey-40);box-sizing:border-box;border:1px solid var(--ref-color-white);bottom:0;right:0;background:var(--ref-color-green-100)}\n"], dependencies: [{ kind: "directive", type: NgOptimizedImage, selector: "img[ngSrc]", inputs: ["ngSrc", "ngSrcset", "sizes", "width", "height", "loading", "priority", "loaderParams", "disableOptimizedSrcset", "fill", "placeholder", "placeholderConfig", "src", "srcset"] }, { kind: "component", type: SymbolComponent, selector: "ap-symbol", inputs: ["color", "symbolId", "size"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
204
205
  }
205
206
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: AvatarComponent, decorators: [{
206
207
  type: Component,
207
- args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'ap-avatar', standalone: true, imports: [NgOptimizedImage, SymbolComponent, LetDirective, NgClass], encapsulation: ViewEncapsulation.None, template: "<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 socialNetwork: socialNetwork$\n } as avatarViewModel\">\n @if (avatarViewModel.displayProfilePicture) {\n @if (avatarViewModel.network !== 'youtube' || youtubeAvatarMode) {\n <img\n [src]=\"avatarViewModel.profilePicture\"\n [width]=\"avatarViewModel.size\"\n [height]=\"avatarViewModel.size\"\n [alt]=\"alt\"\n (error)=\"onImageError()\" />\n } @else {\n <ap-symbol [symbolId]=\"networkSymbolByNetwork[avatarViewModel.network]\" />\n }\n }\n @if (avatarViewModel.displaySingleNeutralSvg) {\n <div class=\"no-profile-picture\">\n <ap-symbol symbolId=\"single-neutral\" />\n </div>\n }\n\n @if (avatarViewModel.displayAnonymous) {\n <div class=\"anonymous\">\n <ap-symbol symbolId=\"show-theater-mask-happy\" />\n </div>\n }\n @if (avatarViewModel.displayOnline) {\n <div class=\"online\"></div>\n }\n @if (avatarViewModel.displayNetwork && avatarViewModel.network && avatarViewModel.network !== 'youtube') {\n <div\n class=\"network\"\n [class.social-network]=\"avatarViewModel.socialNetwork\"\n [ngClass]=\"avatarViewModel.network\">\n <ap-symbol [symbolId]=\"networkSymbolByNetwork[avatarViewModel.network]\" />\n </div>\n }\n\n @if (avatarViewModel.displayInitials) {\n <div class=\"initials\">\n {{ avatarViewModel.initials }}\n </div>\n }\n</ng-container>\n", styles: ["ap-avatar{display:flex;justify-content:center;align-items:center;height:var(--ap-avatar-size);min-height:var(--ap-avatar-size);max-height:var(--ap-avatar-size);width:var(--ap-avatar-size);min-width:var(--ap-avatar-size);max-width:var(--ap-avatar-size);border-radius:var(--sys-border-radius-sm);background:var(--ref-color-grey-40);box-sizing:border-box;position:relative;box-shadow:0 0 0 1px var(--ref-color-grey-10)}ap-avatar.rounded-avatar{border-radius:100%}ap-avatar.rounded-avatar img,ap-avatar.rounded-avatar .no-profile-picture,ap-avatar.rounded-avatar .anonymous{border-radius:100%}ap-avatar.youtube-avatar{box-shadow:unset;background:unset}ap-avatar.youtube-avatar ap-symbol .svg.youtube-official{position:relative;top:unset!important;left:unset!important;width:104.35%!important;height:unset!important}ap-avatar img{overflow:hidden;border-radius:var(--sys-border-radius-sm);box-sizing:border-box}ap-avatar .no-profile-picture,ap-avatar .anonymous{display:flex;justify-content:center;align-items:center;background:var(--ref-color-grey-40);border-radius:var(--sys-border-radius-sm)}ap-avatar .no-profile-picture ap-symbol,ap-avatar .anonymous ap-symbol{color:var(--ref-color-white);width:var(--ap-avatar-symbol-size);min-width:var(--ap-avatar-symbol-size);max-width:var(--ap-avatar-symbol-size);height:var(--ap-avatar-symbol-size);min-height:var(--ap-avatar-symbol-size);max-height:var(--ap-avatar-symbol-size)}ap-avatar .anonymous{margin-top:7%}ap-avatar .online{position:absolute;height:var(--ap-avatar-online-icon-size);min-height:var(--ap-avatar-online-icon-size);max-height:var(--ap-avatar-online-icon-size);width:var(--ap-avatar-online-icon-size);min-width:var(--ap-avatar-online-icon-size);max-width:var(--ap-avatar-online-icon-size);border-radius:100%;overflow:hidden;background:var(--ref-color-grey-40);box-sizing:border-box;border:1px solid var(--ref-color-white);bottom:0;right:0;background:var(--ref-color-green-100)}ap-avatar .initials{font-weight:var(--ref-font-weight-bold);font-size:var(--ap-avatar-initials-size);line-height:var(--ref-font-line-height-xl);font-family:Averta;color:var(--ref-color-white)}ap-avatar .network{position:absolute;height:var(--ap-avatar-online-icon-size);min-height:var(--ap-avatar-network-size);max-height:var(--ap-avatar-network-size);width:var(--ap-avatar-network-size);min-width:var(--ap-avatar-network-size);max-width:var(--ap-avatar-network-size);overflow:hidden;box-sizing:border-box;bottom:0;right:0;box-shadow:0 0 0 1px var(--ref-color-grey-10)}ap-avatar .network.social-network{border-radius:100%}ap-avatar .network.instagram{border-radius:28%}ap-avatar .network.linkedin{border-radius:6%}ap-avatar .network.googleMyBusiness,ap-avatar .network.google{box-shadow:none;border-radius:unset}ap-avatar .network ap-symbol img{border-radius:0;border:none}\n"] }]
208
- }], ctorParameters: () => [{ type: i1.SymbolRegistry }, { type: i0.ElementRef }], propDecorators: { alternativeText: [{
209
- type: Input
210
- }], anonymous: [{
211
- type: Input
212
- }], username: [{
213
- type: Input
214
- }], network: [{
215
- type: Input
216
- }], online: [{
217
- type: Input
218
- }], profilePicture: [{
219
- type: Input
220
- }], showInitials: [{
221
- type: Input
222
- }], alt: [{
223
- type: Input
224
- }], youtubeAvatarMode: [{
225
- type: Input
226
- }], roundedAvatar: [{
227
- type: HostBinding,
228
- args: ['class.rounded-avatar']
229
- }], youtubeAvatar: [{
230
- type: HostBinding,
231
- args: ['class.youtube-avatar']
232
- }], rounded: [{
233
- type: Input,
234
- args: [{
235
- transform: booleanAttribute,
236
- }]
237
- }], size: [{
238
- type: Input
239
- }] } });
240
- //# 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    SymbolComponent,\n    SymbolRegistry,\n    apFacebookOfficial,\n    apGoogleMyBusinessOfficial,\n    apLinkedinOfficial,\n    apPinterestOfficial,\n    apNsThreadsLogo,\n    apShowTheaterMaskHappy,\n    apSingleNeutral,\n    apTiktokOfficial,\n    apWebBlogs,\n    apWebNews,\n    apXOfficial,\n    apYoutubeOfficial,\n    apBlueskyOfficial,\n} from '@agorapulse/ui-symbol';\nimport {NgClass, NgOptimizedImage} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    HostBinding,\n    Input,\n    OnInit,\n    ViewEncapsulation,\n    booleanAttribute,\n} from '@angular/core';\nimport { LetDirective } from '@ngrx/component';\nimport { BehaviorSubject, Observable, combineLatest, map, of } from 'rxjs';\n\nexport type AvatarSize = 56 | 48 | 40 | 36 | 32 | 24 | 16;\n\nexport const AVATAR_NETWORK_ARRAY = ['facebook', 'linkedin', 'twitter', 'X', 'youtube', 'googleMyBusiness', 'google', 'instagram', 'threads', 'tiktok', 'pinterest', 'webBlog', 'webNews', 'bluesky'];\nconst ROUND_BORDER_AVATAR_NETWORK: typeof AVATAR_NETWORK_ARRAY[number][] = ['facebook', 'twitter', 'youtube', 'tiktok', 'X', 'pinterest', 'webBlog', 'webNews', 'threads', 'bluesky'];\nexport type AvatarNetwork = typeof AVATAR_NETWORK_ARRAY[number];\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: [NgOptimizedImage, SymbolComponent, LetDirective, NgClass],\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        X: 'x-official',\n        twitter: 'x-official',\n        linkedin: 'linkedin-official',\n        tiktok: 'tiktok-official',\n        youtube: 'youtube-official',\n        pinterest: 'pinterest-official',\n        threads: 'ns-threads-logo',\n        googleMyBusiness: 'google-my-business-official',\n        google: 'google-my-business-official',\n        webNews: 'web-news',\n        webBlog: 'web-blogs',\n        bluesky: 'bluesky-official'\n    };\n\n    size$: BehaviorSubject<AvatarSize> = new BehaviorSubject<AvatarSize>(40);\n    profilePicture$: BehaviorSubject<string | undefined> = new BehaviorSubject<string | undefined>('');\n    network$: BehaviorSubject<AvatarNetwork | undefined> = new BehaviorSubject<AvatarNetwork | undefined>(undefined);\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 | undefined) {\n        this.network$.next(network);\n\n        if (network === 'youtube') {\n            this.youtubeAvatar = true;\n        }\n\n        this.elementRef.nativeElement.style.setProperty('--ap-avatar-network-size', `${networkSizeByAvatarSize[this.size$.value]}px`);\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 = '';\n\n    @Input() youtubeAvatarMode = false;\n\n    @HostBinding('class.rounded-avatar')\n    roundedAvatar = true;\n\n    @HostBinding('class.youtube-avatar')\n    youtubeAvatar = false;\n\n    @Input({\n        transform: booleanAttribute,\n    })\n    set rounded(rounded: boolean) {\n        this.roundedAvatar = rounded;\n        this.rounded$.next(rounded);\n    }\n\n    // TODO - migrate to signal input and remove size input\n    @Input()\n    set size(size: AvatarSize | `${AvatarSize}`) {\n        this.size$.next(+size as AvatarSize);\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('--ap-avatar-online-icon-size', `${onlineIconSizeByAvatarSize[size]}px`);\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    socialNetwork$: Observable<boolean> = of(false);\n\n    constructor(\n        private symbolRegistry: SymbolRegistry,\n        private elementRef: ElementRef\n    ) {\n        this.symbolRegistry.registerSymbols([\n            apSingleNeutral,\n            apShowTheaterMaskHappy,\n            apFacebookOfficial,\n            apLinkedinOfficial,\n            apYoutubeOfficial,\n            apTiktokOfficial,\n            apGoogleMyBusinessOfficial,\n            apPinterestOfficial,\n            apNsThreadsLogo,\n            apXOfficial,\n            apBlueskyOfficial,\n            apWebBlogs,\n            apWebNews,\n        ]);\n        this.elementRef.nativeElement.style.setProperty('--ap-avatar-size', `40px`);\n        this.elementRef.nativeElement.style.setProperty('--ap-avatar-symbol-size', `${symbolSizeByAvatarSize[this.size$.value]}px`);\n    }\n\n    ngOnInit(): void {\n        this.initialsAvailable$ = this.username$.pipe(\n            map(username => {\n                return !!username;\n            })\n        );\n\n        this.displayProfilePicture$ = combineLatest([this.profilePicture$, this.anonymous$, this.imageError$, this.showInitials$]).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(([profilePicture, imageError, initialsAvailable, showInitials, anonymous, displayInitials, displayProfilePicture]) => {\n                return (\n                    (!profilePicture || imageError || !initialsAvailable || (initialsAvailable && !showInitials)) &&\n                    !anonymous &&\n                    !displayInitials &&\n                    !displayProfilePicture\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.socialNetwork$ = this.network$.pipe(map(network => {\n            if (!network) {\n                return false;\n            }\n\n            return ROUND_BORDER_AVATAR_NETWORK.indexOf(network) > -1;\n        }));\n\n\n        this.initials$ = combineLatest([this.displayInitials$, this.username$]).pipe(\n            map(([displayInitials, username]) => {\n                if ((displayInitials && !username) || !displayInitials) {\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                return `${names[0].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        socialNetwork: socialNetwork$\n    } as avatarViewModel\">\n    @if (avatarViewModel.displayProfilePicture) {\n        @if (avatarViewModel.network !== 'youtube' || youtubeAvatarMode) {\n            <img\n                [src]=\"avatarViewModel.profilePicture\"\n                [width]=\"avatarViewModel.size\"\n                [height]=\"avatarViewModel.size\"\n                [alt]=\"alt\"\n                (error)=\"onImageError()\" />\n        } @else {\n            <ap-symbol [symbolId]=\"networkSymbolByNetwork[avatarViewModel.network]\" />\n        }\n    }\n    @if (avatarViewModel.displaySingleNeutralSvg) {\n        <div class=\"no-profile-picture\">\n            <ap-symbol symbolId=\"single-neutral\" />\n        </div>\n    }\n\n    @if (avatarViewModel.displayAnonymous) {\n        <div class=\"anonymous\">\n            <ap-symbol symbolId=\"show-theater-mask-happy\" />\n        </div>\n    }\n    @if (avatarViewModel.displayOnline) {\n        <div class=\"online\"></div>\n    }\n    @if (avatarViewModel.displayNetwork && avatarViewModel.network && avatarViewModel.network !== 'youtube') {\n        <div\n            class=\"network\"\n            [class.social-network]=\"avatarViewModel.socialNetwork\"\n            [ngClass]=\"avatarViewModel.network\">\n            <ap-symbol [symbolId]=\"networkSymbolByNetwork[avatarViewModel.network]\" />\n        </div>\n    }\n\n    @if (avatarViewModel.displayInitials) {\n        <div class=\"initials\">\n            {{ avatarViewModel.initials }}\n        </div>\n    }\n</ng-container>\n"]}
208
+ args: [{ selector: 'ap-avatar', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [NgOptimizedImage, SymbolComponent, NgClass], hostDirectives: [NgStyle], host: {
209
+ '[class.background-default]': '!useBigNetwork()',
210
+ }, template: "<!-- background -->\n@if (backgroundView(); as bgView) {\n @switch (bgView.mode) {\n @case ('image') {\n <img\n class=\"bg-image\"\n [ngSrc]=\"bgView.image.src\"\n [width]=\"bgView.image.size\"\n [height]=\"bgView.image.size\"\n [alt]=\"bgView.image.alt\"\n (error)=\"onImageError()\" />\n }\n @case ('initials') {\n <div class=\"bg-initials\">\n {{ bgView.text }}\n </div>\n }\n @case ('symbol') {\n <div\n class=\"bg-symbol\"\n [ngClass]=\"['sym-' + bgView.symbolId, bgView.big ? 'big' : '']\">\n <ap-symbol [symbolId]=\"bgView.symbolId\" />\n </div>\n }\n }\n}\n\n<!-- overlay -->\n@if (overlayView(); as ovlView) {\n @switch (ovlView.mode) {\n @case ('network') {\n <div\n class=\"ovl-network\"\n [class.round]=\"ovlView.round\"\n [ngClass]=\"ovlView.network\">\n <ap-symbol [symbolId]=\"ovlView.symbolId\" />\n </div>\n }\n @case ('online') {\n <div class=\"ovl-online\"></div>\n }\n }\n}\n", styles: [":host{display:flex;justify-content:center;align-items:center;height:var(--ap-avatar-size);min-height:var(--ap-avatar-size);max-height:var(--ap-avatar-size);width:var(--ap-avatar-size);min-width:var(--ap-avatar-size);max-width:var(--ap-avatar-size);box-sizing:border-box;position:relative;border-radius:var(--ap-avatar-border-radius)}:host.background-default{background:var(--ref-color-grey-40);box-shadow:0 0 0 1px var(--ref-color-grey-10)}.bg-image{overflow:hidden;box-sizing:border-box;border-radius:var(--ap-avatar-border-radius)}.bg-symbol{display:flex;justify-content:center;align-items:center}.bg-symbol:not(.big) ap-symbol{color:var(--ref-color-white);width:var(--ap-avatar-symbol-size);min-width:var(--ap-avatar-symbol-size);max-width:var(--ap-avatar-symbol-size);height:var(--ap-avatar-symbol-size);min-height:var(--ap-avatar-symbol-size);max-height:var(--ap-avatar-symbol-size)}.bg-symbol.big ap-symbol ::ng-deep .svg{top:unset!important;left:unset!important;width:104.35%!important;height:unset!important}.bg-initials{font-weight:var(--ref-font-weight-bold);font-size:var(--ap-avatar-initials-size);line-height:var(--ref-font-line-height-xl);font-family:Averta;color:var(--ref-color-white)}.ovl-network{position:absolute;height:var(--ap-avatar-online-icon-size);min-height:var(--ap-avatar-network-size);max-height:var(--ap-avatar-network-size);width:var(--ap-avatar-network-size);min-width:var(--ap-avatar-network-size);max-width:var(--ap-avatar-network-size);overflow:hidden;box-sizing:border-box;bottom:0;right:0;box-shadow:0 0 0 1px var(--ref-color-grey-10)}.ovl-network.round{border-radius:100%}.ovl-network.instagram{border-radius:28%}.ovl-network.linkedin{border-radius:6%}.ovl-network.googleMyBusiness,.ovl-network.google{box-shadow:none;border-radius:unset}.ovl-network ap-symbol ::ng-deep img{border-radius:0;border:none}.ovl-online{position:absolute;height:var(--ap-avatar-online-icon-size);min-height:var(--ap-avatar-online-icon-size);max-height:var(--ap-avatar-online-icon-size);width:var(--ap-avatar-online-icon-size);min-width:var(--ap-avatar-online-icon-size);max-width:var(--ap-avatar-online-icon-size);border-radius:100%;overflow:hidden;background:var(--ref-color-grey-40);box-sizing:border-box;border:1px solid var(--ref-color-white);bottom:0;right:0;background:var(--ref-color-green-100)}\n"] }]
211
+ }], ctorParameters: () => [{ type: i1.SymbolRegistry }, { type: i2.NgStyle }] });
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    AgorapulseSymbol,\n    agorapulseSymbol,\n    apBlueskyOfficial,\n    apFacebookOfficial,\n    apGoogleMyBusinessOfficial,\n    apLinkedinOfficial,\n    apNsThreadsLogo,\n    apPinterestOfficial,\n    apTiktokOfficial,\n    apWebBlogs,\n    apWebNews,\n    apXOfficial,\n    apYoutubeOfficial,\n    SymbolComponent,\n    SymbolRegistry,\n} from '@agorapulse/ui-symbol';\nimport { NgClass, NgOptimizedImage, NgStyle } from '@angular/common';\nimport { booleanAttribute, ChangeDetectionStrategy, Component, computed, effect, input, signal, untracked } from '@angular/core';\n\nexport const networkSymbolByNetwork = {\n    bluesky: {\n        round: true,\n        symbol: apBlueskyOfficial,\n    },\n    facebook: {\n        round: true,\n        symbol: apFacebookOfficial,\n    },\n    google: {\n        round: false,\n        symbol: apGoogleMyBusinessOfficial,\n    },\n    instagram: {\n        round: false,\n        symbol: 'instagram-official', // embedded\n    },\n    linkedin: {\n        round: false,\n        symbol: apLinkedinOfficial,\n    },\n    pinterest: {\n        round: true,\n        symbol: apPinterestOfficial,\n    },\n    threads: {\n        round: true,\n        symbol: apNsThreadsLogo,\n    },\n    tiktok: {\n        round: true,\n        symbol: apTiktokOfficial,\n    },\n    twitter: {\n        round: true,\n        symbol: apXOfficial,\n    },\n    webBlog: {\n        round: true,\n        symbol: apWebBlogs,\n    },\n    webNews: {\n        round: true,\n        symbol: apWebNews,\n    },\n    X: {\n        round: true,\n        symbol: apXOfficial,\n    },\n    youtube: {\n        round: true,\n        symbol: apYoutubeOfficial,\n    },\n} satisfies Record<\n    string,\n    {\n        round: boolean;\n        symbol: AgorapulseSymbol | string;\n    }\n>;\n\nexport type AvatarNetwork = keyof typeof networkSymbolByNetwork;\n\nfunction toSymbol(symbol: AgorapulseSymbol | string): string {\n    return typeof symbol == 'string' ? symbol : symbol.name;\n}\n\nexport type AvatarSize = 56 | 48 | 40 | 36 | 32 | 24 | 16;\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\nconst automaticBigSymbolNetwork: AvatarNetwork[] = ['youtube'];\n\ntype BackgroundView =\n    | { mode: 'image'; image: { src: string; size: number; alt?: string } }\n    | { mode: 'initials'; text: string }\n    | { mode: 'symbol'; symbolId: agorapulseSymbol; big?: boolean }\n    | { mode?: never };\n\ntype OverlayView =\n    | { mode: 'online' }\n    | { mode: 'network'; network: AvatarNetwork; symbolId: agorapulseSymbol; round: boolean }\n    | { mode?: never };\n\n@Component({\n    selector: 'ap-avatar',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    templateUrl: './avatar.component.html',\n    styleUrls: ['./avatar.component.scss'],\n    standalone: true,\n    imports: [NgOptimizedImage, SymbolComponent, NgClass],\n    hostDirectives: [NgStyle],\n    host: {\n        '[class.background-default]': '!useBigNetwork()',\n    },\n})\nexport class AvatarComponent {\n    profilePicture = input<string>();\n    alt = input('');\n    network = input(undefined, {\n        transform: (v?: AvatarNetwork | string) => (v !== undefined ? (v as AvatarNetwork) : v),\n    });\n    size = input<AvatarSize | `${AvatarSize}`>(40);\n    username = input('');\n    showInitials = input<boolean | string>();\n    bigNetwork = input(false);\n    anonymous = input(false);\n    online = input(false);\n    hideNetwork = input(false, { alias: 'youtubeAvatarMode' });\n    rounded = input(true, { transform: booleanAttribute });\n\n    private imageError = signal(false);\n\n    backgroundView = computed<BackgroundView>(() => this.buildBackgroundView());\n    overlayView = computed<OverlayView>(() => this.buildOverlayView());\n    protected useBigNetwork = computed(() => {\n        return (this.automaticBigSymbolNetwork() || this.bigNetwork()) && !this.hideNetwork();\n    });\n    private automaticBigSymbolNetwork = computed(() => {\n        return automaticBigSymbolNetwork.includes(this.network() as AvatarNetwork);\n    });\n\n    constructor(\n        symbolRegistry: SymbolRegistry,\n        private ngStyle: NgStyle\n    ) {\n        symbolRegistry.registerSymbols(\n            Object.values(networkSymbolByNetwork).flatMap(({ symbol }) => (typeof symbol !== 'string' ? [symbol] : []))\n        );\n\n        effect(() => {\n            this.ngStyle.ngStyle = this.buildHostStyle();\n            this.ngStyle.ngDoCheck();\n        });\n        effect(() => {\n            this.profilePicture(); // on change\n            untracked(() => this.imageError.set(false));\n        });\n    }\n\n    onImageError(): void {\n        this.imageError.set(true);\n    }\n\n    private buildBackgroundView(): BackgroundView {\n        let bgView: BackgroundView = {};\n\n        if (this.useBigNetwork()) {\n            bgView = { mode: 'symbol', symbolId: toSymbol(networkSymbolByNetwork[this.network()!].symbol), big: true };\n        } else if (this.anonymous()) {\n            bgView = { mode: 'symbol', symbolId: 'show-theater-mask-happy' };\n        } else {\n            const profilePicture = this.profilePicture();\n\n            if (profilePicture && !this.useBigNetwork() && !this.imageError()) {\n                bgView = {\n                    mode: 'image',\n                    image: {\n                        src: profilePicture,\n                        size: +this.size(),\n                        alt: this.alt(),\n                    },\n                };\n            } else {\n                const initials = this.showInitials();\n\n                if (initials !== false && initials !== undefined) {\n                    const useDefault = initials === true || initials === '';\n                    const candidateName = (useDefault ? this.username().charAt(0) : initials.slice(0, 2)).toUpperCase();\n                    bgView = { mode: 'initials', text: candidateName };\n                } else {\n                    if (!this.useBigNetwork()) {\n                        bgView = { mode: 'symbol', symbolId: 'single-neutral' };\n                    }\n                }\n            }\n        }\n\n        return bgView;\n    }\n\n    private buildOverlayView(): OverlayView {\n        let ovlView: OverlayView = {};\n        const network = this.network();\n\n        if (!this.automaticBigSymbolNetwork()) {\n            if (network && !this.bigNetwork() && !this.hideNetwork()) {\n                const { symbol, round } = networkSymbolByNetwork[network];\n                ovlView = { mode: 'network', network, symbolId: toSymbol(symbol), round };\n            } else if (this.online()) {\n                ovlView = { mode: 'online' };\n            }\n        }\n\n        return ovlView;\n    }\n\n    private buildHostStyle() {\n        const bgView = this.backgroundView();\n        const ovlMode = this.overlayView().mode;\n        const size = this.size();\n\n        return {\n            '--ap-avatar-size': `${size}px`,\n            '--ap-avatar-border-radius': this.rounded() ? '100%' : 'var(--sys-border-radius-sm)',\n            '--ap-avatar-initials-size': bgView.mode == 'initials' ? `${initialSizeByAvatarSize[size]}px` : '',\n            '--ap-avatar-symbol-size': bgView.mode == 'symbol' ? `${bgView.big ? size : symbolSizeByAvatarSize[size]}px` : '',\n            '--ap-avatar-network-size': ovlMode == 'network' ? `${networkSizeByAvatarSize[size]}px` : '',\n            '--ap-avatar-online-icon-size': ovlMode == 'online' ? `${onlineIconSizeByAvatarSize[size]}px` : '',\n        };\n    }\n}\n","<!-- background -->\n@if (backgroundView(); as bgView) {\n    @switch (bgView.mode) {\n        @case ('image') {\n            <img\n                class=\"bg-image\"\n                [ngSrc]=\"bgView.image.src\"\n                [width]=\"bgView.image.size\"\n                [height]=\"bgView.image.size\"\n                [alt]=\"bgView.image.alt\"\n                (error)=\"onImageError()\" />\n        }\n        @case ('initials') {\n            <div class=\"bg-initials\">\n                {{ bgView.text }}\n            </div>\n        }\n        @case ('symbol') {\n            <div\n                class=\"bg-symbol\"\n                [ngClass]=\"['sym-' + bgView.symbolId, bgView.big ? 'big' : '']\">\n                <ap-symbol [symbolId]=\"bgView.symbolId\" />\n            </div>\n        }\n    }\n}\n\n<!-- overlay -->\n@if (overlayView(); as ovlView) {\n    @switch (ovlView.mode) {\n        @case ('network') {\n            <div\n                class=\"ovl-network\"\n                [class.round]=\"ovlView.round\"\n                [ngClass]=\"ovlView.network\">\n                <ap-symbol [symbolId]=\"ovlView.symbolId\" />\n            </div>\n        }\n        @case ('online') {\n            <div class=\"ovl-online\"></div>\n        }\n    }\n}\n"]}