@arsedizioni/ars-utils 18.4.64 → 18.4.65

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.
@@ -18,11 +18,11 @@ export declare class ClipperSearchCalendarComponent {
18
18
  canFilter: import("@angular/core").InputSignal<boolean>;
19
19
  /**
20
20
  * Update calendar
21
- * @param value : the snapshot
22
- * @param view : view to update 'month' or ' months'. Default is 'months'
21
+ * @param month : the month snapshot
22
+ * @param months : the months snapshot
23
23
  * @param date : the new current date
24
24
  */
25
- update(value: ClipperSearchCalendarSnapshotResult | null, view: 'month' | 'months', date: Date): void;
25
+ update(month: ClipperSearchCalendarSnapshotResult | null, months: ClipperSearchCalendarSnapshotResult | null, date: Date): void;
26
26
  /**
27
27
  * Filter by date
28
28
  * @param date : the date to filter to or "month" to filter by the whole month.
@@ -43,29 +43,24 @@ export class ClipperSearchCalendarComponent {
43
43
  }
44
44
  /**
45
45
  * Update calendar
46
- * @param value : the snapshot
47
- * @param view : view to update 'month' or ' months'. Default is 'months'
46
+ * @param month : the month snapshot
47
+ * @param months : the months snapshot
48
48
  * @param date : the new current date
49
49
  */
50
- update(value = null, view = 'months', date) {
51
- this.busy.set(true);
52
- setTimeout(() => {
53
- if (view === 'months') {
54
- this.months.set(value?.months);
55
- }
56
- else {
57
- if (value && value.months && value.months.length > 0)
58
- this.calendarSpecialDays = value.months[0].days;
59
- if (this.calendar) {
60
- this.calendar.activeDate = date;
61
- this.calendar.selected = date;
62
- this.calendar.updateTodaysDate();
63
- }
64
- this.calendarDate = date;
65
- }
66
- this.changeDetector.markForCheck();
67
- this.busy.set(false);
68
- }, 250);
50
+ update(month = null, months = null, date) {
51
+ if (months?.months) {
52
+ this.months.set(months.months);
53
+ }
54
+ if (month && month.months && month.months.length > 0) {
55
+ this.calendarSpecialDays = month.months[0].days;
56
+ }
57
+ if (this.calendar) {
58
+ this.calendar.activeDate = date;
59
+ this.calendar.selected = date;
60
+ this.calendar.updateTodaysDate();
61
+ }
62
+ this.calendarDate = date;
63
+ this.changeDetector.markForCheck();
69
64
  }
70
65
  /**
71
66
  * Filter by date
@@ -118,4 +113,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
118
113
  }], changed: [{
119
114
  type: Output
120
115
  }] } });
121
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-calendar.component.js","sourceRoot":"","sources":["../../../../../../projects/ars-utils/clipper.ui/ui/search-calendar/search-calendar.component.ts","../../../../../../projects/ars-utils/clipper.ui/ui/search-calendar/search-calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Output, ViewChild, inject, input, signal } from '@angular/core';\r\nimport { DateInterval } from '@arsedizioni/ars-utils/core';\r\nimport { MatExpansionModule } from '@angular/material/expansion';\r\nimport { MatDividerModule } from '@angular/material/divider';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { FlexModule } from '@ngbracket/ngx-layout/flex';\r\nimport { MatChipsModule } from '@angular/material/chips';\r\nimport { MatCalendar, MatCalendarCellClassFunction } from '@angular/material/datepicker';\r\nimport { endOfDay, endOfMonth, startOfMonth, startOfToday, subDays } from 'date-fns';\r\nimport { CalendarEmptyHeader } from '@arsedizioni/ars-utils/ui.application';\r\nimport { ClipperSearchCalendarSnapshotMonth, ClipperSearchCalendarSnapshotResult } from '@arsedizioni/ars-utils/clipper.common';\r\n\r\n\r\n\r\n@Component({\r\n  selector: 'clipper-search-calendar',\r\n  templateUrl: './search-calendar.component.html',\r\n  styleUrls: ['./search-calendar.component.scss'],\r\n  standalone: true,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  imports: [\r\n    FlexModule,\r\n    MatButtonModule,\r\n    MatTooltipModule,\r\n    MatCalendar,\r\n    MatChipsModule,\r\n    MatIconModule,\r\n    MatDividerModule,\r\n    MatExpansionModule\r\n  ],\r\n})\r\nexport class ClipperSearchCalendarComponent {\r\n  @ViewChild('calendar') calendar!: MatCalendar<any>;\r\n  @Output() changed = new EventEmitter<DateInterval | null>();\r\n  private changeDetector = inject(ChangeDetectorRef);\r\n\r\n  protected busy = signal<boolean>(false);\r\n  protected months = signal<ClipperSearchCalendarSnapshotMonth[]>(null);\r\n  protected calendarSpecialDays?: number[] | null = null;\r\n  protected calendarEmptyHeader = CalendarEmptyHeader;\r\n  public calendarDate: Date = startOfToday();\r\n  protected calendarDateClass: MatCalendarCellClassFunction<Date> = (cellDate) => {\r\n    if (!this.calendarSpecialDays) return '';\r\n    if (this.calendarSpecialDays[cellDate.getDate() - 1] > 0) {\r\n      if (cellDate < startOfToday()) return 'special-date-expired';\r\n      else if (subDays(cellDate, 15) <= startOfToday()) return 'special-date-expiring';\r\n      else return 'special-date';\r\n    }\r\n    return '';\r\n  };\r\n  protected calendarDateFilter = (cellDate: Date): boolean => {\r\n    return this.canFilter() && this.calendarSpecialDays != null && this.calendarSpecialDays[cellDate.getDate() - 1] > 0;\r\n  }\r\n  public canFilter = input<boolean>(false);\r\n\r\n\r\n  /**\r\n   * Update calendar\r\n   * @param value : the snapshot\r\n   * @param view : view to update 'month' or ' months'. Default is 'months'\r\n   * @param date : the new current date\r\n   */\r\n  update(value: ClipperSearchCalendarSnapshotResult | null = null,\r\n    view: 'month' | 'months' = 'months',\r\n    date: Date) {\r\n    this.busy.set(true);\r\n    setTimeout(() => {\r\n      if (view === 'months') {\r\n        this.months.set(value?.months);\r\n      } else {\r\n        if (value && value.months && value.months.length > 0)\r\n          this.calendarSpecialDays = value.months[0].days;\r\n        if (this.calendar) {\r\n          this.calendar.activeDate = date;\r\n          this.calendar.selected = date;\r\n          this.calendar.updateTodaysDate();\r\n        }\r\n        this.calendarDate = date;\r\n      }\r\n      this.changeDetector.markForCheck();\r\n      this.busy.set(false);\r\n    }, 250);\r\n  }\r\n\r\n\r\n  /**\r\n   * Filter by date\r\n   * @param date : the date to filter to or \"month\" to filter by the whole month.\r\n   */\r\n  protected filterByDate(date: Date | string | null) {\r\n    if (date === 'month') {\r\n      if (this.calendarDate) {\r\n        this.changed.emit(\r\n          new DateInterval(\r\n            endOfDay(startOfMonth(this.calendarDate)),\r\n            endOfMonth(this.calendarDate)));\r\n      }\r\n    } else if (date) {\r\n      this.changed.emit(\r\n        new DateInterval(\r\n          endOfDay(date as Date),\r\n          endOfDay(date as Date)));\r\n      this.calendarDate = date as Date;\r\n    } else {\r\n      this.changed.emit(null);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Filter by month\r\n   * @param monthInfo: the month info\r\n   */\r\n  protected filterByMonth(monthInfo: ClipperSearchCalendarSnapshotMonth) {\r\n    let newDate = new Date(monthInfo.year, monthInfo.month - 1, 1);\r\n    this.changed.emit(\r\n      new DateInterval(\r\n        endOfDay(startOfMonth(newDate)),\r\n        endOfMonth(newDate)));\r\n    this.calendarSpecialDays = monthInfo.days;\r\n    this.calendar.activeDate = newDate;\r\n    this.calendar.updateTodaysDate();\r\n    this.calendarDate = newDate;\r\n  }\r\n}\r\n","<div fxLayout=\"column\" fxFill class=\"calendar-container scroll-hidden\">\r\n  <div class=\"calendar-months\">\r\n    <div>\r\n      <div fxLayout=\"row wrap\" fxLayoutAlign=\"center\" fxLayoutGap=\"8px\" fxFill>\r\n        @for (m of months(); track $index) {\r\n        <button fxFlex=\"37px\" mat-button class=\"small uppercase\" (click)=\"filterByMonth(m)\" [disabled]=\"m.total === 0\">\r\n          @if (m.expired) {\r\n          <span class=\"expired\" [matTooltip]=\"m.expired + ' elementi in ritardo'\">{{m.monthShortName}}</span>\r\n          }\r\n          @if (!m.expired) {\r\n          <span [matTooltip]=\"m.total + ' elementi'\">{{m.monthShortName}}</span>\r\n          }\r\n        </button>\r\n        }\r\n      </div>\r\n    </div>\r\n    <div class=\"separator\"></div>\r\n  </div>\r\n  <div fxFlex=\"*\" class=\"scroll-auto\">\r\n    @if (!busy()) {\r\n    <mat-calendar #calendar [headerComponent]=\"calendarEmptyHeader\" [dateClass]=\"calendarDateClass\"\r\n      [dateFilter]=\"calendarDateFilter\" (selectedChange)=\"filterByDate($event)\" class=\"calendar-month\">\r\n    </mat-calendar>\r\n    <div fxLayout=\"row\" fxLayoutAlign=\"space-around\" style=\"padding:0 15px\">\r\n      <button type=\"button\" mat-stroked-button color=\"primary\" (click)=\"filterByDate('month')\">Tutto il\r\n        mese</button>\r\n    </div>\r\n    }\r\n  </div>\r\n</div>"]}
116
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-calendar.component.js","sourceRoot":"","sources":["../../../../../../projects/ars-utils/clipper.ui/ui/search-calendar/search-calendar.component.ts","../../../../../../projects/ars-utils/clipper.ui/ui/search-calendar/search-calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Output, ViewChild, inject, input, signal } from '@angular/core';\r\nimport { DateInterval } from '@arsedizioni/ars-utils/core';\r\nimport { MatExpansionModule } from '@angular/material/expansion';\r\nimport { MatDividerModule } from '@angular/material/divider';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { FlexModule } from '@ngbracket/ngx-layout/flex';\r\nimport { MatChipsModule } from '@angular/material/chips';\r\nimport { MatCalendar, MatCalendarCellClassFunction } from '@angular/material/datepicker';\r\nimport { endOfDay, endOfMonth, startOfMonth, startOfToday, subDays } from 'date-fns';\r\nimport { CalendarEmptyHeader } from '@arsedizioni/ars-utils/ui.application';\r\nimport { ClipperSearchCalendarSnapshotMonth, ClipperSearchCalendarSnapshotResult } from '@arsedizioni/ars-utils/clipper.common';\r\n\r\n\r\n\r\n@Component({\r\n  selector: 'clipper-search-calendar',\r\n  templateUrl: './search-calendar.component.html',\r\n  styleUrls: ['./search-calendar.component.scss'],\r\n  standalone: true,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  imports: [\r\n    FlexModule,\r\n    MatButtonModule,\r\n    MatTooltipModule,\r\n    MatCalendar,\r\n    MatChipsModule,\r\n    MatIconModule,\r\n    MatDividerModule,\r\n    MatExpansionModule\r\n  ],\r\n})\r\nexport class ClipperSearchCalendarComponent {\r\n  @ViewChild('calendar') calendar!: MatCalendar<any>;\r\n  @Output() changed = new EventEmitter<DateInterval | null>();\r\n  private changeDetector = inject(ChangeDetectorRef);\r\n\r\n  protected busy = signal<boolean>(false);\r\n  protected months = signal<ClipperSearchCalendarSnapshotMonth[]>(null);\r\n  protected calendarSpecialDays?: number[] | null = null;\r\n  protected calendarEmptyHeader = CalendarEmptyHeader;\r\n  public calendarDate: Date = startOfToday();\r\n  protected calendarDateClass: MatCalendarCellClassFunction<Date> = (cellDate) => {\r\n    if (!this.calendarSpecialDays) return '';\r\n    if (this.calendarSpecialDays[cellDate.getDate() - 1] > 0) {\r\n      if (cellDate < startOfToday()) return 'special-date-expired';\r\n      else if (subDays(cellDate, 15) <= startOfToday()) return 'special-date-expiring';\r\n      else return 'special-date';\r\n    }\r\n    return '';\r\n  };\r\n  protected calendarDateFilter = (cellDate: Date): boolean => {\r\n    return this.canFilter() && this.calendarSpecialDays != null && this.calendarSpecialDays[cellDate.getDate() - 1] > 0;\r\n  }\r\n  public canFilter = input<boolean>(false);\r\n\r\n\r\n  /**\r\n   * Update calendar\r\n   * @param month : the month snapshot\r\n   * @param months : the months snapshot\r\n   * @param date : the new current date\r\n   */\r\n  update(month: ClipperSearchCalendarSnapshotResult | null = null,\r\n    months: ClipperSearchCalendarSnapshotResult | null = null,\r\n    date: Date) {\r\n    if (months?.months) {\r\n      this.months.set(months.months);\r\n    }\r\n    if (month && month.months && month.months.length > 0) {\r\n      this.calendarSpecialDays = month.months[0].days;\r\n    }\r\n    if (this.calendar) {\r\n      this.calendar.activeDate = date;\r\n      this.calendar.selected = date;\r\n      this.calendar.updateTodaysDate();\r\n    }\r\n    this.calendarDate = date;\r\n    this.changeDetector.markForCheck();\r\n  }\r\n\r\n\r\n  /**\r\n   * Filter by date\r\n   * @param date : the date to filter to or \"month\" to filter by the whole month.\r\n   */\r\n  protected filterByDate(date: Date | string | null) {\r\n    if (date === 'month') {\r\n      if (this.calendarDate) {\r\n        this.changed.emit(\r\n          new DateInterval(\r\n            endOfDay(startOfMonth(this.calendarDate)),\r\n            endOfMonth(this.calendarDate)));\r\n      }\r\n    } else if (date) {\r\n      this.changed.emit(\r\n        new DateInterval(\r\n          endOfDay(date as Date),\r\n          endOfDay(date as Date)));\r\n      this.calendarDate = date as Date;\r\n    } else {\r\n      this.changed.emit(null);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Filter by month\r\n   * @param monthInfo: the month info\r\n   */\r\n  protected filterByMonth(monthInfo: ClipperSearchCalendarSnapshotMonth) {\r\n    let newDate = new Date(monthInfo.year, monthInfo.month - 1, 1);\r\n    this.changed.emit(\r\n      new DateInterval(\r\n        endOfDay(startOfMonth(newDate)),\r\n        endOfMonth(newDate)));\r\n    this.calendarSpecialDays = monthInfo.days;\r\n    this.calendar.activeDate = newDate;\r\n    this.calendar.updateTodaysDate();\r\n    this.calendarDate = newDate;\r\n  }\r\n}\r\n","<div fxLayout=\"column\" fxFill class=\"calendar-container scroll-hidden\">\r\n  <div class=\"calendar-months\">\r\n    <div>\r\n      <div fxLayout=\"row wrap\" fxLayoutAlign=\"center\" fxLayoutGap=\"8px\" fxFill>\r\n        @for (m of months(); track $index) {\r\n        <button fxFlex=\"37px\" mat-button class=\"small uppercase\" (click)=\"filterByMonth(m)\" [disabled]=\"m.total === 0\">\r\n          @if (m.expired) {\r\n          <span class=\"expired\" [matTooltip]=\"m.expired + ' elementi in ritardo'\">{{m.monthShortName}}</span>\r\n          }\r\n          @if (!m.expired) {\r\n          <span [matTooltip]=\"m.total + ' elementi'\">{{m.monthShortName}}</span>\r\n          }\r\n        </button>\r\n        }\r\n      </div>\r\n    </div>\r\n    <div class=\"separator\"></div>\r\n  </div>\r\n  <div fxFlex=\"*\" class=\"scroll-auto\">\r\n    @if (!busy()) {\r\n    <mat-calendar #calendar [headerComponent]=\"calendarEmptyHeader\" [dateClass]=\"calendarDateClass\"\r\n      [dateFilter]=\"calendarDateFilter\" (selectedChange)=\"filterByDate($event)\" class=\"calendar-month\">\r\n    </mat-calendar>\r\n    <div fxLayout=\"row\" fxLayoutAlign=\"space-around\" style=\"padding:0 15px\">\r\n      <button type=\"button\" mat-stroked-button color=\"primary\" (click)=\"filterByDate('month')\">Tutto il\r\n        mese</button>\r\n    </div>\r\n    }\r\n  </div>\r\n</div>"]}
@@ -934,29 +934,24 @@ class ClipperSearchCalendarComponent {
934
934
  }
935
935
  /**
936
936
  * Update calendar
937
- * @param value : the snapshot
938
- * @param view : view to update 'month' or ' months'. Default is 'months'
937
+ * @param month : the month snapshot
938
+ * @param months : the months snapshot
939
939
  * @param date : the new current date
940
940
  */
941
- update(value = null, view = 'months', date) {
942
- this.busy.set(true);
943
- setTimeout(() => {
944
- if (view === 'months') {
945
- this.months.set(value?.months);
946
- }
947
- else {
948
- if (value && value.months && value.months.length > 0)
949
- this.calendarSpecialDays = value.months[0].days;
950
- if (this.calendar) {
951
- this.calendar.activeDate = date;
952
- this.calendar.selected = date;
953
- this.calendar.updateTodaysDate();
954
- }
955
- this.calendarDate = date;
956
- }
957
- this.changeDetector.markForCheck();
958
- this.busy.set(false);
959
- }, 250);
941
+ update(month = null, months = null, date) {
942
+ if (months?.months) {
943
+ this.months.set(months.months);
944
+ }
945
+ if (month && month.months && month.months.length > 0) {
946
+ this.calendarSpecialDays = month.months[0].days;
947
+ }
948
+ if (this.calendar) {
949
+ this.calendar.activeDate = date;
950
+ this.calendar.selected = date;
951
+ this.calendar.updateTodaysDate();
952
+ }
953
+ this.calendarDate = date;
954
+ this.changeDetector.markForCheck();
960
955
  }
961
956
  /**
962
957
  * Filter by date