ng-inail-common 2.1.1 → 3.0.0-alpha.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/core/base.component.mjs +4 -1
- package/esm2022/lib/components/core/layout/dynamic-layout-element.component.mjs +11 -6
- package/esm2022/lib/components/core/layout/footer/footer.component.mjs +11 -6
- package/esm2022/lib/components/core/layout/header/header.component.mjs +11 -6
- package/esm2022/lib/components/core/layout/header-secondario/header-secondario.component.mjs +11 -6
- package/esm2022/lib/components/core/layout/inail-layout/inail-layout.component.mjs +23 -9
- package/esm2022/lib/components/core/layout/inail-layout/webkit-resources.mjs +23 -6
- package/esm2022/lib/components/core/layout/loader/loader.component.mjs +11 -6
- package/esm2022/lib/components/core/layout/logo-header/logo-header.component.mjs +11 -6
- package/esm2022/lib/components/core/layout/menu-intranet/menu-intranet.component.mjs +11 -6
- package/esm2022/lib/components/core/layout/navigazione-principale/navigazione-principale.component.mjs +11 -6
- package/esm2022/lib/components/core/layout/navigazione-secondaria/navigazione-secondaria.component.mjs +11 -6
- package/esm2022/lib/components/core/layout/trigger-slider-menu-button/trigger-slider-menu-button.component.mjs +11 -6
- package/esm2022/lib/ng-inail-common.config.mjs +2 -1
- package/fesm2022/ng-inail-common.mjs +126 -52
- package/fesm2022/ng-inail-common.mjs.map +1 -1
- package/lib/components/core/base.component.d.ts +2 -2
- package/lib/components/core/layout/dynamic-layout-element.component.d.ts +3 -1
- package/lib/components/core/layout/footer/footer.component.d.ts +3 -1
- package/lib/components/core/layout/header/header.component.d.ts +3 -1
- package/lib/components/core/layout/header-secondario/header-secondario.component.d.ts +3 -1
- package/lib/components/core/layout/inail-layout/inail-layout.component.d.ts +5 -2
- package/lib/components/core/layout/inail-layout/webkit-resources.d.ts +2 -0
- package/lib/components/core/layout/loader/loader.component.d.ts +3 -1
- package/lib/components/core/layout/logo-header/logo-header.component.d.ts +3 -1
- package/lib/components/core/layout/menu-intranet/menu-intranet.component.d.ts +3 -1
- package/lib/components/core/layout/navigazione-principale/navigazione-principale.component.d.ts +3 -1
- package/lib/components/core/layout/navigazione-secondaria/navigazione-secondaria.component.d.ts +3 -1
- package/lib/components/core/layout/trigger-slider-menu-button/trigger-slider-menu-button.component.d.ts +3 -1
- package/lib/ng-inail-common.config.d.ts +3 -0
- package/package.json +1 -1
|
@@ -38,6 +38,9 @@ export class BaseComponent {
|
|
|
38
38
|
this.getMessage = (event) => this.logPrefix && isString(event.message) ? `${this.logPrefix} ${event.message}` : event.message;
|
|
39
39
|
this.getNotBlankValue = (v) => isNotBlankOrNull(`${v}`) ? v : undefined;
|
|
40
40
|
this.log = new EventEmitter();
|
|
41
|
+
if (baseElementLibConfig != undefined) {
|
|
42
|
+
// baseElementLibConfig.webkitVersion = baseElementLibConfig.webkitVersion ?? DEFAULT_WEBKIT_VERSION;
|
|
43
|
+
}
|
|
41
44
|
saveEE();
|
|
42
45
|
}
|
|
43
46
|
overrideConfig(config) {
|
|
@@ -117,4 +120,4 @@ function saveEE() {
|
|
|
117
120
|
window['asd'] = JSON.parse(atob('ewogICJhdXRvcmUiOiAiU2ltb25lIEFudG9uaW5pIiwKICAiZXRhIjogImRpcGVuZGUgZGFsbCdhbm5vIGNvcnJlbnRlIiwKICAiaG9iYnkiOiBbIlBlc2NhIiwgIlNub3dib2FyZCIsICJHYW1pbmciLCAiQ3Jvc3NmaXQiXSwKICAicHJlZmVyaXRpIjogewogICAgInBlc2NpIjogWyJDYXJwYSIsICJCbGFjayBCYXNzIl0sCiAgICAidmlkZW9naW9jaGkiOiBbIkZGVklJIiwgIkZGVklJUiIsICJEZWF0aCBTdHJhbmRpbmciLCAiU2VraXJvIiwgIlJlZCBEZWFkIFJlZGVtcHRpb24gMiIsICJUTE9VIiwgIlRMT1UyIl0sCiAgICAibGlicmkiOiBbCiAgICAgIHsiYXV0b3JlIjogIkdhYnJpZWwgR2FyY2lhIE1hcnF1ZXoiLCAidGl0b2xvIjogIkNlbnQnYW5uaSBkaSBzb2xpdHVkaW5lIn0sCiAgICAgIHsiYXV0b3JlIjogIkFsZXNzYW5kcm8gQmFyaWNjbyIsICJ0aXRvbG8iOiAiQ2FzdGVsbGkgZGkgcmFiYmlhIn0sCiAgICAgIHsiYXV0b3JlIjogIkFsZXNzYW5kcm8gQmFyaWNjbyIsICJ0aXRvbG8iOiAiU2V0YSJ9LAogICAgICB7ImF1dG9yZSI6ICJZYXN1bmFyaSBLYXdhYmF0YSIsICJ0aXRvbG8iOiAiTGEgY2FzYSBkZWxsZSBiZWxsZSBhZGRvcm1lbnRhdGUifQogICAgXQogIH0sCiAgImltcHJlc2VDZWxlYnJpIjogWyJTb3Bwb3J0byBtaWEgbWFkcmUgZGEgcXVhc2kgNDAgYW5uaSJdLAogICJwcm92b0Ftb3JlUGVyIjogWyJJbCBtaW8gY2FuZSIsICJJbCBtaW8gZ2F0dG8iLCAiSWwgdGlyYW1pc3UiXQp9'));
|
|
118
121
|
}
|
|
119
122
|
}
|
|
120
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-inail-common/src/lib/components/core/base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Inject,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChange,\n  SimpleChanges,\n  ViewEncapsulation\n} from '@angular/core';\nimport {isNotBlankOrNull, isString} from \"../../utils/common.operators\";\nimport {Observable, Subscription} from \"rxjs\";\nimport {BaseComponentConfig, NG_INAIL_COMMON_CONFIG, NgInailCommonConfig} from \"../../ng-inail-common.config\";\n\nexport enum LogLevel {\n\n  LOG = 'log',\n  TRACE = 'trace',\n  DEBUG = 'debug',\n  INFO = 'info',\n  WARN = 'warn',\n  ERROR = 'error'\n}\n\nexport interface LogEvent {\n\n  message: any;\n  level: LogLevel;\n}\n\nexport const CHANGE_DETECTION_STRATEGY = ChangeDetectionStrategy.OnPush;\n// export const CHANGE_DETECTION_STRATEGY = ChangeDetectionStrategy.Default;\n\nexport const getConfigValue = (value: any, defaultValue: any) => value != undefined ? value : defaultValue;\n\n@Component({\n  selector: 'inail-base',\n  template: '',\n  styles: [],\n  changeDetection: CHANGE_DETECTION_STRATEGY,\n  encapsulation: ViewEncapsulation.None\n})\nexport class BaseComponent implements OnChanges, OnInit, AfterViewInit {\n\n  viewInit: boolean = false;\n\n  /**\n   * Log del componente\n   */\n  @Output()\n  log: EventEmitter<LogEvent>;\n\n  /**\n   * Se true effettua il log direttamente nella console.\n   * Altrimenti emette l'evento log\n   */\n  @Input()\n  logOnConsole: boolean = getConfigValue(this.baseElementLibConfig?.logOnConsole, false);\n\n  /**\n   *\n   */\n  @Input()\n  showState: boolean = false;\n\n  @Input()\n  detectChange: Observable<void>;\n\n  logPrefix: string;\n\n  subcriptions: Subscription[] = [];\n  push = (subcription: Subscription) => this.subcriptions.push(subcription);\n\n  // Detach centralizzato\n  detach = () => {\n    this.baseComponentCdr.detach();\n  };\n\n  detectChanges = () => this.baseComponentCdr.detectChanges();\n  getMessage = (event: LogEvent) => this.logPrefix && isString(event.message) ? `${this.logPrefix} ${event.message}` : event.message;\n  getNotBlankValue = (v) => isNotBlankOrNull(`${v}`) ? v : undefined;\n\n  constructor(private baseComponentCdr: ChangeDetectorRef,\n              @Inject(NG_INAIL_COMMON_CONFIG)\n              private baseElementLibConfig?: NgInailCommonConfig) {\n    this.log = new EventEmitter<LogEvent>();\n    saveEE();\n  }\n\n  overrideConfig(config: BaseComponentConfig) {\n\n    if (config) {\n\n      this.logOnConsole = getConfigValue(config.logOnConsole, this.logOnConsole);\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    this.emitDebug(`ngOnChanges`);\n    this.emitDebug(changes);\n  }\n\n  ngOnInit() {\n\n    this.emitDebug(`ngOnInit`);\n    this.emitDebug(`this`);\n    this.emitDebug(this);\n\n    if (this.detectChange) {\n\n      this.push(this.detectChange.subscribe(() => this.baseComponentCdr.detectChanges()));\n    }\n  }\n\n  ngOnDestroy(): void {\n\n    this.emitDebug(`${this.logPrefix} ngOnDestroy`);\n    this.subcriptions.forEach(s => s?.unsubscribe());\n  }\n\n  emitLog(message: any) {\n    this.emit({message: message, level: LogLevel.LOG});\n  }\n\n  emitTrace(message: any) {\n    this.emit({message: message, level: LogLevel.TRACE});\n  }\n\n  emitDebug(message: any) {\n    this.emit({message: message, level: LogLevel.DEBUG});\n  }\n\n  emitInfo(message: any) {\n    this.emit({message: message, level: LogLevel.INFO});\n  }\n\n  emitWarn(message: any) {\n    this.emit({message: message, level: LogLevel.WARN});\n  }\n\n  emitError(message: any) {\n\n    this.emit({message: message, level: LogLevel.ERROR});\n  }\n\n  emit(event: LogEvent) {\n\n    if (event) {\n\n      if (this.logOnConsole === true) {\n\n        console[event.level].apply(this, [this.getMessage(event)]);\n      } else {\n\n        event.message = this.getMessage(event);\n        this.log.emit(event);\n      }\n    }\n  }\n\n  ngAfterViewInit(): void {\n\n    this.viewInit = true;\n    this.detectChanges();\n  }\n}\n\nexport interface BooleanChange extends SimpleChange {\n\n  currentValue: boolean;\n  previousValue: boolean;\n}\n\nexport interface StringChange extends SimpleChange {\n\n  currentValue: string;\n  previousValue: string;\n}\n\nexport interface NumberChange extends SimpleChange {\n\n  currentValue: number;\n  previousValue: number;\n}\n\nexport interface ObservableChange extends SimpleChange {\n\n  currentValue: Observable<any>;\n  previousValue: Observable<any>;\n}\n\nexport interface BaseComponentChanges extends SimpleChanges {\n\n  logOnConsole: BooleanChange,\n  showState: BooleanChange\n}\n\nfunction saveEE() {\n\n  if (!window['asd']) {\n\n    window['asd'] = JSON.parse(atob('ewogICJhdXRvcmUiOiAiU2ltb25lIEFudG9uaW5pIiwKICAiZXRhIjogImRpcGVuZGUgZGFsbCdhbm5vIGNvcnJlbnRlIiwKICAiaG9iYnkiOiBbIlBlc2NhIiwgIlNub3dib2FyZCIsICJHYW1pbmciLCAiQ3Jvc3NmaXQiXSwKICAicHJlZmVyaXRpIjogewogICAgInBlc2NpIjogWyJDYXJwYSIsICJCbGFjayBCYXNzIl0sCiAgICAidmlkZW9naW9jaGkiOiBbIkZGVklJIiwgIkZGVklJUiIsICJEZWF0aCBTdHJhbmRpbmciLCAiU2VraXJvIiwgIlJlZCBEZWFkIFJlZGVtcHRpb24gMiIsICJUTE9VIiwgIlRMT1UyIl0sCiAgICAibGlicmkiOiBbCiAgICAgIHsiYXV0b3JlIjogIkdhYnJpZWwgR2FyY2lhIE1hcnF1ZXoiLCAidGl0b2xvIjogIkNlbnQnYW5uaSBkaSBzb2xpdHVkaW5lIn0sCiAgICAgIHsiYXV0b3JlIjogIkFsZXNzYW5kcm8gQmFyaWNjbyIsICJ0aXRvbG8iOiAiQ2FzdGVsbGkgZGkgcmFiYmlhIn0sCiAgICAgIHsiYXV0b3JlIjogIkFsZXNzYW5kcm8gQmFyaWNjbyIsICJ0aXRvbG8iOiAiU2V0YSJ9LAogICAgICB7ImF1dG9yZSI6ICJZYXN1bmFyaSBLYXdhYmF0YSIsICJ0aXRvbG8iOiAiTGEgY2FzYSBkZWxsZSBiZWxsZSBhZGRvcm1lbnRhdGUifQogICAgXQogIH0sCiAgImltcHJlc2VDZWxlYnJpIjogWyJTb3Bwb3J0byBtaWEgbWFkcmUgZGEgcXVhc2kgNDAgYW5uaSJdLAogICJwcm92b0Ftb3JlUGVyIjogWyJJbCBtaW8gY2FuZSIsICJJbCBtaW8gZ2F0dG8iLCAiSWwgdGlyYW1pc3UiXQp9'));\n  }\n}\n"]}
|
|
123
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-inail-common/src/lib/components/core/base.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,uBAAuB,EAEvB,SAAS,EACT,YAAY,EACZ,MAAM,EACN,KAAK,EAGL,MAAM,EAGN,iBAAiB,EAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,gBAAgB,EAAE,QAAQ,EAAC,MAAM,8BAA8B,CAAC;AAExE,OAAO,EAA8C,sBAAsB,EAAqC,MAAM,8BAA8B,CAAC;;AAErJ,MAAM,CAAN,IAAY,QAQX;AARD,WAAY,QAAQ;IAElB,uBAAW,CAAA;IACX,2BAAe,CAAA;IACf,2BAAe,CAAA;IACf,yBAAa,CAAA;IACb,yBAAa,CAAA;IACb,2BAAe,CAAA;AACjB,CAAC,EARW,QAAQ,KAAR,QAAQ,QAQnB;AAQD,MAAM,CAAC,MAAM,yBAAyB,GAAG,uBAAuB,CAAC,MAAM,CAAC;AACxE,4EAA4E;AAE5E,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,KAAU,EAAE,YAAiB,EAAE,EAAE,CAAC,KAAK,IAAI,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,YAAY,CAAC;AAS3G,MAAM,OAAO,aAAa;IAwCxB,YAAoB,gBAAmC,EAEnC,oBAAyC;QAFzC,qBAAgB,GAAhB,gBAAgB,CAAmB;QAEnC,yBAAoB,GAApB,oBAAoB,CAAqB;QAxC7D,aAAQ,GAAY,KAAK,CAAC;QAQ1B;;;WAGG;QAEH,iBAAY,GAAY,cAAc,CAAC,IAAI,CAAC,oBAAoB,EAAE,YAAY,EAAE,KAAK,CAAC,CAAC;QAEvF;;WAEG;QAEH,cAAS,GAAY,KAAK,CAAC;QAO3B,iBAAY,GAAmB,EAAE,CAAC;QAClC,SAAI,GAAG,CAAC,WAAyB,EAAE,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAE1E,uBAAuB;QACvB,WAAM,GAAG,GAAG,EAAE;YACZ,IAAI,CAAC,gBAAgB,CAAC,MAAM,EAAE,CAAC;QACjC,CAAC,CAAC;QAEF,kBAAa,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,gBAAgB,CAAC,aAAa,EAAE,CAAC;QAC5D,eAAU,GAAG,CAAC,KAAe,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,IAAI,QAAQ,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,SAAS,IAAI,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC;QACnI,qBAAgB,GAAG,CAAC,CAAC,EAAE,EAAE,CAAC,gBAAgB,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;QAKjE,IAAI,CAAC,GAAG,GAAG,IAAI,YAAY,EAAY,CAAC;QAExC,IAAG,oBAAoB,IAAI,SAAS,EAAE;YAEpC,qGAAqG;SACtG;QAED,MAAM,EAAE,CAAC;IACX,CAAC;IAED,cAAc,CAAC,MAA2B;QAExC,IAAI,MAAM,EAAE;YAEV,IAAI,CAAC,YAAY,GAAG,cAAc,CAAC,MAAM,CAAC,YAAY,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;SAC5E;IACH,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;QAC9B,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;IAC1B,CAAC;IAED,QAAQ;QAEN,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QAC3B,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QACvB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAErB,IAAI,IAAI,CAAC,YAAY,EAAE;YAErB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,gBAAgB,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC;SACrF;IACH,CAAC;IAED,WAAW;QAET,IAAI,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC,SAAS,cAAc,CAAC,CAAC;QAChD,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,WAAW,EAAE,CAAC,CAAC;IACnD,CAAC;IAED,OAAO,CAAC,OAAY;QAClB,IAAI,CAAC,IAAI,CAAC,EAAC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,CAAC,GAAG,EAAC,CAAC,CAAC;IACrD,CAAC;IAED,SAAS,CAAC,OAAY;QACpB,IAAI,CAAC,IAAI,CAAC,EAAC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,CAAC,KAAK,EAAC,CAAC,CAAC;IACvD,CAAC;IAED,SAAS,CAAC,OAAY;QACpB,IAAI,CAAC,IAAI,CAAC,EAAC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,CAAC,KAAK,EAAC,CAAC,CAAC;IACvD,CAAC;IAED,QAAQ,CAAC,OAAY;QACnB,IAAI,CAAC,IAAI,CAAC,EAAC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,CAAC,IAAI,EAAC,CAAC,CAAC;IACtD,CAAC;IAED,QAAQ,CAAC,OAAY;QACnB,IAAI,CAAC,IAAI,CAAC,EAAC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,CAAC,IAAI,EAAC,CAAC,CAAC;IACtD,CAAC;IAED,SAAS,CAAC,OAAY;QAEpB,IAAI,CAAC,IAAI,CAAC,EAAC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,CAAC,KAAK,EAAC,CAAC,CAAC;IACvD,CAAC;IAED,IAAI,CAAC,KAAe;QAElB,IAAI,KAAK,EAAE;YAET,IAAI,IAAI,CAAC,YAAY,KAAK,IAAI,EAAE;gBAE9B,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;aAC5D;iBAAM;gBAEL,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;gBACvC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;aACtB;SACF;IACH,CAAC;IAED,eAAe;QAEb,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACrB,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC;+GAhIU,aAAa,mDAyCJ,sBAAsB;mGAzC/B,aAAa,gMALd,EAAE;;4FAKD,aAAa;kBAPzB,SAAS;+BACE,YAAY,YACZ,EAAE,mBAEK,yBAAyB,iBAC3B,iBAAiB,CAAC,IAAI;;0BA2CxB,MAAM;2BAAC,sBAAsB;4CAjC1C,GAAG;sBADF,MAAM;gBAQP,YAAY;sBADX,KAAK;gBAON,SAAS;sBADR,KAAK;gBAIN,YAAY;sBADX,KAAK;;AA0IR,SAAS,MAAM;IAEb,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE;QAElB,MAAM,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,k+BAAk+B,CAAC,CAAC,CAAC;KACtgC;AACH,CAAC","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Inject,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChange,\n  SimpleChanges,\n  ViewEncapsulation\n} from '@angular/core';\nimport {isNotBlankOrNull, isString} from \"../../utils/common.operators\";\nimport {Observable, Subscription} from \"rxjs\";\nimport {BaseComponentConfig, DEFAULT_WEBKIT_VERSION, NG_INAIL_COMMON_CONFIG, NgInailCommonConfig, WebKitVersion} from \"../../ng-inail-common.config\";\n\nexport enum LogLevel {\n\n  LOG = 'log',\n  TRACE = 'trace',\n  DEBUG = 'debug',\n  INFO = 'info',\n  WARN = 'warn',\n  ERROR = 'error'\n}\n\nexport interface LogEvent {\n\n  message: any;\n  level: LogLevel;\n}\n\nexport const CHANGE_DETECTION_STRATEGY = ChangeDetectionStrategy.OnPush;\n// export const CHANGE_DETECTION_STRATEGY = ChangeDetectionStrategy.Default;\n\nexport const getConfigValue = (value: any, defaultValue: any) => value != undefined ? value : defaultValue;\n\n@Component({\n  selector: 'inail-base',\n  template: '',\n  styles: [],\n  changeDetection: CHANGE_DETECTION_STRATEGY,\n  encapsulation: ViewEncapsulation.None\n})\nexport class BaseComponent implements OnChanges, OnInit, AfterViewInit {\n\n  viewInit: boolean = false;\n\n  /**\n   * Log del componente\n   */\n  @Output()\n  log: EventEmitter<LogEvent>;\n\n  /**\n   * Se true effettua il log direttamente nella console.\n   * Altrimenti emette l'evento log\n   */\n  @Input()\n  logOnConsole: boolean = getConfigValue(this.baseElementLibConfig?.logOnConsole, false);\n\n  /**\n   *\n   */\n  @Input()\n  showState: boolean = false;\n\n  @Input()\n  detectChange: Observable<void>;\n\n  logPrefix: string;\n\n  subcriptions: Subscription[] = [];\n  push = (subcription: Subscription) => this.subcriptions.push(subcription);\n\n  // Detach centralizzato\n  detach = () => {\n    this.baseComponentCdr.detach();\n  };\n\n  detectChanges = () => this.baseComponentCdr.detectChanges();\n  getMessage = (event: LogEvent) => this.logPrefix && isString(event.message) ? `${this.logPrefix} ${event.message}` : event.message;\n  getNotBlankValue = (v) => isNotBlankOrNull(`${v}`) ? v : undefined;\n\n  constructor(private baseComponentCdr: ChangeDetectorRef,\n              @Inject(NG_INAIL_COMMON_CONFIG)\n              private baseElementLibConfig: NgInailCommonConfig) {\n    this.log = new EventEmitter<LogEvent>();\n\n    if(baseElementLibConfig != undefined) {\n\n      // baseElementLibConfig.webkitVersion = baseElementLibConfig.webkitVersion ?? DEFAULT_WEBKIT_VERSION;\n    }\n\n    saveEE();\n  }\n\n  overrideConfig(config: BaseComponentConfig) {\n\n    if (config) {\n\n      this.logOnConsole = getConfigValue(config.logOnConsole, this.logOnConsole);\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    this.emitDebug(`ngOnChanges`);\n    this.emitDebug(changes);\n  }\n\n  ngOnInit() {\n\n    this.emitDebug(`ngOnInit`);\n    this.emitDebug(`this`);\n    this.emitDebug(this);\n\n    if (this.detectChange) {\n\n      this.push(this.detectChange.subscribe(() => this.baseComponentCdr.detectChanges()));\n    }\n  }\n\n  ngOnDestroy(): void {\n\n    this.emitDebug(`${this.logPrefix} ngOnDestroy`);\n    this.subcriptions.forEach(s => s?.unsubscribe());\n  }\n\n  emitLog(message: any) {\n    this.emit({message: message, level: LogLevel.LOG});\n  }\n\n  emitTrace(message: any) {\n    this.emit({message: message, level: LogLevel.TRACE});\n  }\n\n  emitDebug(message: any) {\n    this.emit({message: message, level: LogLevel.DEBUG});\n  }\n\n  emitInfo(message: any) {\n    this.emit({message: message, level: LogLevel.INFO});\n  }\n\n  emitWarn(message: any) {\n    this.emit({message: message, level: LogLevel.WARN});\n  }\n\n  emitError(message: any) {\n\n    this.emit({message: message, level: LogLevel.ERROR});\n  }\n\n  emit(event: LogEvent) {\n\n    if (event) {\n\n      if (this.logOnConsole === true) {\n\n        console[event.level].apply(this, [this.getMessage(event)]);\n      } else {\n\n        event.message = this.getMessage(event);\n        this.log.emit(event);\n      }\n    }\n  }\n\n  ngAfterViewInit(): void {\n\n    this.viewInit = true;\n    this.detectChanges();\n  }\n}\n\nexport interface BooleanChange extends SimpleChange {\n\n  currentValue: boolean;\n  previousValue: boolean;\n}\n\nexport interface StringChange extends SimpleChange {\n\n  currentValue: string;\n  previousValue: string;\n}\n\nexport interface NumberChange extends SimpleChange {\n\n  currentValue: number;\n  previousValue: number;\n}\n\nexport interface ObservableChange extends SimpleChange {\n\n  currentValue: Observable<any>;\n  previousValue: Observable<any>;\n}\n\nexport interface BaseComponentChanges extends SimpleChanges {\n\n  logOnConsole: BooleanChange,\n  showState: BooleanChange\n}\n\nfunction saveEE() {\n\n  if (!window['asd']) {\n\n    window['asd'] = JSON.parse(atob('ewogICJhdXRvcmUiOiAiU2ltb25lIEFudG9uaW5pIiwKICAiZXRhIjogImRpcGVuZGUgZGFsbCdhbm5vIGNvcnJlbnRlIiwKICAiaG9iYnkiOiBbIlBlc2NhIiwgIlNub3dib2FyZCIsICJHYW1pbmciLCAiQ3Jvc3NmaXQiXSwKICAicHJlZmVyaXRpIjogewogICAgInBlc2NpIjogWyJDYXJwYSIsICJCbGFjayBCYXNzIl0sCiAgICAidmlkZW9naW9jaGkiOiBbIkZGVklJIiwgIkZGVklJUiIsICJEZWF0aCBTdHJhbmRpbmciLCAiU2VraXJvIiwgIlJlZCBEZWFkIFJlZGVtcHRpb24gMiIsICJUTE9VIiwgIlRMT1UyIl0sCiAgICAibGlicmkiOiBbCiAgICAgIHsiYXV0b3JlIjogIkdhYnJpZWwgR2FyY2lhIE1hcnF1ZXoiLCAidGl0b2xvIjogIkNlbnQnYW5uaSBkaSBzb2xpdHVkaW5lIn0sCiAgICAgIHsiYXV0b3JlIjogIkFsZXNzYW5kcm8gQmFyaWNjbyIsICJ0aXRvbG8iOiAiQ2FzdGVsbGkgZGkgcmFiYmlhIn0sCiAgICAgIHsiYXV0b3JlIjogIkFsZXNzYW5kcm8gQmFyaWNjbyIsICJ0aXRvbG8iOiAiU2V0YSJ9LAogICAgICB7ImF1dG9yZSI6ICJZYXN1bmFyaSBLYXdhYmF0YSIsICJ0aXRvbG8iOiAiTGEgY2FzYSBkZWxsZSBiZWxsZSBhZGRvcm1lbnRhdGUifQogICAgXQogIH0sCiAgImltcHJlc2VDZWxlYnJpIjogWyJTb3Bwb3J0byBtaWEgbWFkcmUgZGEgcXVhc2kgNDAgYW5uaSJdLAogICJwcm92b0Ftb3JlUGVyIjogWyJJbCBtaW8gY2FuZSIsICJJbCBtaW8gZ2F0dG8iLCAiSWwgdGlyYW1pc3UiXQp9'));\n  }\n}\n"]}
|
|
@@ -1,16 +1,18 @@
|
|
|
1
|
-
import { Component, Input, ViewEncapsulation } from '@angular/core';
|
|
1
|
+
import { Component, Inject, Input, ViewEncapsulation } from '@angular/core';
|
|
2
2
|
import { BaseComponent, CHANGE_DETECTION_STRATEGY } from "../base.component";
|
|
3
3
|
import { finalize, first } from "rxjs/operators";
|
|
4
4
|
import { isBlankOrNull } from "../../../utils/common.operators";
|
|
5
|
+
import { NG_INAIL_COMMON_CONFIG } from "../../../ng-inail-common.config";
|
|
5
6
|
import * as i0 from "@angular/core";
|
|
6
7
|
import * as i1 from "@angular/platform-browser";
|
|
7
8
|
import * as i2 from "@angular/common/http";
|
|
8
9
|
export class DynamicLayoutElementComponent extends BaseComponent {
|
|
9
|
-
constructor(dleSanitizer, dleCdr, dleHttp) {
|
|
10
|
-
super(dleCdr);
|
|
10
|
+
constructor(dleSanitizer, dleCdr, dleHttp, dleLibConfig) {
|
|
11
|
+
super(dleCdr, dleLibConfig);
|
|
11
12
|
this.dleSanitizer = dleSanitizer;
|
|
12
13
|
this.dleCdr = dleCdr;
|
|
13
14
|
this.dleHttp = dleHttp;
|
|
15
|
+
this.dleLibConfig = dleLibConfig;
|
|
14
16
|
/**
|
|
15
17
|
* Forza il componente a utilizzare il frammento html di default.
|
|
16
18
|
* Verra' preso in considerazione solamente in caso di recupero non automatico.
|
|
@@ -134,13 +136,16 @@ export class DynamicLayoutElementComponent extends BaseComponent {
|
|
|
134
136
|
}
|
|
135
137
|
});
|
|
136
138
|
}
|
|
137
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DynamicLayoutElementComponent, deps: [{ token: i1.DomSanitizer }, { token: i0.ChangeDetectorRef }, { token: i2.HttpClient }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
139
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DynamicLayoutElementComponent, deps: [{ token: i1.DomSanitizer }, { token: i0.ChangeDetectorRef }, { token: i2.HttpClient }, { token: NG_INAIL_COMMON_CONFIG }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
138
140
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DynamicLayoutElementComponent, selector: "inail-dynamic-layout-element", inputs: { useDefault: "useDefault", html: "html", url: "url", clientId: "clientId", apiGatewayUrl: "apiGatewayUrl", reload: "reload", recuperoAutomaticoHtml: "recuperoAutomaticoHtml" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: ``, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
139
141
|
}
|
|
140
142
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DynamicLayoutElementComponent, decorators: [{
|
|
141
143
|
type: Component,
|
|
142
144
|
args: [{ selector: 'inail-dynamic-layout-element', template: ``, changeDetection: CHANGE_DETECTION_STRATEGY, encapsulation: ViewEncapsulation.None }]
|
|
143
|
-
}], ctorParameters: function () { return [{ type: i1.DomSanitizer }, { type: i0.ChangeDetectorRef }, { type: i2.HttpClient }
|
|
145
|
+
}], ctorParameters: function () { return [{ type: i1.DomSanitizer }, { type: i0.ChangeDetectorRef }, { type: i2.HttpClient }, { type: undefined, decorators: [{
|
|
146
|
+
type: Inject,
|
|
147
|
+
args: [NG_INAIL_COMMON_CONFIG]
|
|
148
|
+
}] }]; }, propDecorators: { useDefault: [{
|
|
144
149
|
type: Input
|
|
145
150
|
}], html: [{
|
|
146
151
|
type: Input
|
|
@@ -155,4 +160,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
155
160
|
}], recuperoAutomaticoHtml: [{
|
|
156
161
|
type: Input
|
|
157
162
|
}] } });
|
|
158
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-layout-element.component.js","sourceRoot":"","sources":["../../../../../../../projects/ng-inail-common/src/lib/components/core/layout/dynamic-layout-element.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, ChangeDetectorRef, Component, Input, OnChanges, OnDestroy, OnInit, SimpleChanges, ViewEncapsulation} from '@angular/core';\nimport {BaseComponent, CHANGE_DETECTION_STRATEGY} from \"../base.component\";\nimport {DomSanitizer, SafeScript} from \"@angular/platform-browser\";\nimport {HttpClient} from \"@angular/common/http\";\nimport {HFResponse} from \"../../../services/agw-rest.service\";\nimport {Observable} from \"rxjs\";\nimport {finalize, first} from \"rxjs/operators\";\nimport {isBlankOrNull} from \"../../../utils/common.operators\";\n\n@Component({\n  selector: 'inail-dynamic-layout-element',\n  template: ``,\n  styles: [],\n  changeDetection: CHANGE_DETECTION_STRATEGY,\n  encapsulation: ViewEncapsulation.None\n})\nexport class DynamicLayoutElementComponent extends BaseComponent implements OnInit, OnChanges, AfterViewInit, OnDestroy {\n\n  innerHtml: SafeScript;\n\n  /**\n   * Forza il componente a utilizzare il frammento html di default.\n   * Verra' preso in considerazione solamente in caso di recupero non automatico.\n   */\n  @Input()\n  useDefault: boolean = false;\n\n  /**\n   * Frammento html da far visualizzare al componente.\n   * Verra' utilizzato solamente in caso di recupero non automatico.\n   */\n  @Input()\n  html: string;\n\n  /**\n   * Url da cui recuperare il frammento html.\n   * Se passato inibisce il meccanismo di recupero automatico da AGW.\n   * Se non specificato il frammento html verra' recuperato automaticamente dal componente contattando il servizio 'HeaderFooter-MSPublicVersion'.\n   * Nel caso in cui non sia possibile recuperare il frammento l'html verra' visualizzato quello di default.\n   */\n  @Input()\n  url: string;\n\n  /**\n   * ClientId dell'applicazione.\n   * Viene utilizzato in caso di recupero automatico del frammento html dal servizio 'HeaderFooter-MSPublicVersion' esposto su AGW.\n   * Il recupero automatico da AGW non avviene se vengono valorizzate le proprieta' di input 'html' o 'url'.\n   */\n  @Input()\n  clientId: string;\n\n  /**\n   * Url a cui contattare l'AGW per il recupero automatico del frammento html.\n   * Per il recupero verra' contattato il servizio 'HeaderFooter-MSPublicVersion'.\n   * Se non specificato verra' utilizzato l'indirizzo relativo /api.\n   */\n  @Input()\n  apiGatewayUrl: string;\n\n  /**\n   * Alla ricezione del valore effettua il ricaricamento del frammento html recuperato automaticamente.\n   * Il ricaricamento non viene effettuato se e' stata valorizzata la proprieta' di input 'html'.\n   */\n  @Input()\n  reload: Observable<void>;\n\n  /**\n   * Se true viene recuperato automaticamente da remoto il frammento html.\n   * Il frammento html verra' recuperato all'indirizzo indicato tramite la proprieta' di input url.\n   * Se l'indirizzo non viene impostato il frammento html verra' recuperato automaticamente dal componente contattando\n   * il servizio 'HeaderFooter-MSPublicVersion' esposto su AGW.\n   * Se false il frammento html dovra essere passato in input al componente tramite la proprieta' di input html\n   * o inserito nel content del componente.\n   */\n  @Input()\n  recuperoAutomaticoHtml: boolean = false;\n\n  inizializzazioneTerminata: boolean = false;\n\n  visualizzaContentEsterno = (): boolean => this.recuperoAutomaticoHtml !== true\n    && this.useDefault !== true && this.html == undefined\n\n  visualizzaFrammentoDiDefault = (): boolean => (this.recuperoAutomaticoHtml !== true && this.useDefault === true)\n    // Recupero automatico ma frammento non recuperato.\n    || (this.recuperoAutomaticoHtml == true && this.innerHtml == undefined);\n\n  utilizzaHtmlPassatoInInput = (): boolean => this.recuperoAutomaticoHtml !== true\n    && this.useDefault != true && this.html != undefined;\n\n  hfResponse$: Observable<HFResponse>;\n\n  constructor(private dleSanitizer: DomSanitizer,\n              private dleCdr: ChangeDetectorRef,\n              private dleHttp: HttpClient) {\n\n    super(dleCdr);\n    this.detach();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n\n    super.ngOnChanges(changes);\n\n    // Se cambia l'html passato in input\n    if (changes?.html?.currentValue\n      && changes?.html?.firstChange === false\n      && this.utilizzaHtmlPassatoInInput()) {\n\n      this.innerHtml = this.dleSanitizer.bypassSecurityTrustHtml(this.html);\n    }\n\n    this.dleCdr.detectChanges();\n  }\n\n  ngOnInit() {\n\n    super.ngOnInit();\n\n    if (this.recuperoAutomaticoHtml === true) {\n\n      this.recupera();\n\n    } else {\n\n      if (this.utilizzaHtmlPassatoInInput()) {\n\n        this.innerHtml = this.dleSanitizer.bypassSecurityTrustHtml(this.html);\n      }\n\n      this.inizializzazioneTerminata = true;\n      this.dleCdr.detectChanges();\n    }\n\n    if (this.reload) {\n\n      this.reload.subscribe(() => {\n\n        if (this.recuperoAutomaticoHtml === true) {\n\n          this.recupera();\n\n        } else if (this.utilizzaHtmlPassatoInInput()) {\n\n          this.innerHtml = this.dleSanitizer.bypassSecurityTrustHtml(this.html);\n          this.dleCdr.detectChanges();\n        }\n      });\n    }\n\n    if (this.detectChange) {\n\n      this.push(this.detectChange.subscribe(() => this.dleCdr.detectChanges()));\n    }\n  }\n\n  ngAfterViewInit() {\n    super.ngAfterViewInit();\n  }\n\n  recupera() {\n\n    // Recupero da url indicato\n    if (this.url) {\n\n      this.recuperaDaUrl(this.url);\n    }\n    // Recupero da AGW\n    else {\n\n      this.recuperaDaAGW();\n    }\n  }\n\n  recuperaDaUrl(url: string) {\n    this.emitDebug(`Recupero html da: ${url}`);\n\n    this.dleHttp.get(this.url, {responseType: 'text'})\n      .pipe(\n        first(), // Effettua l'unsubscribe dopo l'emissione del primo valore\n        finalize(() => {\n          this.emitDebug(`inizializzazione terminata!`);\n          this.inizializzazioneTerminata = true;\n          this.dleCdr.detectChanges();\n        })\n      )\n      .subscribe(\n        {\n          next: (html: string) => {\n            this.innerHtml = this.dleSanitizer.bypassSecurityTrustHtml(html);\n            this.emitDebug(`html recuperato!`);\n          },\n          error: (err) => {\n            this.innerHtml = undefined;\n            this.emitError(`Errore nel recupero del frammento html`);\n            this.emitError(err);\n            this.emitWarn(`Visualizzazione html di default`);\n          }\n        }\n      );\n  }\n\n  recuperaDaAGW() {\n\n    this.emitDebug(`Recupero html da AGW`);\n\n    this.hfResponse$\n      .pipe(\n        first(), // Effettua l'unsubscribe dopo l'emissione del primo valore\n        finalize(() => {\n          this.emitDebug(`Inizializzazione completata!`);\n          this.inizializzazioneTerminata = true;\n          this.dleCdr.detectChanges();\n        })\n      )\n      .subscribe(\n        {\n          next: (response: HFResponse) => {\n\n            if (isBlankOrNull(response?.html)) {\n\n              this.emitWarn(`Frammento html non ricevuto! Visualizzazione html di default`);\n\n            } else {\n\n              this.innerHtml = this.dleSanitizer.bypassSecurityTrustHtml(response?.html);\n              this.emitDebug(`html recuperato!`);\n            }\n          },\n          error: (err) => {\n            this.innerHtml = undefined;\n            this.emitError(`Errore nel recupero del frammento html`);\n            this.emitError(err);\n            this.emitWarn(`Visualizzazione html di default`);\n          }\n        }\n      );\n  }\n}\n"]}
|
|
163
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-layout-element.component.js","sourceRoot":"","sources":["../../../../../../../projects/ng-inail-common/src/lib/components/core/layout/dynamic-layout-element.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  SimpleChanges,\n  ViewEncapsulation\n} from '@angular/core';\nimport {BaseComponent, CHANGE_DETECTION_STRATEGY} from \"../base.component\";\nimport {DomSanitizer, SafeScript} from \"@angular/platform-browser\";\nimport {HttpClient} from \"@angular/common/http\";\nimport {HFResponse} from \"../../../services/agw-rest.service\";\nimport {Observable} from \"rxjs\";\nimport {finalize, first} from \"rxjs/operators\";\nimport {isBlankOrNull} from \"../../../utils/common.operators\";\nimport {NG_INAIL_COMMON_CONFIG, NgInailCommonConfig} from \"../../../ng-inail-common.config\";\n\n@Component({\n  selector: 'inail-dynamic-layout-element',\n  template: ``,\n  styles: [],\n  changeDetection: CHANGE_DETECTION_STRATEGY,\n  encapsulation: ViewEncapsulation.None\n})\nexport class DynamicLayoutElementComponent extends BaseComponent implements OnInit, OnChanges, AfterViewInit, OnDestroy {\n\n  innerHtml: SafeScript;\n\n  /**\n   * Forza il componente a utilizzare il frammento html di default.\n   * Verra' preso in considerazione solamente in caso di recupero non automatico.\n   */\n  @Input()\n  useDefault: boolean = false;\n\n  /**\n   * Frammento html da far visualizzare al componente.\n   * Verra' utilizzato solamente in caso di recupero non automatico.\n   */\n  @Input()\n  html: string;\n\n  /**\n   * Url da cui recuperare il frammento html.\n   * Se passato inibisce il meccanismo di recupero automatico da AGW.\n   * Se non specificato il frammento html verra' recuperato automaticamente dal componente contattando il servizio 'HeaderFooter-MSPublicVersion'.\n   * Nel caso in cui non sia possibile recuperare il frammento l'html verra' visualizzato quello di default.\n   */\n  @Input()\n  url: string;\n\n  /**\n   * ClientId dell'applicazione.\n   * Viene utilizzato in caso di recupero automatico del frammento html dal servizio 'HeaderFooter-MSPublicVersion' esposto su AGW.\n   * Il recupero automatico da AGW non avviene se vengono valorizzate le proprieta' di input 'html' o 'url'.\n   */\n  @Input()\n  clientId: string;\n\n  /**\n   * Url a cui contattare l'AGW per il recupero automatico del frammento html.\n   * Per il recupero verra' contattato il servizio 'HeaderFooter-MSPublicVersion'.\n   * Se non specificato verra' utilizzato l'indirizzo relativo /api.\n   */\n  @Input()\n  apiGatewayUrl: string;\n\n  /**\n   * Alla ricezione del valore effettua il ricaricamento del frammento html recuperato automaticamente.\n   * Il ricaricamento non viene effettuato se e' stata valorizzata la proprieta' di input 'html'.\n   */\n  @Input()\n  reload: Observable<void>;\n\n  /**\n   * Se true viene recuperato automaticamente da remoto il frammento html.\n   * Il frammento html verra' recuperato all'indirizzo indicato tramite la proprieta' di input url.\n   * Se l'indirizzo non viene impostato il frammento html verra' recuperato automaticamente dal componente contattando\n   * il servizio 'HeaderFooter-MSPublicVersion' esposto su AGW.\n   * Se false il frammento html dovra essere passato in input al componente tramite la proprieta' di input html\n   * o inserito nel content del componente.\n   */\n  @Input()\n  recuperoAutomaticoHtml: boolean = false;\n\n  inizializzazioneTerminata: boolean = false;\n\n  visualizzaContentEsterno = (): boolean => this.recuperoAutomaticoHtml !== true\n    && this.useDefault !== true && this.html == undefined\n\n  visualizzaFrammentoDiDefault = (): boolean => (this.recuperoAutomaticoHtml !== true && this.useDefault === true)\n    // Recupero automatico ma frammento non recuperato.\n    || (this.recuperoAutomaticoHtml == true && this.innerHtml == undefined);\n\n  utilizzaHtmlPassatoInInput = (): boolean => this.recuperoAutomaticoHtml !== true\n    && this.useDefault != true && this.html != undefined;\n\n  hfResponse$: Observable<HFResponse>;\n\n  constructor(private dleSanitizer: DomSanitizer,\n              private dleCdr: ChangeDetectorRef,\n              private dleHttp: HttpClient,\n              @Inject(NG_INAIL_COMMON_CONFIG)\n              private dleLibConfig: NgInailCommonConfig) {\n\n    super(dleCdr, dleLibConfig);\n    this.detach();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n\n    super.ngOnChanges(changes);\n\n    // Se cambia l'html passato in input\n    if (changes?.html?.currentValue\n      && changes?.html?.firstChange === false\n      && this.utilizzaHtmlPassatoInInput()) {\n\n      this.innerHtml = this.dleSanitizer.bypassSecurityTrustHtml(this.html);\n    }\n\n    this.dleCdr.detectChanges();\n  }\n\n  ngOnInit() {\n\n    super.ngOnInit();\n\n    if (this.recuperoAutomaticoHtml === true) {\n\n      this.recupera();\n\n    } else {\n\n      if (this.utilizzaHtmlPassatoInInput()) {\n\n        this.innerHtml = this.dleSanitizer.bypassSecurityTrustHtml(this.html);\n      }\n\n      this.inizializzazioneTerminata = true;\n      this.dleCdr.detectChanges();\n    }\n\n    if (this.reload) {\n\n      this.reload.subscribe(() => {\n\n        if (this.recuperoAutomaticoHtml === true) {\n\n          this.recupera();\n\n        } else if (this.utilizzaHtmlPassatoInInput()) {\n\n          this.innerHtml = this.dleSanitizer.bypassSecurityTrustHtml(this.html);\n          this.dleCdr.detectChanges();\n        }\n      });\n    }\n\n    if (this.detectChange) {\n\n      this.push(this.detectChange.subscribe(() => this.dleCdr.detectChanges()));\n    }\n  }\n\n  ngAfterViewInit() {\n    super.ngAfterViewInit();\n  }\n\n  recupera() {\n\n    // Recupero da url indicato\n    if (this.url) {\n\n      this.recuperaDaUrl(this.url);\n    }\n    // Recupero da AGW\n    else {\n\n      this.recuperaDaAGW();\n    }\n  }\n\n  recuperaDaUrl(url: string) {\n    this.emitDebug(`Recupero html da: ${url}`);\n\n    this.dleHttp.get(this.url, {responseType: 'text'})\n      .pipe(\n        first(), // Effettua l'unsubscribe dopo l'emissione del primo valore\n        finalize(() => {\n          this.emitDebug(`inizializzazione terminata!`);\n          this.inizializzazioneTerminata = true;\n          this.dleCdr.detectChanges();\n        })\n      )\n      .subscribe(\n        {\n          next: (html: string) => {\n            this.innerHtml = this.dleSanitizer.bypassSecurityTrustHtml(html);\n            this.emitDebug(`html recuperato!`);\n          },\n          error: (err) => {\n            this.innerHtml = undefined;\n            this.emitError(`Errore nel recupero del frammento html`);\n            this.emitError(err);\n            this.emitWarn(`Visualizzazione html di default`);\n          }\n        }\n      );\n  }\n\n  recuperaDaAGW() {\n\n    this.emitDebug(`Recupero html da AGW`);\n\n    this.hfResponse$\n      .pipe(\n        first(), // Effettua l'unsubscribe dopo l'emissione del primo valore\n        finalize(() => {\n          this.emitDebug(`Inizializzazione completata!`);\n          this.inizializzazioneTerminata = true;\n          this.dleCdr.detectChanges();\n        })\n      )\n      .subscribe(\n        {\n          next: (response: HFResponse) => {\n\n            if (isBlankOrNull(response?.html)) {\n\n              this.emitWarn(`Frammento html non ricevuto! Visualizzazione html di default`);\n\n            } else {\n\n              this.innerHtml = this.dleSanitizer.bypassSecurityTrustHtml(response?.html);\n              this.emitDebug(`html recuperato!`);\n            }\n          },\n          error: (err) => {\n            this.innerHtml = undefined;\n            this.emitError(`Errore nel recupero del frammento html`);\n            this.emitError(err);\n            this.emitWarn(`Visualizzazione html di default`);\n          }\n        }\n      );\n  }\n}\n"]}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
|
-
import { Component, ViewEncapsulation } from '@angular/core';
|
|
1
|
+
import { Component, Inject, ViewEncapsulation } from '@angular/core';
|
|
2
2
|
import { CHANGE_DETECTION_STRATEGY } from '../../base.component';
|
|
3
3
|
import { DynamicLayoutElementComponent } from "../dynamic-layout-element.component";
|
|
4
|
+
import { NG_INAIL_COMMON_CONFIG } from "../../../../ng-inail-common.config";
|
|
4
5
|
import * as i0 from "@angular/core";
|
|
5
6
|
import * as i1 from "@angular/platform-browser";
|
|
6
7
|
import * as i2 from "@angular/common/http";
|
|
@@ -27,10 +28,11 @@ import * as i6 from "../../../utilities/state-propertie/state-propertie.componen
|
|
|
27
28
|
* la proprieta' di input 'useDefault'.
|
|
28
29
|
*/
|
|
29
30
|
export class FooterComponent extends DynamicLayoutElementComponent {
|
|
30
|
-
constructor(sanitizer, cdr, http, agw) {
|
|
31
|
-
super(sanitizer, cdr, http);
|
|
31
|
+
constructor(sanitizer, cdr, libConfig, http, agw) {
|
|
32
|
+
super(sanitizer, cdr, http, libConfig);
|
|
32
33
|
this.sanitizer = sanitizer;
|
|
33
34
|
this.cdr = cdr;
|
|
35
|
+
this.libConfig = libConfig;
|
|
34
36
|
this.http = http;
|
|
35
37
|
this.agw = agw;
|
|
36
38
|
this.logPrefix = '[inail-footer]';
|
|
@@ -40,11 +42,14 @@ export class FooterComponent extends DynamicLayoutElementComponent {
|
|
|
40
42
|
this.hfResponse$ = this.agw.getFooterRW({ clientId: this.clientId, agwEndPoint: this.apiGatewayUrl });
|
|
41
43
|
super.ngOnInit();
|
|
42
44
|
}
|
|
43
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FooterComponent, deps: [{ token: i1.DomSanitizer }, { token: i0.ChangeDetectorRef }, { token: i2.HttpClient }, { token: i3.AgwRestService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
45
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FooterComponent, deps: [{ token: i1.DomSanitizer }, { token: i0.ChangeDetectorRef }, { token: NG_INAIL_COMMON_CONFIG }, { token: i2.HttpClient }, { token: i3.AgwRestService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
44
46
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: FooterComponent, selector: "inail-footer", usesInheritance: true, ngImport: i0, template: "<ng-container *ngIf=\"inizializzazioneTerminata\">\n <ng-container *ngIf=\"visualizzaContentEsterno()\">\n <ng-content></ng-content>\n </ng-container>\n <ng-container *ngIf=\"!visualizzaContentEsterno()\">\n <div *ngIf=\"!this.visualizzaFrammentoDiDefault() && this.innerHtml != undefined\"\n [innerHtml]=\"innerHtml\">\n </div>\n <div *ngIf=\"this.visualizzaFrammentoDiDefault()\">\n <footer>\n <nav id=\"navigazionealternativa\" class=\"row\"><h2 class=\"hidden\">Navigazione alternativa</h2>\n <div class=\"row col-md-3 col-xs-12\"><span> <img class=\"logo-inail img-responsive\" src=\"https://cdn.inailcloud.it/assets/inail/static/img/LogoInail_footer.svg\"\n alt=\"INAIL - Istituto Nazionale per l'Assicurazione contro gli Infortuni sul Lavoro\"> </span></div>\n <div id=\"contatti-wrapper\" class=\"row col-xs-12 col-md-9\">\n <div id=\"contatti\" class=\"col-xs-12 col-sm-6\"><h3>Recapiti e contatti</h3>\n <ul>\n <li><p class=\"text-white\"><strong>Contact center</strong> <br> <span>(+39) 06.6001</span> <br> <span>Dal luned\u00EC al venerd\u00EC dalle 9.00 alle 18.00</span></p></li>\n </ul>\n </div>\n <div>\n <div class=\"row no-gutters\">\n <div class=\"col-md-6 col-xs-12 noPadding\">\n <ul class=\"list-unstyled\"></ul>\n </div>\n <div class=\"col-md-4 col-xs-12 noPadding\" id=\"accesso-rapido\"><h3>Accesso rapido</h3>\n <ul class=\"list-unstyled\">\n <li><a href=\"/portale/it/supporto.html\" title=\"Supporto\">Supporto</a></li>\n <li><a href=\"/portale/it/supporto/contatti.html\" title=\"Contatti\">Contatti</a></li>\n <li><a href=\"/portale/it/footer/accessibilita.html\" title=\"Dichiarazione di accessibilit\u00E0\"> Dichiarazione di accessibilit\u00E0 </a></li>\n <li class=\"last\"><a href=\"http://pagopa.inail.it/\" title=\"Supporto\">PagoPA</a></li>\n </ul>\n </div>\n </div>\n </div>\n </div>\n </nav>\n <p class=\"hidden\"><a href=\"#navinterna\" title=\"torna alla navigazione interna alla pagina\">Torna alla navigazione interna</a></p></footer>\n <div id=\"subfooter\"></div>\n <div class=\"copyrightFooter\">\n <div class=\"col-lg-8\"> \u00A9 2018 INAIL - Istituto Nazionale per l'Assicurazione contro gli Infortuni sul Lavoro - P. IVA 00968951004</div>\n <div class=\"col-lg-4 text-right\">\n <ul class=\"list-inline mb-0 py-2\">\n <li><a href=\"/portale/it/amministrazione-trasparente/altri-contenuti/dati-ulteriori/privacy.html\" class=\"text-grey-1\" title=\"Privacy e Cookie\">Privacy e\n Cookie</a>\n </li>\n </ul>\n </div>\n </div>\n <script type=\"text/javascript\" src=\"https://cdn.inailcloud.it/assets/inail/static/js/custom/analytics.js\"></script>\n <script type=\"text/javascript\" src=\"https://cdn.inailcloud.it/assets/inail/static/js/feedRSS.js\"></script>\n </div>\n </ng-container>\n</ng-container>\n<debug-pre *ngIf=\"showState\">[inail-footer]<br>\n <state-propertie [label]=\"'url'\" [propertie]=\"url\"></state-propertie>\n <state-propertie [label]=\"'inizializzazioneTerminata'\" [propertie]=\"inizializzazioneTerminata\"></state-propertie>\n</debug-pre>\n", styles: [""], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.PreComponent, selector: "debug-pre" }, { kind: "component", type: i6.StatePropertieComponent, selector: "state-propertie", inputs: ["label", "propertie", "hideIfNull"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
45
47
|
}
|
|
46
48
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FooterComponent, decorators: [{
|
|
47
49
|
type: Component,
|
|
48
50
|
args: [{ selector: 'inail-footer', changeDetection: CHANGE_DETECTION_STRATEGY, encapsulation: ViewEncapsulation.None, template: "<ng-container *ngIf=\"inizializzazioneTerminata\">\n <ng-container *ngIf=\"visualizzaContentEsterno()\">\n <ng-content></ng-content>\n </ng-container>\n <ng-container *ngIf=\"!visualizzaContentEsterno()\">\n <div *ngIf=\"!this.visualizzaFrammentoDiDefault() && this.innerHtml != undefined\"\n [innerHtml]=\"innerHtml\">\n </div>\n <div *ngIf=\"this.visualizzaFrammentoDiDefault()\">\n <footer>\n <nav id=\"navigazionealternativa\" class=\"row\"><h2 class=\"hidden\">Navigazione alternativa</h2>\n <div class=\"row col-md-3 col-xs-12\"><span> <img class=\"logo-inail img-responsive\" src=\"https://cdn.inailcloud.it/assets/inail/static/img/LogoInail_footer.svg\"\n alt=\"INAIL - Istituto Nazionale per l'Assicurazione contro gli Infortuni sul Lavoro\"> </span></div>\n <div id=\"contatti-wrapper\" class=\"row col-xs-12 col-md-9\">\n <div id=\"contatti\" class=\"col-xs-12 col-sm-6\"><h3>Recapiti e contatti</h3>\n <ul>\n <li><p class=\"text-white\"><strong>Contact center</strong> <br> <span>(+39) 06.6001</span> <br> <span>Dal luned\u00EC al venerd\u00EC dalle 9.00 alle 18.00</span></p></li>\n </ul>\n </div>\n <div>\n <div class=\"row no-gutters\">\n <div class=\"col-md-6 col-xs-12 noPadding\">\n <ul class=\"list-unstyled\"></ul>\n </div>\n <div class=\"col-md-4 col-xs-12 noPadding\" id=\"accesso-rapido\"><h3>Accesso rapido</h3>\n <ul class=\"list-unstyled\">\n <li><a href=\"/portale/it/supporto.html\" title=\"Supporto\">Supporto</a></li>\n <li><a href=\"/portale/it/supporto/contatti.html\" title=\"Contatti\">Contatti</a></li>\n <li><a href=\"/portale/it/footer/accessibilita.html\" title=\"Dichiarazione di accessibilit\u00E0\"> Dichiarazione di accessibilit\u00E0 </a></li>\n <li class=\"last\"><a href=\"http://pagopa.inail.it/\" title=\"Supporto\">PagoPA</a></li>\n </ul>\n </div>\n </div>\n </div>\n </div>\n </nav>\n <p class=\"hidden\"><a href=\"#navinterna\" title=\"torna alla navigazione interna alla pagina\">Torna alla navigazione interna</a></p></footer>\n <div id=\"subfooter\"></div>\n <div class=\"copyrightFooter\">\n <div class=\"col-lg-8\"> \u00A9 2018 INAIL - Istituto Nazionale per l'Assicurazione contro gli Infortuni sul Lavoro - P. IVA 00968951004</div>\n <div class=\"col-lg-4 text-right\">\n <ul class=\"list-inline mb-0 py-2\">\n <li><a href=\"/portale/it/amministrazione-trasparente/altri-contenuti/dati-ulteriori/privacy.html\" class=\"text-grey-1\" title=\"Privacy e Cookie\">Privacy e\n Cookie</a>\n </li>\n </ul>\n </div>\n </div>\n <script type=\"text/javascript\" src=\"https://cdn.inailcloud.it/assets/inail/static/js/custom/analytics.js\"></script>\n <script type=\"text/javascript\" src=\"https://cdn.inailcloud.it/assets/inail/static/js/feedRSS.js\"></script>\n </div>\n </ng-container>\n</ng-container>\n<debug-pre *ngIf=\"showState\">[inail-footer]<br>\n <state-propertie [label]=\"'url'\" [propertie]=\"url\"></state-propertie>\n <state-propertie [label]=\"'inizializzazioneTerminata'\" [propertie]=\"inizializzazioneTerminata\"></state-propertie>\n</debug-pre>\n" }]
|
|
49
|
-
}], ctorParameters: function () { return [{ type: i1.DomSanitizer }, { type: i0.ChangeDetectorRef }, { type:
|
|
50
|
-
|
|
51
|
+
}], ctorParameters: function () { return [{ type: i1.DomSanitizer }, { type: i0.ChangeDetectorRef }, { type: undefined, decorators: [{
|
|
52
|
+
type: Inject,
|
|
53
|
+
args: [NG_INAIL_COMMON_CONFIG]
|
|
54
|
+
}] }, { type: i2.HttpClient }, { type: i3.AgwRestService }]; } });
|
|
55
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"footer.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ng-inail-common/src/lib/components/core/layout/footer/footer.component.ts","../../../../../../../../projects/ng-inail-common/src/lib/components/core/layout/footer/footer.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAoB,SAAS,EAAE,MAAM,EAAgC,iBAAiB,EAAC,MAAM,eAAe,CAAC;AAGpH,OAAO,EAAC,yBAAyB,EAAC,MAAM,sBAAsB,CAAC;AAE/D,OAAO,EAAC,6BAA6B,EAAC,MAAM,qCAAqC,CAAC;AAClF,OAAO,EAAC,sBAAsB,EAAsB,MAAM,oCAAoC,CAAC;;;;;;;;AAE/F;;;;;;;;;;;;;;;;;GAiBG;AAQH,MAAM,OAAO,eAAgB,SAAQ,6BAA6B;IAEhE,YAAoB,SAAuB,EACvB,GAAsB,EAEtB,SAA8B,EAC9B,IAAgB,EAChB,GAAmB;QAErC,KAAK,CAAC,SAAS,EAAE,GAAG,EAAE,IAAI,EAAE,SAAS,CAAC,CAAC;QAPrB,cAAS,GAAT,SAAS,CAAc;QACvB,QAAG,GAAH,GAAG,CAAmB;QAEtB,cAAS,GAAT,SAAS,CAAqB;QAC9B,SAAI,GAAJ,IAAI,CAAY;QAChB,QAAG,GAAH,GAAG,CAAgB;QAGrC,IAAI,CAAC,SAAS,GAAG,gBAAgB,CAAC;QAClC,IAAI,CAAC,MAAM,EAAE,CAAC;IAChB,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,GAAG,CAAC,WAAW,CAAC,EAAC,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,WAAW,EAAE,IAAI,CAAC,aAAa,EAAC,CAAC,CAAC;QACpG,KAAK,CAAC,QAAQ,EAAE,CAAC;IACnB,CAAC;+GAjBU,eAAe,+EAIN,sBAAsB;mGAJ/B,eAAe,2ECjC5B,i+GAyDA;;4FDxBa,eAAe;kBAP3B,SAAS;+BACE,cAAc,mBAGP,yBAAyB,iBAC3B,iBAAiB,CAAC,IAAI;;0BAMxB,MAAM;2BAAC,sBAAsB","sourcesContent":["import {ChangeDetectorRef, Component, Inject, OnChanges, OnDestroy, OnInit, ViewEncapsulation} from '@angular/core';\nimport {HttpClient} from '@angular/common/http';\nimport {DomSanitizer} from '@angular/platform-browser';\nimport {CHANGE_DETECTION_STRATEGY} from '../../base.component';\nimport {AgwRestService} from '../../../../services/agw-rest.service';\nimport {DynamicLayoutElementComponent} from \"../dynamic-layout-element.component\";\nimport {NG_INAIL_COMMON_CONFIG, NgInailCommonConfig} from \"../../../../ng-inail-common.config\";\n\n/**\n * Componente per la visualizzazione del Footer INAIL.\n *\n * E' possibile indicare al componente di recuperare il frammento html da remoto, passare un frammento html al componente o dire\n * al componente di utilizzare il frammento html di default.\n *\n * Il recupero automatico puo' essere abilitato valorizzando a true la proprieta' di input 'recuperoAutomaticoHtml'.\n *\n * In caso di recupero automatico il frammento html verra' recuperato contattando il servizio 'HeaderFooter-MSPublicVersion'\n * esposto su AGW oppure, se specificato, recuperato all'indirizzo html fornito valorizzando la proprieta' di input 'url'.\n * Se il recupero automatico non va a buon fine verra' visualizzato l'html di default.\n *\n * In caso di recupero non automatico il frammento html dovra' essere fornito in input al componente valorizzando\n * la proprieta' html oppure inserito nel content del componente.\n *\n * In caso di recupero non automatico e' possibile forzare l'utilizzo del frammento html di default valorizzando a true\n * la proprieta' di input 'useDefault'.\n */\n@Component({\n  selector: 'inail-footer',\n  templateUrl: './footer.component.html',\n  styleUrls: ['./footer.component.css'],\n  changeDetection: CHANGE_DETECTION_STRATEGY,\n  encapsulation: ViewEncapsulation.None\n})\nexport class FooterComponent extends DynamicLayoutElementComponent implements OnInit, OnChanges, OnDestroy {\n\n  constructor(private sanitizer: DomSanitizer,\n              private cdr: ChangeDetectorRef,\n              @Inject(NG_INAIL_COMMON_CONFIG)\n              private libConfig: NgInailCommonConfig,\n              private http: HttpClient,\n              private agw: AgwRestService) {\n\n    super(sanitizer, cdr, http, libConfig);\n    this.logPrefix = '[inail-footer]';\n    this.detach();\n  }\n\n  ngOnInit() {\n    this.hfResponse$ = this.agw.getFooterRW({clientId: this.clientId, agwEndPoint: this.apiGatewayUrl});\n    super.ngOnInit();\n  }\n}\n","<ng-container *ngIf=\"inizializzazioneTerminata\">\n  <ng-container *ngIf=\"visualizzaContentEsterno()\">\n    <ng-content></ng-content>\n  </ng-container>\n  <ng-container *ngIf=\"!visualizzaContentEsterno()\">\n    <div *ngIf=\"!this.visualizzaFrammentoDiDefault() && this.innerHtml != undefined\"\n         [innerHtml]=\"innerHtml\">\n    </div>\n    <div *ngIf=\"this.visualizzaFrammentoDiDefault()\">\n      <footer>\n        <nav id=\"navigazionealternativa\" class=\"row\"><h2 class=\"hidden\">Navigazione alternativa</h2>\n          <div class=\"row col-md-3 col-xs-12\"><span> <img class=\"logo-inail img-responsive\" src=\"https://cdn.inailcloud.it/assets/inail/static/img/LogoInail_footer.svg\"\n                                                          alt=\"INAIL - Istituto Nazionale per l'Assicurazione contro gli Infortuni sul Lavoro\"> </span></div>\n          <div id=\"contatti-wrapper\" class=\"row col-xs-12 col-md-9\">\n            <div id=\"contatti\" class=\"col-xs-12 col-sm-6\"><h3>Recapiti e contatti</h3>\n              <ul>\n                <li><p class=\"text-white\"><strong>Contact center</strong> <br> <span>(+39) 06.6001</span> <br> <span>Dal lunedì al venerdì dalle 9.00 alle 18.00</span></p></li>\n              </ul>\n            </div>\n            <div>\n              <div class=\"row no-gutters\">\n                <div class=\"col-md-6 col-xs-12 noPadding\">\n                  <ul class=\"list-unstyled\"></ul>\n                </div>\n                <div class=\"col-md-4 col-xs-12 noPadding\" id=\"accesso-rapido\"><h3>Accesso rapido</h3>\n                  <ul class=\"list-unstyled\">\n                    <li><a href=\"/portale/it/supporto.html\" title=\"Supporto\">Supporto</a></li>\n                    <li><a href=\"/portale/it/supporto/contatti.html\" title=\"Contatti\">Contatti</a></li>\n                    <li><a href=\"/portale/it/footer/accessibilita.html\" title=\"Dichiarazione di accessibilità\"> Dichiarazione di accessibilità </a></li>\n                    <li class=\"last\"><a href=\"http://pagopa.inail.it/\" title=\"Supporto\">PagoPA</a></li>\n                  </ul>\n                </div>\n              </div>\n            </div>\n          </div>\n        </nav>\n        <p class=\"hidden\"><a href=\"#navinterna\" title=\"torna alla navigazione interna alla pagina\">Torna alla navigazione interna</a></p></footer>\n      <div id=\"subfooter\"></div>\n      <div class=\"copyrightFooter\">\n        <div class=\"col-lg-8\"> © 2018 INAIL - Istituto Nazionale per l'Assicurazione contro gli Infortuni sul Lavoro - P. IVA 00968951004</div>\n        <div class=\"col-lg-4 text-right\">\n          <ul class=\"list-inline mb-0 py-2\">\n            <li><a href=\"/portale/it/amministrazione-trasparente/altri-contenuti/dati-ulteriori/privacy.html\" class=\"text-grey-1\" title=\"Privacy e Cookie\">Privacy e\n              Cookie</a>\n            </li>\n          </ul>\n        </div>\n      </div>\n      <script type=\"text/javascript\" src=\"https://cdn.inailcloud.it/assets/inail/static/js/custom/analytics.js\"></script>\n      <script type=\"text/javascript\" src=\"https://cdn.inailcloud.it/assets/inail/static/js/feedRSS.js\"></script>\n    </div>\n  </ng-container>\n</ng-container>\n<debug-pre *ngIf=\"showState\">[inail-footer]<br>\n  <state-propertie [label]=\"'url'\" [propertie]=\"url\"></state-propertie>\n  <state-propertie [label]=\"'inizializzazioneTerminata'\" [propertie]=\"inizializzazioneTerminata\"></state-propertie>\n</debug-pre>\n"]}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
|
-
import { Component, Input, ViewEncapsulation } from '@angular/core';
|
|
1
|
+
import { Component, Inject, Input, ViewEncapsulation } from '@angular/core';
|
|
2
2
|
import { BaseComponent, CHANGE_DETECTION_STRATEGY } from '../../base.component';
|
|
3
|
+
import { NG_INAIL_COMMON_CONFIG } from "../../../../ng-inail-common.config";
|
|
3
4
|
import * as i0 from "@angular/core";
|
|
4
5
|
import * as i1 from "@angular/common";
|
|
5
6
|
import * as i2 from "../../../utilities/pre/pre.component";
|
|
@@ -46,9 +47,10 @@ import * as i6 from "../header-secondario/header-secondario.component";
|
|
|
46
47
|
* (In caso di utente non autenticato il layout previsto per le applicazioni INAIL non mostra l'header secondario).
|
|
47
48
|
*/
|
|
48
49
|
export class HeaderComponent extends BaseComponent {
|
|
49
|
-
constructor(cdr) {
|
|
50
|
-
super(cdr);
|
|
50
|
+
constructor(cdr, libConfig) {
|
|
51
|
+
super(cdr, libConfig);
|
|
51
52
|
this.cdr = cdr;
|
|
53
|
+
this.libConfig = libConfig;
|
|
52
54
|
this.inizializzazioneCompletata = false;
|
|
53
55
|
this.logPrefix = '[inail-header]';
|
|
54
56
|
this.detach();
|
|
@@ -76,13 +78,16 @@ export class HeaderComponent extends BaseComponent {
|
|
|
76
78
|
ngOnDestroy() {
|
|
77
79
|
super.ngOnDestroy();
|
|
78
80
|
}
|
|
79
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: HeaderComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
81
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: HeaderComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: NG_INAIL_COMMON_CONFIG }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
80
82
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: HeaderComponent, selector: "header[id=\"inail-header\"]", inputs: { config: "config", logoHeaderHtml: "logoHeaderHtml", navigazionePrincipaleHtml: "navigazionePrincipaleHtml", headerSecondarioHtml: "headerSecondarioHtml", headerSecondarioData: "headerSecondarioData", reload: "reload" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<!-- Prima intestazione di pagina (quella contenente il logo) -->\n<inail-logo-header [clientId]=\"config?.clientId\"\n [apiGatewayUrl]=\"config?.apiGatewayUrl\"\n [html]=\"logoHeaderHtml\"\n [url]=\"config?.logoHeaderUrl\"\n [useDefault]=\"config?.useDefaultHtml\"\n [recuperoAutomaticoHtml]=\"config?.recuperoAutomaticoHtml\"\n [reload]=\"reload\"\n [detectChange]=\"detectChange\"\n [logOnConsole]=\"logOnConsole\"\n (log)=\"emit($event)\">\n <ng-content select=\"[logo-header]\"></ng-content>\n</inail-logo-header>\n\n<!-- Menu di navigazione principale recuperato (Barra blu con pulsante 'Esci' o 'Accedi ai servizi online') -->\n<inail-navigazione-principale [clientId]=\"config?.clientId\"\n [apiGatewayUrl]=\"config?.apiGatewayUrl\"\n [html]=\"navigazionePrincipaleHtml\"\n [url]=\"config?.navigazionePrincipaleUrl\"\n [useDefault]=\"config?.useDefaultHtml\"\n [recuperoAutomaticoHtml]=\"config?.recuperoAutomaticoHtml\"\n [isAuth]=\"headerSecondarioData != undefined\"\n [reload]=\"reload\"\n [detectChange]=\"detectChange\"\n [logOnConsole]=\"logOnConsole\"\n (log)=\"emit($event)\">\n <ng-content select=\"[navigazione-principale]\"></ng-content>\n</inail-navigazione-principale>\n\n<!-- Menu di navigazione utente loggato (Barra verde) -->\n<inail-header-secondario [clientId]=\"config?.clientId\"\n [apiGatewayUrl]=\"config?.apiGatewayUrl\"\n [html]=\"headerSecondarioHtml\"\n [data]=\"headerSecondarioData\"\n [url]=\"config?.headerSecondarioUrl\"\n [useDefault]=\"config?.useDefaultHtml\"\n [recuperoAutomaticoHtml]=\"config?.recuperoAutomaticoHtml\"\n [reload]=\"reload\"\n [detectChange]=\"detectChange\"\n [logOnConsole]=\"logOnConsole\"\n (log)=\"emit($event)\">\n <ng-content select=\"[header-secondario]\"></ng-content>\n</inail-header-secondario>\n\n<debug-pre *ngIf=\"showState\">[inail-header]<br>\n <state-propertie [label]=\"'logOnConsole'\" [propertie]=\"logOnConsole\"></state-propertie>\n <state-propertie [label]=\"'config'\" [propertie]=\"config\"></state-propertie>\n</debug-pre>\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.PreComponent, selector: "debug-pre" }, { kind: "component", type: i3.StatePropertieComponent, selector: "state-propertie", inputs: ["label", "propertie", "hideIfNull"] }, { kind: "component", type: i4.NavigazionePrincipaleComponent, selector: "inail-navigazione-principale", inputs: ["isAuth"] }, { kind: "component", type: i5.LogoHeaderComponent, selector: "inail-logo-header" }, { kind: "component", type: i6.HeaderSecondarioComponent, selector: "inail-header-secondario", inputs: ["data"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
81
83
|
}
|
|
82
84
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: HeaderComponent, decorators: [{
|
|
83
85
|
type: Component,
|
|
84
86
|
args: [{ selector: 'header[id="inail-header"]', changeDetection: CHANGE_DETECTION_STRATEGY, encapsulation: ViewEncapsulation.None, template: "<!-- Prima intestazione di pagina (quella contenente il logo) -->\n<inail-logo-header [clientId]=\"config?.clientId\"\n [apiGatewayUrl]=\"config?.apiGatewayUrl\"\n [html]=\"logoHeaderHtml\"\n [url]=\"config?.logoHeaderUrl\"\n [useDefault]=\"config?.useDefaultHtml\"\n [recuperoAutomaticoHtml]=\"config?.recuperoAutomaticoHtml\"\n [reload]=\"reload\"\n [detectChange]=\"detectChange\"\n [logOnConsole]=\"logOnConsole\"\n (log)=\"emit($event)\">\n <ng-content select=\"[logo-header]\"></ng-content>\n</inail-logo-header>\n\n<!-- Menu di navigazione principale recuperato (Barra blu con pulsante 'Esci' o 'Accedi ai servizi online') -->\n<inail-navigazione-principale [clientId]=\"config?.clientId\"\n [apiGatewayUrl]=\"config?.apiGatewayUrl\"\n [html]=\"navigazionePrincipaleHtml\"\n [url]=\"config?.navigazionePrincipaleUrl\"\n [useDefault]=\"config?.useDefaultHtml\"\n [recuperoAutomaticoHtml]=\"config?.recuperoAutomaticoHtml\"\n [isAuth]=\"headerSecondarioData != undefined\"\n [reload]=\"reload\"\n [detectChange]=\"detectChange\"\n [logOnConsole]=\"logOnConsole\"\n (log)=\"emit($event)\">\n <ng-content select=\"[navigazione-principale]\"></ng-content>\n</inail-navigazione-principale>\n\n<!-- Menu di navigazione utente loggato (Barra verde) -->\n<inail-header-secondario [clientId]=\"config?.clientId\"\n [apiGatewayUrl]=\"config?.apiGatewayUrl\"\n [html]=\"headerSecondarioHtml\"\n [data]=\"headerSecondarioData\"\n [url]=\"config?.headerSecondarioUrl\"\n [useDefault]=\"config?.useDefaultHtml\"\n [recuperoAutomaticoHtml]=\"config?.recuperoAutomaticoHtml\"\n [reload]=\"reload\"\n [detectChange]=\"detectChange\"\n [logOnConsole]=\"logOnConsole\"\n (log)=\"emit($event)\">\n <ng-content select=\"[header-secondario]\"></ng-content>\n</inail-header-secondario>\n\n<debug-pre *ngIf=\"showState\">[inail-header]<br>\n <state-propertie [label]=\"'logOnConsole'\" [propertie]=\"logOnConsole\"></state-propertie>\n <state-propertie [label]=\"'config'\" [propertie]=\"config\"></state-propertie>\n</debug-pre>\n" }]
|
|
85
|
-
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }
|
|
87
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: undefined, decorators: [{
|
|
88
|
+
type: Inject,
|
|
89
|
+
args: [NG_INAIL_COMMON_CONFIG]
|
|
90
|
+
}] }]; }, propDecorators: { config: [{
|
|
86
91
|
type: Input
|
|
87
92
|
}], logoHeaderHtml: [{
|
|
88
93
|
type: Input
|
|
@@ -97,4 +102,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
97
102
|
}] } });
|
|
98
103
|
export class HeaderConfigurations {
|
|
99
104
|
}
|
|
100
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"header.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ng-inail-common/src/lib/components/core/layout/header/header.component.ts","../../../../../../../../projects/ng-inail-common/src/lib/components/core/layout/header/header.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAmC,SAAS,EAAE,KAAK,EAA+C,iBAAiB,EAAC,MAAM,eAAe,CAAC;AACjJ,OAAO,EAAC,aAAa,EAAE,yBAAyB,EAAC,MAAM,sBAAsB,CAAC;;;;;;;;AAI9E;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAqCG;AAaH,MAAM,OAAO,eAAgB,SAAQ,aAAa;IAuDhD,YAAoB,GAAsB;QACxC,KAAK,CAAC,GAAG,CAAC,CAAC;QADO,QAAG,GAAH,GAAG,CAAmB;QAF1C,+BAA0B,GAAY,KAAK,CAAC;QAI1C,IAAI,CAAC,SAAS,GAAG,gBAAgB,CAAC;QAClC,IAAI,CAAC,MAAM,EAAE,CAAC;IAChB,CAAC;IAED,WAAW,CAAC,OAAsB;QAEhC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;QAC9B,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;QACxB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;IAED,eAAe;IACf,CAAC;IAED,QAAQ;QAEN,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;QACzB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAE5B,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YAEhB,IAAI,CAAC,MAAM,GAAG,EAAC,QAAQ,EAAE,EAAE,EAAC,CAAC;SAC9B;QAED,IAAI,IAAI,CAAC,YAAY,EAAE;YAErB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC;SACxE;QAED,IAAI,CAAC,0BAA0B,GAAG,IAAI,CAAC;QAEvC,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;IAED,WAAW;QAET,KAAK,CAAC,WAAW,EAAE,CAAC;IACtB,CAAC;+GA/FU,eAAe;mGAAf,eAAe,qVCvD5B,wpFAgDA;;4FDOa,eAAe;kBAZ3B,SAAS;+BAME,2BAA2B,mBAGpB,yBAAyB,iBAC3B,iBAAiB,CAAC,IAAI;wGAQrC,MAAM;sBADL,KAAK;gBASN,cAAc;sBADb,KAAK;gBASN,yBAAyB;sBADxB,KAAK;gBASN,oBAAoB;sBADnB,KAAK;gBAcN,oBAAoB;sBADnB,KAAK;gBASN,MAAM;sBADL,KAAK;;AAgDR,MAAM,OAAO,oBAAoB;CA8DhC","sourcesContent":["import {AfterViewInit, ChangeDetectorRef, Component, Input, OnChanges, OnDestroy, OnInit, SimpleChanges, ViewEncapsulation} from '@angular/core';\nimport {BaseComponent, CHANGE_DETECTION_STRATEGY} from '../../base.component';\nimport {Observable} from 'rxjs';\nimport {HeaderSecondarioData} from '../header-secondario/header-secondario.component';\n\n/**\n * Componente per la visualizzazione di tutto l'header applicativo.\n *\n * L'header e' composto da:\n *\n * - Prima intestazione di pagina (quella contenente il logo).\n * - Navigazione principale (Barra blu con pulsante 'Esci' o 'Accedi ai servizi online').\n * - Header secondario (barra verde con info e menu utente loggato).\n *\n * E' possibile indicare al componente di recuperare i frammenti html da remoto, passare dei frammenti html al componente o dire\n * al componente di utilizzare i frammenti html di default.\n *\n * Il recupero automatico puo' essere abilitato valorizzando a true la proprieta' di configurazione 'recuperoAutomaticoHtml'.\n *\n * In caso di recupero automatico i frammenti html verranno recuperati contattando i servizi 'HeaderFooter-MSPublicVersion'\n * e 'HeaderFooter-MSPrivateVersion' esposti su AGW oppure, se specificate, recuperati agli indirizzi forniti valorizzando le rispettive la proprieta'\n * all'interno del file di configurazione.\n *\n * In caso di recupero da AGW, prima del recupero dei frammenti html, verra' contattato il servizio 'checksession'\n * esposto su AGW per determinare quale dei due servizi contattare nello specifico.\n * In caso di utente autenticato verra' contattato il servizio 'HeaderFooter-MSPrivateVersion',\n * altrimenti verra' contattato il servizio 'HeaderFooter-MSPublicVersion'.\n *\n * Nal caso in cui il recupero dei frammenti html non vada a buon fine il componente renderizza degli html di default.\n * In questo caso, per completare l'header secondario, verra' contattato il servizio 'AU_Rest_Dipendente'\n * per determinare le informazioni inerenti l'utente connesso.\n *\n * In caso di recupero non automatico ii frammenti html dovranno essere forniti in input al componente valorizzando\n * la rispettive proprieta' html oppure inserendoli nel content del componente utilizzando gli appositi selettori.\n *\n * In caso di recupero non automatico e' possibile forzare l'utilizzo dei frammenti html di default valorizzando a true\n * la proprieta' di input 'useDefaultHtml' dell'oggetto di configurazione del componente.\n * In questo caso, per visualizzare il frammento html di default inerente l'header secondario,\n * sara' necessario valorizzare la proprieta' di input 'headerSecondarioData'.\n * Valorizzare o meno la proprieta' 'headerSecondarioData' inoltre determinera' se visualizzare il frammento html di default\n * della navigazione principale inerente l'utente autenticato o quello inerente l'utente non autenticato\n * (In caso di utente non autenticato il layout previsto per le applicazioni INAIL non mostra l'header secondario).\n */\n@Component({\n  // E' stato scelto di utilizzare come selettore il nome del tag\n  // per consentire alle regole css definite dall'INAIL di\n  // matchare con gli elementi html,\n  // cosa che non avverrebbe se venisse utilizzato un tag custom\n  // frapposto tra il tag header e quello contenitore.\n  selector: 'header[id=\"inail-header\"]',\n  templateUrl: './header.component.html',\n  styleUrls: ['./header.component.css'],\n  changeDetection: CHANGE_DETECTION_STRATEGY,\n  encapsulation: ViewEncapsulation.None\n})\nexport class HeaderComponent extends BaseComponent implements OnInit, OnChanges, AfterViewInit, OnDestroy {\n\n  /**\n   * Oggetto di configurazione del componente.\n   */\n  @Input()\n  config: HeaderConfigurations;\n\n  /**\n   * Frammento html della prima intestazione di pagina (quella contenente il logo) da far visualizzare al componente.\n   * Se passato inibisce il meccanismo di recupero automatico e ignora quanto specificato\n   * nella proprieta' 'logoHeaderUrl' dell'oggetto di configurazione del componente.\n   */\n  @Input()\n  logoHeaderHtml: string;\n\n  /**\n   * Frammento html della navigazione principale da far visualizzare al componente.\n   * Se passato inibisce il meccanismo di recupero automatico e ignora quanto specificato\n   * nella proprieta' 'navigazionePrincipaleUrl' dell'oggetto di configurazione del componente.\n   */\n  @Input()\n  navigazionePrincipaleHtml: string;\n\n  /**\n   * Frammento html del header secondario da far visualizzare al componente.\n   * Se passato inibisce il meccanismo di recupero automatico e ignora quanto specificato\n   * nella proprieta' 'headerSecondarioUrl' dell'oggetto di configurazione del componente.\n   */\n  @Input()\n  headerSecondarioHtml: string;\n\n  /**\n   * Dati da visualizzare all'interno del header secondario.\n   * Vengono ignorati se e' stata valorizzata la proprieta' di input 'headerSecondarioHtml'.\n   * Se valorizzato inibisce il meccanismo di recupero automatico e ignora quanto specificato\n   * nella proprieta' 'headerSecondarioUrl' dell'oggetto di configurazione del componente.\n   * Se impostata a 'true' la proprieta' 'useDefaultHtml' dell'oggetto di configurazione del componente,\n   * la valorizzazione della proprieta' 'headerSecondarioData' determinera' se visualizzare il frammento html di default\n   * della navigazione principale inerente l'utente autenticato o quello inerente l'utente non autenticato\n   * e se visualizzare o meno il frammento html di default inerente l'header secondario.\n   */\n  @Input()\n  headerSecondarioData: HeaderSecondarioData;\n\n  /**\n   * Alla ricezione del valore effettua il ricaricamento dei frammenti html recuperati automaticamente.\n   * Il ricaricamento non viene (rispettivamente) effettuato se sono state valorizzate la proprieta' di input:\n   * 'logoHeaderHtml', 'navigazionePrincipaleHtml' e 'headerSecondarioHtml' (o 'headerSecondarioData').\n   */\n  @Input()\n  reload: Observable<void>;\n\n  inizializzazioneCompletata: boolean = false;\n\n  constructor(private cdr: ChangeDetectorRef) {\n    super(cdr);\n    this.logPrefix = '[inail-header]';\n    this.detach();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n\n    this.emitDebug('ngOnChanges');\n    this.emitDebug(changes);\n    this.cdr.detectChanges();\n  }\n\n  ngAfterViewInit(): void {\n  }\n\n  ngOnInit() {\n\n    super.ngOnInit();\n    this.emitDebug('config');\n    this.emitDebug(this.config);\n\n    if (!this.config) {\n\n      this.config = {clientId: ''};\n    }\n\n    if (this.detectChange) {\n\n      this.push(this.detectChange.subscribe(() => this.cdr.detectChanges()));\n    }\n\n    this.inizializzazioneCompletata = true;\n\n    this.cdr.detectChanges();\n  }\n\n  ngOnDestroy(): void {\n\n    super.ngOnDestroy();\n  }\n}\n\nexport class HeaderConfigurations {\n\n  /**\n   * Identificativo dell'applicazione corrente in accordo\n   * con l'API Gateway\n   */\n  clientId?: string;\n\n  /**\n   * Url a cui contattare l'AGW per il recupero automatico dei frammenti html.\n   * Per il recupero verra' contattati i servizi 'HeaderFooter-MSPublicVersion' e 'HeaderFooter-MSPrivateVersion'.\n   * Se non specificato verra' utilizzato l'indirizzo relativo /api.\n   */\n  apiGatewayUrl?: any;\n\n  /**\n   * Url da cui recuperare il frammento html della prima intestazione di pagina (quella contenente il logo).\n   * Se passato inibisce il meccanismo di recupero automatico da AGW.\n   * Se non specificato il frammento html verra' recuperato automaticamente dal componente contattando il servizio 'HeaderFooter-MSPublicVersion'.\n   * Nel caso in cui non sia possibile recuperare il frammento l'html verra' visualizzato quello di default.\n   */\n  logoHeaderUrl?: string;\n\n  /**\n   * Url da cui recuperare il frammento html della navigazione principale.\n   * Se passato inibisce il meccanismo di recupero automatico da AGW.\n   * Se non specificato il frammento html verra' recuperato automaticamente dal componente contattando i servizi 'HeaderFooter-MSPublicVersion'\n   * e 'HeaderFooter-MSPrivateVersion'.\n   * Nel caso in cui non sia possibile recuperare il frammento html verra' visualizzato quello di default.\n   */\n  navigazionePrincipaleUrl?: string;\n\n  /**\n   * Url da cui recuperare il frammento html del header secondario\n   * Se passato inibisce il meccanismo di recupero automatico da AGW.\n   * Se non specificato il frammento html verra' recuperato automaticamente dal componente contattando il servizio 'HeaderFooter-MSPrivateVersion'.\n   * Nel caso in cui non sia possibile recuperare il frammento html verra' visualizzato quello di default.\n   */\n  headerSecondarioUrl?: string;\n\n  /**\n   * Se true vengono recuperati automaticamente i frammenti html di logo, navigazione principale e header secondario.\n   * I frammenti html verranno recuperati agli indirizzi indicati tramite le proprieta' di configurazione logoHeaderUrl, navigazionePrincipaleUrl\n   * headerSecondarioUrl.\n   * Se gli indirizzi non vengono impostati i frammenti html verranno recuperati automaticamente dal componente contattando\n   * il servizio 'HeaderFooter-MSPublicVersion' esposto su AGW.\n   * Se false i frammenti html dovranno essere passati in input al componente tramite le proprieta' di input logoHeaderHtml,\n   * navigazionePrincipaleHtml e headerSecondarioHtml o inseriti nel content del componente attraverso gli appositi selettori di contenuto.\n   */\n  recuperoAutomaticoHtml?: boolean;\n\n  /**\n   * Forza il componente a utilizzare i frammenti html di default.\n   * Se impostato a 'true' inibisce i meccanismi di recupero automatico dei frammenti html\n   * e ignora quanto specificato nelle proprieta' di input 'logoHeaderHtml', 'navigazionePrincipaleHtml' e 'headerSecondarioHtml'.\n   * In questo caso, per visualizzare il frammento html di default inerente l'header secondario,\n   * sara' necessario valorizzare la proprieta' di input 'headerSecondarioData'.\n   * Valorizzare o meno la proprieta' 'headerSecondarioData' inoltre determinera' se visualizzare il frammento html di default\n   * della navigazione principale inerente l'utente autenticato o quello inerente l'utente non autenticato\n   * (In caso di utente non autenticato il layout previsto per le applicazioni INAIL non mostra l'header secondario).\n   */\n  useDefaultHtml?: boolean;\n}\n","<!-- Prima intestazione di pagina (quella contenente il logo) -->\n<inail-logo-header [clientId]=\"config?.clientId\"\n                   [apiGatewayUrl]=\"config?.apiGatewayUrl\"\n                   [html]=\"logoHeaderHtml\"\n                   [url]=\"config?.logoHeaderUrl\"\n                   [useDefault]=\"config?.useDefaultHtml\"\n                   [recuperoAutomaticoHtml]=\"config?.recuperoAutomaticoHtml\"\n                   [reload]=\"reload\"\n                   [detectChange]=\"detectChange\"\n                   [logOnConsole]=\"logOnConsole\"\n                   (log)=\"emit($event)\">\n  <ng-content select=\"[logo-header]\"></ng-content>\n</inail-logo-header>\n\n<!-- Menu di navigazione principale recuperato (Barra blu con pulsante 'Esci' o 'Accedi ai servizi online') -->\n<inail-navigazione-principale [clientId]=\"config?.clientId\"\n                              [apiGatewayUrl]=\"config?.apiGatewayUrl\"\n                              [html]=\"navigazionePrincipaleHtml\"\n                              [url]=\"config?.navigazionePrincipaleUrl\"\n                              [useDefault]=\"config?.useDefaultHtml\"\n                              [recuperoAutomaticoHtml]=\"config?.recuperoAutomaticoHtml\"\n                              [isAuth]=\"headerSecondarioData != undefined\"\n                              [reload]=\"reload\"\n                              [detectChange]=\"detectChange\"\n                              [logOnConsole]=\"logOnConsole\"\n                              (log)=\"emit($event)\">\n  <ng-content select=\"[navigazione-principale]\"></ng-content>\n</inail-navigazione-principale>\n\n<!-- Menu di navigazione utente loggato (Barra verde) -->\n<inail-header-secondario [clientId]=\"config?.clientId\"\n                         [apiGatewayUrl]=\"config?.apiGatewayUrl\"\n                         [html]=\"headerSecondarioHtml\"\n                         [data]=\"headerSecondarioData\"\n                         [url]=\"config?.headerSecondarioUrl\"\n                         [useDefault]=\"config?.useDefaultHtml\"\n                         [recuperoAutomaticoHtml]=\"config?.recuperoAutomaticoHtml\"\n                         [reload]=\"reload\"\n                         [detectChange]=\"detectChange\"\n                         [logOnConsole]=\"logOnConsole\"\n                         (log)=\"emit($event)\">\n  <ng-content select=\"[header-secondario]\"></ng-content>\n</inail-header-secondario>\n\n<debug-pre *ngIf=\"showState\">[inail-header]<br>\n  <state-propertie [label]=\"'logOnConsole'\" [propertie]=\"logOnConsole\"></state-propertie>\n  <state-propertie [label]=\"'config'\" [propertie]=\"config\"></state-propertie>\n</debug-pre>\n"]}
|
|
105
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"header.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ng-inail-common/src/lib/components/core/layout/header/header.component.ts","../../../../../../../../projects/ng-inail-common/src/lib/components/core/layout/header/header.component.html"],"names":[],"mappings":"AAAA,OAAO,EAGL,SAAS,EACT,MAAM,EACN,KAAK,EAKL,iBAAiB,EAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,aAAa,EAAE,yBAAyB,EAAC,MAAM,sBAAsB,CAAC;AAG9E,OAAO,EAAC,sBAAsB,EAAsB,MAAM,oCAAoC,CAAC;;;;;;;;AAE/F;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAqCG;AAaH,MAAM,OAAO,eAAgB,SAAQ,aAAa;IAuDhD,YAAoB,GAAsB,EAEtB,SAA8B;QAChD,KAAK,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;QAHJ,QAAG,GAAH,GAAG,CAAmB;QAEtB,cAAS,GAAT,SAAS,CAAqB;QAJlD,+BAA0B,GAAY,KAAK,CAAC;QAM1C,IAAI,CAAC,SAAS,GAAG,gBAAgB,CAAC;QAClC,IAAI,CAAC,MAAM,EAAE,CAAC;IAChB,CAAC;IAED,WAAW,CAAC,OAAsB;QAEhC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;QAC9B,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;QACxB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;IAED,eAAe;IACf,CAAC;IAED,QAAQ;QAEN,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;QACzB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAE5B,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YAEhB,IAAI,CAAC,MAAM,GAAG,EAAC,QAAQ,EAAE,EAAE,EAAC,CAAC;SAC9B;QAED,IAAI,IAAI,CAAC,YAAY,EAAE;YAErB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC;SACxE;QAED,IAAI,CAAC,0BAA0B,GAAG,IAAI,CAAC;QAEvC,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;IAED,WAAW;QAET,KAAK,CAAC,WAAW,EAAE,CAAC;IACtB,CAAC;+GAjGU,eAAe,mDAwDN,sBAAsB;mGAxD/B,eAAe,qVCnE5B,wpFAgDA;;4FDmBa,eAAe;kBAZ3B,SAAS;+BAME,2BAA2B,mBAGpB,yBAAyB,iBAC3B,iBAAiB,CAAC,IAAI;;0BA0DxB,MAAM;2BAAC,sBAAsB;4CAlD1C,MAAM;sBADL,KAAK;gBASN,cAAc;sBADb,KAAK;gBASN,yBAAyB;sBADxB,KAAK;gBASN,oBAAoB;sBADnB,KAAK;gBAcN,oBAAoB;sBADnB,KAAK;gBASN,MAAM;sBADL,KAAK;;AAkDR,MAAM,OAAO,oBAAoB;CA8DhC","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  SimpleChanges,\n  ViewEncapsulation\n} from '@angular/core';\nimport {BaseComponent, CHANGE_DETECTION_STRATEGY} from '../../base.component';\nimport {Observable} from 'rxjs';\nimport {HeaderSecondarioData} from '../header-secondario/header-secondario.component';\nimport {NG_INAIL_COMMON_CONFIG, NgInailCommonConfig} from \"../../../../ng-inail-common.config\";\n\n/**\n * Componente per la visualizzazione di tutto l'header applicativo.\n *\n * L'header e' composto da:\n *\n * - Prima intestazione di pagina (quella contenente il logo).\n * - Navigazione principale (Barra blu con pulsante 'Esci' o 'Accedi ai servizi online').\n * - Header secondario (barra verde con info e menu utente loggato).\n *\n * E' possibile indicare al componente di recuperare i frammenti html da remoto, passare dei frammenti html al componente o dire\n * al componente di utilizzare i frammenti html di default.\n *\n * Il recupero automatico puo' essere abilitato valorizzando a true la proprieta' di configurazione 'recuperoAutomaticoHtml'.\n *\n * In caso di recupero automatico i frammenti html verranno recuperati contattando i servizi 'HeaderFooter-MSPublicVersion'\n * e 'HeaderFooter-MSPrivateVersion' esposti su AGW oppure, se specificate, recuperati agli indirizzi forniti valorizzando le rispettive la proprieta'\n * all'interno del file di configurazione.\n *\n * In caso di recupero da AGW, prima del recupero dei frammenti html, verra' contattato il servizio 'checksession'\n * esposto su AGW per determinare quale dei due servizi contattare nello specifico.\n * In caso di utente autenticato verra' contattato il servizio 'HeaderFooter-MSPrivateVersion',\n * altrimenti verra' contattato il servizio 'HeaderFooter-MSPublicVersion'.\n *\n * Nal caso in cui il recupero dei frammenti html non vada a buon fine il componente renderizza degli html di default.\n * In questo caso, per completare l'header secondario, verra' contattato il servizio 'AU_Rest_Dipendente'\n * per determinare le informazioni inerenti l'utente connesso.\n *\n * In caso di recupero non automatico ii frammenti html dovranno essere forniti in input al componente valorizzando\n * la rispettive proprieta' html oppure inserendoli nel content del componente utilizzando gli appositi selettori.\n *\n * In caso di recupero non automatico e' possibile forzare l'utilizzo dei frammenti html di default valorizzando a true\n * la proprieta' di input 'useDefaultHtml' dell'oggetto di configurazione del componente.\n * In questo caso, per visualizzare il frammento html di default inerente l'header secondario,\n * sara' necessario valorizzare la proprieta' di input 'headerSecondarioData'.\n * Valorizzare o meno la proprieta' 'headerSecondarioData' inoltre determinera' se visualizzare il frammento html di default\n * della navigazione principale inerente l'utente autenticato o quello inerente l'utente non autenticato\n * (In caso di utente non autenticato il layout previsto per le applicazioni INAIL non mostra l'header secondario).\n */\n@Component({\n  // E' stato scelto di utilizzare come selettore il nome del tag\n  // per consentire alle regole css definite dall'INAIL di\n  // matchare con gli elementi html,\n  // cosa che non avverrebbe se venisse utilizzato un tag custom\n  // frapposto tra il tag header e quello contenitore.\n  selector: 'header[id=\"inail-header\"]',\n  templateUrl: './header.component.html',\n  styleUrls: ['./header.component.css'],\n  changeDetection: CHANGE_DETECTION_STRATEGY,\n  encapsulation: ViewEncapsulation.None\n})\nexport class HeaderComponent extends BaseComponent implements OnInit, OnChanges, AfterViewInit, OnDestroy {\n\n  /**\n   * Oggetto di configurazione del componente.\n   */\n  @Input()\n  config: HeaderConfigurations;\n\n  /**\n   * Frammento html della prima intestazione di pagina (quella contenente il logo) da far visualizzare al componente.\n   * Se passato inibisce il meccanismo di recupero automatico e ignora quanto specificato\n   * nella proprieta' 'logoHeaderUrl' dell'oggetto di configurazione del componente.\n   */\n  @Input()\n  logoHeaderHtml: string;\n\n  /**\n   * Frammento html della navigazione principale da far visualizzare al componente.\n   * Se passato inibisce il meccanismo di recupero automatico e ignora quanto specificato\n   * nella proprieta' 'navigazionePrincipaleUrl' dell'oggetto di configurazione del componente.\n   */\n  @Input()\n  navigazionePrincipaleHtml: string;\n\n  /**\n   * Frammento html del header secondario da far visualizzare al componente.\n   * Se passato inibisce il meccanismo di recupero automatico e ignora quanto specificato\n   * nella proprieta' 'headerSecondarioUrl' dell'oggetto di configurazione del componente.\n   */\n  @Input()\n  headerSecondarioHtml: string;\n\n  /**\n   * Dati da visualizzare all'interno del header secondario.\n   * Vengono ignorati se e' stata valorizzata la proprieta' di input 'headerSecondarioHtml'.\n   * Se valorizzato inibisce il meccanismo di recupero automatico e ignora quanto specificato\n   * nella proprieta' 'headerSecondarioUrl' dell'oggetto di configurazione del componente.\n   * Se impostata a 'true' la proprieta' 'useDefaultHtml' dell'oggetto di configurazione del componente,\n   * la valorizzazione della proprieta' 'headerSecondarioData' determinera' se visualizzare il frammento html di default\n   * della navigazione principale inerente l'utente autenticato o quello inerente l'utente non autenticato\n   * e se visualizzare o meno il frammento html di default inerente l'header secondario.\n   */\n  @Input()\n  headerSecondarioData: HeaderSecondarioData;\n\n  /**\n   * Alla ricezione del valore effettua il ricaricamento dei frammenti html recuperati automaticamente.\n   * Il ricaricamento non viene (rispettivamente) effettuato se sono state valorizzate la proprieta' di input:\n   * 'logoHeaderHtml', 'navigazionePrincipaleHtml' e 'headerSecondarioHtml' (o 'headerSecondarioData').\n   */\n  @Input()\n  reload: Observable<void>;\n\n  inizializzazioneCompletata: boolean = false;\n\n  constructor(private cdr: ChangeDetectorRef,\n              @Inject(NG_INAIL_COMMON_CONFIG)\n              private libConfig: NgInailCommonConfig) {\n    super(cdr, libConfig);\n    this.logPrefix = '[inail-header]';\n    this.detach();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n\n    this.emitDebug('ngOnChanges');\n    this.emitDebug(changes);\n    this.cdr.detectChanges();\n  }\n\n  ngAfterViewInit(): void {\n  }\n\n  ngOnInit() {\n\n    super.ngOnInit();\n    this.emitDebug('config');\n    this.emitDebug(this.config);\n\n    if (!this.config) {\n\n      this.config = {clientId: ''};\n    }\n\n    if (this.detectChange) {\n\n      this.push(this.detectChange.subscribe(() => this.cdr.detectChanges()));\n    }\n\n    this.inizializzazioneCompletata = true;\n\n    this.cdr.detectChanges();\n  }\n\n  ngOnDestroy(): void {\n\n    super.ngOnDestroy();\n  }\n}\n\nexport class HeaderConfigurations {\n\n  /**\n   * Identificativo dell'applicazione corrente in accordo\n   * con l'API Gateway\n   */\n  clientId?: string;\n\n  /**\n   * Url a cui contattare l'AGW per il recupero automatico dei frammenti html.\n   * Per il recupero verra' contattati i servizi 'HeaderFooter-MSPublicVersion' e 'HeaderFooter-MSPrivateVersion'.\n   * Se non specificato verra' utilizzato l'indirizzo relativo /api.\n   */\n  apiGatewayUrl?: any;\n\n  /**\n   * Url da cui recuperare il frammento html della prima intestazione di pagina (quella contenente il logo).\n   * Se passato inibisce il meccanismo di recupero automatico da AGW.\n   * Se non specificato il frammento html verra' recuperato automaticamente dal componente contattando il servizio 'HeaderFooter-MSPublicVersion'.\n   * Nel caso in cui non sia possibile recuperare il frammento l'html verra' visualizzato quello di default.\n   */\n  logoHeaderUrl?: string;\n\n  /**\n   * Url da cui recuperare il frammento html della navigazione principale.\n   * Se passato inibisce il meccanismo di recupero automatico da AGW.\n   * Se non specificato il frammento html verra' recuperato automaticamente dal componente contattando i servizi 'HeaderFooter-MSPublicVersion'\n   * e 'HeaderFooter-MSPrivateVersion'.\n   * Nel caso in cui non sia possibile recuperare il frammento html verra' visualizzato quello di default.\n   */\n  navigazionePrincipaleUrl?: string;\n\n  /**\n   * Url da cui recuperare il frammento html del header secondario\n   * Se passato inibisce il meccanismo di recupero automatico da AGW.\n   * Se non specificato il frammento html verra' recuperato automaticamente dal componente contattando il servizio 'HeaderFooter-MSPrivateVersion'.\n   * Nel caso in cui non sia possibile recuperare il frammento html verra' visualizzato quello di default.\n   */\n  headerSecondarioUrl?: string;\n\n  /**\n   * Se true vengono recuperati automaticamente i frammenti html di logo, navigazione principale e header secondario.\n   * I frammenti html verranno recuperati agli indirizzi indicati tramite le proprieta' di configurazione logoHeaderUrl, navigazionePrincipaleUrl\n   * headerSecondarioUrl.\n   * Se gli indirizzi non vengono impostati i frammenti html verranno recuperati automaticamente dal componente contattando\n   * il servizio 'HeaderFooter-MSPublicVersion' esposto su AGW.\n   * Se false i frammenti html dovranno essere passati in input al componente tramite le proprieta' di input logoHeaderHtml,\n   * navigazionePrincipaleHtml e headerSecondarioHtml o inseriti nel content del componente attraverso gli appositi selettori di contenuto.\n   */\n  recuperoAutomaticoHtml?: boolean;\n\n  /**\n   * Forza il componente a utilizzare i frammenti html di default.\n   * Se impostato a 'true' inibisce i meccanismi di recupero automatico dei frammenti html\n   * e ignora quanto specificato nelle proprieta' di input 'logoHeaderHtml', 'navigazionePrincipaleHtml' e 'headerSecondarioHtml'.\n   * In questo caso, per visualizzare il frammento html di default inerente l'header secondario,\n   * sara' necessario valorizzare la proprieta' di input 'headerSecondarioData'.\n   * Valorizzare o meno la proprieta' 'headerSecondarioData' inoltre determinera' se visualizzare il frammento html di default\n   * della navigazione principale inerente l'utente autenticato o quello inerente l'utente non autenticato\n   * (In caso di utente non autenticato il layout previsto per le applicazioni INAIL non mostra l'header secondario).\n   */\n  useDefaultHtml?: boolean;\n}\n","<!-- Prima intestazione di pagina (quella contenente il logo) -->\n<inail-logo-header [clientId]=\"config?.clientId\"\n                   [apiGatewayUrl]=\"config?.apiGatewayUrl\"\n                   [html]=\"logoHeaderHtml\"\n                   [url]=\"config?.logoHeaderUrl\"\n                   [useDefault]=\"config?.useDefaultHtml\"\n                   [recuperoAutomaticoHtml]=\"config?.recuperoAutomaticoHtml\"\n                   [reload]=\"reload\"\n                   [detectChange]=\"detectChange\"\n                   [logOnConsole]=\"logOnConsole\"\n                   (log)=\"emit($event)\">\n  <ng-content select=\"[logo-header]\"></ng-content>\n</inail-logo-header>\n\n<!-- Menu di navigazione principale recuperato (Barra blu con pulsante 'Esci' o 'Accedi ai servizi online') -->\n<inail-navigazione-principale [clientId]=\"config?.clientId\"\n                              [apiGatewayUrl]=\"config?.apiGatewayUrl\"\n                              [html]=\"navigazionePrincipaleHtml\"\n                              [url]=\"config?.navigazionePrincipaleUrl\"\n                              [useDefault]=\"config?.useDefaultHtml\"\n                              [recuperoAutomaticoHtml]=\"config?.recuperoAutomaticoHtml\"\n                              [isAuth]=\"headerSecondarioData != undefined\"\n                              [reload]=\"reload\"\n                              [detectChange]=\"detectChange\"\n                              [logOnConsole]=\"logOnConsole\"\n                              (log)=\"emit($event)\">\n  <ng-content select=\"[navigazione-principale]\"></ng-content>\n</inail-navigazione-principale>\n\n<!-- Menu di navigazione utente loggato (Barra verde) -->\n<inail-header-secondario [clientId]=\"config?.clientId\"\n                         [apiGatewayUrl]=\"config?.apiGatewayUrl\"\n                         [html]=\"headerSecondarioHtml\"\n                         [data]=\"headerSecondarioData\"\n                         [url]=\"config?.headerSecondarioUrl\"\n                         [useDefault]=\"config?.useDefaultHtml\"\n                         [recuperoAutomaticoHtml]=\"config?.recuperoAutomaticoHtml\"\n                         [reload]=\"reload\"\n                         [detectChange]=\"detectChange\"\n                         [logOnConsole]=\"logOnConsole\"\n                         (log)=\"emit($event)\">\n  <ng-content select=\"[header-secondario]\"></ng-content>\n</inail-header-secondario>\n\n<debug-pre *ngIf=\"showState\">[inail-header]<br>\n  <state-propertie [label]=\"'logOnConsole'\" [propertie]=\"logOnConsole\"></state-propertie>\n  <state-propertie [label]=\"'config'\" [propertie]=\"config\"></state-propertie>\n</debug-pre>\n"]}
|