@datarailsshared/datarailsshared 1.3.21 → 1.3.24
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/datarailsshared-datarailsshared.umd.js +213 -13
- package/bundles/datarailsshared-datarailsshared.umd.js.map +1 -1
- package/datarailsshared-datarailsshared-1.3.24.tgz +0 -0
- package/datarailsshared-datarailsshared.metadata.json +1 -1
- package/esm2015/lib/dr-avatar/dr-avatar.component.js +3 -3
- package/esm2015/lib/dr-dropdown/dr-dropdown-position.directive.js +2 -2
- package/esm2015/lib/dr-dropdown/dr-dropdown.component.js +2 -1
- package/esm2015/lib/dr-inputs/dr-input/dr-input.component.js +4 -2
- package/esm2015/lib/dr-inputs/dr-inputs.module.js +3 -1
- package/esm2015/lib/dr-inputs/dr-toggle/dr-toggle.component.js +12 -4
- package/esm2015/lib/dr-inputs/radio-button/radio-button.component.js +14 -5
- package/esm2015/lib/dr-inputs/radio-button/radio-group.component.js +164 -0
- package/esm2015/lib/models/dropdown.js +1 -1
- package/esm2015/public-api.js +2 -1
- package/fesm2015/datarailsshared-datarailsshared.js +192 -14
- package/fesm2015/datarailsshared-datarailsshared.js.map +1 -1
- package/lib/dr-inputs/dr-input/dr-input.component.d.ts +2 -0
- package/lib/dr-inputs/dr-toggle/dr-toggle.component.d.ts +5 -2
- package/lib/dr-inputs/radio-button/radio-button.component.d.ts +4 -1
- package/lib/dr-inputs/radio-button/radio-group.component.d.ts +39 -0
- package/lib/models/dropdown.d.ts +2 -1
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
- package/datarailsshared-datarailsshared-1.3.21.tgz +0 -0
|
@@ -0,0 +1,164 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, forwardRef, Input, Output, PLATFORM_ID, Inject, ElementRef, } from '@angular/core';
|
|
2
|
+
import { isPlatformBrowser } from '@angular/common';
|
|
3
|
+
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
4
|
+
import { from, fromEvent, merge, Subject } from 'rxjs';
|
|
5
|
+
import { filter, startWith, switchMap, takeUntil } from 'rxjs/operators';
|
|
6
|
+
import { RadioButtonComponent } from './radio-button.component';
|
|
7
|
+
import { DOCUMENT } from '@angular/common';
|
|
8
|
+
export class RadioGroupComponent {
|
|
9
|
+
constructor(hostElement, platformId, document) {
|
|
10
|
+
this.hostElement = hostElement;
|
|
11
|
+
this.platformId = platformId;
|
|
12
|
+
this.document = document;
|
|
13
|
+
this.destroy$ = new Subject();
|
|
14
|
+
this.valueChange = new EventEmitter();
|
|
15
|
+
this.onChange = (value) => { };
|
|
16
|
+
this.onTouched = () => { };
|
|
17
|
+
}
|
|
18
|
+
get value() {
|
|
19
|
+
return this._value;
|
|
20
|
+
}
|
|
21
|
+
set value(value) {
|
|
22
|
+
this._value = value;
|
|
23
|
+
this.updateValues();
|
|
24
|
+
}
|
|
25
|
+
get name() {
|
|
26
|
+
return this._name;
|
|
27
|
+
}
|
|
28
|
+
set name(name) {
|
|
29
|
+
this._name = name;
|
|
30
|
+
this.updateNames();
|
|
31
|
+
}
|
|
32
|
+
get disabled() {
|
|
33
|
+
return this._disabled;
|
|
34
|
+
}
|
|
35
|
+
set disabled(disabled) {
|
|
36
|
+
this._disabled = !!disabled;
|
|
37
|
+
this.updateDisabled();
|
|
38
|
+
}
|
|
39
|
+
ngAfterContentInit() {
|
|
40
|
+
// In case option 'name' isn't set on nb-radio component,
|
|
41
|
+
// we need to set it's name right away, so it won't overlap with options
|
|
42
|
+
// without names from other radio groups. Otherwise they all would have
|
|
43
|
+
// same name and will be considered as options from one group so only the
|
|
44
|
+
// last option will stay selected.
|
|
45
|
+
this.updateNames();
|
|
46
|
+
this.radios.changes
|
|
47
|
+
.pipe(startWith(this.radios),
|
|
48
|
+
// 'changes' emit during change detection run and we can't update
|
|
49
|
+
// option properties right of since they already was initialized.
|
|
50
|
+
// Instead we schedule microtask to update radios after change detection
|
|
51
|
+
// run is finished and trigger one more change detection run.
|
|
52
|
+
switchMap((radios) => from(Promise.resolve(radios))), takeUntil(this.destroy$))
|
|
53
|
+
.subscribe(() => this.updateAndSubscribeToRadios());
|
|
54
|
+
}
|
|
55
|
+
ngOnDestroy() {
|
|
56
|
+
this.destroy$.next();
|
|
57
|
+
this.destroy$.complete();
|
|
58
|
+
}
|
|
59
|
+
registerOnChange(fn) {
|
|
60
|
+
this.onChange = fn;
|
|
61
|
+
}
|
|
62
|
+
registerOnTouched(fn) {
|
|
63
|
+
this.onTouched = fn;
|
|
64
|
+
}
|
|
65
|
+
writeValue(value) {
|
|
66
|
+
this.value = value;
|
|
67
|
+
}
|
|
68
|
+
setDisabledState(isDisabled) {
|
|
69
|
+
this.disabled = isDisabled;
|
|
70
|
+
}
|
|
71
|
+
updateAndSubscribeToRadios() {
|
|
72
|
+
this.updateValueFromCheckedOption();
|
|
73
|
+
this.updateNames();
|
|
74
|
+
this.updateValues();
|
|
75
|
+
this.updateDisabled();
|
|
76
|
+
this.subscribeOnRadiosValueChange();
|
|
77
|
+
this.subscribeOnRadiosBlur();
|
|
78
|
+
}
|
|
79
|
+
updateNames() {
|
|
80
|
+
if (this.radios) {
|
|
81
|
+
this.radios.forEach((radio) => radio._setName(this.name));
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
updateValues() {
|
|
85
|
+
this.updateAndMarkForCheckRadios((radio) => {
|
|
86
|
+
if (radio.value === this.value) {
|
|
87
|
+
radio.modelValue = radio.value;
|
|
88
|
+
}
|
|
89
|
+
});
|
|
90
|
+
}
|
|
91
|
+
updateDisabled() {
|
|
92
|
+
if (typeof this.disabled !== 'undefined') {
|
|
93
|
+
this.updateAndMarkForCheckRadios((radio) => radio.disabled = this.disabled);
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
subscribeOnRadiosValueChange() {
|
|
97
|
+
if (!this.radios || !this.radios.length) {
|
|
98
|
+
return;
|
|
99
|
+
}
|
|
100
|
+
merge(...this.radios.map((radio) => radio.valueChange))
|
|
101
|
+
.pipe(takeUntil(merge(this.radios.changes, this.destroy$)))
|
|
102
|
+
.subscribe((value) => {
|
|
103
|
+
this.writeValue(value);
|
|
104
|
+
this.propagateValue(value);
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
propagateValue(value) {
|
|
108
|
+
this.valueChange.emit(value);
|
|
109
|
+
this.onChange(value);
|
|
110
|
+
}
|
|
111
|
+
subscribeOnRadiosBlur() {
|
|
112
|
+
const hasNoRadios = !this.radios || !this.radios.length;
|
|
113
|
+
if (!isPlatformBrowser(this.platformId) || hasNoRadios) {
|
|
114
|
+
return;
|
|
115
|
+
}
|
|
116
|
+
const hostElement = this.hostElement.nativeElement;
|
|
117
|
+
fromEvent(hostElement, 'focusin')
|
|
118
|
+
.pipe(filter(event => hostElement.contains(event.target)), switchMap(() => merge(fromEvent(this.document, 'focusin'), fromEvent(this.document, 'click'))), filter(event => !hostElement.contains(event.target)), takeUntil(merge(this.radios.changes, this.destroy$)))
|
|
119
|
+
.subscribe(() => this.onTouched());
|
|
120
|
+
}
|
|
121
|
+
updateAndMarkForCheckRadios(updateFn) {
|
|
122
|
+
if (this.radios) {
|
|
123
|
+
this.radios.forEach((radio) => {
|
|
124
|
+
updateFn(radio);
|
|
125
|
+
radio._markForCheck();
|
|
126
|
+
});
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
updateValueFromCheckedOption() {
|
|
130
|
+
const checkedRadio = this.radios.find((radio) => radio.modelValue);
|
|
131
|
+
const isValueMissing = this.value === undefined || this.value === null;
|
|
132
|
+
if (checkedRadio && isValueMissing && checkedRadio.value !== this.value) {
|
|
133
|
+
this.value = checkedRadio.value;
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
RadioGroupComponent.decorators = [
|
|
138
|
+
{ type: Component, args: [{
|
|
139
|
+
selector: 'dr-radio-group',
|
|
140
|
+
template: `
|
|
141
|
+
<ng-content select="dr-radio-button"></ng-content>`,
|
|
142
|
+
providers: [
|
|
143
|
+
{
|
|
144
|
+
provide: NG_VALUE_ACCESSOR,
|
|
145
|
+
useExisting: forwardRef(() => RadioGroupComponent),
|
|
146
|
+
multi: true,
|
|
147
|
+
},
|
|
148
|
+
],
|
|
149
|
+
changeDetection: ChangeDetectionStrategy.OnPush
|
|
150
|
+
},] }
|
|
151
|
+
];
|
|
152
|
+
RadioGroupComponent.ctorParameters = () => [
|
|
153
|
+
{ type: ElementRef },
|
|
154
|
+
{ type: undefined, decorators: [{ type: Inject, args: [PLATFORM_ID,] }] },
|
|
155
|
+
{ type: undefined, decorators: [{ type: Inject, args: [DOCUMENT,] }] }
|
|
156
|
+
];
|
|
157
|
+
RadioGroupComponent.propDecorators = {
|
|
158
|
+
value: [{ type: Input }],
|
|
159
|
+
name: [{ type: Input }],
|
|
160
|
+
disabled: [{ type: Input }],
|
|
161
|
+
radios: [{ type: ContentChildren, args: [RadioButtonComponent, { descendants: true },] }],
|
|
162
|
+
valueChange: [{ type: Output }]
|
|
163
|
+
};
|
|
164
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio-group.component.js","sourceRoot":"","sources":["../../../../../../projects/datarailsshared/src/lib/dr-inputs/radio-button/radio-group.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterContentInit,\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  ContentChildren,\r\n  EventEmitter,\r\n  forwardRef,\r\n  Input,\r\n  OnDestroy,\r\n  Output,\r\n  QueryList,\r\n  PLATFORM_ID,\r\n  Inject,\r\n  ElementRef,\r\n} from '@angular/core';\r\nimport { isPlatformBrowser } from '@angular/common';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { from, fromEvent, merge, Subject } from 'rxjs';\r\nimport { filter, startWith, switchMap, takeUntil } from 'rxjs/operators';\r\nimport { RadioButtonComponent } from './radio-button.component';\r\nimport { DOCUMENT } from '@angular/common';\r\n@Component({\r\n  selector: 'dr-radio-group',\r\n  template: `\r\n    <ng-content select=\"dr-radio-button\"></ng-content>`,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => RadioGroupComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class RadioGroupComponent implements AfterContentInit, OnDestroy, ControlValueAccessor {\r\n\r\n  @Input()\r\n  get value(): any {\r\n    return this._value;\r\n  }\r\n  set value(value: any) {\r\n    this._value = value;\r\n    this.updateValues();\r\n  }\r\n\r\n  @Input()\r\n  get name(): string {\r\n    return this._name;\r\n  }\r\n  set name(name: string) {\r\n    this._name = name;\r\n    this.updateNames();\r\n  }\r\n\r\n  @Input()\r\n  get disabled(): boolean {\r\n    return this._disabled;\r\n  }\r\n  set disabled(disabled: boolean) {\r\n    this._disabled = !!disabled;\r\n    this.updateDisabled();\r\n  }\r\n\r\n  constructor(\r\n    protected hostElement: ElementRef<HTMLElement>,\r\n    @Inject(PLATFORM_ID) protected platformId,\r\n    @Inject(DOCUMENT) protected document,\r\n  ) {}\r\n\r\n  protected destroy$ = new Subject<void>();\r\n  protected _value: any;\r\n  protected _name: string;\r\n  protected _disabled: boolean;\r\n\r\n  @ContentChildren(RadioButtonComponent, { descendants: true }) radios: QueryList<RadioButtonComponent>;\r\n\r\n  @Output() valueChange: EventEmitter<any> = new EventEmitter();\r\n  protected onChange = (value: any) => {};\r\n  protected onTouched = () => {};\r\n\r\n  ngAfterContentInit() {\r\n    // In case option 'name' isn't set on nb-radio component,\r\n    // we need to set it's name right away, so it won't overlap with options\r\n    // without names from other radio groups. Otherwise they all would have\r\n    // same name and will be considered as options from one group so only the\r\n    // last option will stay selected.\r\n    this.updateNames();\r\n\r\n    this.radios.changes\r\n      .pipe(\r\n        startWith(this.radios),\r\n        // 'changes' emit during change detection run and we can't update\r\n        // option properties right of since they already was initialized.\r\n        // Instead we schedule microtask to update radios after change detection\r\n        // run is finished and trigger one more change detection run.\r\n        switchMap((radios: QueryList<RadioButtonComponent>) => from(Promise.resolve(radios))),\r\n        takeUntil(this.destroy$),\r\n      )\r\n      .subscribe(() => this.updateAndSubscribeToRadios());\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.destroy$.next();\r\n    this.destroy$.complete();\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  writeValue(value: any): void {\r\n    this.value = value;\r\n  }\r\n\r\n  setDisabledState(isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n  }\r\n\r\n  protected updateAndSubscribeToRadios() {\r\n    this.updateValueFromCheckedOption();\r\n    this.updateNames();\r\n    this.updateValues();\r\n    this.updateDisabled();\r\n    this.subscribeOnRadiosValueChange();\r\n    this.subscribeOnRadiosBlur();\r\n  }\r\n\r\n  protected updateNames() {\r\n    if (this.radios) {\r\n      this.radios.forEach((radio: RadioButtonComponent) => radio._setName(this.name));\r\n    }\r\n  }\r\n\r\n  protected updateValues() {\r\n    this.updateAndMarkForCheckRadios((radio: RadioButtonComponent) => {\r\n      if (radio.value === this.value) {\r\n        radio.modelValue = radio.value;\r\n      }\r\n    });\r\n  }\r\n\r\n  protected updateDisabled() {\r\n    if (typeof this.disabled !== 'undefined') {\r\n      this.updateAndMarkForCheckRadios((radio: RadioButtonComponent) => radio.disabled = this.disabled);\r\n    }\r\n  }\r\n\r\n  protected subscribeOnRadiosValueChange() {\r\n    if (!this.radios || !this.radios.length) {\r\n      return;\r\n    }\r\n\r\n    merge(...this.radios.map((radio: RadioButtonComponent) => radio.valueChange))\r\n      .pipe(\r\n        takeUntil(\r\n          merge(\r\n            this.radios.changes,\r\n            this.destroy$,\r\n          ),\r\n        ),\r\n      )\r\n      .subscribe((value: any) => {\r\n        this.writeValue(value);\r\n        this.propagateValue(value);\r\n      });\r\n  }\r\n\r\n  protected propagateValue(value: any) {\r\n    this.valueChange.emit(value);\r\n    this.onChange(value);\r\n  }\r\n\r\n  protected subscribeOnRadiosBlur() {\r\n    const hasNoRadios = !this.radios || !this.radios.length;\r\n    if (!isPlatformBrowser(this.platformId) || hasNoRadios) {\r\n      return;\r\n    }\r\n\r\n    const hostElement = this.hostElement.nativeElement;\r\n    fromEvent<Event>(hostElement, 'focusin')\r\n      .pipe(\r\n        filter(event => hostElement.contains(event.target as Node)),\r\n        switchMap(() => merge(\r\n          fromEvent<Event>(this.document, 'focusin'),\r\n          fromEvent<Event>(this.document, 'click'),\r\n        )),\r\n        filter(event => !hostElement.contains(event.target as Node)),\r\n        takeUntil(\r\n          merge(\r\n            this.radios.changes,\r\n            this.destroy$,\r\n          ),\r\n        ),\r\n      )\r\n      .subscribe(() => this.onTouched());\r\n  }\r\n\r\n  protected updateAndMarkForCheckRadios(updateFn: (RadioButtonComponent) => void) {\r\n    if (this.radios) {\r\n      this.radios.forEach((radio) => {\r\n        updateFn(radio);\r\n        radio._markForCheck();\r\n      });\r\n    }\r\n  }\r\n\r\n  protected updateValueFromCheckedOption() {\r\n    const checkedRadio = this.radios.find((radio) => radio.modelValue);\r\n    const isValueMissing = this.value === undefined || this.value === null;\r\n    if (checkedRadio && isValueMissing && checkedRadio.value !== this.value) {\r\n      this.value = checkedRadio.value;\r\n    }\r\n  }\r\n}\r\n"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kYXRhcmFpbHNzaGFyZWQvc3JjL2xpYi9tb2RlbHMvZHJvcGRvd24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB0eXBlIEVsUG9zaXRpb24gPSAnbGVmdCcgfCAncmlnaHQnIHwgJ3RvcCcgfCAnYm90dG9tJyB8ICdjaGlsZCcgfCAndG9wLWxlZnQnIHwgJ2xlZnQtY2VudGVyJyB8ICdib3R0b20tbGVmdCcgfCAnb3ZlcicgfCAncmlnaHQtYm90dG9tJyB8ICdib3R0b20tcmlnaHQnO1xyXG5cclxuLy8gSUNvbnRleHRNZW51XHJcbmV4cG9ydCBpbnRlcmZhY2UgSURyb3Bkb3duPFQ+IHtcclxuICBvcHRpb24/OiBET01SZWN0O1xyXG4gIHBvc2l0aW9uOiBFbFBvc2l0aW9uIHwgSURyb3Bkb3duQ29vcmRpbmF0ZTtcclxuICBsaXN0OiBJRHJvcGRvd25JdGVtPFQ+
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kYXRhcmFpbHNzaGFyZWQvc3JjL2xpYi9tb2RlbHMvZHJvcGRvd24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB0eXBlIEVsUG9zaXRpb24gPSAnbGVmdCcgfCAncmlnaHQnIHwgJ3RvcCcgfCAnYm90dG9tJyB8ICdjaGlsZCcgfCAndG9wLWxlZnQnIHwgJ2xlZnQtY2VudGVyJyB8ICdib3R0b20tbGVmdCcgfCAnb3ZlcicgfCAncmlnaHQtYm90dG9tJyB8ICdib3R0b20tcmlnaHQnO1xyXG5cclxuLy8gSUNvbnRleHRNZW51XHJcbmV4cG9ydCBpbnRlcmZhY2UgSURyb3Bkb3duPFQ+IHtcclxuICBvcHRpb24/OiBET01SZWN0O1xyXG4gIHBvc2l0aW9uOiBFbFBvc2l0aW9uIHwgSURyb3Bkb3duQ29vcmRpbmF0ZTtcclxuICBsaXN0OiBJRHJvcGRvd25JdGVtPFQ+W107XHJcbiAgdGFnPzogc3RyaW5nO1xyXG4gIGNsYXNzPzogc3RyaW5nIHwgdW5kZWZpbmVkO1xyXG59XHJcblxyXG4vLyBBY3Rpb25NZW51XHJcbmV4cG9ydCBpbnRlcmZhY2UgSURyb3Bkb3duSXRlbTxUPiB7XHJcbiAgdGl0bGU/OiBzdHJpbmc7XHJcbiAgaWNvbj86IHN0cmluZztcclxuICBjdXN0b21UaXRsZT86IChwOiBhbnkpID0+IHN0cmluZztcclxuICBhY3Rpb24/OiAocDogVCkgPT4gdm9pZDtcclxuICBldmVudD86IHN0cmluZztcclxuICBkYXRhPzogVDtcclxuICBzaG93PzogKHA6IGFueSkgPT4gYm9vbGVhbjtcclxuICBkaXNhYmxlZD86IChwOiBUKSA9PiBib29sZWFuO1xyXG4gIHRvb2xUaXA/OiBzdHJpbmc7XHJcbiAgdG9vbFRpcElmRGlzYWJsZWQ/OiBib29sZWFuO1xyXG4gIGNoaWxkcmVuPzogVFtdO1xyXG4gIGNoaWxkT3B0aW9ucz86IElEcm9wZG93bjxUPjtcclxuICBhY3Rpb25JY29ucz86IElEcm9wZG93bkFjdGlvbkljb248VD5bXTtcclxuICBzZWxlY3RlZD86IChwOiBUKSA9PiBib29sZWFuO1xyXG4gIGNsYXNzPzogc3RyaW5nIHwgdW5kZWZpbmVkO1xyXG59XHJcblxyXG4vLyBNZW51QWN0aW9uSWNvblxyXG5leHBvcnQgaW50ZXJmYWNlIElEcm9wZG93bkFjdGlvbkljb248VD4ge1xyXG4gIGljb246IHN0cmluZztcclxuICBhY3Rpb246IChwOiBUKSA9PiB2b2lkO1xyXG4gIGRpc2FibGVkPzogYm9vbGVhbjtcclxuICBkYXRhPzogYW55O1xyXG4gIHNob3dPbkhvdmVyPzogYm9vbGVhbjtcclxufVxyXG5cclxuLy8gSUNvbnRleHRNZW51Q29vcmRpbmF0ZVxyXG5leHBvcnQgaW50ZXJmYWNlIElEcm9wZG93bkNvb3JkaW5hdGUge1xyXG4gIHg6IG51bWJlcjtcclxuICB5OiBudW1iZXI7XHJcbiAgY2xpZW50WD86IG51bWJlcjtcclxuICBjbGllbnRZPzogbnVtYmVyO1xyXG59XHJcblxyXG4vLyBJR1RDQ29udGV4dE1lbnVFdmVudFxyXG5leHBvcnQgaW50ZXJmYWNlIElEcm9wZG93bkNhbGxFdmVudCB7XHJcbiAgaWQ6IG51bWJlcjtcclxuICBldmVudDogYW55O1xyXG4gIGl0ZW1zTGlzdDogYW55W107XHJcbn1cclxuXHJcbi8vIENvbnRleHRNZW51Q2xpY2tcclxuZXhwb3J0IGludGVyZmFjZSBJRHJvcGRvd25BY3Rpb248VD4ge1xyXG4gIGV2ZW50OiBzdHJpbmc7XHJcbiAgZGF0YT86IFQ7XHJcbn1cclxuIl19
|
package/esm2015/public-api.js
CHANGED
|
@@ -10,6 +10,7 @@ export * from './lib/list-tags/list-tag.component';
|
|
|
10
10
|
export * from './lib/date-tags/day-tag/day-tag.component';
|
|
11
11
|
export * from './lib/date-tags/date-tag.component';
|
|
12
12
|
export * from './lib/dr-inputs/radio-button/radio-button.component';
|
|
13
|
+
export * from './lib/dr-inputs/radio-button/radio-group.component';
|
|
13
14
|
export * from './lib/dr-inputs/checkbox/checkbox.component';
|
|
14
15
|
export * from './lib/dr-inputs/dr-input/dr-input.component';
|
|
15
16
|
export * from './lib/dr-inputs/dr-select/dr-select.component';
|
|
@@ -46,4 +47,4 @@ export { DrSpinnerModule } from './lib/dr-spinner/dr-spinner.module';
|
|
|
46
47
|
export { DrPopoverModule } from './lib/dr-popover/dr-popover.module';
|
|
47
48
|
export { DrDropdownModule } from './lib/dr-dropdown/dr-dropdown.module';
|
|
48
49
|
export { DrTabsModule } from './lib/dr-tabs/dr-tabs.module';
|
|
49
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxnQkFBZ0I7QUFDaEIsY0FBYyxvQ0FBb0MsQ0FBQztBQUNuRCxjQUFjLHFEQUFxRCxDQUFDO0FBQ3BFLGNBQWMsK0NBQStDLENBQUM7QUFDOUQsY0FBYyxtREFBbUQsQ0FBQztBQUNsRSxjQUFjLDZDQUE2QyxDQUFDO0FBQzVELGNBQWMsNkNBQTZDLENBQUM7QUFDNUQsY0FBYyxnQ0FBZ0MsQ0FBQztBQUMvQyxjQUFjLG9DQUFvQyxDQUFDO0FBQ25ELGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYyxvQ0FBb0MsQ0FBQztBQUNuRCxjQUFjLHFEQUFxRCxDQUFDO0FBQ3BFLGNBQWMsb0RBQW9ELENBQUM7QUFDbkUsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLDZDQUE2QyxDQUFDO0FBQzVELGNBQWMsK0NBQStDLENBQUM7QUFDOUQsY0FBYyxxQ0FBcUMsQ0FBQztBQUNwRCxjQUFjLGdDQUFnQyxDQUFDO0FBQy9DLGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLCtDQUErQyxDQUFDO0FBQzlELGNBQWMsNkRBQTZELENBQUM7QUFDNUUsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLHVDQUF1QyxDQUFDO0FBQ3RELGNBQWMseUNBQXlDLENBQUM7QUFFeEQsY0FBYyx5REFBeUQsQ0FBQztBQUN4RSxjQUFjLGdFQUFnRSxDQUFDO0FBQy9FLGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLHFDQUFxQyxDQUFDO0FBRXBELGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYyxrREFBa0QsQ0FBQztBQUNqRSxjQUFjLHlDQUF5QyxDQUFDO0FBQ3hELGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYyw4Q0FBOEMsQ0FBQztBQUM3RCxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsZ0NBQWdDLENBQUM7QUFhL0MsT0FBTyxFQUNMLFlBQVksRUFNWiwyQkFBMkIsR0FDNUIsTUFBTSxzQkFBc0IsQ0FBQztBQUU5QixhQUFhO0FBQ2IsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQ2hFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUNoRSxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDMUQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGtDQUFrQyxDQUFDO0FBQ2xFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUNyRSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sa0NBQWtDLENBQUM7QUFDbEUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBQ3JFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUNyRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQztBQUN4RSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sOEJBQThCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBjb21wb25lbnRzICovXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RhdGUtdGFncy9kYXRlLXRhZy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kYXRlLXRhZ3MvZm9yZWNhc3QtdGFnL2ZvcmVjYXN0LXRhZy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kYXRlLXRhZ3MvbW9udGgtdGFnL21vbnRoLXRhZy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kYXRlLXRhZ3MvcXVhcnRlci10YWcvcXVhcnRlci10YWcuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZGF0ZS10YWdzL3dlZWstdGFnL3dlZWstdGFnLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RhdGUtdGFncy95ZWFyLXRhZy95ZWFyLXRhZy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kci10YWdzL2RyLXRhZy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9saXN0LXRhZ3MvbGlzdC10YWcuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZGF0ZS10YWdzL2RheS10YWcvZGF5LXRhZy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kYXRlLXRhZ3MvZGF0ZS10YWcuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZHItaW5wdXRzL3JhZGlvLWJ1dHRvbi9yYWRpby1idXR0b24uY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZHItaW5wdXRzL3JhZGlvLWJ1dHRvbi9yYWRpby1ncm91cC5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kci1pbnB1dHMvY2hlY2tib3gvY2hlY2tib3guY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZHItaW5wdXRzL2RyLWlucHV0L2RyLWlucHV0LmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RyLWlucHV0cy9kci1zZWxlY3QvZHItc2VsZWN0LmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RyLWF2YXRhci9kci1hdmF0YXIuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZHItYXZhdGFyL2RyLWF2YXRhci5waXBlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZHItdG9vbHRpcC9kci10b29sdGlwLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RyLXRvb2x0aXAvZHItdG9vbHRpcC5kaXJlY3RpdmUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kci1pbnB1dHMvZHItdG9nZ2xlL2RyLXRvZ2dsZS5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kci1pbnB1dHMvZHItdG9nZ2xlLWJ1dHRvbi9kci10b2dnbGUtYnV0dG9uLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RyLXNwaW5uZXIvZHItc3Bpbm5lci5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kci1zcGlubmVyL2RyLXNwaW5uZXIuZGlyZWN0aXZlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZHItaW5wdXRzL2J1dHRvbi9idXR0b24uY29tcG9uZW50JztcclxuXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RyLWlucHV0cy9kci1kYXRlLXBpY2tlci9kci1kYXRlLXBpY2tlci5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kci1pbnB1dHMvZHItZGF0ZS1waWNrZXIvZHItZGF0ZS1waWNrZXItZm9ybWF0LmRpcmVjdGl2ZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RyLXBvcG92ZXIvZHItcG9wb3Zlci5kaXJlY3RpdmUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kci1wb3BvdmVyL2RyLXBvcG92ZXIuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZHItcG9wb3Zlci9kci1wb3BvdmVyLnNlcnZpY2UnO1xyXG5cclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZHItZHJvcGRvd24vZHItZHJvcGRvd24uZGlyZWN0aXZlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZHItZHJvcGRvd24vZHItZHJvcGRvd24tcG9zaXRpb24uZGlyZWN0aXZlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZHItZHJvcGRvd24vZHItZHJvcGRvd24uY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZHItZHJvcGRvd24vZHItZHJvcGRvd24uc2VydmljZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RyLWRyb3Bkb3duL2RyLWRyb3Bkb3duLWl0ZW0tc2hvdy5waXBlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZHItdGFicy9kci10YWJzLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RyLXRhYnMvZHItdGFiLmNvbXBvbmVudCc7XHJcblxyXG4vKiBtb2RlbHMgKi9cclxuZXhwb3J0IHsgVEFHX1RZUEVTLCBJVGFnLCBJRGF0ZVRhZywgSUxpc3RUYWcsIElUYWdGb3JTZXJ2ZXIgfSBmcm9tICcuL2xpYi9tb2RlbHMvc2VydmVyVGFncyc7XHJcbmV4cG9ydCB7XHJcbiAgRWxQb3NpdGlvbixcclxuICBJRHJvcGRvd24sXHJcbiAgSURyb3Bkb3duSXRlbSxcclxuICBJRHJvcGRvd25BY3Rpb25JY29uLFxyXG4gIElEcm9wZG93bkNvb3JkaW5hdGUsXHJcbiAgSURyb3Bkb3duQ2FsbEV2ZW50LFxyXG4gIElEcm9wZG93bkFjdGlvblxyXG59IGZyb20gJy4vbGliL21vZGVscy9kcm9wZG93bic7XHJcbmV4cG9ydCB7XHJcbiAgRHJQb3BvdmVyUmVmLFxyXG4gIElEclBvcG92ZXJDb21wb25lbnRNb2RlbCxcclxuICBQb2ludCxcclxuICBEclBvcG92ZXJDb25maWcsXHJcbiAgSVBvcG92ZXJNYW51YWxDbG9zaW5nLFxyXG4gIERyUG9wb3ZlckFsaWdubWVudCxcclxuICBEclBvcG92ZXJBbGlnbm1lbnREaW1lbnNpb24sXHJcbn0gZnJvbSAnLi9saWIvbW9kZWxzL3BvcG92ZXInO1xyXG5cclxuLyogbW9kdWxlcyAqL1xyXG5leHBvcnQgeyBEYXRlVGFnTW9kdWxlIH0gZnJvbSAnLi9saWIvZGF0ZS10YWdzL2RhdGUtdGFnLm1vZHVsZSc7XHJcbmV4cG9ydCB7IExpc3RUYWdNb2R1bGUgfSBmcm9tICcuL2xpYi9saXN0LXRhZ3MvbGlzdC10YWcubW9kdWxlJztcclxuZXhwb3J0IHsgRHJUYWdNb2R1bGUgfSBmcm9tICcuL2xpYi9kci10YWdzL2RyLXRhZy5tb2R1bGUnO1xyXG5leHBvcnQgeyBEcklucHV0c01vZHVsZSB9IGZyb20gJy4vbGliL2RyLWlucHV0cy9kci1pbnB1dHMubW9kdWxlJztcclxuZXhwb3J0IHsgRHJUb29sdGlwTW9kdWxlIH0gZnJvbSAnLi9saWIvZHItdG9vbHRpcC9kci10b29sdGlwLm1vZHVsZSc7XHJcbmV4cG9ydCB7IERyQXZhdGFyTW9kdWxlIH0gZnJvbSAnLi9saWIvZHItYXZhdGFyL2RyLWF2YXRhci5tb2R1bGUnO1xyXG5leHBvcnQgeyBEclNwaW5uZXJNb2R1bGUgfSBmcm9tICcuL2xpYi9kci1zcGlubmVyL2RyLXNwaW5uZXIubW9kdWxlJztcclxuZXhwb3J0IHsgRHJQb3BvdmVyTW9kdWxlIH0gZnJvbSAnLi9saWIvZHItcG9wb3Zlci9kci1wb3BvdmVyLm1vZHVsZSc7XHJcbmV4cG9ydCB7IERyRHJvcGRvd25Nb2R1bGUgfSBmcm9tICcuL2xpYi9kci1kcm9wZG93bi9kci1kcm9wZG93bi5tb2R1bGUnO1xyXG5leHBvcnQgeyBEclRhYnNNb2R1bGUgfSBmcm9tICcuL2xpYi9kci10YWJzL2RyLXRhYnMubW9kdWxlJztcclxuIl19
|
|
@@ -1,16 +1,16 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import { EventEmitter, Component, ViewEncapsulation, Input, Output, ChangeDetectionStrategy, ChangeDetectorRef, forwardRef, ElementRef, Renderer2, HostBinding, ContentChild, Pipe, TemplateRef, Directive, HostListener, ComponentFactoryResolver, ViewContainerRef,
|
|
2
|
+
import { EventEmitter, Component, ViewEncapsulation, Input, Output, ChangeDetectionStrategy, ChangeDetectorRef, forwardRef, ElementRef, Inject, PLATFORM_ID, ContentChildren, Renderer2, HostBinding, ContentChild, Pipe, TemplateRef, Directive, HostListener, ComponentFactoryResolver, ViewContainerRef, ViewChild, Optional, Injector, Injectable, NgModule } from '@angular/core';
|
|
3
3
|
import { FormControl, NG_VALUE_ACCESSOR, NgControl, FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
4
4
|
import { DateAdapter, MAT_DATE_LOCALE, MAT_DATE_FORMATS, MatNativeDateModule } from '@angular/material/core';
|
|
5
5
|
import { MomentDateAdapter, MAT_MOMENT_DATE_ADAPTER_OPTIONS, MatMomentDateModule } from '@angular/material-moment-adapter';
|
|
6
6
|
import * as momentImported from 'moment';
|
|
7
|
-
import {
|
|
7
|
+
import { isPlatformBrowser, DOCUMENT, CommonModule } from '@angular/common';
|
|
8
|
+
import { Subject, from, merge, fromEvent, noop as noop$1 } from 'rxjs';
|
|
9
|
+
import { startWith, switchMap, takeUntil, filter, first } from 'rxjs/operators';
|
|
8
10
|
import { transition, style, animate, trigger } from '@angular/animations';
|
|
9
11
|
import * as i1 from '@angular/cdk/overlay';
|
|
10
12
|
import { Overlay, OverlayPositionBuilder, OverlayConfig } from '@angular/cdk/overlay';
|
|
11
13
|
import { ComponentPortal } from '@angular/cdk/portal';
|
|
12
|
-
import { DOCUMENT, CommonModule } from '@angular/common';
|
|
13
|
-
import { first } from 'rxjs/operators';
|
|
14
14
|
import { MatDatepickerModule } from '@angular/material/datepicker';
|
|
15
15
|
import { MatFormFieldModule } from '@angular/material/form-field';
|
|
16
16
|
import { MatInputModule } from '@angular/material/input';
|
|
@@ -785,6 +785,7 @@ DayTagComponent.propDecorators = {
|
|
|
785
785
|
class RadioButtonComponent {
|
|
786
786
|
constructor(cdr) {
|
|
787
787
|
this.cdr = cdr;
|
|
788
|
+
this.valueChange = new EventEmitter();
|
|
788
789
|
this.onChange = (onchanges => { });
|
|
789
790
|
this.onTouched = () => { };
|
|
790
791
|
}
|
|
@@ -808,6 +809,14 @@ class RadioButtonComponent {
|
|
|
808
809
|
}
|
|
809
810
|
valueChanged(event) {
|
|
810
811
|
this.onChange(this.modelValue);
|
|
812
|
+
this.valueChange.emit(this.value);
|
|
813
|
+
}
|
|
814
|
+
_setName(name) {
|
|
815
|
+
this.name = name;
|
|
816
|
+
this.cdr.markForCheck();
|
|
817
|
+
}
|
|
818
|
+
_markForCheck() {
|
|
819
|
+
this.cdr.markForCheck();
|
|
811
820
|
}
|
|
812
821
|
}
|
|
813
822
|
RadioButtonComponent.decorators = [
|
|
@@ -822,8 +831,7 @@ RadioButtonComponent.decorators = [
|
|
|
822
831
|
}
|
|
823
832
|
],
|
|
824
833
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
825
|
-
|
|
826
|
-
styles: ["label input[type=radio].radiobox+span{vertical-align:middle;line-height:20px}input+span,input+span:after,input+span:before{box-sizing:content-box!important;-webkit-box-sizing:content-box!important;-moz-box-sizing:content-box!important}input{visibility:hidden;position:absolute;width:18px;height:18px}label input+span{position:relative;z-index:19;display:inline-block;margin:0 5px 0 0;line-height:17px;min-height:14px;min-width:14px}label input+span:hover{cursor:pointer}label input+span:before{content:\"\";font-size:14px;border-radius:0;display:inline-block;text-align:center;vertical-align:middle;padding:1px;height:12px;line-height:13px;width:12px;margin-right:5px;border:1px solid #C3C4CE;background-color:#fff;font-weight:normal;margin-top:-1px}label input+span:before{border-radius:50%;-moz-border-radius:50%;-webkit-border-radius:50%}label input:checked+span:before,label:hover input:checked+span:before{background:white;border-color:#579bf2;color:#579bf2}label input:checked+span:before,label:hover input:checked+span:before{font-family:\"DataRails\"!important;background-image:url('data:image/svg+xml; utf8, <svg width=\"10\" height=\"10\" viewBox=\"0 0 10 10\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><circle cx=\"5\" cy=\"5\" r=\"4.5\" fill=\"%23579BF2\"/></svg> ');background-repeat:no-repeat;background-position:center;color:#579bf2}label input:disabled+span:before{border-color:#bcbcbc}label input[disabled]:checked+span:before{content:url('data:image/svg+xml; utf8, <svg width=\"10\" height=\"10\" viewBox=\"0 0 10 10\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><circle cx=\"5\" cy=\"5\" r=\"4.5\" fill=\"%23BCBCBC\"/></svg> ');border-color:#bcbcbc}label span:hover:before{border-color:#85889c}\n"]
|
|
834
|
+
styles: [":host{display:flex;line-height:22px}label input[type=radio].radiobox+span{vertical-align:middle;line-height:20px}input+span,input+span:after,input+span:before{box-sizing:content-box!important;-webkit-box-sizing:content-box!important;-moz-box-sizing:content-box!important}input{visibility:hidden;position:absolute;width:18px;height:18px}label input+span{position:relative;z-index:19;display:inline-block;margin:0 5px 0 0;line-height:17px;min-height:14px;min-width:14px}label input+span:hover{cursor:pointer}label input+span:before{content:\"\";font-size:14px;border-radius:0;display:inline-block;text-align:center;vertical-align:middle;padding:1px;height:12px;line-height:13px;width:12px;margin-right:5px;border:1px solid #C3C4CE;background-color:#fff;font-weight:normal;margin-top:-1px}label input+span:before{border-radius:50%;-moz-border-radius:50%;-webkit-border-radius:50%}label input:checked+span:before,label:hover input:checked+span:before{background:white;border-color:#579bf2;color:#579bf2}label input:checked+span:before,label:hover input:checked+span:before{font-family:\"DataRails\"!important;background-image:url('data:image/svg+xml; utf8, <svg width=\"10\" height=\"10\" viewBox=\"0 0 10 10\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><circle cx=\"5\" cy=\"5\" r=\"4.5\" fill=\"%23579BF2\"/></svg> ');background-repeat:no-repeat;background-position:center;color:#579bf2}label input:disabled+span:before{border-color:#bcbcbc}label input[disabled]:checked+span:before{content:url('data:image/svg+xml; utf8, <svg width=\"10\" height=\"10\" viewBox=\"0 0 10 10\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><circle cx=\"5\" cy=\"5\" r=\"4.5\" fill=\"%23BCBCBC\"/></svg> ');border-color:#bcbcbc}label span:hover:before{border-color:#85889c}\n"]
|
|
827
835
|
},] }
|
|
828
836
|
];
|
|
829
837
|
RadioButtonComponent.ctorParameters = () => [
|
|
@@ -832,7 +840,165 @@ RadioButtonComponent.ctorParameters = () => [
|
|
|
832
840
|
RadioButtonComponent.propDecorators = {
|
|
833
841
|
disabled: [{ type: Input }],
|
|
834
842
|
name: [{ type: Input }],
|
|
835
|
-
_value: [{ type: Input, args: ['value',] }]
|
|
843
|
+
_value: [{ type: Input, args: ['value',] }],
|
|
844
|
+
valueChange: [{ type: Output }]
|
|
845
|
+
};
|
|
846
|
+
|
|
847
|
+
class RadioGroupComponent {
|
|
848
|
+
constructor(hostElement, platformId, document) {
|
|
849
|
+
this.hostElement = hostElement;
|
|
850
|
+
this.platformId = platformId;
|
|
851
|
+
this.document = document;
|
|
852
|
+
this.destroy$ = new Subject();
|
|
853
|
+
this.valueChange = new EventEmitter();
|
|
854
|
+
this.onChange = (value) => { };
|
|
855
|
+
this.onTouched = () => { };
|
|
856
|
+
}
|
|
857
|
+
get value() {
|
|
858
|
+
return this._value;
|
|
859
|
+
}
|
|
860
|
+
set value(value) {
|
|
861
|
+
this._value = value;
|
|
862
|
+
this.updateValues();
|
|
863
|
+
}
|
|
864
|
+
get name() {
|
|
865
|
+
return this._name;
|
|
866
|
+
}
|
|
867
|
+
set name(name) {
|
|
868
|
+
this._name = name;
|
|
869
|
+
this.updateNames();
|
|
870
|
+
}
|
|
871
|
+
get disabled() {
|
|
872
|
+
return this._disabled;
|
|
873
|
+
}
|
|
874
|
+
set disabled(disabled) {
|
|
875
|
+
this._disabled = !!disabled;
|
|
876
|
+
this.updateDisabled();
|
|
877
|
+
}
|
|
878
|
+
ngAfterContentInit() {
|
|
879
|
+
// In case option 'name' isn't set on nb-radio component,
|
|
880
|
+
// we need to set it's name right away, so it won't overlap with options
|
|
881
|
+
// without names from other radio groups. Otherwise they all would have
|
|
882
|
+
// same name and will be considered as options from one group so only the
|
|
883
|
+
// last option will stay selected.
|
|
884
|
+
this.updateNames();
|
|
885
|
+
this.radios.changes
|
|
886
|
+
.pipe(startWith(this.radios),
|
|
887
|
+
// 'changes' emit during change detection run and we can't update
|
|
888
|
+
// option properties right of since they already was initialized.
|
|
889
|
+
// Instead we schedule microtask to update radios after change detection
|
|
890
|
+
// run is finished and trigger one more change detection run.
|
|
891
|
+
switchMap((radios) => from(Promise.resolve(radios))), takeUntil(this.destroy$))
|
|
892
|
+
.subscribe(() => this.updateAndSubscribeToRadios());
|
|
893
|
+
}
|
|
894
|
+
ngOnDestroy() {
|
|
895
|
+
this.destroy$.next();
|
|
896
|
+
this.destroy$.complete();
|
|
897
|
+
}
|
|
898
|
+
registerOnChange(fn) {
|
|
899
|
+
this.onChange = fn;
|
|
900
|
+
}
|
|
901
|
+
registerOnTouched(fn) {
|
|
902
|
+
this.onTouched = fn;
|
|
903
|
+
}
|
|
904
|
+
writeValue(value) {
|
|
905
|
+
this.value = value;
|
|
906
|
+
}
|
|
907
|
+
setDisabledState(isDisabled) {
|
|
908
|
+
this.disabled = isDisabled;
|
|
909
|
+
}
|
|
910
|
+
updateAndSubscribeToRadios() {
|
|
911
|
+
this.updateValueFromCheckedOption();
|
|
912
|
+
this.updateNames();
|
|
913
|
+
this.updateValues();
|
|
914
|
+
this.updateDisabled();
|
|
915
|
+
this.subscribeOnRadiosValueChange();
|
|
916
|
+
this.subscribeOnRadiosBlur();
|
|
917
|
+
}
|
|
918
|
+
updateNames() {
|
|
919
|
+
if (this.radios) {
|
|
920
|
+
this.radios.forEach((radio) => radio._setName(this.name));
|
|
921
|
+
}
|
|
922
|
+
}
|
|
923
|
+
updateValues() {
|
|
924
|
+
this.updateAndMarkForCheckRadios((radio) => {
|
|
925
|
+
if (radio.value === this.value) {
|
|
926
|
+
radio.modelValue = radio.value;
|
|
927
|
+
}
|
|
928
|
+
});
|
|
929
|
+
}
|
|
930
|
+
updateDisabled() {
|
|
931
|
+
if (typeof this.disabled !== 'undefined') {
|
|
932
|
+
this.updateAndMarkForCheckRadios((radio) => radio.disabled = this.disabled);
|
|
933
|
+
}
|
|
934
|
+
}
|
|
935
|
+
subscribeOnRadiosValueChange() {
|
|
936
|
+
if (!this.radios || !this.radios.length) {
|
|
937
|
+
return;
|
|
938
|
+
}
|
|
939
|
+
merge(...this.radios.map((radio) => radio.valueChange))
|
|
940
|
+
.pipe(takeUntil(merge(this.radios.changes, this.destroy$)))
|
|
941
|
+
.subscribe((value) => {
|
|
942
|
+
this.writeValue(value);
|
|
943
|
+
this.propagateValue(value);
|
|
944
|
+
});
|
|
945
|
+
}
|
|
946
|
+
propagateValue(value) {
|
|
947
|
+
this.valueChange.emit(value);
|
|
948
|
+
this.onChange(value);
|
|
949
|
+
}
|
|
950
|
+
subscribeOnRadiosBlur() {
|
|
951
|
+
const hasNoRadios = !this.radios || !this.radios.length;
|
|
952
|
+
if (!isPlatformBrowser(this.platformId) || hasNoRadios) {
|
|
953
|
+
return;
|
|
954
|
+
}
|
|
955
|
+
const hostElement = this.hostElement.nativeElement;
|
|
956
|
+
fromEvent(hostElement, 'focusin')
|
|
957
|
+
.pipe(filter(event => hostElement.contains(event.target)), switchMap(() => merge(fromEvent(this.document, 'focusin'), fromEvent(this.document, 'click'))), filter(event => !hostElement.contains(event.target)), takeUntil(merge(this.radios.changes, this.destroy$)))
|
|
958
|
+
.subscribe(() => this.onTouched());
|
|
959
|
+
}
|
|
960
|
+
updateAndMarkForCheckRadios(updateFn) {
|
|
961
|
+
if (this.radios) {
|
|
962
|
+
this.radios.forEach((radio) => {
|
|
963
|
+
updateFn(radio);
|
|
964
|
+
radio._markForCheck();
|
|
965
|
+
});
|
|
966
|
+
}
|
|
967
|
+
}
|
|
968
|
+
updateValueFromCheckedOption() {
|
|
969
|
+
const checkedRadio = this.radios.find((radio) => radio.modelValue);
|
|
970
|
+
const isValueMissing = this.value === undefined || this.value === null;
|
|
971
|
+
if (checkedRadio && isValueMissing && checkedRadio.value !== this.value) {
|
|
972
|
+
this.value = checkedRadio.value;
|
|
973
|
+
}
|
|
974
|
+
}
|
|
975
|
+
}
|
|
976
|
+
RadioGroupComponent.decorators = [
|
|
977
|
+
{ type: Component, args: [{
|
|
978
|
+
selector: 'dr-radio-group',
|
|
979
|
+
template: `
|
|
980
|
+
<ng-content select="dr-radio-button"></ng-content>`,
|
|
981
|
+
providers: [
|
|
982
|
+
{
|
|
983
|
+
provide: NG_VALUE_ACCESSOR,
|
|
984
|
+
useExisting: forwardRef(() => RadioGroupComponent),
|
|
985
|
+
multi: true,
|
|
986
|
+
},
|
|
987
|
+
],
|
|
988
|
+
changeDetection: ChangeDetectionStrategy.OnPush
|
|
989
|
+
},] }
|
|
990
|
+
];
|
|
991
|
+
RadioGroupComponent.ctorParameters = () => [
|
|
992
|
+
{ type: ElementRef },
|
|
993
|
+
{ type: undefined, decorators: [{ type: Inject, args: [PLATFORM_ID,] }] },
|
|
994
|
+
{ type: undefined, decorators: [{ type: Inject, args: [DOCUMENT,] }] }
|
|
995
|
+
];
|
|
996
|
+
RadioGroupComponent.propDecorators = {
|
|
997
|
+
value: [{ type: Input }],
|
|
998
|
+
name: [{ type: Input }],
|
|
999
|
+
disabled: [{ type: Input }],
|
|
1000
|
+
radios: [{ type: ContentChildren, args: [RadioButtonComponent, { descendants: true },] }],
|
|
1001
|
+
valueChange: [{ type: Output }]
|
|
836
1002
|
};
|
|
837
1003
|
|
|
838
1004
|
class CheckboxComponent {
|
|
@@ -1024,7 +1190,7 @@ class DrInputComponent {
|
|
|
1024
1190
|
DrInputComponent.decorators = [
|
|
1025
1191
|
{ type: Component, args: [{
|
|
1026
1192
|
selector: 'dr-input',
|
|
1027
|
-
template: "<ng-content select=\"[prefixIcon]\"></ng-content>\r\n<input [(ngModel)]=\"value\"\r\n (ngModelChange)=\"updateChanges()\"\r\n (blur)=\"blur.emit(value); onTouched()\"\r\n [disabled]=\"_disabled\"\r\n [readonly]=\"readonly\"\r\n [type]=\"type\"\r\n [placeholder]=\"placeholder\"\r\n [name]=\"name\"\r\n>\r\n<span class=\"clear-icon\" (click)=\"writeValue(null)\"></span>\r\n<span *ngIf=\"type === 'search'\" class=\"search-icon\" (click)=\"onSearchClicked($event)\"></span>\r\n<ng-content select=\"[suffixIcon]\"></ng-content>\r\n<button *ngIf=\"_buttonOptions.show || (_buttonOptions.showOnFocus && _buttonOptions.focusSet)\"\r\n (click)=\"onButtonClicked($event)\">\r\n {{_buttonOptions.text}}\r\n</button>\r\n",
|
|
1193
|
+
template: "<ng-content select=\"[prefixIcon]\"></ng-content>\r\n<input [(ngModel)]=\"value\"\r\n (ngModelChange)=\"updateChanges()\"\r\n (blur)=\"blur.emit(value); onTouched()\"\r\n [disabled]=\"_disabled\"\r\n [readonly]=\"readonly\"\r\n [type]=\"type\"\r\n [placeholder]=\"placeholder\"\r\n [name]=\"name\"\r\n [min]=\"min\"\r\n [step]=\"step\"\r\n>\r\n<span class=\"clear-icon\" (click)=\"writeValue(null)\"></span>\r\n<span *ngIf=\"type === 'search'\" class=\"search-icon\" (click)=\"onSearchClicked($event)\"></span>\r\n<ng-content select=\"[suffixIcon]\"></ng-content>\r\n<button *ngIf=\"_buttonOptions.show || (_buttonOptions.showOnFocus && _buttonOptions.focusSet)\"\r\n (click)=\"onButtonClicked($event)\">\r\n {{_buttonOptions.text}}\r\n</button>\r\n",
|
|
1028
1194
|
providers: [{
|
|
1029
1195
|
provide: NG_VALUE_ACCESSOR,
|
|
1030
1196
|
useExisting: forwardRef(() => DrInputComponent),
|
|
@@ -1047,6 +1213,8 @@ DrInputComponent.propDecorators = {
|
|
|
1047
1213
|
placeholder: [{ type: Input }],
|
|
1048
1214
|
readonly: [{ type: Input }],
|
|
1049
1215
|
clearable: [{ type: Input }],
|
|
1216
|
+
min: [{ type: Input }],
|
|
1217
|
+
step: [{ type: Input }],
|
|
1050
1218
|
blur: [{ type: Output }],
|
|
1051
1219
|
elementClass: [{ type: HostBinding, args: ['class',] }],
|
|
1052
1220
|
searchHandler: [{ type: Output }],
|
|
@@ -1149,9 +1317,9 @@ class DrAvatarComponent {
|
|
|
1149
1317
|
DrAvatarComponent.decorators = [
|
|
1150
1318
|
{ type: Component, args: [{
|
|
1151
1319
|
selector: 'dr-avatar',
|
|
1152
|
-
template: "<div class=\"users-section\">\r\n <div *ngIf=\"!parsedUsers.length\"\r\n class=\"users-section__default\"
|
|
1320
|
+
template: "<div class=\"users-section\">\r\n <div *ngIf=\"!parsedUsers.length\"\r\n class=\"users-section__default\">\r\n </div>\r\n\r\n <div *ngFor=\"let user of getFirstUsers()\"\r\n class=\"users-section__user\"\r\n [class]=\"'icon-' + user.colorNumber + ' ' + user.status\"\r\n (click)=\"userClicked.emit()\"\r\n [matTooltip]=\"user | drAvatar\"\r\n [matTooltipPosition]=\"'below'\">\r\n {{user | drAvatar: 'initials'}}\r\n </div>\r\n\r\n <div *ngIf=\"parsedUsers.length > 2\"\r\n class=\"users-section__user icon-2\"\r\n [drTooltip]=\"usersTemplate\"\r\n [drTooltipPosition]=\"'bottom'\">\r\n {{getLastUsers().length}}\r\n </div>\r\n</div>\r\n\r\n<ng-template #usersTemplate>\r\n <div *ngFor=\"let user of getLastUsers()\" class=\"users-popover-item\">\r\n <div class=\"users-section__user\"\r\n (click)=\"userClicked.emit()\"\r\n [class]=\"user.class\">\r\n {{user | drAvatar: 'initials'}}\r\n </div>\r\n <span class=\"username\">\r\n {{user | drAvatar}}\r\n </span>\r\n </div>\r\n</ng-template>\r\n",
|
|
1153
1321
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
1154
|
-
styles: [":host{width:auto}.users-section{display:flex;height:28px}.users-section__default{display:flex;height:28px;width:28px;border-radius:14px;background:url(\"data:image/svg+xml,%3Csvg width%3D%2224%22 height%3D%2224%22 viewBox%3D%220 0 24 24%22 fill%3D%22none%22 xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%0D%3Crect width%3D%2224%22 height%3D%2224%22 rx%3D%2212%22 fill%3D%22%23BCBCBC%22%2F%3E%0D%3Cpath d%3D%22M11.9993 11.9998C13.6108 11.9998 14.916 10.691 14.916 9.08317C14.916 7.47171 13.6108 6.1665 11.9993 6.1665C10.3879 6.1665 9.08268 7.47171 9.08268 9.08317C9.08268 10.691 10.3879 11.9998 11.9993 11.9998ZM11.9993 13.4582C10.0561 13.4582 6.16602 14.4316 6.16602 16.3748V17.8332H17.8327V16.3748C17.8327 14.4316 13.9426 13.4582 11.9993 13.4582Z%22 fill%3D%22white%22%2F%3E%0D%3C%2Fsvg%3E%0D\") no-repeat}.users-popover-item{display:flex;align-items:center;margin:12px}.users-popover-item .username{color:#51566f;font-size:14px}.users-popover-item .users-section__user{margin-right:8px}.users-section__user{position:relative;display:flex;justify-content:center;align-items:center;height:28px;width:28px;border-radius:14px;background:red;color:#fff;font-size:12px}.users-section__user.icon-0{background-color:#7b61ff}.users-section__user.icon-1{background-color:#21b8f1}.users-section__user.icon-2{background-color:#2969b0}.users-section__user.icon-3{background-color:#51566f}.users-section__user.icon-4{background-color:#0061ff}.users-section__user:hover{cursor:pointer}.users-section__user:not(:first-child){margin-left:4px}.users-section__user.warning:after{content:\"\";display:flex;width:8px;height:8px;position:absolute;
|
|
1322
|
+
styles: [":host{width:auto}.users-section{display:flex;height:28px}.users-section__default{display:flex;height:28px;width:28px;border-radius:14px;background:url(\"data:image/svg+xml,%3Csvg width%3D%2224%22 height%3D%2224%22 viewBox%3D%220 0 24 24%22 fill%3D%22none%22 xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%0D%3Crect width%3D%2224%22 height%3D%2224%22 rx%3D%2212%22 fill%3D%22%23BCBCBC%22%2F%3E%0D%3Cpath d%3D%22M11.9993 11.9998C13.6108 11.9998 14.916 10.691 14.916 9.08317C14.916 7.47171 13.6108 6.1665 11.9993 6.1665C10.3879 6.1665 9.08268 7.47171 9.08268 9.08317C9.08268 10.691 10.3879 11.9998 11.9993 11.9998ZM11.9993 13.4582C10.0561 13.4582 6.16602 14.4316 6.16602 16.3748V17.8332H17.8327V16.3748C17.8327 14.4316 13.9426 13.4582 11.9993 13.4582Z%22 fill%3D%22white%22%2F%3E%0D%3C%2Fsvg%3E%0D\") no-repeat}.users-popover-item{display:flex;align-items:center;margin:12px}.users-popover-item .username{color:#51566f;font-size:14px}.users-popover-item .users-section__user{margin-right:8px}.users-section__user{position:relative;display:flex;justify-content:center;align-items:center;height:28px;width:28px;border-radius:14px;background:red;color:#fff;font-size:12px}.users-section__user.icon-0{background-color:#7b61ff}.users-section__user.icon-1{background-color:#21b8f1}.users-section__user.icon-2{background-color:#2969b0}.users-section__user.icon-3{background-color:#51566f}.users-section__user.icon-4{background-color:#0061ff}.users-section__user:hover{cursor:pointer}.users-section__user:not(:first-child){margin-left:4px}.users-section__user.online:after,.users-section__user.offline:after,.users-section__user.warning:after{content:\"\";display:flex;width:8px;height:8px;position:absolute;border-radius:4px;top:-2px;right:0}.users-section__user.online:after{background:#03A678}.users-section__user.offline:after{background:#DE2833}.users-section__user.warning:after{background:#FDA014}\n"]
|
|
1155
1323
|
},] }
|
|
1156
1324
|
];
|
|
1157
1325
|
DrAvatarComponent.ctorParameters = () => [];
|
|
@@ -1399,6 +1567,7 @@ class DrToggleComponent {
|
|
|
1399
1567
|
constructor(cdr) {
|
|
1400
1568
|
this.cdr = cdr;
|
|
1401
1569
|
this._disabled = false;
|
|
1570
|
+
this._elementClass = [];
|
|
1402
1571
|
this.checkedChange = new EventEmitter();
|
|
1403
1572
|
this.onChange = () => { };
|
|
1404
1573
|
this.onTouched = () => { };
|
|
@@ -1406,6 +1575,12 @@ class DrToggleComponent {
|
|
|
1406
1575
|
set disabled(value) {
|
|
1407
1576
|
this.setDisabledState(value);
|
|
1408
1577
|
}
|
|
1578
|
+
get elementClass() { return this._elementClass.join(' '); }
|
|
1579
|
+
ngAfterViewInit() {
|
|
1580
|
+
if (this.toggleTitleRight) {
|
|
1581
|
+
this._elementClass.push('toggle-label-alignment');
|
|
1582
|
+
}
|
|
1583
|
+
}
|
|
1409
1584
|
writeValue(value) {
|
|
1410
1585
|
this.checkedStatus = value;
|
|
1411
1586
|
this.cdr.markForCheck();
|
|
@@ -1434,7 +1609,7 @@ DrToggleComponent.decorators = [
|
|
|
1434
1609
|
{ provide: NG_VALUE_ACCESSOR, useExisting: DrToggleComponent, multi: true }
|
|
1435
1610
|
],
|
|
1436
1611
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
1437
|
-
styles: [":host{display:flex;justify-content:space-between;align-items:center}:host .toggle-container.disabled{pointer-events:none}:host .toggle-container.disabled .toggle-body{background-color:#8f9bb329!important}:host .toggle-container.disabled .toggle-body i{background:rgba(143,155,179,.24)!important}:host .toggle-container.success input:checked+span.toggle-body{background-color:#03a678}:host .toggle-container input{display:none}:host .toggle-container input:checked+span.toggle-body>i,:host .toggle-container input:checked+span.toggle-body:active>i{margin-left:16px}:host .toggle-container input:checked+span.toggle-body{background-color:#579bf2}:host .toggle-container .toggle-body{cursor:pointer;display:block;width:30px;height:16px;margin:7px auto;border-radius:15px;transition:all .2s ease-in-out;-webkit-transition:all .2s ease-in-out;background-color:#aeb5bb;line-height:1}:host .toggle-container .toggle-body:active{background-color:#a6b9cb}:host .toggle-container .toggle-body-wrapper{display:flex;flex-direction:column}:host .toggle-container .toggle-body i{height:12px;width:12px;background:#fff;display:inline-block;border-radius:100px;margin-top:2px;margin-left:1.5px;transition:all .2s ease-in-out;-webkit-transition:all .2s ease-in-out;pointer-events:none}\n"]
|
|
1612
|
+
styles: [":host{display:flex;justify-content:space-between;align-items:center}:host.toggle-label-alignment{justify-content:start}:host .toggle-container.disabled{pointer-events:none}:host .toggle-container.disabled .toggle-body{background-color:#8f9bb329!important}:host .toggle-container.disabled .toggle-body i{background:rgba(143,155,179,.24)!important}:host .toggle-container.success input:checked+span.toggle-body{background-color:#03a678}:host .toggle-container input{display:none}:host .toggle-container input:checked+span.toggle-body>i,:host .toggle-container input:checked+span.toggle-body:active>i{margin-left:16px}:host .toggle-container input:checked+span.toggle-body{background-color:#579bf2}:host .toggle-container .toggle-body{cursor:pointer;display:block;width:30px;height:16px;margin:7px auto;border-radius:15px;transition:all .2s ease-in-out;-webkit-transition:all .2s ease-in-out;background-color:#aeb5bb;line-height:1}:host .toggle-container .toggle-body:active{background-color:#a6b9cb}:host .toggle-container .toggle-body-wrapper{display:flex;flex-direction:column}:host .toggle-container .toggle-body i{height:12px;width:12px;background:#fff;display:inline-block;border-radius:100px;margin-top:2px;margin-left:1.5px;transition:all .2s ease-in-out;-webkit-transition:all .2s ease-in-out;pointer-events:none}\n"]
|
|
1438
1613
|
},] }
|
|
1439
1614
|
];
|
|
1440
1615
|
DrToggleComponent.ctorParameters = () => [
|
|
@@ -1446,7 +1621,8 @@ DrToggleComponent.propDecorators = {
|
|
|
1446
1621
|
successType: [{ type: Input }],
|
|
1447
1622
|
checkedStatus: [{ type: Input }],
|
|
1448
1623
|
disabled: [{ type: Input }],
|
|
1449
|
-
checkedChange: [{ type: Output }]
|
|
1624
|
+
checkedChange: [{ type: Output }],
|
|
1625
|
+
elementClass: [{ type: HostBinding, args: ['class',] }]
|
|
1450
1626
|
};
|
|
1451
1627
|
|
|
1452
1628
|
class DrToggleButtonComponent {
|
|
@@ -2137,6 +2313,7 @@ class DrDropdownComponent {
|
|
|
2137
2313
|
if ((_a = item.children) === null || _a === void 0 ? void 0 : _a.length) {
|
|
2138
2314
|
item.childOptions = {
|
|
2139
2315
|
list: item.children,
|
|
2316
|
+
class: item.childOptions.class,
|
|
2140
2317
|
position: 'child'
|
|
2141
2318
|
};
|
|
2142
2319
|
}
|
|
@@ -2352,7 +2529,7 @@ class DrDropdownPositionDirective {
|
|
|
2352
2529
|
this.renderer.setStyle(this.el.nativeElement, 'z-index', '10010');
|
|
2353
2530
|
}
|
|
2354
2531
|
else {
|
|
2355
|
-
const defaultChildPadding =
|
|
2532
|
+
const defaultChildPadding = 3;
|
|
2356
2533
|
const widthMoreWindowRight = window.innerWidth - this.position.clientX - this.el.nativeElement.offsetWidth - defaultPadding;
|
|
2357
2534
|
const widthMoreWindowBottom = window.innerHeight - this.position.clientY - this.el.nativeElement.offsetHeight - defaultPadding;
|
|
2358
2535
|
const calculatedHorizantallyPos = widthMoreWindowRight < 0
|
|
@@ -2511,6 +2688,7 @@ DrTagModule.decorators = [
|
|
|
2511
2688
|
const components$1 = [
|
|
2512
2689
|
DrButtonComponent,
|
|
2513
2690
|
RadioButtonComponent,
|
|
2691
|
+
RadioGroupComponent,
|
|
2514
2692
|
CheckboxComponent,
|
|
2515
2693
|
DrInputComponent,
|
|
2516
2694
|
DrSelectComponent,
|
|
@@ -2662,5 +2840,5 @@ DrTabsModule.decorators = [
|
|
|
2662
2840
|
* Generated bundle index. Do not edit.
|
|
2663
2841
|
*/
|
|
2664
2842
|
|
|
2665
|
-
export { AnyTagComponent, CheckboxComponent, DateTagComponent, DateTagModule, DayTagComponent, DrAvatarComponent, DrAvatarModule, DrAvatarPipe, DrButtonComponent, DrDatePickerComponent, DrDatePickerFormatDirective, DrDropdownComponent, DrDropdownDirective, DrDropdownItemShowPipe, DrDropdownModule, DrDropdownPositionDirective, DrDropdownService, DrInputComponent, DrInputsModule, DrPopoverAlignmentDimension, DrPopoverComponent, DrPopoverDirective, DrPopoverModule, DrPopoverRef, DrPopoverService, DrSelectComponent, DrSpinnerComponent, DrSpinnerDirective, DrSpinnerModule, DrTabComponent, DrTabsComponent, DrTabsModule, DrTagComponent, DrTagModule, DrToggleButtonComponent, DrToggleComponent, DrTooltipDirective, DrTooltipModule, ForecastTagComponent, ISpinnerOptions, ListTagComponent, ListTagModule, MonthTagComponent, QuarterTagComponent, RadioButtonComponent, TooltipComponent, WeekTagComponent, YearTagComponent, components$2 as ɵa, POPUP_ANIMATION as ɵb, CustomDateFormat as ɵc };
|
|
2843
|
+
export { AnyTagComponent, CheckboxComponent, DateTagComponent, DateTagModule, DayTagComponent, DrAvatarComponent, DrAvatarModule, DrAvatarPipe, DrButtonComponent, DrDatePickerComponent, DrDatePickerFormatDirective, DrDropdownComponent, DrDropdownDirective, DrDropdownItemShowPipe, DrDropdownModule, DrDropdownPositionDirective, DrDropdownService, DrInputComponent, DrInputsModule, DrPopoverAlignmentDimension, DrPopoverComponent, DrPopoverDirective, DrPopoverModule, DrPopoverRef, DrPopoverService, DrSelectComponent, DrSpinnerComponent, DrSpinnerDirective, DrSpinnerModule, DrTabComponent, DrTabsComponent, DrTabsModule, DrTagComponent, DrTagModule, DrToggleButtonComponent, DrToggleComponent, DrTooltipDirective, DrTooltipModule, ForecastTagComponent, ISpinnerOptions, ListTagComponent, ListTagModule, MonthTagComponent, QuarterTagComponent, RadioButtonComponent, RadioGroupComponent, TooltipComponent, WeekTagComponent, YearTagComponent, components$2 as ɵa, POPUP_ANIMATION as ɵb, CustomDateFormat as ɵc };
|
|
2666
2844
|
//# sourceMappingURL=datarailsshared-datarailsshared.js.map
|