@colijnit/corecomponents_v12 12.0.78 → 12.0.79
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/colijnit-corecomponents_v12.umd.js +8 -1
- package/bundles/colijnit-corecomponents_v12.umd.js.map +1 -1
- package/colijnit-corecomponents_v12.metadata.json +1 -1
- package/esm2015/lib/components/input-text/input-text.component.js +16 -7
- package/fesm2015/colijnit-corecomponents_v12.js +15 -6
- package/fesm2015/colijnit-corecomponents_v12.js.map +1 -1
- package/lib/components/input-text/input-text.component.d.ts +2 -0
- package/package.json +1 -1
|
@@ -15,6 +15,7 @@ export class InputTextComponent extends BaseInputComponent {
|
|
|
15
15
|
this.elementRef = elementRef;
|
|
16
16
|
this.placeholder = "";
|
|
17
17
|
this.type = "text";
|
|
18
|
+
this.digitsOnly = false;
|
|
18
19
|
this.showClearButton = undefined;
|
|
19
20
|
this.showPlaceholderOnFocus = true;
|
|
20
21
|
this.hasOwnLabel = true;
|
|
@@ -47,28 +48,35 @@ export class InputTextComponent extends BaseInputComponent {
|
|
|
47
48
|
get hasRightIcon() {
|
|
48
49
|
return this.rightIcon !== undefined && this.rightIcon !== null;
|
|
49
50
|
}
|
|
51
|
+
// exclude some non-digit characters, since input type 'number' still allows the characters -, + and e
|
|
52
|
+
excludeNonDigitChars(event) {
|
|
53
|
+
const excludedKeyCodes = [69, 107, 109, 187, 189];
|
|
54
|
+
return !excludedKeyCodes.includes(event.keyCode);
|
|
55
|
+
}
|
|
50
56
|
}
|
|
51
57
|
InputTextComponent.decorators = [
|
|
52
58
|
{ type: Component, args: [{
|
|
53
59
|
selector: "co-input-text",
|
|
54
60
|
template: `
|
|
55
|
-
<label *ngIf="showPlaceholderOnFocus || (!showPlaceholderOnFocus && !hasValue && !focused)"
|
|
61
|
+
<label *ngIf="showPlaceholderOnFocus || (!showPlaceholderOnFocus && !hasValue && !focused)"
|
|
62
|
+
[textContent]="placeholder"></label>
|
|
56
63
|
<co-icon *ngIf="leftIcon" class="input-text-left-icon" [icon]="leftIcon"></co-icon>
|
|
57
64
|
<co-icon *ngIf="rightIcon" class="input-text-right-icon" [icon]="rightIcon"></co-icon>
|
|
58
65
|
<input #input
|
|
59
|
-
[type]="type"
|
|
66
|
+
[type]="digitsOnly ? 'number' : type"
|
|
60
67
|
[ngModel]="model"
|
|
61
68
|
[min]="type === 'number' && this.min ? this.min : undefined"
|
|
62
69
|
[max]="type === 'number' && this.max ? this.max : undefined"
|
|
63
70
|
[readonly]="readonly"
|
|
64
71
|
[required]="required"
|
|
65
72
|
(ngModelChange)="modelChange.emit($event)"
|
|
73
|
+
(keydown)="digitsOnly ? excludeNonDigitChars($event) : true"
|
|
66
74
|
>
|
|
67
75
|
<co-commit-buttons *ngIf="showSaveCancel && focused && canSaveOrCancel"
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
76
|
+
[committing]="committing"
|
|
77
|
+
[commitFinished]="commitFinished"
|
|
78
|
+
(commitClick)="commitClick($event)"
|
|
79
|
+
(cancelClick)="cancelClick($event)"
|
|
72
80
|
>
|
|
73
81
|
</co-commit-buttons>
|
|
74
82
|
<div class="required-indicator"></div>
|
|
@@ -97,6 +105,7 @@ InputTextComponent.propDecorators = {
|
|
|
97
105
|
type: [{ type: Input }],
|
|
98
106
|
min: [{ type: Input }],
|
|
99
107
|
max: [{ type: Input }],
|
|
108
|
+
digitsOnly: [{ type: Input }],
|
|
100
109
|
showClearButton: [{ type: Input }],
|
|
101
110
|
keyDownWhiteList: [{ type: Input }],
|
|
102
111
|
showPlaceholderOnFocus: [{ type: Input }],
|
|
@@ -109,4 +118,4 @@ InputTextComponent.propDecorators = {
|
|
|
109
118
|
hideArrowButtons: [{ type: Input }, { type: HostBinding, args: ['class.hideArrows',] }],
|
|
110
119
|
isSmall: [{ type: HostBinding, args: ['class.is-small',] }, { type: Input }]
|
|
111
120
|
};
|
|
112
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-text.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/input-text/input-text.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,iBAAiB,EACjB,SAAS,EACT,wBAAwB,EACxB,UAAU,EACV,UAAU,EACV,WAAW,EACX,KAAK,EACL,QAAQ,EACR,iBAAiB,EAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,kBAAkB,EAAC,MAAM,8BAA8B,CAAC;AAChE,OAAO,EAAC,wBAAwB,EAAC,MAAM,kCAAkC,CAAC;AAG1E,OAAO,EAAC,uCAAuC,EAAC,MAAM,4DAA4D,CAAC;AACnH,OAAO,EAAC,oBAAoB,EAAC,MAAM,4CAA4C,CAAC;AAChF,OAAO,EAAC,aAAa,EAAC,MAAM,wBAAwB,CAAC;AAqCrD,MAAM,OAAO,kBAAmB,SAAQ,kBAAuB;IAuE7D,YACqB,aAA4B,EACrC,cAAiC,EACjC,wBAAkD,EAClD,sBAAgE,EAChE,aAAoC,EACvC,UAAuB;QAE9B,KAAK,CAAC,cAAc,EAAE,wBAAwB,EAAE,sBAAsB,EAAE,aAAa,EAAE,UAAU,CAAC,CAAC;QAPhF,kBAAa,GAAb,aAAa,CAAe;QACrC,mBAAc,GAAd,cAAc,CAAmB;QACjC,6BAAwB,GAAxB,wBAAwB,CAA0B;QAClD,2BAAsB,GAAtB,sBAAsB,CAA0C;QAChE,kBAAa,GAAb,aAAa,CAAuB;QACvC,eAAU,GAAV,UAAU,CAAa;QA1EzB,gBAAW,GAAW,EAAE,CAAC;QAGzB,SAAI,GAAW,MAAM,CAAC;QAStB,oBAAe,GAAY,SAAS,CAAC;QAMrC,2BAAsB,GAAY,IAAI,CAAC;QAwCvC,gBAAW,GAAY,IAAI,CAAC;QAI5B,qBAAgB,GAAY,KAAK,CAAC;QAIlC,YAAO,GAAY,KAAK,CAAC;QAW9B,KAAK,CAAC,aAAa,EAAE,CAAC;IACxB,CAAC;IApDD,IAAW,KAAK,CAAC,KAAU;QACzB,IAAI,IAAI,CAAC,IAAI,KAAK,QAAQ,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE;YAC3C,IAAI,IAAI,CAAC,GAAG,IAAI,KAAK,GAAG,IAAI,CAAC,GAAG,IAAI,IAAI,CAAC,GAAG,IAAI,KAAK,GAAG,IAAI,CAAC,GAAG,EAAE;gBAChE,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC;aAClC;iBAAM;gBACL,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC;aACrB;SACF;aAAM;YACL,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC;SACrB;IACH,CAAC;IAED,IAAW,KAAK;QACd,OAAO,KAAK,CAAC,KAAK,CAAC;IACrB,CAAC;IAGM,SAAS;QACd,OAAO,IAAI,CAAC;IACd,CAAC;IAED,IACW,WAAW;QACpB,OAAO,IAAI,CAAC,QAAQ,KAAK,SAAS,IAAI,IAAI,CAAC,QAAQ,KAAK,IAAI,CAAC;IAC/D,CAAC;IAED,IACW,YAAY;QACrB,OAAO,IAAI,CAAC,SAAS,KAAK,SAAS,IAAI,IAAI,CAAC,SAAS,KAAK,IAAI,CAAC;IACjE,CAAC;;;YA5FF,SAAS,SAAC;gBACT,QAAQ,EAAE,eAAe;gBACzB,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;GAsBT;gBACD,SAAS,EAAE,CAAC;wBACV,OAAO,EAAE,wBAAwB;wBACjC,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,kBAAkB,CAAC;qBAClD,EAAE;wBACD,OAAO,EAAE,kBAAkB;wBAC3B,WAAW,EAAE,kBAAkB;qBAChC,CAAC;gBACF,aAAa,EAAE,iBAAiB,CAAC,IAAI;aACtC;;;YApCO,aAAa,uBA6GhB,QAAQ;YA7HX,iBAAiB;YAEjB,wBAAwB;YAYlB,uCAAuC;YACvC,oBAAoB;YAZ1B,UAAU;;;0BAoDT,KAAK;mBAGL,KAAK;kBAGL,KAAK;kBAGL,KAAK;8BAGL,KAAK;+BAGL,KAAK;qCAGL,KAAK;uBAGL,KAAK;wBAGL,KAAK;wBAmBL,WAAW,SAAC,qBAAqB;0BAKjC,WAAW,SAAC,qBAAqB;2BAKjC,WAAW,SAAC,sBAAsB;0BAKlC,WAAW,SAAC,qBAAqB;+BAGjC,KAAK,YACL,WAAW,SAAC,kBAAkB;sBAG9B,WAAW,SAAC,gBAAgB,cAC5B,KAAK","sourcesContent":["import {\r\n  AfterViewInit,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ComponentFactoryResolver,\r\n  ElementRef,\r\n  forwardRef,\r\n  HostBinding,\r\n  Input,\r\n  Optional,\r\n  ViewEncapsulation\r\n} from \"@angular/core\";\r\nimport {BaseInputComponent} from \"../base/base-input.component\";\r\nimport {COMPONENT_INTERFACE_NAME} from \"../base/component-interface-name\";\r\nimport {CoreComponentsIcon} from \"../../core/enum/core-components-icon.enum\";\r\nimport {KeyboardCode} from \"../../core/enum/keyboard-code.enum\";\r\nimport {FormInputUserModelChangeListenerService} from \"../../core/service/form-input-user-change-listener.service\";\r\nimport {NgZoneWrapperService} from \"../../core/service/ng-zone-wrapper.service\";\r\nimport {FormComponent} from \"../form/form.component\";\r\nimport {animate, state, style, transition, trigger} from \"@angular/animations\";\r\n\r\n@Component({\r\n  selector: \"co-input-text\",\r\n  template: `\r\n    <label *ngIf=\"showPlaceholderOnFocus || (!showPlaceholderOnFocus && !hasValue && !focused)\" [textContent]=\"placeholder\"></label>\r\n    <co-icon *ngIf=\"leftIcon\" class=\"input-text-left-icon\" [icon]=\"leftIcon\"></co-icon>\r\n    <co-icon *ngIf=\"rightIcon\" class=\"input-text-right-icon\" [icon]=\"rightIcon\"></co-icon>\r\n    <input #input\r\n           [type]=\"type\"\r\n           [ngModel]=\"model\"\r\n           [min]=\"type === 'number' && this.min ? this.min : undefined\"\r\n           [max]=\"type === 'number' && this.max ? this.max : undefined\"\r\n           [readonly]=\"readonly\"\r\n           [required]=\"required\"\r\n           (ngModelChange)=\"modelChange.emit($event)\"\r\n    >\r\n    <co-commit-buttons *ngIf=\"showSaveCancel && focused && canSaveOrCancel\"\r\n      [committing]=\"committing\"\r\n      [commitFinished]=\"commitFinished\"\r\n      (commitClick)=\"commitClick($event)\"\r\n      (cancelClick)=\"cancelClick($event)\"\r\n    >\r\n    </co-commit-buttons>\r\n    <div class=\"required-indicator\"></div>\r\n    <ng-template #validationError></ng-template>\r\n  `,\r\n  providers: [{\r\n    provide: COMPONENT_INTERFACE_NAME,\r\n    useExisting: forwardRef(() => InputTextComponent)\r\n  }, {\r\n    provide: BaseInputComponent,\r\n    useExisting: InputTextComponent\r\n  }],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class InputTextComponent extends BaseInputComponent<any> implements AfterViewInit {\r\n\r\n  @Input()\r\n  public placeholder: string = \"\";\r\n\r\n  @Input()\r\n  public type: string = \"text\";\r\n\r\n  @Input()\r\n  public min: number;\r\n\r\n  @Input()\r\n  public max: number;\r\n\r\n  @Input()\r\n  public showClearButton: boolean = undefined;\r\n\r\n  @Input()\r\n  public keyDownWhiteList: KeyboardCode[];\r\n\r\n  @Input()\r\n  public showPlaceholderOnFocus: boolean = true;\r\n\r\n  @Input()\r\n  public leftIcon: CoreComponentsIcon;\r\n\r\n  @Input()\r\n  public rightIcon: CoreComponentsIcon;\r\n\r\n  public set model(value: any) {\r\n    if (this.type === 'number' && !isNaN(value)) {\r\n      if (this.min && value < this.min || this.max && value > this.max) {\r\n        super.model = this._initialModel;\r\n      } else {\r\n        super.model = value;\r\n      }\r\n    } else {\r\n      super.model = value;\r\n    }\r\n  }\r\n\r\n  public get model() {\r\n    return super.model;\r\n  }\r\n\r\n  @HostBinding(\"class.co-input-text\")\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  @HostBinding('class.has-left-icon')\r\n  public get hasLeftIcon(): boolean {\r\n    return this.leftIcon !== undefined && this.leftIcon !== null;\r\n  }\r\n\r\n  @HostBinding('class.has-right-icon')\r\n  public get hasRightIcon(): boolean {\r\n    return this.rightIcon !== undefined && this.rightIcon !== null;\r\n  }\r\n\r\n  @HostBinding(\"class.has-own-label\")\r\n  public hasOwnLabel: boolean = true;\r\n\r\n  @Input()\r\n  @HostBinding('class.hideArrows')\r\n  public hideArrowButtons: boolean = false;\r\n\r\n  @HostBinding('class.is-small')\r\n  @Input()\r\n  public isSmall: boolean = false;\r\n\r\n  constructor(\r\n    @Optional() public formComponent: FormComponent,\r\n    protected changeDetector: ChangeDetectorRef,\r\n    protected componentFactoryResolver: ComponentFactoryResolver,\r\n    protected formUserChangeListener?: FormInputUserModelChangeListenerService,\r\n    protected ngZoneWrapper?: NgZoneWrapperService,\r\n    public elementRef?: ElementRef,\r\n  ) {\r\n    super(changeDetector, componentFactoryResolver, formUserChangeListener, ngZoneWrapper, elementRef);\r\n    super._markAsOnPush();\r\n  }\r\n}\r\n"]}
|
|
121
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-text.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/input-text/input-text.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ComponentFactoryResolver,\r\n  ElementRef,\r\n  forwardRef,\r\n  HostBinding,\r\n  Input,\r\n  Optional,\r\n  ViewEncapsulation\r\n} from \"@angular/core\";\r\nimport {BaseInputComponent} from \"../base/base-input.component\";\r\nimport {COMPONENT_INTERFACE_NAME} from \"../base/component-interface-name\";\r\nimport {CoreComponentsIcon} from \"../../core/enum/core-components-icon.enum\";\r\nimport {KeyboardCode} from \"../../core/enum/keyboard-code.enum\";\r\nimport {FormInputUserModelChangeListenerService} from \"../../core/service/form-input-user-change-listener.service\";\r\nimport {NgZoneWrapperService} from \"../../core/service/ng-zone-wrapper.service\";\r\nimport {FormComponent} from \"../form/form.component\";\r\nimport {animate, state, style, transition, trigger} from \"@angular/animations\";\r\n\r\n@Component({\r\n  selector: \"co-input-text\",\r\n  template: `\r\n    <label *ngIf=\"showPlaceholderOnFocus || (!showPlaceholderOnFocus && !hasValue && !focused)\"\r\n           [textContent]=\"placeholder\"></label>\r\n    <co-icon *ngIf=\"leftIcon\" class=\"input-text-left-icon\" [icon]=\"leftIcon\"></co-icon>\r\n    <co-icon *ngIf=\"rightIcon\" class=\"input-text-right-icon\" [icon]=\"rightIcon\"></co-icon>\r\n    <input #input\r\n           [type]=\"digitsOnly ? 'number' : type\"\r\n           [ngModel]=\"model\"\r\n           [min]=\"type === 'number' && this.min ? this.min : undefined\"\r\n           [max]=\"type === 'number' && this.max ? this.max : undefined\"\r\n           [readonly]=\"readonly\"\r\n           [required]=\"required\"\r\n           (ngModelChange)=\"modelChange.emit($event)\"\r\n           (keydown)=\"digitsOnly ? excludeNonDigitChars($event) : true\"\r\n    >\r\n    <co-commit-buttons *ngIf=\"showSaveCancel && focused && canSaveOrCancel\"\r\n                       [committing]=\"committing\"\r\n                       [commitFinished]=\"commitFinished\"\r\n                       (commitClick)=\"commitClick($event)\"\r\n                       (cancelClick)=\"cancelClick($event)\"\r\n    >\r\n    </co-commit-buttons>\r\n    <div class=\"required-indicator\"></div>\r\n    <ng-template #validationError></ng-template>\r\n  `,\r\n  providers: [{\r\n    provide: COMPONENT_INTERFACE_NAME,\r\n    useExisting: forwardRef(() => InputTextComponent)\r\n  }, {\r\n    provide: BaseInputComponent,\r\n    useExisting: InputTextComponent\r\n  }],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class InputTextComponent extends BaseInputComponent<any> implements AfterViewInit {\r\n\r\n  @Input()\r\n  public placeholder: string = \"\";\r\n\r\n  @Input()\r\n  public type: string = \"text\";\r\n\r\n  @Input()\r\n  public min: number;\r\n\r\n  @Input()\r\n  public max: number;\r\n\r\n  @Input()\r\n  public digitsOnly: boolean = false;\r\n\r\n  @Input()\r\n  public showClearButton: boolean = undefined;\r\n\r\n  @Input()\r\n  public keyDownWhiteList: KeyboardCode[];\r\n\r\n  @Input()\r\n  public showPlaceholderOnFocus: boolean = true;\r\n\r\n  @Input()\r\n  public leftIcon: CoreComponentsIcon;\r\n\r\n  @Input()\r\n  public rightIcon: CoreComponentsIcon;\r\n\r\n  public set model(value: any) {\r\n    if (this.type === 'number' && !isNaN(value)) {\r\n      if (this.min && value < this.min || this.max && value > this.max) {\r\n        super.model = this._initialModel;\r\n      } else {\r\n        super.model = value;\r\n      }\r\n    } else {\r\n      super.model = value;\r\n    }\r\n  }\r\n\r\n  public get model() {\r\n    return super.model;\r\n  }\r\n\r\n  @HostBinding(\"class.co-input-text\")\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  @HostBinding('class.has-left-icon')\r\n  public get hasLeftIcon(): boolean {\r\n    return this.leftIcon !== undefined && this.leftIcon !== null;\r\n  }\r\n\r\n  @HostBinding('class.has-right-icon')\r\n  public get hasRightIcon(): boolean {\r\n    return this.rightIcon !== undefined && this.rightIcon !== null;\r\n  }\r\n\r\n  @HostBinding(\"class.has-own-label\")\r\n  public hasOwnLabel: boolean = true;\r\n\r\n  @Input()\r\n  @HostBinding('class.hideArrows')\r\n  public hideArrowButtons: boolean = false;\r\n\r\n  @HostBinding('class.is-small')\r\n  @Input()\r\n  public isSmall: boolean = false;\r\n\r\n  constructor(\r\n    @Optional() public formComponent: FormComponent,\r\n    protected changeDetector: ChangeDetectorRef,\r\n    protected componentFactoryResolver: ComponentFactoryResolver,\r\n    protected formUserChangeListener?: FormInputUserModelChangeListenerService,\r\n    protected ngZoneWrapper?: NgZoneWrapperService,\r\n    public elementRef?: ElementRef,\r\n  ) {\r\n    super(changeDetector, componentFactoryResolver, formUserChangeListener, ngZoneWrapper, elementRef);\r\n    super._markAsOnPush();\r\n  }\r\n\r\n  // exclude some non-digit characters, since input type 'number' still allows the characters -, + and e\r\n  public excludeNonDigitChars(event): boolean {\r\n    const excludedKeyCodes = [69, 107, 109, 187, 189];\r\n    return !excludedKeyCodes.includes(event.keyCode)\r\n  }\r\n}\r\n"]}
|
|
@@ -7193,6 +7193,7 @@ class InputTextComponent extends BaseInputComponent {
|
|
|
7193
7193
|
this.elementRef = elementRef;
|
|
7194
7194
|
this.placeholder = "";
|
|
7195
7195
|
this.type = "text";
|
|
7196
|
+
this.digitsOnly = false;
|
|
7196
7197
|
this.showClearButton = undefined;
|
|
7197
7198
|
this.showPlaceholderOnFocus = true;
|
|
7198
7199
|
this.hasOwnLabel = true;
|
|
@@ -7225,28 +7226,35 @@ class InputTextComponent extends BaseInputComponent {
|
|
|
7225
7226
|
get hasRightIcon() {
|
|
7226
7227
|
return this.rightIcon !== undefined && this.rightIcon !== null;
|
|
7227
7228
|
}
|
|
7229
|
+
// exclude some non-digit characters, since input type 'number' still allows the characters -, + and e
|
|
7230
|
+
excludeNonDigitChars(event) {
|
|
7231
|
+
const excludedKeyCodes = [69, 107, 109, 187, 189];
|
|
7232
|
+
return !excludedKeyCodes.includes(event.keyCode);
|
|
7233
|
+
}
|
|
7228
7234
|
}
|
|
7229
7235
|
InputTextComponent.decorators = [
|
|
7230
7236
|
{ type: Component, args: [{
|
|
7231
7237
|
selector: "co-input-text",
|
|
7232
7238
|
template: `
|
|
7233
|
-
<label *ngIf="showPlaceholderOnFocus || (!showPlaceholderOnFocus && !hasValue && !focused)"
|
|
7239
|
+
<label *ngIf="showPlaceholderOnFocus || (!showPlaceholderOnFocus && !hasValue && !focused)"
|
|
7240
|
+
[textContent]="placeholder"></label>
|
|
7234
7241
|
<co-icon *ngIf="leftIcon" class="input-text-left-icon" [icon]="leftIcon"></co-icon>
|
|
7235
7242
|
<co-icon *ngIf="rightIcon" class="input-text-right-icon" [icon]="rightIcon"></co-icon>
|
|
7236
7243
|
<input #input
|
|
7237
|
-
[type]="type"
|
|
7244
|
+
[type]="digitsOnly ? 'number' : type"
|
|
7238
7245
|
[ngModel]="model"
|
|
7239
7246
|
[min]="type === 'number' && this.min ? this.min : undefined"
|
|
7240
7247
|
[max]="type === 'number' && this.max ? this.max : undefined"
|
|
7241
7248
|
[readonly]="readonly"
|
|
7242
7249
|
[required]="required"
|
|
7243
7250
|
(ngModelChange)="modelChange.emit($event)"
|
|
7251
|
+
(keydown)="digitsOnly ? excludeNonDigitChars($event) : true"
|
|
7244
7252
|
>
|
|
7245
7253
|
<co-commit-buttons *ngIf="showSaveCancel && focused && canSaveOrCancel"
|
|
7246
|
-
|
|
7247
|
-
|
|
7248
|
-
|
|
7249
|
-
|
|
7254
|
+
[committing]="committing"
|
|
7255
|
+
[commitFinished]="commitFinished"
|
|
7256
|
+
(commitClick)="commitClick($event)"
|
|
7257
|
+
(cancelClick)="cancelClick($event)"
|
|
7250
7258
|
>
|
|
7251
7259
|
</co-commit-buttons>
|
|
7252
7260
|
<div class="required-indicator"></div>
|
|
@@ -7275,6 +7283,7 @@ InputTextComponent.propDecorators = {
|
|
|
7275
7283
|
type: [{ type: Input }],
|
|
7276
7284
|
min: [{ type: Input }],
|
|
7277
7285
|
max: [{ type: Input }],
|
|
7286
|
+
digitsOnly: [{ type: Input }],
|
|
7278
7287
|
showClearButton: [{ type: Input }],
|
|
7279
7288
|
keyDownWhiteList: [{ type: Input }],
|
|
7280
7289
|
showPlaceholderOnFocus: [{ type: Input }],
|