geonetwork-ui 2.6.0-dev.ceb4be4c1 → 2.6.0-dev.d1dbf336f
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/libs/api/metadata-converter/src/lib/iso19115-3/read-parts.mjs +8 -4
- package/esm2022/libs/api/metadata-converter/src/lib/iso19115-3/write-parts.mjs +5 -2
- package/esm2022/libs/api/metadata-converter/src/lib/iso19139/read-parts.mjs +3 -3
- package/esm2022/libs/api/metadata-converter/src/lib/iso19139/write-parts.mjs +2 -2
- package/esm2022/libs/api/repository/src/lib/gn4/gn4-repository.mjs +14 -5
- package/esm2022/libs/common/domain/src/lib/repository/records-repository.interface.mjs +1 -1
- package/esm2022/libs/feature/editor/src/lib/components/multilingual-panel/multilingual-panel.component.mjs +266 -11
- package/esm2022/libs/ui/search/src/index.mjs +2 -1
- package/esm2022/libs/ui/search/src/lib/results-table/action-menu/action-menu.component.mjs +19 -12
- package/esm2022/libs/ui/search/src/lib/results-table/results-table.component.mjs +3 -3
- package/esm2022/libs/ui/search/src/lib/ui-search.module.mjs +10 -4
- package/esm2022/libs/util/i18n/src/lib/i18n.constants.mjs +42 -1
- package/esm2022/libs/util/i18n/src/lib/language-codes.mjs +24 -2
- package/esm2022/translations/de.json +28 -4
- package/esm2022/translations/en.json +28 -4
- package/esm2022/translations/es.json +27 -3
- package/esm2022/translations/fr.json +28 -4
- package/esm2022/translations/it.json +27 -3
- package/esm2022/translations/nl.json +27 -3
- package/esm2022/translations/pt.json +27 -3
- package/fesm2022/geonetwork-ui.mjs +604 -107
- package/fesm2022/geonetwork-ui.mjs.map +1 -1
- package/libs/api/metadata-converter/src/lib/iso19115-3/read-parts.d.ts +1 -0
- package/libs/api/metadata-converter/src/lib/iso19115-3/read-parts.d.ts.map +1 -1
- package/libs/api/metadata-converter/src/lib/iso19115-3/write-parts.d.ts.map +1 -1
- package/libs/api/metadata-converter/src/lib/iso19139/read-parts.d.ts.map +1 -1
- package/libs/api/metadata-converter/src/lib/iso19139/write-parts.d.ts.map +1 -1
- package/libs/api/repository/src/lib/gn4/gn4-repository.d.ts +4 -2
- package/libs/api/repository/src/lib/gn4/gn4-repository.d.ts.map +1 -1
- package/libs/common/domain/src/lib/repository/records-repository.interface.d.ts +1 -0
- package/libs/common/domain/src/lib/repository/records-repository.interface.d.ts.map +1 -1
- package/libs/feature/editor/src/lib/components/multilingual-panel/multilingual-panel.component.d.ts +48 -3
- package/libs/feature/editor/src/lib/components/multilingual-panel/multilingual-panel.component.d.ts.map +1 -1
- package/libs/ui/search/src/index.d.ts +1 -0
- package/libs/ui/search/src/index.d.ts.map +1 -1
- package/libs/ui/search/src/lib/results-table/action-menu/action-menu.component.d.ts +3 -3
- package/libs/ui/search/src/lib/results-table/action-menu/action-menu.component.d.ts.map +1 -1
- package/libs/ui/search/src/lib/ui-search.module.d.ts +2 -1
- package/libs/ui/search/src/lib/ui-search.module.d.ts.map +1 -1
- package/libs/util/i18n/src/lib/i18n.constants.d.ts +1 -0
- package/libs/util/i18n/src/lib/i18n.constants.d.ts.map +1 -1
- package/libs/util/i18n/src/lib/language-codes.d.ts +23 -1
- package/libs/util/i18n/src/lib/language-codes.d.ts.map +1 -1
- package/package.json +1 -1
- package/src/libs/api/metadata-converter/src/lib/fixtures/geocat-ch.records.ts +1 -1
- package/src/libs/api/metadata-converter/src/lib/iso19115-3/read-parts.ts +13 -3
- package/src/libs/api/metadata-converter/src/lib/iso19115-3/write-parts.ts +5 -1
- package/src/libs/api/metadata-converter/src/lib/iso19139/read-parts.ts +6 -3
- package/src/libs/api/metadata-converter/src/lib/iso19139/write-parts.ts +4 -1
- package/src/libs/api/repository/src/lib/gn4/gn4-repository.ts +16 -2
- package/src/libs/common/domain/src/lib/repository/records-repository.interface.ts +1 -0
- package/src/libs/feature/editor/src/lib/components/multilingual-panel/multilingual-panel.component.html +117 -11
- package/src/libs/feature/editor/src/lib/components/multilingual-panel/multilingual-panel.component.ts +316 -6
- package/src/libs/ui/search/src/index.ts +1 -0
- package/src/libs/ui/search/src/lib/results-table/action-menu/action-menu.component.html +11 -3
- package/src/libs/ui/search/src/lib/results-table/action-menu/action-menu.component.ts +14 -11
- package/src/libs/ui/search/src/lib/results-table/results-table.component.html +1 -1
- package/src/libs/ui/search/src/lib/ui-search.module.ts +3 -0
- package/src/libs/util/i18n/src/lib/i18n.constants.ts +42 -0
- package/src/libs/util/i18n/src/lib/language-codes.ts +23 -1
- package/tailwind.base.css +1 -1
- package/translations/de.json +28 -4
- package/translations/en.json +28 -4
- package/translations/es.json +27 -3
- package/translations/fr.json +28 -4
- package/translations/it.json +27 -3
- package/translations/nl.json +27 -3
- package/translations/pt.json +27 -3
- package/translations/sk.json +27 -3
|
@@ -1,18 +1,273 @@
|
|
|
1
|
-
import { Component } from '@angular/core';
|
|
1
|
+
import { ChangeDetectorRef, Component, ElementRef, Input, QueryList, ViewChildren, ViewContainerRef, } from '@angular/core';
|
|
2
2
|
import { CommonModule } from '@angular/common';
|
|
3
|
-
import { CheckToggleComponent } from '../../../../../../../libs/ui/inputs/src';
|
|
4
|
-
import { TranslateModule } from '@ngx-translate/core';
|
|
3
|
+
import { ButtonComponent, CheckToggleComponent } from '../../../../../../../libs/ui/inputs/src';
|
|
4
|
+
import { TranslateModule, TranslateService } from '@ngx-translate/core';
|
|
5
|
+
import { NgIconComponent, provideIcons, provideNgIconsConfig, } from '@ng-icons/core';
|
|
6
|
+
import { iconoirCheckCircle, iconoirCircle, iconoirSettings, } from '@ng-icons/iconoir';
|
|
7
|
+
import { matMoreHorizOutline } from '@ng-icons/material-icons/outline';
|
|
8
|
+
import { EditorFacade } from '../../+state/editor.facade';
|
|
9
|
+
import { ConfirmationDialogComponent } from '../../../../../../../libs/ui/elements/src';
|
|
10
|
+
import { MatDialog } from '@angular/material/dialog';
|
|
11
|
+
import { RecordsRepositoryInterface } from '../../../../../../../libs/common/domain/src/lib/repository/records-repository.interface';
|
|
12
|
+
import { map, Subscription } from 'rxjs';
|
|
13
|
+
import { Overlay } from '@angular/cdk/overlay';
|
|
14
|
+
import { TemplatePortal } from '@angular/cdk/portal';
|
|
15
|
+
import { ActionMenuComponent } from '../../../../../../../libs/ui/search/src';
|
|
5
16
|
import * as i0 from "@angular/core";
|
|
6
|
-
import * as i1 from "
|
|
17
|
+
import * as i1 from "../../+state/editor.facade";
|
|
18
|
+
import * as i2 from "@angular/material/dialog";
|
|
19
|
+
import * as i3 from "@ngx-translate/core";
|
|
20
|
+
import * as i4 from "../../../../../../../libs/common/domain/src/lib/repository/records-repository.interface";
|
|
21
|
+
import * as i5 from "@angular/cdk/overlay";
|
|
22
|
+
import * as i6 from "@angular/common";
|
|
23
|
+
const extraFlagMap = {
|
|
24
|
+
ar: 'arab',
|
|
25
|
+
en: 'gb',
|
|
26
|
+
ko: 'kr',
|
|
27
|
+
cs: 'cz',
|
|
28
|
+
zh: 'cn',
|
|
29
|
+
ca: 'es-ct',
|
|
30
|
+
rm: 'ch',
|
|
31
|
+
da: 'dk',
|
|
32
|
+
sv: 'se',
|
|
33
|
+
cy: 'gb-wls',
|
|
34
|
+
hy: 'am',
|
|
35
|
+
ka: 'ge',
|
|
36
|
+
uk: 'ua',
|
|
37
|
+
};
|
|
7
38
|
export class MultilingualPanelComponent {
|
|
8
|
-
|
|
9
|
-
this.
|
|
39
|
+
set record(value) {
|
|
40
|
+
this._record = value;
|
|
41
|
+
this.isMultilingual = value.otherLanguages.length > 0;
|
|
42
|
+
this.editTranslations = false;
|
|
43
|
+
this.recordLanguages = [...value.otherLanguages, value.defaultLanguage];
|
|
44
|
+
this.selectedLanguages = this.recordLanguages;
|
|
45
|
+
this.formLanguage = value.defaultLanguage;
|
|
10
46
|
}
|
|
11
|
-
|
|
12
|
-
|
|
47
|
+
constructor(facade, dialog, translateService, recordsRepository, overlay, viewContainerRef, cdr) {
|
|
48
|
+
this.facade = facade;
|
|
49
|
+
this.dialog = dialog;
|
|
50
|
+
this.translateService = translateService;
|
|
51
|
+
this.recordsRepository = recordsRepository;
|
|
52
|
+
this.overlay = overlay;
|
|
53
|
+
this.viewContainerRef = viewContainerRef;
|
|
54
|
+
this.cdr = cdr;
|
|
55
|
+
this.selectedLanguages = [];
|
|
56
|
+
this.recordLanguages = [];
|
|
57
|
+
this.formLanguage = '';
|
|
58
|
+
this.isActionMenuOpen = false;
|
|
59
|
+
this.subscription = new Subscription();
|
|
60
|
+
this.supportedLanguages$ = this.recordsRepository
|
|
61
|
+
.getApplicationLanguages()
|
|
62
|
+
.pipe(map((languages) => this.sortLanguages(languages)));
|
|
63
|
+
}
|
|
64
|
+
ngOnDestroy() {
|
|
65
|
+
this.subscription.unsubscribe();
|
|
66
|
+
}
|
|
67
|
+
sortLanguages(languages) {
|
|
68
|
+
return languages
|
|
69
|
+
.map((lang) => {
|
|
70
|
+
const label = this.translateService.instant('language.' + lang);
|
|
71
|
+
const isTranslated = label !== 'language.' + lang;
|
|
72
|
+
return {
|
|
73
|
+
lang,
|
|
74
|
+
label,
|
|
75
|
+
isTranslated,
|
|
76
|
+
};
|
|
77
|
+
})
|
|
78
|
+
.sort((a, b) => {
|
|
79
|
+
if (a.isTranslated && !b.isTranslated)
|
|
80
|
+
return -1;
|
|
81
|
+
if (!a.isTranslated && b.isTranslated)
|
|
82
|
+
return 1;
|
|
83
|
+
return a.label.localeCompare(b.label);
|
|
84
|
+
})
|
|
85
|
+
.map((item) => item.lang);
|
|
86
|
+
}
|
|
87
|
+
toggleLanguageSelection() {
|
|
88
|
+
this.editTranslations = !this.editTranslations;
|
|
89
|
+
}
|
|
90
|
+
getIconClass(lang) {
|
|
91
|
+
return extraFlagMap[lang]
|
|
92
|
+
? `fi fi-${extraFlagMap[lang]} w-4 h-3`
|
|
93
|
+
: `fi fi-${lang} w-4 h-3`;
|
|
94
|
+
}
|
|
95
|
+
switchMultilingual() {
|
|
96
|
+
if (this.isMultilingual && this.selectedLanguages.length > 1) {
|
|
97
|
+
this.confirmDeleteAction();
|
|
98
|
+
}
|
|
99
|
+
else {
|
|
100
|
+
this.isMultilingual = true;
|
|
101
|
+
this.editTranslations = true;
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
getExtraClass(lang) {
|
|
105
|
+
const baseClass = 'h-[34px] w-full font-bold justify-start hover:bg-white';
|
|
106
|
+
if (this.selectedLanguages.includes(lang)) {
|
|
107
|
+
return `${baseClass} bg-white border border-black`;
|
|
108
|
+
}
|
|
109
|
+
return baseClass;
|
|
110
|
+
}
|
|
111
|
+
toggleLanguage(lang) {
|
|
112
|
+
if (this.selectedLanguages.includes(lang)) {
|
|
113
|
+
this.removeSelectedLanguage(lang);
|
|
114
|
+
}
|
|
115
|
+
else {
|
|
116
|
+
this.selectedLanguages.push(lang);
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
removeSelectedLanguage(lang) {
|
|
120
|
+
this.selectedLanguages = this.selectedLanguages.filter((language) => language !== lang);
|
|
121
|
+
}
|
|
122
|
+
validateTranslations() {
|
|
123
|
+
const equalLength = this.selectedLanguages.length === this.recordLanguages.length;
|
|
124
|
+
if (this.selectedLanguages.length < this.recordLanguages.length ||
|
|
125
|
+
(equalLength && this.selectedLanguages !== this.recordLanguages)) {
|
|
126
|
+
this.confirmDeleteAction(this.selectedLanguages);
|
|
127
|
+
}
|
|
128
|
+
else {
|
|
129
|
+
this.updateTranslations();
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
updateTranslations() {
|
|
133
|
+
this.facade.updateRecordField('otherLanguages', this.selectedLanguages.filter((lang) => lang !== this.formLanguage));
|
|
134
|
+
this.recordLanguages = this.selectedLanguages;
|
|
135
|
+
this.editTranslations = false;
|
|
136
|
+
}
|
|
137
|
+
switchFormLang(lang) {
|
|
138
|
+
// TO IMPLEMENT FURTHER
|
|
139
|
+
}
|
|
140
|
+
switchDefaultLang(lang) {
|
|
141
|
+
this.formLanguage = lang;
|
|
142
|
+
this.facade.updateRecordField('defaultLanguage', lang);
|
|
143
|
+
this.facade.updateRecordField('otherLanguages', this.selectedLanguages.filter((lang) => lang !== this.formLanguage));
|
|
144
|
+
this.closeActionMenu();
|
|
145
|
+
}
|
|
146
|
+
confirmDeleteAction(lang) {
|
|
147
|
+
const dialogRef = this.dialog.open(ConfirmationDialogComponent, {
|
|
148
|
+
data: {
|
|
149
|
+
title: this.translateService.instant('editor.record.multilingual.confirmation.title'),
|
|
150
|
+
message: this.translateService.instant('editor.record.multilingual.confirmation.message'),
|
|
151
|
+
confirmText: this.translateService.instant('editor.record.multilingual.confirmation.confirmText'),
|
|
152
|
+
cancelText: this.translateService.instant('editor.record.multilingual.confirmation.cancelText'),
|
|
153
|
+
},
|
|
154
|
+
restoreFocus: true,
|
|
155
|
+
});
|
|
156
|
+
this.subscription.add(dialogRef.afterClosed().subscribe((confirmed) => {
|
|
157
|
+
if (confirmed) {
|
|
158
|
+
if (lang) {
|
|
159
|
+
if (!Array.isArray(lang)) {
|
|
160
|
+
this.removeSelectedLanguage(lang);
|
|
161
|
+
this.closeActionMenu();
|
|
162
|
+
}
|
|
163
|
+
this.updateTranslations();
|
|
164
|
+
}
|
|
165
|
+
else {
|
|
166
|
+
this.facade.updateRecordField('otherLanguages', []);
|
|
167
|
+
this.isMultilingual = false;
|
|
168
|
+
this.selectedLanguages = [];
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
else {
|
|
172
|
+
this.isMultilingual = true;
|
|
173
|
+
this.selectedLanguages = this.recordLanguages;
|
|
174
|
+
}
|
|
175
|
+
this.editTranslations = false;
|
|
176
|
+
}));
|
|
177
|
+
}
|
|
178
|
+
isFirstUnsupported(index) {
|
|
179
|
+
const langs = this.sortLanguages(this.recordLanguages);
|
|
180
|
+
return (langs[index].length === 3 &&
|
|
181
|
+
langs.slice(0, index).every((lang) => lang.length !== 3));
|
|
182
|
+
}
|
|
183
|
+
isLangSupported(lang) {
|
|
184
|
+
return lang.length === 2;
|
|
185
|
+
}
|
|
186
|
+
getToggleTitle(lang) {
|
|
187
|
+
if (lang === this._record.defaultLanguage) {
|
|
188
|
+
return this.translateService.instant('editor.record.form.multilingual.forbidden');
|
|
189
|
+
}
|
|
190
|
+
return '';
|
|
191
|
+
}
|
|
192
|
+
openActionMenu(item, template) {
|
|
193
|
+
this.isActionMenuOpen = true;
|
|
194
|
+
const index = this.sortLanguages(this.selectedLanguages).indexOf(item);
|
|
195
|
+
const buttonElement = this.actionMenuButtons.toArray()[index];
|
|
196
|
+
const positionStrategy = this.overlay
|
|
197
|
+
.position()
|
|
198
|
+
.flexibleConnectedTo(buttonElement)
|
|
199
|
+
.withFlexibleDimensions(true)
|
|
200
|
+
.withPush(true)
|
|
201
|
+
.withPositions([
|
|
202
|
+
{
|
|
203
|
+
originX: 'end',
|
|
204
|
+
originY: 'bottom',
|
|
205
|
+
overlayX: 'end',
|
|
206
|
+
overlayY: 'top',
|
|
207
|
+
},
|
|
208
|
+
{
|
|
209
|
+
originX: 'end',
|
|
210
|
+
originY: 'top',
|
|
211
|
+
overlayX: 'end',
|
|
212
|
+
overlayY: 'bottom',
|
|
213
|
+
},
|
|
214
|
+
]);
|
|
215
|
+
this.overlayRef = this.overlay.create({
|
|
216
|
+
hasBackdrop: true,
|
|
217
|
+
backdropClass: 'cdk-overlay-transparent-backdrop',
|
|
218
|
+
positionStrategy: positionStrategy,
|
|
219
|
+
scrollStrategy: this.overlay.scrollStrategies.reposition(),
|
|
220
|
+
});
|
|
221
|
+
const portal = new TemplatePortal(template, this.viewContainerRef);
|
|
222
|
+
this.overlayRef.attach(portal);
|
|
223
|
+
this.subscription.add(this.overlayRef.backdropClick().subscribe(() => {
|
|
224
|
+
this.closeActionMenu();
|
|
225
|
+
}));
|
|
226
|
+
}
|
|
227
|
+
closeActionMenu() {
|
|
228
|
+
if (this.overlayRef) {
|
|
229
|
+
this.isActionMenuOpen = false;
|
|
230
|
+
this.overlayRef.dispose();
|
|
231
|
+
this.cdr.markForCheck();
|
|
232
|
+
}
|
|
233
|
+
}
|
|
234
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MultilingualPanelComponent, deps: [{ token: i1.EditorFacade }, { token: i2.MatDialog }, { token: i3.TranslateService }, { token: i4.RecordsRepositoryInterface }, { token: i5.Overlay }, { token: i0.ViewContainerRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
235
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: MultilingualPanelComponent, isStandalone: true, selector: "gn-ui-multilingual-panel", inputs: { record: "record" }, providers: [
|
|
236
|
+
provideIcons({
|
|
237
|
+
iconoirSettings,
|
|
238
|
+
matMoreHorizOutline,
|
|
239
|
+
iconoirCheckCircle,
|
|
240
|
+
iconoirCircle,
|
|
241
|
+
}),
|
|
242
|
+
provideNgIconsConfig({
|
|
243
|
+
size: '1.25em',
|
|
244
|
+
}),
|
|
245
|
+
], viewQueries: [{ propertyName: "actionMenuButtons", predicate: ["actionMenuButton"], descendants: true, read: ElementRef }], ngImport: i0, template: "<div\n class=\"flex flex-col h-full w-[302px] bg-neutral-100 border-l border-gray-300 py-8 px-3 gap-6 overflow-auto\"\n>\n <div class=\"flex flex-row px-2 justify-between\">\n <span class=\"text-3xl font-title text-black/80\" translate\n >editor.record.form.multilingual.title</span\n >\n <button\n [title]=\"'editor.record.form.multilingual.open' | translate\"\n (click)=\"toggleLanguageSelection()\"\n *ngIf=\"isMultilingual\"\n data-test=\"activateSelection\"\n >\n <ng-icon class=\"mt-1\" name=\"iconoirSettings\"></ng-icon>\n </button>\n </div>\n <div class=\"flex flex-col gap-2\" *ngIf=\"editTranslations || !isMultilingual\">\n <gn-ui-check-toggle\n class=\"p-2\"\n [label]=\"'editor.record.form.multilingual.enable' | translate\"\n [color]=\"'primary'\"\n [(value)]=\"isMultilingual\"\n (toggled)=\"switchMultilingual($event)\"\n ></gn-ui-check-toggle>\n <div *ngIf=\"isMultilingual\" class=\"flex flex-col gap-2\">\n <div class=\"flex flex-row justify-between border-t border-gray-300 p-3\">\n <span class=\"mt-2 text-sm text-gray-600\" translate\n >editor.record.form.multilingual.activate</span\n >\n <gn-ui-button\n extraClass=\"w-16 h-8 font-bold\"\n type=\"gray\"\n (buttonClick)=\"validateTranslations()\"\n data-test=\"validateSelection\"\n >{{ 'editor.record.form.multilingual.validate' | translate }}\n </gn-ui-button>\n </div>\n <ng-container *ngIf=\"supportedLanguages$ | async as languages\">\n <div\n class=\"flex flex-col gap-2 w-full px-2\"\n data-test=\"langAvailable\"\n *ngFor=\"let lang of languages\"\n >\n <gn-ui-button\n [extraClass]=\"getExtraClass(lang)\"\n type=\"gray\"\n (buttonClick)=\"toggleLanguage(lang)\"\n [disabled]=\"lang === _record.defaultLanguage\"\n [title]=\"getToggleTitle(lang)\"\n >\n <span [class]=\"getIconClass(lang)\"></span>\n <span class=\"ml-2\">{{ 'language.' + lang | translate }}</span>\n </gn-ui-button>\n </div>\n </ng-container>\n </div>\n </div>\n <div *ngIf=\"!editTranslations && isMultilingual\" class=\"flex flex-col gap-2\">\n <gn-ui-button\n *ngFor=\"let recordLang of sortLanguages(recordLanguages); let i = index\"\n extraClass=\"flex flex-row justify-between bg-white border border-white rounded mb-1 h-[34px] w-full\"\n [ngClass]=\"{\n 'mt-8': isFirstUnsupported(i),\n '': true,\n }\"\n (buttonClick)=\"switchFormLang(recordLang)\"\n type=\"outline\"\n data-test=\"langSwitch\"\n >\n <div class=\"flex flex-row gap-2 items-center\">\n <ng-icon\n *ngIf=\"recordLang === formLanguage\"\n class=\"text-primary mt-1\"\n name=\"iconoirCheckCircle\"\n ></ng-icon>\n <ng-icon\n *ngIf=\"recordLang !== formLanguage\"\n class=\"text-gray-800 mt-1\"\n name=\"iconoirCircle\"\n ></ng-icon>\n <span\n *ngIf=\"recordLang.length === 2\"\n [class]=\"getIconClass(recordLang) + 'mt-1'\"\n ></span>\n <span [ngClass]=\"recordLang === formLanguage ? 'text-black' : ''\">{{\n isLangSupported(recordLang)\n ? ('language.' + recordLang | translate)\n : recordLang.toUpperCase()\n }}</span>\n </div>\n <div class=\"flex flex-row gap-2 items-center\">\n <span\n *ngIf=\"recordLang === formLanguage\"\n class=\"text-xs text-base\"\n translate\n >editor.record.form.multilingual.default</span\n >\n <button\n (click)=\"\n openActionMenu(recordLang, template); $event.stopPropagation()\n \"\n cdkOverlayOrigin\n #actionMenuButton\n >\n <ng-icon class=\"pb-5\" name=\"matMoreHorizOutline\"></ng-icon>\n </button>\n <ng-template #template>\n <gn-ui-action-menu\n [canDelete]=\"recordLang !== _record.defaultLanguage\"\n page=\"record\"\n (delete)=\"confirmDeleteAction(recordLang)\"\n (closeActionMenu)=\"closeActionMenu()\"\n (switch)=\"switchDefaultLang(recordLang)\"\n >\n </gn-ui-action-menu>\n </ng-template>\n </div>\n </gn-ui-button>\n </div>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i6.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }, { kind: "component", type: CheckToggleComponent, selector: "gn-ui-check-toggle", inputs: ["title", "label", "value", "color"], outputs: ["toggled"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }, { kind: "directive", type: i3.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: ButtonComponent, selector: "gn-ui-button", inputs: ["type", "disabled", "extraClass"], outputs: ["buttonClick"] }, { kind: "component", type: NgIconComponent, selector: "ng-icon", inputs: ["name", "svg", "size", "strokeWidth", "color"] }, { kind: "component", type: ActionMenuComponent, selector: "gn-ui-action-menu", inputs: ["canDuplicate", "canDelete", "page"], outputs: ["duplicate", "delete", "closeActionMenu", "rollback", "switch"] }] }); }
|
|
13
246
|
}
|
|
14
247
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MultilingualPanelComponent, decorators: [{
|
|
15
248
|
type: Component,
|
|
16
|
-
args: [{ selector: 'gn-ui-multilingual-panel', standalone: true, imports: [
|
|
17
|
-
|
|
18
|
-
|
|
249
|
+
args: [{ selector: 'gn-ui-multilingual-panel', standalone: true, imports: [
|
|
250
|
+
CommonModule,
|
|
251
|
+
CheckToggleComponent,
|
|
252
|
+
TranslateModule,
|
|
253
|
+
ButtonComponent,
|
|
254
|
+
NgIconComponent,
|
|
255
|
+
ActionMenuComponent,
|
|
256
|
+
], providers: [
|
|
257
|
+
provideIcons({
|
|
258
|
+
iconoirSettings,
|
|
259
|
+
matMoreHorizOutline,
|
|
260
|
+
iconoirCheckCircle,
|
|
261
|
+
iconoirCircle,
|
|
262
|
+
}),
|
|
263
|
+
provideNgIconsConfig({
|
|
264
|
+
size: '1.25em',
|
|
265
|
+
}),
|
|
266
|
+
], template: "<div\n class=\"flex flex-col h-full w-[302px] bg-neutral-100 border-l border-gray-300 py-8 px-3 gap-6 overflow-auto\"\n>\n <div class=\"flex flex-row px-2 justify-between\">\n <span class=\"text-3xl font-title text-black/80\" translate\n >editor.record.form.multilingual.title</span\n >\n <button\n [title]=\"'editor.record.form.multilingual.open' | translate\"\n (click)=\"toggleLanguageSelection()\"\n *ngIf=\"isMultilingual\"\n data-test=\"activateSelection\"\n >\n <ng-icon class=\"mt-1\" name=\"iconoirSettings\"></ng-icon>\n </button>\n </div>\n <div class=\"flex flex-col gap-2\" *ngIf=\"editTranslations || !isMultilingual\">\n <gn-ui-check-toggle\n class=\"p-2\"\n [label]=\"'editor.record.form.multilingual.enable' | translate\"\n [color]=\"'primary'\"\n [(value)]=\"isMultilingual\"\n (toggled)=\"switchMultilingual($event)\"\n ></gn-ui-check-toggle>\n <div *ngIf=\"isMultilingual\" class=\"flex flex-col gap-2\">\n <div class=\"flex flex-row justify-between border-t border-gray-300 p-3\">\n <span class=\"mt-2 text-sm text-gray-600\" translate\n >editor.record.form.multilingual.activate</span\n >\n <gn-ui-button\n extraClass=\"w-16 h-8 font-bold\"\n type=\"gray\"\n (buttonClick)=\"validateTranslations()\"\n data-test=\"validateSelection\"\n >{{ 'editor.record.form.multilingual.validate' | translate }}\n </gn-ui-button>\n </div>\n <ng-container *ngIf=\"supportedLanguages$ | async as languages\">\n <div\n class=\"flex flex-col gap-2 w-full px-2\"\n data-test=\"langAvailable\"\n *ngFor=\"let lang of languages\"\n >\n <gn-ui-button\n [extraClass]=\"getExtraClass(lang)\"\n type=\"gray\"\n (buttonClick)=\"toggleLanguage(lang)\"\n [disabled]=\"lang === _record.defaultLanguage\"\n [title]=\"getToggleTitle(lang)\"\n >\n <span [class]=\"getIconClass(lang)\"></span>\n <span class=\"ml-2\">{{ 'language.' + lang | translate }}</span>\n </gn-ui-button>\n </div>\n </ng-container>\n </div>\n </div>\n <div *ngIf=\"!editTranslations && isMultilingual\" class=\"flex flex-col gap-2\">\n <gn-ui-button\n *ngFor=\"let recordLang of sortLanguages(recordLanguages); let i = index\"\n extraClass=\"flex flex-row justify-between bg-white border border-white rounded mb-1 h-[34px] w-full\"\n [ngClass]=\"{\n 'mt-8': isFirstUnsupported(i),\n '': true,\n }\"\n (buttonClick)=\"switchFormLang(recordLang)\"\n type=\"outline\"\n data-test=\"langSwitch\"\n >\n <div class=\"flex flex-row gap-2 items-center\">\n <ng-icon\n *ngIf=\"recordLang === formLanguage\"\n class=\"text-primary mt-1\"\n name=\"iconoirCheckCircle\"\n ></ng-icon>\n <ng-icon\n *ngIf=\"recordLang !== formLanguage\"\n class=\"text-gray-800 mt-1\"\n name=\"iconoirCircle\"\n ></ng-icon>\n <span\n *ngIf=\"recordLang.length === 2\"\n [class]=\"getIconClass(recordLang) + 'mt-1'\"\n ></span>\n <span [ngClass]=\"recordLang === formLanguage ? 'text-black' : ''\">{{\n isLangSupported(recordLang)\n ? ('language.' + recordLang | translate)\n : recordLang.toUpperCase()\n }}</span>\n </div>\n <div class=\"flex flex-row gap-2 items-center\">\n <span\n *ngIf=\"recordLang === formLanguage\"\n class=\"text-xs text-base\"\n translate\n >editor.record.form.multilingual.default</span\n >\n <button\n (click)=\"\n openActionMenu(recordLang, template); $event.stopPropagation()\n \"\n cdkOverlayOrigin\n #actionMenuButton\n >\n <ng-icon class=\"pb-5\" name=\"matMoreHorizOutline\"></ng-icon>\n </button>\n <ng-template #template>\n <gn-ui-action-menu\n [canDelete]=\"recordLang !== _record.defaultLanguage\"\n page=\"record\"\n (delete)=\"confirmDeleteAction(recordLang)\"\n (closeActionMenu)=\"closeActionMenu()\"\n (switch)=\"switchDefaultLang(recordLang)\"\n >\n </gn-ui-action-menu>\n </ng-template>\n </div>\n </gn-ui-button>\n </div>\n</div>\n" }]
|
|
267
|
+
}], ctorParameters: () => [{ type: i1.EditorFacade }, { type: i2.MatDialog }, { type: i3.TranslateService }, { type: i4.RecordsRepositoryInterface }, { type: i5.Overlay }, { type: i0.ViewContainerRef }, { type: i0.ChangeDetectorRef }], propDecorators: { record: [{
|
|
268
|
+
type: Input
|
|
269
|
+
}], actionMenuButtons: [{
|
|
270
|
+
type: ViewChildren,
|
|
271
|
+
args: ['actionMenuButton', { read: ElementRef }]
|
|
272
|
+
}] } });
|
|
273
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multilingual-panel.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/feature/editor/src/lib/components/multilingual-panel/multilingual-panel.component.ts","../../../../../../../../../libs/feature/editor/src/lib/components/multilingual-panel/multilingual-panel.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Input,\n  OnDestroy,\n  QueryList,\n  ViewChildren,\n  ViewContainerRef,\n} from '@angular/core'\nimport { CommonModule } from '@angular/common'\nimport { ButtonComponent, CheckToggleComponent } from '../../../../../../../libs/ui/inputs/src'\nimport { TranslateModule, TranslateService } from '@ngx-translate/core'\nimport { CatalogRecord } from '../../../../../../../libs/common/domain/src/lib/model/record'\nimport {\n  NgIconComponent,\n  provideIcons,\n  provideNgIconsConfig,\n} from '@ng-icons/core'\nimport {\n  iconoirCheckCircle,\n  iconoirCircle,\n  iconoirSettings,\n} from '@ng-icons/iconoir'\nimport { matMoreHorizOutline } from '@ng-icons/material-icons/outline'\nimport { EditorFacade } from '../../+state/editor.facade'\nimport { ConfirmationDialogComponent } from '../../../../../../../libs/ui/elements/src'\nimport { MatDialog } from '@angular/material/dialog'\nimport { RecordsRepositoryInterface } from '../../../../../../../libs/common/domain/src/lib/repository/records-repository.interface'\nimport { map, Subscription } from 'rxjs'\nimport { Overlay, OverlayRef } from '@angular/cdk/overlay'\nimport { TemplatePortal } from '@angular/cdk/portal'\nimport { ActionMenuComponent } from '../../../../../../../libs/ui/search/src'\n\nconst extraFlagMap: { [key: string]: string } = {\n  ar: 'arab',\n  en: 'gb',\n  ko: 'kr',\n  cs: 'cz',\n  zh: 'cn',\n  ca: 'es-ct',\n  rm: 'ch',\n  da: 'dk',\n  sv: 'se',\n  cy: 'gb-wls',\n  hy: 'am',\n  ka: 'ge',\n  uk: 'ua',\n}\n\n@Component({\n  selector: 'gn-ui-multilingual-panel',\n  standalone: true,\n  imports: [\n    CommonModule,\n    CheckToggleComponent,\n    TranslateModule,\n    ButtonComponent,\n    NgIconComponent,\n    ActionMenuComponent,\n  ],\n  providers: [\n    provideIcons({\n      iconoirSettings,\n      matMoreHorizOutline,\n      iconoirCheckCircle,\n      iconoirCircle,\n    }),\n    provideNgIconsConfig({\n      size: '1.25em',\n    }),\n  ],\n  templateUrl: './multilingual-panel.component.html',\n  styleUrl: './multilingual-panel.component.css',\n})\nexport class MultilingualPanelComponent implements OnDestroy {\n  isMultilingual: boolean\n  _record: CatalogRecord\n  editTranslations: boolean\n  selectedLanguages = []\n  recordLanguages = []\n  formLanguage = ''\n  @Input() set record(value: CatalogRecord) {\n    this._record = value\n    this.isMultilingual = value.otherLanguages.length > 0\n    this.editTranslations = false\n    this.recordLanguages = [...value.otherLanguages, value.defaultLanguage]\n    this.selectedLanguages = this.recordLanguages\n    this.formLanguage = value.defaultLanguage\n  }\n  @ViewChildren('actionMenuButton', { read: ElementRef })\n  actionMenuButtons!: QueryList<ElementRef>\n  private overlayRef!: OverlayRef\n\n  isActionMenuOpen = false\n  subscription = new Subscription()\n\n  supportedLanguages$ = this.recordsRepository\n    .getApplicationLanguages()\n    .pipe(map((languages) => this.sortLanguages(languages)))\n\n  constructor(\n    public facade: EditorFacade,\n    public dialog: MatDialog,\n    private translateService: TranslateService,\n    private recordsRepository: RecordsRepositoryInterface,\n    private overlay: Overlay,\n    private viewContainerRef: ViewContainerRef,\n    private cdr: ChangeDetectorRef\n  ) {}\n\n  ngOnDestroy() {\n    this.subscription.unsubscribe()\n  }\n\n  sortLanguages(languages: string[]) {\n    return languages\n      .map((lang) => {\n        const label = this.translateService.instant('language.' + lang)\n        const isTranslated = label !== 'language.' + lang\n\n        return {\n          lang,\n          label,\n          isTranslated,\n        }\n      })\n      .sort((a, b) => {\n        if (a.isTranslated && !b.isTranslated) return -1\n        if (!a.isTranslated && b.isTranslated) return 1\n\n        return a.label.localeCompare(b.label)\n      })\n      .map((item) => item.lang)\n  }\n\n  toggleLanguageSelection() {\n    this.editTranslations = !this.editTranslations\n  }\n\n  getIconClass(lang: string) {\n    return extraFlagMap[lang]\n      ? `fi fi-${extraFlagMap[lang]} w-4 h-3`\n      : `fi fi-${lang} w-4 h-3`\n  }\n\n  switchMultilingual() {\n    if (this.isMultilingual && this.selectedLanguages.length > 1) {\n      this.confirmDeleteAction()\n    } else {\n      this.isMultilingual = true\n      this.editTranslations = true\n    }\n  }\n\n  getExtraClass(lang: string) {\n    const baseClass = 'h-[34px] w-full font-bold justify-start hover:bg-white'\n    if (this.selectedLanguages.includes(lang)) {\n      return `${baseClass} bg-white border border-black`\n    }\n    return baseClass\n  }\n\n  toggleLanguage(lang: string) {\n    if (this.selectedLanguages.includes(lang)) {\n      this.removeSelectedLanguage(lang)\n    } else {\n      this.selectedLanguages.push(lang)\n    }\n  }\n\n  removeSelectedLanguage(lang: string) {\n    this.selectedLanguages = this.selectedLanguages.filter(\n      (language) => language !== lang\n    )\n  }\n\n  validateTranslations() {\n    const equalLength =\n      this.selectedLanguages.length === this.recordLanguages.length\n    if (\n      this.selectedLanguages.length < this.recordLanguages.length ||\n      (equalLength && this.selectedLanguages !== this.recordLanguages)\n    ) {\n      this.confirmDeleteAction(this.selectedLanguages)\n    } else {\n      this.updateTranslations()\n    }\n  }\n\n  updateTranslations() {\n    this.facade.updateRecordField(\n      'otherLanguages',\n      this.selectedLanguages.filter((lang) => lang !== this.formLanguage)\n    )\n    this.recordLanguages = this.selectedLanguages\n    this.editTranslations = false\n  }\n\n  switchFormLang(lang) {\n    // TO IMPLEMENT FURTHER\n  }\n\n  switchDefaultLang(lang: string) {\n    this.formLanguage = lang\n    this.facade.updateRecordField('defaultLanguage', lang)\n    this.facade.updateRecordField(\n      'otherLanguages',\n      this.selectedLanguages.filter((lang) => lang !== this.formLanguage)\n    )\n    this.closeActionMenu()\n  }\n\n  confirmDeleteAction(lang?: string[] | string) {\n    const dialogRef = this.dialog.open(ConfirmationDialogComponent, {\n      data: {\n        title: this.translateService.instant(\n          'editor.record.multilingual.confirmation.title'\n        ),\n        message: this.translateService.instant(\n          'editor.record.multilingual.confirmation.message'\n        ),\n        confirmText: this.translateService.instant(\n          'editor.record.multilingual.confirmation.confirmText'\n        ),\n        cancelText: this.translateService.instant(\n          'editor.record.multilingual.confirmation.cancelText'\n        ),\n      },\n      restoreFocus: true,\n    })\n    this.subscription.add(\n      dialogRef.afterClosed().subscribe((confirmed) => {\n        if (confirmed) {\n          if (lang) {\n            if (!Array.isArray(lang)) {\n              this.removeSelectedLanguage(lang)\n              this.closeActionMenu()\n            }\n            this.updateTranslations()\n          } else {\n            this.facade.updateRecordField('otherLanguages', [])\n            this.isMultilingual = false\n            this.selectedLanguages = []\n          }\n        } else {\n          this.isMultilingual = true\n          this.selectedLanguages = this.recordLanguages\n        }\n        this.editTranslations = false\n      })\n    )\n  }\n\n  isFirstUnsupported(index: number): boolean {\n    const langs = this.sortLanguages(this.recordLanguages)\n    return (\n      langs[index].length === 3 &&\n      langs.slice(0, index).every((lang) => lang.length !== 3)\n    )\n  }\n\n  isLangSupported(lang: string) {\n    return lang.length === 2\n  }\n\n  getToggleTitle(lang: string) {\n    if (lang === this._record.defaultLanguage) {\n      return this.translateService.instant(\n        'editor.record.form.multilingual.forbidden'\n      )\n    }\n    return ''\n  }\n\n  openActionMenu(item: string, template) {\n    this.isActionMenuOpen = true\n    const index = this.sortLanguages(this.selectedLanguages).indexOf(item)\n    const buttonElement = this.actionMenuButtons.toArray()[index]\n\n    const positionStrategy = this.overlay\n      .position()\n      .flexibleConnectedTo(buttonElement)\n      .withFlexibleDimensions(true)\n      .withPush(true)\n      .withPositions([\n        {\n          originX: 'end',\n          originY: 'bottom',\n          overlayX: 'end',\n          overlayY: 'top',\n        },\n        {\n          originX: 'end',\n          originY: 'top',\n          overlayX: 'end',\n          overlayY: 'bottom',\n        },\n      ])\n\n    this.overlayRef = this.overlay.create({\n      hasBackdrop: true,\n      backdropClass: 'cdk-overlay-transparent-backdrop',\n      positionStrategy: positionStrategy,\n      scrollStrategy: this.overlay.scrollStrategies.reposition(),\n    })\n\n    const portal = new TemplatePortal(template, this.viewContainerRef)\n\n    this.overlayRef.attach(portal)\n    this.subscription.add(\n      this.overlayRef.backdropClick().subscribe(() => {\n        this.closeActionMenu()\n      })\n    )\n  }\n\n  closeActionMenu() {\n    if (this.overlayRef) {\n      this.isActionMenuOpen = false\n      this.overlayRef.dispose()\n      this.cdr.markForCheck()\n    }\n  }\n}\n","<div\n  class=\"flex flex-col h-full w-[302px] bg-neutral-100 border-l border-gray-300 py-8 px-3 gap-6 overflow-auto\"\n>\n  <div class=\"flex flex-row px-2 justify-between\">\n    <span class=\"text-3xl font-title text-black/80\" translate\n      >editor.record.form.multilingual.title</span\n    >\n    <button\n      [title]=\"'editor.record.form.multilingual.open' | translate\"\n      (click)=\"toggleLanguageSelection()\"\n      *ngIf=\"isMultilingual\"\n      data-test=\"activateSelection\"\n    >\n      <ng-icon class=\"mt-1\" name=\"iconoirSettings\"></ng-icon>\n    </button>\n  </div>\n  <div class=\"flex flex-col gap-2\" *ngIf=\"editTranslations || !isMultilingual\">\n    <gn-ui-check-toggle\n      class=\"p-2\"\n      [label]=\"'editor.record.form.multilingual.enable' | translate\"\n      [color]=\"'primary'\"\n      [(value)]=\"isMultilingual\"\n      (toggled)=\"switchMultilingual($event)\"\n    ></gn-ui-check-toggle>\n    <div *ngIf=\"isMultilingual\" class=\"flex flex-col gap-2\">\n      <div class=\"flex flex-row justify-between border-t border-gray-300 p-3\">\n        <span class=\"mt-2 text-sm text-gray-600\" translate\n          >editor.record.form.multilingual.activate</span\n        >\n        <gn-ui-button\n          extraClass=\"w-16 h-8 font-bold\"\n          type=\"gray\"\n          (buttonClick)=\"validateTranslations()\"\n          data-test=\"validateSelection\"\n          >{{ 'editor.record.form.multilingual.validate' | translate }}\n        </gn-ui-button>\n      </div>\n      <ng-container *ngIf=\"supportedLanguages$ | async as languages\">\n        <div\n          class=\"flex flex-col gap-2 w-full px-2\"\n          data-test=\"langAvailable\"\n          *ngFor=\"let lang of languages\"\n        >\n          <gn-ui-button\n            [extraClass]=\"getExtraClass(lang)\"\n            type=\"gray\"\n            (buttonClick)=\"toggleLanguage(lang)\"\n            [disabled]=\"lang === _record.defaultLanguage\"\n            [title]=\"getToggleTitle(lang)\"\n          >\n            <span [class]=\"getIconClass(lang)\"></span>\n            <span class=\"ml-2\">{{ 'language.' + lang | translate }}</span>\n          </gn-ui-button>\n        </div>\n      </ng-container>\n    </div>\n  </div>\n  <div *ngIf=\"!editTranslations && isMultilingual\" class=\"flex flex-col gap-2\">\n    <gn-ui-button\n      *ngFor=\"let recordLang of sortLanguages(recordLanguages); let i = index\"\n      extraClass=\"flex flex-row justify-between bg-white border border-white rounded mb-1 h-[34px] w-full\"\n      [ngClass]=\"{\n        'mt-8': isFirstUnsupported(i),\n        '': true,\n      }\"\n      (buttonClick)=\"switchFormLang(recordLang)\"\n      type=\"outline\"\n      data-test=\"langSwitch\"\n    >\n      <div class=\"flex flex-row gap-2 items-center\">\n        <ng-icon\n          *ngIf=\"recordLang === formLanguage\"\n          class=\"text-primary mt-1\"\n          name=\"iconoirCheckCircle\"\n        ></ng-icon>\n        <ng-icon\n          *ngIf=\"recordLang !== formLanguage\"\n          class=\"text-gray-800 mt-1\"\n          name=\"iconoirCircle\"\n        ></ng-icon>\n        <span\n          *ngIf=\"recordLang.length === 2\"\n          [class]=\"getIconClass(recordLang) + 'mt-1'\"\n        ></span>\n        <span [ngClass]=\"recordLang === formLanguage ? 'text-black' : ''\">{{\n          isLangSupported(recordLang)\n            ? ('language.' + recordLang | translate)\n            : recordLang.toUpperCase()\n        }}</span>\n      </div>\n      <div class=\"flex flex-row gap-2 items-center\">\n        <span\n          *ngIf=\"recordLang === formLanguage\"\n          class=\"text-xs text-base\"\n          translate\n          >editor.record.form.multilingual.default</span\n        >\n        <button\n          (click)=\"\n            openActionMenu(recordLang, template); $event.stopPropagation()\n          \"\n          cdkOverlayOrigin\n          #actionMenuButton\n        >\n          <ng-icon class=\"pb-5\" name=\"matMoreHorizOutline\"></ng-icon>\n        </button>\n        <ng-template #template>\n          <gn-ui-action-menu\n            [canDelete]=\"recordLang !== _record.defaultLanguage\"\n            page=\"record\"\n            (delete)=\"confirmDeleteAction(recordLang)\"\n            (closeActionMenu)=\"closeActionMenu()\"\n            (switch)=\"switchDefaultLang(recordLang)\"\n          >\n          </gn-ui-action-menu>\n        </ng-template>\n      </div>\n    </gn-ui-button>\n  </div>\n</div>\n"]}
|
|
@@ -19,4 +19,5 @@ export * from './lib/results-list-item/results-list-item.component';
|
|
|
19
19
|
export * from './lib/results-hits-search-kind/results-hits-search-kind.component';
|
|
20
20
|
export * from './lib/results-hits-number/results-hits-number.component';
|
|
21
21
|
export * from './lib/results-table/results-table.component';
|
|
22
|
-
|
|
22
|
+
export * from './lib/results-table/action-menu/action-menu.component';
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3VpL3NlYXJjaC9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksSUFBSSxjQUFjLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQTtBQUMzRSxjQUFjLDJCQUEyQixDQUFBO0FBQ3pDLGNBQWMsdUJBQXVCLENBQUE7QUFDckMsY0FBYyxnREFBZ0QsQ0FBQTtBQUM5RCxjQUFjLDhDQUE4QyxDQUFBO0FBQzVELGNBQWMsOENBQThDLENBQUE7QUFDNUQsY0FBYyx3QkFBd0IsQ0FBQTtBQUN0QyxjQUFjLDBDQUEwQyxDQUFBO0FBQ3hELGNBQWMsMkNBQTJDLENBQUE7QUFDekQsY0FBYywrQ0FBK0MsQ0FBQTtBQUM3RCxjQUFjLHlEQUF5RCxDQUFBO0FBQ3ZFLGNBQWMsdURBQXVELENBQUE7QUFDckUsY0FBYyx5REFBeUQsQ0FBQTtBQUN2RSxjQUFjLHlEQUF5RCxDQUFBO0FBQ3ZFLGNBQWMseURBQXlELENBQUE7QUFDdkUsY0FBYywyREFBMkQsQ0FBQTtBQUN6RSxjQUFjLDZDQUE2QyxDQUFBO0FBQzNELGNBQWMscURBQXFELENBQUE7QUFDbkUsY0FBYyxtRUFBbUUsQ0FBQTtBQUNqRixjQUFjLHlEQUF5RCxDQUFBO0FBQ3ZFLGNBQWMsNkNBQTZDLENBQUE7QUFDM0QsY0FBYyx1REFBdUQsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IEZhY2V0c01vZHVsZSBhcyBVaUZhY2V0c01vZHVsZSB9IGZyb20gJy4vbGliL2ZhY2V0cy9mYWNldHMubW9kdWxlJ1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZmFjZXRzL2ZhY2V0cy5tb2RlbCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ZhY2V0cy9maXh0dXJlcydcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ZhY2V0cy9mYWNldC1ibG9jay9mYWNldC1ibG9jay5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9mYWNldHMvZmFjZXQtbGlzdC9mYWNldC1saXN0LmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ZhY2V0cy9mYWNldC1pdGVtL2ZhY2V0LWl0ZW0uY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdWktc2VhcmNoLm1vZHVsZSdcbmV4cG9ydCAqIGZyb20gJy4vbGliL3Jlc3VsdHMtbGlzdC9yZXN1bHRzLWxheW91dC5jb25maWcnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9yZXN1bHRzLWxpc3QvcmVzdWx0cy1saXN0LmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL3JlY29yZC1wcmV2aWV3L3JlY29yZC1wcmV2aWV3LmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL3JlY29yZC1wcmV2aWV3LWZlZWQvcmVjb3JkLXByZXZpZXctZmVlZC5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9yZWNvcmQtcHJldmlldy1yb3cvcmVjb3JkLXByZXZpZXctcm93LmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL3JlY29yZC1wcmV2aWV3LWNhcmQvcmVjb3JkLXByZXZpZXctY2FyZC5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9yZWNvcmQtcHJldmlldy1saXN0L3JlY29yZC1wcmV2aWV3LWxpc3QuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcmVjb3JkLXByZXZpZXctdGV4dC9yZWNvcmQtcHJldmlldy10ZXh0LmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL3JlY29yZC1wcmV2aWV3LXRpdGxlL3JlY29yZC1wcmV2aWV3LXRpdGxlLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL3JlY29yZC1tZXRyaWMvcmVjb3JkLW1ldHJpYy5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9yZXN1bHRzLWxpc3QtaXRlbS9yZXN1bHRzLWxpc3QtaXRlbS5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9yZXN1bHRzLWhpdHMtc2VhcmNoLWtpbmQvcmVzdWx0cy1oaXRzLXNlYXJjaC1raW5kLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL3Jlc3VsdHMtaGl0cy1udW1iZXIvcmVzdWx0cy1oaXRzLW51bWJlci5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9yZXN1bHRzLXRhYmxlL3Jlc3VsdHMtdGFibGUuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcmVzdWx0cy10YWJsZS9hY3Rpb24tbWVudS9hY3Rpb24tbWVudS5jb21wb25lbnQnXG4iXX0=
|
|
@@ -13,30 +13,35 @@ export class ActionMenuComponent {
|
|
|
13
13
|
constructor(dialog, cdr) {
|
|
14
14
|
this.dialog = dialog;
|
|
15
15
|
this.cdr = cdr;
|
|
16
|
+
this.canDuplicate = true;
|
|
17
|
+
this.canDelete = true;
|
|
16
18
|
this.duplicate = new EventEmitter();
|
|
17
19
|
this.delete = new EventEmitter();
|
|
18
20
|
this.closeActionMenu = new EventEmitter();
|
|
19
21
|
this.rollback = new EventEmitter();
|
|
22
|
+
this.switch = new EventEmitter();
|
|
20
23
|
this.sectionDisplayed = 'mainMenu';
|
|
21
24
|
}
|
|
22
|
-
openMenu() {
|
|
23
|
-
this.trigger.openMenu();
|
|
24
|
-
}
|
|
25
25
|
displayMainMenu() {
|
|
26
26
|
this.sectionDisplayed = 'mainMenu';
|
|
27
27
|
this.cdr.markForCheck();
|
|
28
28
|
}
|
|
29
29
|
displayDeleteMenu() {
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
30
|
+
switch (this.page) {
|
|
31
|
+
case 'draft':
|
|
32
|
+
this.sectionDisplayed = 'rollbackMenu';
|
|
33
|
+
break;
|
|
34
|
+
case 'record':
|
|
35
|
+
this.delete.emit();
|
|
36
|
+
break;
|
|
37
|
+
case 'main':
|
|
38
|
+
default:
|
|
39
|
+
this.sectionDisplayed = 'deleteMenu';
|
|
35
40
|
}
|
|
36
41
|
this.cdr.markForCheck();
|
|
37
42
|
}
|
|
38
43
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ActionMenuComponent, deps: [{ token: i1.MatDialog }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
39
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ActionMenuComponent, isStandalone: true, selector: "gn-ui-action-menu", inputs: { canDuplicate: "canDuplicate", canDelete: "canDelete",
|
|
44
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ActionMenuComponent, isStandalone: true, selector: "gn-ui-action-menu", inputs: { canDuplicate: "canDuplicate", canDelete: "canDelete", page: "page" }, outputs: { duplicate: "duplicate", delete: "delete", closeActionMenu: "closeActionMenu", rollback: "rollback", switch: "switch" }, viewQueries: [{ propertyName: "trigger", first: true, predicate: MatMenuTrigger, descendants: true }], ngImport: i0, template: "<ng-container [ngSwitch]=\"sectionDisplayed\">\n <ng-container *ngSwitchCase=\"'mainMenu'\">\n <div\n data-test=\"mainMenuSection\"\n class=\"mt-2 border border-gray-100 p-2 flex items-center bg-white shadow-2xl rounded-2xl\"\n >\n <ul class=\"flex flex-col gap-2 w-full\">\n <gn-ui-button\n *ngIf=\"page === 'main'\"\n type=\"light\"\n extraClass=\"flex flex-row items-center gap-2 w-full justify-start\"\n (buttonClick)=\"duplicate.emit()\"\n [disabled]=\"!canDuplicate\"\n data-test=\"record-menu-duplicate-button\"\n >\n <span *ngIf=\"canDuplicate\" translate>record.action.duplicate</span>\n <span *ngIf=\"!canDuplicate\" translate\n >record.action.duplicating</span\n ></gn-ui-button\n >\n <gn-ui-button\n *ngIf=\"page === 'record'\"\n type=\"light\"\n extraClass=\"flex flex-row items-center gap-2 w-full justify-start\"\n (buttonClick)=\"switch.emit()\"\n data-test=\"record-menu-switch-button\"\n ><span translate>record.action.switchLang</span></gn-ui-button\n >\n <gn-ui-button\n type=\"light\"\n extraClass=\"flex flex-row items-center gap-2 w-full justify-start\"\n (buttonClick)=\"displayDeleteMenu()\"\n [disabled]=\"!canDelete\"\n data-test=\"record-menu-delete-button\"\n ><span *ngIf=\"page !== 'draft'\" translate>record.action.delete</span>\n <span *ngIf=\"page === 'draft'\" translate\n >record.action.rollback</span\n ></gn-ui-button\n >\n </ul>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'deleteMenu'\">\n <div\n data-test=\"deleteMenuSection\"\n class=\"w-72 p-6 flex flex-col gap-3 mt-2 border border-gray-100 bg-white shadow-2xl rounded-2xl\"\n >\n <span class=\"text-lg font-bold text-center\">{{\n 'editor.record.delete.confirmation.title' | translate\n }}</span>\n <span class=\"text-center\">{{\n 'editor.record.delete.confirmation.message' | translate\n }}</span>\n <div class=\"flex flex-row gap-8 justify-center\">\n <gn-ui-button\n (buttonClick)=\"delete.emit()\"\n cdkFocusInitial\n type=\"primary\"\n data-cy=\"confirm-button\"\n [style.--gn-ui-button-width]=\"'100px'\"\n >{{\n 'editor.record.delete.confirmation.confirmText' | translate\n }}</gn-ui-button\n >\n <gn-ui-button\n [style.--gn-ui-button-width]=\"'100px'\"\n (buttonClick)=\"closeActionMenu.emit()\"\n >{{\n 'editor.record.delete.confirmation.cancelText' | translate\n }}</gn-ui-button\n >\n </div>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'rollbackMenu'\">\n <div\n data-test=\"rollbackMenuSection\"\n class=\"w-80 p-6 flex flex-col gap-3 mt-2 border border-gray-100 bg-white shadow-2xl rounded-2xl\"\n >\n <span class=\"text-lg font-bold text-center\">{{\n 'editor.record.undo.confirmation.title' | translate\n }}</span>\n <span class=\"text-center\">{{\n 'editor.record.undo.confirmation.message' | translate\n }}</span>\n <div class=\"flex flex-row gap-8 justify-center\">\n <gn-ui-button\n (buttonClick)=\"rollback.emit()\"\n cdkFocusInitial\n type=\"primary\"\n data-cy=\"confirm-button\"\n [style.--gn-ui-button-width]=\"'120px'\"\n >{{\n 'editor.record.undo.confirmation.confirmText' | translate\n }}</gn-ui-button\n >\n <gn-ui-button\n [style.--gn-ui-button-width]=\"'120px'\"\n (buttonClick)=\"closeActionMenu.emit()\"\n >{{\n 'editor.record.undo.confirmation.cancelText' | translate\n }}</gn-ui-button\n >\n </div>\n </div>\n </ng-container>\n</ng-container>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i2.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "component", type: ButtonComponent, selector: "gn-ui-button", inputs: ["type", "disabled", "extraClass"], outputs: ["buttonClick"] }, { kind: "ngmodule", type: MatMenuModule }, { kind: "ngmodule", type: MatDialogModule }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }, { kind: "directive", type: i3.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }] }); }
|
|
40
45
|
}
|
|
41
46
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ActionMenuComponent, decorators: [{
|
|
42
47
|
type: Component,
|
|
@@ -47,12 +52,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
47
52
|
MatDialogModule,
|
|
48
53
|
ConfirmationDialogComponent,
|
|
49
54
|
TranslateModule,
|
|
50
|
-
], template: "<ng-container [ngSwitch]=\"sectionDisplayed\">\n <ng-container *ngSwitchCase=\"'mainMenu'\">\n <div\n data-test=\"mainMenuSection\"\n class=\"mt-2 border border-gray-100 p-2 flex items-center bg-white shadow-2xl rounded-2xl\"\n >\n <ul class=\"flex flex-col gap-2 w-full\">\n <gn-ui-button\n *ngIf=\"
|
|
55
|
+
], template: "<ng-container [ngSwitch]=\"sectionDisplayed\">\n <ng-container *ngSwitchCase=\"'mainMenu'\">\n <div\n data-test=\"mainMenuSection\"\n class=\"mt-2 border border-gray-100 p-2 flex items-center bg-white shadow-2xl rounded-2xl\"\n >\n <ul class=\"flex flex-col gap-2 w-full\">\n <gn-ui-button\n *ngIf=\"page === 'main'\"\n type=\"light\"\n extraClass=\"flex flex-row items-center gap-2 w-full justify-start\"\n (buttonClick)=\"duplicate.emit()\"\n [disabled]=\"!canDuplicate\"\n data-test=\"record-menu-duplicate-button\"\n >\n <span *ngIf=\"canDuplicate\" translate>record.action.duplicate</span>\n <span *ngIf=\"!canDuplicate\" translate\n >record.action.duplicating</span\n ></gn-ui-button\n >\n <gn-ui-button\n *ngIf=\"page === 'record'\"\n type=\"light\"\n extraClass=\"flex flex-row items-center gap-2 w-full justify-start\"\n (buttonClick)=\"switch.emit()\"\n data-test=\"record-menu-switch-button\"\n ><span translate>record.action.switchLang</span></gn-ui-button\n >\n <gn-ui-button\n type=\"light\"\n extraClass=\"flex flex-row items-center gap-2 w-full justify-start\"\n (buttonClick)=\"displayDeleteMenu()\"\n [disabled]=\"!canDelete\"\n data-test=\"record-menu-delete-button\"\n ><span *ngIf=\"page !== 'draft'\" translate>record.action.delete</span>\n <span *ngIf=\"page === 'draft'\" translate\n >record.action.rollback</span\n ></gn-ui-button\n >\n </ul>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'deleteMenu'\">\n <div\n data-test=\"deleteMenuSection\"\n class=\"w-72 p-6 flex flex-col gap-3 mt-2 border border-gray-100 bg-white shadow-2xl rounded-2xl\"\n >\n <span class=\"text-lg font-bold text-center\">{{\n 'editor.record.delete.confirmation.title' | translate\n }}</span>\n <span class=\"text-center\">{{\n 'editor.record.delete.confirmation.message' | translate\n }}</span>\n <div class=\"flex flex-row gap-8 justify-center\">\n <gn-ui-button\n (buttonClick)=\"delete.emit()\"\n cdkFocusInitial\n type=\"primary\"\n data-cy=\"confirm-button\"\n [style.--gn-ui-button-width]=\"'100px'\"\n >{{\n 'editor.record.delete.confirmation.confirmText' | translate\n }}</gn-ui-button\n >\n <gn-ui-button\n [style.--gn-ui-button-width]=\"'100px'\"\n (buttonClick)=\"closeActionMenu.emit()\"\n >{{\n 'editor.record.delete.confirmation.cancelText' | translate\n }}</gn-ui-button\n >\n </div>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'rollbackMenu'\">\n <div\n data-test=\"rollbackMenuSection\"\n class=\"w-80 p-6 flex flex-col gap-3 mt-2 border border-gray-100 bg-white shadow-2xl rounded-2xl\"\n >\n <span class=\"text-lg font-bold text-center\">{{\n 'editor.record.undo.confirmation.title' | translate\n }}</span>\n <span class=\"text-center\">{{\n 'editor.record.undo.confirmation.message' | translate\n }}</span>\n <div class=\"flex flex-row gap-8 justify-center\">\n <gn-ui-button\n (buttonClick)=\"rollback.emit()\"\n cdkFocusInitial\n type=\"primary\"\n data-cy=\"confirm-button\"\n [style.--gn-ui-button-width]=\"'120px'\"\n >{{\n 'editor.record.undo.confirmation.confirmText' | translate\n }}</gn-ui-button\n >\n <gn-ui-button\n [style.--gn-ui-button-width]=\"'120px'\"\n (buttonClick)=\"closeActionMenu.emit()\"\n >{{\n 'editor.record.undo.confirmation.cancelText' | translate\n }}</gn-ui-button\n >\n </div>\n </div>\n </ng-container>\n</ng-container>\n" }]
|
|
51
56
|
}], ctorParameters: () => [{ type: i1.MatDialog }, { type: i0.ChangeDetectorRef }], propDecorators: { canDuplicate: [{
|
|
52
57
|
type: Input
|
|
53
58
|
}], canDelete: [{
|
|
54
59
|
type: Input
|
|
55
|
-
}],
|
|
60
|
+
}], page: [{
|
|
56
61
|
type: Input
|
|
57
62
|
}], duplicate: [{
|
|
58
63
|
type: Output
|
|
@@ -62,8 +67,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
62
67
|
type: Output
|
|
63
68
|
}], rollback: [{
|
|
64
69
|
type: Output
|
|
70
|
+
}], switch: [{
|
|
71
|
+
type: Output
|
|
65
72
|
}], trigger: [{
|
|
66
73
|
type: ViewChild,
|
|
67
74
|
args: [MatMenuTrigger]
|
|
68
75
|
}] } });
|
|
69
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action-menu.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/ui/search/src/lib/results-table/action-menu/action-menu.component.ts","../../../../../../../../../libs/ui/search/src/lib/results-table/action-menu/action-menu.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAA;AAC9C,OAAO,EACL,iBAAiB,EACjB,SAAS,EACT,YAAY,EACZ,KAAK,EACL,MAAM,EACN,SAAS,GACV,MAAM,eAAe,CAAA;AACtB,OAAO,EAAE,SAAS,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAA;AACrE,OAAO,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAA;AACtE,OAAO,EAAE,2BAA2B,EAAE,MAAM,2CAA2C,CAAA;AACvF,OAAO,EAAE,eAAe,EAAE,MAAM,yCAAyC,CAAA;AACzE,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;;;;;AAkBrD,MAAM,OAAO,mBAAmB;IAa9B,YACS,MAAiB,EAChB,GAAsB;QADvB,WAAM,GAAN,MAAM,CAAW;QAChB,QAAG,GAAH,GAAG,CAAmB;QAXtB,cAAS,GAAG,IAAI,YAAY,EAAQ,CAAA;QACpC,WAAM,GAAG,IAAI,YAAY,EAAQ,CAAA;QACjC,oBAAe,GAAG,IAAI,YAAY,EAAQ,CAAA;QAC1C,aAAQ,GAAG,IAAI,YAAY,EAAQ,CAAA;QAI7C,qBAAgB,GAAmB,UAAU,CAAA;IAK1C,CAAC;IAEJ,QAAQ;QACN,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAA;IACzB,CAAC;IAED,eAAe;QACb,IAAI,CAAC,gBAAgB,GAAG,UAAU,CAAA;QAClC,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAA;IACzB,CAAC;IAED,iBAAiB;QACf,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,IAAI,CAAC,gBAAgB,GAAG,cAAc,CAAA;QACxC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,gBAAgB,GAAG,YAAY,CAAA;QACtC,CAAC;QACD,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAA;IACzB,CAAC;+GAlCU,mBAAmB;mGAAnB,mBAAmB,qUASnB,cAAc,gDCxC3B,qmHAmGA,yDD5EI,YAAY,+TACZ,eAAe,8HACf,aAAa,8BACb,eAAe,8BAEf,eAAe;;4FAGN,mBAAmB;kBAd/B,SAAS;+BACE,mBAAmB,cAGjB,IAAI,WACP;wBACP,YAAY;wBACZ,eAAe;wBACf,aAAa;wBACb,eAAe;wBACf,2BAA2B;wBAC3B,eAAe;qBAChB;8GAGQ,YAAY;sBAApB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACI,SAAS;sBAAlB,MAAM;gBACG,MAAM;sBAAf,MAAM;gBACG,eAAe;sBAAxB,MAAM;gBACG,QAAQ;sBAAjB,MAAM;gBAEoB,OAAO;sBAAjC,SAAS;uBAAC,cAAc","sourcesContent":["import { CommonModule } from '@angular/common'\nimport {\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  ViewChild,\n} from '@angular/core'\nimport { MatDialog, MatDialogModule } from '@angular/material/dialog'\nimport { MatMenuModule, MatMenuTrigger } from '@angular/material/menu'\nimport { ConfirmationDialogComponent } from '../../../../../../../libs/ui/elements/src'\nimport { ButtonComponent } from '../../../../../../../libs/ui/inputs/src'\nimport { TranslateModule } from '@ngx-translate/core'\n\ntype ActionMenuPage = 'mainMenu' | 'deleteMenu' | 'rollbackMenu'\n\n@Component({\n  selector: 'gn-ui-action-menu',\n  templateUrl: './action-menu.component.html',\n  styleUrls: ['./action-menu.component.css'],\n  standalone: true,\n  imports: [\n    CommonModule,\n    ButtonComponent,\n    MatMenuModule,\n    MatDialogModule,\n    ConfirmationDialogComponent,\n    TranslateModule,\n  ],\n})\nexport class ActionMenuComponent {\n  @Input() canDuplicate: boolean\n  @Input() canDelete: boolean\n  @Input() isDraftPage: boolean\n  @Output() duplicate = new EventEmitter<void>()\n  @Output() delete = new EventEmitter<void>()\n  @Output() closeActionMenu = new EventEmitter<void>()\n  @Output() rollback = new EventEmitter<void>()\n\n  @ViewChild(MatMenuTrigger) trigger: MatMenuTrigger\n\n  sectionDisplayed: ActionMenuPage = 'mainMenu'\n\n  constructor(\n    public dialog: MatDialog,\n    private cdr: ChangeDetectorRef\n  ) {}\n\n  openMenu() {\n    this.trigger.openMenu()\n  }\n\n  displayMainMenu() {\n    this.sectionDisplayed = 'mainMenu'\n    this.cdr.markForCheck()\n  }\n\n  displayDeleteMenu() {\n    if (this.isDraftPage) {\n      this.sectionDisplayed = 'rollbackMenu'\n    } else {\n      this.sectionDisplayed = 'deleteMenu'\n    }\n    this.cdr.markForCheck()\n  }\n}\n","<ng-container [ngSwitch]=\"sectionDisplayed\">\n  <ng-container *ngSwitchCase=\"'mainMenu'\">\n    <div\n      data-test=\"mainMenuSection\"\n      class=\"mt-2 border border-gray-100 p-2 flex items-center bg-white shadow-2xl rounded-2xl\"\n    >\n      <ul class=\"flex flex-col gap-2 w-full\">\n        <gn-ui-button\n          *ngIf=\"!isDraftPage\"\n          type=\"light\"\n          extraClass=\"flex flex-row items-center gap-2 w-full justify-start\"\n          (buttonClick)=\"duplicate.emit()\"\n          [disabled]=\"!canDuplicate\"\n          data-test=\"record-menu-duplicate-button\"\n        >\n          <span *ngIf=\"canDuplicate\" translate>record.action.duplicate</span>\n          <span *ngIf=\"!canDuplicate\" translate\n            >record.action.duplicating</span\n          ></gn-ui-button\n        >\n        <gn-ui-button\n          type=\"light\"\n          extraClass=\"flex flex-row items-center gap-2 w-full justify-start\"\n          (buttonClick)=\"displayDeleteMenu()\"\n          [disabled]=\"!canDelete\"\n          data-test=\"record-menu-delete-button\"\n          ><span *ngIf=\"!isDraftPage\" translate>record.action.delete</span>\n          <span *ngIf=\"isDraftPage\" translate\n            >record.action.rollback</span\n          ></gn-ui-button\n        >\n      </ul>\n    </div>\n  </ng-container>\n  <ng-container *ngSwitchCase=\"'deleteMenu'\">\n    <div\n      data-test=\"deleteMenuSection\"\n      class=\"w-72 p-6 flex flex-col gap-3 mt-2 border border-gray-100 bg-white shadow-2xl rounded-2xl\"\n    >\n      <span class=\"text-lg font-bold text-center\">{{\n        'editor.record.delete.confirmation.title' | translate\n      }}</span>\n      <span class=\"text-center\">{{\n        'editor.record.delete.confirmation.message' | translate\n      }}</span>\n      <div class=\"flex flex-row gap-8 justify-center\">\n        <gn-ui-button\n          (buttonClick)=\"delete.emit()\"\n          cdkFocusInitial\n          type=\"primary\"\n          data-cy=\"confirm-button\"\n          [style.--gn-ui-button-width]=\"'100px'\"\n          >{{\n            'editor.record.delete.confirmation.confirmText' | translate\n          }}</gn-ui-button\n        >\n        <gn-ui-button\n          [style.--gn-ui-button-width]=\"'100px'\"\n          (buttonClick)=\"closeActionMenu.emit()\"\n          >{{\n            'editor.record.delete.confirmation.cancelText' | translate\n          }}</gn-ui-button\n        >\n      </div>\n    </div>\n  </ng-container>\n  <ng-container *ngSwitchCase=\"'rollbackMenu'\">\n    <div\n      data-test=\"rollbackMenuSection\"\n      class=\"w-80 p-6 flex flex-col gap-3 mt-2 border border-gray-100 bg-white shadow-2xl rounded-2xl\"\n    >\n      <span class=\"text-lg font-bold text-center\">{{\n        'editor.record.undo.confirmation.title' | translate\n      }}</span>\n      <span class=\"text-center\">{{\n        'editor.record.undo.confirmation.message' | translate\n      }}</span>\n      <div class=\"flex flex-row gap-8 justify-center\">\n        <gn-ui-button\n          (buttonClick)=\"rollback.emit()\"\n          cdkFocusInitial\n          type=\"primary\"\n          data-cy=\"confirm-button\"\n          [style.--gn-ui-button-width]=\"'120px'\"\n          >{{\n            'editor.record.undo.confirmation.confirmText' | translate\n          }}</gn-ui-button\n        >\n        <gn-ui-button\n          [style.--gn-ui-button-width]=\"'120px'\"\n          (buttonClick)=\"closeActionMenu.emit()\"\n          >{{\n            'editor.record.undo.confirmation.cancelText' | translate\n          }}</gn-ui-button\n        >\n      </div>\n    </div>\n  </ng-container>\n</ng-container>\n"]}
|
|
76
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action-menu.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/ui/search/src/lib/results-table/action-menu/action-menu.component.ts","../../../../../../../../../libs/ui/search/src/lib/results-table/action-menu/action-menu.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAA;AAC9C,OAAO,EACL,iBAAiB,EACjB,SAAS,EACT,YAAY,EACZ,KAAK,EACL,MAAM,EACN,SAAS,GACV,MAAM,eAAe,CAAA;AACtB,OAAO,EAAE,SAAS,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAA;AACrE,OAAO,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAA;AACtE,OAAO,EAAE,2BAA2B,EAAE,MAAM,2CAA2C,CAAA;AACvF,OAAO,EAAE,eAAe,EAAE,MAAM,yCAAyC,CAAA;AACzE,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;;;;;AAkBrD,MAAM,OAAO,mBAAmB;IAc9B,YACS,MAAiB,EAChB,GAAsB;QADvB,WAAM,GAAN,MAAM,CAAW;QAChB,QAAG,GAAH,GAAG,CAAmB;QAfvB,iBAAY,GAAG,IAAI,CAAA;QACnB,cAAS,GAAG,IAAI,CAAA;QAEf,cAAS,GAAG,IAAI,YAAY,EAAQ,CAAA;QACpC,WAAM,GAAG,IAAI,YAAY,EAAQ,CAAA;QACjC,oBAAe,GAAG,IAAI,YAAY,EAAQ,CAAA;QAC1C,aAAQ,GAAG,IAAI,YAAY,EAAQ,CAAA;QACnC,WAAM,GAAG,IAAI,YAAY,EAAQ,CAAA;QAI3C,qBAAgB,GAAmB,UAAU,CAAA;IAK1C,CAAC;IAEJ,eAAe;QACb,IAAI,CAAC,gBAAgB,GAAG,UAAU,CAAA;QAClC,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAA;IACzB,CAAC;IAED,iBAAiB;QACf,QAAQ,IAAI,CAAC,IAAI,EAAE,CAAC;YAClB,KAAK,OAAO;gBACV,IAAI,CAAC,gBAAgB,GAAG,cAAc,CAAA;gBACtC,MAAK;YACP,KAAK,QAAQ;gBACX,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAA;gBAClB,MAAK;YACP,KAAK,MAAM,CAAC;YACZ;gBACE,IAAI,CAAC,gBAAgB,GAAG,YAAY,CAAA;QACxC,CAAC;QACD,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAA;IACzB,CAAC;+GArCU,mBAAmB;mGAAnB,mBAAmB,yUAUnB,cAAc,gDCzC3B,48HA2GA,yDDpFI,YAAY,+TACZ,eAAe,8HACf,aAAa,8BACb,eAAe,8BAEf,eAAe;;4FAGN,mBAAmB;kBAd/B,SAAS;+BACE,mBAAmB,cAGjB,IAAI,WACP;wBACP,YAAY;wBACZ,eAAe;wBACf,aAAa;wBACb,eAAe;wBACf,2BAA2B;wBAC3B,eAAe;qBAChB;8GAGQ,YAAY;sBAApB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACI,SAAS;sBAAlB,MAAM;gBACG,MAAM;sBAAf,MAAM;gBACG,eAAe;sBAAxB,MAAM;gBACG,QAAQ;sBAAjB,MAAM;gBACG,MAAM;sBAAf,MAAM;gBAEoB,OAAO;sBAAjC,SAAS;uBAAC,cAAc","sourcesContent":["import { CommonModule } from '@angular/common'\nimport {\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  ViewChild,\n} from '@angular/core'\nimport { MatDialog, MatDialogModule } from '@angular/material/dialog'\nimport { MatMenuModule, MatMenuTrigger } from '@angular/material/menu'\nimport { ConfirmationDialogComponent } from '../../../../../../../libs/ui/elements/src'\nimport { ButtonComponent } from '../../../../../../../libs/ui/inputs/src'\nimport { TranslateModule } from '@ngx-translate/core'\n\ntype ActionMenuPage = 'mainMenu' | 'deleteMenu' | 'rollbackMenu'\n\n@Component({\n  selector: 'gn-ui-action-menu',\n  templateUrl: './action-menu.component.html',\n  styleUrls: ['./action-menu.component.css'],\n  standalone: true,\n  imports: [\n    CommonModule,\n    ButtonComponent,\n    MatMenuModule,\n    MatDialogModule,\n    ConfirmationDialogComponent,\n    TranslateModule,\n  ],\n})\nexport class ActionMenuComponent {\n  @Input() canDuplicate = true\n  @Input() canDelete = true\n  @Input() page: 'draft' | 'main' | 'record'\n  @Output() duplicate = new EventEmitter<void>()\n  @Output() delete = new EventEmitter<void>()\n  @Output() closeActionMenu = new EventEmitter<void>()\n  @Output() rollback = new EventEmitter<void>()\n  @Output() switch = new EventEmitter<void>()\n\n  @ViewChild(MatMenuTrigger) trigger: MatMenuTrigger\n\n  sectionDisplayed: ActionMenuPage = 'mainMenu'\n\n  constructor(\n    public dialog: MatDialog,\n    private cdr: ChangeDetectorRef\n  ) {}\n\n  displayMainMenu() {\n    this.sectionDisplayed = 'mainMenu'\n    this.cdr.markForCheck()\n  }\n\n  displayDeleteMenu() {\n    switch (this.page) {\n      case 'draft':\n        this.sectionDisplayed = 'rollbackMenu'\n        break\n      case 'record':\n        this.delete.emit()\n        break\n      case 'main':\n      default:\n        this.sectionDisplayed = 'deleteMenu'\n    }\n    this.cdr.markForCheck()\n  }\n}\n","<ng-container [ngSwitch]=\"sectionDisplayed\">\n  <ng-container *ngSwitchCase=\"'mainMenu'\">\n    <div\n      data-test=\"mainMenuSection\"\n      class=\"mt-2 border border-gray-100 p-2 flex items-center bg-white shadow-2xl rounded-2xl\"\n    >\n      <ul class=\"flex flex-col gap-2 w-full\">\n        <gn-ui-button\n          *ngIf=\"page === 'main'\"\n          type=\"light\"\n          extraClass=\"flex flex-row items-center gap-2 w-full justify-start\"\n          (buttonClick)=\"duplicate.emit()\"\n          [disabled]=\"!canDuplicate\"\n          data-test=\"record-menu-duplicate-button\"\n        >\n          <span *ngIf=\"canDuplicate\" translate>record.action.duplicate</span>\n          <span *ngIf=\"!canDuplicate\" translate\n            >record.action.duplicating</span\n          ></gn-ui-button\n        >\n        <gn-ui-button\n          *ngIf=\"page === 'record'\"\n          type=\"light\"\n          extraClass=\"flex flex-row items-center gap-2 w-full justify-start\"\n          (buttonClick)=\"switch.emit()\"\n          data-test=\"record-menu-switch-button\"\n          ><span translate>record.action.switchLang</span></gn-ui-button\n        >\n        <gn-ui-button\n          type=\"light\"\n          extraClass=\"flex flex-row items-center gap-2 w-full justify-start\"\n          (buttonClick)=\"displayDeleteMenu()\"\n          [disabled]=\"!canDelete\"\n          data-test=\"record-menu-delete-button\"\n          ><span *ngIf=\"page !== 'draft'\" translate>record.action.delete</span>\n          <span *ngIf=\"page === 'draft'\" translate\n            >record.action.rollback</span\n          ></gn-ui-button\n        >\n      </ul>\n    </div>\n  </ng-container>\n  <ng-container *ngSwitchCase=\"'deleteMenu'\">\n    <div\n      data-test=\"deleteMenuSection\"\n      class=\"w-72 p-6 flex flex-col gap-3 mt-2 border border-gray-100 bg-white shadow-2xl rounded-2xl\"\n    >\n      <span class=\"text-lg font-bold text-center\">{{\n        'editor.record.delete.confirmation.title' | translate\n      }}</span>\n      <span class=\"text-center\">{{\n        'editor.record.delete.confirmation.message' | translate\n      }}</span>\n      <div class=\"flex flex-row gap-8 justify-center\">\n        <gn-ui-button\n          (buttonClick)=\"delete.emit()\"\n          cdkFocusInitial\n          type=\"primary\"\n          data-cy=\"confirm-button\"\n          [style.--gn-ui-button-width]=\"'100px'\"\n          >{{\n            'editor.record.delete.confirmation.confirmText' | translate\n          }}</gn-ui-button\n        >\n        <gn-ui-button\n          [style.--gn-ui-button-width]=\"'100px'\"\n          (buttonClick)=\"closeActionMenu.emit()\"\n          >{{\n            'editor.record.delete.confirmation.cancelText' | translate\n          }}</gn-ui-button\n        >\n      </div>\n    </div>\n  </ng-container>\n  <ng-container *ngSwitchCase=\"'rollbackMenu'\">\n    <div\n      data-test=\"rollbackMenuSection\"\n      class=\"w-80 p-6 flex flex-col gap-3 mt-2 border border-gray-100 bg-white shadow-2xl rounded-2xl\"\n    >\n      <span class=\"text-lg font-bold text-center\">{{\n        'editor.record.undo.confirmation.title' | translate\n      }}</span>\n      <span class=\"text-center\">{{\n        'editor.record.undo.confirmation.message' | translate\n      }}</span>\n      <div class=\"flex flex-row gap-8 justify-center\">\n        <gn-ui-button\n          (buttonClick)=\"rollback.emit()\"\n          cdkFocusInitial\n          type=\"primary\"\n          data-cy=\"confirm-button\"\n          [style.--gn-ui-button-width]=\"'120px'\"\n          >{{\n            'editor.record.undo.confirmation.confirmText' | translate\n          }}</gn-ui-button\n        >\n        <gn-ui-button\n          [style.--gn-ui-button-width]=\"'120px'\"\n          (buttonClick)=\"closeActionMenu.emit()\"\n          >{{\n            'editor.record.undo.confirmation.cancelText' | translate\n          }}</gn-ui-button\n        >\n      </div>\n    </div>\n  </ng-container>\n</ng-container>\n"]}
|