@tilde-nlp/ngx-common 4.1.9 → 4.1.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/filter-bar/filter-bar.component.mjs +2 -2
- package/esm2022/lib/notification-message/interfaces/notification-message.model.mjs +1 -1
- package/esm2022/lib/notification-message/notification-message.component.mjs +5 -4
- package/esm2022/lib/notification-message/notification-message.module.mjs +8 -4
- package/esm2022/lib/terminology/components/terminology-panel/terminology-collection-list/terminology-collection-list.component.mjs +2 -2
- package/esm2022/lib/terminology/components/terminology-panel/terminology-panel.component.mjs +14 -3
- package/esm2022/lib/terminology/config/models/terminology-config.model.mjs +1 -1
- package/esm2022/lib/terminology/config/services/terminology-config/terminology-config.service.mjs +4 -2
- package/esm2022/lib/terminology/services/system-api-v2/system-api.service.mjs +5 -1
- package/esm2022/lib/terminology/terminology.component.mjs +28 -20
- package/fesm2022/tilde-nlp-ngx-common.mjs +81 -26
- package/fesm2022/tilde-nlp-ngx-common.mjs.map +1 -1
- package/lib/notification-message/interfaces/notification-message.model.d.ts +6 -0
- package/lib/notification-message/notification-message.module.d.ts +2 -1
- package/lib/terminology/components/terminology-panel/terminology-panel.component.d.ts +6 -2
- package/lib/terminology/config/models/terminology-config.model.d.ts +4 -0
- package/lib/terminology/terminology.component.d.ts +5 -1
- package/package.json +1 -1
|
@@ -100,7 +100,7 @@ export class FilterBarComponent {
|
|
|
100
100
|
const target = event.target;
|
|
101
101
|
this.settings.filters?.map((item) => {
|
|
102
102
|
if (item.fieldName === filter.fieldName && item.search) {
|
|
103
|
-
item.search.filteredValues = filter.values.filter((value) => (item.translated ? value.key : this.translate.instant(value.key)).toLowerCase().includes(target.value));
|
|
103
|
+
item.search.filteredValues = filter.values.filter((value) => (item.translated ? value.key : this.translate.instant(value.key)).toLowerCase().includes(target.value.toLowerCase()));
|
|
104
104
|
}
|
|
105
105
|
});
|
|
106
106
|
}
|
|
@@ -177,4 +177,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
177
177
|
}], filterBarChange: [{
|
|
178
178
|
type: Output
|
|
179
179
|
}] } });
|
|
180
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-bar.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-common/src/lib/filter-bar/filter-bar.component.ts","../../../../../projects/ngx-common/src/lib/filter-bar/filter-bar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ChangeDetectorRef, Component, ElementRef, EventEmitter, HostListener, Input, OnDestroy, OnInit, Output, ViewChild, ViewChildren } from '@angular/core';\r\nimport { FormControl, FormGroup } from '@angular/forms';\r\nimport { Subscription } from 'rxjs';\r\nimport { FilterBarFilter, FilterBarFilterItem } from './models';\r\nimport { FilterBarChangeEvent } from './models/filter-bar-change-event.model';\r\nimport { FilterBarSettings } from './models/filter-bar-settings.model';\r\nimport { MatSelect } from '@angular/material/select';\r\nimport { TranslateService } from '@ngx-translate/core';\r\n\r\n@Component({\r\n  // eslint-disable-next-line @angular-eslint/component-selector\r\n  selector: 'tld-filter-bar',\r\n  templateUrl: './filter-bar.component.html',\r\n  styleUrls: ['./filter-bar.component.scss']\r\n})\r\nexport class FilterBarComponent implements OnInit, AfterViewInit, OnDestroy {\r\n  @ViewChild(\"filterWrapper\") filterWrapper!: ElementRef;\r\n  @ViewChildren('optionSearchInput') optionSearchInputs!: ElementRef<MatSelect>[];\r\n  @HostListener('window:resize', [])\r\n  onResize() {\r\n    this.checkOverflow();\r\n  }\r\n\r\n  @Input() settings!: FilterBarSettings;\r\n  @Input() set filterRowVisible(value: boolean) {\r\n    this._filterRowVisible = value;\r\n    this.cdref.detectChanges();\r\n    this.checkOverflow();\r\n  }\r\n\r\n  @Output() filterBarChange: EventEmitter<FilterBarChangeEvent> = new EventEmitter<FilterBarChangeEvent>();\r\n\r\n  private _inputText = \"\";\r\n  private _filterRowVisible!: boolean;\r\n  private formChangesSubscription!: Subscription;\r\n\r\n  /** To hide filters, but leave chips visible */\r\n  readonly inputFormControlName = \"input\";\r\n  readonly filterFormGroup = new FormGroup({});\r\n  readonly form = new FormGroup({\r\n    [this.inputFormControlName]: new FormControl(\"\"),\r\n    filters: this.filterFormGroup\r\n  });\r\n\r\n  searchTitle!: string;\r\n  searchTooltip!: string;\r\n  suffixIcon!: string;\r\n  prefixIcon!: string;\r\n  showSuffixIcon!: boolean;\r\n  filters: FilterBarChangeEvent = {\r\n    filters: {},\r\n    input: \"\"\r\n  };\r\n\r\n  filterOverflow = false;\r\n  activeFilterIndex = 0;\r\n\r\n  // when to show filter by name or id on mobile\r\n  searchIndex = -1;\r\n\r\n  // getter for cleaner template html\r\n  get filterFormGroupValue(): { [key: string]: FilterBarFilterItem[] } {\r\n    return this.filterFormGroup.value;\r\n  }\r\n  // eslint-disable-next-line @typescript-eslint/adjacent-overload-signatures\r\n  get filterRowVisible() { return this._filterRowVisible; }\r\n  get inputText() {\r\n    return this._inputText;\r\n  }\r\n  get showSearch() {\r\n    return !this.settings?.hideSearch;\r\n  }\r\n  get outputFilterKeyAndValue() {\r\n    return this.settings?.outputFilterKeyAndValue;\r\n  }\r\n\r\n  // eslint-disable-next-line @typescript-eslint/adjacent-overload-signatures\r\n  set inputText(value) {\r\n    this._inputText = value;\r\n    this.filters.input = this._inputText;\r\n    this.emitFilters();\r\n  }\r\n\r\n  constructor(private cdref: ChangeDetectorRef, private translate: TranslateService) { }\r\n\r\n  ngOnInit() {\r\n    this.settings.filters?.forEach((field) => {\r\n      this.filterFormGroup.addControl(field.fieldName, new FormControl([]));\r\n    })\r\n\r\n    this.subscribeToFormValueChanges();\r\n    this.searchTooltip = this.settings?.searchTooltip ?? 'FILTER_BAR.SEARCH_TOOLTIP';\r\n    this.searchTitle = this.settings?.searchTitle ?? 'FILTER_BAR.SEARCH';\r\n    this.prefixIcon = this.settings?.prefixIcon ?? \"filter_alt\";\r\n    this.suffixIcon = this.settings?.suffixIcon ?? \"question_mark\";\r\n    this.showSuffixIcon = this.settings?.showSuffixIcon ?? true;\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.checkOverflow();\r\n    this.cdref.detectChanges();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.formChangesSubscription.unsubscribe();\r\n  }\r\n\r\n  focusOptionSearchInput(filter: FilterBarFilter, index: number): void {\r\n    if (!filter.search?.placeholder) {\r\n      return;\r\n    }\r\n\r\n    setTimeout(() => {\r\n      this.optionSearchInputs.find((_item, i) => i === index)?.nativeElement.focus();\r\n    }, 300);\r\n\r\n    if (filter.maxPanelWidth === '' && filter.search.placeholder) {\r\n      this.setPanelWidth(filter);\r\n    }\r\n  }\r\n\r\n  filterOptions(event: KeyboardEvent, filter: FilterBarFilter) {\r\n    const target = event.target as HTMLTextAreaElement;\r\n    this.settings.filters?.map((item) => {\r\n      if (item.fieldName === filter.fieldName && item.search) {\r\n        item.search.filteredValues = filter.values.filter(\r\n          (value) => (item.translated ? value.key : this.translate.instant(value.key)).toLowerCase().includes(target.value)\r\n        );\r\n      }\r\n    });\r\n  }\r\n\r\n  setPanelWidth(filter: FilterBarFilter): void {\r\n    // We must save panel width, so filtering does not affect it`s size.\r\n    const selectPanel = document.querySelector('.cdk-overlay-pane') as HTMLElement;\r\n    const selectPanelWidth = selectPanel.clientWidth as number;\r\n    const filterObj = this.settings.filters?.find((item) => item.fieldName === filter.fieldName) as FilterBarFilter;\r\n    filterObj.maxPanelWidth = selectPanelWidth;\r\n    selectPanel.style.minWidth = `${selectPanelWidth}px`;\r\n  }\r\n\r\n  emitFilters() {\r\n    this.filterBarChange.next(this.filters);\r\n  }\r\n\r\n  switchRight() {\r\n    if (this.settings?.filters && this.settings?.filters.length === this.activeFilterIndex + 1) {\r\n      return;\r\n    }\r\n    this.activeFilterIndex += 1;\r\n  }\r\n\r\n  switchLeft() {\r\n    if (this.activeFilterIndex === this.searchIndex) {\r\n      return;\r\n    }\r\n    this.activeFilterIndex -= 1;\r\n  }\r\n\r\n  removeFilter(key: string, ix: number) {\r\n    const control = this.filterFormGroup.get(key);\r\n\r\n    if (!control) {\r\n      return;\r\n    }\r\n\r\n    const newArray = control.value as [];\r\n    newArray.splice(ix, 1);\r\n    control.setValue(newArray);\r\n  }\r\n\r\n  private checkOverflow() {\r\n    if (this.filterWrapper) {\r\n      this.filterOverflow = this.filterWrapper.nativeElement.clientWidth < this.filterWrapper.nativeElement.scrollWidth;\r\n    }\r\n  }\r\n\r\n  private subscribeToFormValueChanges() {\r\n    this.formChangesSubscription = this.form.valueChanges.subscribe(() => {\r\n      this.filters = {\r\n        input: this.form.value.input ?? \"\",\r\n        filters: {}\r\n      };\r\n\r\n      for (const filterKey in this.form.value.filters) {\r\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n        const filter: FilterBarFilterItem[] = (this.form.value.filters as any)[filterKey] as FilterBarFilterItem[];\r\n        this.filters.filters[filterKey] = filter.map((item) => this.outputFilterKeyAndValue ? item : item.value)\r\n      }\r\n      this.emitFilters();\r\n    })\r\n  }\r\n}\r\n","<div class=\"filter-row\" *ngIf=\"filterRowVisible\">\r\n  <div fxLayout=\"row\" class=\"filter-wrapper\" #filterWrapper [formGroup]=\"form\">\r\n    <mat-form-field fxFlex *ngIf=\"showSearch && !filterOverflow || activeFilterIndex === searchIndex\" class=\"filter-bar-search-input\">\r\n      <span matPrefix class=\"material-icons-outlined\">\r\n        {{prefixIcon}}\r\n      </span>\r\n      <span matSuffix class=\"material-icons-outlined\" *ngIf=\"showSuffixIcon\" [matTooltip]=\"searchTooltip | translate\">\r\n        {{suffixIcon}}\r\n      </span>\r\n      <input class=\"search-input\" matInput [placeholder]=\"searchTitle | translate\"\r\n        [formControlName]=\"inputFormControlName\">\r\n    </mat-form-field>\r\n    <ng-container [formGroup]=\"filterFormGroup\">\r\n\r\n      <mat-form-field [ngClass]=\"{'hidden': filterOverflow && activeFilterIndex !== i, 'engine-filter': !filterOverflow}\" *ngFor=\"let filter of settings?.filters; let i = index\">\r\n        <mat-label>{{filter.title | translate}}</mat-label>\r\n        <mat-select multiple [panelWidth]=\"filter?.maxPanelWidth ?? 'auto'\" [formControlName]=\"filter.fieldName\" (openedChange)=\"$event === true ? focusOptionSearchInput(filter, i) : null\">\r\n          <ng-container *ngIf=\"filter?.search?.placeholder\">\r\n            <input #optionSearchInput class=\"option-search-input\" type=\"text\" [placeholder]=\"filter.search?.placeholder ?? '' | translate\" (keyup)=\"filterOptions($event, filter)\" (keydown)=\"$event.stopPropagation()\">\r\n          </ng-container>\r\n         \r\n          <ng-container *ngIf=\"filter.values.length\">\r\n            <ng-container *ngIf=\"filter.translated; else sortedValuesByProperty\">\r\n              <mat-option class=\"filter-option\" *ngFor=\"let value of (filter.search?.filteredValues ?? filter.values) | sortAlphabetically:'key'\" [disabled]=\"filter.singleSelection?.selected && filter.singleSelection?.value !== value.value\" [value]=\"value\">\r\n                {{ filter.disableTitleCase ? value.key : (value.key | titlecase) }}\r\n              </mat-option>\r\n            </ng-container>\r\n            \r\n            <ng-template #sortedValuesByProperty>\r\n              <mat-option class=\"filter-option\" *ngFor=\"let value of (filter.search?.filteredValues ?? filter.values) | sortTranslationsByProperty:'key':'value'\" [disabled]=\"filter.singleSelection?.selected && filter.singleSelection?.value !== value.value\" [value]=\"value\">\r\n                <ng-container *ngIf=\"!filter.disableTitleCase; else defaultCase\">\r\n                 {{ value.key | translate : { default: value.value | titlecase } }}\r\n                </ng-container>\r\n\r\n                <ng-template #defaultCase>\r\n                  {{ value.key | translate : { default: value.value } }} \r\n                </ng-template>\r\n              </mat-option>\r\n            </ng-template>\r\n          </ng-container>\r\n        </mat-select>\r\n      </mat-form-field>\r\n    </ng-container>\r\n  </div>\r\n  <button mat-icon-button (click)=\"switchLeft()\" *ngIf=\"filterOverflow\">\r\n    <span class=\"material-icons-outlined\">\r\n      arrow_back_ios\r\n    </span>\r\n  </button>\r\n  <button mat-icon-button *ngIf=\"filterOverflow\" (click)=\"switchRight()\">\r\n    <span class=\"material-icons-outlined\">\r\n      arrow_forward_ios\r\n    </span>\r\n  </button>\r\n</div>\r\n<mat-chip-listbox>\r\n  <div *ngFor=\"let filter of settings?.filters\">\r\n    <mat-chip-option *ngFor=\"let filterValue of filterFormGroupValue[filter.fieldName]; let ix=index\"\r\n      (removed)=\"removeFilter(filter.fieldName, ix)\" class=\"text-s\">\r\n      <button matChipRemove>\r\n        <mat-icon>close</mat-icon>\r\n      </button>\r\n      <span class=\"chip-filter-title\">{{filter.title | translate}}:</span>\r\n      <span class=\"chip-value semi-bold\"> {{(filter.translated ? filterValue.key : filterValue.key | translate : {default: filterValue.value}) | titlecase\r\n        }}</span>\r\n    </mat-chip-option>\r\n  </div>\r\n</mat-chip-listbox>\r\n"]}
|
|
180
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-bar.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-common/src/lib/filter-bar/filter-bar.component.ts","../../../../../projects/ngx-common/src/lib/filter-bar/filter-bar.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAoC,SAAS,EAAc,YAAY,EAAE,YAAY,EAAE,KAAK,EAAqB,MAAM,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAC/K,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;;;;;;;;;;;;;;;;;AAcxD,MAAM,OAAO,kBAAkB;IAI7B,QAAQ;QACN,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC;IAGD,IAAa,gBAAgB,CAAC,KAAc;QAC1C,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;QAC/B,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;QAC3B,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC;IAgCD,mCAAmC;IACnC,IAAI,oBAAoB;QACtB,OAAO,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC;IACpC,CAAC;IACD,2EAA2E;IAC3E,IAAI,gBAAgB,KAAK,OAAO,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC;IACzD,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IACD,IAAI,UAAU;QACZ,OAAO,CAAC,IAAI,CAAC,QAAQ,EAAE,UAAU,CAAC;IACpC,CAAC;IACD,IAAI,uBAAuB;QACzB,OAAO,IAAI,CAAC,QAAQ,EAAE,uBAAuB,CAAC;IAChD,CAAC;IAED,2EAA2E;IAC3E,IAAI,SAAS,CAAC,KAAK;QACjB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC;QACrC,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAED,YAAoB,KAAwB,EAAU,SAA2B;QAA7D,UAAK,GAAL,KAAK,CAAmB;QAAU,cAAS,GAAT,SAAS,CAAkB;QArDvE,oBAAe,GAAuC,IAAI,YAAY,EAAwB,CAAC;QAEjG,eAAU,GAAG,EAAE,CAAC;QAIxB,+CAA+C;QACtC,yBAAoB,GAAG,OAAO,CAAC;QAC/B,oBAAe,GAAG,IAAI,SAAS,CAAC,EAAE,CAAC,CAAC;QACpC,SAAI,GAAG,IAAI,SAAS,CAAC;YAC5B,CAAC,IAAI,CAAC,oBAAoB,CAAC,EAAE,IAAI,WAAW,CAAC,EAAE,CAAC;YAChD,OAAO,EAAE,IAAI,CAAC,eAAe;SAC9B,CAAC,CAAC;QAOH,YAAO,GAAyB;YAC9B,OAAO,EAAE,EAAE;YACX,KAAK,EAAE,EAAE;SACV,CAAC;QAEF,mBAAc,GAAG,KAAK,CAAC;QACvB,sBAAiB,GAAG,CAAC,CAAC;QAEtB,8CAA8C;QAC9C,gBAAW,GAAG,CAAC,CAAC,CAAC;IAyBoE,CAAC;IAEtF,QAAQ;QACN,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;YACvC,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,KAAK,CAAC,SAAS,EAAE,IAAI,WAAW,CAAC,EAAE,CAAC,CAAC,CAAC;QACxE,CAAC,CAAC,CAAA;QAEF,IAAI,CAAC,2BAA2B,EAAE,CAAC;QACnC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,QAAQ,EAAE,aAAa,IAAI,2BAA2B,CAAC;QACjF,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,EAAE,WAAW,IAAI,mBAAmB,CAAC;QACrE,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,QAAQ,EAAE,UAAU,IAAI,YAAY,CAAC;QAC5D,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,QAAQ,EAAE,UAAU,IAAI,eAAe,CAAC;QAC/D,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,QAAQ,EAAE,cAAc,IAAI,IAAI,CAAC;IAC9D,CAAC;IAED,eAAe;QACb,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;IAC7B,CAAC;IAED,WAAW;QACT,IAAI,CAAC,uBAAuB,CAAC,WAAW,EAAE,CAAC;IAC7C,CAAC;IAED,sBAAsB,CAAC,MAAuB,EAAE,KAAa;QAC3D,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,WAAW,EAAE;YAC/B,OAAO;SACR;QAED,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,KAAK,CAAC,EAAE,aAAa,CAAC,KAAK,EAAE,CAAC;QACjF,CAAC,EAAE,GAAG,CAAC,CAAC;QAER,IAAI,MAAM,CAAC,aAAa,KAAK,EAAE,IAAI,MAAM,CAAC,MAAM,CAAC,WAAW,EAAE;YAC5D,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;SAC5B;IACH,CAAC;IAED,aAAa,CAAC,KAAoB,EAAE,MAAuB;QACzD,MAAM,MAAM,GAAG,KAAK,CAAC,MAA6B,CAAC;QACnD,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;YAClC,IAAI,IAAI,CAAC,SAAS,KAAK,MAAM,CAAC,SAAS,IAAI,IAAI,CAAC,MAAM,EAAE;gBACtD,IAAI,CAAC,MAAM,CAAC,cAAc,GAAG,MAAM,CAAC,MAAM,CAAC,MAAM,CAC/C,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,CAChI,CAAC;aACH;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,aAAa,CAAC,MAAuB;QACnC,oEAAoE;QACpE,MAAM,WAAW,GAAG,QAAQ,CAAC,aAAa,CAAC,mBAAmB,CAAgB,CAAC;QAC/E,MAAM,gBAAgB,GAAG,WAAW,CAAC,WAAqB,CAAC;QAC3D,MAAM,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,KAAK,MAAM,CAAC,SAAS,CAAoB,CAAC;QAChH,SAAS,CAAC,aAAa,GAAG,gBAAgB,CAAC;QAC3C,WAAW,CAAC,KAAK,CAAC,QAAQ,GAAG,GAAG,gBAAgB,IAAI,CAAC;IACvD,CAAC;IAED,WAAW;QACT,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAC1C,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,QAAQ,EAAE,OAAO,IAAI,IAAI,CAAC,QAAQ,EAAE,OAAO,CAAC,MAAM,KAAK,IAAI,CAAC,iBAAiB,GAAG,CAAC,EAAE;YAC1F,OAAO;SACR;QACD,IAAI,CAAC,iBAAiB,IAAI,CAAC,CAAC;IAC9B,CAAC;IAED,UAAU;QACR,IAAI,IAAI,CAAC,iBAAiB,KAAK,IAAI,CAAC,WAAW,EAAE;YAC/C,OAAO;SACR;QACD,IAAI,CAAC,iBAAiB,IAAI,CAAC,CAAC;IAC9B,CAAC;IAED,YAAY,CAAC,GAAW,EAAE,EAAU;QAClC,MAAM,OAAO,GAAG,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QAE9C,IAAI,CAAC,OAAO,EAAE;YACZ,OAAO;SACR;QAED,MAAM,QAAQ,GAAG,OAAO,CAAC,KAAW,CAAC;QACrC,QAAQ,CAAC,MAAM,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;QACvB,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;IAC7B,CAAC;IAEO,aAAa;QACnB,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,WAAW,CAAC;SACnH;IACH,CAAC;IAEO,2BAA2B;QACjC,IAAI,CAAC,uBAAuB,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,GAAG,EAAE;YACnE,IAAI,CAAC,OAAO,GAAG;gBACb,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,IAAI,EAAE;gBAClC,OAAO,EAAE,EAAE;aACZ,CAAC;YAEF,KAAK,MAAM,SAAS,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE;gBAC/C,8DAA8D;gBAC9D,MAAM,MAAM,GAA2B,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,OAAe,CAAC,SAAS,CAA0B,CAAC;gBAC3G,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,SAAS,CAAC,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;aACzG;YACD,IAAI,CAAC,WAAW,EAAE,CAAC;QACrB,CAAC,CAAC,CAAA;IACJ,CAAC;+GAhLU,kBAAkB;mGAAlB,kBAAkB,obCf/B,2/HAoEA;;4FDrDa,kBAAkB;kBAN9B,SAAS;+BAEE,gBAAgB;uIAKE,aAAa;sBAAxC,SAAS;uBAAC,eAAe;gBACS,kBAAkB;sBAApD,YAAY;uBAAC,mBAAmB;gBAEjC,QAAQ;sBADP,YAAY;uBAAC,eAAe,EAAE,EAAE;gBAKxB,QAAQ;sBAAhB,KAAK;gBACO,gBAAgB;sBAA5B,KAAK;gBAMI,eAAe;sBAAxB,MAAM","sourcesContent":["import { AfterViewInit, ChangeDetectorRef, Component, ElementRef, EventEmitter, HostListener, Input, OnDestroy, OnInit, Output, ViewChild, ViewChildren } from '@angular/core';\r\nimport { FormControl, FormGroup } from '@angular/forms';\r\nimport { Subscription } from 'rxjs';\r\nimport { FilterBarFilter, FilterBarFilterItem } from './models';\r\nimport { FilterBarChangeEvent } from './models/filter-bar-change-event.model';\r\nimport { FilterBarSettings } from './models/filter-bar-settings.model';\r\nimport { MatSelect } from '@angular/material/select';\r\nimport { TranslateService } from '@ngx-translate/core';\r\n\r\n@Component({\r\n  // eslint-disable-next-line @angular-eslint/component-selector\r\n  selector: 'tld-filter-bar',\r\n  templateUrl: './filter-bar.component.html',\r\n  styleUrls: ['./filter-bar.component.scss']\r\n})\r\nexport class FilterBarComponent implements OnInit, AfterViewInit, OnDestroy {\r\n  @ViewChild(\"filterWrapper\") filterWrapper!: ElementRef;\r\n  @ViewChildren('optionSearchInput') optionSearchInputs!: ElementRef<MatSelect>[];\r\n  @HostListener('window:resize', [])\r\n  onResize() {\r\n    this.checkOverflow();\r\n  }\r\n\r\n  @Input() settings!: FilterBarSettings;\r\n  @Input() set filterRowVisible(value: boolean) {\r\n    this._filterRowVisible = value;\r\n    this.cdref.detectChanges();\r\n    this.checkOverflow();\r\n  }\r\n\r\n  @Output() filterBarChange: EventEmitter<FilterBarChangeEvent> = new EventEmitter<FilterBarChangeEvent>();\r\n\r\n  private _inputText = \"\";\r\n  private _filterRowVisible!: boolean;\r\n  private formChangesSubscription!: Subscription;\r\n\r\n  /** To hide filters, but leave chips visible */\r\n  readonly inputFormControlName = \"input\";\r\n  readonly filterFormGroup = new FormGroup({});\r\n  readonly form = new FormGroup({\r\n    [this.inputFormControlName]: new FormControl(\"\"),\r\n    filters: this.filterFormGroup\r\n  });\r\n\r\n  searchTitle!: string;\r\n  searchTooltip!: string;\r\n  suffixIcon!: string;\r\n  prefixIcon!: string;\r\n  showSuffixIcon!: boolean;\r\n  filters: FilterBarChangeEvent = {\r\n    filters: {},\r\n    input: \"\"\r\n  };\r\n\r\n  filterOverflow = false;\r\n  activeFilterIndex = 0;\r\n\r\n  // when to show filter by name or id on mobile\r\n  searchIndex = -1;\r\n\r\n  // getter for cleaner template html\r\n  get filterFormGroupValue(): { [key: string]: FilterBarFilterItem[] } {\r\n    return this.filterFormGroup.value;\r\n  }\r\n  // eslint-disable-next-line @typescript-eslint/adjacent-overload-signatures\r\n  get filterRowVisible() { return this._filterRowVisible; }\r\n  get inputText() {\r\n    return this._inputText;\r\n  }\r\n  get showSearch() {\r\n    return !this.settings?.hideSearch;\r\n  }\r\n  get outputFilterKeyAndValue() {\r\n    return this.settings?.outputFilterKeyAndValue;\r\n  }\r\n\r\n  // eslint-disable-next-line @typescript-eslint/adjacent-overload-signatures\r\n  set inputText(value) {\r\n    this._inputText = value;\r\n    this.filters.input = this._inputText;\r\n    this.emitFilters();\r\n  }\r\n\r\n  constructor(private cdref: ChangeDetectorRef, private translate: TranslateService) { }\r\n\r\n  ngOnInit() {\r\n    this.settings.filters?.forEach((field) => {\r\n      this.filterFormGroup.addControl(field.fieldName, new FormControl([]));\r\n    })\r\n\r\n    this.subscribeToFormValueChanges();\r\n    this.searchTooltip = this.settings?.searchTooltip ?? 'FILTER_BAR.SEARCH_TOOLTIP';\r\n    this.searchTitle = this.settings?.searchTitle ?? 'FILTER_BAR.SEARCH';\r\n    this.prefixIcon = this.settings?.prefixIcon ?? \"filter_alt\";\r\n    this.suffixIcon = this.settings?.suffixIcon ?? \"question_mark\";\r\n    this.showSuffixIcon = this.settings?.showSuffixIcon ?? true;\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.checkOverflow();\r\n    this.cdref.detectChanges();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.formChangesSubscription.unsubscribe();\r\n  }\r\n\r\n  focusOptionSearchInput(filter: FilterBarFilter, index: number): void {\r\n    if (!filter.search?.placeholder) {\r\n      return;\r\n    }\r\n\r\n    setTimeout(() => {\r\n      this.optionSearchInputs.find((_item, i) => i === index)?.nativeElement.focus();\r\n    }, 300);\r\n\r\n    if (filter.maxPanelWidth === '' && filter.search.placeholder) {\r\n      this.setPanelWidth(filter);\r\n    }\r\n  }\r\n\r\n  filterOptions(event: KeyboardEvent, filter: FilterBarFilter) {\r\n    const target = event.target as HTMLTextAreaElement;\r\n    this.settings.filters?.map((item) => {\r\n      if (item.fieldName === filter.fieldName && item.search) {\r\n        item.search.filteredValues = filter.values.filter(\r\n          (value) => (item.translated ? value.key : this.translate.instant(value.key)).toLowerCase().includes(target.value.toLowerCase())\r\n        );\r\n      }\r\n    });\r\n  }\r\n\r\n  setPanelWidth(filter: FilterBarFilter): void {\r\n    // We must save panel width, so filtering does not affect it`s size.\r\n    const selectPanel = document.querySelector('.cdk-overlay-pane') as HTMLElement;\r\n    const selectPanelWidth = selectPanel.clientWidth as number;\r\n    const filterObj = this.settings.filters?.find((item) => item.fieldName === filter.fieldName) as FilterBarFilter;\r\n    filterObj.maxPanelWidth = selectPanelWidth;\r\n    selectPanel.style.minWidth = `${selectPanelWidth}px`;\r\n  }\r\n\r\n  emitFilters() {\r\n    this.filterBarChange.next(this.filters);\r\n  }\r\n\r\n  switchRight() {\r\n    if (this.settings?.filters && this.settings?.filters.length === this.activeFilterIndex + 1) {\r\n      return;\r\n    }\r\n    this.activeFilterIndex += 1;\r\n  }\r\n\r\n  switchLeft() {\r\n    if (this.activeFilterIndex === this.searchIndex) {\r\n      return;\r\n    }\r\n    this.activeFilterIndex -= 1;\r\n  }\r\n\r\n  removeFilter(key: string, ix: number) {\r\n    const control = this.filterFormGroup.get(key);\r\n\r\n    if (!control) {\r\n      return;\r\n    }\r\n\r\n    const newArray = control.value as [];\r\n    newArray.splice(ix, 1);\r\n    control.setValue(newArray);\r\n  }\r\n\r\n  private checkOverflow() {\r\n    if (this.filterWrapper) {\r\n      this.filterOverflow = this.filterWrapper.nativeElement.clientWidth < this.filterWrapper.nativeElement.scrollWidth;\r\n    }\r\n  }\r\n\r\n  private subscribeToFormValueChanges() {\r\n    this.formChangesSubscription = this.form.valueChanges.subscribe(() => {\r\n      this.filters = {\r\n        input: this.form.value.input ?? \"\",\r\n        filters: {}\r\n      };\r\n\r\n      for (const filterKey in this.form.value.filters) {\r\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n        const filter: FilterBarFilterItem[] = (this.form.value.filters as any)[filterKey] as FilterBarFilterItem[];\r\n        this.filters.filters[filterKey] = filter.map((item) => this.outputFilterKeyAndValue ? item : item.value)\r\n      }\r\n      this.emitFilters();\r\n    })\r\n  }\r\n}\r\n","<div class=\"filter-row\" *ngIf=\"filterRowVisible\">\r\n  <div fxLayout=\"row\" class=\"filter-wrapper\" #filterWrapper [formGroup]=\"form\">\r\n    <mat-form-field fxFlex *ngIf=\"showSearch && !filterOverflow || activeFilterIndex === searchIndex\" class=\"filter-bar-search-input\">\r\n      <span matPrefix class=\"material-icons-outlined\">\r\n        {{prefixIcon}}\r\n      </span>\r\n      <span matSuffix class=\"material-icons-outlined\" *ngIf=\"showSuffixIcon\" [matTooltip]=\"searchTooltip | translate\">\r\n        {{suffixIcon}}\r\n      </span>\r\n      <input class=\"search-input\" matInput [placeholder]=\"searchTitle | translate\"\r\n        [formControlName]=\"inputFormControlName\">\r\n    </mat-form-field>\r\n    <ng-container [formGroup]=\"filterFormGroup\">\r\n\r\n      <mat-form-field [ngClass]=\"{'hidden': filterOverflow && activeFilterIndex !== i, 'engine-filter': !filterOverflow}\" *ngFor=\"let filter of settings?.filters; let i = index\">\r\n        <mat-label>{{filter.title | translate}}</mat-label>\r\n        <mat-select multiple [panelWidth]=\"filter?.maxPanelWidth ?? 'auto'\" [formControlName]=\"filter.fieldName\" (openedChange)=\"$event === true ? focusOptionSearchInput(filter, i) : null\">\r\n          <ng-container *ngIf=\"filter?.search?.placeholder\">\r\n            <input #optionSearchInput class=\"option-search-input\" type=\"text\" [placeholder]=\"filter.search?.placeholder ?? '' | translate\" (keyup)=\"filterOptions($event, filter)\" (keydown)=\"$event.stopPropagation()\">\r\n          </ng-container>\r\n         \r\n          <ng-container *ngIf=\"filter.values.length\">\r\n            <ng-container *ngIf=\"filter.translated; else sortedValuesByProperty\">\r\n              <mat-option class=\"filter-option\" *ngFor=\"let value of (filter.search?.filteredValues ?? filter.values) | sortAlphabetically:'key'\" [disabled]=\"filter.singleSelection?.selected && filter.singleSelection?.value !== value.value\" [value]=\"value\">\r\n                {{ filter.disableTitleCase ? value.key : (value.key | titlecase) }}\r\n              </mat-option>\r\n            </ng-container>\r\n            \r\n            <ng-template #sortedValuesByProperty>\r\n              <mat-option class=\"filter-option\" *ngFor=\"let value of (filter.search?.filteredValues ?? filter.values) | sortTranslationsByProperty:'key':'value'\" [disabled]=\"filter.singleSelection?.selected && filter.singleSelection?.value !== value.value\" [value]=\"value\">\r\n                <ng-container *ngIf=\"!filter.disableTitleCase; else defaultCase\">\r\n                 {{ value.key | translate : { default: value.value | titlecase } }}\r\n                </ng-container>\r\n\r\n                <ng-template #defaultCase>\r\n                  {{ value.key | translate : { default: value.value } }} \r\n                </ng-template>\r\n              </mat-option>\r\n            </ng-template>\r\n          </ng-container>\r\n        </mat-select>\r\n      </mat-form-field>\r\n    </ng-container>\r\n  </div>\r\n  <button mat-icon-button (click)=\"switchLeft()\" *ngIf=\"filterOverflow\">\r\n    <span class=\"material-icons-outlined\">\r\n      arrow_back_ios\r\n    </span>\r\n  </button>\r\n  <button mat-icon-button *ngIf=\"filterOverflow\" (click)=\"switchRight()\">\r\n    <span class=\"material-icons-outlined\">\r\n      arrow_forward_ios\r\n    </span>\r\n  </button>\r\n</div>\r\n<mat-chip-listbox>\r\n  <div *ngFor=\"let filter of settings?.filters\">\r\n    <mat-chip-option *ngFor=\"let filterValue of filterFormGroupValue[filter.fieldName]; let ix=index\"\r\n      (removed)=\"removeFilter(filter.fieldName, ix)\" class=\"text-s\">\r\n      <button matChipRemove>\r\n        <mat-icon>close</mat-icon>\r\n      </button>\r\n      <span class=\"chip-filter-title\">{{filter.title | translate}}:</span>\r\n      <span class=\"chip-value semi-bold\"> {{(filter.translated ? filterValue.key : filterValue.key | translate : {default: filterValue.value}) | titlecase\r\n        }}</span>\r\n    </mat-chip-option>\r\n  </div>\r\n</mat-chip-listbox>\r\n"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm90aWZpY2F0aW9uLW1lc3NhZ2UubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtY29tbW9uL3NyYy9saWIvbm90aWZpY2F0aW9uLW1lc3NhZ2UvaW50ZXJmYWNlcy9ub3RpZmljYXRpb24tbWVzc2FnZS5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTm90aWZpY2F0aW9uTWVzc2FnZVR5cGUgfSBmcm9tIFwiLi4vZW51bXMvbm90aWZpY2F0aW9uLW1lc3NhZ2UtdHlwZS5lbnVtXCI7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIE5vdGlmaWNhdGlvbk1lc3NhZ2Uge1xyXG4gIHR5cGU6IE5vdGlmaWNhdGlvbk1lc3NhZ2VUeXBlO1xyXG4gIGlkPzogc3RyaW5nO1xyXG4gIHRpdGxlPzogc3RyaW5nO1xyXG4gIGJvZHk/OiBzdHJpbmc7XHJcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1leHBsaWNpdC1hbnlcclxuICBsb2NhbGl6YXRpb25QYXJhbXM/
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm90aWZpY2F0aW9uLW1lc3NhZ2UubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtY29tbW9uL3NyYy9saWIvbm90aWZpY2F0aW9uLW1lc3NhZ2UvaW50ZXJmYWNlcy9ub3RpZmljYXRpb24tbWVzc2FnZS5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTm90aWZpY2F0aW9uTWVzc2FnZVR5cGUgfSBmcm9tIFwiLi4vZW51bXMvbm90aWZpY2F0aW9uLW1lc3NhZ2UtdHlwZS5lbnVtXCI7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIE5vdGlmaWNhdGlvbk1lc3NhZ2Uge1xyXG4gIHR5cGU6IE5vdGlmaWNhdGlvbk1lc3NhZ2VUeXBlO1xyXG4gIGlkPzogc3RyaW5nO1xyXG4gIHRpdGxlPzogc3RyaW5nO1xyXG4gIGJvZHk/OiBzdHJpbmc7XHJcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1leHBsaWNpdC1hbnlcclxuICBsb2NhbGl6YXRpb25QYXJhbXM/OiBhbnk7XHJcbiAgYnV0dG9uVGV4dD86IHN0cmluZztcclxuICBsaW5rVGV4dD86IHN0cmluZztcclxuICBsaW5rSHJlZj86IHN0cmluZztcclxuICByb3V0ZXJMaW5rPzogc3RyaW5nO1xyXG4gIGhpZGVDbG9zZT86IGJvb2xlYW47XHJcbiAgLyoqXHJcbiAgICogUHJvdmlkZSBmb2xsb3dpbmcgcGFyYW1zIHRvIHVzZSBjYWxsYmFjayBidXR0b24gaW5zdGVhZCBvZiBjbG9zZSBidXR0b24uXHJcbiAgICovXHJcbiAgY2FsbGJhY2tCdXR0b25UZXh0Pzogc3RyaW5nO1xyXG4gIGNhbGxiYWNrQnV0dG9uSWNvbj86IHN0cmluZztcclxuICBjYWxsYmFja0J1dHRvbkNsaWNrPzogKCkgPT4gdm9pZDtcclxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWV4cGxpY2l0LWFueVxyXG4gIGVycm9yPzogYW55O1xyXG4gIC8qKlxyXG4gICAqIExvY2FsaXphdGlvbiBrZXkgZm9yIHN1cHBvcnQgaW5mbyBmb3IgbWVzc2FnZS4gSWYgdmFsdWUgaXMgbm90IG51bGwsIGl0IGlzIGRpc3BsYXllZCByaWdodCBhZnRlciBib2R5IHRleHQuXHJcbiAgICovXHJcbiAgc3VwcG9ydD86IHN0cmluZztcclxuICAvKipcclxuICAqIFNldCB0aGlzIHRvIHRydWUgYW5kIHByb3ZpZGUgc2FtZSBtZXNzYWdlIG9iamVjdCBpbiBjYXNlIHlvdSB3YW50IHRvIHJlbW92ZSBtZXNzYWdlIGZyb20gb3V0c2lkZS5cclxuICAqL1xyXG4gIGRlbGV0ZT86IGJvb2xlYW47XHJcbn1cclxuIl19
|
|
@@ -6,7 +6,8 @@ import * as i3 from "@angular/flex-layout/extended";
|
|
|
6
6
|
import * as i4 from "../close-button/close-button.component";
|
|
7
7
|
import * as i5 from "@angular/material/button";
|
|
8
8
|
import * as i6 from "@angular/router";
|
|
9
|
-
import * as i7 from "@
|
|
9
|
+
import * as i7 from "@angular/material/icon";
|
|
10
|
+
import * as i8 from "@ngx-translate/core";
|
|
10
11
|
export class NotificationMessageComponent {
|
|
11
12
|
constructor() {
|
|
12
13
|
this.buttonClicked = new EventEmitter();
|
|
@@ -33,11 +34,11 @@ export class NotificationMessageComponent {
|
|
|
33
34
|
this.linkClicked.next(null);
|
|
34
35
|
}
|
|
35
36
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NotificationMessageComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
36
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NotificationMessageComponent, selector: "lib-tld-notification-message", inputs: { message: "message", inline: "inline" }, outputs: { buttonClicked: "buttonClicked", closeClicked: "closeClicked", linkClicked: "linkClicked" }, ngImport: i0, template: "<div class=\"notification-message {{className}}\">\r\n <div class=\"notification-message-container tld-default-border\" [ngClass.lt-md]=\"'mobile'\" [class.inline]=\"inline\"\r\n fxLayout=\"row\" fxLayoutAlign=\"start start\" [attr.id]=\"message.id\" aria-live=\"polite\" fxLayout=\"row\">\r\n <span class=\"material-icons-outlined message-icon\">\r\n {{iconNames[message.type]}}\r\n </span>\r\n <div class=\"items-container\" fxFlex>\r\n <div fxLayout=\"row\">\r\n <div class=\"text-container\" fxFlex>\r\n <h1 *ngIf=\"message.title\" class=\"message-title\"\r\n [innerHtml]=\"message.title | translate: message.localizationParams\"></h1>\r\n <p *ngIf=\"message.body\" class=\"message-body\">\r\n <span [innerHtml]=\"message.body | translate: message.localizationParams\"></span>\r\n <span *ngIf=\"message.support\" [innerHtml]=\"message.support | translate: message.localizationParams\"></span>\r\n </p>\r\n </div>\r\n <tld-close-button *ngIf=\"!message.hideClose\" class=\"close-button\" [class.no-top-margin]=\"!message.title\" (tldClick)=\"closeClick()\">\r\n </tld-close-button>\r\n </div>\r\n <div fxLayout=\"row\" fxLayoutGap=\"16px\" fxLayoutAlign=\"start center\"\r\n *ngIf=\"message.buttonText || message.linkHref || message.routerLink\">\r\n <button class=\"message-action-button\" color=\"accent\" mat-flat-button *ngIf=\"message.buttonText\"\r\n (click)=\"buttonClick()\">{{message.buttonText | translate}} </button>\r\n <a class=\"message-action-link\" *ngIf=\"message.linkHref && message.linkText\" (click)=\"linkClick()\"\r\n [attr.href]=\"message.linkHref\">{{message.linkText |\r\n translate}}</a>\r\n <a class=\"message-action-link\" *ngIf=\"message.routerLink && message.linkText\" (click)=\"linkClick()\"\r\n [routerLink]=\"[message.routerLink]\">{{message.linkText |\r\n translate}}</a>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [":host{display:inline-block;width:100%}.close-button{position:absolute;top:.2em;right:.2em}.no-top-margin{top:0}.text-container{margin-right:45px}.notification-message{position:relative}.notification-message.basic .notification-message-container{background-color:var(--base-100)}.notification-message.basic .notification-message-container .close-button,.notification-message.basic .notification-message-container .message-icon{color:var(--base-40)}.notification-message.basic .notification-message-container .message-action-button{background-color:var(--base-40)}.notification-message.info .notification-message-container{background-color:var(--info-light)}.notification-message.info .notification-message-container .text-container{color:var(--info-dark)}.notification-message.info .notification-message-container .message-icon{color:var(--info-primary)}.notification-message.info .notification-message-container .close-button{color:var(--info-dark)}.notification-message.info .notification-message-container .message-action-button{background-color:var(--base-40)}.notification-message.error .notification-message-container{background-color:var(--error-light)}.notification-message.error .notification-message-container .close-button,.notification-message.error .notification-message-container .text-container,.notification-message.error .notification-message-container .message-icon{color:var(--error-dark)}.notification-message.error .notification-message-container .message-action-button{background-color:var(--base-40)}.notification-message.warning .notification-message-container{background-color:var(--warning-light)}.notification-message.warning .notification-message-container .close-button,.notification-message.warning .notification-message-container .text-container,.notification-message.warning .notification-message-container .message-icon{color:var(--warning-dark)}.notification-message.warning .notification-message-container .message-action-button{background-color:var(--base-40)}.notification-message.success .notification-message-container{background-color:var(--success-light)}.notification-message.success .notification-message-container .close-button,.notification-message.success .notification-message-container .text-container,.notification-message.success .notification-message-container .message-icon{color:var(--success-dark)}.notification-message.success .notification-message-container .message-action-button{background-color:var(--base-40)}.notification-message .notification-message-container{border-radius:4px}.notification-message .notification-message-container.mobile{padding:.6em .4em!important;border-radius:0}.notification-message .notification-message-container.mobile .items-container{margin-left:.4em!important}.notification-message .notification-message-container.mobile .items-container div+div{margin-top:.2em!important}.notification-message .notification-message-container.mobile .items-container .message-title+.message-body{margin-top:0!important}.notification-message .notification-message-container .text-container:first-child{line-height:1.5em}.notification-message .notification-message-container .text-container .message-title{font-weight:600;margin:0}.notification-message .notification-message-container .text-container .message-body{margin:0}.notification-message .notification-message-container:not(.inline){padding:1.5em}.notification-message .notification-message-container:not(.inline) .items-container{margin-left:1em}.notification-message .notification-message-container:not(.inline) .items-container div+div,.notification-message .notification-message-container:not(.inline) .items-container .message-title+.message-body{margin-top:1em}.notification-message .notification-message-container:not(.inline) .message-title{font-size:1.25em}.notification-message .notification-message-container:not(.inline) .message-body{line-height:1.5em}.notification-message .notification-message-container.inline{padding:.75em 1em}.notification-message .notification-message-container.inline .items-container{margin-left:.75em}.notification-message .notification-message-container.inline .items-container div+div{margin-top:.5em}.notification-message .notification-message-container.inline .items-container .message-title+.message-body{margin-top:.2em}.notification-message .notification-message-container.inline .message-title{font-size:1em}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { kind: "directive", type: i2.DefaultLayoutGapDirective, selector: " [fxLayoutGap], [fxLayoutGap.xs], [fxLayoutGap.sm], [fxLayoutGap.md], [fxLayoutGap.lg], [fxLayoutGap.xl], [fxLayoutGap.lt-sm], [fxLayoutGap.lt-md], [fxLayoutGap.lt-lg], [fxLayoutGap.lt-xl], [fxLayoutGap.gt-xs], [fxLayoutGap.gt-sm], [fxLayoutGap.gt-md], [fxLayoutGap.gt-lg]", inputs: ["fxLayoutGap", "fxLayoutGap.xs", "fxLayoutGap.sm", "fxLayoutGap.md", "fxLayoutGap.lg", "fxLayoutGap.xl", "fxLayoutGap.lt-sm", "fxLayoutGap.lt-md", "fxLayoutGap.lt-lg", "fxLayoutGap.lt-xl", "fxLayoutGap.gt-xs", "fxLayoutGap.gt-sm", "fxLayoutGap.gt-md", "fxLayoutGap.gt-lg"] }, { kind: "directive", type: i2.DefaultLayoutAlignDirective, selector: " [fxLayoutAlign], [fxLayoutAlign.xs], [fxLayoutAlign.sm], [fxLayoutAlign.md], [fxLayoutAlign.lg], [fxLayoutAlign.xl], [fxLayoutAlign.lt-sm], [fxLayoutAlign.lt-md], [fxLayoutAlign.lt-lg], [fxLayoutAlign.lt-xl], [fxLayoutAlign.gt-xs], [fxLayoutAlign.gt-sm], [fxLayoutAlign.gt-md], [fxLayoutAlign.gt-lg]", inputs: ["fxLayoutAlign", "fxLayoutAlign.xs", "fxLayoutAlign.sm", "fxLayoutAlign.md", "fxLayoutAlign.lg", "fxLayoutAlign.xl", "fxLayoutAlign.lt-sm", "fxLayoutAlign.lt-md", "fxLayoutAlign.lt-lg", "fxLayoutAlign.lt-xl", "fxLayoutAlign.gt-xs", "fxLayoutAlign.gt-sm", "fxLayoutAlign.gt-md", "fxLayoutAlign.gt-lg"] }, { kind: "directive", type: i2.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { kind: "directive", type: i3.DefaultClassDirective, selector: " [ngClass], [ngClass.xs], [ngClass.sm], [ngClass.md], [ngClass.lg], [ngClass.xl], [ngClass.lt-sm], [ngClass.lt-md], [ngClass.lt-lg], [ngClass.lt-xl], [ngClass.gt-xs], [ngClass.gt-sm], [ngClass.gt-md], [ngClass.gt-lg]", inputs: ["ngClass", "ngClass.xs", "ngClass.sm", "ngClass.md", "ngClass.lg", "ngClass.xl", "ngClass.lt-sm", "ngClass.lt-md", "ngClass.lt-lg", "ngClass.lt-xl", "ngClass.gt-xs", "ngClass.gt-sm", "ngClass.gt-md", "ngClass.gt-lg"] }, { kind: "component", type: i4.CloseButtonComponent, selector: "tld-close-button", inputs: ["ariaCode", "disabled", "tooltip"], outputs: ["tldClick"] }, { kind: "component", type: i5.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "directive", type: i6.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "pipe", type: i7.TranslatePipe, name: "translate" }] }); }
|
|
37
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NotificationMessageComponent, selector: "lib-tld-notification-message", inputs: { message: "message", inline: "inline" }, outputs: { buttonClicked: "buttonClicked", closeClicked: "closeClicked", linkClicked: "linkClicked" }, ngImport: i0, template: "<div class=\"notification-message {{className}}\">\r\n <div class=\"notification-message-container tld-default-border\" [ngClass.lt-md]=\"'mobile'\" [class.inline]=\"inline\"\r\n fxLayout=\"row\" fxLayoutAlign=\"start start\" [attr.id]=\"message.id\" aria-live=\"polite\" fxLayout=\"row\">\r\n <span class=\"material-icons-outlined message-icon\">\r\n {{iconNames[message.type]}}\r\n </span>\r\n <div class=\"items-container\" fxFlex>\r\n <div fxLayout=\"row\">\r\n <div class=\"text-container\" fxFlex>\r\n <h1 *ngIf=\"message.title\" class=\"message-title\"\r\n [innerHtml]=\"message.title | translate: message.localizationParams\"></h1>\r\n <p *ngIf=\"message.body\" class=\"message-body\">\r\n <span [innerHtml]=\"message.body | translate: message.localizationParams\"></span>\r\n <span *ngIf=\"message.support\" [innerHtml]=\"message.support | translate: message.localizationParams\"></span>\r\n </p>\r\n </div>\r\n <button \r\n *ngIf=\"message.callbackButtonText\" \r\n color=\"accent\" \r\n mat-stroked-button \r\n class=\"callback-button\" \r\n (click)=\"message?.callbackButtonClick()\"\r\n >\r\n <mat-icon *ngIf=\"message.callbackButtonIcon\">{{message.callbackButtonIcon}}</mat-icon>\r\n {{ message.callbackButtonText | translate }}\r\n </button>\r\n <tld-close-button *ngIf=\"!message.hideClose && !message.callbackButtonText\" class=\"close-button\" [class.no-top-margin]=\"!message.title\" (tldClick)=\"closeClick()\">\r\n </tld-close-button>\r\n </div>\r\n <div fxLayout=\"row\" fxLayoutGap=\"16px\" fxLayoutAlign=\"start center\"\r\n *ngIf=\"message.buttonText || message.linkHref || message.routerLink\">\r\n <button class=\"message-action-button\" color=\"accent\" mat-flat-button *ngIf=\"message.buttonText\"\r\n (click)=\"buttonClick()\">{{message.buttonText | translate}} </button>\r\n <a class=\"message-action-link\" *ngIf=\"message.linkHref && message.linkText\" (click)=\"linkClick()\"\r\n [attr.href]=\"message.linkHref\">{{message.linkText |\r\n translate}}</a>\r\n <a class=\"message-action-link\" *ngIf=\"message.routerLink && message.linkText\" (click)=\"linkClick()\"\r\n [routerLink]=\"[message.routerLink]\">{{message.linkText |\r\n translate}}</a>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [":host{display:inline-block;width:100%}.close-button{position:absolute;top:.2em;right:.2em}.no-top-margin{top:0}.text-container{margin-right:45px}.notification-message{position:relative}.notification-message.basic .notification-message-container{background-color:var(--base-100)}.notification-message.basic .notification-message-container .close-button,.notification-message.basic .notification-message-container .message-icon{color:var(--base-40)}.notification-message.basic .notification-message-container .message-action-button{background-color:var(--base-40)}.notification-message.info .notification-message-container{background-color:var(--info-light)}.notification-message.info .notification-message-container .text-container{color:var(--info-dark)}.notification-message.info .notification-message-container .message-icon{color:var(--info-primary)}.notification-message.info .notification-message-container .close-button{color:var(--info-dark)}.notification-message.info .notification-message-container .message-action-button{background-color:var(--base-40)}.notification-message.error .notification-message-container{background-color:var(--error-light)}.notification-message.error .notification-message-container .close-button,.notification-message.error .notification-message-container .text-container,.notification-message.error .notification-message-container .message-icon{color:var(--error-dark)}.notification-message.error .notification-message-container .message-action-button{background-color:var(--base-40)}.notification-message.warning .notification-message-container{background-color:var(--warning-light)}.notification-message.warning .notification-message-container .close-button,.notification-message.warning .notification-message-container .text-container,.notification-message.warning .notification-message-container .message-icon{color:var(--warning-dark)}.notification-message.warning .notification-message-container .message-action-button{background-color:var(--base-40)}.notification-message.success .notification-message-container{background-color:var(--success-light)}.notification-message.success .notification-message-container .close-button,.notification-message.success .notification-message-container .text-container,.notification-message.success .notification-message-container .message-icon{color:var(--success-dark)}.notification-message.success .notification-message-container .message-action-button{background-color:var(--base-40)}.notification-message .notification-message-container{border-radius:4px}.notification-message .notification-message-container.mobile{padding:.6em .4em!important;border-radius:0}.notification-message .notification-message-container.mobile .items-container{margin-left:.4em!important}.notification-message .notification-message-container.mobile .items-container div+div{margin-top:.2em!important}.notification-message .notification-message-container.mobile .items-container .message-title+.message-body{margin-top:0!important}.notification-message .notification-message-container .text-container:first-child{line-height:1.5em}.notification-message .notification-message-container .text-container .message-title{font-weight:600;margin:0}.notification-message .notification-message-container .text-container .message-body{margin:0}.notification-message .notification-message-container:not(.inline){padding:1.5em}.notification-message .notification-message-container:not(.inline) .items-container{margin-left:1em}.notification-message .notification-message-container:not(.inline) .items-container div+div,.notification-message .notification-message-container:not(.inline) .items-container .message-title+.message-body{margin-top:1em}.notification-message .notification-message-container:not(.inline) .message-title{font-size:1.25em}.notification-message .notification-message-container:not(.inline) .message-body{line-height:1.5em}.notification-message .notification-message-container.inline{padding:.75em 1em}.notification-message .notification-message-container.inline .items-container{margin-left:.75em}.notification-message .notification-message-container.inline .items-container div+div{margin-top:.5em}.notification-message .notification-message-container.inline .items-container .message-title+.message-body{margin-top:.2em}.notification-message .notification-message-container.inline .message-title{font-size:1em}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { kind: "directive", type: i2.DefaultLayoutGapDirective, selector: " [fxLayoutGap], [fxLayoutGap.xs], [fxLayoutGap.sm], [fxLayoutGap.md], [fxLayoutGap.lg], [fxLayoutGap.xl], [fxLayoutGap.lt-sm], [fxLayoutGap.lt-md], [fxLayoutGap.lt-lg], [fxLayoutGap.lt-xl], [fxLayoutGap.gt-xs], [fxLayoutGap.gt-sm], [fxLayoutGap.gt-md], [fxLayoutGap.gt-lg]", inputs: ["fxLayoutGap", "fxLayoutGap.xs", "fxLayoutGap.sm", "fxLayoutGap.md", "fxLayoutGap.lg", "fxLayoutGap.xl", "fxLayoutGap.lt-sm", "fxLayoutGap.lt-md", "fxLayoutGap.lt-lg", "fxLayoutGap.lt-xl", "fxLayoutGap.gt-xs", "fxLayoutGap.gt-sm", "fxLayoutGap.gt-md", "fxLayoutGap.gt-lg"] }, { kind: "directive", type: i2.DefaultLayoutAlignDirective, selector: " [fxLayoutAlign], [fxLayoutAlign.xs], [fxLayoutAlign.sm], [fxLayoutAlign.md], [fxLayoutAlign.lg], [fxLayoutAlign.xl], [fxLayoutAlign.lt-sm], [fxLayoutAlign.lt-md], [fxLayoutAlign.lt-lg], [fxLayoutAlign.lt-xl], [fxLayoutAlign.gt-xs], [fxLayoutAlign.gt-sm], [fxLayoutAlign.gt-md], [fxLayoutAlign.gt-lg]", inputs: ["fxLayoutAlign", "fxLayoutAlign.xs", "fxLayoutAlign.sm", "fxLayoutAlign.md", "fxLayoutAlign.lg", "fxLayoutAlign.xl", "fxLayoutAlign.lt-sm", "fxLayoutAlign.lt-md", "fxLayoutAlign.lt-lg", "fxLayoutAlign.lt-xl", "fxLayoutAlign.gt-xs", "fxLayoutAlign.gt-sm", "fxLayoutAlign.gt-md", "fxLayoutAlign.gt-lg"] }, { kind: "directive", type: i2.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { kind: "directive", type: i3.DefaultClassDirective, selector: " [ngClass], [ngClass.xs], [ngClass.sm], [ngClass.md], [ngClass.lg], [ngClass.xl], [ngClass.lt-sm], [ngClass.lt-md], [ngClass.lt-lg], [ngClass.lt-xl], [ngClass.gt-xs], [ngClass.gt-sm], [ngClass.gt-md], [ngClass.gt-lg]", inputs: ["ngClass", "ngClass.xs", "ngClass.sm", "ngClass.md", "ngClass.lg", "ngClass.xl", "ngClass.lt-sm", "ngClass.lt-md", "ngClass.lt-lg", "ngClass.lt-xl", "ngClass.gt-xs", "ngClass.gt-sm", "ngClass.gt-md", "ngClass.gt-lg"] }, { kind: "component", type: i4.CloseButtonComponent, selector: "tld-close-button", inputs: ["ariaCode", "disabled", "tooltip"], outputs: ["tldClick"] }, { kind: "component", type: i5.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "directive", type: i6.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "component", type: i7.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "pipe", type: i8.TranslatePipe, name: "translate" }] }); }
|
|
37
38
|
}
|
|
38
39
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NotificationMessageComponent, decorators: [{
|
|
39
40
|
type: Component,
|
|
40
|
-
args: [{ selector: 'lib-tld-notification-message', template: "<div class=\"notification-message {{className}}\">\r\n <div class=\"notification-message-container tld-default-border\" [ngClass.lt-md]=\"'mobile'\" [class.inline]=\"inline\"\r\n fxLayout=\"row\" fxLayoutAlign=\"start start\" [attr.id]=\"message.id\" aria-live=\"polite\" fxLayout=\"row\">\r\n <span class=\"material-icons-outlined message-icon\">\r\n {{iconNames[message.type]}}\r\n </span>\r\n <div class=\"items-container\" fxFlex>\r\n <div fxLayout=\"row\">\r\n <div class=\"text-container\" fxFlex>\r\n <h1 *ngIf=\"message.title\" class=\"message-title\"\r\n [innerHtml]=\"message.title | translate: message.localizationParams\"></h1>\r\n <p *ngIf=\"message.body\" class=\"message-body\">\r\n <span [innerHtml]=\"message.body | translate: message.localizationParams\"></span>\r\n <span *ngIf=\"message.support\" [innerHtml]=\"message.support | translate: message.localizationParams\"></span>\r\n </p>\r\n </div>\r\n <tld-close-button *ngIf=\"!message.hideClose\" class=\"close-button\" [class.no-top-margin]=\"!message.title\" (tldClick)=\"closeClick()\">\r\n </tld-close-button>\r\n </div>\r\n <div fxLayout=\"row\" fxLayoutGap=\"16px\" fxLayoutAlign=\"start center\"\r\n *ngIf=\"message.buttonText || message.linkHref || message.routerLink\">\r\n <button class=\"message-action-button\" color=\"accent\" mat-flat-button *ngIf=\"message.buttonText\"\r\n (click)=\"buttonClick()\">{{message.buttonText | translate}} </button>\r\n <a class=\"message-action-link\" *ngIf=\"message.linkHref && message.linkText\" (click)=\"linkClick()\"\r\n [attr.href]=\"message.linkHref\">{{message.linkText |\r\n translate}}</a>\r\n <a class=\"message-action-link\" *ngIf=\"message.routerLink && message.linkText\" (click)=\"linkClick()\"\r\n [routerLink]=\"[message.routerLink]\">{{message.linkText |\r\n translate}}</a>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [":host{display:inline-block;width:100%}.close-button{position:absolute;top:.2em;right:.2em}.no-top-margin{top:0}.text-container{margin-right:45px}.notification-message{position:relative}.notification-message.basic .notification-message-container{background-color:var(--base-100)}.notification-message.basic .notification-message-container .close-button,.notification-message.basic .notification-message-container .message-icon{color:var(--base-40)}.notification-message.basic .notification-message-container .message-action-button{background-color:var(--base-40)}.notification-message.info .notification-message-container{background-color:var(--info-light)}.notification-message.info .notification-message-container .text-container{color:var(--info-dark)}.notification-message.info .notification-message-container .message-icon{color:var(--info-primary)}.notification-message.info .notification-message-container .close-button{color:var(--info-dark)}.notification-message.info .notification-message-container .message-action-button{background-color:var(--base-40)}.notification-message.error .notification-message-container{background-color:var(--error-light)}.notification-message.error .notification-message-container .close-button,.notification-message.error .notification-message-container .text-container,.notification-message.error .notification-message-container .message-icon{color:var(--error-dark)}.notification-message.error .notification-message-container .message-action-button{background-color:var(--base-40)}.notification-message.warning .notification-message-container{background-color:var(--warning-light)}.notification-message.warning .notification-message-container .close-button,.notification-message.warning .notification-message-container .text-container,.notification-message.warning .notification-message-container .message-icon{color:var(--warning-dark)}.notification-message.warning .notification-message-container .message-action-button{background-color:var(--base-40)}.notification-message.success .notification-message-container{background-color:var(--success-light)}.notification-message.success .notification-message-container .close-button,.notification-message.success .notification-message-container .text-container,.notification-message.success .notification-message-container .message-icon{color:var(--success-dark)}.notification-message.success .notification-message-container .message-action-button{background-color:var(--base-40)}.notification-message .notification-message-container{border-radius:4px}.notification-message .notification-message-container.mobile{padding:.6em .4em!important;border-radius:0}.notification-message .notification-message-container.mobile .items-container{margin-left:.4em!important}.notification-message .notification-message-container.mobile .items-container div+div{margin-top:.2em!important}.notification-message .notification-message-container.mobile .items-container .message-title+.message-body{margin-top:0!important}.notification-message .notification-message-container .text-container:first-child{line-height:1.5em}.notification-message .notification-message-container .text-container .message-title{font-weight:600;margin:0}.notification-message .notification-message-container .text-container .message-body{margin:0}.notification-message .notification-message-container:not(.inline){padding:1.5em}.notification-message .notification-message-container:not(.inline) .items-container{margin-left:1em}.notification-message .notification-message-container:not(.inline) .items-container div+div,.notification-message .notification-message-container:not(.inline) .items-container .message-title+.message-body{margin-top:1em}.notification-message .notification-message-container:not(.inline) .message-title{font-size:1.25em}.notification-message .notification-message-container:not(.inline) .message-body{line-height:1.5em}.notification-message .notification-message-container.inline{padding:.75em 1em}.notification-message .notification-message-container.inline .items-container{margin-left:.75em}.notification-message .notification-message-container.inline .items-container div+div{margin-top:.5em}.notification-message .notification-message-container.inline .items-container .message-title+.message-body{margin-top:.2em}.notification-message .notification-message-container.inline .message-title{font-size:1em}\n"] }]
|
|
41
|
+
args: [{ selector: 'lib-tld-notification-message', template: "<div class=\"notification-message {{className}}\">\r\n <div class=\"notification-message-container tld-default-border\" [ngClass.lt-md]=\"'mobile'\" [class.inline]=\"inline\"\r\n fxLayout=\"row\" fxLayoutAlign=\"start start\" [attr.id]=\"message.id\" aria-live=\"polite\" fxLayout=\"row\">\r\n <span class=\"material-icons-outlined message-icon\">\r\n {{iconNames[message.type]}}\r\n </span>\r\n <div class=\"items-container\" fxFlex>\r\n <div fxLayout=\"row\">\r\n <div class=\"text-container\" fxFlex>\r\n <h1 *ngIf=\"message.title\" class=\"message-title\"\r\n [innerHtml]=\"message.title | translate: message.localizationParams\"></h1>\r\n <p *ngIf=\"message.body\" class=\"message-body\">\r\n <span [innerHtml]=\"message.body | translate: message.localizationParams\"></span>\r\n <span *ngIf=\"message.support\" [innerHtml]=\"message.support | translate: message.localizationParams\"></span>\r\n </p>\r\n </div>\r\n <button \r\n *ngIf=\"message.callbackButtonText\" \r\n color=\"accent\" \r\n mat-stroked-button \r\n class=\"callback-button\" \r\n (click)=\"message?.callbackButtonClick()\"\r\n >\r\n <mat-icon *ngIf=\"message.callbackButtonIcon\">{{message.callbackButtonIcon}}</mat-icon>\r\n {{ message.callbackButtonText | translate }}\r\n </button>\r\n <tld-close-button *ngIf=\"!message.hideClose && !message.callbackButtonText\" class=\"close-button\" [class.no-top-margin]=\"!message.title\" (tldClick)=\"closeClick()\">\r\n </tld-close-button>\r\n </div>\r\n <div fxLayout=\"row\" fxLayoutGap=\"16px\" fxLayoutAlign=\"start center\"\r\n *ngIf=\"message.buttonText || message.linkHref || message.routerLink\">\r\n <button class=\"message-action-button\" color=\"accent\" mat-flat-button *ngIf=\"message.buttonText\"\r\n (click)=\"buttonClick()\">{{message.buttonText | translate}} </button>\r\n <a class=\"message-action-link\" *ngIf=\"message.linkHref && message.linkText\" (click)=\"linkClick()\"\r\n [attr.href]=\"message.linkHref\">{{message.linkText |\r\n translate}}</a>\r\n <a class=\"message-action-link\" *ngIf=\"message.routerLink && message.linkText\" (click)=\"linkClick()\"\r\n [routerLink]=\"[message.routerLink]\">{{message.linkText |\r\n translate}}</a>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [":host{display:inline-block;width:100%}.close-button{position:absolute;top:.2em;right:.2em}.no-top-margin{top:0}.text-container{margin-right:45px}.notification-message{position:relative}.notification-message.basic .notification-message-container{background-color:var(--base-100)}.notification-message.basic .notification-message-container .close-button,.notification-message.basic .notification-message-container .message-icon{color:var(--base-40)}.notification-message.basic .notification-message-container .message-action-button{background-color:var(--base-40)}.notification-message.info .notification-message-container{background-color:var(--info-light)}.notification-message.info .notification-message-container .text-container{color:var(--info-dark)}.notification-message.info .notification-message-container .message-icon{color:var(--info-primary)}.notification-message.info .notification-message-container .close-button{color:var(--info-dark)}.notification-message.info .notification-message-container .message-action-button{background-color:var(--base-40)}.notification-message.error .notification-message-container{background-color:var(--error-light)}.notification-message.error .notification-message-container .close-button,.notification-message.error .notification-message-container .text-container,.notification-message.error .notification-message-container .message-icon{color:var(--error-dark)}.notification-message.error .notification-message-container .message-action-button{background-color:var(--base-40)}.notification-message.warning .notification-message-container{background-color:var(--warning-light)}.notification-message.warning .notification-message-container .close-button,.notification-message.warning .notification-message-container .text-container,.notification-message.warning .notification-message-container .message-icon{color:var(--warning-dark)}.notification-message.warning .notification-message-container .message-action-button{background-color:var(--base-40)}.notification-message.success .notification-message-container{background-color:var(--success-light)}.notification-message.success .notification-message-container .close-button,.notification-message.success .notification-message-container .text-container,.notification-message.success .notification-message-container .message-icon{color:var(--success-dark)}.notification-message.success .notification-message-container .message-action-button{background-color:var(--base-40)}.notification-message .notification-message-container{border-radius:4px}.notification-message .notification-message-container.mobile{padding:.6em .4em!important;border-radius:0}.notification-message .notification-message-container.mobile .items-container{margin-left:.4em!important}.notification-message .notification-message-container.mobile .items-container div+div{margin-top:.2em!important}.notification-message .notification-message-container.mobile .items-container .message-title+.message-body{margin-top:0!important}.notification-message .notification-message-container .text-container:first-child{line-height:1.5em}.notification-message .notification-message-container .text-container .message-title{font-weight:600;margin:0}.notification-message .notification-message-container .text-container .message-body{margin:0}.notification-message .notification-message-container:not(.inline){padding:1.5em}.notification-message .notification-message-container:not(.inline) .items-container{margin-left:1em}.notification-message .notification-message-container:not(.inline) .items-container div+div,.notification-message .notification-message-container:not(.inline) .items-container .message-title+.message-body{margin-top:1em}.notification-message .notification-message-container:not(.inline) .message-title{font-size:1.25em}.notification-message .notification-message-container:not(.inline) .message-body{line-height:1.5em}.notification-message .notification-message-container.inline{padding:.75em 1em}.notification-message .notification-message-container.inline .items-container{margin-left:.75em}.notification-message .notification-message-container.inline .items-container div+div{margin-top:.5em}.notification-message .notification-message-container.inline .items-container .message-title+.message-body{margin-top:.2em}.notification-message .notification-message-container.inline .message-title{font-size:1em}\n"] }]
|
|
41
42
|
}], propDecorators: { message: [{
|
|
42
43
|
type: Input
|
|
43
44
|
}], buttonClicked: [{
|
|
@@ -49,4 +50,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
49
50
|
}], inline: [{
|
|
50
51
|
type: Input
|
|
51
52
|
}] } });
|
|
52
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
53
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm90aWZpY2F0aW9uLW1lc3NhZ2UuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LWNvbW1vbi9zcmMvbGliL25vdGlmaWNhdGlvbi1tZXNzYWdlL25vdGlmaWNhdGlvbi1tZXNzYWdlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1jb21tb24vc3JjL2xpYi9ub3RpZmljYXRpb24tbWVzc2FnZS9ub3RpZmljYXRpb24tbWVzc2FnZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQVUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7Ozs7Ozs7O0FBUy9FLE1BQU0sT0FBTyw0QkFBNEI7SUFMekM7UUFRWSxrQkFBYSxHQUFHLElBQUksWUFBWSxFQUFFLENBQUM7UUFDbkMsaUJBQVksR0FBRyxJQUFJLFlBQVksRUFBRSxDQUFDO1FBQ2xDLGdCQUFXLEdBQUcsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUlsQyxjQUFTLEdBQWlEO1lBQ2pFLE9BQU8sRUFBRSxNQUFNO1lBQ2YsTUFBTSxFQUFFLE1BQU07WUFDZCxPQUFPLEVBQUUsT0FBTztZQUNoQixTQUFTLEVBQUUsY0FBYztZQUN6QixTQUFTLEVBQUUsTUFBTTtTQUNsQixDQUFBO0tBbUJGO0lBaEJDLFFBQVE7UUFDTixJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLGlCQUFpQixFQUFFLENBQUM7SUFDekQsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQTtJQUMvQixDQUFDO0lBRUQsVUFBVTtRQUNSLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFBO0lBQzlCLENBQUM7SUFFRCxTQUFTO1FBQ1AsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUE7SUFDN0IsQ0FBQzsrR0FoQ1UsNEJBQTRCO21HQUE1Qiw0QkFBNEIsNk5DVHpDLHE5RUEyQ0E7OzRGRGxDYSw0QkFBNEI7a0JBTHhDLFNBQVM7K0JBQ0UsOEJBQThCOzhCQUsvQixPQUFPO3NCQUFmLEtBQUs7Z0JBRUksYUFBYTtzQkFBdEIsTUFBTTtnQkFDRyxZQUFZO3NCQUFyQixNQUFNO2dCQUNHLFdBQVc7c0JBQXBCLE1BQU07Z0JBRUUsTUFBTTtzQkFBZCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkluaXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBOb3RpZmljYXRpb25NZXNzYWdlVHlwZSB9IGZyb20gJy4vZW51bXMvbm90aWZpY2F0aW9uLW1lc3NhZ2UtdHlwZS5lbnVtJztcclxuaW1wb3J0IHsgTm90aWZpY2F0aW9uTWVzc2FnZSB9IGZyb20gJy4vaW50ZXJmYWNlcy9ub3RpZmljYXRpb24tbWVzc2FnZS5tb2RlbCc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2xpYi10bGQtbm90aWZpY2F0aW9uLW1lc3NhZ2UnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9ub3RpZmljYXRpb24tbWVzc2FnZS5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vbm90aWZpY2F0aW9uLW1lc3NhZ2UuY29tcG9uZW50LnNjc3MnXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgTm90aWZpY2F0aW9uTWVzc2FnZUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcbiAgQElucHV0KCkgbWVzc2FnZSE6IE5vdGlmaWNhdGlvbk1lc3NhZ2U7XHJcblxyXG4gIEBPdXRwdXQoKSBidXR0b25DbGlja2VkID0gbmV3IEV2ZW50RW1pdHRlcigpO1xyXG4gIEBPdXRwdXQoKSBjbG9zZUNsaWNrZWQgPSBuZXcgRXZlbnRFbWl0dGVyKCk7XHJcbiAgQE91dHB1dCgpIGxpbmtDbGlja2VkID0gbmV3IEV2ZW50RW1pdHRlcigpO1xyXG4gIC8qKiBBZGRzIGFkZGl0aW9uYWwgY2xhc3MgdGhhdCBtYWtlcyBtZXNzYWdlIHRvIHRha2UgbGVzcyBzcGFjZSBvbiBzY3JlZW4uICovXHJcbiAgQElucHV0KCkgaW5saW5lITogYm9vbGVhbjtcclxuXHJcbiAgcmVhZG9ubHkgaWNvbk5hbWVzOiB7IFtrZXkgaW4gTm90aWZpY2F0aW9uTWVzc2FnZVR5cGVdOiBzdHJpbmcgfSA9IHtcclxuICAgIFwiQkFTSUNcIjogXCJpbmZvXCIsXHJcbiAgICBcIklORk9cIjogXCJpbmZvXCIsXHJcbiAgICBcIkVSUk9SXCI6IFwiZXJyb3JcIixcclxuICAgIFwiU1VDQ0VTU1wiOiBcImNoZWNrX2NpcmNsZVwiLFxyXG4gICAgXCJXQVJOSU5HXCI6IFwiaW5mb1wiLFxyXG4gIH1cclxuICBjbGFzc05hbWUhOiBzdHJpbmc7XHJcblxyXG4gIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgdGhpcy5jbGFzc05hbWUgPSB0aGlzLm1lc3NhZ2UudHlwZS50b0xvY2FsZUxvd2VyQ2FzZSgpO1xyXG4gIH1cclxuXHJcbiAgYnV0dG9uQ2xpY2soKSB7XHJcbiAgICB0aGlzLmJ1dHRvbkNsaWNrZWQubmV4dChudWxsKVxyXG4gIH1cclxuXHJcbiAgY2xvc2VDbGljaygpIHtcclxuICAgIHRoaXMuY2xvc2VDbGlja2VkLm5leHQobnVsbClcclxuICB9XHJcblxyXG4gIGxpbmtDbGljaygpe1xyXG4gICAgdGhpcy5saW5rQ2xpY2tlZC5uZXh0KG51bGwpXHJcbiAgfVxyXG5cclxufVxyXG4iLCI8ZGl2IGNsYXNzPVwibm90aWZpY2F0aW9uLW1lc3NhZ2Uge3tjbGFzc05hbWV9fVwiPlxyXG4gIDxkaXYgY2xhc3M9XCJub3RpZmljYXRpb24tbWVzc2FnZS1jb250YWluZXIgdGxkLWRlZmF1bHQtYm9yZGVyXCIgW25nQ2xhc3MubHQtbWRdPVwiJ21vYmlsZSdcIiBbY2xhc3MuaW5saW5lXT1cImlubGluZVwiXHJcbiAgICBmeExheW91dD1cInJvd1wiIGZ4TGF5b3V0QWxpZ249XCJzdGFydCBzdGFydFwiIFthdHRyLmlkXT1cIm1lc3NhZ2UuaWRcIiBhcmlhLWxpdmU9XCJwb2xpdGVcIiBmeExheW91dD1cInJvd1wiPlxyXG4gICAgPHNwYW4gY2xhc3M9XCJtYXRlcmlhbC1pY29ucy1vdXRsaW5lZCBtZXNzYWdlLWljb25cIj5cclxuICAgICAge3tpY29uTmFtZXNbbWVzc2FnZS50eXBlXX19XHJcbiAgICA8L3NwYW4+XHJcbiAgICA8ZGl2IGNsYXNzPVwiaXRlbXMtY29udGFpbmVyXCIgZnhGbGV4PlxyXG4gICAgICA8ZGl2IGZ4TGF5b3V0PVwicm93XCI+XHJcbiAgICAgICAgPGRpdiBjbGFzcz1cInRleHQtY29udGFpbmVyXCIgZnhGbGV4PlxyXG4gICAgICAgICAgPGgxICpuZ0lmPVwibWVzc2FnZS50aXRsZVwiIGNsYXNzPVwibWVzc2FnZS10aXRsZVwiXHJcbiAgICAgICAgICAgIFtpbm5lckh0bWxdPVwibWVzc2FnZS50aXRsZSB8IHRyYW5zbGF0ZTogbWVzc2FnZS5sb2NhbGl6YXRpb25QYXJhbXNcIj48L2gxPlxyXG4gICAgICAgICAgPHAgKm5nSWY9XCJtZXNzYWdlLmJvZHlcIiBjbGFzcz1cIm1lc3NhZ2UtYm9keVwiPlxyXG4gICAgICAgICAgICA8c3BhbiBbaW5uZXJIdG1sXT1cIm1lc3NhZ2UuYm9keSB8IHRyYW5zbGF0ZTogbWVzc2FnZS5sb2NhbGl6YXRpb25QYXJhbXNcIj48L3NwYW4+XHJcbiAgICAgICAgICAgIDxzcGFuICpuZ0lmPVwibWVzc2FnZS5zdXBwb3J0XCIgW2lubmVySHRtbF09XCJtZXNzYWdlLnN1cHBvcnQgfCB0cmFuc2xhdGU6IG1lc3NhZ2UubG9jYWxpemF0aW9uUGFyYW1zXCI+PC9zcGFuPlxyXG4gICAgICAgICAgPC9wPlxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgICAgIDxidXR0b24gXHJcbiAgICAgICAgICAqbmdJZj1cIm1lc3NhZ2UuY2FsbGJhY2tCdXR0b25UZXh0XCIgXHJcbiAgICAgICAgICBjb2xvcj1cImFjY2VudFwiIFxyXG4gICAgICAgICAgbWF0LXN0cm9rZWQtYnV0dG9uIFxyXG4gICAgICAgICAgY2xhc3M9XCJjYWxsYmFjay1idXR0b25cIiBcclxuICAgICAgICAgIChjbGljayk9XCJtZXNzYWdlPy5jYWxsYmFja0J1dHRvbkNsaWNrKClcIlxyXG4gICAgICAgID5cclxuICAgICAgICAgIDxtYXQtaWNvbiAqbmdJZj1cIm1lc3NhZ2UuY2FsbGJhY2tCdXR0b25JY29uXCI+e3ttZXNzYWdlLmNhbGxiYWNrQnV0dG9uSWNvbn19PC9tYXQtaWNvbj5cclxuICAgICAgICAgIHt7IG1lc3NhZ2UuY2FsbGJhY2tCdXR0b25UZXh0IHwgdHJhbnNsYXRlIH19XHJcbiAgICAgICAgPC9idXR0b24+XHJcbiAgICAgICAgPHRsZC1jbG9zZS1idXR0b24gKm5nSWY9XCIhbWVzc2FnZS5oaWRlQ2xvc2UgJiYgIW1lc3NhZ2UuY2FsbGJhY2tCdXR0b25UZXh0XCIgY2xhc3M9XCJjbG9zZS1idXR0b25cIiBbY2xhc3Mubm8tdG9wLW1hcmdpbl09XCIhbWVzc2FnZS50aXRsZVwiICh0bGRDbGljayk9XCJjbG9zZUNsaWNrKClcIj5cclxuICAgICAgICA8L3RsZC1jbG9zZS1idXR0b24+XHJcbiAgICAgIDwvZGl2PlxyXG4gICAgICA8ZGl2IGZ4TGF5b3V0PVwicm93XCIgZnhMYXlvdXRHYXA9XCIxNnB4XCIgZnhMYXlvdXRBbGlnbj1cInN0YXJ0IGNlbnRlclwiXHJcbiAgICAgICAgKm5nSWY9XCJtZXNzYWdlLmJ1dHRvblRleHQgfHwgbWVzc2FnZS5saW5rSHJlZiB8fCBtZXNzYWdlLnJvdXRlckxpbmtcIj5cclxuICAgICAgICA8YnV0dG9uIGNsYXNzPVwibWVzc2FnZS1hY3Rpb24tYnV0dG9uXCIgY29sb3I9XCJhY2NlbnRcIiBtYXQtZmxhdC1idXR0b24gKm5nSWY9XCJtZXNzYWdlLmJ1dHRvblRleHRcIlxyXG4gICAgICAgICAgKGNsaWNrKT1cImJ1dHRvbkNsaWNrKClcIj57e21lc3NhZ2UuYnV0dG9uVGV4dCB8IHRyYW5zbGF0ZX19IDwvYnV0dG9uPlxyXG4gICAgICAgIDxhIGNsYXNzPVwibWVzc2FnZS1hY3Rpb24tbGlua1wiICpuZ0lmPVwibWVzc2FnZS5saW5rSHJlZiAmJiBtZXNzYWdlLmxpbmtUZXh0XCIgKGNsaWNrKT1cImxpbmtDbGljaygpXCJcclxuICAgICAgICAgIFthdHRyLmhyZWZdPVwibWVzc2FnZS5saW5rSHJlZlwiPnt7bWVzc2FnZS5saW5rVGV4dCB8XHJcbiAgICAgICAgICB0cmFuc2xhdGV9fTwvYT5cclxuICAgICAgICA8YSBjbGFzcz1cIm1lc3NhZ2UtYWN0aW9uLWxpbmtcIiAqbmdJZj1cIm1lc3NhZ2Uucm91dGVyTGluayAmJiBtZXNzYWdlLmxpbmtUZXh0XCIgKGNsaWNrKT1cImxpbmtDbGljaygpXCJcclxuICAgICAgICAgIFtyb3V0ZXJMaW5rXT1cIlttZXNzYWdlLnJvdXRlckxpbmtdXCI+e3ttZXNzYWdlLmxpbmtUZXh0IHxcclxuICAgICAgICAgIHRyYW5zbGF0ZX19PC9hPlxyXG4gICAgICA8L2Rpdj5cclxuICAgIDwvZGl2PlxyXG4gIDwvZGl2PlxyXG48L2Rpdj5cclxuIl19
|
|
@@ -6,6 +6,7 @@ import { RouterModule } from '@angular/router';
|
|
|
6
6
|
import { TranslateModule } from '@ngx-translate/core';
|
|
7
7
|
import { CloseButtonModule } from '../close-button/close-button.module';
|
|
8
8
|
import { NotificationMessageComponent } from './notification-message.component';
|
|
9
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
9
10
|
import * as i0 from "@angular/core";
|
|
10
11
|
export class NotificationMessageModule {
|
|
11
12
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NotificationMessageModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
@@ -14,13 +15,15 @@ export class NotificationMessageModule {
|
|
|
14
15
|
CloseButtonModule,
|
|
15
16
|
MatButtonModule,
|
|
16
17
|
TranslateModule,
|
|
17
|
-
RouterModule
|
|
18
|
+
RouterModule,
|
|
19
|
+
MatIconModule], exports: [NotificationMessageComponent] }); }
|
|
18
20
|
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NotificationMessageModule, imports: [CommonModule,
|
|
19
21
|
FlexLayoutModule,
|
|
20
22
|
CloseButtonModule,
|
|
21
23
|
MatButtonModule,
|
|
22
24
|
TranslateModule,
|
|
23
|
-
RouterModule
|
|
25
|
+
RouterModule,
|
|
26
|
+
MatIconModule] }); }
|
|
24
27
|
}
|
|
25
28
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NotificationMessageModule, decorators: [{
|
|
26
29
|
type: NgModule,
|
|
@@ -34,11 +37,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
34
37
|
CloseButtonModule,
|
|
35
38
|
MatButtonModule,
|
|
36
39
|
TranslateModule,
|
|
37
|
-
RouterModule
|
|
40
|
+
RouterModule,
|
|
41
|
+
MatIconModule
|
|
38
42
|
],
|
|
39
43
|
exports: [
|
|
40
44
|
NotificationMessageComponent
|
|
41
45
|
]
|
|
42
46
|
}]
|
|
43
47
|
}] });
|
|
44
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
48
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm90aWZpY2F0aW9uLW1lc3NhZ2UubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LWNvbW1vbi9zcmMvbGliL25vdGlmaWNhdGlvbi1tZXNzYWdlL25vdGlmaWNhdGlvbi1tZXNzYWdlLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN4RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUN0RCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUN4RSxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUNoRixPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7O0FBcUJ2RCxNQUFNLE9BQU8seUJBQXlCOytHQUF6Qix5QkFBeUI7Z0hBQXpCLHlCQUF5QixpQkFmbEMsNEJBQTRCLGFBRzVCLFlBQVk7WUFDWixnQkFBZ0I7WUFDaEIsaUJBQWlCO1lBQ2pCLGVBQWU7WUFDZixlQUFlO1lBQ2YsWUFBWTtZQUNaLGFBQWEsYUFHYiw0QkFBNEI7Z0hBR25CLHlCQUF5QixZQVpsQyxZQUFZO1lBQ1osZ0JBQWdCO1lBQ2hCLGlCQUFpQjtZQUNqQixlQUFlO1lBQ2YsZUFBZTtZQUNmLFlBQVk7WUFDWixhQUFhOzs0RkFNSix5QkFBeUI7a0JBakJyQyxRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRTt3QkFDWiw0QkFBNEI7cUJBQzdCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLGdCQUFnQjt3QkFDaEIsaUJBQWlCO3dCQUNqQixlQUFlO3dCQUNmLGVBQWU7d0JBQ2YsWUFBWTt3QkFDWixhQUFhO3FCQUNkO29CQUNELE9BQU8sRUFBRTt3QkFDUCw0QkFBNEI7cUJBQzdCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgRmxleExheW91dE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2ZsZXgtbGF5b3V0JztcclxuaW1wb3J0IHsgTWF0QnV0dG9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uJztcclxuaW1wb3J0IHsgUm91dGVyTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcclxuaW1wb3J0IHsgVHJhbnNsYXRlTW9kdWxlIH0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSc7XHJcbmltcG9ydCB7IENsb3NlQnV0dG9uTW9kdWxlIH0gZnJvbSAnLi4vY2xvc2UtYnV0dG9uL2Nsb3NlLWJ1dHRvbi5tb2R1bGUnO1xyXG5pbXBvcnQgeyBOb3RpZmljYXRpb25NZXNzYWdlQ29tcG9uZW50IH0gZnJvbSAnLi9ub3RpZmljYXRpb24tbWVzc2FnZS5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XHJcblxyXG5cclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgZGVjbGFyYXRpb25zOiBbXHJcbiAgICBOb3RpZmljYXRpb25NZXNzYWdlQ29tcG9uZW50XHJcbiAgXSxcclxuICBpbXBvcnRzOiBbXHJcbiAgICBDb21tb25Nb2R1bGUsXHJcbiAgICBGbGV4TGF5b3V0TW9kdWxlLFxyXG4gICAgQ2xvc2VCdXR0b25Nb2R1bGUsXHJcbiAgICBNYXRCdXR0b25Nb2R1bGUsXHJcbiAgICBUcmFuc2xhdGVNb2R1bGUsXHJcbiAgICBSb3V0ZXJNb2R1bGUsXHJcbiAgICBNYXRJY29uTW9kdWxlXHJcbiAgXSxcclxuICBleHBvcnRzOiBbXHJcbiAgICBOb3RpZmljYXRpb25NZXNzYWdlQ29tcG9uZW50XHJcbiAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgTm90aWZpY2F0aW9uTWVzc2FnZU1vZHVsZSB7IH1cclxuIl19
|
|
@@ -38,7 +38,7 @@ export class TerminologyCollectionListComponent {
|
|
|
38
38
|
const srcKey = `"id":"${this.system.sourceLanguageCode}"`;
|
|
39
39
|
const trgKey = `"id":"${this.system.targetLanguageCode}"`;
|
|
40
40
|
data[this.system.systemId]?.collections.forEach((collection) => {
|
|
41
|
-
if (JSON.stringify(collection.termCollection?.languages ?? []).includes(srcKey && trgKey) || !collection.isTermPortalCollection) {
|
|
41
|
+
if (JSON.stringify(collection.termCollection?.languages ?? []).includes(srcKey && trgKey) || !collection.isTermPortalCollection || collection?.mtCollection) {
|
|
42
42
|
collections.push(collection);
|
|
43
43
|
}
|
|
44
44
|
});
|
|
@@ -67,4 +67,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
67
67
|
}], glossarySelectEvent: [{
|
|
68
68
|
type: Output
|
|
69
69
|
}] } });
|
|
70
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"terminology-collection-list.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-common/src/lib/terminology/components/terminology-panel/terminology-collection-list/terminology-collection-list.component.ts","../../../../../../../../projects/ngx-common/src/lib/terminology/components/terminology-panel/terminology-collection-list/terminology-collection-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from \"@angular/core\";\r\nimport { TerminologyService } from \"../../../services\";\r\nimport { CombinedCollection } from \"../../../models\";\r\nimport { Subject, takeUntil } from \"rxjs\";\r\nimport { TerminologyConfigService } from \"../../../config/services\";\r\n\r\n@Component({\r\n  selector: \"lib-terminology-collection-list\",\r\n  templateUrl: \"./terminology-collection-list.component.html\",\r\n  styleUrls: [\"./terminology-collection-list.component.scss\"],\r\n})\r\nexport class TerminologyCollectionListComponent implements OnInit {\r\n  @Input({ required: true }) system!: { systemId: string; sourceLanguageCode: string; targetLanguageCode: string };\r\n  @Input() selectedCollection!: CombinedCollection | null;\r\n  @Output() glossarySelectEvent = new EventEmitter<CombinedCollection | null>();\r\n\r\n  appName!: string;\r\n\r\n  collections: CombinedCollection[] = [];\r\n\r\n  readonly localizationKey = \"TERM_COLLECTIONS.\";\r\n  readonly tooltipLocalizationKey = \"TERM_COLLECTIONS.TOOLTIPS.\";\r\n\r\n  get hasAnyCollections() {\r\n    return this.terminologyService.hasAnyCollections(this.system.systemId) as boolean;\r\n  }\r\n\r\n  get hasEditPermissions() {\r\n    return this.terminologyService.hasEditPermissions as boolean;\r\n  }\r\n\r\n  private readonly destroy = new Subject();\r\n\r\n  constructor(\r\n    private readonly terminologyService: TerminologyService,\r\n    private readonly config: TerminologyConfigService\r\n  ) {\r\n    this.appName = this.config.termConfig.appName as string;\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.terminologyService.getCollections().pipe(takeUntil(this.destroy)).subscribe((data) => {\r\n      const collections: CombinedCollection[] = [];\r\n\r\n      if (data[this.system.systemId]?.collections) {\r\n        const srcKey = `\"id\":\"${this.system.sourceLanguageCode}\"`;\r\n        const trgKey = `\"id\":\"${this.system.targetLanguageCode}\"`;\r\n\r\n        data[this.system.systemId]?.collections.forEach((collection) => {\r\n          if (JSON.stringify(collection.termCollection?.languages ?? []).includes(srcKey && trgKey) || !collection.isTermPortalCollection) {\r\n            collections.push(collection);\r\n          }\r\n        })\r\n\r\n        this.collections = collections.sort(this.collectionsSortFunction);\r\n      }\r\n    });\r\n  }\r\n  \r\n  selectGlossary(collection: CombinedCollection | null): void {\r\n    this.glossarySelectEvent.emit(collection as CombinedCollection);\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.destroy.next(null);\r\n    this.destroy.complete();\r\n  }\r\n\r\n  private collectionsSortFunction = (a: CombinedCollection, b: CombinedCollection) => {\r\n    const aName = a.name ?? \"\";\r\n    const bName = b.name ?? \"\";\r\n\r\n    return Number(a.default) - Number(b.default) || aName.localeCompare(bName);\r\n  };\r\n}\r\n","<header class=\"tld-collection-list-header\">\r\n  <h1 class=\"term-window-title text-l-semi-bold\">\r\n    <span>{{ localizationKey + \"TITLE\" | translate }}</span>\r\n  </h1>\r\n  <ng-container *ngIf=\"hasAnyCollections\">\r\n    <p class=\"term-window-description text-s\">\r\n      <span>{{ localizationKey + \"DESCRIPTION\" | translate }}</span>\r\n    </p>\r\n  </ng-container>\r\n  <ng-container *ngIf=\"!hasAnyCollections\">\r\n    <p class=\"term-window-unavailable text-xl-semi-bold\">\r\n      {{ localizationKey + \"UNAVAILABLE_GLOSSARIES\" | translate }}\r\n    </p>\r\n\r\n    <p [innerHtml]=\"localizationKey + 'DESCRIPTION_EMPTY' | translate : {\r\n      srcLang: system.sourceLanguageCode | languageTranslate,\r\n      trgLang: system.targetLanguageCode | languageTranslate\r\n    }\" class=\"term-window-description text-m\"></p>\r\n  </ng-container>\r\n</header>\r\n<div *ngIf=\"hasAnyCollections\" class=\"tld-collection-list-body\">\r\n  <mat-radio-group [attr.aria-label]=\"localizationKey + 'ARIA_LABELS.RADIO_GROUP' | translate\">\r\n    <div fxLayout=\"row\" fxLayoutAlign=\"start center\" class=\"none-option\">\r\n      <mat-radio-button [class.mat-mdc-radio-checked]=\"!selectedCollection\" (click)=\"selectGlossary(null)\">\r\n        <span class=\"text-m-semi-bold\">\r\n          {{ localizationKey + \"SELECTED_NONE\" | translate }}\r\n        </span>\r\n      </mat-radio-button>\r\n    </div>\r\n    <div class=\"collection\" *ngFor=\"let collection of collections\">\r\n      <lib-terminology-collection-card\r\n        *ngIf=\"collection.status\"\r\n        class=\"collection-card\"\r\n        [collection]=\"collection\"\r\n        [engineId]=\"system.systemId\"\r\n        [selected]=\"selectedCollection\"\r\n        [localizationKey]=\"localizationKey\"\r\n        [tooltipLocalizationKey]=\"tooltipLocalizationKey\"\r\n        [hasEditPermissions]=\"hasEditPermissions\"\r\n        [sourceLanguageCode]=\"system.sourceLanguageCode\"\r\n        [targetLanguageCode]=\"system.targetLanguageCode\"\r\n        (glossarySelectEvent)=\"selectGlossary($event)\"\r\n      ></lib-terminology-collection-card>\r\n    </div>\r\n  </mat-radio-group>\r\n</div>\r\n"]}
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"terminology-collection-list.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-common/src/lib/terminology/components/terminology-panel/terminology-collection-list/terminology-collection-list.component.ts","../../../../../../../../projects/ngx-common/src/lib/terminology/components/terminology-panel/terminology-collection-list/terminology-collection-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from \"@angular/core\";\r\nimport { TerminologyService } from \"../../../services\";\r\nimport { CombinedCollection } from \"../../../models\";\r\nimport { Subject, takeUntil } from \"rxjs\";\r\nimport { TerminologyConfigService } from \"../../../config/services\";\r\n\r\n@Component({\r\n  selector: \"lib-terminology-collection-list\",\r\n  templateUrl: \"./terminology-collection-list.component.html\",\r\n  styleUrls: [\"./terminology-collection-list.component.scss\"],\r\n})\r\nexport class TerminologyCollectionListComponent implements OnInit {\r\n  @Input({ required: true }) system!: { systemId: string; sourceLanguageCode: string; targetLanguageCode: string };\r\n  @Input() selectedCollection!: CombinedCollection | null;\r\n  @Output() glossarySelectEvent = new EventEmitter<CombinedCollection | null>();\r\n\r\n  appName!: string;\r\n\r\n  collections: CombinedCollection[] = [];\r\n\r\n  readonly localizationKey = \"TERM_COLLECTIONS.\";\r\n  readonly tooltipLocalizationKey = \"TERM_COLLECTIONS.TOOLTIPS.\";\r\n\r\n  get hasAnyCollections() {\r\n    return this.terminologyService.hasAnyCollections(this.system.systemId) as boolean;\r\n  }\r\n\r\n  get hasEditPermissions() {\r\n    return this.terminologyService.hasEditPermissions as boolean;\r\n  }\r\n\r\n  private readonly destroy = new Subject();\r\n\r\n  constructor(\r\n    private readonly terminologyService: TerminologyService,\r\n    private readonly config: TerminologyConfigService\r\n  ) {\r\n    this.appName = this.config.termConfig.appName as string;\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.terminologyService.getCollections().pipe(takeUntil(this.destroy)).subscribe((data) => {\r\n      const collections: CombinedCollection[] = [];\r\n\r\n      if (data[this.system.systemId]?.collections) {\r\n        const srcKey = `\"id\":\"${this.system.sourceLanguageCode}\"`;\r\n        const trgKey = `\"id\":\"${this.system.targetLanguageCode}\"`;\r\n\r\n        data[this.system.systemId]?.collections.forEach((collection) => {\r\n          if (JSON.stringify(collection.termCollection?.languages ?? []).includes(srcKey && trgKey) || !collection.isTermPortalCollection || collection?.mtCollection) {\r\n            collections.push(collection);\r\n          }\r\n        })\r\n\r\n        this.collections = collections.sort(this.collectionsSortFunction);\r\n      }\r\n    });\r\n  }\r\n  \r\n  selectGlossary(collection: CombinedCollection | null): void {\r\n    this.glossarySelectEvent.emit(collection as CombinedCollection);\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.destroy.next(null);\r\n    this.destroy.complete();\r\n  }\r\n\r\n  private collectionsSortFunction = (a: CombinedCollection, b: CombinedCollection) => {\r\n    const aName = a.name ?? \"\";\r\n    const bName = b.name ?? \"\";\r\n\r\n    return Number(a.default) - Number(b.default) || aName.localeCompare(bName);\r\n  };\r\n}\r\n","<header class=\"tld-collection-list-header\">\r\n  <h1 class=\"term-window-title text-l-semi-bold\">\r\n    <span>{{ localizationKey + \"TITLE\" | translate }}</span>\r\n  </h1>\r\n  <ng-container *ngIf=\"hasAnyCollections\">\r\n    <p class=\"term-window-description text-s\">\r\n      <span>{{ localizationKey + \"DESCRIPTION\" | translate }}</span>\r\n    </p>\r\n  </ng-container>\r\n  <ng-container *ngIf=\"!hasAnyCollections\">\r\n    <p class=\"term-window-unavailable text-xl-semi-bold\">\r\n      {{ localizationKey + \"UNAVAILABLE_GLOSSARIES\" | translate }}\r\n    </p>\r\n\r\n    <p [innerHtml]=\"localizationKey + 'DESCRIPTION_EMPTY' | translate : {\r\n      srcLang: system.sourceLanguageCode | languageTranslate,\r\n      trgLang: system.targetLanguageCode | languageTranslate\r\n    }\" class=\"term-window-description text-m\"></p>\r\n  </ng-container>\r\n</header>\r\n<div *ngIf=\"hasAnyCollections\" class=\"tld-collection-list-body\">\r\n  <mat-radio-group [attr.aria-label]=\"localizationKey + 'ARIA_LABELS.RADIO_GROUP' | translate\">\r\n    <div fxLayout=\"row\" fxLayoutAlign=\"start center\" class=\"none-option\">\r\n      <mat-radio-button [class.mat-mdc-radio-checked]=\"!selectedCollection\" (click)=\"selectGlossary(null)\">\r\n        <span class=\"text-m-semi-bold\">\r\n          {{ localizationKey + \"SELECTED_NONE\" | translate }}\r\n        </span>\r\n      </mat-radio-button>\r\n    </div>\r\n    <div class=\"collection\" *ngFor=\"let collection of collections\">\r\n      <lib-terminology-collection-card\r\n        *ngIf=\"collection.status\"\r\n        class=\"collection-card\"\r\n        [collection]=\"collection\"\r\n        [engineId]=\"system.systemId\"\r\n        [selected]=\"selectedCollection\"\r\n        [localizationKey]=\"localizationKey\"\r\n        [tooltipLocalizationKey]=\"tooltipLocalizationKey\"\r\n        [hasEditPermissions]=\"hasEditPermissions\"\r\n        [sourceLanguageCode]=\"system.sourceLanguageCode\"\r\n        [targetLanguageCode]=\"system.targetLanguageCode\"\r\n        (glossarySelectEvent)=\"selectGlossary($event)\"\r\n      ></lib-terminology-collection-card>\r\n    </div>\r\n  </mat-radio-group>\r\n</div>\r\n"]}
|
package/esm2022/lib/terminology/components/terminology-panel/terminology-panel.component.mjs
CHANGED
|
@@ -12,6 +12,10 @@ export class TerminologyPanelComponent {
|
|
|
12
12
|
get hasAnyCollections() { return this.terminologyService.hasAnyCollections(this.system.systemId); }
|
|
13
13
|
get hasEditPermissions() { return this.terminologyService.hasEditPermissions; }
|
|
14
14
|
get canCreateCollections() { return this.terminologyService.canCreateCollections; }
|
|
15
|
+
get showGlossaryMenuAdvertisement() { return this.config.termConfig.showGlossaryMenuAdvertisement; }
|
|
16
|
+
get showGlossaryList() {
|
|
17
|
+
return (this.hasAnyCollections || this.canCreateCollections) && (this.showGlossaryMenuAdvertisement && this.hasAnyCollections || !this.showGlossaryMenuAdvertisement);
|
|
18
|
+
}
|
|
15
19
|
constructor(terminologyService, config) {
|
|
16
20
|
this.terminologyService = terminologyService;
|
|
17
21
|
this.config = config;
|
|
@@ -19,8 +23,15 @@ export class TerminologyPanelComponent {
|
|
|
19
23
|
this.readerLocalizationKey = "TERM_COLLECTIONS.READER.";
|
|
20
24
|
}
|
|
21
25
|
ngOnInit() {
|
|
26
|
+
this.systemId = this.system.systemId;
|
|
22
27
|
this.initializeData(this.system.sourceLanguageCode, this.system.targetLanguageCode, this.system.systemId, this.setSelectedFromLocalStorage);
|
|
23
28
|
}
|
|
29
|
+
ngOnChanges(changes) {
|
|
30
|
+
if (changes && this.systemId !== this.system.systemId) {
|
|
31
|
+
this.systemId = this.system.systemId;
|
|
32
|
+
this.initializeData(this.system.sourceLanguageCode, this.system.targetLanguageCode, this.system.systemId, this.setSelectedFromLocalStorage);
|
|
33
|
+
}
|
|
34
|
+
}
|
|
24
35
|
selectGlossary(collection) {
|
|
25
36
|
this.glossarySelectEvent.emit(collection);
|
|
26
37
|
}
|
|
@@ -33,11 +44,11 @@ export class TerminologyPanelComponent {
|
|
|
33
44
|
}
|
|
34
45
|
}
|
|
35
46
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TerminologyPanelComponent, deps: [{ token: i1.TerminologyService }, { token: i2.TerminologyConfigService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
36
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TerminologyPanelComponent, selector: "lib-terminology-panel", inputs: { system: "system", setSelectedFromLocalStorage: "setSelectedFromLocalStorage", selectedCollection: "selectedCollection" }, outputs: { glossarySelectEvent: "glossarySelectEvent" }, ngImport: i0, template: "<section class=\"tld-collection-list-wrapper\">\r\n <ng-container *ngIf=\"
|
|
47
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TerminologyPanelComponent, selector: "lib-terminology-panel", inputs: { system: "system", setSelectedFromLocalStorage: "setSelectedFromLocalStorage", selectedCollection: "selectedCollection" }, outputs: { glossarySelectEvent: "glossarySelectEvent" }, usesOnChanges: true, ngImport: i0, template: "<section class=\"tld-collection-list-wrapper\">\r\n <ng-container *ngIf=\"showGlossaryList; else emptyView\">\r\n <lib-terminology-collection-list (glossarySelectEvent)=\"selectGlossary($event)\" [system]=\"system\" [selectedCollection]=\"selectedCollection\"></lib-terminology-collection-list>\r\n\r\n <footer *ngIf=\"hasEditPermissions\" class=\"tld-collection-list-footer\" fxLayout=\"row\" fxLayoutAlign=\"start center\" fxLayoutGap=\"1rem\">\r\n <lib-terminology-create-collection [sourceLanguageCode]=\"sourceLanguageCode\" [targetLanguageCode]=\"targetLanguageCode\"></lib-terminology-create-collection>\r\n \r\n <a *ngIf=\"defaultGlossaryManagementLink\" [attr.href]=\"defaultGlossaryManagementLink\" class=\"default-glossary-management text-m\" target=\"_blank\">\r\n {{ \"TERM_COLLECTIONS.DEFAULT_GLOSSARY_MANAGEMENT\" | translate }}\r\n </a>\r\n </footer>\r\n </ng-container>\r\n <ng-template #emptyView>\r\n <section class=\"term-reader-wrapper\" fxLayout=\"column\" fxLayoutGap=\"16px\">\r\n <div>\r\n <h1 class=\"text-l-semi-bold\">{{ readerLocalizationKey + \"TITLE\" | translate }}</h1>\r\n <p class=\"text-xl-semi-bold glossary-unavailable\">{{ readerLocalizationKey + \"UNAVAILABLE\" | translate }}</p>\r\n <p [innerHtml]=\"readerLocalizationKey + 'TEXT' | translate\"></p>\r\n\r\n <!-- Will be uncommented with new menu implementation -->\r\n\r\n <!-- <p class=\"text-s-semi-bold hint-title\">{{ readerLocalizationKey + \"WHAT_IS_GLOSSARY_TITLE\" | translate }}</p>\r\n <p class=\"text-s\">{{ readerLocalizationKey + \"WHAT_IS_GLOSSARY_DESC\" | translate }}</p>\r\n \r\n <p class=\"text-s-semi-bold hint-title\">{{ readerLocalizationKey + \"BENEFITS_TITLE\" | translate }}</p>\r\n <p class=\"text-s\">{{ readerLocalizationKey + \"BENEFITS_DESC\" | translate }}</p> -->\r\n </div>\r\n </section>\r\n </ng-template>\r\n</section>\r\n", styles: [".tld-collection-list-footer{margin-top:1rem;padding:0 .75em 1em}.default-glossary-management{display:block;color:var(--base-30)}.term-reader-wrapper{margin:1em}.glossary-unavailable{font-weight:500;font-style:italic}.hint-title{margin-bottom:0}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { kind: "directive", type: i4.DefaultLayoutGapDirective, selector: " [fxLayoutGap], [fxLayoutGap.xs], [fxLayoutGap.sm], [fxLayoutGap.md], [fxLayoutGap.lg], [fxLayoutGap.xl], [fxLayoutGap.lt-sm], [fxLayoutGap.lt-md], [fxLayoutGap.lt-lg], [fxLayoutGap.lt-xl], [fxLayoutGap.gt-xs], [fxLayoutGap.gt-sm], [fxLayoutGap.gt-md], [fxLayoutGap.gt-lg]", inputs: ["fxLayoutGap", "fxLayoutGap.xs", "fxLayoutGap.sm", "fxLayoutGap.md", "fxLayoutGap.lg", "fxLayoutGap.xl", "fxLayoutGap.lt-sm", "fxLayoutGap.lt-md", "fxLayoutGap.lt-lg", "fxLayoutGap.lt-xl", "fxLayoutGap.gt-xs", "fxLayoutGap.gt-sm", "fxLayoutGap.gt-md", "fxLayoutGap.gt-lg"] }, { kind: "directive", type: i4.DefaultLayoutAlignDirective, selector: " [fxLayoutAlign], [fxLayoutAlign.xs], [fxLayoutAlign.sm], [fxLayoutAlign.md], [fxLayoutAlign.lg], [fxLayoutAlign.xl], [fxLayoutAlign.lt-sm], [fxLayoutAlign.lt-md], [fxLayoutAlign.lt-lg], [fxLayoutAlign.lt-xl], [fxLayoutAlign.gt-xs], [fxLayoutAlign.gt-sm], [fxLayoutAlign.gt-md], [fxLayoutAlign.gt-lg]", inputs: ["fxLayoutAlign", "fxLayoutAlign.xs", "fxLayoutAlign.sm", "fxLayoutAlign.md", "fxLayoutAlign.lg", "fxLayoutAlign.xl", "fxLayoutAlign.lt-sm", "fxLayoutAlign.lt-md", "fxLayoutAlign.lt-lg", "fxLayoutAlign.lt-xl", "fxLayoutAlign.gt-xs", "fxLayoutAlign.gt-sm", "fxLayoutAlign.gt-md", "fxLayoutAlign.gt-lg"] }, { kind: "component", type: i5.TerminologyCreateCollectionComponent, selector: "lib-terminology-create-collection", inputs: ["sourceLanguageCode", "targetLanguageCode"], outputs: ["collectionCreated"] }, { kind: "component", type: i6.TerminologyCollectionListComponent, selector: "lib-terminology-collection-list", inputs: ["system", "selectedCollection"], outputs: ["glossarySelectEvent"] }, { kind: "pipe", type: i7.TranslatePipe, name: "translate" }] }); }
|
|
37
48
|
}
|
|
38
49
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TerminologyPanelComponent, decorators: [{
|
|
39
50
|
type: Component,
|
|
40
|
-
args: [{ selector: "lib-terminology-panel", template: "<section class=\"tld-collection-list-wrapper\">\r\n <ng-container *ngIf=\"
|
|
51
|
+
args: [{ selector: "lib-terminology-panel", template: "<section class=\"tld-collection-list-wrapper\">\r\n <ng-container *ngIf=\"showGlossaryList; else emptyView\">\r\n <lib-terminology-collection-list (glossarySelectEvent)=\"selectGlossary($event)\" [system]=\"system\" [selectedCollection]=\"selectedCollection\"></lib-terminology-collection-list>\r\n\r\n <footer *ngIf=\"hasEditPermissions\" class=\"tld-collection-list-footer\" fxLayout=\"row\" fxLayoutAlign=\"start center\" fxLayoutGap=\"1rem\">\r\n <lib-terminology-create-collection [sourceLanguageCode]=\"sourceLanguageCode\" [targetLanguageCode]=\"targetLanguageCode\"></lib-terminology-create-collection>\r\n \r\n <a *ngIf=\"defaultGlossaryManagementLink\" [attr.href]=\"defaultGlossaryManagementLink\" class=\"default-glossary-management text-m\" target=\"_blank\">\r\n {{ \"TERM_COLLECTIONS.DEFAULT_GLOSSARY_MANAGEMENT\" | translate }}\r\n </a>\r\n </footer>\r\n </ng-container>\r\n <ng-template #emptyView>\r\n <section class=\"term-reader-wrapper\" fxLayout=\"column\" fxLayoutGap=\"16px\">\r\n <div>\r\n <h1 class=\"text-l-semi-bold\">{{ readerLocalizationKey + \"TITLE\" | translate }}</h1>\r\n <p class=\"text-xl-semi-bold glossary-unavailable\">{{ readerLocalizationKey + \"UNAVAILABLE\" | translate }}</p>\r\n <p [innerHtml]=\"readerLocalizationKey + 'TEXT' | translate\"></p>\r\n\r\n <!-- Will be uncommented with new menu implementation -->\r\n\r\n <!-- <p class=\"text-s-semi-bold hint-title\">{{ readerLocalizationKey + \"WHAT_IS_GLOSSARY_TITLE\" | translate }}</p>\r\n <p class=\"text-s\">{{ readerLocalizationKey + \"WHAT_IS_GLOSSARY_DESC\" | translate }}</p>\r\n \r\n <p class=\"text-s-semi-bold hint-title\">{{ readerLocalizationKey + \"BENEFITS_TITLE\" | translate }}</p>\r\n <p class=\"text-s\">{{ readerLocalizationKey + \"BENEFITS_DESC\" | translate }}</p> -->\r\n </div>\r\n </section>\r\n </ng-template>\r\n</section>\r\n", styles: [".tld-collection-list-footer{margin-top:1rem;padding:0 .75em 1em}.default-glossary-management{display:block;color:var(--base-30)}.term-reader-wrapper{margin:1em}.glossary-unavailable{font-weight:500;font-style:italic}.hint-title{margin-bottom:0}\n"] }]
|
|
41
52
|
}], ctorParameters: function () { return [{ type: i1.TerminologyService }, { type: i2.TerminologyConfigService }]; }, propDecorators: { system: [{
|
|
42
53
|
type: Input,
|
|
43
54
|
args: [{ required: true }]
|
|
@@ -49,4 +60,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
49
60
|
}], glossarySelectEvent: [{
|
|
50
61
|
type: Output
|
|
51
62
|
}] } });
|
|
52
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"terminology-panel.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-common/src/lib/terminology/components/terminology-panel/terminology-panel.component.ts","../../../../../../../projects/ngx-common/src/lib/terminology/components/terminology-panel/terminology-panel.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;;;;;;;;;AAU/E,MAAM,OAAO,yBAAyB;IAMpC,IAAI,eAAe,KAAK,OAAO,IAAI,CAAC,kBAAkB,CAAC,eAAe,CAAA,CAAC,CAAC;IACxE,IAAI,iBAAiB,KAAK,OAAO,IAAI,CAAC,kBAAkB,CAAC,iBAAiB,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAA,CAAC,CAAC;IAClG,IAAI,kBAAkB,KAAI,OAAO,IAAI,CAAC,kBAAkB,CAAC,kBAAkB,CAAA,CAAC,CAAC;IAC7E,IAAI,oBAAoB,KAAK,OAAO,IAAI,CAAC,kBAAkB,CAAC,oBAAoB,CAAA,CAAC,CAAC;IASlF,YAA6B,kBAAsC,EAAmB,MAAgC;QAAzF,uBAAkB,GAAlB,kBAAkB,CAAoB;QAAmB,WAAM,GAAN,MAAM,CAA0B;QAd5G,wBAAmB,GAAG,IAAI,YAAY,EAA6B,CAAC;QAYrE,0BAAqB,GAAG,0BAA0B,CAAC;IAE6D,CAAC;IAE1H,QAAQ;QACN,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,kBAAkB,EAAE,IAAI,CAAC,MAAM,CAAC,kBAAkB,EAAE,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,IAAI,CAAC,2BAA2B,CAAC,CAAC;IAC9I,CAAC;IAED,cAAc,CAAC,UAAqC;QAClD,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAC5C,CAAC;IAEO,cAAc,CAAC,OAAe,EAAE,OAAe,EAAE,QAAgB,EAAE,2BAAoC;QAC7G,IAAI,CAAC,kBAAkB,GAAG,OAAO,CAAC;QAClC,IAAI,CAAC,kBAAkB,GAAG,OAAO,CAAC;QAElC,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC,IAAI,CAAC,kBAAkB,EAAE,IAAI,CAAC,kBAAkB,CAAC,EAAE,2BAA2B,CAAC,CAAC;QAE7H,IAAI,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,6BAA6B,EAAE;YACxD,IAAI,CAAC,6BAA6B,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,6BAA6B,CAAC,QAAQ,CAAC,CAAC;SACrG;IACH,CAAC;+GArCU,yBAAyB;mGAAzB,yBAAyB,0PCVtC,08DA8BA;;4FDpBa,yBAAyB;kBALrC,SAAS;+BACE,uBAAuB;gJAKN,MAAM;sBAAhC,KAAK;uBAAC,EAAE,QAAQ,EAAE,IAAI,EAAE;gBACE,2BAA2B;sBAArD,KAAK;uBAAC,EAAE,QAAQ,EAAE,IAAI,EAAE;gBAChB,kBAAkB;sBAA1B,KAAK;gBACI,mBAAmB;sBAA5B,MAAM","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from \"@angular/core\";\r\nimport { TerminologyService } from \"../../services\";\r\nimport { TerminologyConfigService } from \"../../config/services\";\r\nimport { CombinedCollection } from \"../../models\";\r\n\r\n@Component({\r\n  selector: \"lib-terminology-panel\",\r\n  templateUrl: \"./terminology-panel.component.html\",\r\n  styleUrls: [\"./terminology-panel.component.scss\"],\r\n})\r\nexport class TerminologyPanelComponent implements OnInit {\r\n  @Input({ required: true }) system!: { systemId: string, sourceLanguageCode: string, targetLanguageCode: string };\r\n  @Input({ required: true }) setSelectedFromLocalStorage!: boolean;\r\n  @Input() selectedCollection!: CombinedCollection | null;\r\n  @Output() glossarySelectEvent = new EventEmitter<CombinedCollection | null>();\r\n  \r\n  get isAuthenticated() { return this.terminologyService.isAuthenticated }\r\n  get hasAnyCollections() { return this.terminologyService.hasAnyCollections(this.system.systemId) }\r\n  get hasEditPermissions(){ return this.terminologyService.hasEditPermissions }\r\n  get canCreateCollections() { return this.terminologyService.canCreateCollections }\r\n  \r\n  sourceLanguageCode!: string;\r\n  targetLanguageCode!: string;\r\n\r\n  defaultGlossaryManagementLink!: string;\r\n\r\n  readonly readerLocalizationKey = \"TERM_COLLECTIONS.READER.\";\r\n\r\n  constructor(private readonly terminologyService: TerminologyService, private readonly config: TerminologyConfigService) {}\r\n\r\n  ngOnInit(): void {\r\n    this.initializeData(this.system.sourceLanguageCode, this.system.targetLanguageCode, this.system.systemId, this.setSelectedFromLocalStorage);\r\n  }\r\n\r\n  selectGlossary(collection: CombinedCollection | null): void {\r\n    this.glossarySelectEvent.emit(collection);\r\n  }\r\n\r\n  private initializeData(srcLang: string, trgLang: string, systemId: string, setSelectedFromLocalStorage: boolean): void {\r\n    this.sourceLanguageCode = srcLang;\r\n    this.targetLanguageCode = trgLang;\r\n    \r\n    this.terminologyService.setEngine(systemId, [this.sourceLanguageCode, this.targetLanguageCode], setSelectedFromLocalStorage);\r\n    \r\n    if (this.config.termConfig.defaultGlossaryManagementLink) {\r\n      this.defaultGlossaryManagementLink = this.config.termConfig.defaultGlossaryManagementLink(systemId);\r\n    }\r\n  }\r\n}\r\n","<section class=\"tld-collection-list-wrapper\">\r\n  <ng-container *ngIf=\"hasAnyCollections || canCreateCollections; else emptyView\">\r\n    <lib-terminology-collection-list (glossarySelectEvent)=\"selectGlossary($event)\" [system]=\"system\" [selectedCollection]=\"selectedCollection\"></lib-terminology-collection-list>\r\n\r\n    <footer *ngIf=\"hasEditPermissions\" class=\"tld-collection-list-footer\" fxLayout=\"row\" fxLayoutAlign=\"start center\" fxLayoutGap=\"1rem\">\r\n      <lib-terminology-create-collection [sourceLanguageCode]=\"sourceLanguageCode\" [targetLanguageCode]=\"targetLanguageCode\"></lib-terminology-create-collection>\r\n    \r\n      <a *ngIf=\"defaultGlossaryManagementLink\" [attr.href]=\"defaultGlossaryManagementLink\" class=\"default-glossary-management text-m\" target=\"_blank\">\r\n        {{ \"TERM_COLLECTIONS.DEFAULT_GLOSSARY_MANAGEMENT\" | translate }}\r\n      </a>\r\n    </footer>\r\n  </ng-container>\r\n  <ng-template #emptyView>\r\n    <section class=\"term-reader-wrapper\" fxLayout=\"column\" fxLayoutGap=\"16px\">\r\n      <div>\r\n        <h1 class=\"text-l-semi-bold\">{{ readerLocalizationKey + \"TITLE\" | translate }}</h1>\r\n        <p class=\"text-xl-semi-bold glossary-unavailable\">{{ readerLocalizationKey + \"UNAVAILABLE\" | translate }}</p>\r\n        <p [innerHtml]=\"readerLocalizationKey + 'TEXT' | translate\"></p>\r\n\r\n        <!-- Will be uncommented with new menu implementation -->\r\n\r\n        <!-- <p class=\"text-s-semi-bold hint-title\">{{ readerLocalizationKey + \"WHAT_IS_GLOSSARY_TITLE\" | translate }}</p>\r\n        <p class=\"text-s\">{{ readerLocalizationKey + \"WHAT_IS_GLOSSARY_DESC\" | translate }}</p>\r\n        \r\n        <p class=\"text-s-semi-bold hint-title\">{{ readerLocalizationKey + \"BENEFITS_TITLE\" | translate }}</p>\r\n        <p class=\"text-s\">{{ readerLocalizationKey + \"BENEFITS_DESC\" | translate }}</p> -->\r\n      </div>\r\n    </section>\r\n  </ng-template>\r\n</section>\r\n"]}
|
|
63
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"terminology-panel.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-common/src/lib/terminology/components/terminology-panel/terminology-panel.component.ts","../../../../../../../projects/ngx-common/src/lib/terminology/components/terminology-panel/terminology-panel.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges } from \"@angular/core\";\r\nimport { TerminologyService } from \"../../services\";\r\nimport { TerminologyConfigService } from \"../../config/services\";\r\nimport { CombinedCollection } from \"../../models\";\r\n\r\n@Component({\r\n  selector: \"lib-terminology-panel\",\r\n  templateUrl: \"./terminology-panel.component.html\",\r\n  styleUrls: [\"./terminology-panel.component.scss\"],\r\n})\r\nexport class TerminologyPanelComponent implements OnInit, OnChanges {\r\n  @Input({ required: true }) system!: { systemId: string, sourceLanguageCode: string, targetLanguageCode: string };\r\n  @Input({ required: true }) setSelectedFromLocalStorage!: boolean;\r\n  @Input() selectedCollection!: CombinedCollection | null;\r\n  @Output() glossarySelectEvent = new EventEmitter<CombinedCollection | null>();\r\n  \r\n  get isAuthenticated() { return this.terminologyService.isAuthenticated }\r\n  get hasAnyCollections() { return this.terminologyService.hasAnyCollections(this.system.systemId) }\r\n  get hasEditPermissions(){ return this.terminologyService.hasEditPermissions }\r\n  get canCreateCollections() { return this.terminologyService.canCreateCollections }\r\n  get showGlossaryMenuAdvertisement() { return this.config.termConfig.showGlossaryMenuAdvertisement }\r\n  \r\n  get showGlossaryList() {\r\n    return (this.hasAnyCollections || this.canCreateCollections) && (this.showGlossaryMenuAdvertisement && this.hasAnyCollections || !this.showGlossaryMenuAdvertisement)\r\n  }\r\n\r\n  sourceLanguageCode!: string;\r\n  targetLanguageCode!: string;\r\n\r\n  defaultGlossaryManagementLink!: string;\r\n\r\n  readonly readerLocalizationKey = \"TERM_COLLECTIONS.READER.\";\r\n\r\n  constructor(private readonly terminologyService: TerminologyService, private readonly config: TerminologyConfigService) {}\r\n\r\n  private systemId!: string;\r\n\r\n  ngOnInit(): void {\r\n    this.systemId = this.system.systemId;\r\n    this.initializeData(this.system.sourceLanguageCode, this.system.targetLanguageCode, this.system.systemId, this.setSelectedFromLocalStorage);\r\n  }\r\n  \r\n  ngOnChanges(changes: SimpleChanges): void {\r\n      if (changes && this.systemId !== this.system.systemId) {\r\n        this.systemId = this.system.systemId;\r\n        this.initializeData(this.system.sourceLanguageCode, this.system.targetLanguageCode, this.system.systemId, this.setSelectedFromLocalStorage);\r\n      }\r\n  }\r\n\r\n  selectGlossary(collection: CombinedCollection | null): void {\r\n    this.glossarySelectEvent.emit(collection);\r\n  }\r\n\r\n  private initializeData(srcLang: string, trgLang: string, systemId: string, setSelectedFromLocalStorage: boolean): void {\r\n    this.sourceLanguageCode = srcLang;\r\n    this.targetLanguageCode = trgLang;\r\n    \r\n    this.terminologyService.setEngine(systemId, [this.sourceLanguageCode, this.targetLanguageCode], setSelectedFromLocalStorage);\r\n    \r\n    if (this.config.termConfig.defaultGlossaryManagementLink) {\r\n      this.defaultGlossaryManagementLink = this.config.termConfig.defaultGlossaryManagementLink(systemId);\r\n    }\r\n  }\r\n}\r\n","<section class=\"tld-collection-list-wrapper\">\r\n  <ng-container *ngIf=\"showGlossaryList; else emptyView\">\r\n    <lib-terminology-collection-list (glossarySelectEvent)=\"selectGlossary($event)\" [system]=\"system\" [selectedCollection]=\"selectedCollection\"></lib-terminology-collection-list>\r\n\r\n    <footer *ngIf=\"hasEditPermissions\" class=\"tld-collection-list-footer\" fxLayout=\"row\" fxLayoutAlign=\"start center\" fxLayoutGap=\"1rem\">\r\n      <lib-terminology-create-collection [sourceLanguageCode]=\"sourceLanguageCode\" [targetLanguageCode]=\"targetLanguageCode\"></lib-terminology-create-collection>\r\n    \r\n      <a *ngIf=\"defaultGlossaryManagementLink\" [attr.href]=\"defaultGlossaryManagementLink\" class=\"default-glossary-management text-m\" target=\"_blank\">\r\n        {{ \"TERM_COLLECTIONS.DEFAULT_GLOSSARY_MANAGEMENT\" | translate }}\r\n      </a>\r\n    </footer>\r\n  </ng-container>\r\n  <ng-template #emptyView>\r\n    <section class=\"term-reader-wrapper\" fxLayout=\"column\" fxLayoutGap=\"16px\">\r\n      <div>\r\n        <h1 class=\"text-l-semi-bold\">{{ readerLocalizationKey + \"TITLE\" | translate }}</h1>\r\n        <p class=\"text-xl-semi-bold glossary-unavailable\">{{ readerLocalizationKey + \"UNAVAILABLE\" | translate }}</p>\r\n        <p [innerHtml]=\"readerLocalizationKey + 'TEXT' | translate\"></p>\r\n\r\n        <!-- Will be uncommented with new menu implementation -->\r\n\r\n        <!-- <p class=\"text-s-semi-bold hint-title\">{{ readerLocalizationKey + \"WHAT_IS_GLOSSARY_TITLE\" | translate }}</p>\r\n        <p class=\"text-s\">{{ readerLocalizationKey + \"WHAT_IS_GLOSSARY_DESC\" | translate }}</p>\r\n        \r\n        <p class=\"text-s-semi-bold hint-title\">{{ readerLocalizationKey + \"BENEFITS_TITLE\" | translate }}</p>\r\n        <p class=\"text-s\">{{ readerLocalizationKey + \"BENEFITS_DESC\" | translate }}</p> -->\r\n      </div>\r\n    </section>\r\n  </ng-template>\r\n</section>\r\n"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVybWlub2xvZ3ktY29uZmlnLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LWNvbW1vbi9zcmMvbGliL3Rlcm1pbm9sb2d5L2NvbmZpZy9tb2RlbHMvdGVybWlub2xvZ3ktY29uZmlnLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcclxuICogSW50ZXJmYWNlIGZvciBjb25maWd1cmF0aW5nIGNvbGxlY3Rpb24gc3VwcG9ydCBmcm9tIE1UIGFwaSBhbmQgVGlsZGUgVGVybS5cclxuICovXHJcbmV4cG9ydCBpbnRlcmZhY2UgVGVybWlub2xvZ3lDb25maWcge1xyXG4gIGFwcE5hbWU/OiBzdHJpbmc7XHJcbiAgaXNBdXRoPzogYm9vbGVhbjtcclxuICB4QXBpS2V5Pzogc3RyaW5nO1xyXG4gIG1heFJlY2VudFN5c3RlbUNvdW50PzogbnVtYmVyO1xyXG4gIGRlZmF1bHREb21haW5zPzogc3RyaW5nW107XHJcbiAgYXV0b0RvbWFpbkRldGVjdGlvbj86IGJvb2xlYW47XHJcbiAgc3lzdGVtTGlzdFVybD86IHN0cmluZztcclxuICBkZWZhdWx0VmVuZG9yPzogc3RyaW5nO1xyXG4gIGFsbG93ZWRTeXN0ZW1TdGF0dXNlcz86IHN0cmluZ1tdO1xyXG4gIGFwcElkPzogc3RyaW5nO1xyXG4gIC8qKiBUaWxkZSB0ZXJtIHBvcnRhbCBBUEkgdXJsICovXHJcbiAgdGVybWlub2xvZ3lQb3J0YWxVcmw/OiBzdHJpbmc7XHJcbiAgLyoqIElmIHVzZXIgaGFzIHBlcm1pc3Npb25zIHRvIGNyZWF0ZS9lZGl0IG5ldyBjb2xsZWN0aW9uLiBUaGlzIHNob3VsZCBiZSB2YWxpZGF0ZWQgb3V0c2lkZSBvZiB0aGUgbGlicmFyeSAqL1xyXG4gIGNhbkNyZWF0ZUNvbGxlY3Rpb24/
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVybWlub2xvZ3ktY29uZmlnLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LWNvbW1vbi9zcmMvbGliL3Rlcm1pbm9sb2d5L2NvbmZpZy9tb2RlbHMvdGVybWlub2xvZ3ktY29uZmlnLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcclxuICogSW50ZXJmYWNlIGZvciBjb25maWd1cmF0aW5nIGNvbGxlY3Rpb24gc3VwcG9ydCBmcm9tIE1UIGFwaSBhbmQgVGlsZGUgVGVybS5cclxuICovXHJcbmV4cG9ydCBpbnRlcmZhY2UgVGVybWlub2xvZ3lDb25maWcge1xyXG4gIGFwcE5hbWU/OiBzdHJpbmc7XHJcbiAgaXNBdXRoPzogYm9vbGVhbjtcclxuICB4QXBpS2V5Pzogc3RyaW5nO1xyXG4gIG1heFJlY2VudFN5c3RlbUNvdW50PzogbnVtYmVyO1xyXG4gIGRlZmF1bHREb21haW5zPzogc3RyaW5nW107XHJcbiAgYXV0b0RvbWFpbkRldGVjdGlvbj86IGJvb2xlYW47XHJcbiAgc3lzdGVtTGlzdFVybD86IHN0cmluZztcclxuICBkZWZhdWx0VmVuZG9yPzogc3RyaW5nO1xyXG4gIGFsbG93ZWRTeXN0ZW1TdGF0dXNlcz86IHN0cmluZ1tdO1xyXG4gIGFwcElkPzogc3RyaW5nO1xyXG4gIC8qKiBUaWxkZSB0ZXJtIHBvcnRhbCBBUEkgdXJsICovXHJcbiAgdGVybWlub2xvZ3lQb3J0YWxVcmw/OiBzdHJpbmc7XHJcbiAgLyoqIElmIHVzZXIgaGFzIHBlcm1pc3Npb25zIHRvIGNyZWF0ZS9lZGl0IG5ldyBjb2xsZWN0aW9uLiBUaGlzIHNob3VsZCBiZSB2YWxpZGF0ZWQgb3V0c2lkZSBvZiB0aGUgbGlicmFyeSAqL1xyXG4gIGNhbkNyZWF0ZUNvbGxlY3Rpb24/OiBib29sZWFuO1xyXG4gIC8qKiBXaGV0aGVyIGNvbGxlY3Rpb25zIHNob3VsZCBiZSByZWFkIGZyb20gYm90aCBBUElzKi9cclxuICBpc0NvbGxlY3Rpb25zQWN0aXZhdGVkPzogYm9vbGVhbjtcclxuICAvKiogSWYgdHJ1ZSBhbmQgbGFuZ3VhZ2UgZGlyZWN0aW9uIGNvbGxlY3Rpb25zIGFyZSB1bmF2YWlsYWJsZSBtZW51IHdpbGwgYmUgaGlkZGVuLiAqL1xyXG4gIGhpZGVHbG9zc2FyeU1lbnVXaXRob3V0Q29sbGVjdGlvbnM/OiBib29sZWFuO1xyXG4gIC8qKiBJZiB0cnVlIGFuZCBsYW5ndWFnZSBkaXJlY3Rpb24gY29sbGVjdGlvbnMgYXJlIHVuYXZhaWxhYmxlIG1lbnUgd2l0aCBhZHZlcnRpc2VtZW50IHdpbGwgYXBwZWFyLiBPdGhlcndpc2UsIGNyZWF0ZSBuZXcgZ2xvc3NhcnkgdmlldyB3aWxsIGFwcGVhci4gKi9cclxuICBzaG93R2xvc3NhcnlNZW51QWR2ZXJ0aXNlbWVudD86IGJvb2xlYW47XHJcbiAgLyoqIERldGVybWluZXMgaWYgVGlsZGUgVGVybWlub2xvZ3kgcG9ydGFsIGlzIHN1cHBvcnRlZCovXHJcbiAgaXNUZXJtUG9ydGFsU3VwcG9ydGVkPzogYm9vbGVhbjtcclxuICAvKiogTWluIGxlbmd0aCBmb3IgY29sbGVjdGlvbiBuYW1lIGlucHV0Ki9cclxuICBjb2xsZWN0aW9uTmFtZU1pbkxlbmd0aD86IG51bWJlcjtcclxuICAvKiogTWF4IGxlbmd0aCBmb3IgY29sbGVjdGlvbiBuYW1lIGlucHV0Ki9cclxuICBjb2xsZWN0aW9uTmFtZU1heExlbmd0aD86IG51bWJlcjtcclxuICAvKiogVGltZW91dCBpbiBtcyBhZnRlciBob3cgbG9uZyBzaG91dCBoYXBwZW4gYXV0b21hdGljIHJlZnJlc2ggb2YgY29sbGVjdGlvbiBsaXN0IChGcm9tIGJvdGggTVQgYW5kIHRlcm0gYXBpKSovXHJcbiAgcmVmcmVzaFRpbWVvdXRNcz86IG51bWJlcjtcclxuICAvKiogT3ZlcnJpZGVzIHJlZnJlc2hUaW1lb3V0TXMgaWYgYW55IG9mIGNvbGxlY3Rpb25zIGlzIGltcG9ydGluZy5cclxuICAvIFVzZSBjYXNlOiBub3JtYWx5IHJlZnJlc2hpbmcgbGlzdCBldmVyeSAxMHNlY29uZHMsIGJ1dCB3aGVuIGNvbGxlY3Rpb24gaXMgaW1wb3J0ZW5kLCB3ZSBtaWdodCB3YW50IHRvIHJlZnJlc2ggbGlzdCBldmVyeSA1c2Vjcywgc28gdXNlciBnZXRzIGZhc3RlciBmZWVkYmFjayB3aGVuIGltcG9ydCBmaW5pc2hlZC5cclxuICAqL1xyXG4gIHJlZnJlc2hUaW1lb3V0TXNXaGVuSW1wb3J0aW5nPzogbnVtYmVyO1xyXG4gIC8vKiogRW5naW5lIFRlcm0gdjIgQVBJIHVybCAqL1xyXG4gIGVuZ2luZVRlcm1Vcmw/OiBzdHJpbmc7XHJcbiAgLyoqIExpbmsgZm9yIGRlZmF1bHQgZ2xvc3NhcnkgbWFuYWdlbWVudCBsaW5rIGluIGdsb3NzYXJ5IHBvcHVwLiAqL1xyXG4gIGRlZmF1bHRHbG9zc2FyeU1hbmFnZW1lbnRMaW5rPzogKGVuZ2luZUlkOiBzdHJpbmcpID0+IHN0cmluZztcclxufVxyXG4iXX0=
|
package/esm2022/lib/terminology/config/services/terminology-config/terminology-config.service.mjs
CHANGED
|
@@ -15,7 +15,7 @@ export class TerminologyConfigService {
|
|
|
15
15
|
this._termConfig.xApiKey = config?.xApiKey;
|
|
16
16
|
this._termConfig.systemListUrl = config?.systemListUrl ?? this.defaultApiUrl;
|
|
17
17
|
this._termConfig.engineTermUrl = config?.engineTermUrl ?? this.defaultApiUrl;
|
|
18
|
-
this._termConfig.terminologyPortalUrl = config?.terminologyPortalUrl ?? "https://term.tilde.
|
|
18
|
+
this._termConfig.terminologyPortalUrl = config?.terminologyPortalUrl ?? "https://mtnova-test-term.tilde.lv";
|
|
19
19
|
this._termConfig.isTermPortalSupported = config?.isTermPortalSupported ?? false;
|
|
20
20
|
this._termConfig.refreshTimeoutMs = config?.refreshTimeoutMs ?? 10000;
|
|
21
21
|
this._termConfig.refreshTimeoutMsWhenImporting = config?.refreshTimeoutMsWhenImporting ?? 5000;
|
|
@@ -24,6 +24,8 @@ export class TerminologyConfigService {
|
|
|
24
24
|
this._termConfig.canCreateCollection = config?.canCreateCollection;
|
|
25
25
|
this._termConfig.isAuth = config?.isAuth ?? false;
|
|
26
26
|
this._termConfig.defaultGlossaryManagementLink = config?.defaultGlossaryManagementLink;
|
|
27
|
+
this._termConfig.hideGlossaryMenuWithoutCollections = config?.hideGlossaryMenuWithoutCollections ?? false;
|
|
28
|
+
this._termConfig.showGlossaryMenuAdvertisement = config?.showGlossaryMenuAdvertisement ?? false;
|
|
27
29
|
this._termConfig.isCollectionsActivated = config?.isCollectionsActivated;
|
|
28
30
|
this._termConfig.maxRecentSystemCount = config?.maxRecentSystemCount ?? 4;
|
|
29
31
|
this._termConfig.autoDomainDetection = config?.autoDomainDetection ?? false;
|
|
@@ -40,4 +42,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
40
42
|
providedIn: "root",
|
|
41
43
|
}]
|
|
42
44
|
}] });
|
|
43
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVybWlub2xvZ3ktY29uZmlnLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtY29tbW9uL3NyYy9saWIvdGVybWlub2xvZ3kvY29uZmlnL3NlcnZpY2VzL3Rlcm1pbm9sb2d5LWNvbmZpZy90ZXJtaW5vbG9neS1jb25maWcuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQU0zQyxNQUFNLE9BQU8sd0JBQXdCO0lBSHJDO1FBSVUsZ0JBQVcsR0FBc0IsRUFBRSxDQUFDO1FBTTNCLGtCQUFhLEdBQUcseUNBQXlDLENBQUM7S0E2QjVFO0lBakNDLElBQUksVUFBVTtRQUNaLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQztJQUMxQixDQUFDO0lBSUQsV0FBVyxDQUFDLGFBQWlDO1FBQzNDLE1BQU0sTUFBTSxHQUFHLGFBQWEsSUFBSSxFQUFFLENBQUM7UUFFbkMsSUFBSSxDQUFDLFdBQVcsQ0FBQyx1QkFBdUIsR0FBRyxNQUFNLEVBQUUsdUJBQXVCLElBQUksQ0FBQyxDQUFDO1FBQ2hGLElBQUksQ0FBQyxXQUFXLENBQUMsdUJBQXVCLEdBQUcsTUFBTSxFQUFFLHVCQUF1QixJQUFJLEdBQUcsQ0FBQztRQUNsRixJQUFJLENBQUMsV0FBVyxDQUFDLE9BQU8sR0FBRyxNQUFNLEVBQUUsT0FBTyxDQUFDO1FBQzNDLElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxHQUFHLE1BQU0sRUFBRSxhQUFhLElBQUksSUFBSSxDQUFDLGFBQWEsQ0FBQztRQUM3RSxJQUFJLENBQUMsV0FBVyxDQUFDLGFBQWEsR0FBRyxNQUFNLEVBQUUsYUFBYSxJQUFJLElBQUksQ0FBQyxhQUFhLENBQUM7UUFDN0UsSUFBSSxDQUFDLFdBQVcsQ0FBQyxvQkFBb0IsR0FBRyxNQUFNLEVBQUUsb0JBQW9CLElBQUksbUNBQW1DLENBQUM7UUFDNUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxxQkFBcUIsR0FBRyxNQUFNLEVBQUUscUJBQXFCLElBQUksS0FBSyxDQUFDO1FBQ2hGLElBQUksQ0FBQyxXQUFXLENBQUMsZ0JBQWdCLEdBQUcsTUFBTSxFQUFFLGdCQUFnQixJQUFJLEtBQUssQ0FBQztRQUN0RSxJQUFJLENBQUMsV0FBVyxDQUFDLDZCQUE2QixHQUFHLE1BQU0sRUFBRSw2QkFBNkIsSUFBSSxJQUFJLENBQUM7UUFDL0YsSUFBSSxDQUFDLFdBQVcsQ0FBQyxxQkFBcUIsR0FBRyxNQUFNLEVBQUUscUJBQXFCLElBQUksQ0FBQyxTQUFTLEVBQUUsU0FBUyxFQUFFLGVBQWUsQ0FBQyxDQUFDO1FBQ2xILElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxHQUFHLE1BQU0sRUFBRSxhQUFhLElBQUksT0FBTyxDQUFDO1FBQ2xFLElBQUksQ0FBQyxXQUFXLENBQUMsbUJBQW1CLEdBQUcsTUFBTSxFQUFFLG1CQUFtQixDQUFDO1FBQ25FLElBQUksQ0FBQyxXQUFXLENBQUMsTUFBTSxHQUFHLE1BQU0sRUFBRSxNQUFNLElBQUksS0FBSyxDQUFDO1FBQ2xELElBQUksQ0FBQyxXQUFXLENBQUMsNkJBQTZCLEdBQUcsTUFBTSxFQUFFLDZCQUE2QixDQUFDO1FBQ3ZGLElBQUksQ0FBQyxXQUFXLENBQUMsa0NBQWtDLEdBQUcsTUFBTSxFQUFFLGtDQUFrQyxJQUFJLEtBQUssQ0FBQztRQUMxRyxJQUFJLENBQUMsV0FBVyxDQUFDLDZCQUE2QixHQUFHLE1BQU0sRUFBRSw2QkFBNkIsSUFBSSxLQUFLLENBQUM7UUFFaEcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxzQkFBc0IsR0FBRyxNQUFNLEVBQUUsc0JBQXNCLENBQUM7UUFDekUsSUFBSSxDQUFDLFdBQVcsQ0FBQyxvQkFBb0IsR0FBRyxNQUFNLEVBQUUsb0JBQW9CLElBQUksQ0FBQyxDQUFDO1FBQzFFLElBQUksQ0FBQyxXQUFXLENBQUMsbUJBQW1CLEdBQUcsTUFBTSxFQUFFLG1CQUFtQixJQUFJLEtBQUssQ0FBQztRQUM1RSxJQUFJLENBQUMsV0FBVyxDQUFDLGNBQWMsR0FBRyxNQUFNLEVBQUUsY0FBYyxJQUFJLENBQUMsS0FBSyxFQUFFLFNBQVMsQ0FBQyxDQUFDO1FBQy9FLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxHQUFHLE1BQU0sRUFBRSxLQUFLLENBQUM7UUFDdkMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxPQUFPLEdBQUcsTUFBTSxFQUFFLE9BQU8sSUFBSSxVQUFVLENBQUM7SUFDM0QsQ0FBQzsrR0FuQ1Usd0JBQXdCO21IQUF4Qix3QkFBd0IsY0FGdkIsTUFBTTs7NEZBRVAsd0JBQXdCO2tCQUhwQyxVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBUZXJtaW5vbG9neUNvbmZpZyB9IGZyb20gXCIuLi8uLi9tb2RlbHNcIjtcclxuXHJcbkBJbmplY3RhYmxlKHtcclxuICBwcm92aWRlZEluOiBcInJvb3RcIixcclxufSlcclxuZXhwb3J0IGNsYXNzIFRlcm1pbm9sb2d5Q29uZmlnU2VydmljZSB7XHJcbiAgcHJpdmF0ZSBfdGVybUNvbmZpZzogVGVybWlub2xvZ3lDb25maWcgPSB7fTtcclxuXHJcbiAgZ2V0IHRlcm1Db25maWcoKSB7XHJcbiAgICByZXR1cm4gdGhpcy5fdGVybUNvbmZpZztcclxuICB9XHJcblxyXG4gIHByaXZhdGUgcmVhZG9ubHkgZGVmYXVsdEFwaVVybCA9IFwiaHR0cHM6Ly9tdG5vdmEtdGVzdC50aWxkZS5sdi9hcGkvZW5naW5lXCI7XHJcblxyXG4gIGluaXRDb25maWdzKGNvbmZpZ3VyYXRpb24/OiBUZXJtaW5vbG9neUNvbmZpZyk6IHZvaWQge1xyXG4gICAgY29uc3QgY29uZmlnID0gY29uZmlndXJhdGlvbiA/PyB7fTtcclxuICAgIFxyXG4gICAgdGhpcy5fdGVybUNvbmZpZy5jb2xsZWN0aW9uTmFtZU1pbkxlbmd0aCA9IGNvbmZpZz8uY29sbGVjdGlvbk5hbWVNaW5MZW5ndGggPz8gODtcclxuICAgIHRoaXMuX3Rlcm1Db25maWcuY29sbGVjdGlvbk5hbWVNYXhMZW5ndGggPSBjb25maWc/LmNvbGxlY3Rpb25OYW1lTWF4TGVuZ3RoID8/IDMwMDtcclxuICAgIHRoaXMuX3Rlcm1Db25maWcueEFwaUtleSA9IGNvbmZpZz8ueEFwaUtleTtcclxuICAgIHRoaXMuX3Rlcm1Db25maWcuc3lzdGVtTGlzdFVybCA9IGNvbmZpZz8uc3lzdGVtTGlzdFVybCA/PyB0aGlzLmRlZmF1bHRBcGlVcmw7XHJcbiAgICB0aGlzLl90ZXJtQ29uZmlnLmVuZ2luZVRlcm1VcmwgPSBjb25maWc/LmVuZ2luZVRlcm1VcmwgPz8gdGhpcy5kZWZhdWx0QXBpVXJsO1xyXG4gICAgdGhpcy5fdGVybUNvbmZpZy50ZXJtaW5vbG9neVBvcnRhbFVybCA9IGNvbmZpZz8udGVybWlub2xvZ3lQb3J0YWxVcmwgPz8gXCJodHRwczovL210bm92YS10ZXN0LXRlcm0udGlsZGUubHZcIjtcclxuICAgIHRoaXMuX3Rlcm1Db25maWcuaXNUZXJtUG9ydGFsU3VwcG9ydGVkID0gY29uZmlnPy5pc1Rlcm1Qb3J0YWxTdXBwb3J0ZWQgPz8gZmFsc2U7XHJcbiAgICB0aGlzLl90ZXJtQ29uZmlnLnJlZnJlc2hUaW1lb3V0TXMgPSBjb25maWc/LnJlZnJlc2hUaW1lb3V0TXMgPz8gMTAwMDA7XHJcbiAgICB0aGlzLl90ZXJtQ29uZmlnLnJlZnJlc2hUaW1lb3V0TXNXaGVuSW1wb3J0aW5nID0gY29uZmlnPy5yZWZyZXNoVGltZW91dE1zV2hlbkltcG9ydGluZyA/PyA1MDAwO1xyXG4gICAgdGhpcy5fdGVybUNvbmZpZy5hbGxvd2VkU3lzdGVtU3RhdHVzZXMgPSBjb25maWc/LmFsbG93ZWRTeXN0ZW1TdGF0dXNlcyA/PyBbJ3J1bm5pbmcnLCAnc3RhbmRieScsICdxdWV1aW5ndHJhbnNsJ107XHJcbiAgICB0aGlzLl90ZXJtQ29uZmlnLmRlZmF1bHRWZW5kb3IgPSBjb25maWc/LmRlZmF1bHRWZW5kb3IgPz8gXCJUaWxkZVwiO1xyXG4gICAgdGhpcy5fdGVybUNvbmZpZy5jYW5DcmVhdGVDb2xsZWN0aW9uID0gY29uZmlnPy5jYW5DcmVhdGVDb2xsZWN0aW9uO1xyXG4gICAgdGhpcy5fdGVybUNvbmZpZy5pc0F1dGggPSBjb25maWc/LmlzQXV0aCA/PyBmYWxzZTtcclxuICAgIHRoaXMuX3Rlcm1Db25maWcuZGVmYXVsdEdsb3NzYXJ5TWFuYWdlbWVudExpbmsgPSBjb25maWc/LmRlZmF1bHRHbG9zc2FyeU1hbmFnZW1lbnRMaW5rO1xyXG4gICAgdGhpcy5fdGVybUNvbmZpZy5oaWRlR2xvc3NhcnlNZW51V2l0aG91dENvbGxlY3Rpb25zID0gY29uZmlnPy5oaWRlR2xvc3NhcnlNZW51V2l0aG91dENvbGxlY3Rpb25zID8/IGZhbHNlO1xyXG4gICAgdGhpcy5fdGVybUNvbmZpZy5zaG93R2xvc3NhcnlNZW51QWR2ZXJ0aXNlbWVudCA9IGNvbmZpZz8uc2hvd0dsb3NzYXJ5TWVudUFkdmVydGlzZW1lbnQgPz8gZmFsc2U7XHJcblxyXG4gICAgdGhpcy5fdGVybUNvbmZpZy5pc0NvbGxlY3Rpb25zQWN0aXZhdGVkID0gY29uZmlnPy5pc0NvbGxlY3Rpb25zQWN0aXZhdGVkO1xyXG4gICAgdGhpcy5fdGVybUNvbmZpZy5tYXhSZWNlbnRTeXN0ZW1Db3VudCA9IGNvbmZpZz8ubWF4UmVjZW50U3lzdGVtQ291bnQgPz8gNDtcclxuICAgIHRoaXMuX3Rlcm1Db25maWcuYXV0b0RvbWFpbkRldGVjdGlvbiA9IGNvbmZpZz8uYXV0b0RvbWFpbkRldGVjdGlvbiA/PyBmYWxzZTtcclxuICAgIHRoaXMuX3Rlcm1Db25maWcuZGVmYXVsdERvbWFpbnMgPSBjb25maWc/LmRlZmF1bHREb21haW5zID8/IFtcIkdFTlwiLCBcImdlbmVyYWxcIl07XHJcbiAgICB0aGlzLl90ZXJtQ29uZmlnLmFwcElkID0gY29uZmlnPy5hcHBJZDtcclxuICAgIHRoaXMuX3Rlcm1Db25maWcuYXBwTmFtZSA9IGNvbmZpZz8uYXBwTmFtZSA/PyBcIlRpbGRlIE1UXCI7XHJcbiAgfVxyXG59XHJcbiJdfQ==
|