design-angular-kit 1.1.1 → 1.1.2

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.
@@ -113,4 +113,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImpor
113
113
  type: ViewChild,
114
114
  args: ['toggleButtonRef']
115
115
  }] } });
116
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navscroll.component.js","sourceRoot":"","sources":["../../../../../../../projects/design-angular-kit/src/lib/components/navigation/navscroll/navscroll.component.ts","../../../../../../../projects/design-angular-kit/src/lib/components/navigation/navscroll/navscroll.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AsyncPipe, NgClass, NgTemplateOutlet, ViewportScroller } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  DestroyRef,\n  ElementRef,\n  HostListener,\n  inject,\n  Input,\n  OnInit,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { RouterLink, RouterLinkActive, RouterLinkWithHref } from '@angular/router';\nimport { delay, filter, map, tap, withLatestFrom } from 'rxjs';\nimport { ItNavscrollListItemsComponent } from './navscroll-list-items.component';\nimport { NavscrollItem } from './navscroll.model';\nimport { NavscrollStore } from './navscroll.store';\n\n/**\n * Navscroll\n * @description Show a list of links to anchor of the document.\n */\n@Component({\n  selector: 'it-navscroll',\n  standalone: true,\n  imports: [\n    ItNavscrollListItemsComponent,\n    AsyncPipe,\n    NgTemplateOutlet,\n    RouterLink,\n    RouterLinkActive,\n    RouterLinkWithHref,\n    AsyncPipe,\n    NgClass,\n  ],\n  templateUrl: './navscroll.component.html',\n  styleUrl: './navscroll.component.scss',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [NavscrollStore],\n})\nexport class ItNavscrollComponent implements OnInit {\n  /**\n   * Header of the Navscroll\n   */\n  @Input() readonly header = '';\n  /**\n   * A list of links\n   */\n  @Input() readonly items!: Array<NavscrollItem>;\n  /**\n   * Border position\n   * @default left\n   */\n  @Input() readonly borderPosition: 'left' | 'right' = 'left';\n  /**\n   * Alignment\n   * @default top\n   */\n  @Input() readonly alignment: 'top' | 'bottom' = 'top';\n\n  /**\n   * Theme\n   * @default light\n   */\n  @Input() readonly theme: 'light' | 'dark' = 'light';\n\n  /**\n   * Custom template for the content section\n   */\n  @Input()\n  pageSectionsTemplate?: TemplateRef<any>;\n\n  @HostListener('window:scroll', ['$event']) // for window scroll events\n  onScroll() {\n    const sectionContainer = this.#elementRef.nativeElement.querySelector('.it-page-sections-container');\n    this.#store.updateProgressBar(sectionContainer);\n  }\n\n  @HostListener('window:resize', ['$event'])\n  onResize() {\n    this.#setMobile();\n  }\n\n  @ViewChild('toggleButtonRef')\n  readonly toggleButtonRef!: ElementRef<HTMLButtonElement>;\n\n  readonly #store = inject(NavscrollStore);\n\n  readonly #scroller = inject(ViewportScroller);\n\n  readonly #destroyRef = inject(DestroyRef);\n\n  readonly #elementRef = inject(ElementRef);\n\n  readonly selectedTitle = this.#store.selected.pipe(map(selected => selected?.title ?? ''));\n\n  readonly progressBarValue = this.#store.progressBar;\n\n  readonly isMobile = this.#store.isMobile;\n\n  constructor() {\n    this.#store.menuItemSelected\n      .pipe(\n        takeUntilDestroyed(),\n        withLatestFrom(this.isMobile),\n        tap(v => {\n          const isMobile = v[1];\n          if (isMobile) {\n            this.toggleButtonRef.nativeElement.click();\n          }\n        })\n      )\n      .subscribe();\n  }\n\n  ngOnInit(): void {\n    this.#initViewScrollerSubscription();\n    this.#store.init(this.items);\n    this.#setMobile();\n  }\n\n  #initViewScrollerSubscription() {\n    this.#store.selected\n      .pipe(\n        takeUntilDestroyed(this.#destroyRef),\n        filter(selected => Boolean(selected)),\n        map(v => v as NavscrollItem),\n        delay(0), //WA\n        tap({\n          next: ({ href }) => {\n            this.#scroller.scrollToAnchor(href);\n          },\n        })\n      )\n      .subscribe();\n  }\n\n  #setMobile() {\n    this.#store.setMobile(window);\n  }\n}\n","<div class=\"container py-lg-5\">\n  <div class=\"row\">\n    <div class=\"col-12 col-lg-4\">\n      <div class=\"it-navscroll-sticky\" [ngClass]=\"{ 'it-navscroll-sticky-mobile': isMobile | async }\" data-bs-stackable=\"true\">\n        <nav\n          class=\"navbar it-navscroll-wrapper navbar-expand-lg\"\n          [class.it-top-navscroll]=\"alignment === 'top'\"\n          [class.it-bottom-navscroll]=\"alignment === 'bottom'\"\n          [class.it-left-side]=\"borderPosition === 'left'\"\n          [class.it-right-side]=\"borderPosition === 'right'\"\n          [class.theme-dark-mobile]=\"theme === 'dark'\"\n          [class.theme-dark-desktop]=\"theme === 'dark'\">\n          <button\n            class=\"custom-navbar-toggler\"\n            type=\"button\"\n            aria-controls=\"navbarNav\"\n            aria-expanded=\"false\"\n            aria-label=\"Toggle navigation\"\n            data-bs-toggle=\"navbarcollapsible\"\n            data-bs-target=\"#navbarNav\"\n            #toggleButtonRef>\n            <span class=\"it-list\"></span>{{ selectedTitle | async }}\n          </button>\n          <div class=\"progress custom-navbar-progressbar\">\n            <div\n              class=\"progress-bar it-navscroll-progressbar\"\n              role=\"progressbar\"\n              [style.width.%]=\"progressBarValue | async\"\n              [attr.aria-valuenow]=\"progressBarValue | async\"\n              aria-valuemin=\"0\"\n              aria-valuemax=\"100\"></div>\n          </div>\n          <div class=\"navbar-collapsable\" id=\"navbarNav\">\n            <div class=\"overlay\"></div>\n            <div class=\"close-div visually-hidden\">\n              <button class=\"btn close-menu\" type=\"button\"><span class=\"it-close\"></span>Chiudi</button>\n            </div>\n            <button type=\"button\" class=\"it-back-button btn w-100 text-start\">\n              <svg class=\"icon icon-sm icon-primary align-top\">\n                <use\n                  href=\"/bootstrap-italia/dist/svg/sprites.svg#it-chevron-left\"\n                  xlink:href=\"/bootstrap-italia/dist/svg/sprites.svg#it-chevron-left\"></use>\n              </svg>\n              <span>Indietro</span>\n            </button>\n            <div class=\"menu-wrapper\">\n              <div class=\"link-list-wrapper\">\n                <h3>{{ header }}</h3>\n                <div class=\"progress\">\n                  <div\n                    class=\"progress-bar it-navscroll-progressbar\"\n                    role=\"progressbar\"\n                    [style.width.%]=\"progressBarValue | async\"\n                    [attr.aria-valuenow]=\"progressBarValue | async\"\n                    aria-valuemin=\"0\"\n                    aria-valuemax=\"100\"></div>\n                </div>\n                <it-navscroll-list-items [items]=\"items\"></it-navscroll-list-items>\n              </div>\n            </div>\n          </div>\n        </nav>\n      </div>\n    </div>\n    <div class=\"col-12 col-lg-8 it-page-sections-container\">\n      <ng-container\n        *ngTemplateOutlet=\"pageSectionsTemplate ? pageSectionsTemplate : defaultPageSectionsTemplate; context: { items: items }\">\n      </ng-container>\n    </div>\n  </div>\n</div>\n\n<ng-template #defaultPageSectionsTemplate let-items=\"items\">\n  @for (item of items; track item.href) {\n    <ng-container *ngTemplateOutlet=\"paragraphTemplate; context: { item: item, level: 1 }\"></ng-container>\n  }\n</ng-template>\n\n<ng-template #paragraphTemplate let-item=\"item\" let-level=\"level\" let-nextLevel=\"level+1\">\n  @switch (level) {\n    @case (1) {\n      <h2 class=\"it-page-section\" id=\"{{ item.href }}\">{{ item.title }}</h2>\n    }\n    @case (2) {\n      <h3 class=\"it-page-section\" id=\"{{ item.href }}\">{{ item.title }}</h3>\n    }\n    @case (3) {\n      <h4 class=\"it-page-section\" id=\"{{ item.href }}\">{{ item.title }}</h4>\n    }\n    @case (4) {\n      <h5 class=\"it-page-section\" id=\"{{ item.href }}\">{{ item.title }}</h5>\n    }\n    @default {\n      <h6 class=\"it-page-section\" id=\"{{ item.href }}\">{{ item.title }}</h6>\n    }\n  }\n  <p>{{ item.text }}</p>\n  @for (item of item.childs; track item.href) {\n    <ng-container *ngTemplateOutlet=\"paragraphTemplate; context: { item: item, level: nextLevel }\"></ng-container>\n  }\n</ng-template>\n"]}
116
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navscroll.component.js","sourceRoot":"","sources":["../../../../../../../projects/design-angular-kit/src/lib/components/navigation/navscroll/navscroll.component.ts","../../../../../../../projects/design-angular-kit/src/lib/components/navigation/navscroll/navscroll.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AsyncPipe, NgClass, NgTemplateOutlet, ViewportScroller } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  DestroyRef,\n  ElementRef,\n  HostListener,\n  inject,\n  Input,\n  OnInit,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { RouterLink, RouterLinkActive, RouterLinkWithHref } from '@angular/router';\nimport { delay, filter, map, tap, withLatestFrom } from 'rxjs';\nimport { ItNavscrollListItemsComponent } from './navscroll-list-items.component';\nimport { NavscrollItem } from './navscroll.model';\nimport { NavscrollStore } from './navscroll.store';\n\n/**\n * Navscroll\n * @description Show a list of links to anchor of the document.\n */\n@Component({\n  selector: 'it-navscroll',\n  standalone: true,\n  imports: [\n    ItNavscrollListItemsComponent,\n    AsyncPipe,\n    NgTemplateOutlet,\n    RouterLink,\n    RouterLinkActive,\n    RouterLinkWithHref,\n    AsyncPipe,\n    NgClass,\n  ],\n  templateUrl: './navscroll.component.html',\n  styleUrl: './navscroll.component.scss',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [NavscrollStore],\n})\nexport class ItNavscrollComponent implements OnInit {\n  /**\n   * Header of the Navscroll\n   */\n  @Input() header = '';\n  /**\n   * A list of links\n   */\n  @Input() items!: Array<NavscrollItem>;\n  /**\n   * Border position\n   * @default left\n   */\n  @Input() borderPosition: 'left' | 'right' = 'left';\n  /**\n   * Alignment\n   * @default top\n   */\n  @Input() alignment: 'top' | 'bottom' = 'top';\n\n  /**\n   * Theme\n   * @default light\n   */\n  @Input() theme: 'light' | 'dark' = 'light';\n\n  /**\n   * Custom template for the content section\n   */\n  @Input()\n  pageSectionsTemplate?: TemplateRef<any>;\n\n  @HostListener('window:scroll', ['$event']) // for window scroll events\n  onScroll() {\n    const sectionContainer = this.#elementRef.nativeElement.querySelector('.it-page-sections-container');\n    this.#store.updateProgressBar(sectionContainer);\n  }\n\n  @HostListener('window:resize', ['$event'])\n  onResize() {\n    this.#setMobile();\n  }\n\n  @ViewChild('toggleButtonRef')\n  readonly toggleButtonRef!: ElementRef<HTMLButtonElement>;\n\n  readonly #store = inject(NavscrollStore);\n\n  readonly #scroller = inject(ViewportScroller);\n\n  readonly #destroyRef = inject(DestroyRef);\n\n  readonly #elementRef = inject(ElementRef);\n\n  readonly selectedTitle = this.#store.selected.pipe(map(selected => selected?.title ?? ''));\n\n  readonly progressBarValue = this.#store.progressBar;\n\n  readonly isMobile = this.#store.isMobile;\n\n  constructor() {\n    this.#store.menuItemSelected\n      .pipe(\n        takeUntilDestroyed(),\n        withLatestFrom(this.isMobile),\n        tap(v => {\n          const isMobile = v[1];\n          if (isMobile) {\n            this.toggleButtonRef.nativeElement.click();\n          }\n        })\n      )\n      .subscribe();\n  }\n\n  ngOnInit(): void {\n    this.#initViewScrollerSubscription();\n    this.#store.init(this.items);\n    this.#setMobile();\n  }\n\n  #initViewScrollerSubscription() {\n    this.#store.selected\n      .pipe(\n        takeUntilDestroyed(this.#destroyRef),\n        filter(selected => Boolean(selected)),\n        map(v => v as NavscrollItem),\n        delay(0), //WA\n        tap({\n          next: ({ href }) => {\n            this.#scroller.scrollToAnchor(href);\n          },\n        })\n      )\n      .subscribe();\n  }\n\n  #setMobile() {\n    this.#store.setMobile(window);\n  }\n}\n","<div class=\"container py-lg-5\">\n  <div class=\"row\">\n    <div class=\"col-12 col-lg-4\">\n      <div class=\"it-navscroll-sticky\" [ngClass]=\"{ 'it-navscroll-sticky-mobile': isMobile | async }\" data-bs-stackable=\"true\">\n        <nav\n          class=\"navbar it-navscroll-wrapper navbar-expand-lg\"\n          [class.it-top-navscroll]=\"alignment === 'top'\"\n          [class.it-bottom-navscroll]=\"alignment === 'bottom'\"\n          [class.it-left-side]=\"borderPosition === 'left'\"\n          [class.it-right-side]=\"borderPosition === 'right'\"\n          [class.theme-dark-mobile]=\"theme === 'dark'\"\n          [class.theme-dark-desktop]=\"theme === 'dark'\">\n          <button\n            class=\"custom-navbar-toggler\"\n            type=\"button\"\n            aria-controls=\"navbarNav\"\n            aria-expanded=\"false\"\n            aria-label=\"Toggle navigation\"\n            data-bs-toggle=\"navbarcollapsible\"\n            data-bs-target=\"#navbarNav\"\n            #toggleButtonRef>\n            <span class=\"it-list\"></span>{{ selectedTitle | async }}\n          </button>\n          <div class=\"progress custom-navbar-progressbar\">\n            <div\n              class=\"progress-bar it-navscroll-progressbar\"\n              role=\"progressbar\"\n              [style.width.%]=\"progressBarValue | async\"\n              [attr.aria-valuenow]=\"progressBarValue | async\"\n              aria-valuemin=\"0\"\n              aria-valuemax=\"100\"></div>\n          </div>\n          <div class=\"navbar-collapsable\" id=\"navbarNav\">\n            <div class=\"overlay\"></div>\n            <div class=\"close-div visually-hidden\">\n              <button class=\"btn close-menu\" type=\"button\"><span class=\"it-close\"></span>Chiudi</button>\n            </div>\n            <button type=\"button\" class=\"it-back-button btn w-100 text-start\">\n              <svg class=\"icon icon-sm icon-primary align-top\">\n                <use\n                  href=\"/bootstrap-italia/dist/svg/sprites.svg#it-chevron-left\"\n                  xlink:href=\"/bootstrap-italia/dist/svg/sprites.svg#it-chevron-left\"></use>\n              </svg>\n              <span>Indietro</span>\n            </button>\n            <div class=\"menu-wrapper\">\n              <div class=\"link-list-wrapper\">\n                <h3>{{ header }}</h3>\n                <div class=\"progress\">\n                  <div\n                    class=\"progress-bar it-navscroll-progressbar\"\n                    role=\"progressbar\"\n                    [style.width.%]=\"progressBarValue | async\"\n                    [attr.aria-valuenow]=\"progressBarValue | async\"\n                    aria-valuemin=\"0\"\n                    aria-valuemax=\"100\"></div>\n                </div>\n                <it-navscroll-list-items [items]=\"items\"></it-navscroll-list-items>\n              </div>\n            </div>\n          </div>\n        </nav>\n      </div>\n    </div>\n    <div class=\"col-12 col-lg-8 it-page-sections-container\">\n      <ng-container\n        *ngTemplateOutlet=\"pageSectionsTemplate ? pageSectionsTemplate : defaultPageSectionsTemplate; context: { items: items }\">\n      </ng-container>\n    </div>\n  </div>\n</div>\n\n<ng-template #defaultPageSectionsTemplate let-items=\"items\">\n  @for (item of items; track item.href) {\n    <ng-container *ngTemplateOutlet=\"paragraphTemplate; context: { item: item, level: 1 }\"></ng-container>\n  }\n</ng-template>\n\n<ng-template #paragraphTemplate let-item=\"item\" let-level=\"level\" let-nextLevel=\"level+1\">\n  @switch (level) {\n    @case (1) {\n      <h2 class=\"it-page-section\" id=\"{{ item.href }}\">{{ item.title }}</h2>\n    }\n    @case (2) {\n      <h3 class=\"it-page-section\" id=\"{{ item.href }}\">{{ item.title }}</h3>\n    }\n    @case (3) {\n      <h4 class=\"it-page-section\" id=\"{{ item.href }}\">{{ item.title }}</h4>\n    }\n    @case (4) {\n      <h5 class=\"it-page-section\" id=\"{{ item.href }}\">{{ item.title }}</h5>\n    }\n    @default {\n      <h6 class=\"it-page-section\" id=\"{{ item.href }}\">{{ item.title }}</h6>\n    }\n  }\n  <p>{{ item.text }}</p>\n  @for (item of item.childs; track item.href) {\n    <ng-container *ngTemplateOutlet=\"paragraphTemplate; context: { item: item, level: nextLevel }\"></ng-container>\n  }\n</ng-template>\n"]}