@annalib/anna-core 30.0.10 → 30.0.11

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -18,7 +18,7 @@ export class AnnaCalendarFilterComponent {
18
18
  this.disabled = false;
19
19
  this.selectedDate = new EventEmitter();
20
20
  this.showFooterTemplate = false;
21
- this.placement = ["top-start", "bottom-start", "left", "auto"];
21
+ this.placement = ["top-start", "left", "bottom-start", "auto"];
22
22
  this.apply = new EventEmitter();
23
23
  this.cancel = new EventEmitter();
24
24
  this.disableApplyBtn = false;
@@ -157,4 +157,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
157
157
  }], cancel: [{
158
158
  type: Output
159
159
  }] } });
160
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"anna-calendar-filter.component.js","sourceRoot":"","sources":["../../../../../../../projects/anna-core/src/lib/anna-dropdown-lib/components/anna-calendar-filter/anna-calendar-filter.component.ts","../../../../../../../projects/anna-core/src/lib/anna-dropdown-lib/components/anna-calendar-filter/anna-calendar-filter.component.html"],"names":[],"mappings":"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","sourcesContent":["// Angular import statements\r\nimport { NgClass, NgIf, TitleCasePipe } from \"@angular/common\";\r\nimport {\r\n    ChangeDetectionStrategy,\r\n    Component,\r\n    EventEmitter,\r\n    Input,\r\n    OnChanges,\r\n    OnInit,\r\n    Output,\r\n    SimpleChanges,\r\n} from \"@angular/core\";\r\nimport { FormsModule } from \"@angular/forms\";\r\nimport { NgbDate, NgbDateStruct, NgbInputDatepicker } from \"@ng-bootstrap/ng-bootstrap\";\r\nimport { Placement } from \"@ng-bootstrap/ng-bootstrap/util/positioning\";\r\nimport dayjs from \"dayjs\";\r\n\r\nimport { AnnaDateTimeFormatService } from \"../../../anna-core-shared-lib/services/anna-date-time-format.service\";\r\n\r\n@Component({\r\n    selector: \"anna-core-calendar-filter-lib\",\r\n    templateUrl: \"./anna-calendar-filter.component.html\",\r\n    styleUrls: [\"./anna-calendar-filter.component.scss\"],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    standalone: true,\r\n    imports: [NgIf, FormsModule, NgbInputDatepicker, NgClass, TitleCasePipe],\r\n})\r\nexport class AnnaCalendarFilterComponent implements OnInit, OnChanges {\r\n    @Input() maxDate: any;\r\n    @Input() autoClose: \"inside\" | \"outside\" | boolean = \"outside\";\r\n    @Input() label: string;\r\n    @Input() minDate: any;\r\n    @Input() showLabel: boolean = true;\r\n    @Input() dateFormat: string = \"MM/DD/YYYY\";\r\n    @Input() placeholder: string = \"MM/DD/YYYY\";\r\n    @Input() disabled: boolean = false;\r\n    @Output() selectedDate = new EventEmitter();\r\n    @Input() selectedFromDate: any;\r\n    @Input() selectedToDate: any;\r\n    @Input() disableFunction: any;\r\n    @Input() showFooterTemplate: boolean = false;\r\n    @Input() placement: Placement[] = [\"top-start\", \"bottom-start\", \"left\", \"auto\"];\r\n\r\n    @Output() apply = new EventEmitter();\r\n    @Output() cancel = new EventEmitter();\r\n    fromDate: any;\r\n    toDate: any;\r\n    hoveredDate: any;\r\n    disableApplyBtn: boolean = false;\r\n    dateToBeShownInInput: string = \"\";\r\n\r\n    constructor(private annaTimeService: AnnaDateTimeFormatService) {\r\n        this.disableFunction = (date: NgbDateStruct) => false;\r\n    }\r\n\r\n    ngOnChanges(changes: SimpleChanges): void {\r\n        this.setStartAndEndDate();\r\n        this.setInputText();\r\n    }\r\n\r\n    setStartAndEndDate() {\r\n        this.fromDate = this.selectedFromDate;\r\n        this.toDate = this.selectedToDate;\r\n    }\r\n\r\n    ngOnInit() {\r\n        this.disableApplyBtn = true;\r\n        // this.fromDate = this.selectedFromDate;\r\n        // this.toDate = this.selectedToDate;\r\n        // this.setInputText();\r\n    }\r\n\r\n    onDateSelection(date: NgbDate) {\r\n        if (!this.fromDate && !this.toDate) {\r\n            this.fromDate = date;\r\n        } else if (this.fromDate && !this.toDate && (date.after(this.fromDate) || date.equals(this.fromDate))) {\r\n            const isDisabledDatePresent = this.checkIfDisabledDateSelectedInRange(date);\r\n            this.toDate = isDisabledDatePresent ? null : date;\r\n        } else {\r\n            this.toDate = null;\r\n            this.fromDate = date;\r\n        }\r\n        this.selectedDate.emit({ fromDate: this.fromDate, toDate: this.toDate });\r\n        this.disableCalendarApplyBtn();\r\n        this.setInputText();\r\n    }\r\n\r\n    checkIfDisabledDateSelectedInRange(date: NgbDate) {\r\n        let dayJsStartDate = dayjs(\r\n            this.annaTimeService.convertNgbDateToMomentInSpecificFormat(this.fromDate, this.dateFormat),\r\n            this.dateFormat,\r\n        );\r\n        const dayJsEndDate = dayjs(\r\n            this.annaTimeService.convertNgbDateToMomentInSpecificFormat(date, this.dateFormat),\r\n            this.dateFormat,\r\n        );\r\n\r\n        while (!dayJsStartDate.isSame(dayJsEndDate)) {\r\n            if (\r\n                this.disableFunction(\r\n                    this.annaTimeService.convertToNgbDate(dayJsStartDate.format(this.dateFormat), this.dateFormat),\r\n                )\r\n            ) {\r\n                return true;\r\n            }\r\n            dayJsStartDate = dayJsStartDate.add(1, \"day\");\r\n        }\r\n\r\n        return false;\r\n    }\r\n\r\n    isHovered(date: NgbDate) {\r\n        return (\r\n            this.fromDate &&\r\n            !this.toDate &&\r\n            this.hoveredDate &&\r\n            date.after(this.fromDate) &&\r\n            date.before(this.hoveredDate)\r\n        );\r\n    }\r\n\r\n    isInside(date: NgbDate) {\r\n        return this.toDate && date.after(this.fromDate) && date.before(this.toDate);\r\n    }\r\n\r\n    isRange(date: NgbDate) {\r\n        return (\r\n            date.equals(this.fromDate) ||\r\n            (this.toDate && date.equals(this.toDate)) ||\r\n            this.isInside(date) ||\r\n            this.isHovered(date)\r\n        );\r\n    }\r\n\r\n    cancelSelection() {\r\n        this.cancel.emit();\r\n    }\r\n\r\n    applySelection() {\r\n        if (this.fromDate && this.toDate) {\r\n            const dateObj = { fromDate: this.fromDate, toDate: this.toDate };\r\n            this.apply.emit(dateObj);\r\n        }\r\n    }\r\n\r\n    disableCalendarApplyBtn() {\r\n        this.disableApplyBtn = !(this.fromDate && this.toDate);\r\n    }\r\n\r\n    setInputText() {\r\n        if (this.fromDate && this.toDate) {\r\n            // eslint-disable-next-line max-len\r\n            this.dateToBeShownInInput = `${this.annaTimeService.convertNgbDateToMomentInSpecificFormat(this.fromDate, this.dateFormat)} - ${this.annaTimeService.convertNgbDateToMomentInSpecificFormat(this.toDate, this.dateFormat)}`;\r\n        } else if (this.fromDate) {\r\n            // eslint-disable-next-line max-len\r\n            this.dateToBeShownInInput = `${this.annaTimeService.convertNgbDateToMomentInSpecificFormat(this.fromDate, this.dateFormat)}`;\r\n        } else {\r\n            this.dateToBeShownInInput = null;\r\n        }\r\n    }\r\n\r\n    datepickerClosed() {\r\n        // Required for Pending ec order\r\n        if (this.showFooterTemplate) {\r\n            this.selectedFromDate = null;\r\n            this.fromDate = null;\r\n            this.selectedToDate = null;\r\n            this.toDate = null;\r\n            this.setInputText();\r\n            this.disableApplyBtn = true;\r\n        }\r\n    }\r\n}\r\n","<!-- container=\"body\"\r\ndatepickerClass = \"calendar-filter\" -->\r\n\r\n<p\r\n    class=\"calendar-label\"\r\n    *ngIf=\"showLabel\"\r\n>\r\n    {{ label | titlecase }}\r\n</p>\r\n<form>\r\n    <div class=\"padding-class\">\r\n        <div class=\"dp-hidden position-absolute\">\r\n            <div class=\"input-group\">\r\n                <input\r\n                    name=\"datepicker\"\r\n                    class=\"form-control\"\r\n                    ngbDatepicker\r\n                    #datepicker=\"ngbDatepicker\"\r\n                    (dateSelect)=\"onDateSelection($event)\"\r\n                    [displayMonths]=\"1\"\r\n                    [dayTemplate]=\"t\"\r\n                    [maxDate]=\"maxDate\"\r\n                    [minDate]=\"minDate\"\r\n                    [autoClose]=\"autoClose\"\r\n                    [startDate]=\"fromDate\"\r\n                    [markDisabled]=\"disableFunction\"\r\n                    [footerTemplate]=\"footerTemplate\"\r\n                    navigation=\"select\"\r\n                    (closed)=\"datepickerClosed()\"\r\n                    [placement]=\"placement\"\r\n                />\r\n                <ng-template\r\n                    #t\r\n                    let-date\r\n                    let-focused=\"focused\"\r\n                >\r\n                    <span\r\n                        class=\"custom-day\"\r\n                        [class.focused]=\"focused\"\r\n                        [class.range]=\"isRange(date)\"\r\n                        [class.faded]=\"isHovered(date) || isInside(date)\"\r\n                        (mouseenter)=\"hoveredDate = date\"\r\n                        (mouseleave)=\"hoveredDate = null\"\r\n                    >\r\n                        {{ date.day }}\r\n                    </span>\r\n                </ng-template>\r\n            </div>\r\n        </div>\r\n        <div class=\"input-group\">\r\n            <input\r\n                #dpFromDate\r\n                id=\"datepicker-input\"\r\n                class=\"form-control\"\r\n                [placeholder]=\"placeholder\"\r\n                readonly\r\n                name=\"dpFromDate\"\r\n                [value]=\"dateToBeShownInInput\"\r\n            />\r\n            <button\r\n                class=\"icon-container\"\r\n                (click)=\"datepicker.toggle()\"\r\n                type=\"button\"\r\n                [disabled]=\"disabled\"\r\n            >\r\n                <i\r\n                    class=\"mdi mdi-calendar-range\"\r\n                    *ngIf=\"!datepicker.isOpen()\"\r\n                ></i>\r\n                <i\r\n                    class=\"mdi mdi-check\"\r\n                    *ngIf=\"datepicker.isOpen()\"\r\n                ></i>\r\n            </button>\r\n        </div>\r\n    </div>\r\n</form>\r\n\r\n<ng-template #footerTemplate>\r\n    <div\r\n        class=\"buttons-container\"\r\n        *ngIf=\"showFooterTemplate\"\r\n    >\r\n        <button\r\n            class=\"button\"\r\n            (click)=\"cancelSelection(); datepicker.close()\"\r\n        >\r\n            Cancel\r\n        </button>\r\n        <button\r\n            class=\"button\"\r\n            [ngClass]=\"{ disabled: disableApplyBtn }\"\r\n            [disabled]=\"disableApplyBtn\"\r\n            (click)=\"applySelection(); datepicker.close()\"\r\n        >\r\n            Apply\r\n        </button>\r\n    </div>\r\n</ng-template>\r\n"]}
160
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"anna-calendar-filter.component.js","sourceRoot":"","sources":["../../../../../../../projects/anna-core/src/lib/anna-dropdown-lib/components/anna-calendar-filter/anna-calendar-filter.component.ts","../../../../../../../projects/anna-core/src/lib/anna-dropdown-lib/components/anna-calendar-filter/anna-calendar-filter.component.html"],"names":[],"mappings":"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","sourcesContent":["// Angular import statements\r\nimport { NgClass, NgIf, TitleCasePipe } from \"@angular/common\";\r\nimport {\r\n    ChangeDetectionStrategy,\r\n    Component,\r\n    EventEmitter,\r\n    Input,\r\n    OnChanges,\r\n    OnInit,\r\n    Output,\r\n    SimpleChanges,\r\n} from \"@angular/core\";\r\nimport { FormsModule } from \"@angular/forms\";\r\nimport { NgbDate, NgbDateStruct, NgbInputDatepicker } from \"@ng-bootstrap/ng-bootstrap\";\r\nimport { Placement } from \"@ng-bootstrap/ng-bootstrap/util/positioning\";\r\nimport dayjs from \"dayjs\";\r\n\r\nimport { AnnaDateTimeFormatService } from \"../../../anna-core-shared-lib/services/anna-date-time-format.service\";\r\n\r\n@Component({\r\n    selector: \"anna-core-calendar-filter-lib\",\r\n    templateUrl: \"./anna-calendar-filter.component.html\",\r\n    styleUrls: [\"./anna-calendar-filter.component.scss\"],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    standalone: true,\r\n    imports: [NgIf, FormsModule, NgbInputDatepicker, NgClass, TitleCasePipe],\r\n})\r\nexport class AnnaCalendarFilterComponent implements OnInit, OnChanges {\r\n    @Input() maxDate: any;\r\n    @Input() autoClose: \"inside\" | \"outside\" | boolean = \"outside\";\r\n    @Input() label: string;\r\n    @Input() minDate: any;\r\n    @Input() showLabel: boolean = true;\r\n    @Input() dateFormat: string = \"MM/DD/YYYY\";\r\n    @Input() placeholder: string = \"MM/DD/YYYY\";\r\n    @Input() disabled: boolean = false;\r\n    @Output() selectedDate = new EventEmitter();\r\n    @Input() selectedFromDate: any;\r\n    @Input() selectedToDate: any;\r\n    @Input() disableFunction: any;\r\n    @Input() showFooterTemplate: boolean = false;\r\n    @Input() placement: Placement[] = [\"top-start\", \"left\", \"bottom-start\", \"auto\"];\r\n\r\n    @Output() apply = new EventEmitter();\r\n    @Output() cancel = new EventEmitter();\r\n    fromDate: any;\r\n    toDate: any;\r\n    hoveredDate: any;\r\n    disableApplyBtn: boolean = false;\r\n    dateToBeShownInInput: string = \"\";\r\n\r\n    constructor(private annaTimeService: AnnaDateTimeFormatService) {\r\n        this.disableFunction = (date: NgbDateStruct) => false;\r\n    }\r\n\r\n    ngOnChanges(changes: SimpleChanges): void {\r\n        this.setStartAndEndDate();\r\n        this.setInputText();\r\n    }\r\n\r\n    setStartAndEndDate() {\r\n        this.fromDate = this.selectedFromDate;\r\n        this.toDate = this.selectedToDate;\r\n    }\r\n\r\n    ngOnInit() {\r\n        this.disableApplyBtn = true;\r\n        // this.fromDate = this.selectedFromDate;\r\n        // this.toDate = this.selectedToDate;\r\n        // this.setInputText();\r\n    }\r\n\r\n    onDateSelection(date: NgbDate) {\r\n        if (!this.fromDate && !this.toDate) {\r\n            this.fromDate = date;\r\n        } else if (this.fromDate && !this.toDate && (date.after(this.fromDate) || date.equals(this.fromDate))) {\r\n            const isDisabledDatePresent = this.checkIfDisabledDateSelectedInRange(date);\r\n            this.toDate = isDisabledDatePresent ? null : date;\r\n        } else {\r\n            this.toDate = null;\r\n            this.fromDate = date;\r\n        }\r\n        this.selectedDate.emit({ fromDate: this.fromDate, toDate: this.toDate });\r\n        this.disableCalendarApplyBtn();\r\n        this.setInputText();\r\n    }\r\n\r\n    checkIfDisabledDateSelectedInRange(date: NgbDate) {\r\n        let dayJsStartDate = dayjs(\r\n            this.annaTimeService.convertNgbDateToMomentInSpecificFormat(this.fromDate, this.dateFormat),\r\n            this.dateFormat,\r\n        );\r\n        const dayJsEndDate = dayjs(\r\n            this.annaTimeService.convertNgbDateToMomentInSpecificFormat(date, this.dateFormat),\r\n            this.dateFormat,\r\n        );\r\n\r\n        while (!dayJsStartDate.isSame(dayJsEndDate)) {\r\n            if (\r\n                this.disableFunction(\r\n                    this.annaTimeService.convertToNgbDate(dayJsStartDate.format(this.dateFormat), this.dateFormat),\r\n                )\r\n            ) {\r\n                return true;\r\n            }\r\n            dayJsStartDate = dayJsStartDate.add(1, \"day\");\r\n        }\r\n\r\n        return false;\r\n    }\r\n\r\n    isHovered(date: NgbDate) {\r\n        return (\r\n            this.fromDate &&\r\n            !this.toDate &&\r\n            this.hoveredDate &&\r\n            date.after(this.fromDate) &&\r\n            date.before(this.hoveredDate)\r\n        );\r\n    }\r\n\r\n    isInside(date: NgbDate) {\r\n        return this.toDate && date.after(this.fromDate) && date.before(this.toDate);\r\n    }\r\n\r\n    isRange(date: NgbDate) {\r\n        return (\r\n            date.equals(this.fromDate) ||\r\n            (this.toDate && date.equals(this.toDate)) ||\r\n            this.isInside(date) ||\r\n            this.isHovered(date)\r\n        );\r\n    }\r\n\r\n    cancelSelection() {\r\n        this.cancel.emit();\r\n    }\r\n\r\n    applySelection() {\r\n        if (this.fromDate && this.toDate) {\r\n            const dateObj = { fromDate: this.fromDate, toDate: this.toDate };\r\n            this.apply.emit(dateObj);\r\n        }\r\n    }\r\n\r\n    disableCalendarApplyBtn() {\r\n        this.disableApplyBtn = !(this.fromDate && this.toDate);\r\n    }\r\n\r\n    setInputText() {\r\n        if (this.fromDate && this.toDate) {\r\n            // eslint-disable-next-line max-len\r\n            this.dateToBeShownInInput = `${this.annaTimeService.convertNgbDateToMomentInSpecificFormat(this.fromDate, this.dateFormat)} - ${this.annaTimeService.convertNgbDateToMomentInSpecificFormat(this.toDate, this.dateFormat)}`;\r\n        } else if (this.fromDate) {\r\n            // eslint-disable-next-line max-len\r\n            this.dateToBeShownInInput = `${this.annaTimeService.convertNgbDateToMomentInSpecificFormat(this.fromDate, this.dateFormat)}`;\r\n        } else {\r\n            this.dateToBeShownInInput = null;\r\n        }\r\n    }\r\n\r\n    datepickerClosed() {\r\n        // Required for Pending ec order\r\n        if (this.showFooterTemplate) {\r\n            this.selectedFromDate = null;\r\n            this.fromDate = null;\r\n            this.selectedToDate = null;\r\n            this.toDate = null;\r\n            this.setInputText();\r\n            this.disableApplyBtn = true;\r\n        }\r\n    }\r\n}\r\n","<!-- container=\"body\"\r\ndatepickerClass = \"calendar-filter\" -->\r\n\r\n<p\r\n    class=\"calendar-label\"\r\n    *ngIf=\"showLabel\"\r\n>\r\n    {{ label | titlecase }}\r\n</p>\r\n<form>\r\n    <div class=\"padding-class\">\r\n        <div class=\"dp-hidden position-absolute\">\r\n            <div class=\"input-group\">\r\n                <input\r\n                    name=\"datepicker\"\r\n                    class=\"form-control\"\r\n                    ngbDatepicker\r\n                    #datepicker=\"ngbDatepicker\"\r\n                    (dateSelect)=\"onDateSelection($event)\"\r\n                    [displayMonths]=\"1\"\r\n                    [dayTemplate]=\"t\"\r\n                    [maxDate]=\"maxDate\"\r\n                    [minDate]=\"minDate\"\r\n                    [autoClose]=\"autoClose\"\r\n                    [startDate]=\"fromDate\"\r\n                    [markDisabled]=\"disableFunction\"\r\n                    [footerTemplate]=\"footerTemplate\"\r\n                    navigation=\"select\"\r\n                    (closed)=\"datepickerClosed()\"\r\n                    [placement]=\"placement\"\r\n                />\r\n                <ng-template\r\n                    #t\r\n                    let-date\r\n                    let-focused=\"focused\"\r\n                >\r\n                    <span\r\n                        class=\"custom-day\"\r\n                        [class.focused]=\"focused\"\r\n                        [class.range]=\"isRange(date)\"\r\n                        [class.faded]=\"isHovered(date) || isInside(date)\"\r\n                        (mouseenter)=\"hoveredDate = date\"\r\n                        (mouseleave)=\"hoveredDate = null\"\r\n                    >\r\n                        {{ date.day }}\r\n                    </span>\r\n                </ng-template>\r\n            </div>\r\n        </div>\r\n        <div class=\"input-group\">\r\n            <input\r\n                #dpFromDate\r\n                id=\"datepicker-input\"\r\n                class=\"form-control\"\r\n                [placeholder]=\"placeholder\"\r\n                readonly\r\n                name=\"dpFromDate\"\r\n                [value]=\"dateToBeShownInInput\"\r\n            />\r\n            <button\r\n                class=\"icon-container\"\r\n                (click)=\"datepicker.toggle()\"\r\n                type=\"button\"\r\n                [disabled]=\"disabled\"\r\n            >\r\n                <i\r\n                    class=\"mdi mdi-calendar-range\"\r\n                    *ngIf=\"!datepicker.isOpen()\"\r\n                ></i>\r\n                <i\r\n                    class=\"mdi mdi-check\"\r\n                    *ngIf=\"datepicker.isOpen()\"\r\n                ></i>\r\n            </button>\r\n        </div>\r\n    </div>\r\n</form>\r\n\r\n<ng-template #footerTemplate>\r\n    <div\r\n        class=\"buttons-container\"\r\n        *ngIf=\"showFooterTemplate\"\r\n    >\r\n        <button\r\n            class=\"button\"\r\n            (click)=\"cancelSelection(); datepicker.close()\"\r\n        >\r\n            Cancel\r\n        </button>\r\n        <button\r\n            class=\"button\"\r\n            [ngClass]=\"{ disabled: disableApplyBtn }\"\r\n            [disabled]=\"disableApplyBtn\"\r\n            (click)=\"applySelection(); datepicker.close()\"\r\n        >\r\n            Apply\r\n        </button>\r\n    </div>\r\n</ng-template>\r\n"]}