barsa-calendar 0.0.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.
- package/README.md +25 -0
- package/esm2020/barsa-calendar.mjs +5 -0
- package/esm2020/lib/barsa-calendar.module.mjs +106 -0
- package/esm2020/lib/calendar-container/calendar-container.component.mjs +190 -0
- package/esm2020/lib/calendar-header/calendar-header.component.mjs +61 -0
- package/esm2020/lib/calendar-list/calendar-list.component.mjs +19 -0
- package/esm2020/lib/calendar-list-container/calendar-list-container.component.mjs +30 -0
- package/esm2020/lib/calendar-list-item/calendar-list-item.component.mjs +14 -0
- package/esm2020/lib/calendar-month/calendar-month.component.mjs +244 -0
- package/esm2020/lib/calendar-selection-days/calendar-selection-days.component.mjs +193 -0
- package/esm2020/lib/calendar-week/calendar-week.component.mjs +182 -0
- package/esm2020/lib/constants.mjs +4 -0
- package/esm2020/lib/date-time-picker/date-time-picker.component.mjs +324 -0
- package/esm2020/lib/day-event-list/day-event-list.component.mjs +53 -0
- package/esm2020/lib/day-number-box/day-number-box.component.mjs +105 -0
- package/esm2020/lib/days-in-week.pipe.mjs +17 -0
- package/esm2020/lib/equal-date.pipe.mjs +23 -0
- package/esm2020/lib/event-button/event-button.component.mjs +70 -0
- package/esm2020/lib/event-date.pipe.mjs +24 -0
- package/esm2020/lib/event-preview/event-preview.component.mjs +60 -0
- package/esm2020/lib/event-time.pipe.mjs +22 -0
- package/esm2020/lib/from-to-time.pipe.mjs +23 -0
- package/esm2020/lib/models.mjs +14 -0
- package/esm2020/lib/month-days/month-days.component.mjs +220 -0
- package/esm2020/lib/services/calendar.service.mjs +610 -0
- package/esm2020/public-api.mjs +21 -0
- package/fesm2015/barsa-calendar.mjs +2447 -0
- package/fesm2015/barsa-calendar.mjs.map +1 -0
- package/fesm2020/barsa-calendar.mjs +2455 -0
- package/fesm2020/barsa-calendar.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/barsa-calendar.module.d.ts +33 -0
- package/lib/calendar-container/calendar-container.component.d.ts +73 -0
- package/lib/calendar-header/calendar-header.component.d.ts +29 -0
- package/lib/calendar-list/calendar-list.component.d.ts +8 -0
- package/lib/calendar-list-container/calendar-list-container.component.d.ts +14 -0
- package/lib/calendar-list-item/calendar-list-item.component.d.ts +7 -0
- package/lib/calendar-month/calendar-month.component.d.ts +70 -0
- package/lib/calendar-selection-days/calendar-selection-days.component.d.ts +47 -0
- package/lib/calendar-week/calendar-week.component.d.ts +57 -0
- package/lib/constants.d.ts +1 -0
- package/lib/date-time-picker/date-time-picker.component.d.ts +98 -0
- package/lib/day-event-list/day-event-list.component.d.ts +20 -0
- package/lib/day-number-box/day-number-box.component.d.ts +30 -0
- package/lib/days-in-week.pipe.d.ts +9 -0
- package/lib/equal-date.pipe.d.ts +8 -0
- package/lib/event-button/event-button.component.d.ts +26 -0
- package/lib/event-date.pipe.d.ts +9 -0
- package/lib/event-preview/event-preview.component.d.ts +19 -0
- package/lib/event-time.pipe.d.ts +9 -0
- package/lib/from-to-time.pipe.d.ts +9 -0
- package/lib/models.d.ts +107 -0
- package/lib/month-days/month-days.component.d.ts +69 -0
- package/lib/services/calendar.service.d.ts +70 -0
- package/package.json +31 -0
- package/public-api.d.ts +17 -0
|
@@ -0,0 +1,244 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import moment from 'moment';
|
|
3
|
+
import { BaseComponent } from 'barsa-novin-ray-core';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "../days-in-week.pipe";
|
|
6
|
+
import * as i2 from "../services/calendar.service";
|
|
7
|
+
import * as i3 from "@angular/common";
|
|
8
|
+
import * as i4 from "@fundamental-ngx/core/button";
|
|
9
|
+
import * as i5 from "@fundamental-ngx/core/popover";
|
|
10
|
+
import * as i6 from "@fundamental-ngx/core/table";
|
|
11
|
+
import * as i7 from "../day-number-box/day-number-box.component";
|
|
12
|
+
import * as i8 from "../event-button/event-button.component";
|
|
13
|
+
import * as i9 from "../day-event-list/day-event-list.component";
|
|
14
|
+
import * as i10 from "barsa-novin-ray-core";
|
|
15
|
+
import * as i11 from "../equal-date.pipe";
|
|
16
|
+
export class CalendarMonthComponent extends BaseComponent {
|
|
17
|
+
constructor(daysInWeek, _cdr, _calendarService) {
|
|
18
|
+
super();
|
|
19
|
+
this.daysInWeek = daysInWeek;
|
|
20
|
+
this._cdr = _cdr;
|
|
21
|
+
this._calendarService = _calendarService;
|
|
22
|
+
this.datePicker = false;
|
|
23
|
+
this.rangePicker = false;
|
|
24
|
+
this.canDelete = false;
|
|
25
|
+
this.canAdd = false;
|
|
26
|
+
this.canEdit = false;
|
|
27
|
+
this.editEvent = new EventEmitter();
|
|
28
|
+
this.deleteEvent = new EventEmitter();
|
|
29
|
+
this.daySelect = new EventEmitter();
|
|
30
|
+
this.dayClick = new EventEmitter();
|
|
31
|
+
this.dayMouseMove = new EventEmitter();
|
|
32
|
+
this.dayMouseUp = new EventEmitter();
|
|
33
|
+
this.dayMouseDown = new EventEmitter();
|
|
34
|
+
this.showEvent = new EventEmitter();
|
|
35
|
+
this.taskHeight = 30;
|
|
36
|
+
this._hasPopoverOpened = [];
|
|
37
|
+
}
|
|
38
|
+
ngOnChanges(changes) {
|
|
39
|
+
super.ngOnChanges(changes);
|
|
40
|
+
let needToDetectChange = false;
|
|
41
|
+
const { containerHeight, deviceSize, moDataList, days, monthWeeksCount, startSelectedDayIndex, endSelectedDayIndex } = changes;
|
|
42
|
+
if (containerHeight && !containerHeight.firstChange) {
|
|
43
|
+
this.fitToContainer(changes.containerHeight.currentValue);
|
|
44
|
+
}
|
|
45
|
+
if (deviceSize && !deviceSize.firstChange) {
|
|
46
|
+
this.prepareWeekDays(changes.deviceSize.currentValue);
|
|
47
|
+
}
|
|
48
|
+
if (moDataList && !moDataList.firstChange) {
|
|
49
|
+
this._prepareDaysTasks(changes.moDataList.currentValue);
|
|
50
|
+
needToDetectChange = true;
|
|
51
|
+
}
|
|
52
|
+
if (days && !days.firstChange) {
|
|
53
|
+
this.fitToContainer(this.containerHeight);
|
|
54
|
+
this._prepareDaysTasks(this.moDataList);
|
|
55
|
+
needToDetectChange = true;
|
|
56
|
+
}
|
|
57
|
+
if (monthWeeksCount && !monthWeeksCount.firstChange) {
|
|
58
|
+
this.fitToContainer(this.containerHeight);
|
|
59
|
+
this._prepareDaysTasks(this.moDataList);
|
|
60
|
+
needToDetectChange = true;
|
|
61
|
+
}
|
|
62
|
+
if ((startSelectedDayIndex && !startSelectedDayIndex.firstChange) ||
|
|
63
|
+
(endSelectedDayIndex && !endSelectedDayIndex.firstChange)) {
|
|
64
|
+
needToDetectChange = true;
|
|
65
|
+
}
|
|
66
|
+
if (needToDetectChange) {
|
|
67
|
+
this._cdr.detectChanges();
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
ngOnInit() {
|
|
71
|
+
super.ngOnInit();
|
|
72
|
+
this.isPickerMode = this.datePicker || this.rangePicker;
|
|
73
|
+
this.prepareWeekDays(this.deviceSize);
|
|
74
|
+
this._prepareDaysTasks(this.moDataList);
|
|
75
|
+
this.fitToContainer(this.containerHeight);
|
|
76
|
+
}
|
|
77
|
+
onDayBoxSelect(day) {
|
|
78
|
+
this._fireDaySelect(day);
|
|
79
|
+
}
|
|
80
|
+
onDaySelect(weekIndex, dayIndex) {
|
|
81
|
+
if (!this.canAdd) {
|
|
82
|
+
return;
|
|
83
|
+
}
|
|
84
|
+
const day = this.days[weekIndex * 7 + dayIndex];
|
|
85
|
+
this._fireDaySelect(day);
|
|
86
|
+
}
|
|
87
|
+
onOpenPopoverChange(isOpen) {
|
|
88
|
+
this._openPopover(isOpen);
|
|
89
|
+
}
|
|
90
|
+
onMoreButton(e, popover) {
|
|
91
|
+
this._preventEvent(e);
|
|
92
|
+
popover.open();
|
|
93
|
+
}
|
|
94
|
+
onTask(e, task) {
|
|
95
|
+
this.showEvent.emit(task);
|
|
96
|
+
}
|
|
97
|
+
onDayClick(day) {
|
|
98
|
+
this.selected = day;
|
|
99
|
+
this.dayClick.emit(day);
|
|
100
|
+
}
|
|
101
|
+
onDayMouseMove(day) {
|
|
102
|
+
this.dayMouseMove.emit(day);
|
|
103
|
+
}
|
|
104
|
+
onDayMouseDown(day) {
|
|
105
|
+
this.dayMouseDown.emit(day);
|
|
106
|
+
}
|
|
107
|
+
onDayMouseUp(day) {
|
|
108
|
+
this.dayMouseUp.emit(day);
|
|
109
|
+
}
|
|
110
|
+
_preventEvent(e) {
|
|
111
|
+
e.stopPropagation();
|
|
112
|
+
e.preventDefault();
|
|
113
|
+
}
|
|
114
|
+
_fireDaySelect(day) {
|
|
115
|
+
if (this._hasPopoverOpened.length === 0) {
|
|
116
|
+
this.daySelect.emit(moment(day.date));
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
_openPopover(isOpen) {
|
|
120
|
+
if (isOpen) {
|
|
121
|
+
this._hasPopoverOpened.push(true);
|
|
122
|
+
}
|
|
123
|
+
else {
|
|
124
|
+
setTimeout(() => {
|
|
125
|
+
this._hasPopoverOpened = [];
|
|
126
|
+
}, 0);
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
prepareWeekDays(deviceSize) {
|
|
130
|
+
if (deviceSize !== 's' && deviceSize !== 'm') {
|
|
131
|
+
this.selectedWeekDays = this.weekDays;
|
|
132
|
+
}
|
|
133
|
+
else {
|
|
134
|
+
this.selectedWeekDays = this.weekDaysMin;
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
fitToContainer(containerHeight) {
|
|
138
|
+
let _weeksCount;
|
|
139
|
+
if (this.monthWeeksCount > 0) {
|
|
140
|
+
const weeksCount = this.monthWeeksCount;
|
|
141
|
+
_weeksCount = weeksCount;
|
|
142
|
+
}
|
|
143
|
+
else {
|
|
144
|
+
_weeksCount = this.days.length / 7;
|
|
145
|
+
}
|
|
146
|
+
this.numberOfWeek = Array.from(Array(_weeksCount).keys());
|
|
147
|
+
this.numberOfWeek = this.numberOfWeek.map((value) => value);
|
|
148
|
+
if (this.isPickerMode) {
|
|
149
|
+
this.dayHeight = 40;
|
|
150
|
+
return;
|
|
151
|
+
}
|
|
152
|
+
this.dayHeight = Math.floor(containerHeight / (_weeksCount + 1));
|
|
153
|
+
this.maxTaskCount = Math.floor((this.dayHeight - this.taskHeight) / this.taskHeight);
|
|
154
|
+
if (this.maxTaskCount > 0) {
|
|
155
|
+
this.maxRowTasks = new Array(this.maxTaskCount).fill(0).map((x, i) => i);
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
_prepareDaysTasks(calendarTasks) {
|
|
159
|
+
if (this.isPickerMode) {
|
|
160
|
+
this.weekTasksArray = {};
|
|
161
|
+
return;
|
|
162
|
+
}
|
|
163
|
+
const calendarFields = this.calendarFields;
|
|
164
|
+
// Sort all Tasks
|
|
165
|
+
const moDataList = this._calendarService.sortTasks(calendarTasks, calendarFields);
|
|
166
|
+
this.days.forEach((day) => (day.tasks = []));
|
|
167
|
+
const weekTasksArray = [];
|
|
168
|
+
for (let j = 0; j < this.days.length / 7; j++) {
|
|
169
|
+
const days = this.daysInWeek.transform(this.days, j);
|
|
170
|
+
const week = this._calendarService.createWeekTask(days, moDataList, calendarFields, 0);
|
|
171
|
+
weekTasksArray.push(week);
|
|
172
|
+
}
|
|
173
|
+
weekTasksArray.forEach((week) => {
|
|
174
|
+
const arr = Object.values(week);
|
|
175
|
+
for (let i = arr.length; i < this.maxTaskCount; i++) {
|
|
176
|
+
week[i.toString()] = [];
|
|
177
|
+
}
|
|
178
|
+
});
|
|
179
|
+
// به ازای هر ردیف تسک باید تعداد 7 ستون اضافه گردد و برای ستونی که تسکی ندارد یک جای خالی colspan 1 میگذاریم
|
|
180
|
+
weekTasksArray.forEach((week) => {
|
|
181
|
+
this._calendarService.fillWeek(week);
|
|
182
|
+
});
|
|
183
|
+
this.weekTasksArray = weekTasksArray;
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
CalendarMonthComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: CalendarMonthComponent, deps: [{ token: i1.DaysInWeekPipe }, { token: i0.ChangeDetectorRef }, { token: i2.CalendarService }], target: i0.ɵɵFactoryTarget.Component });
|
|
187
|
+
CalendarMonthComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: CalendarMonthComponent, selector: "bc-calendar-month", inputs: { monthWeeksCount: "monthWeeksCount", weekDays: "weekDays", weekDaysMin: "weekDaysMin", today: "today", containerHeight: "containerHeight", days: "days", calendarFields: "calendarFields", rtl: "rtl", deviceSize: "deviceSize", moDataList: "moDataList", datePicker: "datePicker", rangePicker: "rangePicker", canDelete: "canDelete", canAdd: "canAdd", canEdit: "canEdit", selectedDate: "selectedDate", startSelectedDayIndex: "startSelectedDayIndex", endSelectedDayIndex: "endSelectedDayIndex" }, outputs: { editEvent: "editEvent", deleteEvent: "deleteEvent", daySelect: "daySelect", dayClick: "dayClick", dayMouseMove: "dayMouseMove", dayMouseUp: "dayMouseUp", dayMouseDown: "dayMouseDown", showEvent: "showEvent" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<table fd-table class=\"table-header\" [compact]=\"true\" [attr.picker]=\"datePicker\">\n <thead fd-table-header>\n <tr fd-table-row>\n <th\n class=\"weekday-header\"\n *ngFor=\"let weekDay of selectedWeekDays\"\n fd-table-cell\n [class.noborder]=\"isPickerMode\"\n >\n {{ weekDay }}\n </th>\n </tr>\n </thead>\n <tbody fd-table-body>\n <ng-container *ngFor=\"let weekDay of numberOfWeek\">\n <tr fd-table-row>\n <td\n [style.height.px]=\"dayHeight\"\n fd-table-cell\n colspan=\"7\"\n [style.border]=\"isPickerMode ? 'none' : null\"\n >\n <ng-container\n *ngTemplateOutlet=\"\n renderTasks;\n context: {\n $implicit: isPickerMode ? null : moDataList[weekDay],\n weekIndex: weekDay,\n days: days | daysInWeek: weekDay,\n maxRowTasks: maxRowTasks,\n weekDays: weekDays,\n calendarFields: calendarFields,\n rtl: rtl,\n isPickerMode: isPickerMode\n }\n \"\n ></ng-container>\n </td>\n </tr>\n </ng-container>\n </tbody>\n</table>\n<ng-template\n #renderTasks\n let-task\n let-weekIndex=\"weekIndex\"\n let-weekDays=\"weekDays\"\n let-days=\"days\"\n let-maxRowTasks=\"maxRowTasks\"\n let-calendarFields=\"calendarFields\"\n let-deviceSize=\"deviceSize\"\n let-rtl=\"rtl\"\n let-isPickerMode=\"isPickerMode\"\n>\n <table fd-table-body class=\"table-content\" [compact]=\"true\">\n <tbody>\n <tr fd-table-row class=\"row-day-number\" [attr.rtl]=\"rtl\">\n <td fd-table-cell *ngFor=\"let day of days\" [class.noborder]=\"isPickerMode\">\n <bc-day-number-box\n [class.fd-calendar__item]=\"isPickerMode\"\n [class.fd-calendar__item--other-month]=\"isPickerMode && !day.isInMonth\"\n [class.fd-calendar__item--weekend]=\"isPickerMode && day.isWeekend\"\n [isPickerMode]=\"isPickerMode\"\n [day]=\"day\"\n [isActive]=\"\n day.index === startSelectedDayIndex || day.index === endSelectedDayIndex || day.date\n | equalDate: selectedDate\n \"\n [itemInRange]=\"\n startSelectedDayIndex !== undefined &&\n endSelectedDayIndex !== undefined &&\n day.index >= startSelectedDayIndex &&\n day.index <= endSelectedDayIndex\n \"\n (dayClick)=\"onDayClick(day)\"\n (dayMouseMove)=\"onDayMouseMove(day)\"\n (dayMouseDown)=\"onDayMouseDown(day)\"\n (dayMouseUp)=\"onDayMouseUp(day)\"\n ></bc-day-number-box>\n </td>\n </tr>\n <ng-container *ngIf=\"!isPickerMode\">\n <ng-container\n *ngTemplateOutlet=\"\n renderDayTasks;\n context: {\n $implicit: weekTasksArray[weekIndex],\n maxRowTasks: maxRowTasks,\n weekIndex: weekIndex,\n deviceSize: deviceSize,\n calendarFields: calendarFields,\n weekDays: weekDays\n }\n \"\n ></ng-container>\n <tr fd-table-row>\n <td fd-table-cell *ngFor=\"let day of days\" class=\"more-fd\" (click)=\"onDayBoxSelect(day)\">\n <ng-container *ngIf=\"maxRowTasks?.length < day.tasks.length\">\n <button\n fd-button\n (click)=\"onMoreButton($event, popover)\"\n [fdType]=\"'transparent'\"\n [compact]=\"true\"\n >\n {{ day.tasks?.length - maxRowTasks?.length }}\n {{ 'More' | bbbTranslate }}\n </button>\n <fd-popover\n #popover\n [mobile]=\"deviceSize === 's'\"\n placement=\"bottom\"\n [focusTrapped]=\"true\"\n [focusAutoCapture]=\"true\"\n (isOpenChange)=\"onOpenPopoverChange($event)\"\n >\n <bc-day-event-list\n [day]=\"day\"\n [calendarFields]=\"calendarFields\"\n [deviceSize]=\"deviceSize\"\n [weekDays]=\"weekDays\"\n [rtl]=\"rtl\"\n [canDelete]=\"canDelete\"\n [canEdit]=\"canEdit\"\n [popover]=\"popover\"\n (deleteEvent)=\"deleteEvent.emit($event)\"\n (editEvent)=\"editEvent.emit($event)\"\n ></bc-day-event-list>\n </fd-popover>\n </ng-container>\n </td>\n </tr>\n </ng-container>\n </tbody>\n </table>\n</ng-template>\n\n<ng-template\n #renderDayTasks\n let-weekTasks\n let-maxRowTasks=\"maxRowTasks\"\n let-weekIndex=\"weekIndex\"\n let-deviceSize=\"deviceSize\"\n let-calendarFields=\"calendarFields\"\n let-weekDays=\"weekDays\"\n>\n <tr fd-table-row *ngFor=\"let rowTask of maxRowTasks; let i = index\">\n <ng-container *ngIf=\"!weekTasks[i] || weekTasks[i].length === 0\">\n <td fd-table-cell *ngFor=\"let day of weekDays\"></td>\n </ng-container>\n <ng-container *ngFor=\"let task of weekTasks[i]; let dayIndex = index\">\n <td fd-table-cell [attr.colspan]=\"task.colSpan\" *ngIf=\"task.colSpan\">\n <ng-container *ngIf=\"task.event; else newDaySelect\">\n <bc-event-button\n [task]=\"task\"\n [calendarFields]=\"calendarFields\"\n [deviceSize]=\"deviceSize\"\n [rtl]=\"rtl\"\n [canDelete]=\"canDelete\"\n [canEdit]=\"canEdit\"\n (deleteEvent)=\"deleteEvent.emit($event)\"\n (editEvent)=\"editEvent.emit($event)\"\n (openPopoverChange)=\"onOpenPopoverChange($event)\"\n ></bc-event-button>\n </ng-container>\n <ng-template #newDaySelect>\n <div style=\"width: 100%; height: 100%\" (click)=\"onDaySelect(weekIndex, dayIndex)\"></div>\n </ng-template>\n </td>\n </ng-container>\n </tr>\n</ng-template>\n", styles: [":host{display:block}table{table-layout:fixed}.table-header td{padding:0!important}.table-content{width:100%;height:100%;border:none;border-spacing:0}.table-content td{border:none;border-right:var(--sapList_BorderWidth, .0625rem) solid var(--sapList_BorderColor, #e5e5e5);height:1.425rem}.table-content .row-day-number[rtl=true] td:first-child{border-right:none}.table-content .row-day-number[rtl=\"fa;se\"] td:first-child{border-left:none}table td{overflow:hidden}thead tr{border-bottom:none!important}thead tr th{text-align:center!important;background-color:var(--sapList_Background, #fff)}.weekday-header,.row-day-number td{width:100%}tbody tr td{padding-top:5px}tbody tr:first-child td{padding-top:0}.fd-table__cell{padding:0 .5rem!important}.more-fd{text-align:center!important}.more-fd button{font-size:12px}.fd-calendar__item{font-size:.875rem;font-size:var(--sapFontSize, .875rem);line-height:1.4;line-height:var(--sapContent_LineHeight, 1.4);color:#32363a;color:var(--sapTextColor, #32363a);font-family:\"72\",\"72full\",Arial,Helvetica,sans-serif;font-family:var(--sapFontFamily, \"72\", \"72full\", Arial, Helvetica, sans-serif);font-weight:400;box-sizing:border-box;padding:0;border:0;overflow:hidden;position:relative;height:2.75rem;margin:.0625rem;min-width:2.125rem;border-radius:.25rem;border-radius:var(--sapElement_BorderCornerRadius, .25rem);background-color:#fafafa;background-color:var(--sapLegend_WorkingBackground, #fafafa);flex:1 1 .375rem;border:none!important;padding:1px!important}.fd-calendar__item.fd-calendar__item--other-month{background-color:var(--sapList_Background, #fff)}.fd-calendar__item.fd-calendar__item--weekend{background-color:var(--sapLegend_NotWorkingBackground, #dedede)}.fd-calendar__item.is-active{background-color:var(--sapContent_Selected_Background, #0854a0);border:var(--fdCalendar_Active_Item_Border, none)}.fd-calendar__item.is-active ::ng-deep span{color:var(--sapContent_Selected_TextColor, #fff)}.fd-calendar__item.fd-calendar__item--range{border:.0625rem solid var(--sapList_SelectionBorderColor, #0854a0);background-color:var(--sapList_SelectionBackgroundColor, #e5f0fa)}.noborder{border:none!important}table[picker=true] thead,table[picker=true] tbody{border:none}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i4.ButtonComponent, selector: "button[fd-button], a[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "directive", type: i4.DeprecatedButtonContentDensityDirective, selector: "[fd-button][compact]" }, { kind: "component", type: i5.PopoverComponent, selector: "fd-popover", inputs: ["title", "trigger", "fixedPosition", "id", "mobile", "mobileConfig"] }, { kind: "component", type: i6.TableComponent, selector: "table[fd-table]", inputs: ["noBorderX", "noBorderY", "popIn", "responsive", "keys", "allCellsFocusable"], exportAs: ["fd-table"] }, { kind: "directive", type: i6.TableHeaderDirective, selector: "[fdTableHeader], [fd-table-header]", inputs: ["noBorderX", "noBorderY"] }, { kind: "directive", type: i6.TableBodyDirective, selector: "[fdTableBody], [fd-table-body]", inputs: ["noBorderX", "noBorderY"] }, { kind: "directive", type: i6.TableRowDirective, selector: "[fdTableRow], [fd-table-row]", inputs: ["activable", "highlightActive", "hoverable", "focusable", "main", "secondary", "active"] }, { kind: "directive", type: i6.TableCellDirective, selector: "[fdTableCell], [fd-table-cell]", inputs: ["noBorderX", "noBorderY", "activable", "focusable", "tabindex", "hoverable", "fitContent", "noPadding", "noData", "key", "cellFocusedEventAnnouncer"] }, { kind: "directive", type: i6.DeprecatedTableCompactDirective, selector: "table[fd-table][compact]" }, { kind: "component", type: i7.DayNumberBoxComponent, selector: "bc-day-number-box", inputs: ["isWeekMode", "isSingleDay", "day", "isPickerMode", "itemInRange", "isActive"], outputs: ["dayClick", "dayMouseDown", "dayMouseUp", "dayMouseMove"] }, { kind: "component", type: i8.EventButtonComponent, selector: "bc-event-button", inputs: ["buttonTemplate", "calendarFields", "task", "rtl", "canDelete", "canEdit", "deviceSize"], outputs: ["deleteEvent", "editEvent", "openPopoverChange"] }, { kind: "component", type: i9.DayEventListComponent, selector: "bc-day-event-list", inputs: ["day", "deviceSize", "weekDays", "calendarFields", "rtl", "canDelete", "canEdit", "popover"], outputs: ["deleteEvent", "editEvent", "openPopOver"] }, { kind: "pipe", type: i10.BbbTranslatePipe, name: "bbbTranslate" }, { kind: "pipe", type: i1.DaysInWeekPipe, name: "daysInWeek" }, { kind: "pipe", type: i11.EqualDatePipe, name: "equalDate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
188
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: CalendarMonthComponent, decorators: [{
|
|
189
|
+
type: Component,
|
|
190
|
+
args: [{ selector: 'bc-calendar-month', changeDetection: ChangeDetectionStrategy.OnPush, template: "<table fd-table class=\"table-header\" [compact]=\"true\" [attr.picker]=\"datePicker\">\n <thead fd-table-header>\n <tr fd-table-row>\n <th\n class=\"weekday-header\"\n *ngFor=\"let weekDay of selectedWeekDays\"\n fd-table-cell\n [class.noborder]=\"isPickerMode\"\n >\n {{ weekDay }}\n </th>\n </tr>\n </thead>\n <tbody fd-table-body>\n <ng-container *ngFor=\"let weekDay of numberOfWeek\">\n <tr fd-table-row>\n <td\n [style.height.px]=\"dayHeight\"\n fd-table-cell\n colspan=\"7\"\n [style.border]=\"isPickerMode ? 'none' : null\"\n >\n <ng-container\n *ngTemplateOutlet=\"\n renderTasks;\n context: {\n $implicit: isPickerMode ? null : moDataList[weekDay],\n weekIndex: weekDay,\n days: days | daysInWeek: weekDay,\n maxRowTasks: maxRowTasks,\n weekDays: weekDays,\n calendarFields: calendarFields,\n rtl: rtl,\n isPickerMode: isPickerMode\n }\n \"\n ></ng-container>\n </td>\n </tr>\n </ng-container>\n </tbody>\n</table>\n<ng-template\n #renderTasks\n let-task\n let-weekIndex=\"weekIndex\"\n let-weekDays=\"weekDays\"\n let-days=\"days\"\n let-maxRowTasks=\"maxRowTasks\"\n let-calendarFields=\"calendarFields\"\n let-deviceSize=\"deviceSize\"\n let-rtl=\"rtl\"\n let-isPickerMode=\"isPickerMode\"\n>\n <table fd-table-body class=\"table-content\" [compact]=\"true\">\n <tbody>\n <tr fd-table-row class=\"row-day-number\" [attr.rtl]=\"rtl\">\n <td fd-table-cell *ngFor=\"let day of days\" [class.noborder]=\"isPickerMode\">\n <bc-day-number-box\n [class.fd-calendar__item]=\"isPickerMode\"\n [class.fd-calendar__item--other-month]=\"isPickerMode && !day.isInMonth\"\n [class.fd-calendar__item--weekend]=\"isPickerMode && day.isWeekend\"\n [isPickerMode]=\"isPickerMode\"\n [day]=\"day\"\n [isActive]=\"\n day.index === startSelectedDayIndex || day.index === endSelectedDayIndex || day.date\n | equalDate: selectedDate\n \"\n [itemInRange]=\"\n startSelectedDayIndex !== undefined &&\n endSelectedDayIndex !== undefined &&\n day.index >= startSelectedDayIndex &&\n day.index <= endSelectedDayIndex\n \"\n (dayClick)=\"onDayClick(day)\"\n (dayMouseMove)=\"onDayMouseMove(day)\"\n (dayMouseDown)=\"onDayMouseDown(day)\"\n (dayMouseUp)=\"onDayMouseUp(day)\"\n ></bc-day-number-box>\n </td>\n </tr>\n <ng-container *ngIf=\"!isPickerMode\">\n <ng-container\n *ngTemplateOutlet=\"\n renderDayTasks;\n context: {\n $implicit: weekTasksArray[weekIndex],\n maxRowTasks: maxRowTasks,\n weekIndex: weekIndex,\n deviceSize: deviceSize,\n calendarFields: calendarFields,\n weekDays: weekDays\n }\n \"\n ></ng-container>\n <tr fd-table-row>\n <td fd-table-cell *ngFor=\"let day of days\" class=\"more-fd\" (click)=\"onDayBoxSelect(day)\">\n <ng-container *ngIf=\"maxRowTasks?.length < day.tasks.length\">\n <button\n fd-button\n (click)=\"onMoreButton($event, popover)\"\n [fdType]=\"'transparent'\"\n [compact]=\"true\"\n >\n {{ day.tasks?.length - maxRowTasks?.length }}\n {{ 'More' | bbbTranslate }}\n </button>\n <fd-popover\n #popover\n [mobile]=\"deviceSize === 's'\"\n placement=\"bottom\"\n [focusTrapped]=\"true\"\n [focusAutoCapture]=\"true\"\n (isOpenChange)=\"onOpenPopoverChange($event)\"\n >\n <bc-day-event-list\n [day]=\"day\"\n [calendarFields]=\"calendarFields\"\n [deviceSize]=\"deviceSize\"\n [weekDays]=\"weekDays\"\n [rtl]=\"rtl\"\n [canDelete]=\"canDelete\"\n [canEdit]=\"canEdit\"\n [popover]=\"popover\"\n (deleteEvent)=\"deleteEvent.emit($event)\"\n (editEvent)=\"editEvent.emit($event)\"\n ></bc-day-event-list>\n </fd-popover>\n </ng-container>\n </td>\n </tr>\n </ng-container>\n </tbody>\n </table>\n</ng-template>\n\n<ng-template\n #renderDayTasks\n let-weekTasks\n let-maxRowTasks=\"maxRowTasks\"\n let-weekIndex=\"weekIndex\"\n let-deviceSize=\"deviceSize\"\n let-calendarFields=\"calendarFields\"\n let-weekDays=\"weekDays\"\n>\n <tr fd-table-row *ngFor=\"let rowTask of maxRowTasks; let i = index\">\n <ng-container *ngIf=\"!weekTasks[i] || weekTasks[i].length === 0\">\n <td fd-table-cell *ngFor=\"let day of weekDays\"></td>\n </ng-container>\n <ng-container *ngFor=\"let task of weekTasks[i]; let dayIndex = index\">\n <td fd-table-cell [attr.colspan]=\"task.colSpan\" *ngIf=\"task.colSpan\">\n <ng-container *ngIf=\"task.event; else newDaySelect\">\n <bc-event-button\n [task]=\"task\"\n [calendarFields]=\"calendarFields\"\n [deviceSize]=\"deviceSize\"\n [rtl]=\"rtl\"\n [canDelete]=\"canDelete\"\n [canEdit]=\"canEdit\"\n (deleteEvent)=\"deleteEvent.emit($event)\"\n (editEvent)=\"editEvent.emit($event)\"\n (openPopoverChange)=\"onOpenPopoverChange($event)\"\n ></bc-event-button>\n </ng-container>\n <ng-template #newDaySelect>\n <div style=\"width: 100%; height: 100%\" (click)=\"onDaySelect(weekIndex, dayIndex)\"></div>\n </ng-template>\n </td>\n </ng-container>\n </tr>\n</ng-template>\n", styles: [":host{display:block}table{table-layout:fixed}.table-header td{padding:0!important}.table-content{width:100%;height:100%;border:none;border-spacing:0}.table-content td{border:none;border-right:var(--sapList_BorderWidth, .0625rem) solid var(--sapList_BorderColor, #e5e5e5);height:1.425rem}.table-content .row-day-number[rtl=true] td:first-child{border-right:none}.table-content .row-day-number[rtl=\"fa;se\"] td:first-child{border-left:none}table td{overflow:hidden}thead tr{border-bottom:none!important}thead tr th{text-align:center!important;background-color:var(--sapList_Background, #fff)}.weekday-header,.row-day-number td{width:100%}tbody tr td{padding-top:5px}tbody tr:first-child td{padding-top:0}.fd-table__cell{padding:0 .5rem!important}.more-fd{text-align:center!important}.more-fd button{font-size:12px}.fd-calendar__item{font-size:.875rem;font-size:var(--sapFontSize, .875rem);line-height:1.4;line-height:var(--sapContent_LineHeight, 1.4);color:#32363a;color:var(--sapTextColor, #32363a);font-family:\"72\",\"72full\",Arial,Helvetica,sans-serif;font-family:var(--sapFontFamily, \"72\", \"72full\", Arial, Helvetica, sans-serif);font-weight:400;box-sizing:border-box;padding:0;border:0;overflow:hidden;position:relative;height:2.75rem;margin:.0625rem;min-width:2.125rem;border-radius:.25rem;border-radius:var(--sapElement_BorderCornerRadius, .25rem);background-color:#fafafa;background-color:var(--sapLegend_WorkingBackground, #fafafa);flex:1 1 .375rem;border:none!important;padding:1px!important}.fd-calendar__item.fd-calendar__item--other-month{background-color:var(--sapList_Background, #fff)}.fd-calendar__item.fd-calendar__item--weekend{background-color:var(--sapLegend_NotWorkingBackground, #dedede)}.fd-calendar__item.is-active{background-color:var(--sapContent_Selected_Background, #0854a0);border:var(--fdCalendar_Active_Item_Border, none)}.fd-calendar__item.is-active ::ng-deep span{color:var(--sapContent_Selected_TextColor, #fff)}.fd-calendar__item.fd-calendar__item--range{border:.0625rem solid var(--sapList_SelectionBorderColor, #0854a0);background-color:var(--sapList_SelectionBackgroundColor, #e5f0fa)}.noborder{border:none!important}table[picker=true] thead,table[picker=true] tbody{border:none}\n"] }]
|
|
191
|
+
}], ctorParameters: function () { return [{ type: i1.DaysInWeekPipe }, { type: i0.ChangeDetectorRef }, { type: i2.CalendarService }]; }, propDecorators: { monthWeeksCount: [{
|
|
192
|
+
type: Input
|
|
193
|
+
}], weekDays: [{
|
|
194
|
+
type: Input
|
|
195
|
+
}], weekDaysMin: [{
|
|
196
|
+
type: Input
|
|
197
|
+
}], today: [{
|
|
198
|
+
type: Input
|
|
199
|
+
}], containerHeight: [{
|
|
200
|
+
type: Input
|
|
201
|
+
}], days: [{
|
|
202
|
+
type: Input
|
|
203
|
+
}], calendarFields: [{
|
|
204
|
+
type: Input
|
|
205
|
+
}], rtl: [{
|
|
206
|
+
type: Input
|
|
207
|
+
}], deviceSize: [{
|
|
208
|
+
type: Input
|
|
209
|
+
}], moDataList: [{
|
|
210
|
+
type: Input
|
|
211
|
+
}], datePicker: [{
|
|
212
|
+
type: Input
|
|
213
|
+
}], rangePicker: [{
|
|
214
|
+
type: Input
|
|
215
|
+
}], canDelete: [{
|
|
216
|
+
type: Input
|
|
217
|
+
}], canAdd: [{
|
|
218
|
+
type: Input
|
|
219
|
+
}], canEdit: [{
|
|
220
|
+
type: Input
|
|
221
|
+
}], selectedDate: [{
|
|
222
|
+
type: Input
|
|
223
|
+
}], startSelectedDayIndex: [{
|
|
224
|
+
type: Input
|
|
225
|
+
}], endSelectedDayIndex: [{
|
|
226
|
+
type: Input
|
|
227
|
+
}], editEvent: [{
|
|
228
|
+
type: Output
|
|
229
|
+
}], deleteEvent: [{
|
|
230
|
+
type: Output
|
|
231
|
+
}], daySelect: [{
|
|
232
|
+
type: Output
|
|
233
|
+
}], dayClick: [{
|
|
234
|
+
type: Output
|
|
235
|
+
}], dayMouseMove: [{
|
|
236
|
+
type: Output
|
|
237
|
+
}], dayMouseUp: [{
|
|
238
|
+
type: Output
|
|
239
|
+
}], dayMouseDown: [{
|
|
240
|
+
type: Output
|
|
241
|
+
}], showEvent: [{
|
|
242
|
+
type: Output
|
|
243
|
+
}] } });
|
|
244
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-month.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-calendar/src/lib/calendar-month/calendar-month.component.ts","../../../../../projects/barsa-calendar/src/lib/calendar-month/calendar-month.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    EventEmitter,\n    Input,\n    OnChanges,\n    OnInit,\n    Output,\n    SimpleChanges\n} from '@angular/core';\n\nimport moment from 'moment';\n\nimport { BaseComponent, CalendarFields, CalendarMetaobjectDataModel, MetaobjectDataModel } from 'barsa-novin-ray-core';\nimport { Day } from '../models';\nimport { DaysInWeekPipe } from '../days-in-week.pipe';\n\nimport { CalendarService } from '../services/calendar.service';\n\n@Component({\n    selector: 'bc-calendar-month',\n    templateUrl: './calendar-month.component.html',\n    styleUrls: ['./calendar-month.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class CalendarMonthComponent extends BaseComponent implements OnChanges, OnInit {\n    @Input() monthWeeksCount: number;\n    @Input() weekDays: string[];\n    @Input() weekDaysMin: string[];\n    @Input() today: Date;\n    @Input() containerHeight: number;\n    @Input() days: Day[];\n    @Input() calendarFields: CalendarFields;\n    @Input() rtl: boolean;\n    @Input() deviceSize: string;\n    @Input() moDataList: MetaobjectDataModel[];\n    @Input() datePicker = false;\n    @Input() rangePicker = false;\n    @Input() canDelete = false;\n    @Input() canAdd = false;\n    @Input() canEdit = false;\n    @Input() selectedDate: Date | undefined;\n    @Input() startSelectedDayIndex: number | undefined;\n    @Input() endSelectedDayIndex: number | undefined;\n    @Output() editEvent = new EventEmitter<MetaobjectDataModel>();\n    @Output() deleteEvent = new EventEmitter<MetaobjectDataModel>();\n    @Output() daySelect = new EventEmitter<any>();\n    @Output() dayClick = new EventEmitter<Day>();\n    @Output() dayMouseMove = new EventEmitter<Day>();\n    @Output() dayMouseUp = new EventEmitter<Day>();\n    @Output() dayMouseDown = new EventEmitter<Day>();\n    @Output() showEvent = new EventEmitter<CalendarMetaobjectDataModel>();\n\n    defaultWeeksCountD: number;\n    defaultFirstWeekIndex: number;\n    selectedWeekDays: string[];\n    selected: Day;\n    numberOfWeek: number[];\n    dayHeight: number;\n    taskHeight = 30;\n    maxTaskCount: number;\n    maxRowTasks: number[];\n    weekTasksArray: any;\n    extraRow: number[];\n    isPickerMode: boolean;\n\n    private _hasPopoverOpened: boolean[] = [];\n\n    constructor(\n        private daysInWeek: DaysInWeekPipe,\n        private _cdr: ChangeDetectorRef,\n        private _calendarService: CalendarService\n    ) {\n        super();\n    }\n    ngOnChanges(changes: SimpleChanges): void {\n        super.ngOnChanges(changes);\n        let needToDetectChange = false;\n        const {\n            containerHeight,\n            deviceSize,\n            moDataList,\n            days,\n            monthWeeksCount,\n            startSelectedDayIndex,\n            endSelectedDayIndex\n        } = changes;\n        if (containerHeight && !containerHeight.firstChange) {\n            this.fitToContainer(changes.containerHeight.currentValue);\n        }\n        if (deviceSize && !deviceSize.firstChange) {\n            this.prepareWeekDays(changes.deviceSize.currentValue);\n        }\n        if (moDataList && !moDataList.firstChange) {\n            this._prepareDaysTasks(changes.moDataList.currentValue);\n            needToDetectChange = true;\n        }\n        if (days && !days.firstChange) {\n            this.fitToContainer(this.containerHeight);\n            this._prepareDaysTasks(this.moDataList);\n            needToDetectChange = true;\n        }\n        if (monthWeeksCount && !monthWeeksCount.firstChange) {\n            this.fitToContainer(this.containerHeight);\n            this._prepareDaysTasks(this.moDataList);\n            needToDetectChange = true;\n        }\n        if (\n            (startSelectedDayIndex && !startSelectedDayIndex.firstChange) ||\n            (endSelectedDayIndex && !endSelectedDayIndex.firstChange)\n        ) {\n            needToDetectChange = true;\n        }\n        if (needToDetectChange) {\n            this._cdr.detectChanges();\n        }\n    }\n\n    ngOnInit(): void {\n        super.ngOnInit();\n        this.isPickerMode = this.datePicker || this.rangePicker;\n        this.prepareWeekDays(this.deviceSize);\n        this._prepareDaysTasks(this.moDataList);\n        this.fitToContainer(this.containerHeight);\n    }\n\n    onDayBoxSelect(day: Day): void {\n        this._fireDaySelect(day);\n    }\n    onDaySelect(weekIndex: number, dayIndex: number): void {\n        if (!this.canAdd) {\n            return;\n        }\n        const day = this.days[weekIndex * 7 + dayIndex];\n        this._fireDaySelect(day);\n    }\n\n    onOpenPopoverChange(isOpen: boolean): void {\n        this._openPopover(isOpen);\n    }\n    onMoreButton(e, popover): void {\n        this._preventEvent(e);\n        popover.open();\n    }\n    onTask(e, task: CalendarMetaobjectDataModel): void {\n        this.showEvent.emit(task);\n    }\n    onDayClick(day: Day): void {\n        this.selected = day;\n        this.dayClick.emit(day);\n    }\n    onDayMouseMove(day: Day): void {\n        this.dayMouseMove.emit(day);\n    }\n    onDayMouseDown(day: Day): void {\n        this.dayMouseDown.emit(day);\n    }\n    onDayMouseUp(day: Day): void {\n        this.dayMouseUp.emit(day);\n    }\n    private _preventEvent(e): void {\n        e.stopPropagation();\n        e.preventDefault();\n    }\n    private _fireDaySelect(day: Day): void {\n        if (this._hasPopoverOpened.length === 0) {\n            this.daySelect.emit(moment(day.date));\n        }\n    }\n    private _openPopover(isOpen: boolean): void {\n        if (isOpen) {\n            this._hasPopoverOpened.push(true);\n        } else {\n            setTimeout(() => {\n                this._hasPopoverOpened = [];\n            }, 0);\n        }\n    }\n    private prepareWeekDays(deviceSize: string): void {\n        if (deviceSize !== 's' && deviceSize !== 'm') {\n            this.selectedWeekDays = this.weekDays;\n        } else {\n            this.selectedWeekDays = this.weekDaysMin;\n        }\n    }\n    private fitToContainer(containerHeight): void {\n        let _weeksCount;\n\n        if (this.monthWeeksCount > 0) {\n            const weeksCount = this.monthWeeksCount;\n            _weeksCount = weeksCount;\n        } else {\n            _weeksCount = this.days.length / 7;\n        }\n        this.numberOfWeek = Array.from(Array(_weeksCount).keys());\n        this.numberOfWeek = this.numberOfWeek.map((value) => value);\n        if (this.isPickerMode) {\n            this.dayHeight = 40;\n            return;\n        }\n        this.dayHeight = Math.floor(containerHeight / (_weeksCount + 1));\n\n        this.maxTaskCount = Math.floor((this.dayHeight - this.taskHeight) / this.taskHeight);\n        if (this.maxTaskCount > 0) {\n            this.maxRowTasks = new Array(this.maxTaskCount).fill(0).map((x, i) => i);\n        }\n    }\n    private _prepareDaysTasks(calendarTasks): void {\n        if (this.isPickerMode) {\n            this.weekTasksArray = {};\n            return;\n        }\n\n        const calendarFields = this.calendarFields;\n\n        // Sort all Tasks\n        const moDataList = this._calendarService.sortTasks(calendarTasks, calendarFields);\n        this.days.forEach((day) => (day.tasks = []));\n        const weekTasksArray: any = [];\n        for (let j = 0; j < this.days.length / 7; j++) {\n            const days = this.daysInWeek.transform(this.days, j);\n            const week = this._calendarService.createWeekTask(days, moDataList, calendarFields, 0);\n            weekTasksArray.push(week);\n        }\n\n        weekTasksArray.forEach((week) => {\n            const arr: any[] = Object.values(week);\n            for (let i = arr.length; i < this.maxTaskCount; i++) {\n                week[i.toString()] = [];\n            }\n        });\n        // به ازای هر ردیف تسک باید تعداد 7 ستون اضافه گردد و برای ستونی که تسکی ندارد یک جای خالی colspan 1 میگذاریم\n        weekTasksArray.forEach((week) => {\n            this._calendarService.fillWeek(week);\n        });\n        this.weekTasksArray = weekTasksArray;\n    }\n}\n","<table fd-table class=\"table-header\" [compact]=\"true\" [attr.picker]=\"datePicker\">\n    <thead fd-table-header>\n        <tr fd-table-row>\n            <th\n                class=\"weekday-header\"\n                *ngFor=\"let weekDay of selectedWeekDays\"\n                fd-table-cell\n                [class.noborder]=\"isPickerMode\"\n            >\n                {{ weekDay }}\n            </th>\n        </tr>\n    </thead>\n    <tbody fd-table-body>\n        <ng-container *ngFor=\"let weekDay of numberOfWeek\">\n            <tr fd-table-row>\n                <td\n                    [style.height.px]=\"dayHeight\"\n                    fd-table-cell\n                    colspan=\"7\"\n                    [style.border]=\"isPickerMode ? 'none' : null\"\n                >\n                    <ng-container\n                        *ngTemplateOutlet=\"\n                            renderTasks;\n                            context: {\n                                $implicit: isPickerMode ? null : moDataList[weekDay],\n                                weekIndex: weekDay,\n                                days: days | daysInWeek: weekDay,\n                                maxRowTasks: maxRowTasks,\n                                weekDays: weekDays,\n                                calendarFields: calendarFields,\n                                rtl: rtl,\n                                isPickerMode: isPickerMode\n                            }\n                        \"\n                    ></ng-container>\n                </td>\n            </tr>\n        </ng-container>\n    </tbody>\n</table>\n<ng-template\n    #renderTasks\n    let-task\n    let-weekIndex=\"weekIndex\"\n    let-weekDays=\"weekDays\"\n    let-days=\"days\"\n    let-maxRowTasks=\"maxRowTasks\"\n    let-calendarFields=\"calendarFields\"\n    let-deviceSize=\"deviceSize\"\n    let-rtl=\"rtl\"\n    let-isPickerMode=\"isPickerMode\"\n>\n    <table fd-table-body class=\"table-content\" [compact]=\"true\">\n        <tbody>\n            <tr fd-table-row class=\"row-day-number\" [attr.rtl]=\"rtl\">\n                <td fd-table-cell *ngFor=\"let day of days\" [class.noborder]=\"isPickerMode\">\n                    <bc-day-number-box\n                        [class.fd-calendar__item]=\"isPickerMode\"\n                        [class.fd-calendar__item--other-month]=\"isPickerMode && !day.isInMonth\"\n                        [class.fd-calendar__item--weekend]=\"isPickerMode && day.isWeekend\"\n                        [isPickerMode]=\"isPickerMode\"\n                        [day]=\"day\"\n                        [isActive]=\"\n                            day.index === startSelectedDayIndex || day.index === endSelectedDayIndex || day.date\n                                | equalDate: selectedDate\n                        \"\n                        [itemInRange]=\"\n                            startSelectedDayIndex !== undefined &&\n                            endSelectedDayIndex !== undefined &&\n                            day.index >= startSelectedDayIndex &&\n                            day.index <= endSelectedDayIndex\n                        \"\n                        (dayClick)=\"onDayClick(day)\"\n                        (dayMouseMove)=\"onDayMouseMove(day)\"\n                        (dayMouseDown)=\"onDayMouseDown(day)\"\n                        (dayMouseUp)=\"onDayMouseUp(day)\"\n                    ></bc-day-number-box>\n                </td>\n            </tr>\n            <ng-container *ngIf=\"!isPickerMode\">\n                <ng-container\n                    *ngTemplateOutlet=\"\n                        renderDayTasks;\n                        context: {\n                            $implicit: weekTasksArray[weekIndex],\n                            maxRowTasks: maxRowTasks,\n                            weekIndex: weekIndex,\n                            deviceSize: deviceSize,\n                            calendarFields: calendarFields,\n                            weekDays: weekDays\n                        }\n                    \"\n                ></ng-container>\n                <tr fd-table-row>\n                    <td fd-table-cell *ngFor=\"let day of days\" class=\"more-fd\" (click)=\"onDayBoxSelect(day)\">\n                        <ng-container *ngIf=\"maxRowTasks?.length < day.tasks.length\">\n                            <button\n                                fd-button\n                                (click)=\"onMoreButton($event, popover)\"\n                                [fdType]=\"'transparent'\"\n                                [compact]=\"true\"\n                            >\n                                {{ day.tasks?.length - maxRowTasks?.length }}\n                                {{ 'More' | bbbTranslate }}\n                            </button>\n                            <fd-popover\n                                #popover\n                                [mobile]=\"deviceSize === 's'\"\n                                placement=\"bottom\"\n                                [focusTrapped]=\"true\"\n                                [focusAutoCapture]=\"true\"\n                                (isOpenChange)=\"onOpenPopoverChange($event)\"\n                            >\n                                <bc-day-event-list\n                                    [day]=\"day\"\n                                    [calendarFields]=\"calendarFields\"\n                                    [deviceSize]=\"deviceSize\"\n                                    [weekDays]=\"weekDays\"\n                                    [rtl]=\"rtl\"\n                                    [canDelete]=\"canDelete\"\n                                    [canEdit]=\"canEdit\"\n                                    [popover]=\"popover\"\n                                    (deleteEvent)=\"deleteEvent.emit($event)\"\n                                    (editEvent)=\"editEvent.emit($event)\"\n                                ></bc-day-event-list>\n                            </fd-popover>\n                        </ng-container>\n                    </td>\n                </tr>\n            </ng-container>\n        </tbody>\n    </table>\n</ng-template>\n\n<ng-template\n    #renderDayTasks\n    let-weekTasks\n    let-maxRowTasks=\"maxRowTasks\"\n    let-weekIndex=\"weekIndex\"\n    let-deviceSize=\"deviceSize\"\n    let-calendarFields=\"calendarFields\"\n    let-weekDays=\"weekDays\"\n>\n    <tr fd-table-row *ngFor=\"let rowTask of maxRowTasks; let i = index\">\n        <ng-container *ngIf=\"!weekTasks[i] || weekTasks[i].length === 0\">\n            <td fd-table-cell *ngFor=\"let day of weekDays\"></td>\n        </ng-container>\n        <ng-container *ngFor=\"let task of weekTasks[i]; let dayIndex = index\">\n            <td fd-table-cell [attr.colspan]=\"task.colSpan\" *ngIf=\"task.colSpan\">\n                <ng-container *ngIf=\"task.event; else newDaySelect\">\n                    <bc-event-button\n                        [task]=\"task\"\n                        [calendarFields]=\"calendarFields\"\n                        [deviceSize]=\"deviceSize\"\n                        [rtl]=\"rtl\"\n                        [canDelete]=\"canDelete\"\n                        [canEdit]=\"canEdit\"\n                        (deleteEvent)=\"deleteEvent.emit($event)\"\n                        (editEvent)=\"editEvent.emit($event)\"\n                        (openPopoverChange)=\"onOpenPopoverChange($event)\"\n                    ></bc-event-button>\n                </ng-container>\n                <ng-template #newDaySelect>\n                    <div style=\"width: 100%; height: 100%\" (click)=\"onDaySelect(weekIndex, dayIndex)\"></div>\n                </ng-template>\n            </td>\n        </ng-container>\n    </tr>\n</ng-template>\n"]}
|
|
@@ -0,0 +1,193 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, Self } from '@angular/core';
|
|
2
|
+
import { distinctUntilChanged, map } from 'rxjs/operators';
|
|
3
|
+
import { BaseComponent, DateService, getDateService } from 'barsa-novin-ray-core';
|
|
4
|
+
import { CalendarService } from '../services/calendar.service';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "../services/calendar.service";
|
|
7
|
+
import * as i2 from "barsa-novin-ray-core";
|
|
8
|
+
import * as i3 from "@angular/common";
|
|
9
|
+
import * as i4 from "@fundamental-ngx/core/button";
|
|
10
|
+
import * as i5 from "@fundamental-ngx/core/popover";
|
|
11
|
+
import * as i6 from "@fundamental-ngx/core/toolbar";
|
|
12
|
+
import * as i7 from "@fundamental-ngx/platform/button";
|
|
13
|
+
import * as i8 from "../calendar-month/calendar-month.component";
|
|
14
|
+
export class CalendarSelectionDaysComponent extends BaseComponent {
|
|
15
|
+
constructor(_calendarService, _portalService) {
|
|
16
|
+
super();
|
|
17
|
+
this._calendarService = _calendarService;
|
|
18
|
+
this.rangeChange = new EventEmitter();
|
|
19
|
+
this.selectionMode = 'day';
|
|
20
|
+
this.months = [];
|
|
21
|
+
this._isMouseDown = false;
|
|
22
|
+
this.rtl$ = _portalService.rtl$;
|
|
23
|
+
this.width$ = _portalService.deviceSize$.pipe(distinctUntilChanged(), map((deviceSize) => {
|
|
24
|
+
switch (deviceSize) {
|
|
25
|
+
case 'l':
|
|
26
|
+
case 'xl':
|
|
27
|
+
return 480;
|
|
28
|
+
case 's':
|
|
29
|
+
return 320;
|
|
30
|
+
default:
|
|
31
|
+
return 480;
|
|
32
|
+
}
|
|
33
|
+
}));
|
|
34
|
+
this.weekDaysMin = this._calendarService.weekDaysMin();
|
|
35
|
+
this.weekDays = this._calendarService.weekDays();
|
|
36
|
+
this.selectedMonth$ = this._calendarService.selected$;
|
|
37
|
+
this.today = this._calendarService.today;
|
|
38
|
+
this.months = this._calendarService.Months;
|
|
39
|
+
this._prepareYear(this._calendarService.selectedMonth.dateInfo.year);
|
|
40
|
+
}
|
|
41
|
+
ngOnChanges(changes) {
|
|
42
|
+
super.ngOnChanges(changes);
|
|
43
|
+
const { monthInfo } = changes;
|
|
44
|
+
if (monthInfo) {
|
|
45
|
+
this._calendarService.loadCalendarMonthInfo(monthInfo.currentValue);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
onMonthSelected(monthName, index) {
|
|
49
|
+
this._calendarService.gotoMonth(monthName, index);
|
|
50
|
+
}
|
|
51
|
+
onYearSelected(year) {
|
|
52
|
+
this._calendarService.gotoYear(+year);
|
|
53
|
+
}
|
|
54
|
+
onPrevTap() {
|
|
55
|
+
if (this.selectionMode === 'day') {
|
|
56
|
+
this._calendarService.loadPrevious();
|
|
57
|
+
}
|
|
58
|
+
else if (this.selectionMode === 'month') {
|
|
59
|
+
this._calendarService.loadPrevYear();
|
|
60
|
+
}
|
|
61
|
+
else if (this.selectionMode === 'year') {
|
|
62
|
+
this._prepareYear(Number(this.years[0]) - 20);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
onNextTap() {
|
|
66
|
+
if (this.selectionMode === 'day') {
|
|
67
|
+
this._calendarService.loadNext();
|
|
68
|
+
}
|
|
69
|
+
else if (this.selectionMode === 'month') {
|
|
70
|
+
this._calendarService.loadNextYear();
|
|
71
|
+
}
|
|
72
|
+
else if (this.selectionMode === 'year') {
|
|
73
|
+
this._prepareYear(Number(this.years[this.years.length - 1]) + 1);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
onToday() {
|
|
77
|
+
this._calendarService.gotoToday();
|
|
78
|
+
}
|
|
79
|
+
onDayMouseMove(day, monthInfo) {
|
|
80
|
+
if (this._isMouseDown) {
|
|
81
|
+
const { endDay, startDay } = this.getStartAndEndDay(monthInfo, day);
|
|
82
|
+
this.startSelectedDayIndex = startDay?.index;
|
|
83
|
+
this.endSelectedDayIndex = endDay?.index;
|
|
84
|
+
console.log('-move-', this.startSelectedDay?.index, this.endSelectedDay?.index);
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
onDayMouseDown(day) {
|
|
88
|
+
this._isMouseDown = true;
|
|
89
|
+
this.startSelectedDay = null;
|
|
90
|
+
this.endSelectedDay = null;
|
|
91
|
+
this.startSelectedDay = day;
|
|
92
|
+
this.startSelectedDayIndex = day.index;
|
|
93
|
+
}
|
|
94
|
+
onDayMouseUp(day, monthInfo, popover) {
|
|
95
|
+
this._isMouseDown = false;
|
|
96
|
+
const { endDay, startDay } = this.getStartAndEndDay(monthInfo, day);
|
|
97
|
+
this.startSelectedDay = startDay;
|
|
98
|
+
this.endSelectedDay = endDay;
|
|
99
|
+
this._setFirstAndEndDay(monthInfo, popover);
|
|
100
|
+
}
|
|
101
|
+
onDayClick(day, monthInfo, popover) {
|
|
102
|
+
this.startSelectedDay = this.endSelectedDay = day;
|
|
103
|
+
this._setFirstAndEndDay(monthInfo, popover);
|
|
104
|
+
}
|
|
105
|
+
_prepareYear(from) {
|
|
106
|
+
const years = [];
|
|
107
|
+
for (let i = 0; i < 20; i++) {
|
|
108
|
+
years.push(`${from + i}`);
|
|
109
|
+
}
|
|
110
|
+
this.years = years;
|
|
111
|
+
}
|
|
112
|
+
getStartAndEndDay(monthInfo, day) {
|
|
113
|
+
let startDay = null;
|
|
114
|
+
let endDay = null;
|
|
115
|
+
if (this.startSelectedDay && !this.endSelectedDay) {
|
|
116
|
+
if (day && this.startSelectedDay.date > day.date) {
|
|
117
|
+
startDay = day;
|
|
118
|
+
endDay = this.startSelectedDay;
|
|
119
|
+
}
|
|
120
|
+
else {
|
|
121
|
+
startDay = this.startSelectedDay;
|
|
122
|
+
endDay = day;
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
else if (this.startSelectedDay && this.endSelectedDay) {
|
|
126
|
+
if (day && this.startSelectedDay.date < day.date) {
|
|
127
|
+
startDay = this.startSelectedDay;
|
|
128
|
+
endDay = day;
|
|
129
|
+
}
|
|
130
|
+
else {
|
|
131
|
+
startDay = day;
|
|
132
|
+
endDay = this.endSelectedDay;
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
console.log('-2-', startDay, endDay);
|
|
136
|
+
if (startDay && endDay) {
|
|
137
|
+
const diff = Math.abs(startDay.momentOfDate.diff(endDay.momentOfDate, 'day'));
|
|
138
|
+
if (diff > 6) {
|
|
139
|
+
startDay = monthInfo.days[Math.floor(startDay.index / 7) * 7];
|
|
140
|
+
// const end = endDay.index % 7;
|
|
141
|
+
const indexEnd = Math.ceil((endDay.index + 1) / 7);
|
|
142
|
+
// if (end > 0) {
|
|
143
|
+
// indexEnd++;
|
|
144
|
+
// }
|
|
145
|
+
endDay = monthInfo.days[indexEnd * 7 - 1];
|
|
146
|
+
console.log('-3-', startDay, endDay);
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
return { endDay, startDay };
|
|
150
|
+
}
|
|
151
|
+
_setFirstAndEndDay(monthInfo, popover) {
|
|
152
|
+
console.log('-finish-', this.startSelectedDay, this.endSelectedDay);
|
|
153
|
+
if (this.startSelectedDay && this.endSelectedDay) {
|
|
154
|
+
if (popover) {
|
|
155
|
+
popover.close();
|
|
156
|
+
}
|
|
157
|
+
this.rangeChange.emit({
|
|
158
|
+
startDay: this.startSelectedDay,
|
|
159
|
+
endDay: this.endSelectedDay,
|
|
160
|
+
monthInfo
|
|
161
|
+
});
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
CalendarSelectionDaysComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: CalendarSelectionDaysComponent, deps: [{ token: i1.CalendarService, self: true }, { token: i2.PortalService }], target: i0.ɵɵFactoryTarget.Component });
|
|
166
|
+
CalendarSelectionDaysComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: CalendarSelectionDaysComponent, selector: "bc-calendar-selection-days", inputs: { startSelectedDayIndex: "startSelectedDayIndex", endSelectedDayIndex: "endSelectedDayIndex", monthInfo: "monthInfo" }, outputs: { rangeChange: "rangeChange" }, providers: [
|
|
167
|
+
{
|
|
168
|
+
provide: DateService,
|
|
169
|
+
useFactory: getDateService
|
|
170
|
+
},
|
|
171
|
+
CalendarService
|
|
172
|
+
], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<fdp-button glyph=\"calendar\" buttonType=\"transparent\" [fdPopoverTrigger]=\"popover\"></fdp-button>\n<fd-popover #popover [focusTrapped]=\"true\" [focusAutoCapture]=\"true\" [mobile]=\"(deviceSize$ | async) === 's'\">\n <fd-popover-body [style.width.px]=\"width$ | async\">\n <ng-container\n *ngTemplateOutlet=\"\n month;\n context: {\n $implicit: selectedMonth$ | async,\n width: width$ | async,\n height: height,\n rtl: rtl$ | async,\n weekDays: weekDays,\n weekDaysMin: weekDaysMin,\n today: today,\n deviceSize: deviceSize$ | async,\n popover: popover\n }\n \"\n >\n </ng-container>\n </fd-popover-body>\n</fd-popover>\n\n<ng-template\n #month\n let-selectedMonth\n let-width=\"width\"\n let-height=\"height\"\n let-rtl=\"rtl\"\n let-today=\"today\"\n let-showEvents=\"showEvents\"\n let-deviceSize=\"deviceSize\"\n let-popover=\"popover\"\n>\n <fd-toolbar [fdType]=\"'transparent'\">\n <fdp-button fd-toolbar-item [label]=\"'DateR_Today' | bbbTranslate\" (click)=\"onToday()\"></fdp-button>\n <fdp-button\n buttonType=\"transparent\"\n fd-toolbar-item\n [glyph]=\"rtl ? 'navigation-right-arrow' : 'navigation-left-arrow'\"\n (click)=\"onPrevTap()\"\n ></fdp-button>\n <fdp-button\n buttonType=\"transparent\"\n fd-toolbar-item\n [glyph]=\"rtl ? 'navigation-left-arrow' : 'navigation-right-arrow'\"\n (click)=\"onNextTap()\"\n ></fdp-button>\n <div class=\"month-years-wrapper\" fd-title fd-toolbar-item>\n <button\n *ngIf=\"selectionMode === 'day' || selectionMode === 'month'\"\n fd-button\n [fdType]=\"'transparent'\"\n [label]=\"selectedMonth.dateInfo.monthName\"\n (click)=\"selectionMode = 'month'\"\n ></button>\n <button\n fd-button\n [fdType]=\"'transparent'\"\n [label]=\"selectedMonth.dateInfo.year\"\n (click)=\"selectionMode = 'year'\"\n ></button>\n </div>\n </fd-toolbar>\n <ng-container [ngSwitch]=\"selectionMode\">\n <ng-container *ngSwitchCase=\"'month'\">\n <div class=\"month-year-selection-wrapper\">\n <button\n style=\"flex-grow: 1; width: 33%\"\n *ngFor=\"let month of months; let i = index\"\n fd-button\n [fdType]=\"selectedMonth.dateInfo.monthName === month ? 'emphasized' : 'transparent'\"\n [label]=\"month\"\n (click)=\"selectionMode = 'day'; onMonthSelected(month, i)\"\n ></button>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'year'\">\n <div class=\"month-year-selection-wrapper\">\n <button\n style=\"flex-grow: 1; width: 25%\"\n *ngFor=\"let year of years\"\n fd-button\n [fdType]=\"selectedMonth.dateInfo.year === +year ? 'emphasized' : 'transparent'\"\n [label]=\"year\"\n (click)=\"selectionMode = 'day'; onYearSelected(year)\"\n ></button>\n </div>\n </ng-container>\n <bc-calendar-month\n *ngSwitchDefault\n [style.width]=\"width\"\n [containerHeight]=\"height\"\n [containerWidth]=\"width\"\n [rtl]=\"rtl\"\n [monthWeeksCount]=\"6\"\n [weekDays]=\"weekDays\"\n [weekDaysMin]=\"weekDaysMin\"\n [today]=\"today\"\n [datePicker]=\"true\"\n [dateRange]=\"true\"\n [days]=\"selectedMonth.days\"\n [deviceSize]=\"deviceSize\"\n (dayClick)=\"onDayClick($event, selectedMonth, popover)\"\n (dayMouseMove)=\"onDayMouseMove($event, selectedMonth)\"\n (dayMouseUp)=\"onDayMouseUp($event, selectedMonth, popover)\"\n (dayMouseDown)=\"onDayMouseDown($event)\"\n [startSelectedDayIndex]=\"startSelectedDayIndex\"\n [endSelectedDayIndex]=\"endSelectedDayIndex\"\n ></bc-calendar-month>\n </ng-container>\n</ng-template>\n", styles: [""], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i3.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i3.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "component", type: i4.ButtonComponent, selector: "button[fd-button], a[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i5.PopoverBodyComponent, selector: "fd-popover-body" }, { kind: "component", type: i5.PopoverComponent, selector: "fd-popover", inputs: ["title", "trigger", "fixedPosition", "id", "mobile", "mobileConfig"] }, { kind: "directive", type: i5.PopoverTriggerDirective, selector: "[fdPopoverTrigger], [fd-popover-trigger]", inputs: ["fdPopoverTrigger"] }, { kind: "component", type: i6.ToolbarComponent, selector: "fd-toolbar", inputs: ["class", "shouldOverflow", "fdType", "hasTitle", "title", "active", "clearBorder", "forceOverflow", "tabindex"] }, { kind: "directive", type: i6.ToolbarItemDirective, selector: "[fd-toolbar-item]" }, { kind: "component", type: i7.ButtonComponent, selector: "fdp-button", inputs: ["glyphPosition", "label", "glyph", "buttonType", "title", "ariaSelected", "ariaDisabled", "ariaExpanded", "ariaControlsId", "ariaPressed", "name", "type", "value"], outputs: ["buttonClicked"] }, { kind: "component", type: i8.CalendarMonthComponent, selector: "bc-calendar-month", inputs: ["monthWeeksCount", "weekDays", "weekDaysMin", "today", "containerHeight", "days", "calendarFields", "rtl", "deviceSize", "moDataList", "datePicker", "rangePicker", "canDelete", "canAdd", "canEdit", "selectedDate", "startSelectedDayIndex", "endSelectedDayIndex"], outputs: ["editEvent", "deleteEvent", "daySelect", "dayClick", "dayMouseMove", "dayMouseUp", "dayMouseDown", "showEvent"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i2.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
173
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: CalendarSelectionDaysComponent, decorators: [{
|
|
174
|
+
type: Component,
|
|
175
|
+
args: [{ selector: 'bc-calendar-selection-days', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
176
|
+
{
|
|
177
|
+
provide: DateService,
|
|
178
|
+
useFactory: getDateService
|
|
179
|
+
},
|
|
180
|
+
CalendarService
|
|
181
|
+
], template: "<fdp-button glyph=\"calendar\" buttonType=\"transparent\" [fdPopoverTrigger]=\"popover\"></fdp-button>\n<fd-popover #popover [focusTrapped]=\"true\" [focusAutoCapture]=\"true\" [mobile]=\"(deviceSize$ | async) === 's'\">\n <fd-popover-body [style.width.px]=\"width$ | async\">\n <ng-container\n *ngTemplateOutlet=\"\n month;\n context: {\n $implicit: selectedMonth$ | async,\n width: width$ | async,\n height: height,\n rtl: rtl$ | async,\n weekDays: weekDays,\n weekDaysMin: weekDaysMin,\n today: today,\n deviceSize: deviceSize$ | async,\n popover: popover\n }\n \"\n >\n </ng-container>\n </fd-popover-body>\n</fd-popover>\n\n<ng-template\n #month\n let-selectedMonth\n let-width=\"width\"\n let-height=\"height\"\n let-rtl=\"rtl\"\n let-today=\"today\"\n let-showEvents=\"showEvents\"\n let-deviceSize=\"deviceSize\"\n let-popover=\"popover\"\n>\n <fd-toolbar [fdType]=\"'transparent'\">\n <fdp-button fd-toolbar-item [label]=\"'DateR_Today' | bbbTranslate\" (click)=\"onToday()\"></fdp-button>\n <fdp-button\n buttonType=\"transparent\"\n fd-toolbar-item\n [glyph]=\"rtl ? 'navigation-right-arrow' : 'navigation-left-arrow'\"\n (click)=\"onPrevTap()\"\n ></fdp-button>\n <fdp-button\n buttonType=\"transparent\"\n fd-toolbar-item\n [glyph]=\"rtl ? 'navigation-left-arrow' : 'navigation-right-arrow'\"\n (click)=\"onNextTap()\"\n ></fdp-button>\n <div class=\"month-years-wrapper\" fd-title fd-toolbar-item>\n <button\n *ngIf=\"selectionMode === 'day' || selectionMode === 'month'\"\n fd-button\n [fdType]=\"'transparent'\"\n [label]=\"selectedMonth.dateInfo.monthName\"\n (click)=\"selectionMode = 'month'\"\n ></button>\n <button\n fd-button\n [fdType]=\"'transparent'\"\n [label]=\"selectedMonth.dateInfo.year\"\n (click)=\"selectionMode = 'year'\"\n ></button>\n </div>\n </fd-toolbar>\n <ng-container [ngSwitch]=\"selectionMode\">\n <ng-container *ngSwitchCase=\"'month'\">\n <div class=\"month-year-selection-wrapper\">\n <button\n style=\"flex-grow: 1; width: 33%\"\n *ngFor=\"let month of months; let i = index\"\n fd-button\n [fdType]=\"selectedMonth.dateInfo.monthName === month ? 'emphasized' : 'transparent'\"\n [label]=\"month\"\n (click)=\"selectionMode = 'day'; onMonthSelected(month, i)\"\n ></button>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'year'\">\n <div class=\"month-year-selection-wrapper\">\n <button\n style=\"flex-grow: 1; width: 25%\"\n *ngFor=\"let year of years\"\n fd-button\n [fdType]=\"selectedMonth.dateInfo.year === +year ? 'emphasized' : 'transparent'\"\n [label]=\"year\"\n (click)=\"selectionMode = 'day'; onYearSelected(year)\"\n ></button>\n </div>\n </ng-container>\n <bc-calendar-month\n *ngSwitchDefault\n [style.width]=\"width\"\n [containerHeight]=\"height\"\n [containerWidth]=\"width\"\n [rtl]=\"rtl\"\n [monthWeeksCount]=\"6\"\n [weekDays]=\"weekDays\"\n [weekDaysMin]=\"weekDaysMin\"\n [today]=\"today\"\n [datePicker]=\"true\"\n [dateRange]=\"true\"\n [days]=\"selectedMonth.days\"\n [deviceSize]=\"deviceSize\"\n (dayClick)=\"onDayClick($event, selectedMonth, popover)\"\n (dayMouseMove)=\"onDayMouseMove($event, selectedMonth)\"\n (dayMouseUp)=\"onDayMouseUp($event, selectedMonth, popover)\"\n (dayMouseDown)=\"onDayMouseDown($event)\"\n [startSelectedDayIndex]=\"startSelectedDayIndex\"\n [endSelectedDayIndex]=\"endSelectedDayIndex\"\n ></bc-calendar-month>\n </ng-container>\n</ng-template>\n" }]
|
|
182
|
+
}], ctorParameters: function () { return [{ type: i1.CalendarService, decorators: [{
|
|
183
|
+
type: Self
|
|
184
|
+
}] }, { type: i2.PortalService }]; }, propDecorators: { startSelectedDayIndex: [{
|
|
185
|
+
type: Input
|
|
186
|
+
}], endSelectedDayIndex: [{
|
|
187
|
+
type: Input
|
|
188
|
+
}], monthInfo: [{
|
|
189
|
+
type: Input
|
|
190
|
+
}], rangeChange: [{
|
|
191
|
+
type: Output
|
|
192
|
+
}] } });
|
|
193
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-selection-days.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-calendar/src/lib/calendar-selection-days/calendar-selection-days.component.ts","../../../../../projects/barsa-calendar/src/lib/calendar-selection-days/calendar-selection-days.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    EventEmitter,\n    Input,\n    OnChanges,\n    Output,\n    Self,\n    SimpleChanges\n} from '@angular/core';\nimport { Observable } from 'rxjs';\nimport { distinctUntilChanged, map } from 'rxjs/operators';\nimport { BaseComponent, DateService, getDateService, PortalService } from 'barsa-novin-ray-core';\nimport { CalendarMonthInfo, Day } from '../models';\nimport { CalendarService } from '../services/calendar.service';\n@Component({\n    selector: 'bc-calendar-selection-days',\n    templateUrl: './calendar-selection-days.component.html',\n    styleUrls: ['./calendar-selection-days.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        {\n            provide: DateService,\n            useFactory: getDateService\n        },\n        CalendarService\n    ]\n})\nexport class CalendarSelectionDaysComponent extends BaseComponent implements OnChanges {\n    @Input() startSelectedDayIndex: number | undefined;\n    @Input() endSelectedDayIndex: number | undefined;\n    @Input() monthInfo: CalendarMonthInfo;\n    @Output() rangeChange = new EventEmitter<{\n        startDay: Day;\n        endDay: Day;\n        monthInfo: CalendarMonthInfo;\n    }>();\n    selectionMode: 'day' | 'month' | 'year' = 'day';\n\n    endSelectedDay: Day | null;\n    startSelectedDay: Day | null;\n    width$: Observable<number>;\n    height: number;\n    selectedMonth$: Observable<CalendarMonthInfo>;\n    rtl$: Observable<boolean>;\n    today: Date;\n    weekDaysMin: string[];\n    weekDays: string[];\n    deviceSize$: Observable<string>;\n    months: string[] = [];\n    years: string[];\n    private _isMouseDown = false;\n    constructor(@Self() private _calendarService: CalendarService, _portalService: PortalService) {\n        super();\n        this.rtl$ = _portalService.rtl$;\n        this.width$ = _portalService.deviceSize$.pipe(\n            distinctUntilChanged(),\n            map((deviceSize) => {\n                switch (deviceSize) {\n                    case 'l':\n                    case 'xl':\n                        return 480;\n                    case 's':\n                        return 320;\n                    default:\n                        return 480;\n                }\n            })\n        );\n        this.weekDaysMin = this._calendarService.weekDaysMin();\n        this.weekDays = this._calendarService.weekDays();\n        this.selectedMonth$ = this._calendarService.selected$;\n        this.today = this._calendarService.today;\n        this.months = this._calendarService.Months;\n        this._prepareYear(this._calendarService.selectedMonth.dateInfo.year);\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        super.ngOnChanges(changes);\n        const { monthInfo } = changes;\n        if (monthInfo) {\n            this._calendarService.loadCalendarMonthInfo(monthInfo.currentValue);\n        }\n    }\n    onMonthSelected(monthName: string, index: number): void {\n        this._calendarService.gotoMonth(monthName, index);\n    }\n    onYearSelected(year: string): void {\n        this._calendarService.gotoYear(+year);\n    }\n\n    onPrevTap(): void {\n        if (this.selectionMode === 'day') {\n            this._calendarService.loadPrevious();\n        } else if (this.selectionMode === 'month') {\n            this._calendarService.loadPrevYear();\n        } else if (this.selectionMode === 'year') {\n            this._prepareYear(Number(this.years[0]) - 20);\n        }\n    }\n\n    onNextTap(): void {\n        if (this.selectionMode === 'day') {\n            this._calendarService.loadNext();\n        } else if (this.selectionMode === 'month') {\n            this._calendarService.loadNextYear();\n        } else if (this.selectionMode === 'year') {\n            this._prepareYear(Number(this.years[this.years.length - 1]) + 1);\n        }\n    }\n\n    onToday(): void {\n        this._calendarService.gotoToday();\n    }\n    onDayMouseMove(day: Day, monthInfo: CalendarMonthInfo): void {\n        if (this._isMouseDown) {\n            const { endDay, startDay } = this.getStartAndEndDay(monthInfo, day);\n            this.startSelectedDayIndex = startDay?.index;\n            this.endSelectedDayIndex = endDay?.index;\n            console.log('-move-', this.startSelectedDay?.index, this.endSelectedDay?.index);\n        }\n    }\n\n    onDayMouseDown(day: Day): void {\n        this._isMouseDown = true;\n        this.startSelectedDay = null;\n        this.endSelectedDay = null;\n        this.startSelectedDay = day;\n        this.startSelectedDayIndex = day.index;\n    }\n    onDayMouseUp(day: Day, monthInfo, popover): void {\n        this._isMouseDown = false;\n\n        const { endDay, startDay } = this.getStartAndEndDay(monthInfo, day);\n        this.startSelectedDay = startDay;\n        this.endSelectedDay = endDay;\n        this._setFirstAndEndDay(monthInfo, popover);\n    }\n    onDayClick(day: Day, monthInfo, popover): void {\n        this.startSelectedDay = this.endSelectedDay = day;\n        this._setFirstAndEndDay(monthInfo, popover);\n    }\n    private _prepareYear(from: number): void {\n        const years: string[] = [];\n        for (let i = 0; i < 20; i++) {\n            years.push(`${from + i}`);\n        }\n        this.years = years;\n    }\n    private getStartAndEndDay(\n        monthInfo: CalendarMonthInfo,\n        day: Day | null\n    ): { endDay: Day | null; startDay: Day | null } {\n        let startDay: Day | null = null;\n        let endDay: Day | null = null;\n        if (this.startSelectedDay && !this.endSelectedDay) {\n            if (day && this.startSelectedDay.date > day.date) {\n                startDay = day;\n                endDay = this.startSelectedDay;\n            } else {\n                startDay = this.startSelectedDay;\n                endDay = day;\n            }\n        } else if (this.startSelectedDay && this.endSelectedDay) {\n            if (day && this.startSelectedDay.date < day.date) {\n                startDay = this.startSelectedDay;\n                endDay = day;\n            } else {\n                startDay = day;\n                endDay = this.endSelectedDay;\n            }\n        }\n        console.log('-2-', startDay, endDay);\n        if (startDay && endDay) {\n            const diff = Math.abs(startDay.momentOfDate.diff(endDay.momentOfDate, 'day'));\n            if (diff > 6) {\n                startDay = monthInfo.days[Math.floor(startDay.index / 7) * 7];\n                // const end = endDay.index % 7;\n                const indexEnd = Math.ceil((endDay.index + 1) / 7);\n                // if (end > 0) {\n                //     indexEnd++;\n                // }\n                endDay = monthInfo.days[indexEnd * 7 - 1];\n                console.log('-3-', startDay, endDay);\n            }\n        }\n        return { endDay, startDay };\n    }\n\n    private _setFirstAndEndDay(monthInfo, popover): void {\n        console.log('-finish-', this.startSelectedDay, this.endSelectedDay);\n        if (this.startSelectedDay && this.endSelectedDay) {\n            if (popover) {\n                popover.close();\n            }\n            this.rangeChange.emit({\n                startDay: this.startSelectedDay,\n                endDay: this.endSelectedDay,\n                monthInfo\n            });\n        }\n    }\n}\n","<fdp-button glyph=\"calendar\" buttonType=\"transparent\" [fdPopoverTrigger]=\"popover\"></fdp-button>\n<fd-popover #popover [focusTrapped]=\"true\" [focusAutoCapture]=\"true\" [mobile]=\"(deviceSize$ | async) === 's'\">\n    <fd-popover-body [style.width.px]=\"width$ | async\">\n        <ng-container\n            *ngTemplateOutlet=\"\n                month;\n                context: {\n                    $implicit: selectedMonth$ | async,\n                    width: width$ | async,\n                    height: height,\n                    rtl: rtl$ | async,\n                    weekDays: weekDays,\n                    weekDaysMin: weekDaysMin,\n                    today: today,\n                    deviceSize: deviceSize$ | async,\n                    popover: popover\n                }\n            \"\n        >\n        </ng-container>\n    </fd-popover-body>\n</fd-popover>\n\n<ng-template\n    #month\n    let-selectedMonth\n    let-width=\"width\"\n    let-height=\"height\"\n    let-rtl=\"rtl\"\n    let-today=\"today\"\n    let-showEvents=\"showEvents\"\n    let-deviceSize=\"deviceSize\"\n    let-popover=\"popover\"\n>\n    <fd-toolbar [fdType]=\"'transparent'\">\n        <fdp-button fd-toolbar-item [label]=\"'DateR_Today' | bbbTranslate\" (click)=\"onToday()\"></fdp-button>\n        <fdp-button\n            buttonType=\"transparent\"\n            fd-toolbar-item\n            [glyph]=\"rtl ? 'navigation-right-arrow' : 'navigation-left-arrow'\"\n            (click)=\"onPrevTap()\"\n        ></fdp-button>\n        <fdp-button\n            buttonType=\"transparent\"\n            fd-toolbar-item\n            [glyph]=\"rtl ? 'navigation-left-arrow' : 'navigation-right-arrow'\"\n            (click)=\"onNextTap()\"\n        ></fdp-button>\n        <div class=\"month-years-wrapper\" fd-title fd-toolbar-item>\n            <button\n                *ngIf=\"selectionMode === 'day' || selectionMode === 'month'\"\n                fd-button\n                [fdType]=\"'transparent'\"\n                [label]=\"selectedMonth.dateInfo.monthName\"\n                (click)=\"selectionMode = 'month'\"\n            ></button>\n            <button\n                fd-button\n                [fdType]=\"'transparent'\"\n                [label]=\"selectedMonth.dateInfo.year\"\n                (click)=\"selectionMode = 'year'\"\n            ></button>\n        </div>\n    </fd-toolbar>\n    <ng-container [ngSwitch]=\"selectionMode\">\n        <ng-container *ngSwitchCase=\"'month'\">\n            <div class=\"month-year-selection-wrapper\">\n                <button\n                    style=\"flex-grow: 1; width: 33%\"\n                    *ngFor=\"let month of months; let i = index\"\n                    fd-button\n                    [fdType]=\"selectedMonth.dateInfo.monthName === month ? 'emphasized' : 'transparent'\"\n                    [label]=\"month\"\n                    (click)=\"selectionMode = 'day'; onMonthSelected(month, i)\"\n                ></button>\n            </div>\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'year'\">\n            <div class=\"month-year-selection-wrapper\">\n                <button\n                    style=\"flex-grow: 1; width: 25%\"\n                    *ngFor=\"let year of years\"\n                    fd-button\n                    [fdType]=\"selectedMonth.dateInfo.year === +year ? 'emphasized' : 'transparent'\"\n                    [label]=\"year\"\n                    (click)=\"selectionMode = 'day'; onYearSelected(year)\"\n                ></button>\n            </div>\n        </ng-container>\n        <bc-calendar-month\n            *ngSwitchDefault\n            [style.width]=\"width\"\n            [containerHeight]=\"height\"\n            [containerWidth]=\"width\"\n            [rtl]=\"rtl\"\n            [monthWeeksCount]=\"6\"\n            [weekDays]=\"weekDays\"\n            [weekDaysMin]=\"weekDaysMin\"\n            [today]=\"today\"\n            [datePicker]=\"true\"\n            [dateRange]=\"true\"\n            [days]=\"selectedMonth.days\"\n            [deviceSize]=\"deviceSize\"\n            (dayClick)=\"onDayClick($event, selectedMonth, popover)\"\n            (dayMouseMove)=\"onDayMouseMove($event, selectedMonth)\"\n            (dayMouseUp)=\"onDayMouseUp($event, selectedMonth, popover)\"\n            (dayMouseDown)=\"onDayMouseDown($event)\"\n            [startSelectedDayIndex]=\"startSelectedDayIndex\"\n            [endSelectedDayIndex]=\"endSelectedDayIndex\"\n        ></bc-calendar-month>\n    </ng-container>\n</ng-template>\n"]}
|