@agorapulse/ui-components 14.0.6 → 14.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (47) hide show
  1. package/agorapulse-ui-components-14.1.1.tgz +0 -0
  2. package/directives/truncate-tooltip.directive.d.ts +3 -2
  3. package/directives/truncate-tooltip.model.d.ts +5 -0
  4. package/esm2020/datepicker/datepicker.component.mjs +2 -2
  5. package/esm2020/directives/truncate-tooltip.directive.mjs +11 -3
  6. package/esm2020/directives/truncate-tooltip.model.mjs +2 -0
  7. package/esm2020/index.mjs +2 -1
  8. package/esm2020/neo-datepicker/agorapulse-ui-components-neo-datepicker.mjs +5 -0
  9. package/esm2020/neo-datepicker/day-detail.model.mjs +2 -0
  10. package/esm2020/neo-datepicker/day-disabled.pipe.mjs +21 -0
  11. package/esm2020/neo-datepicker/neo-datepicker.component.mjs +189 -0
  12. package/esm2020/neo-datepicker/public_api.mjs +4 -0
  13. package/esm2020/src/lib/agorapulse-ui-components.module.mjs +16 -2
  14. package/esm2020/tooltip-neo/tooltip-neo.component.mjs +6 -3
  15. package/esm2020/tooltip-neo/tooltip-neo.directive.mjs +3 -2
  16. package/esm2020/tooltip-neo/tooltip-neo.model.mjs +1 -1
  17. package/fesm2015/agorapulse-ui-components-datepicker.mjs +1 -1
  18. package/fesm2015/agorapulse-ui-components-datepicker.mjs.map +1 -1
  19. package/fesm2015/agorapulse-ui-components-directives.mjs +6 -1
  20. package/fesm2015/agorapulse-ui-components-directives.mjs.map +1 -1
  21. package/fesm2015/agorapulse-ui-components-neo-datepicker.mjs +214 -0
  22. package/fesm2015/agorapulse-ui-components-neo-datepicker.mjs.map +1 -0
  23. package/fesm2015/agorapulse-ui-components-tooltip-neo.mjs +7 -3
  24. package/fesm2015/agorapulse-ui-components-tooltip-neo.mjs.map +1 -1
  25. package/fesm2015/agorapulse-ui-components.mjs +16 -1
  26. package/fesm2015/agorapulse-ui-components.mjs.map +1 -1
  27. package/fesm2020/agorapulse-ui-components-datepicker.mjs +1 -1
  28. package/fesm2020/agorapulse-ui-components-datepicker.mjs.map +1 -1
  29. package/fesm2020/agorapulse-ui-components-directives.mjs +9 -1
  30. package/fesm2020/agorapulse-ui-components-directives.mjs.map +1 -1
  31. package/fesm2020/agorapulse-ui-components-neo-datepicker.mjs +214 -0
  32. package/fesm2020/agorapulse-ui-components-neo-datepicker.mjs.map +1 -0
  33. package/fesm2020/agorapulse-ui-components-tooltip-neo.mjs +7 -3
  34. package/fesm2020/agorapulse-ui-components-tooltip-neo.mjs.map +1 -1
  35. package/fesm2020/agorapulse-ui-components.mjs +16 -1
  36. package/fesm2020/agorapulse-ui-components.mjs.map +1 -1
  37. package/index.d.ts +1 -0
  38. package/neo-datepicker/day-detail.model.d.ts +9 -0
  39. package/neo-datepicker/day-disabled.pipe.d.ts +8 -0
  40. package/neo-datepicker/index.d.ts +5 -0
  41. package/neo-datepicker/neo-datepicker.component.d.ts +49 -0
  42. package/neo-datepicker/public_api.d.ts +3 -0
  43. package/package.json +11 -2
  44. package/src/lib/agorapulse-ui-components.module.d.ts +13 -12
  45. package/tooltip-neo/tooltip-neo.component.d.ts +1 -0
  46. package/tooltip-neo/tooltip-neo.model.d.ts +1 -0
  47. package/agorapulse-ui-components-14.0.6.tgz +0 -0
@@ -1,10 +1,11 @@
1
- import { TooltipNeoDirective, TooltipNeoParams } from '@agorapulse/ui-components/tooltip-neo';
1
+ import { TooltipNeoDirective } from '@agorapulse/ui-components/tooltip-neo';
2
2
  import { ElementRef, OnDestroy, OnInit } from '@angular/core';
3
+ import { TruncateTooltipNeoParams } from './truncate-tooltip.model';
3
4
  import * as i0 from "@angular/core";
4
5
  export declare class TruncateTooltipDirective implements OnInit, OnDestroy {
5
6
  private tooltipNeo;
6
7
  private elementRef;
7
- truncateTooltip: string | TooltipNeoParams;
8
+ truncateTooltip: string | TruncateTooltipNeoParams;
8
9
  private elementRefMouseOver$;
9
10
  constructor(tooltipNeo: TooltipNeoDirective, elementRef: ElementRef<HTMLElement>);
10
11
  private updateTruncateState;
@@ -0,0 +1,5 @@
1
+ import { TemplateRef } from '@angular/core';
2
+ import { TooltipNeoParams } from "@agorapulse/ui-components/tooltip-neo";
3
+ export interface TruncateTooltipNeoParams extends TooltipNeoParams {
4
+ defaultContent?: string | TemplateRef<any>;
5
+ }
@@ -1,7 +1,7 @@
1
1
  import { AgorapulseUiSymbolModule } from '@agorapulse/ui-symbol';
2
2
  import { NgIf } from '@angular/common';
3
3
  import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
4
- import moment from 'moment';
4
+ import * as moment from 'moment';
5
5
  import { NgxDaterangepickerMd } from 'ngx-daterangepicker-material';
6
6
  import * as i0 from "@angular/core";
7
7
  import * as i1 from "@agorapulse/ui-symbol";
@@ -222,4 +222,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
222
222
  }], periodSelected: [{
223
223
  type: Output
224
224
  }] } });
225
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.component.js","sourceRoot":"","sources":["../../../../libs/ui-components/datepicker/src/datepicker.component.ts","../../../../libs/ui-components/datepicker/src/datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AgorapulseUiSymbolModule} from '@agorapulse/ui-symbol';\nimport {NgIf} from '@angular/common';\nimport {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    EventEmitter,\n    Input,\n    OnChanges,\n    OnInit,\n    Output,\n    ViewChild,\n} from '@angular/core';\nimport moment, {Moment} from 'moment';\nimport {DaterangepickerComponent, NgxDaterangepickerMd} from 'ngx-daterangepicker-material';\n\nexport enum DatepickerMode {\n    Single = 'Single',\n    Multiple = 'Multiple',\n    Range = 'Range',\n}\n\nexport interface Period {\n    startDate: Moment;\n    endDate: Moment;\n}\n\nexport interface I18nDatePicker {\n    ranges: {\n        yesterday: string;\n        lastWeek: string;\n        last30Days: string;\n        lastMonth: string;\n        thisMonth: string;\n    }\n}\n\nenum SideEnum {\n    left = \"left\",\n    right = \"right\"\n}\n\n// TODO fix css for range mode (more lateral padding)\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    selector: 'ap-datepicker',\n    templateUrl: './datepicker.component.html',\n    standalone: true,\n    imports: [AgorapulseUiSymbolModule, NgIf, NgxDaterangepickerMd],\n    styleUrls: ['./datepicker.component.scss'],\n})\nexport class DatepickerComponent implements OnInit, OnChanges, AfterViewInit {\n    @ViewChild('datepickerRef') datepickerRef: DaterangepickerComponent;\n\n    @Input() firstDayOfWeek: string;\n    @Input() i18n: I18nDatePicker = {\n        ranges: {\n            yesterday: 'Yesterday',\n            lastWeek: 'Last Week',\n            last30Days: 'Last 30 days',\n            lastMonth: 'Previous month',\n            thisMonth: 'This Month',\n        },\n    };\n    @Input() locale;\n    @Input() maxDate: Moment;\n    @Input() minDate: Moment;\n    @Input() mode: DatepickerMode;\n    @Input() selectedDate: Moment;\n    @Input() selectedDates: Moment[] = [];\n    @Input() selectedPeriod: Period = {startDate: null, endDate: null};\n    @Input() showRanges: boolean;\n\n    @Output() dateSelected = new EventEmitter<any>();\n    @Output() periodSelected = new EventEmitter<Period>();\n\n    DatepickerMode = DatepickerMode;\n    doubleCalendarWidth = 528; // 231px calendar table * 2 = 462 (+ 16px x-padding * 4 = 64)\n    localeConfig: {\n        customRangeLabel: string;\n        daysOfWeek: string[];\n        monthNames: string[];\n        firstDay: number;\n    };\n    ranges: {[period: string]: [Moment, Moment]} = {};\n    rangePickerWidth = 150;\n    width: number;\n    pageSet = false;\n\n    constructor(public changeDetectorRef: ChangeDetectorRef) {}\n\n    ngOnInit() {\n        this.initRanges();\n        this.initDatePickerLocale();\n    }\n\n    ngOnChanges(changes) {\n        this.setWidth();\n        if (this.datepickerRef) {\n            setTimeout(() => {\n                this.datepickerRef.updateCalendars();\n                this.changeDetectorRef.detectChanges();\n            }, 100);\n        }\n        if (changes.selectedPeriod?.currentValue && this.datepickerRef) {\n            if (this.selectedPeriod.startDate === null && this.selectedPeriod.endDate === null) {\n                this.datepickerRef.clear();\n            } else {\n                this.datepickerRef.setStartDate(this.selectedPeriod.startDate);\n                this.datepickerRef.setEndDate(this.selectedPeriod.endDate);\n            }\n        }\n        if (changes.mode?.currentValue === DatepickerMode.Single && this.datepickerRef) {\n            this.setCalendarCurrentPage();\n        }\n    }\n    ngAfterViewInit(): void {\n        if (this.datepickerRef) {\n            setTimeout(() => {\n                this.datepickerRef.updateCalendars();\n                this.setCalendarCurrentPage();\n            }, 100);\n        }\n    }\n\n    initDatePickerLocale() {\n        if (this.locale) {\n            moment.locale(this.locale);\n        }\n        let firstDayOfWeekIndex: number;\n        if (this.firstDayOfWeek === 'sunday') {\n            firstDayOfWeekIndex = 0;\n        } else if (this.firstDayOfWeek === 'monday') {\n            firstDayOfWeekIndex = 1;\n        } else {\n            firstDayOfWeekIndex = moment.localeData().firstDayOfWeek();\n        }\n        this.localeConfig = {\n            customRangeLabel: 'custom',\n            daysOfWeek: moment.weekdaysMin(),\n            monthNames: moment.months(),\n            firstDay: firstDayOfWeekIndex,\n        };\n    }\n\n    initRanges() {\n        this.ranges[this.i18n.ranges.yesterday] = [moment().subtract(1, 'days'), moment().subtract(1, 'days')];\n        this.ranges[this.i18n.ranges.lastWeek] = [moment().subtract(7, 'days'), moment().subtract(1, 'days')];\n        this.ranges[this.i18n.ranges.last30Days] = [moment().subtract(30, 'days'), moment().subtract(1, 'days')];\n        this.ranges[this.i18n.ranges.lastMonth] = [\n            moment().subtract(1, 'month').startOf('month'),\n            moment().subtract(1, 'month').endOf('month'),\n        ];\n        this.ranges[this.i18n.ranges.thisMonth] = [moment().startOf('month'), moment().endOf('month')];\n    }\n\n    isCustomDate = (date: any) => {\n        const classes: string[] = [];\n        if (this.mode === DatepickerMode.Multiple) {\n            classes.push(this.isSelected(date) ? 'active' : 'force-inactive');\n        } else if (this.mode === DatepickerMode.Single) {\n            classes.push(this.selectedDate && this.selectedDate.isSame(date, 'day') ? 'active' : 'force-inactive');\n        } else if (this.mode === DatepickerMode.Range) {\n            classes.push('range-picker-mode');\n            // Workaround to fix the auto-active today date when no date is selected\n            if (moment().isSame(date, 'day') && !this.selectedPeriod?.startDate && !this.selectedPeriod?.endDate) {\n                classes.push('force-inactive');\n            }\n        }\n        return classes;\n    };\n\n    private isSelected(date: any) {\n        return this.selectedDates && this.selectedDates.some(selectedDate => selectedDate.isSame(date, 'day'));\n    }\n\n    onStartDateChanged(event: any) {\n        const date = event.startDate;\n        if (this.mode !== DatepickerMode.Range) {\n            this.selectedDate = date;\n            this.datepickerRef.setEndDate(date);\n            if (this.pageSet) {\n                this.pageSet = false;\n            } else {\n                this.dateSelected.emit(date.clone());\n                if (this.mode === DatepickerMode.Multiple) {\n                    this.selectedDates.push(date);\n                }\n            }\n            if (this.datepickerRef) {\n                this.datepickerRef.updateCalendars();\n            }\n        }\n    }\n\n    onDatesUpdated(event: any) {\n        if (this.mode === DatepickerMode.Range) {\n            this.periodSelected.emit({\n                startDate: event.startDate?.clone(),\n                endDate: event.endDate?.clone(),\n            });\n        }\n        if (this.datepickerRef) {\n            this.datepickerRef.updateCalendars();\n        }\n    }\n\n    onNextMonth() {\n        this.datepickerRef.leftCalendar.month = this.datepickerRef.leftCalendar.month.add(1, 'months').clone();\n        this.datepickerRef.rightCalendar.month = this.datepickerRef.rightCalendar.month.add(1, 'months').clone();\n        this.datepickerRef.clickNext(SideEnum.left);\n        this.datepickerRef.clickNext(SideEnum.right);\n    }\n\n    onPreviousMonth() {\n        this.datepickerRef.leftCalendar.month = this.datepickerRef.leftCalendar.month.subtract(1, 'months').clone();\n        this.datepickerRef.rightCalendar.month = this.datepickerRef.rightCalendar.month.subtract(1, 'months').clone();\n        this.datepickerRef.clickPrev(SideEnum.left);\n        this.datepickerRef.clickPrev(SideEnum.right);\n    }\n\n    /**\n     * Ugly hack used here to open the calendar on the right day if they are selected dates\n     *      * https://github.com/fetrarij/ngx-daterangepicker-material/issues/139\n     */\n    setCalendarCurrentPage(): void {\n        const selectedFirstDate = this.selectedDates.length > 0 ? this.selectedDates[0] : this.selectedDate;\n        if (selectedFirstDate && selectedFirstDate.isValid() && this.mode !== DatepickerMode.Range) {\n            const endDate = selectedFirstDate.clone();\n            endDate.add(1, 'month');\n            this.pageSet = true;\n            this.datepickerRef.setStartDate(selectedFirstDate);\n            this.datepickerRef.setEndDate(endDate);\n            this.datepickerRef.updateView();\n        }\n        this.changeDetectorRef.detectChanges();\n    }\n\n    setWidth() {\n        this.width =\n            this.showRanges && this.mode === DatepickerMode.Range\n                ? this.doubleCalendarWidth + this.rangePickerWidth\n                : this.doubleCalendarWidth;\n    }\n}\n","<div class=\"custom-calendar\" [style.width]=\"width + 'px'\">\n    <div class=\"custom-header\">\n        <div class=\"month-header\"\n             *ngIf=\"this.datepickerRef.leftCalendar.month\">\n            <div class=\"month-arrow-button\" (click)=\"onPreviousMonth()\">\n                <ap-symbol\n                    [symbolId]=\"'arrow-left-1'\"\n                    [color]=\"'#858FA1'\"\n                    [size]=\"'14'\"></ap-symbol>\n            </div>\n            <div class=\"month-label\">\n                {{ this.datepickerRef.leftCalendar.month.locale(locale).format('MMMM YYYY') }}\n            </div>\n        </div>\n        <div class=\"month-header\"\n             *ngIf=\"this.datepickerRef.rightCalendar.month\">\n            <div class=\"month-label\">\n                {{ this.datepickerRef.rightCalendar.month.locale(locale).format('MMMM YYYY') }}\n            </div>\n            <div class=\"month-arrow-button\" (click)=\"onNextMonth()\">\n                <ap-symbol\n                    [symbolId]=\"'arrow-right-1'\"\n                    [color]=\"'#858FA1'\"\n                    [size]=\"'14'\"></ap-symbol>\n            </div>\n        </div>\n        <div class=\"header-filler\" *ngIf=\"showRanges && mode === DatepickerMode.Range\">\n        </div>\n    </div>\n    <ngx-daterangepicker-material\n        #datepickerRef\n        [class.hide-ranges]=\"!showRanges\"\n        [alwaysShowCalendars]=\"true\"\n        [autoApply]=\"true\"\n        [customRangeDirection]=\"true\"\n        [isCustomDate]=\"$any(isCustomDate)\"\n        [locale]=\"localeConfig\"\n        [maxDate]=\"maxDate\"\n        [minDate]=\"minDate\"\n        [ranges]=\"showRanges && mode === DatepickerMode.Range ? ranges : null\"\n        (datesUpdated)=\"onDatesUpdated($event)\"\n        (startDateChanged)=\"onStartDateChanged($event)\">\n    </ngx-daterangepicker-material>\n</div>\n"]}
225
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.component.js","sourceRoot":"","sources":["../../../../libs/ui-components/datepicker/src/datepicker.component.ts","../../../../libs/ui-components/datepicker/src/datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AgorapulseUiSymbolModule} from '@agorapulse/ui-symbol';\nimport {NgIf} from '@angular/common';\nimport {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    EventEmitter,\n    Input,\n    OnChanges,\n    OnInit,\n    Output,\n    ViewChild,\n} from '@angular/core';\nimport * as moment from 'moment';\nimport {Moment} from 'moment';\nimport {DaterangepickerComponent, NgxDaterangepickerMd} from 'ngx-daterangepicker-material';\n\nexport enum DatepickerMode {\n    Single = 'Single',\n    Multiple = 'Multiple',\n    Range = 'Range',\n}\n\nexport interface Period {\n    startDate: Moment;\n    endDate: Moment;\n}\n\nexport interface I18nDatePicker {\n    ranges: {\n        yesterday: string;\n        lastWeek: string;\n        last30Days: string;\n        lastMonth: string;\n        thisMonth: string;\n    }\n}\n\nenum SideEnum {\n    left = \"left\",\n    right = \"right\"\n}\n\n// TODO fix css for range mode (more lateral padding)\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    selector: 'ap-datepicker',\n    templateUrl: './datepicker.component.html',\n    standalone: true,\n    imports: [AgorapulseUiSymbolModule, NgIf, NgxDaterangepickerMd],\n    styleUrls: ['./datepicker.component.scss'],\n})\nexport class DatepickerComponent implements OnInit, OnChanges, AfterViewInit {\n    @ViewChild('datepickerRef') datepickerRef: DaterangepickerComponent;\n\n    @Input() firstDayOfWeek: string;\n    @Input() i18n: I18nDatePicker = {\n        ranges: {\n            yesterday: 'Yesterday',\n            lastWeek: 'Last Week',\n            last30Days: 'Last 30 days',\n            lastMonth: 'Previous month',\n            thisMonth: 'This Month',\n        },\n    };\n    @Input() locale;\n    @Input() maxDate: Moment;\n    @Input() minDate: Moment;\n    @Input() mode: DatepickerMode;\n    @Input() selectedDate: Moment;\n    @Input() selectedDates: Moment[] = [];\n    @Input() selectedPeriod: Period = {startDate: null, endDate: null};\n    @Input() showRanges: boolean;\n\n    @Output() dateSelected = new EventEmitter<any>();\n    @Output() periodSelected = new EventEmitter<Period>();\n\n    DatepickerMode = DatepickerMode;\n    doubleCalendarWidth = 528; // 231px calendar table * 2 = 462 (+ 16px x-padding * 4 = 64)\n    localeConfig: {\n        customRangeLabel: string;\n        daysOfWeek: string[];\n        monthNames: string[];\n        firstDay: number;\n    };\n    ranges: {[period: string]: [Moment, Moment]} = {};\n    rangePickerWidth = 150;\n    width: number;\n    pageSet = false;\n\n    constructor(public changeDetectorRef: ChangeDetectorRef) {}\n\n    ngOnInit() {\n        this.initRanges();\n        this.initDatePickerLocale();\n    }\n\n    ngOnChanges(changes) {\n        this.setWidth();\n        if (this.datepickerRef) {\n            setTimeout(() => {\n                this.datepickerRef.updateCalendars();\n                this.changeDetectorRef.detectChanges();\n            }, 100);\n        }\n        if (changes.selectedPeriod?.currentValue && this.datepickerRef) {\n            if (this.selectedPeriod.startDate === null && this.selectedPeriod.endDate === null) {\n                this.datepickerRef.clear();\n            } else {\n                this.datepickerRef.setStartDate(this.selectedPeriod.startDate);\n                this.datepickerRef.setEndDate(this.selectedPeriod.endDate);\n            }\n        }\n        if (changes.mode?.currentValue === DatepickerMode.Single && this.datepickerRef) {\n            this.setCalendarCurrentPage();\n        }\n    }\n    ngAfterViewInit(): void {\n        if (this.datepickerRef) {\n            setTimeout(() => {\n                this.datepickerRef.updateCalendars();\n                this.setCalendarCurrentPage();\n            }, 100);\n        }\n    }\n\n    initDatePickerLocale() {\n        if (this.locale) {\n            moment.locale(this.locale);\n        }\n        let firstDayOfWeekIndex: number;\n        if (this.firstDayOfWeek === 'sunday') {\n            firstDayOfWeekIndex = 0;\n        } else if (this.firstDayOfWeek === 'monday') {\n            firstDayOfWeekIndex = 1;\n        } else {\n            firstDayOfWeekIndex = moment.localeData().firstDayOfWeek();\n        }\n        this.localeConfig = {\n            customRangeLabel: 'custom',\n            daysOfWeek: moment.weekdaysMin(),\n            monthNames: moment.months(),\n            firstDay: firstDayOfWeekIndex,\n        };\n    }\n\n    initRanges() {\n        this.ranges[this.i18n.ranges.yesterday] = [moment().subtract(1, 'days'), moment().subtract(1, 'days')];\n        this.ranges[this.i18n.ranges.lastWeek] = [moment().subtract(7, 'days'), moment().subtract(1, 'days')];\n        this.ranges[this.i18n.ranges.last30Days] = [moment().subtract(30, 'days'), moment().subtract(1, 'days')];\n        this.ranges[this.i18n.ranges.lastMonth] = [\n            moment().subtract(1, 'month').startOf('month'),\n            moment().subtract(1, 'month').endOf('month'),\n        ];\n        this.ranges[this.i18n.ranges.thisMonth] = [moment().startOf('month'), moment().endOf('month')];\n    }\n\n    isCustomDate = (date: any) => {\n        const classes: string[] = [];\n        if (this.mode === DatepickerMode.Multiple) {\n            classes.push(this.isSelected(date) ? 'active' : 'force-inactive');\n        } else if (this.mode === DatepickerMode.Single) {\n            classes.push(this.selectedDate && this.selectedDate.isSame(date, 'day') ? 'active' : 'force-inactive');\n        } else if (this.mode === DatepickerMode.Range) {\n            classes.push('range-picker-mode');\n            // Workaround to fix the auto-active today date when no date is selected\n            if (moment().isSame(date, 'day') && !this.selectedPeriod?.startDate && !this.selectedPeriod?.endDate) {\n                classes.push('force-inactive');\n            }\n        }\n        return classes;\n    };\n\n    private isSelected(date: any) {\n        return this.selectedDates && this.selectedDates.some(selectedDate => selectedDate.isSame(date, 'day'));\n    }\n\n    onStartDateChanged(event: any) {\n        const date = event.startDate;\n        if (this.mode !== DatepickerMode.Range) {\n            this.selectedDate = date;\n            this.datepickerRef.setEndDate(date);\n            if (this.pageSet) {\n                this.pageSet = false;\n            } else {\n                this.dateSelected.emit(date.clone());\n                if (this.mode === DatepickerMode.Multiple) {\n                    this.selectedDates.push(date);\n                }\n            }\n            if (this.datepickerRef) {\n                this.datepickerRef.updateCalendars();\n            }\n        }\n    }\n\n    onDatesUpdated(event: any) {\n        if (this.mode === DatepickerMode.Range) {\n            this.periodSelected.emit({\n                startDate: event.startDate?.clone(),\n                endDate: event.endDate?.clone(),\n            });\n        }\n        if (this.datepickerRef) {\n            this.datepickerRef.updateCalendars();\n        }\n    }\n\n    onNextMonth() {\n        this.datepickerRef.leftCalendar.month = this.datepickerRef.leftCalendar.month.add(1, 'months').clone();\n        this.datepickerRef.rightCalendar.month = this.datepickerRef.rightCalendar.month.add(1, 'months').clone();\n        this.datepickerRef.clickNext(SideEnum.left);\n        this.datepickerRef.clickNext(SideEnum.right);\n    }\n\n    onPreviousMonth() {\n        this.datepickerRef.leftCalendar.month = this.datepickerRef.leftCalendar.month.subtract(1, 'months').clone();\n        this.datepickerRef.rightCalendar.month = this.datepickerRef.rightCalendar.month.subtract(1, 'months').clone();\n        this.datepickerRef.clickPrev(SideEnum.left);\n        this.datepickerRef.clickPrev(SideEnum.right);\n    }\n\n    /**\n     * Ugly hack used here to open the calendar on the right day if they are selected dates\n     *      * https://github.com/fetrarij/ngx-daterangepicker-material/issues/139\n     */\n    setCalendarCurrentPage(): void {\n        const selectedFirstDate = this.selectedDates.length > 0 ? this.selectedDates[0] : this.selectedDate;\n        if (selectedFirstDate && selectedFirstDate.isValid() && this.mode !== DatepickerMode.Range) {\n            const endDate = selectedFirstDate.clone();\n            endDate.add(1, 'month');\n            this.pageSet = true;\n            this.datepickerRef.setStartDate(selectedFirstDate);\n            this.datepickerRef.setEndDate(endDate);\n            this.datepickerRef.updateView();\n        }\n        this.changeDetectorRef.detectChanges();\n    }\n\n    setWidth() {\n        this.width =\n            this.showRanges && this.mode === DatepickerMode.Range\n                ? this.doubleCalendarWidth + this.rangePickerWidth\n                : this.doubleCalendarWidth;\n    }\n}\n","<div class=\"custom-calendar\" [style.width]=\"width + 'px'\">\n    <div class=\"custom-header\">\n        <div class=\"month-header\"\n             *ngIf=\"this.datepickerRef.leftCalendar.month\">\n            <div class=\"month-arrow-button\" (click)=\"onPreviousMonth()\">\n                <ap-symbol\n                    [symbolId]=\"'arrow-left-1'\"\n                    [color]=\"'#858FA1'\"\n                    [size]=\"'14'\"></ap-symbol>\n            </div>\n            <div class=\"month-label\">\n                {{ this.datepickerRef.leftCalendar.month.locale(locale).format('MMMM YYYY') }}\n            </div>\n        </div>\n        <div class=\"month-header\"\n             *ngIf=\"this.datepickerRef.rightCalendar.month\">\n            <div class=\"month-label\">\n                {{ this.datepickerRef.rightCalendar.month.locale(locale).format('MMMM YYYY') }}\n            </div>\n            <div class=\"month-arrow-button\" (click)=\"onNextMonth()\">\n                <ap-symbol\n                    [symbolId]=\"'arrow-right-1'\"\n                    [color]=\"'#858FA1'\"\n                    [size]=\"'14'\"></ap-symbol>\n            </div>\n        </div>\n        <div class=\"header-filler\" *ngIf=\"showRanges && mode === DatepickerMode.Range\">\n        </div>\n    </div>\n    <ngx-daterangepicker-material\n        #datepickerRef\n        [class.hide-ranges]=\"!showRanges\"\n        [alwaysShowCalendars]=\"true\"\n        [autoApply]=\"true\"\n        [customRangeDirection]=\"true\"\n        [isCustomDate]=\"$any(isCustomDate)\"\n        [locale]=\"localeConfig\"\n        [maxDate]=\"maxDate\"\n        [minDate]=\"minDate\"\n        [ranges]=\"showRanges && mode === DatepickerMode.Range ? ranges : null\"\n        (datesUpdated)=\"onDatesUpdated($event)\"\n        (startDateChanged)=\"onStartDateChanged($event)\">\n    </ngx-daterangepicker-material>\n</div>\n"]}
@@ -1,7 +1,7 @@
1
1
  // Angular
2
2
  import { Directive, Input } from '@angular/core';
3
3
  // Third-parties
4
- import { fromEvent } from "rxjs";
4
+ import { fromEvent } from 'rxjs';
5
5
  import * as i0 from "@angular/core";
6
6
  import * as i1 from "@agorapulse/ui-components/tooltip-neo";
7
7
  export class TruncateTooltipDirective {
@@ -12,7 +12,15 @@ export class TruncateTooltipDirective {
12
12
  updateTruncateState() {
13
13
  const element = this.elementRef.nativeElement;
14
14
  const truncated = element.scrollWidth > element.clientWidth;
15
- this.tooltipNeo.apTooltipNeo = truncated ? this.truncateTooltip : '';
15
+ let defaultTooltip = '';
16
+ // In case a default tooltip content exists, even not truncated, the tooltip stay displayed
17
+ if (typeof (this.truncateTooltip) === 'object' && this.truncateTooltip.defaultContent) {
18
+ defaultTooltip = {
19
+ ...this.truncateTooltip,
20
+ content: this.truncateTooltip.defaultContent
21
+ };
22
+ }
23
+ this.tooltipNeo.apTooltipNeo = truncated ? this.truncateTooltip : defaultTooltip;
16
24
  }
17
25
  ngOnInit() {
18
26
  this.elementRefMouseOver$ = fromEvent(this.elementRef.nativeElement, 'mouseover')
@@ -30,4 +38,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
30
38
  }], ctorParameters: function () { return [{ type: i1.TooltipNeoDirective }, { type: i0.ElementRef }]; }, propDecorators: { truncateTooltip: [{
31
39
  type: Input
32
40
  }] } });
33
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1bmNhdGUtdG9vbHRpcC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL3VpLWNvbXBvbmVudHMvZGlyZWN0aXZlcy9zcmMvdHJ1bmNhdGUtdG9vbHRpcC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsVUFBVTtBQUNWLE9BQU8sRUFBQyxTQUFTLEVBQWMsS0FBSyxFQUFvQixNQUFNLGVBQWUsQ0FBQztBQUM5RSxnQkFBZ0I7QUFDaEIsT0FBTyxFQUFDLFNBQVMsRUFBZSxNQUFNLE1BQU0sQ0FBQzs7O0FBRzdDLE1BQU0sT0FBTyx3QkFBd0I7SUFNakMsWUFDWSxVQUErQixFQUMvQixVQUFtQztRQURuQyxlQUFVLEdBQVYsVUFBVSxDQUFxQjtRQUMvQixlQUFVLEdBQVYsVUFBVSxDQUF5QjtJQUUvQyxDQUFDO0lBRU8sbUJBQW1CO1FBQ3ZCLE1BQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDO1FBQzlDLE1BQU0sU0FBUyxHQUFHLE9BQU8sQ0FBQyxXQUFXLEdBQUcsT0FBTyxDQUFDLFdBQVcsQ0FBQztRQUM1RCxJQUFJLENBQUMsVUFBVSxDQUFDLFlBQVksR0FBRyxTQUFTLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztJQUN6RSxDQUFDO0lBRUQsUUFBUTtRQUNKLElBQUksQ0FBQyxvQkFBb0IsR0FBRyxTQUFTLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLEVBQUUsV0FBVyxDQUFDO2FBQzVFLFNBQVMsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsbUJBQW1CLEVBQUUsQ0FBQyxDQUFDO0lBQ3JELENBQUM7SUFFRCxXQUFXO1FBQ1AsSUFBSSxDQUFDLG9CQUFvQixDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQzVDLENBQUM7O3FIQXpCUSx3QkFBd0I7eUdBQXhCLHdCQUF3QjsyRkFBeEIsd0JBQXdCO2tCQURwQyxTQUFTO21CQUFDLEVBQUMsUUFBUSxFQUFFLGlDQUFpQyxFQUFFLFVBQVUsRUFBRSxJQUFJLEdBQUU7bUlBRzlELGVBQWU7c0JBQXZCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBBZ29yYXB1bHNlXG5pbXBvcnQge1Rvb2x0aXBOZW9EaXJlY3RpdmUsIFRvb2x0aXBOZW9QYXJhbXN9IGZyb20gJ0BhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvdG9vbHRpcC1uZW8nO1xuLy8gQW5ndWxhclxuaW1wb3J0IHtEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIElucHV0LCBPbkRlc3Ryb3ksIE9uSW5pdH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG4vLyBUaGlyZC1wYXJ0aWVzXG5pbXBvcnQge2Zyb21FdmVudCwgU3Vic2NyaXB0aW9ufSBmcm9tIFwicnhqc1wiO1xuXG5ARGlyZWN0aXZlKHtzZWxlY3RvcjogJ1thcFRvb2x0aXBOZW9dW3RydW5jYXRlVG9vbHRpcF0nLCBzdGFuZGFsb25lOiB0cnVlLH0pXG5leHBvcnQgY2xhc3MgVHJ1bmNhdGVUb29sdGlwRGlyZWN0aXZlIGltcGxlbWVudHMgT25Jbml0LCBPbkRlc3Ryb3kge1xuXG4gICAgQElucHV0KCkgdHJ1bmNhdGVUb29sdGlwOiBzdHJpbmcgfCBUb29sdGlwTmVvUGFyYW1zO1xuXG4gICAgcHJpdmF0ZSBlbGVtZW50UmVmTW91c2VPdmVyJDogU3Vic2NyaXB0aW9uO1xuXG4gICAgY29uc3RydWN0b3IoXG4gICAgICAgIHByaXZhdGUgdG9vbHRpcE5lbzogVG9vbHRpcE5lb0RpcmVjdGl2ZSxcbiAgICAgICAgcHJpdmF0ZSBlbGVtZW50UmVmOiBFbGVtZW50UmVmPEhUTUxFbGVtZW50PlxuICAgICkge1xuICAgIH1cblxuICAgIHByaXZhdGUgdXBkYXRlVHJ1bmNhdGVTdGF0ZSgpOiB2b2lkIHtcbiAgICAgICAgY29uc3QgZWxlbWVudCA9IHRoaXMuZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50O1xuICAgICAgICBjb25zdCB0cnVuY2F0ZWQgPSBlbGVtZW50LnNjcm9sbFdpZHRoID4gZWxlbWVudC5jbGllbnRXaWR0aDtcbiAgICAgICAgdGhpcy50b29sdGlwTmVvLmFwVG9vbHRpcE5lbyA9IHRydW5jYXRlZCA/IHRoaXMudHJ1bmNhdGVUb29sdGlwIDogJyc7XG4gICAgfVxuXG4gICAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuZWxlbWVudFJlZk1vdXNlT3ZlciQgPSBmcm9tRXZlbnQodGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQsICdtb3VzZW92ZXInKVxuICAgICAgICAgICAgLnN1YnNjcmliZSgoKSA9PiB0aGlzLnVwZGF0ZVRydW5jYXRlU3RhdGUoKSk7XG4gICAgfVxuXG4gICAgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgICAgIHRoaXMuZWxlbWVudFJlZk1vdXNlT3ZlciQudW5zdWJzY3JpYmUoKTtcbiAgICB9XG59XG4iXX0=
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1bmNhdGUtdG9vbHRpcC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL3VpLWNvbXBvbmVudHMvZGlyZWN0aXZlcy9zcmMvdHJ1bmNhdGUtdG9vbHRpcC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsVUFBVTtBQUNWLE9BQU8sRUFBQyxTQUFTLEVBQWMsS0FBSyxFQUFvQixNQUFNLGVBQWUsQ0FBQztBQUM5RSxnQkFBZ0I7QUFDaEIsT0FBTyxFQUFDLFNBQVMsRUFBZSxNQUFNLE1BQU0sQ0FBQzs7O0FBSTdDLE1BQU0sT0FBTyx3QkFBd0I7SUFNakMsWUFDWSxVQUErQixFQUMvQixVQUFtQztRQURuQyxlQUFVLEdBQVYsVUFBVSxDQUFxQjtRQUMvQixlQUFVLEdBQVYsVUFBVSxDQUF5QjtJQUUvQyxDQUFDO0lBRU8sbUJBQW1CO1FBQ3ZCLE1BQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDO1FBQzlDLE1BQU0sU0FBUyxHQUFHLE9BQU8sQ0FBQyxXQUFXLEdBQUcsT0FBTyxDQUFDLFdBQVcsQ0FBQztRQUU1RCxJQUFJLGNBQWMsR0FBOEIsRUFBRSxDQUFDO1FBQ25ELDJGQUEyRjtRQUMzRixJQUFJLE9BQU0sQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDLEtBQUssUUFBUSxJQUFJLElBQUksQ0FBQyxlQUFlLENBQUMsY0FBYyxFQUFFO1lBQ2xGLGNBQWMsR0FBRztnQkFDYixHQUFHLElBQUksQ0FBQyxlQUFlO2dCQUN2QixPQUFPLEVBQUUsSUFBSSxDQUFDLGVBQWUsQ0FBQyxjQUFjO2FBQy9DLENBQUE7U0FDSjtRQUNELElBQUksQ0FBQyxVQUFVLENBQUMsWUFBWSxHQUFHLFNBQVMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxDQUFDLENBQUMsY0FBYyxDQUFDO0lBRXJGLENBQUM7SUFFRCxRQUFRO1FBQ0osSUFBSSxDQUFDLG9CQUFvQixHQUFHLFNBQVMsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsRUFBRSxXQUFXLENBQUM7YUFDNUUsU0FBUyxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxtQkFBbUIsRUFBRSxDQUFDLENBQUM7SUFDckQsQ0FBQztJQUVELFdBQVc7UUFDUCxJQUFJLENBQUMsb0JBQW9CLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDNUMsQ0FBQzs7cUhBbkNRLHdCQUF3Qjt5R0FBeEIsd0JBQXdCOzJGQUF4Qix3QkFBd0I7a0JBRHBDLFNBQVM7bUJBQUMsRUFBQyxRQUFRLEVBQUUsaUNBQWlDLEVBQUUsVUFBVSxFQUFFLElBQUksR0FBRTttSUFHOUQsZUFBZTtzQkFBdkIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbIi8vIEFnb3JhcHVsc2VcbmltcG9ydCB7VG9vbHRpcE5lb0RpcmVjdGl2ZSwgVG9vbHRpcE5lb1BhcmFtc30gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy90b29sdGlwLW5lbyc7XG4vLyBBbmd1bGFyXG5pbXBvcnQge0RpcmVjdGl2ZSwgRWxlbWVudFJlZiwgSW5wdXQsIE9uRGVzdHJveSwgT25Jbml0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcbi8vIFRoaXJkLXBhcnRpZXNcbmltcG9ydCB7ZnJvbUV2ZW50LCBTdWJzY3JpcHRpb259IGZyb20gJ3J4anMnO1xuaW1wb3J0IHtUcnVuY2F0ZVRvb2x0aXBOZW9QYXJhbXN9IGZyb20gJy4vdHJ1bmNhdGUtdG9vbHRpcC5tb2RlbCc7XG5cbkBEaXJlY3RpdmUoe3NlbGVjdG9yOiAnW2FwVG9vbHRpcE5lb11bdHJ1bmNhdGVUb29sdGlwXScsIHN0YW5kYWxvbmU6IHRydWUsfSlcbmV4cG9ydCBjbGFzcyBUcnVuY2F0ZVRvb2x0aXBEaXJlY3RpdmUgaW1wbGVtZW50cyBPbkluaXQsIE9uRGVzdHJveSB7XG5cbiAgICBASW5wdXQoKSB0cnVuY2F0ZVRvb2x0aXA6IHN0cmluZyB8IFRydW5jYXRlVG9vbHRpcE5lb1BhcmFtcztcblxuICAgIHByaXZhdGUgZWxlbWVudFJlZk1vdXNlT3ZlciQ6IFN1YnNjcmlwdGlvbjtcblxuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBwcml2YXRlIHRvb2x0aXBOZW86IFRvb2x0aXBOZW9EaXJlY3RpdmUsXG4gICAgICAgIHByaXZhdGUgZWxlbWVudFJlZjogRWxlbWVudFJlZjxIVE1MRWxlbWVudD5cbiAgICApIHtcbiAgICB9XG5cbiAgICBwcml2YXRlIHVwZGF0ZVRydW5jYXRlU3RhdGUoKTogdm9pZCB7XG4gICAgICAgIGNvbnN0IGVsZW1lbnQgPSB0aGlzLmVsZW1lbnRSZWYubmF0aXZlRWxlbWVudDtcbiAgICAgICAgY29uc3QgdHJ1bmNhdGVkID0gZWxlbWVudC5zY3JvbGxXaWR0aCA+IGVsZW1lbnQuY2xpZW50V2lkdGg7XG5cbiAgICAgICAgbGV0IGRlZmF1bHRUb29sdGlwOiBzdHJpbmcgfCBUb29sdGlwTmVvUGFyYW1zID0gJyc7XG4gICAgICAgIC8vIEluIGNhc2UgYSBkZWZhdWx0IHRvb2x0aXAgY29udGVudCBleGlzdHMsIGV2ZW4gbm90IHRydW5jYXRlZCwgdGhlIHRvb2x0aXAgc3RheSBkaXNwbGF5ZWRcbiAgICAgICAgaWYgKHR5cGVvZih0aGlzLnRydW5jYXRlVG9vbHRpcCkgPT09ICdvYmplY3QnICYmIHRoaXMudHJ1bmNhdGVUb29sdGlwLmRlZmF1bHRDb250ZW50KSB7XG4gICAgICAgICAgICBkZWZhdWx0VG9vbHRpcCA9IHtcbiAgICAgICAgICAgICAgICAuLi50aGlzLnRydW5jYXRlVG9vbHRpcCxcbiAgICAgICAgICAgICAgICBjb250ZW50OiB0aGlzLnRydW5jYXRlVG9vbHRpcC5kZWZhdWx0Q29udGVudFxuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIHRoaXMudG9vbHRpcE5lby5hcFRvb2x0aXBOZW8gPSB0cnVuY2F0ZWQgPyB0aGlzLnRydW5jYXRlVG9vbHRpcCA6IGRlZmF1bHRUb29sdGlwO1xuXG4gICAgfVxuXG4gICAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuZWxlbWVudFJlZk1vdXNlT3ZlciQgPSBmcm9tRXZlbnQodGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQsICdtb3VzZW92ZXInKVxuICAgICAgICAgICAgLnN1YnNjcmliZSgoKSA9PiB0aGlzLnVwZGF0ZVRydW5jYXRlU3RhdGUoKSk7XG4gICAgfVxuXG4gICAgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgICAgIHRoaXMuZWxlbWVudFJlZk1vdXNlT3ZlciQudW5zdWJzY3JpYmUoKTtcbiAgICB9XG59XG4iXX0=
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1bmNhdGUtdG9vbHRpcC5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2xpYnMvdWktY29tcG9uZW50cy9kaXJlY3RpdmVzL3NyYy90cnVuY2F0ZS10b29sdGlwLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1RlbXBsYXRlUmVmfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7VG9vbHRpcE5lb1BhcmFtc30gZnJvbSBcIkBhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvdG9vbHRpcC1uZW9cIjtcblxuZXhwb3J0IGludGVyZmFjZSBUcnVuY2F0ZVRvb2x0aXBOZW9QYXJhbXMgZXh0ZW5kcyBUb29sdGlwTmVvUGFyYW1zIHtcbiAgICBkZWZhdWx0Q29udGVudD86IHN0cmluZyB8IFRlbXBsYXRlUmVmPGFueT47XG59XG4iXX0=
package/esm2020/index.mjs CHANGED
@@ -14,6 +14,7 @@ export { AvatarComponent } from '@agorapulse/ui-components/avatar';
14
14
  export { StepperComponent } from '@agorapulse/ui-components/stepper';
15
15
  export { ConfirmModalComponent } from '@agorapulse/ui-components/confirm-modal';
16
16
  export { DatepickerComponent, DatepickerMode } from '@agorapulse/ui-components/datepicker';
17
+ export { NeoDatepickerComponent, DayDisabledPipe } from '@agorapulse/ui-components/neo-datepicker';
17
18
  export { DotsStepperComponent } from '@agorapulse/ui-components/dots-stepper';
18
19
  export { InfoboxComponent } from '@agorapulse/ui-components/infobox';
19
20
  export { LabelComponent } from '@agorapulse/ui-components/labels';
@@ -32,4 +33,4 @@ export { SnackbarsThreadComponent } from '@agorapulse/ui-components/snackbars-th
32
33
  // Service
33
34
  export { SnackbarsThreadService } from '@agorapulse/ui-components/snackbars-thread';
34
35
  export { generateCodeStatus, CodeStatus } from '@agorapulse/ui-components/snackbars-thread';
35
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9saWJzL3VpLWNvbXBvbmVudHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxTQUFTO0FBQ1QsT0FBTyxFQUFDLDRCQUE0QixFQUFDLE1BQU0sMkNBQTJDLENBQUM7QUFDdkYsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLG1DQUFtQyxDQUFDO0FBRWhFLFlBQVk7QUFDWixPQUFPLEVBQUMseUJBQXlCLEVBQUUscUJBQXFCLEVBQUUsaUJBQWlCLEVBQ3ZFLGtCQUFrQixFQUFFLHVCQUF1QixFQUFFLHVCQUF1QixFQUFFLHdCQUF3QixFQUFDLE1BQU0sc0NBQXNDLENBQUM7QUFDaEosT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sbUNBQW1DLENBQUM7QUFDbkUsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0sdUNBQXVDLENBQUM7QUFFMUUsWUFBWTtBQUNaLE9BQU8sRUFBQyxtQkFBbUIsRUFBQyxNQUFNLHVDQUF1QyxDQUFDO0FBQzFFLE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSxrQ0FBa0MsQ0FBQztBQUNqRSxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxtQ0FBbUMsQ0FBQztBQUNuRSxPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSx5Q0FBeUMsQ0FBQztBQUM5RSxPQUFPLEVBQUMsbUJBQW1CLEVBQUUsY0FBYyxFQUF5QixNQUFNLHNDQUFzQyxDQUFDO0FBQ2pILE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLHdDQUF3QyxDQUFDO0FBQzVFLE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLG1DQUFtQyxDQUFDO0FBQ25FLE9BQU8sRUFBQyxjQUFjLEVBQUMsTUFBTSxrQ0FBa0MsQ0FBQztBQUNoRSxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSxrQ0FBa0MsQ0FBQztBQUNwRSxPQUFPLEVBQUMsdUJBQXVCLEVBQUMsTUFBTSwyQ0FBMkMsQ0FBQztBQUNsRixPQUFPLEVBQUMsa0NBQWtDLEVBQUMsTUFBTSxpREFBaUQsQ0FBQztBQUNuRyxPQUFPLEVBQUMsY0FBYyxFQUFjLE1BQU0saUNBQWlDLENBQUM7QUFDNUUsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0scUNBQXFDLENBQUM7QUFDdkUsT0FBTyxFQUFDLHNCQUFzQixFQUFDLE1BQU0sMENBQTBDLENBQUM7QUFDaEYsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sbUNBQW1DLENBQUM7QUFDbkUsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0sb0NBQW9DLENBQUM7QUFDckUsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0sd0NBQXdDLENBQUM7QUFDN0UsT0FBTyxFQUFDLHdCQUF3QixFQUFDLE1BQU0scUNBQXFDLENBQUM7QUFDN0UsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sd0NBQXdDLENBQUM7QUFDNUUsT0FBTyxFQUFDLHdCQUF3QixFQUFDLE1BQU0sNENBQTRDLENBQUM7QUFFcEYsVUFBVTtBQUNWLE9BQU8sRUFBQyxzQkFBc0IsRUFBQyxNQUFNLDRDQUE0QyxDQUFDO0FBS2xGLE9BQU8sRUFBQyxrQkFBa0IsRUFBRSxVQUFVLEVBQXVFLE1BQU0sNENBQTRDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIHVpXG4gKi9cblxuLy8gTW9kdWxlXG5leHBvcnQge0Fnb3JhcHVsc2VVaUNvbXBvbmVudHNNb2R1bGV9IGZyb20gJy4vc3JjL2xpYi9hZ29yYXB1bHNlLXVpLWNvbXBvbmVudHMubW9kdWxlJztcbmV4cG9ydCB7UG9wbWVudU1vZHVsZX0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9wb3BtZW51JztcblxuLy8gRGlyZWN0aXZlXG5leHBvcnQge0F1dG9zaXplVGV4dGFyZWFEaXJlY3RpdmUsIERlZmF1bHRJbWFnZURpcmVjdGl2ZSwgRWxsaXBzaXNEaXJlY3RpdmUsXG4gICAgRnJvemVuR2lmRGlyZWN0aXZlLCBFcXVhbFZhbGlkYXRvckRpcmVjdGl2ZSwgTXVsdGlTdHlsZVRleHREaXJlY3RpdmUsIFRydW5jYXRlVG9vbHRpcERpcmVjdGl2ZX0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9kaXJlY3RpdmVzJztcbmV4cG9ydCB7UG9wbWVudURpcmVjdGl2ZX0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9wb3BtZW51JztcbmV4cG9ydCB7VG9vbHRpcE5lb0RpcmVjdGl2ZX0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy90b29sdGlwLW5lbyc7XG5cbi8vIENvbXBvbmVudFxuZXhwb3J0IHtBZGRDb21tZW50Q29tcG9uZW50fSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL2FkZC1jb21tZW50JztcbmV4cG9ydCB7QXZhdGFyQ29tcG9uZW50fSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL2F2YXRhcic7XG5leHBvcnQge1N0ZXBwZXJDb21wb25lbnR9IGZyb20gJ0BhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvc3RlcHBlcic7XG5leHBvcnQge0NvbmZpcm1Nb2RhbENvbXBvbmVudH0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9jb25maXJtLW1vZGFsJztcbmV4cG9ydCB7RGF0ZXBpY2tlckNvbXBvbmVudCwgRGF0ZXBpY2tlck1vZGUsIEkxOG5EYXRlUGlja2VyLCBQZXJpb2R9IGZyb20gJ0BhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvZGF0ZXBpY2tlcic7XG5leHBvcnQge0RvdHNTdGVwcGVyQ29tcG9uZW50fSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL2RvdHMtc3RlcHBlcic7XG5leHBvcnQge0luZm9ib3hDb21wb25lbnR9IGZyb20gJ0BhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvaW5mb2JveCc7XG5leHBvcnQge0xhYmVsQ29tcG9uZW50fSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL2xhYmVscyc7XG5leHBvcnQge0xhYmVsTGlzdENvbXBvbmVudH0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9sYWJlbHMnO1xuZXhwb3J0IHtMYWJlbHNTZWxlY3RvckNvbXBvbmVudH0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9sYWJlbHMtc2VsZWN0b3InO1xuZXhwb3J0IHtNZWRpYURpc3BsYXlPdmVybGF5RGlhbG9nQ29tcG9uZW50fSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL21lZGlhLWRpc3BsYXktb3ZlcmxheSc7XG5leHBvcnQge01vZGFsQ29tcG9uZW50LCBNb2RhbENvbmZpZ30gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9tb2RhbCc7XG5leHBvcnQge1BhZ2luYXRvckNvbXBvbmVudH0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9wYWdpbmF0b3InO1xuZXhwb3J0IHtQYXNzd29yZElucHV0Q29tcG9uZW50fSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL3Bhc3N3b3JkLWlucHV0JztcbmV4cG9ydCB7UG9wbWVudUNvbXBvbmVudH0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9wb3BtZW51JztcbmV4cG9ydCB7U25hY2tCYXJDb21wb25lbnR9IGZyb20gJ0BhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvc25hY2tiYXInO1xuZXhwb3J0IHtOb3RpZmljYXRpb25Db21wb25lbnR9IGZyb20gJ0BhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvbm90aWZpY2F0aW9uJztcbmV4cG9ydCB7UGFnaW5hdG9yQnV0dG9uQ29tcG9uZW50fSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL3BhZ2luYXRvcic7XG5leHBvcnQge1NsaWRlVG9nZ2xlQ29tcG9uZW50fSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL3NsaWRlLXRvZ2dsZSc7XG5leHBvcnQge1NuYWNrYmFyc1RocmVhZENvbXBvbmVudH0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9zbmFja2JhcnMtdGhyZWFkJztcblxuLy8gU2VydmljZVxuZXhwb3J0IHtTbmFja2JhcnNUaHJlYWRTZXJ2aWNlfSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL3NuYWNrYmFycy10aHJlYWQnO1xuXG4vLyBNb2RlbFxuZXhwb3J0IHtTdGVwfSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL3N0ZXBwZXInO1xuZXhwb3J0IHtDb25maXJtTW9kYWxUZXh0c30gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9jb25maXJtLW1vZGFsJztcbmV4cG9ydCB7Z2VuZXJhdGVDb2RlU3RhdHVzLCBDb2RlU3RhdHVzLCBTbmFja2JhcnNUaHJlYWRCYXNlLCBTbmFja2JhclR5cGVWYWx1ZXMsIGV4dGVybmFsU25hY2tiYXJUeXBlQWxsb3dlZH0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9zbmFja2JhcnMtdGhyZWFkJztcbiJdfQ==
36
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9saWJzL3VpLWNvbXBvbmVudHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxTQUFTO0FBQ1QsT0FBTyxFQUFDLDRCQUE0QixFQUFDLE1BQU0sMkNBQTJDLENBQUM7QUFDdkYsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLG1DQUFtQyxDQUFDO0FBRWhFLFlBQVk7QUFDWixPQUFPLEVBQUMseUJBQXlCLEVBQUUscUJBQXFCLEVBQUUsaUJBQWlCLEVBQ3ZFLGtCQUFrQixFQUFFLHVCQUF1QixFQUFFLHVCQUF1QixFQUFFLHdCQUF3QixFQUFDLE1BQU0sc0NBQXNDLENBQUM7QUFDaEosT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sbUNBQW1DLENBQUM7QUFDbkUsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0sdUNBQXVDLENBQUM7QUFFMUUsWUFBWTtBQUNaLE9BQU8sRUFBQyxtQkFBbUIsRUFBQyxNQUFNLHVDQUF1QyxDQUFDO0FBQzFFLE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSxrQ0FBa0MsQ0FBQztBQUNqRSxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxtQ0FBbUMsQ0FBQztBQUNuRSxPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSx5Q0FBeUMsQ0FBQztBQUM5RSxPQUFPLEVBQUMsbUJBQW1CLEVBQUUsY0FBYyxFQUF5QixNQUFNLHNDQUFzQyxDQUFDO0FBQ2pILE9BQU8sRUFBQyxzQkFBc0IsRUFBaUUsZUFBZSxFQUFDLE1BQU0sMENBQTBDLENBQUM7QUFDaEssT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sd0NBQXdDLENBQUM7QUFDNUUsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sbUNBQW1DLENBQUM7QUFDbkUsT0FBTyxFQUFDLGNBQWMsRUFBQyxNQUFNLGtDQUFrQyxDQUFDO0FBQ2hFLE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLGtDQUFrQyxDQUFDO0FBQ3BFLE9BQU8sRUFBQyx1QkFBdUIsRUFBQyxNQUFNLDJDQUEyQyxDQUFDO0FBQ2xGLE9BQU8sRUFBQyxrQ0FBa0MsRUFBQyxNQUFNLGlEQUFpRCxDQUFDO0FBQ25HLE9BQU8sRUFBQyxjQUFjLEVBQWMsTUFBTSxpQ0FBaUMsQ0FBQztBQUM1RSxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQztBQUN2RSxPQUFPLEVBQUMsc0JBQXNCLEVBQUMsTUFBTSwwQ0FBMEMsQ0FBQztBQUNoRixPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxtQ0FBbUMsQ0FBQztBQUNuRSxPQUFPLEVBQUMsaUJBQWlCLEVBQUMsTUFBTSxvQ0FBb0MsQ0FBQztBQUNyRSxPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSx3Q0FBd0MsQ0FBQztBQUM3RSxPQUFPLEVBQUMsd0JBQXdCLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQztBQUM3RSxPQUFPLEVBQUMsb0JBQW9CLEVBQUMsTUFBTSx3Q0FBd0MsQ0FBQztBQUM1RSxPQUFPLEVBQUMsd0JBQXdCLEVBQUMsTUFBTSw0Q0FBNEMsQ0FBQztBQUVwRixVQUFVO0FBQ1YsT0FBTyxFQUFDLHNCQUFzQixFQUFDLE1BQU0sNENBQTRDLENBQUM7QUFLbEYsT0FBTyxFQUFDLGtCQUFrQixFQUFFLFVBQVUsRUFBdUUsTUFBTSw0Q0FBNEMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgdWlcbiAqL1xuXG4vLyBNb2R1bGVcbmV4cG9ydCB7QWdvcmFwdWxzZVVpQ29tcG9uZW50c01vZHVsZX0gZnJvbSAnLi9zcmMvbGliL2Fnb3JhcHVsc2UtdWktY29tcG9uZW50cy5tb2R1bGUnO1xuZXhwb3J0IHtQb3BtZW51TW9kdWxlfSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL3BvcG1lbnUnO1xuXG4vLyBEaXJlY3RpdmVcbmV4cG9ydCB7QXV0b3NpemVUZXh0YXJlYURpcmVjdGl2ZSwgRGVmYXVsdEltYWdlRGlyZWN0aXZlLCBFbGxpcHNpc0RpcmVjdGl2ZSxcbiAgICBGcm96ZW5HaWZEaXJlY3RpdmUsIEVxdWFsVmFsaWRhdG9yRGlyZWN0aXZlLCBNdWx0aVN0eWxlVGV4dERpcmVjdGl2ZSwgVHJ1bmNhdGVUb29sdGlwRGlyZWN0aXZlfSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL2RpcmVjdGl2ZXMnO1xuZXhwb3J0IHtQb3BtZW51RGlyZWN0aXZlfSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL3BvcG1lbnUnO1xuZXhwb3J0IHtUb29sdGlwTmVvRGlyZWN0aXZlfSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL3Rvb2x0aXAtbmVvJztcblxuLy8gQ29tcG9uZW50XG5leHBvcnQge0FkZENvbW1lbnRDb21wb25lbnR9IGZyb20gJ0BhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvYWRkLWNvbW1lbnQnO1xuZXhwb3J0IHtBdmF0YXJDb21wb25lbnR9IGZyb20gJ0BhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvYXZhdGFyJztcbmV4cG9ydCB7U3RlcHBlckNvbXBvbmVudH0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9zdGVwcGVyJztcbmV4cG9ydCB7Q29uZmlybU1vZGFsQ29tcG9uZW50fSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL2NvbmZpcm0tbW9kYWwnO1xuZXhwb3J0IHtEYXRlcGlja2VyQ29tcG9uZW50LCBEYXRlcGlja2VyTW9kZSwgSTE4bkRhdGVQaWNrZXIsIFBlcmlvZH0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9kYXRlcGlja2VyJztcbmV4cG9ydCB7TmVvRGF0ZXBpY2tlckNvbXBvbmVudCwgTmVvRGF0ZVBpY2tlclN0YXJ0c09uLCBOZW9EYXRlUGlja2VyTW9kZSwgTmVvRGF0ZVBpY2tlckxvY2FsZSwgRGF5RGlzYWJsZWRQaXBlfSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL25lby1kYXRlcGlja2VyJztcbmV4cG9ydCB7RG90c1N0ZXBwZXJDb21wb25lbnR9IGZyb20gJ0BhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvZG90cy1zdGVwcGVyJztcbmV4cG9ydCB7SW5mb2JveENvbXBvbmVudH0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9pbmZvYm94JztcbmV4cG9ydCB7TGFiZWxDb21wb25lbnR9IGZyb20gJ0BhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvbGFiZWxzJztcbmV4cG9ydCB7TGFiZWxMaXN0Q29tcG9uZW50fSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL2xhYmVscyc7XG5leHBvcnQge0xhYmVsc1NlbGVjdG9yQ29tcG9uZW50fSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL2xhYmVscy1zZWxlY3Rvcic7XG5leHBvcnQge01lZGlhRGlzcGxheU92ZXJsYXlEaWFsb2dDb21wb25lbnR9IGZyb20gJ0BhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvbWVkaWEtZGlzcGxheS1vdmVybGF5JztcbmV4cG9ydCB7TW9kYWxDb21wb25lbnQsIE1vZGFsQ29uZmlnfSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL21vZGFsJztcbmV4cG9ydCB7UGFnaW5hdG9yQ29tcG9uZW50fSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL3BhZ2luYXRvcic7XG5leHBvcnQge1Bhc3N3b3JkSW5wdXRDb21wb25lbnR9IGZyb20gJ0BhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvcGFzc3dvcmQtaW5wdXQnO1xuZXhwb3J0IHtQb3BtZW51Q29tcG9uZW50fSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL3BvcG1lbnUnO1xuZXhwb3J0IHtTbmFja0JhckNvbXBvbmVudH0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9zbmFja2Jhcic7XG5leHBvcnQge05vdGlmaWNhdGlvbkNvbXBvbmVudH0gZnJvbSAnQGFnb3JhcHVsc2UvdWktY29tcG9uZW50cy9ub3RpZmljYXRpb24nO1xuZXhwb3J0IHtQYWdpbmF0b3JCdXR0b25Db21wb25lbnR9IGZyb20gJ0BhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvcGFnaW5hdG9yJztcbmV4cG9ydCB7U2xpZGVUb2dnbGVDb21wb25lbnR9IGZyb20gJ0BhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvc2xpZGUtdG9nZ2xlJztcbmV4cG9ydCB7U25hY2tiYXJzVGhyZWFkQ29tcG9uZW50fSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL3NuYWNrYmFycy10aHJlYWQnO1xuXG4vLyBTZXJ2aWNlXG5leHBvcnQge1NuYWNrYmFyc1RocmVhZFNlcnZpY2V9IGZyb20gJ0BhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvc25hY2tiYXJzLXRocmVhZCc7XG5cbi8vIE1vZGVsXG5leHBvcnQge1N0ZXB9IGZyb20gJ0BhZ29yYXB1bHNlL3VpLWNvbXBvbmVudHMvc3RlcHBlcic7XG5leHBvcnQge0NvbmZpcm1Nb2RhbFRleHRzfSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL2NvbmZpcm0tbW9kYWwnO1xuZXhwb3J0IHtnZW5lcmF0ZUNvZGVTdGF0dXMsIENvZGVTdGF0dXMsIFNuYWNrYmFyc1RocmVhZEJhc2UsIFNuYWNrYmFyVHlwZVZhbHVlcywgZXh0ZXJuYWxTbmFja2JhclR5cGVBbGxvd2VkfSBmcm9tICdAYWdvcmFwdWxzZS91aS1jb21wb25lbnRzL3NuYWNrYmFycy10aHJlYWQnO1xuIl19
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './public_api';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWdvcmFwdWxzZS11aS1jb21wb25lbnRzLW5lby1kYXRlcGlja2VyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vbGlicy91aS1jb21wb25lbnRzL25lby1kYXRlcGlja2VyL3NyYy9hZ29yYXB1bHNlLXVpLWNvbXBvbmVudHMtbmVvLWRhdGVwaWNrZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWNfYXBpJztcbiJdfQ==
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF5LWRldGFpbC5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2xpYnMvdWktY29tcG9uZW50cy9uZW8tZGF0ZXBpY2tlci9zcmMvZGF5LWRldGFpbC5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgZGF5anMgZnJvbSAnZGF5anMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIERheURldGFpbCB7XG4gICAgZGF0ZTogbnVtYmVyLFxuICAgIGRheSxcbiAgICBtb250aCxcbiAgICB0aW1lc3RhbXA6IG51bWJlcixcbiAgICBkYXlTdHJpbmc6IHN0cmluZyxcbiAgICBkYXlqczogZGF5anMuRGF5anMsXG59XG4iXX0=
@@ -0,0 +1,21 @@
1
+ import { Pipe } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class DayDisabledPipe {
4
+ transform(day, todayTimestamp, minDateTimestamp, maxDateTimestamp) {
5
+ return day.month !== 0
6
+ || (day.timestamp < todayTimestamp && !minDateTimestamp)
7
+ || (minDateTimestamp && day.timestamp < minDateTimestamp)
8
+ || (maxDateTimestamp && day.timestamp > maxDateTimestamp);
9
+ }
10
+ }
11
+ DayDisabledPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: DayDisabledPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe });
12
+ DayDisabledPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "14.2.0", ngImport: i0, type: DayDisabledPipe, isStandalone: true, name: "dayDisabled" });
13
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: DayDisabledPipe, decorators: [{
14
+ type: Pipe,
15
+ args: [{
16
+ name: 'dayDisabled',
17
+ pure: true,
18
+ standalone: true
19
+ }]
20
+ }] });
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF5LWRpc2FibGVkLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL3VpLWNvbXBvbmVudHMvbmVvLWRhdGVwaWNrZXIvc3JjL2RheS1kaXNhYmxlZC5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxJQUFJLEVBQWdCLE1BQU0sZUFBZSxDQUFDOztBQVFsRCxNQUFNLE9BQU8sZUFBZTtJQUV4QixTQUFTLENBQUMsR0FBYyxFQUFFLGNBQXNCLEVBQUUsZ0JBQXlCLEVBQUUsZ0JBQXlCO1FBQ2xHLE9BQU8sR0FBRyxDQUFDLEtBQUssS0FBSyxDQUFDO2VBQ2YsQ0FBQyxHQUFHLENBQUMsU0FBUyxHQUFHLGNBQWMsSUFBSSxDQUFDLGdCQUFnQixDQUFDO2VBQ3JELENBQUMsZ0JBQWdCLElBQUksR0FBRyxDQUFDLFNBQVMsR0FBRyxnQkFBZ0IsQ0FBQztlQUN0RCxDQUFDLGdCQUFnQixJQUFJLEdBQUcsQ0FBQyxTQUFTLEdBQUcsZ0JBQWdCLENBQUMsQ0FBQTtJQUNqRSxDQUFDOzs0R0FQUSxlQUFlOzBHQUFmLGVBQWU7MkZBQWYsZUFBZTtrQkFMM0IsSUFBSTttQkFBQztvQkFDRixJQUFJLEVBQUUsYUFBYTtvQkFDbkIsSUFBSSxFQUFFLElBQUk7b0JBQ1YsVUFBVSxFQUFFLElBQUk7aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtQaXBlLCBQaXBlVHJhbnNmb3JtfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7RGF5RGV0YWlsfSBmcm9tIFwiLi9kYXktZGV0YWlsLm1vZGVsXCI7XG5cbkBQaXBlKHtcbiAgICBuYW1lOiAnZGF5RGlzYWJsZWQnLFxuICAgIHB1cmU6IHRydWUsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZVxufSlcbmV4cG9ydCBjbGFzcyBEYXlEaXNhYmxlZFBpcGUgaW1wbGVtZW50cyBQaXBlVHJhbnNmb3JtIHtcblxuICAgIHRyYW5zZm9ybShkYXk6IERheURldGFpbCwgdG9kYXlUaW1lc3RhbXA6IG51bWJlciwgbWluRGF0ZVRpbWVzdGFtcD86IG51bWJlciwgbWF4RGF0ZVRpbWVzdGFtcD86IG51bWJlcik6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gZGF5Lm1vbnRoICE9PSAwXG4gICAgICAgICAgICB8fCAoZGF5LnRpbWVzdGFtcCA8IHRvZGF5VGltZXN0YW1wICYmICFtaW5EYXRlVGltZXN0YW1wKVxuICAgICAgICAgICAgfHwgKG1pbkRhdGVUaW1lc3RhbXAgJiYgZGF5LnRpbWVzdGFtcCA8IG1pbkRhdGVUaW1lc3RhbXApXG4gICAgICAgICAgICB8fCAobWF4RGF0ZVRpbWVzdGFtcCAmJiBkYXkudGltZXN0YW1wID4gbWF4RGF0ZVRpbWVzdGFtcClcbiAgICB9XG59XG4iXX0=
@@ -0,0 +1,189 @@
1
+ import { AgorapulseUiSymbolModule } from '@agorapulse/ui-symbol';
2
+ import { NgForOf, NgIf, NgTemplateOutlet, SlicePipe, TitleCasePipe } from '@angular/common';
3
+ import { ChangeDetectionStrategy, Component, EventEmitter, inject, Input, Output, } from '@angular/core';
4
+ import { MatButtonModule } from '@angular/material/button';
5
+ import dayjs from 'dayjs';
6
+ import 'dayjs/locale/de';
7
+ import 'dayjs/locale/en';
8
+ import 'dayjs/locale/es';
9
+ import 'dayjs/locale/fr';
10
+ import 'dayjs/locale/pt';
11
+ import localeData from 'dayjs/plugin/localeData';
12
+ import { DayDisabledPipe } from './day-disabled.pipe';
13
+ import * as i0 from "@angular/core";
14
+ import * as i1 from "@agorapulse/ui-symbol";
15
+ import * as i2 from "@angular/material/button";
16
+ export class NeoDatepickerComponent {
17
+ constructor() {
18
+ this.ONE_DAY = 60 * 60 * 24 * 1000;
19
+ this.TODAY_TIMESTAMP = Date.now() - (Date.now() % this.ONE_DAY) + new Date().getTimezoneOffset() * 1000 * 60;
20
+ this._mode = 'single';
21
+ this.startsOn = 'monday';
22
+ this.datesSelected = new EventEmitter();
23
+ this.nextMonth = new EventEmitter();
24
+ this.previousMonth = new EventEmitter();
25
+ this.selectedDaysTimestamp = new Set();
26
+ this.dayDisabledPipe = inject(DayDisabledPipe);
27
+ }
28
+ set mode(mode) {
29
+ this._mode = mode;
30
+ if (this._mode === 'single') {
31
+ this._selectedDates = this._selectedDates.slice(0, 1);
32
+ this.selectedDaysTimestamp = new Set(Array.from(this.selectedDaysTimestamp).slice(0, 1));
33
+ }
34
+ }
35
+ get mode() {
36
+ return this._mode;
37
+ }
38
+ set selectedDates(dates) {
39
+ if (this._mode === 'single') {
40
+ dates = dates.slice(0, 1);
41
+ }
42
+ this.selectedDaysTimestamp = new Set();
43
+ this._selectedDates = dates;
44
+ if (this._selectedDates.length) {
45
+ this._selectedDates.forEach(day => {
46
+ this.selectedDaysTimestamp.add(day.toDate().getTime());
47
+ });
48
+ }
49
+ }
50
+ get selectedDates() {
51
+ return this._selectedDates;
52
+ }
53
+ ngOnInit() {
54
+ dayjs.extend(localeData);
55
+ const date = new Date();
56
+ this.currentYear = date.getFullYear();
57
+ this.currentMonth = date.getMonth();
58
+ if (this.minDate) {
59
+ this.minDateTimestamp = this.minDate.toDate().getTime();
60
+ }
61
+ if (this.maxDate) {
62
+ this.maxDateTimestamp = this.maxDate.toDate().getTime();
63
+ }
64
+ if (this.locale) {
65
+ dayjs.locale(this.locale);
66
+ }
67
+ this.months = dayjs.months();
68
+ this.weekDays = [...dayjs.weekdays()];
69
+ if (this.startsOn === 'monday') {
70
+ const sunday = this.weekDays.slice(0, 1);
71
+ this.weekDays.splice(0, 1);
72
+ this.weekDays = this.weekDays.concat(sunday);
73
+ }
74
+ this.currentMonthDates = this.getMonthDetails(this.currentYear, this.currentMonth);
75
+ }
76
+ getDayDetails(index, firstDay, month, numberOfDays, year) {
77
+ const date = index - firstDay;
78
+ const day = index % 7;
79
+ let prevMonth = month - 1;
80
+ let prevYear = year;
81
+ if (prevMonth < 0) {
82
+ prevMonth = 11;
83
+ prevYear--;
84
+ }
85
+ const prevMonthNumberOfDays = this.getNumberOfDays(prevYear, prevMonth);
86
+ const _date = (date < 0 ? prevMonthNumberOfDays + date : date % numberOfDays) + 1;
87
+ const _month = date < 0 ? -1 : date >= numberOfDays ? 1 : 0;
88
+ const newDate = new Date(year, _month + month, _date);
89
+ const timestamp = newDate.getTime();
90
+ const dayString = this.weekDays[day];
91
+ return {
92
+ date: _date,
93
+ day,
94
+ month: _month,
95
+ timestamp,
96
+ dayString,
97
+ dayjs: dayjs(newDate),
98
+ };
99
+ }
100
+ getNumberOfDays(year, month) {
101
+ return 40 - new Date(year, month, 40).getDate();
102
+ }
103
+ getMonthDetails(year, month) {
104
+ let firstDay = new Date(year, month).getDay();
105
+ if (this.startsOn === 'monday') {
106
+ firstDay -= 1;
107
+ }
108
+ const numberOfDays = this.getNumberOfDays(year, month);
109
+ const monthArray = [];
110
+ const rows = 6;
111
+ let currentDay = null;
112
+ let index = 0;
113
+ const cols = 7;
114
+ for (let row = 0; row < rows; row++) {
115
+ for (let col = 0; col < cols; col++) {
116
+ currentDay = this.getDayDetails(index, firstDay, month, numberOfDays, year);
117
+ monthArray.push(currentDay);
118
+ index++;
119
+ }
120
+ }
121
+ return monthArray;
122
+ }
123
+ onPreviousMonth() {
124
+ this.previousMonth.emit();
125
+ this.currentMonth -= 1;
126
+ if (this.currentMonth === -1) {
127
+ this.currentMonth = 11;
128
+ this.currentYear -= 1;
129
+ }
130
+ this.currentMonthDates = this.getMonthDetails(this.currentYear, this.currentMonth);
131
+ }
132
+ onNextMonth() {
133
+ this.nextMonth.emit();
134
+ this.currentMonth += 1;
135
+ if (this.currentMonth === 12) {
136
+ this.currentMonth = 0;
137
+ this.currentYear += 1;
138
+ }
139
+ this.currentMonthDates = this.getMonthDetails(this.currentYear, this.currentMonth);
140
+ }
141
+ onSelectDay(dayDetail) {
142
+ const dayDisabled = this.dayDisabledPipe.transform(dayDetail, this.TODAY_TIMESTAMP, this.minDateTimestamp, this.maxDateTimestamp);
143
+ if (!dayDisabled) {
144
+ if (this.mode === 'single') {
145
+ this.selectedDaysTimestamp.clear();
146
+ }
147
+ if (this.minDate && dayDetail.dayjs.isBefore(dayjs(this.minDate))) {
148
+ return;
149
+ }
150
+ if (this.maxDate && dayDetail.dayjs.isAfter(dayjs(this.maxDate))) {
151
+ return;
152
+ }
153
+ if (this.selectedDaysTimestamp.has(dayDetail.timestamp)) {
154
+ this.selectedDaysTimestamp.delete(dayDetail.timestamp);
155
+ }
156
+ else {
157
+ this.selectedDaysTimestamp.add(dayDetail.timestamp);
158
+ }
159
+ this.datesSelected.emit(Array.from(this.selectedDaysTimestamp).map(timestamp => dayjs(timestamp)));
160
+ }
161
+ }
162
+ }
163
+ NeoDatepickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: NeoDatepickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
164
+ NeoDatepickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: NeoDatepickerComponent, isStandalone: true, selector: "ap-neo-date-picker", inputs: { dayTemplate: "dayTemplate", locale: "locale", minDate: "minDate", maxDate: "maxDate", mode: "mode", selectedDates: "selectedDates", startsOn: "startsOn" }, outputs: { datesSelected: "datesSelected", nextMonth: "nextMonth", previousMonth: "previousMonth" }, providers: [DayDisabledPipe], ngImport: i0, template: "<div class=\"date-picker-container\">\n <div class=\"date-picker\">\n <div class=\"month-navigation\">\n <button mat-stroked-button\n class=\"circle ghost left\"\n (click)=\"onPreviousMonth()\"\n >\n <ap-symbol\n symbolId=\"arrow-button-left\"\n size=\"micro\"\n >\n </ap-symbol>\n </button>\n <span>\n {{ months[currentMonth] | titlecase }} {{ currentYear }}\n </span>\n <button mat-stroked-button\n class=\"circle ghost right\"\n (click)=\"onNextMonth()\"\n >\n <ap-symbol\n symbolId=\"arrow-button-right\"\n size=\"micro\"\n >\n </ap-symbol>\n </button>\n </div>\n <div class=\"week-header\">\n <ng-container *ngFor=\"let day of weekDays\">\n <div class=\"day\">\n {{ day | slice:0:2 | titlecase }}\n </div>\n </ng-container>\n </div>\n <div class=\"days-container\">\n <ng-container *ngFor=\"let day of currentMonthDates\">\n <ng-container *ngIf=\"dayTemplate\"\n [ngTemplateOutlet]=\"dayTemplate\"\n [ngTemplateOutletContext]=\"{day: day}\"\n ></ng-container>\n <ng-container *ngIf=\"!dayTemplate\">\n <div class=\"day\"\n [class.disabled]=\"day | dayDisabled:TODAY_TIMESTAMP:minDateTimestamp:maxDateTimestamp\"\n [class.today]=\"day.timestamp === TODAY_TIMESTAMP\"\n [class.selected]=\"selectedDaysTimestamp.has(day.timestamp)\"\n (click)=\"onSelectDay(day)\"\n >\n <span>\n {{ day.date }}\n </span>\n </div>\n </ng-container>\n </ng-container>\n </div>\n </div>\n</div>\n", styles: ["[color=facebook]{color:#1877f2}[bgcolor=facebook],[hcolor=facebook]:hover{background-color:#1877f2}[border=facebook]{border:1px solid #1877f2}[color=google]{color:#4e85e8}[bgcolor=google],[hcolor=google]:hover{background-color:#4e85e8}[border=google]{border:1px solid #4e85e8}[color=instagram]{color:#e1306c}[bgcolor=instagram],[hcolor=instagram]:hover{background-color:#e1306c}[border=instagram]{border:1px solid #e1306c}[color=instagrammagenta]{color:#c13584}[bgcolor=instagrammagenta],[hcolor=instagrammagenta]:hover{background-color:#c13584}[border=instagrammagenta]{border:1px solid #c13584}[color=instagramblue]{color:#5851db}[bgcolor=instagramblue],[hcolor=instagramblue]:hover{background-color:#5851db}[border=instagramblue]{border:1px solid #5851db}[color=instagrampurple]{color:#833ab4}[bgcolor=instagrampurple],[hcolor=instagrampurple]:hover{background-color:#833ab4}[border=instagrampurple]{border:1px solid #833ab4}[color=instagramorange]{color:#f56040}[bgcolor=instagramorange],[hcolor=instagramorange]:hover{background-color:#f56040}[border=instagramorange]{border:1px solid #f56040}[color=instagramyellow]{color:#ffdc80}[bgcolor=instagramyellow],[hcolor=instagramyellow]:hover{background-color:#ffdc80}[border=instagramyellow]{border:1px solid #ffdc80}[color=linkedin]{color:#2c67bc}[bgcolor=linkedin],[hcolor=linkedin]:hover{background-color:#2c67bc}[border=linkedin]{border:1px solid #2c67bc}[color=twitter]{color:#55acee}[bgcolor=twitter],[hcolor=twitter]:hover{background-color:#55acee}[border=twitter]{border:1px solid #55acee}[color=youtube]{color:red}[bgcolor=youtube],[hcolor=youtube]:hover{background-color:red}[border=youtube]{border:1px solid #ff0000}[color=blood-orange]{color:#ff4d00}[bgcolor=blood-orange],[hcolor=blood-orange]:hover{background-color:#ff4d00}[border=blood-orange]{border:1px solid #ff4d00}[color=pinkish-orange]{color:#ff7b49}[bgcolor=pinkish-orange],[hcolor=pinkish-orange]:hover{background-color:#ff7b49}[border=pinkish-orange]{border:1px solid #ff7b49}[color=charcoal-grey]{color:#2a2f34}[bgcolor=charcoal-grey],[hcolor=charcoal-grey]:hover{background-color:#2a2f34}[border=charcoal-grey]{border:1px solid #2a2f34}[color=azure]{color:#00aeef}[bgcolor=azure],[hcolor=azure]:hover{background-color:#00aeef}[border=azure]{border:1px solid #00aeef}[color=light-azure]{color:#eaf5fd}[bgcolor=light-azure],[hcolor=light-azure]:hover{background-color:#eaf5fd}[border=light-azure]{border:1px solid #eaf5fd}[color=blue-grey]{color:#8d98a9}[bgcolor=blue-grey],[hcolor=blue-grey]:hover{background-color:#8d98a9}[border=blue-grey]{border:1px solid #8d98a9}[color=silver]{color:#ced0da}[bgcolor=silver],[hcolor=silver]:hover{background-color:#ced0da}[border=silver]{border:1px solid #ced0da}[color=pale-grey]{color:#dfe3e9}[bgcolor=pale-grey],[hcolor=pale-grey]:hover{background-color:#dfe3e9}[border=pale-grey]{border:1px solid #dfe3e9}[color=grey-white]{color:#f5f7f8}[bgcolor=grey-white],[hcolor=grey-white]:hover{background-color:#f5f7f8}[border=grey-white]{border:1px solid #f5f7f8}[color=cool-grey]{color:#b4bbc6}[bgcolor=cool-grey],[hcolor=cool-grey]:hover{background-color:#b4bbc6}[border=cool-grey]{border:1px solid #b4bbc6}[color=black]{color:#344563}[bgcolor=black],[hcolor=black]:hover{background-color:#344563}[border=black]{border:1px solid #344563}[color=grey-blue]{color:#68768c}[bgcolor=grey-blue],[hcolor=grey-blue]:hover{background-color:#68768c}[border=grey-blue]{border:1px solid #68768c}[color=strawberry]{color:#f4282d}[bgcolor=strawberry],[hcolor=strawberry]:hover{background-color:#f4282d}[border=strawberry]{border:1px solid #f4282d}[color=light-strawberry]{color:#f8eded}[bgcolor=light-strawberry],[hcolor=light-strawberry]:hover{background-color:#f8eded}[border=light-strawberry]{border:1px solid #f8eded}[color=white]{color:#fff}[bgcolor=white],[hcolor=white]:hover{background-color:#fff}[border=white]{border:1px solid #ffffff}[color=cool-green]{color:#33c15d}[bgcolor=cool-green],[hcolor=cool-green]:hover{background-color:#33c15d}[border=cool-green]{border:1px solid #33c15d}[color=light-green]{color:#ebfaef}[bgcolor=light-green],[hcolor=light-green]:hover{background-color:#ebfaef}[border=light-green]{border:1px solid #ebfaef}[color=transparent]{color:transparent}[bgcolor=transparent],[hcolor=transparent]:hover{background-color:transparent}[border=transparent]{border:1px solid transparent}[color=c0]{color:#a566a5}[bgcolor=c0],[hcolor=c0]:hover{background-color:#a566a5}[border=c0]{border:1px solid #A566A5}[color=c1]{color:#c7ab82}[bgcolor=c1],[hcolor=c1]:hover{background-color:#c7ab82}[border=c1]{border:1px solid #C7AB82}[color=c2]{color:#f2713c}[bgcolor=c2],[hcolor=c2]:hover{background-color:#f2713c}[border=c2]{border:1px solid #F2713C}[color=c3]{color:#ffd006}[bgcolor=c3],[hcolor=c3]:hover{background-color:#ffd006}[border=c3]{border:1px solid #FFD006}[color=c4]{color:#94c5aa}[bgcolor=c4],[hcolor=c4]:hover{background-color:#94c5aa}[border=c4]{border:1px solid #94C5AA}[color=c5]{color:#2a9d8f}[bgcolor=c5],[hcolor=c5]:hover{background-color:#2a9d8f}[border=c5]{border:1px solid #2A9D8F}[color=c6]{color:#78acd8}[bgcolor=c6],[hcolor=c6]:hover{background-color:#78acd8}[border=c6]{border:1px solid #78ACD8}[color=c7]{color:#525a9e}[bgcolor=c7],[hcolor=c7]:hover{background-color:#525a9e}[border=c7]{border:1px solid #525A9E}[color=c8]{color:#6a2459}[bgcolor=c8],[hcolor=c8]:hover{background-color:#6a2459}[border=c8]{border:1px solid #6A2459}[color=c9]{color:#74729e}[bgcolor=c9],[hcolor=c9]:hover{background-color:#74729e}[border=c9]{border:1px solid #74729E}:host .date-picker-container{display:flex;justify-content:center;align-items:center}:host .date-picker-container .date-picker{width:248px}:host .date-picker-container .date-picker .month-navigation{display:flex;justify-content:space-between;margin-bottom:32px}:host .date-picker-container .date-picker .month-navigation .left ap-symbol{margin-right:2px}:host .date-picker-container .date-picker .month-navigation .right ap-symbol{margin-left:2px}:host .date-picker-container .date-picker .month-navigation ap-symbol{display:grid;place-content:center}:host .date-picker-container .date-picker .month-navigation span{font-style:normal;font-weight:700;font-size:16px;line-height:20px;text-align:center;color:#344563;align-items:center;display:flex}:host .date-picker-container .date-picker .week-header{display:flex;justify-content:space-between;margin-bottom:8px}:host .date-picker-container .date-picker .week-header .day{width:32px;text-align:center;font-weight:700;font-size:12px;line-height:15px;color:#aeb5c1}:host .date-picker-container .date-picker .days-container{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:2px}:host .date-picker-container .date-picker .days-container .day{font-style:normal;font-weight:400;font-size:14px;line-height:128.7%;text-align:center;width:32px;height:32px;display:flex;justify-content:center;align-items:center;border-radius:100%;position:relative}:host .date-picker-container .date-picker .days-container .day:hover{cursor:pointer}:host .date-picker-container .date-picker .days-container .day:hover:not(.disabled):not(.selected){background:#f5f5f7}:host .date-picker-container .date-picker .days-container .day.today{border:1px #178dfe solid}:host .date-picker-container .date-picker .days-container .day.selected{background:#178dfe;color:#fff!important}:host .date-picker-container .date-picker .days-container .day.selected .bubble{background:white!important}:host .date-picker-container .date-picker .days-container .day.disabled{color:#aeb5c1}:host .date-picker-container .date-picker .days-container .day .bubble{width:4px;height:4px;border-radius:100%;bottom:3px;position:absolute;background:#178dfe}\n"], dependencies: [{ kind: "ngmodule", type: AgorapulseUiSymbolModule }, { kind: "component", type: i1.SymbolComponent, selector: "ap-symbol", inputs: ["color", "id", "symbolId", "size", "state"] }, { kind: "pipe", type: TitleCasePipe, name: "titlecase" }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i2.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "directive", type: NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: SlicePipe, name: "slice" }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "pipe", type: DayDisabledPipe, name: "dayDisabled" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
165
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: NeoDatepickerComponent, decorators: [{
166
+ type: Component,
167
+ args: [{ selector: 'ap-neo-date-picker', changeDetection: ChangeDetectionStrategy.OnPush, providers: [DayDisabledPipe], imports: [AgorapulseUiSymbolModule, TitleCasePipe, MatButtonModule, NgForOf, NgIf, SlicePipe, NgTemplateOutlet, DayDisabledPipe], standalone: true, template: "<div class=\"date-picker-container\">\n <div class=\"date-picker\">\n <div class=\"month-navigation\">\n <button mat-stroked-button\n class=\"circle ghost left\"\n (click)=\"onPreviousMonth()\"\n >\n <ap-symbol\n symbolId=\"arrow-button-left\"\n size=\"micro\"\n >\n </ap-symbol>\n </button>\n <span>\n {{ months[currentMonth] | titlecase }} {{ currentYear }}\n </span>\n <button mat-stroked-button\n class=\"circle ghost right\"\n (click)=\"onNextMonth()\"\n >\n <ap-symbol\n symbolId=\"arrow-button-right\"\n size=\"micro\"\n >\n </ap-symbol>\n </button>\n </div>\n <div class=\"week-header\">\n <ng-container *ngFor=\"let day of weekDays\">\n <div class=\"day\">\n {{ day | slice:0:2 | titlecase }}\n </div>\n </ng-container>\n </div>\n <div class=\"days-container\">\n <ng-container *ngFor=\"let day of currentMonthDates\">\n <ng-container *ngIf=\"dayTemplate\"\n [ngTemplateOutlet]=\"dayTemplate\"\n [ngTemplateOutletContext]=\"{day: day}\"\n ></ng-container>\n <ng-container *ngIf=\"!dayTemplate\">\n <div class=\"day\"\n [class.disabled]=\"day | dayDisabled:TODAY_TIMESTAMP:minDateTimestamp:maxDateTimestamp\"\n [class.today]=\"day.timestamp === TODAY_TIMESTAMP\"\n [class.selected]=\"selectedDaysTimestamp.has(day.timestamp)\"\n (click)=\"onSelectDay(day)\"\n >\n <span>\n {{ day.date }}\n </span>\n </div>\n </ng-container>\n </ng-container>\n </div>\n </div>\n</div>\n", styles: ["[color=facebook]{color:#1877f2}[bgcolor=facebook],[hcolor=facebook]:hover{background-color:#1877f2}[border=facebook]{border:1px solid #1877f2}[color=google]{color:#4e85e8}[bgcolor=google],[hcolor=google]:hover{background-color:#4e85e8}[border=google]{border:1px solid #4e85e8}[color=instagram]{color:#e1306c}[bgcolor=instagram],[hcolor=instagram]:hover{background-color:#e1306c}[border=instagram]{border:1px solid #e1306c}[color=instagrammagenta]{color:#c13584}[bgcolor=instagrammagenta],[hcolor=instagrammagenta]:hover{background-color:#c13584}[border=instagrammagenta]{border:1px solid #c13584}[color=instagramblue]{color:#5851db}[bgcolor=instagramblue],[hcolor=instagramblue]:hover{background-color:#5851db}[border=instagramblue]{border:1px solid #5851db}[color=instagrampurple]{color:#833ab4}[bgcolor=instagrampurple],[hcolor=instagrampurple]:hover{background-color:#833ab4}[border=instagrampurple]{border:1px solid #833ab4}[color=instagramorange]{color:#f56040}[bgcolor=instagramorange],[hcolor=instagramorange]:hover{background-color:#f56040}[border=instagramorange]{border:1px solid #f56040}[color=instagramyellow]{color:#ffdc80}[bgcolor=instagramyellow],[hcolor=instagramyellow]:hover{background-color:#ffdc80}[border=instagramyellow]{border:1px solid #ffdc80}[color=linkedin]{color:#2c67bc}[bgcolor=linkedin],[hcolor=linkedin]:hover{background-color:#2c67bc}[border=linkedin]{border:1px solid #2c67bc}[color=twitter]{color:#55acee}[bgcolor=twitter],[hcolor=twitter]:hover{background-color:#55acee}[border=twitter]{border:1px solid #55acee}[color=youtube]{color:red}[bgcolor=youtube],[hcolor=youtube]:hover{background-color:red}[border=youtube]{border:1px solid #ff0000}[color=blood-orange]{color:#ff4d00}[bgcolor=blood-orange],[hcolor=blood-orange]:hover{background-color:#ff4d00}[border=blood-orange]{border:1px solid #ff4d00}[color=pinkish-orange]{color:#ff7b49}[bgcolor=pinkish-orange],[hcolor=pinkish-orange]:hover{background-color:#ff7b49}[border=pinkish-orange]{border:1px solid #ff7b49}[color=charcoal-grey]{color:#2a2f34}[bgcolor=charcoal-grey],[hcolor=charcoal-grey]:hover{background-color:#2a2f34}[border=charcoal-grey]{border:1px solid #2a2f34}[color=azure]{color:#00aeef}[bgcolor=azure],[hcolor=azure]:hover{background-color:#00aeef}[border=azure]{border:1px solid #00aeef}[color=light-azure]{color:#eaf5fd}[bgcolor=light-azure],[hcolor=light-azure]:hover{background-color:#eaf5fd}[border=light-azure]{border:1px solid #eaf5fd}[color=blue-grey]{color:#8d98a9}[bgcolor=blue-grey],[hcolor=blue-grey]:hover{background-color:#8d98a9}[border=blue-grey]{border:1px solid #8d98a9}[color=silver]{color:#ced0da}[bgcolor=silver],[hcolor=silver]:hover{background-color:#ced0da}[border=silver]{border:1px solid #ced0da}[color=pale-grey]{color:#dfe3e9}[bgcolor=pale-grey],[hcolor=pale-grey]:hover{background-color:#dfe3e9}[border=pale-grey]{border:1px solid #dfe3e9}[color=grey-white]{color:#f5f7f8}[bgcolor=grey-white],[hcolor=grey-white]:hover{background-color:#f5f7f8}[border=grey-white]{border:1px solid #f5f7f8}[color=cool-grey]{color:#b4bbc6}[bgcolor=cool-grey],[hcolor=cool-grey]:hover{background-color:#b4bbc6}[border=cool-grey]{border:1px solid #b4bbc6}[color=black]{color:#344563}[bgcolor=black],[hcolor=black]:hover{background-color:#344563}[border=black]{border:1px solid #344563}[color=grey-blue]{color:#68768c}[bgcolor=grey-blue],[hcolor=grey-blue]:hover{background-color:#68768c}[border=grey-blue]{border:1px solid #68768c}[color=strawberry]{color:#f4282d}[bgcolor=strawberry],[hcolor=strawberry]:hover{background-color:#f4282d}[border=strawberry]{border:1px solid #f4282d}[color=light-strawberry]{color:#f8eded}[bgcolor=light-strawberry],[hcolor=light-strawberry]:hover{background-color:#f8eded}[border=light-strawberry]{border:1px solid #f8eded}[color=white]{color:#fff}[bgcolor=white],[hcolor=white]:hover{background-color:#fff}[border=white]{border:1px solid #ffffff}[color=cool-green]{color:#33c15d}[bgcolor=cool-green],[hcolor=cool-green]:hover{background-color:#33c15d}[border=cool-green]{border:1px solid #33c15d}[color=light-green]{color:#ebfaef}[bgcolor=light-green],[hcolor=light-green]:hover{background-color:#ebfaef}[border=light-green]{border:1px solid #ebfaef}[color=transparent]{color:transparent}[bgcolor=transparent],[hcolor=transparent]:hover{background-color:transparent}[border=transparent]{border:1px solid transparent}[color=c0]{color:#a566a5}[bgcolor=c0],[hcolor=c0]:hover{background-color:#a566a5}[border=c0]{border:1px solid #A566A5}[color=c1]{color:#c7ab82}[bgcolor=c1],[hcolor=c1]:hover{background-color:#c7ab82}[border=c1]{border:1px solid #C7AB82}[color=c2]{color:#f2713c}[bgcolor=c2],[hcolor=c2]:hover{background-color:#f2713c}[border=c2]{border:1px solid #F2713C}[color=c3]{color:#ffd006}[bgcolor=c3],[hcolor=c3]:hover{background-color:#ffd006}[border=c3]{border:1px solid #FFD006}[color=c4]{color:#94c5aa}[bgcolor=c4],[hcolor=c4]:hover{background-color:#94c5aa}[border=c4]{border:1px solid #94C5AA}[color=c5]{color:#2a9d8f}[bgcolor=c5],[hcolor=c5]:hover{background-color:#2a9d8f}[border=c5]{border:1px solid #2A9D8F}[color=c6]{color:#78acd8}[bgcolor=c6],[hcolor=c6]:hover{background-color:#78acd8}[border=c6]{border:1px solid #78ACD8}[color=c7]{color:#525a9e}[bgcolor=c7],[hcolor=c7]:hover{background-color:#525a9e}[border=c7]{border:1px solid #525A9E}[color=c8]{color:#6a2459}[bgcolor=c8],[hcolor=c8]:hover{background-color:#6a2459}[border=c8]{border:1px solid #6A2459}[color=c9]{color:#74729e}[bgcolor=c9],[hcolor=c9]:hover{background-color:#74729e}[border=c9]{border:1px solid #74729E}:host .date-picker-container{display:flex;justify-content:center;align-items:center}:host .date-picker-container .date-picker{width:248px}:host .date-picker-container .date-picker .month-navigation{display:flex;justify-content:space-between;margin-bottom:32px}:host .date-picker-container .date-picker .month-navigation .left ap-symbol{margin-right:2px}:host .date-picker-container .date-picker .month-navigation .right ap-symbol{margin-left:2px}:host .date-picker-container .date-picker .month-navigation ap-symbol{display:grid;place-content:center}:host .date-picker-container .date-picker .month-navigation span{font-style:normal;font-weight:700;font-size:16px;line-height:20px;text-align:center;color:#344563;align-items:center;display:flex}:host .date-picker-container .date-picker .week-header{display:flex;justify-content:space-between;margin-bottom:8px}:host .date-picker-container .date-picker .week-header .day{width:32px;text-align:center;font-weight:700;font-size:12px;line-height:15px;color:#aeb5c1}:host .date-picker-container .date-picker .days-container{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:2px}:host .date-picker-container .date-picker .days-container .day{font-style:normal;font-weight:400;font-size:14px;line-height:128.7%;text-align:center;width:32px;height:32px;display:flex;justify-content:center;align-items:center;border-radius:100%;position:relative}:host .date-picker-container .date-picker .days-container .day:hover{cursor:pointer}:host .date-picker-container .date-picker .days-container .day:hover:not(.disabled):not(.selected){background:#f5f5f7}:host .date-picker-container .date-picker .days-container .day.today{border:1px #178dfe solid}:host .date-picker-container .date-picker .days-container .day.selected{background:#178dfe;color:#fff!important}:host .date-picker-container .date-picker .days-container .day.selected .bubble{background:white!important}:host .date-picker-container .date-picker .days-container .day.disabled{color:#aeb5c1}:host .date-picker-container .date-picker .days-container .day .bubble{width:4px;height:4px;border-radius:100%;bottom:3px;position:absolute;background:#178dfe}\n"] }]
168
+ }], propDecorators: { dayTemplate: [{
169
+ type: Input
170
+ }], locale: [{
171
+ type: Input
172
+ }], minDate: [{
173
+ type: Input
174
+ }], maxDate: [{
175
+ type: Input
176
+ }], mode: [{
177
+ type: Input
178
+ }], selectedDates: [{
179
+ type: Input
180
+ }], startsOn: [{
181
+ type: Input
182
+ }], datesSelected: [{
183
+ type: Output
184
+ }], nextMonth: [{
185
+ type: Output
186
+ }], previousMonth: [{
187
+ type: Output
188
+ }] } });
189
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"neo-datepicker.component.js","sourceRoot":"","sources":["../../../../libs/ui-components/neo-datepicker/src/neo-datepicker.component.ts","../../../../libs/ui-components/neo-datepicker/src/neo-datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AgorapulseUiSymbolModule} from '@agorapulse/ui-symbol';\nimport {NgForOf, NgIf, NgTemplateOutlet, SlicePipe, TitleCasePipe} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    EventEmitter,\n    inject,\n    Input,\n    OnInit,\n    Output,\n    TemplateRef,\n} from '@angular/core';\nimport {MatButtonModule} from '@angular/material/button';\nimport dayjs from 'dayjs';\nimport 'dayjs/locale/de';\nimport 'dayjs/locale/en';\nimport 'dayjs/locale/es';\nimport 'dayjs/locale/fr';\nimport 'dayjs/locale/pt';\nimport localeData from 'dayjs/plugin/localeData';\nimport {DayDetail} from './day-detail.model';\nimport {DayDisabledPipe} from './day-disabled.pipe';\n\nexport type NeoDatePickerMode = 'single' | 'multiple';\nexport type NeoDatePickerStartsOn = 'monday' | 'sunday';\nexport type NeoDatePickerLocale = 'en' | 'es' | 'fr' | 'pt' | 'de';\n\n@Component({\n    selector: 'ap-neo-date-picker',\n    styleUrls: ['neo-datepicker.component.scss'],\n    templateUrl: 'neo-datepicker.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [DayDisabledPipe],\n    imports: [AgorapulseUiSymbolModule, TitleCasePipe, MatButtonModule, NgForOf, NgIf, SlicePipe, NgTemplateOutlet, DayDisabledPipe],\n    standalone: true,\n})\nexport class NeoDatepickerComponent implements OnInit {\n    readonly ONE_DAY: number = 60 * 60 * 24 * 1000;\n    readonly TODAY_TIMESTAMP: number =\n        Date.now() - (Date.now() % this.ONE_DAY) + new Date().getTimezoneOffset() * 1000 * 60;\n\n    @Input() dayTemplate: TemplateRef<HTMLElement>;\n    @Input() locale: NeoDatePickerLocale;\n    @Input() minDate: dayjs.Dayjs;\n    @Input() maxDate: dayjs.Dayjs;\n\n    private _mode: NeoDatePickerMode = 'single';\n    @Input() set mode(mode: NeoDatePickerMode) {\n        this._mode = mode;\n        if (this._mode === 'single') {\n            this._selectedDates = this._selectedDates.slice(0, 1);\n            this.selectedDaysTimestamp = new Set(Array.from(this.selectedDaysTimestamp).slice(0, 1));\n        }\n    }\n    get mode(): NeoDatePickerMode {\n        return this._mode;\n    }\n\n    private _selectedDates: dayjs.Dayjs[];\n    @Input() set selectedDates(dates: dayjs.Dayjs[]) {\n        if (this._mode === 'single') {\n            dates = dates.slice(0, 1);\n        }\n        this.selectedDaysTimestamp = new Set();\n        this._selectedDates = dates;\n        if (this._selectedDates.length) {\n            this._selectedDates.forEach(day => {\n                this.selectedDaysTimestamp.add(day.toDate().getTime());\n            });\n        }\n    }\n\n    get selectedDates(): dayjs.Dayjs[] {\n        return this._selectedDates;\n    }\n\n    @Input() startsOn: NeoDatePickerStartsOn = 'monday';\n\n    @Output() datesSelected: EventEmitter<dayjs.Dayjs[]> = new EventEmitter<dayjs.Dayjs[]>();\n    @Output() nextMonth: EventEmitter<void> = new EventEmitter<void>();\n    @Output() previousMonth: EventEmitter<void> = new EventEmitter<void>();\n\n    currentYear: number;\n    currentMonth: number;\n    currentMonthDates: any;\n    minDateTimestamp: number;\n    maxDateTimestamp: number;\n    months: string[];\n    selectedDaysTimestamp: Set<number> = new Set();\n    weekDays: string[];\n\n    dayDisabledPipe: DayDisabledPipe = inject(DayDisabledPipe);\n\n    ngOnInit(): void {\n        dayjs.extend(localeData);\n        const date = new Date();\n        this.currentYear = date.getFullYear();\n        this.currentMonth = date.getMonth();\n        if (this.minDate) {\n            this.minDateTimestamp = this.minDate.toDate().getTime();\n        }\n        if (this.maxDate) {\n            this.maxDateTimestamp = this.maxDate.toDate().getTime();\n        }\n        if (this.locale) {\n            dayjs.locale(this.locale);\n        }\n        this.months = dayjs.months();\n        this.weekDays = [...dayjs.weekdays()];\n\n        if (this.startsOn === 'monday') {\n            const sunday = this.weekDays.slice(0, 1);\n            this.weekDays.splice(0, 1);\n            this.weekDays = this.weekDays.concat(sunday);\n        }\n        this.currentMonthDates = this.getMonthDetails(this.currentYear, this.currentMonth);\n    }\n\n    getDayDetails(index: number, firstDay: number, month: number, numberOfDays: number, year: number): DayDetail {\n        const date = index - firstDay;\n        const day = index % 7;\n        let prevMonth = month - 1;\n        let prevYear = year;\n        if (prevMonth < 0) {\n            prevMonth = 11;\n            prevYear--;\n        }\n        const prevMonthNumberOfDays = this.getNumberOfDays(prevYear, prevMonth);\n        const _date = (date < 0 ? prevMonthNumberOfDays + date : date % numberOfDays) + 1;\n        const _month = date < 0 ? -1 : date >= numberOfDays ? 1 : 0;\n        const newDate = new Date(year, _month + month, _date);\n        const timestamp = newDate.getTime();\n        const dayString = this.weekDays[day];\n        return {\n            date: _date,\n            day,\n            month: _month,\n            timestamp,\n            dayString,\n            dayjs: dayjs(newDate),\n        };\n    }\n\n    getNumberOfDays(year: number, month: number): number {\n        return 40 - new Date(year, month, 40).getDate();\n    }\n\n    getMonthDetails(year: number, month: number): DayDetail[] {\n        let firstDay = new Date(year, month).getDay();\n        if (this.startsOn === 'monday') {\n            firstDay -= 1;\n        }\n        const numberOfDays = this.getNumberOfDays(year, month);\n        const monthArray = [];\n        const rows = 6;\n        let currentDay = null;\n        let index = 0;\n        const cols = 7;\n\n        for (let row = 0; row < rows; row++) {\n            for (let col = 0; col < cols; col++) {\n                currentDay = this.getDayDetails(index, firstDay, month, numberOfDays, year);\n                monthArray.push(currentDay);\n                index++;\n            }\n        }\n        return monthArray;\n    }\n\n    onPreviousMonth(): void {\n        this.previousMonth.emit();\n        this.currentMonth -= 1;\n        if (this.currentMonth === -1) {\n            this.currentMonth = 11;\n            this.currentYear -= 1;\n        }\n        this.currentMonthDates = this.getMonthDetails(this.currentYear, this.currentMonth);\n    }\n\n    onNextMonth(): void {\n        this.nextMonth.emit();\n        this.currentMonth += 1;\n        if (this.currentMonth === 12) {\n            this.currentMonth = 0;\n            this.currentYear += 1;\n        }\n        this.currentMonthDates = this.getMonthDetails(this.currentYear, this.currentMonth);\n    }\n\n    onSelectDay(dayDetail: DayDetail): void {\n        const dayDisabled = this.dayDisabledPipe.transform(\n            dayDetail,\n            this.TODAY_TIMESTAMP,\n            this.minDateTimestamp,\n            this.maxDateTimestamp\n        );\n        if (!dayDisabled) {\n            if (this.mode === 'single') {\n                this.selectedDaysTimestamp.clear();\n            }\n            if (this.minDate && dayDetail.dayjs.isBefore(dayjs(this.minDate))) {\n                return;\n            }\n            if (this.maxDate && dayDetail.dayjs.isAfter(dayjs(this.maxDate))) {\n                return;\n            }\n            if (this.selectedDaysTimestamp.has(dayDetail.timestamp)) {\n                this.selectedDaysTimestamp.delete(dayDetail.timestamp);\n            } else {\n                this.selectedDaysTimestamp.add(dayDetail.timestamp);\n            }\n            this.datesSelected.emit(Array.from(this.selectedDaysTimestamp).map(timestamp => dayjs(timestamp)));\n        }\n    }\n}\n","<div class=\"date-picker-container\">\n    <div class=\"date-picker\">\n        <div class=\"month-navigation\">\n            <button mat-stroked-button\n                    class=\"circle ghost left\"\n                    (click)=\"onPreviousMonth()\"\n            >\n                <ap-symbol\n                    symbolId=\"arrow-button-left\"\n                    size=\"micro\"\n                >\n                </ap-symbol>\n            </button>\n            <span>\n                {{ months[currentMonth] | titlecase  }} {{ currentYear }}\n            </span>\n            <button mat-stroked-button\n                    class=\"circle ghost right\"\n                    (click)=\"onNextMonth()\"\n            >\n                <ap-symbol\n                    symbolId=\"arrow-button-right\"\n                    size=\"micro\"\n                >\n                </ap-symbol>\n            </button>\n        </div>\n        <div class=\"week-header\">\n            <ng-container *ngFor=\"let day of weekDays\">\n                <div class=\"day\">\n                    {{ day | slice:0:2 | titlecase }}\n                </div>\n            </ng-container>\n        </div>\n        <div class=\"days-container\">\n            <ng-container *ngFor=\"let day of currentMonthDates\">\n                <ng-container *ngIf=\"dayTemplate\"\n                            [ngTemplateOutlet]=\"dayTemplate\"\n                            [ngTemplateOutletContext]=\"{day: day}\"\n                ></ng-container>\n                <ng-container *ngIf=\"!dayTemplate\">\n                    <div class=\"day\"\n                         [class.disabled]=\"day | dayDisabled:TODAY_TIMESTAMP:minDateTimestamp:maxDateTimestamp\"\n                         [class.today]=\"day.timestamp === TODAY_TIMESTAMP\"\n                         [class.selected]=\"selectedDaysTimestamp.has(day.timestamp)\"\n                        (click)=\"onSelectDay(day)\"\n                    >\n                        <span>\n                            {{ day.date }}\n                        </span>\n                    </div>\n                </ng-container>\n            </ng-container>\n        </div>\n    </div>\n</div>\n"]}
@@ -0,0 +1,4 @@
1
+ export * from './neo-datepicker.component';
2
+ export * from './day-detail.model';
3
+ export * from './day-disabled.pipe';
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2xpYnMvdWktY29tcG9uZW50cy9uZW8tZGF0ZXBpY2tlci9zcmMvcHVibGljX2FwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDRCQUE0QixDQUFDO0FBQzNDLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxxQkFBcUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbmVvLWRhdGVwaWNrZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZGF5LWRldGFpbC5tb2RlbCc7XG5leHBvcnQgKiBmcm9tICcuL2RheS1kaXNhYmxlZC5waXBlJztcbiJdfQ==