@colijnit/corecomponents_v12 260.1.18 → 261.1.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.
@@ -156,4 +156,4 @@ __decorate([
156
156
  __decorate([
157
157
  InputBoolean()
158
158
  ], ScreenConfigurationDirective.prototype, "noModuleService", void 0);
159
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"screen-configuration.directive.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/directives/screen-configuration/screen-configuration.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, ElementRef, Inject, Input, OnDestroy, Renderer2} from '@angular/core';\nimport {InputBoolean} from '../../core/decorator/input-boolean.decorator';\nimport {ScreenConfigAdapterComponent} from '../../interfaces/screen-config-adapter.component.interface';\nimport {SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from '../../interfaces/screen-config-adapter-component-interface-name';\nimport {Subscription} from 'rxjs';\nimport {BaseModuleScreenConfigService} from '../../service/base-module-screen-config.service';\nimport {BaseModuleService} from '../../service/base-module.service';\nimport {ValidationResult} from '@colijnit/ioneconnector/build/model/validation-result';\nimport {ValidationMessage} from '@colijnit/ioneconnector/build/model/validation-message';\nimport {ObjectConfiguration} from '@colijnit/ioneconnector/build/model/object-configuration';\n\n// Directive to represents the marker of \"screen config name ID's\" of components within a module.\n// Manipulates visibility, readonly and other dynamic states of an input element according to its db-fetched screen configuration object.\n@Directive({\n    selector: '[screenConfigurationObject]'\n})\nexport class ScreenConfigurationDirective implements OnDestroy {\n    @Input('screenConfigurationObject')\n    public set screenConfigurationObject(value: string) {\n        if (value) {\n            this._screenConfigurationObject = value;\n            this._updateHost();\n        }\n    }\n\n    public get screenConfigurationObject(): string {\n        return this._screenConfigurationObject;\n    }\n\n    @Input()\n    public dataName: string;\n\n    @Input()\n    @InputBoolean()\n    public screenConfigNativeElement: boolean = false;\n\n    @Input()\n    @InputBoolean()\n    public noModuleService: boolean = false;\n\n    private _isHeader: boolean;\n\n    private _screenConfigurationObject: string;\n\n    // feature toggle for devs so you can see the whole screen with all inputs etc by temporarily turning off the hiding effects of this directive on its host\n    private _isTurnedOff: boolean = false;\n\n    private _subs: Subscription[] = [];\n\n    constructor(\n        @Inject(SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME)\n        public hostComponent: ScreenConfigAdapterComponent,\n        private _element: ElementRef,\n        // we must always have a config service to fetch config objects with\n        private _configService: BaseModuleScreenConfigService,\n        private _renderer: Renderer2,\n        // to make host readonly when MODULE switches to readonly:\n        private _moduleService?: BaseModuleService\n    ) {\n        this._subs.push(this._configService.configSet.subscribe((configObjects: ObjectConfiguration[]) => {\n            if (configObjects && configObjects.length > 0) {\n                this._updateHost();\n            }\n        }));\n\n        if (this._moduleService && !this.noModuleService) {\n            this._subs.push(\n                this._moduleService.readonlyChange.subscribe((moduleInReadonlyState: boolean) => {\n                    if (this.hostComponent) {\n                        this.hostComponent.readonly = this.hostComponent.forceReadonly || moduleInReadonlyState;\n                    }\n                }),\n                this._moduleService.errorValidationReceived.subscribe((validationResult: any) => {\n                    this._setErrorRedBackgroundAfterScrCfgValidate(validationResult);\n                }),\n                this._moduleService.successfulUpdate.subscribe(() => {\n                    if (this.hostComponent) {\n                        this.hostComponent.redErrorBackground = false;\n                    }\n                })\n            );\n        }\n    }\n\n    ngOnInit(): void {\n        this._updateHost();\n\n        // this._updateHeaderStateOnHostComponent(true);\n\n        // show initial error message if any\n        if (!this.noModuleService) {\n            // this._setErrorRedBackgroundAfterScrCfgValidate(this._moduleService.lastError);\n        }\n    }\n\n    ngOnDestroy(): void {\n        this._subs.forEach(sub => sub.unsubscribe());\n        if (this._isHeader) {\n            // this._doubleClickHeaders.handleCollapseableDestroy(this.screenConfigurationObject);\n        }\n        this._element = undefined;\n        this.hostComponent = undefined;\n    }\n\n    // Sets host component visibility, required, readonly etc. if specified in backend screen config OR module readonly status.\n    private _updateHost(): void {\n        if (this._mayUpdateHost() || this.screenConfigNativeElement) {\n            if (!this.screenConfigNativeElement) {\n                this.hostComponent.objectConfigName = this.screenConfigurationObject;\n            }\n            const myCfgObj: ObjectConfiguration = this._configService.getObjectConfigurationFor(this.screenConfigurationObject);\n            if (myCfgObj) {\n                this._setHostVisible(myCfgObj.immediatelyVisible());\n                if (!this.screenConfigNativeElement) {\n                    this.hostComponent.required = this.hostComponent.required || myCfgObj.isRequired();\n                    this.hostComponent.readonly = this.hostComponent.forceReadonly || this._moduleInReadonlyMode() || myCfgObj.isReadonly();\n                    this.hostComponent.decimals = myCfgObj.scale;\n                    this.hostComponent.maxLength = myCfgObj.maxLength;\n                    this.hostComponent.defaultValue = myCfgObj.defaultValue;\n                    if ('configObject' in this.hostComponent) {\n                      this.hostComponent.configObject = myCfgObj;\n                    }\n                }\n            } else {\n                this._setHostVisible(false);\n                if (!this.screenConfigNativeElement) {\n                    this.hostComponent.readonly = this._moduleInReadonlyMode();\n                }\n            }\n        }\n    }\n\n    /**\n     * Spawn error message tooltip onto our host comp, if any error was meant for the host (found by screenConfigurationObject);\n     * @param errorValidation A top-level full validation result, either from the backend or from some client-side validation error.\n     */\n    private _setErrorRedBackgroundAfterScrCfgValidate(errorValidation: ValidationResult): void {\n        if (this.hostComponent && errorValidation) {\n            const errorMessages: ValidationMessage[] = errorValidation.getAllErrorMessagesOfMyValidationFields();\n            for (let i: number = 0, len: number = errorMessages.length; i < len; i++) {\n                const errorMsg: ValidationMessage = errorMessages[i];\n                const configName: string = this.dataName ? this.dataName : this.screenConfigurationObject;\n                if (errorMsg.fieldId === configName && this._element /*&& this._properHost(errorMsg.boId)*/) {\n                    this.hostComponent.redErrorBackground = true;\n                }\n            }\n        }\n    }\n\n    private _moduleInReadonlyMode(): boolean {\n        return !this.noModuleService ? (this._moduleService ? this._moduleService.readonly : false) : false;\n    }\n\n    private _mayUpdateHost(): boolean {\n        return !!this.hostComponent && !this._isTurnedOff && !!this.screenConfigurationObject;\n    }\n\n    private _setHostVisible(visible: boolean): void {\n        if (!this.screenConfigNativeElement) {\n            this.hostComponent.hidden = !visible;\n        } else {\n            if (this._element && this._element.nativeElement) {\n                if (!visible) {\n                    this._renderer.addClass(this._element.nativeElement, 'hidden');\n                } else {\n                    this._renderer.removeClass(this._element.nativeElement, 'hidden');\n                }\n            }\n        }\n    }\n}\n"]}
159
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"screen-configuration.directive.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/directives/screen-configuration/screen-configuration.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, ElementRef, Inject, Input, OnDestroy, Renderer2} from '@angular/core';\r\nimport {InputBoolean} from '../../core/decorator/input-boolean.decorator';\r\nimport {ScreenConfigAdapterComponent} from '../../interfaces/screen-config-adapter.component.interface';\r\nimport {SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from '../../interfaces/screen-config-adapter-component-interface-name';\r\nimport {Subscription} from 'rxjs';\r\nimport {BaseModuleScreenConfigService} from '../../service/base-module-screen-config.service';\r\nimport {BaseModuleService} from '../../service/base-module.service';\r\nimport {ValidationResult} from '@colijnit/ioneconnector/build/model/validation-result';\r\nimport {ValidationMessage} from '@colijnit/ioneconnector/build/model/validation-message';\r\nimport {ObjectConfiguration} from '@colijnit/ioneconnector/build/model/object-configuration';\r\n\r\n// Directive to represents the marker of \"screen config name ID's\" of components within a module.\r\n// Manipulates visibility, readonly and other dynamic states of an input element according to its db-fetched screen configuration object.\r\n@Directive({\r\n    selector: '[screenConfigurationObject]'\r\n})\r\nexport class ScreenConfigurationDirective implements OnDestroy {\r\n    @Input('screenConfigurationObject')\r\n    public set screenConfigurationObject(value: string) {\r\n        if (value) {\r\n            this._screenConfigurationObject = value;\r\n            this._updateHost();\r\n        }\r\n    }\r\n\r\n    public get screenConfigurationObject(): string {\r\n        return this._screenConfigurationObject;\r\n    }\r\n\r\n    @Input()\r\n    public dataName: string;\r\n\r\n    @Input()\r\n    @InputBoolean()\r\n    public screenConfigNativeElement: boolean = false;\r\n\r\n    @Input()\r\n    @InputBoolean()\r\n    public noModuleService: boolean = false;\r\n\r\n    private _isHeader: boolean;\r\n\r\n    private _screenConfigurationObject: string;\r\n\r\n    // feature toggle for devs so you can see the whole screen with all inputs etc by temporarily turning off the hiding effects of this directive on its host\r\n    private _isTurnedOff: boolean = false;\r\n\r\n    private _subs: Subscription[] = [];\r\n\r\n    constructor(\r\n        @Inject(SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME)\r\n        public hostComponent: ScreenConfigAdapterComponent,\r\n        private _element: ElementRef,\r\n        // we must always have a config service to fetch config objects with\r\n        private _configService: BaseModuleScreenConfigService,\r\n        private _renderer: Renderer2,\r\n        // to make host readonly when MODULE switches to readonly:\r\n        private _moduleService?: BaseModuleService\r\n    ) {\r\n        this._subs.push(this._configService.configSet.subscribe((configObjects: ObjectConfiguration[]) => {\r\n            if (configObjects && configObjects.length > 0) {\r\n                this._updateHost();\r\n            }\r\n        }));\r\n\r\n        if (this._moduleService && !this.noModuleService) {\r\n            this._subs.push(\r\n                this._moduleService.readonlyChange.subscribe((moduleInReadonlyState: boolean) => {\r\n                    if (this.hostComponent) {\r\n                        this.hostComponent.readonly = this.hostComponent.forceReadonly || moduleInReadonlyState;\r\n                    }\r\n                }),\r\n                this._moduleService.errorValidationReceived.subscribe((validationResult: any) => {\r\n                    this._setErrorRedBackgroundAfterScrCfgValidate(validationResult);\r\n                }),\r\n                this._moduleService.successfulUpdate.subscribe(() => {\r\n                    if (this.hostComponent) {\r\n                        this.hostComponent.redErrorBackground = false;\r\n                    }\r\n                })\r\n            );\r\n        }\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        this._updateHost();\r\n\r\n        // this._updateHeaderStateOnHostComponent(true);\r\n\r\n        // show initial error message if any\r\n        if (!this.noModuleService) {\r\n            // this._setErrorRedBackgroundAfterScrCfgValidate(this._moduleService.lastError);\r\n        }\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        this._subs.forEach(sub => sub.unsubscribe());\r\n        if (this._isHeader) {\r\n            // this._doubleClickHeaders.handleCollapseableDestroy(this.screenConfigurationObject);\r\n        }\r\n        this._element = undefined;\r\n        this.hostComponent = undefined;\r\n    }\r\n\r\n    // Sets host component visibility, required, readonly etc. if specified in backend screen config OR module readonly status.\r\n    private _updateHost(): void {\r\n        if (this._mayUpdateHost() || this.screenConfigNativeElement) {\r\n            if (!this.screenConfigNativeElement) {\r\n                this.hostComponent.objectConfigName = this.screenConfigurationObject;\r\n            }\r\n            const myCfgObj: ObjectConfiguration = this._configService.getObjectConfigurationFor(this.screenConfigurationObject);\r\n            if (myCfgObj) {\r\n                this._setHostVisible(myCfgObj.immediatelyVisible());\r\n                if (!this.screenConfigNativeElement) {\r\n                    this.hostComponent.required = this.hostComponent.required || myCfgObj.isRequired();\r\n                    this.hostComponent.readonly = this.hostComponent.forceReadonly || this._moduleInReadonlyMode() || myCfgObj.isReadonly();\r\n                    this.hostComponent.decimals = myCfgObj.scale;\r\n                    this.hostComponent.maxLength = myCfgObj.maxLength;\r\n                    this.hostComponent.defaultValue = myCfgObj.defaultValue;\r\n                    if ('configObject' in this.hostComponent) {\r\n                      this.hostComponent.configObject = myCfgObj;\r\n                    }\r\n                }\r\n            } else {\r\n                this._setHostVisible(false);\r\n                if (!this.screenConfigNativeElement) {\r\n                    this.hostComponent.readonly = this._moduleInReadonlyMode();\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Spawn error message tooltip onto our host comp, if any error was meant for the host (found by screenConfigurationObject);\r\n     * @param errorValidation A top-level full validation result, either from the backend or from some client-side validation error.\r\n     */\r\n    private _setErrorRedBackgroundAfterScrCfgValidate(errorValidation: ValidationResult): void {\r\n        if (this.hostComponent && errorValidation) {\r\n            const errorMessages: ValidationMessage[] = errorValidation.getAllErrorMessagesOfMyValidationFields();\r\n            for (let i: number = 0, len: number = errorMessages.length; i < len; i++) {\r\n                const errorMsg: ValidationMessage = errorMessages[i];\r\n                const configName: string = this.dataName ? this.dataName : this.screenConfigurationObject;\r\n                if (errorMsg.fieldId === configName && this._element /*&& this._properHost(errorMsg.boId)*/) {\r\n                    this.hostComponent.redErrorBackground = true;\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    private _moduleInReadonlyMode(): boolean {\r\n        return !this.noModuleService ? (this._moduleService ? this._moduleService.readonly : false) : false;\r\n    }\r\n\r\n    private _mayUpdateHost(): boolean {\r\n        return !!this.hostComponent && !this._isTurnedOff && !!this.screenConfigurationObject;\r\n    }\r\n\r\n    private _setHostVisible(visible: boolean): void {\r\n        if (!this.screenConfigNativeElement) {\r\n            this.hostComponent.hidden = !visible;\r\n        } else {\r\n            if (this._element && this._element.nativeElement) {\r\n                if (!visible) {\r\n                    this._renderer.addClass(this._element.nativeElement, 'hidden');\r\n                } else {\r\n                    this._renderer.removeClass(this._element.nativeElement, 'hidden');\r\n                }\r\n            }\r\n        }\r\n    }\r\n}\r\n"]}
@@ -5809,12 +5809,14 @@ class InputTextComponent extends BaseInputComponent {
5809
5809
  get hasRightIcon() {
5810
5810
  return this.rightIcon !== undefined && this.rightIcon !== null;
5811
5811
  }
5812
- handleDocumentMouseUp(event) {
5812
+ handleDocumentPointerUp(event) {
5813
5813
  if (this._isLeftIconMouseDown) {
5814
- this.leftIconMouseUp.next(event);
5814
+ this._isLeftIconMouseDown = false;
5815
+ this.leftIconMouseUp.emit(event);
5815
5816
  }
5816
5817
  if (this._isRightIconMouseDown) {
5817
- this.rightIconMouseUp.next(event);
5818
+ this._isRightIconMouseDown = false;
5819
+ this.rightIconMouseUp.emit(event);
5818
5820
  }
5819
5821
  }
5820
5822
  set model(value) {
@@ -5878,6 +5880,22 @@ class InputTextComponent extends BaseInputComponent {
5878
5880
  this._isRightIconMouseDown = false;
5879
5881
  this.rightIconMouseUp.emit(event);
5880
5882
  }
5883
+ handleRightIconPointerDown(event) {
5884
+ var _a;
5885
+ event.preventDefault();
5886
+ event.stopPropagation();
5887
+ this._isRightIconMouseDown = true;
5888
+ this.rightIconMouseDown.emit(event);
5889
+ (_a = event.target) === null || _a === void 0 ? void 0 : _a.setPointerCapture(event.pointerId);
5890
+ }
5891
+ handleRightIconPointerUp(event) {
5892
+ var _a;
5893
+ event.preventDefault();
5894
+ event.stopPropagation();
5895
+ this._isRightIconMouseDown = false;
5896
+ this.rightIconMouseUp.emit(event);
5897
+ (_a = event.target) === null || _a === void 0 ? void 0 : _a.releasePointerCapture(event.pointerId);
5898
+ }
5881
5899
  handleInputFocus(event) {
5882
5900
  event.preventDefault();
5883
5901
  event.stopPropagation();
@@ -6037,8 +6055,10 @@ InputTextComponent.decorators = [
6037
6055
  <div *ngIf="rightIcon || rightIconData" class="spacer right-icon"></div>
6038
6056
  <co-icon *ngIf="rightIcon || rightIconData" class="input-text-right-icon" [icon]="rightIcon"
6039
6057
  [iconData]="rightIconData"
6040
- (click)="handleRightIconClick($event)" (mousedown)="handleRightIconMouseDown($event)"
6041
- (mouseup)="handleRightIconMouseUp($event)"></co-icon>
6058
+ (click)="handleRightIconClick($event)"
6059
+ (pointerdown)="handleRightIconPointerDown($event)"
6060
+ (pointerup)="handleRightIconPointerUp($event)"
6061
+ (pointercancel)="handleRightIconPointerUp($event)"></co-icon>
6042
6062
  </div>
6043
6063
  <!--
6044
6064
  <co-commit-buttons *ngIf="showSaveCancel && focused && canSaveOrCancel"
@@ -6108,7 +6128,7 @@ InputTextComponent.propDecorators = {
6108
6128
  hasLeftIcon: [{ type: HostBinding, args: ['class.has-left-icon',] }],
6109
6129
  hasRightIcon: [{ type: HostBinding, args: ['class.has-right-icon',] }],
6110
6130
  hasOwnLabel: [{ type: HostBinding, args: ['class.has-own-label',] }],
6111
- handleDocumentMouseUp: [{ type: HostListener, args: ['document:mouseup', ['$event'],] }],
6131
+ handleDocumentPointerUp: [{ type: HostListener, args: ['document:pointerup', ['$event'],] }, { type: HostListener, args: ['document:pointercancel', ['$event'],] }],
6112
6132
  model: [{ type: Input }]
6113
6133
  };
6114
6134
 
@@ -11410,11 +11430,11 @@ class ListOfValuesPopupComponent {
11410
11430
  this.viewModels.length = 0;
11411
11431
  this.viewModels = this.viewModelsMain.filter(vm => {
11412
11432
  return Object.values(vm.model).some((value) => {
11413
- if (!this.searchTerm || !value) {
11433
+ if (!this.searchTerm) {
11414
11434
  return true;
11415
11435
  }
11416
11436
  else {
11417
- return value.toString().toLowerCase().includes(this.searchTerm.toLowerCase());
11437
+ return value && value.toString().toLowerCase().includes(this.searchTerm.toLowerCase());
11418
11438
  }
11419
11439
  });
11420
11440
  });
@@ -11742,58 +11762,58 @@ class ListOfValuesComponent extends BaseInputComponent {
11742
11762
  ListOfValuesComponent.decorators = [
11743
11763
  { type: Component, args: [{
11744
11764
  selector: 'co-list-of-values',
11745
- template: `
11746
- <co-input-text
11747
- *ngIf="!largeCollection"
11748
- aria-haspopup="listbox"
11749
- [attr.aria-expanded]="isSelectOpen"
11750
- aria-controls="lov-popup"
11751
- role="combobox"
11752
- class="no-focus-line"
11753
- overlayParent
11754
- #parentForOverlay="overlayParent"
11755
- type="text"
11756
- [id]="label"
11757
- [model]="multiselect ? ((!selectedModels || selectedModels.length === 0) ? null : selectedModels ) : selectedModel"
11758
- [placeholder]="label"
11759
- [myFormInputInstance]="this"
11760
- [readonly]="readonly"
11761
- [disabled]="disabled"
11762
- [required]="required"
11763
- [noClickFocus]="false"
11764
- [leftIconData]=" model && model[optionIcon] ? iconCacheService.getIcon(model[optionIcon]) : leftIconData"
11765
- [rightIcon]="isSelectOpen ? icons.ChevronUpRegular : icons.ChevronDownRegular"
11766
- [showClearButton]="true"
11767
- [useContent]="multiselect"
11768
- [customHeight]="multiselect"
11769
- [keepFocussed]="keepFocussed"
11770
- (modelChange)="handleInputModelChange($event)"
11771
- (click)="openPopup()"
11772
- (rightIconClick)="toggleSelect()"
11773
- (keydown)="handleInputKeyDown($event)"
11774
- (clearIconClick)="clearModel($event)"
11775
- (blur)="checkModel()">
11776
- <ng-container *ngIf="multiselect && showChips">
11777
- <div class="multiselect-chips-wrapper">
11778
- <div class="chips" *ngFor="let chip of model">
11779
- <span class="chips-description" [textContent]="chip[displayField]"></span>
11780
- <co-icon class="remove-chip-icon" [icon]="icons.CrossSkinny" (click)="removeOptionFromModel(chip)"></co-icon>
11781
- </div>
11782
- </div>
11783
- </ng-container>
11784
- </co-input-text>
11785
-
11786
- <co-input-text
11787
- *ngIf="largeCollection"
11788
- [model]="filterText"
11789
- [placeholder]="label"
11790
- [required]="required"
11791
- [disabled]="disabled"
11792
- [readonly]="readonly"
11793
- (modelChange)="onModelChange($event)">
11794
- </co-input-text>
11795
- <div *ngIf="isLoading" class="filter-loader"><span></span></div>
11796
- <input type="hidden" [ngModel]="(selectedModels && selectedModels.length) || selectedModel ? model : null">
11765
+ template: `
11766
+ <co-input-text
11767
+ *ngIf="!largeCollection"
11768
+ aria-haspopup="listbox"
11769
+ [attr.aria-expanded]="isSelectOpen"
11770
+ aria-controls="lov-popup"
11771
+ role="combobox"
11772
+ class="no-focus-line"
11773
+ overlayParent
11774
+ #parentForOverlay="overlayParent"
11775
+ type="text"
11776
+ [id]="label"
11777
+ [model]="multiselect ? ((!selectedModels || selectedModels.length === 0) ? null : selectedModels ) : selectedModel"
11778
+ [placeholder]="label"
11779
+ [myFormInputInstance]="this"
11780
+ [readonly]="readonly"
11781
+ [disabled]="disabled"
11782
+ [required]="required"
11783
+ [noClickFocus]="false"
11784
+ [leftIconData]=" model && model[optionIcon] ? iconCacheService.getIcon(model[optionIcon]) : leftIconData"
11785
+ [rightIcon]="isSelectOpen ? icons.ChevronUpRegular : icons.ChevronDownRegular"
11786
+ [showClearButton]="true"
11787
+ [useContent]="multiselect"
11788
+ [customHeight]="multiselect"
11789
+ [keepFocussed]="keepFocussed"
11790
+ (modelChange)="handleInputModelChange($event)"
11791
+ (click)="openPopup()"
11792
+ (rightIconClick)="toggleSelect()"
11793
+ (keydown)="handleInputKeyDown($event)"
11794
+ (clearIconClick)="clearModel($event)"
11795
+ (blur)="checkModel()">
11796
+ <ng-container *ngIf="multiselect && showChips">
11797
+ <div class="multiselect-chips-wrapper">
11798
+ <div class="chips" *ngFor="let chip of model">
11799
+ <span class="chips-description" [textContent]="chip[displayField]"></span>
11800
+ <co-icon class="remove-chip-icon" [icon]="icons.CrossSkinny" (click)="removeOptionFromModel(chip)"></co-icon>
11801
+ </div>
11802
+ </div>
11803
+ </ng-container>
11804
+ </co-input-text>
11805
+
11806
+ <co-input-text
11807
+ *ngIf="largeCollection"
11808
+ [model]="filterText"
11809
+ [placeholder]="label"
11810
+ [required]="required"
11811
+ [disabled]="disabled"
11812
+ [readonly]="readonly"
11813
+ (modelChange)="onModelChange($event)">
11814
+ </co-input-text>
11815
+ <div *ngIf="isLoading" class="filter-loader"><span></span></div>
11816
+ <input type="hidden" [ngModel]="(selectedModels && selectedModels.length) || selectedModel ? model : null">
11797
11817
  `,
11798
11818
  providers: [
11799
11819
  OverlayService,
@@ -13261,169 +13281,169 @@ class FilterItemComponent {
13261
13281
  FilterItemComponent.decorators = [
13262
13282
  { type: Component, args: [{
13263
13283
  selector: "co-filter-item",
13264
- template: `
13265
- <div class="co-filter-item-header">
13266
- <co-collapsible
13267
- [headerTitle]="placeholder"
13268
- [expandButtonLast]="true"
13269
- [iconData]="iconService.getIcon(icons.ArrowPointDown)"
13270
- [expanded]="expanded"
13271
- [showButton]="showButton || alwaysShowButton"
13272
- [buttonText]="filterButtonLabel"
13273
- (buttonClicked)="onButtonClicked()"
13274
- >
13275
- <div class="co-filter-item-collapsable-content">
13276
- <div class="co-filter-item-custom-content" *ngIf="customContent; else collectionContent"
13277
- (keydown)="showButton=true" (mousedown)="showButton=true">
13278
- <ng-content></ng-content>
13279
- </div>
13280
- <ng-template #collectionContent>
13281
- <div class="co-filter-item-collection-content" *ngIf="mode === modes.Filterlist || mode === modes.SingleSelectList
13282
- || mode === modes.SelectListWithNumberOutput || mode === modes.SelectListWithStringCollectionOutput">
13283
- <co-input-text
13284
- *ngIf="collection?.length > 10 || minSearchCharsToLoadCollection"
13285
- [placeholder]="searchPlaceholder"
13286
- [model]="filterText"
13287
- (modelChange)="onModelChange($event)"
13288
- [readonly]="readonly"
13289
- >
13290
- </co-input-text>
13291
- <div *ngIf="isLoading" class="filter-loader"><span></span></div>
13292
- <div class="no-results" *ngIf="filteredCollection?.length === 0">
13293
- <span [textContent]="noResultsLabel"></span>
13294
- </div>
13295
- <div class="co-filter-item-collection-results">
13296
- <ng-container
13297
- *ngFor="let option of filteredCollection; let index = index">
13298
- <div class="co-filter-item-collection-result-item" *ngIf="index < limitTo || showAllResults">
13299
- <co-input-checkbox *ngIf="mode !== modes.SingleSelectList"
13300
- [label]="option.description"
13301
- [model]="option.checked"
13302
- [clickableLabel]="false"
13303
- (modelChange)="handleModelChange(option)"
13304
- [readonly]="readonly"
13305
- ></co-input-checkbox>
13306
- <co-input-radio-button *ngIf="mode === modes.SingleSelectList"
13307
- [label]="option.description"
13308
- [model]="option.checked"
13309
- (modelChange)="handleModelChange(option)"
13310
- [readonly]="readonly"
13311
- ></co-input-radio-button>
13312
- <div class="co-filter-item-amount" *ngIf="option.count"
13313
- [textContent]="option.count.toString() | append: ')' | prepend: ' ('"
13314
- ></div>
13315
- </div>
13316
-
13317
- </ng-container>
13318
- </div>
13319
- <div class="co-filter-show-more-or-less" *ngIf="!showAllResults">
13320
- <div class="co-filter-show-more clickable"
13321
- *ngIf="moreToShow()">
13322
- <a (click)="increaseLimit()">
13323
- <co-icon [iconData]="iconService.getIcon(icons.ArrowPointDown)"></co-icon>
13324
- <span [textContent]="showMoreLabel"></span>
13325
- </a>
13326
- </div>
13327
- <div class="co-filter-show-less clickable"
13328
- *ngIf="lessToShow()">
13329
- <a (click)="setToInitialLimit()">
13330
- <co-icon [iconData]="iconService.getIcon(icons.ArrowPointUp)"></co-icon>
13331
- <span [textContent]="showLessLabel"></span>
13332
- </a>
13333
- </div>
13334
- </div>
13335
- </div>
13336
- <div class="co-filter-item-slider-content" *ngIf="mode === modes.Slider">
13337
- <co-input-text
13338
- class="slider-from"
13339
- [type]="'number'"
13340
- [digitsOnly]="true"
13341
- [hideArrowButtons]="true"
13342
- [excludePlusMinus]="true"
13343
- [label]="'FROM' | coreLocalize"
13344
- [(model)]="sliderMin"
13345
- [readonly]="readonly"
13346
- (modelChange)="handleModelChange(sliderMin)"
13347
- ></co-input-text>
13348
- <co-input-text
13349
- class="slider-to"
13350
- [type]="'number'"
13351
- [digitsOnly]="true"
13352
- [hideArrowButtons]="true"
13353
- [excludePlusMinus]="true"
13354
- [label]="'TO' | coreLocalize"
13355
- [(model)]="sliderMax"
13356
- [readonly]="readonly"
13357
- (modelChange)="handleModelChange(sliderMax)"
13358
- ></co-input-text>
13359
- </div>
13360
- <div class="co-filter-item-slider-content" *ngIf="mode === modes.NullableSlider">
13361
- <co-input-text
13362
- class="slider-from"
13363
- [type]="'number'"
13364
- [digitsOnly]="true"
13365
- [hideArrowButtons]="true"
13366
- [excludePlusMinus]="true"
13367
- [label]="'FROM' | coreLocalize"
13368
- [(model)]="sliderMin"
13369
- [readonly]="readonly"
13370
- (modelChange)="handleModelChange(sliderMin)"
13371
- ></co-input-text>
13372
- <co-input-text
13373
- class="slider-to"
13374
- [type]="'number'"
13375
- [digitsOnly]="true"
13376
- [hideArrowButtons]="true"
13377
- [excludePlusMinus]="true"
13378
- [label]="'TO' | coreLocalize"
13379
- [(model)]="sliderMax"
13380
- [readonly]="readonly"
13381
- (modelChange)="handleModelChange(sliderMax)"
13382
- ></co-input-text>
13383
- </div>
13384
- <div class="co-filter-item-checkbox-content" *ngIf="mode === modes.Checkbox">
13385
- <co-input-checkbox
13386
- [(model)]="model"
13387
- [clickableLabel]="false"
13388
- (modelChange)="handleModelChange($event)"
13389
- [readonly]="readonly"
13390
- [label]="placeholder">
13391
- </co-input-checkbox>
13392
- </div>
13393
- <div class="co-filter-item-checkbox-content"
13394
- *ngIf="mode === modes.CheckboxToText || mode === modes.CheckboxToSimpleText || mode === modes.CheckboxToBinary || mode === modes.CheckboxToTFSimpleText || mode === modes.CheckboxToTFText">
13395
- <co-input-checkbox
13396
- [(model)]="checkBoxToTextModel"
13397
- [clickableLabel]="false"
13398
- (modelChange)="handleModelChange($event)"
13399
- [readonly]="readonly"
13400
- [label]="placeholder"></co-input-checkbox>
13401
- </div>
13402
- <div class="co-filter-item-textfield-content" *ngIf="mode === modes.TextField">
13403
- <co-input-text
13404
- [(model)]="model" [readonly]="readonly"
13405
- (modelChange)="handleModelChange($event)"></co-input-text>
13406
- </div>
13407
- <div class="co-filter-item-dateField-content" *ngIf="mode === modes.DateField">
13408
- <co-input-date
13409
- #dateInput
13410
- [(model)]="dateFieldValue" [readonly]="readonly" [firstDayOfWeek]="firstDayOfWeek"
13411
- (modelChange)="handleModelChange($event)"
13412
- ></co-input-date>
13413
- </div>
13414
- <div class="co-filter-item-dateField-content" *ngIf="mode === modes.DateRangeField">
13415
- <co-input-date-range [readonly]="readonly" [firstDayOfWeek]="firstDayOfWeek"
13416
- #dateRangeInput
13417
- [model]="[dateRangeStart, dateRangeEnd]"
13418
- (modelChange)="handleModelChange($event)"
13419
- [placeholder]="'Kies datum' | coreLocalize">
13420
- </co-input-date-range>
13421
- </div>
13422
- </ng-template>
13423
- </div>
13424
- </co-collapsible>
13425
- </div>
13426
-
13284
+ template: `
13285
+ <div class="co-filter-item-header">
13286
+ <co-collapsible
13287
+ [headerTitle]="placeholder"
13288
+ [expandButtonLast]="true"
13289
+ [iconData]="iconService.getIcon(icons.ArrowPointDown)"
13290
+ [expanded]="expanded"
13291
+ [showButton]="showButton || alwaysShowButton"
13292
+ [buttonText]="filterButtonLabel"
13293
+ (buttonClicked)="onButtonClicked()"
13294
+ >
13295
+ <div class="co-filter-item-collapsable-content">
13296
+ <div class="co-filter-item-custom-content" *ngIf="customContent; else collectionContent"
13297
+ (keydown)="showButton=true" (mousedown)="showButton=true">
13298
+ <ng-content></ng-content>
13299
+ </div>
13300
+ <ng-template #collectionContent>
13301
+ <div class="co-filter-item-collection-content" *ngIf="mode === modes.Filterlist || mode === modes.SingleSelectList
13302
+ || mode === modes.SelectListWithNumberOutput || mode === modes.SelectListWithStringCollectionOutput">
13303
+ <co-input-text
13304
+ *ngIf="collection?.length > 10 || minSearchCharsToLoadCollection"
13305
+ [placeholder]="searchPlaceholder"
13306
+ [model]="filterText"
13307
+ (modelChange)="onModelChange($event)"
13308
+ [readonly]="readonly"
13309
+ >
13310
+ </co-input-text>
13311
+ <div *ngIf="isLoading" class="filter-loader"><span></span></div>
13312
+ <div class="no-results" *ngIf="filteredCollection?.length === 0">
13313
+ <span [textContent]="noResultsLabel"></span>
13314
+ </div>
13315
+ <div class="co-filter-item-collection-results">
13316
+ <ng-container
13317
+ *ngFor="let option of filteredCollection; let index = index">
13318
+ <div class="co-filter-item-collection-result-item" *ngIf="index < limitTo || showAllResults">
13319
+ <co-input-checkbox *ngIf="mode !== modes.SingleSelectList"
13320
+ [label]="option.description"
13321
+ [model]="option.checked"
13322
+ [clickableLabel]="false"
13323
+ (modelChange)="handleModelChange(option)"
13324
+ [readonly]="readonly"
13325
+ ></co-input-checkbox>
13326
+ <co-input-radio-button *ngIf="mode === modes.SingleSelectList"
13327
+ [label]="option.description"
13328
+ [model]="option.checked"
13329
+ (modelChange)="handleModelChange(option)"
13330
+ [readonly]="readonly"
13331
+ ></co-input-radio-button>
13332
+ <div class="co-filter-item-amount" *ngIf="option.count"
13333
+ [textContent]="option.count.toString() | append: ')' | prepend: ' ('"
13334
+ ></div>
13335
+ </div>
13336
+
13337
+ </ng-container>
13338
+ </div>
13339
+ <div class="co-filter-show-more-or-less" *ngIf="!showAllResults">
13340
+ <div class="co-filter-show-more clickable"
13341
+ *ngIf="moreToShow()">
13342
+ <a (click)="increaseLimit()">
13343
+ <co-icon [iconData]="iconService.getIcon(icons.ArrowPointDown)"></co-icon>
13344
+ <span [textContent]="showMoreLabel"></span>
13345
+ </a>
13346
+ </div>
13347
+ <div class="co-filter-show-less clickable"
13348
+ *ngIf="lessToShow()">
13349
+ <a (click)="setToInitialLimit()">
13350
+ <co-icon [iconData]="iconService.getIcon(icons.ArrowPointUp)"></co-icon>
13351
+ <span [textContent]="showLessLabel"></span>
13352
+ </a>
13353
+ </div>
13354
+ </div>
13355
+ </div>
13356
+ <div class="co-filter-item-slider-content" *ngIf="mode === modes.Slider">
13357
+ <co-input-text
13358
+ class="slider-from"
13359
+ [type]="'number'"
13360
+ [digitsOnly]="true"
13361
+ [hideArrowButtons]="true"
13362
+ [excludePlusMinus]="true"
13363
+ [label]="'FROM' | coreLocalize"
13364
+ [(model)]="sliderMin"
13365
+ [readonly]="readonly"
13366
+ (modelChange)="handleModelChange(sliderMin)"
13367
+ ></co-input-text>
13368
+ <co-input-text
13369
+ class="slider-to"
13370
+ [type]="'number'"
13371
+ [digitsOnly]="true"
13372
+ [hideArrowButtons]="true"
13373
+ [excludePlusMinus]="true"
13374
+ [label]="'TO' | coreLocalize"
13375
+ [(model)]="sliderMax"
13376
+ [readonly]="readonly"
13377
+ (modelChange)="handleModelChange(sliderMax)"
13378
+ ></co-input-text>
13379
+ </div>
13380
+ <div class="co-filter-item-slider-content" *ngIf="mode === modes.NullableSlider">
13381
+ <co-input-text
13382
+ class="slider-from"
13383
+ [type]="'number'"
13384
+ [digitsOnly]="true"
13385
+ [hideArrowButtons]="true"
13386
+ [excludePlusMinus]="true"
13387
+ [label]="'FROM' | coreLocalize"
13388
+ [(model)]="sliderMin"
13389
+ [readonly]="readonly"
13390
+ (modelChange)="handleModelChange(sliderMin)"
13391
+ ></co-input-text>
13392
+ <co-input-text
13393
+ class="slider-to"
13394
+ [type]="'number'"
13395
+ [digitsOnly]="true"
13396
+ [hideArrowButtons]="true"
13397
+ [excludePlusMinus]="true"
13398
+ [label]="'TO' | coreLocalize"
13399
+ [(model)]="sliderMax"
13400
+ [readonly]="readonly"
13401
+ (modelChange)="handleModelChange(sliderMax)"
13402
+ ></co-input-text>
13403
+ </div>
13404
+ <div class="co-filter-item-checkbox-content" *ngIf="mode === modes.Checkbox">
13405
+ <co-input-checkbox
13406
+ [(model)]="model"
13407
+ [clickableLabel]="false"
13408
+ (modelChange)="handleModelChange($event)"
13409
+ [readonly]="readonly"
13410
+ [label]="placeholder">
13411
+ </co-input-checkbox>
13412
+ </div>
13413
+ <div class="co-filter-item-checkbox-content"
13414
+ *ngIf="mode === modes.CheckboxToText || mode === modes.CheckboxToSimpleText || mode === modes.CheckboxToBinary || mode === modes.CheckboxToTFSimpleText || mode === modes.CheckboxToTFText">
13415
+ <co-input-checkbox
13416
+ [(model)]="checkBoxToTextModel"
13417
+ [clickableLabel]="false"
13418
+ (modelChange)="handleModelChange($event)"
13419
+ [readonly]="readonly"
13420
+ [label]="placeholder"></co-input-checkbox>
13421
+ </div>
13422
+ <div class="co-filter-item-textfield-content" *ngIf="mode === modes.TextField">
13423
+ <co-input-text
13424
+ [(model)]="model" [readonly]="readonly"
13425
+ (modelChange)="handleModelChange($event)"></co-input-text>
13426
+ </div>
13427
+ <div class="co-filter-item-dateField-content" *ngIf="mode === modes.DateField">
13428
+ <co-input-date
13429
+ #dateInput
13430
+ [(model)]="dateFieldValue" [readonly]="readonly" [firstDayOfWeek]="firstDayOfWeek"
13431
+ (modelChange)="handleModelChange($event)"
13432
+ ></co-input-date>
13433
+ </div>
13434
+ <div class="co-filter-item-dateField-content" *ngIf="mode === modes.DateRangeField">
13435
+ <co-input-date-range [readonly]="readonly" [firstDayOfWeek]="firstDayOfWeek"
13436
+ #dateRangeInput
13437
+ [model]="[dateRangeStart, dateRangeEnd]"
13438
+ (modelChange)="handleModelChange($event)"
13439
+ [placeholder]="'Kies datum' | coreLocalize">
13440
+ </co-input-date-range>
13441
+ </div>
13442
+ </ng-template>
13443
+ </div>
13444
+ </co-collapsible>
13445
+ </div>
13446
+
13427
13447
  `,
13428
13448
  encapsulation: ViewEncapsulation.None,
13429
13449
  changeDetection: ChangeDetectionStrategy.OnPush,