@elderbyte/ngx-starter 15.13.2 → 15.14.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,15 @@
1
+ export class Translated {
2
+ constructor() {
3
+ this.locales = {};
4
+ }
5
+ with(locale, value) {
6
+ this.locales[locale] = value;
7
+ return this;
8
+ }
9
+ get(locale, value) {
10
+ return this.locales[locale];
11
+ }
12
+ }
13
+ export class TranslatedText extends Translated {
14
+ }
15
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNsYXRlZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VsZGVyYnl0ZS9uZ3gtc3RhcnRlci9zcmMvbGliL2NvbW1vbi9pMThuL2VudGl0eS9pbXBsL3RyYW5zbGF0ZWQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBR0EsTUFBTSxPQUFPLFVBQVU7SUFBdkI7UUFDUyxZQUFPLEdBQWlCLEVBQUUsQ0FBQztJQVVwQyxDQUFDO0lBUlEsSUFBSSxDQUFDLE1BQW1CLEVBQUUsS0FBUTtRQUN2QyxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxHQUFHLEtBQUssQ0FBQztRQUM3QixPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFFTSxHQUFHLENBQUMsTUFBbUIsRUFBRSxLQUFRO1FBQ3RDLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUM5QixDQUFDO0NBQ0Y7QUFFRCxNQUFNLE9BQU8sY0FBZSxTQUFRLFVBQWtCO0NBQStCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtJVHJhbnNsYXRlZCwgSVRyYW5zbGF0ZWRUZXh0LCBMb2NhbGVNYXB9IGZyb20gJy4uL3RyYW5zbGF0ZWQnO1xuaW1wb3J0IHtMYW5ndWFnZVRhZ30gZnJvbSAnLi4vbGFuZ3VhZ2UtdGFnJztcblxuZXhwb3J0IGNsYXNzIFRyYW5zbGF0ZWQ8VD4gaW1wbGVtZW50cyBJVHJhbnNsYXRlZDxUPiB7XG4gIHB1YmxpYyBsb2NhbGVzOiBMb2NhbGVNYXA8VD4gPSB7fTtcblxuICBwdWJsaWMgd2l0aChsb2NhbGU6IExhbmd1YWdlVGFnLCB2YWx1ZTogVCk6IHRoaXMge1xuICAgIHRoaXMubG9jYWxlc1tsb2NhbGVdID0gdmFsdWU7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICBwdWJsaWMgZ2V0KGxvY2FsZTogTGFuZ3VhZ2VUYWcsIHZhbHVlOiBUKTogVCB8IHVuZGVmaW5lZCB7XG4gICAgcmV0dXJuIHRoaXMubG9jYWxlc1tsb2NhbGVdO1xuICB9XG59XG5cbmV4cG9ydCBjbGFzcyBUcmFuc2xhdGVkVGV4dCBleHRlbmRzIFRyYW5zbGF0ZWQ8c3RyaW5nPiBpbXBsZW1lbnRzIElUcmFuc2xhdGVkVGV4dCB7IH1cbiJdfQ==
@@ -1,4 +1,4 @@
1
- export class KnownLocaleType {
1
+ export class KnownLocaleTags {
2
2
  constructor() {
3
3
  this.ENGLISH = 'en';
4
4
  this.en_US = 'en-US';
@@ -9,4 +9,4 @@ export class KnownLocaleType {
9
9
  this.de_CH = 'de-CH';
10
10
  }
11
11
  }
12
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFuZ3VhZ2UtdGFnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tbW9uL2kxOG4vZW50aXR5L2xhbmd1YWdlLXRhZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFPQSxNQUFNLE9BQU8sZUFBZTtJQUE1QjtRQUVrQixZQUFPLEdBQWdCLElBQUksQ0FBQztRQUM1QixVQUFLLEdBQWdCLE9BQU8sQ0FBQztRQUU3QixXQUFNLEdBQWdCLElBQUksQ0FBQztRQUMzQixVQUFLLEdBQWdCLE9BQU8sQ0FBQztRQUU3QixXQUFNLEdBQWdCLElBQUksQ0FBQztRQUMzQixVQUFLLEdBQWdCLE9BQU8sQ0FBQztRQUM3QixVQUFLLEdBQWdCLE9BQU8sQ0FBQztJQUMvQyxDQUFDO0NBQUEiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFJlcHJlc2VudHMgSUVURiBMYW5ndWFnZSBUYWdzLCBjb25zaXN0aW5nIG9mXG4gKiBJU08gTGFuZ3VhZ2UgQ29kZXMgKDYzOS0xIGFuZCA2OTMtMikgYW5kIElFVEYgbGFuZ3VhZ2UgdHlwZXMuXG4gKiBodHRwczovL2RhdGFodWIuaW8vY29yZS9sYW5ndWFnZS1jb2RlcyNyZXNvdXJjZS1pZXRmLWxhbmd1YWdlLXRhZ3NcbiAqL1xuZXhwb3J0IHR5cGUgTGFuZ3VhZ2VUYWcgPSBzdHJpbmc7XG5cbmV4cG9ydCBjbGFzcyBLbm93bkxvY2FsZVR5cGUge1xuXG4gIHB1YmxpYyByZWFkb25seSBFTkdMSVNIOiBMYW5ndWFnZVRhZyA9ICdlbic7XG4gIHB1YmxpYyByZWFkb25seSBlbl9VUzogTGFuZ3VhZ2VUYWcgPSAnZW4tVVMnO1xuXG4gIHB1YmxpYyByZWFkb25seSBGUkVOQ0g6IExhbmd1YWdlVGFnID0gJ2ZyJztcbiAgcHVibGljIHJlYWRvbmx5IGZyX0ZSOiBMYW5ndWFnZVRhZyA9ICdmci1GUic7XG5cbiAgcHVibGljIHJlYWRvbmx5IEdFUk1BTjogTGFuZ3VhZ2VUYWcgPSAnZGUnO1xuICBwdWJsaWMgcmVhZG9ubHkgZGVfREU6IExhbmd1YWdlVGFnID0gJ2RlLURFJztcbiAgcHVibGljIHJlYWRvbmx5IGRlX0NIOiBMYW5ndWFnZVRhZyA9ICdkZS1DSCc7XG59XG4iXX0=
12
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFuZ3VhZ2UtdGFnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tbW9uL2kxOG4vZW50aXR5L2xhbmd1YWdlLXRhZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFPQSxNQUFNLE9BQU8sZUFBZTtJQUE1QjtRQUVrQixZQUFPLEdBQWdCLElBQUksQ0FBQztRQUM1QixVQUFLLEdBQWdCLE9BQU8sQ0FBQztRQUU3QixXQUFNLEdBQWdCLElBQUksQ0FBQztRQUMzQixVQUFLLEdBQWdCLE9BQU8sQ0FBQztRQUU3QixXQUFNLEdBQWdCLElBQUksQ0FBQztRQUMzQixVQUFLLEdBQWdCLE9BQU8sQ0FBQztRQUM3QixVQUFLLEdBQWdCLE9BQU8sQ0FBQztJQUMvQyxDQUFDO0NBQUEiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFJlcHJlc2VudHMgSUVURiBMYW5ndWFnZSBUYWdzLCBjb25zaXN0aW5nIG9mXG4gKiBJU08gTGFuZ3VhZ2UgQ29kZXMgKDYzOS0xIGFuZCA2OTMtMikgYW5kIElFVEYgbGFuZ3VhZ2UgdHlwZXMuXG4gKiBodHRwczovL2RhdGFodWIuaW8vY29yZS9sYW5ndWFnZS1jb2RlcyNyZXNvdXJjZS1pZXRmLWxhbmd1YWdlLXRhZ3NcbiAqL1xuZXhwb3J0IHR5cGUgTGFuZ3VhZ2VUYWcgPSBzdHJpbmc7XG5cbmV4cG9ydCBjbGFzcyBLbm93bkxvY2FsZVRhZ3Mge1xuXG4gIHB1YmxpYyByZWFkb25seSBFTkdMSVNIOiBMYW5ndWFnZVRhZyA9ICdlbic7XG4gIHB1YmxpYyByZWFkb25seSBlbl9VUzogTGFuZ3VhZ2VUYWcgPSAnZW4tVVMnO1xuXG4gIHB1YmxpYyByZWFkb25seSBGUkVOQ0g6IExhbmd1YWdlVGFnID0gJ2ZyJztcbiAgcHVibGljIHJlYWRvbmx5IGZyX0ZSOiBMYW5ndWFnZVRhZyA9ICdmci1GUic7XG5cbiAgcHVibGljIHJlYWRvbmx5IEdFUk1BTjogTGFuZ3VhZ2VUYWcgPSAnZGUnO1xuICBwdWJsaWMgcmVhZG9ubHkgZGVfREU6IExhbmd1YWdlVGFnID0gJ2RlLURFJztcbiAgcHVibGljIHJlYWRvbmx5IGRlX0NIOiBMYW5ndWFnZVRhZyA9ICdkZS1DSCc7XG59XG4iXX0=
@@ -1,6 +1,9 @@
1
1
  export * from './language-tag';
2
2
  export * from './localized';
3
+ export * from './translated';
4
+ export * from './impl/translated';
5
+ export * from './translated-converter';
3
6
  export * from './localisation-picker';
4
7
  export * from './impl/i18n-base';
5
8
  export * from './impl/i18n-text';
6
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VsZGVyYnl0ZS9uZ3gtc3RhcnRlci9zcmMvbGliL2NvbW1vbi9pMThuL2VudGl0eS9wdWJsaWNfYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsa0JBQWtCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJcbmV4cG9ydCAqIGZyb20gJy4vbGFuZ3VhZ2UtdGFnJztcbmV4cG9ydCAqIGZyb20gJy4vbG9jYWxpemVkJztcbmV4cG9ydCAqIGZyb20gJy4vbG9jYWxpc2F0aW9uLXBpY2tlcic7XG5leHBvcnQgKiBmcm9tICcuL2ltcGwvaTE4bi1iYXNlJztcbmV4cG9ydCAqIGZyb20gJy4vaW1wbC9pMThuLXRleHQnO1xuXG4iXX0=
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VsZGVyYnl0ZS9uZ3gtc3RhcnRlci9zcmMvbGliL2NvbW1vbi9pMThuL2VudGl0eS9wdWJsaWNfYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLGtCQUFrQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiXG5leHBvcnQgKiBmcm9tICcuL2xhbmd1YWdlLXRhZyc7XG5leHBvcnQgKiBmcm9tICcuL2xvY2FsaXplZCc7XG5leHBvcnQgKiBmcm9tICcuL3RyYW5zbGF0ZWQnO1xuZXhwb3J0ICogZnJvbSAnLi9pbXBsL3RyYW5zbGF0ZWQnO1xuZXhwb3J0ICogZnJvbSAnLi90cmFuc2xhdGVkLWNvbnZlcnRlcic7XG5leHBvcnQgKiBmcm9tICcuL2xvY2FsaXNhdGlvbi1waWNrZXInO1xuZXhwb3J0ICogZnJvbSAnLi9pbXBsL2kxOG4tYmFzZSc7XG5leHBvcnQgKiBmcm9tICcuL2ltcGwvaTE4bi10ZXh0JztcblxuIl19
@@ -0,0 +1,18 @@
1
+ import { TranslatedText } from './impl/translated';
2
+ import { I18nText } from './impl/i18n-text';
3
+ export class TranslatedConverter {
4
+ static toTranslatedText(localized) {
5
+ return TranslatedConverter.toTranslatedTextWith(localized, l => l.text);
6
+ }
7
+ static toTranslatedTextWith(localized, textFn) {
8
+ const translated = new TranslatedText();
9
+ if (localized) {
10
+ localized.forEach(l => translated.with(l.locale, textFn(l)));
11
+ }
12
+ return translated;
13
+ }
14
+ static toI18nText(translatedText) {
15
+ return Object.keys(translatedText.locales).map(locale => new I18nText(locale, translatedText.locales[locale]));
16
+ }
17
+ }
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNsYXRlZC1jb252ZXJ0ZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21tb24vaTE4bi9lbnRpdHkvdHJhbnNsYXRlZC1jb252ZXJ0ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFDLGNBQWMsRUFBQyxNQUFNLG1CQUFtQixDQUFDO0FBRWpELE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxrQkFBa0IsQ0FBQztBQUUxQyxNQUFNLE9BQU8sbUJBQW1CO0lBRXZCLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FDNUIsU0FBcUI7UUFFckIsT0FBTyxtQkFBbUIsQ0FBQyxvQkFBb0IsQ0FBQyxTQUFTLEVBQUUsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDMUUsQ0FBQztJQUVNLE1BQU0sQ0FBQyxvQkFBb0IsQ0FDaEMsU0FBYyxFQUNkLE1BQWdDO1FBRWhDLE1BQU0sVUFBVSxHQUFHLElBQUksY0FBYyxFQUFFLENBQUM7UUFDeEMsSUFBSSxTQUFTLEVBQUU7WUFDYixTQUFTLENBQUMsT0FBTyxDQUNmLENBQUMsQ0FBQyxFQUFFLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsTUFBTSxFQUFFLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUMxQyxDQUFDO1NBQ0g7UUFDRCxPQUFPLFVBQVUsQ0FBQztJQUNwQixDQUFDO0lBRU0sTUFBTSxDQUFDLFVBQVUsQ0FDdEIsY0FBK0I7UUFFL0IsT0FBTyxNQUFNLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxHQUFHLENBQzVDLE1BQU0sQ0FBQyxFQUFFLENBQUMsSUFBSSxRQUFRLENBQUMsTUFBTSxFQUFFLGNBQWMsQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FDL0QsQ0FBQztJQUNKLENBQUM7Q0FHRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TG9jYWxpemVkfSBmcm9tICcuL2xvY2FsaXplZCc7XG5pbXBvcnQge1RyYW5zbGF0ZWRUZXh0fSBmcm9tICcuL2ltcGwvdHJhbnNsYXRlZCc7XG5pbXBvcnQge0lUcmFuc2xhdGVkVGV4dH0gZnJvbSAnLi90cmFuc2xhdGVkJztcbmltcG9ydCB7STE4blRleHR9IGZyb20gJy4vaW1wbC9pMThuLXRleHQnO1xuXG5leHBvcnQgY2xhc3MgVHJhbnNsYXRlZENvbnZlcnRlciB7XG5cbiAgcHVibGljIHN0YXRpYyB0b1RyYW5zbGF0ZWRUZXh0PFQgZXh0ZW5kcyBMb2NhbGl6ZWQ+KFxuICAgIGxvY2FsaXplZDogSTE4blRleHRbXVxuICApOiBUcmFuc2xhdGVkVGV4dCB7XG4gICAgcmV0dXJuIFRyYW5zbGF0ZWRDb252ZXJ0ZXIudG9UcmFuc2xhdGVkVGV4dFdpdGgobG9jYWxpemVkLCBsID0+IGwudGV4dCk7XG4gIH1cblxuICBwdWJsaWMgc3RhdGljIHRvVHJhbnNsYXRlZFRleHRXaXRoPFQgZXh0ZW5kcyBMb2NhbGl6ZWQ+KFxuICAgIGxvY2FsaXplZDogVFtdLFxuICAgIHRleHRGbjogKGxvY2FsaXplZDogVCkgPT4gc3RyaW5nXG4gICk6IFRyYW5zbGF0ZWRUZXh0IHtcbiAgICBjb25zdCB0cmFuc2xhdGVkID0gbmV3IFRyYW5zbGF0ZWRUZXh0KCk7XG4gICAgaWYgKGxvY2FsaXplZCkge1xuICAgICAgbG9jYWxpemVkLmZvckVhY2goXG4gICAgICAgIGwgPT4gdHJhbnNsYXRlZC53aXRoKGwubG9jYWxlLCB0ZXh0Rm4obCkpXG4gICAgICApO1xuICAgIH1cbiAgICByZXR1cm4gdHJhbnNsYXRlZDtcbiAgfVxuXG4gIHB1YmxpYyBzdGF0aWMgdG9JMThuVGV4dChcbiAgICB0cmFuc2xhdGVkVGV4dDogSVRyYW5zbGF0ZWRUZXh0XG4gICk6IEkxOG5UZXh0W10ge1xuICAgIHJldHVybiBPYmplY3Qua2V5cyh0cmFuc2xhdGVkVGV4dC5sb2NhbGVzKS5tYXAoXG4gICAgICBsb2NhbGUgPT4gbmV3IEkxOG5UZXh0KGxvY2FsZSwgdHJhbnNsYXRlZFRleHQubG9jYWxlc1tsb2NhbGVdKVxuICAgICk7XG4gIH1cblxuXG59XG4iXX0=
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNsYXRlZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VsZGVyYnl0ZS9uZ3gtc3RhcnRlci9zcmMvbGliL2NvbW1vbi9pMThuL2VudGl0eS90cmFuc2xhdGVkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0xhbmd1YWdlVGFnfSBmcm9tICcuL2xhbmd1YWdlLXRhZyc7XG5cbmV4cG9ydCB0eXBlIExvY2FsZU1hcDxUPiA9IHtcbiAgW25hbWUgaW4gTGFuZ3VhZ2VUYWddOiBUO1xufTtcblxuZXhwb3J0IGludGVyZmFjZSBJVHJhbnNsYXRlZDxUPiB7XG4gIGxvY2FsZXM6IExvY2FsZU1hcDxUPjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJVHJhbnNsYXRlZFRleHQgZXh0ZW5kcyBJVHJhbnNsYXRlZDxzdHJpbmc+IHt9XG4iXX0=
@@ -114,7 +114,7 @@ export class ElderTableActivationDirective {
114
114
  }
115
115
  hasItemFocus(item) {
116
116
  const row = this.getRowForItem(item);
117
- return row.hasFocus;
117
+ return row?.hasFocus;
118
118
  }
119
119
  nextCloseTo(active) {
120
120
  const next = this.nextRowItem();
@@ -272,4 +272,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
272
272
  }], activeItem: [{
273
273
  type: Input
274
274
  }] } });
275
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-table-activation.directive.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/data-view/table/activation/elder-table-activation.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Directive,\n  HostListener,\n  Input,\n  OnDestroy, Output,\n} from '@angular/core';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {ElderTableRowDirective} from '../elder-table-row.directive';\nimport {switchMap, takeUntil, tap} from 'rxjs/operators';\nimport {BehaviorSubject, combineLatest, Observable, Subject} from 'rxjs';\nimport {ElderTableComponent} from '../elder-table/elder-table.component';\nimport {ElderTableActivationOptions} from './elder-table-activation-options';\nimport {ElderItemActivator} from './elder-item-activator';\n\n@Directive({\n  selector: 'elder-table[elderTableActivation]',\n  exportAs: 'elderTableActivation'\n})\nexport class ElderTableActivationDirective<T> implements ElderItemActivator<T>, AfterViewInit, OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private readonly destroy$ = new Subject<void>();\n\n  public readonly activeItem$ = new BehaviorSubject<T>(null);\n\n  @Input('elderTableActivation')\n  public activationOptions: ElderTableActivationOptions = {};\n\n  private _data: T[] = [];\n\n  public readonly rows$ = new BehaviorSubject<ElderTableRowDirective<T>[]>([]);\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private readonly elderTable: ElderTableComponent\n  ) {\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngAfterViewInit(): void {\n\n    const rows$ = this.elderTable.rows$;\n    const data$ = this.elderTable.dataContext$.pipe(\n      switchMap(dc => dc.data),\n      tap(data => this._data = data)\n    );\n\n    combineLatest([rows$, data$]).pipe(\n      takeUntil(this.destroy$)\n    ).subscribe(\n      ([rows, data]) => {\n        this.rows$.next(\n          this.rowDataUpdated(rows, data)\n        );\n        this.handleAutoActivations();\n      }\n    );\n\n    combineLatest([this.rows$, this.activeItem$]).pipe(\n      takeUntil(this.destroy$)\n    ).subscribe(\n      ([rows, activeItem]) => {\n        this.updateRowsActivation(rows, activeItem);\n      }\n    );\n  }\n\n  public ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n    // this.elderTable.rows$.getValue().forEach(r => r.bindTableActivation(null));\n  }\n\n  /***************************************************************************\n   *                                                                         *.\n   * Host Listeners                                                          *\n   *                                                                         *\n   **************************************************************************/\n\n  @HostListener('keydown', ['$event'])\n  public onKeydown(event: KeyboardEvent) {\n    let newActiveItem: T;\n    if (event.key === 'ArrowDown') {\n      newActiveItem = this.nextRowItem();\n    } else if (event.key === 'ArrowUp') {\n      newActiveItem = this.previousRowItem();\n    }\n\n    if (newActiveItem) {\n      this.focusAndActivate(newActiveItem);\n    }\n\n    const active = this.activeItem;\n    if (active) {\n      if (event.key === 'Enter') {\n        this.elderTable.onItemClick(active);\n        event.stopPropagation();\n      } else if (event.key === 'Spacebar' || event.key === ' ') {\n        this.elderTable.selectionModel.toggle(active);\n        event.stopPropagation();\n      }\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Output()\n  public get activeItemChange(): Observable<T> {\n    return this.activeItem$;\n  }\n\n  public get activeItem(): T {\n    return this.activeItem$.getValue();\n  }\n\n  @Input()\n  public set activeItem(item: T) {\n    if (item !== this.activeItem) {\n      this.activeItem$.next(item);\n      this.logger.debug('Set active item to ', item);\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public activate(item: T): void {\n    this.activeItem = item;\n  }\n\n  public focusAndActivate(item: T): void {\n    const row = this.getRowForItem(item);\n    if (row) {\n      row.foucs(); // Focus will auto activate the row\n    }\n  }\n\n  public isItemActive(item: T): boolean {\n    if (this.activeItem) {\n      return this.itemEquals(this.activeItem, item);\n    } else {\n      return false;\n    }\n  }\n\n  public hasItemFocus(item: T): boolean {\n    const row = this.getRowForItem(item);\n    return row.hasFocus;\n  }\n\n  public nextCloseTo(active: T): T {\n    const next = this.nextRowItem();\n    if (next !== active) {\n      return next;\n    }\n    return this.previousRowItem();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private updateRowsActivation(rows: ElderTableRowDirective<T>[], activeItem: T): void {\n    const activeId = this.getId(activeItem);\n    rows.forEach(row => {\n      this.updateRowActivation(row, activeId);\n    });\n  }\n\n  private updateRowActivation(row: ElderTableRowDirective<T>, activeId: any): void {\n    if (row.model) {\n      if (this.itemEqualsId(row.model, activeId)) {\n        if (!row.activated) {\n          row.activated = true;\n          this.logger.debug('Activated row: ', row);\n          if (!row.hasFocus) {\n            row.bringToView();\n          }\n        }\n      } else {\n        row.activated = false;\n      }\n    } else {\n      row.activated = false;\n    }\n  }\n\n  private rowDataUpdated(\n    rows: ElderTableRowDirective<T>[],\n    data: T[]\n  ): ElderTableRowDirective<T>[] {\n    // this.logger.debug('Found rows:', rows);\n    rows.forEach(row => {\n      row.bindTableActivation(this);\n    });\n    return rows;\n  }\n\n\n  private getRowForItem(item: T): ElderTableRowDirective<T> | null {\n    const rows = this.rows$.getValue();\n    return rows.find(r => r.model === item);\n  }\n\n  private handleAutoActivations(): void {\n    if (!this.hasActiveItem || this.activationOptions.mode === 'always') {\n      switch (this.activationOptions.row) {\n        case 'none':\n          break;\n        case 'first':\n          this.activateFirst();\n          break;\n        case 'last':\n          this.activateLast();\n          break;\n      }\n    }\n  }\n\n  private get hasActiveItem(): boolean {\n    return !!this.activeItem;\n  }\n\n  private activateFirst(): void {\n    const item = this.getItemAtIndex(0);\n    if (item) {\n      this.activate(item);\n    }\n  }\n\n  private activateLast(): void {\n    if (this._data) {\n      const item = this.getItemAtIndex(this._data.length - 1);\n      if (item) {\n        this.activate(item);\n      }\n    }\n  }\n\n  private previousRowItem(): T {\n    const rows = this._data;\n    let currentIndex = this.getCurrentIndex();\n    if (currentIndex > 0) {\n      --currentIndex;\n    } else {\n      if (this.activationOptions.loop) {\n        currentIndex = rows.length - 1;\n      }\n    }\n    return this.getItemAtIndex(currentIndex);\n  }\n\n  private nextRowItem(): T {\n    const rows = this._data;\n    let currentIndex = this.getCurrentIndex();\n\n    if (currentIndex < (rows.length - 1)) {\n      ++currentIndex;\n    } else {\n      if (this.activationOptions.loop) {\n        currentIndex = 0;\n      }\n    }\n    return this.getItemAtIndex(currentIndex);\n  }\n\n  private getCurrentIndex(): number {\n    const activeItem = this.activeItem;\n    if (activeItem) {\n      return this.findItemIndex(activeItem);\n    } else {\n      return -1;\n    }\n  }\n\n  private getItemAtIndex(index: number): T | undefined {\n    return this._data[index];\n  }\n\n  private findItemIndex(item: T): number {\n    const needleId = this.getId(item);\n    return this._data.findIndex(itm => this.itemEqualsId(itm, needleId));\n  }\n\n  private itemEquals(a: T, b: T): boolean {\n    return this.getId(a) === this.getId(b);\n  }\n\n  private itemEqualsId(a: T, needleId: any): boolean {\n    return this.getId(a) === needleId;\n  }\n\n  private getId(item: T): any {\n    if (item) {\n      const dc = this.elderTable.dataContext$.getValue();\n      return dc?.dataSource?.getId(item);\n    } else {\n      return item;\n    }\n  }\n\n}\n"]}
275
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-table-activation.directive.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/data-view/table/activation/elder-table-activation.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Directive,\n  HostListener,\n  Input,\n  OnDestroy, Output,\n} from '@angular/core';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {ElderTableRowDirective} from '../elder-table-row.directive';\nimport {switchMap, takeUntil, tap} from 'rxjs/operators';\nimport {BehaviorSubject, combineLatest, Observable, Subject} from 'rxjs';\nimport {ElderTableComponent} from '../elder-table/elder-table.component';\nimport {ElderTableActivationOptions} from './elder-table-activation-options';\nimport {ElderItemActivator} from './elder-item-activator';\n\n@Directive({\n  selector: 'elder-table[elderTableActivation]',\n  exportAs: 'elderTableActivation'\n})\nexport class ElderTableActivationDirective<T> implements ElderItemActivator<T>, AfterViewInit, OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private readonly destroy$ = new Subject<void>();\n\n  public readonly activeItem$ = new BehaviorSubject<T>(null);\n\n  @Input('elderTableActivation')\n  public activationOptions: ElderTableActivationOptions = {};\n\n  private _data: T[] = [];\n\n  public readonly rows$ = new BehaviorSubject<ElderTableRowDirective<T>[]>([]);\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private readonly elderTable: ElderTableComponent\n  ) {\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngAfterViewInit(): void {\n\n    const rows$ = this.elderTable.rows$;\n    const data$ = this.elderTable.dataContext$.pipe(\n      switchMap(dc => dc.data),\n      tap(data => this._data = data)\n    );\n\n    combineLatest([rows$, data$]).pipe(\n      takeUntil(this.destroy$)\n    ).subscribe(\n      ([rows, data]) => {\n        this.rows$.next(\n          this.rowDataUpdated(rows, data)\n        );\n        this.handleAutoActivations();\n      }\n    );\n\n    combineLatest([this.rows$, this.activeItem$]).pipe(\n      takeUntil(this.destroy$)\n    ).subscribe(\n      ([rows, activeItem]) => {\n        this.updateRowsActivation(rows, activeItem);\n      }\n    );\n  }\n\n  public ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n    // this.elderTable.rows$.getValue().forEach(r => r.bindTableActivation(null));\n  }\n\n  /***************************************************************************\n   *                                                                         *.\n   * Host Listeners                                                          *\n   *                                                                         *\n   **************************************************************************/\n\n  @HostListener('keydown', ['$event'])\n  public onKeydown(event: KeyboardEvent) {\n    let newActiveItem: T;\n    if (event.key === 'ArrowDown') {\n      newActiveItem = this.nextRowItem();\n    } else if (event.key === 'ArrowUp') {\n      newActiveItem = this.previousRowItem();\n    }\n\n    if (newActiveItem) {\n      this.focusAndActivate(newActiveItem);\n    }\n\n    const active = this.activeItem;\n    if (active) {\n      if (event.key === 'Enter') {\n        this.elderTable.onItemClick(active);\n        event.stopPropagation();\n      } else if (event.key === 'Spacebar' || event.key === ' ') {\n        this.elderTable.selectionModel.toggle(active);\n        event.stopPropagation();\n      }\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Output()\n  public get activeItemChange(): Observable<T> {\n    return this.activeItem$;\n  }\n\n  public get activeItem(): T {\n    return this.activeItem$.getValue();\n  }\n\n  @Input()\n  public set activeItem(item: T) {\n    if (item !== this.activeItem) {\n      this.activeItem$.next(item);\n      this.logger.debug('Set active item to ', item);\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public activate(item: T): void {\n    this.activeItem = item;\n  }\n\n  public focusAndActivate(item: T): void {\n    const row = this.getRowForItem(item);\n    if (row) {\n      row.foucs(); // Focus will auto activate the row\n    }\n  }\n\n  public isItemActive(item: T): boolean {\n    if (this.activeItem) {\n      return this.itemEquals(this.activeItem, item);\n    } else {\n      return false;\n    }\n  }\n\n  public hasItemFocus(item: T): boolean {\n    const row = this.getRowForItem(item);\n    return row?.hasFocus;\n  }\n\n  public nextCloseTo(active: T): T {\n    const next = this.nextRowItem();\n    if (next !== active) {\n      return next;\n    }\n    return this.previousRowItem();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private updateRowsActivation(rows: ElderTableRowDirective<T>[], activeItem: T): void {\n    const activeId = this.getId(activeItem);\n    rows.forEach(row => {\n      this.updateRowActivation(row, activeId);\n    });\n  }\n\n  private updateRowActivation(row: ElderTableRowDirective<T>, activeId: any): void {\n    if (row.model) {\n      if (this.itemEqualsId(row.model, activeId)) {\n        if (!row.activated) {\n          row.activated = true;\n          this.logger.debug('Activated row: ', row);\n          if (!row.hasFocus) {\n            row.bringToView();\n          }\n        }\n      } else {\n        row.activated = false;\n      }\n    } else {\n      row.activated = false;\n    }\n  }\n\n  private rowDataUpdated(\n    rows: ElderTableRowDirective<T>[],\n    data: T[]\n  ): ElderTableRowDirective<T>[] {\n    // this.logger.debug('Found rows:', rows);\n    rows.forEach(row => {\n      row.bindTableActivation(this);\n    });\n    return rows;\n  }\n\n\n  private getRowForItem(item: T): ElderTableRowDirective<T> | null {\n    const rows = this.rows$.getValue();\n    return rows.find(r => r.model === item);\n  }\n\n  private handleAutoActivations(): void {\n    if (!this.hasActiveItem || this.activationOptions.mode === 'always') {\n      switch (this.activationOptions.row) {\n        case 'none':\n          break;\n        case 'first':\n          this.activateFirst();\n          break;\n        case 'last':\n          this.activateLast();\n          break;\n      }\n    }\n  }\n\n  private get hasActiveItem(): boolean {\n    return !!this.activeItem;\n  }\n\n  private activateFirst(): void {\n    const item = this.getItemAtIndex(0);\n    if (item) {\n      this.activate(item);\n    }\n  }\n\n  private activateLast(): void {\n    if (this._data) {\n      const item = this.getItemAtIndex(this._data.length - 1);\n      if (item) {\n        this.activate(item);\n      }\n    }\n  }\n\n  private previousRowItem(): T {\n    const rows = this._data;\n    let currentIndex = this.getCurrentIndex();\n    if (currentIndex > 0) {\n      --currentIndex;\n    } else {\n      if (this.activationOptions.loop) {\n        currentIndex = rows.length - 1;\n      }\n    }\n    return this.getItemAtIndex(currentIndex);\n  }\n\n  private nextRowItem(): T {\n    const rows = this._data;\n    let currentIndex = this.getCurrentIndex();\n\n    if (currentIndex < (rows.length - 1)) {\n      ++currentIndex;\n    } else {\n      if (this.activationOptions.loop) {\n        currentIndex = 0;\n      }\n    }\n    return this.getItemAtIndex(currentIndex);\n  }\n\n  private getCurrentIndex(): number {\n    const activeItem = this.activeItem;\n    if (activeItem) {\n      return this.findItemIndex(activeItem);\n    } else {\n      return -1;\n    }\n  }\n\n  private getItemAtIndex(index: number): T | undefined {\n    return this._data[index];\n  }\n\n  private findItemIndex(item: T): number {\n    const needleId = this.getId(item);\n    return this._data.findIndex(itm => this.itemEqualsId(itm, needleId));\n  }\n\n  private itemEquals(a: T, b: T): boolean {\n    return this.getId(a) === this.getId(b);\n  }\n\n  private itemEqualsId(a: T, needleId: any): boolean {\n    return this.getId(a) === needleId;\n  }\n\n  private getId(item: T): any {\n    if (item) {\n      const dc = this.elderTable.dataContext$.getValue();\n      return dc?.dataSource?.getId(item);\n    } else {\n      return item;\n    }\n  }\n\n}\n"]}
@@ -21,6 +21,7 @@ import { MatToolbarModule } from '@angular/material/toolbar';
21
21
  import { I18nPickAsyncPipe } from './picker/i18n-pick-async.pipe';
22
22
  import { I18nPickPipe } from './picker/i18n-pick.pipe';
23
23
  import { ElderLocalizedTextsDirective } from './elder-localized-texts.directive';
24
+ import { ElderThemeModule } from '../../theme/elder-theme.module';
24
25
  import * as i0 from "@angular/core";
25
26
  export * from './elder-localized-text-column.directive';
26
27
  export * from './elder-localized-texts.directive';
@@ -54,7 +55,8 @@ ElderI18nEntitiesModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0",
54
55
  A11yModule,
55
56
  MatIconModule,
56
57
  ElderFormsModule,
57
- MatToolbarModule], exports: [ElderLocalizedTextColumnDirective,
58
+ MatToolbarModule,
59
+ ElderThemeModule], exports: [ElderLocalizedTextColumnDirective,
58
60
  ElderLocalizedTextsDirective,
59
61
  ElderLocalizedInputTableComponent,
60
62
  ElderLocalizedInputDialogComponent,
@@ -75,7 +77,8 @@ ElderI18nEntitiesModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0",
75
77
  A11yModule,
76
78
  MatIconModule,
77
79
  ElderFormsModule,
78
- MatToolbarModule] });
80
+ MatToolbarModule,
81
+ ElderThemeModule] });
79
82
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: ElderI18nEntitiesModule, decorators: [{
80
83
  type: NgModule,
81
84
  args: [{
@@ -113,7 +116,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
113
116
  MatIconModule,
114
117
  ElderFormsModule,
115
118
  MatToolbarModule,
119
+ ElderThemeModule,
116
120
  ]
117
121
  }]
118
122
  }] });
119
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItaTE4bi1lbnRpdGllcy5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21wb25lbnRzL2kxOG4vZW50aXRpZXMvZWxkZXItaTE4bi1lbnRpdGllcy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sMENBQTBDLENBQUM7QUFDMUUsT0FBTyxFQUFDLGNBQWMsRUFBQyxNQUFNLHlCQUF5QixDQUFDO0FBQ3ZELE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSx3QkFBd0IsQ0FBQztBQUNyRCxPQUFPLEVBQUMsY0FBYyxFQUFDLE1BQU0seUJBQXlCLENBQUM7QUFDdkQsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLHFCQUFxQixDQUFDO0FBQ3BELE9BQU8sRUFBQyxXQUFXLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQztBQUMzQyxPQUFPLEVBQUMsaUNBQWlDLEVBQUMsTUFBTSxxRUFBcUUsQ0FBQztBQUN0SCxPQUFPLEVBQUMsaUNBQWlDLEVBQUMsTUFBTSx5Q0FBeUMsQ0FBQztBQUMxRixPQUFPLEVBQUMsY0FBYyxFQUFDLE1BQU0seUJBQXlCLENBQUM7QUFDdkQsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLDBDQUEwQyxDQUFDO0FBQ3pFLE9BQU8sRUFBRSxrQ0FBa0MsRUFBRSxNQUFNLHVFQUF1RSxDQUFDO0FBQzNILE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSwwQkFBMEIsQ0FBQztBQUN6RCxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sMEJBQTBCLENBQUM7QUFDekQsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLG1CQUFtQixDQUFDO0FBQzdDLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLHlEQUF5RCxDQUFDO0FBQ3ZHLE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSx3QkFBd0IsQ0FBQztBQUNyRCxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNoRSxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSwyQkFBMkIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUNsRSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDdkQsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sbUNBQW1DLENBQUM7O0FBRWpGLGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYyxtQ0FBbUMsQ0FBQztBQUNsRCxjQUFjLHFFQUFxRSxDQUFDO0FBQ3BGLGNBQWMsdUVBQXVFLENBQUM7QUFDdEYsY0FBYyx3Q0FBd0MsQ0FBQztBQUN2RCxjQUFjLHlEQUF5RCxDQUFDO0FBQ3hFLGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLCtCQUErQixDQUFDO0FBeUM5QyxNQUFNLE9BQU8sdUJBQXVCOztvSEFBdkIsdUJBQXVCO3FIQUF2Qix1QkFBdUIsaUJBckNoQyxpQ0FBaUM7UUFDakMsNEJBQTRCO1FBQzVCLGlDQUFpQztRQUNqQyxrQ0FBa0M7UUFDbEMsNEJBQTRCO1FBQzVCLFlBQVk7UUFDWixpQkFBaUIsYUFhakIsWUFBWTtRQUNaLGNBQWM7UUFDZCxhQUFhO1FBQ2IsY0FBYztRQUNkLGVBQWU7UUFDZixXQUFXO1FBRVgsZ0JBQWdCO1FBQ2hCLGNBQWM7UUFDZCxlQUFlO1FBQ2YsZUFBZTtRQUNmLGVBQWU7UUFDZixVQUFVO1FBQ1YsYUFBYTtRQUNiLGdCQUFnQjtRQUNoQixnQkFBZ0IsYUF4QmhCLGlDQUFpQztRQUNqQyw0QkFBNEI7UUFDNUIsaUNBQWlDO1FBQ2pDLGtDQUFrQztRQUNsQyw0QkFBNEI7UUFDNUIsWUFBWTtRQUNaLGlCQUFpQjtxSEFxQlIsdUJBQXVCLFlBbEJoQyxZQUFZO1FBQ1osY0FBYztRQUNkLGFBQWE7UUFDYixjQUFjO1FBQ2QsZUFBZTtRQUNmLFdBQVc7UUFFWCxnQkFBZ0I7UUFDaEIsY0FBYztRQUNkLGVBQWU7UUFDZixlQUFlO1FBQ2YsZUFBZTtRQUNmLFVBQVU7UUFDVixhQUFhO1FBQ2IsZ0JBQWdCO1FBQ2hCLGdCQUFnQjsyRkFHUCx1QkFBdUI7a0JBdkNuQyxRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRTt3QkFDWixpQ0FBaUM7d0JBQ2pDLDRCQUE0Qjt3QkFDNUIsaUNBQWlDO3dCQUNqQyxrQ0FBa0M7d0JBQ2xDLDRCQUE0Qjt3QkFDNUIsWUFBWTt3QkFDWixpQkFBaUI7cUJBRWxCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxpQ0FBaUM7d0JBQ2pDLDRCQUE0Qjt3QkFDNUIsaUNBQWlDO3dCQUNqQyxrQ0FBa0M7d0JBQ2xDLDRCQUE0Qjt3QkFDNUIsWUFBWTt3QkFDWixpQkFBaUI7cUJBQ2xCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLGNBQWM7d0JBQ2QsYUFBYTt3QkFDYixjQUFjO3dCQUNkLGVBQWU7d0JBQ2YsV0FBVzt3QkFFWCxnQkFBZ0I7d0JBQ2hCLGNBQWM7d0JBQ2QsZUFBZTt3QkFDZixlQUFlO3dCQUNmLGVBQWU7d0JBQ2YsVUFBVTt3QkFDVixhQUFhO3dCQUNiLGdCQUFnQjt3QkFDaEIsZ0JBQWdCO3FCQUNqQjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtFbGRlclRhYmxlTW9kdWxlfSBmcm9tICcuLi8uLi9kYXRhLXZpZXcvdGFibGUvZWxkZXItdGFibGUubW9kdWxlJztcbmltcG9ydCB7TWF0VGFibGVNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3RhYmxlJztcbmltcG9ydCB7TWF0U29ydE1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvc29ydCc7XG5pbXBvcnQge01hdElucHV0TW9kdWxlfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pbnB1dCc7XG5pbXBvcnQge1RyYW5zbGF0ZU1vZHVsZX0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSc7XG5pbXBvcnQge0Zvcm1zTW9kdWxlfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQge0VsZGVyTG9jYWxpemVkSW5wdXRUYWJsZUNvbXBvbmVudH0gZnJvbSAnLi9lbGRlci1sb2NhbGl6ZWQtaW5wdXQtdGFibGUvZWxkZXItbG9jYWxpemVkLWlucHV0LXRhYmxlLmNvbXBvbmVudCc7XG5pbXBvcnQge0VsZGVyTG9jYWxpemVkVGV4dENvbHVtbkRpcmVjdGl2ZX0gZnJvbSAnLi9lbGRlci1sb2NhbGl6ZWQtdGV4dC1jb2x1bW4uZGlyZWN0aXZlJztcbmltcG9ydCB7TWF0Q2hpcHNNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NoaXBzJztcbmltcG9ydCB7RWxkZXJDYXJkTW9kdWxlfSBmcm9tICcuLi8uLi9jYXJkcy9lbGRlci1jYXJkL2VsZGVyLWNhcmQubW9kdWxlJztcbmltcG9ydCB7IEVsZGVyTG9jYWxpemVkSW5wdXREaWFsb2dDb21wb25lbnQgfSBmcm9tICcuL2VsZGVyLWxvY2FsaXplZC1pbnB1dC1kaWFsb2cvZWxkZXItbG9jYWxpemVkLWlucHV0LWRpYWxvZy5jb21wb25lbnQnO1xuaW1wb3J0IHtNYXREaWFsb2dNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RpYWxvZyc7XG5pbXBvcnQge01hdEJ1dHRvbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uJztcbmltcG9ydCB7QTExeU1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY2RrL2ExMXknO1xuaW1wb3J0IHsgRWxkZXJMb2NhbGl6ZWRJbnB1dENvbXBvbmVudCB9IGZyb20gJy4vZWxkZXItbG9jYWxpemVkLWlucHV0L2VsZGVyLWxvY2FsaXplZC1pbnB1dC5jb21wb25lbnQnO1xuaW1wb3J0IHtNYXRJY29uTW9kdWxlfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pY29uJztcbmltcG9ydCB7RWxkZXJGb3Jtc01vZHVsZX0gZnJvbSAnLi4vLi4vZm9ybXMvZWxkZXItZm9ybXMubW9kdWxlJztcbmltcG9ydCB7TWF0VG9vbGJhck1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvdG9vbGJhcic7XG5pbXBvcnQgeyBJMThuUGlja0FzeW5jUGlwZSB9IGZyb20gJy4vcGlja2VyL2kxOG4tcGljay1hc3luYy5waXBlJztcbmltcG9ydCB7IEkxOG5QaWNrUGlwZSB9IGZyb20gJy4vcGlja2VyL2kxOG4tcGljay5waXBlJztcbmltcG9ydCB7IEVsZGVyTG9jYWxpemVkVGV4dHNEaXJlY3RpdmUgfSBmcm9tICcuL2VsZGVyLWxvY2FsaXplZC10ZXh0cy5kaXJlY3RpdmUnO1xuXG5leHBvcnQgKiBmcm9tICcuL2VsZGVyLWxvY2FsaXplZC10ZXh0LWNvbHVtbi5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9lbGRlci1sb2NhbGl6ZWQtdGV4dHMuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vZWxkZXItbG9jYWxpemVkLWlucHV0LXRhYmxlL2VsZGVyLWxvY2FsaXplZC1pbnB1dC10YWJsZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9lbGRlci1sb2NhbGl6ZWQtaW5wdXQtZGlhbG9nL2VsZGVyLWxvY2FsaXplZC1pbnB1dC1kaWFsb2cuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZWxkZXItbG9jYWxpemVkLWlucHV0LWRpYWxvZy5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vZWxkZXItbG9jYWxpemVkLWlucHV0L2VsZGVyLWxvY2FsaXplZC1pbnB1dC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9waWNrZXIvbG9jYWxpc2F0aW9uLXBpY2tlci5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vcGlja2VyL2kxOG4tcGljay5waXBlJztcbmV4cG9ydCAqIGZyb20gJy4vcGlja2VyL2kxOG4tcGljay1hc3luYy5waXBlJztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgRWxkZXJMb2NhbGl6ZWRUZXh0Q29sdW1uRGlyZWN0aXZlLFxuICAgIEVsZGVyTG9jYWxpemVkVGV4dHNEaXJlY3RpdmUsXG4gICAgRWxkZXJMb2NhbGl6ZWRJbnB1dFRhYmxlQ29tcG9uZW50LFxuICAgIEVsZGVyTG9jYWxpemVkSW5wdXREaWFsb2dDb21wb25lbnQsXG4gICAgRWxkZXJMb2NhbGl6ZWRJbnB1dENvbXBvbmVudCxcbiAgICBJMThuUGlja1BpcGUsXG4gICAgSTE4blBpY2tBc3luY1BpcGUsXG5cbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIEVsZGVyTG9jYWxpemVkVGV4dENvbHVtbkRpcmVjdGl2ZSxcbiAgICBFbGRlckxvY2FsaXplZFRleHRzRGlyZWN0aXZlLFxuICAgIEVsZGVyTG9jYWxpemVkSW5wdXRUYWJsZUNvbXBvbmVudCxcbiAgICBFbGRlckxvY2FsaXplZElucHV0RGlhbG9nQ29tcG9uZW50LFxuICAgIEVsZGVyTG9jYWxpemVkSW5wdXRDb21wb25lbnQsXG4gICAgSTE4blBpY2tQaXBlLFxuICAgIEkxOG5QaWNrQXN5bmNQaXBlXG4gIF0sXG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgTWF0VGFibGVNb2R1bGUsXG4gICAgTWF0U29ydE1vZHVsZSxcbiAgICBNYXRJbnB1dE1vZHVsZSxcbiAgICBUcmFuc2xhdGVNb2R1bGUsXG4gICAgRm9ybXNNb2R1bGUsXG5cbiAgICBFbGRlclRhYmxlTW9kdWxlLFxuICAgIE1hdENoaXBzTW9kdWxlLFxuICAgIEVsZGVyQ2FyZE1vZHVsZSxcbiAgICBNYXREaWFsb2dNb2R1bGUsXG4gICAgTWF0QnV0dG9uTW9kdWxlLFxuICAgIEExMXlNb2R1bGUsXG4gICAgTWF0SWNvbk1vZHVsZSxcbiAgICBFbGRlckZvcm1zTW9kdWxlLFxuICAgIE1hdFRvb2xiYXJNb2R1bGUsXG4gIF1cbn0pXG5leHBvcnQgY2xhc3MgRWxkZXJJMThuRW50aXRpZXNNb2R1bGUgeyB9XG4iXX0=
123
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItaTE4bi1lbnRpdGllcy5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21wb25lbnRzL2kxOG4vZW50aXRpZXMvZWxkZXItaTE4bi1lbnRpdGllcy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sMENBQTBDLENBQUM7QUFDMUUsT0FBTyxFQUFDLGNBQWMsRUFBQyxNQUFNLHlCQUF5QixDQUFDO0FBQ3ZELE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSx3QkFBd0IsQ0FBQztBQUNyRCxPQUFPLEVBQUMsY0FBYyxFQUFDLE1BQU0seUJBQXlCLENBQUM7QUFDdkQsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLHFCQUFxQixDQUFDO0FBQ3BELE9BQU8sRUFBQyxXQUFXLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQztBQUMzQyxPQUFPLEVBQUMsaUNBQWlDLEVBQUMsTUFBTSxxRUFBcUUsQ0FBQztBQUN0SCxPQUFPLEVBQUMsaUNBQWlDLEVBQUMsTUFBTSx5Q0FBeUMsQ0FBQztBQUMxRixPQUFPLEVBQUMsY0FBYyxFQUFDLE1BQU0seUJBQXlCLENBQUM7QUFDdkQsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLDBDQUEwQyxDQUFDO0FBQ3pFLE9BQU8sRUFBRSxrQ0FBa0MsRUFBRSxNQUFNLHVFQUF1RSxDQUFDO0FBQzNILE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSwwQkFBMEIsQ0FBQztBQUN6RCxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sMEJBQTBCLENBQUM7QUFDekQsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLG1CQUFtQixDQUFDO0FBQzdDLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLHlEQUF5RCxDQUFDO0FBQ3ZHLE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSx3QkFBd0IsQ0FBQztBQUNyRCxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNoRSxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSwyQkFBMkIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUNsRSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDdkQsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFDakYsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sZ0NBQWdDLENBQUM7O0FBRWhFLGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYyxtQ0FBbUMsQ0FBQztBQUNsRCxjQUFjLHFFQUFxRSxDQUFDO0FBQ3BGLGNBQWMsdUVBQXVFLENBQUM7QUFDdEYsY0FBYyx3Q0FBd0MsQ0FBQztBQUN2RCxjQUFjLHlEQUF5RCxDQUFDO0FBQ3hFLGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLCtCQUErQixDQUFDO0FBMEM5QyxNQUFNLE9BQU8sdUJBQXVCOztvSEFBdkIsdUJBQXVCO3FIQUF2Qix1QkFBdUIsaUJBdENoQyxpQ0FBaUM7UUFDakMsNEJBQTRCO1FBQzVCLGlDQUFpQztRQUNqQyxrQ0FBa0M7UUFDbEMsNEJBQTRCO1FBQzVCLFlBQVk7UUFDWixpQkFBaUIsYUFhYixZQUFZO1FBQ1osY0FBYztRQUNkLGFBQWE7UUFDYixjQUFjO1FBQ2QsZUFBZTtRQUNmLFdBQVc7UUFFWCxnQkFBZ0I7UUFDaEIsY0FBYztRQUNkLGVBQWU7UUFDZixlQUFlO1FBQ2YsZUFBZTtRQUNmLFVBQVU7UUFDVixhQUFhO1FBQ2IsZ0JBQWdCO1FBQ2hCLGdCQUFnQjtRQUNoQixnQkFBZ0IsYUF6QnBCLGlDQUFpQztRQUNqQyw0QkFBNEI7UUFDNUIsaUNBQWlDO1FBQ2pDLGtDQUFrQztRQUNsQyw0QkFBNEI7UUFDNUIsWUFBWTtRQUNaLGlCQUFpQjtxSEFzQlIsdUJBQXVCLFlBbkI1QixZQUFZO1FBQ1osY0FBYztRQUNkLGFBQWE7UUFDYixjQUFjO1FBQ2QsZUFBZTtRQUNmLFdBQVc7UUFFWCxnQkFBZ0I7UUFDaEIsY0FBYztRQUNkLGVBQWU7UUFDZixlQUFlO1FBQ2YsZUFBZTtRQUNmLFVBQVU7UUFDVixhQUFhO1FBQ2IsZ0JBQWdCO1FBQ2hCLGdCQUFnQjtRQUNoQixnQkFBZ0I7MkZBR1gsdUJBQXVCO2tCQXhDbkMsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUU7d0JBQ1osaUNBQWlDO3dCQUNqQyw0QkFBNEI7d0JBQzVCLGlDQUFpQzt3QkFDakMsa0NBQWtDO3dCQUNsQyw0QkFBNEI7d0JBQzVCLFlBQVk7d0JBQ1osaUJBQWlCO3FCQUVsQjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsaUNBQWlDO3dCQUNqQyw0QkFBNEI7d0JBQzVCLGlDQUFpQzt3QkFDakMsa0NBQWtDO3dCQUNsQyw0QkFBNEI7d0JBQzVCLFlBQVk7d0JBQ1osaUJBQWlCO3FCQUNsQjtvQkFDQyxPQUFPLEVBQUU7d0JBQ0wsWUFBWTt3QkFDWixjQUFjO3dCQUNkLGFBQWE7d0JBQ2IsY0FBYzt3QkFDZCxlQUFlO3dCQUNmLFdBQVc7d0JBRVgsZ0JBQWdCO3dCQUNoQixjQUFjO3dCQUNkLGVBQWU7d0JBQ2YsZUFBZTt3QkFDZixlQUFlO3dCQUNmLFVBQVU7d0JBQ1YsYUFBYTt3QkFDYixnQkFBZ0I7d0JBQ2hCLGdCQUFnQjt3QkFDaEIsZ0JBQWdCO3FCQUNuQjtpQkFDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtFbGRlclRhYmxlTW9kdWxlfSBmcm9tICcuLi8uLi9kYXRhLXZpZXcvdGFibGUvZWxkZXItdGFibGUubW9kdWxlJztcbmltcG9ydCB7TWF0VGFibGVNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3RhYmxlJztcbmltcG9ydCB7TWF0U29ydE1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvc29ydCc7XG5pbXBvcnQge01hdElucHV0TW9kdWxlfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pbnB1dCc7XG5pbXBvcnQge1RyYW5zbGF0ZU1vZHVsZX0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSc7XG5pbXBvcnQge0Zvcm1zTW9kdWxlfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQge0VsZGVyTG9jYWxpemVkSW5wdXRUYWJsZUNvbXBvbmVudH0gZnJvbSAnLi9lbGRlci1sb2NhbGl6ZWQtaW5wdXQtdGFibGUvZWxkZXItbG9jYWxpemVkLWlucHV0LXRhYmxlLmNvbXBvbmVudCc7XG5pbXBvcnQge0VsZGVyTG9jYWxpemVkVGV4dENvbHVtbkRpcmVjdGl2ZX0gZnJvbSAnLi9lbGRlci1sb2NhbGl6ZWQtdGV4dC1jb2x1bW4uZGlyZWN0aXZlJztcbmltcG9ydCB7TWF0Q2hpcHNNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NoaXBzJztcbmltcG9ydCB7RWxkZXJDYXJkTW9kdWxlfSBmcm9tICcuLi8uLi9jYXJkcy9lbGRlci1jYXJkL2VsZGVyLWNhcmQubW9kdWxlJztcbmltcG9ydCB7IEVsZGVyTG9jYWxpemVkSW5wdXREaWFsb2dDb21wb25lbnQgfSBmcm9tICcuL2VsZGVyLWxvY2FsaXplZC1pbnB1dC1kaWFsb2cvZWxkZXItbG9jYWxpemVkLWlucHV0LWRpYWxvZy5jb21wb25lbnQnO1xuaW1wb3J0IHtNYXREaWFsb2dNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RpYWxvZyc7XG5pbXBvcnQge01hdEJ1dHRvbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uJztcbmltcG9ydCB7QTExeU1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY2RrL2ExMXknO1xuaW1wb3J0IHsgRWxkZXJMb2NhbGl6ZWRJbnB1dENvbXBvbmVudCB9IGZyb20gJy4vZWxkZXItbG9jYWxpemVkLWlucHV0L2VsZGVyLWxvY2FsaXplZC1pbnB1dC5jb21wb25lbnQnO1xuaW1wb3J0IHtNYXRJY29uTW9kdWxlfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pY29uJztcbmltcG9ydCB7RWxkZXJGb3Jtc01vZHVsZX0gZnJvbSAnLi4vLi4vZm9ybXMvZWxkZXItZm9ybXMubW9kdWxlJztcbmltcG9ydCB7TWF0VG9vbGJhck1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvdG9vbGJhcic7XG5pbXBvcnQgeyBJMThuUGlja0FzeW5jUGlwZSB9IGZyb20gJy4vcGlja2VyL2kxOG4tcGljay1hc3luYy5waXBlJztcbmltcG9ydCB7IEkxOG5QaWNrUGlwZSB9IGZyb20gJy4vcGlja2VyL2kxOG4tcGljay5waXBlJztcbmltcG9ydCB7IEVsZGVyTG9jYWxpemVkVGV4dHNEaXJlY3RpdmUgfSBmcm9tICcuL2VsZGVyLWxvY2FsaXplZC10ZXh0cy5kaXJlY3RpdmUnO1xuaW1wb3J0IHtFbGRlclRoZW1lTW9kdWxlfSBmcm9tICcuLi8uLi90aGVtZS9lbGRlci10aGVtZS5tb2R1bGUnO1xuXG5leHBvcnQgKiBmcm9tICcuL2VsZGVyLWxvY2FsaXplZC10ZXh0LWNvbHVtbi5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9lbGRlci1sb2NhbGl6ZWQtdGV4dHMuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vZWxkZXItbG9jYWxpemVkLWlucHV0LXRhYmxlL2VsZGVyLWxvY2FsaXplZC1pbnB1dC10YWJsZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9lbGRlci1sb2NhbGl6ZWQtaW5wdXQtZGlhbG9nL2VsZGVyLWxvY2FsaXplZC1pbnB1dC1kaWFsb2cuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZWxkZXItbG9jYWxpemVkLWlucHV0LWRpYWxvZy5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vZWxkZXItbG9jYWxpemVkLWlucHV0L2VsZGVyLWxvY2FsaXplZC1pbnB1dC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9waWNrZXIvbG9jYWxpc2F0aW9uLXBpY2tlci5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vcGlja2VyL2kxOG4tcGljay5waXBlJztcbmV4cG9ydCAqIGZyb20gJy4vcGlja2VyL2kxOG4tcGljay1hc3luYy5waXBlJztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgRWxkZXJMb2NhbGl6ZWRUZXh0Q29sdW1uRGlyZWN0aXZlLFxuICAgIEVsZGVyTG9jYWxpemVkVGV4dHNEaXJlY3RpdmUsXG4gICAgRWxkZXJMb2NhbGl6ZWRJbnB1dFRhYmxlQ29tcG9uZW50LFxuICAgIEVsZGVyTG9jYWxpemVkSW5wdXREaWFsb2dDb21wb25lbnQsXG4gICAgRWxkZXJMb2NhbGl6ZWRJbnB1dENvbXBvbmVudCxcbiAgICBJMThuUGlja1BpcGUsXG4gICAgSTE4blBpY2tBc3luY1BpcGUsXG5cbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIEVsZGVyTG9jYWxpemVkVGV4dENvbHVtbkRpcmVjdGl2ZSxcbiAgICBFbGRlckxvY2FsaXplZFRleHRzRGlyZWN0aXZlLFxuICAgIEVsZGVyTG9jYWxpemVkSW5wdXRUYWJsZUNvbXBvbmVudCxcbiAgICBFbGRlckxvY2FsaXplZElucHV0RGlhbG9nQ29tcG9uZW50LFxuICAgIEVsZGVyTG9jYWxpemVkSW5wdXRDb21wb25lbnQsXG4gICAgSTE4blBpY2tQaXBlLFxuICAgIEkxOG5QaWNrQXN5bmNQaXBlXG4gIF0sXG4gICAgaW1wb3J0czogW1xuICAgICAgICBDb21tb25Nb2R1bGUsXG4gICAgICAgIE1hdFRhYmxlTW9kdWxlLFxuICAgICAgICBNYXRTb3J0TW9kdWxlLFxuICAgICAgICBNYXRJbnB1dE1vZHVsZSxcbiAgICAgICAgVHJhbnNsYXRlTW9kdWxlLFxuICAgICAgICBGb3Jtc01vZHVsZSxcblxuICAgICAgICBFbGRlclRhYmxlTW9kdWxlLFxuICAgICAgICBNYXRDaGlwc01vZHVsZSxcbiAgICAgICAgRWxkZXJDYXJkTW9kdWxlLFxuICAgICAgICBNYXREaWFsb2dNb2R1bGUsXG4gICAgICAgIE1hdEJ1dHRvbk1vZHVsZSxcbiAgICAgICAgQTExeU1vZHVsZSxcbiAgICAgICAgTWF0SWNvbk1vZHVsZSxcbiAgICAgICAgRWxkZXJGb3Jtc01vZHVsZSxcbiAgICAgICAgTWF0VG9vbGJhck1vZHVsZSxcbiAgICAgICAgRWxkZXJUaGVtZU1vZHVsZSxcbiAgICBdXG59KVxuZXhwb3J0IGNsYXNzIEVsZGVySTE4bkVudGl0aWVzTW9kdWxlIHsgfVxuIl19
@@ -1,4 +1,4 @@
1
- import { Component, ChangeDetectionStrategy, ContentChildren, Input } from '@angular/core';
1
+ import { Component, ChangeDetectionStrategy, ContentChildren, Input, Output } from '@angular/core';
2
2
  import { FormFieldBaseComponent } from '../../../../common/forms/form-field-base.component';
3
3
  import { LoggerFactory } from '@elderbyte/ts-logger';
4
4
  import { BehaviorSubject, combineLatest, Subject } from 'rxjs';
@@ -6,6 +6,7 @@ import { map, switchMap } from 'rxjs/operators';
6
6
  import { ElderLocalizedTextColumnDirective } from '../elder-localized-text-column.directive';
7
7
  import { QueryListBinding } from '../../../../common/utils/query-list-binding';
8
8
  import { buildFormIntegrationProviders } from '../../../../common/forms/template-composite-control';
9
+ import { TranslatedConverter } from '../../../../common/i18n/entity/translated-converter';
9
10
  import * as i0 from "@angular/core";
10
11
  import * as i1 from "../elder-localized-input-dialog.service";
11
12
  import * as i2 from "../picker/localisation-picker.service";
@@ -42,6 +43,7 @@ export class ElderLocalizedInputComponent extends FormFieldBaseComponent {
42
43
  this.textColumns$
43
44
  ]).pipe(switchMap(([values, columns]) => this.toInputText(values, columns)));
44
45
  this.hintText$ = this.value$.pipe(map(values => this.toHintText(values)));
46
+ this.translatedValueChange = this.valueChange.pipe(map(localized => TranslatedConverter.toTranslatedText(localized)));
45
47
  }
46
48
  /***************************************************************************
47
49
  * *
@@ -75,6 +77,9 @@ export class ElderLocalizedInputComponent extends FormFieldBaseComponent {
75
77
  get textColumns() {
76
78
  return this.textColumns$.getValue();
77
79
  }
80
+ set translatedValue(translated) {
81
+ this.value = TranslatedConverter.toI18nText(translated);
82
+ }
78
83
  /***************************************************************************
79
84
  * *
80
85
  * Public API *
@@ -122,14 +127,18 @@ export class ElderLocalizedInputComponent extends FormFieldBaseComponent {
122
127
  }
123
128
  }
124
129
  ElderLocalizedInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: ElderLocalizedInputComponent, deps: [{ token: i1.ElderLocalizedInputDialogService }, { token: i2.LocalisationPickerService }], target: i0.ɵɵFactoryTarget.Component });
125
- ElderLocalizedInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: ElderLocalizedInputComponent, selector: "elder-localized-input", inputs: { textColumns: "textColumns" }, host: { classAttribute: "elder-form-field-host" }, providers: buildFormIntegrationProviders(ElderLocalizedInputComponent), queries: [{ propertyName: "textColumnsQuery", predicate: ElderLocalizedTextColumnDirective }], usesInheritance: true, ngImport: i0, template: "<mat-form-field [appearance]=\"appearance\"\n [color]=\"color\"\n>\n <mat-label *ngIf=\"label\">{{label | translate}}</mat-label>\n\n <mat-icon matPrefix *ngIf=\"icon\"\n [color]=\"color\">\n {{icon}}\n </mat-icon>\n\n <button matSuffix mat-icon-button\n (click)=\"openTranslationPopup($event)\" aria-label=\"Search\"\n elderStopEventPropagation\n tabIndex=\"-1\"\n >\n <mat-icon>translate</mat-icon>\n </button>\n\n <!-- A dynamic input -->\n <input\n matInput type=\"text\"\n [disabled]=\"disabled\"\n [required]=\"required\"\n readonly\n [name]=\"name + '-localized'\"\n [ngModel]=\"inputText$ | async\" [ngModelOptions]=\"{standalone: true}\"\n >\n\n <mat-hint>{{hintText$ | async}}</mat-hint>\n\n</mat-form-field>\n", styles: [".prefix-padding{padding-right:4px}.leading-icon{font-size:16px;width:16px;height:16px}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i5.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i5.MatLabel, selector: "mat-label" }, { kind: "directive", type: i5.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i5.MatPrefix, selector: "[matPrefix], [matIconPrefix], [matTextPrefix]", inputs: ["matTextPrefix"] }, { kind: "directive", type: i5.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "directive", type: i6.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: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i7.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i8.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i9.ElderStopEventPropagationDirective, selector: "[elderStopEventPropagation]" }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i10.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
130
+ ElderLocalizedInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: ElderLocalizedInputComponent, selector: "elder-localized-input", inputs: { textColumns: "textColumns", translatedValue: "translatedValue" }, outputs: { translatedValueChange: "translatedValueChange" }, host: { classAttribute: "elder-form-field-host" }, providers: buildFormIntegrationProviders(ElderLocalizedInputComponent), queries: [{ propertyName: "textColumnsQuery", predicate: ElderLocalizedTextColumnDirective }], usesInheritance: true, ngImport: i0, template: "<mat-form-field [appearance]=\"appearance\"\n [color]=\"color\"\n>\n <mat-label *ngIf=\"label\">{{label | translate}}</mat-label>\n\n <mat-icon matPrefix *ngIf=\"icon\"\n [color]=\"color\">\n {{icon}}\n </mat-icon>\n\n <button matSuffix mat-icon-button\n (click)=\"openTranslationPopup($event)\" aria-label=\"Search\"\n elderStopEventPropagation\n tabIndex=\"-1\"\n >\n <mat-icon>translate</mat-icon>\n </button>\n\n <!-- A dynamic input -->\n <input\n matInput type=\"text\"\n [disabled]=\"disabled\"\n [required]=\"required\"\n readonly\n [name]=\"name + '-localized'\"\n [ngModel]=\"inputText$ | async\" [ngModelOptions]=\"{standalone: true}\"\n >\n\n <mat-hint>{{hintText$ | async}}</mat-hint>\n\n</mat-form-field>\n", styles: [".prefix-padding{padding-right:4px}.leading-icon{font-size:16px;width:16px;height:16px}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i5.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i5.MatLabel, selector: "mat-label" }, { kind: "directive", type: i5.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i5.MatPrefix, selector: "[matPrefix], [matIconPrefix], [matTextPrefix]", inputs: ["matTextPrefix"] }, { kind: "directive", type: i5.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "directive", type: i6.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: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i7.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i8.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i9.ElderStopEventPropagationDirective, selector: "[elderStopEventPropagation]" }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i10.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
126
131
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: ElderLocalizedInputComponent, decorators: [{
127
132
  type: Component,
128
133
  args: [{ selector: 'elder-localized-input', changeDetection: ChangeDetectionStrategy.OnPush, host: { 'class': 'elder-form-field-host' }, providers: buildFormIntegrationProviders(ElderLocalizedInputComponent), template: "<mat-form-field [appearance]=\"appearance\"\n [color]=\"color\"\n>\n <mat-label *ngIf=\"label\">{{label | translate}}</mat-label>\n\n <mat-icon matPrefix *ngIf=\"icon\"\n [color]=\"color\">\n {{icon}}\n </mat-icon>\n\n <button matSuffix mat-icon-button\n (click)=\"openTranslationPopup($event)\" aria-label=\"Search\"\n elderStopEventPropagation\n tabIndex=\"-1\"\n >\n <mat-icon>translate</mat-icon>\n </button>\n\n <!-- A dynamic input -->\n <input\n matInput type=\"text\"\n [disabled]=\"disabled\"\n [required]=\"required\"\n readonly\n [name]=\"name + '-localized'\"\n [ngModel]=\"inputText$ | async\" [ngModelOptions]=\"{standalone: true}\"\n >\n\n <mat-hint>{{hintText$ | async}}</mat-hint>\n\n</mat-form-field>\n", styles: [".prefix-padding{padding-right:4px}.leading-icon{font-size:16px;width:16px;height:16px}\n"] }]
129
134
  }], ctorParameters: function () { return [{ type: i1.ElderLocalizedInputDialogService }, { type: i2.LocalisationPickerService }]; }, propDecorators: { textColumnsQuery: [{
130
135
  type: ContentChildren,
131
136
  args: [ElderLocalizedTextColumnDirective]
137
+ }], translatedValueChange: [{
138
+ type: Output
132
139
  }], textColumns: [{
133
140
  type: Input
141
+ }], translatedValue: [{
142
+ type: Input
134
143
  }] } });
135
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-localized-input.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/i18n/entities/elder-localized-input/elder-localized-input.component.ts","../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/i18n/entities/elder-localized-input/elder-localized-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, OnInit, ChangeDetectionStrategy, ContentChildren, QueryList, Input, AfterViewInit, OnDestroy} from '@angular/core';\nimport {FormFieldBaseComponent} from '../../../../common/forms/form-field-base.component';\nimport {Localized} from '../../../../common/i18n/entity/localized';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {BehaviorSubject, combineLatest, Observable, of, Subject} from 'rxjs';\nimport {filter, map, switchMap} from 'rxjs/operators';\nimport {ElderLocalizedInputDialogService} from '../elder-localized-input-dialog.service';\nimport {ElderLocalizedTextColumnDirective} from '../elder-localized-text-column.directive';\nimport {QueryListBinding} from '../../../../common/utils/query-list-binding';\nimport {LocalisationPickerService} from '../picker/localisation-picker.service';\nimport {ElderLocalizedInputOptions} from '../elder-localized-input-dialog/elder-localized-input-dialog.component';\nimport {buildFormIntegrationProviders} from '../../../../common/forms/template-composite-control';\nimport {AbstractControl, ValidationErrors} from '@angular/forms';\n\n@Component({\n  selector: 'elder-localized-input',\n  templateUrl: './elder-localized-input.component.html',\n  styleUrls: ['./elder-localized-input.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  // eslint-disable-next-line @angular-eslint/no-host-metadata-property\n  host: {'class': 'elder-form-field-host'},\n  providers: buildFormIntegrationProviders(ElderLocalizedInputComponent)\n})\nexport class ElderLocalizedInputComponent<T extends Localized = Localized>\n  extends FormFieldBaseComponent<T[]> implements OnInit, AfterViewInit, OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  public readonly inputText$: Observable<string>;\n  public readonly hintText$: Observable<string>;\n\n  @ContentChildren(ElderLocalizedTextColumnDirective)\n  public textColumnsQuery: QueryList<ElderLocalizedTextColumnDirective>;\n  public readonly textColumns$ = new BehaviorSubject<ElderLocalizedTextColumnDirective[]>([\n    ElderLocalizedTextColumnDirective.DEFAULT_TEXT_COL\n  ]);\n\n  private readonly destroy$ = new Subject<void>();\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private readonly localizedInputDialog: ElderLocalizedInputDialogService,\n    private readonly localisationPicker: LocalisationPickerService\n  ) {\n    super();\n\n    this.inputText$ = combineLatest([\n      this.value$,\n      this.textColumns$\n    ]).pipe(\n       switchMap(([values, columns]) => this.toInputText(values, columns))\n    );\n\n    this.hintText$ = this.value$.pipe(\n      map(values => this.toHintText(values))\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n\n  }\n\n  public ngAfterViewInit(): void {\n    QueryListBinding\n      .of(this.textColumnsQuery)\n      .updated(columns => {\n        if (columns?.length > 0) {\n          this.textColumns$.next(columns);\n        }\n      })\n      .bindUntil(this.destroy$);\n  }\n\n  public ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set textColumns(cols: ElderLocalizedTextColumnDirective[]) {\n    this.textColumns$.next(cols);\n  }\n\n  public get textColumns(): ElderLocalizedTextColumnDirective[] {\n    return this.textColumns$.getValue();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public openTranslationPopup(\n    $event: MouseEvent,\n  ) {\n\n    const data = <ElderLocalizedInputOptions<T>>{\n      title: this.label ?? this.placeholder,\n      localizables: this.value,\n      textColumns: this.textColumns,\n      explicitSave: false,\n      readonly: this.readonly,\n      disabled: this.disabled,\n      required: this.required\n    };\n\n    const dlgRef = this.localizedInputDialog.editLocalized(\n      data\n    ).subscribe(\n      updated => this.updateValue(data.localizables)\n    );\n  }\n\n\n  public validate(c: AbstractControl): ValidationErrors | null {\n    let result = null;\n    if (this.required && !(this.value?.length > 0)) {\n      result = {\n        required: { valid: false }\n      };\n    }\n    return result;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private toInputText(\n    localizables: T[],\n    columns: ElderLocalizedTextColumnDirective[]\n  ): Observable<string | undefined> {\n    return this.localisationPicker.pickCurrentText(\n      localizables,\n      this.displayTextField(columns)\n    );\n  }\n\n  private displayTextField(\n    columns: ElderLocalizedTextColumnDirective[]\n  ): string | undefined {\n    return columns ? columns[0]?.name : undefined;\n  }\n\n  private toHintText(localizables: T[]): string {\n    if (localizables) {\n      return localizables.map(l => l.locale).join(', ');\n    } else {\n      return '';\n    }\n  }\n}\n","<mat-form-field [appearance]=\"appearance\"\n                [color]=\"color\"\n>\n  <mat-label *ngIf=\"label\">{{label | translate}}</mat-label>\n\n  <mat-icon matPrefix *ngIf=\"icon\"\n            [color]=\"color\">\n    {{icon}}\n  </mat-icon>\n\n  <button matSuffix mat-icon-button\n          (click)=\"openTranslationPopup($event)\" aria-label=\"Search\"\n          elderStopEventPropagation\n          tabIndex=\"-1\"\n  >\n    <mat-icon>translate</mat-icon>\n  </button>\n\n  <!-- A dynamic input -->\n  <input\n    matInput type=\"text\"\n    [disabled]=\"disabled\"\n    [required]=\"required\"\n    readonly\n    [name]=\"name + '-localized'\"\n    [ngModel]=\"inputText$ | async\" [ngModelOptions]=\"{standalone: true}\"\n  >\n\n  <mat-hint>{{hintText$ | async}}</mat-hint>\n\n</mat-form-field>\n"]}
144
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-localized-input.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/i18n/entities/elder-localized-input/elder-localized-input.component.ts","../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/i18n/entities/elder-localized-input/elder-localized-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  OnInit,\n  ChangeDetectionStrategy,\n  ContentChildren,\n  QueryList,\n  Input,\n  AfterViewInit,\n  OnDestroy,\n  Output\n} from '@angular/core';\nimport {FormFieldBaseComponent} from '../../../../common/forms/form-field-base.component';\nimport {Localized} from '../../../../common/i18n/entity/localized';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {BehaviorSubject, combineLatest, Observable, of, Subject} from 'rxjs';\nimport {filter, map, switchMap} from 'rxjs/operators';\nimport {ElderLocalizedInputDialogService} from '../elder-localized-input-dialog.service';\nimport {ElderLocalizedTextColumnDirective} from '../elder-localized-text-column.directive';\nimport {QueryListBinding} from '../../../../common/utils/query-list-binding';\nimport {LocalisationPickerService} from '../picker/localisation-picker.service';\nimport {ElderLocalizedInputOptions} from '../elder-localized-input-dialog/elder-localized-input-dialog.component';\nimport {buildFormIntegrationProviders} from '../../../../common/forms/template-composite-control';\nimport {AbstractControl, ValidationErrors} from '@angular/forms';\nimport {ITranslatedText} from '../../../../common/i18n/entity/translated';\nimport {TranslatedConverter} from '../../../../common/i18n/entity/translated-converter';\n\n@Component({\n  selector: 'elder-localized-input',\n  templateUrl: './elder-localized-input.component.html',\n  styleUrls: ['./elder-localized-input.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  // eslint-disable-next-line @angular-eslint/no-host-metadata-property\n  host: {'class': 'elder-form-field-host'},\n  providers: buildFormIntegrationProviders(ElderLocalizedInputComponent)\n})\nexport class ElderLocalizedInputComponent<T extends Localized = Localized>\n  extends FormFieldBaseComponent<T[]> implements OnInit, AfterViewInit, OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  public readonly inputText$: Observable<string>;\n  public readonly hintText$: Observable<string>;\n\n  @ContentChildren(ElderLocalizedTextColumnDirective)\n  public textColumnsQuery: QueryList<ElderLocalizedTextColumnDirective>;\n  public readonly textColumns$ = new BehaviorSubject<ElderLocalizedTextColumnDirective[]>([\n    ElderLocalizedTextColumnDirective.DEFAULT_TEXT_COL\n  ]);\n\n  @Output()\n  public readonly translatedValueChange: Observable<ITranslatedText>;\n\n  private readonly destroy$ = new Subject<void>();\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private readonly localizedInputDialog: ElderLocalizedInputDialogService,\n    private readonly localisationPicker: LocalisationPickerService\n  ) {\n    super();\n\n    this.inputText$ = combineLatest([\n      this.value$,\n      this.textColumns$\n    ]).pipe(\n       switchMap(([values, columns]) => this.toInputText(values, columns))\n    );\n\n    this.hintText$ = this.value$.pipe(\n      map(values => this.toHintText(values))\n    );\n\n    this.translatedValueChange = this.valueChange.pipe(\n      map(localized => TranslatedConverter.toTranslatedText(<any>localized))\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n\n  }\n\n  public ngAfterViewInit(): void {\n    QueryListBinding\n      .of(this.textColumnsQuery)\n      .updated(columns => {\n        if (columns?.length > 0) {\n          this.textColumns$.next(columns);\n        }\n      })\n      .bindUntil(this.destroy$);\n  }\n\n  public ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set textColumns(cols: ElderLocalizedTextColumnDirective[]) {\n    this.textColumns$.next(cols);\n  }\n\n  public get textColumns(): ElderLocalizedTextColumnDirective[] {\n    return this.textColumns$.getValue();\n  }\n\n  @Input()\n  public set translatedValue(translated: ITranslatedText){\n    this.value = <any>TranslatedConverter.toI18nText(translated);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public openTranslationPopup(\n    $event: MouseEvent,\n  ) {\n\n    const data = <ElderLocalizedInputOptions<T>>{\n      title: this.label ?? this.placeholder,\n      localizables: this.value,\n      textColumns: this.textColumns,\n      explicitSave: false,\n      readonly: this.readonly,\n      disabled: this.disabled,\n      required: this.required\n    };\n\n    const dlgRef = this.localizedInputDialog.editLocalized(\n      data\n    ).subscribe(\n      updated => this.updateValue(data.localizables)\n    );\n  }\n\n\n  public validate(c: AbstractControl): ValidationErrors | null {\n    let result = null;\n    if (this.required && !(this.value?.length > 0)) {\n      result = {\n        required: { valid: false }\n      };\n    }\n    return result;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private toInputText(\n    localizables: T[],\n    columns: ElderLocalizedTextColumnDirective[]\n  ): Observable<string | undefined> {\n    return this.localisationPicker.pickCurrentText(\n      localizables,\n      this.displayTextField(columns)\n    );\n  }\n\n  private displayTextField(\n    columns: ElderLocalizedTextColumnDirective[]\n  ): string | undefined {\n    return columns ? columns[0]?.name : undefined;\n  }\n\n  private toHintText(localizables: T[]): string {\n    if (localizables) {\n      return localizables.map(l => l.locale).join(', ');\n    } else {\n      return '';\n    }\n  }\n}\n","<mat-form-field [appearance]=\"appearance\"\n                [color]=\"color\"\n>\n  <mat-label *ngIf=\"label\">{{label | translate}}</mat-label>\n\n  <mat-icon matPrefix *ngIf=\"icon\"\n            [color]=\"color\">\n    {{icon}}\n  </mat-icon>\n\n  <button matSuffix mat-icon-button\n          (click)=\"openTranslationPopup($event)\" aria-label=\"Search\"\n          elderStopEventPropagation\n          tabIndex=\"-1\"\n  >\n    <mat-icon>translate</mat-icon>\n  </button>\n\n  <!-- A dynamic input -->\n  <input\n    matInput type=\"text\"\n    [disabled]=\"disabled\"\n    [required]=\"required\"\n    readonly\n    [name]=\"name + '-localized'\"\n    [ngModel]=\"inputText$ | async\" [ngModelOptions]=\"{standalone: true}\"\n  >\n\n  <mat-hint>{{hintText$ | async}}</mat-hint>\n\n</mat-form-field>\n"]}
@@ -7,7 +7,8 @@ import * as i3 from "@ngx-translate/core";
7
7
  import * as i4 from "@angular/material/button";
8
8
  import * as i5 from "@angular/material/icon";
9
9
  import * as i6 from "@angular/material/toolbar";
10
- import * as i7 from "../elder-localized-input-table/elder-localized-input-table.component";
10
+ import * as i7 from "../../../theme/elder-theme.directive";
11
+ import * as i8 from "../elder-localized-input-table/elder-localized-input-table.component";
11
12
  export class ElderLocalizedInputDialogComponent {
12
13
  constructor(dialogRef, data) {
13
14
  this.dialogRef = dialogRef;
@@ -17,12 +18,12 @@ export class ElderLocalizedInputDialogComponent {
17
18
  }
18
19
  }
19
20
  ElderLocalizedInputDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: ElderLocalizedInputDialogComponent, deps: [{ token: i1.MatDialogRef }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component });
20
- ElderLocalizedInputDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: ElderLocalizedInputDialogComponent, selector: "elder-localized-input-dialog", ngImport: i0, template: "\n<div class=\"layout-col full\">\n\n <mat-toolbar color=\"primary\">\n <mat-toolbar-row class=\"gap-sm\">\n <mat-icon class=\"noselect\">translate</mat-icon>\n <h2 class=\"noselect\" translate>{{data.title}}</h2>\n <span class=\"flex\"></span>\n <button *ngIf=\"data.explicitSave\"\n mat-icon-button type=\"submit\"\n [disabled]=\"data.readonly\"\n [mat-dialog-close]=\"data.localizables\"\n >\n <mat-icon>save</mat-icon>\n </button>\n </mat-toolbar-row>\n </mat-toolbar>\n\n <div class=\"layout-col flex p-sm\">\n <elder-localized-input-table\n [float]=\"true\" class=\"flex\"\n [textColumns]=\"data.textColumns\"\n [(value)]=\"data.localizables\"\n [readonly]=\"data.readonly\"\n [disabled]=\"data.disabled\"\n [required]=\"data.required\"\n >\n </elder-localized-input-table>\n </div>\n</div>\n\n\n\n\n\n\n", styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "directive", type: i1.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "component", type: i4.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i6.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { kind: "directive", type: i6.MatToolbarRow, selector: "mat-toolbar-row", exportAs: ["matToolbarRow"] }, { kind: "component", type: i7.ElderLocalizedInputTableComponent, selector: "elder-localized-input-table", inputs: ["dense", "float", "embedded", "textColumns", "defaultLanguageTags"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
21
+ ElderLocalizedInputDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: ElderLocalizedInputDialogComponent, selector: "elder-localized-input-dialog", ngImport: i0, template: "\n<div class=\"layout-col full\">\n\n <mat-toolbar elderTheme color=\"primary\">\n <mat-toolbar-row class=\"gap-sm\">\n <mat-icon class=\"noselect\">translate</mat-icon>\n <h2 class=\"noselect\" translate>{{data.title}}</h2>\n <span class=\"flex\"></span>\n <button *ngIf=\"data.explicitSave\"\n mat-icon-button type=\"submit\"\n [disabled]=\"data.readonly\"\n [mat-dialog-close]=\"data.localizables\"\n >\n <mat-icon>save</mat-icon>\n </button>\n </mat-toolbar-row>\n </mat-toolbar>\n\n <div class=\"layout-col flex p-sm\">\n <elder-localized-input-table\n [float]=\"true\" class=\"flex\"\n [textColumns]=\"data.textColumns\"\n [(value)]=\"data.localizables\"\n [readonly]=\"data.readonly\"\n [disabled]=\"data.disabled\"\n [required]=\"data.required\"\n >\n </elder-localized-input-table>\n </div>\n</div>\n\n\n\n\n\n\n", styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "directive", type: i1.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "component", type: i4.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i6.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { kind: "directive", type: i6.MatToolbarRow, selector: "mat-toolbar-row", exportAs: ["matToolbarRow"] }, { kind: "directive", type: i7.ElderThemeDirective, selector: "[elderTheme]" }, { kind: "component", type: i8.ElderLocalizedInputTableComponent, selector: "elder-localized-input-table", inputs: ["dense", "float", "embedded", "textColumns", "defaultLanguageTags"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
21
22
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: ElderLocalizedInputDialogComponent, decorators: [{
22
23
  type: Component,
23
- args: [{ selector: 'elder-localized-input-dialog', changeDetection: ChangeDetectionStrategy.OnPush, template: "\n<div class=\"layout-col full\">\n\n <mat-toolbar color=\"primary\">\n <mat-toolbar-row class=\"gap-sm\">\n <mat-icon class=\"noselect\">translate</mat-icon>\n <h2 class=\"noselect\" translate>{{data.title}}</h2>\n <span class=\"flex\"></span>\n <button *ngIf=\"data.explicitSave\"\n mat-icon-button type=\"submit\"\n [disabled]=\"data.readonly\"\n [mat-dialog-close]=\"data.localizables\"\n >\n <mat-icon>save</mat-icon>\n </button>\n </mat-toolbar-row>\n </mat-toolbar>\n\n <div class=\"layout-col flex p-sm\">\n <elder-localized-input-table\n [float]=\"true\" class=\"flex\"\n [textColumns]=\"data.textColumns\"\n [(value)]=\"data.localizables\"\n [readonly]=\"data.readonly\"\n [disabled]=\"data.disabled\"\n [required]=\"data.required\"\n >\n </elder-localized-input-table>\n </div>\n</div>\n\n\n\n\n\n\n" }]
24
+ args: [{ selector: 'elder-localized-input-dialog', changeDetection: ChangeDetectionStrategy.OnPush, template: "\n<div class=\"layout-col full\">\n\n <mat-toolbar elderTheme color=\"primary\">\n <mat-toolbar-row class=\"gap-sm\">\n <mat-icon class=\"noselect\">translate</mat-icon>\n <h2 class=\"noselect\" translate>{{data.title}}</h2>\n <span class=\"flex\"></span>\n <button *ngIf=\"data.explicitSave\"\n mat-icon-button type=\"submit\"\n [disabled]=\"data.readonly\"\n [mat-dialog-close]=\"data.localizables\"\n >\n <mat-icon>save</mat-icon>\n </button>\n </mat-toolbar-row>\n </mat-toolbar>\n\n <div class=\"layout-col flex p-sm\">\n <elder-localized-input-table\n [float]=\"true\" class=\"flex\"\n [textColumns]=\"data.textColumns\"\n [(value)]=\"data.localizables\"\n [readonly]=\"data.readonly\"\n [disabled]=\"data.disabled\"\n [required]=\"data.required\"\n >\n </elder-localized-input-table>\n </div>\n</div>\n\n\n\n\n\n\n" }]
24
25
  }], ctorParameters: function () { return [{ type: i1.MatDialogRef }, { type: undefined, decorators: [{
25
26
  type: Inject,
26
27
  args: [MAT_DIALOG_DATA]
27
28
  }] }]; } });
28
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItbG9jYWxpemVkLWlucHV0LWRpYWxvZy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21wb25lbnRzL2kxOG4vZW50aXRpZXMvZWxkZXItbG9jYWxpemVkLWlucHV0LWRpYWxvZy9lbGRlci1sb2NhbGl6ZWQtaW5wdXQtZGlhbG9nLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VsZGVyYnl0ZS9uZ3gtc3RhcnRlci9zcmMvbGliL2NvbXBvbmVudHMvaTE4bi9lbnRpdGllcy9lbGRlci1sb2NhbGl6ZWQtaW5wdXQtZGlhbG9nL2VsZGVyLWxvY2FsaXplZC1pbnB1dC1kaWFsb2cuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBVSx1QkFBdUIsRUFBRSxNQUFNLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDakYsT0FBTyxFQUFDLGVBQWUsRUFBZSxNQUFNLDBCQUEwQixDQUFDOzs7Ozs7Ozs7QUFxQnZFLE1BQU0sT0FBTyxrQ0FBa0M7SUFFN0MsWUFDUyxTQUEyRCxFQUNsQyxJQUFnQztRQUR6RCxjQUFTLEdBQVQsU0FBUyxDQUFrRDtRQUNsQyxTQUFJLEdBQUosSUFBSSxDQUE0QjtJQUM5RCxDQUFDO0lBRUwsUUFBUTtJQUNSLENBQUM7OytIQVJVLGtDQUFrQyw4Q0FJbkMsZUFBZTttSEFKZCxrQ0FBa0Msb0VDdEIvQyx5NkJBb0NBOzJGRGRhLGtDQUFrQztrQkFOOUMsU0FBUzsrQkFDRSw4QkFBOEIsbUJBR3ZCLHVCQUF1QixDQUFDLE1BQU07OzBCQU01QyxNQUFNOzJCQUFDLGVBQWUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgT25Jbml0LCBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgSW5qZWN0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7TUFUX0RJQUxPR19EQVRBLCBNYXREaWFsb2dSZWZ9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RpYWxvZyc7XG5pbXBvcnQge0VsZGVyTG9jYWxpemVkVGV4dENvbHVtbkRpcmVjdGl2ZX0gZnJvbSAnLi4vZWxkZXItbG9jYWxpemVkLXRleHQtY29sdW1uLmRpcmVjdGl2ZSc7XG5pbXBvcnQge0xvY2FsaXplZH0gZnJvbSAnLi4vLi4vLi4vLi4vY29tbW9uL2kxOG4vZW50aXR5L2xvY2FsaXplZCc7XG5cblxuZXhwb3J0IGludGVyZmFjZSBFbGRlckxvY2FsaXplZElucHV0T3B0aW9uczxUIGV4dGVuZHMgTG9jYWxpemVkID0gTG9jYWxpemVkPiB7XG4gIHRpdGxlOiBzdHJpbmc7XG4gIGxvY2FsaXphYmxlczogVFtdO1xuICB0ZXh0Q29sdW1uczogRWxkZXJMb2NhbGl6ZWRUZXh0Q29sdW1uRGlyZWN0aXZlW107XG4gIGV4cGxpY2l0U2F2ZTogYm9vbGVhbjtcbiAgcmVhZG9ubHk/OiBib29sZWFuO1xuICBkaXNhYmxlZD86IGJvb2xlYW47XG4gIHJlcXVpcmVkPzogYm9vbGVhbjtcbn1cblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZWxkZXItbG9jYWxpemVkLWlucHV0LWRpYWxvZycsXG4gIHRlbXBsYXRlVXJsOiAnLi9lbGRlci1sb2NhbGl6ZWQtaW5wdXQtZGlhbG9nLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZWxkZXItbG9jYWxpemVkLWlucHV0LWRpYWxvZy5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBFbGRlckxvY2FsaXplZElucHV0RGlhbG9nQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwdWJsaWMgZGlhbG9nUmVmOiBNYXREaWFsb2dSZWY8RWxkZXJMb2NhbGl6ZWRJbnB1dERpYWxvZ0NvbXBvbmVudD4sXG4gICAgQEluamVjdChNQVRfRElBTE9HX0RBVEEpIHB1YmxpYyBkYXRhOiBFbGRlckxvY2FsaXplZElucHV0T3B0aW9uc1xuICApIHsgfVxuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICB9XG5cbn1cbiIsIlxuPGRpdiBjbGFzcz1cImxheW91dC1jb2wgZnVsbFwiPlxuXG4gIDxtYXQtdG9vbGJhciBjb2xvcj1cInByaW1hcnlcIj5cbiAgICA8bWF0LXRvb2xiYXItcm93IGNsYXNzPVwiZ2FwLXNtXCI+XG4gICAgICA8bWF0LWljb24gY2xhc3M9XCJub3NlbGVjdFwiPnRyYW5zbGF0ZTwvbWF0LWljb24+XG4gICAgICA8aDIgY2xhc3M9XCJub3NlbGVjdFwiIHRyYW5zbGF0ZT57e2RhdGEudGl0bGV9fTwvaDI+XG4gICAgICA8c3BhbiBjbGFzcz1cImZsZXhcIj48L3NwYW4+XG4gICAgICA8YnV0dG9uICpuZ0lmPVwiZGF0YS5leHBsaWNpdFNhdmVcIlxuICAgICAgICAgICAgICBtYXQtaWNvbi1idXR0b24gdHlwZT1cInN1Ym1pdFwiXG4gICAgICAgICAgICAgIFtkaXNhYmxlZF09XCJkYXRhLnJlYWRvbmx5XCJcbiAgICAgICAgICAgICAgW21hdC1kaWFsb2ctY2xvc2VdPVwiZGF0YS5sb2NhbGl6YWJsZXNcIlxuICAgICAgPlxuICAgICAgICA8bWF0LWljb24+c2F2ZTwvbWF0LWljb24+XG4gICAgICA8L2J1dHRvbj5cbiAgICA8L21hdC10b29sYmFyLXJvdz5cbiAgPC9tYXQtdG9vbGJhcj5cblxuICA8ZGl2IGNsYXNzPVwibGF5b3V0LWNvbCBmbGV4IHAtc21cIj5cbiAgICA8ZWxkZXItbG9jYWxpemVkLWlucHV0LXRhYmxlXG4gICAgICBbZmxvYXRdPVwidHJ1ZVwiIGNsYXNzPVwiZmxleFwiXG4gICAgICBbdGV4dENvbHVtbnNdPVwiZGF0YS50ZXh0Q29sdW1uc1wiXG4gICAgICBbKHZhbHVlKV09XCJkYXRhLmxvY2FsaXphYmxlc1wiXG4gICAgICBbcmVhZG9ubHldPVwiZGF0YS5yZWFkb25seVwiXG4gICAgICBbZGlzYWJsZWRdPVwiZGF0YS5kaXNhYmxlZFwiXG4gICAgICBbcmVxdWlyZWRdPVwiZGF0YS5yZXF1aXJlZFwiXG4gICAgPlxuICAgIDwvZWxkZXItbG9jYWxpemVkLWlucHV0LXRhYmxlPlxuICA8L2Rpdj5cbjwvZGl2PlxuXG5cblxuXG5cblxuIl19
29
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItbG9jYWxpemVkLWlucHV0LWRpYWxvZy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21wb25lbnRzL2kxOG4vZW50aXRpZXMvZWxkZXItbG9jYWxpemVkLWlucHV0LWRpYWxvZy9lbGRlci1sb2NhbGl6ZWQtaW5wdXQtZGlhbG9nLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VsZGVyYnl0ZS9uZ3gtc3RhcnRlci9zcmMvbGliL2NvbXBvbmVudHMvaTE4bi9lbnRpdGllcy9lbGRlci1sb2NhbGl6ZWQtaW5wdXQtZGlhbG9nL2VsZGVyLWxvY2FsaXplZC1pbnB1dC1kaWFsb2cuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBVSx1QkFBdUIsRUFBRSxNQUFNLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDakYsT0FBTyxFQUFDLGVBQWUsRUFBZSxNQUFNLDBCQUEwQixDQUFDOzs7Ozs7Ozs7O0FBcUJ2RSxNQUFNLE9BQU8sa0NBQWtDO0lBRTdDLFlBQ1MsU0FBMkQsRUFDbEMsSUFBZ0M7UUFEekQsY0FBUyxHQUFULFNBQVMsQ0FBa0Q7UUFDbEMsU0FBSSxHQUFKLElBQUksQ0FBNEI7SUFDOUQsQ0FBQztJQUVMLFFBQVE7SUFDUixDQUFDOzsrSEFSVSxrQ0FBa0MsOENBSW5DLGVBQWU7bUhBSmQsa0NBQWtDLG9FQ3RCL0MsbzdCQW9DQTsyRkRkYSxrQ0FBa0M7a0JBTjlDLFNBQVM7K0JBQ0UsOEJBQThCLG1CQUd2Qix1QkFBdUIsQ0FBQyxNQUFNOzswQkFNNUMsTUFBTTsyQkFBQyxlQUFlIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDb21wb25lbnQsIE9uSW5pdCwgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIEluamVjdH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge01BVF9ESUFMT0dfREFUQSwgTWF0RGlhbG9nUmVmfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xuaW1wb3J0IHtFbGRlckxvY2FsaXplZFRleHRDb2x1bW5EaXJlY3RpdmV9IGZyb20gJy4uL2VsZGVyLWxvY2FsaXplZC10ZXh0LWNvbHVtbi5kaXJlY3RpdmUnO1xuaW1wb3J0IHtMb2NhbGl6ZWR9IGZyb20gJy4uLy4uLy4uLy4uL2NvbW1vbi9pMThuL2VudGl0eS9sb2NhbGl6ZWQnO1xuXG5cbmV4cG9ydCBpbnRlcmZhY2UgRWxkZXJMb2NhbGl6ZWRJbnB1dE9wdGlvbnM8VCBleHRlbmRzIExvY2FsaXplZCA9IExvY2FsaXplZD4ge1xuICB0aXRsZTogc3RyaW5nO1xuICBsb2NhbGl6YWJsZXM6IFRbXTtcbiAgdGV4dENvbHVtbnM6IEVsZGVyTG9jYWxpemVkVGV4dENvbHVtbkRpcmVjdGl2ZVtdO1xuICBleHBsaWNpdFNhdmU6IGJvb2xlYW47XG4gIHJlYWRvbmx5PzogYm9vbGVhbjtcbiAgZGlzYWJsZWQ/OiBib29sZWFuO1xuICByZXF1aXJlZD86IGJvb2xlYW47XG59XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2VsZGVyLWxvY2FsaXplZC1pbnB1dC1kaWFsb2cnLFxuICB0ZW1wbGF0ZVVybDogJy4vZWxkZXItbG9jYWxpemVkLWlucHV0LWRpYWxvZy5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2VsZGVyLWxvY2FsaXplZC1pbnB1dC1kaWFsb2cuY29tcG9uZW50LnNjc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgRWxkZXJMb2NhbGl6ZWRJbnB1dERpYWxvZ0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHVibGljIGRpYWxvZ1JlZjogTWF0RGlhbG9nUmVmPEVsZGVyTG9jYWxpemVkSW5wdXREaWFsb2dDb21wb25lbnQ+LFxuICAgIEBJbmplY3QoTUFUX0RJQUxPR19EQVRBKSBwdWJsaWMgZGF0YTogRWxkZXJMb2NhbGl6ZWRJbnB1dE9wdGlvbnNcbiAgKSB7IH1cblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgfVxuXG59XG4iLCJcbjxkaXYgY2xhc3M9XCJsYXlvdXQtY29sIGZ1bGxcIj5cblxuICA8bWF0LXRvb2xiYXIgZWxkZXJUaGVtZSBjb2xvcj1cInByaW1hcnlcIj5cbiAgICA8bWF0LXRvb2xiYXItcm93IGNsYXNzPVwiZ2FwLXNtXCI+XG4gICAgICA8bWF0LWljb24gY2xhc3M9XCJub3NlbGVjdFwiPnRyYW5zbGF0ZTwvbWF0LWljb24+XG4gICAgICA8aDIgY2xhc3M9XCJub3NlbGVjdFwiIHRyYW5zbGF0ZT57e2RhdGEudGl0bGV9fTwvaDI+XG4gICAgICA8c3BhbiBjbGFzcz1cImZsZXhcIj48L3NwYW4+XG4gICAgICA8YnV0dG9uICpuZ0lmPVwiZGF0YS5leHBsaWNpdFNhdmVcIlxuICAgICAgICAgICAgICBtYXQtaWNvbi1idXR0b24gdHlwZT1cInN1Ym1pdFwiXG4gICAgICAgICAgICAgIFtkaXNhYmxlZF09XCJkYXRhLnJlYWRvbmx5XCJcbiAgICAgICAgICAgICAgW21hdC1kaWFsb2ctY2xvc2VdPVwiZGF0YS5sb2NhbGl6YWJsZXNcIlxuICAgICAgPlxuICAgICAgICA8bWF0LWljb24+c2F2ZTwvbWF0LWljb24+XG4gICAgICA8L2J1dHRvbj5cbiAgICA8L21hdC10b29sYmFyLXJvdz5cbiAgPC9tYXQtdG9vbGJhcj5cblxuICA8ZGl2IGNsYXNzPVwibGF5b3V0LWNvbCBmbGV4IHAtc21cIj5cbiAgICA8ZWxkZXItbG9jYWxpemVkLWlucHV0LXRhYmxlXG4gICAgICBbZmxvYXRdPVwidHJ1ZVwiIGNsYXNzPVwiZmxleFwiXG4gICAgICBbdGV4dENvbHVtbnNdPVwiZGF0YS50ZXh0Q29sdW1uc1wiXG4gICAgICBbKHZhbHVlKV09XCJkYXRhLmxvY2FsaXphYmxlc1wiXG4gICAgICBbcmVhZG9ubHldPVwiZGF0YS5yZWFkb25seVwiXG4gICAgICBbZGlzYWJsZWRdPVwiZGF0YS5kaXNhYmxlZFwiXG4gICAgICBbcmVxdWlyZWRdPVwiZGF0YS5yZXF1aXJlZFwiXG4gICAgPlxuICAgIDwvZWxkZXItbG9jYWxpemVkLWlucHV0LXRhYmxlPlxuICA8L2Rpdj5cbjwvZGl2PlxuXG5cblxuXG5cblxuIl19