@leanix/components 0.3.56 → 0.3.57
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/esm2020/lib/forms-ui/components/option-group-dropdown/option-group-dropdown.component.mjs +1 -1
- package/fesm2015/leanix-components.mjs.map +1 -1
- package/fesm2020/leanix-components.mjs.map +1 -1
- package/lib/forms-ui/components/option-group-dropdown/option-group-dropdown.component.d.ts +3 -0
- package/package.json +1 -1
package/esm2020/lib/forms-ui/components/option-group-dropdown/option-group-dropdown.component.mjs
CHANGED
|
@@ -97,4 +97,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.3", ngImpor
|
|
|
97
97
|
type: ContentChild,
|
|
98
98
|
args: ['noResultsOptionTemplateRef']
|
|
99
99
|
}] } });
|
|
100
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"option-group-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/forms-ui/components/option-group-dropdown/option-group-dropdown.component.ts","../../../../../../../../libs/components/src/lib/forms-ui/components/option-group-dropdown/option-group-dropdown.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,YAAY,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAe,MAAM,eAAe,CAAC;AAC3H,OAAO,EAAE,sBAAsB,EAAE,MAAM,4CAA4C,CAAC;AACpF,OAAO,EAAE,uBAAuB,EAAE,MAAM,8BAA8B,CAAC;;;;;;;;;AAQvE;;;;;;;;;;;;;;;;;GAiBG;AAOH,MAAM,OAAO,4BAA6B,SAAQ,uBAAuB;IANzE;;QAOW,SAAI,GAAG,8BAA8B,CAAC;QAEtC,iBAAY,GAA8B,EAAE,CAAC;QAM7C,wBAAmB,GAAY,KAAK,CAAC;QACrC,aAAQ,GAAW,OAAO,CAAC;QAC3B,YAAO,GAAY,KAAK,CAAC;QAEzB,gCAA2B,GAAY,KAAK,CAAC;QAE5C,mBAAc,GAAG,IAAI,YAAY,EAA2B,CAAC;QAC7D,sBAAiB,GAAG,IAAI,YAAY,EAAE,CAAC;QACvC,oBAAe,GAAG,IAAI,YAAY,EAAU,CAAC;KAqCxD;IA3BC,IAAW,SAAS;QAClB,MAAM,OAAO,GACX,IAAI,CAAC,YAAY,EAAE,MAAM,CAA8B,CAAC,WAAW,EAAE,WAAW,EAAE,EAAE,CAAC,WAAW,CAAC,MAAM,CAAC,WAAW,CAAC,OAAO,CAAC,EAAE,EAAE,CAAC;YACjI,EAAE,CAAC;QACL,OAAO,sBAAsB,CAAC,SAAS,CAAC,OAAO,EAAE,IAAI,CAAC,cAAc,IAAI,EAAE,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;IAC7F,CAAC;IAED,YAAY,CAAC,MAA+B;QAC1C,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACnC,CAAC;IAED,YAAY,CAAC,KAAa,EAAE,WAAoC;QAC9D,OAAO,WAAW,CAAC,KAAK,GAAG,KAAK,CAAC;IACnC,CAAC;IAEM,iBAAiB;QACtB,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,cAAc,EAAE;YACxC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;SAChD;IACH,CAAC;IAED,YAAY,CAAC,MAAc,EAAE,MAA+B;QAC1D,IAAI,IAAI,CAAC,eAAe,EAAE;YACxB,OAAO,MAAM,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;SACrC;QACD,OAAO,MAAM,CAAC,KAAK,CAAC;IACtB,CAAC;;yHArDU,4BAA4B;6GAA5B,4BAA4B,guBClCzC,w9FAyEA;2FDvCa,4BAA4B;kBANxC,SAAS;+BACE,0BAA0B,mBAGnB,uBAAuB,CAAC,MAAM;8BAKtC,YAAY;sBAApB,KAAK;gBAIG,cAAc;sBAAtB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,mBAAmB;sBAA3B,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,2BAA2B;sBAAnC,KAAK;gBAEI,cAAc;sBAAvB,MAAM;gBACG,iBAAiB;sBAA1B,MAAM;gBACG,eAAe;sBAAxB,MAAM;gBAEyB,iBAAiB;sBAAhD,YAAY;uBAAC,gBAAgB;gBAMc,0BAA0B;sBAArE,YAAY;uBAAC,4BAA4B","sourcesContent":["import { ChangeDetectionStrategy, Component, ContentChild, EventEmitter, Input, Output, TemplateRef } from '@angular/core';\nimport { BasicDropdownComponent } from '../basic-dropdown/basic-dropdown.component';\nimport { KeyboardSelectDirective } from '../keyboard-select.directive';\n\nexport type OptionGroupOption = { value: string; label: string };\nexport type SingleSelectOptionGroup<T = any> = {\n  label: string;\n  options: (OptionGroupOption | T)[];\n};\n\n/**\n * Usage:\n * <lx-single-select\n *    #singleSelect\n *    [selection]=\"value\"\n *    (selectionChange)=\"onSelectionChange($event)\">\n *   <span class=\"selectedOption\">\n *     {{ value.label }}\n *   </span>\n *   <lx-option-group-dropdown\n *     class=\"dropdownComponent\"\n *     [keyboardSelectAction]=\"singleSelect.optionsKeyboardSelectAction$\"\n *     [optionGroups]=\"optionGroups\"\n *     (onItemSelected)=\"singleSelect.selectOption($event)\">\n *    </lx-option-group-dropdown>\n * </lx-single-select>\n *\n */\n@Component({\n  selector: 'lx-option-group-dropdown',\n  templateUrl: 'option-group-dropdown.component.html',\n  styleUrls: ['option-group-dropdown.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class OptionGroupDropdownComponent extends KeyboardSelectDirective {\n  readonly NAME = 'OptionGroupDropdownComponent';\n\n  @Input() optionGroups: SingleSelectOptionGroup[] = [];\n  /**\n   * Usually a stream of the current input value of the parent select.\n   */\n  @Input() newOptionLabel?: string;\n  @Input() highlightTerm?: string;\n  @Input() showCreateNewOption: boolean = false;\n  @Input() labelKey: string = 'label';\n  @Input() loading: boolean = false;\n  @Input() trackByProperty?: string;\n  @Input() showNoResultsIfGroupIsEmpty: boolean = false;\n\n  @Output() onItemSelected = new EventEmitter<OptionGroupOption | any>();\n  @Output() containerScrolled = new EventEmitter();\n  @Output() createNewOption = new EventEmitter<string>();\n\n  @ContentChild('optionTemplate') optionTemplateRef?: TemplateRef<any>;\n  /**\n   * If you provide a <ng-template #noResultsOptionTemplateRef></ng-template> inside the <lx-option-group-dropdown>\n   * it will be used to display the \"no results\" option instead of the default \"No results\" text.\n   * This way you can easily define different \"No results\" texts for different groups too.\n   */\n  @ContentChild('noResultsOptionTemplateRef') noResultsOptionTemplateRef?: TemplateRef<any>;\n\n  public get isNewItem() {\n    const options =\n      this.optionGroups?.reduce<(OptionGroupOption | any)[]>((flatOptions, optionGroup) => flatOptions.concat(optionGroup.options), []) ??\n      [];\n    return BasicDropdownComponent.isNewItem(options, this.newOptionLabel ?? '', this.labelKey);\n  }\n\n  selectOption(option: OptionGroupOption | any) {\n    this.onItemSelected.emit(option);\n  }\n\n  trackByLabel(index: number, optionGroup: SingleSelectOptionGroup) {\n    return optionGroup.label + index;\n  }\n\n  public onCreateNewOption() {\n    if (!this.loading && this.newOptionLabel) {\n      this.createNewOption.emit(this.newOptionLabel);\n    }\n  }\n\n  trackByValue(_index: number, option: OptionGroupOption | any) {\n    if (this.trackByProperty) {\n      return option[this.trackByProperty];\n    }\n    return option.value;\n  }\n}\n","<div\n  #keyboardSelectContainer\n  class=\"scrollingPanel lxThinScrollbar\"\n  infinite-scroll\n  [scrollWindow]=\"false\"\n  [fromRoot]=\"true\"\n  (scrolled)=\"containerScrolled.emit()\"\n>\n  <ul class=\"options\">\n    <li\n      *ngIf=\"showCreateNewOption && newOptionLabel && isNewItem\"\n      lxSelectableItem\n      [scrollInContainer]=\"keyboardSelectContainer\"\n      #item\n      (click)=\"onCreateNewOption()\"\n      (select)=\"onCreateNewOption()\"\n      [class.highlighted]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n      class=\"option\"\n    >\n      <span class=\"newEntryContent\">\n        {{ newOptionLabel }}\n      </span>\n      <lx-badge class=\"lx-margin-left\" size=\"small\" [content]=\"'common.new' | translate | uppercase\"></lx-badge>\n    </li>\n    <ng-container *ngFor=\"let optionGroup of optionGroups; let groupIndex = index; trackBy: trackByLabel\">\n      <li>\n        <div class=\"groupLabel\" *ngIf=\"optionGroup.label\">\n          <span>{{ optionGroup.label | uppercase }}</span>\n        </div>\n        <ul>\n          <ng-container *ngIf=\"showNoResultsIfGroupIsEmpty && optionGroup.options.length === 0; else options\">\n            <li class=\"noResult\">\n              <ng-container *ngIf=\"noResultsOptionTemplateRef; else defaultText\">\n                <ng-container\n                  *ngTemplateOutlet=\"noResultsOptionTemplateRef; context: { group: optionGroup, groupIndex: groupIndex }\"\n                ></ng-container>\n              </ng-container>\n              <ng-template #defaultText>\n                <span>{{ NAME + '.noResults' | translate }}</span>\n              </ng-template>\n            </li>\n          </ng-container>\n          <ng-template #options>\n            <li\n              *ngFor=\"let option of optionGroup.options; let index = index; trackBy: trackByValue\"\n              lxSelectableItem\n              [scrollInContainer]=\"keyboardSelectContainer\"\n              #item\n              class=\"option\"\n              (click)=\"selectOption(option)\"\n              (select)=\"selectOption(option)\"\n              [class.highlighted]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n            >\n              <ng-container *ngIf=\"optionTemplateRef; else basicDropdownOption\">\n                <ng-container\n                  *ngTemplateOutlet=\"optionTemplateRef; context: { $implicit: option, index: index, groupIndex: groupIndex }\"\n                ></ng-container>\n              </ng-container>\n              <ng-template #basicDropdownOption>\n                <lx-basic-dropdown-item\n                  [label]=\"option.label\"\n                  labelFontWeight=\"normal\"\n                  [highlightTerm]=\"highlightTerm\"\n                ></lx-basic-dropdown-item>\n              </ng-template>\n            </li>\n          </ng-template>\n        </ul>\n      </li>\n    </ng-container>\n    <lx-spinner *ngIf=\"loading\" [fadeBackground]=\"true\"></lx-spinner>\n  </ul>\n</div>\n"]}
|
|
100
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"option-group-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/forms-ui/components/option-group-dropdown/option-group-dropdown.component.ts","../../../../../../../../libs/components/src/lib/forms-ui/components/option-group-dropdown/option-group-dropdown.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,YAAY,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAe,MAAM,eAAe,CAAC;AAC3H,OAAO,EAAE,sBAAsB,EAAE,MAAM,4CAA4C,CAAC;AACpF,OAAO,EAAE,uBAAuB,EAAE,MAAM,8BAA8B,CAAC;;;;;;;;;AAWvE;;;;;;;;;;;;;;;;;GAiBG;AAOH,MAAM,OAAO,4BAA6B,SAAQ,uBAAuB;IANzE;;QAOW,SAAI,GAAG,8BAA8B,CAAC;QAEtC,iBAAY,GAA8B,EAAE,CAAC;QAM7C,wBAAmB,GAAY,KAAK,CAAC;QACrC,aAAQ,GAAW,OAAO,CAAC;QAC3B,YAAO,GAAY,KAAK,CAAC;QAEzB,gCAA2B,GAAY,KAAK,CAAC;QAE5C,mBAAc,GAAG,IAAI,YAAY,EAA2B,CAAC;QAC7D,sBAAiB,GAAG,IAAI,YAAY,EAAE,CAAC;QACvC,oBAAe,GAAG,IAAI,YAAY,EAAU,CAAC;KAqCxD;IA3BC,IAAW,SAAS;QAClB,MAAM,OAAO,GACX,IAAI,CAAC,YAAY,EAAE,MAAM,CAA8B,CAAC,WAAW,EAAE,WAAW,EAAE,EAAE,CAAC,WAAW,CAAC,MAAM,CAAC,WAAW,CAAC,OAAO,CAAC,EAAE,EAAE,CAAC;YACjI,EAAE,CAAC;QACL,OAAO,sBAAsB,CAAC,SAAS,CAAC,OAAO,EAAE,IAAI,CAAC,cAAc,IAAI,EAAE,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;IAC7F,CAAC;IAED,YAAY,CAAC,MAA+B;QAC1C,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACnC,CAAC;IAED,YAAY,CAAC,KAAa,EAAE,WAAoC;QAC9D,OAAO,WAAW,CAAC,KAAK,GAAG,KAAK,CAAC;IACnC,CAAC;IAEM,iBAAiB;QACtB,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,cAAc,EAAE;YACxC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;SAChD;IACH,CAAC;IAED,YAAY,CAAC,MAAc,EAAE,MAA+B;QAC1D,IAAI,IAAI,CAAC,eAAe,EAAE;YACxB,OAAO,MAAM,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;SACrC;QACD,OAAO,MAAM,CAAC,KAAK,CAAC;IACtB,CAAC;;yHArDU,4BAA4B;6GAA5B,4BAA4B,guBCrCzC,w9FAyEA;2FDpCa,4BAA4B;kBANxC,SAAS;+BACE,0BAA0B,mBAGnB,uBAAuB,CAAC,MAAM;8BAKtC,YAAY;sBAApB,KAAK;gBAIG,cAAc;sBAAtB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,mBAAmB;sBAA3B,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,2BAA2B;sBAAnC,KAAK;gBAEI,cAAc;sBAAvB,MAAM;gBACG,iBAAiB;sBAA1B,MAAM;gBACG,eAAe;sBAAxB,MAAM;gBAEyB,iBAAiB;sBAAhD,YAAY;uBAAC,gBAAgB;gBAMc,0BAA0B;sBAArE,YAAY;uBAAC,4BAA4B","sourcesContent":["import { ChangeDetectionStrategy, Component, ContentChild, EventEmitter, Input, Output, TemplateRef } from '@angular/core';\nimport { BasicDropdownComponent } from '../basic-dropdown/basic-dropdown.component';\nimport { KeyboardSelectDirective } from '../keyboard-select.directive';\n\nexport type OptionGroupOption = { value: string; label: string };\n/**\n * TODO: rename to something unspecific for single selects because multiselects are also supported\n */\nexport type SingleSelectOptionGroup<T = any> = {\n  label: string;\n  options: (OptionGroupOption | T)[];\n};\n\n/**\n * Usage:\n * <lx-single-select\n *    #singleSelect\n *    [selection]=\"value\"\n *    (selectionChange)=\"onSelectionChange($event)\">\n *   <span class=\"selectedOption\">\n *     {{ value.label }}\n *   </span>\n *   <lx-option-group-dropdown\n *     class=\"dropdownComponent\"\n *     [keyboardSelectAction]=\"singleSelect.optionsKeyboardSelectAction$\"\n *     [optionGroups]=\"optionGroups\"\n *     (onItemSelected)=\"singleSelect.selectOption($event)\">\n *    </lx-option-group-dropdown>\n * </lx-single-select>\n *\n */\n@Component({\n  selector: 'lx-option-group-dropdown',\n  templateUrl: 'option-group-dropdown.component.html',\n  styleUrls: ['option-group-dropdown.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class OptionGroupDropdownComponent extends KeyboardSelectDirective {\n  readonly NAME = 'OptionGroupDropdownComponent';\n\n  @Input() optionGroups: SingleSelectOptionGroup[] = [];\n  /**\n   * Usually a stream of the current input value of the parent select.\n   */\n  @Input() newOptionLabel?: string;\n  @Input() highlightTerm?: string;\n  @Input() showCreateNewOption: boolean = false;\n  @Input() labelKey: string = 'label';\n  @Input() loading: boolean = false;\n  @Input() trackByProperty?: string;\n  @Input() showNoResultsIfGroupIsEmpty: boolean = false;\n\n  @Output() onItemSelected = new EventEmitter<OptionGroupOption | any>();\n  @Output() containerScrolled = new EventEmitter();\n  @Output() createNewOption = new EventEmitter<string>();\n\n  @ContentChild('optionTemplate') optionTemplateRef?: TemplateRef<any>;\n  /**\n   * If you provide a <ng-template #noResultsOptionTemplateRef></ng-template> inside the <lx-option-group-dropdown>\n   * it will be used to display the \"no results\" option instead of the default \"No results\" text.\n   * This way you can easily define different \"No results\" texts for different groups too.\n   */\n  @ContentChild('noResultsOptionTemplateRef') noResultsOptionTemplateRef?: TemplateRef<any>;\n\n  public get isNewItem() {\n    const options =\n      this.optionGroups?.reduce<(OptionGroupOption | any)[]>((flatOptions, optionGroup) => flatOptions.concat(optionGroup.options), []) ??\n      [];\n    return BasicDropdownComponent.isNewItem(options, this.newOptionLabel ?? '', this.labelKey);\n  }\n\n  selectOption(option: OptionGroupOption | any) {\n    this.onItemSelected.emit(option);\n  }\n\n  trackByLabel(index: number, optionGroup: SingleSelectOptionGroup) {\n    return optionGroup.label + index;\n  }\n\n  public onCreateNewOption() {\n    if (!this.loading && this.newOptionLabel) {\n      this.createNewOption.emit(this.newOptionLabel);\n    }\n  }\n\n  trackByValue(_index: number, option: OptionGroupOption | any) {\n    if (this.trackByProperty) {\n      return option[this.trackByProperty];\n    }\n    return option.value;\n  }\n}\n","<div\n  #keyboardSelectContainer\n  class=\"scrollingPanel lxThinScrollbar\"\n  infinite-scroll\n  [scrollWindow]=\"false\"\n  [fromRoot]=\"true\"\n  (scrolled)=\"containerScrolled.emit()\"\n>\n  <ul class=\"options\">\n    <li\n      *ngIf=\"showCreateNewOption && newOptionLabel && isNewItem\"\n      lxSelectableItem\n      [scrollInContainer]=\"keyboardSelectContainer\"\n      #item\n      (click)=\"onCreateNewOption()\"\n      (select)=\"onCreateNewOption()\"\n      [class.highlighted]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n      class=\"option\"\n    >\n      <span class=\"newEntryContent\">\n        {{ newOptionLabel }}\n      </span>\n      <lx-badge class=\"lx-margin-left\" size=\"small\" [content]=\"'common.new' | translate | uppercase\"></lx-badge>\n    </li>\n    <ng-container *ngFor=\"let optionGroup of optionGroups; let groupIndex = index; trackBy: trackByLabel\">\n      <li>\n        <div class=\"groupLabel\" *ngIf=\"optionGroup.label\">\n          <span>{{ optionGroup.label | uppercase }}</span>\n        </div>\n        <ul>\n          <ng-container *ngIf=\"showNoResultsIfGroupIsEmpty && optionGroup.options.length === 0; else options\">\n            <li class=\"noResult\">\n              <ng-container *ngIf=\"noResultsOptionTemplateRef; else defaultText\">\n                <ng-container\n                  *ngTemplateOutlet=\"noResultsOptionTemplateRef; context: { group: optionGroup, groupIndex: groupIndex }\"\n                ></ng-container>\n              </ng-container>\n              <ng-template #defaultText>\n                <span>{{ NAME + '.noResults' | translate }}</span>\n              </ng-template>\n            </li>\n          </ng-container>\n          <ng-template #options>\n            <li\n              *ngFor=\"let option of optionGroup.options; let index = index; trackBy: trackByValue\"\n              lxSelectableItem\n              [scrollInContainer]=\"keyboardSelectContainer\"\n              #item\n              class=\"option\"\n              (click)=\"selectOption(option)\"\n              (select)=\"selectOption(option)\"\n              [class.highlighted]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n            >\n              <ng-container *ngIf=\"optionTemplateRef; else basicDropdownOption\">\n                <ng-container\n                  *ngTemplateOutlet=\"optionTemplateRef; context: { $implicit: option, index: index, groupIndex: groupIndex }\"\n                ></ng-container>\n              </ng-container>\n              <ng-template #basicDropdownOption>\n                <lx-basic-dropdown-item\n                  [label]=\"option.label\"\n                  labelFontWeight=\"normal\"\n                  [highlightTerm]=\"highlightTerm\"\n                ></lx-basic-dropdown-item>\n              </ng-template>\n            </li>\n          </ng-template>\n        </ul>\n      </li>\n    </ng-container>\n    <lx-spinner *ngIf=\"loading\" [fadeBackground]=\"true\"></lx-spinner>\n  </ul>\n</div>\n"]}
|