asksuite-citrus 0.6.0 → 0.6.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/asksuite-citrus.module.mjs +15 -5
- package/esm2022/lib/components/autocomplete/autocomplete.component.mjs +11 -21
- package/esm2022/lib/components/avatar/avatar.component.mjs +6 -3
- package/esm2022/lib/components/chips/chips.component.mjs +3 -3
- package/esm2022/lib/components/date-picker/date-picker.component.mjs +8 -2
- package/esm2022/lib/directives/autofocus/autofocus.directive.mjs +20 -0
- package/esm2022/lib/directives/scroll/scroll.directive.mjs +37 -0
- package/esm2022/public-api.mjs +3 -1
- package/fesm2022/asksuite-citrus.mjs +90 -32
- package/fesm2022/asksuite-citrus.mjs.map +1 -1
- package/lib/asksuite-citrus.module.d.ts +8 -6
- package/lib/components/autocomplete/autocomplete.component.d.ts +2 -3
- package/lib/components/avatar/avatar.component.d.ts +2 -1
- package/lib/directives/autofocus/autofocus.directive.d.ts +9 -0
- package/lib/directives/scroll/scroll.directive.d.ts +12 -0
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
@@ -59,7 +59,10 @@ export class DatePickerComponent {
|
|
59
59
|
}
|
60
60
|
selectPeriod(period) {
|
61
61
|
this.periods.forEach((period) => period.selected = false);
|
62
|
-
this.date =
|
62
|
+
this.date = {
|
63
|
+
...this.date,
|
64
|
+
...period.getRange()
|
65
|
+
};
|
63
66
|
this.date.label = period.label;
|
64
67
|
this.isCustomRange = period.isCustomRange || false;
|
65
68
|
period.selected = true;
|
@@ -74,6 +77,9 @@ export class DatePickerComponent {
|
|
74
77
|
}
|
75
78
|
}
|
76
79
|
emitValue() {
|
80
|
+
if (this.isCustomRange && !this.date.to) {
|
81
|
+
this.date.to = this.date.from;
|
82
|
+
}
|
77
83
|
this.dateChange.emit(this.date);
|
78
84
|
this.onChange(this.date);
|
79
85
|
this.close.emit();
|
@@ -136,4 +142,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
|
|
136
142
|
}], close: [{
|
137
143
|
type: Output
|
138
144
|
}] } });
|
139
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/asksuite-citrus/src/lib/components/date-picker/date-picker.component.ts","../../../../../../projects/asksuite-citrus/src/lib/components/date-picker/date-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, forwardRef, Input, OnInit, Output, Provider} from '@angular/core';\nimport moment from 'moment';\nimport {DatePickerValue, DateRange, PeriodLabel, formatFrom, formatTo} from \"./date-picker-calendar/date-picker-calendar.component\";\nimport {ControlValueAccessor, NG_VALUE_ACCESSOR} from \"@angular/forms\";\n\ninterface Period {\n  label: PeriodLabel;\n  getRange: () => DateRange;\n  isCustomRange?: boolean;\n  selected: boolean;\n}\n\nconst VALUE_ACCESSOR: Provider = {\n  provide: NG_VALUE_ACCESSOR,\n  multi: true,\n  useExisting: forwardRef(() => DatePickerComponent),\n}\n\n\n\n@Component({\n  selector: 'ask-date-picker',\n  templateUrl: './date-picker.component.html',\n  styleUrls: ['./date-picker.component.scss'],\n  providers: [ VALUE_ACCESSOR ],\n})\nexport class DatePickerComponent implements OnInit, ControlValueAccessor {\n\n  periods: Array<Period> = [\n    { label: PeriodLabel.TODAY, getRange: () => ({ from: formatFrom(moment()), to: formatTo(moment()) }), selected: false },\n    { label: PeriodLabel.YESTERDAY, getRange: () => ({ from: formatFrom(moment().subtract(1, 'day')), to: formatTo(moment().subtract(1, 'day')) }), selected: false },\n    { label: PeriodLabel.LAST_7_DAYS, getRange: () => ({ from: formatFrom(moment().subtract(1, 'week')), to: formatTo(moment()) }), selected: false },\n    { label: PeriodLabel.LAST_30_DAYS, getRange: () => ({ from: formatFrom(moment().subtract(30, 'days')), to: formatTo(moment()) }), selected: false },\n    { label: PeriodLabel.THIS_MONTH, getRange: () => ({ from: formatFrom(moment().startOf('month')), to: formatTo(moment().endOf('month')) }), selected: false },\n    { label: PeriodLabel.LAST_QUARTER, getRange: () => ({ from: formatFrom(moment().subtract(3, 'months')), to: formatTo(moment().endOf('month')) }), selected: false },\n    { label: PeriodLabel.CUSTOM_PERIOD, getRange: () => ({}), isCustomRange: true, selected: false },\n  ];\n\n  @Input() date: DatePickerValue = moment().format();\n  @Input() isRange: boolean = false;\n  @Input() periodsFilter: PeriodLabel[] = [];\n\n  @Output() dateChange = new EventEmitter<DatePickerValue>();\n  @Output() close = new EventEmitter();\n\n  isCustomRange = false;\n\n  get filteredPeriods() {\n    if (!this.periodsFilter?.length) {\n      return this.periods;\n    }\n\n    return this.periods.filter(p => this.periodsFilter.includes(p.label));\n  }\n\n  get from(): string | undefined {\n    if (!this.isRange) {\n      return;\n    }\n\n    return (this.date as DateRange).from;\n  }\n\n  get to(): string | undefined {\n    if (!this.isRange) {\n      return;\n    }\n\n    return (this.date as DateRange).to;\n  }\n\n  get dateDisplay(): string {\n    const from = this.from ? moment(this.from).format('L') : '';\n    const to = this.to ? moment(this.to).format('L') : '';\n\n    return `${from} ${ to ? '- ' + to : '' }`;\n  }\n\n  ngOnInit(): void {\n  }\n\n  selectPeriod(period: Period) {\n    this.periods.forEach((period: Period) => period.selected = false);\n\n    this.date = period.getRange();\n    this.date.label = period.label;\n    this.isCustomRange = period.isCustomRange || false;\n    period.selected = true;\n\n    if (!this.isCustomRange) {\n      this.emitValue();\n    }\n  }\n\n  handleDateChange(value: DatePickerValue) {\n    this.date = value;\n\n    if (!this.isRange) {\n      this.emitValue();\n    }\n  }\n\n  emitValue() {\n    this.dateChange.emit(this.date);\n    this.onChange(this.date);\n    this.close.emit();\n  }\n\n  handleCancelClick() {\n    this.close.emit();\n  }\n\n  private getPeriodOrDefault(periodName: PeriodLabel, defaultPeriodName: PeriodLabel = PeriodLabel.TODAY) {\n    return this.periods.find(p => p.label === periodName) ||\n      this.periods.find(p => p.label === defaultPeriodName);\n  }\n\n  checkPeriodShouldBeSelectedByValue() {\n    if (!this.isRange) {\n      return;\n    }\n\n    this.periods.forEach((period: Period) => period.selected = false);\n    const period = this.periods.find(p => p.label === (this.date as DateRange)?.label);\n\n    if (!period) {\n      return;\n    }\n\n    period.selected = true;\n    this.isCustomRange = period.isCustomRange || false;\n  }\n\n  writeValue(value: DatePickerValue) {\n    if (this.isRange) {\n      const valueRange = value as DateRange;\n\n      if (valueRange.label && valueRange.label !== PeriodLabel.CUSTOM_PERIOD) {\n        const period = this.getPeriodOrDefault(valueRange.label)?.getRange() || {};\n        this.date = { ...period, label: valueRange.label };\n      }\n\n      else if (valueRange.from && valueRange.to) {\n        this.date = { from: valueRange.from, to: valueRange.to, label: PeriodLabel.CUSTOM_PERIOD };\n      }\n\n      this.checkPeriodShouldBeSelectedByValue();\n    }\n\n    else {\n      this.date = value;\n    }\n  }\n\n  registerOnChange(fn: (value: DatePickerValue) => void): void {\n    this.onChange = fn;\n  }\n\n  onChange = (value: DatePickerValue) => {};\n\n  registerOnTouched(fn: any): void {\n    this.onTouch = fn;\n  }\n\n  onTouch = () => {};\n}\n","<div class=\"date-picker-container\">\n  <main class=\"main-content\">\n    <div\n      class=\"periods-list\"\n      *ngIf=\"isRange\"\n      [ngClass]=\"{ 'show-divider': isCustomRange }\"\n    >\n      <button\n        *ngFor=\"let period of filteredPeriods\"\n        type=\"button\"\n        class=\"period\"\n        [ngClass]=\"{ 'selected': period.selected }\"\n        (click)=\"selectPeriod(period)\"\n      >\n        {{ period.label.toString() | translate }}\n      </button>\n    </div>\n\n    <ask-date-picker-calendar\n      *ngIf=\"!isRange || (isRange && isCustomRange)\"\n      [date]=\"date\"\n      (dateChange)=\"handleDateChange($event)\"\n      [isRange]=\"isRange\"\n    ></ask-date-picker-calendar>\n  </main>\n\n  <footer class=\"footer\" *ngIf=\"isCustomRange && isRange\">\n    <div class=\"date-display\">{{ dateDisplay }}</div>\n\n    <div class=\"button-tray\">\n      <ask-button\n        [size]=\"'xsmall'\"\n        [type]=\"'secondary'\"\n        (click)=\"handleCancelClick()\"\n      >\n        {{ 'CANCEL' | translate }}\n      </ask-button>\n\n      <ask-button\n        [size]=\"'xsmall'\"\n        [type]=\"'primary'\"\n        (click)=\"emitValue()\"\n      >\n        {{ 'APPLY' | translate }}\n      </ask-button>\n    </div>\n  </footer>\n</div>\n"]}
|
145
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/asksuite-citrus/src/lib/components/date-picker/date-picker.component.ts","../../../../../../projects/asksuite-citrus/src/lib/components/date-picker/date-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, forwardRef, Input, OnInit, Output, Provider} from '@angular/core';\nimport moment from 'moment';\nimport {DatePickerValue, DateRange, PeriodLabel, formatFrom, formatTo} from \"./date-picker-calendar/date-picker-calendar.component\";\nimport {ControlValueAccessor, NG_VALUE_ACCESSOR} from \"@angular/forms\";\n\ninterface Period {\n  label: PeriodLabel;\n  getRange: () => DateRange;\n  isCustomRange?: boolean;\n  selected: boolean;\n}\n\nconst VALUE_ACCESSOR: Provider = {\n  provide: NG_VALUE_ACCESSOR,\n  multi: true,\n  useExisting: forwardRef(() => DatePickerComponent),\n}\n\n\n\n@Component({\n  selector: 'ask-date-picker',\n  templateUrl: './date-picker.component.html',\n  styleUrls: ['./date-picker.component.scss'],\n  providers: [ VALUE_ACCESSOR ],\n})\nexport class DatePickerComponent implements OnInit, ControlValueAccessor {\n\n  periods: Array<Period> = [\n    { label: PeriodLabel.TODAY, getRange: () => ({ from: formatFrom(moment()), to: formatTo(moment()) }), selected: false },\n    { label: PeriodLabel.YESTERDAY, getRange: () => ({ from: formatFrom(moment().subtract(1, 'day')), to: formatTo(moment().subtract(1, 'day')) }), selected: false },\n    { label: PeriodLabel.LAST_7_DAYS, getRange: () => ({ from: formatFrom(moment().subtract(1, 'week')), to: formatTo(moment()) }), selected: false },\n    { label: PeriodLabel.LAST_30_DAYS, getRange: () => ({ from: formatFrom(moment().subtract(30, 'days')), to: formatTo(moment()) }), selected: false },\n    { label: PeriodLabel.THIS_MONTH, getRange: () => ({ from: formatFrom(moment().startOf('month')), to: formatTo(moment().endOf('month')) }), selected: false },\n    { label: PeriodLabel.LAST_QUARTER, getRange: () => ({ from: formatFrom(moment().subtract(3, 'months')), to: formatTo(moment().endOf('month')) }), selected: false },\n    { label: PeriodLabel.CUSTOM_PERIOD, getRange: () => ({}), isCustomRange: true, selected: false },\n  ];\n\n  @Input() date: DatePickerValue = moment().format();\n  @Input() isRange: boolean = false;\n  @Input() periodsFilter: PeriodLabel[] = [];\n\n  @Output() dateChange = new EventEmitter<DatePickerValue>();\n  @Output() close = new EventEmitter();\n\n  isCustomRange = false;\n\n  get filteredPeriods() {\n    if (!this.periodsFilter?.length) {\n      return this.periods;\n    }\n\n    return this.periods.filter(p => this.periodsFilter.includes(p.label));\n  }\n\n  get from(): string | undefined {\n    if (!this.isRange) {\n      return;\n    }\n\n    return (this.date as DateRange).from;\n  }\n\n  get to(): string | undefined {\n    if (!this.isRange) {\n      return;\n    }\n\n    return (this.date as DateRange).to;\n  }\n\n  get dateDisplay(): string {\n    const from = this.from ? moment(this.from).format('L') : '';\n    const to = this.to ? moment(this.to).format('L') : '';\n\n    return `${from} ${ to ? '- ' + to : '' }`;\n  }\n\n  ngOnInit(): void {\n  }\n\n  selectPeriod(period: Period) {\n    this.periods.forEach((period: Period) => period.selected = false);\n\n    this.date = {\n      ...(this.date as DateRange),\n      ...period.getRange()\n    };\n    this.date.label = period.label;\n    this.isCustomRange = period.isCustomRange || false;\n    period.selected = true;\n\n    if (!this.isCustomRange) {\n      this.emitValue();\n    }\n  }\n\n  handleDateChange(value: DatePickerValue) {\n    this.date = value;\n\n    if (!this.isRange) {\n      this.emitValue();\n    }\n  }\n\n  emitValue() {\n    if (this.isCustomRange && !(this.date as DateRange).to) {\n      (this.date as DateRange).to = (this.date as DateRange).from;\n    }\n\n    this.dateChange.emit(this.date);\n    this.onChange(this.date);\n    this.close.emit();\n  }\n\n  handleCancelClick() {\n    this.close.emit();\n  }\n\n  private getPeriodOrDefault(periodName: PeriodLabel, defaultPeriodName: PeriodLabel = PeriodLabel.TODAY) {\n    return this.periods.find(p => p.label === periodName) ||\n      this.periods.find(p => p.label === defaultPeriodName);\n  }\n\n  checkPeriodShouldBeSelectedByValue() {\n    if (!this.isRange) {\n      return;\n    }\n\n    this.periods.forEach((period: Period) => period.selected = false);\n    const period = this.periods.find(p => p.label === (this.date as DateRange)?.label);\n\n    if (!period) {\n      return;\n    }\n\n    period.selected = true;\n    this.isCustomRange = period.isCustomRange || false;\n  }\n\n  writeValue(value: DatePickerValue) {\n    if (this.isRange) {\n      const valueRange = value as DateRange;\n\n      if (valueRange.label && valueRange.label !== PeriodLabel.CUSTOM_PERIOD) {\n        const period = this.getPeriodOrDefault(valueRange.label)?.getRange() || {};\n        this.date = { ...period, label: valueRange.label };\n      }\n\n      else if (valueRange.from && valueRange.to) {\n        this.date = { from: valueRange.from, to: valueRange.to, label: PeriodLabel.CUSTOM_PERIOD };\n      }\n\n      this.checkPeriodShouldBeSelectedByValue();\n    }\n\n    else {\n      this.date = value;\n    }\n  }\n\n  registerOnChange(fn: (value: DatePickerValue) => void): void {\n    this.onChange = fn;\n  }\n\n  onChange = (value: DatePickerValue) => {};\n\n  registerOnTouched(fn: any): void {\n    this.onTouch = fn;\n  }\n\n  onTouch = () => {};\n}\n","<div class=\"date-picker-container\">\n  <main class=\"main-content\">\n    <div\n      class=\"periods-list\"\n      *ngIf=\"isRange\"\n      [ngClass]=\"{ 'show-divider': isCustomRange }\"\n    >\n      <button\n        *ngFor=\"let period of filteredPeriods\"\n        type=\"button\"\n        class=\"period\"\n        [ngClass]=\"{ 'selected': period.selected }\"\n        (click)=\"selectPeriod(period)\"\n      >\n        {{ period.label.toString() | translate }}\n      </button>\n    </div>\n\n    <ask-date-picker-calendar\n      *ngIf=\"!isRange || (isRange && isCustomRange)\"\n      [date]=\"date\"\n      (dateChange)=\"handleDateChange($event)\"\n      [isRange]=\"isRange\"\n    ></ask-date-picker-calendar>\n  </main>\n\n  <footer class=\"footer\" *ngIf=\"isCustomRange && isRange\">\n    <div class=\"date-display\">{{ dateDisplay }}</div>\n\n    <div class=\"button-tray\">\n      <ask-button\n        [size]=\"'xsmall'\"\n        [type]=\"'secondary'\"\n        (click)=\"handleCancelClick()\"\n      >\n        {{ 'CANCEL' | translate }}\n      </ask-button>\n\n      <ask-button\n        [size]=\"'xsmall'\"\n        [type]=\"'primary'\"\n        (click)=\"emitValue()\"\n      >\n        {{ 'APPLY' | translate }}\n      </ask-button>\n    </div>\n  </footer>\n</div>\n"]}
|
@@ -0,0 +1,20 @@
|
|
1
|
+
import { Directive } from '@angular/core';
|
2
|
+
import * as i0 from "@angular/core";
|
3
|
+
export class AutofocusDirective {
|
4
|
+
constructor(elRef) {
|
5
|
+
this.elRef = elRef;
|
6
|
+
}
|
7
|
+
ngAfterViewInit() {
|
8
|
+
if (this.elRef)
|
9
|
+
this.elRef.nativeElement.focus();
|
10
|
+
}
|
11
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: AutofocusDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
12
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.6", type: AutofocusDirective, selector: "[askAutofocus]", ngImport: i0 }); }
|
13
|
+
}
|
14
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: AutofocusDirective, decorators: [{
|
15
|
+
type: Directive,
|
16
|
+
args: [{
|
17
|
+
selector: '[askAutofocus]'
|
18
|
+
}]
|
19
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }]; } });
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0b2ZvY3VzLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Fza3N1aXRlLWNpdHJ1cy9zcmMvbGliL2RpcmVjdGl2ZXMvYXV0b2ZvY3VzL2F1dG9mb2N1cy5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFnQixTQUFTLEVBQWEsTUFBTSxlQUFlLENBQUM7O0FBS25FLE1BQU0sT0FBTyxrQkFBa0I7SUFFN0IsWUFBb0IsS0FBaUI7UUFBakIsVUFBSyxHQUFMLEtBQUssQ0FBWTtJQUFJLENBQUM7SUFFMUMsZUFBZTtRQUNiLElBQUksSUFBSSxDQUFDLEtBQUs7WUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLGFBQWEsQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUNuRCxDQUFDOzhHQU5VLGtCQUFrQjtrR0FBbEIsa0JBQWtCOzsyRkFBbEIsa0JBQWtCO2tCQUg5QixTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxnQkFBZ0I7aUJBQzNCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtBZnRlclZpZXdJbml0LCBEaXJlY3RpdmUsIEVsZW1lbnRSZWZ9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbYXNrQXV0b2ZvY3VzXSdcbn0pXG5leHBvcnQgY2xhc3MgQXV0b2ZvY3VzRGlyZWN0aXZlIGltcGxlbWVudHMgQWZ0ZXJWaWV3SW5pdHtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGVsUmVmOiBFbGVtZW50UmVmKSB7IH1cblxuICBuZ0FmdGVyVmlld0luaXQoKSB7XG4gICAgaWYgKHRoaXMuZWxSZWYpIHRoaXMuZWxSZWYubmF0aXZlRWxlbWVudC5mb2N1cygpO1xuICB9XG5cbn1cbiJdfQ==
|
@@ -0,0 +1,37 @@
|
|
1
|
+
import { Directive, EventEmitter, HostListener, Input, Output } from '@angular/core';
|
2
|
+
import * as i0 from "@angular/core";
|
3
|
+
export class ScrollDirective {
|
4
|
+
constructor(el) {
|
5
|
+
this.el = el;
|
6
|
+
this.askScrollThreshold = 0;
|
7
|
+
this.scrollEnd = new EventEmitter();
|
8
|
+
}
|
9
|
+
onScroll(event) {
|
10
|
+
const element = event.target;
|
11
|
+
if (this.isScrollAtEnd(element)) {
|
12
|
+
this.scrollEnd.emit();
|
13
|
+
}
|
14
|
+
}
|
15
|
+
isScrollAtEnd(element) {
|
16
|
+
const scrollTop = element.scrollTop || element.scrollTop === 0 ? element.scrollTop : 0;
|
17
|
+
const scrollHeight = element.scrollHeight || 0;
|
18
|
+
const clientHeight = element.clientHeight || 0;
|
19
|
+
return scrollTop + clientHeight >= (scrollHeight - Number(this.askScrollThreshold));
|
20
|
+
}
|
21
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: ScrollDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
22
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.6", type: ScrollDirective, selector: "[askScroll]", inputs: { askScrollThreshold: "askScrollThreshold" }, outputs: { scrollEnd: "scrollEnd" }, host: { listeners: { "scroll": "onScroll($event)" } }, ngImport: i0 }); }
|
23
|
+
}
|
24
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: ScrollDirective, decorators: [{
|
25
|
+
type: Directive,
|
26
|
+
args: [{
|
27
|
+
selector: '[askScroll]'
|
28
|
+
}]
|
29
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { askScrollThreshold: [{
|
30
|
+
type: Input
|
31
|
+
}], scrollEnd: [{
|
32
|
+
type: Output
|
33
|
+
}], onScroll: [{
|
34
|
+
type: HostListener,
|
35
|
+
args: ['scroll', ['$event']]
|
36
|
+
}] } });
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2Nyb2xsLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Fza3N1aXRlLWNpdHJ1cy9zcmMvbGliL2RpcmVjdGl2ZXMvc2Nyb2xsL3Njcm9sbC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBYyxZQUFZLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUMsTUFBTSxlQUFlLENBQUM7O0FBSy9GLE1BQU0sT0FBTyxlQUFlO0lBSzFCLFlBQW9CLEVBQWM7UUFBZCxPQUFFLEdBQUYsRUFBRSxDQUFZO1FBSnpCLHVCQUFrQixHQUFXLENBQUMsQ0FBQztRQUU5QixjQUFTLEdBQUcsSUFBSSxZQUFZLEVBQVEsQ0FBQztJQUVWLENBQUM7SUFHdEMsUUFBUSxDQUFDLEtBQVk7UUFDbkIsTUFBTSxPQUFPLEdBQUcsS0FBSyxDQUFDLE1BQXFCLENBQUM7UUFDNUMsSUFBSSxJQUFJLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxFQUFFO1lBQy9CLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxFQUFFLENBQUM7U0FDdkI7SUFDSCxDQUFDO0lBRU8sYUFBYSxDQUFDLE9BQW9CO1FBQ3hDLE1BQU0sU0FBUyxHQUFHLE9BQU8sQ0FBQyxTQUFTLElBQUksT0FBTyxDQUFDLFNBQVMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUN2RixNQUFNLFlBQVksR0FBRyxPQUFPLENBQUMsWUFBWSxJQUFJLENBQUMsQ0FBQztRQUMvQyxNQUFNLFlBQVksR0FBRyxPQUFPLENBQUMsWUFBWSxJQUFJLENBQUMsQ0FBQztRQUMvQyxPQUFPLFNBQVMsR0FBRyxZQUFZLElBQUksQ0FBQyxZQUFZLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDLENBQUM7SUFDdEYsQ0FBQzs4R0FwQlUsZUFBZTtrR0FBZixlQUFlOzsyRkFBZixlQUFlO2tCQUgzQixTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxhQUFhO2lCQUN4QjtpR0FFVSxrQkFBa0I7c0JBQTFCLEtBQUs7Z0JBRUksU0FBUztzQkFBbEIsTUFBTTtnQkFLUCxRQUFRO3NCQURQLFlBQVk7dUJBQUMsUUFBUSxFQUFFLENBQUMsUUFBUSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIEV2ZW50RW1pdHRlciwgSG9zdExpc3RlbmVyLCBJbnB1dCwgT3V0cHV0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW2Fza1Njcm9sbF0nXG59KVxuZXhwb3J0IGNsYXNzIFNjcm9sbERpcmVjdGl2ZSB7XG4gIEBJbnB1dCgpIGFza1Njcm9sbFRocmVzaG9sZDogbnVtYmVyID0gMDtcblxuICBAT3V0cHV0KCkgc2Nyb2xsRW5kID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgZWw6IEVsZW1lbnRSZWYpIHt9XG5cbiAgQEhvc3RMaXN0ZW5lcignc2Nyb2xsJywgWyckZXZlbnQnXSlcbiAgb25TY3JvbGwoZXZlbnQ6IEV2ZW50KSB7XG4gICAgY29uc3QgZWxlbWVudCA9IGV2ZW50LnRhcmdldCBhcyBIVE1MRWxlbWVudDtcbiAgICBpZiAodGhpcy5pc1Njcm9sbEF0RW5kKGVsZW1lbnQpKSB7XG4gICAgICB0aGlzLnNjcm9sbEVuZC5lbWl0KCk7XG4gICAgfVxuICB9XG5cbiAgcHJpdmF0ZSBpc1Njcm9sbEF0RW5kKGVsZW1lbnQ6IEhUTUxFbGVtZW50KTogYm9vbGVhbiB7XG4gICAgY29uc3Qgc2Nyb2xsVG9wID0gZWxlbWVudC5zY3JvbGxUb3AgfHwgZWxlbWVudC5zY3JvbGxUb3AgPT09IDAgPyBlbGVtZW50LnNjcm9sbFRvcCA6IDA7XG4gICAgY29uc3Qgc2Nyb2xsSGVpZ2h0ID0gZWxlbWVudC5zY3JvbGxIZWlnaHQgfHwgMDtcbiAgICBjb25zdCBjbGllbnRIZWlnaHQgPSBlbGVtZW50LmNsaWVudEhlaWdodCB8fCAwO1xuICAgIHJldHVybiBzY3JvbGxUb3AgKyBjbGllbnRIZWlnaHQgPj0gKHNjcm9sbEhlaWdodCAtIE51bWJlcih0aGlzLmFza1Njcm9sbFRocmVzaG9sZCkpO1xuICB9XG5cbn1cbiJdfQ==
|
package/esm2022/public-api.mjs
CHANGED
@@ -19,4 +19,6 @@ export * from './lib/components/skeleton/skeleton.component';
|
|
19
19
|
export * from './lib/directives/ask-dropdown.directive';
|
20
20
|
export * from './lib/directives/spinner/spinner.directive';
|
21
21
|
export * from './lib/directives/badge/badge.directive';
|
22
|
-
|
22
|
+
export * from './lib/directives/autofocus/autofocus.directive';
|
23
|
+
export * from './lib/directives/scroll/scroll.directive';
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2Fza3N1aXRlLWNpdHJ1cy9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsOEJBQThCLENBQUM7QUFFN0MsYUFBYTtBQUNiLGNBQWMsMENBQTBDLENBQUE7QUFDeEQsY0FBYyx3Q0FBd0MsQ0FBQTtBQUN0RCxjQUFjLDBDQUEwQyxDQUFBO0FBQ3hELGNBQWMsb0NBQW9DLENBQUE7QUFDbEQsY0FBYywwQ0FBMEMsQ0FBQTtBQUN4RCxjQUFjLGtFQUFrRSxDQUFBO0FBQ2hGLGNBQWMsc0RBQXNELENBQUE7QUFDcEUsY0FBYyw4Q0FBOEMsQ0FBQTtBQUM1RCxjQUFjLHdDQUF3QyxDQUFBO0FBQ3RELGNBQWMsb0RBQW9ELENBQUE7QUFDbEUsY0FBYyxrRkFBa0YsQ0FBQTtBQUNoRyxjQUFjLDhDQUE4QyxDQUFBO0FBRTVELGFBQWE7QUFDYixjQUFjLHlDQUF5QyxDQUFBO0FBQ3ZELGNBQWMsNENBQTRDLENBQUE7QUFDMUQsY0FBYyx3Q0FBd0MsQ0FBQTtBQUN0RCxjQUFjLGdEQUFnRCxDQUFBO0FBQzlELGNBQWMsMENBQTBDLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIGFza3N1aXRlLWNpdHJ1c1xuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL2Fza3N1aXRlLWNpdHJ1cy5tb2R1bGUnO1xuXG4vLyBDb21wb25lbnRzXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2J1dHRvbi9idXR0b24uY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9pbnB1dC9pbnB1dC5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL3NlbGVjdC9zZWxlY3QuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9ib3gvYm94LmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvYXZhdGFyL2F2YXRhci5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Ryb3Bkb3duLWNvbnRhaW5lci9kcm9wZG93bi1jb250YWluZXIuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9hdXRvY29tcGxldGUvYXV0b2NvbXBsZXRlLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY2hlY2tib3gvY2hlY2tib3guY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jaGlwcy9jaGlwcy5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2RhdGUtcGlja2VyL2RhdGUtcGlja2VyLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvZGF0ZS1waWNrZXIvZGF0ZS1waWNrZXItY2FsZW5kYXIvZGF0ZS1waWNrZXItY2FsZW5kYXIuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9za2VsZXRvbi9za2VsZXRvbi5jb21wb25lbnQnXG5cbi8vIERpcmVjdGl2ZXNcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpcmVjdGl2ZXMvYXNrLWRyb3Bkb3duLmRpcmVjdGl2ZSdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpcmVjdGl2ZXMvc3Bpbm5lci9zcGlubmVyLmRpcmVjdGl2ZSdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpcmVjdGl2ZXMvYmFkZ2UvYmFkZ2UuZGlyZWN0aXZlJ1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGlyZWN0aXZlcy9hdXRvZm9jdXMvYXV0b2ZvY3VzLmRpcmVjdGl2ZSdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpcmVjdGl2ZXMvc2Nyb2xsL3Njcm9sbC5kaXJlY3RpdmUnXG4iXX0=
|