stream-chat-angular 6.4.1 → 7.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +12 -18
- package/assets/version.d.ts +1 -1
- package/{esm2020 → esm2022}/assets/version.mjs +2 -2
- package/{esm2020 → esm2022}/lib/attachment-configuration.service.mjs +4 -4
- package/esm2022/lib/attachment-list/attachment-list.component.mjs +232 -0
- package/esm2022/lib/attachment-preview-list/attachment-preview-list.component.mjs +55 -0
- package/{esm2020 → esm2022}/lib/attachment.service.mjs +5 -5
- package/{esm2020 → esm2022}/lib/avatar/avatar.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/avatar-placeholder/avatar-placeholder.component.mjs +6 -6
- package/esm2022/lib/channel/channel.component.mjs +45 -0
- package/{esm2020 → esm2022}/lib/channel-header/channel-header.component.mjs +6 -6
- package/esm2022/lib/channel-list/channel-list.component.mjs +47 -0
- package/{esm2020 → esm2022}/lib/channel-preview/channel-preview.component.mjs +6 -6
- package/esm2022/lib/channel.service.mjs +1575 -0
- package/{esm2020 → esm2022}/lib/chat-client.service.mjs +5 -5
- package/{esm2020 → esm2022}/lib/custom-templates.service.mjs +5 -5
- package/{esm2020 → esm2022}/lib/date-parser.service.mjs +5 -5
- package/{esm2020 → esm2022}/lib/icon/icon-placeholder/icon-placeholder.component.mjs +6 -6
- package/{esm2020 → esm2022}/lib/icon/icon.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/icon/icon.module.mjs +11 -11
- package/{esm2020 → esm2022}/lib/icon/loading-indicator/loading-indicator.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/icon/loading-indicator-placeholder/loading-indicator-placeholder.component.mjs +6 -6
- package/esm2022/lib/message/message.component.mjs +501 -0
- package/{esm2020 → esm2022}/lib/message-actions-box/message-actions-box.component.mjs +6 -6
- package/{esm2020 → esm2022}/lib/message-actions.service.mjs +5 -5
- package/{esm2020 → esm2022}/lib/message-blocked/message-blocked.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/message-bounce-prompt/message-bounce-prompt.component.mjs +6 -6
- package/{esm2020 → esm2022}/lib/message-input/autocomplete-textarea/autocomplete-textarea.component.mjs +6 -6
- package/{esm2020 → esm2022}/lib/message-input/emoji-input.service.mjs +5 -5
- package/{esm2020 → esm2022}/lib/message-input/message-input-config.service.mjs +5 -5
- package/{esm2020 → esm2022}/lib/message-input/message-input.component.mjs +7 -7
- package/{esm2020 → esm2022}/lib/message-input/textarea/textarea.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/message-input/textarea.directive.mjs +5 -5
- package/{esm2020 → esm2022}/lib/message-input/voice-recorder.service.mjs +5 -5
- package/esm2022/lib/message-list/message-list.component.mjs +717 -0
- package/{esm2020 → esm2022}/lib/message-reactions/message-reactions.component.mjs +6 -6
- package/{esm2020 → esm2022}/lib/message-reactions-selector/message-reactions-selector.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/message-reactions.service.mjs +5 -5
- package/{esm2020 → esm2022}/lib/message-text/message-text.component.mjs +6 -6
- package/{esm2020 → esm2022}/lib/message.service.mjs +5 -5
- package/{esm2020 → esm2022}/lib/modal/modal.component.mjs +6 -6
- package/{esm2020 → esm2022}/lib/modal/stream-modal.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/notification/notification.component.mjs +6 -6
- package/{esm2020 → esm2022}/lib/notification-list/notification-list.component.mjs +6 -6
- package/{esm2020 → esm2022}/lib/notification-list/stream-notification.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/notification.service.mjs +5 -5
- package/{esm2020 → esm2022}/lib/paginated-list/paginated-list.component.mjs +6 -6
- package/{esm2020 → esm2022}/lib/paginated-list/stream-paginated-list.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/polls/base-poll.component.mjs +5 -5
- package/esm2022/lib/polls/poll/poll.component.mjs +34 -0
- package/{esm2020 → esm2022}/lib/polls/poll-actions/add-option/add-option.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/polls/poll-actions/poll-actions.component.mjs +6 -6
- package/esm2022/lib/polls/poll-actions/poll-answers-list/poll-answers-list.component.mjs +82 -0
- package/esm2022/lib/polls/poll-actions/poll-results/poll-results-list/poll-results-list.component.mjs +63 -0
- package/{esm2020 → esm2022}/lib/polls/poll-actions/poll-results/poll-vote/poll-vote.component.mjs +6 -6
- package/{esm2020 → esm2022}/lib/polls/poll-actions/poll-results/poll-vote-results-list/poll-vote-results-list.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/polls/poll-actions/upsert-answer/upsert-answer.component.mjs +4 -4
- package/esm2022/lib/polls/poll-composer/poll-composer.component.mjs +134 -0
- package/{esm2020 → esm2022}/lib/polls/poll-header/poll-header.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/polls/poll-option-selector/poll-option-selector.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/polls/poll-options-list/poll-options-list.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/polls/poll-preview/poll-preview.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/polls/stream-polls.module.mjs +41 -41
- package/esm2022/lib/stream-autocomplete-textarea.module.mjs +33 -0
- package/{esm2020 → esm2022}/lib/stream-avatar.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/stream-chat.module.mjs +67 -67
- package/esm2022/lib/stream-i18n.service.mjs +34 -0
- package/esm2022/lib/stream-textarea.module.mjs +31 -0
- package/{esm2020 → esm2022}/lib/theme.service.mjs +5 -5
- package/{esm2020 → esm2022}/lib/thread/thread.component.mjs +6 -6
- package/{esm2020 → esm2022}/lib/transliteration.service.mjs +5 -5
- package/{esm2020 → esm2022}/lib/types.mjs +1 -1
- package/{esm2020 → esm2022}/lib/user-list/user-list.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/voice-recorder/amplitude-recorder.service.mjs +5 -5
- package/{esm2020 → esm2022}/lib/voice-recorder/audio-recorder.service.mjs +5 -5
- package/{esm2020 → esm2022}/lib/voice-recorder/transcoder.service.mjs +5 -5
- package/{esm2020 → esm2022}/lib/voice-recorder/voice-recorder-wavebar/voice-recorder-wavebar.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/voice-recorder/voice-recorder.component.mjs +6 -6
- package/{esm2020 → esm2022}/lib/voice-recorder/voice-recorder.module.mjs +9 -9
- package/{esm2020 → esm2022}/lib/voice-recording/voice-recording-wavebar/voice-recording-wavebar.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/voice-recording/voice-recording.component.mjs +6 -6
- package/{esm2020 → esm2022}/lib/voice-recording/voice-recording.module.mjs +5 -5
- package/{fesm2020 → fesm2022}/stream-chat-angular.mjs +463 -470
- package/fesm2022/stream-chat-angular.mjs.map +1 -0
- package/lib/attachment-list/attachment-list.component.d.ts +1 -1
- package/lib/attachment-preview-list/attachment-preview-list.component.d.ts +1 -1
- package/lib/avatar/avatar.component.d.ts +1 -1
- package/lib/avatar-placeholder/avatar-placeholder.component.d.ts +1 -1
- package/lib/channel-preview/channel-preview.component.d.ts +1 -1
- package/lib/chat-client.service.d.ts +1 -1
- package/lib/custom-templates.service.d.ts +1 -0
- package/lib/icon/icon-placeholder/icon-placeholder.component.d.ts +1 -1
- package/lib/icon/icon.component.d.ts +2 -2
- package/lib/message/message.component.d.ts +1 -1
- package/lib/message-actions-box/message-actions-box.component.d.ts +1 -1
- package/lib/message-blocked/message-blocked.component.d.ts +1 -1
- package/lib/message-input/autocomplete-textarea/autocomplete-textarea.component.d.ts +1 -1
- package/lib/message-input/message-input.component.d.ts +1 -1
- package/lib/message-input/textarea/textarea.component.d.ts +1 -1
- package/lib/message-input/textarea.directive.d.ts +1 -1
- package/lib/message-list/group-styles.d.ts +1 -1
- package/lib/message-list/message-list.component.d.ts +1 -1
- package/lib/message-reactions/message-reactions.component.d.ts +1 -1
- package/lib/message-reactions-selector/message-reactions-selector.component.d.ts +1 -1
- package/lib/message-text/message-text.component.d.ts +2 -2
- package/lib/modal/modal.component.d.ts +1 -1
- package/lib/notification/notification.component.d.ts +1 -1
- package/lib/paginated-list/paginated-list.component.d.ts +5 -2
- package/lib/polls/base-poll.component.d.ts +1 -1
- package/lib/polls/poll-actions/add-option/add-option.component.d.ts +1 -1
- package/lib/polls/poll-actions/poll-actions.component.d.ts +2 -2
- package/lib/polls/poll-actions/poll-answers-list/poll-answers-list.component.d.ts +1 -1
- package/lib/polls/poll-actions/poll-results/poll-vote/poll-vote.component.d.ts +1 -1
- package/lib/polls/poll-actions/poll-results/poll-vote-results-list/poll-vote-results-list.component.d.ts +1 -1
- package/lib/polls/poll-actions/upsert-answer/upsert-answer.component.d.ts +1 -1
- package/lib/polls/poll-composer/poll-composer.component.d.ts +2 -2
- package/lib/polls/poll-header/poll-header.component.d.ts +1 -1
- package/lib/polls/poll-option-selector/poll-option-selector.component.d.ts +1 -1
- package/lib/polls/poll-options-list/poll-options-list.component.d.ts +1 -1
- package/lib/types.d.ts +79 -79
- package/lib/user-list/user-list.component.d.ts +1 -1
- package/lib/voice-recorder/amplitude-recorder.service.d.ts +2 -2
- package/lib/voice-recorder/media-recorder.d.ts +2 -2
- package/lib/voice-recorder/transcoder.service.d.ts +4 -4
- package/lib/voice-recorder/voice-recorder.component.d.ts +1 -1
- package/lib/voice-recording/voice-recording-wavebar/voice-recording-wavebar.component.d.ts +1 -1
- package/lib/voice-recording/voice-recording.component.d.ts +1 -1
- package/package.json +11 -17
- package/src/assets/version.ts +1 -1
- package/esm2020/lib/attachment-list/attachment-list.component.mjs +0 -232
- package/esm2020/lib/attachment-preview-list/attachment-preview-list.component.mjs +0 -55
- package/esm2020/lib/channel/channel.component.mjs +0 -45
- package/esm2020/lib/channel-list/channel-list.component.mjs +0 -47
- package/esm2020/lib/channel.service.mjs +0 -1575
- package/esm2020/lib/message/message.component.mjs +0 -501
- package/esm2020/lib/message-list/message-list.component.mjs +0 -717
- package/esm2020/lib/polls/poll/poll.component.mjs +0 -34
- package/esm2020/lib/polls/poll-actions/poll-answers-list/poll-answers-list.component.mjs +0 -82
- package/esm2020/lib/polls/poll-actions/poll-results/poll-results-list/poll-results-list.component.mjs +0 -63
- package/esm2020/lib/polls/poll-composer/poll-composer.component.mjs +0 -134
- package/esm2020/lib/stream-autocomplete-textarea.module.mjs +0 -33
- package/esm2020/lib/stream-i18n.service.mjs +0 -41
- package/esm2020/lib/stream-textarea.module.mjs +0 -31
- package/fesm2015/stream-chat-angular.mjs +0 -10596
- package/fesm2015/stream-chat-angular.mjs.map +0 -1
- package/fesm2020/stream-chat-angular.mjs.map +0 -1
- /package/{esm2020 → esm2022}/assets/i18n/en.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/channel-query.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/file-utils.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/format-duration.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/get-channel-display-text.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/get-message-translation.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/injection-tokens.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/is-image-attachment.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/is-on-separate-date.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/is-safari.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/list-users.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/message-input/textarea.interface.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/message-list/group-styles.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/message-preview.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/parse-date.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/polls/poll-composer/validators.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/polls/unique.validator.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/read-by.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/types-custom.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/virtualized-list.service.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/virtualized-message-list.service.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/voice-recorder/media-recorder.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/voice-recorder/mp3-transcoder.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/wave-form-sampler.mjs +0 -0
- /package/{esm2020 → esm2022}/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/stream-chat-angular.mjs +0 -0
- /package/{esm2020 → esm2022}/stream-chat.mjs +0 -0
|
@@ -0,0 +1,134 @@
|
|
|
1
|
+
import { Component, EventEmitter, Output, ViewChild, } from '@angular/core';
|
|
2
|
+
import { FormArray, FormControl, FormGroup, Validators } from '@angular/forms';
|
|
3
|
+
import { VotingVisibility } from 'stream-chat';
|
|
4
|
+
import { atLeastOneOption, maximumNumberOfVotes } from './validators';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "../../custom-templates.service";
|
|
7
|
+
import * as i2 from "../../chat-client.service";
|
|
8
|
+
import * as i3 from "../../notification.service";
|
|
9
|
+
import * as i4 from "@angular/common";
|
|
10
|
+
import * as i5 from "../../modal/modal.component";
|
|
11
|
+
import * as i6 from "../../notification-list/notification-list.component";
|
|
12
|
+
import * as i7 from "@angular/forms";
|
|
13
|
+
import * as i8 from "@ngx-translate/core";
|
|
14
|
+
/**
|
|
15
|
+
*
|
|
16
|
+
*/
|
|
17
|
+
export class PollComposerComponent {
|
|
18
|
+
constructor(customTemplatesService, chatService, notificationService) {
|
|
19
|
+
this.customTemplatesService = customTemplatesService;
|
|
20
|
+
this.chatService = chatService;
|
|
21
|
+
this.notificationService = notificationService;
|
|
22
|
+
/**
|
|
23
|
+
* Emitted when a poll is created, the poll id is emitted
|
|
24
|
+
*/
|
|
25
|
+
this.pollCompose = new EventEmitter();
|
|
26
|
+
/**
|
|
27
|
+
* Emitted when the poll composing is cancelled
|
|
28
|
+
*/
|
|
29
|
+
this.cancel = new EventEmitter();
|
|
30
|
+
this.formGroup = new FormGroup({
|
|
31
|
+
name: new FormControl('', [Validators.required]),
|
|
32
|
+
options: new FormArray([new FormControl('')], [atLeastOneOption()]),
|
|
33
|
+
multiple_answers: new FormControl(false),
|
|
34
|
+
maximum_number_of_votes: new FormControl(null, [
|
|
35
|
+
Validators.min(2),
|
|
36
|
+
Validators.max(10),
|
|
37
|
+
]),
|
|
38
|
+
is_anonymous: new FormControl(false),
|
|
39
|
+
allow_user_suggested_options: new FormControl(false),
|
|
40
|
+
allow_answers: new FormControl(false),
|
|
41
|
+
});
|
|
42
|
+
this.isModalOpen = true;
|
|
43
|
+
this.formGroup
|
|
44
|
+
.get('maximum_number_of_votes')
|
|
45
|
+
?.addValidators([
|
|
46
|
+
maximumNumberOfVotes(this.formGroup.get('multiple_answers')),
|
|
47
|
+
]);
|
|
48
|
+
this.formGroup.get('maximum_number_of_votes')?.disable();
|
|
49
|
+
this.formGroup.valueChanges.subscribe((value) => {
|
|
50
|
+
if (value.multiple_answers &&
|
|
51
|
+
this.formGroup.get('maximum_number_of_votes')?.disabled) {
|
|
52
|
+
this.formGroup.get('maximum_number_of_votes')?.enable();
|
|
53
|
+
}
|
|
54
|
+
else if (!value.multiple_answers &&
|
|
55
|
+
this.formGroup.get('maximum_number_of_votes')?.enabled) {
|
|
56
|
+
this.formGroup.get('maximum_number_of_votes')?.disable();
|
|
57
|
+
}
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
optionChanged(index) {
|
|
61
|
+
const control = this.options.at(index);
|
|
62
|
+
const penultimateIndex = this.options.length - 2;
|
|
63
|
+
if (index === this.options.length - 1) {
|
|
64
|
+
this.addOption();
|
|
65
|
+
}
|
|
66
|
+
else if (index === penultimateIndex &&
|
|
67
|
+
control.value?.length === 0 &&
|
|
68
|
+
this.options.at(this.options.length - 1).value?.length === 0) {
|
|
69
|
+
this.removeLastOption();
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
get options() {
|
|
73
|
+
return this.formGroup.get('options');
|
|
74
|
+
}
|
|
75
|
+
addOption() {
|
|
76
|
+
const control = new FormControl('', []);
|
|
77
|
+
this.options.push(control);
|
|
78
|
+
}
|
|
79
|
+
removeLastOption() {
|
|
80
|
+
this.options.removeAt(this.options.length - 1);
|
|
81
|
+
}
|
|
82
|
+
getModalContext() {
|
|
83
|
+
return {
|
|
84
|
+
isOpen: this.isModalOpen,
|
|
85
|
+
isOpenChangeHandler: (isOpen) => {
|
|
86
|
+
if (!isOpen) {
|
|
87
|
+
this.cancel.emit();
|
|
88
|
+
}
|
|
89
|
+
this.isModalOpen = isOpen;
|
|
90
|
+
},
|
|
91
|
+
content: this.formContent,
|
|
92
|
+
};
|
|
93
|
+
}
|
|
94
|
+
async createPoll() {
|
|
95
|
+
try {
|
|
96
|
+
const maxVotesControl = this.formGroup.get('maximum_number_of_votes');
|
|
97
|
+
const response = await this.chatService.chatClient.polls.createPoll({
|
|
98
|
+
name: this.formGroup.get('name').value,
|
|
99
|
+
options: this.formGroup
|
|
100
|
+
.get('options')
|
|
101
|
+
.value.filter((v) => !!v)
|
|
102
|
+
.map((v) => ({ text: v })),
|
|
103
|
+
enforce_unique_vote: !this.formGroup.get('multiple_answers')?.value,
|
|
104
|
+
max_votes_allowed: maxVotesControl?.value
|
|
105
|
+
? +maxVotesControl.value
|
|
106
|
+
: undefined,
|
|
107
|
+
voting_visibility: this.formGroup.get('is_anonymous')?.value
|
|
108
|
+
? VotingVisibility.anonymous
|
|
109
|
+
: VotingVisibility.public,
|
|
110
|
+
allow_user_suggested_options: !!this.formGroup.get('allow_user_suggested_options')?.value,
|
|
111
|
+
allow_answers: !!this.formGroup.get('allow_answers')?.value,
|
|
112
|
+
});
|
|
113
|
+
this.pollCompose.emit(response?.id);
|
|
114
|
+
}
|
|
115
|
+
catch (error) {
|
|
116
|
+
this.notificationService.addTemporaryNotification('streamChat.Failed to create poll');
|
|
117
|
+
throw error;
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PollComposerComponent, deps: [{ token: i1.CustomTemplatesService }, { token: i2.ChatClientService }, { token: i3.NotificationService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
121
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: PollComposerComponent, selector: "stream-poll-composer", outputs: { pollCompose: "pollCompose", cancel: "cancel" }, viewQueries: [{ propertyName: "formContent", first: true, predicate: ["formContent"], descendants: true }], ngImport: i0, template: "<ng-container>\n <ng-container\n *ngTemplateOutlet=\"\n (customTemplatesService.modalTemplate$ | async) || defaultModal;\n context: getModalContext()\n \"\n />\n</ng-container>\n\n<ng-template\n #defaultModal\n let-isOpen=\"isOpen\"\n let-isOpenChangeHandler=\"isOpenChangeHandler\"\n let-content=\"content\"\n>\n <stream-modal\n class=\"str-chat-angular__create-poll-modal str-chat__create-poll-modal\"\n [isOpen]=\"isOpen\"\n [content]=\"content\"\n (isOpenChange)=\"isOpenChangeHandler($event)\"\n />\n</ng-template>\n\n<ng-template #formContent>\n <div\n class=\"str-chat__dialog str-chat__poll-creation-dialog\"\n data-testid=\"poll-creation-dialog\"\n >\n <div class=\"str-chat__modal-header\">\n <div class=\"str-chat__modal-header__title\">\n {{ \"streamChat.Create poll\" | translate }}\n </div>\n </div>\n <div class=\"str-chat__dialog__body\">\n <form [formGroup]=\"formGroup\" autocomplete=\"off\">\n <div\n class=\"str-chat__form__field str-chat__form__input-field str-chat__form__input-field--with-label\"\n [class.str-chat__form__input-field--has-error]=\"\n formGroup.get('name')?.errors && formGroup.get('name')?.touched\n \"\n >\n <label class=\"str-chat__form__field-label\" htmlFor=\"name\">\n {{ \"streamChat.Question\" | translate }}\n </label>\n <div class=\"str-chat__form__input-field__value\">\n <div\n class=\"str-chat__form-field-error str-chat__form__input-field__error\"\n >\n {{\n (formGroup.get(\"name\")?.errors?.required &&\n formGroup.get(\"name\")?.touched\n ? \"streamChat.Question is required\"\n : \"\"\n ) | translate\n }}\n </div>\n <input\n id=\"name\"\n type=\"text\"\n formControlName=\"name\"\n placeholder=\"{{ 'streamChat.Ask a question' | translate }}\"\n />\n </div>\n </div>\n <fieldset class=\"str-chat__form__field str-chat__form__input-fieldset\">\n <legend class=\"str-chat__form__field-label\">\n {{ \"streamChat.Options\" | translate }}\n </legend>\n <div\n class=\"str-chat__form-field-error str-chat__form__input-field__error\"\n >\n {{\n (formGroup.get(\"options\")?.errors?.atLeastOne &&\n formGroup.get(\"options\")?.touched\n ? \"streamChat.Provide at least one option\"\n : \"\"\n ) | translate\n }}\n </div>\n <ng-container formArrayName=\"options\">\n <div class=\"str-chat__form__input-fieldset__values\">\n <!-- eslint-disable @angular-eslint/template/use-track-by-function -->\n <ng-container\n *ngFor=\"let option of options.controls; let i = index\"\n >\n <!-- eslint-enable @angular-eslint/template/use-track-by-function -->\n <div class=\"str-chat__drag-and-drop-container__item\">\n <div class=\"str-chat__form__input-field\">\n <div class=\"str-chat__form__input-field__value\">\n <input\n id=\"option{{ i }}\"\n name=\"option{{ i }}\"\n type=\"text\"\n [formControl]=\"option\"\n (input)=\"optionChanged(i)\"\n placeholder=\"{{\n 'streamChat.Add an option' | translate\n }}\"\n />\n </div>\n </div>\n </div>\n </ng-container>\n </div>\n </ng-container>\n </fieldset>\n <ng-container\n *ngTemplateOutlet=\"\n switch;\n context: {\n name: 'multiple_answers',\n control: formGroup.get('multiple_answers'),\n label: 'streamChat.Multiple answers' | translate\n }\n \"\n />\n <div\n *ngIf=\"formGroup.get('multiple_answers')?.value\"\n class=\"str-chat__form__field str-chat__form__input-field str-chat__form__input-field--with-label\"\n [class.str-chat__form__input-field--has-error]=\"\n formGroup.get('maximum_number_of_votes')?.errors &&\n formGroup.get('maximum_number_of_votes')?.touched\n \"\n >\n <label class=\"str-chat__form__field-label\" htmlFor=\"name\">\n {{ \"streamChat.Maximum number of votes\" | translate }}\n </label>\n <div class=\"str-chat__form__input-field__value\">\n <div\n class=\"str-chat__form-field-error str-chat__form__input-field__error\"\n >\n {{\n (formGroup.get(\"maximum_number_of_votes\")?.errors &&\n formGroup.get(\"maximum_number_of_votes\")?.touched\n ? \"streamChat.Provide a value between {{ min }}\n and {{ max }}\" : \"\" ) | translate: { min: 2, max: 10 } }}\n </div>\n <input\n id=\"maximum_number_of_votes\"\n type=\"text\"\n formControlName=\"maximum_number_of_votes\"\n placeholder=\"{{ 'streamChat.Provide a value between ' \n + '{{ min }} and {{ max }}' | translate: { min: 2, max: 10 } }}\"\n />\n </div>\n </div>\n <ng-container\n *ngTemplateOutlet=\"\n switch;\n context: {\n name: 'is_anonymous',\n control: formGroup.get('is_anonymous'),\n label: 'streamChat.Anonymous poll' | translate\n }\n \"\n />\n <ng-container\n *ngTemplateOutlet=\"\n switch;\n context: {\n name: 'allow_user_suggested_options',\n control: formGroup.get('allow_user_suggested_options'),\n label: 'streamChat.Allow option suggestions' | translate\n }\n \"\n />\n <ng-container\n *ngTemplateOutlet=\"\n switch;\n context: {\n name: 'allow_answers',\n control: formGroup.get('allow_answers'),\n label: 'streamChat.Allow comments' | translate\n }\n \"\n />\n </form>\n </div>\n <stream-notification-list />\n <div class=\"str-chat__dialog__controls\">\n <button\n class=\"str-chat__dialog__controls-button str-chat__dialog__controls-button--cancel\"\n (click)=\"cancel.emit()\"\n type=\"button\"\n >\n {{ \"streamChat.Cancel\" | translate }}\n </button>\n <button\n class=\"str-chat__dialog__controls-button str-chat__dialog__controls-button--submit\"\n (click)=\"createPoll()\"\n [disabled]=\"formGroup.invalid\"\n type=\"submit\"\n >\n {{ \"streamChat.Create\" | translate }}\n </button>\n </div>\n </div>\n</ng-template>\n\n<ng-template #switch let-control=\"control\" let-label=\"label\" let-name=\"name\">\n <div class=\"str-chat__form__field str-chat__form__switch-field\">\n <label>\n <div class=\"str-chat__form__field str-chat__form__switch-field-content\">\n <div class=\"str-chat__form__field str-chat__form__switch-field__text\">\n {{ label | translate }}\n </div>\n </div>\n <input\n type=\"checkbox\"\n [checked]=\"control.value\"\n id=\"{{ name }}\"\n name=\"{{ name }}\"\n />\n <div\n class=\"str-chat__form__switch-field__switch\"\n [class.str-chat__form__switch-field__switch--on]=\"control.value\"\n (click)=\"control.setValue(!control.value, { emitEvent: true })\"\n (keyup.enter)=\"control.setValue(!control.value, { emitEvent: true })\"\n >\n <div class=\"str-chat__form__switch-field__switch-handle\"></div>\n </div>\n </label>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i5.ModalComponent, selector: "stream-modal", inputs: ["isOpen", "content"], outputs: ["isOpenChange"] }, { kind: "component", type: i6.NotificationListComponent, selector: "stream-notification-list" }, { kind: "directive", type: i7.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i7.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: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i7.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i7.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i7.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i7.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i7.FormArrayName, selector: "[formArrayName]", inputs: ["formArrayName"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "pipe", type: i8.TranslatePipe, name: "translate" }] }); }
|
|
122
|
+
}
|
|
123
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PollComposerComponent, decorators: [{
|
|
124
|
+
type: Component,
|
|
125
|
+
args: [{ selector: 'stream-poll-composer', template: "<ng-container>\n <ng-container\n *ngTemplateOutlet=\"\n (customTemplatesService.modalTemplate$ | async) || defaultModal;\n context: getModalContext()\n \"\n />\n</ng-container>\n\n<ng-template\n #defaultModal\n let-isOpen=\"isOpen\"\n let-isOpenChangeHandler=\"isOpenChangeHandler\"\n let-content=\"content\"\n>\n <stream-modal\n class=\"str-chat-angular__create-poll-modal str-chat__create-poll-modal\"\n [isOpen]=\"isOpen\"\n [content]=\"content\"\n (isOpenChange)=\"isOpenChangeHandler($event)\"\n />\n</ng-template>\n\n<ng-template #formContent>\n <div\n class=\"str-chat__dialog str-chat__poll-creation-dialog\"\n data-testid=\"poll-creation-dialog\"\n >\n <div class=\"str-chat__modal-header\">\n <div class=\"str-chat__modal-header__title\">\n {{ \"streamChat.Create poll\" | translate }}\n </div>\n </div>\n <div class=\"str-chat__dialog__body\">\n <form [formGroup]=\"formGroup\" autocomplete=\"off\">\n <div\n class=\"str-chat__form__field str-chat__form__input-field str-chat__form__input-field--with-label\"\n [class.str-chat__form__input-field--has-error]=\"\n formGroup.get('name')?.errors && formGroup.get('name')?.touched\n \"\n >\n <label class=\"str-chat__form__field-label\" htmlFor=\"name\">\n {{ \"streamChat.Question\" | translate }}\n </label>\n <div class=\"str-chat__form__input-field__value\">\n <div\n class=\"str-chat__form-field-error str-chat__form__input-field__error\"\n >\n {{\n (formGroup.get(\"name\")?.errors?.required &&\n formGroup.get(\"name\")?.touched\n ? \"streamChat.Question is required\"\n : \"\"\n ) | translate\n }}\n </div>\n <input\n id=\"name\"\n type=\"text\"\n formControlName=\"name\"\n placeholder=\"{{ 'streamChat.Ask a question' | translate }}\"\n />\n </div>\n </div>\n <fieldset class=\"str-chat__form__field str-chat__form__input-fieldset\">\n <legend class=\"str-chat__form__field-label\">\n {{ \"streamChat.Options\" | translate }}\n </legend>\n <div\n class=\"str-chat__form-field-error str-chat__form__input-field__error\"\n >\n {{\n (formGroup.get(\"options\")?.errors?.atLeastOne &&\n formGroup.get(\"options\")?.touched\n ? \"streamChat.Provide at least one option\"\n : \"\"\n ) | translate\n }}\n </div>\n <ng-container formArrayName=\"options\">\n <div class=\"str-chat__form__input-fieldset__values\">\n <!-- eslint-disable @angular-eslint/template/use-track-by-function -->\n <ng-container\n *ngFor=\"let option of options.controls; let i = index\"\n >\n <!-- eslint-enable @angular-eslint/template/use-track-by-function -->\n <div class=\"str-chat__drag-and-drop-container__item\">\n <div class=\"str-chat__form__input-field\">\n <div class=\"str-chat__form__input-field__value\">\n <input\n id=\"option{{ i }}\"\n name=\"option{{ i }}\"\n type=\"text\"\n [formControl]=\"option\"\n (input)=\"optionChanged(i)\"\n placeholder=\"{{\n 'streamChat.Add an option' | translate\n }}\"\n />\n </div>\n </div>\n </div>\n </ng-container>\n </div>\n </ng-container>\n </fieldset>\n <ng-container\n *ngTemplateOutlet=\"\n switch;\n context: {\n name: 'multiple_answers',\n control: formGroup.get('multiple_answers'),\n label: 'streamChat.Multiple answers' | translate\n }\n \"\n />\n <div\n *ngIf=\"formGroup.get('multiple_answers')?.value\"\n class=\"str-chat__form__field str-chat__form__input-field str-chat__form__input-field--with-label\"\n [class.str-chat__form__input-field--has-error]=\"\n formGroup.get('maximum_number_of_votes')?.errors &&\n formGroup.get('maximum_number_of_votes')?.touched\n \"\n >\n <label class=\"str-chat__form__field-label\" htmlFor=\"name\">\n {{ \"streamChat.Maximum number of votes\" | translate }}\n </label>\n <div class=\"str-chat__form__input-field__value\">\n <div\n class=\"str-chat__form-field-error str-chat__form__input-field__error\"\n >\n {{\n (formGroup.get(\"maximum_number_of_votes\")?.errors &&\n formGroup.get(\"maximum_number_of_votes\")?.touched\n ? \"streamChat.Provide a value between {{ min }}\n and {{ max }}\" : \"\" ) | translate: { min: 2, max: 10 } }}\n </div>\n <input\n id=\"maximum_number_of_votes\"\n type=\"text\"\n formControlName=\"maximum_number_of_votes\"\n placeholder=\"{{ 'streamChat.Provide a value between ' \n + '{{ min }} and {{ max }}' | translate: { min: 2, max: 10 } }}\"\n />\n </div>\n </div>\n <ng-container\n *ngTemplateOutlet=\"\n switch;\n context: {\n name: 'is_anonymous',\n control: formGroup.get('is_anonymous'),\n label: 'streamChat.Anonymous poll' | translate\n }\n \"\n />\n <ng-container\n *ngTemplateOutlet=\"\n switch;\n context: {\n name: 'allow_user_suggested_options',\n control: formGroup.get('allow_user_suggested_options'),\n label: 'streamChat.Allow option suggestions' | translate\n }\n \"\n />\n <ng-container\n *ngTemplateOutlet=\"\n switch;\n context: {\n name: 'allow_answers',\n control: formGroup.get('allow_answers'),\n label: 'streamChat.Allow comments' | translate\n }\n \"\n />\n </form>\n </div>\n <stream-notification-list />\n <div class=\"str-chat__dialog__controls\">\n <button\n class=\"str-chat__dialog__controls-button str-chat__dialog__controls-button--cancel\"\n (click)=\"cancel.emit()\"\n type=\"button\"\n >\n {{ \"streamChat.Cancel\" | translate }}\n </button>\n <button\n class=\"str-chat__dialog__controls-button str-chat__dialog__controls-button--submit\"\n (click)=\"createPoll()\"\n [disabled]=\"formGroup.invalid\"\n type=\"submit\"\n >\n {{ \"streamChat.Create\" | translate }}\n </button>\n </div>\n </div>\n</ng-template>\n\n<ng-template #switch let-control=\"control\" let-label=\"label\" let-name=\"name\">\n <div class=\"str-chat__form__field str-chat__form__switch-field\">\n <label>\n <div class=\"str-chat__form__field str-chat__form__switch-field-content\">\n <div class=\"str-chat__form__field str-chat__form__switch-field__text\">\n {{ label | translate }}\n </div>\n </div>\n <input\n type=\"checkbox\"\n [checked]=\"control.value\"\n id=\"{{ name }}\"\n name=\"{{ name }}\"\n />\n <div\n class=\"str-chat__form__switch-field__switch\"\n [class.str-chat__form__switch-field__switch--on]=\"control.value\"\n (click)=\"control.setValue(!control.value, { emitEvent: true })\"\n (keyup.enter)=\"control.setValue(!control.value, { emitEvent: true })\"\n >\n <div class=\"str-chat__form__switch-field__switch-handle\"></div>\n </div>\n </label>\n </div>\n</ng-template>\n" }]
|
|
126
|
+
}], ctorParameters: () => [{ type: i1.CustomTemplatesService }, { type: i2.ChatClientService }, { type: i3.NotificationService }], propDecorators: { pollCompose: [{
|
|
127
|
+
type: Output
|
|
128
|
+
}], cancel: [{
|
|
129
|
+
type: Output
|
|
130
|
+
}], formContent: [{
|
|
131
|
+
type: ViewChild,
|
|
132
|
+
args: ['formContent']
|
|
133
|
+
}] } });
|
|
134
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"poll-composer.component.js","sourceRoot":"","sources":["../../../../../../projects/stream-chat-angular/src/lib/polls/poll-composer/poll-composer.component.ts","../../../../../../projects/stream-chat-angular/src/lib/polls/poll-composer/poll-composer.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Output,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport { FormArray, FormControl, FormGroup, Validators } from '@angular/forms';\nimport { VotingVisibility } from 'stream-chat';\nimport { CustomTemplatesService } from '../../custom-templates.service';\nimport { ModalContext } from '../../types';\nimport { ChatClientService } from '../../chat-client.service';\nimport { NotificationService } from '../../notification.service';\nimport { atLeastOneOption, maximumNumberOfVotes } from './validators';\n\n/**\n *\n */\n@Component({\n  selector: 'stream-poll-composer',\n  templateUrl: './poll-composer.component.html',\n  styles: [],\n})\nexport class PollComposerComponent {\n  /**\n   * Emitted when a poll is created, the poll id is emitted\n   */\n  @Output() readonly pollCompose = new EventEmitter<string>();\n  /**\n   * Emitted when the poll composing is cancelled\n   */\n  @Output() readonly cancel = new EventEmitter<void>();\n  formGroup = new FormGroup({\n    name: new FormControl('', [Validators.required]),\n    options: new FormArray<FormControl<string | null>>(\n      [new FormControl<string | null>('')],\n      [atLeastOneOption()]\n    ),\n    multiple_answers: new FormControl(false),\n    maximum_number_of_votes: new FormControl(null, [\n      Validators.min(2),\n      Validators.max(10),\n    ]),\n    is_anonymous: new FormControl(false),\n    allow_user_suggested_options: new FormControl(false),\n    allow_answers: new FormControl(false),\n  });\n  isModalOpen = true;\n  @ViewChild('formContent') private formContent!: TemplateRef<void>;\n\n  constructor(\n    readonly customTemplatesService: CustomTemplatesService,\n    private chatService: ChatClientService,\n    private notificationService: NotificationService\n  ) {\n    this.formGroup\n      .get('maximum_number_of_votes')\n      ?.addValidators([\n        maximumNumberOfVotes(\n          this.formGroup.get('multiple_answers') as FormControl<boolean>\n        ),\n      ]);\n    this.formGroup.get('maximum_number_of_votes')?.disable();\n    this.formGroup.valueChanges.subscribe((value) => {\n      if (\n        value.multiple_answers &&\n        this.formGroup.get('maximum_number_of_votes')?.disabled\n      ) {\n        this.formGroup.get('maximum_number_of_votes')?.enable();\n      } else if (\n        !value.multiple_answers &&\n        this.formGroup.get('maximum_number_of_votes')?.enabled\n      ) {\n        this.formGroup.get('maximum_number_of_votes')?.disable();\n      }\n    });\n  }\n\n  optionChanged(index: number) {\n    const control = this.options.at(index);\n    const penultimateIndex = this.options.length - 2;\n    if (index === this.options.length - 1) {\n      this.addOption();\n    } else if (\n      index === penultimateIndex &&\n      control.value?.length === 0 &&\n      this.options.at(this.options.length - 1).value?.length === 0\n    ) {\n      this.removeLastOption();\n    }\n  }\n\n  get options() {\n    return this.formGroup.get('options') as FormArray<\n      FormControl<string | null>\n    >;\n  }\n\n  addOption() {\n    const control = new FormControl<string | null>('', []);\n    this.options.push(control);\n  }\n\n  removeLastOption() {\n    this.options.removeAt(this.options.length - 1);\n  }\n\n  getModalContext(): ModalContext {\n    return {\n      isOpen: this.isModalOpen,\n      isOpenChangeHandler: (isOpen: boolean) => {\n        if (!isOpen) {\n          this.cancel.emit();\n        }\n        this.isModalOpen = isOpen;\n      },\n      content: this.formContent,\n    };\n  }\n\n  async createPoll() {\n    try {\n      const maxVotesControl = this.formGroup.get('maximum_number_of_votes');\n      const response = await this.chatService.chatClient.polls.createPoll({\n        name: this.formGroup.get('name')!.value!,\n        options: this.formGroup\n          .get('options')!\n          .value.filter((v) => !!v)\n          .map((v) => ({ text: v! })),\n        enforce_unique_vote: !this.formGroup.get('multiple_answers')?.value,\n        max_votes_allowed: maxVotesControl?.value\n          ? +maxVotesControl.value\n          : undefined,\n        voting_visibility: this.formGroup.get('is_anonymous')?.value\n          ? VotingVisibility.anonymous\n          : VotingVisibility.public,\n        allow_user_suggested_options: !!this.formGroup.get(\n          'allow_user_suggested_options'\n        )?.value,\n        allow_answers: !!this.formGroup.get('allow_answers')?.value,\n      });\n      this.pollCompose.emit(response?.id);\n    } catch (error) {\n      this.notificationService.addTemporaryNotification(\n        'streamChat.Failed to create poll'\n      );\n      throw error;\n    }\n  }\n}\n","<ng-container>\n  <ng-container\n    *ngTemplateOutlet=\"\n      (customTemplatesService.modalTemplate$ | async) || defaultModal;\n      context: getModalContext()\n    \"\n  />\n</ng-container>\n\n<ng-template\n  #defaultModal\n  let-isOpen=\"isOpen\"\n  let-isOpenChangeHandler=\"isOpenChangeHandler\"\n  let-content=\"content\"\n>\n  <stream-modal\n    class=\"str-chat-angular__create-poll-modal str-chat__create-poll-modal\"\n    [isOpen]=\"isOpen\"\n    [content]=\"content\"\n    (isOpenChange)=\"isOpenChangeHandler($event)\"\n  />\n</ng-template>\n\n<ng-template #formContent>\n  <div\n    class=\"str-chat__dialog str-chat__poll-creation-dialog\"\n    data-testid=\"poll-creation-dialog\"\n  >\n    <div class=\"str-chat__modal-header\">\n      <div class=\"str-chat__modal-header__title\">\n        {{ \"streamChat.Create poll\" | translate }}\n      </div>\n    </div>\n    <div class=\"str-chat__dialog__body\">\n      <form [formGroup]=\"formGroup\" autocomplete=\"off\">\n        <div\n          class=\"str-chat__form__field str-chat__form__input-field str-chat__form__input-field--with-label\"\n          [class.str-chat__form__input-field--has-error]=\"\n            formGroup.get('name')?.errors && formGroup.get('name')?.touched\n          \"\n        >\n          <label class=\"str-chat__form__field-label\" htmlFor=\"name\">\n            {{ \"streamChat.Question\" | translate }}\n          </label>\n          <div class=\"str-chat__form__input-field__value\">\n            <div\n              class=\"str-chat__form-field-error str-chat__form__input-field__error\"\n            >\n              {{\n                (formGroup.get(\"name\")?.errors?.required &&\n                formGroup.get(\"name\")?.touched\n                  ? \"streamChat.Question is required\"\n                  : \"\"\n                ) | translate\n              }}\n            </div>\n            <input\n              id=\"name\"\n              type=\"text\"\n              formControlName=\"name\"\n              placeholder=\"{{ 'streamChat.Ask a question' | translate }}\"\n            />\n          </div>\n        </div>\n        <fieldset class=\"str-chat__form__field str-chat__form__input-fieldset\">\n          <legend class=\"str-chat__form__field-label\">\n            {{ \"streamChat.Options\" | translate }}\n          </legend>\n          <div\n            class=\"str-chat__form-field-error str-chat__form__input-field__error\"\n          >\n            {{\n              (formGroup.get(\"options\")?.errors?.atLeastOne &&\n              formGroup.get(\"options\")?.touched\n                ? \"streamChat.Provide at least one option\"\n                : \"\"\n              ) | translate\n            }}\n          </div>\n          <ng-container formArrayName=\"options\">\n            <div class=\"str-chat__form__input-fieldset__values\">\n              <!-- eslint-disable @angular-eslint/template/use-track-by-function -->\n              <ng-container\n                *ngFor=\"let option of options.controls; let i = index\"\n              >\n                <!-- eslint-enable @angular-eslint/template/use-track-by-function -->\n                <div class=\"str-chat__drag-and-drop-container__item\">\n                  <div class=\"str-chat__form__input-field\">\n                    <div class=\"str-chat__form__input-field__value\">\n                      <input\n                        id=\"option{{ i }}\"\n                        name=\"option{{ i }}\"\n                        type=\"text\"\n                        [formControl]=\"option\"\n                        (input)=\"optionChanged(i)\"\n                        placeholder=\"{{\n                          'streamChat.Add an option' | translate\n                        }}\"\n                      />\n                    </div>\n                  </div>\n                </div>\n              </ng-container>\n            </div>\n          </ng-container>\n        </fieldset>\n        <ng-container\n          *ngTemplateOutlet=\"\n            switch;\n            context: {\n              name: 'multiple_answers',\n              control: formGroup.get('multiple_answers'),\n              label: 'streamChat.Multiple answers' | translate\n            }\n          \"\n        />\n        <div\n          *ngIf=\"formGroup.get('multiple_answers')?.value\"\n          class=\"str-chat__form__field str-chat__form__input-field str-chat__form__input-field--with-label\"\n          [class.str-chat__form__input-field--has-error]=\"\n            formGroup.get('maximum_number_of_votes')?.errors &&\n            formGroup.get('maximum_number_of_votes')?.touched\n          \"\n        >\n          <label class=\"str-chat__form__field-label\" htmlFor=\"name\">\n            {{ \"streamChat.Maximum number of votes\" | translate }}\n          </label>\n          <div class=\"str-chat__form__input-field__value\">\n            <div\n              class=\"str-chat__form-field-error str-chat__form__input-field__error\"\n            >\n              {{\n                (formGroup.get(\"maximum_number_of_votes\")?.errors &&\n                formGroup.get(\"maximum_number_of_votes\")?.touched\n                  ? \"streamChat.Provide a value between {{ min }}\n              and {{ max }}\" : \"\" ) | translate: { min: 2, max: 10 } }}\n            </div>\n            <input\n              id=\"maximum_number_of_votes\"\n              type=\"text\"\n              formControlName=\"maximum_number_of_votes\"\n              placeholder=\"{{ 'streamChat.Provide a value between ' \n              + '{{ min }} and {{ max }}' | translate: { min: 2, max: 10 } }}\"\n            />\n          </div>\n        </div>\n        <ng-container\n          *ngTemplateOutlet=\"\n            switch;\n            context: {\n              name: 'is_anonymous',\n              control: formGroup.get('is_anonymous'),\n              label: 'streamChat.Anonymous poll' | translate\n            }\n          \"\n        />\n        <ng-container\n          *ngTemplateOutlet=\"\n            switch;\n            context: {\n              name: 'allow_user_suggested_options',\n              control: formGroup.get('allow_user_suggested_options'),\n              label: 'streamChat.Allow option suggestions' | translate\n            }\n          \"\n        />\n        <ng-container\n          *ngTemplateOutlet=\"\n            switch;\n            context: {\n              name: 'allow_answers',\n              control: formGroup.get('allow_answers'),\n              label: 'streamChat.Allow comments' | translate\n            }\n          \"\n        />\n      </form>\n    </div>\n    <stream-notification-list />\n    <div class=\"str-chat__dialog__controls\">\n      <button\n        class=\"str-chat__dialog__controls-button str-chat__dialog__controls-button--cancel\"\n        (click)=\"cancel.emit()\"\n        type=\"button\"\n      >\n        {{ \"streamChat.Cancel\" | translate }}\n      </button>\n      <button\n        class=\"str-chat__dialog__controls-button str-chat__dialog__controls-button--submit\"\n        (click)=\"createPoll()\"\n        [disabled]=\"formGroup.invalid\"\n        type=\"submit\"\n      >\n        {{ \"streamChat.Create\" | translate }}\n      </button>\n    </div>\n  </div>\n</ng-template>\n\n<ng-template #switch let-control=\"control\" let-label=\"label\" let-name=\"name\">\n  <div class=\"str-chat__form__field str-chat__form__switch-field\">\n    <label>\n      <div class=\"str-chat__form__field str-chat__form__switch-field-content\">\n        <div class=\"str-chat__form__field str-chat__form__switch-field__text\">\n          {{ label | translate }}\n        </div>\n      </div>\n      <input\n        type=\"checkbox\"\n        [checked]=\"control.value\"\n        id=\"{{ name }}\"\n        name=\"{{ name }}\"\n      />\n      <div\n        class=\"str-chat__form__switch-field__switch\"\n        [class.str-chat__form__switch-field__switch--on]=\"control.value\"\n        (click)=\"control.setValue(!control.value, { emitEvent: true })\"\n        (keyup.enter)=\"control.setValue(!control.value, { emitEvent: true })\"\n      >\n        <div class=\"str-chat__form__switch-field__switch-handle\"></div>\n      </div>\n    </label>\n  </div>\n</ng-template>\n"]}
|
|
@@ -70,11 +70,11 @@ export class PollHeaderComponent extends BasePollComponent {
|
|
|
70
70
|
count: undefined,
|
|
71
71
|
};
|
|
72
72
|
}
|
|
73
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PollHeaderComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
74
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: PollHeaderComponent, selector: "stream-poll-header", usesInheritance: true, ngImport: i0, template: "<div class=\"str-chat__poll-header\">\n <div class=\"str-chat__poll-title\">{{ name }}</div>\n <div class=\"str-chat__poll-subtitle\">\n {{ selectionInstructions.text | translate : selectionInstructions }}\n </div>\n</div>\n", dependencies: [{ kind: "pipe", type: i1.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
73
75
|
}
|
|
74
|
-
|
|
75
|
-
PollHeaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.4", type: PollHeaderComponent, selector: "stream-poll-header", usesInheritance: true, ngImport: i0, template: "<div class=\"str-chat__poll-header\">\n <div class=\"str-chat__poll-title\">{{ name }}</div>\n <div class=\"str-chat__poll-subtitle\">\n {{ selectionInstructions.text | translate : selectionInstructions }}\n </div>\n</div>\n", dependencies: [{ kind: "pipe", type: i1.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
76
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: PollHeaderComponent, decorators: [{
|
|
76
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PollHeaderComponent, decorators: [{
|
|
77
77
|
type: Component,
|
|
78
78
|
args: [{ selector: 'stream-poll-header', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"str-chat__poll-header\">\n <div class=\"str-chat__poll-title\">{{ name }}</div>\n <div class=\"str-chat__poll-subtitle\">\n {{ selectionInstructions.text | translate : selectionInstructions }}\n </div>\n</div>\n" }]
|
|
79
79
|
}] });
|
|
80
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
80
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9sbC1oZWFkZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc3RyZWFtLWNoYXQtYW5ndWxhci9zcmMvbGliL3BvbGxzL3BvbGwtaGVhZGVyL3BvbGwtaGVhZGVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3N0cmVhbS1jaGF0LWFuZ3VsYXIvc3JjL2xpYi9wb2xscy9wb2xsLWhlYWRlci9wb2xsLWhlYWRlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRW5FLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHdCQUF3QixDQUFDOzs7QUFPM0Q7O0dBRUc7QUFPSCxNQUFNLE9BQU8sbUJBQW9CLFNBQVEsaUJBQWlCO0lBTjFEOztRQU9FLFNBQUksR0FBRyxFQUFFLENBQUM7UUFDViwwQkFBcUIsR0FBMEI7WUFDN0MsSUFBSSxFQUFFLEVBQUU7WUFDUixLQUFLLEVBQUUsU0FBUztTQUNqQixDQUFDO0tBNEVIO0lBMUVXLGtCQUFrQixDQUMxQixJQUFVLEVBQ1YsWUFBd0I7UUFFeEIsTUFBTSxXQUFXLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxxQkFBcUIsQ0FDbEQsQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7WUFDVixJQUFJLEVBQUUsS0FBSyxDQUFDLElBQUk7WUFDaEIsU0FBUyxFQUFFLEtBQUssQ0FBQyxTQUFTO1lBQzFCLG1CQUFtQixFQUFFLEtBQUssQ0FBQyxtQkFBbUI7WUFDOUMsaUJBQWlCLEVBQUUsS0FBSyxDQUFDLGlCQUFpQjtZQUMxQyxPQUFPLEVBQUUsS0FBSyxDQUFDLE9BQU87U0FDdkIsQ0FBQyxFQUNGLENBQUMsS0FBSyxFQUFFLEVBQUU7WUFDUixNQUFNLElBQUksR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDO1lBQ3hCLE1BQU0scUJBQXFCLEdBQUcsSUFBSSxDQUFDLHdCQUF3QixDQUFDLEtBQUssQ0FBQyxDQUFDO1lBRW5FLElBQUksT0FBTyxHQUFHLEtBQUssQ0FBQztZQUNwQixJQUFJLElBQUksS0FBSyxJQUFJLENBQUMsSUFBSSxFQUFFO2dCQUN0QixJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQztnQkFDakIsT0FBTyxHQUFHLElBQUksQ0FBQzthQUNoQjtZQUNELElBQ0UscUJBQXFCLENBQUMsSUFBSSxLQUFLLElBQUksQ0FBQyxxQkFBcUIsQ0FBQyxJQUFJO2dCQUM5RCxxQkFBcUIsQ0FBQyxLQUFLLEtBQUssSUFBSSxDQUFDLHFCQUFxQixDQUFDLEtBQUssRUFDaEU7Z0JBQ0EsSUFBSSxDQUFDLHFCQUFxQixHQUFHLHFCQUFxQixDQUFDO2dCQUNuRCxPQUFPLEdBQUcsSUFBSSxDQUFDO2FBQ2hCO1lBRUQsSUFBSSxPQUFPLEVBQUU7Z0JBQ1gsWUFBWSxFQUFFLENBQUM7YUFDaEI7UUFDSCxDQUFDLENBQ0YsQ0FBQztRQUVGLE9BQU8sV0FBVyxDQUFDO0lBQ3JCLENBQUM7SUFFRCx3QkFBd0IsQ0FDdEIsS0FHQztRQUVELElBQUksS0FBSyxDQUFDLFNBQVM7WUFDakIsT0FBTztnQkFDTCxJQUFJLEVBQUUsdUJBQXVCO2dCQUM3QixLQUFLLEVBQUUsU0FBUzthQUNqQixDQUFDO1FBQ0osSUFBSSxLQUFLLENBQUMsbUJBQW1CLElBQUksS0FBSyxDQUFDLE9BQU8sQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFO1lBQzNELE9BQU87Z0JBQ0wsSUFBSSxFQUFFLHVCQUF1QjtnQkFDN0IsS0FBSyxFQUFFLFNBQVM7YUFDakIsQ0FBQztTQUNIO1FBQ0QsSUFBSSxLQUFLLENBQUMsaUJBQWlCO1lBQ3pCLE9BQU87Z0JBQ0wsSUFBSSxFQUFFLG1DQUFtQztnQkFDekMsS0FBSyxFQUNILEtBQUssQ0FBQyxpQkFBaUIsR0FBRyxLQUFLLENBQUMsT0FBTyxDQUFDLE1BQU07b0JBQzVDLENBQUMsQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLE1BQU07b0JBQ3RCLENBQUMsQ0FBQyxLQUFLLENBQUMsaUJBQWlCO2FBQzlCLENBQUM7UUFDSixJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRTtZQUM1QixPQUFPO2dCQUNMLElBQUksRUFBRSwrQkFBK0I7Z0JBQ3JDLEtBQUssRUFBRSxTQUFTO2FBQ2pCLENBQUM7U0FDSDtRQUNELE9BQU87WUFDTCxJQUFJLEVBQUUsRUFBRTtZQUNSLEtBQUssRUFBRSxTQUFTO1NBQ2pCLENBQUM7SUFDSixDQUFDOytHQWhGVSxtQkFBbUI7bUdBQW5CLG1CQUFtQixpRkNsQmhDLHdPQU1BOzs0RkRZYSxtQkFBbUI7a0JBTi9CLFNBQVM7K0JBQ0Usb0JBQW9CLG1CQUdiLHVCQUF1QixDQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIENoYW5nZURldGVjdGlvblN0cmF0ZWd5IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBQb2xsLCBQb2xsU3RhdGUgfSBmcm9tICdzdHJlYW0tY2hhdCc7XG5pbXBvcnQgeyBCYXNlUG9sbENvbXBvbmVudCB9IGZyb20gJy4uL2Jhc2UtcG9sbC5jb21wb25lbnQnO1xuXG50eXBlIFNlbGVjdGlvbkluc3RydWN0aW9ucyA9IHtcbiAgdGV4dDogc3RyaW5nO1xuICBjb3VudDogbnVtYmVyIHwgdW5kZWZpbmVkO1xufTtcblxuLyoqXG4gKlxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdzdHJlYW0tcG9sbC1oZWFkZXInLFxuICB0ZW1wbGF0ZVVybDogJy4vcG9sbC1oZWFkZXIuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZXM6IFtdLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgUG9sbEhlYWRlckNvbXBvbmVudCBleHRlbmRzIEJhc2VQb2xsQ29tcG9uZW50IHtcbiAgbmFtZSA9ICcnO1xuICBzZWxlY3Rpb25JbnN0cnVjdGlvbnM6IFNlbGVjdGlvbkluc3RydWN0aW9ucyA9IHtcbiAgICB0ZXh0OiAnJyxcbiAgICBjb3VudDogdW5kZWZpbmVkLFxuICB9O1xuXG4gIHByb3RlY3RlZCBzdGF0ZVN0b3JlU2VsZWN0b3IoXG4gICAgcG9sbDogUG9sbCxcbiAgICBtYXJrRm9yQ2hlY2s6ICgpID0+IHZvaWRcbiAgKTogKCkgPT4gdm9pZCB7XG4gICAgY29uc3QgdW5zdWJzY3JpYmUgPSBwb2xsLnN0YXRlLnN1YnNjcmliZVdpdGhTZWxlY3RvcihcbiAgICAgIChzdGF0ZSkgPT4gKHtcbiAgICAgICAgbmFtZTogc3RhdGUubmFtZSxcbiAgICAgICAgaXNfY2xvc2VkOiBzdGF0ZS5pc19jbG9zZWQsXG4gICAgICAgIGVuZm9yY2VfdW5pcXVlX3ZvdGU6IHN0YXRlLmVuZm9yY2VfdW5pcXVlX3ZvdGUsXG4gICAgICAgIG1heF92b3Rlc19hbGxvd2VkOiBzdGF0ZS5tYXhfdm90ZXNfYWxsb3dlZCxcbiAgICAgICAgb3B0aW9uczogc3RhdGUub3B0aW9ucyxcbiAgICAgIH0pLFxuICAgICAgKHN0YXRlKSA9PiB7XG4gICAgICAgIGNvbnN0IG5hbWUgPSBzdGF0ZS5uYW1lO1xuICAgICAgICBjb25zdCBzZWxlY3Rpb25JbnN0cnVjdGlvbnMgPSB0aGlzLmdldFNlbGVjdGlvbkluc3RydWN0aW9ucyhzdGF0ZSk7XG5cbiAgICAgICAgbGV0IGNoYW5nZWQgPSBmYWxzZTtcbiAgICAgICAgaWYgKG5hbWUgIT09IHRoaXMubmFtZSkge1xuICAgICAgICAgIHRoaXMubmFtZSA9IG5hbWU7XG4gICAgICAgICAgY2hhbmdlZCA9IHRydWU7XG4gICAgICAgIH1cbiAgICAgICAgaWYgKFxuICAgICAgICAgIHNlbGVjdGlvbkluc3RydWN0aW9ucy50ZXh0ICE9PSB0aGlzLnNlbGVjdGlvbkluc3RydWN0aW9ucy50ZXh0IHx8XG4gICAgICAgICAgc2VsZWN0aW9uSW5zdHJ1Y3Rpb25zLmNvdW50ICE9PSB0aGlzLnNlbGVjdGlvbkluc3RydWN0aW9ucy5jb3VudFxuICAgICAgICApIHtcbiAgICAgICAgICB0aGlzLnNlbGVjdGlvbkluc3RydWN0aW9ucyA9IHNlbGVjdGlvbkluc3RydWN0aW9ucztcbiAgICAgICAgICBjaGFuZ2VkID0gdHJ1ZTtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChjaGFuZ2VkKSB7XG4gICAgICAgICAgbWFya0ZvckNoZWNrKCk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICApO1xuXG4gICAgcmV0dXJuIHVuc3Vic2NyaWJlO1xuICB9XG5cbiAgZ2V0U2VsZWN0aW9uSW5zdHJ1Y3Rpb25zKFxuICAgIHN0YXRlOiBQaWNrPFxuICAgICAgUG9sbFN0YXRlLFxuICAgICAgJ2lzX2Nsb3NlZCcgfCAnZW5mb3JjZV91bmlxdWVfdm90ZScgfCAnbWF4X3ZvdGVzX2FsbG93ZWQnIHwgJ29wdGlvbnMnXG4gICAgPlxuICApOiBTZWxlY3Rpb25JbnN0cnVjdGlvbnMge1xuICAgIGlmIChzdGF0ZS5pc19jbG9zZWQpXG4gICAgICByZXR1cm4ge1xuICAgICAgICB0ZXh0OiAnc3RyZWFtQ2hhdC5Wb3RlIGVuZGVkJyxcbiAgICAgICAgY291bnQ6IHVuZGVmaW5lZCxcbiAgICAgIH07XG4gICAgaWYgKHN0YXRlLmVuZm9yY2VfdW5pcXVlX3ZvdGUgfHwgc3RhdGUub3B0aW9ucy5sZW5ndGggPT09IDEpIHtcbiAgICAgIHJldHVybiB7XG4gICAgICAgIHRleHQ6ICdzdHJlYW1DaGF0LlNlbGVjdCBvbmUnLFxuICAgICAgICBjb3VudDogdW5kZWZpbmVkLFxuICAgICAgfTtcbiAgICB9XG4gICAgaWYgKHN0YXRlLm1heF92b3Rlc19hbGxvd2VkKVxuICAgICAgcmV0dXJuIHtcbiAgICAgICAgdGV4dDogJ3N0cmVhbUNoYXQuU2VsZWN0IHVwIHRvIHt7Y291bnR9fScsXG4gICAgICAgIGNvdW50OlxuICAgICAgICAgIHN0YXRlLm1heF92b3Rlc19hbGxvd2VkID4gc3RhdGUub3B0aW9ucy5sZW5ndGhcbiAgICAgICAgICAgID8gc3RhdGUub3B0aW9ucy5sZW5ndGhcbiAgICAgICAgICAgIDogc3RhdGUubWF4X3ZvdGVzX2FsbG93ZWQsXG4gICAgICB9O1xuICAgIGlmIChzdGF0ZS5vcHRpb25zLmxlbmd0aCA+IDEpIHtcbiAgICAgIHJldHVybiB7XG4gICAgICAgIHRleHQ6ICdzdHJlYW1DaGF0LlNlbGVjdCBvbmUgb3IgbW9yZScsXG4gICAgICAgIGNvdW50OiB1bmRlZmluZWQsXG4gICAgICB9O1xuICAgIH1cbiAgICByZXR1cm4ge1xuICAgICAgdGV4dDogJycsXG4gICAgICBjb3VudDogdW5kZWZpbmVkLFxuICAgIH07XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJzdHItY2hhdF9fcG9sbC1oZWFkZXJcIj5cbiAgPGRpdiBjbGFzcz1cInN0ci1jaGF0X19wb2xsLXRpdGxlXCI+e3sgbmFtZSB9fTwvZGl2PlxuICA8ZGl2IGNsYXNzPVwic3RyLWNoYXRfX3BvbGwtc3VidGl0bGVcIj5cbiAgICB7eyBzZWxlY3Rpb25JbnN0cnVjdGlvbnMudGV4dCB8IHRyYW5zbGF0ZSA6IHNlbGVjdGlvbkluc3RydWN0aW9ucyB9fVxuICA8L2Rpdj5cbjwvZGl2PlxuIl19
|
package/{esm2020 → esm2022}/lib/polls/poll-option-selector/poll-option-selector.component.mjs
RENAMED
|
@@ -121,12 +121,12 @@ export class PollOptionSelectorComponent extends BasePollComponent {
|
|
|
121
121
|
});
|
|
122
122
|
return unsubscribe;
|
|
123
123
|
}
|
|
124
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PollOptionSelectorComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
125
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: PollOptionSelectorComponent, selector: "stream-poll-option-selector", inputs: { option: "option", displayAvatarCount: "displayAvatarCount", voteCountVerbose: "voteCountVerbose" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div\n class=\"str-chat__poll-option\"\n [class.str-chat__poll-option--votable]=\"\n !isClosed &&\n canVote &&\n maxVoteAllowedCount &&\n ownVoteCount < maxVoteAllowedCount &&\n !ownVote\n \"\n (click)=\"toggleVote()\"\n (keyup.enter)=\"toggleVote()\"\n>\n <ng-container *ngIf=\"canVote\">\n <ng-container *ngTemplateOutlet=\"checkmark\" />\n </ng-container>\n <div class=\"str-chat__poll-option-data\">\n <p class=\"str-chat__poll-option-text\">{{ option?.text }}</p>\n <ng-container *ngIf=\"displayAvatarCount && votingVisibility === 'public'\">\n <div\n *ngFor=\"let vote of latestVotes; trackBy: trackByVoteId\"\n class=\"str-chat__poll-option-voters\"\n >\n <stream-avatar-placeholder\n location=\"poll-voter\"\n [user]=\"vote.user\"\n [imageUrl]=\"vote.user?.image\"\n [name]=\"vote.user?.name\"\n type=\"user\"\n />\n </div>\n </ng-container>\n <div class=\"str-chat__poll-option-vote-count\">\n <ng-container *ngIf=\"voteCountVerbose; else count\">\n {{ 'streamChat.{{ count }} votes' | translate:{count: voteCount} }}\n </ng-container>\n <ng-template #count>\n {{ voteCount }}\n </ng-template>\n </div>\n </div>\n <ng-container *ngTemplateOutlet=\"amountBar\" />\n</div>\n\n<ng-template #checkmark>\n <div\n class=\"str-chat__checkmark\"\n [class.str-chat__checkmark--checked]=\"!!ownVote\"\n ></div>\n</ng-template>\n\n<ng-template #amountBar>\n <div\n class=\"str-chat__amount-bar str-chat__poll-option__votes-bar\"\n [class.str-chat__poll-option__votes-bar--winner]=\"isClosed && isWinner\"\n role=\"progressbar\"\n [ngStyle]=\"{\n '--str-chat__amount-bar-fulfillment':\n (winningOptionCount && voteCount / winningOptionCount) * 100 + '%'\n }\"\n ></div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i2.AvatarPlaceholderComponent, selector: "stream-avatar-placeholder", inputs: ["name", "imageUrl", "location", "channel", "user", "type", "initialsType", "showOnlineIndicator"] }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
124
126
|
}
|
|
125
|
-
|
|
126
|
-
PollOptionSelectorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.4", type: PollOptionSelectorComponent, selector: "stream-poll-option-selector", inputs: { option: "option", displayAvatarCount: "displayAvatarCount", voteCountVerbose: "voteCountVerbose" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div\n class=\"str-chat__poll-option\"\n [class.str-chat__poll-option--votable]=\"\n !isClosed &&\n canVote &&\n maxVoteAllowedCount &&\n ownVoteCount < maxVoteAllowedCount &&\n !ownVote\n \"\n (click)=\"toggleVote()\"\n (keyup.enter)=\"toggleVote()\"\n>\n <ng-container *ngIf=\"canVote\">\n <ng-container *ngTemplateOutlet=\"checkmark\"></ng-container>\n </ng-container>\n <div class=\"str-chat__poll-option-data\">\n <p class=\"str-chat__poll-option-text\">{{ option?.text }}</p>\n <ng-container *ngIf=\"displayAvatarCount && votingVisibility === 'public'\">\n <div\n *ngFor=\"let vote of latestVotes; trackBy: trackByVoteId\"\n class=\"str-chat__poll-option-voters\"\n >\n <stream-avatar-placeholder\n location=\"poll-voter\"\n [user]=\"vote.user\"\n [imageUrl]=\"vote.user?.image\"\n [name]=\"vote.user?.name\"\n type=\"user\"\n ></stream-avatar-placeholder>\n </div>\n </ng-container>\n <div class=\"str-chat__poll-option-vote-count\">\n <ng-container *ngIf=\"voteCountVerbose; else count\">\n {{ 'streamChat.{{ count }} votes' | translate:{count: voteCount} }}\n </ng-container>\n <ng-template #count>\n {{ voteCount }}\n </ng-template>\n </div>\n </div>\n <ng-container *ngTemplateOutlet=\"amountBar\"></ng-container>\n</div>\n\n<ng-template #checkmark>\n <div\n class=\"str-chat__checkmark\"\n [class.str-chat__checkmark--checked]=\"!!ownVote\"\n ></div>\n</ng-template>\n\n<ng-template #amountBar>\n <div\n class=\"str-chat__amount-bar str-chat__poll-option__votes-bar\"\n [class.str-chat__poll-option__votes-bar--winner]=\"isClosed && isWinner\"\n role=\"progressbar\"\n [ngStyle]=\"{\n '--str-chat__amount-bar-fulfillment':\n (winningOptionCount && voteCount / winningOptionCount) * 100 + '%'\n }\"\n ></div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i2.AvatarPlaceholderComponent, selector: "stream-avatar-placeholder", inputs: ["name", "imageUrl", "location", "channel", "user", "type", "initialsType", "showOnlineIndicator"] }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
127
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: PollOptionSelectorComponent, decorators: [{
|
|
127
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PollOptionSelectorComponent, decorators: [{
|
|
128
128
|
type: Component,
|
|
129
|
-
args: [{ selector: 'stream-poll-option-selector', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n class=\"str-chat__poll-option\"\n [class.str-chat__poll-option--votable]=\"\n !isClosed &&\n canVote &&\n maxVoteAllowedCount &&\n ownVoteCount < maxVoteAllowedCount &&\n !ownVote\n \"\n (click)=\"toggleVote()\"\n (keyup.enter)=\"toggleVote()\"\n>\n <ng-container *ngIf=\"canVote\">\n <ng-container *ngTemplateOutlet=\"checkmark\"
|
|
129
|
+
args: [{ selector: 'stream-poll-option-selector', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n class=\"str-chat__poll-option\"\n [class.str-chat__poll-option--votable]=\"\n !isClosed &&\n canVote &&\n maxVoteAllowedCount &&\n ownVoteCount < maxVoteAllowedCount &&\n !ownVote\n \"\n (click)=\"toggleVote()\"\n (keyup.enter)=\"toggleVote()\"\n>\n <ng-container *ngIf=\"canVote\">\n <ng-container *ngTemplateOutlet=\"checkmark\" />\n </ng-container>\n <div class=\"str-chat__poll-option-data\">\n <p class=\"str-chat__poll-option-text\">{{ option?.text }}</p>\n <ng-container *ngIf=\"displayAvatarCount && votingVisibility === 'public'\">\n <div\n *ngFor=\"let vote of latestVotes; trackBy: trackByVoteId\"\n class=\"str-chat__poll-option-voters\"\n >\n <stream-avatar-placeholder\n location=\"poll-voter\"\n [user]=\"vote.user\"\n [imageUrl]=\"vote.user?.image\"\n [name]=\"vote.user?.name\"\n type=\"user\"\n />\n </div>\n </ng-container>\n <div class=\"str-chat__poll-option-vote-count\">\n <ng-container *ngIf=\"voteCountVerbose; else count\">\n {{ 'streamChat.{{ count }} votes' | translate:{count: voteCount} }}\n </ng-container>\n <ng-template #count>\n {{ voteCount }}\n </ng-template>\n </div>\n </div>\n <ng-container *ngTemplateOutlet=\"amountBar\" />\n</div>\n\n<ng-template #checkmark>\n <div\n class=\"str-chat__checkmark\"\n [class.str-chat__checkmark--checked]=\"!!ownVote\"\n ></div>\n</ng-template>\n\n<ng-template #amountBar>\n <div\n class=\"str-chat__amount-bar str-chat__poll-option__votes-bar\"\n [class.str-chat__poll-option__votes-bar--winner]=\"isClosed && isWinner\"\n role=\"progressbar\"\n [ngStyle]=\"{\n '--str-chat__amount-bar-fulfillment':\n (winningOptionCount && voteCount / winningOptionCount) * 100 + '%'\n }\"\n ></div>\n</ng-template>\n" }]
|
|
130
130
|
}], propDecorators: { option: [{
|
|
131
131
|
type: Input
|
|
132
132
|
}], displayAvatarCount: [{
|
|
@@ -134,4 +134,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImpor
|
|
|
134
134
|
}], voteCountVerbose: [{
|
|
135
135
|
type: Input
|
|
136
136
|
}] } });
|
|
137
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"poll-option-selector.component.js","sourceRoot":"","sources":["../../../../../../projects/stream-chat-angular/src/lib/polls/poll-option-selector/poll-option-selector.component.ts","../../../../../../projects/stream-chat-angular/src/lib/polls/poll-option-selector/poll-option-selector.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  Input,\n  OnChanges,\n  SimpleChanges,\n} from '@angular/core';\nimport { BasePollComponent } from '../base-poll.component';\nimport {\n  isVoteAnswer,\n  Poll,\n  PollOption,\n  PollVote,\n  VotingVisibility,\n} from 'stream-chat';\n\n/**\n *\n */\n@Component({\n  selector: 'stream-poll-option-selector',\n  templateUrl: './poll-option-selector.component.html',\n  styles: [],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class PollOptionSelectorComponent\n  extends BasePollComponent\n  implements OnChanges\n{\n  @Input() option: PollOption | undefined;\n  @Input() displayAvatarCount = 3;\n  @Input() voteCountVerbose = false;\n  isClosed = false;\n  latestVotes: PollVote[] = [];\n  isWinner = false;\n  ownVote: PollVote | undefined;\n  voteCount = 0;\n  votingVisibility: VotingVisibility | undefined;\n  winningOptionCount = 0;\n  maxVoteAllowedCount = 0;\n  ownVoteCount = 0;\n\n  ngOnChanges(changes: SimpleChanges): void {\n    super.ngOnChanges(changes);\n    if (changes['option']) {\n      this.setupStateStoreSelector();\n    }\n  }\n\n  async toggleVote() {\n    if (!this.canVote || !this.option?.id || !this.messageId || this.isClosed)\n      return;\n    const haveVotedForTheOption = !!this.ownVote;\n    if (\n      !haveVotedForTheOption &&\n      this.maxVoteAllowedCount > 0 &&\n      this.ownVoteCount >= this.maxVoteAllowedCount\n    ) {\n      this.addNotification(\n        'streamChat.You have reached the maximum number of votes allowed'\n      );\n      return;\n    }\n    try {\n      await (haveVotedForTheOption\n        ? this.poll?.removeVote(this.ownVote!.id, this.messageId)\n        : this.poll?.castVote(this.option?.id, this.messageId));\n    } catch (error) {\n      this.notificationService.addTemporaryNotification(\n        'streamChat.Failed to cast vote'\n      );\n      throw error;\n    }\n  }\n\n  trackByVoteId(_: number, vote: PollVote) {\n    return vote.id;\n  }\n\n  protected stateStoreSelector(\n    poll: Poll,\n    markForCheck: () => void\n  ): () => void {\n    const unsubscribe = poll.state.subscribeWithSelector(\n      (nextValue) => {\n        return {\n          is_closed: nextValue.is_closed,\n          latest_votes_by_option: nextValue.latest_votes_by_option,\n          maxVotedOptionIds: nextValue.maxVotedOptionIds,\n          ownVotesByOptionId: nextValue.ownVotesByOptionId,\n          vote_counts_by_option: nextValue.vote_counts_by_option,\n          voting_visibility: nextValue.voting_visibility,\n          max_votes_allowed: nextValue.max_votes_allowed,\n        };\n      },\n      (state) => {\n        const isClosed = state.is_closed;\n        const latestVotes =\n          state.latest_votes_by_option[this.option?.id ?? '']?.filter(\n            (vote) => !!vote.user && !isVoteAnswer(vote)\n          ) ?? [];\n        const isWinner =\n          state.maxVotedOptionIds.includes(this.option?.id ?? '') &&\n          state.maxVotedOptionIds.length === 1;\n        const ownVote = state.ownVotesByOptionId[this.option?.id ?? ''];\n        const voteCount = state.vote_counts_by_option[this.option?.id ?? ''];\n        const votingVisibility = state.voting_visibility;\n        const winningOptionCount =\n          state.vote_counts_by_option[state.maxVotedOptionIds?.[0] ?? ''];\n        const maxVoteAllowedCount = state.max_votes_allowed;\n        const ownVoteCount = Object.keys(state.ownVotesByOptionId).length;\n\n        let changed = false;\n        if (isClosed !== this.isClosed) {\n          this.isClosed = isClosed ?? false;\n          changed = true;\n        }\n        if (latestVotes !== this.latestVotes) {\n          this.latestVotes = latestVotes ?? [];\n          changed = true;\n        }\n        if (isWinner !== this.isWinner) {\n          this.isWinner = isWinner ?? false;\n          changed = true;\n        }\n        if (ownVote !== this.ownVote) {\n          this.ownVote = ownVote ?? undefined;\n          changed = true;\n        }\n        if (voteCount !== this.voteCount) {\n          this.voteCount = voteCount ?? 0;\n          changed = true;\n        }\n        if (votingVisibility !== this.votingVisibility) {\n          this.votingVisibility = votingVisibility ?? undefined;\n          changed = true;\n        }\n        if (winningOptionCount !== this.winningOptionCount) {\n          this.winningOptionCount = winningOptionCount ?? 0;\n          changed = true;\n        }\n        if (maxVoteAllowedCount !== this.maxVoteAllowedCount) {\n          this.maxVoteAllowedCount = maxVoteAllowedCount ?? 0;\n          changed = true;\n        }\n        if (ownVoteCount !== this.ownVoteCount) {\n          this.ownVoteCount = ownVoteCount ?? 0;\n          changed = true;\n        }\n\n        if (\n          this.dismissNotificationFn &&\n          this.maxVoteAllowedCount > 0 &&\n          this.ownVoteCount <= this.maxVoteAllowedCount\n        ) {\n          this.dismissNotificationFn();\n          changed = true;\n        }\n\n        if (changed) {\n          markForCheck();\n        }\n      }\n    );\n\n    return unsubscribe;\n  }\n}\n","<div\n  class=\"str-chat__poll-option\"\n  [class.str-chat__poll-option--votable]=\"\n    !isClosed &&\n    canVote &&\n    maxVoteAllowedCount &&\n    ownVoteCount < maxVoteAllowedCount &&\n    !ownVote\n  \"\n  (click)=\"toggleVote()\"\n  (keyup.enter)=\"toggleVote()\"\n>\n  <ng-container *ngIf=\"canVote\">\n    <ng-container *ngTemplateOutlet=\"checkmark\"></ng-container>\n  </ng-container>\n  <div class=\"str-chat__poll-option-data\">\n    <p class=\"str-chat__poll-option-text\">{{ option?.text }}</p>\n    <ng-container *ngIf=\"displayAvatarCount && votingVisibility === 'public'\">\n      <div\n        *ngFor=\"let vote of latestVotes; trackBy: trackByVoteId\"\n        class=\"str-chat__poll-option-voters\"\n      >\n        <stream-avatar-placeholder\n          location=\"poll-voter\"\n          [user]=\"vote.user\"\n          [imageUrl]=\"vote.user?.image\"\n          [name]=\"vote.user?.name\"\n          type=\"user\"\n        ></stream-avatar-placeholder>\n      </div>\n    </ng-container>\n    <div class=\"str-chat__poll-option-vote-count\">\n      <ng-container *ngIf=\"voteCountVerbose; else count\">\n        {{ 'streamChat.{{ count }} votes' | translate:{count: voteCount} }}\n      </ng-container>\n      <ng-template #count>\n        {{ voteCount }}\n      </ng-template>\n    </div>\n  </div>\n  <ng-container *ngTemplateOutlet=\"amountBar\"></ng-container>\n</div>\n\n<ng-template #checkmark>\n  <div\n    class=\"str-chat__checkmark\"\n    [class.str-chat__checkmark--checked]=\"!!ownVote\"\n  ></div>\n</ng-template>\n\n<ng-template #amountBar>\n  <div\n    class=\"str-chat__amount-bar str-chat__poll-option__votes-bar\"\n    [class.str-chat__poll-option__votes-bar--winner]=\"isClosed && isWinner\"\n    role=\"progressbar\"\n    [ngStyle]=\"{\n      '--str-chat__amount-bar-fulfillment':\n        (winningOptionCount && voteCount / winningOptionCount) * 100 + '%'\n    }\"\n  ></div>\n</ng-template>\n"]}
|
|
137
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"poll-option-selector.component.js","sourceRoot":"","sources":["../../../../../../projects/stream-chat-angular/src/lib/polls/poll-option-selector/poll-option-selector.component.ts","../../../../../../projects/stream-chat-angular/src/lib/polls/poll-option-selector/poll-option-selector.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  Input,\n  OnChanges,\n  SimpleChanges,\n} from '@angular/core';\nimport { BasePollComponent } from '../base-poll.component';\nimport {\n  isVoteAnswer,\n  Poll,\n  PollOption,\n  PollVote,\n  VotingVisibility,\n} from 'stream-chat';\n\n/**\n *\n */\n@Component({\n  selector: 'stream-poll-option-selector',\n  templateUrl: './poll-option-selector.component.html',\n  styles: [],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class PollOptionSelectorComponent\n  extends BasePollComponent\n  implements OnChanges\n{\n  @Input() option: PollOption | undefined;\n  @Input() displayAvatarCount = 3;\n  @Input() voteCountVerbose = false;\n  isClosed = false;\n  latestVotes: PollVote[] = [];\n  isWinner = false;\n  ownVote: PollVote | undefined;\n  voteCount = 0;\n  votingVisibility: VotingVisibility | undefined;\n  winningOptionCount = 0;\n  maxVoteAllowedCount = 0;\n  ownVoteCount = 0;\n\n  ngOnChanges(changes: SimpleChanges): void {\n    super.ngOnChanges(changes);\n    if (changes['option']) {\n      this.setupStateStoreSelector();\n    }\n  }\n\n  async toggleVote() {\n    if (!this.canVote || !this.option?.id || !this.messageId || this.isClosed)\n      return;\n    const haveVotedForTheOption = !!this.ownVote;\n    if (\n      !haveVotedForTheOption &&\n      this.maxVoteAllowedCount > 0 &&\n      this.ownVoteCount >= this.maxVoteAllowedCount\n    ) {\n      this.addNotification(\n        'streamChat.You have reached the maximum number of votes allowed'\n      );\n      return;\n    }\n    try {\n      await (haveVotedForTheOption\n        ? this.poll?.removeVote(this.ownVote!.id, this.messageId)\n        : this.poll?.castVote(this.option?.id, this.messageId));\n    } catch (error) {\n      this.notificationService.addTemporaryNotification(\n        'streamChat.Failed to cast vote'\n      );\n      throw error;\n    }\n  }\n\n  trackByVoteId(_: number, vote: PollVote) {\n    return vote.id;\n  }\n\n  protected stateStoreSelector(\n    poll: Poll,\n    markForCheck: () => void\n  ): () => void {\n    const unsubscribe = poll.state.subscribeWithSelector(\n      (nextValue) => {\n        return {\n          is_closed: nextValue.is_closed,\n          latest_votes_by_option: nextValue.latest_votes_by_option,\n          maxVotedOptionIds: nextValue.maxVotedOptionIds,\n          ownVotesByOptionId: nextValue.ownVotesByOptionId,\n          vote_counts_by_option: nextValue.vote_counts_by_option,\n          voting_visibility: nextValue.voting_visibility,\n          max_votes_allowed: nextValue.max_votes_allowed,\n        };\n      },\n      (state) => {\n        const isClosed = state.is_closed;\n        const latestVotes =\n          state.latest_votes_by_option[this.option?.id ?? '']?.filter(\n            (vote) => !!vote.user && !isVoteAnswer(vote)\n          ) ?? [];\n        const isWinner =\n          state.maxVotedOptionIds.includes(this.option?.id ?? '') &&\n          state.maxVotedOptionIds.length === 1;\n        const ownVote = state.ownVotesByOptionId[this.option?.id ?? ''];\n        const voteCount = state.vote_counts_by_option[this.option?.id ?? ''];\n        const votingVisibility = state.voting_visibility;\n        const winningOptionCount =\n          state.vote_counts_by_option[state.maxVotedOptionIds?.[0] ?? ''];\n        const maxVoteAllowedCount = state.max_votes_allowed;\n        const ownVoteCount = Object.keys(state.ownVotesByOptionId).length;\n\n        let changed = false;\n        if (isClosed !== this.isClosed) {\n          this.isClosed = isClosed ?? false;\n          changed = true;\n        }\n        if (latestVotes !== this.latestVotes) {\n          this.latestVotes = latestVotes ?? [];\n          changed = true;\n        }\n        if (isWinner !== this.isWinner) {\n          this.isWinner = isWinner ?? false;\n          changed = true;\n        }\n        if (ownVote !== this.ownVote) {\n          this.ownVote = ownVote ?? undefined;\n          changed = true;\n        }\n        if (voteCount !== this.voteCount) {\n          this.voteCount = voteCount ?? 0;\n          changed = true;\n        }\n        if (votingVisibility !== this.votingVisibility) {\n          this.votingVisibility = votingVisibility ?? undefined;\n          changed = true;\n        }\n        if (winningOptionCount !== this.winningOptionCount) {\n          this.winningOptionCount = winningOptionCount ?? 0;\n          changed = true;\n        }\n        if (maxVoteAllowedCount !== this.maxVoteAllowedCount) {\n          this.maxVoteAllowedCount = maxVoteAllowedCount ?? 0;\n          changed = true;\n        }\n        if (ownVoteCount !== this.ownVoteCount) {\n          this.ownVoteCount = ownVoteCount ?? 0;\n          changed = true;\n        }\n\n        if (\n          this.dismissNotificationFn &&\n          this.maxVoteAllowedCount > 0 &&\n          this.ownVoteCount <= this.maxVoteAllowedCount\n        ) {\n          this.dismissNotificationFn();\n          changed = true;\n        }\n\n        if (changed) {\n          markForCheck();\n        }\n      }\n    );\n\n    return unsubscribe;\n  }\n}\n","<div\n  class=\"str-chat__poll-option\"\n  [class.str-chat__poll-option--votable]=\"\n    !isClosed &&\n    canVote &&\n    maxVoteAllowedCount &&\n    ownVoteCount < maxVoteAllowedCount &&\n    !ownVote\n  \"\n  (click)=\"toggleVote()\"\n  (keyup.enter)=\"toggleVote()\"\n>\n  <ng-container *ngIf=\"canVote\">\n    <ng-container *ngTemplateOutlet=\"checkmark\" />\n  </ng-container>\n  <div class=\"str-chat__poll-option-data\">\n    <p class=\"str-chat__poll-option-text\">{{ option?.text }}</p>\n    <ng-container *ngIf=\"displayAvatarCount && votingVisibility === 'public'\">\n      <div\n        *ngFor=\"let vote of latestVotes; trackBy: trackByVoteId\"\n        class=\"str-chat__poll-option-voters\"\n      >\n        <stream-avatar-placeholder\n          location=\"poll-voter\"\n          [user]=\"vote.user\"\n          [imageUrl]=\"vote.user?.image\"\n          [name]=\"vote.user?.name\"\n          type=\"user\"\n        />\n      </div>\n    </ng-container>\n    <div class=\"str-chat__poll-option-vote-count\">\n      <ng-container *ngIf=\"voteCountVerbose; else count\">\n        {{ 'streamChat.{{ count }} votes' | translate:{count: voteCount} }}\n      </ng-container>\n      <ng-template #count>\n        {{ voteCount }}\n      </ng-template>\n    </div>\n  </div>\n  <ng-container *ngTemplateOutlet=\"amountBar\" />\n</div>\n\n<ng-template #checkmark>\n  <div\n    class=\"str-chat__checkmark\"\n    [class.str-chat__checkmark--checked]=\"!!ownVote\"\n  ></div>\n</ng-template>\n\n<ng-template #amountBar>\n  <div\n    class=\"str-chat__amount-bar str-chat__poll-option__votes-bar\"\n    [class.str-chat__poll-option__votes-bar--winner]=\"isClosed && isWinner\"\n    role=\"progressbar\"\n    [ngStyle]=\"{\n      '--str-chat__amount-bar-fulfillment':\n        (winningOptionCount && voteCount / winningOptionCount) * 100 + '%'\n    }\"\n  ></div>\n</ng-template>\n"]}
|
|
@@ -27,13 +27,13 @@ export class PollOptionsListComponent extends BasePollComponent {
|
|
|
27
27
|
trackByOptionId(_, option) {
|
|
28
28
|
return option.id;
|
|
29
29
|
}
|
|
30
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PollOptionsListComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
31
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: PollOptionsListComponent, selector: "stream-poll-options-list", inputs: { maxOptionsDisplayed: "maxOptionsDisplayed" }, usesInheritance: true, ngImport: i0, template: "<div\n class=\"str-chat__poll-option-list\"\n [class.str-chat__poll-option-list--full]=\"\n !maxOptionsDisplayed || maxOptionsDisplayed === options.length\n \"\n>\n <ng-container\n *ngFor=\"\n let option of options | slice : 0 : maxOptionsDisplayed;\n trackBy: trackByOptionId\n \"\n >\n <stream-poll-option-selector\n [option]=\"option\"\n [messageId]=\"messageId\"\n [pollId]=\"pollId\"\n />\n </ng-container>\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i2.PollOptionSelectorComponent, selector: "stream-poll-option-selector", inputs: ["option", "displayAvatarCount", "voteCountVerbose"] }, { kind: "pipe", type: i1.SlicePipe, name: "slice" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
30
32
|
}
|
|
31
|
-
|
|
32
|
-
PollOptionsListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.4", type: PollOptionsListComponent, selector: "stream-poll-options-list", inputs: { maxOptionsDisplayed: "maxOptionsDisplayed" }, usesInheritance: true, ngImport: i0, template: "<div\n class=\"str-chat__poll-option-list\"\n [class.str-chat__poll-option-list--full]=\"\n !maxOptionsDisplayed || maxOptionsDisplayed === options.length\n \"\n>\n <ng-container\n *ngFor=\"\n let option of options | slice : 0 : maxOptionsDisplayed;\n trackBy: trackByOptionId\n \"\n >\n <stream-poll-option-selector\n [option]=\"option\"\n [messageId]=\"messageId\"\n [pollId]=\"pollId\"\n ></stream-poll-option-selector>\n </ng-container>\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i2.PollOptionSelectorComponent, selector: "stream-poll-option-selector", inputs: ["option", "displayAvatarCount", "voteCountVerbose"] }, { kind: "pipe", type: i1.SlicePipe, name: "slice" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
33
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: PollOptionsListComponent, decorators: [{
|
|
33
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PollOptionsListComponent, decorators: [{
|
|
34
34
|
type: Component,
|
|
35
|
-
args: [{ selector: 'stream-poll-options-list', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n class=\"str-chat__poll-option-list\"\n [class.str-chat__poll-option-list--full]=\"\n !maxOptionsDisplayed || maxOptionsDisplayed === options.length\n \"\n>\n <ng-container\n *ngFor=\"\n let option of options | slice : 0 : maxOptionsDisplayed;\n trackBy: trackByOptionId\n \"\n >\n <stream-poll-option-selector\n [option]=\"option\"\n [messageId]=\"messageId\"\n [pollId]=\"pollId\"\n
|
|
35
|
+
args: [{ selector: 'stream-poll-options-list', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n class=\"str-chat__poll-option-list\"\n [class.str-chat__poll-option-list--full]=\"\n !maxOptionsDisplayed || maxOptionsDisplayed === options.length\n \"\n>\n <ng-container\n *ngFor=\"\n let option of options | slice : 0 : maxOptionsDisplayed;\n trackBy: trackByOptionId\n \"\n >\n <stream-poll-option-selector\n [option]=\"option\"\n [messageId]=\"messageId\"\n [pollId]=\"pollId\"\n />\n </ng-container>\n</div>\n" }]
|
|
36
36
|
}], propDecorators: { maxOptionsDisplayed: [{
|
|
37
37
|
type: Input
|
|
38
38
|
}] } });
|
|
39
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9sbC1vcHRpb25zLWxpc3QuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc3RyZWFtLWNoYXQtYW5ndWxhci9zcmMvbGliL3BvbGxzL3BvbGwtb3B0aW9ucy1saXN0L3BvbGwtb3B0aW9ucy1saXN0LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3N0cmVhbS1jaGF0LWFuZ3VsYXIvc3JjL2xpYi9wb2xscy9wb2xsLW9wdGlvbnMtbGlzdC9wb2xsLW9wdGlvbnMtbGlzdC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMxRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQzs7OztBQUczRDs7R0FFRztBQU9ILE1BQU0sT0FBTyx3QkFBeUIsU0FBUSxpQkFBaUI7SUFOL0Q7O1FBT0U7O1dBRUc7UUFDTSx3QkFBbUIsR0FBdUIsRUFBRSxDQUFDO1FBQ3RELFlBQU8sR0FBaUIsRUFBRSxDQUFDO0tBc0I1QjtJQXBCVyxrQkFBa0IsQ0FDMUIsSUFBVSxFQUNWLFlBQXdCO1FBRXhCLE1BQU0sV0FBVyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMscUJBQXFCLENBQ2xELENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1lBQ1YsT0FBTyxFQUFFLEtBQUssQ0FBQyxPQUFPO1NBQ3ZCLENBQUMsRUFDRixDQUFDLEtBQUssRUFBRSxFQUFFO1lBQ1IsSUFBSSxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUMsT0FBTyxDQUFDO1lBQzdCLFlBQVksRUFBRSxDQUFDO1FBQ2pCLENBQUMsQ0FDRixDQUFDO1FBRUYsT0FBTyxXQUFXLENBQUM7SUFDckIsQ0FBQztJQUVELGVBQWUsQ0FBQyxDQUFTLEVBQUUsTUFBa0I7UUFDM0MsT0FBTyxNQUFNLENBQUMsRUFBRSxDQUFDO0lBQ25CLENBQUM7K0dBMUJVLHdCQUF3QjttR0FBeEIsd0JBQXdCLCtJQ2JyQyxxZEFtQkE7OzRGRE5hLHdCQUF3QjtrQkFOcEMsU0FBUzsrQkFDRSwwQkFBMEIsbUJBR25CLHVCQUF1QixDQUFDLE1BQU07OEJBTXRDLG1CQUFtQjtzQkFBM0IsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBCYXNlUG9sbENvbXBvbmVudCB9IGZyb20gJy4uL2Jhc2UtcG9sbC5jb21wb25lbnQnO1xuaW1wb3J0IHsgUG9sbCwgUG9sbE9wdGlvbiB9IGZyb20gJ3N0cmVhbS1jaGF0JztcblxuLyoqXG4gKlxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdzdHJlYW0tcG9sbC1vcHRpb25zLWxpc3QnLFxuICB0ZW1wbGF0ZVVybDogJy4vcG9sbC1vcHRpb25zLWxpc3QuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZXM6IFtdLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgUG9sbE9wdGlvbnNMaXN0Q29tcG9uZW50IGV4dGVuZHMgQmFzZVBvbGxDb21wb25lbnQge1xuICAvKipcbiAgICogSG93IG1hbnkgb3B0aW9ucyBzaG91bGQgYmUgZGlzcGxheWVkLiBJZiB0aGVyZSBhcmUgbW9yZSBvcHRpb25zIHRoYW4gdGhpcyBudW1iZXIsIHVzZSB0aGUgcG9sbCBhY3Rpb25zIHRvIGRpc3BsYXkgYWxsIG9wdGlvbnNcbiAgICovXG4gIEBJbnB1dCgpIG1heE9wdGlvbnNEaXNwbGF5ZWQ6IG51bWJlciB8IHVuZGVmaW5lZCA9IDEwO1xuICBvcHRpb25zOiBQb2xsT3B0aW9uW10gPSBbXTtcblxuICBwcm90ZWN0ZWQgc3RhdGVTdG9yZVNlbGVjdG9yKFxuICAgIHBvbGw6IFBvbGwsXG4gICAgbWFya0ZvckNoZWNrOiAoKSA9PiB2b2lkXG4gICk6ICgpID0+IHZvaWQge1xuICAgIGNvbnN0IHVuc3Vic2NyaWJlID0gcG9sbC5zdGF0ZS5zdWJzY3JpYmVXaXRoU2VsZWN0b3IoXG4gICAgICAoc3RhdGUpID0+ICh7XG4gICAgICAgIG9wdGlvbnM6IHN0YXRlLm9wdGlvbnMsXG4gICAgICB9KSxcbiAgICAgIChzdGF0ZSkgPT4ge1xuICAgICAgICB0aGlzLm9wdGlvbnMgPSBzdGF0ZS5vcHRpb25zO1xuICAgICAgICBtYXJrRm9yQ2hlY2soKTtcbiAgICAgIH1cbiAgICApO1xuXG4gICAgcmV0dXJuIHVuc3Vic2NyaWJlO1xuICB9XG5cbiAgdHJhY2tCeU9wdGlvbklkKF86IG51bWJlciwgb3B0aW9uOiBQb2xsT3B0aW9uKSB7XG4gICAgcmV0dXJuIG9wdGlvbi5pZDtcbiAgfVxufVxuIiwiPGRpdlxuICBjbGFzcz1cInN0ci1jaGF0X19wb2xsLW9wdGlvbi1saXN0XCJcbiAgW2NsYXNzLnN0ci1jaGF0X19wb2xsLW9wdGlvbi1saXN0LS1mdWxsXT1cIlxuICAgICFtYXhPcHRpb25zRGlzcGxheWVkIHx8IG1heE9wdGlvbnNEaXNwbGF5ZWQgPT09IG9wdGlvbnMubGVuZ3RoXG4gIFwiXG4+XG4gIDxuZy1jb250YWluZXJcbiAgICAqbmdGb3I9XCJcbiAgICAgIGxldCBvcHRpb24gb2Ygb3B0aW9ucyB8IHNsaWNlIDogMCA6IG1heE9wdGlvbnNEaXNwbGF5ZWQ7XG4gICAgICB0cmFja0J5OiB0cmFja0J5T3B0aW9uSWRcbiAgICBcIlxuICA+XG4gICAgPHN0cmVhbS1wb2xsLW9wdGlvbi1zZWxlY3RvclxuICAgICAgW29wdGlvbl09XCJvcHRpb25cIlxuICAgICAgW21lc3NhZ2VJZF09XCJtZXNzYWdlSWRcIlxuICAgICAgW3BvbGxJZF09XCJwb2xsSWRcIlxuICAgIC8+XG4gIDwvbmctY29udGFpbmVyPlxuPC9kaXY+XG4iXX0=
|
|
@@ -21,11 +21,11 @@ export class PollPreviewComponent extends BasePollComponent {
|
|
|
21
21
|
});
|
|
22
22
|
return unsubscribe;
|
|
23
23
|
}
|
|
24
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PollPreviewComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
25
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: PollPreviewComponent, selector: "stream-poll-preview", usesInheritance: true, ngImport: i0, template: "<div\n class=\"str-chat__quoted-poll-preview\"\n [class.str-chat__quoted-poll-preview--closed]=\"isClosed\"\n>\n <div class=\"str-chat__quoted-poll-preview__icon\">\uD83D\uDCCA</div>\n <div class=\"str-chat__quoted-poll-preview__name\">{{ name }}</div>\n</div>\n", changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
24
26
|
}
|
|
25
|
-
|
|
26
|
-
PollPreviewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.4", type: PollPreviewComponent, selector: "stream-poll-preview", usesInheritance: true, ngImport: i0, template: "<div\n class=\"str-chat__quoted-poll-preview\"\n [class.str-chat__quoted-poll-preview--closed]=\"isClosed\"\n>\n <div class=\"str-chat__quoted-poll-preview__icon\">\uD83D\uDCCA</div>\n <div class=\"str-chat__quoted-poll-preview__name\">{{ name }}</div>\n</div>\n", changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
27
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: PollPreviewComponent, decorators: [{
|
|
27
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PollPreviewComponent, decorators: [{
|
|
28
28
|
type: Component,
|
|
29
29
|
args: [{ selector: 'stream-poll-preview', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n class=\"str-chat__quoted-poll-preview\"\n [class.str-chat__quoted-poll-preview--closed]=\"isClosed\"\n>\n <div class=\"str-chat__quoted-poll-preview__icon\">\uD83D\uDCCA</div>\n <div class=\"str-chat__quoted-poll-preview__name\">{{ name }}</div>\n</div>\n" }]
|
|
30
30
|
}] });
|
|
31
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9sbC1wcmV2aWV3LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3N0cmVhbS1jaGF0LWFuZ3VsYXIvc3JjL2xpYi9wb2xscy9wb2xsLXByZXZpZXcvcG9sbC1wcmV2aWV3LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3N0cmVhbS1jaGF0LWFuZ3VsYXIvc3JjL2xpYi9wb2xscy9wb2xsLXByZXZpZXcvcG9sbC1wcmV2aWV3LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbkUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7O0FBRzNEOztHQUVHO0FBT0gsTUFBTSxPQUFPLG9CQUFxQixTQUFRLGlCQUFpQjtJQU4zRDs7UUFPRSxTQUFJLEdBQUcsRUFBRSxDQUFDO1FBQ1YsYUFBUSxHQUFHLEtBQUssQ0FBQztLQW9CbEI7SUFsQlcsa0JBQWtCLENBQzFCLElBQVUsRUFDVixZQUF3QjtRQUV4QixNQUFNLFdBQVcsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLHFCQUFxQixDQUNsRCxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztZQUNWLElBQUksRUFBRSxLQUFLLENBQUMsSUFBSTtZQUNoQixTQUFTLEVBQUUsS0FBSyxDQUFDLFNBQVM7U0FDM0IsQ0FBQyxFQUNGLENBQUMsS0FBSyxFQUFFLEVBQUU7WUFDUixJQUFJLENBQUMsSUFBSSxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUM7WUFDdkIsSUFBSSxDQUFDLFFBQVEsR0FBRyxLQUFLLENBQUMsU0FBUyxJQUFJLEtBQUssQ0FBQztZQUN6QyxZQUFZLEVBQUUsQ0FBQztRQUNqQixDQUFDLENBQ0YsQ0FBQztRQUVGLE9BQU8sV0FBVyxDQUFDO0lBQ3JCLENBQUM7K0dBckJVLG9CQUFvQjttR0FBcEIsb0JBQW9CLGtGQ2JqQyw0UUFPQTs7NEZETWEsb0JBQW9CO2tCQU5oQyxTQUFTOytCQUNFLHFCQUFxQixtQkFHZCx1QkFBdUIsQ0FBQyxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQmFzZVBvbGxDb21wb25lbnQgfSBmcm9tICcuLi9iYXNlLXBvbGwuY29tcG9uZW50JztcbmltcG9ydCB7IFBvbGwgfSBmcm9tICdzdHJlYW0tY2hhdCc7XG5cbi8qKlxuICpcbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnc3RyZWFtLXBvbGwtcHJldmlldycsXG4gIHRlbXBsYXRlVXJsOiAnLi9wb2xsLXByZXZpZXcuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZXM6IFtdLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgUG9sbFByZXZpZXdDb21wb25lbnQgZXh0ZW5kcyBCYXNlUG9sbENvbXBvbmVudCB7XG4gIG5hbWUgPSAnJztcbiAgaXNDbG9zZWQgPSBmYWxzZTtcblxuICBwcm90ZWN0ZWQgc3RhdGVTdG9yZVNlbGVjdG9yKFxuICAgIHBvbGw6IFBvbGwsXG4gICAgbWFya0ZvckNoZWNrOiAoKSA9PiB2b2lkXG4gICk6ICgpID0+IHZvaWQge1xuICAgIGNvbnN0IHVuc3Vic2NyaWJlID0gcG9sbC5zdGF0ZS5zdWJzY3JpYmVXaXRoU2VsZWN0b3IoXG4gICAgICAoc3RhdGUpID0+ICh7XG4gICAgICAgIG5hbWU6IHN0YXRlLm5hbWUsXG4gICAgICAgIGlzX2Nsb3NlZDogc3RhdGUuaXNfY2xvc2VkLFxuICAgICAgfSksXG4gICAgICAoc3RhdGUpID0+IHtcbiAgICAgICAgdGhpcy5uYW1lID0gc3RhdGUubmFtZTtcbiAgICAgICAgdGhpcy5pc0Nsb3NlZCA9IHN0YXRlLmlzX2Nsb3NlZCA/PyBmYWxzZTtcbiAgICAgICAgbWFya0ZvckNoZWNrKCk7XG4gICAgICB9XG4gICAgKTtcblxuICAgIHJldHVybiB1bnN1YnNjcmliZTtcbiAgfVxufVxuIiwiPGRpdlxuICBjbGFzcz1cInN0ci1jaGF0X19xdW90ZWQtcG9sbC1wcmV2aWV3XCJcbiAgW2NsYXNzLnN0ci1jaGF0X19xdW90ZWQtcG9sbC1wcmV2aWV3LS1jbG9zZWRdPVwiaXNDbG9zZWRcIlxuPlxuICA8ZGl2IGNsYXNzPVwic3RyLWNoYXRfX3F1b3RlZC1wb2xsLXByZXZpZXdfX2ljb25cIj7wn5OKPC9kaXY+XG4gIDxkaXYgY2xhc3M9XCJzdHItY2hhdF9fcXVvdGVkLXBvbGwtcHJldmlld19fbmFtZVwiPnt7IG5hbWUgfX08L2Rpdj5cbjwvZGl2PlxuIl19
|
|
@@ -21,47 +21,47 @@ import { ReactiveFormsModule } from '@angular/forms';
|
|
|
21
21
|
import { PollPreviewComponent } from './poll-preview/poll-preview.component';
|
|
22
22
|
import * as i0 from "@angular/core";
|
|
23
23
|
export class StreamPollsModule {
|
|
24
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: StreamPollsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
25
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.12", ngImport: i0, type: StreamPollsModule, declarations: [PollComposerComponent,
|
|
26
|
+
PollComponent,
|
|
27
|
+
PollHeaderComponent,
|
|
28
|
+
PollOptionsListComponent,
|
|
29
|
+
PollOptionSelectorComponent,
|
|
30
|
+
PollActionsComponent,
|
|
31
|
+
PollResultsListComponent,
|
|
32
|
+
PollVoteResultsListComponent,
|
|
33
|
+
PollVoteComponent,
|
|
34
|
+
PollAnswersListComponent,
|
|
35
|
+
UpsertAnswerComponent,
|
|
36
|
+
AddOptionComponent,
|
|
37
|
+
PollPreviewComponent], imports: [CommonModule,
|
|
38
|
+
TranslateModule,
|
|
39
|
+
StreamAvatarModule,
|
|
40
|
+
StreamModalModule,
|
|
41
|
+
StreamNotificationModule,
|
|
42
|
+
StreamPaginatedListModule,
|
|
43
|
+
ReactiveFormsModule], exports: [PollComposerComponent,
|
|
44
|
+
PollComponent,
|
|
45
|
+
PollHeaderComponent,
|
|
46
|
+
PollOptionsListComponent,
|
|
47
|
+
PollOptionSelectorComponent,
|
|
48
|
+
PollActionsComponent,
|
|
49
|
+
PollResultsListComponent,
|
|
50
|
+
PollVoteResultsListComponent,
|
|
51
|
+
PollVoteComponent,
|
|
52
|
+
PollAnswersListComponent,
|
|
53
|
+
UpsertAnswerComponent,
|
|
54
|
+
AddOptionComponent,
|
|
55
|
+
PollPreviewComponent] }); }
|
|
56
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: StreamPollsModule, imports: [CommonModule,
|
|
57
|
+
TranslateModule,
|
|
58
|
+
StreamAvatarModule,
|
|
59
|
+
StreamModalModule,
|
|
60
|
+
StreamNotificationModule,
|
|
61
|
+
StreamPaginatedListModule,
|
|
62
|
+
ReactiveFormsModule] }); }
|
|
24
63
|
}
|
|
25
|
-
|
|
26
|
-
StreamPollsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.0.4", ngImport: i0, type: StreamPollsModule, declarations: [PollComposerComponent,
|
|
27
|
-
PollComponent,
|
|
28
|
-
PollHeaderComponent,
|
|
29
|
-
PollOptionsListComponent,
|
|
30
|
-
PollOptionSelectorComponent,
|
|
31
|
-
PollActionsComponent,
|
|
32
|
-
PollResultsListComponent,
|
|
33
|
-
PollVoteResultsListComponent,
|
|
34
|
-
PollVoteComponent,
|
|
35
|
-
PollAnswersListComponent,
|
|
36
|
-
UpsertAnswerComponent,
|
|
37
|
-
AddOptionComponent,
|
|
38
|
-
PollPreviewComponent], imports: [CommonModule,
|
|
39
|
-
TranslateModule,
|
|
40
|
-
StreamAvatarModule,
|
|
41
|
-
StreamModalModule,
|
|
42
|
-
StreamNotificationModule,
|
|
43
|
-
StreamPaginatedListModule,
|
|
44
|
-
ReactiveFormsModule], exports: [PollComposerComponent,
|
|
45
|
-
PollComponent,
|
|
46
|
-
PollHeaderComponent,
|
|
47
|
-
PollOptionsListComponent,
|
|
48
|
-
PollOptionSelectorComponent,
|
|
49
|
-
PollActionsComponent,
|
|
50
|
-
PollResultsListComponent,
|
|
51
|
-
PollVoteResultsListComponent,
|
|
52
|
-
PollVoteComponent,
|
|
53
|
-
PollAnswersListComponent,
|
|
54
|
-
UpsertAnswerComponent,
|
|
55
|
-
AddOptionComponent,
|
|
56
|
-
PollPreviewComponent] });
|
|
57
|
-
StreamPollsModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: StreamPollsModule, imports: [CommonModule,
|
|
58
|
-
TranslateModule,
|
|
59
|
-
StreamAvatarModule,
|
|
60
|
-
StreamModalModule,
|
|
61
|
-
StreamNotificationModule,
|
|
62
|
-
StreamPaginatedListModule,
|
|
63
|
-
ReactiveFormsModule] });
|
|
64
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: StreamPollsModule, decorators: [{
|
|
64
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: StreamPollsModule, decorators: [{
|
|
65
65
|
type: NgModule,
|
|
66
66
|
args: [{
|
|
67
67
|
declarations: [
|
|
@@ -105,4 +105,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImpor
|
|
|
105
105
|
],
|
|
106
106
|
}]
|
|
107
107
|
}] });
|
|
108
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
108
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RyZWFtLXBvbGxzLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3N0cmVhbS1jaGF0LWFuZ3VsYXIvc3JjL2xpYi9wb2xscy9zdHJlYW0tcG9sbHMubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHlDQUF5QyxDQUFDO0FBQ2hGLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUN0RCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUMxRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDdEQsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0saURBQWlELENBQUM7QUFDM0YsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sdURBQXVELENBQUM7QUFDcEcsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDN0QsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDN0UsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDakUsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0saURBQWlELENBQUM7QUFDM0YsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sZ0RBQWdELENBQUM7QUFDM0YsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sMkRBQTJELENBQUM7QUFDOUYsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sOERBQThELENBQUM7QUFDeEcsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0scUZBQXFGLENBQUM7QUFDbkksT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sMkVBQTJFLENBQUM7QUFDckgsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sc0RBQXNELENBQUM7QUFDN0YsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sZ0RBQWdELENBQUM7QUFDcEYsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDckQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7O0FBMkM3RSxNQUFNLE9BQU8saUJBQWlCOytHQUFqQixpQkFBaUI7Z0hBQWpCLGlCQUFpQixpQkF2QzFCLHFCQUFxQjtZQUNyQixhQUFhO1lBQ2IsbUJBQW1CO1lBQ25CLHdCQUF3QjtZQUN4QiwyQkFBMkI7WUFDM0Isb0JBQW9CO1lBQ3BCLHdCQUF3QjtZQUN4Qiw0QkFBNEI7WUFDNUIsaUJBQWlCO1lBQ2pCLHdCQUF3QjtZQUN4QixxQkFBcUI7WUFDckIsa0JBQWtCO1lBQ2xCLG9CQUFvQixhQUdwQixZQUFZO1lBQ1osZUFBZTtZQUNmLGtCQUFrQjtZQUNsQixpQkFBaUI7WUFDakIsd0JBQXdCO1lBQ3hCLHlCQUF5QjtZQUN6QixtQkFBbUIsYUFHbkIscUJBQXFCO1lBQ3JCLGFBQWE7WUFDYixtQkFBbUI7WUFDbkIsd0JBQXdCO1lBQ3hCLDJCQUEyQjtZQUMzQixvQkFBb0I7WUFDcEIsd0JBQXdCO1lBQ3hCLDRCQUE0QjtZQUM1QixpQkFBaUI7WUFDakIsd0JBQXdCO1lBQ3hCLHFCQUFxQjtZQUNyQixrQkFBa0I7WUFDbEIsb0JBQW9CO2dIQUdYLGlCQUFpQixZQXhCMUIsWUFBWTtZQUNaLGVBQWU7WUFDZixrQkFBa0I7WUFDbEIsaUJBQWlCO1lBQ2pCLHdCQUF3QjtZQUN4Qix5QkFBeUI7WUFDekIsbUJBQW1COzs0RkFrQlYsaUJBQWlCO2tCQXpDN0IsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUU7d0JBQ1oscUJBQXFCO3dCQUNyQixhQUFhO3dCQUNiLG1CQUFtQjt3QkFDbkIsd0JBQXdCO3dCQUN4QiwyQkFBMkI7d0JBQzNCLG9CQUFvQjt3QkFDcEIsd0JBQXdCO3dCQUN4Qiw0QkFBNEI7d0JBQzVCLGlCQUFpQjt3QkFDakIsd0JBQXdCO3dCQUN4QixxQkFBcUI7d0JBQ3JCLGtCQUFrQjt3QkFDbEIsb0JBQW9CO3FCQUNyQjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixlQUFlO3dCQUNmLGtCQUFrQjt3QkFDbEIsaUJBQWlCO3dCQUNqQix3QkFBd0I7d0JBQ3hCLHlCQUF5Qjt3QkFDekIsbUJBQW1CO3FCQUNwQjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AscUJBQXFCO3dCQUNyQixhQUFhO3dCQUNiLG1CQUFtQjt3QkFDbkIsd0JBQXdCO3dCQUN4QiwyQkFBMkI7d0JBQzNCLG9CQUFvQjt3QkFDcEIsd0JBQXdCO3dCQUN4Qiw0QkFBNEI7d0JBQzVCLGlCQUFpQjt3QkFDakIsd0JBQXdCO3dCQUN4QixxQkFBcUI7d0JBQ3JCLGtCQUFrQjt3QkFDbEIsb0JBQW9CO3FCQUNyQjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgUG9sbENvbXBvc2VyQ29tcG9uZW50IH0gZnJvbSAnLi9wb2xsLWNvbXBvc2VyL3BvbGwtY29tcG9zZXIuY29tcG9uZW50JztcbmltcG9ydCB7IFBvbGxDb21wb25lbnQgfSBmcm9tICcuL3BvbGwvcG9sbC5jb21wb25lbnQnO1xuaW1wb3J0IHsgUG9sbEhlYWRlckNvbXBvbmVudCB9IGZyb20gJy4vcG9sbC1oZWFkZXIvcG9sbC1oZWFkZXIuY29tcG9uZW50JztcbmltcG9ydCB7IFRyYW5zbGF0ZU1vZHVsZSB9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnO1xuaW1wb3J0IHsgUG9sbE9wdGlvbnNMaXN0Q29tcG9uZW50IH0gZnJvbSAnLi9wb2xsLW9wdGlvbnMtbGlzdC9wb2xsLW9wdGlvbnMtbGlzdC5jb21wb25lbnQnO1xuaW1wb3J0IHsgUG9sbE9wdGlvblNlbGVjdG9yQ29tcG9uZW50IH0gZnJvbSAnLi9wb2xsLW9wdGlvbi1zZWxlY3Rvci9wb2xsLW9wdGlvbi1zZWxlY3Rvci5jb21wb25lbnQnO1xuaW1wb3J0IHsgU3RyZWFtQXZhdGFyTW9kdWxlIH0gZnJvbSAnLi4vc3RyZWFtLWF2YXRhci5tb2R1bGUnO1xuaW1wb3J0IHsgUG9sbEFjdGlvbnNDb21wb25lbnQgfSBmcm9tICcuL3BvbGwtYWN0aW9ucy9wb2xsLWFjdGlvbnMuY29tcG9uZW50JztcbmltcG9ydCB7IFN0cmVhbU1vZGFsTW9kdWxlIH0gZnJvbSAnLi4vbW9kYWwvc3RyZWFtLW1vZGFsLm1vZHVsZSc7XG5pbXBvcnQgeyBTdHJlYW1Ob3RpZmljYXRpb25Nb2R1bGUgfSBmcm9tICcuLi9ub3RpZmljYXRpb24tbGlzdC9zdHJlYW0tbm90aWZpY2F0aW9uLm1vZHVsZSc7XG5pbXBvcnQgeyBTdHJlYW1QYWdpbmF0ZWRMaXN0TW9kdWxlIH0gZnJvbSAnLi4vcGFnaW5hdGVkLWxpc3Qvc3RyZWFtLXBhZ2luYXRlZC1saXN0Lm1vZHVsZSc7XG5pbXBvcnQgeyBQb2xsVm90ZUNvbXBvbmVudCB9IGZyb20gJy4vcG9sbC1hY3Rpb25zL3BvbGwtcmVzdWx0cy9wb2xsLXZvdGUvcG9sbC12b3RlLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBQb2xsQW5zd2Vyc0xpc3RDb21wb25lbnQgfSBmcm9tICcuL3BvbGwtYWN0aW9ucy9wb2xsLWFuc3dlcnMtbGlzdC9wb2xsLWFuc3dlcnMtbGlzdC5jb21wb25lbnQnO1xuaW1wb3J0IHsgUG9sbFZvdGVSZXN1bHRzTGlzdENvbXBvbmVudCB9IGZyb20gJy4vcG9sbC1hY3Rpb25zL3BvbGwtcmVzdWx0cy9wb2xsLXZvdGUtcmVzdWx0cy1saXN0L3BvbGwtdm90ZS1yZXN1bHRzLWxpc3QuY29tcG9uZW50JztcbmltcG9ydCB7IFBvbGxSZXN1bHRzTGlzdENvbXBvbmVudCB9IGZyb20gJy4vcG9sbC1hY3Rpb25zL3BvbGwtcmVzdWx0cy9wb2xsLXJlc3VsdHMtbGlzdC9wb2xsLXJlc3VsdHMtbGlzdC5jb21wb25lbnQnO1xuaW1wb3J0IHsgVXBzZXJ0QW5zd2VyQ29tcG9uZW50IH0gZnJvbSAnLi9wb2xsLWFjdGlvbnMvdXBzZXJ0LWFuc3dlci91cHNlcnQtYW5zd2VyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBBZGRPcHRpb25Db21wb25lbnQgfSBmcm9tICcuL3BvbGwtYWN0aW9ucy9hZGQtb3B0aW9uL2FkZC1vcHRpb24uY29tcG9uZW50JztcbmltcG9ydCB7IFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBQb2xsUHJldmlld0NvbXBvbmVudCB9IGZyb20gJy4vcG9sbC1wcmV2aWV3L3BvbGwtcHJldmlldy5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBQb2xsQ29tcG9zZXJDb21wb25lbnQsXG4gICAgUG9sbENvbXBvbmVudCxcbiAgICBQb2xsSGVhZGVyQ29tcG9uZW50LFxuICAgIFBvbGxPcHRpb25zTGlzdENvbXBvbmVudCxcbiAgICBQb2xsT3B0aW9uU2VsZWN0b3JDb21wb25lbnQsXG4gICAgUG9sbEFjdGlvbnNDb21wb25lbnQsXG4gICAgUG9sbFJlc3VsdHNMaXN0Q29tcG9uZW50LFxuICAgIFBvbGxWb3RlUmVzdWx0c0xpc3RDb21wb25lbnQsXG4gICAgUG9sbFZvdGVDb21wb25lbnQsXG4gICAgUG9sbEFuc3dlcnNMaXN0Q29tcG9uZW50LFxuICAgIFVwc2VydEFuc3dlckNvbXBvbmVudCxcbiAgICBBZGRPcHRpb25Db21wb25lbnQsXG4gICAgUG9sbFByZXZpZXdDb21wb25lbnQsXG4gIF0sXG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgVHJhbnNsYXRlTW9kdWxlLFxuICAgIFN0cmVhbUF2YXRhck1vZHVsZSxcbiAgICBTdHJlYW1Nb2RhbE1vZHVsZSxcbiAgICBTdHJlYW1Ob3RpZmljYXRpb25Nb2R1bGUsXG4gICAgU3RyZWFtUGFnaW5hdGVkTGlzdE1vZHVsZSxcbiAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlLFxuICBdLFxuICBleHBvcnRzOiBbXG4gICAgUG9sbENvbXBvc2VyQ29tcG9uZW50LFxuICAgIFBvbGxDb21wb25lbnQsXG4gICAgUG9sbEhlYWRlckNvbXBvbmVudCxcbiAgICBQb2xsT3B0aW9uc0xpc3RDb21wb25lbnQsXG4gICAgUG9sbE9wdGlvblNlbGVjdG9yQ29tcG9uZW50LFxuICAgIFBvbGxBY3Rpb25zQ29tcG9uZW50LFxuICAgIFBvbGxSZXN1bHRzTGlzdENvbXBvbmVudCxcbiAgICBQb2xsVm90ZVJlc3VsdHNMaXN0Q29tcG9uZW50LFxuICAgIFBvbGxWb3RlQ29tcG9uZW50LFxuICAgIFBvbGxBbnN3ZXJzTGlzdENvbXBvbmVudCxcbiAgICBVcHNlcnRBbnN3ZXJDb21wb25lbnQsXG4gICAgQWRkT3B0aW9uQ29tcG9uZW50LFxuICAgIFBvbGxQcmV2aWV3Q29tcG9uZW50LFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBTdHJlYW1Qb2xsc01vZHVsZSB7fVxuIl19
|