@agorapulse/ui-components 18.0.9 → 18.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.
- package/agorapulse-ui-components-18.0.11.tgz +0 -0
- package/esm2022/datepicker/datepicker.component.mjs +1 -1
- package/esm2022/index.mjs +2 -1
- package/esm2022/input-search/input-search.component.mjs +5 -4
- package/esm2022/nav-selector/agorapulse-ui-components-nav-selector.mjs +5 -0
- package/esm2022/nav-selector/directives/tree-node-accessibility.directive.mjs +30 -0
- package/esm2022/nav-selector/nav-selector-category/nav-selector-category.component.mjs +81 -0
- package/esm2022/nav-selector/nav-selector-category/nav-selector-category.presenter.mjs +29 -0
- package/esm2022/nav-selector/nav-selector-group/nav-selector-group.component.mjs +142 -0
- package/esm2022/nav-selector/nav-selector-group/nav-selector-group.presenter.mjs +31 -0
- package/esm2022/nav-selector/nav-selector-leaf/nav-selector-leaf.component.mjs +240 -0
- package/esm2022/nav-selector/nav-selector-leaf/nav-selector-leaf.presenter.mjs +35 -0
- package/esm2022/nav-selector/nav-selector-leaf-detail/nav-selector-leaf-detail.component.mjs +39 -0
- package/esm2022/nav-selector/nav-selector-leaf-detail/nav-selector-leaf-detail.presenter.mjs +18 -0
- package/esm2022/nav-selector/nav-selector-leaf-details/nav-selector-leaf-details.component.mjs +92 -0
- package/esm2022/nav-selector/nav-selector-leaf-details/nav-selector-leaf-details.presenter.mjs +31 -0
- package/esm2022/nav-selector/nav-selector.component.mjs +123 -0
- package/esm2022/nav-selector/nav-selector.mjs +9 -0
- package/esm2022/nav-selector/nav-selector.state.mjs +173 -0
- package/esm2022/nav-selector/public_api.mjs +2 -0
- package/esm2022/nav-selector/utils/leaf.utils.mjs +10 -0
- package/esm2022/nav-selector/utils/nav-selector.accessibility.mjs +171 -0
- package/esm2022/nav-selector/utils/nav-selector.builder.mjs +263 -0
- package/esm2022/nav-selector/utils/nav-selector.filter.mjs +102 -0
- package/esm2022/nav-selector/utils/nav-selector.folding.mjs +219 -0
- package/esm2022/nav-selector/utils/nav-selector.minifying.mjs +50 -0
- package/esm2022/nav-selector/utils/nav-selector.multi-select.mjs +208 -0
- package/esm2022/nav-selector/utils/nav-selector.single-select.mjs +91 -0
- package/esm2022/nav-selector/utils/nav-selector.view-more.mjs +98 -0
- package/fesm2022/agorapulse-ui-components-datepicker.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-input-search.mjs +4 -3
- package/fesm2022/agorapulse-ui-components-input-search.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-nav-selector.mjs +2198 -0
- package/fesm2022/agorapulse-ui-components-nav-selector.mjs.map +1 -0
- package/fesm2022/agorapulse-ui-components.mjs +1 -0
- package/fesm2022/agorapulse-ui-components.mjs.map +1 -1
- package/index.d.ts +1 -0
- package/input-search/input-search.component.d.ts +1 -1
- package/nav-selector/directives/tree-node-accessibility.directive.d.ts +9 -0
- package/nav-selector/index.d.ts +5 -0
- package/nav-selector/nav-selector-category/nav-selector-category.component.d.ts +16 -0
- package/nav-selector/nav-selector-category/nav-selector-category.presenter.d.ts +14 -0
- package/nav-selector/nav-selector-group/nav-selector-group.component.d.ts +29 -0
- package/nav-selector/nav-selector-group/nav-selector-group.presenter.d.ts +17 -0
- package/nav-selector/nav-selector-leaf/nav-selector-leaf.component.d.ts +51 -0
- package/nav-selector/nav-selector-leaf/nav-selector-leaf.presenter.d.ts +19 -0
- package/nav-selector/nav-selector-leaf-detail/nav-selector-leaf-detail.component.d.ts +13 -0
- package/nav-selector/nav-selector-leaf-detail/nav-selector-leaf-detail.presenter.d.ts +10 -0
- package/nav-selector/nav-selector-leaf-details/nav-selector-leaf-details.component.d.ts +24 -0
- package/nav-selector/nav-selector-leaf-details/nav-selector-leaf-details.presenter.d.ts +14 -0
- package/nav-selector/nav-selector.component.d.ts +29 -0
- package/nav-selector/nav-selector.d.ts +220 -0
- package/nav-selector/nav-selector.state.d.ts +47 -0
- package/nav-selector/public_api.d.ts +2 -0
- package/nav-selector/utils/leaf.utils.d.ts +5 -0
- package/nav-selector/utils/nav-selector.accessibility.d.ts +52 -0
- package/nav-selector/utils/nav-selector.builder.d.ts +32 -0
- package/nav-selector/utils/nav-selector.filter.d.ts +30 -0
- package/nav-selector/utils/nav-selector.folding.d.ts +47 -0
- package/nav-selector/utils/nav-selector.minifying.d.ts +27 -0
- package/nav-selector/utils/nav-selector.multi-select.d.ts +54 -0
- package/nav-selector/utils/nav-selector.single-select.d.ts +15 -0
- package/nav-selector/utils/nav-selector.view-more.d.ts +30 -0
- package/package.json +13 -7
- package/agorapulse-ui-components-18.0.9.tgz +0 -0
|
Binary file
|
|
@@ -285,4 +285,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
285
285
|
}], periodSelected: [{
|
|
286
286
|
type: Output
|
|
287
287
|
}] } });
|
|
288
|
-
//# 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 { SymbolComponent, SymbolRegistry, apArrowLeft, apArrowRight } from '@agorapulse/ui-symbol';\n\nimport { DaterangepickerComponent, NgxDaterangepickerMd } from '@agorapulse/ngx-daterangepicker-material';\nimport {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    EventEmitter,\n    Input,\n    OnChanges,\n    OnInit,\n    Output,\n    SimpleChanges,\n    ViewChild,\n    input,\n} from '@angular/core';\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';\n\nexport enum DatepickerMode {\n    Single = 'Single',\n    Multiple = 'Multiple',\n    Range = 'Range',\n}\n\nexport interface Period {\n    startDate?: dayjs.Dayjs;\n    endDate?: dayjs.Dayjs;\n}\n\nexport interface StartDate {\n    startDate: dayjs.Dayjs;\n}\n\nexport interface I18nDatePicker {\n    ranges: {\n        yesterday: string;\n        lastWeek: string;\n        last30Days: string;\n        lastMonth: string;\n        thisMonth: string;\n        [other: string]: string\n    };\n}\n\nenum SideEnum {\n    left = 'left',\n    right = 'right',\n}\n\n\nexport type RangesConfigPresetType = { [periodText: string]: [dayjs.Dayjs, dayjs.Dayjs] };\nexport const RangesConfigPreset = {\n    yesterday: [dayjs().subtract(1, 'days'), dayjs().subtract(1, 'days')],\n    lastWeek: [dayjs().subtract(7, 'days'), dayjs().subtract(1, 'days')],\n    last30Days: [dayjs().subtract(30, 'days'), dayjs().subtract(1, 'days')],\n    lastMonth: [dayjs().subtract(1, 'month').startOf('month'), dayjs().subtract(1, 'month').endOf('month')],\n    thisMonth: [dayjs().startOf('month'), dayjs().endOf('month')],\n    \n    lastWeekFromToday: [dayjs().subtract(6, 'days'), dayjs()],\n    lastMonthFromToday: [dayjs().subtract(1, 'month').add(1, 'days'), dayjs()],\n    last3MonthsFromToday: [dayjs().subtract(3, 'month').add(1, 'days'), dayjs()],\n    last6MonthsFromToday: [dayjs().subtract(6, 'month').add(1, 'days'), dayjs()],\n    lastYearFromToday: [dayjs().subtract(1, 'year').add(1, 'days'), dayjs()],\n    \n} satisfies RangesConfigPresetType;\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: [SymbolComponent, NgxDaterangepickerMd],\n    styleUrls: ['./datepicker.component.scss'],\n})\nexport class DatepickerComponent implements OnInit, OnChanges, AfterViewInit {\n    @ViewChild('datepickerRef') datepickerRef!: DaterangepickerComponent;\n\n    @Input() firstDayOfWeek = 'monday';\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 = 'en';\n    @Input() set maxDate(maxDate: dayjs.Dayjs | undefined) {\n        if (maxDate) {\n            this.maxDateStr = maxDate.toISOString();\n        } else {\n            this.maxDateStr = '';\n        }\n    }\n    @Input() set minDate(minDate: dayjs.Dayjs | undefined) {\n        if (minDate) {\n            this.minDateStr = minDate.toISOString();\n        } else {\n            this.minDateStr = '';\n        }\n    }\n    @Input({\n        required: true,\n    })\n    mode!: DatepickerMode;\n    @Input() selectedDate: dayjs.Dayjs | undefined = undefined;\n    @Input() selectedDates: dayjs.Dayjs[] = [];\n    @Input() selectedPeriod: Period = { startDate: undefined, endDate: undefined };\n    @Input() showRanges = false;\n    showCustomRangeLabel = input<boolean>(false);\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    rangesConfig = input<RangesConfigPresetType | null>(null);\n    ranges: RangesConfigPresetType = {};\n    rangePickerWidth = 150;\n    width = 0;\n    pageSet = false;\n    maxDateStr: string = '';\n    minDateStr: string = '';\n    constructor(\n        public changeDetectorRef: ChangeDetectorRef,\n        public symbolRegistry: SymbolRegistry\n    ) {\n        this.symbolRegistry.registerSymbols([apArrowLeft, apArrowRight]);\n    }\n\n    ngOnInit() {\n        dayjs.extend(localeData);\n        const rangesConfig = this.rangesConfig();\n        if (rangesConfig) {\n            this.ranges = rangesConfig;\n        } else {\n            // if config not defined - init default ranges\n            this.initRanges();\n        }\n        this.initDatePickerLocale();\n    }\n\n    ngOnChanges(changes: SimpleChanges) {\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 ?? dayjs(undefined));\n                this.datepickerRef.setEndDate(this.selectedPeriod.endDate ?? dayjs(undefined));\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            dayjs.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 = dayjs.localeData().firstDayOfWeek();\n        }\n        this.localeConfig = {\n            customRangeLabel: 'Custom',\n            daysOfWeek: dayjs.weekdaysMin(),\n            monthNames: dayjs.months(),\n            firstDay: firstDayOfWeekIndex,\n        };\n    }\n\n    private initRanges(): void {\n        this.ranges[this.i18n.ranges.yesterday] = RangesConfigPreset.yesterday;\n        this.ranges[this.i18n.ranges.lastWeek] = RangesConfigPreset.lastWeek;\n        this.ranges[this.i18n.ranges.last30Days] = RangesConfigPreset.last30Days;\n        this.ranges[this.i18n.ranges.lastMonth] = RangesConfigPreset.lastMonth;\n        this.ranges[this.i18n.ranges.thisMonth] = RangesConfigPreset.thisMonth;\n    }\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 (dayjs().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: StartDate) {\n        const date = event.startDate.toDate();\n        const dateLocalTime = new Date(date.getTime());\n        const dayJsDate = dayjs(dateLocalTime);\n        if (this.mode !== DatepickerMode.Range) {\n            this.selectedDate = dayJsDate;\n            this.datepickerRef.setEndDate(dayJsDate);\n            if (this.pageSet) {\n                this.pageSet = false;\n            } else {\n                this.dateSelected.emit(dayJsDate.clone());\n                if (this.mode === DatepickerMode.Multiple) {\n                    this.selectedDates.push(dayJsDate);\n                }\n            }\n            if (this.datepickerRef) {\n                this.datepickerRef.updateCalendars();\n            }\n        }\n    }\n\n    onDatesUpdated(event: Period) {\n        if (this.mode === DatepickerMode.Range) {\n            const startDate = event.startDate?.toDate();\n            const startDateLocalTime = startDate ? new Date(startDate.getTime()) : new Date();\n            const endDate = event.endDate?.toDate();\n            const endDateLocalTime = endDate ? new Date(endDate.getTime()) : new Date();\n            this.periodSelected.emit({\n                startDate: dayjs(startDateLocalTime).startOf('day'),\n                endDate: dayjs(endDateLocalTime).endOf('day'),\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\n    class=\"custom-calendar\"\n    [style.width]=\"width + 'px'\">\n    <div class=\"custom-header\">\n        @if (this.datepickerRef.leftCalendar.month) {\n            <div class=\"month-header\">\n                <div\n                    class=\"month-arrow-button\"\n                    (click)=\"onPreviousMonth()\">\n                    <ap-symbol\n                        symbolId=\"arrow-left\"\n                        [color]=\"'#858FA1'\"\n                        [size]=\"14\" />\n                </div>\n                <div class=\"month-label\">\n                    {{ this.datepickerRef.leftCalendar.month.locale(locale).format('MMMM YYYY') }}\n                </div>\n            </div>\n        }\n        @if (this.datepickerRef.rightCalendar.month) {\n            <div class=\"month-header\">\n                <div class=\"month-label\">\n                    {{ this.datepickerRef.rightCalendar.month.locale(locale).format('MMMM YYYY') }}\n                </div>\n                <div\n                    class=\"month-arrow-button\"\n                    (click)=\"onNextMonth()\">\n                    <ap-symbol\n                        symbolId=\"arrow-right\"\n                        [color]=\"'#858FA1'\"\n                        [size]=\"14\" />\n                </div>\n            </div>\n        }\n        @if (showRanges && mode === DatepickerMode.Range) {\n            <div class=\"header-filler\"></div>\n        }\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]=\"maxDateStr\"\n        [minDate]=\"minDateStr\"\n        [ranges]=\"showRanges && mode === DatepickerMode.Range ? ranges : $any(null)\"\n        [showCustomRangeLabel]=\"showCustomRangeLabel()\"\n        (datesUpdated)=\"onDatesUpdated($event)\"\n        (startDateChanged)=\"onStartDateChanged($event)\" />\n</div>\n"]}
|
|
288
|
+
//# 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 { SymbolComponent, SymbolRegistry, apArrowLeft, apArrowRight } from '@agorapulse/ui-symbol';\n\nimport { DaterangepickerComponent, NgxDaterangepickerMd } from '@agorapulse/ngx-daterangepicker-material';\nimport {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    EventEmitter,\n    Input,\n    OnChanges,\n    OnInit,\n    Output,\n    SimpleChanges,\n    ViewChild,\n    input,\n} from '@angular/core';\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';\n\nexport enum DatepickerMode {\n    Single = 'Single',\n    Multiple = 'Multiple',\n    Range = 'Range',\n}\n\nexport interface Period {\n    startDate?: dayjs.Dayjs;\n    endDate?: dayjs.Dayjs;\n}\n\nexport interface StartDate {\n    startDate: dayjs.Dayjs;\n}\n\nexport interface I18nDatePicker {\n    ranges: {\n        yesterday: string;\n        lastWeek: string;\n        last30Days: string;\n        lastMonth: string;\n        thisMonth: string;\n        [other: string]: string;\n    };\n}\n\nenum SideEnum {\n    left = 'left',\n    right = 'right',\n}\n\nexport type RangesConfigPresetType = { [periodText: string]: [dayjs.Dayjs, dayjs.Dayjs] };\nexport const RangesConfigPreset = {\n    yesterday: [dayjs().subtract(1, 'days'), dayjs().subtract(1, 'days')],\n    lastWeek: [dayjs().subtract(7, 'days'), dayjs().subtract(1, 'days')],\n    last30Days: [dayjs().subtract(30, 'days'), dayjs().subtract(1, 'days')],\n    lastMonth: [dayjs().subtract(1, 'month').startOf('month'), dayjs().subtract(1, 'month').endOf('month')],\n    thisMonth: [dayjs().startOf('month'), dayjs().endOf('month')],\n\n    lastWeekFromToday: [dayjs().subtract(6, 'days'), dayjs()],\n    lastMonthFromToday: [dayjs().subtract(1, 'month').add(1, 'days'), dayjs()],\n    last3MonthsFromToday: [dayjs().subtract(3, 'month').add(1, 'days'), dayjs()],\n    last6MonthsFromToday: [dayjs().subtract(6, 'month').add(1, 'days'), dayjs()],\n    lastYearFromToday: [dayjs().subtract(1, 'year').add(1, 'days'), dayjs()],\n} satisfies RangesConfigPresetType;\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: [SymbolComponent, NgxDaterangepickerMd],\n    styleUrls: ['./datepicker.component.scss'],\n})\nexport class DatepickerComponent implements OnInit, OnChanges, AfterViewInit {\n    @ViewChild('datepickerRef') datepickerRef!: DaterangepickerComponent;\n\n    @Input() firstDayOfWeek = 'monday';\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 = 'en';\n    @Input() set maxDate(maxDate: dayjs.Dayjs | undefined) {\n        if (maxDate) {\n            this.maxDateStr = maxDate.toISOString();\n        } else {\n            this.maxDateStr = '';\n        }\n    }\n    @Input() set minDate(minDate: dayjs.Dayjs | undefined) {\n        if (minDate) {\n            this.minDateStr = minDate.toISOString();\n        } else {\n            this.minDateStr = '';\n        }\n    }\n    @Input({\n        required: true,\n    })\n    mode!: DatepickerMode;\n    @Input() selectedDate: dayjs.Dayjs | undefined = undefined;\n    @Input() selectedDates: dayjs.Dayjs[] = [];\n    @Input() selectedPeriod: Period = { startDate: undefined, endDate: undefined };\n    @Input() showRanges = false;\n    showCustomRangeLabel = input<boolean>(false);\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    rangesConfig = input<RangesConfigPresetType | null>(null);\n    ranges: RangesConfigPresetType = {};\n    rangePickerWidth = 150;\n    width = 0;\n    pageSet = false;\n    maxDateStr: string = '';\n    minDateStr: string = '';\n    constructor(\n        public changeDetectorRef: ChangeDetectorRef,\n        public symbolRegistry: SymbolRegistry\n    ) {\n        this.symbolRegistry.registerSymbols([apArrowLeft, apArrowRight]);\n    }\n\n    ngOnInit() {\n        dayjs.extend(localeData);\n        const rangesConfig = this.rangesConfig();\n        if (rangesConfig) {\n            this.ranges = rangesConfig;\n        } else {\n            // if config not defined - init default ranges\n            this.initRanges();\n        }\n        this.initDatePickerLocale();\n    }\n\n    ngOnChanges(changes: SimpleChanges) {\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 ?? dayjs(undefined));\n                this.datepickerRef.setEndDate(this.selectedPeriod.endDate ?? dayjs(undefined));\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            dayjs.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 = dayjs.localeData().firstDayOfWeek();\n        }\n        this.localeConfig = {\n            customRangeLabel: 'Custom',\n            daysOfWeek: dayjs.weekdaysMin(),\n            monthNames: dayjs.months(),\n            firstDay: firstDayOfWeekIndex,\n        };\n    }\n\n    private initRanges(): void {\n        this.ranges[this.i18n.ranges.yesterday] = RangesConfigPreset.yesterday;\n        this.ranges[this.i18n.ranges.lastWeek] = RangesConfigPreset.lastWeek;\n        this.ranges[this.i18n.ranges.last30Days] = RangesConfigPreset.last30Days;\n        this.ranges[this.i18n.ranges.lastMonth] = RangesConfigPreset.lastMonth;\n        this.ranges[this.i18n.ranges.thisMonth] = RangesConfigPreset.thisMonth;\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 (dayjs().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: StartDate) {\n        const date = event.startDate.toDate();\n        const dateLocalTime = new Date(date.getTime());\n        const dayJsDate = dayjs(dateLocalTime);\n        if (this.mode !== DatepickerMode.Range) {\n            this.selectedDate = dayJsDate;\n            this.datepickerRef.setEndDate(dayJsDate);\n            if (this.pageSet) {\n                this.pageSet = false;\n            } else {\n                this.dateSelected.emit(dayJsDate.clone());\n                if (this.mode === DatepickerMode.Multiple) {\n                    this.selectedDates.push(dayJsDate);\n                }\n            }\n            if (this.datepickerRef) {\n                this.datepickerRef.updateCalendars();\n            }\n        }\n    }\n\n    onDatesUpdated(event: Period) {\n        if (this.mode === DatepickerMode.Range) {\n            const startDate = event.startDate?.toDate();\n            const startDateLocalTime = startDate ? new Date(startDate.getTime()) : new Date();\n            const endDate = event.endDate?.toDate();\n            const endDateLocalTime = endDate ? new Date(endDate.getTime()) : new Date();\n            this.periodSelected.emit({\n                startDate: dayjs(startDateLocalTime).startOf('day'),\n                endDate: dayjs(endDateLocalTime).endOf('day'),\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\n    class=\"custom-calendar\"\n    [style.width]=\"width + 'px'\">\n    <div class=\"custom-header\">\n        @if (this.datepickerRef.leftCalendar.month) {\n            <div class=\"month-header\">\n                <div\n                    class=\"month-arrow-button\"\n                    (click)=\"onPreviousMonth()\">\n                    <ap-symbol\n                        symbolId=\"arrow-left\"\n                        [color]=\"'#858FA1'\"\n                        [size]=\"14\" />\n                </div>\n                <div class=\"month-label\">\n                    {{ this.datepickerRef.leftCalendar.month.locale(locale).format('MMMM YYYY') }}\n                </div>\n            </div>\n        }\n        @if (this.datepickerRef.rightCalendar.month) {\n            <div class=\"month-header\">\n                <div class=\"month-label\">\n                    {{ this.datepickerRef.rightCalendar.month.locale(locale).format('MMMM YYYY') }}\n                </div>\n                <div\n                    class=\"month-arrow-button\"\n                    (click)=\"onNextMonth()\">\n                    <ap-symbol\n                        symbolId=\"arrow-right\"\n                        [color]=\"'#858FA1'\"\n                        [size]=\"14\" />\n                </div>\n            </div>\n        }\n        @if (showRanges && mode === DatepickerMode.Range) {\n            <div class=\"header-filler\"></div>\n        }\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]=\"maxDateStr\"\n        [minDate]=\"minDateStr\"\n        [ranges]=\"showRanges && mode === DatepickerMode.Range ? ranges : $any(null)\"\n        [showCustomRangeLabel]=\"showCustomRangeLabel()\"\n        (datesUpdated)=\"onDatesUpdated($event)\"\n        (startDateChanged)=\"onStartDateChanged($event)\" />\n</div>\n"]}
|
package/esm2022/index.mjs
CHANGED
|
@@ -28,6 +28,7 @@ export { SelectComponent } from '@agorapulse/ui-components/legacy/select';
|
|
|
28
28
|
export { TextareaComponent } from '@agorapulse/ui-components/legacy/textarea';
|
|
29
29
|
export { MediaDisplayOverlayDialogComponent } from '@agorapulse/ui-components/media-display-overlay';
|
|
30
30
|
export { ModalComponent } from '@agorapulse/ui-components/modal';
|
|
31
|
+
export { NavSelectorComponent } from '@agorapulse/ui-components/nav-selector';
|
|
31
32
|
export { DayDisabledPipe, NeoDatepickerComponent, } from '@agorapulse/ui-components/neo-datepicker';
|
|
32
33
|
export { NotificationComponent } from '@agorapulse/ui-components/notification';
|
|
33
34
|
export { PaginatorButtonComponent, PaginatorComponent } from '@agorapulse/ui-components/paginator';
|
|
@@ -45,4 +46,4 @@ export { ToggleComponent } from '@agorapulse/ui-components/toggle';
|
|
|
45
46
|
// Service
|
|
46
47
|
export { SnackbarsThreadService } from '@agorapulse/ui-components/snackbars-thread';
|
|
47
48
|
export { CodeStatus, SnackbarTypeValues, generateCodeStatus, } from '@agorapulse/ui-components/snackbars-thread';
|
|
48
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
49
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../libs/ui-components/index.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Public API Surface of ui\n */\n\n// Module\nexport { PopmenuModule } from '@agorapulse/ui-components/popmenu';\nexport { AgorapulseUiComponentsModule } from './src/lib/agorapulse-ui-components.module';\n\n// Directive\nexport {\n    AutosizeTextareaDirective,\n    DefaultImageDirective,\n    EllipsisDirective,\n    EqualValidatorDirective,\n    FrozenGifDirective,\n    MultiStyleTextDirective,\n} from '@agorapulse/ui-components/directives';\nexport { PopmenuDirective } from '@agorapulse/ui-components/popmenu';\nexport { TooltipDirective } from '@agorapulse/ui-components/tooltip';\n\n// Component\nexport { AddCommentComponent } from '@agorapulse/ui-components/add-comment';\nexport { AutocompleteComponent } from '@agorapulse/ui-components/autocomplete';\nexport { AvatarComponent } from '@agorapulse/ui-components/avatar';\nexport { BadgeComponent } from '@agorapulse/ui-components/badge';\nexport { ButtonComponent } from '@agorapulse/ui-components/button';\nexport { CheckboxComponent } from '@agorapulse/ui-components/checkbox';\nexport { ConfirmModalComponent } from '@agorapulse/ui-components/confirm-modal';\nexport { CounterComponent } from '@agorapulse/ui-components/counter';\nexport { DatepickerComponent, DatepickerMode, I18nDatePicker, Period } from '@agorapulse/ui-components/datepicker';\nexport { DotStepperComponent } from '@agorapulse/ui-components/dot-stepper';\nexport { IconButtonComponent } from '@agorapulse/ui-components/icon-button';\nexport { InfoboxComponent } from '@agorapulse/ui-components/infobox';\nexport { LabelComponent, LabelListComponent } from '@agorapulse/ui-components/labels';\nexport { LabelsSelectorComponent } from '@agorapulse/ui-components/labels-selector';\nexport { InputComponent } from '@agorapulse/ui-components/legacy/input';\nexport { SelectComponent } from '@agorapulse/ui-components/legacy/select';\nexport { TextareaComponent } from '@agorapulse/ui-components/legacy/textarea';\nexport { MediaDisplayOverlayDialogComponent } from '@agorapulse/ui-components/media-display-overlay';\nexport { ModalComponent, ModalConfig } from '@agorapulse/ui-components/modal';\nexport { NavSelectorComponent } from '@agorapulse/ui-components/nav-selector'\nexport {\n    DayDisabledPipe,\n    NeoDatePickerLocale,\n    NeoDatePickerMode,\n    NeoDatePickerStartsOn,\n    NeoDatepickerComponent,\n} from '@agorapulse/ui-components/neo-datepicker';\nexport { NotificationComponent } from '@agorapulse/ui-components/notification';\nexport { PaginatorButtonComponent, PaginatorComponent } from '@agorapulse/ui-components/paginator';\nexport { PasswordInputComponent } from '@agorapulse/ui-components/password-input';\nexport { PopmenuComponent } from '@agorapulse/ui-components/popmenu';\nexport { RadioComponent } from '@agorapulse/ui-components/radio';\nexport { SlideToggleComponent } from '@agorapulse/ui-components/slide-toggle';\nexport { SnackbarsThreadComponent } from '@agorapulse/ui-components/snackbars-thread';\nexport { SocialButtonComponent } from '@agorapulse/ui-components/social-button';\nexport { StatusComponent } from '@agorapulse/ui-components/status';\nexport { StatusCardActor, StatusCardComponent } from '@agorapulse/ui-components/status-card';\nexport { StepperComponent } from '@agorapulse/ui-components/stepper';\nexport { TagComponent } from '@agorapulse/ui-components/tag';\nexport { ToggleComponent } from '@agorapulse/ui-components/toggle';\n\n// Service\nexport { SnackbarsThreadService } from '@agorapulse/ui-components/snackbars-thread';\n\n// Model\nexport { ConfirmModalTexts } from '@agorapulse/ui-components/confirm-modal';\nexport {\n    CodeStatus,\n    SnackbarTypeValues,\n    SnackbarsThreadBase,\n    externalSnackbarTypeAllowed,\n    generateCodeStatus,\n} from '@agorapulse/ui-components/snackbars-thread';\nexport { Step } from '@agorapulse/ui-components/stepper';\n"]}
|
|
@@ -43,7 +43,8 @@ export class InputSearchComponent {
|
|
|
43
43
|
setDisabledState(isDisabled) {
|
|
44
44
|
this.disabled.set(isDisabled);
|
|
45
45
|
}
|
|
46
|
-
onClear() {
|
|
46
|
+
onClear($event) {
|
|
47
|
+
$event.stopImmediatePropagation();
|
|
47
48
|
this.onValueChange(null);
|
|
48
49
|
}
|
|
49
50
|
onFocusHandle($event) {
|
|
@@ -62,7 +63,7 @@ export class InputSearchComponent {
|
|
|
62
63
|
useExisting: forwardRef(() => InputSearchComponent),
|
|
63
64
|
multi: true,
|
|
64
65
|
},
|
|
65
|
-
], viewQueries: [{ propertyName: "inputElement", first: true, predicate: ["input"], descendants: true, isSignal: true }], ngImport: i0, template: "<ap-input-group>\n <ap-symbol symbolId=\"search\" />\n <input\n #input\n apInput\n [id]=\"inputId()\"\n [placeholder]=\"placeholder()\"\n [disabled]=\"disabled()\"\n [ngModel]=\"value()\"\n (blur)=\"onBlurHandle($event)\"\n (focus)=\"onFocusHandle($event)\"\n (keyup)=\"onKeyup($event)\"\n (ngModelChange)=\"onValueChange($event)\" />\n @if (clearable() && value()) {\n <div\n class=\"close\"\n tabindex=\"0\"\n (click)=\"onClear()\"\n (
|
|
66
|
+
], viewQueries: [{ propertyName: "inputElement", first: true, predicate: ["input"], descendants: true, isSignal: true }], ngImport: i0, template: "<ap-input-group>\n <ap-symbol symbolId=\"search\" />\n <input\n #input\n apInput\n [id]=\"inputId()\"\n [placeholder]=\"placeholder()\"\n [disabled]=\"disabled()\"\n [ngModel]=\"value()\"\n (blur)=\"onBlurHandle($event)\"\n (focus)=\"onFocusHandle($event)\"\n (keyup)=\"onKeyup($event)\"\n (ngModelChange)=\"onValueChange($event)\" />\n @if (clearable() && value()) {\n <div\n class=\"close\"\n tabindex=\"0\"\n (click)=\"onClear($event)\"\n (keydown.space)=\"onClear($event)\"\n (keydown.enter)=\"onClear($event)\">\n <ap-symbol\n aria-label=\"close-snackbar\"\n symbolId=\"delete-no-circle\"\n size=\"xs\" />\n </div>\n }\n</ap-input-group>\n", styles: ["ap-input-search ap-input-group .ap-input-group .close{height:20px;width:20px;display:flex;justify-content:center;align-items:center;border-radius:50%}ap-input-search ap-input-group .ap-input-group .close ap-symbol{color:var(--ref-color-grey-100);align-self:center}ap-input-search ap-input-group .ap-input-group .close:hover{background:#3445631a;border-radius:50%;cursor:pointer}ap-input-search ap-input-group .ap-input-group input{width:100%}\n"], dependencies: [{ kind: "component", type: InputGroupComponent, selector: "ap-input-group", inputs: ["symbolPosition"] }, { kind: "directive", type: InputDirective, selector: "[apInput]" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: SymbolComponent, selector: "ap-symbol", inputs: ["symbolId", "color", "size"], outputs: ["sizeChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
66
67
|
}
|
|
67
68
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: InputSearchComponent, decorators: [{
|
|
68
69
|
type: Component,
|
|
@@ -72,6 +73,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
72
73
|
useExisting: forwardRef(() => InputSearchComponent),
|
|
73
74
|
multi: true,
|
|
74
75
|
},
|
|
75
|
-
], template: "<ap-input-group>\n <ap-symbol symbolId=\"search\" />\n <input\n #input\n apInput\n [id]=\"inputId()\"\n [placeholder]=\"placeholder()\"\n [disabled]=\"disabled()\"\n [ngModel]=\"value()\"\n (blur)=\"onBlurHandle($event)\"\n (focus)=\"onFocusHandle($event)\"\n (keyup)=\"onKeyup($event)\"\n (ngModelChange)=\"onValueChange($event)\" />\n @if (clearable() && value()) {\n <div\n class=\"close\"\n tabindex=\"0\"\n (click)=\"onClear()\"\n (
|
|
76
|
+
], template: "<ap-input-group>\n <ap-symbol symbolId=\"search\" />\n <input\n #input\n apInput\n [id]=\"inputId()\"\n [placeholder]=\"placeholder()\"\n [disabled]=\"disabled()\"\n [ngModel]=\"value()\"\n (blur)=\"onBlurHandle($event)\"\n (focus)=\"onFocusHandle($event)\"\n (keyup)=\"onKeyup($event)\"\n (ngModelChange)=\"onValueChange($event)\" />\n @if (clearable() && value()) {\n <div\n class=\"close\"\n tabindex=\"0\"\n (click)=\"onClear($event)\"\n (keydown.space)=\"onClear($event)\"\n (keydown.enter)=\"onClear($event)\">\n <ap-symbol\n aria-label=\"close-snackbar\"\n symbolId=\"delete-no-circle\"\n size=\"xs\" />\n </div>\n }\n</ap-input-group>\n", styles: ["ap-input-search ap-input-group .ap-input-group .close{height:20px;width:20px;display:flex;justify-content:center;align-items:center;border-radius:50%}ap-input-search ap-input-group .ap-input-group .close ap-symbol{color:var(--ref-color-grey-100);align-self:center}ap-input-search ap-input-group .ap-input-group .close:hover{background:#3445631a;border-radius:50%;cursor:pointer}ap-input-search ap-input-group .ap-input-group input{width:100%}\n"] }]
|
|
76
77
|
}], ctorParameters: () => [] });
|
|
77
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
78
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-search.component.js","sourceRoot":"","sources":["../../../../libs/ui-components/input-search/src/input-search.component.ts","../../../../libs/ui-components/input-search/src/input-search.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AACjE,OAAO,EAAE,mBAAmB,EAAE,MAAM,uCAAuC,CAAC;AAC5E,OAAO,EAAE,eAAe,EAAE,cAAc,EAAE,gBAAgB,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AACpG,OAAO,EACH,uBAAuB,EACvB,SAAS,EAET,iBAAiB,EACjB,QAAQ,EACR,UAAU,EACV,MAAM,EACN,KAAK,EACL,MAAM,EACN,MAAM,EACN,SAAS,GACZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAwB,WAAW,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;;;AAEtF,IAAI,aAAa,GAAG,CAAC,CAAC;AAmBtB,MAAM,OAAO,oBAAoB;IAC7B,EAAE,GAAG,KAAK,CAAS,EAAE,CAAC,CAAC;IACvB,WAAW,GAAG,KAAK,CAAS,EAAE,CAAC,CAAC;IAChC,SAAS,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC;IAExB,KAAK,GAAG,MAAM,EAAc,CAAC;IAC7B,IAAI,GAAG,MAAM,EAAc,CAAC;IAC5B,KAAK,GAAG,MAAM,EAAiB,CAAC;IAEhC,YAAY,GAAG,SAAS,CAAC,QAAQ,CAAa,OAAO,CAAC,CAAC;IAEvD,KAAK,GAAG,MAAM,CAAgB,EAAE,CAAC,CAAC;IAClC,cAAc,GAAG,mBAAmB,aAAa,EAAE,EAAE,CAAC;IAEtD,OAAO,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,IAAI,CAAC,cAAc,CAAC,CAAC;IAE3D,QAAQ,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;IAEzB,SAAS,GAAe,GAAG,EAAE,GAAE,CAAC,CAAC;IAEjC,SAAS,GAAyB,GAAG,EAAE,GAAE,CAAC,CAAC;IAEnC,cAAc,GAAG,MAAM,CAAC,cAAc,CAAC,CAAC;IAEhD;QACI,IAAI,CAAC,cAAc,CAAC,eAAe,CAAC,CAAC,QAAQ,EAAE,gBAAgB,CAAC,CAAC,CAAC;IACtE,CAAC;IAED,gBAAgB,CAAC,EAAkC;QAC/C,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACxB,CAAC;IAED,iBAAiB,CAAC,EAAc;QAC5B,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACxB,CAAC;IAED,aAAa,CAAC,KAAoB;QAC9B,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QACvB,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IAC1B,CAAC;IAED,UAAU;QACN,IAAI,CAAC,YAAY,EAAE,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IAC9C,CAAC;IAED,UAAU,CAAC,KAAoB;QAC3B,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IAC1B,CAAC;IAED,gBAAgB,CAAC,UAAmB;QAChC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;IAClC,CAAC;IAED,OAAO,CAAC,MAAa;QACjB,MAAM,CAAC,wBAAwB,EAAE,CAAC;QAClC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;IAC7B,CAAC;IAED,aAAa,CAAC,MAAkB;QAC5B,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC5B,CAAC;IAED,YAAY,CAAC,MAAkB;QAC3B,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC3B,CAAC;IAED,OAAO,CAAC,MAAqB;QACzB,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC5B,CAAC;uGApEQ,oBAAoB;2FAApB,oBAAoB,kgBARlB;YACP;gBACI,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,oBAAoB,CAAC;gBACnD,KAAK,EAAE,IAAI;aACd;SACJ,iJCnCL,q1BA2BA,sfDAc,mBAAmB,uFAAE,cAAc,qDAAE,WAAW,+mBAAE,eAAe;;2FAUlE,oBAAoB;kBAjBhC,SAAS;+BACI,iBAAiB,cAGf,IAAI,mBACC,uBAAuB,CAAC,MAAM,iBAChC,iBAAiB,CAAC,IAAI,WAC5B,CAAC,mBAAmB,EAAE,cAAc,EAAE,WAAW,EAAE,eAAe,CAAC,aAEjE;wBACP;4BACI,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,qBAAqB,CAAC;4BACnD,KAAK,EAAE,IAAI;yBACd;qBACJ","sourcesContent":["import { InputDirective } from '@agorapulse/ui-components/input';\nimport { InputGroupComponent } from '@agorapulse/ui-components/input-group';\nimport { SymbolComponent, SymbolRegistry, apDeleteNoCircle, apSearch } from '@agorapulse/ui-symbol';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    ViewEncapsulation,\n    computed,\n    forwardRef,\n    inject,\n    input,\n    output,\n    signal,\n    viewChild,\n} from '@angular/core';\nimport { ControlValueAccessor, FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nlet inputSearchId = 0;\n\n@Component({\n    selector: 'ap-input-search',\n    templateUrl: './input-search.component.html',\n    styleUrls: ['./input-search.component.scss'],\n    standalone: true,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    imports: [InputGroupComponent, InputDirective, FormsModule, SymbolComponent],\n\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => InputSearchComponent),\n            multi: true,\n        },\n    ],\n})\nexport class InputSearchComponent implements ControlValueAccessor {\n    id = input<string>('');\n    placeholder = input<string>('');\n    clearable = input(true);\n\n    focus = output<FocusEvent>();\n    blur = output<FocusEvent>();\n    keyup = output<KeyboardEvent>();\n\n    inputElement = viewChild.required<ElementRef>('input');\n\n    value = signal<string | null>('');\n    defaultInputId = `ap-input-search-${inputSearchId++}`;\n\n    inputId = computed(() => this.id() ?? this.defaultInputId);\n\n    disabled = signal(false);\n\n    onTouched: () => void = () => {};\n\n    onChanged: (value: any) => void = () => {};\n\n    private symbolRegistry = inject(SymbolRegistry);\n\n    constructor() {\n        this.symbolRegistry.registerSymbols([apSearch, apDeleteNoCircle]);\n    }\n\n    registerOnChange(fn: (value: string | null) => void): void {\n        this.onChanged = fn;\n    }\n\n    registerOnTouched(fn: () => void): void {\n        this.onTouched = fn;\n    }\n\n    onValueChange(value: string | null) {\n        this.writeValue(value);\n        this.onChanged(value);\n    }\n\n    focusInput(): void {\n        this.inputElement().nativeElement.focus();\n    }\n\n    writeValue(value: string | null): void {\n        this.value.set(value);\n    }\n\n    setDisabledState(isDisabled: boolean): void {\n        this.disabled.set(isDisabled);\n    }\n\n    onClear($event: Event): void {\n        $event.stopImmediatePropagation();\n        this.onValueChange(null);\n    }\n\n    onFocusHandle($event: FocusEvent): void {\n        this.focus.emit($event);\n    }\n\n    onBlurHandle($event: FocusEvent): void {\n        this.blur.emit($event);\n    }\n\n    onKeyup($event: KeyboardEvent): void {\n        this.keyup.emit($event);\n    }\n}\n","<ap-input-group>\n    <ap-symbol symbolId=\"search\" />\n    <input\n        #input\n        apInput\n        [id]=\"inputId()\"\n        [placeholder]=\"placeholder()\"\n        [disabled]=\"disabled()\"\n        [ngModel]=\"value()\"\n        (blur)=\"onBlurHandle($event)\"\n        (focus)=\"onFocusHandle($event)\"\n        (keyup)=\"onKeyup($event)\"\n        (ngModelChange)=\"onValueChange($event)\" />\n    @if (clearable() && value()) {\n        <div\n            class=\"close\"\n            tabindex=\"0\"\n            (click)=\"onClear($event)\"\n            (keydown.space)=\"onClear($event)\"\n            (keydown.enter)=\"onClear($event)\">\n            <ap-symbol\n                aria-label=\"close-snackbar\"\n                symbolId=\"delete-no-circle\"\n                size=\"xs\" />\n        </div>\n    }\n</ap-input-group>\n"]}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './public_api';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWdvcmFwdWxzZS11aS1jb21wb25lbnRzLW5hdi1zZWxlY3Rvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2xpYnMvdWktY29tcG9uZW50cy9uYXYtc2VsZWN0b3Ivc3JjL2Fnb3JhcHVsc2UtdWktY29tcG9uZW50cy1uYXYtc2VsZWN0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWNfYXBpJztcbiJdfQ==
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { afterRender, Directive, input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class TreeNodeAccessibilityDirective {
|
|
4
|
+
apTreeNodeAccessibility = input.required();
|
|
5
|
+
constructor(el, renderer) {
|
|
6
|
+
afterRender(() => {
|
|
7
|
+
const nativeEl = el.nativeElement;
|
|
8
|
+
const entry = this.apTreeNodeAccessibility();
|
|
9
|
+
renderer.setAttribute(nativeEl, 'aria-level', `${entry.accessibility.ariaLevel}`);
|
|
10
|
+
renderer.setAttribute(nativeEl, 'aria-setsize', `${entry.accessibility.ariaSetsize}`);
|
|
11
|
+
renderer.setAttribute(nativeEl, 'aria-posinset', `${entry.accessibility.ariaPosinset}`);
|
|
12
|
+
renderer.setAttribute(nativeEl, 'tabindex', `${entry.accessibility.tabIndex}`);
|
|
13
|
+
renderer.setAttribute(nativeEl, 'aria-label', `${entry.alias}`);
|
|
14
|
+
if ('folded' in entry) {
|
|
15
|
+
renderer.setAttribute(nativeEl, 'aria-expanded', `${entry.folded}`);
|
|
16
|
+
}
|
|
17
|
+
renderer.setAttribute(nativeEl, 'role', 'treeitem');
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: TreeNodeAccessibilityDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
|
|
21
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.9", type: TreeNodeAccessibilityDirective, isStandalone: true, selector: "[apTreeNodeAccessibility]", inputs: { apTreeNodeAccessibility: { classPropertyName: "apTreeNodeAccessibility", publicName: "apTreeNodeAccessibility", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0 });
|
|
22
|
+
}
|
|
23
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: TreeNodeAccessibilityDirective, decorators: [{
|
|
24
|
+
type: Directive,
|
|
25
|
+
args: [{
|
|
26
|
+
selector: '[apTreeNodeAccessibility]',
|
|
27
|
+
standalone: true,
|
|
28
|
+
}]
|
|
29
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }] });
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJlZS1ub2RlLWFjY2Vzc2liaWxpdHkuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy91aS1jb21wb25lbnRzL25hdi1zZWxlY3Rvci9zcmMvZGlyZWN0aXZlcy90cmVlLW5vZGUtYWNjZXNzaWJpbGl0eS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFdBQVcsRUFBRSxTQUFTLEVBQWMsS0FBSyxFQUFhLE1BQU0sZUFBZSxDQUFDOztBQU9yRixNQUFNLE9BQU8sOEJBQThCO0lBQ3ZDLHVCQUF1QixHQUFHLEtBQUssQ0FBQyxRQUFRLEVBQTRCLENBQUM7SUFFckUsWUFBWSxFQUFjLEVBQUUsUUFBbUI7UUFDM0MsV0FBVyxDQUFDLEdBQUcsRUFBRTtZQUNiLE1BQU0sUUFBUSxHQUFHLEVBQUUsQ0FBQyxhQUFhLENBQUM7WUFDbEMsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLHVCQUF1QixFQUFFLENBQUM7WUFDN0MsUUFBUSxDQUFDLFlBQVksQ0FBQyxRQUFRLEVBQUUsWUFBWSxFQUFFLEdBQUcsS0FBSyxDQUFDLGFBQWEsQ0FBQyxTQUFTLEVBQUUsQ0FBQyxDQUFDO1lBQ2xGLFFBQVEsQ0FBQyxZQUFZLENBQUMsUUFBUSxFQUFFLGNBQWMsRUFBRSxHQUFHLEtBQUssQ0FBQyxhQUFhLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQztZQUN0RixRQUFRLENBQUMsWUFBWSxDQUFDLFFBQVEsRUFBRSxlQUFlLEVBQUUsR0FBRyxLQUFLLENBQUMsYUFBYSxDQUFDLFlBQVksRUFBRSxDQUFDLENBQUM7WUFDeEYsUUFBUSxDQUFDLFlBQVksQ0FBQyxRQUFRLEVBQUUsVUFBVSxFQUFFLEdBQUcsS0FBSyxDQUFDLGFBQWEsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDO1lBQy9FLFFBQVEsQ0FBQyxZQUFZLENBQUMsUUFBUSxFQUFFLFlBQVksRUFBRSxHQUFHLEtBQUssQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDO1lBQ2hFLElBQUksUUFBUSxJQUFJLEtBQUssRUFBRSxDQUFDO2dCQUNwQixRQUFRLENBQUMsWUFBWSxDQUFDLFFBQVEsRUFBRSxlQUFlLEVBQUUsR0FBRyxLQUFLLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQztZQUN4RSxDQUFDO1lBQ0QsUUFBUSxDQUFDLFlBQVksQ0FBQyxRQUFRLEVBQUUsTUFBTSxFQUFFLFVBQVUsQ0FBQyxDQUFDO1FBQ3hELENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQzt1R0FqQlEsOEJBQThCOzJGQUE5Qiw4QkFBOEI7OzJGQUE5Qiw4QkFBOEI7a0JBSjFDLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLDJCQUEyQjtvQkFDckMsVUFBVSxFQUFFLElBQUk7aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgYWZ0ZXJSZW5kZXIsIERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgaW5wdXQsIFJlbmRlcmVyMiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgSW50ZXJuYWxOYXZTZWxlY3RvckVudHJ5IH0gZnJvbSAnLi4vbmF2LXNlbGVjdG9yJztcblxuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICdbYXBUcmVlTm9kZUFjY2Vzc2liaWxpdHldJyxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxufSlcbmV4cG9ydCBjbGFzcyBUcmVlTm9kZUFjY2Vzc2liaWxpdHlEaXJlY3RpdmUge1xuICAgIGFwVHJlZU5vZGVBY2Nlc3NpYmlsaXR5ID0gaW5wdXQucmVxdWlyZWQ8SW50ZXJuYWxOYXZTZWxlY3RvckVudHJ5PigpO1xuXG4gICAgY29uc3RydWN0b3IoZWw6IEVsZW1lbnRSZWYsIHJlbmRlcmVyOiBSZW5kZXJlcjIpIHtcbiAgICAgICAgYWZ0ZXJSZW5kZXIoKCkgPT4ge1xuICAgICAgICAgICAgY29uc3QgbmF0aXZlRWwgPSBlbC5uYXRpdmVFbGVtZW50O1xuICAgICAgICAgICAgY29uc3QgZW50cnkgPSB0aGlzLmFwVHJlZU5vZGVBY2Nlc3NpYmlsaXR5KCk7XG4gICAgICAgICAgICByZW5kZXJlci5zZXRBdHRyaWJ1dGUobmF0aXZlRWwsICdhcmlhLWxldmVsJywgYCR7ZW50cnkuYWNjZXNzaWJpbGl0eS5hcmlhTGV2ZWx9YCk7XG4gICAgICAgICAgICByZW5kZXJlci5zZXRBdHRyaWJ1dGUobmF0aXZlRWwsICdhcmlhLXNldHNpemUnLCBgJHtlbnRyeS5hY2Nlc3NpYmlsaXR5LmFyaWFTZXRzaXplfWApO1xuICAgICAgICAgICAgcmVuZGVyZXIuc2V0QXR0cmlidXRlKG5hdGl2ZUVsLCAnYXJpYS1wb3NpbnNldCcsIGAke2VudHJ5LmFjY2Vzc2liaWxpdHkuYXJpYVBvc2luc2V0fWApO1xuICAgICAgICAgICAgcmVuZGVyZXIuc2V0QXR0cmlidXRlKG5hdGl2ZUVsLCAndGFiaW5kZXgnLCBgJHtlbnRyeS5hY2Nlc3NpYmlsaXR5LnRhYkluZGV4fWApO1xuICAgICAgICAgICAgcmVuZGVyZXIuc2V0QXR0cmlidXRlKG5hdGl2ZUVsLCAnYXJpYS1sYWJlbCcsIGAke2VudHJ5LmFsaWFzfWApO1xuICAgICAgICAgICAgaWYgKCdmb2xkZWQnIGluIGVudHJ5KSB7XG4gICAgICAgICAgICAgICAgcmVuZGVyZXIuc2V0QXR0cmlidXRlKG5hdGl2ZUVsLCAnYXJpYS1leHBhbmRlZCcsIGAke2VudHJ5LmZvbGRlZH1gKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIHJlbmRlcmVyLnNldEF0dHJpYnV0ZShuYXRpdmVFbCwgJ3JvbGUnLCAndHJlZWl0ZW0nKTtcbiAgICAgICAgfSk7XG4gICAgfVxufVxuIl19
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
import { apChevronDown, apChevronUp, SymbolComponent, withSymbols } from '@agorapulse/ui-symbol';
|
|
2
|
+
import { animate, keyframes, state, style, transition, trigger } from '@angular/animations';
|
|
3
|
+
import { afterNextRender, ChangeDetectionStrategy, Component, computed, effect, input, signal } from '@angular/core';
|
|
4
|
+
import { EventPluginsModule } from '@tinkoff/ng-event-plugins';
|
|
5
|
+
import { TreeNodeAccessibilityDirective } from '../directives/tree-node-accessibility.directive';
|
|
6
|
+
import { NavSelectorGroupComponent } from '../nav-selector-group/nav-selector-group.component';
|
|
7
|
+
import { NavSelectorLeafComponent } from '../nav-selector-leaf/nav-selector-leaf.component';
|
|
8
|
+
import { NavSelectorCategoryPresenter } from './nav-selector-category.presenter';
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
import * as i1 from "./nav-selector-category.presenter";
|
|
11
|
+
export class NavSelectorCategoryComponent {
|
|
12
|
+
el;
|
|
13
|
+
navSelectorCategoryPresenter;
|
|
14
|
+
category = input.required();
|
|
15
|
+
foldSymbol = computed(() => (this.category().folded ? 'chevron-down' : 'chevron-up'));
|
|
16
|
+
foldedWithDelay = signal(false);
|
|
17
|
+
animationState = computed(() => (this.category().folded ? 'collapsed' : 'expanded'));
|
|
18
|
+
constructor(el, navSelectorCategoryPresenter) {
|
|
19
|
+
this.el = el;
|
|
20
|
+
this.navSelectorCategoryPresenter = navSelectorCategoryPresenter;
|
|
21
|
+
afterNextRender(() => this.maxHeight.set(`${this.el.nativeElement.scrollHeight}px`));
|
|
22
|
+
effect(() => {
|
|
23
|
+
if (this.category().folded) {
|
|
24
|
+
setTimeout(() => this.foldedWithDelay.set(true), 150);
|
|
25
|
+
}
|
|
26
|
+
else {
|
|
27
|
+
this.foldedWithDelay.set(false);
|
|
28
|
+
}
|
|
29
|
+
}, { allowSignalWrites: true });
|
|
30
|
+
}
|
|
31
|
+
maxHeight = signal('0px');
|
|
32
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NavSelectorCategoryComponent, deps: [{ token: i0.ElementRef }, { token: i1.NavSelectorCategoryPresenter }], target: i0.ɵɵFactoryTarget.Component });
|
|
33
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.9", type: NavSelectorCategoryComponent, isStandalone: true, selector: "ap-nav-selector-category", inputs: { category: { classPropertyName: "category", publicName: "category", isSignal: true, isRequired: true, transformFunction: null } }, host: { listeners: { "keydown.arrowLeft": "navSelectorCategoryPresenter.fold($event, this.category())", "keydown.arrowRight": "navSelectorCategoryPresenter.unfold($event, this.category())" }, properties: { "class.minified": "!navSelectorCategoryPresenter.expanded()" } }, providers: [withSymbols(apChevronDown, apChevronUp), NavSelectorCategoryPresenter], ngImport: i0, template: "@if (navSelectorCategoryPresenter.expandedAfterDelay()) {\n <div\n class=\"content\"\n [apTreeNodeAccessibility]=\"category()\"\n (keydown.space.stop)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\"\n (keydown.enter)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\">\n <span class=\"caption\">{{ category().alias }}</span>\n\n <ap-symbol\n class=\"folding-button\"\n size=\"sm\"\n [attr.aria-label]=\"'Toggle ' + category().alias\"\n [symbolId]=\"foldSymbol()\"\n (click)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\"\n (keydown.space)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\"\n (keydown.enter)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\" />\n </div>\n\n <div\n class=\"children-container\"\n [@accordion]=\"{\n value: animationState(),\n params: {\n maxHeight: maxHeight()\n }\n }\">\n @if (!foldedWithDelay()) {\n <div class=\"children\">\n @for (child of category().children; track child.uid) {\n @if (!child.hidden) {\n @if (child.type === 'LEAF') {\n <ap-nav-selector-leaf [leaf]=\"child\" />\n } @else if (child.type === 'GROUP') {\n <ap-nav-selector-group [group]=\"child\" />\n }\n }\n }\n </div>\n }\n </div>\n} @else {\n <div\n class=\"content\"\n [apTreeNodeAccessibility]=\"category()\"\n (click)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\"\n (keydown.space)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\"\n (keydown.enter)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\">\n <div class=\"name-container\">\n <span class=\"caption\">{{ category().alias }}</span>\n <span>.</span>\n </div>\n\n <div class=\"toggle\">\n <ap-symbol\n size=\"sm\"\n [symbolId]=\"foldSymbol()\" />\n </div>\n </div>\n\n <div\n class=\"children-container\"\n [@accordion]=\"{\n value: animationState(),\n params: {\n maxHeight: maxHeight()\n }\n }\">\n @if (!foldedWithDelay()) {\n <div class=\"children\">\n @for (child of category().children; track child.uid) {\n @if (!child.hidden) {\n @if (child.type === 'LEAF') {\n <ap-nav-selector-leaf [leaf]=\"child\" />\n } @else if (child.type === 'GROUP') {\n <ap-nav-selector-group [group]=\"child\" />\n }\n }\n }\n </div>\n }\n </div>\n}\n", styles: [":host{display:flex;align-items:center;flex-shrink:0;align-self:stretch;flex-direction:column}:host .children-container{align-self:stretch}:host .folding-button{display:flex;width:24px;height:24px;justify-content:center;align-items:center;flex-shrink:0}:host .folding-button:hover{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host .folding-button:active{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-40)}:host .content{padding:0 var(--ref-spacing-xxs);display:flex;height:36px;align-items:center;gap:var(--ref-spacing-xxs);flex-shrink:0;flex-grow:1;align-self:stretch;cursor:pointer}:host .content:hover{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-10)}:host .content:active{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host .content:focus{outline:none;border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-10);box-shadow:0 0 0 1px var(--ref-color-white),0 0 0 3px var(--ref-color-electric-blue-100)}:host .content:focus-within{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host:not(.minified) ap-symbol[symbol-id=chevron-down],:host:not(.minified) ap-symbol[symbol-id=chevron-up]{color:var(--ref-color-grey-80)}:host:not(.minified) ap-symbol[symbol-id=chevron-down]:hover,:host:not(.minified) ap-symbol[symbol-id=chevron-up]:hover{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host:not(.minified) ap-symbol[symbol-id=chevron-down]:active,:host:not(.minified) ap-symbol[symbol-id=chevron-up]:active{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-40)}:host:not(.minified) ap-symbol[symbol-id=chevron-down]:focus,:host:not(.minified) ap-symbol[symbol-id=chevron-up]:focus{outline:none;border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20);box-shadow:0 0 0 1px #fff,0 0 0 3px #178dfe}:host ap-symbol[symbol-id=chevron-down],:host ap-symbol[symbol-id=chevron-up]{color:var(--ref-color-grey-80)}:host .caption{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:1;flex:1 0 0;overflow:hidden;color:var(--ref-color-grey-100);text-overflow:ellipsis;font-family:Averta;font-size:var(--sys-text-style-h4-size);font-style:normal;font-weight:var(--ref-font-weight-bold);line-height:var(--ref-font-line-height-md)}:host .children{display:flex;flex-direction:column;align-items:flex-start;flex:1 0 0;align-self:stretch}:host.minified .name-container{overflow:hidden;display:flex}:host.minified .content{position:relative}:host.minified .content .toggle{position:absolute;display:none}:host.minified .content:hover .toggle,:host.minified .content:focus .toggle{inset:0;display:flex;justify-content:center;align-items:center}:host.minified .content:hover .name-container,:host.minified .content:focus .name-container{display:none}\n"], dependencies: [{ kind: "component", type: NavSelectorLeafComponent, selector: "ap-nav-selector-leaf", inputs: ["leaf"] }, { kind: "component", type: SymbolComponent, selector: "ap-symbol", inputs: ["symbolId", "color", "size"], outputs: ["sizeChange"] }, { kind: "component", type: NavSelectorGroupComponent, selector: "ap-nav-selector-group", inputs: ["group"] }, { kind: "ngmodule", type: EventPluginsModule }, { kind: "directive", type: TreeNodeAccessibilityDirective, selector: "[apTreeNodeAccessibility]", inputs: ["apTreeNodeAccessibility"] }], animations: [
|
|
34
|
+
/**
|
|
35
|
+
* Overflow hidden is put only during the animation and on the collapsed state because if it is put on the expanded state then children’s border will be cut (hover / focus)
|
|
36
|
+
*/
|
|
37
|
+
trigger('accordion', [
|
|
38
|
+
state('collapsed', style({
|
|
39
|
+
maxHeight: 0,
|
|
40
|
+
overflow: 'hidden',
|
|
41
|
+
})),
|
|
42
|
+
state('expanded', style({
|
|
43
|
+
maxHeight: 'initial',
|
|
44
|
+
})),
|
|
45
|
+
transition('collapsed => expanded', [
|
|
46
|
+
animate('250ms cubic-bezier(.4, 0, .3, 1)', style({ overflow: 'hidden', maxHeight: '{{maxHeight}}' })),
|
|
47
|
+
]),
|
|
48
|
+
transition('expanded => collapsed', [
|
|
49
|
+
animate('250ms cubic-bezier(.4, 0, .3, 1)', keyframes([style({ maxHeight: '{{maxHeight}}' }), style({ overflow: 'hidden', maxHeight: 0 })])),
|
|
50
|
+
]),
|
|
51
|
+
]),
|
|
52
|
+
], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
53
|
+
}
|
|
54
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NavSelectorCategoryComponent, decorators: [{
|
|
55
|
+
type: Component,
|
|
56
|
+
args: [{ selector: 'ap-nav-selector-category', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [NavSelectorLeafComponent, SymbolComponent, NavSelectorGroupComponent, EventPluginsModule, TreeNodeAccessibilityDirective], providers: [withSymbols(apChevronDown, apChevronUp), NavSelectorCategoryPresenter], host: {
|
|
57
|
+
'[class.minified]': '!navSelectorCategoryPresenter.expanded()',
|
|
58
|
+
'(keydown.arrowLeft)': 'navSelectorCategoryPresenter.fold($event, this.category())',
|
|
59
|
+
'(keydown.arrowRight)': 'navSelectorCategoryPresenter.unfold($event, this.category())',
|
|
60
|
+
}, animations: [
|
|
61
|
+
/**
|
|
62
|
+
* Overflow hidden is put only during the animation and on the collapsed state because if it is put on the expanded state then children’s border will be cut (hover / focus)
|
|
63
|
+
*/
|
|
64
|
+
trigger('accordion', [
|
|
65
|
+
state('collapsed', style({
|
|
66
|
+
maxHeight: 0,
|
|
67
|
+
overflow: 'hidden',
|
|
68
|
+
})),
|
|
69
|
+
state('expanded', style({
|
|
70
|
+
maxHeight: 'initial',
|
|
71
|
+
})),
|
|
72
|
+
transition('collapsed => expanded', [
|
|
73
|
+
animate('250ms cubic-bezier(.4, 0, .3, 1)', style({ overflow: 'hidden', maxHeight: '{{maxHeight}}' })),
|
|
74
|
+
]),
|
|
75
|
+
transition('expanded => collapsed', [
|
|
76
|
+
animate('250ms cubic-bezier(.4, 0, .3, 1)', keyframes([style({ maxHeight: '{{maxHeight}}' }), style({ overflow: 'hidden', maxHeight: 0 })])),
|
|
77
|
+
]),
|
|
78
|
+
]),
|
|
79
|
+
], template: "@if (navSelectorCategoryPresenter.expandedAfterDelay()) {\n <div\n class=\"content\"\n [apTreeNodeAccessibility]=\"category()\"\n (keydown.space.stop)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\"\n (keydown.enter)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\">\n <span class=\"caption\">{{ category().alias }}</span>\n\n <ap-symbol\n class=\"folding-button\"\n size=\"sm\"\n [attr.aria-label]=\"'Toggle ' + category().alias\"\n [symbolId]=\"foldSymbol()\"\n (click)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\"\n (keydown.space)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\"\n (keydown.enter)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\" />\n </div>\n\n <div\n class=\"children-container\"\n [@accordion]=\"{\n value: animationState(),\n params: {\n maxHeight: maxHeight()\n }\n }\">\n @if (!foldedWithDelay()) {\n <div class=\"children\">\n @for (child of category().children; track child.uid) {\n @if (!child.hidden) {\n @if (child.type === 'LEAF') {\n <ap-nav-selector-leaf [leaf]=\"child\" />\n } @else if (child.type === 'GROUP') {\n <ap-nav-selector-group [group]=\"child\" />\n }\n }\n }\n </div>\n }\n </div>\n} @else {\n <div\n class=\"content\"\n [apTreeNodeAccessibility]=\"category()\"\n (click)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\"\n (keydown.space)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\"\n (keydown.enter)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\">\n <div class=\"name-container\">\n <span class=\"caption\">{{ category().alias }}</span>\n <span>.</span>\n </div>\n\n <div class=\"toggle\">\n <ap-symbol\n size=\"sm\"\n [symbolId]=\"foldSymbol()\" />\n </div>\n </div>\n\n <div\n class=\"children-container\"\n [@accordion]=\"{\n value: animationState(),\n params: {\n maxHeight: maxHeight()\n }\n }\">\n @if (!foldedWithDelay()) {\n <div class=\"children\">\n @for (child of category().children; track child.uid) {\n @if (!child.hidden) {\n @if (child.type === 'LEAF') {\n <ap-nav-selector-leaf [leaf]=\"child\" />\n } @else if (child.type === 'GROUP') {\n <ap-nav-selector-group [group]=\"child\" />\n }\n }\n }\n </div>\n }\n </div>\n}\n", styles: [":host{display:flex;align-items:center;flex-shrink:0;align-self:stretch;flex-direction:column}:host .children-container{align-self:stretch}:host .folding-button{display:flex;width:24px;height:24px;justify-content:center;align-items:center;flex-shrink:0}:host .folding-button:hover{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host .folding-button:active{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-40)}:host .content{padding:0 var(--ref-spacing-xxs);display:flex;height:36px;align-items:center;gap:var(--ref-spacing-xxs);flex-shrink:0;flex-grow:1;align-self:stretch;cursor:pointer}:host .content:hover{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-10)}:host .content:active{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host .content:focus{outline:none;border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-10);box-shadow:0 0 0 1px var(--ref-color-white),0 0 0 3px var(--ref-color-electric-blue-100)}:host .content:focus-within{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host:not(.minified) ap-symbol[symbol-id=chevron-down],:host:not(.minified) ap-symbol[symbol-id=chevron-up]{color:var(--ref-color-grey-80)}:host:not(.minified) ap-symbol[symbol-id=chevron-down]:hover,:host:not(.minified) ap-symbol[symbol-id=chevron-up]:hover{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20)}:host:not(.minified) ap-symbol[symbol-id=chevron-down]:active,:host:not(.minified) ap-symbol[symbol-id=chevron-up]:active{border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-40)}:host:not(.minified) ap-symbol[symbol-id=chevron-down]:focus,:host:not(.minified) ap-symbol[symbol-id=chevron-up]:focus{outline:none;border-radius:var(--ref-border-radius-sm);background:var(--ref-color-electric-blue-20);box-shadow:0 0 0 1px #fff,0 0 0 3px #178dfe}:host ap-symbol[symbol-id=chevron-down],:host ap-symbol[symbol-id=chevron-up]{color:var(--ref-color-grey-80)}:host .caption{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:1;flex:1 0 0;overflow:hidden;color:var(--ref-color-grey-100);text-overflow:ellipsis;font-family:Averta;font-size:var(--sys-text-style-h4-size);font-style:normal;font-weight:var(--ref-font-weight-bold);line-height:var(--ref-font-line-height-md)}:host .children{display:flex;flex-direction:column;align-items:flex-start;flex:1 0 0;align-self:stretch}:host.minified .name-container{overflow:hidden;display:flex}:host.minified .content{position:relative}:host.minified .content .toggle{position:absolute;display:none}:host.minified .content:hover .toggle,:host.minified .content:focus .toggle{inset:0;display:flex;justify-content:center;align-items:center}:host.minified .content:hover .name-container,:host.minified .content:focus .name-container{display:none}\n"] }]
|
|
80
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.NavSelectorCategoryPresenter }] });
|
|
81
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav-selector-category.component.js","sourceRoot":"","sources":["../../../../../libs/ui-components/nav-selector/src/nav-selector-category/nav-selector-category.component.ts","../../../../../libs/ui-components/nav-selector/src/nav-selector-category/nav-selector-category.component.html"],"names":[],"mappings":"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","sourcesContent":["import { apChevronDown, apChevronUp, SymbolComponent, withSymbols } from '@agorapulse/ui-symbol';\nimport { animate, keyframes, state, style, transition, trigger } from '@angular/animations';\nimport { afterNextRender, ChangeDetectionStrategy, Component, computed, effect, ElementRef, input, signal } from '@angular/core';\nimport { EventPluginsModule } from '@tinkoff/ng-event-plugins';\nimport { TreeNodeAccessibilityDirective } from '../directives/tree-node-accessibility.directive';\nimport { InternalNavSelectorCategory } from '../nav-selector';\nimport { NavSelectorGroupComponent } from '../nav-selector-group/nav-selector-group.component';\nimport { NavSelectorLeafComponent } from '../nav-selector-leaf/nav-selector-leaf.component';\nimport { NavSelectorCategoryPresenter } from './nav-selector-category.presenter';\n\n@Component({\n    selector: 'ap-nav-selector-category',\n    templateUrl: './nav-selector-category.component.html',\n    styleUrls: ['./nav-selector-category.component.scss'],\n    standalone: true,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    imports: [NavSelectorLeafComponent, SymbolComponent, NavSelectorGroupComponent, EventPluginsModule, TreeNodeAccessibilityDirective],\n    providers: [withSymbols(apChevronDown, apChevronUp), NavSelectorCategoryPresenter],\n    host: {\n        '[class.minified]': '!navSelectorCategoryPresenter.expanded()',\n        '(keydown.arrowLeft)': 'navSelectorCategoryPresenter.fold($event, this.category())',\n        '(keydown.arrowRight)': 'navSelectorCategoryPresenter.unfold($event, this.category())',\n    },\n    animations: [\n        /**\n         * Overflow hidden is put only during the animation and on the collapsed state because if it is put on the expanded state then children’s border will be cut (hover / focus)\n         */\n        trigger('accordion', [\n            state(\n                'collapsed',\n                style({\n                    maxHeight: 0,\n                    overflow: 'hidden',\n                })\n            ),\n            state(\n                'expanded',\n                style({\n                    maxHeight: 'initial',\n                })\n            ),\n            transition('collapsed => expanded', [\n                animate('250ms cubic-bezier(.4, 0, .3, 1)', style({ overflow: 'hidden', maxHeight: '{{maxHeight}}' })),\n            ]),\n            transition('expanded => collapsed', [\n                animate(\n                    '250ms cubic-bezier(.4, 0, .3, 1)',\n                    keyframes([style({ maxHeight: '{{maxHeight}}' }), style({ overflow: 'hidden', maxHeight: 0 })])\n                ),\n            ]),\n        ]),\n    ],\n})\nexport class NavSelectorCategoryComponent {\n    category = input.required<InternalNavSelectorCategory>();\n\n    foldSymbol = computed(() => (this.category().folded ? 'chevron-down' : 'chevron-up'));\n\n    foldedWithDelay = signal(false);\n\n    animationState = computed(() => (this.category().folded ? 'collapsed' : 'expanded'));\n\n    constructor(\n        private el: ElementRef,\n        public navSelectorCategoryPresenter: NavSelectorCategoryPresenter\n    ) {\n        afterNextRender(() => this.maxHeight.set(`${this.el.nativeElement.scrollHeight}px`));\n\n        effect(\n            () => {\n                if (this.category().folded) {\n                    setTimeout(() => this.foldedWithDelay.set(true), 150);\n                } else {\n                    this.foldedWithDelay.set(false);\n                }\n            },\n            { allowSignalWrites: true }\n        );\n    }\n\n    maxHeight = signal('0px');\n}\n","@if (navSelectorCategoryPresenter.expandedAfterDelay()) {\n    <div\n        class=\"content\"\n        [apTreeNodeAccessibility]=\"category()\"\n        (keydown.space.stop)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\"\n        (keydown.enter)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\">\n        <span class=\"caption\">{{ category().alias }}</span>\n\n        <ap-symbol\n            class=\"folding-button\"\n            size=\"sm\"\n            [attr.aria-label]=\"'Toggle ' + category().alias\"\n            [symbolId]=\"foldSymbol()\"\n            (click)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\"\n            (keydown.space)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\"\n            (keydown.enter)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\" />\n    </div>\n\n    <div\n        class=\"children-container\"\n        [@accordion]=\"{\n            value: animationState(),\n            params: {\n                maxHeight: maxHeight()\n            }\n        }\">\n        @if (!foldedWithDelay()) {\n            <div class=\"children\">\n                @for (child of category().children; track child.uid) {\n                    @if (!child.hidden) {\n                        @if (child.type === 'LEAF') {\n                            <ap-nav-selector-leaf [leaf]=\"child\" />\n                        } @else if (child.type === 'GROUP') {\n                            <ap-nav-selector-group [group]=\"child\" />\n                        }\n                    }\n                }\n            </div>\n        }\n    </div>\n} @else {\n    <div\n        class=\"content\"\n        [apTreeNodeAccessibility]=\"category()\"\n        (click)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\"\n        (keydown.space)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\"\n        (keydown.enter)=\"navSelectorCategoryPresenter.toggleFolding($event, this.category())\">\n        <div class=\"name-container\">\n            <span class=\"caption\">{{ category().alias }}</span>\n            <span>.</span>\n        </div>\n\n        <div class=\"toggle\">\n            <ap-symbol\n                size=\"sm\"\n                [symbolId]=\"foldSymbol()\" />\n        </div>\n    </div>\n\n    <div\n        class=\"children-container\"\n        [@accordion]=\"{\n            value: animationState(),\n            params: {\n                maxHeight: maxHeight()\n            }\n        }\">\n        @if (!foldedWithDelay()) {\n            <div class=\"children\">\n                @for (child of category().children; track child.uid) {\n                    @if (!child.hidden) {\n                        @if (child.type === 'LEAF') {\n                            <ap-nav-selector-leaf [leaf]=\"child\" />\n                        } @else if (child.type === 'GROUP') {\n                            <ap-nav-selector-group [group]=\"child\" />\n                        }\n                    }\n                }\n            </div>\n        }\n    </div>\n}\n"]}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { computed, Injectable } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "../nav-selector.state";
|
|
4
|
+
export class NavSelectorCategoryPresenter {
|
|
5
|
+
navSelectorState;
|
|
6
|
+
expanded = computed(() => this.navSelectorState.expanded());
|
|
7
|
+
expandedAfterDelay = computed(() => this.navSelectorState.expandedAfterDelay());
|
|
8
|
+
constructor(navSelectorState) {
|
|
9
|
+
this.navSelectorState = navSelectorState;
|
|
10
|
+
}
|
|
11
|
+
toggleFolding(event, category) {
|
|
12
|
+
event.stopImmediatePropagation();
|
|
13
|
+
this.navSelectorState.onGroupToggleFolding(category);
|
|
14
|
+
}
|
|
15
|
+
fold(event, category) {
|
|
16
|
+
event.stopImmediatePropagation();
|
|
17
|
+
this.navSelectorState.fold(category);
|
|
18
|
+
}
|
|
19
|
+
unfold(event, category) {
|
|
20
|
+
event.stopImmediatePropagation();
|
|
21
|
+
this.navSelectorState.unfold(category);
|
|
22
|
+
}
|
|
23
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NavSelectorCategoryPresenter, deps: [{ token: i1.NavSelectorState }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
24
|
+
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NavSelectorCategoryPresenter });
|
|
25
|
+
}
|
|
26
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NavSelectorCategoryPresenter, decorators: [{
|
|
27
|
+
type: Injectable
|
|
28
|
+
}], ctorParameters: () => [{ type: i1.NavSelectorState }] });
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2LXNlbGVjdG9yLWNhdGVnb3J5LnByZXNlbnRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvdWktY29tcG9uZW50cy9uYXYtc2VsZWN0b3Ivc3JjL25hdi1zZWxlY3Rvci1jYXRlZ29yeS9uYXYtc2VsZWN0b3ItY2F0ZWdvcnkucHJlc2VudGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFLckQsTUFBTSxPQUFPLDRCQUE0QjtJQUlqQjtJQUhwQixRQUFRLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDO0lBQzVELGtCQUFrQixHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsa0JBQWtCLEVBQUUsQ0FBQyxDQUFDO0lBRWhGLFlBQW9CLGdCQUFrQztRQUFsQyxxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQWtCO0lBQUcsQ0FBQztJQUUxRCxhQUFhLENBQUMsS0FBWSxFQUFFLFFBQXFDO1FBQzdELEtBQUssQ0FBQyx3QkFBd0IsRUFBRSxDQUFDO1FBQ2pDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxvQkFBb0IsQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUN6RCxDQUFDO0lBRUQsSUFBSSxDQUFDLEtBQVksRUFBRSxRQUFxQztRQUNwRCxLQUFLLENBQUMsd0JBQXdCLEVBQUUsQ0FBQztRQUNqQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ3pDLENBQUM7SUFFRCxNQUFNLENBQUMsS0FBWSxFQUFFLFFBQXFDO1FBQ3RELEtBQUssQ0FBQyx3QkFBd0IsRUFBRSxDQUFDO1FBQ2pDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDM0MsQ0FBQzt1R0FuQlEsNEJBQTRCOzJHQUE1Qiw0QkFBNEI7OzJGQUE1Qiw0QkFBNEI7a0JBRHhDLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjb21wdXRlZCwgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgSW50ZXJuYWxOYXZTZWxlY3RvckNhdGVnb3J5IH0gZnJvbSAnLi4vbmF2LXNlbGVjdG9yJztcbmltcG9ydCB7IE5hdlNlbGVjdG9yU3RhdGUgfSBmcm9tICcuLi9uYXYtc2VsZWN0b3Iuc3RhdGUnO1xuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgTmF2U2VsZWN0b3JDYXRlZ29yeVByZXNlbnRlciB7XG4gICAgZXhwYW5kZWQgPSBjb21wdXRlZCgoKSA9PiB0aGlzLm5hdlNlbGVjdG9yU3RhdGUuZXhwYW5kZWQoKSk7XG4gICAgZXhwYW5kZWRBZnRlckRlbGF5ID0gY29tcHV0ZWQoKCkgPT4gdGhpcy5uYXZTZWxlY3RvclN0YXRlLmV4cGFuZGVkQWZ0ZXJEZWxheSgpKTtcblxuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgbmF2U2VsZWN0b3JTdGF0ZTogTmF2U2VsZWN0b3JTdGF0ZSkge31cblxuICAgIHRvZ2dsZUZvbGRpbmcoZXZlbnQ6IEV2ZW50LCBjYXRlZ29yeTogSW50ZXJuYWxOYXZTZWxlY3RvckNhdGVnb3J5KSB7XG4gICAgICAgIGV2ZW50LnN0b3BJbW1lZGlhdGVQcm9wYWdhdGlvbigpO1xuICAgICAgICB0aGlzLm5hdlNlbGVjdG9yU3RhdGUub25Hcm91cFRvZ2dsZUZvbGRpbmcoY2F0ZWdvcnkpO1xuICAgIH1cblxuICAgIGZvbGQoZXZlbnQ6IEV2ZW50LCBjYXRlZ29yeTogSW50ZXJuYWxOYXZTZWxlY3RvckNhdGVnb3J5KSB7XG4gICAgICAgIGV2ZW50LnN0b3BJbW1lZGlhdGVQcm9wYWdhdGlvbigpO1xuICAgICAgICB0aGlzLm5hdlNlbGVjdG9yU3RhdGUuZm9sZChjYXRlZ29yeSk7XG4gICAgfVxuXG4gICAgdW5mb2xkKGV2ZW50OiBFdmVudCwgY2F0ZWdvcnk6IEludGVybmFsTmF2U2VsZWN0b3JDYXRlZ29yeSkge1xuICAgICAgICBldmVudC5zdG9wSW1tZWRpYXRlUHJvcGFnYXRpb24oKTtcbiAgICAgICAgdGhpcy5uYXZTZWxlY3RvclN0YXRlLnVuZm9sZChjYXRlZ29yeSk7XG4gICAgfVxufVxuIl19
|