@colijnit/sharedcomponents 260.1.0 → 260.1.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/bundles/colijnit-sharedcomponents.umd.js +17 -4
- package/bundles/colijnit-sharedcomponents.umd.js.map +1 -1
- package/colijnit-sharedcomponents.metadata.json +1 -1
- package/esm2015/lib/components/date-planning/component/agenda/agenda-header.component.js +14 -2
- package/esm2015/lib/components/date-planning/date-planning.module.js +3 -1
- package/esm2015/lib/components/files-upload/files-upload.component.js +1 -1
- package/esm2015/lib/components/send-method-dialog/components/layout-selection/layout-selection.component.js +2 -2
- package/esm2015/lib/components/send-method-dialog/components/pdf-preview/pdf-preview.component.js +10 -10
- package/esm2015/lib/res/dictionary/dictionaries.js +3 -3
- package/fesm2015/colijnit-sharedcomponents.js +26 -13
- package/fesm2015/colijnit-sharedcomponents.js.map +1 -1
- package/lib/components/date-planning/component/agenda/agenda-header.component.d.ts +1 -0
- package/lib/components/date-planning/component/agenda/style/_layout.scss +1 -1
- package/lib/components/files-upload/files-upload.component.d.ts +1 -1
- package/lib/res/dictionary/dictionaries.d.ts +3 -0
- package/package.json +1 -1
|
@@ -180,6 +180,18 @@ export class AgendaHeaderComponent {
|
|
|
180
180
|
capitalizeString(label) {
|
|
181
181
|
return label[0].toUpperCase() + label.slice(1);
|
|
182
182
|
}
|
|
183
|
+
getWeekNumber(date) {
|
|
184
|
+
// Copy date so we don’t modify the original
|
|
185
|
+
const target = new Date(Date.UTC(date.getFullYear(), date.getMonth(), date.getDate()));
|
|
186
|
+
// ISO week starts on Monday (1) and ends on Sunday (7)
|
|
187
|
+
// Set to nearest Thursday: current date + 4 - current day number
|
|
188
|
+
const dayNum = target.getUTCDay() || 7;
|
|
189
|
+
target.setUTCDate(target.getUTCDate() + 4 - dayNum);
|
|
190
|
+
// Calculate week number
|
|
191
|
+
const yearStart = new Date(Date.UTC(target.getUTCFullYear(), 0, 1));
|
|
192
|
+
const weekNo = Math.ceil((((target.getTime() - yearStart.getTime()) / 86400000) + 1) / 7);
|
|
193
|
+
return weekNo;
|
|
194
|
+
}
|
|
183
195
|
}
|
|
184
196
|
AgendaHeaderComponent.decorators = [
|
|
185
197
|
{ type: Component, args: [{
|
|
@@ -202,7 +214,7 @@ AgendaHeaderComponent.decorators = [
|
|
|
202
214
|
<view-select [selectedView]="view" (selectedViewChange)="changeTheView($event)"></view-select>
|
|
203
215
|
</div>
|
|
204
216
|
<div class="month-description" *ngIf="weekDays?.length > 0">
|
|
205
|
-
{{ weekDays[0].weekdayMonthLong + ' ' + weekDays[0].weekdayYear }}
|
|
217
|
+
{{ weekDays[0].weekdayMonthLong + ' ' + weekDays[0].weekdayYear + ' ' + ('WEEK' | sharedLocalize)+ ': ' + this.getWeekNumber(weekDays[0].date) }}
|
|
206
218
|
</div>
|
|
207
219
|
<div class="week-day-label days-around" *ngFor="let weekDay of weekDays; let index = index"
|
|
208
220
|
[class.selected]="weekDay.weekdaySelected" (click)="setUnit(weekDay)">
|
|
@@ -279,4 +291,4 @@ AgendaHeaderComponent.propDecorators = {
|
|
|
279
291
|
selectedDateChange: [{ type: Output }],
|
|
280
292
|
rangeChange: [{ type: Output }]
|
|
281
293
|
};
|
|
282
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"agenda-header.component.js","sourceRoot":"","sources":["../../../../../../../../projects/sharedcomponents/src/lib/components/date-planning/component/agenda/agenda-header.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterContentChecked,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Inject,\r\n  Input,\r\n  LOCALE_ID,\r\n  NgZone,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  Renderer2, ViewEncapsulation\r\n} from \"@angular/core\";\r\nimport {CalendarView} from \"../../../../enum/calendar-view.enum\";\r\nimport {LanguageCode} from \"../../../../enum/language-code.enum\";\r\nimport {Weekday} from \"../../../../model/weekday.model\";\r\nimport {Week} from \"../../../../model/week.model\";\r\nimport {CalendarUtils} from \"../../../../utils/calendar.utils\";\r\nimport {NULL_DAY} from \"../../../../model/agenda-null-objects\";\r\nimport {Day} from \"../../../../model/day.model\"\r\nimport {Icon} from \"../../../../enum/icon.enum\";\r\nimport {AgendaEventPerDay} from \"../../../../model/agenda-event-per-day.model\";\r\nimport {DateUtils} from \"../../../../utils/date-utils\";\r\nimport {IconCacheService} from \"../../../../service/icon-cache.service\";\r\n\r\n@Component({\r\n    selector: \"agenda-header\",\r\n    template: `\r\n      <div class=\"agenda-header-wrapper\" *ngIf=\"view === viewTypes.DayView\">\r\n        <div class=\"hour-label-placeholder\" *ngIf=\"viewSelection\">\r\n          <view-select [selectedView]=\"view\" (selectedViewChange)=\"changeTheView($event)\"></view-select>\r\n        </div>\r\n        <div class=\"week-day-label\">\r\n          <co-icon class=\"pointer-hover no-user-select sub-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointLeft)\" (click)=\"subUnit()\"></co-icon>\r\n          <div class=\"day-description\" [textContent]=\"day.description\"></div>\r\n          <co-icon class=\"pointer-hover no-user-select add-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointRight)\" (click)=\"addUnit()\"></co-icon>\r\n        </div>\r\n      </div>\r\n      <div class=\"agenda-header-wrapper days-around\" *ngIf=\"view === viewTypes.DaysAround\">\r\n        <div class=\"hour-label-placeholder\" *ngIf=\"viewSelection\">\r\n          <view-select [selectedView]=\"view\" (selectedViewChange)=\"changeTheView($event)\"></view-select>\r\n        </div>\r\n        <div class=\"month-description\" *ngIf=\"weekDays?.length > 0\">\r\n          {{ weekDays[0].weekdayMonthLong + ' ' + weekDays[0].weekdayYear }}\r\n        </div>\r\n        <div class=\"week-day-label days-around\" *ngFor=\"let weekDay of weekDays; let index = index\"\r\n             [class.selected]=\"weekDay.weekdaySelected\" (click)=\"setUnit(weekDay)\">\r\n          <co-icon *ngIf=\"showBackButton && index === 0\" class=\"pointer-hover no-user-select sub-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointLeft)\" (click)=\"subUnit()\"></co-icon>\r\n          <div class=\"weekday-value day\"\r\n               [textContent]=\"capitalizeString(weekDay.weekdayShort)\"></div>\r\n          <div class=\"weekday-value date\"\r\n               [textContent]=\"weekDay.weekdayDay\"></div>\r\n          <co-icon *ngIf=\"index === 6\" class=\"pointer-hover no-user-select add-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointRight)\" (click)=\"addUnit()\"></co-icon>\r\n        </div>\r\n      </div>\r\n      <div class=\"agenda-header-wrapper\" *ngIf=\"view === viewTypes.WeekView\">\r\n        <div class=\"hour-label-placeholder\" *ngIf=\"viewSelection\">\r\n          <view-select [selectedView]=\"view\" (selectedViewChange)=\"changeTheView($event)\"></view-select>\r\n        </div>\r\n        <div class=\"week-day-label\" *ngFor=\"let weekDay of weekDays; let index = index\"\r\n             [class.selected]=\"weekDay.weekdaySelected\" (click)=\"setUnit(weekDay)\">\r\n          <co-icon *ngIf=\"showBackButton && index === 0\" class=\"pointer-hover no-user-select sub-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointLeft)\" (click)=\"subUnit()\"></co-icon>\r\n          <div *ngIf=\"weekDay.newMonth\" [textContent]=\"weekDay.weekdayMonthLong + ' ' + weekDay.weekdayYear\"\r\n               class=\"month-description\"></div>\r\n          <div class=\"weekday-value\"\r\n               [textContent]=\"capitalizeString(weekDay.weekdayLong) + ' ' + weekDay.weekdayDay + ' ' + capitalizeString(weekDay.weekdayMonthLong) + ' ' + weekDay.weekdayYear \"></div>\r\n          <co-icon *ngIf=\"index === 2\" class=\"pointer-hover no-user-select add-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointRight)\" (click)=\"addUnit()\"></co-icon>\r\n\r\n        </div>\r\n\r\n      </div>\r\n\r\n\r\n      <div class=\"agenda-header-wrapper\" *ngIf=\"view === viewTypes.WeekSelectView\">\r\n        <div class=\"week-day-label\" *ngFor=\"let weekDay of weekDays; let index = index\"\r\n             [class.selected]=\"weekDay.weekdaySelected\"\r\n             [class.selectable]=\"weekDay.events && weekDay.events.length > 0\"\r\n             (click)=\"setUnit(weekDay)\">\r\n          <co-icon *ngIf=\"index === 0 && showBackButton\" class=\"pointer-hover no-user-select sub-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointLeft)\" (click)=\"subUnit()\"></co-icon>\r\n          <div class=\"weekday-description\" [textContent]=\"weekDay.weekdayShort\"></div>\r\n          <div class=\"weekday-value\" [textContent]=\"weekDay.weekdayDay + ' ' + weekDay.weekdayMonthShort\"></div>\r\n          <co-icon *ngIf=\"index === 6\" class=\"pointer-hover no-user-select add-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointRight)\" (click)=\"addUnit()\"></co-icon>\r\n        </div>\r\n      </div>\r\n      <div class=\"agenda-header-wrapper\" *ngIf=\"view === viewTypes.MonthView\">\r\n        <div class=\"week-day-label\" *ngFor=\"let weekDay of weekDays; let index = index\">\r\n          <co-icon *ngIf=\"index === 0 && showBackButton\" class=\"pointer-hover no-user-select sub-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointLeft)\" (click)=\"subUnit()\"></co-icon>\r\n          <div class=\"weekday-description\" [textContent]=\"weekDay.weekdayShort\"></div>\r\n          <co-icon *ngIf=\"index === 6\" class=\"pointer-hover no-user-select add-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointRight)\" (click)=\"addUnit()\"></co-icon>\r\n        </div>\r\n      </div>\r\n    `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class AgendaHeaderComponent implements OnInit, OnDestroy, AfterContentChecked {\r\n    public readonly icons: typeof Icon = Icon;\r\n    public readonly viewTypes: typeof CalendarView = CalendarView;\r\n\r\n    private readonly scrollbarWidth: number = 15;\r\n\r\n    public today: Date = new Date();\r\n\r\n    @Input()\r\n    public set selectedDate(value: Date) {\r\n        this._selectedDate = new Date(value);\r\n        this._prepareHeaderData();\r\n    }\r\n\r\n    public get selectedDate(): Date {\r\n        return this._selectedDate;\r\n    }\r\n\r\n    @Input()\r\n    public view: CalendarView;\r\n\r\n    @Input()\r\n    public set firstAvailableDate(value: Date) {\r\n        if (value) {\r\n            this._firstAvailableDate = new Date(value);\r\n            this._prepareHeaderData();\r\n        }\r\n    }\r\n\r\n    public get firstAvailableDate(): Date {\r\n        return this._firstAvailableDate;\r\n    }\r\n\r\n    @Input()\r\n    public set eventsPerDay(value: AgendaEventPerDay[]) {\r\n        this._eventsPerDay = value;\r\n        this._prepareHeaderData();\r\n    }\r\n\r\n    @Input()\r\n    public viewSelection: boolean;\r\n\r\n    @Output()\r\n    public viewChange: EventEmitter<CalendarView> = new EventEmitter<CalendarView>();\r\n\r\n    @Output()\r\n    public selectedDateChange: EventEmitter<Date> = new EventEmitter<Date>();\r\n\r\n    @Output()\r\n    public rangeChange: EventEmitter<Date> = new EventEmitter<Date>();\r\n\r\n    public weekDays: Weekday[] = [];\r\n    public day: Day = NULL_DAY;\r\n    public showBackButton: boolean = true;\r\n\r\n    private _selectedDate: Date;\r\n    private _firstAvailableDate: Date;\r\n    private _eventsPerDay: AgendaEventPerDay[] = [];\r\n\r\n    constructor(\r\n        @Inject(LOCALE_ID) private readonly _locale: LanguageCode,\r\n        private _elementRef: ElementRef,\r\n        private _renderer: Renderer2,\r\n        private _ngZone: NgZone,\r\n        public iconCacheService: IconCacheService\r\n    ) {\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        window.removeEventListener(\"resize\", this._onResize);\r\n        this._elementRef = undefined;\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        this._ngZone.runOutsideAngular(() => {\r\n            window.addEventListener(\"resize\", this._onResize);\r\n        });\r\n    }\r\n\r\n    ngAfterContentChecked(): void {\r\n        this._resizeHost();\r\n    }\r\n\r\n    public subUnit(): void {\r\n        if (this.selectedDate) {\r\n            const newDate: Date = new Date(this.selectedDate);\r\n            switch (this.view) {\r\n                case CalendarView.DayView:\r\n                    newDate.setDate(this.selectedDate.getDate() - 1);\r\n                    break;\r\n                case CalendarView.DaysAround:\r\n                  newDate.setDate(this.selectedDate.getDate() - 1);\r\n                  break;\r\n                case CalendarView.WeekView:\r\n                    newDate.setDate(this.selectedDate.getDate() - 3);\r\n                    break;\r\n                case CalendarView.WeekSelectView:\r\n                    newDate.setDate(this.selectedDate.getDate() - 7);\r\n                    break;\r\n                case CalendarView.MonthView:\r\n                    newDate.setMonth(this.selectedDate.getMonth() - 1);\r\n                    break;\r\n            }\r\n            this.selectedDate = newDate;\r\n            this.rangeChange.emit(this.selectedDate);\r\n        }\r\n    }\r\n\r\n    public addUnit(): void {\r\n        if (this.selectedDate) {\r\n            const newDate: Date = new Date(this.selectedDate);\r\n            switch (this.view) {\r\n                case CalendarView.DayView:\r\n                    newDate.setDate(this.selectedDate.getDate() + 1);\r\n                    break;\r\n                case CalendarView.DaysAround:\r\n                    newDate.setDate(this.selectedDate.getDate() + 1);\r\n                    break;\r\n                case CalendarView.WeekView:\r\n                    newDate.setDate(this.selectedDate.getDate() + 3);\r\n                    break;\r\n                case CalendarView.WeekSelectView:\r\n                    newDate.setDate(this.selectedDate.getDate() + 7);\r\n                    break;\r\n                case CalendarView.MonthView:\r\n                    newDate.setMonth(this.selectedDate.getMonth() + 1);\r\n                    break;\r\n            }\r\n            this.selectedDate = newDate;\r\n            this.rangeChange.emit(this.selectedDate);\r\n        }\r\n    }\r\n\r\n    public setUnit(weekDay: Weekday): void {\r\n        this.selectedDate = weekDay.date;\r\n        this.selectedDateChange.emit(this.selectedDate);\r\n    }\r\n\r\n    public changeTheView(view: CalendarView): void {\r\n        this.view = view;\r\n        this.viewChange.emit(view);\r\n        this._prepareHeaderData();\r\n    }\r\n\r\n    private _onResize: EventListener = async (): Promise<void> => {\r\n        this._resizeHost();\r\n    }\r\n\r\n    /**\r\n     * Need to resize the host component to size it's fixed positioned child through css\r\n     */\r\n    private _resizeHost(): void {\r\n        if (this._elementRef) {\r\n            this._renderer.setStyle(\r\n                this._elementRef.nativeElement, \"width\", this._elementRef.nativeElement.parentElement.clientWidth - this.scrollbarWidth + \"px\");\r\n        }\r\n    }\r\n\r\n    private _prepareHeaderData(): void {\r\n        if (this.selectedDate) {\r\n            switch (this.view) {\r\n                case CalendarView.DayView:\r\n                    const day: Day = new Day();\r\n                    day.date = new Date(this.selectedDate);\r\n                    const options: any = { year: \"numeric\", month: \"long\", day: \"numeric\" };\r\n                    day.description = this.selectedDate.toLocaleDateString(this._locale, options);\r\n                    this.day = day;\r\n                    break;\r\n                case CalendarView.DaysAround:\r\n                    const weekAroundView: Week = CalendarUtils.GetDaysAround(this.selectedDate);\r\n                    this.weekDays = weekAroundView.weekDays;\r\n                    if (this.firstAvailableDate) {\r\n                      this.showBackButton = this.weekDays.find(wd => DateUtils.DatesEqual(this.firstAvailableDate, wd.date)) === undefined;\r\n                    }\r\n                    break;\r\n                case CalendarView.WeekView:\r\n                    const weekView: Week = CalendarUtils.GetDaysOfWeek(this.selectedDate);\r\n                    this.weekDays = weekView.weekDays;\r\n                    if (this.firstAvailableDate) {\r\n                        this.showBackButton = this.weekDays.find(wd => DateUtils.DatesEqual(this.firstAvailableDate, wd.date)) === undefined;\r\n                    }\r\n                    break;\r\n                case CalendarView.WeekSelectView:\r\n                    const weekSelectView: Week = CalendarUtils.GetDaysOfWeek(this.selectedDate);\r\n                    this.weekDays = weekSelectView.weekDays;\r\n                    this.weekDays.forEach((wd: Weekday) => {\r\n                        const evPerDay: AgendaEventPerDay = this._eventsPerDay && this._eventsPerDay.length > 0 ? this._eventsPerDay.find(e => DateUtils.DatesEqual(e.date, wd.date)) : null;\r\n                        if (evPerDay) {\r\n                            wd.events = evPerDay.events;\r\n                        } else {\r\n                            wd.weekdaySelected = false;\r\n                        }\r\n                    });\r\n                    if (this.firstAvailableDate) {\r\n                        this.showBackButton = this.weekDays.find(wd => DateUtils.DatesEqual(this.firstAvailableDate, wd.date)) === undefined;\r\n                    }\r\n                    break;\r\n                case CalendarView.MonthView:\r\n                    const weekOfMonth: Week = CalendarUtils.GetDaysOfWeek(this.selectedDate);\r\n                    this.weekDays = weekOfMonth.weekDays;\r\n                    if (this.firstAvailableDate) {\r\n                        this.showBackButton = this.weekDays.find(wd => DateUtils.DatesEqual(this.firstAvailableDate, wd.date)) === undefined;\r\n                    }\r\n                    break;\r\n            }\r\n        }\r\n    }\r\n\r\n    public capitalizeString(label: string): string {\r\n      return label[0].toUpperCase() + label.slice(1);\r\n    }\r\n}\r\n"]}
|
|
294
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"agenda-header.component.js","sourceRoot":"","sources":["../../../../../../../../projects/sharedcomponents/src/lib/components/date-planning/component/agenda/agenda-header.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterContentChecked,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Inject,\r\n  Input,\r\n  LOCALE_ID,\r\n  NgZone,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  Renderer2, ViewEncapsulation\r\n} from \"@angular/core\";\r\nimport {CalendarView} from \"../../../../enum/calendar-view.enum\";\r\nimport {LanguageCode} from \"../../../../enum/language-code.enum\";\r\nimport {Weekday} from \"../../../../model/weekday.model\";\r\nimport {Week} from \"../../../../model/week.model\";\r\nimport {CalendarUtils} from \"../../../../utils/calendar.utils\";\r\nimport {NULL_DAY} from \"../../../../model/agenda-null-objects\";\r\nimport {Day} from \"../../../../model/day.model\"\r\nimport {Icon} from \"../../../../enum/icon.enum\";\r\nimport {AgendaEventPerDay} from \"../../../../model/agenda-event-per-day.model\";\r\nimport {DateUtils} from \"../../../../utils/date-utils\";\r\nimport {IconCacheService} from \"../../../../service/icon-cache.service\";\r\n\r\n@Component({\r\n    selector: \"agenda-header\",\r\n    template: `\r\n      <div class=\"agenda-header-wrapper\" *ngIf=\"view === viewTypes.DayView\">\r\n        <div class=\"hour-label-placeholder\" *ngIf=\"viewSelection\">\r\n          <view-select [selectedView]=\"view\" (selectedViewChange)=\"changeTheView($event)\"></view-select>\r\n        </div>\r\n        <div class=\"week-day-label\">\r\n          <co-icon class=\"pointer-hover no-user-select sub-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointLeft)\" (click)=\"subUnit()\"></co-icon>\r\n          <div class=\"day-description\" [textContent]=\"day.description\"></div>\r\n          <co-icon class=\"pointer-hover no-user-select add-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointRight)\" (click)=\"addUnit()\"></co-icon>\r\n        </div>\r\n      </div>\r\n      <div class=\"agenda-header-wrapper days-around\" *ngIf=\"view === viewTypes.DaysAround\">\r\n        <div class=\"hour-label-placeholder\" *ngIf=\"viewSelection\">\r\n          <view-select [selectedView]=\"view\" (selectedViewChange)=\"changeTheView($event)\"></view-select>\r\n        </div>\r\n        <div class=\"month-description\" *ngIf=\"weekDays?.length > 0\">\r\n          {{ weekDays[0].weekdayMonthLong + ' ' + weekDays[0].weekdayYear + ' ' + ('WEEK' | sharedLocalize)+ ': ' +  this.getWeekNumber(weekDays[0].date) }}\r\n        </div>\r\n        <div class=\"week-day-label days-around\" *ngFor=\"let weekDay of weekDays; let index = index\"\r\n             [class.selected]=\"weekDay.weekdaySelected\" (click)=\"setUnit(weekDay)\">\r\n          <co-icon *ngIf=\"showBackButton && index === 0\" class=\"pointer-hover no-user-select sub-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointLeft)\" (click)=\"subUnit()\"></co-icon>\r\n          <div class=\"weekday-value day\"\r\n               [textContent]=\"capitalizeString(weekDay.weekdayShort)\"></div>\r\n          <div class=\"weekday-value date\"\r\n               [textContent]=\"weekDay.weekdayDay\"></div>\r\n          <co-icon *ngIf=\"index === 6\" class=\"pointer-hover no-user-select add-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointRight)\" (click)=\"addUnit()\"></co-icon>\r\n        </div>\r\n      </div>\r\n      <div class=\"agenda-header-wrapper\" *ngIf=\"view === viewTypes.WeekView\">\r\n        <div class=\"hour-label-placeholder\" *ngIf=\"viewSelection\">\r\n          <view-select [selectedView]=\"view\" (selectedViewChange)=\"changeTheView($event)\"></view-select>\r\n        </div>\r\n        <div class=\"week-day-label\" *ngFor=\"let weekDay of weekDays; let index = index\"\r\n             [class.selected]=\"weekDay.weekdaySelected\" (click)=\"setUnit(weekDay)\">\r\n          <co-icon *ngIf=\"showBackButton && index === 0\" class=\"pointer-hover no-user-select sub-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointLeft)\" (click)=\"subUnit()\"></co-icon>\r\n          <div *ngIf=\"weekDay.newMonth\" [textContent]=\"weekDay.weekdayMonthLong + ' ' + weekDay.weekdayYear\"\r\n               class=\"month-description\"></div>\r\n          <div class=\"weekday-value\"\r\n               [textContent]=\"capitalizeString(weekDay.weekdayLong) + ' ' + weekDay.weekdayDay + ' ' + capitalizeString(weekDay.weekdayMonthLong) + ' ' + weekDay.weekdayYear \"></div>\r\n          <co-icon *ngIf=\"index === 2\" class=\"pointer-hover no-user-select add-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointRight)\" (click)=\"addUnit()\"></co-icon>\r\n\r\n        </div>\r\n\r\n      </div>\r\n\r\n\r\n      <div class=\"agenda-header-wrapper\" *ngIf=\"view === viewTypes.WeekSelectView\">\r\n        <div class=\"week-day-label\" *ngFor=\"let weekDay of weekDays; let index = index\"\r\n             [class.selected]=\"weekDay.weekdaySelected\"\r\n             [class.selectable]=\"weekDay.events && weekDay.events.length > 0\"\r\n             (click)=\"setUnit(weekDay)\">\r\n          <co-icon *ngIf=\"index === 0 && showBackButton\" class=\"pointer-hover no-user-select sub-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointLeft)\" (click)=\"subUnit()\"></co-icon>\r\n          <div class=\"weekday-description\" [textContent]=\"weekDay.weekdayShort\"></div>\r\n          <div class=\"weekday-value\" [textContent]=\"weekDay.weekdayDay + ' ' + weekDay.weekdayMonthShort\"></div>\r\n          <co-icon *ngIf=\"index === 6\" class=\"pointer-hover no-user-select add-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointRight)\" (click)=\"addUnit()\"></co-icon>\r\n        </div>\r\n      </div>\r\n      <div class=\"agenda-header-wrapper\" *ngIf=\"view === viewTypes.MonthView\">\r\n        <div class=\"week-day-label\" *ngFor=\"let weekDay of weekDays; let index = index\">\r\n          <co-icon *ngIf=\"index === 0 && showBackButton\" class=\"pointer-hover no-user-select sub-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointLeft)\" (click)=\"subUnit()\"></co-icon>\r\n          <div class=\"weekday-description\" [textContent]=\"weekDay.weekdayShort\"></div>\r\n          <co-icon *ngIf=\"index === 6\" class=\"pointer-hover no-user-select add-unit-icon dark\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.ArrowPointRight)\" (click)=\"addUnit()\"></co-icon>\r\n        </div>\r\n      </div>\r\n    `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class AgendaHeaderComponent implements OnInit, OnDestroy, AfterContentChecked {\r\n    public readonly icons: typeof Icon = Icon;\r\n    public readonly viewTypes: typeof CalendarView = CalendarView;\r\n\r\n    private readonly scrollbarWidth: number = 15;\r\n\r\n    public today: Date = new Date();\r\n\r\n    @Input()\r\n    public set selectedDate(value: Date) {\r\n        this._selectedDate = new Date(value);\r\n        this._prepareHeaderData();\r\n    }\r\n\r\n    public get selectedDate(): Date {\r\n        return this._selectedDate;\r\n    }\r\n\r\n    @Input()\r\n    public view: CalendarView;\r\n\r\n    @Input()\r\n    public set firstAvailableDate(value: Date) {\r\n        if (value) {\r\n            this._firstAvailableDate = new Date(value);\r\n            this._prepareHeaderData();\r\n        }\r\n    }\r\n\r\n    public get firstAvailableDate(): Date {\r\n        return this._firstAvailableDate;\r\n    }\r\n\r\n    @Input()\r\n    public set eventsPerDay(value: AgendaEventPerDay[]) {\r\n        this._eventsPerDay = value;\r\n        this._prepareHeaderData();\r\n    }\r\n\r\n    @Input()\r\n    public viewSelection: boolean;\r\n\r\n    @Output()\r\n    public viewChange: EventEmitter<CalendarView> = new EventEmitter<CalendarView>();\r\n\r\n    @Output()\r\n    public selectedDateChange: EventEmitter<Date> = new EventEmitter<Date>();\r\n\r\n    @Output()\r\n    public rangeChange: EventEmitter<Date> = new EventEmitter<Date>();\r\n\r\n    public weekDays: Weekday[] = [];\r\n    public day: Day = NULL_DAY;\r\n    public showBackButton: boolean = true;\r\n\r\n    private _selectedDate: Date;\r\n    private _firstAvailableDate: Date;\r\n    private _eventsPerDay: AgendaEventPerDay[] = [];\r\n\r\n    constructor(\r\n        @Inject(LOCALE_ID) private readonly _locale: LanguageCode,\r\n        private _elementRef: ElementRef,\r\n        private _renderer: Renderer2,\r\n        private _ngZone: NgZone,\r\n        public iconCacheService: IconCacheService\r\n    ) {\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        window.removeEventListener(\"resize\", this._onResize);\r\n        this._elementRef = undefined;\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        this._ngZone.runOutsideAngular(() => {\r\n            window.addEventListener(\"resize\", this._onResize);\r\n        });\r\n    }\r\n\r\n    ngAfterContentChecked(): void {\r\n        this._resizeHost();\r\n    }\r\n\r\n    public subUnit(): void {\r\n        if (this.selectedDate) {\r\n            const newDate: Date = new Date(this.selectedDate);\r\n            switch (this.view) {\r\n                case CalendarView.DayView:\r\n                    newDate.setDate(this.selectedDate.getDate() - 1);\r\n                    break;\r\n                case CalendarView.DaysAround:\r\n                  newDate.setDate(this.selectedDate.getDate() - 1);\r\n                  break;\r\n                case CalendarView.WeekView:\r\n                    newDate.setDate(this.selectedDate.getDate() - 3);\r\n                    break;\r\n                case CalendarView.WeekSelectView:\r\n                    newDate.setDate(this.selectedDate.getDate() - 7);\r\n                    break;\r\n                case CalendarView.MonthView:\r\n                    newDate.setMonth(this.selectedDate.getMonth() - 1);\r\n                    break;\r\n            }\r\n            this.selectedDate = newDate;\r\n            this.rangeChange.emit(this.selectedDate);\r\n        }\r\n    }\r\n\r\n    public addUnit(): void {\r\n        if (this.selectedDate) {\r\n            const newDate: Date = new Date(this.selectedDate);\r\n            switch (this.view) {\r\n                case CalendarView.DayView:\r\n                    newDate.setDate(this.selectedDate.getDate() + 1);\r\n                    break;\r\n                case CalendarView.DaysAround:\r\n                    newDate.setDate(this.selectedDate.getDate() + 1);\r\n                    break;\r\n                case CalendarView.WeekView:\r\n                    newDate.setDate(this.selectedDate.getDate() + 3);\r\n                    break;\r\n                case CalendarView.WeekSelectView:\r\n                    newDate.setDate(this.selectedDate.getDate() + 7);\r\n                    break;\r\n                case CalendarView.MonthView:\r\n                    newDate.setMonth(this.selectedDate.getMonth() + 1);\r\n                    break;\r\n            }\r\n            this.selectedDate = newDate;\r\n            this.rangeChange.emit(this.selectedDate);\r\n        }\r\n    }\r\n\r\n    public setUnit(weekDay: Weekday): void {\r\n        this.selectedDate = weekDay.date;\r\n        this.selectedDateChange.emit(this.selectedDate);\r\n    }\r\n\r\n    public changeTheView(view: CalendarView): void {\r\n        this.view = view;\r\n        this.viewChange.emit(view);\r\n        this._prepareHeaderData();\r\n    }\r\n\r\n    private _onResize: EventListener = async (): Promise<void> => {\r\n        this._resizeHost();\r\n    }\r\n\r\n    /**\r\n     * Need to resize the host component to size it's fixed positioned child through css\r\n     */\r\n    private _resizeHost(): void {\r\n        if (this._elementRef) {\r\n            this._renderer.setStyle(\r\n                this._elementRef.nativeElement, \"width\", this._elementRef.nativeElement.parentElement.clientWidth - this.scrollbarWidth + \"px\");\r\n        }\r\n    }\r\n\r\n    private _prepareHeaderData(): void {\r\n        if (this.selectedDate) {\r\n            switch (this.view) {\r\n                case CalendarView.DayView:\r\n                    const day: Day = new Day();\r\n                    day.date = new Date(this.selectedDate);\r\n                    const options: any = { year: \"numeric\", month: \"long\", day: \"numeric\" };\r\n                    day.description = this.selectedDate.toLocaleDateString(this._locale, options);\r\n                    this.day = day;\r\n                    break;\r\n                case CalendarView.DaysAround:\r\n                    const weekAroundView: Week = CalendarUtils.GetDaysAround(this.selectedDate);\r\n                    this.weekDays = weekAroundView.weekDays;\r\n                    if (this.firstAvailableDate) {\r\n                      this.showBackButton = this.weekDays.find(wd => DateUtils.DatesEqual(this.firstAvailableDate, wd.date)) === undefined;\r\n                    }\r\n                    break;\r\n                case CalendarView.WeekView:\r\n                    const weekView: Week = CalendarUtils.GetDaysOfWeek(this.selectedDate);\r\n                    this.weekDays = weekView.weekDays;\r\n                    if (this.firstAvailableDate) {\r\n                        this.showBackButton = this.weekDays.find(wd => DateUtils.DatesEqual(this.firstAvailableDate, wd.date)) === undefined;\r\n                    }\r\n                    break;\r\n                case CalendarView.WeekSelectView:\r\n                    const weekSelectView: Week = CalendarUtils.GetDaysOfWeek(this.selectedDate);\r\n                    this.weekDays = weekSelectView.weekDays;\r\n                    this.weekDays.forEach((wd: Weekday) => {\r\n                        const evPerDay: AgendaEventPerDay = this._eventsPerDay && this._eventsPerDay.length > 0 ? this._eventsPerDay.find(e => DateUtils.DatesEqual(e.date, wd.date)) : null;\r\n                        if (evPerDay) {\r\n                            wd.events = evPerDay.events;\r\n                        } else {\r\n                            wd.weekdaySelected = false;\r\n                        }\r\n                    });\r\n                    if (this.firstAvailableDate) {\r\n                        this.showBackButton = this.weekDays.find(wd => DateUtils.DatesEqual(this.firstAvailableDate, wd.date)) === undefined;\r\n                    }\r\n                    break;\r\n                case CalendarView.MonthView:\r\n                    const weekOfMonth: Week = CalendarUtils.GetDaysOfWeek(this.selectedDate);\r\n                    this.weekDays = weekOfMonth.weekDays;\r\n                    if (this.firstAvailableDate) {\r\n                        this.showBackButton = this.weekDays.find(wd => DateUtils.DatesEqual(this.firstAvailableDate, wd.date)) === undefined;\r\n                    }\r\n                    break;\r\n            }\r\n        }\r\n    }\r\n\r\n    public capitalizeString(label: string): string {\r\n      return label[0].toUpperCase() + label.slice(1);\r\n    }\r\n\r\n    public getWeekNumber(date: Date): number {\r\n        // Copy date so we don’t modify the original\r\n        const target = new Date(Date.UTC(date.getFullYear(), date.getMonth(), date.getDate()));\r\n\r\n        // ISO week starts on Monday (1) and ends on Sunday (7)\r\n        // Set to nearest Thursday: current date + 4 - current day number\r\n        const dayNum = target.getUTCDay() || 7;\r\n        target.setUTCDate(target.getUTCDate() + 4 - dayNum);\r\n\r\n        // Calculate week number\r\n        const yearStart = new Date(Date.UTC(target.getUTCFullYear(), 0, 1));\r\n        const weekNo = Math.ceil((((target.getTime() - yearStart.getTime()) / 86400000) + 1) / 7);\r\n\r\n        return weekNo;\r\n    }\r\n}\r\n"]}
|
|
@@ -22,6 +22,7 @@ import { AgendaEventComponent } from "./component/agenda/agenda-event.component"
|
|
|
22
22
|
import { MASTER_PIPES } from "../../pipe/master-pipes";
|
|
23
23
|
import { ViewSelectComponent } from "./component/agenda/view-select.component";
|
|
24
24
|
import { AgendaSelectEventComponent } from "./component/agenda/agenda-select-event.component";
|
|
25
|
+
import { SharedComponentsTranslationModule } from '../../translation/shared-components-translation.module';
|
|
25
26
|
export class DatePlanningModule {
|
|
26
27
|
}
|
|
27
28
|
DatePlanningModule.decorators = [
|
|
@@ -31,6 +32,7 @@ DatePlanningModule.decorators = [
|
|
|
31
32
|
InputDatePickerModule,
|
|
32
33
|
IconModule,
|
|
33
34
|
ButtonModule,
|
|
35
|
+
SharedComponentsTranslationModule
|
|
34
36
|
],
|
|
35
37
|
declarations: [
|
|
36
38
|
DatePlanningComponent,
|
|
@@ -60,4 +62,4 @@ DatePlanningModule.decorators = [
|
|
|
60
62
|
]
|
|
61
63
|
},] }
|
|
62
64
|
];
|
|
63
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
65
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS1wbGFubmluZy5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zaGFyZWRjb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9kYXRlLXBsYW5uaW5nL2RhdGUtcGxhbm5pbmcubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBQyxxQkFBcUIsRUFBQyxNQUFNLDJCQUEyQixDQUFDO0FBQ2hFLE9BQU8sRUFBQyxZQUFZLEVBQUUsVUFBVSxFQUFFLHFCQUFxQixFQUFDLE1BQU0sOEJBQThCLENBQUM7QUFDN0YsT0FBTyxFQUFDLHlCQUF5QixFQUFDLE1BQU0sbURBQW1ELENBQUM7QUFDNUYsT0FBTyxFQUFDLDBCQUEwQixFQUFDLE1BQU0sb0RBQW9ELENBQUM7QUFDOUYsT0FBTyxFQUFDLHVCQUF1QixFQUFDLE1BQU0sZ0RBQWdELENBQUM7QUFDdkYsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0seUNBQXlDLENBQUM7QUFDMUUsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0sOENBQThDLENBQUM7QUFDbkYsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0sNENBQTRDLENBQUM7QUFDakYsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0sMENBQTBDLENBQUM7QUFDN0UsT0FBTyxFQUFDLHdCQUF3QixFQUFDLE1BQU0sZ0RBQWdELENBQUM7QUFDeEYsT0FBTyxFQUFDLHNCQUFzQixFQUFDLE1BQU0sOENBQThDLENBQUM7QUFDcEYsT0FBTyxFQUFDLHVCQUF1QixFQUFDLE1BQU0sK0NBQStDLENBQUM7QUFDdEYsT0FBTyxFQUFDLDZCQUE2QixFQUFDLE1BQU0sc0RBQXNELENBQUM7QUFDbkcsT0FBTyxFQUFDLHVCQUF1QixFQUFDLE1BQU0sK0NBQStDLENBQUM7QUFDdEYsT0FBTyxFQUFDLHVCQUF1QixFQUFDLE1BQU0sK0NBQStDLENBQUM7QUFDdEYsT0FBTyxFQUFDLDZCQUE2QixFQUFDLE1BQU0sc0RBQXNELENBQUM7QUFDbkcsT0FBTyxFQUFDLDJCQUEyQixFQUFDLE1BQU0sb0RBQW9ELENBQUM7QUFDL0YsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0sNENBQTRDLENBQUM7QUFDakYsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sMkNBQTJDLENBQUM7QUFDL0UsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLHlCQUF5QixDQUFDO0FBQ3JELE9BQU8sRUFBQyxtQkFBbUIsRUFBQyxNQUFNLDBDQUEwQyxDQUFDO0FBQzdFLE9BQU8sRUFBQywwQkFBMEIsRUFBQyxNQUFNLGtEQUFrRCxDQUFDO0FBQzVGLE9BQU8sRUFBQyxpQ0FBaUMsRUFBQyxNQUFNLHdEQUF3RCxDQUFDO0FBcUN6RyxNQUFNLE9BQU8sa0JBQWtCOzs7WUFuQzlCLFFBQVEsU0FBQztnQkFDUixPQUFPLEVBQUU7b0JBQ1AsWUFBWTtvQkFDWixxQkFBcUI7b0JBQ3JCLFVBQVU7b0JBQ1YsWUFBWTtvQkFDWixpQ0FBaUM7aUJBQ2xDO2dCQUNELFlBQVksRUFBRTtvQkFDWixxQkFBcUI7b0JBQ3JCLHlCQUF5QjtvQkFDekIsMEJBQTBCO29CQUMxQix1QkFBdUI7b0JBQ3ZCLGlCQUFpQjtvQkFDakIscUJBQXFCO29CQUNyQixxQkFBcUI7b0JBQ3JCLG1CQUFtQjtvQkFDbkIsd0JBQXdCO29CQUN4QixzQkFBc0I7b0JBQ3RCLHVCQUF1QjtvQkFDdkIsNkJBQTZCO29CQUM3Qix1QkFBdUI7b0JBQ3ZCLHVCQUF1QjtvQkFDdkIsNkJBQTZCO29CQUM3QiwyQkFBMkI7b0JBQzNCLHFCQUFxQjtvQkFDckIsb0JBQW9CO29CQUNwQixtQkFBbUI7b0JBQ25CLDBCQUEwQjtvQkFDMUIsWUFBWTtpQkFDYjtnQkFDRCxPQUFPLEVBQUU7b0JBQ1AscUJBQXFCO2lCQUN0QjthQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtOZ01vZHVsZX0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHtDb21tb25Nb2R1bGV9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcclxuaW1wb3J0IHtEYXRlUGxhbm5pbmdDb21wb25lbnR9IGZyb20gXCIuL2RhdGUtcGxhbm5pbmcuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7QnV0dG9uTW9kdWxlLCBJY29uTW9kdWxlLCBJbnB1dERhdGVQaWNrZXJNb2R1bGV9IGZyb20gXCJAY29saWpuaXQvY29yZWNvbXBvbmVudHNfdjEyXCI7XHJcbmltcG9ydCB7Q2FsZW5kYXJBbGxZZWFyc0NvbXBvbmVudH0gZnJvbSBcIi4vY29tcG9uZW50L2NhbGVuZGFyL2NhbGVuZGFyLWFsbC15ZWFycy5jb21wb25lbnRcIjtcclxuaW1wb3J0IHtDYWxlbmRhckFsbE1vbnRoc0NvbXBvbmVudH0gZnJvbSBcIi4vY29tcG9uZW50L2NhbGVuZGFyL2NhbGVuZGFyLWFsbC1tb250aHMuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7Q2FsZW5kYXJIZWFkZXJDb21wb25lbnR9IGZyb20gXCIuL2NvbXBvbmVudC9jYWxlbmRhci9jYWxlbmRhci1oZWFkZXIuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7Q2FsZW5kYXJDb21wb25lbnR9IGZyb20gXCIuL2NvbXBvbmVudC9jYWxlbmRhci9jYWxlbmRhci5jb21wb25lbnRcIjtcclxuaW1wb3J0IHtDYWxlbmRhclZpZXdDb21wb25lbnR9IGZyb20gXCIuL2NvbXBvbmVudC9jYWxlbmRhci9jYWxlbmRhci12aWV3LmNvbXBvbmVudFwiO1xyXG5pbXBvcnQge0FnZW5kYUhlYWRlckNvbXBvbmVudH0gZnJvbSBcIi4vY29tcG9uZW50L2FnZW5kYS9hZ2VuZGEtaGVhZGVyLmNvbXBvbmVudFwiO1xyXG5pbXBvcnQge0FnZW5kYVZpZXdDb21wb25lbnR9IGZyb20gXCIuL2NvbXBvbmVudC9hZ2VuZGEvYWdlbmRhLXZpZXcuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7QWdlbmRhTW9udGhWaWV3Q29tcG9uZW50fSBmcm9tIFwiLi9jb21wb25lbnQvYWdlbmRhL2FnZW5kYS1tb250aC12aWV3LmNvbXBvbmVudFwiO1xyXG5pbXBvcnQge0FnZW5kYURheVZpZXdDb21wb25lbnR9IGZyb20gXCIuL2NvbXBvbmVudC9hZ2VuZGEvYWdlbmRhLWRheS12aWV3LmNvbXBvbmVudFwiO1xyXG5pbXBvcnQge0FnZW5kYVdlZWtWaWV3Q29tcG9uZW50fSBmcm9tIFwiLi9jb21wb25lbnQvYWdlbmRhL2FnZW5kYS13ZWVrLXZpZXcuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7QWdlbmRhV2Vla1NlbGVjdFZpZXdDb21wb25lbnR9IGZyb20gXCIuL2NvbXBvbmVudC9hZ2VuZGEvYWdlbmRhLXdlZWstc2VsZWN0LXZpZXcuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7QWdlbmRhSG91clZpZXdDb21wb25lbnR9IGZyb20gXCIuL2NvbXBvbmVudC9hZ2VuZGEvYWdlbmRhLWhvdXItdmlldy5jb21wb25lbnRcIjtcclxuaW1wb3J0IHtBZ2VuZGFIb3VyQ2VsbENvbXBvbmVudH0gZnJvbSBcIi4vY29tcG9uZW50L2FnZW5kYS9hZ2VuZGEtaG91ci1jZWxsLmNvbXBvbmVudFwiO1xyXG5pbXBvcnQge0FnZW5kYUhvdXJWaWV3TGFiZWxzQ29tcG9uZW50fSBmcm9tIFwiLi9jb21wb25lbnQvYWdlbmRhL2FnZW5kYS1ob3VyLXZpZXctbGFiZWxzLmNvbXBvbmVudFwiO1xyXG5pbXBvcnQge0FnZW5kYUhhbGZIb3VyQ2VsbENvbXBvbmVudH0gZnJvbSBcIi4vY29tcG9uZW50L2FnZW5kYS9hZ2VuZGEtaGFsZi1ob3VyLWNlbGwuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7QWdlbmRhRXZlbnRzQ29tcG9uZW50fSBmcm9tIFwiLi9jb21wb25lbnQvYWdlbmRhL2FnZW5kYS1ldmVudHMuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7QWdlbmRhRXZlbnRDb21wb25lbnR9IGZyb20gXCIuL2NvbXBvbmVudC9hZ2VuZGEvYWdlbmRhLWV2ZW50LmNvbXBvbmVudFwiO1xyXG5pbXBvcnQge01BU1RFUl9QSVBFU30gZnJvbSBcIi4uLy4uL3BpcGUvbWFzdGVyLXBpcGVzXCI7XHJcbmltcG9ydCB7Vmlld1NlbGVjdENvbXBvbmVudH0gZnJvbSBcIi4vY29tcG9uZW50L2FnZW5kYS92aWV3LXNlbGVjdC5jb21wb25lbnRcIjtcclxuaW1wb3J0IHtBZ2VuZGFTZWxlY3RFdmVudENvbXBvbmVudH0gZnJvbSBcIi4vY29tcG9uZW50L2FnZW5kYS9hZ2VuZGEtc2VsZWN0LWV2ZW50LmNvbXBvbmVudFwiO1xyXG5pbXBvcnQge1NoYXJlZENvbXBvbmVudHNUcmFuc2xhdGlvbk1vZHVsZX0gZnJvbSAnLi4vLi4vdHJhbnNsYXRpb24vc2hhcmVkLWNvbXBvbmVudHMtdHJhbnNsYXRpb24ubW9kdWxlJztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgaW1wb3J0czogW1xyXG4gICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgSW5wdXREYXRlUGlja2VyTW9kdWxlLFxyXG4gICAgSWNvbk1vZHVsZSxcclxuICAgIEJ1dHRvbk1vZHVsZSxcclxuICAgIFNoYXJlZENvbXBvbmVudHNUcmFuc2xhdGlvbk1vZHVsZVxyXG4gIF0sXHJcbiAgZGVjbGFyYXRpb25zOiBbXHJcbiAgICBEYXRlUGxhbm5pbmdDb21wb25lbnQsXHJcbiAgICBDYWxlbmRhckFsbFllYXJzQ29tcG9uZW50LFxyXG4gICAgQ2FsZW5kYXJBbGxNb250aHNDb21wb25lbnQsXHJcbiAgICBDYWxlbmRhckhlYWRlckNvbXBvbmVudCxcclxuICAgIENhbGVuZGFyQ29tcG9uZW50LFxyXG4gICAgQ2FsZW5kYXJWaWV3Q29tcG9uZW50LFxyXG4gICAgQWdlbmRhSGVhZGVyQ29tcG9uZW50LFxyXG4gICAgQWdlbmRhVmlld0NvbXBvbmVudCxcclxuICAgIEFnZW5kYU1vbnRoVmlld0NvbXBvbmVudCxcclxuICAgIEFnZW5kYURheVZpZXdDb21wb25lbnQsXHJcbiAgICBBZ2VuZGFXZWVrVmlld0NvbXBvbmVudCxcclxuICAgIEFnZW5kYVdlZWtTZWxlY3RWaWV3Q29tcG9uZW50LFxyXG4gICAgQWdlbmRhSG91clZpZXdDb21wb25lbnQsXHJcbiAgICBBZ2VuZGFIb3VyQ2VsbENvbXBvbmVudCxcclxuICAgIEFnZW5kYUhvdXJWaWV3TGFiZWxzQ29tcG9uZW50LFxyXG4gICAgQWdlbmRhSGFsZkhvdXJDZWxsQ29tcG9uZW50LFxyXG4gICAgQWdlbmRhRXZlbnRzQ29tcG9uZW50LFxyXG4gICAgQWdlbmRhRXZlbnRDb21wb25lbnQsXHJcbiAgICBWaWV3U2VsZWN0Q29tcG9uZW50LFxyXG4gICAgQWdlbmRhU2VsZWN0RXZlbnRDb21wb25lbnQsXHJcbiAgICBNQVNURVJfUElQRVNcclxuICBdLFxyXG4gIGV4cG9ydHM6IFtcclxuICAgIERhdGVQbGFubmluZ0NvbXBvbmVudFxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIERhdGVQbGFubmluZ01vZHVsZSB7XHJcbn1cclxuIl19
|
|
@@ -140,4 +140,4 @@ __decorate([
|
|
|
140
140
|
__decorate([
|
|
141
141
|
InputBoolean()
|
|
142
142
|
], FilesUploadComponent.prototype, "hideAvatars", void 0);
|
|
143
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"files-upload.component.js","sourceRoot":"","sources":["../../../../../../projects/sharedcomponents/src/lib/components/files-upload/files-upload.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ComponentFactoryResolver,\r\n  ContentChild,\r\n  ElementRef,\r\n  EventEmitter, forwardRef,\r\n  HostBinding,\r\n  Input,\r\n  OnDestroy,\r\n  Output,\r\n  TemplateRef,\r\n  ViewChild,\r\n  ViewContainerRef,\r\n  ViewEncapsulation\r\n} from \"@angular/core\";\r\nimport {BaseFileUploadComponent} from \"./components/base-file-upload.component\";\r\nimport {SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from \"@colijnit/corecomponents_v12\";\r\nimport {CoDocument} from \"@colijnit/mainapi/build/model/co-document.bo\";\r\nimport {TagTreeItem} from \"@colijnit/mainapi/build/model/tag-tree-item.bo\";\r\nimport {InputBoolean} from \"../../decorator/input-boolean.decorator\";\r\nimport {SharedComponentsDictionaryService} from '../../translation/shared-components-dictionary.service';\r\n\r\n@Component({\r\n    selector: \"co-files-upload\",\r\n    template: `\r\n        <div class=\"files-upload-wrapper\">\r\n            <drag-drop-container\r\n                                 [sortableList]=\"documents\"\r\n                                 (sortingChange)=\"handleSortingChange($event)\"\r\n                                 [handleSort]=\"true\"\r\n                                 dragHandle=\"tile\"\r\n                                 [enabled]=\"!noDragDropOrdering\">\r\n              <div class=\"upload-add-wrapper\">\r\n                <co-file-upload *ngIf=\"canAdd && addWithButton\" class=\"add-file\"\r\n                                isAddingTile\r\n                                icon=\"plus_round_open\"\r\n                                [link]=\"true\"\r\n                                [label]=\"label | sharedLocalize\"\r\n                                (mouseover)=\"mouseOverAdd = true\"\r\n                                (mouseout)=\"mouseOverAdd = false\"\r\n                                (click)=\"handleAddClick()\"></co-file-upload> <!-- (click)=\"handleAddClick()\" -->\r\n                <co-file-upload *ngIf=\"!documents || documents.length === 0\" class=\"add-dropzone\"\r\n                                isAddingTile\r\n                                [dropzone]=\"true\"\r\n                                [link]=\"true\"\r\n                                [label]=\"'DROPZONE_TEXT' | sharedLocalize\"\r\n                                (mouseover)=\"mouseOverAdd = true\"\r\n                                (mouseout)=\"mouseOverAdd = false\"\r\n                                (click)=\"handleAddClick()\"></co-file-upload>\r\n              </div>\r\n              <div class=\"uploaded-images-wrapper\">\r\n                <co-file-upload *ngFor=\"let file of documents\" class=\"tile\"\r\n                                [readonly]=\"file.readonly || readonly\"\r\n                                [class.hidden]=\"hideAvatars ? file.isAvatar : false\"\r\n                                [file]=\"file\"\r\n                                [label]=\"file.fileName\"\r\n                                [showTrashCan]=\"canDelete\"\r\n                                [fileSavesOnPopupOkClick]=\"fileSavesOnPopupOkClick\"\r\n                                [isEditable]=\"isEditable\"\r\n                                [customImageClick]=\"customImageClick\"\r\n                                (imageClick)=\"imageClick.emit($event)\"\r\n                                (deleteClick)=\"handleDelete(file)\"\r\n                                (editClick)=\"handleEditDocumentClick($event)\"></co-file-upload>\r\n              </div>\r\n            </drag-drop-container>\r\n            <span class=\"maxuploadsize\" textContent=\"getMaxFileSizeNotition()\" [class.show]=\"mouseOverAdd\"></span>\r\n            <input #inputFile [accept]=\"acceptedUploadFormats\" (change)=\"handleFileChange($event)\" type=\"file\" hidden multiple/>\r\n        </div>\r\n    `,\r\n    encapsulation: ViewEncapsulation.None,\r\n    providers: [\r\n        {\r\n            provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,\r\n            useExisting: forwardRef(() => FilesUploadComponent)\r\n        }\r\n    ]\r\n})\r\n// A component that lets the user make a list of files from its device. Doesn't actually upload, but outputs chosen files as filesChanged.\r\nexport class FilesUploadComponent extends BaseFileUploadComponent implements OnDestroy {\r\n\r\n    @Input()\r\n    public set dropzone(value: boolean) {\r\n        this.isDropzone = value;\r\n    }\r\n\r\n    //todo see if this is used anywhere if not, remove\r\n    @ContentChild(\"slideoutTemplate\", {static: true})\r\n    public slideoutTemplate: TemplateRef<any>;\r\n\r\n    // (Hidden) input for file upload facilities\r\n    @ViewChild(\"inputFile\", {static: true})\r\n    public input: ElementRef;\r\n\r\n    // Input button label\r\n    @Input()\r\n    public label: string = \"UPLOAD_FILE\";\r\n\r\n    @Input()\r\n    public cfgNames: any;\r\n\r\n    @Input()\r\n    public customImageClick: boolean = false;\r\n\r\n    @Input()\r\n    @InputBoolean()\r\n    public isEditable: boolean = false;\r\n\r\n    @Input() @InputBoolean()\r\n    public hideAvatars: boolean = false;\r\n\r\n    @Input()\r\n    public fileSavesOnPopupOkClick: string;\r\n\r\n    @Input()\r\n    public selected: string;\r\n\r\n    @Output()\r\n    public readonly editSlideoutSubmit: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n    @Output()\r\n    public tagsChangeEvent: EventEmitter<TagTreeItem[]> = new EventEmitter<TagTreeItem[]>();\r\n\r\n    @Output()\r\n    public imageClick: EventEmitter<CoDocument> = new EventEmitter<CoDocument>();\r\n\r\n    @HostBinding('class.co-files-upload')\r\n    public showClass() {\r\n      return true;\r\n    }\r\n\r\n    @HostBinding(\"class.editable\")\r\n    public get editable(): boolean {\r\n        return this.canAdd;\r\n    }\r\n\r\n    @HostBinding(\"class.empty\")\r\n    public get empty(): boolean {\r\n        return !this.documents || this.documents.length === 0;\r\n    }\r\n\r\n    public mouseOverAdd: boolean;\r\n    public slideoutShown: boolean = false;\r\n    @HostBinding('class.dropzone')\r\n    public isDropzone: boolean = false;\r\n\r\n    constructor(\r\n        //promptService: PromptService,\r\n        dictionaryService: SharedComponentsDictionaryService,\r\n        //userService: UserService,\r\n        protected _container: ViewContainerRef,\r\n        protected _factory: ComponentFactoryResolver,\r\n        //protected _dataService: DataService,\r\n        //protected _baseDataDalRepository: BaseDataDalRepository,\r\n       // protected _generalDalRepository: GeneralDalRepository,\r\n        //protected _coDocumentDataLoader: CoDocumentDataLoaderService,\r\n        //private _workability: AppWorkabilityService,\r\n        //private _fileTypeImgPipe: FileTypeImagePipe\r\n    ) {\r\n        super(dictionaryService, _container, _factory);\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        this.slideoutTemplate = undefined;\r\n        this.input = undefined;\r\n        super.ngOnDestroy();\r\n    }\r\n\r\n    public async openFileBrowser(): Promise<void> {\r\n        if (this.input && this.input.nativeElement) {\r\n            this.input.nativeElement.click();\r\n        }\r\n    }\r\n\r\n    public handleAddClick(): void {\r\n        this.openFileBrowser();\r\n    }\r\n\r\n    //todo check if this can be removed at the end of the run\r\n    /*public onCustomClose(): void {\r\n        this.documentUnderEdit = undefined;\r\n    }*/\r\n}\r\n"]}
|
|
143
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"files-upload.component.js","sourceRoot":"","sources":["../../../../../../projects/sharedcomponents/src/lib/components/files-upload/files-upload.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ComponentFactoryResolver,\r\n  ContentChild,\r\n  ElementRef,\r\n  EventEmitter, forwardRef,\r\n  HostBinding,\r\n  Input,\r\n  OnDestroy,\r\n  Output,\r\n  TemplateRef,\r\n  ViewChild,\r\n  ViewContainerRef,\r\n  ViewEncapsulation\r\n} from \"@angular/core\";\r\nimport {BaseFileUploadComponent} from \"./components/base-file-upload.component\";\r\nimport {SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from \"@colijnit/corecomponents_v12\";\r\nimport {TagTreeItem} from \"@colijnit/mainapi/build/model/tag-tree-item.bo\";\r\nimport {InputBoolean} from \"../../decorator/input-boolean.decorator\";\r\nimport {SharedComponentsDictionaryService} from '../../translation/shared-components-dictionary.service';\r\nimport {CoDocument} from '@colijnit/mainapi/build/model/co-document.bo';\r\n\r\n@Component({\r\n    selector: \"co-files-upload\",\r\n    template: `\r\n        <div class=\"files-upload-wrapper\">\r\n            <drag-drop-container\r\n                                 [sortableList]=\"documents\"\r\n                                 (sortingChange)=\"handleSortingChange($event)\"\r\n                                 [handleSort]=\"true\"\r\n                                 dragHandle=\"tile\"\r\n                                 [enabled]=\"!noDragDropOrdering\">\r\n              <div class=\"upload-add-wrapper\">\r\n                <co-file-upload *ngIf=\"canAdd && addWithButton\" class=\"add-file\"\r\n                                isAddingTile\r\n                                icon=\"plus_round_open\"\r\n                                [link]=\"true\"\r\n                                [label]=\"label | sharedLocalize\"\r\n                                (mouseover)=\"mouseOverAdd = true\"\r\n                                (mouseout)=\"mouseOverAdd = false\"\r\n                                (click)=\"handleAddClick()\"></co-file-upload> <!-- (click)=\"handleAddClick()\" -->\r\n                <co-file-upload *ngIf=\"!documents || documents.length === 0\" class=\"add-dropzone\"\r\n                                isAddingTile\r\n                                [dropzone]=\"true\"\r\n                                [link]=\"true\"\r\n                                [label]=\"'DROPZONE_TEXT' | sharedLocalize\"\r\n                                (mouseover)=\"mouseOverAdd = true\"\r\n                                (mouseout)=\"mouseOverAdd = false\"\r\n                                (click)=\"handleAddClick()\"></co-file-upload>\r\n              </div>\r\n              <div class=\"uploaded-images-wrapper\">\r\n                <co-file-upload *ngFor=\"let file of documents\" class=\"tile\"\r\n                                [readonly]=\"file.readonly || readonly\"\r\n                                [class.hidden]=\"hideAvatars ? file.isAvatar : false\"\r\n                                [file]=\"file\"\r\n                                [label]=\"file.fileName\"\r\n                                [showTrashCan]=\"canDelete\"\r\n                                [fileSavesOnPopupOkClick]=\"fileSavesOnPopupOkClick\"\r\n                                [isEditable]=\"isEditable\"\r\n                                [customImageClick]=\"customImageClick\"\r\n                                (imageClick)=\"imageClick.emit($event)\"\r\n                                (deleteClick)=\"handleDelete(file)\"\r\n                                (editClick)=\"handleEditDocumentClick($event)\"></co-file-upload>\r\n              </div>\r\n            </drag-drop-container>\r\n            <span class=\"maxuploadsize\" textContent=\"getMaxFileSizeNotition()\" [class.show]=\"mouseOverAdd\"></span>\r\n            <input #inputFile [accept]=\"acceptedUploadFormats\" (change)=\"handleFileChange($event)\" type=\"file\" hidden multiple/>\r\n        </div>\r\n    `,\r\n    encapsulation: ViewEncapsulation.None,\r\n    providers: [\r\n        {\r\n            provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,\r\n            useExisting: forwardRef(() => FilesUploadComponent)\r\n        }\r\n    ]\r\n})\r\n// A component that lets the user make a list of files from its device. Doesn't actually upload, but outputs chosen files as filesChanged.\r\nexport class FilesUploadComponent extends BaseFileUploadComponent implements OnDestroy {\r\n\r\n    @Input()\r\n    public set dropzone(value: boolean) {\r\n        this.isDropzone = value;\r\n    }\r\n\r\n    //todo see if this is used anywhere if not, remove\r\n    @ContentChild(\"slideoutTemplate\", {static: true})\r\n    public slideoutTemplate: TemplateRef<any>;\r\n\r\n    // (Hidden) input for file upload facilities\r\n    @ViewChild(\"inputFile\", {static: true})\r\n    public input: ElementRef;\r\n\r\n    // Input button label\r\n    @Input()\r\n    public label: string = \"UPLOAD_FILE\";\r\n\r\n    @Input()\r\n    public cfgNames: any;\r\n\r\n    @Input()\r\n    public customImageClick: boolean = false;\r\n\r\n    @Input()\r\n    @InputBoolean()\r\n    public isEditable: boolean = false;\r\n\r\n    @Input() @InputBoolean()\r\n    public hideAvatars: boolean = false;\r\n\r\n    @Input()\r\n    public fileSavesOnPopupOkClick: string;\r\n\r\n    @Input()\r\n    public selected: string;\r\n\r\n    @Output()\r\n    public readonly editSlideoutSubmit: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n    @Output()\r\n    public tagsChangeEvent: EventEmitter<TagTreeItem[]> = new EventEmitter<TagTreeItem[]>();\r\n\r\n    @Output()\r\n    public imageClick: EventEmitter<CoDocument> = new EventEmitter<CoDocument>();\r\n\r\n    @HostBinding('class.co-files-upload')\r\n    public showClass() {\r\n      return true;\r\n    }\r\n\r\n    @HostBinding(\"class.editable\")\r\n    public get editable(): boolean {\r\n        return this.canAdd;\r\n    }\r\n\r\n    @HostBinding(\"class.empty\")\r\n    public get empty(): boolean {\r\n        return !this.documents || this.documents.length === 0;\r\n    }\r\n\r\n    public mouseOverAdd: boolean;\r\n    public slideoutShown: boolean = false;\r\n    @HostBinding('class.dropzone')\r\n    public isDropzone: boolean = false;\r\n\r\n    constructor(\r\n        //promptService: PromptService,\r\n        dictionaryService: SharedComponentsDictionaryService,\r\n        //userService: UserService,\r\n        protected _container: ViewContainerRef,\r\n        protected _factory: ComponentFactoryResolver,\r\n        //protected _dataService: DataService,\r\n        //protected _baseDataDalRepository: BaseDataDalRepository,\r\n       // protected _generalDalRepository: GeneralDalRepository,\r\n        //protected _coDocumentDataLoader: CoDocumentDataLoaderService,\r\n        //private _workability: AppWorkabilityService,\r\n        //private _fileTypeImgPipe: FileTypeImagePipe\r\n    ) {\r\n        super(dictionaryService, _container, _factory);\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        this.slideoutTemplate = undefined;\r\n        this.input = undefined;\r\n        super.ngOnDestroy();\r\n    }\r\n\r\n    public async openFileBrowser(): Promise<void> {\r\n        if (this.input && this.input.nativeElement) {\r\n            this.input.nativeElement.click();\r\n        }\r\n    }\r\n\r\n    public handleAddClick(): void {\r\n        this.openFileBrowser();\r\n    }\r\n\r\n    //todo check if this can be removed at the end of the run\r\n    /*public onCustomClose(): void {\r\n        this.documentUnderEdit = undefined;\r\n    }*/\r\n}\r\n"]}
|
|
@@ -36,8 +36,8 @@ export class LayoutSelectionComponent {
|
|
|
36
36
|
else {
|
|
37
37
|
this.currentLayout = this.layouts[0];
|
|
38
38
|
}
|
|
39
|
+
this.loadDefaultPrinterName.emit(this.currentLayout.reportId);
|
|
39
40
|
}
|
|
40
|
-
this.loadDefaultPrinterName.emit(this.currentLayout.reportId);
|
|
41
41
|
}
|
|
42
42
|
handleSelectLayout(reportLayout) {
|
|
43
43
|
this.currentLayout = reportLayout;
|
|
@@ -109,4 +109,4 @@ LayoutSelectionComponent.propDecorators = {
|
|
|
109
109
|
loadDefaultPrinterName: [{ type: Output }],
|
|
110
110
|
showClass: [{ type: HostBinding, args: ['class.co-layout-selection',] }]
|
|
111
111
|
};
|
|
112
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
112
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"layout-selection.component.js","sourceRoot":"","sources":["../../../../../../../../projects/sharedcomponents/src/lib/components/send-method-dialog/components/layout-selection/layout-selection.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, HostBinding, Input, OnInit, Output, ViewEncapsulation} from '@angular/core';\r\nimport {animate, state, style, transition, trigger} from '@angular/animations';\r\nimport {ReportLayoutSelectionBase} from '@colijnit/mainapi/build/model/report-layout-selection-base.bo';\r\nimport {ReportingDocumentBaseRequest} from '@colijnit/mainapi/build/model/reporting-document-base-request';\r\nimport {Icon} from '../../../../enum/icon.enum';\r\nimport {IconCacheService} from '../../../../service/icon-cache.service';\r\n\r\n@Component({\r\n  selector: 'co-layout-selection',\r\n  template: `\r\n    <!--\r\n    <div class=\"layout-selection-wrapper\" (click)=\"showLayoutList = !showLayoutList\">\r\n      <div class=\"title\" [textContent]=\"'Lay-out'\"></div>\r\n      <div class=\"layout-description\" [textContent]=\"currentLayout?.description || 'Layout kiezen'\"></div>\r\n    </div>\r\n    <div class=\"layouts-wrapper co-small-scrollbar\" *ngIf=\"showLayoutList\" @showHideLayouts>\r\n      <div class=\"layouts-wrapper-header\">\r\n        <div class=\"title\" [textContent]=\"'Lay-out'\"></div>\r\n        <div class=\"close-layouts\">\r\n          <div class=\"dialog-close-button\" (click)=\"closeSelectLayout()\">\r\n            <co-icon [iconData]=\"iconCacheService.getIcon(icons.XSolid)\"></co-icon>\r\n          </div>\r\n        </div>\r\n      </div>\r\n\r\n      <div class=\"layout-selection-wrapper\" *ngFor=\"let reportLayout of layouts\"\r\n           [class.selected]=\"reportLayout.reportId === currentLayout?.reportId\"\r\n           (click)=\"handleSelectLayout(reportLayout)\">\r\n        <div class=\"layout-description\" [textContent]=\"reportLayout.description\"></div>\r\n      </div>\r\n    </div>\r\n    -->\r\n    <co-list-of-values\r\n      [displayField]=\"'description'\"\r\n      [(model)]=\"currentLayout\"\r\n      [label]=\"label | sharedLocalize\"\r\n      [collection]=\"layouts\"\r\n      (modelChange)=\"handleSelectLayout($event)\"\r\n      [disabled]=\"useDefault\"\r\n      [readonly]=\"useDefault\"\r\n      [required]=\"!useDefault\">\r\n    </co-list-of-values>\r\n  `,\r\n  animations: [\r\n    trigger(\"showHideLayouts\", [\r\n      state(\"void\", style({height: 0})),\r\n      state(\"*\", style({height: \"100%\"})),\r\n      transition(\"void => *\", animate(\"200ms ease-in-out\")),\r\n      transition(\"* => void\", animate(\"200ms ease-out\"))\r\n    ])\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class LayoutSelectionComponent implements OnInit {\r\n  public readonly icons: typeof Icon = Icon;\r\n  @Input()\r\n  public set request(value: ReportingDocumentBaseRequest) {\r\n    this._request = value;\r\n    if (!this._request.reportId && this.currentLayout) {\r\n      this._request.reportId = this.currentLayout.reportId;\r\n      this.requestChange.emit(this._request);\r\n    }\r\n  }\r\n\r\n  @Input()\r\n  public useDefault: boolean = true;\r\n\r\n  @Input()\r\n  public label: string = 'LAYOUT';\r\n\r\n  @Input()\r\n  public layouts: ReportLayoutSelectionBase[] = [];\r\n\r\n  @Output()\r\n  public requestChange: EventEmitter<ReportingDocumentBaseRequest> = new EventEmitter<ReportingDocumentBaseRequest>();\r\n\r\n  @Output()\r\n  public loadDefaultPrinterName: EventEmitter<number> = new EventEmitter<number>();\r\n\r\n\r\n\r\n  @HostBinding('class.co-layout-selection')\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  public currentLayout: ReportLayoutSelectionBase;\r\n  public showLayoutList: boolean = false;\r\n  private _request: ReportingDocumentBaseRequest;\r\n  constructor(\r\n    public iconCacheService: IconCacheService\r\n  ) {\r\n  }\r\n  ngOnInit(): void {\r\n    if (this.layouts && this.layouts.length > 0) {\r\n      if (this._request) {\r\n        this.currentLayout = this.layouts.find(l => l.reportId === this._request.reportId);\r\n        if (!this.currentLayout) {\r\n          this.currentLayout = this.layouts[0];\r\n          this._request.reportId =  this.currentLayout.reportId;\r\n          this.requestChange.emit(this._request);\r\n        }\r\n      } else {\r\n        this.currentLayout = this.layouts[0];\r\n      }\r\n      this.loadDefaultPrinterName.emit(this.currentLayout.reportId)\r\n    }\r\n  }\r\n\r\n  public handleSelectLayout(reportLayout: ReportLayoutSelectionBase): void {\r\n    this.currentLayout = reportLayout;\r\n    this._request.reportId = this.currentLayout.reportId;\r\n    this.requestChange.emit(this._request);\r\n    // this.showLayoutList = false;\r\n  }\r\n  public closeSelectLayout(): void {\r\n    this.showLayoutList = false;\r\n  }\r\n}\r\n"]}
|
package/esm2015/lib/components/send-method-dialog/components/pdf-preview/pdf-preview.component.js
CHANGED
|
@@ -36,15 +36,15 @@ export class PdfPreviewComponent {
|
|
|
36
36
|
PdfPreviewComponent.decorators = [
|
|
37
37
|
{ type: Component, args: [{
|
|
38
38
|
selector: "co-pdf-preview",
|
|
39
|
-
template: `
|
|
40
|
-
<div class="pdf-preview-button" [class.disabled]="disablePdfPreview" (click)="dialogRequested()">
|
|
41
|
-
<co-icon [iconData]="iconCacheService.getIcon(icons.FileMagnifyingGlass)"></co-icon>
|
|
42
|
-
</div>
|
|
43
|
-
<co-preview-pdf-dialog
|
|
44
|
-
*ngIf="showDialog"
|
|
45
|
-
[pdfDoc]="pdfDoc"
|
|
46
|
-
(closePDFDialog)="showDialog = false">
|
|
47
|
-
</co-preview-pdf-dialog>
|
|
39
|
+
template: `
|
|
40
|
+
<div class="pdf-preview-button" [class.disabled]="disablePdfPreview" (click)="dialogRequested()">
|
|
41
|
+
<co-icon [iconData]="iconCacheService.getIcon(icons.FileMagnifyingGlass)"></co-icon>
|
|
42
|
+
</div>
|
|
43
|
+
<co-preview-pdf-dialog
|
|
44
|
+
*ngIf="showDialog"
|
|
45
|
+
[pdfDoc]="pdfDoc"
|
|
46
|
+
(closePDFDialog)="showDialog = false">
|
|
47
|
+
</co-preview-pdf-dialog>
|
|
48
48
|
`,
|
|
49
49
|
encapsulation: ViewEncapsulation.None
|
|
50
50
|
},] }
|
|
@@ -58,4 +58,4 @@ PdfPreviewComponent.propDecorators = {
|
|
|
58
58
|
disablePdfPreview: [{ type: Input }],
|
|
59
59
|
showFilePreview: [{ type: Output }]
|
|
60
60
|
};
|
|
61
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
61
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGRmLXByZXZpZXcuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc2hhcmVkY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvc2VuZC1tZXRob2QtZGlhbG9nL2NvbXBvbmVudHMvcGRmLXByZXZpZXcvcGRmLXByZXZpZXcuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUUsWUFBWSxFQUFFLFdBQVcsRUFBRSxLQUFLLEVBQVUsTUFBTSxFQUFFLGlCQUFpQixFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQzdHLE9BQU8sRUFBQyxJQUFJLEVBQUMsTUFBTSw0QkFBNEIsQ0FBQztBQUNoRCxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSx3Q0FBd0MsQ0FBQztBQWdCeEUsTUFBTSxPQUFPLG1CQUFtQjtJQWlDOUIsWUFBbUIsZ0JBQWtDO1FBQWxDLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBa0I7UUExQjdDLHlCQUFvQixHQUFZLEtBQUssQ0FBQztRQWtCdkMsc0JBQWlCLEdBQVksS0FBSyxDQUFDO1FBR25DLG9CQUFlLEdBQXlCLElBQUksWUFBWSxFQUFVLENBQUM7UUFFMUQsVUFBSyxHQUFnQixJQUFJLENBQUM7UUFDbkMsZUFBVSxHQUFZLEtBQUssQ0FBQztJQUVzQixDQUFDO0lBL0JuRCxTQUFTO1FBQ2QsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBS0QsSUFDSSxNQUFNLENBQUMsS0FBVTtRQUNuQixJQUFJLEtBQUssS0FBSyxJQUFJLENBQUMsT0FBTyxFQUFFO1lBQzFCLElBQUksQ0FBQyxPQUFPLEdBQUcsS0FBSyxDQUFDO1lBQ3JCLElBQUksSUFBSSxDQUFDLG9CQUFvQixFQUFFO2dCQUM3QixJQUFJLENBQUMsb0JBQW9CLEdBQUcsS0FBSyxDQUFBO2dCQUNqQyxJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQzthQUN4QjtTQUNGO0lBQ0gsQ0FBQztJQUVELElBQUksTUFBTTtRQUNSLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQztJQUN0QixDQUFDO0lBYUQsUUFBUTtRQUNOLCtCQUErQjtJQUNqQyxDQUFDO0lBRU0sZUFBZTtRQUNwQixJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUM3QixJQUFJLENBQUMsb0JBQW9CLEdBQUcsSUFBSSxDQUFDO0lBQ25DLENBQUM7OztZQXhERixTQUFTLFNBQUM7Z0JBQ1QsUUFBUSxFQUFFLGdCQUFnQjtnQkFDMUIsUUFBUSxFQUFFOzs7Ozs7Ozs7R0FTVDtnQkFDRCxhQUFhLEVBQUUsaUJBQWlCLENBQUMsSUFBSTthQUN0Qzs7O1lBZk8sZ0JBQWdCOzs7d0JBaUJyQixXQUFXLFNBQUMsc0JBQXNCO3FCQVFsQyxLQUFLO2dDQWVMLEtBQUs7OEJBR0wsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIEhvc3RCaW5kaW5nLCBJbnB1dCwgT25Jbml0LCBPdXRwdXQsIFZpZXdFbmNhcHN1bGF0aW9ufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7SWNvbn0gZnJvbSBcIi4uLy4uLy4uLy4uL2VudW0vaWNvbi5lbnVtXCI7XG5pbXBvcnQge0ljb25DYWNoZVNlcnZpY2V9IGZyb20gXCIuLi8uLi8uLi8uLi9zZXJ2aWNlL2ljb24tY2FjaGUuc2VydmljZVwiO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6IFwiY28tcGRmLXByZXZpZXdcIixcbiAgdGVtcGxhdGU6IGBcbiAgICAgIDxkaXYgY2xhc3M9XCJwZGYtcHJldmlldy1idXR0b25cIiBbY2xhc3MuZGlzYWJsZWRdPVwiZGlzYWJsZVBkZlByZXZpZXdcIiAoY2xpY2spPVwiZGlhbG9nUmVxdWVzdGVkKClcIj5cbiAgICAgICAgICA8Y28taWNvbiBbaWNvbkRhdGFdPVwiaWNvbkNhY2hlU2VydmljZS5nZXRJY29uKGljb25zLkZpbGVNYWduaWZ5aW5nR2xhc3MpXCI+PC9jby1pY29uPlxuICAgICAgPC9kaXY+XG4gICAgICA8Y28tcHJldmlldy1wZGYtZGlhbG9nXG4gICAgICAgICAgICAgICpuZ0lmPVwic2hvd0RpYWxvZ1wiXG4gICAgICAgICAgICAgIFtwZGZEb2NdPVwicGRmRG9jXCJcbiAgICAgICAgICAgICAgKGNsb3NlUERGRGlhbG9nKT1cInNob3dEaWFsb2cgPSBmYWxzZVwiPlxuICAgICAgPC9jby1wcmV2aWV3LXBkZi1kaWFsb2c+XG4gIGAsXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmVcbn0pXG5leHBvcnQgY2xhc3MgUGRmUHJldmlld0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIEBIb3N0QmluZGluZyhcImNsYXNzLmNvLXBkZi1wcmV2aWV3XCIpXG4gIHB1YmxpYyBzaG93Q2xhc3MoKSB7XG4gICAgcmV0dXJuIHRydWU7XG4gIH1cblxuICBwcml2YXRlIF9wZGZEb2M6IGFueTtcbiAgcHJpdmF0ZSBfd2FpdGluZ1RvU2hvd0RpYWxvZzogYm9vbGVhbiA9IGZhbHNlO1xuXG4gIEBJbnB1dCgpXG4gIHNldCBwZGZEb2ModmFsdWU6IGFueSkge1xuICAgIGlmICh2YWx1ZSAhPT0gdGhpcy5fcGRmRG9jKSB7XG4gICAgICB0aGlzLl9wZGZEb2MgPSB2YWx1ZTtcbiAgICAgIGlmICh0aGlzLl93YWl0aW5nVG9TaG93RGlhbG9nKSB7XG4gICAgICAgIHRoaXMuX3dhaXRpbmdUb1Nob3dEaWFsb2cgPSBmYWxzZVxuICAgICAgICB0aGlzLnNob3dEaWFsb2cgPSB0cnVlO1xuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIGdldCBwZGZEb2MoKTogYW55IHtcbiAgICByZXR1cm4gdGhpcy5fcGRmRG9jO1xuICB9XG5cbiAgQElucHV0KClcbiAgcHVibGljIGRpc2FibGVQZGZQcmV2aWV3OiBib29sZWFuID0gZmFsc2U7XG5cbiAgQE91dHB1dCgpXG4gIHB1YmxpYyBzaG93RmlsZVByZXZpZXc6IEV2ZW50RW1pdHRlcjxudW1iZXI+ID0gbmV3IEV2ZW50RW1pdHRlcjxudW1iZXI+KCk7XG5cbiAgcHVibGljIHJlYWRvbmx5IGljb25zOiB0eXBlb2YgSWNvbiA9IEljb247XG4gIHB1YmxpYyBzaG93RGlhbG9nOiBib29sZWFuID0gZmFsc2U7XG5cbiAgY29uc3RydWN0b3IocHVibGljIGljb25DYWNoZVNlcnZpY2U6IEljb25DYWNoZVNlcnZpY2UpIHsgfVxuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIC8vdGhpcy5zaG93RmlsZVByZXZpZXcuZW1pdCgwKTtcbiAgfVxuXG4gIHB1YmxpYyBkaWFsb2dSZXF1ZXN0ZWQoKSB7XG4gICAgdGhpcy5zaG93RmlsZVByZXZpZXcuZW1pdCgwKTtcbiAgICB0aGlzLl93YWl0aW5nVG9TaG93RGlhbG9nID0gdHJ1ZTtcbiAgfVxufVxuIl19
|