@sedeh/into-pipes
Version:
Have you ever wanted to transform data in different parts of your application into interactive objects without writing a single line of code?
304 lines • 46.9 kB
JavaScript
/* calendar code is copied from "ben tedder"
* http://www.bentedder.com/create-calendar-grid-component-angular-4/
*/
import { Component, Output, EventEmitter } from '@angular/core';
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
export class CalendarComponent {
constructor(renderer) {
this.renderer = renderer;
this.showCalendar = false;
this.editName = false;
this.multiselect = false;
this.disabled = false;
this.active = true;
this.validate = (item, newValue) => true;
this.dayNames = ['S', 'M', 'T', 'W', 'T', 'F', 'S'];
this.weeks = [];
this.selectedDays = [];
this.onIntoComponentChange = new EventEmitter();
}
keyup(event) {
event.stopPropagation();
event.preventDefault();
const code = event.which;
if (code === 13 && !this.disabled) {
event.target.click();
}
}
popdatepicker(event) {
event.stopPropagation();
event.preventDefault();
this.showCalendar = !this.showCalendar;
}
static settingsPatterns() {
return ['calendar:MM/dd/yyyy']; //date format
}
transform(source, data, args) {
this.source = source;
this.currentDate = new Date(source);
this.origDate = new Date(source);
if (source instanceof Array) {
this.multiselect = true;
source.map((item) => {
this.selectedDays.push(new Date(item));
});
}
else {
this.multiselect = false;
this.selectedDays.push(new Date(this.source));
}
this.item = data;
this.generateCalendar();
this.formatting = (args && args.length) ? args[0] : "";
}
isSelected(date) {
let index = -1;
for (let i = 0; i < this.selectedDays.length; i++) {
const selectedDate = this.selectedDays[i];
if (this.isSameDay(date, selectedDate)) {
index = i;
}
}
return index > -1;
}
isSelectedMonth(date) {
return this.isSameMonth(date, this.currentDate);
}
toggleSelectedDates(day) {
let found = false;
if (this.multiselect) {
for (let i = 0; i < this.selectedDays.length; i++) {
const date = this.selectedDays[i];
if (this.isSameDay(day.date, date)) {
this.selectedDays.splice(i, 1);
found = true;
day.selected = false;
break;
}
}
if (!found) {
this.selectedDays.push(day.date);
day.selected = true;
}
}
else {
this.selectedDays = [day.date];
day.selected = true;
}
}
selectDate(event, day) {
event.stopPropagation();
event.preventDefault();
if (this.validate(this.item, day.date)) {
this.origDate = day.date;
this.currentDate = day.date;
this.toggleSelectedDates(day);
this.selectedDays.sort((a, b) => {
return a > b ? -1 : 1;
});
this.onIntoComponentChange.emit({
id: this.id,
name: this.name,
value: this.selectedDays,
type: "select",
item: this.item
});
this.generateCalendar();
}
this.showCalendar = false;
}
// actions from calendar
prevMonth(event) {
event.stopPropagation();
event.preventDefault();
this.currentDate = new Date(this.currentDate.getFullYear(), this.currentDate.getMonth() - 1, this.currentDate.getDate());
this.generateCalendar();
}
nextMonth(event) {
event.stopPropagation();
event.preventDefault();
this.currentDate = new Date(this.currentDate.getFullYear(), this.currentDate.getMonth() + 1, this.currentDate.getDate());
this.generateCalendar();
}
prevYear(event) {
event.stopPropagation();
event.preventDefault();
this.currentDate = new Date(this.currentDate.getFullYear() - 1, this.currentDate.getMonth(), this.currentDate.getDate());
this.generateCalendar();
}
nextYear(event) {
event.stopPropagation();
event.preventDefault();
this.currentDate = new Date(this.currentDate.getFullYear() + 1, this.currentDate.getMonth(), this.currentDate.getDate());
this.generateCalendar();
}
// generate the calendar grid
generateCalendar() {
const dates = this.fillDates(this.currentDate);
const weeks = [];
while (dates.length > 0) {
weeks.push(dates.splice(0, 7));
}
this.weeks = weeks;
}
isSameDay(a, b) {
return a.getFullYear() === b.getFullYear() &&
a.getMonth() === b.getMonth() &&
a.getDate() === b.getDate();
}
isSameMonth(a, b) {
return a.getYear() === b.getYear() &&
a.getMonth() === b.getMonth();
}
fillDates(currentDate) {
const cm = new Date(currentDate);
const tm = new Date();
const firstDay = new Date(cm.getFullYear(), cm.getMonth(), 1);
const firstOfMonth = firstDay.getDay();
const firstDayOfGrid = new Date(firstDay.getFullYear(), firstDay.getMonth(), firstDay.getDate() - firstOfMonth);
const start = firstDayOfGrid.getDate();
const list = [];
for (let i = start; i < (start + 42); i++) {
const d = new Date(firstDayOfGrid.getFullYear(), firstDayOfGrid.getMonth(), i);
list.push({
today: this.isSameDay(tm, d),
selected: this.isSelected(d),
date: d
});
}
return list;
}
}
CalendarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CalendarComponent, deps: [{ token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
CalendarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: CalendarComponent, selector: "calendar-component", outputs: { onIntoComponentChange: "onIntoComponentChange" }, ngImport: i0, template: `
<span class="calendar-box">
<span class="date" [textContent]="origDate | date:formatting"></span>
<a
tabindex="{{active ? 0 : -1}}"
class="popper {{disabled ? 'disabled': ''}}"
(keyup)="keyup($event)"
(click)="popdatepicker($event)">
<span class="fa fa-calendar" aria-hidden="true"></span>
<span class="off-screen">Pick a date</span>
</a>
</span>
<div class="calendar" *ngIf="!disabled && showCalendar">
<div class="calendar-navs">
<div class="month-nav">
<button (click)="prevMonth($event)">
<span class="fa fa-chevron-left"></span>
<span class="off-screen">Back a month</span>
</button>
<span class="p4">{{ currentDate | date:'MMMM' }}</span>
<button (click)="nextMonth($event)">
<span class="fa fa-chevron-right"></span>
<span class="off-screen">Forward a month</span>
</button>
</div>
<div class="year-nav">
<button (click)="prevYear($event)">
<span class="fa fa-chevron-left"></span>
<span class="off-screen">Back a year</span>
</button>
<span>{{ currentDate | date: 'yyyy' }}</span>
<button (click)="nextYear($event)">
<span class="fa fa-chevron-right"></span>
<span class="off-screen">Forward a year</span>
</button>
</div>
</div>
<div class="month-grid">
<div class="day-names">
<div *ngFor="let name of dayNames" class="day-name p9">{{ name }}</div>
</div>
<div class="weeks">
<div *ngFor="let week of weeks" class="week">
<ng-container *ngFor="let day of week">
<div class="week-date disabled" *ngIf="!isSelectedMonth(day.date)">
<span class="date-text">{{ day.date.getDate() }}</span>
</div>
<div class="week-date enabled"
*ngIf="isSelectedMonth(day.date)"
tabindex="{{active ? 0 : -1}}"
(keyup)="keyup($event)"
(click)="selectDate($event, day)"
[class.today]="day.today"
[class.selected]="day.selected">
<span class="date-text">{{ day.date.getDate() }}</span>
</div>
</ng-container>
</div>
</div>
</div>
</div>
`, isInline: true, styles: [":host{display:table;float:left;min-height:var(--sedeh-min-height, 25px)}.popper .fa-calendar{display:inline-block;margin:var(--sedeh-margin, 0 5px)}.popper:hover .fa-calendar{color:var(--sedeh-hover-opacity, .5)}.popper:focus{outline:none}.popper:focus .fa{zoom:1.1;right:var(--sedeh-shift-right, 0);position:relative;color:var(--sedeh-focus-color, darkblue)}.popper.disabled .fa-calendar{color:var(--sedeh-disabled-color, #888)}.popper.disabled:hover .fa-calendar{cursor:default;color:var(--sedeh-disabled-color, #888)}.popper.disabled{color:var(--sedeh-disabled-color, #888);pointer-events:none;cursor:default;text-decoration:none}.calendar-box{display:flex;flex-direction:row;cursor:default;width:100%;display:inline-block}.calendar-box date{flex:1}.calendar-box .popper{cursor:pointer;flex:0 0 15px}.calendar{display:table;width:210px;position:absolute;background-color:#fff;z-index:2;border:1px solid #ddd;border-radius:4px;box-shadow:var(--sedeh-box-shadow, 3px 3px 3px #999)}.calendar *{box-sizing:border-box}.calendar .calendar-navs{background-color:#f5f5f5}.calendar .month-nav,.calendar .year-nav{padding:2px;display:flex;flex-direction:row;justify-content:space-between}.calendar .month-nav button,.calendar .year-nav button{border:0;background:transparent;cursor:pointer}.calendar .month-nav button:hover,.calendar .year-nav button:hover{color:red}.calendar .month-grid .day-names{display:flex;flex-direction:row;background:whitesmoke;border-bottom-right-radius:3px;border-bottom-left-radius:3px}.calendar .month-grid .weeks{display:flex;flex-direction:column}.calendar .month-grid .week{display:flex;flex-direction:row}.calendar .month-grid .day-names{border-top:1px dotted #ddd;border-bottom:1px dashed #ddd}.calendar .month-grid .week-date,.calendar .month-grid .day-name{text-align:center;padding:2px;display:block;width:30px;display:flex;justify-content:center;align-items:center}.calendar .month-grid .week-date{height:30px;position:relative;padding:5px}.calendar .month-grid .week-date .date-text{font-size:10px;z-index:10}.calendar .month-grid .week-date:after{content:\"\";height:24px;width:24px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:50%;transition:background-color .15s linear,color .15s linear;z-index:1}.calendar .month-grid .week-date.disabled{color:#aaa}.calendar .month-grid .week-date.enabled{cursor:pointer}.calendar .month-grid .week-date.enabled:focus{outline:0}.calendar .month-grid .week-date.enabled:hover .date-text,.calendar .month-grid .week-date.enabled:focus .date-text{font-weight:700;color:#00f}.calendar .month-grid .week-date.enabled:hover:after,.calendar .month-grid .week-date.enabled:focus:after{background-color:#f5f5f5}.calendar .month-grid .week-date.selected .date-text{color:#fff!important}.calendar .month-grid .week-date.selected:after{background-color:#00f!important}.calendar .month-grid .week-date.today:after{background-color:#add8e6;font-weight:700;color:#fff}@media print{.calendar-box .popper{display:none}}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i1.DatePipe, name: "date" }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CalendarComponent, decorators: [{
type: Component,
args: [{ selector: 'calendar-component', template: `
<span class="calendar-box">
<span class="date" [textContent]="origDate | date:formatting"></span>
<a
tabindex="{{active ? 0 : -1}}"
class="popper {{disabled ? 'disabled': ''}}"
(keyup)="keyup($event)"
(click)="popdatepicker($event)">
<span class="fa fa-calendar" aria-hidden="true"></span>
<span class="off-screen">Pick a date</span>
</a>
</span>
<div class="calendar" *ngIf="!disabled && showCalendar">
<div class="calendar-navs">
<div class="month-nav">
<button (click)="prevMonth($event)">
<span class="fa fa-chevron-left"></span>
<span class="off-screen">Back a month</span>
</button>
<span class="p4">{{ currentDate | date:'MMMM' }}</span>
<button (click)="nextMonth($event)">
<span class="fa fa-chevron-right"></span>
<span class="off-screen">Forward a month</span>
</button>
</div>
<div class="year-nav">
<button (click)="prevYear($event)">
<span class="fa fa-chevron-left"></span>
<span class="off-screen">Back a year</span>
</button>
<span>{{ currentDate | date: 'yyyy' }}</span>
<button (click)="nextYear($event)">
<span class="fa fa-chevron-right"></span>
<span class="off-screen">Forward a year</span>
</button>
</div>
</div>
<div class="month-grid">
<div class="day-names">
<div *ngFor="let name of dayNames" class="day-name p9">{{ name }}</div>
</div>
<div class="weeks">
<div *ngFor="let week of weeks" class="week">
<ng-container *ngFor="let day of week">
<div class="week-date disabled" *ngIf="!isSelectedMonth(day.date)">
<span class="date-text">{{ day.date.getDate() }}</span>
</div>
<div class="week-date enabled"
*ngIf="isSelectedMonth(day.date)"
tabindex="{{active ? 0 : -1}}"
(keyup)="keyup($event)"
(click)="selectDate($event, day)"
[class.today]="day.today"
[class.selected]="day.selected">
<span class="date-text">{{ day.date.getDate() }}</span>
</div>
</ng-container>
</div>
</div>
</div>
</div>
`, styles: [":host{display:table;float:left;min-height:var(--sedeh-min-height, 25px)}.popper .fa-calendar{display:inline-block;margin:var(--sedeh-margin, 0 5px)}.popper:hover .fa-calendar{color:var(--sedeh-hover-opacity, .5)}.popper:focus{outline:none}.popper:focus .fa{zoom:1.1;right:var(--sedeh-shift-right, 0);position:relative;color:var(--sedeh-focus-color, darkblue)}.popper.disabled .fa-calendar{color:var(--sedeh-disabled-color, #888)}.popper.disabled:hover .fa-calendar{cursor:default;color:var(--sedeh-disabled-color, #888)}.popper.disabled{color:var(--sedeh-disabled-color, #888);pointer-events:none;cursor:default;text-decoration:none}.calendar-box{display:flex;flex-direction:row;cursor:default;width:100%;display:inline-block}.calendar-box date{flex:1}.calendar-box .popper{cursor:pointer;flex:0 0 15px}.calendar{display:table;width:210px;position:absolute;background-color:#fff;z-index:2;border:1px solid #ddd;border-radius:4px;box-shadow:var(--sedeh-box-shadow, 3px 3px 3px #999)}.calendar *{box-sizing:border-box}.calendar .calendar-navs{background-color:#f5f5f5}.calendar .month-nav,.calendar .year-nav{padding:2px;display:flex;flex-direction:row;justify-content:space-between}.calendar .month-nav button,.calendar .year-nav button{border:0;background:transparent;cursor:pointer}.calendar .month-nav button:hover,.calendar .year-nav button:hover{color:red}.calendar .month-grid .day-names{display:flex;flex-direction:row;background:whitesmoke;border-bottom-right-radius:3px;border-bottom-left-radius:3px}.calendar .month-grid .weeks{display:flex;flex-direction:column}.calendar .month-grid .week{display:flex;flex-direction:row}.calendar .month-grid .day-names{border-top:1px dotted #ddd;border-bottom:1px dashed #ddd}.calendar .month-grid .week-date,.calendar .month-grid .day-name{text-align:center;padding:2px;display:block;width:30px;display:flex;justify-content:center;align-items:center}.calendar .month-grid .week-date{height:30px;position:relative;padding:5px}.calendar .month-grid .week-date .date-text{font-size:10px;z-index:10}.calendar .month-grid .week-date:after{content:\"\";height:24px;width:24px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:50%;transition:background-color .15s linear,color .15s linear;z-index:1}.calendar .month-grid .week-date.disabled{color:#aaa}.calendar .month-grid .week-date.enabled{cursor:pointer}.calendar .month-grid .week-date.enabled:focus{outline:0}.calendar .month-grid .week-date.enabled:hover .date-text,.calendar .month-grid .week-date.enabled:focus .date-text{font-weight:700;color:#00f}.calendar .month-grid .week-date.enabled:hover:after,.calendar .month-grid .week-date.enabled:focus:after{background-color:#f5f5f5}.calendar .month-grid .week-date.selected .date-text{color:#fff!important}.calendar .month-grid .week-date.selected:after{background-color:#00f!important}.calendar .month-grid .week-date.today:after{background-color:#add8e6;font-weight:700;color:#fff}@media print{.calendar-box .popper{display:none}}\n"] }]
}], ctorParameters: function () { return [{ type: i0.Renderer2 }]; }, propDecorators: { onIntoComponentChange: [{
type: Output,
args: ["onIntoComponentChange"]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar.component.js","sourceRoot":"","sources":["../../../../../projects/into-pipes/src/lib/calendar/calendar.component.ts"],"names":[],"mappings":"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","sourcesContent":["/* calendar code is copied from \"ben tedder\" \r\n* http://www.bentedder.com/create-calendar-grid-component-angular-4/\r\n*/\r\nimport { Component, ViewChild, Renderer2, Output, EventEmitter } from '@angular/core';\r\nimport { PipeComponentInterface } from '../common/pipe.component.interface';\r\n\r\nexport interface CalendarDateInterface {\r\n    date: Date;\r\n    selected?: boolean;\r\n    today?: boolean;\r\n  }\r\n  \r\n@Component({\r\n    selector: 'calendar-component',\r\n    template: `\r\n    <span class=\"calendar-box\">\r\n      <span class=\"date\" [textContent]=\"origDate | date:formatting\"></span>\r\n      <a \r\n        tabindex=\"{{active ? 0 : -1}}\" \r\n        class=\"popper {{disabled ? 'disabled': ''}}\" \r\n        (keyup)=\"keyup($event)\" \r\n        (click)=\"popdatepicker($event)\">\r\n          <span class=\"fa fa-calendar\" aria-hidden=\"true\"></span>\r\n          <span class=\"off-screen\">Pick a date</span>\r\n      </a>\r\n    </span>\r\n    <div class=\"calendar\" *ngIf=\"!disabled && showCalendar\">\r\n\t\t<div class=\"calendar-navs\">\r\n\t\t\t<div class=\"month-nav\">\r\n                <button (click)=\"prevMonth($event)\">\r\n                    <span class=\"fa fa-chevron-left\"></span>\r\n                    <span class=\"off-screen\">Back a month</span>\r\n                </button>\r\n\t\t\t\t<span class=\"p4\">{{ currentDate | date:'MMMM' }}</span>\r\n                <button (click)=\"nextMonth($event)\">\r\n                    <span class=\"fa fa-chevron-right\"></span>\r\n                    <span class=\"off-screen\">Forward a month</span>\r\n                </button>\r\n\t\t\t</div>\r\n\t\t\t<div class=\"year-nav\">\r\n                <button (click)=\"prevYear($event)\">\r\n                    <span class=\"fa fa-chevron-left\"></span>\r\n                    <span class=\"off-screen\">Back a year</span>\r\n                </button>\r\n\t\t\t\t<span>{{ currentDate | date: 'yyyy' }}</span>\r\n                <button (click)=\"nextYear($event)\">\r\n                    <span class=\"fa fa-chevron-right\"></span>\r\n                    <span class=\"off-screen\">Forward a year</span>\r\n                </button>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\t\t<div class=\"month-grid\">\r\n\t\t\t<div class=\"day-names\">\r\n\t\t\t\t<div *ngFor=\"let name of dayNames\" class=\"day-name p9\">{{ name }}</div>\r\n\t\t\t</div>\r\n\t\t\t<div class=\"weeks\">\r\n\t\t\t\t<div *ngFor=\"let week of weeks\" class=\"week\">\r\n\t\t\t\t\t<ng-container *ngFor=\"let day of week\">\r\n\t\t\t\t\t\t<div class=\"week-date disabled\" *ngIf=\"!isSelectedMonth(day.date)\">\r\n\t\t\t\t\t\t\t<span class=\"date-text\">{{ day.date.getDate() }}</span>\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t\t<div class=\"week-date enabled\"\r\n                           *ngIf=\"isSelectedMonth(day.date)\"\r\n                           tabindex=\"{{active ? 0 : -1}}\"\r\n                           (keyup)=\"keyup($event)\"\r\n\t\t\t\t\t\t   (click)=\"selectDate($event, day)\"\r\n\t\t\t\t\t\t   [class.today]=\"day.today\"\r\n\t\t\t\t\t\t   [class.selected]=\"day.selected\">\r\n\t\t\t\t\t\t\t<span class=\"date-text\">{{ day.date.getDate() }}</span>\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t</ng-container>\r\n\t\t\t\t</div>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\t</div>\r\n    `,\r\n    styles: [\r\n        `\r\n        :host {display:table;float:left;min-height: var(--sedeh-min-height, 25px);}\r\n        .popper .fa-calendar{display: inline-block;margin: var(--sedeh-margin, 0 5px);}\r\n        .popper:hover .fa-calendar{color: var(--sedeh-hover-opacity, 0.5);}\r\n        .popper:focus {outline: none;}\r\n        .popper:focus .fa{zoom: 1.1;right: var(--sedeh-shift-right, 0);position: relative;color: var(--sedeh-focus-color, darkblue);}\r\n        .popper.disabled .fa-calendar{color: var(--sedeh-disabled-color, #888);}\r\n        .popper.disabled:hover .fa-calendar{cursor:default;color: var(--sedeh-disabled-color, #888);}\r\n        .popper.disabled{color: var(--sedeh-disabled-color, #888);pointer-events:none;cursor:default;text-decoration: none;}\r\n        .calendar-box {\r\n          display: flex;\r\n          flex-direction: row;\r\n          cursor: default;\r\n          width: 100%;\r\n          display: inline-block;\r\n        }\r\n        .calendar-box date {flex: 1;}\r\n        .calendar-box .popper {cursor: pointer;flex: 0 0 15px}\r\n        .calendar {\r\n            display: table;\r\n            width: 210px;\r\n            position: absolute;\r\n            background-color: #fff;\r\n            z-index: 2;\r\n            border: 1px solid #ddd;\r\n            border-radius: 4px;\r\n            box-shadow: var(--sedeh-box-shadow, 3px 3px 3px #999);\r\n        }\r\n        .calendar * {\r\n            box-sizing: border-box;\r\n        }\r\n        .calendar .calendar-navs {\r\n            background-color: whitesmoke;\r\n        }\r\n        .calendar .month-nav {\r\n            padding: 2px;\r\n            display: flex;\r\n            flex-direction: row;\r\n            justify-content: space-between;\r\n        }\r\n        .calendar .year-nav {\r\n            padding: 2px;\r\n            display: flex;\r\n            flex-direction: row;\r\n            justify-content: space-between;\r\n        }\r\n        .calendar .month-nav button,\r\n        .calendar .year-nav button {\r\n            border: 0;\r\n            background: transparent;\r\n            cursor: pointer;\r\n        }\r\n        .calendar .month-nav button:hover,\r\n        .calendar .year-nav button:hover {\r\n            color: red;\r\n        }\r\n        .calendar .month-grid .day-names {\r\n            display: flex;\r\n            flex-direction: row;\r\n            background: whitesmoke;\r\n            border-bottom-right-radius: 3px;\r\n            border-bottom-left-radius: 3px;\r\n        }\r\n        .calendar .month-grid .weeks {\r\n            display: flex;\r\n            flex-direction: column;\r\n        }\r\n        .calendar .month-grid .week {\r\n            display: flex;\r\n            flex-direction: row;\r\n        }\r\n        .calendar .month-grid .day-names {\r\n            border-top: 1px dotted #ddd;\r\n            border-bottom: 1px dashed #ddd;\r\n        }\r\n        .calendar .month-grid .week-date,\r\n        .calendar .month-grid .day-name {\r\n            text-align: center;\r\n            padding: 2px;\r\n            display: block;\r\n            width: 30px;\r\n            display: flex;\r\n            justify-content: center;\r\n            align-items: center;\r\n        }\r\n        .calendar .month-grid .week-date {\r\n            height: 30px;\r\n            position: relative;\r\n            padding: 5px;\r\n        }\r\n        .calendar .month-grid .week-date .date-text {\r\n            font-size: 10px;\r\n            z-index: 10;\r\n        }\r\n        .calendar .month-grid .week-date::after {\r\n            content: '';\r\n            height: 24px;\r\n            width: 24px;\r\n            position: absolute;\r\n            top: 50%;\r\n            left: 50%;\r\n            transform: translate(-50%, -50%);\r\n            border-radius: 50%;\r\n            transition: background-color 150ms linear, color 150ms linear;\r\n            z-index: 1;\r\n        }\r\n        .calendar .month-grid .week-date.disabled {color: #aaa;}\r\n        .calendar .month-grid .week-date.enabled {\r\n            cursor: pointer;\r\n        }\r\n        .calendar .month-grid .week-date.enabled:focus {\r\n            outline: 0;\r\n        }\r\n        .calendar .month-grid .week-date.enabled:hover .date-text,\r\n        .calendar .month-grid .week-date.enabled:focus .date-text {\r\n            font-weight: bold;\r\n            color: blue;\r\n        }\r\n        .calendar .month-grid .week-date.enabled:hover::after,\r\n        .calendar .month-grid .week-date.enabled:focus::after {\r\n            background-color: whitesmoke;\r\n        }\r\n        .calendar .month-grid .week-date.selected .date-text {\r\n            color: #fff !important;\r\n        }\r\n        .calendar .month-grid .week-date.selected::after{\r\n            background-color: blue !important;\r\n        }\r\n        .calendar .month-grid .week-date.today::after {\r\n            background-color: lightblue;\r\n            font-weight: bold;\r\n            color: #fff;\r\n        }\r\n        @media print {\r\n            .calendar-box .popper {\r\n                display: none;\r\n            }\r\n        }\r\n        `\r\n    ]\r\n})\r\nexport class CalendarComponent implements PipeComponentInterface {\r\n\r\n  source!: Date;\r\n  id!: string;\r\n  name!: string;\r\n  item: any;\r\n  showCalendar = false;\r\n  formatting!:string;\r\n  editName = false;\r\n  multiselect = false;\r\n  disabled = false;\r\n  active = true;\r\n  validate = (item: any, newValue: any) => true;\r\n\r\n  origDate!: Date;\r\n  currentDate!: Date;\r\n  dayNames = ['S', 'M', 'T', 'W', 'T', 'F', 'S'];\r\n  weeks: CalendarDateInterface[][] = [];\r\n  selectedDays: Date[] = [];\r\n\r\n  @Output(\"onIntoComponentChange\")\r\n  onIntoComponentChange = new EventEmitter();\r\n\r\n  constructor(private renderer: Renderer2) {\r\n\r\n  }\r\n\r\n  keyup(event: any) {\r\n    event.stopPropagation();\r\n    event.preventDefault();\r\n\r\n    const code = event.which;\r\n    if (code === 13 && !this.disabled) {\r\n        event.target.click();\r\n    }\r\n  }\r\n  popdatepicker(event: any) {\r\n    event.stopPropagation();\r\n    event.preventDefault();\r\n\r\n    this.showCalendar = !this.showCalendar;\r\n  }\r\n\r\n  static settingsPatterns() {\r\n    return ['calendar:MM/dd/yyyy']; //date format\r\n  }\r\n  transform(source: Date, data: any, args?: any[]) {\r\n    this.source= source;\r\n    this.currentDate = new Date(source);\r\n    this.origDate =  new Date(source);\r\n\r\n    if (source instanceof Array) {\r\n        this.multiselect = true;\r\n        source.map( (item) => {\r\n            this.selectedDays.push(new Date(item));\r\n        })\r\n    } else {\r\n        this.multiselect = false;\r\n        this.selectedDays.push(new Date(this.source));\r\n    }\r\n    this.item = data;\r\n    this.generateCalendar();\r\n    this.formatting= (args && args.length) ? args[0] : \"\";\r\n  }\r\n\r\n  isSelected(date: Date): boolean {\r\n      let index = -1;\r\n      for (let i = 0; i < this.selectedDays.length; i++) {\r\n          const selectedDate: Date = this.selectedDays[i];\r\n          if (this.isSameDay(date, selectedDate)) {\r\n            index = i;\r\n          }\r\n      }\r\n    return index > -1;\r\n  }\r\n\r\n  isSelectedMonth(date: Date): boolean {\r\n    return this.isSameMonth(date, this.currentDate);\r\n  }\r\n\r\n  toggleSelectedDates(day: CalendarDateInterface) {\r\n      let found = false;\r\n      if (this.multiselect) {\r\n        for (let i = 0; i < this.selectedDays.length; i++) {\r\n            const date: Date = this.selectedDays[i];\r\n            if (this.isSameDay(day.date, date)) {\r\n                this.selectedDays.splice(i,1);\r\n                found = true;\r\n                day.selected = false;\r\n                break;\r\n            }\r\n          }\r\n          if(!found) {\r\n              this.selectedDays.push(day.date);\r\n              day.selected = true;\r\n          }\r\n      } else {\r\n        this.selectedDays = [day.date];\r\n        day.selected = true;\r\n      }\r\n  }\r\n  selectDate(event: any, day: CalendarDateInterface): void {\r\n    event.stopPropagation();\r\n    event.preventDefault();\r\n\r\n    if(this.validate(this.item, day.date)) {\r\n        this.origDate = day.date;\r\n        this.currentDate = day.date;\r\n        this.toggleSelectedDates( day );\r\n    \r\n        this.selectedDays.sort( (a, b) => {\r\n            return a > b ? -1 : 1;\r\n        });\r\n        this.onIntoComponentChange.emit({\r\n            id: this.id,\r\n            name: this.name,\r\n            value: this.selectedDays,\r\n            type: \"select\",\r\n            item: this.item\r\n        });\r\n        this.generateCalendar();\r\n    }\r\n    this.showCalendar = false;\r\n  }\r\n\r\n  // actions from calendar\r\n  prevMonth(event: any): void {\r\n    event.stopPropagation();\r\n    event.preventDefault();\r\n\r\n    this.currentDate = new Date(this.currentDate.getFullYear(),this.currentDate.getMonth()-1, this.currentDate.getDate());\r\n    this.generateCalendar();\r\n  }\r\n\r\n  nextMonth(event: any): void {\r\n    event.stopPropagation();\r\n    event.preventDefault();\r\n\r\n    this.currentDate = new Date(this.currentDate.getFullYear(),this.currentDate.getMonth()+1, this.currentDate.getDate());\r\n    this.generateCalendar();\r\n  }\r\n\r\n  prevYear(event: any): void {\r\n    event.stopPropagation();\r\n    event.preventDefault();\r\n\r\n    this.currentDate = new Date(this.currentDate.getFullYear()-1,this.currentDate.getMonth(), this.currentDate.getDate());\r\n    this.generateCalendar();\r\n  }\r\n\r\n  nextYear(event: any): void {\r\n    event.stopPropagation();\r\n    event.preventDefault();\r\n\r\n    this.currentDate = new Date(this.currentDate.getFullYear()+1,this.currentDate.getMonth(), this.currentDate.getDate());\r\n    this.generateCalendar();\r\n  }\r\n\r\n    // generate the calendar grid\r\n    generateCalendar(): void {\r\n        const dates = this.fillDates(this.currentDate);\r\n        const weeks: CalendarDateInterface[][] = [];\r\n        while (dates.length > 0) {\r\n        weeks.push(dates.splice(0, 7));\r\n        }\r\n        this.weeks = weeks;\r\n    }\r\n    private isSameDay(a: Date, b: Date) {\r\n        return a.getFullYear() === b.getFullYear() && \r\n            a.getMonth() === b.getMonth() && \r\n            a.getDate() === b.getDate();\r\n    }\r\n    private isSameMonth(a: any, b: any) {\r\n        return a.getYear() === b.getYear() && \r\n            a.getMonth() === b.getMonth();\r\n    }\r\n\r\n    fillDates(currentDate: Date): CalendarDateInterface[] {\r\n        const cm = new Date(currentDate);\r\n        const tm = new Date();\r\n        const firstDay = new Date(cm.getFullYear(), cm.getMonth(), 1)\r\n        const firstOfMonth = firstDay.getDay();\r\n        const firstDayOfGrid = new Date(firstDay.getFullYear(), firstDay.getMonth(), firstDay.getDate() - firstOfMonth);\r\n        const start = firstDayOfGrid.getDate();\r\n        const list = [];\r\n        for (let i = start; i< (start + 42);i++){\r\n            const d = new Date(firstDayOfGrid.getFullYear(), firstDayOfGrid.getMonth(), i);\r\n            list.push({\r\n                today: this.isSameDay(tm, d),\r\n                selected: this.isSelected(d),\r\n                date: d\r\n            });\r\n        }\r\n        return list;\r\n    }\r\n}\r\n\r\n"]}