@klippa/ngx-enhancy-forms 2.3.1 → 5.0.0
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/bundles/klippa-ngx-enhancy-forms.umd.js +960 -469
- package/bundles/klippa-ngx-enhancy-forms.umd.js.map +1 -1
- package/bundles/klippa-ngx-enhancy-forms.umd.min.js +3 -2
- package/bundles/klippa-ngx-enhancy-forms.umd.min.js.map +1 -1
- package/esm2015/lib/elements/date-picker/date-picker.component.js +92 -0
- package/esm2015/lib/elements/date-time-picker/date-time-picker.component.js +311 -0
- package/esm2015/lib/elements/email/email-input.component.js +2 -2
- package/esm2015/lib/elements/password-field/password-field.component.js +6 -4
- package/esm2015/lib/elements/select/select-footer/select-footer.component.js +15 -0
- package/esm2015/lib/elements/select/select.component.js +30 -9
- package/esm2015/lib/elements/sortable-items/sortable-items.component.js +46 -4
- package/esm2015/lib/elements/text-input/text-input.component.js +7 -4
- package/esm2015/lib/elements/value-accessor-base/multiple-value-accessor-base.component.js +63 -0
- package/esm2015/lib/elements/value-accessor-base/value-accessor-base.component.js +3 -3
- package/esm2015/lib/form/form-element/form-element.component.js +13 -15
- package/esm2015/lib/form/form.component.js +64 -18
- package/esm2015/lib/ngx-enhancy-forms.module.js +36 -25
- package/esm2015/lib/util/values.js +8 -17
- package/esm2015/public-api.js +5 -2
- package/fesm2015/klippa-ngx-enhancy-forms.js +556 -90
- package/fesm2015/klippa-ngx-enhancy-forms.js.map +1 -1
- package/klippa-ngx-enhancy-forms.metadata.json +1 -1
- package/lib/elements/date-picker/date-picker.component.d.ts +23 -0
- package/lib/elements/date-time-picker/date-time-picker.component.d.ts +59 -0
- package/lib/elements/email/email-input.component.d.ts +1 -1
- package/lib/elements/password-field/password-field.component.d.ts +2 -1
- package/lib/elements/select/select-footer/select-footer.component.d.ts +4 -0
- package/lib/elements/select/select.component.d.ts +12 -4
- package/lib/elements/sortable-items/sortable-items.component.d.ts +12 -2
- package/lib/elements/text-input/text-input.component.d.ts +2 -0
- package/lib/elements/value-accessor-base/multiple-value-accessor-base.component.d.ts +11 -0
- package/lib/elements/value-accessor-base/value-accessor-base.component.d.ts +2 -1
- package/lib/form/form-element/form-element.component.d.ts +5 -5
- package/lib/form/form.component.d.ts +11 -7
- package/lib/util/values.d.ts +2 -4
- package/package.json +1 -1
- package/public-api.d.ts +4 -1
- package/esm2015/lib/elements/datepicker/datepicker.component.js +0 -111
- package/lib/elements/datepicker/datepicker.component.d.ts +0 -26
|
@@ -1,19 +1,22 @@
|
|
|
1
|
-
import { EventEmitter } from '@angular/core';
|
|
1
|
+
import { EventEmitter, InjectionToken, TemplateRef } from '@angular/core';
|
|
2
2
|
import { ControlContainer } from '@angular/forms';
|
|
3
|
-
import { ValueAccessorBase } from
|
|
4
|
-
import { FormElementComponent } from
|
|
3
|
+
import { ValueAccessorBase } from '../value-accessor-base/value-accessor-base.component';
|
|
4
|
+
import { FormElementComponent } from '../../form/form-element/form-element.component';
|
|
5
5
|
export declare type AppSelectOptions = Array<{
|
|
6
6
|
id: any;
|
|
7
7
|
name: string;
|
|
8
8
|
description?: string;
|
|
9
9
|
disabled?: boolean;
|
|
10
10
|
}>;
|
|
11
|
+
export declare const SELECT_TRANSLATIONS: InjectionToken<any>;
|
|
11
12
|
export declare class SelectComponent extends ValueAccessorBase<string | string[]> {
|
|
12
13
|
protected parent: FormElementComponent;
|
|
13
14
|
protected controlContainer: ControlContainer;
|
|
15
|
+
private translations;
|
|
14
16
|
placeholder: string;
|
|
15
17
|
options: AppSelectOptions;
|
|
16
18
|
multiple: boolean;
|
|
19
|
+
multipleDisplayedAsAmount: boolean;
|
|
17
20
|
clearable: boolean;
|
|
18
21
|
dropdownPosition: string;
|
|
19
22
|
customSearchFn: (term: string, item: {
|
|
@@ -21,6 +24,11 @@ export declare class SelectComponent extends ValueAccessorBase<string | string[]
|
|
|
21
24
|
name: string;
|
|
22
25
|
description: string;
|
|
23
26
|
}) => boolean;
|
|
27
|
+
footerElement: TemplateRef<any>;
|
|
24
28
|
onSearch: EventEmitter<string>;
|
|
25
|
-
|
|
29
|
+
currentQueryString: string;
|
|
30
|
+
constructor(parent: FormElementComponent, controlContainer: ControlContainer, translations: any);
|
|
31
|
+
onTextInput(value: string): void;
|
|
32
|
+
getDefaultTranslation(key: string): (x: any) => string;
|
|
33
|
+
getTranslation(key: string, params?: any): string;
|
|
26
34
|
}
|
|
@@ -1,6 +1,16 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
1
|
+
import { OnInit } from '@angular/core';
|
|
2
|
+
import { Options } from 'sortablejs';
|
|
3
|
+
import { ValueAccessorBase } from '../value-accessor-base/value-accessor-base.component';
|
|
4
|
+
export declare class SortableItemsComponent extends ValueAccessorBase<Array<any>> implements OnInit {
|
|
3
5
|
template: any;
|
|
4
6
|
sortableItemSize: 'sm' | 'lg';
|
|
7
|
+
useCustomScroll: boolean;
|
|
8
|
+
sortablejsOptions: Options;
|
|
9
|
+
private scrollInterval;
|
|
10
|
+
ngOnInit(): void;
|
|
5
11
|
itemsOrderChanged: () => void;
|
|
12
|
+
onItemDrag: (data: any) => void;
|
|
13
|
+
onEnd: () => void;
|
|
14
|
+
private scrollPage;
|
|
15
|
+
private stopScrolling;
|
|
6
16
|
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { ControlContainer } from '@angular/forms';
|
|
2
|
+
import { ValueAccessorBase } from './value-accessor-base.component';
|
|
3
|
+
import { FormElementComponent } from '../../form/form-element/form-element.component';
|
|
4
|
+
export declare class MultipleValueAccessorBase<T> extends ValueAccessorBase<Array<T> | T> {
|
|
5
|
+
protected parent: FormElementComponent;
|
|
6
|
+
protected controlContainer: ControlContainer;
|
|
7
|
+
multiple: boolean;
|
|
8
|
+
constructor(parent: FormElementComponent, controlContainer: ControlContainer);
|
|
9
|
+
writeValue(value: Array<T> | T): void;
|
|
10
|
+
setInnerValueAndNotify(value: T | Array<T>): void;
|
|
11
|
+
}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { ControlContainer, ControlValueAccessor, FormControl } from '@angular/forms';
|
|
2
|
+
import { OnDestroy, OnInit } from '@angular/core';
|
|
2
3
|
import { FormElementComponent } from '../../form/form-element/form-element.component';
|
|
3
4
|
/**
|
|
4
5
|
* This component is a base in order to create a component that supports ngModel.
|
|
@@ -9,7 +10,7 @@ import { FormElementComponent } from '../../form/form-element/form-element.compo
|
|
|
9
10
|
* setInnerValueAndNotify() = call this when you want your ngModel to be updated from INSIDE of your component, and provide it to the OUTSIDE.
|
|
10
11
|
* ngOnInit() = Used to support the angular reactive forms framework. If you use ngOnInit in your own component (which happens fairly often) you must not forget to call the super.ngOnInit() method.
|
|
11
12
|
*/
|
|
12
|
-
export declare class ValueAccessorBase<T> implements ControlValueAccessor {
|
|
13
|
+
export declare class ValueAccessorBase<T> implements ControlValueAccessor, OnInit, OnDestroy {
|
|
13
14
|
protected parent: FormElementComponent;
|
|
14
15
|
protected controlContainer: ControlContainer;
|
|
15
16
|
innerValue: T;
|
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
import { ElementRef, InjectionToken } from '@angular/core';
|
|
2
2
|
import { AbstractControl, FormControl } from '@angular/forms';
|
|
3
|
-
import { FormComponent } from
|
|
4
|
-
import { CustomErrorMessages, FormErrorMessages } from
|
|
3
|
+
import { FormComponent } from '../form.component';
|
|
4
|
+
import { CustomErrorMessages, FormErrorMessages } from '../../types';
|
|
5
5
|
export declare const FORM_ERROR_MESSAGES: InjectionToken<Record<"max" | "required" | "pattern" | "min" | "email" | "minLength" | "maxLength" | "matchPassword" | "date", () => string>>;
|
|
6
6
|
export declare const DEFAULT_ERROR_MESSAGES: FormErrorMessages;
|
|
7
7
|
export declare class FormElementComponent {
|
|
8
8
|
private parent;
|
|
9
9
|
private customMessages;
|
|
10
10
|
attachedControl: AbstractControl;
|
|
11
|
-
caption:
|
|
11
|
+
caption: string;
|
|
12
12
|
direction: 'horizontal' | 'vertical';
|
|
13
13
|
captionSpacing: 'percentages' | 'none';
|
|
14
14
|
swapInputAndCaption: boolean;
|
|
@@ -29,10 +29,10 @@ export declare class FormElementComponent {
|
|
|
29
29
|
getErrorToShow(): string;
|
|
30
30
|
getCustomErrorHandler(error: string): {
|
|
31
31
|
error: string;
|
|
32
|
-
templateRef: ElementRef
|
|
32
|
+
templateRef: ElementRef;
|
|
33
33
|
};
|
|
34
34
|
showDefaultError(error: string): boolean;
|
|
35
35
|
getScrollableParent(node: any): any;
|
|
36
36
|
scrollTo(): void;
|
|
37
|
-
|
|
37
|
+
getErrorMessage(key: keyof FormErrorMessages): string;
|
|
38
38
|
}
|
|
@@ -1,17 +1,21 @@
|
|
|
1
|
-
import { OnInit } from '@angular/core';
|
|
2
|
-
import { FormControl, FormGroup
|
|
1
|
+
import { OnDestroy, OnInit } from '@angular/core';
|
|
2
|
+
import { FormArray, FormControl, FormGroup } from '@angular/forms';
|
|
3
3
|
import { FormElementComponent } from './form-element/form-element.component';
|
|
4
4
|
export declare const invalidFieldsSymbol: unique symbol;
|
|
5
|
-
export declare class
|
|
6
|
-
|
|
5
|
+
export declare class SubFormDirective {
|
|
6
|
+
injectInto: FormArray | FormGroup;
|
|
7
|
+
at: number | string;
|
|
7
8
|
}
|
|
8
|
-
export declare class FormComponent implements OnInit {
|
|
9
|
+
export declare class FormComponent implements OnInit, OnDestroy {
|
|
9
10
|
private parent;
|
|
10
|
-
private
|
|
11
|
+
private subFormPlaceholder;
|
|
11
12
|
formGroup: FormGroup;
|
|
13
|
+
patchValueInterceptor: (values: any) => Promise<any>;
|
|
12
14
|
private activeControls;
|
|
13
|
-
constructor(parent: FormComponent,
|
|
15
|
+
constructor(parent: FormComponent, subFormPlaceholder: SubFormDirective);
|
|
14
16
|
ngOnInit(): void;
|
|
17
|
+
ngOnDestroy(): void;
|
|
18
|
+
private addSupportForPatchValueInterceptor;
|
|
15
19
|
registerControl(formControl: FormControl, formElement: FormElementComponent): void;
|
|
16
20
|
unregisterControl(formControl: FormControl): void;
|
|
17
21
|
private addFormGroupControls;
|
package/lib/util/values.d.ts
CHANGED
|
@@ -1,9 +1,7 @@
|
|
|
1
|
-
export declare function
|
|
1
|
+
export declare function stringIsSetAndFilled(s: string): boolean;
|
|
2
2
|
export declare function isNullOrUndefined(value: any): boolean;
|
|
3
3
|
export declare function numberIsSet(value: any): boolean;
|
|
4
4
|
export declare function isValueSet(value: any): boolean;
|
|
5
|
+
export declare function removeDuplicatesFromArray(array: Array<any>): any[];
|
|
5
6
|
export declare function stringOrArrayIsSetAndEmpty(value: any[] | string): boolean;
|
|
6
|
-
export declare function useIfStringIsSet(s: string): string;
|
|
7
|
-
export declare function useIfArrayIsSetWithOneItem(a: Array<any>): any;
|
|
8
|
-
export declare function convertParentToChild<C>(originalClass: any, newClass: C): C;
|
|
9
7
|
export declare function truncateString(s: string, length: number): string;
|
package/package.json
CHANGED
package/public-api.d.ts
CHANGED
|
@@ -1,16 +1,19 @@
|
|
|
1
1
|
export * from './lib/ngx-enhancy-forms.module';
|
|
2
2
|
export * from './lib/elements/button/button.component';
|
|
3
3
|
export * from './lib/elements/checkbox/checkbox.component';
|
|
4
|
-
export * from './lib/elements/
|
|
4
|
+
export * from './lib/elements/date-picker/date-picker.component';
|
|
5
|
+
export * from './lib/elements/date-time-picker/date-time-picker.component';
|
|
5
6
|
export * from './lib/elements/email/email-input.component';
|
|
6
7
|
export * from './lib/elements/loading-indicator/loading-indicator.component';
|
|
7
8
|
export * from './lib/elements/number-input/number-input.component';
|
|
8
9
|
export * from './lib/elements/password-field/password-field.component';
|
|
10
|
+
export * from './lib/elements/select/select-footer/select-footer.component';
|
|
9
11
|
export * from './lib/elements/select/select.component';
|
|
10
12
|
export * from './lib/elements/sortable-items/sortable-items.component';
|
|
11
13
|
export * from './lib/elements/text-input/text-input.component';
|
|
12
14
|
export * from './lib/elements/toggle/toggle.component';
|
|
13
15
|
export * from './lib/elements/value-accessor-base/value-accessor-base.component';
|
|
16
|
+
export * from './lib/elements/value-accessor-base/multiple-value-accessor-base.component';
|
|
14
17
|
export * from './lib/form/form.component';
|
|
15
18
|
export * from './lib/form/form-caption/form-caption.component';
|
|
16
19
|
export * from './lib/form/form-element/form-element.component';
|
|
@@ -1,111 +0,0 @@
|
|
|
1
|
-
import { Component, InjectionToken, Input, Optional, ViewChild } from '@angular/core';
|
|
2
|
-
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
-
import { isNullOrUndefined, stringIsSetAndNotEmpty } from '../../util/values';
|
|
4
|
-
import { invalidDateKey } from '../../validators/dateValidator';
|
|
5
|
-
import { ValueAccessorBase } from "../value-accessor-base/value-accessor-base.component";
|
|
6
|
-
import { MAT_DATE_FORMATS, MAT_NATIVE_DATE_FORMATS } from "@angular/material/core";
|
|
7
|
-
export const KLP_DATE_FORMATS = new InjectionToken('klp.form.date.formats');
|
|
8
|
-
export function matDateFormatsFactory(component, dateFormats) {
|
|
9
|
-
var _a;
|
|
10
|
-
return (_a = dateFormats === null || dateFormats === void 0 ? void 0 : dateFormats(component.format)) !== null && _a !== void 0 ? _a : MAT_NATIVE_DATE_FORMATS;
|
|
11
|
-
}
|
|
12
|
-
export class DatepickerComponent extends ValueAccessorBase {
|
|
13
|
-
constructor() {
|
|
14
|
-
super(...arguments);
|
|
15
|
-
this.minDate = undefined;
|
|
16
|
-
this.maxDate = undefined;
|
|
17
|
-
this.placeholder = 'Select date';
|
|
18
|
-
this.clearable = false;
|
|
19
|
-
this.minDateStartOfDay = undefined;
|
|
20
|
-
this.maxDateEndOfDay = undefined;
|
|
21
|
-
}
|
|
22
|
-
ngOnChanges(changes) {
|
|
23
|
-
if (changes.minDate) {
|
|
24
|
-
this.setMinDate(changes.minDate.currentValue);
|
|
25
|
-
}
|
|
26
|
-
if (changes.maxDate) {
|
|
27
|
-
this.setMaxDate(changes.maxDate.currentValue);
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
setMinDate(minDate) {
|
|
31
|
-
if (minDate) {
|
|
32
|
-
this.minDateStartOfDay = new Date(minDate);
|
|
33
|
-
this.minDateStartOfDay.setHours(0, 0, 0, 0);
|
|
34
|
-
}
|
|
35
|
-
else {
|
|
36
|
-
this.minDateStartOfDay = undefined;
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
setMaxDate(maxDate) {
|
|
40
|
-
if (maxDate) {
|
|
41
|
-
this.maxDateEndOfDay = new Date(maxDate);
|
|
42
|
-
this.maxDateEndOfDay.setHours(23, 59, 59, 999);
|
|
43
|
-
}
|
|
44
|
-
else {
|
|
45
|
-
this.maxDateEndOfDay = undefined;
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
|
-
// dateChanged is called when the output of the datepicker is changed and
|
|
49
|
-
// parsed correctly. If the date is invalid, it will be called the first time
|
|
50
|
-
// with null but never again until a valid input is provided.
|
|
51
|
-
dateChanged(event) {
|
|
52
|
-
const nativeInputValue = this.nativeInputRef.nativeElement.value;
|
|
53
|
-
const date = event.value;
|
|
54
|
-
if (isNullOrUndefined(date) && stringIsSetAndNotEmpty(nativeInputValue)) {
|
|
55
|
-
this.setInnerValueAndNotify(invalidDateKey);
|
|
56
|
-
}
|
|
57
|
-
else {
|
|
58
|
-
this.setInnerValueAndNotify(date);
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
writeValue(value) {
|
|
62
|
-
super.writeValue(value);
|
|
63
|
-
this.valueForMaterialDatePicker = value === invalidDateKey ? null : value;
|
|
64
|
-
}
|
|
65
|
-
// nativeValueChanged is called when the internal text value changes, but not
|
|
66
|
-
// when the date is changed via the date picker. We need this so that we can
|
|
67
|
-
// determine if the datepicker is empty or invalid.
|
|
68
|
-
nativeValueChanged(event) {
|
|
69
|
-
const nativeInputValue = event.target.value;
|
|
70
|
-
const date = this.valueForMaterialDatePicker;
|
|
71
|
-
if (this.datePickerRef.opened) {
|
|
72
|
-
// if the user is typing instead of using the picker, close it.
|
|
73
|
-
this.datePickerRef.close();
|
|
74
|
-
}
|
|
75
|
-
if (isNullOrUndefined(date) && stringIsSetAndNotEmpty(nativeInputValue)) {
|
|
76
|
-
this.setInnerValueAndNotify(invalidDateKey);
|
|
77
|
-
}
|
|
78
|
-
else {
|
|
79
|
-
this.setInnerValueAndNotify(date);
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
resetToNull() {
|
|
83
|
-
this.setInnerValueAndNotify(null);
|
|
84
|
-
this.valueForMaterialDatePicker = null;
|
|
85
|
-
this.nativeInputRef.nativeElement.value = null;
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
DatepickerComponent.decorators = [
|
|
89
|
-
{ type: Component, args: [{
|
|
90
|
-
selector: 'klp-form-datepicker',
|
|
91
|
-
template: "<div class=\"componentContainer\" [ngClass]=\"{showErrors: isInErrorState()}\">\n\t<mat-form-field [floatLabel]=\"'never'\">\n\t\t<input\n\t\t\t#nativeInput\n\t\t\tmatInput\n\t\t\t[matDatepicker]=\"picker\"\n\t\t\t[(ngModel)]=\"valueForMaterialDatePicker\"\n\t\t\t(dateInput)=\"dateChanged($event)\"\n\t\t\t(input)=\"nativeValueChanged($event)\"\n\t\t\t[min]=\"minDateStartOfDay\"\n\t\t\t[max]=\"maxDateEndOfDay\"\n\t\t\t[placeholder]=\"placeholder\"\n\t\t\t(click)=\"picker.open()\"\n\t\t\t(blur)=\"touch()\"\n\t\t>\n\t\t<mat-datepicker-toggle matSuffix [for]=\"picker\"></mat-datepicker-toggle>\n\t\t<mat-datepicker #picker\n\t\t></mat-datepicker>\n\t</mat-form-field>\n\t<button *ngIf=\"clearable\" class=\"clearButton\" (click)=\"resetToNull()\">\u00D7</button>\n</div>\n",
|
|
92
|
-
providers: [
|
|
93
|
-
{ provide: NG_VALUE_ACCESSOR, useExisting: DatepickerComponent, multi: true },
|
|
94
|
-
{ provide: MAT_DATE_FORMATS,
|
|
95
|
-
deps: [DatepickerComponent, [new Optional(), KLP_DATE_FORMATS]],
|
|
96
|
-
useFactory: matDateFormatsFactory,
|
|
97
|
-
}
|
|
98
|
-
],
|
|
99
|
-
styles: [":host{display:block}:host ::ng-deep mat-form-field{display:block;height:100%}:host ::ng-deep mat-form-field.mat-focused .mat-form-field-label,:host ::ng-deep mat-form-field .mat-form-field-label{color:#adadad}:host ::ng-deep .mat-datepicker-toggle-active{color:#666}:host ::ng-deep .mat-form-field-wrapper{padding-bottom:none}:host ::ng-deep .mat-form-field-flex{flex-direction:row-reverse}:host ::ng-deep .mat-form-field-infix{border-top:none}:host ::ng-deep .mat-form-field-suffix{margin-right:.625rem}:host ::ng-deep .mat-form-field-suffix:hover .mat-button-focus-overlay{opacity:.1}:host ::ng-deep .mat-form-field-underline{display:none}.componentContainer{-moz-transition:all .2s ease-in;-ms-transition:all .2s ease-in;-o-transition:all .2s ease-in;-webkit-transition:all .2s ease-in;border:1px solid #e6ecf5;border-radius:2px;box-shadow:none;color:#888da8;display:block;font-size:14px;height:42px;padding:.375rem .625rem;position:relative;transition:all .2s ease-in;width:100%}.componentContainer::-webkit-input-placeholder{color:#adadad}.componentContainer:-moz-placeholder,.componentContainer::-moz-placeholder{color:#adadad}.componentContainer:-ms-input-placeholder{color:#adadad}.componentContainer:focus{border-color:#3ed778;box-shadow:none;outline:0 none}.componentContainer.input-sm{height:30px}.componentContainer.input-lg{height:50px}.componentContainer.error{background-color:#ffeff4;border-color:#ff3c7e}.componentContainer.valid{background-color:#ebfaeb;border-color:#37c936;color:#278d26}.componentContainer.showErrors{border-color:#ff8000}.componentContainer .clearButton{align-items:center;background:none;border:none;bottom:0;color:#7b7b7b;display:flex;font-size:18px;position:absolute;right:1.25rem;top:0}"]
|
|
100
|
-
},] }
|
|
101
|
-
];
|
|
102
|
-
DatepickerComponent.propDecorators = {
|
|
103
|
-
minDate: [{ type: Input }],
|
|
104
|
-
maxDate: [{ type: Input }],
|
|
105
|
-
format: [{ type: Input }],
|
|
106
|
-
placeholder: [{ type: Input }],
|
|
107
|
-
clearable: [{ type: Input }],
|
|
108
|
-
nativeInputRef: [{ type: ViewChild, args: ['nativeInput',] }],
|
|
109
|
-
datePickerRef: [{ type: ViewChild, args: ['picker',] }]
|
|
110
|
-
};
|
|
111
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.component.js","sourceRoot":"/home/runner/work/ngx-enhancy-forms/ngx-enhancy-forms/projects/klippa/ngx-enhancy-forms/src/","sources":["lib/elements/datepicker/datepicker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tComponent,\n\tElementRef,\n\tHost,\n\tInject,\n\tInjectionToken,\n\tInput,\n\tOptional,\n\tSimpleChanges,\n\tViewChild\n} from '@angular/core';\nimport {ControlContainer, NG_VALUE_ACCESSOR} from '@angular/forms';\nimport {isNullOrUndefined, isValueSet, stringIsSetAndNotEmpty} from '../../util/values';\nimport { invalidDateKey } from '../../validators/dateValidator';\nimport { MatDatepicker } from '@angular/material/datepicker';\nimport {ValueAccessorBase} from \"../value-accessor-base/value-accessor-base.component\";\nimport {MAT_DATE_FORMATS, MAT_NATIVE_DATE_FORMATS} from \"@angular/material/core\";\nimport {KlpDateFormats} from \"../../types\";\n\nexport const KLP_DATE_FORMATS = new InjectionToken<KlpDateFormats>('klp.form.date.formats');\n\nexport function matDateFormatsFactory(component: DatepickerComponent, dateFormats?: KlpDateFormats) {\n\treturn dateFormats?.(component.format) ?? MAT_NATIVE_DATE_FORMATS;\n}\n\n@Component({\n\tselector: 'klp-form-datepicker',\n\ttemplateUrl: './datepicker.component.html',\n\tstyleUrls: ['./datepicker.component.scss'],\n\tproviders: [\n\t\t{ provide: NG_VALUE_ACCESSOR, useExisting: DatepickerComponent, multi: true },\n\t\t{ provide: MAT_DATE_FORMATS,\n\t\t\tdeps: [DatepickerComponent, [new Optional(), KLP_DATE_FORMATS]],\n\t\t\tuseFactory: matDateFormatsFactory,\n\t\t}\n\t],\n})\nexport class DatepickerComponent extends ValueAccessorBase<Date | typeof invalidDateKey> {\n\t@Input() public minDate: Date = undefined;\n\t@Input() public maxDate: Date = undefined;\n\t@Input() public format: string;\n\t@Input() public placeholder = 'Select date';\n\t@Input() public clearable = false;\n\n\t@ViewChild('nativeInput') nativeInputRef: ElementRef;\n\t@ViewChild('picker') datePickerRef: MatDatepicker<Date>;\n\n\tminDateStartOfDay: Date = undefined;\n\tmaxDateEndOfDay: Date = undefined;\n\n\t// this is passed as ngmodel and is used to set the inital date. But we also\n\t// use input and nativeInput callbacks to extend the validation logic so we\n\t// can destinguish between empty and invalid dates.\n\tvalueForMaterialDatePicker: Date;\n\n\tngOnChanges(changes: SimpleChanges) {\n\t\tif (changes.minDate) {\n\t\t\tthis.setMinDate(changes.minDate.currentValue);\n\t\t}\n\t\tif (changes.maxDate) {\n\t\t\tthis.setMaxDate(changes.maxDate.currentValue);\n\t\t}\n\t}\n\n\tsetMinDate(minDate: Date) {\n\t\tif (minDate) {\n\t\t\tthis.minDateStartOfDay = new Date(minDate);\n\t\t\tthis.minDateStartOfDay.setHours(0, 0, 0, 0);\n\t\t} else {\n\t\t\tthis.minDateStartOfDay = undefined;\n\t\t}\n\t}\n\n\tsetMaxDate(maxDate: Date) {\n\t\tif (maxDate) {\n\t\t\tthis.maxDateEndOfDay = new Date(maxDate);\n\t\t\tthis.maxDateEndOfDay.setHours(23, 59, 59, 999);\n\t\t} else {\n\t\t\tthis.maxDateEndOfDay = undefined;\n\t\t}\n\t}\n\n\t// dateChanged is called when the output of the datepicker is changed and\n\t// parsed correctly. If the date is invalid, it will be called the first time\n\t// with null but never again until a valid input is provided.\n\tdateChanged(event: any) {\n\t\tconst nativeInputValue = this.nativeInputRef.nativeElement.value;\n\t\tconst date = event.value;\n\t\tif (isNullOrUndefined(date) && stringIsSetAndNotEmpty(nativeInputValue)) {\n\t\t\tthis.setInnerValueAndNotify(invalidDateKey);\n\t\t} else {\n\t\t\tthis.setInnerValueAndNotify(date);\n\t\t}\n\t}\n\n\twriteValue(value: Date | typeof invalidDateKey) {\n\t\tsuper.writeValue(value);\n\t\tthis.valueForMaterialDatePicker = value === invalidDateKey ? null : value;\n\t}\n\n\t// nativeValueChanged is called when the internal text value changes, but not\n\t// when the date is changed via the date picker. We need this so that we can\n\t// determine if the datepicker is empty or invalid.\n\tnativeValueChanged(event: any) {\n\t\tconst nativeInputValue = event.target.value;\n\t\tconst date = this.valueForMaterialDatePicker;\n\n\t\tif (this.datePickerRef.opened) {\n\t\t\t// if the user is typing instead of using the picker, close it.\n\t\t\tthis.datePickerRef.close();\n\t\t}\n\n\t\tif (isNullOrUndefined(date) && stringIsSetAndNotEmpty(nativeInputValue)) {\n\t\t\tthis.setInnerValueAndNotify(invalidDateKey);\n\t\t} else {\n\t\t\tthis.setInnerValueAndNotify(date);\n\t\t}\n\t}\n\n\tresetToNull() {\n\t\tthis.setInnerValueAndNotify(null);\n\t\tthis.valueForMaterialDatePicker = null;\n\t\tthis.nativeInputRef.nativeElement.value = null;\n\t}\n}\n"]}
|
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
import { ElementRef, InjectionToken, SimpleChanges } from '@angular/core';
|
|
2
|
-
import { invalidDateKey } from '../../validators/dateValidator';
|
|
3
|
-
import { MatDatepicker } from '@angular/material/datepicker';
|
|
4
|
-
import { ValueAccessorBase } from "../value-accessor-base/value-accessor-base.component";
|
|
5
|
-
import { KlpDateFormats } from "../../types";
|
|
6
|
-
export declare const KLP_DATE_FORMATS: InjectionToken<KlpDateFormats>;
|
|
7
|
-
export declare function matDateFormatsFactory(component: DatepickerComponent, dateFormats?: KlpDateFormats): import("@angular/material/core").MatDateFormats;
|
|
8
|
-
export declare class DatepickerComponent extends ValueAccessorBase<Date | typeof invalidDateKey> {
|
|
9
|
-
minDate: Date;
|
|
10
|
-
maxDate: Date;
|
|
11
|
-
format: string;
|
|
12
|
-
placeholder: string;
|
|
13
|
-
clearable: boolean;
|
|
14
|
-
nativeInputRef: ElementRef;
|
|
15
|
-
datePickerRef: MatDatepicker<Date>;
|
|
16
|
-
minDateStartOfDay: Date;
|
|
17
|
-
maxDateEndOfDay: Date;
|
|
18
|
-
valueForMaterialDatePicker: Date;
|
|
19
|
-
ngOnChanges(changes: SimpleChanges): void;
|
|
20
|
-
setMinDate(minDate: Date): void;
|
|
21
|
-
setMaxDate(maxDate: Date): void;
|
|
22
|
-
dateChanged(event: any): void;
|
|
23
|
-
writeValue(value: Date | typeof invalidDateKey): void;
|
|
24
|
-
nativeValueChanged(event: any): void;
|
|
25
|
-
resetToNull(): void;
|
|
26
|
-
}
|