@colijnit/corecomponents_v12 12.0.95 → 12.0.96

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.
@@ -6,10 +6,21 @@ export class IconComponent {
6
6
  this.showClass = true;
7
7
  }
8
8
  set icon(value) {
9
- this._setIconFromEnum(value);
9
+ this._icon = value;
10
+ }
11
+ ngOnInit() {
12
+ this._prepareIcon();
13
+ }
14
+ _prepareIcon() {
15
+ if (this.iconData) {
16
+ this.innerIconData = this.iconData;
17
+ }
18
+ else if (this._icon) {
19
+ this._setIconFromEnum(this._icon);
20
+ }
10
21
  }
11
22
  _setIconFromEnum(icon) {
12
- this.iconData = this._iconCache.getIcon(icon);
23
+ this.innerIconData = this._iconCache.getIcon(icon);
13
24
  }
14
25
  }
15
26
  IconComponent.decorators = [
@@ -24,7 +35,8 @@ IconComponent.ctorParameters = () => [
24
35
  ];
25
36
  IconComponent.propDecorators = {
26
37
  icon: [{ type: Input }],
27
- iconData: [{ type: Input }, { type: HostBinding, args: ["innerHtml",] }],
28
- showClass: [{ type: HostBinding, args: ["class.co-icon",] }]
38
+ iconData: [{ type: Input }],
39
+ showClass: [{ type: HostBinding, args: ['class.co-icon',] }],
40
+ innerIconData: [{ type: HostBinding, args: ['innerHtml',] }]
29
41
  };
30
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWNvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvaWNvbi9pY29uLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLFdBQVcsRUFBRSxLQUFLLEVBQUUsaUJBQWlCLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFHL0UsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sc0JBQXNCLENBQUM7QUFRdEQsTUFBTSxPQUFPLGFBQWE7SUFjdEIsWUFBb0IsVUFBNEI7UUFBNUIsZUFBVSxHQUFWLFVBQVUsQ0FBa0I7UUFGekMsY0FBUyxHQUFZLElBQUksQ0FBQztJQUdqQyxDQUFDO0lBYkQsSUFDVyxJQUFJLENBQUMsS0FBeUI7UUFDckMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2pDLENBQUM7SUFZTyxnQkFBZ0IsQ0FBQyxJQUF3QjtRQUM3QyxJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ2xELENBQUM7OztZQXpCSixTQUFTLFNBQUM7Z0JBQ1QsUUFBUSxFQUFFLFNBQVM7Z0JBQ25CLFFBQVEsRUFBRSxFQUFFO2dCQUVaLGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO2FBQ3RDOzs7WUFQTyxnQkFBZ0I7OzttQkFVbkIsS0FBSzt1QkFLTCxLQUFLLFlBQ0wsV0FBVyxTQUFDLFdBQVc7d0JBR3ZCLFdBQVcsU0FBQyxlQUFlIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDb21wb25lbnQsIEhvc3RCaW5kaW5nLCBJbnB1dCwgVmlld0VuY2Fwc3VsYXRpb259IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQge1NhZmVIdG1sfSBmcm9tICdAYW5ndWxhci9wbGF0Zm9ybS1icm93c2VyJztcclxuaW1wb3J0IHtDb3JlQ29tcG9uZW50c0ljb259IGZyb20gJy4uLy4uL2NvcmUvZW51bS9jb3JlLWNvbXBvbmVudHMtaWNvbi5lbnVtJztcclxuaW1wb3J0IHtJY29uQ2FjaGVTZXJ2aWNlfSBmcm9tICcuL2ljb24tY2FjaGUuc2VydmljZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2NvLWljb24nLFxyXG4gIHRlbXBsYXRlOiAnJ1xyXG4gICxcclxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBJY29uQ29tcG9uZW50IHtcclxuXHJcbiAgICBASW5wdXQoKVxyXG4gICAgcHVibGljIHNldCBpY29uKHZhbHVlOiBDb3JlQ29tcG9uZW50c0ljb24pIHtcclxuICAgICAgICB0aGlzLl9zZXRJY29uRnJvbUVudW0odmFsdWUpO1xyXG4gICAgfVxyXG5cclxuICAgIEBJbnB1dCgpXHJcbiAgICBASG9zdEJpbmRpbmcoXCJpbm5lckh0bWxcIilcclxuICAgIHB1YmxpYyBpY29uRGF0YTogU2FmZUh0bWwgfCB1bmRlZmluZWQ7XHJcblxyXG4gICAgQEhvc3RCaW5kaW5nKFwiY2xhc3MuY28taWNvblwiKVxyXG4gICAgcHVibGljIHNob3dDbGFzczogYm9vbGVhbiA9IHRydWU7XHJcblxyXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBfaWNvbkNhY2hlOiBJY29uQ2FjaGVTZXJ2aWNlKSB7XHJcbiAgICB9XHJcblxyXG4gICAgcHJpdmF0ZSBfc2V0SWNvbkZyb21FbnVtKGljb246IENvcmVDb21wb25lbnRzSWNvbik6IHZvaWQge1xyXG4gICAgICAgIHRoaXMuaWNvbkRhdGEgPSB0aGlzLl9pY29uQ2FjaGUuZ2V0SWNvbihpY29uKTtcclxuICAgIH1cclxufVxyXG4iXX0=
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWNvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvaWNvbi9pY29uLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLFdBQVcsRUFBRSxLQUFLLEVBQVUsaUJBQWlCLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFHdkYsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sc0JBQXNCLENBQUM7QUFRdEQsTUFBTSxPQUFPLGFBQWE7SUFrQnhCLFlBQW9CLFVBQTRCO1FBQTVCLGVBQVUsR0FBVixVQUFVLENBQWtCO1FBUHpDLGNBQVMsR0FBWSxJQUFJLENBQUM7SUFRakMsQ0FBQztJQWpCRCxJQUNXLElBQUksQ0FBQyxLQUF5QjtRQUN2QyxJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztJQUNyQixDQUFDO0lBZ0JELFFBQVE7UUFDTixJQUFJLENBQUMsWUFBWSxFQUFFLENBQUM7SUFDdEIsQ0FBQztJQUVPLFlBQVk7UUFDbEIsSUFBSSxJQUFJLENBQUMsUUFBUSxFQUFFO1lBQ2pCLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQztTQUNwQzthQUFNLElBQUksSUFBSSxDQUFDLEtBQUssRUFBRTtZQUNyQixJQUFJLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1NBQ25DO0lBQ0gsQ0FBQztJQUVPLGdCQUFnQixDQUFDLElBQXdCO1FBQy9DLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDckQsQ0FBQzs7O1lBekNGLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsU0FBUztnQkFDbkIsUUFBUSxFQUFFLEVBQUU7Z0JBRVosYUFBYSxFQUFFLGlCQUFpQixDQUFDLElBQUk7YUFDdEM7OztZQVBPLGdCQUFnQjs7O21CQVVyQixLQUFLO3VCQUtMLEtBQUs7d0JBR0wsV0FBVyxTQUFDLGVBQWU7NEJBRzNCLFdBQVcsU0FBQyxXQUFXIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDb21wb25lbnQsIEhvc3RCaW5kaW5nLCBJbnB1dCwgT25Jbml0LCBWaWV3RW5jYXBzdWxhdGlvbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7U2FmZUh0bWx9IGZyb20gJ0Bhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXInO1xyXG5pbXBvcnQge0NvcmVDb21wb25lbnRzSWNvbn0gZnJvbSAnLi4vLi4vY29yZS9lbnVtL2NvcmUtY29tcG9uZW50cy1pY29uLmVudW0nO1xyXG5pbXBvcnQge0ljb25DYWNoZVNlcnZpY2V9IGZyb20gJy4vaWNvbi1jYWNoZS5zZXJ2aWNlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnY28taWNvbicsXHJcbiAgdGVtcGxhdGU6ICcnXHJcbiAgLFxyXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmVcclxufSlcclxuZXhwb3J0IGNsYXNzIEljb25Db21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBzZXQgaWNvbih2YWx1ZTogQ29yZUNvbXBvbmVudHNJY29uKSB7XHJcbiAgICB0aGlzLl9pY29uID0gdmFsdWU7XHJcbiAgfVxyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBpY29uRGF0YTogU2FmZUh0bWwgfCB1bmRlZmluZWQ7XHJcblxyXG4gIEBIb3N0QmluZGluZygnY2xhc3MuY28taWNvbicpXHJcbiAgcHVibGljIHNob3dDbGFzczogYm9vbGVhbiA9IHRydWU7XHJcblxyXG4gIEBIb3N0QmluZGluZygnaW5uZXJIdG1sJylcclxuICBwdWJsaWMgaW5uZXJJY29uRGF0YTogU2FmZUh0bWwgfCB1bmRlZmluZWQ7XHJcblxyXG4gIHByaXZhdGUgX2ljb246IENvcmVDb21wb25lbnRzSWNvbjtcclxuXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBfaWNvbkNhY2hlOiBJY29uQ2FjaGVTZXJ2aWNlKSB7XHJcbiAgfVxyXG5cclxuICBuZ09uSW5pdCgpIHtcclxuICAgIHRoaXMuX3ByZXBhcmVJY29uKCk7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIF9wcmVwYXJlSWNvbigpOiB2b2lkIHtcclxuICAgIGlmICh0aGlzLmljb25EYXRhKSB7XHJcbiAgICAgIHRoaXMuaW5uZXJJY29uRGF0YSA9IHRoaXMuaWNvbkRhdGE7XHJcbiAgICB9IGVsc2UgaWYgKHRoaXMuX2ljb24pIHtcclxuICAgICAgdGhpcy5fc2V0SWNvbkZyb21FbnVtKHRoaXMuX2ljb24pO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgcHJpdmF0ZSBfc2V0SWNvbkZyb21FbnVtKGljb246IENvcmVDb21wb25lbnRzSWNvbik6IHZvaWQge1xyXG4gICAgdGhpcy5pbm5lckljb25EYXRhID0gdGhpcy5faWNvbkNhY2hlLmdldEljb24oaWNvbik7XHJcbiAgfVxyXG59XHJcbiJdfQ==
@@ -8,6 +8,8 @@ export class InputSearchComponent extends BaseInputComponent {
8
8
  super(...arguments);
9
9
  this.searchIcon = CoreComponentsIcon.Magnifier;
10
10
  this.search = new EventEmitter();
11
+ this.leftIconClick = new EventEmitter();
12
+ this.rightIconClick = new EventEmitter();
11
13
  this.useLeftIcon = false;
12
14
  this.useRightIcon = false;
13
15
  this.centerLabel = false;
@@ -33,10 +35,14 @@ InputSearchComponent.decorators = [
33
35
  [model]="model"
34
36
  [leftIcon]="useLeftIcon ? searchIcon : null"
35
37
  [rightIcon]="useRightIcon ? searchIcon : null"
38
+ [leftIconData]="useLeftIcon && leftIconData ? leftIconData : undefined"
39
+ [rightIconData]="useRightIcon && rightIconData ? rightIconData : undefined"
36
40
  [placeholder]="placeholder"
37
41
  [customHeight]="true"
38
42
  [showPlaceholderOnFocus]="false"
39
43
  (modelChange)="modelChange.emit($event)"
44
+ (leftIconClick)="leftIconClick.emit($event)"
45
+ (rightIconClick)="rightIconClick.emit($event)"
40
46
  ></co-input-text>
41
47
  `,
42
48
  changeDetection: ChangeDetectionStrategy.OnPush,
@@ -46,8 +52,12 @@ InputSearchComponent.decorators = [
46
52
  InputSearchComponent.propDecorators = {
47
53
  placeholder: [{ type: Input }],
48
54
  search: [{ type: Output }],
55
+ leftIconClick: [{ type: Output }],
56
+ rightIconClick: [{ type: Output }],
49
57
  useLeftIcon: [{ type: Input }],
50
58
  useRightIcon: [{ type: Input }],
59
+ leftIconData: [{ type: Input }],
60
+ rightIconData: [{ type: Input }],
51
61
  centerLabel: [{ type: HostBinding, args: ['class.center-label',] }, { type: Input }],
52
62
  showClass: [{ type: HostBinding, args: ['class.co-input-search',] }]
53
63
  };
@@ -57,4 +67,4 @@ __decorate([
57
67
  __decorate([
58
68
  InputBoolean()
59
69
  ], InputSearchComponent.prototype, "useRightIcon", void 0);
60
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtc2VhcmNoLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmVjb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9pbnB1dC1zZWFyY2gvaW5wdXQtc2VhcmNoLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUNMLHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsWUFBWSxFQUNaLFdBQVcsRUFFWCxLQUFLLEVBRUwsTUFBTSxFQUNOLGlCQUFpQixFQUNsQixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSwyQ0FBMkMsQ0FBQztBQUM3RSxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSw4QkFBOEIsQ0FBQztBQUNoRSxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0sOENBQThDLENBQUM7QUFrQjFFLE1BQU0sT0FBTyxvQkFBcUIsU0FBUSxrQkFBMEI7SUFoQnBFOztRQWtCa0IsZUFBVSxHQUF1QixrQkFBa0IsQ0FBQyxTQUFTLENBQUM7UUFNdkUsV0FBTSxHQUF5QixJQUFJLFlBQVksRUFBVSxDQUFDO1FBSTFELGdCQUFXLEdBQVksS0FBSyxDQUFDO1FBSTdCLGlCQUFZLEdBQVksS0FBSyxDQUFDO1FBSTlCLGdCQUFXLEdBQVksS0FBSyxDQUFDO0lBZ0J0QyxDQUFDO0lBYlEsU0FBUztRQUNkLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVNLGFBQWEsQ0FBQyxLQUFvQjtRQUN2QyxRQUFRLEtBQUssQ0FBQyxJQUFJLEVBQUU7WUFDbEIsS0FBSyxPQUFPLENBQUM7WUFDYixLQUFLLGFBQWE7Z0JBQ2hCLEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQztnQkFDdkIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO2dCQUM3QixPQUFPO1NBQ1Y7SUFDSCxDQUFDOzs7WUFuREYsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSxpQkFBaUI7Z0JBQzNCLFFBQVEsRUFBRTs7Ozs7Ozs7OztHQVVUO2dCQUNELGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO2dCQUMvQyxhQUFhLEVBQUUsaUJBQWlCLENBQUMsSUFBSTthQUN0Qzs7OzBCQUtFLEtBQUs7cUJBR0wsTUFBTTswQkFHTixLQUFLOzJCQUlMLEtBQUs7MEJBSUwsV0FBVyxTQUFDLG9CQUFvQixjQUNoQyxLQUFLO3dCQUdMLFdBQVcsU0FBQyx1QkFBdUI7O0FBVnBDO0lBREMsWUFBWSxFQUFFO3lEQUNxQjtBQUlwQztJQURDLFlBQVksRUFBRTswREFDc0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xyXG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxyXG4gIENvbXBvbmVudCxcclxuICBFdmVudEVtaXR0ZXIsXHJcbiAgSG9zdEJpbmRpbmcsXHJcbiAgSG9zdExpc3RlbmVyLFxyXG4gIElucHV0LFxyXG4gIE9uRGVzdHJveSxcclxuICBPdXRwdXQsXHJcbiAgVmlld0VuY2Fwc3VsYXRpb25cclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHtDb3JlQ29tcG9uZW50c0ljb259IGZyb20gJy4uLy4uL2NvcmUvZW51bS9jb3JlLWNvbXBvbmVudHMtaWNvbi5lbnVtJztcclxuaW1wb3J0IHtCYXNlSW5wdXRDb21wb25lbnR9IGZyb20gJy4uL2Jhc2UvYmFzZS1pbnB1dC5jb21wb25lbnQnO1xyXG5pbXBvcnQge0lucHV0Qm9vbGVhbn0gZnJvbSBcIi4uLy4uL2NvcmUvZGVjb3JhdG9yL2lucHV0LWJvb2xlYW4uZGVjb3JhdG9yXCI7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2NvLWlucHV0LXNlYXJjaCcsXHJcbiAgdGVtcGxhdGU6IGBcclxuICAgIDxjby1pbnB1dC10ZXh0XHJcbiAgICAgIFttb2RlbF09XCJtb2RlbFwiXHJcbiAgICAgIFtsZWZ0SWNvbl09XCJ1c2VMZWZ0SWNvbiA/IHNlYXJjaEljb24gOiBudWxsXCJcclxuICAgICAgW3JpZ2h0SWNvbl09XCJ1c2VSaWdodEljb24gPyBzZWFyY2hJY29uIDogbnVsbFwiXHJcbiAgICAgIFtwbGFjZWhvbGRlcl09XCJwbGFjZWhvbGRlclwiXHJcbiAgICAgIFtjdXN0b21IZWlnaHRdPVwidHJ1ZVwiXHJcbiAgICAgIFtzaG93UGxhY2Vob2xkZXJPbkZvY3VzXT1cImZhbHNlXCJcclxuICAgICAgKG1vZGVsQ2hhbmdlKT1cIm1vZGVsQ2hhbmdlLmVtaXQoJGV2ZW50KVwiXHJcbiAgICA+PC9jby1pbnB1dC10ZXh0PlxyXG4gIGAsXHJcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXHJcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZVxyXG59KVxyXG5leHBvcnQgY2xhc3MgSW5wdXRTZWFyY2hDb21wb25lbnQgZXh0ZW5kcyBCYXNlSW5wdXRDb21wb25lbnQ8c3RyaW5nPiBpbXBsZW1lbnRzIE9uRGVzdHJveSB7XHJcblxyXG4gIHB1YmxpYyByZWFkb25seSBzZWFyY2hJY29uOiBDb3JlQ29tcG9uZW50c0ljb24gPSBDb3JlQ29tcG9uZW50c0ljb24uTWFnbmlmaWVyO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBwbGFjZWhvbGRlcjogc3RyaW5nO1xyXG5cclxuICBAT3V0cHV0KClcclxuICBwdWJsaWMgc2VhcmNoOiBFdmVudEVtaXR0ZXI8c3RyaW5nPiA9IG5ldyBFdmVudEVtaXR0ZXI8c3RyaW5nPigpO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIEBJbnB1dEJvb2xlYW4oKVxyXG4gIHB1YmxpYyB1c2VMZWZ0SWNvbjogYm9vbGVhbiA9IGZhbHNlO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIEBJbnB1dEJvb2xlYW4oKVxyXG4gIHB1YmxpYyB1c2VSaWdodEljb246IGJvb2xlYW4gPSBmYWxzZTtcclxuXHJcbiAgQEhvc3RCaW5kaW5nKCdjbGFzcy5jZW50ZXItbGFiZWwnKVxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGNlbnRlckxhYmVsOiBib29sZWFuID0gZmFsc2U7XHJcblxyXG4gIEBIb3N0QmluZGluZygnY2xhc3MuY28taW5wdXQtc2VhcmNoJylcclxuICBwdWJsaWMgc2hvd0NsYXNzKCkge1xyXG4gICAgcmV0dXJuIHRydWU7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgaGFuZGxlS2V5RG93bihldmVudDogS2V5Ym9hcmRFdmVudCk6IHZvaWQge1xyXG4gICAgc3dpdGNoIChldmVudC5jb2RlKSB7XHJcbiAgICAgIGNhc2UgJ0VudGVyJzpcclxuICAgICAgY2FzZSAnTnVtcGFkRW50ZXInOlxyXG4gICAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XHJcbiAgICAgICAgdGhpcy5zZWFyY2gubmV4dCh0aGlzLm1vZGVsKTtcclxuICAgICAgICByZXR1cm47XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiJdfQ==
70
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtc2VhcmNoLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmVjb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9pbnB1dC1zZWFyY2gvaW5wdXQtc2VhcmNoLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUNMLHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsWUFBWSxFQUNaLFdBQVcsRUFFWCxLQUFLLEVBRUwsTUFBTSxFQUNOLGlCQUFpQixFQUNsQixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSwyQ0FBMkMsQ0FBQztBQUM3RSxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSw4QkFBOEIsQ0FBQztBQUNoRSxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0sOENBQThDLENBQUM7QUF1QjFFLE1BQU0sT0FBTyxvQkFBcUIsU0FBUSxrQkFBMEI7SUFwQnBFOztRQXNCa0IsZUFBVSxHQUF1QixrQkFBa0IsQ0FBQyxTQUFTLENBQUM7UUFNdkUsV0FBTSxHQUF5QixJQUFJLFlBQVksRUFBVSxDQUFDO1FBRzFELGtCQUFhLEdBQTZCLElBQUksWUFBWSxFQUFjLENBQUM7UUFHekUsbUJBQWMsR0FBNkIsSUFBSSxZQUFZLEVBQWMsQ0FBQztRQUkxRSxnQkFBVyxHQUFZLEtBQUssQ0FBQztRQUk3QixpQkFBWSxHQUFZLEtBQUssQ0FBQztRQVU5QixnQkFBVyxHQUFZLEtBQUssQ0FBQztJQWdCdEMsQ0FBQztJQWJRLFNBQVM7UUFDZCxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFFTSxhQUFhLENBQUMsS0FBb0I7UUFDdkMsUUFBUSxLQUFLLENBQUMsSUFBSSxFQUFFO1lBQ2xCLEtBQUssT0FBTyxDQUFDO1lBQ2IsS0FBSyxhQUFhO2dCQUNoQixLQUFLLENBQUMsY0FBYyxFQUFFLENBQUM7Z0JBQ3ZCLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztnQkFDN0IsT0FBTztTQUNWO0lBQ0gsQ0FBQzs7O1lBbkVGLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsaUJBQWlCO2dCQUMzQixRQUFRLEVBQUU7Ozs7Ozs7Ozs7Ozs7O0dBY1Q7Z0JBQ0QsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07Z0JBQy9DLGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO2FBQ3RDOzs7MEJBS0UsS0FBSztxQkFHTCxNQUFNOzRCQUdOLE1BQU07NkJBR04sTUFBTTswQkFHTixLQUFLOzJCQUlMLEtBQUs7MkJBSUwsS0FBSzs0QkFHTCxLQUFLOzBCQUdMLFdBQVcsU0FBQyxvQkFBb0IsY0FDaEMsS0FBSzt3QkFHTCxXQUFXLFNBQUMsdUJBQXVCOztBQWhCcEM7SUFEQyxZQUFZLEVBQUU7eURBQ3FCO0FBSXBDO0lBREMsWUFBWSxFQUFFOzBEQUNzQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XHJcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXHJcbiAgQ29tcG9uZW50LFxyXG4gIEV2ZW50RW1pdHRlcixcclxuICBIb3N0QmluZGluZyxcclxuICBIb3N0TGlzdGVuZXIsXHJcbiAgSW5wdXQsXHJcbiAgT25EZXN0cm95LFxyXG4gIE91dHB1dCxcclxuICBWaWV3RW5jYXBzdWxhdGlvblxyXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQge0NvcmVDb21wb25lbnRzSWNvbn0gZnJvbSAnLi4vLi4vY29yZS9lbnVtL2NvcmUtY29tcG9uZW50cy1pY29uLmVudW0nO1xyXG5pbXBvcnQge0Jhc2VJbnB1dENvbXBvbmVudH0gZnJvbSAnLi4vYmFzZS9iYXNlLWlucHV0LmNvbXBvbmVudCc7XHJcbmltcG9ydCB7SW5wdXRCb29sZWFufSBmcm9tIFwiLi4vLi4vY29yZS9kZWNvcmF0b3IvaW5wdXQtYm9vbGVhbi5kZWNvcmF0b3JcIjtcclxuaW1wb3J0IHtTYWZlSHRtbH0gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlcic7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2NvLWlucHV0LXNlYXJjaCcsXHJcbiAgdGVtcGxhdGU6IGBcclxuICAgIDxjby1pbnB1dC10ZXh0XHJcbiAgICAgIFttb2RlbF09XCJtb2RlbFwiXHJcbiAgICAgIFtsZWZ0SWNvbl09XCJ1c2VMZWZ0SWNvbiA/IHNlYXJjaEljb24gOiBudWxsXCJcclxuICAgICAgW3JpZ2h0SWNvbl09XCJ1c2VSaWdodEljb24gPyBzZWFyY2hJY29uIDogbnVsbFwiXHJcbiAgICAgIFtsZWZ0SWNvbkRhdGFdPVwidXNlTGVmdEljb24gJiYgbGVmdEljb25EYXRhID8gbGVmdEljb25EYXRhIDogdW5kZWZpbmVkXCJcclxuICAgICAgW3JpZ2h0SWNvbkRhdGFdPVwidXNlUmlnaHRJY29uICYmIHJpZ2h0SWNvbkRhdGEgPyByaWdodEljb25EYXRhIDogdW5kZWZpbmVkXCJcclxuICAgICAgW3BsYWNlaG9sZGVyXT1cInBsYWNlaG9sZGVyXCJcclxuICAgICAgW2N1c3RvbUhlaWdodF09XCJ0cnVlXCJcclxuICAgICAgW3Nob3dQbGFjZWhvbGRlck9uRm9jdXNdPVwiZmFsc2VcIlxyXG4gICAgICAobW9kZWxDaGFuZ2UpPVwibW9kZWxDaGFuZ2UuZW1pdCgkZXZlbnQpXCJcclxuICAgICAgKGxlZnRJY29uQ2xpY2spPVwibGVmdEljb25DbGljay5lbWl0KCRldmVudClcIlxyXG4gICAgICAocmlnaHRJY29uQ2xpY2spPVwicmlnaHRJY29uQ2xpY2suZW1pdCgkZXZlbnQpXCJcclxuICAgID48L2NvLWlucHV0LXRleHQ+XHJcbiAgYCxcclxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcclxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBJbnB1dFNlYXJjaENvbXBvbmVudCBleHRlbmRzIEJhc2VJbnB1dENvbXBvbmVudDxzdHJpbmc+IGltcGxlbWVudHMgT25EZXN0cm95IHtcclxuXHJcbiAgcHVibGljIHJlYWRvbmx5IHNlYXJjaEljb246IENvcmVDb21wb25lbnRzSWNvbiA9IENvcmVDb21wb25lbnRzSWNvbi5NYWduaWZpZXI7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIHBsYWNlaG9sZGVyOiBzdHJpbmc7XHJcblxyXG4gIEBPdXRwdXQoKVxyXG4gIHB1YmxpYyBzZWFyY2g6IEV2ZW50RW1pdHRlcjxzdHJpbmc+ID0gbmV3IEV2ZW50RW1pdHRlcjxzdHJpbmc+KCk7XHJcblxyXG4gIEBPdXRwdXQoKVxyXG4gIHB1YmxpYyBsZWZ0SWNvbkNsaWNrOiBFdmVudEVtaXR0ZXI8TW91c2VFdmVudD4gPSBuZXcgRXZlbnRFbWl0dGVyPE1vdXNlRXZlbnQ+KCk7XHJcblxyXG4gIEBPdXRwdXQoKVxyXG4gIHB1YmxpYyByaWdodEljb25DbGljazogRXZlbnRFbWl0dGVyPE1vdXNlRXZlbnQ+ID0gbmV3IEV2ZW50RW1pdHRlcjxNb3VzZUV2ZW50PigpO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIEBJbnB1dEJvb2xlYW4oKVxyXG4gIHB1YmxpYyB1c2VMZWZ0SWNvbjogYm9vbGVhbiA9IGZhbHNlO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIEBJbnB1dEJvb2xlYW4oKVxyXG4gIHB1YmxpYyB1c2VSaWdodEljb246IGJvb2xlYW4gPSBmYWxzZTtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgbGVmdEljb25EYXRhOiBTYWZlSHRtbCB8IHVuZGVmaW5lZDtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgcmlnaHRJY29uRGF0YTogU2FmZUh0bWwgfCB1bmRlZmluZWQ7XHJcblxyXG4gIEBIb3N0QmluZGluZygnY2xhc3MuY2VudGVyLWxhYmVsJylcclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBjZW50ZXJMYWJlbDogYm9vbGVhbiA9IGZhbHNlO1xyXG5cclxuICBASG9zdEJpbmRpbmcoJ2NsYXNzLmNvLWlucHV0LXNlYXJjaCcpXHJcbiAgcHVibGljIHNob3dDbGFzcygpIHtcclxuICAgIHJldHVybiB0cnVlO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGhhbmRsZUtleURvd24oZXZlbnQ6IEtleWJvYXJkRXZlbnQpOiB2b2lkIHtcclxuICAgIHN3aXRjaCAoZXZlbnQuY29kZSkge1xyXG4gICAgICBjYXNlICdFbnRlcic6XHJcbiAgICAgIGNhc2UgJ051bXBhZEVudGVyJzpcclxuICAgICAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xyXG4gICAgICAgIHRoaXMuc2VhcmNoLm5leHQodGhpcy5tb2RlbCk7XHJcbiAgICAgICAgcmV0dXJuO1xyXG4gICAgfVxyXG4gIH1cclxufVxyXG4iXX0=
@@ -1,4 +1,4 @@
1
- import { ChangeDetectorRef, Component, ComponentFactoryResolver, ElementRef, forwardRef, HostBinding, Input, Optional, ViewEncapsulation } from "@angular/core";
1
+ import { ChangeDetectorRef, Component, ComponentFactoryResolver, ElementRef, EventEmitter, forwardRef, HostBinding, Input, Optional, Output, ViewEncapsulation } from '@angular/core';
2
2
  import { BaseInputComponent } from "../base/base-input.component";
3
3
  import { SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME } from "../../interfaces/screen-config-adapter-component-interface-name";
4
4
  import { FormInputUserModelChangeListenerService } from "../../core/service/form-input-user-change-listener.service";
@@ -20,11 +20,22 @@ export class InputTextComponent extends BaseInputComponent {
20
20
  this.showClearButton = undefined;
21
21
  this.showPlaceholderOnFocus = true;
22
22
  this.noStyle = false;
23
- this.hasOwnLabel = true;
24
23
  this.hideArrowButtons = false;
25
24
  this.isSmall = false;
25
+ this.leftIconClick = new EventEmitter();
26
+ this.rightIconClick = new EventEmitter();
27
+ this.hasOwnLabel = true;
26
28
  super._markAsOnPush();
27
29
  }
30
+ showClass() {
31
+ return true;
32
+ }
33
+ get hasLeftIcon() {
34
+ return this.leftIcon !== undefined && this.leftIcon !== null;
35
+ }
36
+ get hasRightIcon() {
37
+ return this.rightIcon !== undefined && this.rightIcon !== null;
38
+ }
28
39
  set model(value) {
29
40
  if (this.type === 'number' && !isNaN(value)) {
30
41
  if (this.min && value < this.min || this.max && value > this.max) {
@@ -41,29 +52,29 @@ export class InputTextComponent extends BaseInputComponent {
41
52
  get model() {
42
53
  return super.model;
43
54
  }
44
- showClass() {
45
- return true;
46
- }
47
- get hasLeftIcon() {
48
- return this.leftIcon !== undefined && this.leftIcon !== null;
49
- }
50
- get hasRightIcon() {
51
- return this.rightIcon !== undefined && this.rightIcon !== null;
52
- }
53
55
  // exclude some non-digit characters, since input type 'number' still allows the characters -, + and e
54
56
  excludeNonDigitChars(event) {
55
57
  const excludedKeys = this.excludePlusMinus ? ['e', '-', '+'] : ['e'];
56
58
  return !excludedKeys.includes(event.key);
57
59
  }
60
+ handleLeftIconClick(event) {
61
+ event.preventDefault();
62
+ event.stopPropagation();
63
+ this.leftIconClick.emit(event);
64
+ }
65
+ handleRightIconClick(event) {
66
+ event.preventDefault();
67
+ event.stopPropagation();
68
+ this.rightIconClick.emit(event);
69
+ }
58
70
  }
59
71
  InputTextComponent.decorators = [
60
72
  { type: Component, args: [{
61
73
  selector: "co-input-text",
62
74
  template: `
75
+ <co-icon *ngIf="leftIcon" class="input-text-left-icon" [icon]="leftIcon" [iconData]="leftIconData" (click)="handleLeftIconClick($event)"></co-icon>
63
76
  <label *ngIf="showPlaceholderOnFocus || (!showPlaceholderOnFocus && !hasValue && !focused)"
64
77
  [textContent]="placeholder"></label>
65
- <co-icon *ngIf="leftIcon" class="input-text-left-icon" [icon]="leftIcon"></co-icon>
66
- <co-icon *ngIf="rightIcon" class="input-text-right-icon" [icon]="rightIcon"></co-icon>
67
78
  <input #input
68
79
  [type]="digitsOnly ? 'number' : type"
69
80
  [ngModel]="model"
@@ -74,6 +85,7 @@ InputTextComponent.decorators = [
74
85
  (ngModelChange)="modelChange.emit($event)"
75
86
  (keydown)="digitsOnly ? excludeNonDigitChars($event) : true"
76
87
  >
88
+ <co-icon *ngIf="rightIcon" class="input-text-right-icon" [icon]="rightIcon" [iconData]="rightIconData" (click)="handleRightIconClick($event)"></co-icon>
77
89
  <co-commit-buttons *ngIf="showSaveCancel && focused && canSaveOrCancel"
78
90
  [committing]="committing"
79
91
  [commitFinished]="commitFinished"
@@ -114,12 +126,16 @@ InputTextComponent.propDecorators = {
114
126
  showPlaceholderOnFocus: [{ type: Input }],
115
127
  leftIcon: [{ type: Input }],
116
128
  rightIcon: [{ type: Input }],
129
+ leftIconData: [{ type: Input }],
130
+ rightIconData: [{ type: Input }],
117
131
  noStyle: [{ type: HostBinding, args: ['class.no-style',] }, { type: Input }],
132
+ hideArrowButtons: [{ type: Input }, { type: HostBinding, args: ['class.hide-arrows',] }],
133
+ isSmall: [{ type: HostBinding, args: ['class.is-small',] }, { type: Input }],
134
+ leftIconClick: [{ type: Output }],
135
+ rightIconClick: [{ type: Output }],
118
136
  showClass: [{ type: HostBinding, args: ["class.co-input-text",] }],
119
137
  hasLeftIcon: [{ type: HostBinding, args: ['class.has-left-icon',] }],
120
138
  hasRightIcon: [{ type: HostBinding, args: ['class.has-right-icon',] }],
121
- hasOwnLabel: [{ type: HostBinding, args: ["class.has-own-label",] }],
122
- hideArrowButtons: [{ type: Input }, { type: HostBinding, args: ['class.hide-arrows',] }],
123
- isSmall: [{ type: HostBinding, args: ['class.is-small',] }, { type: Input }]
139
+ hasOwnLabel: [{ type: HostBinding, args: ["class.has-own-label",] }]
124
140
  };
125
- //# 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 {SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from \"../../interfaces/screen-config-adapter-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: SCREEN_CONFIG_ADAPTER_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 excludePlusMinus: boolean = true;\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  @HostBinding('class.no-style')\r\n  @Input()\r\n  public noStyle: boolean = false;\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.hide-arrows')\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 excludedKeys = this.excludePlusMinus ? ['e', '-', '+'] : ['e'];\r\n\r\n    return !excludedKeys.includes(event.key);\r\n  }\r\n}\r\n"]}
141
+ //# 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, EventEmitter,\r\n  forwardRef,\r\n  HostBinding,\r\n  Input,\r\n  Optional, Output,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport {BaseInputComponent} from \"../base/base-input.component\";\r\nimport {SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from \"../../interfaces/screen-config-adapter-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\nimport {SafeHtml} from '@angular/platform-browser';\r\n\r\n@Component({\r\n  selector: \"co-input-text\",\r\n  template: `\r\n    <co-icon *ngIf=\"leftIcon\" class=\"input-text-left-icon\" [icon]=\"leftIcon\" [iconData]=\"leftIconData\" (click)=\"handleLeftIconClick($event)\"></co-icon>\r\n    <label *ngIf=\"showPlaceholderOnFocus || (!showPlaceholderOnFocus && !hasValue && !focused)\"\r\n           [textContent]=\"placeholder\"></label>\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-icon *ngIf=\"rightIcon\" class=\"input-text-right-icon\" [icon]=\"rightIcon\" [iconData]=\"rightIconData\" (click)=\"handleRightIconClick($event)\"></co-icon>\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: SCREEN_CONFIG_ADAPTER_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 excludePlusMinus: boolean = true;\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  @Input()\r\n  public leftIconData: SafeHtml | undefined;\r\n\r\n  @Input()\r\n  public rightIconData: SafeHtml | undefined;\r\n\r\n  @HostBinding('class.no-style')\r\n  @Input()\r\n  public noStyle: boolean = false;\r\n\r\n  @Input()\r\n  @HostBinding('class.hide-arrows')\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  @Output()\r\n  public leftIconClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @Output()\r\n  public rightIconClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\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  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  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 excludedKeys = this.excludePlusMinus ? ['e', '-', '+'] : ['e'];\r\n\r\n    return !excludedKeys.includes(event.key);\r\n  }\r\n\r\n  public handleLeftIconClick(event: MouseEvent): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this.leftIconClick.emit(event);\r\n  }\r\n\r\n  public handleRightIconClick(event: MouseEvent): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this.rightIconClick.emit(event);\r\n  }\r\n}\r\n"]}
@@ -1247,10 +1247,21 @@ class IconComponent {
1247
1247
  this.showClass = true;
1248
1248
  }
1249
1249
  set icon(value) {
1250
- this._setIconFromEnum(value);
1250
+ this._icon = value;
1251
+ }
1252
+ ngOnInit() {
1253
+ this._prepareIcon();
1254
+ }
1255
+ _prepareIcon() {
1256
+ if (this.iconData) {
1257
+ this.innerIconData = this.iconData;
1258
+ }
1259
+ else if (this._icon) {
1260
+ this._setIconFromEnum(this._icon);
1261
+ }
1251
1262
  }
1252
1263
  _setIconFromEnum(icon) {
1253
- this.iconData = this._iconCache.getIcon(icon);
1264
+ this.innerIconData = this._iconCache.getIcon(icon);
1254
1265
  }
1255
1266
  }
1256
1267
  IconComponent.decorators = [
@@ -1265,8 +1276,9 @@ IconComponent.ctorParameters = () => [
1265
1276
  ];
1266
1277
  IconComponent.propDecorators = {
1267
1278
  icon: [{ type: Input }],
1268
- iconData: [{ type: Input }, { type: HostBinding, args: ["innerHtml",] }],
1269
- showClass: [{ type: HostBinding, args: ["class.co-icon",] }]
1279
+ iconData: [{ type: Input }],
1280
+ showClass: [{ type: HostBinding, args: ['class.co-icon',] }],
1281
+ innerIconData: [{ type: HostBinding, args: ['innerHtml',] }]
1270
1282
  };
1271
1283
 
1272
1284
  class IconModule {
@@ -7073,11 +7085,22 @@ class InputTextComponent extends BaseInputComponent {
7073
7085
  this.showClearButton = undefined;
7074
7086
  this.showPlaceholderOnFocus = true;
7075
7087
  this.noStyle = false;
7076
- this.hasOwnLabel = true;
7077
7088
  this.hideArrowButtons = false;
7078
7089
  this.isSmall = false;
7090
+ this.leftIconClick = new EventEmitter();
7091
+ this.rightIconClick = new EventEmitter();
7092
+ this.hasOwnLabel = true;
7079
7093
  super._markAsOnPush();
7080
7094
  }
7095
+ showClass() {
7096
+ return true;
7097
+ }
7098
+ get hasLeftIcon() {
7099
+ return this.leftIcon !== undefined && this.leftIcon !== null;
7100
+ }
7101
+ get hasRightIcon() {
7102
+ return this.rightIcon !== undefined && this.rightIcon !== null;
7103
+ }
7081
7104
  set model(value) {
7082
7105
  if (this.type === 'number' && !isNaN(value)) {
7083
7106
  if (this.min && value < this.min || this.max && value > this.max) {
@@ -7094,29 +7117,29 @@ class InputTextComponent extends BaseInputComponent {
7094
7117
  get model() {
7095
7118
  return super.model;
7096
7119
  }
7097
- showClass() {
7098
- return true;
7099
- }
7100
- get hasLeftIcon() {
7101
- return this.leftIcon !== undefined && this.leftIcon !== null;
7102
- }
7103
- get hasRightIcon() {
7104
- return this.rightIcon !== undefined && this.rightIcon !== null;
7105
- }
7106
7120
  // exclude some non-digit characters, since input type 'number' still allows the characters -, + and e
7107
7121
  excludeNonDigitChars(event) {
7108
7122
  const excludedKeys = this.excludePlusMinus ? ['e', '-', '+'] : ['e'];
7109
7123
  return !excludedKeys.includes(event.key);
7110
7124
  }
7125
+ handleLeftIconClick(event) {
7126
+ event.preventDefault();
7127
+ event.stopPropagation();
7128
+ this.leftIconClick.emit(event);
7129
+ }
7130
+ handleRightIconClick(event) {
7131
+ event.preventDefault();
7132
+ event.stopPropagation();
7133
+ this.rightIconClick.emit(event);
7134
+ }
7111
7135
  }
7112
7136
  InputTextComponent.decorators = [
7113
7137
  { type: Component, args: [{
7114
7138
  selector: "co-input-text",
7115
7139
  template: `
7140
+ <co-icon *ngIf="leftIcon" class="input-text-left-icon" [icon]="leftIcon" [iconData]="leftIconData" (click)="handleLeftIconClick($event)"></co-icon>
7116
7141
  <label *ngIf="showPlaceholderOnFocus || (!showPlaceholderOnFocus && !hasValue && !focused)"
7117
7142
  [textContent]="placeholder"></label>
7118
- <co-icon *ngIf="leftIcon" class="input-text-left-icon" [icon]="leftIcon"></co-icon>
7119
- <co-icon *ngIf="rightIcon" class="input-text-right-icon" [icon]="rightIcon"></co-icon>
7120
7143
  <input #input
7121
7144
  [type]="digitsOnly ? 'number' : type"
7122
7145
  [ngModel]="model"
@@ -7127,6 +7150,7 @@ InputTextComponent.decorators = [
7127
7150
  (ngModelChange)="modelChange.emit($event)"
7128
7151
  (keydown)="digitsOnly ? excludeNonDigitChars($event) : true"
7129
7152
  >
7153
+ <co-icon *ngIf="rightIcon" class="input-text-right-icon" [icon]="rightIcon" [iconData]="rightIconData" (click)="handleRightIconClick($event)"></co-icon>
7130
7154
  <co-commit-buttons *ngIf="showSaveCancel && focused && canSaveOrCancel"
7131
7155
  [committing]="committing"
7132
7156
  [commitFinished]="commitFinished"
@@ -7167,13 +7191,17 @@ InputTextComponent.propDecorators = {
7167
7191
  showPlaceholderOnFocus: [{ type: Input }],
7168
7192
  leftIcon: [{ type: Input }],
7169
7193
  rightIcon: [{ type: Input }],
7194
+ leftIconData: [{ type: Input }],
7195
+ rightIconData: [{ type: Input }],
7170
7196
  noStyle: [{ type: HostBinding, args: ['class.no-style',] }, { type: Input }],
7197
+ hideArrowButtons: [{ type: Input }, { type: HostBinding, args: ['class.hide-arrows',] }],
7198
+ isSmall: [{ type: HostBinding, args: ['class.is-small',] }, { type: Input }],
7199
+ leftIconClick: [{ type: Output }],
7200
+ rightIconClick: [{ type: Output }],
7171
7201
  showClass: [{ type: HostBinding, args: ["class.co-input-text",] }],
7172
7202
  hasLeftIcon: [{ type: HostBinding, args: ['class.has-left-icon',] }],
7173
7203
  hasRightIcon: [{ type: HostBinding, args: ['class.has-right-icon',] }],
7174
- hasOwnLabel: [{ type: HostBinding, args: ["class.has-own-label",] }],
7175
- hideArrowButtons: [{ type: Input }, { type: HostBinding, args: ['class.hide-arrows',] }],
7176
- isSmall: [{ type: HostBinding, args: ['class.is-small',] }, { type: Input }]
7204
+ hasOwnLabel: [{ type: HostBinding, args: ["class.has-own-label",] }]
7177
7205
  };
7178
7206
 
7179
7207
  class ValidationErrorModule {
@@ -7319,6 +7347,8 @@ class InputSearchComponent extends BaseInputComponent {
7319
7347
  super(...arguments);
7320
7348
  this.searchIcon = CoreComponentsIcon.Magnifier;
7321
7349
  this.search = new EventEmitter();
7350
+ this.leftIconClick = new EventEmitter();
7351
+ this.rightIconClick = new EventEmitter();
7322
7352
  this.useLeftIcon = false;
7323
7353
  this.useRightIcon = false;
7324
7354
  this.centerLabel = false;
@@ -7344,10 +7374,14 @@ InputSearchComponent.decorators = [
7344
7374
  [model]="model"
7345
7375
  [leftIcon]="useLeftIcon ? searchIcon : null"
7346
7376
  [rightIcon]="useRightIcon ? searchIcon : null"
7377
+ [leftIconData]="useLeftIcon && leftIconData ? leftIconData : undefined"
7378
+ [rightIconData]="useRightIcon && rightIconData ? rightIconData : undefined"
7347
7379
  [placeholder]="placeholder"
7348
7380
  [customHeight]="true"
7349
7381
  [showPlaceholderOnFocus]="false"
7350
7382
  (modelChange)="modelChange.emit($event)"
7383
+ (leftIconClick)="leftIconClick.emit($event)"
7384
+ (rightIconClick)="rightIconClick.emit($event)"
7351
7385
  ></co-input-text>
7352
7386
  `,
7353
7387
  changeDetection: ChangeDetectionStrategy.OnPush,
@@ -7357,8 +7391,12 @@ InputSearchComponent.decorators = [
7357
7391
  InputSearchComponent.propDecorators = {
7358
7392
  placeholder: [{ type: Input }],
7359
7393
  search: [{ type: Output }],
7394
+ leftIconClick: [{ type: Output }],
7395
+ rightIconClick: [{ type: Output }],
7360
7396
  useLeftIcon: [{ type: Input }],
7361
7397
  useRightIcon: [{ type: Input }],
7398
+ leftIconData: [{ type: Input }],
7399
+ rightIconData: [{ type: Input }],
7362
7400
  centerLabel: [{ type: HostBinding, args: ['class.center-label',] }, { type: Input }],
7363
7401
  showClass: [{ type: HostBinding, args: ['class.co-input-search',] }]
7364
7402
  };