myrta-ui 17.0.30 → 17.0.31
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/esm2022/lib/components/form/select/components/select/select.component.mjs +98 -0
- package/esm2022/lib/components/form/select/components/select-multi/select-multi.component.mjs +112 -0
- package/esm2022/lib/components/form/select/enums/index.mjs +1 -2
- package/esm2022/lib/components/form/select/helpers/clean-selected-items.helper.mjs +4 -0
- package/esm2022/lib/components/form/select/helpers/get-selected-items.helper.mjs +21 -0
- package/esm2022/lib/components/form/select/models/select-inner-item.model.mjs +2 -0
- package/esm2022/lib/components/form/select/models/select-item.model.mjs +2 -0
- package/esm2022/lib/components/form/select/select.module.mjs +15 -6
- package/esm2022/lib/components/popup/components/popup/popup.component.mjs +17 -6
- package/esm2022/lib/components/popup/components/popup-item/popup-item.component.mjs +8 -5
- package/esm2022/lib/components/popup/directives/popup-trigger.directive.mjs +43 -8
- package/esm2022/lib/services/modal-service/modal-service.service.mjs +4 -4
- package/esm2022/public-api.mjs +3 -2
- package/fesm2022/myrta-ui.mjs +253 -41
- package/fesm2022/myrta-ui.mjs.map +1 -1
- package/lib/components/form/select/components/select/select.component.d.ts +28 -0
- package/lib/components/form/select/components/select-multi/select-multi.component.d.ts +31 -0
- package/lib/components/form/select/enums/index.d.ts +0 -1
- package/lib/components/form/select/helpers/clean-selected-items.helper.d.ts +4 -0
- package/lib/components/form/select/helpers/get-selected-items.helper.d.ts +2 -0
- package/lib/components/form/select/models/select-inner-item.model.d.ts +5 -0
- package/lib/components/form/select/models/select-item.model.d.ts +3 -0
- package/lib/components/form/select/select.module.d.ts +6 -4
- package/lib/components/popup/components/popup/popup.component.d.ts +6 -2
- package/lib/components/popup/components/popup-item/popup-item.component.d.ts +2 -1
- package/lib/components/popup/directives/popup-trigger.directive.d.ts +9 -4
- package/package.json +1 -1
- package/public-api.d.ts +2 -1
- package/esm2022/lib/components/form/select/enums/select-type.enum.mjs +0 -6
- package/esm2022/lib/components/form/select/select.component.mjs +0 -62
- package/lib/components/form/select/enums/select-type.enum.d.ts +0 -5
- package/lib/components/form/select/select.component.d.ts +0 -21
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, forwardRef, Input, ViewChild } from '@angular/core';
|
|
2
|
+
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
+
import { SelectSizeEnum } from '../../enums';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "../../../../popup/components/popup/popup.component";
|
|
6
|
+
import * as i2 from "../../../../popup/components/popup-item/popup-item.component";
|
|
7
|
+
import * as i3 from "../../../../popup/directives/popup-trigger.directive";
|
|
8
|
+
import * as i4 from "@angular/common";
|
|
9
|
+
export class SelectComponent {
|
|
10
|
+
isOpen = false;
|
|
11
|
+
selected = null;
|
|
12
|
+
items = [];
|
|
13
|
+
size = 'large';
|
|
14
|
+
bindValue = null;
|
|
15
|
+
bindLabel = 'label';
|
|
16
|
+
bindIcon = 'icon';
|
|
17
|
+
dropdown;
|
|
18
|
+
get getClasses() {
|
|
19
|
+
return `${SelectSizeEnum[this.size]}`;
|
|
20
|
+
}
|
|
21
|
+
get getSelectedSingleLabels() {
|
|
22
|
+
return this.selected?.[this.bindLabel] || '';
|
|
23
|
+
}
|
|
24
|
+
onChange = (value) => { };
|
|
25
|
+
onTouched = () => { };
|
|
26
|
+
registerOnChange(fn) {
|
|
27
|
+
this.onChange = fn;
|
|
28
|
+
}
|
|
29
|
+
registerOnTouched(fn) {
|
|
30
|
+
this.onTouched = fn;
|
|
31
|
+
}
|
|
32
|
+
writeValue(selected) {
|
|
33
|
+
if (selected) {
|
|
34
|
+
this.selected = selected;
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
updateValue(selected) {
|
|
38
|
+
this.selected = selected;
|
|
39
|
+
// this.changed.emit(this.formatValue(insideValue));
|
|
40
|
+
// this.modelChange.emit({value: this.formatValue(insideValue), id: this.uuid})
|
|
41
|
+
this.onChange(this.bindValue ? this.selected[this.bindValue] : this.selected);
|
|
42
|
+
this.onTouched();
|
|
43
|
+
}
|
|
44
|
+
onSelect(item) {
|
|
45
|
+
this.selected = item;
|
|
46
|
+
this.updateValue(item);
|
|
47
|
+
}
|
|
48
|
+
onOpen(event) {
|
|
49
|
+
event.stopPropagation();
|
|
50
|
+
if (this.isOpen) {
|
|
51
|
+
this.dropdown.togglePopup(false);
|
|
52
|
+
}
|
|
53
|
+
else {
|
|
54
|
+
this.dropdown.togglePopup(true);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
onClear(event) {
|
|
58
|
+
event.stopPropagation();
|
|
59
|
+
this.selected = null;
|
|
60
|
+
this.updateValue(this.selected);
|
|
61
|
+
this.dropdown.togglePopup(false);
|
|
62
|
+
}
|
|
63
|
+
togglePopup(isOpen) {
|
|
64
|
+
this.isOpen = isOpen;
|
|
65
|
+
}
|
|
66
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SelectComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
67
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: SelectComponent, selector: "mrx-select", inputs: { items: "items", size: "size", bindValue: "bindValue", bindLabel: "bindLabel", bindIcon: "bindIcon" }, providers: [
|
|
68
|
+
{
|
|
69
|
+
provide: NG_VALUE_ACCESSOR,
|
|
70
|
+
useExisting: forwardRef(() => SelectComponent),
|
|
71
|
+
multi: true,
|
|
72
|
+
},
|
|
73
|
+
], viewQueries: [{ propertyName: "dropdown", first: true, predicate: ["dropdown"], descendants: true }], ngImport: i0, template: "<div class=\"mrx-select\" [class]=\"getClasses\">\r\n <div class=\"mrx-select__wrapper\">\r\n {{ selected | json }}\r\n <div class=\"mrx-select__input\" [mrxPopupTrigger]=\"dropdown\">\r\n <div class=\"mrx-select__input__box\">\r\n @if (getSelectedSingleLabels) {\r\n <div class=\"mrx-select__input__value\">{{ getSelectedSingleLabels }}</div>\r\n } @else {\r\n <div class=\"mrx-select__input__placeholder\"></div>\r\n }\r\n </div>\r\n\r\n <div class=\"mrx-select__input__controls\">\r\n @if (selected) {\r\n <div class=\"mrx-select__input__controls--item\" (click)=\"onClear($event)\">\r\n <span class=\"mrx-icon icon-close icon-font-24\"></span>\r\n </div>\r\n }\r\n <div class=\"mrx-select__input__controls--item\" (click)=\"onOpen($event)\">\r\n @if (isOpen) {\r\n <span class=\"mrx-icon icon-chevron-up icon-font-24\"></span>\r\n } @else {\r\n <span class=\"mrx-icon icon-chevron-down icon-font-24\"></span>\r\n }\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <mrx-popup #dropdown [closeAfterClick]=\"true\" (toggle)=\"togglePopup($event)\">\r\n @for (item of items; track item.name) {\r\n <mrx-popup-item [custom]=\"true\" (clicked)=\"onSelect(item)\">\r\n {{ item.label }}\r\n </mrx-popup-item>\r\n }\r\n </mrx-popup>\r\n </div>\r\n</div>\r\n", styles: [".mrx-select__input{border:var(--border-width-default) solid var(--neutral-bg-stroke-default);border-radius:var(--border-radius-1);width:100%;outline:none;transition:outline-width .2s,border .2s;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:8px}.mrx-select__input:focus,.mrx-select__input:active{outline:var(--neutral-bg-island-default) solid var(--border-width-focused)}.mrx-select__input:hover{border:var(--border-width-default) solid var(--neutral-bg-stroke-hover)}.mrx-select__input__box{flex-grow:1}.mrx-select__input__controls{display:flex;align-items:center;gap:8px}.mrx-select__input__controls--item{display:flex;align-items:center;justify-content:center;border-radius:4px;background-color:transparent;transition:background-color .2s}.mrx-select__input__controls--item:hover{background-color:var(--brand-bg-tertiary-hover, #EDF5FF)}.mrx-select.mrx-select-lg .mrx-select__input{font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height);padding:calc(var(--spacing-3) - var(--border-width-default)) var(--spacing-4)}.mrx-select.mrx-select-lg .mrx-select__input__box{min-height:24px}.mrx-select__dropdown__item{padding:8px 16px;background-color:transparent;transition:background-color .3s;cursor:pointer;font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height)}.mrx-select__dropdown__item:hover{background-color:var(--brand-bg-tertiary-hover, #EDF5FF)}\n"], dependencies: [{ kind: "component", type: i1.PopupComponent, selector: "mrx-popup", inputs: ["closeAfterClick"], outputs: ["toggle", "_toggleInner", "_updateInner"] }, { kind: "component", type: i2.PopupItemComponent, selector: "mrx-popup-item", inputs: ["custom"], outputs: ["clicked"] }, { kind: "directive", type: i3.PopupTriggerDirective, selector: "[mrxPopupTrigger]", inputs: ["mrxPopupTrigger", "popupPosition"] }, { kind: "pipe", type: i4.JsonPipe, name: "json" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
74
|
+
}
|
|
75
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SelectComponent, decorators: [{
|
|
76
|
+
type: Component,
|
|
77
|
+
args: [{ selector: 'mrx-select', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
78
|
+
{
|
|
79
|
+
provide: NG_VALUE_ACCESSOR,
|
|
80
|
+
useExisting: forwardRef(() => SelectComponent),
|
|
81
|
+
multi: true,
|
|
82
|
+
},
|
|
83
|
+
], template: "<div class=\"mrx-select\" [class]=\"getClasses\">\r\n <div class=\"mrx-select__wrapper\">\r\n {{ selected | json }}\r\n <div class=\"mrx-select__input\" [mrxPopupTrigger]=\"dropdown\">\r\n <div class=\"mrx-select__input__box\">\r\n @if (getSelectedSingleLabels) {\r\n <div class=\"mrx-select__input__value\">{{ getSelectedSingleLabels }}</div>\r\n } @else {\r\n <div class=\"mrx-select__input__placeholder\"></div>\r\n }\r\n </div>\r\n\r\n <div class=\"mrx-select__input__controls\">\r\n @if (selected) {\r\n <div class=\"mrx-select__input__controls--item\" (click)=\"onClear($event)\">\r\n <span class=\"mrx-icon icon-close icon-font-24\"></span>\r\n </div>\r\n }\r\n <div class=\"mrx-select__input__controls--item\" (click)=\"onOpen($event)\">\r\n @if (isOpen) {\r\n <span class=\"mrx-icon icon-chevron-up icon-font-24\"></span>\r\n } @else {\r\n <span class=\"mrx-icon icon-chevron-down icon-font-24\"></span>\r\n }\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <mrx-popup #dropdown [closeAfterClick]=\"true\" (toggle)=\"togglePopup($event)\">\r\n @for (item of items; track item.name) {\r\n <mrx-popup-item [custom]=\"true\" (clicked)=\"onSelect(item)\">\r\n {{ item.label }}\r\n </mrx-popup-item>\r\n }\r\n </mrx-popup>\r\n </div>\r\n</div>\r\n", styles: [".mrx-select__input{border:var(--border-width-default) solid var(--neutral-bg-stroke-default);border-radius:var(--border-radius-1);width:100%;outline:none;transition:outline-width .2s,border .2s;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:8px}.mrx-select__input:focus,.mrx-select__input:active{outline:var(--neutral-bg-island-default) solid var(--border-width-focused)}.mrx-select__input:hover{border:var(--border-width-default) solid var(--neutral-bg-stroke-hover)}.mrx-select__input__box{flex-grow:1}.mrx-select__input__controls{display:flex;align-items:center;gap:8px}.mrx-select__input__controls--item{display:flex;align-items:center;justify-content:center;border-radius:4px;background-color:transparent;transition:background-color .2s}.mrx-select__input__controls--item:hover{background-color:var(--brand-bg-tertiary-hover, #EDF5FF)}.mrx-select.mrx-select-lg .mrx-select__input{font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height);padding:calc(var(--spacing-3) - var(--border-width-default)) var(--spacing-4)}.mrx-select.mrx-select-lg .mrx-select__input__box{min-height:24px}.mrx-select__dropdown__item{padding:8px 16px;background-color:transparent;transition:background-color .3s;cursor:pointer;font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height)}.mrx-select__dropdown__item:hover{background-color:var(--brand-bg-tertiary-hover, #EDF5FF)}\n"] }]
|
|
84
|
+
}], propDecorators: { items: [{
|
|
85
|
+
type: Input
|
|
86
|
+
}], size: [{
|
|
87
|
+
type: Input
|
|
88
|
+
}], bindValue: [{
|
|
89
|
+
type: Input
|
|
90
|
+
}], bindLabel: [{
|
|
91
|
+
type: Input
|
|
92
|
+
}], bindIcon: [{
|
|
93
|
+
type: Input
|
|
94
|
+
}], dropdown: [{
|
|
95
|
+
type: ViewChild,
|
|
96
|
+
args: ['dropdown']
|
|
97
|
+
}] } });
|
|
98
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/myrta-ui/src/lib/components/form/select/components/select/select.component.ts","../../../../../../../../../projects/myrta-ui/src/lib/components/form/select/components/select/select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  forwardRef,\r\n  Input,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { SelectSizeEnum, SelectSizeTypes } from '../../enums';\r\nimport { PopupComponent } from '../../../../popup/components/popup/popup.component';\r\n\r\n@Component({\r\n  selector: 'mrx-select',\r\n  templateUrl: './select.component.html',\r\n  styleUrl: './select.component.less',\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => SelectComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class SelectComponent implements ControlValueAccessor {\r\n  public isOpen: boolean = false\r\n  public selected: any | any[] = null;\r\n\r\n  @Input() items: any[] = [];\r\n  @Input() size: SelectSizeTypes = 'large';\r\n  @Input() bindValue: string | null = null;\r\n  @Input() bindLabel: string = 'label';\r\n  @Input() bindIcon: string = 'icon';\r\n\r\n  @ViewChild('dropdown') dropdown!: PopupComponent;\r\n\r\n  public get getClasses(): string {\r\n    return `${SelectSizeEnum[this.size]}`;\r\n  }\r\n\r\n  public get getSelectedSingleLabels(): string {\r\n    return this.selected?.[this.bindLabel] || ''\r\n  }\r\n\r\n  private onChange = (value: any) => {};\r\n  private onTouched = () => {};\r\n\r\n  public registerOnChange(fn: any) {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  public registerOnTouched(fn: () => {}): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  writeValue(selected: any): void {\r\n    if (selected) {\r\n      this.selected = selected\r\n    }\r\n  }\r\n\r\n  public updateValue(selected: any) {\r\n    this.selected = selected;\r\n    // this.changed.emit(this.formatValue(insideValue));\r\n    // this.modelChange.emit({value: this.formatValue(insideValue), id: this.uuid})\r\n    this.onChange(this.bindValue ? this.selected[this.bindValue] : this.selected);\r\n    this.onTouched();\r\n  }\r\n\r\n  public onSelect(item: any) {\r\n    this.selected = item\r\n\r\n    this.updateValue(item)\r\n  }\r\n\r\n  public onOpen(event: MouseEvent) {\r\n    event.stopPropagation()\r\n\r\n    if (this.isOpen) {\r\n      this.dropdown.togglePopup(false)\r\n    } else {\r\n      this.dropdown.togglePopup(true)\r\n    }\r\n  }\r\n\r\n  public onClear(event: MouseEvent) {\r\n    event.stopPropagation()\r\n\r\n    this.selected = null\r\n\r\n    this.updateValue(this.selected)\r\n\r\n    this.dropdown.togglePopup(false)\r\n  }\r\n\r\n  public togglePopup(isOpen: boolean) {\r\n    this.isOpen = isOpen\r\n  }\r\n}\r\n","<div class=\"mrx-select\" [class]=\"getClasses\">\r\n  <div class=\"mrx-select__wrapper\">\r\n    {{ selected | json }}\r\n    <div class=\"mrx-select__input\" [mrxPopupTrigger]=\"dropdown\">\r\n      <div class=\"mrx-select__input__box\">\r\n        @if (getSelectedSingleLabels) {\r\n          <div class=\"mrx-select__input__value\">{{ getSelectedSingleLabels }}</div>\r\n        } @else {\r\n          <div class=\"mrx-select__input__placeholder\"></div>\r\n        }\r\n      </div>\r\n\r\n      <div class=\"mrx-select__input__controls\">\r\n        @if (selected) {\r\n          <div class=\"mrx-select__input__controls--item\" (click)=\"onClear($event)\">\r\n            <span class=\"mrx-icon icon-close icon-font-24\"></span>\r\n          </div>\r\n        }\r\n        <div class=\"mrx-select__input__controls--item\" (click)=\"onOpen($event)\">\r\n          @if (isOpen) {\r\n            <span class=\"mrx-icon icon-chevron-up icon-font-24\"></span>\r\n          } @else {\r\n            <span class=\"mrx-icon icon-chevron-down icon-font-24\"></span>\r\n          }\r\n        </div>\r\n      </div>\r\n    </div>\r\n\r\n    <mrx-popup #dropdown [closeAfterClick]=\"true\" (toggle)=\"togglePopup($event)\">\r\n      @for (item of items; track item.name) {\r\n        <mrx-popup-item [custom]=\"true\" (clicked)=\"onSelect(item)\">\r\n          {{ item.label }}\r\n        </mrx-popup-item>\r\n      }\r\n    </mrx-popup>\r\n  </div>\r\n</div>\r\n"]}
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, forwardRef, Input, ViewChild } from '@angular/core';
|
|
2
|
+
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
+
import { SelectSizeEnum } from '../../enums';
|
|
4
|
+
import { getSelectedItems } from '../../helpers/get-selected-items.helper';
|
|
5
|
+
import { isEqual } from 'lodash-es';
|
|
6
|
+
import { cleanSelectedItems } from '../../helpers/clean-selected-items.helper';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "../../../../popup/components/popup/popup.component";
|
|
9
|
+
import * as i2 from "../../../../popup/components/popup-item/popup-item.component";
|
|
10
|
+
import * as i3 from "../../../../popup/directives/popup-trigger.directive";
|
|
11
|
+
export class SelectMultiComponent {
|
|
12
|
+
isOpen = false;
|
|
13
|
+
originItems = [];
|
|
14
|
+
innerItems = [];
|
|
15
|
+
set items(list) {
|
|
16
|
+
this.originItems = list;
|
|
17
|
+
this.innerItems = list.map((item, idx) => ({
|
|
18
|
+
...item, __id: item['id'] || idx, __selected: false
|
|
19
|
+
}));
|
|
20
|
+
}
|
|
21
|
+
size = 'large';
|
|
22
|
+
bindValue = null;
|
|
23
|
+
bindLabel = 'label';
|
|
24
|
+
bindIcon = 'icon';
|
|
25
|
+
dropdown;
|
|
26
|
+
get getClasses() {
|
|
27
|
+
return `${SelectSizeEnum[this.size]}`;
|
|
28
|
+
}
|
|
29
|
+
get getSelectedMultiLabels() {
|
|
30
|
+
return this.innerItems.filter(i => i.__selected);
|
|
31
|
+
}
|
|
32
|
+
onChange = (value) => {
|
|
33
|
+
};
|
|
34
|
+
onTouched = () => {
|
|
35
|
+
};
|
|
36
|
+
registerOnChange(fn) {
|
|
37
|
+
this.onChange = fn;
|
|
38
|
+
}
|
|
39
|
+
registerOnTouched(fn) {
|
|
40
|
+
this.onTouched = fn;
|
|
41
|
+
}
|
|
42
|
+
writeValue(selected = []) {
|
|
43
|
+
if (selected) {
|
|
44
|
+
this.innerItems = this.originItems.map((item, idx) => {
|
|
45
|
+
const findItem = selected.find(i => isEqual(i, item));
|
|
46
|
+
return { ...item, __id: item['id'] || idx, __selected: !!findItem };
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
updateValue(selected) {
|
|
51
|
+
console.log(selected);
|
|
52
|
+
// this.changed.emit(this.formatValue(insideValue));
|
|
53
|
+
// this.modelChange.emit({value: this.formatValue(insideValue), id: this.uuid})
|
|
54
|
+
// this.onChange(getSelectedItems(this.selected, this.bindValue));
|
|
55
|
+
this.onTouched();
|
|
56
|
+
}
|
|
57
|
+
onSelectMulti(item) {
|
|
58
|
+
item.__selected = !item.__selected;
|
|
59
|
+
this.dropdown.updatePopup();
|
|
60
|
+
this.updateValue(getSelectedItems(cleanSelectedItems(this.innerItems.filter(item => item.__selected)), this.bindValue));
|
|
61
|
+
}
|
|
62
|
+
onOpen(event) {
|
|
63
|
+
event.stopPropagation();
|
|
64
|
+
if (this.isOpen) {
|
|
65
|
+
this.dropdown.togglePopup(false);
|
|
66
|
+
}
|
|
67
|
+
else {
|
|
68
|
+
this.dropdown.togglePopup(true);
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
onClear(event) {
|
|
72
|
+
event.stopPropagation();
|
|
73
|
+
this.innerItems = this.innerItems.map(item => ({ ...item, __selected: false }));
|
|
74
|
+
this.dropdown.togglePopup(false);
|
|
75
|
+
this.updateValue([]);
|
|
76
|
+
}
|
|
77
|
+
togglePopup(isOpen) {
|
|
78
|
+
this.isOpen = isOpen;
|
|
79
|
+
}
|
|
80
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SelectMultiComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
81
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: SelectMultiComponent, selector: "mrx-select-multi", inputs: { items: "items", size: "size", bindValue: "bindValue", bindLabel: "bindLabel", bindIcon: "bindIcon" }, providers: [
|
|
82
|
+
{
|
|
83
|
+
provide: NG_VALUE_ACCESSOR,
|
|
84
|
+
useExisting: forwardRef(() => SelectMultiComponent),
|
|
85
|
+
multi: true,
|
|
86
|
+
},
|
|
87
|
+
], viewQueries: [{ propertyName: "dropdown", first: true, predicate: ["dropdown"], descendants: true }], ngImport: i0, template: "<div class=\"mrx-select\" [class]=\"getClasses\">\r\n <div class=\"mrx-select__wrapper\">\r\n <div class=\"mrx-select__input\" [mrxPopupTrigger]=\"dropdown\">\r\n <div class=\"mrx-select__input__box\">\r\n @if (getSelectedMultiLabels.length) {\r\n <div class=\"mrx-select__input__value\">\r\n @for (item of getSelectedMultiLabels; track item) {\r\n {{ item[bindLabel] }}\r\n }\r\n </div>\r\n } @else {\r\n <div class=\"mrx-select__input__placeholder\"></div>\r\n }\r\n </div>\r\n\r\n <div class=\"mrx-select__input__controls\">\r\n @if (getSelectedMultiLabels.length) {\r\n <div class=\"mrx-select__input__controls--item\" (click)=\"onClear($event)\">\r\n <span class=\"mrx-icon icon-close icon-font-24\"></span>\r\n </div>\r\n }\r\n <div class=\"mrx-select__input__controls--item\" (click)=\"onOpen($event)\">\r\n @if (isOpen) {\r\n <span class=\"mrx-icon icon-chevron-up icon-font-24\"></span>\r\n } @else {\r\n <span class=\"mrx-icon icon-chevron-down icon-font-24\"></span>\r\n }\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <mrx-popup #dropdown [closeAfterClick]=\"false\" (toggle)=\"togglePopup($event)\">\r\n @for (item of innerItems; track item.__id) {\r\n <mrx-popup-item [custom]=\"true\" (clicked)=\"onSelectMulti(item)\">\r\n {{ item['label'] }}\r\n </mrx-popup-item>\r\n }\r\n </mrx-popup>\r\n </div>\r\n</div>\r\n", styles: [".mrx-select__input{border:var(--border-width-default) solid var(--neutral-bg-stroke-default);border-radius:var(--border-radius-1);width:100%;outline:none;transition:outline-width .2s,border .2s;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:8px}.mrx-select__input:focus,.mrx-select__input:active{outline:var(--neutral-bg-island-default) solid var(--border-width-focused)}.mrx-select__input:hover{border:var(--border-width-default) solid var(--neutral-bg-stroke-hover)}.mrx-select__input__box{flex-grow:1}.mrx-select__input__controls{display:flex;align-items:center;gap:8px}.mrx-select__input__controls--item{display:flex;align-items:center;justify-content:center;border-radius:4px;background-color:transparent;transition:background-color .2s}.mrx-select__input__controls--item:hover{background-color:var(--brand-bg-tertiary-hover, #EDF5FF)}.mrx-select.mrx-select-lg .mrx-select__input{font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height);padding:calc(var(--spacing-3) - var(--border-width-default)) var(--spacing-4)}.mrx-select.mrx-select-lg .mrx-select__input__box{min-height:24px}.mrx-select__dropdown__item{padding:8px 16px;background-color:transparent;transition:background-color .3s;cursor:pointer;font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height)}.mrx-select__dropdown__item:hover{background-color:var(--brand-bg-tertiary-hover, #EDF5FF)}\n"], dependencies: [{ kind: "component", type: i1.PopupComponent, selector: "mrx-popup", inputs: ["closeAfterClick"], outputs: ["toggle", "_toggleInner", "_updateInner"] }, { kind: "component", type: i2.PopupItemComponent, selector: "mrx-popup-item", inputs: ["custom"], outputs: ["clicked"] }, { kind: "directive", type: i3.PopupTriggerDirective, selector: "[mrxPopupTrigger]", inputs: ["mrxPopupTrigger", "popupPosition"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
88
|
+
}
|
|
89
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SelectMultiComponent, decorators: [{
|
|
90
|
+
type: Component,
|
|
91
|
+
args: [{ selector: 'mrx-select-multi', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
92
|
+
{
|
|
93
|
+
provide: NG_VALUE_ACCESSOR,
|
|
94
|
+
useExisting: forwardRef(() => SelectMultiComponent),
|
|
95
|
+
multi: true,
|
|
96
|
+
},
|
|
97
|
+
], template: "<div class=\"mrx-select\" [class]=\"getClasses\">\r\n <div class=\"mrx-select__wrapper\">\r\n <div class=\"mrx-select__input\" [mrxPopupTrigger]=\"dropdown\">\r\n <div class=\"mrx-select__input__box\">\r\n @if (getSelectedMultiLabels.length) {\r\n <div class=\"mrx-select__input__value\">\r\n @for (item of getSelectedMultiLabels; track item) {\r\n {{ item[bindLabel] }}\r\n }\r\n </div>\r\n } @else {\r\n <div class=\"mrx-select__input__placeholder\"></div>\r\n }\r\n </div>\r\n\r\n <div class=\"mrx-select__input__controls\">\r\n @if (getSelectedMultiLabels.length) {\r\n <div class=\"mrx-select__input__controls--item\" (click)=\"onClear($event)\">\r\n <span class=\"mrx-icon icon-close icon-font-24\"></span>\r\n </div>\r\n }\r\n <div class=\"mrx-select__input__controls--item\" (click)=\"onOpen($event)\">\r\n @if (isOpen) {\r\n <span class=\"mrx-icon icon-chevron-up icon-font-24\"></span>\r\n } @else {\r\n <span class=\"mrx-icon icon-chevron-down icon-font-24\"></span>\r\n }\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <mrx-popup #dropdown [closeAfterClick]=\"false\" (toggle)=\"togglePopup($event)\">\r\n @for (item of innerItems; track item.__id) {\r\n <mrx-popup-item [custom]=\"true\" (clicked)=\"onSelectMulti(item)\">\r\n {{ item['label'] }}\r\n </mrx-popup-item>\r\n }\r\n </mrx-popup>\r\n </div>\r\n</div>\r\n", styles: [".mrx-select__input{border:var(--border-width-default) solid var(--neutral-bg-stroke-default);border-radius:var(--border-radius-1);width:100%;outline:none;transition:outline-width .2s,border .2s;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:8px}.mrx-select__input:focus,.mrx-select__input:active{outline:var(--neutral-bg-island-default) solid var(--border-width-focused)}.mrx-select__input:hover{border:var(--border-width-default) solid var(--neutral-bg-stroke-hover)}.mrx-select__input__box{flex-grow:1}.mrx-select__input__controls{display:flex;align-items:center;gap:8px}.mrx-select__input__controls--item{display:flex;align-items:center;justify-content:center;border-radius:4px;background-color:transparent;transition:background-color .2s}.mrx-select__input__controls--item:hover{background-color:var(--brand-bg-tertiary-hover, #EDF5FF)}.mrx-select.mrx-select-lg .mrx-select__input{font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height);padding:calc(var(--spacing-3) - var(--border-width-default)) var(--spacing-4)}.mrx-select.mrx-select-lg .mrx-select__input__box{min-height:24px}.mrx-select__dropdown__item{padding:8px 16px;background-color:transparent;transition:background-color .3s;cursor:pointer;font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height)}.mrx-select__dropdown__item:hover{background-color:var(--brand-bg-tertiary-hover, #EDF5FF)}\n"] }]
|
|
98
|
+
}], propDecorators: { items: [{
|
|
99
|
+
type: Input
|
|
100
|
+
}], size: [{
|
|
101
|
+
type: Input
|
|
102
|
+
}], bindValue: [{
|
|
103
|
+
type: Input
|
|
104
|
+
}], bindLabel: [{
|
|
105
|
+
type: Input
|
|
106
|
+
}], bindIcon: [{
|
|
107
|
+
type: Input
|
|
108
|
+
}], dropdown: [{
|
|
109
|
+
type: ViewChild,
|
|
110
|
+
args: ['dropdown']
|
|
111
|
+
}] } });
|
|
112
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-multi.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/myrta-ui/src/lib/components/form/select/components/select-multi/select-multi.component.ts","../../../../../../../../../projects/myrta-ui/src/lib/components/form/select/components/select-multi/select-multi.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  forwardRef,\r\n  Input,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { SelectSizeEnum, SelectSizeTypes } from '../../enums';\r\nimport { PopupComponent } from '../../../../popup/components/popup/popup.component';\r\nimport { SelectInnerItemModel } from '../../models/select-inner-item.model';\r\nimport { SelectItemModel } from '../../models/select-item.model';\r\nimport { getSelectedItems } from '../../helpers/get-selected-items.helper';\r\nimport { isEqual } from 'lodash-es';\r\nimport { cleanSelectedItems } from '../../helpers/clean-selected-items.helper';\r\n\r\n@Component({\r\n  selector: 'mrx-select-multi',\r\n  templateUrl: './select-multi.component.html',\r\n  styleUrl: './select-multi.component.less',\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => SelectMultiComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class SelectMultiComponent implements ControlValueAccessor {\r\n  public isOpen: boolean = false;\r\n  public originItems: SelectItemModel[] = [];\r\n  public innerItems: SelectInnerItemModel[] = [];\r\n\r\n\r\n  @Input() set items(list: SelectItemModel[]) {\r\n    this.originItems = list;\r\n\r\n    this.innerItems = list.map((item, idx) => ({\r\n      ...item, __id: item['id'] || idx, __selected: false\r\n    }));\r\n  }\r\n\r\n  @Input() size: SelectSizeTypes = 'large';\r\n  @Input() bindValue: string | null = null;\r\n  @Input() bindLabel: string = 'label';\r\n  @Input() bindIcon: string = 'icon';\r\n\r\n  @ViewChild('dropdown') dropdown!: PopupComponent;\r\n\r\n  public get getClasses(): string {\r\n    return `${SelectSizeEnum[this.size]}`;\r\n  }\r\n\r\n  public get getSelectedMultiLabels(): SelectInnerItemModel[] {\r\n    return this.innerItems.filter(i => i.__selected);\r\n  }\r\n\r\n  private onChange = (value: any) => {\r\n  };\r\n  private onTouched = () => {\r\n  };\r\n\r\n  public registerOnChange(fn: any) {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  public registerOnTouched(fn: () => {}): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  writeValue(selected: any[] = []): void {\r\n    if (selected) {\r\n      this.innerItems = this.originItems.map((item, idx): SelectInnerItemModel => {\r\n        const findItem = selected.find(i => isEqual(i, item));\r\n\r\n        return {...item, __id: item['id'] || idx, __selected: !!findItem};\r\n      });\r\n    }\r\n  }\r\n\r\n  public updateValue(selected: any) {\r\n    console.log(selected);\r\n    // this.changed.emit(this.formatValue(insideValue));\r\n    // this.modelChange.emit({value: this.formatValue(insideValue), id: this.uuid})\r\n    // this.onChange(getSelectedItems(this.selected, this.bindValue));\r\n    this.onTouched();\r\n  }\r\n\r\n  public onSelectMulti(item: any) {\r\n    item.__selected = !item.__selected;\r\n\r\n    this.dropdown.updatePopup();\r\n\r\n    this.updateValue(\r\n      getSelectedItems(\r\n        cleanSelectedItems(this.innerItems.filter(item => item.__selected)),\r\n        this.bindValue\r\n      )\r\n    );\r\n  }\r\n\r\n  public onOpen(event: MouseEvent) {\r\n    event.stopPropagation();\r\n\r\n    if (this.isOpen) {\r\n      this.dropdown.togglePopup(false);\r\n    } else {\r\n      this.dropdown.togglePopup(true);\r\n    }\r\n  }\r\n\r\n  public onClear(event: MouseEvent) {\r\n    event.stopPropagation();\r\n\r\n    this.innerItems = this.innerItems.map(item => ({...item, __selected: false}));\r\n\r\n    this.dropdown.togglePopup(false);\r\n\r\n    this.updateValue([]);\r\n  }\r\n\r\n  public togglePopup(isOpen: boolean) {\r\n    this.isOpen = isOpen;\r\n  }\r\n}\r\n","<div class=\"mrx-select\" [class]=\"getClasses\">\r\n  <div class=\"mrx-select__wrapper\">\r\n    <div class=\"mrx-select__input\" [mrxPopupTrigger]=\"dropdown\">\r\n      <div class=\"mrx-select__input__box\">\r\n        @if (getSelectedMultiLabels.length) {\r\n          <div class=\"mrx-select__input__value\">\r\n            @for (item of getSelectedMultiLabels; track item) {\r\n              {{ item[bindLabel] }}\r\n            }\r\n          </div>\r\n        } @else {\r\n          <div class=\"mrx-select__input__placeholder\"></div>\r\n        }\r\n      </div>\r\n\r\n      <div class=\"mrx-select__input__controls\">\r\n        @if (getSelectedMultiLabels.length) {\r\n          <div class=\"mrx-select__input__controls--item\" (click)=\"onClear($event)\">\r\n            <span class=\"mrx-icon icon-close icon-font-24\"></span>\r\n          </div>\r\n        }\r\n        <div class=\"mrx-select__input__controls--item\" (click)=\"onOpen($event)\">\r\n          @if (isOpen) {\r\n            <span class=\"mrx-icon icon-chevron-up icon-font-24\"></span>\r\n          } @else {\r\n            <span class=\"mrx-icon icon-chevron-down icon-font-24\"></span>\r\n          }\r\n        </div>\r\n      </div>\r\n    </div>\r\n\r\n    <mrx-popup #dropdown [closeAfterClick]=\"false\" (toggle)=\"togglePopup($event)\">\r\n      @for (item of innerItems; track item.__id) {\r\n        <mrx-popup-item [custom]=\"true\" (clicked)=\"onSelectMulti(item)\">\r\n          {{ item['label'] }}\r\n        </mrx-popup-item>\r\n      }\r\n    </mrx-popup>\r\n  </div>\r\n</div>\r\n"]}
|
|
@@ -1,3 +1,2 @@
|
|
|
1
1
|
export * from './select-size.enum';
|
|
2
|
-
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9teXJ0YS11aS9zcmMvbGliL2NvbXBvbmVudHMvZm9ybS9zZWxlY3QvZW51bXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxvQkFBb0IsQ0FBQTtBQUNsQyxjQUFjLG9CQUFvQixDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9zZWxlY3Qtc2l6ZS5lbnVtJ1xyXG5leHBvcnQgKiBmcm9tICcuL3NlbGVjdC10eXBlLmVudW0nXHJcbiJdfQ==
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9teXJ0YS11aS9zcmMvbGliL2NvbXBvbmVudHMvZm9ybS9zZWxlY3QvZW51bXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxvQkFBb0IsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vc2VsZWN0LXNpemUuZW51bSdcclxuIl19
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export const cleanSelectedItems = (innerList) => {
|
|
2
|
+
return innerList.map(({ __id, __selected, ...rest }) => rest);
|
|
3
|
+
};
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xlYW4tc2VsZWN0ZWQtaXRlbXMuaGVscGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXlydGEtdWkvc3JjL2xpYi9jb21wb25lbnRzL2Zvcm0vc2VsZWN0L2hlbHBlcnMvY2xlYW4tc2VsZWN0ZWQtaXRlbXMuaGVscGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLENBQUMsU0FBaUMsRUFBRSxFQUFFO0lBQ3RFLE9BQU8sU0FBUyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQUMsSUFBSSxFQUFFLFVBQVUsRUFBRSxHQUFHLElBQUksRUFBQyxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQztBQUM5RCxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTZWxlY3RJbm5lckl0ZW1Nb2RlbCB9IGZyb20gJy4uL21vZGVscy9zZWxlY3QtaW5uZXItaXRlbS5tb2RlbCc7XHJcblxyXG5leHBvcnQgY29uc3QgY2xlYW5TZWxlY3RlZEl0ZW1zID0gKGlubmVyTGlzdDogU2VsZWN0SW5uZXJJdGVtTW9kZWxbXSkgPT4ge1xyXG4gIHJldHVybiBpbm5lckxpc3QubWFwKCh7X19pZCwgX19zZWxlY3RlZCwgLi4ucmVzdH0pID0+IHJlc3QpO1xyXG59O1xyXG4iXX0=
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
export const getSelectedItems = (selected, bindValue) => {
|
|
2
|
+
if (bindValue) {
|
|
3
|
+
const modifiedSelected = [];
|
|
4
|
+
for (let item of selected) {
|
|
5
|
+
for (let key in item) {
|
|
6
|
+
if (item.hasOwnProperty(bindValue) && key === bindValue) {
|
|
7
|
+
modifiedSelected.push(item[bindValue]);
|
|
8
|
+
}
|
|
9
|
+
if (!item.hasOwnProperty(bindValue)) {
|
|
10
|
+
modifiedSelected.push(null);
|
|
11
|
+
break;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
return modifiedSelected;
|
|
16
|
+
}
|
|
17
|
+
else {
|
|
18
|
+
return selected;
|
|
19
|
+
}
|
|
20
|
+
};
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0LXNlbGVjdGVkLWl0ZW1zLmhlbHBlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL215cnRhLXVpL3NyYy9saWIvY29tcG9uZW50cy9mb3JtL3NlbGVjdC9oZWxwZXJzL2dldC1zZWxlY3RlZC1pdGVtcy5oZWxwZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxDQUFDLE1BQU0sZ0JBQWdCLEdBQUcsQ0FBQyxRQUEyQixFQUFFLFNBQXdCLEVBQUUsRUFBRTtJQUN4RixJQUFJLFNBQVMsRUFBRSxDQUFDO1FBQ2QsTUFBTSxnQkFBZ0IsR0FBUSxFQUFFLENBQUE7UUFFaEMsS0FBSyxJQUFJLElBQUksSUFBSSxRQUFRLEVBQUUsQ0FBQztZQUMxQixLQUFLLElBQUksR0FBRyxJQUFJLElBQUksRUFBRSxDQUFDO2dCQUNyQixJQUFJLElBQUksQ0FBQyxjQUFjLENBQUMsU0FBUyxDQUFDLElBQUksR0FBRyxLQUFLLFNBQVMsRUFBRSxDQUFDO29CQUN4RCxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUE7Z0JBQ3hDLENBQUM7Z0JBRUQsSUFBSSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsU0FBUyxDQUFDLEVBQUUsQ0FBQztvQkFDcEMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFBO29CQUMzQixNQUFLO2dCQUNQLENBQUM7WUFDSCxDQUFDO1FBQ0gsQ0FBQztRQUVELE9BQU8sZ0JBQWdCLENBQUE7SUFDekIsQ0FBQztTQUFNLENBQUM7UUFDTixPQUFPLFFBQVEsQ0FBQTtJQUNqQixDQUFDO0FBQ0gsQ0FBQyxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtTZWxlY3RJdGVtTW9kZWx9IGZyb20gXCIuLi9tb2RlbHMvc2VsZWN0LWl0ZW0ubW9kZWxcIjtcclxuXHJcbmV4cG9ydCBjb25zdCBnZXRTZWxlY3RlZEl0ZW1zID0gKHNlbGVjdGVkOiBTZWxlY3RJdGVtTW9kZWxbXSwgYmluZFZhbHVlOiBzdHJpbmcgfCBudWxsKSA9PiB7XHJcbiAgaWYgKGJpbmRWYWx1ZSkge1xyXG4gICAgY29uc3QgbW9kaWZpZWRTZWxlY3RlZDogYW55ID0gW11cclxuXHJcbiAgICBmb3IgKGxldCBpdGVtIG9mIHNlbGVjdGVkKSB7XHJcbiAgICAgIGZvciAobGV0IGtleSBpbiBpdGVtKSB7XHJcbiAgICAgICAgaWYgKGl0ZW0uaGFzT3duUHJvcGVydHkoYmluZFZhbHVlKSAmJiBrZXkgPT09IGJpbmRWYWx1ZSkge1xyXG4gICAgICAgICAgbW9kaWZpZWRTZWxlY3RlZC5wdXNoKGl0ZW1bYmluZFZhbHVlXSlcclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIGlmICghaXRlbS5oYXNPd25Qcm9wZXJ0eShiaW5kVmFsdWUpKSB7XHJcbiAgICAgICAgICBtb2RpZmllZFNlbGVjdGVkLnB1c2gobnVsbClcclxuICAgICAgICAgIGJyZWFrXHJcbiAgICAgICAgfVxyXG4gICAgICB9XHJcbiAgICB9XHJcblxyXG4gICAgcmV0dXJuIG1vZGlmaWVkU2VsZWN0ZWRcclxuICB9IGVsc2Uge1xyXG4gICAgcmV0dXJuIHNlbGVjdGVkXHJcbiAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0LWlubmVyLWl0ZW0ubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9teXJ0YS11aS9zcmMvbGliL2NvbXBvbmVudHMvZm9ybS9zZWxlY3QvbW9kZWxzL3NlbGVjdC1pbm5lci1pdGVtLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIFNlbGVjdElubmVySXRlbU1vZGVsIHtcclxuICBbbmFtZTogc3RyaW5nXTogYW55O1xyXG5cclxuICBfX2lkOiBudW1iZXI7XHJcbiAgX19zZWxlY3RlZDogYm9vbGVhbjtcclxufVxyXG4iXX0=
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0LWl0ZW0ubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9teXJ0YS11aS9zcmMvbGliL2NvbXBvbmVudHMvZm9ybS9zZWxlY3QvbW9kZWxzL3NlbGVjdC1pdGVtLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIFNlbGVjdEl0ZW1Nb2RlbCB7XHJcbiAgW25hbWU6IHN0cmluZ106IGFueTtcclxufVxyXG4iXX0=
|
|
@@ -1,28 +1,37 @@
|
|
|
1
1
|
import { NgModule } from '@angular/core';
|
|
2
2
|
import { CommonModule } from '@angular/common';
|
|
3
|
-
import { SelectComponent } from './select.component';
|
|
4
3
|
import { PopupModule } from '../../popup/popup.module';
|
|
4
|
+
import { FormsModule } from '@angular/forms';
|
|
5
|
+
import { SelectComponent } from './components/select/select.component';
|
|
6
|
+
import { SelectMultiComponent } from './components/select-multi/select-multi.component';
|
|
5
7
|
import * as i0 from "@angular/core";
|
|
6
8
|
export class SelectModule {
|
|
7
9
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SelectModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
8
|
-
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.12", ngImport: i0, type: SelectModule, declarations: [SelectComponent
|
|
9
|
-
|
|
10
|
+
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.12", ngImport: i0, type: SelectModule, declarations: [SelectComponent,
|
|
11
|
+
SelectMultiComponent], imports: [CommonModule,
|
|
12
|
+
FormsModule,
|
|
13
|
+
PopupModule], exports: [SelectComponent,
|
|
14
|
+
SelectMultiComponent] });
|
|
10
15
|
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SelectModule, imports: [CommonModule,
|
|
16
|
+
FormsModule,
|
|
11
17
|
PopupModule] });
|
|
12
18
|
}
|
|
13
19
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SelectModule, decorators: [{
|
|
14
20
|
type: NgModule,
|
|
15
21
|
args: [{
|
|
16
22
|
declarations: [
|
|
17
|
-
SelectComponent
|
|
23
|
+
SelectComponent,
|
|
24
|
+
SelectMultiComponent
|
|
18
25
|
],
|
|
19
26
|
imports: [
|
|
20
27
|
CommonModule,
|
|
28
|
+
FormsModule,
|
|
21
29
|
PopupModule
|
|
22
30
|
],
|
|
23
31
|
exports: [
|
|
24
|
-
SelectComponent
|
|
32
|
+
SelectComponent,
|
|
33
|
+
SelectMultiComponent
|
|
25
34
|
]
|
|
26
35
|
}]
|
|
27
36
|
}] });
|
|
28
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL215cnRhLXVpL3NyYy9saWIvY29tcG9uZW50cy9mb3JtL3NlbGVjdC9zZWxlY3QubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUN2RCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDN0MsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLGtEQUFrRCxDQUFDOztBQW1CeEYsTUFBTSxPQUFPLFlBQVk7d0dBQVosWUFBWTt5R0FBWixZQUFZLGlCQWJyQixlQUFlO1lBQ2Ysb0JBQW9CLGFBR3BCLFlBQVk7WUFDWixXQUFXO1lBQ1gsV0FBVyxhQUdYLGVBQWU7WUFDZixvQkFBb0I7eUdBR1gsWUFBWSxZQVRyQixZQUFZO1lBQ1osV0FBVztZQUNYLFdBQVc7OzRGQU9GLFlBQVk7a0JBZnhCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLGVBQWU7d0JBQ2Ysb0JBQW9CO3FCQUNyQjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixXQUFXO3dCQUNYLFdBQVc7cUJBQ1o7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLGVBQWU7d0JBQ2Ysb0JBQW9CO3FCQUNyQjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IFBvcHVwTW9kdWxlIH0gZnJvbSAnLi4vLi4vcG9wdXAvcG9wdXAubW9kdWxlJztcclxuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcbmltcG9ydCB7IFNlbGVjdENvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9zZWxlY3Qvc2VsZWN0LmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IFNlbGVjdE11bHRpQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL3NlbGVjdC1tdWx0aS9zZWxlY3QtbXVsdGkuY29tcG9uZW50JztcclxuXHJcblxyXG5cclxuQE5nTW9kdWxlKHtcclxuICBkZWNsYXJhdGlvbnM6IFtcclxuICAgIFNlbGVjdENvbXBvbmVudCxcclxuICAgIFNlbGVjdE11bHRpQ29tcG9uZW50XHJcbiAgXSxcclxuICBpbXBvcnRzOiBbXHJcbiAgICBDb21tb25Nb2R1bGUsXHJcbiAgICBGb3Jtc01vZHVsZSxcclxuICAgIFBvcHVwTW9kdWxlXHJcbiAgXSxcclxuICBleHBvcnRzOiBbXHJcbiAgICBTZWxlY3RDb21wb25lbnQsXHJcbiAgICBTZWxlY3RNdWx0aUNvbXBvbmVudFxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIFNlbGVjdE1vZHVsZSB7IH1cclxuIl19
|
|
@@ -4,16 +4,23 @@ import * as i0 from "@angular/core";
|
|
|
4
4
|
import * as i1 from "@angular/common";
|
|
5
5
|
export class PopupComponent {
|
|
6
6
|
closeAfterClick = true;
|
|
7
|
-
// @Input() maxWidth: string = '800px';
|
|
8
7
|
templateRef;
|
|
9
8
|
popupItemComponents;
|
|
10
|
-
|
|
9
|
+
toggle = new EventEmitter();
|
|
10
|
+
_toggleInner = new EventEmitter();
|
|
11
|
+
_updateInner = new EventEmitter();
|
|
12
|
+
togglePopup(value) {
|
|
13
|
+
this._toggleInner.emit(value);
|
|
14
|
+
}
|
|
15
|
+
updatePopup() {
|
|
16
|
+
this._updateInner.emit();
|
|
17
|
+
}
|
|
11
18
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PopupComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
12
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: PopupComponent, selector: "mrx-popup", inputs: { closeAfterClick: "closeAfterClick" }, outputs: {
|
|
19
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: PopupComponent, selector: "mrx-popup", inputs: { closeAfterClick: "closeAfterClick" }, outputs: { toggle: "toggle", _toggleInner: "_toggleInner", _updateInner: "_updateInner" }, queries: [{ propertyName: "popupItemComponents", predicate: PopupItemComponent }], viewQueries: [{ propertyName: "templateRef", first: true, predicate: TemplateRef, descendants: true, static: true }], ngImport: i0, template: "<ng-template>\r\n <div class=\"mrx-popup-content\" [style.width]=\"'100%'\">\r\n <ng-container *ngFor=\"let item of popupItemComponents; let index = index; let first = first; let last = last\">\r\n <ng-container *ngTemplateOutlet=\"item.templateRef\"></ng-container>\r\n </ng-container>\r\n </div>\r\n</ng-template>\r\n", styles: [".mrx-popup-content{background-color:#fff;border-radius:4px;box-shadow:0 1px 4px #3a3a3a4d}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }] });
|
|
13
20
|
}
|
|
14
21
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PopupComponent, decorators: [{
|
|
15
22
|
type: Component,
|
|
16
|
-
args: [{ selector: 'mrx-popup', template: "<ng-template>\r\n <div class=\"mrx-popup-content\" [style.width]=\"'100%'\">\r\n <ng-container *ngFor=\"let item of popupItemComponents; let index = index; let first = first; let last = last\">\r\n <ng-container *ngTemplateOutlet=\"item.templateRef\"></ng-container>\r\n </ng-container>\r\n </div>\r\n</ng-template>\r\n", styles: [".mrx-popup-content{
|
|
23
|
+
args: [{ selector: 'mrx-popup', template: "<ng-template>\r\n <div class=\"mrx-popup-content\" [style.width]=\"'100%'\">\r\n <ng-container *ngFor=\"let item of popupItemComponents; let index = index; let first = first; let last = last\">\r\n <ng-container *ngTemplateOutlet=\"item.templateRef\"></ng-container>\r\n </ng-container>\r\n </div>\r\n</ng-template>\r\n", styles: [".mrx-popup-content{background-color:#fff;border-radius:4px;box-shadow:0 1px 4px #3a3a3a4d}\n"] }]
|
|
17
24
|
}], propDecorators: { closeAfterClick: [{
|
|
18
25
|
type: Input
|
|
19
26
|
}], templateRef: [{
|
|
@@ -22,7 +29,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
22
29
|
}], popupItemComponents: [{
|
|
23
30
|
type: ContentChildren,
|
|
24
31
|
args: [PopupItemComponent]
|
|
25
|
-
}],
|
|
32
|
+
}], toggle: [{
|
|
33
|
+
type: Output
|
|
34
|
+
}], _toggleInner: [{
|
|
35
|
+
type: Output
|
|
36
|
+
}], _updateInner: [{
|
|
26
37
|
type: Output
|
|
27
38
|
}] } });
|
|
28
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9wdXAuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXlydGEtdWkvc3JjL2xpYi9jb21wb25lbnRzL3BvcHVwL2NvbXBvbmVudHMvcG9wdXAvcG9wdXAuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXlydGEtdWkvc3JjL2xpYi9jb21wb25lbnRzL3BvcHVwL2NvbXBvbmVudHMvcG9wdXAvcG9wdXAuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLFNBQVMsRUFDVCxlQUFlLEVBQ2YsWUFBWSxFQUFFLEtBQUssRUFDbkIsTUFBTSxFQUVOLFdBQVcsRUFDWCxTQUFTLEVBQ1YsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sb0NBQW9DLENBQUM7OztBQU94RSxNQUFNLE9BQU8sY0FBYztJQUNoQixlQUFlLEdBQVksSUFBSSxDQUFDO0lBRUMsV0FBVyxDQUFvQjtJQUVwQyxtQkFBbUIsQ0FBaUM7SUFFL0UsTUFBTSxHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7SUFFckMsWUFBWSxHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7SUFDM0MsWUFBWSxHQUFHLElBQUksWUFBWSxFQUFRLENBQUM7SUFHM0MsV0FBVyxDQUFDLEtBQWM7UUFDL0IsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUE7SUFDL0IsQ0FBQztJQUVNLFdBQVc7UUFDaEIsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLEVBQUUsQ0FBQTtJQUMxQixDQUFDO3dHQW5CVSxjQUFjOzRGQUFkLGNBQWMsZ09BS1Isa0JBQWtCLDBFQUZ4QixXQUFXLDhEQ25CeEIsOFVBT0E7OzRGRFNhLGNBQWM7a0JBTDFCLFNBQVM7K0JBQ0UsV0FBVzs4QkFLWixlQUFlO3NCQUF2QixLQUFLO2dCQUVvQyxXQUFXO3NCQUFwRCxTQUFTO3VCQUFDLFdBQVcsRUFBRSxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUU7Z0JBRUgsbUJBQW1CO3NCQUF2RCxlQUFlO3VCQUFDLGtCQUFrQjtnQkFFekIsTUFBTTtzQkFBZixNQUFNO2dCQUVHLFlBQVk7c0JBQXJCLE1BQU07Z0JBQ0csWUFBWTtzQkFBckIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XHJcbiAgQ29tcG9uZW50LFxyXG4gIENvbnRlbnRDaGlsZHJlbixcclxuICBFdmVudEVtaXR0ZXIsIElucHV0LFxyXG4gIE91dHB1dCxcclxuICBRdWVyeUxpc3QsXHJcbiAgVGVtcGxhdGVSZWYsXHJcbiAgVmlld0NoaWxkXHJcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFBvcHVwSXRlbUNvbXBvbmVudCB9IGZyb20gJy4uL3BvcHVwLWl0ZW0vcG9wdXAtaXRlbS5jb21wb25lbnQnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdtcngtcG9wdXAnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9wb3B1cC5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vcG9wdXAuY29tcG9uZW50Lmxlc3MnXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgUG9wdXBDb21wb25lbnQge1xyXG4gIEBJbnB1dCgpIGNsb3NlQWZ0ZXJDbGljazogYm9vbGVhbiA9IHRydWU7XHJcblxyXG4gIEBWaWV3Q2hpbGQoVGVtcGxhdGVSZWYsIHsgc3RhdGljOiB0cnVlIH0pIHRlbXBsYXRlUmVmITogVGVtcGxhdGVSZWY8YW55PjtcclxuXHJcbiAgQENvbnRlbnRDaGlsZHJlbihQb3B1cEl0ZW1Db21wb25lbnQpIHBvcHVwSXRlbUNvbXBvbmVudHMhOiBRdWVyeUxpc3Q8UG9wdXBJdGVtQ29tcG9uZW50PjtcclxuXHJcbiAgQE91dHB1dCgpIHRvZ2dsZSA9IG5ldyBFdmVudEVtaXR0ZXI8Ym9vbGVhbj4oKTtcclxuXHJcbiAgQE91dHB1dCgpIF90b2dnbGVJbm5lciA9IG5ldyBFdmVudEVtaXR0ZXI8Ym9vbGVhbj4oKTtcclxuICBAT3V0cHV0KCkgX3VwZGF0ZUlubmVyID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xyXG5cclxuXHJcbiAgcHVibGljIHRvZ2dsZVBvcHVwKHZhbHVlOiBib29sZWFuKSB7XHJcbiAgICB0aGlzLl90b2dnbGVJbm5lci5lbWl0KHZhbHVlKVxyXG4gIH1cclxuXHJcbiAgcHVibGljIHVwZGF0ZVBvcHVwKCkge1xyXG4gICAgdGhpcy5fdXBkYXRlSW5uZXIuZW1pdCgpXHJcbiAgfVxyXG59XHJcbiIsIjxuZy10ZW1wbGF0ZT5cclxuICA8ZGl2IGNsYXNzPVwibXJ4LXBvcHVwLWNvbnRlbnRcIiBbc3R5bGUud2lkdGhdPVwiJzEwMCUnXCI+XHJcbiAgICA8bmctY29udGFpbmVyICpuZ0Zvcj1cImxldCBpdGVtIG9mIHBvcHVwSXRlbUNvbXBvbmVudHM7IGxldCBpbmRleCA9IGluZGV4OyBsZXQgZmlyc3QgPSBmaXJzdDsgbGV0IGxhc3QgPSBsYXN0XCI+XHJcbiAgICAgIDxuZy1jb250YWluZXIgKm5nVGVtcGxhdGVPdXRsZXQ9XCJpdGVtLnRlbXBsYXRlUmVmXCI+PC9uZy1jb250YWluZXI+XHJcbiAgICA8L25nLWNvbnRhaW5lcj5cclxuICA8L2Rpdj5cclxuPC9uZy10ZW1wbGF0ZT5cclxuIl19
|
|
@@ -1,18 +1,21 @@
|
|
|
1
|
-
import { Component, EventEmitter, Output, TemplateRef, ViewChild } from '@angular/core';
|
|
1
|
+
import { Component, EventEmitter, Input, Output, TemplateRef, ViewChild } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
export class PopupItemComponent {
|
|
4
|
+
custom = false;
|
|
4
5
|
templateRef;
|
|
5
6
|
clicked = new EventEmitter();
|
|
6
7
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PopupItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
7
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: PopupItemComponent, selector: "mrx-popup-item", outputs: { clicked: "clicked" }, viewQueries: [{ propertyName: "templateRef", first: true, predicate: TemplateRef, descendants: true, static: true }], ngImport: i0, template: "<ng-template>\r\n <div class=\"mrx-popup-item\" (click)=\"clicked.emit()\">\r\n <ng-content></ng-content>\r\n </div>\r\n</ng-template>\r\n", styles: [".mrx-popup-item{padding:8px 16px;background-color:transparent;transition:background-color .3s;cursor:pointer}.mrx-popup-item:hover{background-color:var(--brand-bg-tertiary-hover, #EDF5FF)}\n"] });
|
|
8
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: PopupItemComponent, selector: "mrx-popup-item", inputs: { custom: "custom" }, outputs: { clicked: "clicked" }, viewQueries: [{ propertyName: "templateRef", first: true, predicate: TemplateRef, descendants: true, static: true }], ngImport: i0, template: "<ng-template>\r\n <div class=\"mrx-popup-item\" [class.mrx-popup-item--default]=\"custom\" (click)=\"clicked.emit()\">\r\n <ng-content></ng-content>\r\n </div>\r\n</ng-template>\r\n", styles: [".mrx-popup-item{padding:8px 8px 8px 16px;background-color:transparent;transition:background-color .3s;cursor:pointer}.mrx-popup-item:hover{background-color:var(--brand-bg-tertiary-hover, #EDF5FF)}\n"] });
|
|
8
9
|
}
|
|
9
10
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PopupItemComponent, decorators: [{
|
|
10
11
|
type: Component,
|
|
11
|
-
args: [{ selector: 'mrx-popup-item', template: "<ng-template>\r\n <div class=\"mrx-popup-item\" (click)=\"clicked.emit()\">\r\n <ng-content></ng-content>\r\n </div>\r\n</ng-template>\r\n", styles: [".mrx-popup-item{padding:8px 16px;background-color:transparent;transition:background-color .3s;cursor:pointer}.mrx-popup-item:hover{background-color:var(--brand-bg-tertiary-hover, #EDF5FF)}\n"] }]
|
|
12
|
-
}], propDecorators: {
|
|
12
|
+
args: [{ selector: 'mrx-popup-item', template: "<ng-template>\r\n <div class=\"mrx-popup-item\" [class.mrx-popup-item--default]=\"custom\" (click)=\"clicked.emit()\">\r\n <ng-content></ng-content>\r\n </div>\r\n</ng-template>\r\n", styles: [".mrx-popup-item{padding:8px 8px 8px 16px;background-color:transparent;transition:background-color .3s;cursor:pointer}.mrx-popup-item:hover{background-color:var(--brand-bg-tertiary-hover, #EDF5FF)}\n"] }]
|
|
13
|
+
}], propDecorators: { custom: [{
|
|
14
|
+
type: Input
|
|
15
|
+
}], templateRef: [{
|
|
13
16
|
type: ViewChild,
|
|
14
17
|
args: [TemplateRef, { static: true }]
|
|
15
18
|
}], clicked: [{
|
|
16
19
|
type: Output
|
|
17
20
|
}] } });
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9wdXAtaXRlbS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9teXJ0YS11aS9zcmMvbGliL2NvbXBvbmVudHMvcG9wdXAvY29tcG9uZW50cy9wb3B1cC1pdGVtL3BvcHVwLWl0ZW0uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXlydGEtdWkvc3JjL2xpYi9jb21wb25lbnRzL3BvcHVwL2NvbXBvbmVudHMvcG9wdXAtaXRlbS9wb3B1cC1pdGVtLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsV0FBVyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFPL0YsTUFBTSxPQUFPLGtCQUFrQjtJQUNwQixNQUFNLEdBQVksS0FBSyxDQUFDO0lBRVMsV0FBVyxDQUFvQjtJQUUvRCxPQUFPLEdBQUcsSUFBSSxZQUFZLEVBQVEsQ0FBQzt3R0FMbEMsa0JBQWtCOzRGQUFsQixrQkFBa0Isa0tBR2xCLFdBQVcsOERDVnhCLDRMQUtBOzs0RkRFYSxrQkFBa0I7a0JBTDlCLFNBQVM7K0JBQ0UsZ0JBQWdCOzhCQUtqQixNQUFNO3NCQUFkLEtBQUs7Z0JBRW9DLFdBQVc7c0JBQXBELFNBQVM7dUJBQUMsV0FBVyxFQUFFLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRTtnQkFFOUIsT0FBTztzQkFBaEIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0LCBUZW1wbGF0ZVJlZiwgVmlld0NoaWxkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ21yeC1wb3B1cC1pdGVtJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vcG9wdXAtaXRlbS5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vcG9wdXAtaXRlbS5jb21wb25lbnQubGVzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBQb3B1cEl0ZW1Db21wb25lbnQge1xyXG4gIEBJbnB1dCgpIGN1c3RvbTogYm9vbGVhbiA9IGZhbHNlO1xyXG5cclxuICBAVmlld0NoaWxkKFRlbXBsYXRlUmVmLCB7IHN0YXRpYzogdHJ1ZSB9KSB0ZW1wbGF0ZVJlZiE6IFRlbXBsYXRlUmVmPGFueT47XHJcblxyXG4gIEBPdXRwdXQoKSBjbGlja2VkID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xyXG59XHJcbiIsIjxuZy10ZW1wbGF0ZT5cclxuICA8ZGl2IGNsYXNzPVwibXJ4LXBvcHVwLWl0ZW1cIiBbY2xhc3MubXJ4LXBvcHVwLWl0ZW0tLWRlZmF1bHRdPVwiY3VzdG9tXCIgKGNsaWNrKT1cImNsaWNrZWQuZW1pdCgpXCI+XHJcbiAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XHJcbiAgPC9kaXY+XHJcbjwvbmctdGVtcGxhdGU+XHJcbiJdfQ==
|