@valtimo/dossier 12.1.2 → 12.1.3

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.
@@ -44,13 +44,14 @@ export class TabLoaderImpl {
44
44
  if (!initialTab) {
45
45
  initialTab = this._tabs[0] || null;
46
46
  }
47
- this.load(initialTab);
47
+ this.load(initialTab, true);
48
48
  }
49
- load(newTab) {
49
+ load(newTab, isInitial = false) {
50
50
  if (newTab !== this._activeTab) {
51
51
  this._tabs.forEach(tab => tab.deactivate());
52
52
  this.replaceView(newTab);
53
- this.replaceUrlState(newTab);
53
+ if (!isInitial)
54
+ this.replaceUrlState(newTab);
54
55
  this.setActive(newTab);
55
56
  }
56
57
  }
@@ -121,4 +122,4 @@ export class TabImpl {
121
122
  return this._active;
122
123
  }
123
124
  }
124
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tabs.model.js","sourceRoot":"","sources":["../../../../../../projects/valtimo/dossier/src/lib/models/tabs.model.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {ComponentFactoryResolver, ComponentRef, ViewContainerRef} from '@angular/core';\nimport {ActivatedRoute, Router} from '@angular/router';\nimport {BehaviorSubject, filter, Observable, take} from 'rxjs';\n\nexport interface TabLoader<T_TAB extends Tab> {\n  tabs: T_TAB[];\n\n  initial(tabName?: string): void;\n\n  load(tabToLoad: T_TAB): void;\n}\n\nexport class TabLoaderImpl implements TabLoader<TabImpl> {\n  private readonly _activeTab$ = new BehaviorSubject<TabImpl | null>(null);\n  private readonly _tabs: TabImpl[] = null;\n  private readonly _componentFactoryResolver: ComponentFactoryResolver = null;\n  private readonly _viewContainerRef: ViewContainerRef = null;\n  private _activeComponent: ComponentRef<any> = null;\n  private _activeTab: TabImpl = null;\n  private _router: Router;\n  private _route: ActivatedRoute;\n\n  constructor(\n    tabs: TabImpl[],\n    componentFactoryResolver: ComponentFactoryResolver,\n    viewContainerRef: ViewContainerRef,\n    router: Router,\n    route: ActivatedRoute\n  ) {\n    this._tabs = tabs;\n    this._componentFactoryResolver = componentFactoryResolver;\n    this._viewContainerRef = viewContainerRef;\n    this._router = router;\n    this._route = route;\n  }\n\n  public get tabs(): TabImpl[] {\n    return this._tabs;\n  }\n\n  public get activeTab$(): Observable<TabImpl> {\n    return this._activeTab$.pipe(filter(tab => !!tab));\n  }\n\n  public initial(tabName?: string): void {\n    let initialTab!: TabImpl;\n\n    if (tabName) {\n      initialTab =\n        this._tabs.find(tab => tab.name === tabName) ||\n        this._tabs.find(tab => tab.contentKey === tabName);\n    }\n\n    if (!initialTab) {\n      initialTab = this._tabs[0] || null;\n    }\n\n    this.load(initialTab);\n  }\n\n  public load(newTab: TabImpl): void {\n    if (newTab !== this._activeTab) {\n      this._tabs.forEach(tab => tab.deactivate());\n      this.replaceView(newTab);\n      this.replaceUrlState(newTab);\n      this.setActive(newTab);\n    }\n  }\n\n  public refreshView() {\n    this.replaceView(this._activeTab);\n  }\n\n  private replaceView(tab: TabImpl): void {\n    const componentFactory = this._componentFactoryResolver.resolveComponentFactory(tab.component);\n    this._viewContainerRef.clear();\n    if (this._activeTab !== null) {\n      this._activeComponent.destroy();\n    }\n    this._activeComponent = this._viewContainerRef.createComponent(componentFactory);\n  }\n\n  private replaceUrlState(nextTab: TabImpl): void {\n    this._route.params.pipe(take(1)).subscribe(params => {\n      const currentUrl = this._router.url;\n      const currentDocumentId = params?.documentId;\n      const urlBeforeDocumentId = currentUrl.split(currentDocumentId)[0];\n\n      this._router.navigateByUrl(`${urlBeforeDocumentId}${currentDocumentId}/${nextTab.name}`);\n    });\n  }\n\n  private setActive(tab: TabImpl): void {\n    tab.activate();\n    this._activeTab = tab;\n    this._activeTab$.next(tab);\n  }\n}\n\nexport interface Tab {\n  name: string;\n  sequence: number;\n  component: any;\n  title: string;\n  contentKey: string;\n\n  activate(): void;\n\n  deactivate(): void;\n\n  isActive(): boolean;\n}\n\nexport class TabImpl implements Tab {\n  private readonly _name: string;\n  private readonly _sequence: number;\n  private readonly _component: any;\n  private readonly _contentKey: string;\n  private readonly _title: string;\n  private _active = false;\n  private _showTasks = false;\n\n  constructor(\n    name: string,\n    sequence: number,\n    component: any,\n    contentKey?: string,\n    title?: string,\n    showTasks: boolean = false\n  ) {\n    this._name = name;\n    this._sequence = sequence;\n    this._component = component;\n\n    if (contentKey) this._contentKey = contentKey;\n    if (title) this._title = title;\n    if (showTasks) this._showTasks = showTasks;\n  }\n\n  public get name(): string {\n    return this._name;\n  }\n\n  public get sequence(): number {\n    return this._sequence;\n  }\n\n  public get component(): any {\n    return this._component;\n  }\n\n  public get contentKey(): string {\n    return this._contentKey;\n  }\n\n  public get title(): string {\n    return this._title;\n  }\n\n  public get showTasks(): boolean {\n    return this._showTasks;\n  }\n\n  public activate(): void {\n    this._active = true;\n  }\n\n  public deactivate(): void {\n    this._active = false;\n  }\n\n  public isActive(): boolean {\n    return this._active;\n  }\n}\n"]}
125
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tabs.model.js","sourceRoot":"","sources":["../../../../../../projects/valtimo/dossier/src/lib/models/tabs.model.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {ComponentFactoryResolver, ComponentRef, ViewContainerRef} from '@angular/core';\nimport {ActivatedRoute, Router} from '@angular/router';\nimport {BehaviorSubject, filter, Observable, take} from 'rxjs';\n\nexport interface TabLoader<T_TAB extends Tab> {\n  tabs: T_TAB[];\n\n  initial(tabName?: string): void;\n\n  load(tabToLoad: T_TAB): void;\n}\n\nexport class TabLoaderImpl implements TabLoader<TabImpl> {\n  private readonly _activeTab$ = new BehaviorSubject<TabImpl | null>(null);\n  private readonly _tabs: TabImpl[] = null;\n  private readonly _componentFactoryResolver: ComponentFactoryResolver = null;\n  private readonly _viewContainerRef: ViewContainerRef = null;\n  private _activeComponent: ComponentRef<any> = null;\n  private _activeTab: TabImpl = null;\n  private _router: Router;\n  private _route: ActivatedRoute;\n\n  constructor(\n    tabs: TabImpl[],\n    componentFactoryResolver: ComponentFactoryResolver,\n    viewContainerRef: ViewContainerRef,\n    router: Router,\n    route: ActivatedRoute\n  ) {\n    this._tabs = tabs;\n    this._componentFactoryResolver = componentFactoryResolver;\n    this._viewContainerRef = viewContainerRef;\n    this._router = router;\n    this._route = route;\n  }\n\n  public get tabs(): TabImpl[] {\n    return this._tabs;\n  }\n\n  public get activeTab$(): Observable<TabImpl> {\n    return this._activeTab$.pipe(filter(tab => !!tab));\n  }\n\n  public initial(tabName?: string): void {\n    let initialTab!: TabImpl;\n\n    if (tabName) {\n      initialTab =\n        this._tabs.find(tab => tab.name === tabName) ||\n        this._tabs.find(tab => tab.contentKey === tabName);\n    }\n\n    if (!initialTab) {\n      initialTab = this._tabs[0] || null;\n    }\n\n    this.load(initialTab, true);\n  }\n\n  public load(newTab: TabImpl, isInitial = false): void {\n    if (newTab !== this._activeTab) {\n      this._tabs.forEach(tab => tab.deactivate());\n      this.replaceView(newTab);\n      if (!isInitial) this.replaceUrlState(newTab);\n      this.setActive(newTab);\n    }\n  }\n\n  public refreshView() {\n    this.replaceView(this._activeTab);\n  }\n\n  private replaceView(tab: TabImpl): void {\n    const componentFactory = this._componentFactoryResolver.resolveComponentFactory(tab.component);\n    this._viewContainerRef.clear();\n    if (this._activeTab !== null) {\n      this._activeComponent.destroy();\n    }\n    this._activeComponent = this._viewContainerRef.createComponent(componentFactory);\n  }\n\n  private replaceUrlState(nextTab: TabImpl): void {\n    this._route.params.pipe(take(1)).subscribe(params => {\n      const currentUrl = this._router.url;\n      const currentDocumentId = params?.documentId;\n      const urlBeforeDocumentId = currentUrl.split(currentDocumentId)[0];\n\n      this._router.navigateByUrl(`${urlBeforeDocumentId}${currentDocumentId}/${nextTab.name}`);\n    });\n  }\n\n  private setActive(tab: TabImpl): void {\n    tab.activate();\n    this._activeTab = tab;\n    this._activeTab$.next(tab);\n  }\n}\n\nexport interface Tab {\n  name: string;\n  sequence: number;\n  component: any;\n  title: string;\n  contentKey: string;\n\n  activate(): void;\n\n  deactivate(): void;\n\n  isActive(): boolean;\n}\n\nexport class TabImpl implements Tab {\n  private readonly _name: string;\n  private readonly _sequence: number;\n  private readonly _component: any;\n  private readonly _contentKey: string;\n  private readonly _title: string;\n  private _active = false;\n  private _showTasks = false;\n\n  constructor(\n    name: string,\n    sequence: number,\n    component: any,\n    contentKey?: string,\n    title?: string,\n    showTasks: boolean = false\n  ) {\n    this._name = name;\n    this._sequence = sequence;\n    this._component = component;\n\n    if (contentKey) this._contentKey = contentKey;\n    if (title) this._title = title;\n    if (showTasks) this._showTasks = showTasks;\n  }\n\n  public get name(): string {\n    return this._name;\n  }\n\n  public get sequence(): number {\n    return this._sequence;\n  }\n\n  public get component(): any {\n    return this._component;\n  }\n\n  public get contentKey(): string {\n    return this._contentKey;\n  }\n\n  public get title(): string {\n    return this._title;\n  }\n\n  public get showTasks(): boolean {\n    return this._showTasks;\n  }\n\n  public activate(): void {\n    this._active = true;\n  }\n\n  public deactivate(): void {\n    this._active = false;\n  }\n\n  public isActive(): boolean {\n    return this._active;\n  }\n}\n"]}
@@ -918,13 +918,14 @@ class TabLoaderImpl {
918
918
  if (!initialTab) {
919
919
  initialTab = this._tabs[0] || null;
920
920
  }
921
- this.load(initialTab);
921
+ this.load(initialTab, true);
922
922
  }
923
- load(newTab) {
923
+ load(newTab, isInitial = false) {
924
924
  if (newTab !== this._activeTab) {
925
925
  this._tabs.forEach(tab => tab.deactivate());
926
926
  this.replaceView(newTab);
927
- this.replaceUrlState(newTab);
927
+ if (!isInitial)
928
+ this.replaceUrlState(newTab);
928
929
  this.setActive(newTab);
929
930
  }
930
931
  }