@seniorsistemas/angular-components 17.13.1 → 17.14.1
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/seniorsistemas-angular-components.umd.js +998 -779
- package/bundles/seniorsistemas-angular-components.umd.js.map +1 -1
- package/bundles/seniorsistemas-angular-components.umd.min.js +2 -2
- package/bundles/seniorsistemas-angular-components.umd.min.js.map +1 -1
- package/components/checkbox/checkbox.component.d.ts +16 -0
- package/components/checkbox/checkbox.module.d.ts +2 -0
- package/components/checkbox/index.d.ts +3 -0
- package/components/checkbox/models/checkbox-data.d.ts +4 -0
- package/components/checkbox/models/checkbox-state.d.ts +6 -0
- package/components/checkbox/models/index.d.ts +2 -0
- package/components/code-editor/{presentation/code-editor-component.d.ts → code-editor.component.d.ts} +11 -6
- package/components/code-editor/index.d.ts +1 -1
- package/components/dynamic-form/components/fields/base-field-component.d.ts +6 -5
- package/components/dynamic-form/components/fields/checkbox/checkbox-field.component.d.ts +7 -0
- package/components/dynamic-form/components/fields/checkbox/checkbox-field.module.d.ts +2 -0
- package/components/dynamic-form/components/fields/code-editor/code-editor-field.component.d.ts +6 -0
- package/components/dynamic-form/components/fields/code-editor/code-editor-field.module.d.ts +2 -0
- package/components/dynamic-form/components/fields/index.d.ts +1 -0
- package/components/dynamic-form/configurations/field-type.d.ts +2 -0
- package/components/dynamic-form/configurations/fields/checkbox-field.d.ts +9 -0
- package/components/dynamic-form/configurations/fields/code-editor-field.d.ts +17 -0
- package/components/dynamic-form/configurations/fields/index.d.ts +1 -0
- package/components/dynamic-form/configurations/form-field.d.ts +2 -2
- package/components/dynamic-form/index.d.ts +5 -4
- package/components/index.d.ts +1 -0
- package/esm2015/components/checkbox/checkbox.component.js +104 -0
- package/esm2015/components/checkbox/checkbox.module.js +16 -0
- package/esm2015/components/checkbox/index.js +3 -0
- package/esm2015/components/checkbox/models/checkbox-data.js +1 -0
- package/esm2015/components/checkbox/models/checkbox-state.js +1 -0
- package/esm2015/components/checkbox/models/index.js +1 -0
- package/esm2015/components/code-editor/code-editor.component.js +110 -0
- package/esm2015/components/code-editor/code-editor.module.js +24 -0
- package/esm2015/components/code-editor/index.js +2 -2
- package/esm2015/components/dynamic-form/components/fields/base-field-component.js +1 -1
- package/esm2015/components/dynamic-form/components/fields/checkbox/checkbox-field.component.js +17 -0
- package/esm2015/components/dynamic-form/components/fields/checkbox/checkbox-field.module.js +17 -0
- package/esm2015/components/dynamic-form/components/fields/code-editor/code-editor-field.component.js +17 -0
- package/esm2015/components/dynamic-form/components/fields/code-editor/code-editor-field.module.js +18 -0
- package/esm2015/components/dynamic-form/components/fields/index.js +2 -1
- package/esm2015/components/dynamic-form/configurations/field-type.js +3 -1
- package/esm2015/components/dynamic-form/configurations/fields/checkbox-field.js +8 -0
- package/esm2015/components/dynamic-form/configurations/fields/code-editor-field.js +12 -0
- package/esm2015/components/dynamic-form/configurations/fields/index.js +2 -1
- package/esm2015/components/dynamic-form/configurations/form-field.js +11 -6
- package/esm2015/components/dynamic-form/dynamic-form.js +8 -2
- package/esm2015/components/dynamic-form/dynamic-form.module.js +19 -33
- package/esm2015/components/dynamic-form/index.js +5 -4
- package/esm2015/components/index.js +2 -1
- package/esm2015/seniorsistemas-angular-components.js +82 -78
- package/esm5/components/checkbox/checkbox.component.js +109 -0
- package/esm5/components/checkbox/checkbox.module.js +19 -0
- package/esm5/components/checkbox/index.js +3 -0
- package/esm5/components/checkbox/models/checkbox-data.js +1 -0
- package/esm5/components/checkbox/models/checkbox-state.js +1 -0
- package/esm5/components/checkbox/models/index.js +1 -0
- package/esm5/components/code-editor/code-editor.component.js +121 -0
- package/esm5/components/code-editor/code-editor.module.js +27 -0
- package/esm5/components/code-editor/index.js +2 -2
- package/esm5/components/dynamic-form/components/fields/base-field-component.js +1 -1
- package/esm5/components/dynamic-form/components/fields/checkbox/checkbox-field.component.js +20 -0
- package/esm5/components/dynamic-form/components/fields/checkbox/checkbox-field.module.js +20 -0
- package/esm5/components/dynamic-form/components/fields/code-editor/code-editor-field.component.js +20 -0
- package/esm5/components/dynamic-form/components/fields/code-editor/code-editor-field.module.js +21 -0
- package/esm5/components/dynamic-form/components/fields/index.js +2 -1
- package/esm5/components/dynamic-form/configurations/field-type.js +3 -1
- package/esm5/components/dynamic-form/configurations/fields/checkbox-field.js +13 -0
- package/esm5/components/dynamic-form/configurations/fields/code-editor-field.js +17 -0
- package/esm5/components/dynamic-form/configurations/fields/index.js +2 -1
- package/esm5/components/dynamic-form/configurations/form-field.js +11 -6
- package/esm5/components/dynamic-form/dynamic-form.js +8 -2
- package/esm5/components/dynamic-form/dynamic-form.module.js +19 -33
- package/esm5/components/dynamic-form/index.js +5 -4
- package/esm5/components/index.js +2 -1
- package/esm5/seniorsistemas-angular-components.js +82 -78
- package/fesm2015/seniorsistemas-angular-components.js +751 -566
- package/fesm2015/seniorsistemas-angular-components.js.map +1 -1
- package/fesm5/seniorsistemas-angular-components.js +914 -702
- package/fesm5/seniorsistemas-angular-components.js.map +1 -1
- package/package.json +1 -1
- package/seniorsistemas-angular-components.d.ts +81 -77
- package/seniorsistemas-angular-components.metadata.json +1 -1
- package/esm2015/components/code-editor/presentation/code-editor-component.js +0 -91
- package/esm2015/components/code-editor/presentation/code-editor-module.js +0 -27
- package/esm5/components/code-editor/presentation/code-editor-component.js +0 -101
- package/esm5/components/code-editor/presentation/code-editor-module.js +0 -30
- /package/components/code-editor/{presentation/code-editor-module.d.ts → code-editor.module.d.ts} +0 -0
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { ControlValueAccessor } from "@angular/forms";
|
|
2
|
+
import { CheckboxData } from "./models/checkbox-data";
|
|
3
|
+
import { CheckboxState } from "./models/checkbox-state";
|
|
4
|
+
export declare class CheckboxComponent implements ControlValueAccessor {
|
|
5
|
+
data: CheckboxData;
|
|
6
|
+
state: CheckboxState;
|
|
7
|
+
private _onChange;
|
|
8
|
+
private _onTouched;
|
|
9
|
+
writeValue(value: CheckboxState): void;
|
|
10
|
+
registerOnChange(onChange: (value: CheckboxState) => void): void;
|
|
11
|
+
registerOnTouched(onTouched: () => void): void;
|
|
12
|
+
private _initializeChildren;
|
|
13
|
+
updateParent(): void;
|
|
14
|
+
onCheckboxChange(): void;
|
|
15
|
+
private _toggleChildrenCheck;
|
|
16
|
+
}
|
|
@@ -1,18 +1,23 @@
|
|
|
1
1
|
import { OnInit, AfterViewInit, OnDestroy, EventEmitter } from "@angular/core";
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
|
|
2
|
+
import { ControlValueAccessor } from "@angular/forms";
|
|
3
|
+
import { CoreFacade } from "./core/facades/core-facade";
|
|
4
|
+
import { EditorOptions } from "./models";
|
|
5
|
+
export declare class CodeEditorComponent implements OnInit, AfterViewInit, ControlValueAccessor, OnDestroy {
|
|
5
6
|
private readonly coreFacade;
|
|
6
|
-
private _ngUnsubscribe;
|
|
7
|
-
private coreWrapperElement;
|
|
8
7
|
set editorOptions(options: EditorOptions);
|
|
9
8
|
set code(code: string);
|
|
10
9
|
codeChange: EventEmitter<string>;
|
|
11
|
-
isCodeValid: boolean;
|
|
12
10
|
isCodeValidChange: EventEmitter<boolean>;
|
|
13
11
|
onCodeChange: EventEmitter<string>;
|
|
14
12
|
onComponentFinishLoad: EventEmitter<void>;
|
|
13
|
+
private coreWrapperElement;
|
|
14
|
+
private _ngUnsubscribe;
|
|
15
|
+
private _onChange;
|
|
16
|
+
private _onTouched;
|
|
15
17
|
constructor(coreFacade: CoreFacade);
|
|
18
|
+
writeValue(value: string): void;
|
|
19
|
+
registerOnChange(onChange: (value: string) => void): void;
|
|
20
|
+
registerOnTouched(onTouched: () => void): void;
|
|
16
21
|
ngOnInit(): void;
|
|
17
22
|
ngAfterViewInit(): void;
|
|
18
23
|
ngOnDestroy(): void;
|
|
@@ -1,23 +1,24 @@
|
|
|
1
1
|
import { FormControl } from "@angular/forms";
|
|
2
2
|
import { AutocompleteField } from "../../configurations/fields/autocomplete-field";
|
|
3
|
+
import { BlobField } from "../../configurations/fields/blob-field";
|
|
3
4
|
import { BooleanField } from "../../configurations/fields/boolean-field";
|
|
4
5
|
import { CalendarField } from "../../configurations/fields/calendar-field";
|
|
6
|
+
import { CheckboxField } from "../../configurations/fields/checkbox-field";
|
|
5
7
|
import { ChipsField } from "../../configurations/fields/chips-field";
|
|
6
8
|
import { CountryPhonePickerField } from "../../configurations/fields/country-phone-picker-field";
|
|
7
9
|
import { CurrencyField } from "../../configurations/fields/currency-field";
|
|
8
|
-
import {
|
|
10
|
+
import { EditorField } from "../../configurations/fields/editor-field";
|
|
9
11
|
import { LookupField } from "../../configurations/fields/lookup-field";
|
|
10
12
|
import { NumberField } from "../../configurations/fields/number-field";
|
|
13
|
+
import { PasswordField } from "../../configurations/fields/password-field";
|
|
11
14
|
import { RadioButtonField } from "../../configurations/fields/radio-button-field";
|
|
12
15
|
import { SelectField } from "../../configurations/fields/select-field";
|
|
16
|
+
import { SliderField } from "../../configurations/fields/slider-field";
|
|
13
17
|
import { TextAreaField } from "../../configurations/fields/text-area-field";
|
|
14
18
|
import { TextAreaIAField } from "../../configurations/fields/text-area-ia-field";
|
|
15
19
|
import { TextField } from "../../configurations/fields/text-field";
|
|
16
|
-
import { PasswordField } from "../../configurations/fields/password-field";
|
|
17
|
-
import { SliderField } from "../../configurations/fields/slider-field";
|
|
18
|
-
import { EditorField } from "../../configurations/fields/editor-field";
|
|
19
20
|
export interface BaseFieldComponentConfig {
|
|
20
|
-
field: AutocompleteField | BooleanField | BlobField | CalendarField | ChipsField | CountryPhonePickerField | CurrencyField | EditorField | LookupField | NumberField | PasswordField | RadioButtonField | SelectField | SliderField | TextAreaField | TextAreaIAField | TextField;
|
|
21
|
+
field: AutocompleteField | BooleanField | BlobField | CalendarField | CheckboxField | ChipsField | CountryPhonePickerField | CurrencyField | EditorField | LookupField | NumberField | PasswordField | RadioButtonField | SelectField | SliderField | TextAreaField | TextAreaIAField | TextField;
|
|
21
22
|
formControl: FormControl;
|
|
22
23
|
}
|
|
23
24
|
export declare class BaseFieldComponent {
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { FormControl } from "@angular/forms";
|
|
2
|
+
import { CheckboxField } from "../../../configurations/fields";
|
|
3
|
+
import { BaseFieldComponentConfig } from "../base-field-component";
|
|
4
|
+
export declare class CheckboxFieldComponent implements BaseFieldComponentConfig {
|
|
5
|
+
field: CheckboxField;
|
|
6
|
+
formControl: FormControl;
|
|
7
|
+
}
|
|
@@ -3,6 +3,7 @@ export { BignumberFieldComponent } from "./bignumber/bignumber-field.component";
|
|
|
3
3
|
export { BooleanFieldComponent } from "./boolean/boolean-field.component";
|
|
4
4
|
export { BooleanSwitchFieldComponent } from "./boolean/boolean-switch-field.component";
|
|
5
5
|
export { CalendarFieldComponent } from "./calendar/calendar-field.component";
|
|
6
|
+
export { CheckboxFieldComponent } from "./checkbox/checkbox-field.component";
|
|
6
7
|
export { ChipsFieldComponent } from "./chips/chips-field.component";
|
|
7
8
|
export { CountryPhonePickerFieldComponent } from "./country-phone-picker/country-phone-picker-field.component";
|
|
8
9
|
export { CurrencyFieldComponent } from "./currency/currency-field.component";
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { CheckboxData } from "../../../checkbox/models";
|
|
2
|
+
import { Field, FieldConfig } from "./field";
|
|
3
|
+
export interface CheckboxFieldConfig extends FieldConfig {
|
|
4
|
+
data: CheckboxData;
|
|
5
|
+
}
|
|
6
|
+
export declare class CheckboxField extends Field {
|
|
7
|
+
data: CheckboxData;
|
|
8
|
+
constructor(config: CheckboxFieldConfig);
|
|
9
|
+
}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { EditorOptions } from "../../../code-editor";
|
|
2
|
+
import { Field, FieldConfig } from "./field";
|
|
3
|
+
export interface CodeEditorConfig extends FieldConfig {
|
|
4
|
+
editorOptions: EditorOptions;
|
|
5
|
+
code: string;
|
|
6
|
+
isCodeValid: boolean;
|
|
7
|
+
onComponentFinishLoad: (event: any) => void;
|
|
8
|
+
onCodeChange: (event: any) => void;
|
|
9
|
+
}
|
|
10
|
+
export declare class CodeEditorField extends Field {
|
|
11
|
+
editorOptions: EditorOptions;
|
|
12
|
+
code: string;
|
|
13
|
+
isCodeValid: boolean;
|
|
14
|
+
onComponentFinishLoad: (event: any) => void;
|
|
15
|
+
onCodeChange: (event: any) => void;
|
|
16
|
+
constructor(config: CodeEditorConfig);
|
|
17
|
+
}
|
|
@@ -4,6 +4,7 @@ export { BlobField } from "./blob-field";
|
|
|
4
4
|
export { BooleanField } from "./boolean-field";
|
|
5
5
|
export { BooleanSwitchField } from "./boolean-switch-field";
|
|
6
6
|
export { CalendarField } from "./calendar-field";
|
|
7
|
+
export { CheckboxField } from "./checkbox-field";
|
|
7
8
|
export { ChipsField } from "./chips-field";
|
|
8
9
|
export { CountryPhonePickerField } from "./country-phone-picker-field";
|
|
9
10
|
export { CurrencyField } from "./currency-field";
|
|
@@ -1,3 +1,5 @@
|
|
|
1
|
+
import { TemplateRef } from "@angular/core";
|
|
2
|
+
import { AbstractControl } from "@angular/forms";
|
|
1
3
|
import { AlignmentOptions } from "@seniorsistemas/ng2-currency-mask";
|
|
2
4
|
import { FileDto } from "../../file-upload/index";
|
|
3
5
|
import { CalendarLocaleOptions, NumberLocaleOptions } from "../../locale/index";
|
|
@@ -6,8 +8,6 @@ import { AddonConfig } from "./addon-config";
|
|
|
6
8
|
import { FieldSize } from "./field-size";
|
|
7
9
|
import { FieldType } from "./field-type";
|
|
8
10
|
import { BooleanOptionsLabel } from "./fields/boolean-field";
|
|
9
|
-
import { TemplateRef } from "@angular/core";
|
|
10
|
-
import { AbstractControl } from "@angular/forms";
|
|
11
11
|
export declare class FormField {
|
|
12
12
|
id?: string;
|
|
13
13
|
/**
|
|
@@ -1,27 +1,28 @@
|
|
|
1
|
-
export * from "./components/lookup/lookup.component";
|
|
2
1
|
export * from "./components/fields/base-field-component";
|
|
2
|
+
export * from "./components/lookup/lookup.component";
|
|
3
|
+
export * from "./components/lookup/models/index";
|
|
3
4
|
export * from "./configurations/addon-config";
|
|
4
5
|
export * from "./configurations/dynamic-config";
|
|
5
6
|
export * from "./configurations/dynamic-type";
|
|
6
7
|
export * from "./configurations/field-type";
|
|
7
8
|
export * from "./configurations/fields/autocomplete-field";
|
|
9
|
+
export * from "./configurations/fields/bignumber-field";
|
|
8
10
|
export * from "./configurations/fields/boolean-field";
|
|
9
11
|
export * from "./configurations/fields/calendar-field";
|
|
10
12
|
export * from "./configurations/fields/chips-field";
|
|
13
|
+
export * from "./configurations/fields/code-editor-field";
|
|
11
14
|
export * from "./configurations/fields/currency-field";
|
|
12
15
|
export * from "./configurations/fields/field";
|
|
13
16
|
export * from "./configurations/fields/lookup-field";
|
|
14
17
|
export * from "./configurations/fields/number-field";
|
|
15
|
-
export * from "./configurations/fields/
|
|
18
|
+
export * from "./configurations/fields/password-field";
|
|
16
19
|
export * from "./configurations/fields/radio-button-field";
|
|
17
20
|
export * from "./configurations/fields/select-field";
|
|
18
21
|
export * from "./configurations/fields/text-area-field";
|
|
19
22
|
export * from "./configurations/fields/text-field";
|
|
20
|
-
export * from "./configurations/fields/password-field";
|
|
21
23
|
export * from "./configurations/form-field";
|
|
22
24
|
export * from "./configurations/structure/fieldset";
|
|
23
25
|
export * from "./configurations/structure/section";
|
|
24
26
|
export * from "./configurations/structure/structure";
|
|
25
|
-
export * from "./components/lookup/models/index";
|
|
26
27
|
export * from "./dynamic-form.component";
|
|
27
28
|
export * from "./dynamic-form.module";
|
package/components/index.d.ts
CHANGED
|
@@ -6,6 +6,7 @@ export * from "./breadcrumb/index";
|
|
|
6
6
|
export * from "./button/index";
|
|
7
7
|
export * from "./calendar-mask/index";
|
|
8
8
|
export * from "./card/index";
|
|
9
|
+
export * from "./checkbox/index";
|
|
9
10
|
export * from "./code-editor/index";
|
|
10
11
|
export * from "./collapse-link/index";
|
|
11
12
|
export * from "./control-errors/index";
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
var CheckboxComponent_1;
|
|
2
|
+
import { __decorate } from "tslib";
|
|
3
|
+
import { Component, forwardRef, Input } from "@angular/core";
|
|
4
|
+
import { NG_VALUE_ACCESSOR } from "@angular/forms";
|
|
5
|
+
let CheckboxComponent = CheckboxComponent_1 = class CheckboxComponent {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.state = {
|
|
8
|
+
checked: false,
|
|
9
|
+
indeterminate: false,
|
|
10
|
+
children: {},
|
|
11
|
+
};
|
|
12
|
+
this._onChange = () => { };
|
|
13
|
+
this._onTouched = () => { };
|
|
14
|
+
}
|
|
15
|
+
writeValue(value) {
|
|
16
|
+
if (value) {
|
|
17
|
+
this.state = value;
|
|
18
|
+
}
|
|
19
|
+
else {
|
|
20
|
+
this.state = {
|
|
21
|
+
checked: false,
|
|
22
|
+
indeterminate: false,
|
|
23
|
+
disabled: false,
|
|
24
|
+
children: this._initializeChildren(this.data),
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
registerOnChange(onChange) {
|
|
29
|
+
this._onChange = onChange;
|
|
30
|
+
}
|
|
31
|
+
registerOnTouched(onTouched) {
|
|
32
|
+
this._onTouched = onTouched;
|
|
33
|
+
}
|
|
34
|
+
_initializeChildren(item) {
|
|
35
|
+
const childrenState = {};
|
|
36
|
+
if (item.children) {
|
|
37
|
+
item.children.forEach((child) => {
|
|
38
|
+
childrenState[child.label] = {
|
|
39
|
+
checked: false,
|
|
40
|
+
indeterminate: false,
|
|
41
|
+
children: this._initializeChildren(child),
|
|
42
|
+
};
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
return childrenState;
|
|
46
|
+
}
|
|
47
|
+
updateParent() {
|
|
48
|
+
if (this.data.children && this.data.children.length > 0) {
|
|
49
|
+
const allChecked = this.data.children.every((child) => { var _a; return (_a = this.state.children[child.label]) === null || _a === void 0 ? void 0 : _a.checked; });
|
|
50
|
+
const someChecked = this.data.children.some((child) => { var _a, _b; return ((_a = this.state.children[child.label]) === null || _a === void 0 ? void 0 : _a.checked) || ((_b = this.state.children[child.label]) === null || _b === void 0 ? void 0 : _b.indeterminate); });
|
|
51
|
+
this.state.checked = allChecked;
|
|
52
|
+
this.state.indeterminate = !allChecked && someChecked;
|
|
53
|
+
}
|
|
54
|
+
this._onChange(this.state);
|
|
55
|
+
this._onTouched();
|
|
56
|
+
}
|
|
57
|
+
onCheckboxChange() {
|
|
58
|
+
if (this.state.disabled)
|
|
59
|
+
return;
|
|
60
|
+
this.state.checked = !this.state.checked;
|
|
61
|
+
this.state.indeterminate = false;
|
|
62
|
+
this._toggleChildrenCheck(this.data, this.state, this.state.checked);
|
|
63
|
+
this._onChange(this.state);
|
|
64
|
+
this._onTouched();
|
|
65
|
+
}
|
|
66
|
+
_toggleChildrenCheck(item, state, checked) {
|
|
67
|
+
var _a;
|
|
68
|
+
if ((_a = item.children) === null || _a === void 0 ? void 0 : _a.length) {
|
|
69
|
+
item.children.forEach((child) => {
|
|
70
|
+
if (!state.children[child.label]) {
|
|
71
|
+
state.children[child.label] = {
|
|
72
|
+
checked: false,
|
|
73
|
+
indeterminate: false,
|
|
74
|
+
children: this._initializeChildren(child),
|
|
75
|
+
};
|
|
76
|
+
}
|
|
77
|
+
state.children[child.label].checked = checked;
|
|
78
|
+
state.children[child.label].indeterminate = false;
|
|
79
|
+
if (child.children) {
|
|
80
|
+
this._toggleChildrenCheck(child, state.children[child.label], checked);
|
|
81
|
+
}
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
};
|
|
86
|
+
__decorate([
|
|
87
|
+
Input()
|
|
88
|
+
], CheckboxComponent.prototype, "data", void 0);
|
|
89
|
+
CheckboxComponent = CheckboxComponent_1 = __decorate([
|
|
90
|
+
Component({
|
|
91
|
+
selector: "s-checkbox",
|
|
92
|
+
template: "<div class=\"checkbox\">\n <label>\n <div\n class=\"checkbox-wrapper\"\n [ngClass]=\"{ 'checkbox-wrapper--disabled': state.disabled }\">\n <input\n type=\"checkbox\"\n class=\"checkbox-input\"\n [disabled]=\"state.disabled\"\n [ngClass]=\"{\n 'checkbox-input--checked': state.checked,\n 'checkbox-input--indeterminate': state.indeterminate\n }\"\n (change)=\"onCheckboxChange()\"\n [attr.aria-checked]=\"state.indeterminate ? 'mixed' : state.checked\"\n [attr.aria-disabled]=\"state.disabled\"\n role=\"checkbox\" />\n {{ data.label }}\n </div>\n </label>\n <div *ngIf=\"data.children && data.children.length\" class=\"checkbox-children\">\n <s-checkbox\n *ngFor=\"let child of data.children\"\n [data]=\"child\"\n [ngModel]=\"state.children[child.label]\"\n (ngModelChange)=\"updateParent()\">\n </s-checkbox>\n </div>\n</div>\n",
|
|
93
|
+
providers: [
|
|
94
|
+
{
|
|
95
|
+
provide: NG_VALUE_ACCESSOR,
|
|
96
|
+
useExisting: forwardRef(() => CheckboxComponent_1),
|
|
97
|
+
multi: true,
|
|
98
|
+
},
|
|
99
|
+
],
|
|
100
|
+
styles: [".checkbox{display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;gap:10px;margin-bottom:10px}.checkbox .checkbox-wrapper{-ms-flex-align:center;align-items:center;color:#212533;display:-ms-flexbox;display:flex;font-family:\"Open Sans\" sans-serif;font-size:14px;gap:12px}.checkbox .checkbox-wrapper .checkbox-input{-webkit-appearance:none;appearance:none;background-color:#fff;border:1px solid #c1c1cc;border-radius:4px;cursor:pointer;-ms-flex-negative:0;flex-shrink:0;height:20px;width:20px;position:relative}.checkbox .checkbox-wrapper .checkbox-input--checked{background-color:#428bca;border-color:#428bca}.checkbox .checkbox-wrapper .checkbox-input--checked::after{border:solid #fff;border-width:0 2px 2px 0;content:\"\";height:12px;left:6px;position:absolute;top:2px;transform:rotate(45deg);width:6px}.checkbox .checkbox-wrapper .checkbox-input--indeterminate{background-color:#428bca;border-color:#428bca}.checkbox .checkbox-wrapper .checkbox-input--indeterminate::after{background-color:#fff;content:\"\";height:2px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:10px}.checkbox .checkbox-wrapper:not(.checkbox-wrapper--disabled) .checkbox-input:not(.checkbox-input--checked):hover{background-color:#e5eaea;border-color:#ccc}.checkbox .checkbox-wrapper--disabled{opacity:.5;cursor:auto}.checkbox .checkbox-children{margin-left:20px}"]
|
|
101
|
+
})
|
|
102
|
+
], CheckboxComponent);
|
|
103
|
+
export { CheckboxComponent };
|
|
104
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox.component.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/checkbox/checkbox.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, forwardRef, Input, OnInit } from \"@angular/core\";\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\n\nimport { CheckboxData } from \"./models/checkbox-data\";\nimport { CheckboxState } from \"./models/checkbox-state\";\n\n@Component({\n    selector: \"s-checkbox\",\n    templateUrl: \"./checkbox.component.html\",\n    styleUrls: [\"./checkbox.component.scss\"],\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => CheckboxComponent),\n            multi: true,\n        },\n    ],\n})\nexport class CheckboxComponent implements ControlValueAccessor {\n    @Input()\n    public data: CheckboxData;\n\n    public state: CheckboxState = {\n        checked: false,\n        indeterminate: false,\n        children: {},\n    };\n\n    private _onChange: (value: CheckboxState) => void = () => {};\n    private _onTouched: () => void = () => {};\n\n    public writeValue(value: CheckboxState): void {\n        if (value) {\n            this.state = value;\n        } else {\n            this.state = {\n                checked: false,\n                indeterminate: false,\n                disabled: false,\n                children: this._initializeChildren(this.data),\n            };\n        }\n    }\n\n    public registerOnChange(onChange: (value: CheckboxState) => void): void {\n        this._onChange = onChange;\n    }\n\n    public registerOnTouched(onTouched: () => void): void {\n        this._onTouched = onTouched;\n    }\n\n    private _initializeChildren(item: CheckboxData): { [key: string]: CheckboxState } {\n        const childrenState: { [key: string]: CheckboxState } = {};\n        if (item.children) {\n            item.children.forEach((child) => {\n                childrenState[child.label] = {\n                    checked: false,\n                    indeterminate: false,\n                    children: this._initializeChildren(child),\n                };\n            });\n        }\n        return childrenState;\n    }\n\n    public updateParent(): void {\n        if (this.data.children && this.data.children.length > 0) {\n            const allChecked = this.data.children.every((child) => this.state.children[child.label]?.checked);\n            const someChecked = this.data.children.some(\n                (child) => this.state.children[child.label]?.checked || this.state.children[child.label]?.indeterminate\n            );\n            this.state.checked = allChecked;\n            this.state.indeterminate = !allChecked && someChecked;\n        }\n        this._onChange(this.state);\n        this._onTouched();\n    }\n\n    public onCheckboxChange(): void {\n        if (this.state.disabled) return;\n\n        this.state.checked = !this.state.checked;\n        this.state.indeterminate = false;\n        this._toggleChildrenCheck(this.data, this.state, this.state.checked);\n        this._onChange(this.state);\n        this._onTouched();\n    }\n\n    private _toggleChildrenCheck(item: CheckboxData, state: CheckboxState, checked: boolean): void {\n        if (item.children?.length) {\n            item.children.forEach((child) => {\n                if (!state.children[child.label]) {\n                    state.children[child.label] = {\n                        checked: false,\n                        indeterminate: false,\n                        children: this._initializeChildren(child),\n                    };\n                }\n                state.children[child.label].checked = checked;\n                state.children[child.label].indeterminate = false;\n                if (child.children) {\n                    this._toggleChildrenCheck(child, state.children[child.label], checked);\n                }\n            });\n        }\n    }\n}\n"]}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { CommonModule } from "@angular/common";
|
|
3
|
+
import { NgModule } from "@angular/core";
|
|
4
|
+
import { FormsModule } from "@angular/forms";
|
|
5
|
+
import { CheckboxComponent } from "./checkbox.component";
|
|
6
|
+
let CheckboxModule = class CheckboxModule {
|
|
7
|
+
};
|
|
8
|
+
CheckboxModule = __decorate([
|
|
9
|
+
NgModule({
|
|
10
|
+
imports: [CommonModule, FormsModule],
|
|
11
|
+
declarations: [CheckboxComponent],
|
|
12
|
+
exports: [CheckboxComponent],
|
|
13
|
+
})
|
|
14
|
+
], CheckboxModule);
|
|
15
|
+
export { CheckboxModule };
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3gubW9kdWxlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQHNlbmlvcnNpc3RlbWFzL2FuZ3VsYXItY29tcG9uZW50cy8iLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvY2hlY2tib3gvY2hlY2tib3gubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFN0MsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFPekQsSUFBYSxjQUFjLEdBQTNCLE1BQWEsY0FBYztDQUFHLENBQUE7QUFBakIsY0FBYztJQUwxQixRQUFRLENBQUM7UUFDTixPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsV0FBVyxDQUFDO1FBQ3BDLFlBQVksRUFBRSxDQUFDLGlCQUFpQixDQUFDO1FBQ2pDLE9BQU8sRUFBRSxDQUFDLGlCQUFpQixDQUFDO0tBQy9CLENBQUM7R0FDVyxjQUFjLENBQUc7U0FBakIsY0FBYyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2Zvcm1zXCI7XG5cbmltcG9ydCB7IENoZWNrYm94Q29tcG9uZW50IH0gZnJvbSBcIi4vY2hlY2tib3guY29tcG9uZW50XCI7XG5cbkBOZ01vZHVsZSh7XG4gICAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgRm9ybXNNb2R1bGVdLFxuICAgIGRlY2xhcmF0aW9uczogW0NoZWNrYm94Q29tcG9uZW50XSxcbiAgICBleHBvcnRzOiBbQ2hlY2tib3hDb21wb25lbnRdLFxufSlcbmV4cG9ydCBjbGFzcyBDaGVja2JveE1vZHVsZSB7fVxuIl19
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export { CheckboxComponent } from "./checkbox.component";
|
|
2
|
+
export { CheckboxModule } from "./checkbox.module";
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yc2lzdGVtYXMvYW5ndWxhci1jb21wb25lbnRzLyIsInNvdXJjZXMiOlsiY29tcG9uZW50cy9jaGVja2JveC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN6RCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sbUJBQW1CLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBDaGVja2JveENvbXBvbmVudCB9IGZyb20gXCIuL2NoZWNrYm94LmNvbXBvbmVudFwiO1xuZXhwb3J0IHsgQ2hlY2tib3hNb2R1bGUgfSBmcm9tIFwiLi9jaGVja2JveC5tb2R1bGVcIjtcblxuZXhwb3J0IHsgQ2hlY2tib3hEYXRhLCBDaGVja2JveFN0YXRlIH0gZnJvbSBcIi4vbW9kZWxzXCI7XG4iXX0=
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3gtZGF0YS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BzZW5pb3JzaXN0ZW1hcy9hbmd1bGFyLWNvbXBvbmVudHMvIiwic291cmNlcyI6WyJjb21wb25lbnRzL2NoZWNrYm94L21vZGVscy9jaGVja2JveC1kYXRhLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIENoZWNrYm94RGF0YSB7XG4gICAgbGFiZWw6IHN0cmluZztcbiAgICBjaGlsZHJlbj86IENoZWNrYm94RGF0YVtdO1xufVxuIl19
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3gtc3RhdGUuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yc2lzdGVtYXMvYW5ndWxhci1jb21wb25lbnRzLyIsInNvdXJjZXMiOlsiY29tcG9uZW50cy9jaGVja2JveC9tb2RlbHMvY2hlY2tib3gtc3RhdGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgQ2hlY2tib3hTdGF0ZSB7XG4gICAgY2hlY2tlZDogYm9vbGVhbjtcbiAgICBpbmRldGVybWluYXRlPzogYm9vbGVhbjtcbiAgICBkaXNhYmxlZD86IGJvb2xlYW47XG4gICAgY2hpbGRyZW4/OiBSZWNvcmQ8c3RyaW5nLCBDaGVja2JveFN0YXRlPjtcbn1cbiJdfQ==
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yc2lzdGVtYXMvYW5ndWxhci1jb21wb25lbnRzLyIsInNvdXJjZXMiOlsiY29tcG9uZW50cy9jaGVja2JveC9tb2RlbHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IENoZWNrYm94RGF0YSB9IGZyb20gXCIuL2NoZWNrYm94LWRhdGFcIjtcbmV4cG9ydCB7IENoZWNrYm94U3RhdGUgfSBmcm9tIFwiLi9jaGVja2JveC1zdGF0ZVwiO1xuIl19
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
var CodeEditorComponent_1;
|
|
2
|
+
import { __decorate } from "tslib";
|
|
3
|
+
import { Component, Input, Output, EventEmitter, ViewChild, forwardRef } from "@angular/core";
|
|
4
|
+
import { NG_VALUE_ACCESSOR } from "@angular/forms";
|
|
5
|
+
import { Subject } from "rxjs";
|
|
6
|
+
import { take, takeUntil } from "rxjs/operators";
|
|
7
|
+
import { CoreFacade } from "./core/facades/core-facade";
|
|
8
|
+
let CodeEditorComponent = CodeEditorComponent_1 = class CodeEditorComponent {
|
|
9
|
+
constructor(coreFacade) {
|
|
10
|
+
this.coreFacade = coreFacade;
|
|
11
|
+
this.codeChange = new EventEmitter();
|
|
12
|
+
this.isCodeValidChange = new EventEmitter();
|
|
13
|
+
this.onCodeChange = new EventEmitter();
|
|
14
|
+
this.onComponentFinishLoad = new EventEmitter();
|
|
15
|
+
this._ngUnsubscribe = new Subject();
|
|
16
|
+
this._onChange = () => { };
|
|
17
|
+
this._onTouched = () => { };
|
|
18
|
+
}
|
|
19
|
+
set editorOptions(options) {
|
|
20
|
+
this.coreFacade.changeEditorOptions(options);
|
|
21
|
+
}
|
|
22
|
+
set code(code) {
|
|
23
|
+
this.coreFacade.changeCode(code);
|
|
24
|
+
}
|
|
25
|
+
writeValue(value) {
|
|
26
|
+
this.code = value;
|
|
27
|
+
}
|
|
28
|
+
registerOnChange(onChange) {
|
|
29
|
+
this._onChange = onChange;
|
|
30
|
+
}
|
|
31
|
+
registerOnTouched(onTouched) {
|
|
32
|
+
this._onTouched = onTouched;
|
|
33
|
+
}
|
|
34
|
+
ngOnInit() {
|
|
35
|
+
this.coreFacade.initCore();
|
|
36
|
+
this.setupCoreListeners();
|
|
37
|
+
}
|
|
38
|
+
ngAfterViewInit() {
|
|
39
|
+
this.setCoreWrapperElement();
|
|
40
|
+
}
|
|
41
|
+
ngOnDestroy() {
|
|
42
|
+
this.coreFacade.destroyCore();
|
|
43
|
+
this._ngUnsubscribe.next();
|
|
44
|
+
this._ngUnsubscribe.complete();
|
|
45
|
+
}
|
|
46
|
+
setCoreWrapperElement() {
|
|
47
|
+
this.coreFacade.setCoreWrapperElement(this.coreWrapperElement.nativeElement);
|
|
48
|
+
}
|
|
49
|
+
setupCoreListeners() {
|
|
50
|
+
this.coreFacade
|
|
51
|
+
.getOnCoreFinishLoadObservable()
|
|
52
|
+
.pipe(take(1))
|
|
53
|
+
.subscribe(() => this.onComponentFinishLoad.emit());
|
|
54
|
+
this.coreFacade
|
|
55
|
+
.getOnCodeChangeObservable()
|
|
56
|
+
.pipe(takeUntil(this._ngUnsubscribe))
|
|
57
|
+
.subscribe((code) => {
|
|
58
|
+
this.codeChange.emit(code);
|
|
59
|
+
this.onCodeChange.emit(code);
|
|
60
|
+
this._onTouched();
|
|
61
|
+
this._onChange(code);
|
|
62
|
+
});
|
|
63
|
+
this.coreFacade
|
|
64
|
+
.getOnCodeValidityChangeObservable()
|
|
65
|
+
.pipe(takeUntil(this._ngUnsubscribe))
|
|
66
|
+
.subscribe((validity) => {
|
|
67
|
+
this.isCodeValidChange.emit(validity);
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
};
|
|
71
|
+
CodeEditorComponent.ctorParameters = () => [
|
|
72
|
+
{ type: CoreFacade }
|
|
73
|
+
];
|
|
74
|
+
__decorate([
|
|
75
|
+
Input()
|
|
76
|
+
], CodeEditorComponent.prototype, "editorOptions", null);
|
|
77
|
+
__decorate([
|
|
78
|
+
Input()
|
|
79
|
+
], CodeEditorComponent.prototype, "code", null);
|
|
80
|
+
__decorate([
|
|
81
|
+
Output()
|
|
82
|
+
], CodeEditorComponent.prototype, "codeChange", void 0);
|
|
83
|
+
__decorate([
|
|
84
|
+
Output()
|
|
85
|
+
], CodeEditorComponent.prototype, "isCodeValidChange", void 0);
|
|
86
|
+
__decorate([
|
|
87
|
+
Output()
|
|
88
|
+
], CodeEditorComponent.prototype, "onCodeChange", void 0);
|
|
89
|
+
__decorate([
|
|
90
|
+
Output()
|
|
91
|
+
], CodeEditorComponent.prototype, "onComponentFinishLoad", void 0);
|
|
92
|
+
__decorate([
|
|
93
|
+
ViewChild("coreWrapper")
|
|
94
|
+
], CodeEditorComponent.prototype, "coreWrapperElement", void 0);
|
|
95
|
+
CodeEditorComponent = CodeEditorComponent_1 = __decorate([
|
|
96
|
+
Component({
|
|
97
|
+
selector: "s-code-editor",
|
|
98
|
+
template: "<div #coreWrapper class=\"core-wrapper\"></div>",
|
|
99
|
+
providers: [
|
|
100
|
+
{
|
|
101
|
+
provide: NG_VALUE_ACCESSOR,
|
|
102
|
+
useExisting: forwardRef(() => CodeEditorComponent_1),
|
|
103
|
+
multi: true,
|
|
104
|
+
},
|
|
105
|
+
],
|
|
106
|
+
styles: [".core-wrapper{height:100%}"]
|
|
107
|
+
})
|
|
108
|
+
], CodeEditorComponent);
|
|
109
|
+
export { CodeEditorComponent };
|
|
110
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"code-editor.component.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/code-editor/code-editor.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, AfterViewInit, OnDestroy, Input, Output, EventEmitter, ViewChild, ElementRef, forwardRef } from \"@angular/core\";\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\n\nimport { Subject } from \"rxjs\";\nimport { take, takeUntil } from \"rxjs/operators\";\n\nimport { CoreFacade } from \"./core/facades/core-facade\";\nimport { EditorOptions } from \"./models\";\n\n@Component({\n    selector: \"s-code-editor\",\n    templateUrl: \"./code-editor.component.html\",\n    styleUrls: [\"./code-editor.component.scss\"],\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => CodeEditorComponent),\n            multi: true,\n        },\n    ],\n})\nexport class CodeEditorComponent implements OnInit, AfterViewInit, ControlValueAccessor, OnDestroy {\n    @Input()\n    public set editorOptions(options: EditorOptions) {\n        this.coreFacade.changeEditorOptions(options);\n    }\n\n    @Input()\n    public set code(code: string) {\n        this.coreFacade.changeCode(code);\n    }\n\n    @Output()\n    public codeChange = new EventEmitter<string>();\n\n    @Output()\n    public isCodeValidChange = new EventEmitter<boolean>();\n\n    @Output()\n    public onCodeChange = new EventEmitter<string>();\n\n    @Output()\n    public onComponentFinishLoad = new EventEmitter<void>();\n\n    @ViewChild(\"coreWrapper\")\n    private coreWrapperElement: ElementRef;\n\n    private _ngUnsubscribe = new Subject<void>();\n\n    private _onChange: (value: string) => void = () => {};\n    private _onTouched: () => void = () => {};\n\n    constructor(private readonly coreFacade: CoreFacade) {}\n\n    public writeValue(value: string): void {\n        this.code = value;\n    }\n\n    public registerOnChange(onChange: (value: string) => void): void {\n        this._onChange = onChange;\n    }\n\n    public registerOnTouched(onTouched: () => void): void {\n        this._onTouched = onTouched;\n    }\n\n    public ngOnInit(): void {\n        this.coreFacade.initCore();\n        this.setupCoreListeners();\n    }\n\n    public ngAfterViewInit(): void {\n        this.setCoreWrapperElement();\n    }\n\n    public ngOnDestroy(): void {\n        this.coreFacade.destroyCore();\n        this._ngUnsubscribe.next();\n        this._ngUnsubscribe.complete();\n    }\n\n    private setCoreWrapperElement(): void {\n        this.coreFacade.setCoreWrapperElement(this.coreWrapperElement.nativeElement as HTMLDivElement);\n    }\n\n    private setupCoreListeners(): void {\n        this.coreFacade\n            .getOnCoreFinishLoadObservable()\n            .pipe(take(1))\n            .subscribe(() => this.onComponentFinishLoad.emit());\n\n        this.coreFacade\n            .getOnCodeChangeObservable()\n            .pipe(takeUntil(this._ngUnsubscribe))\n            .subscribe((code) => {\n                this.codeChange.emit(code);\n                this.onCodeChange.emit(code);\n                this._onTouched();\n                this._onChange(code);\n            });\n\n        this.coreFacade\n            .getOnCodeValidityChangeObservable()\n            .pipe(takeUntil(this._ngUnsubscribe))\n            .subscribe((validity) => {\n                this.isCodeValidChange.emit(validity);\n            });\n    }\n}\n"]}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { CommonModule } from "@angular/common";
|
|
3
|
+
import { NgModule } from "@angular/core";
|
|
4
|
+
import { CodeEditorComponent } from "./code-editor.component";
|
|
5
|
+
import { CoreFacade } from "./core/facades/core-facade";
|
|
6
|
+
import { CodeMirror6Core } from "./infra/cores/codemirror-6/codemirror-6-core";
|
|
7
|
+
import { CustomTranslationsModule } from "./infra/utils/custom-translations/custom-translations.module";
|
|
8
|
+
let CodeEditorModule = class CodeEditorModule {
|
|
9
|
+
};
|
|
10
|
+
CodeEditorModule = __decorate([
|
|
11
|
+
NgModule({
|
|
12
|
+
imports: [CommonModule, CustomTranslationsModule],
|
|
13
|
+
declarations: [CodeEditorComponent],
|
|
14
|
+
exports: [CodeEditorComponent],
|
|
15
|
+
providers: [
|
|
16
|
+
{
|
|
17
|
+
provide: CoreFacade,
|
|
18
|
+
useClass: CodeMirror6Core,
|
|
19
|
+
},
|
|
20
|
+
],
|
|
21
|
+
})
|
|
22
|
+
], CodeEditorModule);
|
|
23
|
+
export { CodeEditorModule };
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29kZS1lZGl0b3IubW9kdWxlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQHNlbmlvcnNpc3RlbWFzL2FuZ3VsYXItY29tcG9uZW50cy8iLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvY29kZS1lZGl0b3IvY29kZS1lZGl0b3IubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV6QyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUM5RCxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDeEQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDhDQUE4QyxDQUFDO0FBQy9FLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLDhEQUE4RCxDQUFDO0FBYXhHLElBQWEsZ0JBQWdCLEdBQTdCLE1BQWEsZ0JBQWdCO0NBQUcsQ0FBQTtBQUFuQixnQkFBZ0I7SUFYNUIsUUFBUSxDQUFDO1FBQ04sT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLHdCQUF3QixDQUFDO1FBQ2pELFlBQVksRUFBRSxDQUFDLG1CQUFtQixDQUFDO1FBQ25DLE9BQU8sRUFBRSxDQUFDLG1CQUFtQixDQUFDO1FBQzlCLFNBQVMsRUFBRTtZQUNQO2dCQUNJLE9BQU8sRUFBRSxVQUFVO2dCQUNuQixRQUFRLEVBQUUsZUFBZTthQUM1QjtTQUNKO0tBQ0osQ0FBQztHQUNXLGdCQUFnQixDQUFHO1NBQW5CLGdCQUFnQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcblxuaW1wb3J0IHsgQ29kZUVkaXRvckNvbXBvbmVudCB9IGZyb20gXCIuL2NvZGUtZWRpdG9yLmNvbXBvbmVudFwiO1xuaW1wb3J0IHsgQ29yZUZhY2FkZSB9IGZyb20gXCIuL2NvcmUvZmFjYWRlcy9jb3JlLWZhY2FkZVwiO1xuaW1wb3J0IHsgQ29kZU1pcnJvcjZDb3JlIH0gZnJvbSBcIi4vaW5mcmEvY29yZXMvY29kZW1pcnJvci02L2NvZGVtaXJyb3ItNi1jb3JlXCI7XG5pbXBvcnQgeyBDdXN0b21UcmFuc2xhdGlvbnNNb2R1bGUgfSBmcm9tIFwiLi9pbmZyYS91dGlscy9jdXN0b20tdHJhbnNsYXRpb25zL2N1c3RvbS10cmFuc2xhdGlvbnMubW9kdWxlXCI7XG5cbkBOZ01vZHVsZSh7XG4gICAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgQ3VzdG9tVHJhbnNsYXRpb25zTW9kdWxlXSxcbiAgICBkZWNsYXJhdGlvbnM6IFtDb2RlRWRpdG9yQ29tcG9uZW50XSxcbiAgICBleHBvcnRzOiBbQ29kZUVkaXRvckNvbXBvbmVudF0sXG4gICAgcHJvdmlkZXJzOiBbXG4gICAgICAgIHtcbiAgICAgICAgICAgIHByb3ZpZGU6IENvcmVGYWNhZGUsXG4gICAgICAgICAgICB1c2VDbGFzczogQ29kZU1pcnJvcjZDb3JlLFxuICAgICAgICB9LFxuICAgIF0sXG59KVxuZXhwb3J0IGNsYXNzIENvZGVFZGl0b3JNb2R1bGUge31cbiJdfQ==
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
export * from "./
|
|
1
|
+
export * from "./code-editor.module";
|
|
2
2
|
export * from "./models";
|
|
3
3
|
/* External Language's configs */
|
|
4
4
|
export * from "./infra/cores/codemirror-6/languages/tax-calculation/tax-calculation-language-configs";
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yc2lzdGVtYXMvYW5ndWxhci1jb21wb25lbnRzLyIsInNvdXJjZXMiOlsiY29tcG9uZW50cy9jb2RlLWVkaXRvci9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsVUFBVSxDQUFDO0FBRXpCLGlDQUFpQztBQUNqQyxjQUFjLHVGQUF1RixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcIi4vY29kZS1lZGl0b3IubW9kdWxlXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9tb2RlbHNcIjtcblxuLyogRXh0ZXJuYWwgTGFuZ3VhZ2UncyBjb25maWdzICovXG5leHBvcnQgKiBmcm9tIFwiLi9pbmZyYS9jb3Jlcy9jb2RlbWlycm9yLTYvbGFuZ3VhZ2VzL3RheC1jYWxjdWxhdGlvbi90YXgtY2FsY3VsYXRpb24tbGFuZ3VhZ2UtY29uZmlnc1wiO1xuIl19
|
|
@@ -6,4 +6,4 @@ export class BaseFieldComponent {
|
|
|
6
6
|
return callback();
|
|
7
7
|
}
|
|
8
8
|
}
|
|
9
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1maWVsZC1jb21wb25lbnQuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yc2lzdGVtYXMvYW5ndWxhci1jb21wb25lbnRzLyIsInNvdXJjZXMiOlsiY29tcG9uZW50cy9keW5hbWljLWZvcm0vY29tcG9uZW50cy9maWVsZHMvYmFzZS1maWVsZC1jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNENBLE1BQU0sT0FBTyxrQkFBa0I7SUFDcEIsVUFBVSxDQUFDLEtBQVU7UUFDeEIsT0FBTyxLQUFLLFlBQVksUUFBUSxDQUFDO0lBQ3JDLENBQUM7SUFFTSxPQUFPLENBQUMsUUFBYTtRQUN4QixPQUFPLFFBQVEsRUFBRSxDQUFDO0lBQ3RCLENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEZvcm1Db250cm9sIH0gZnJvbSBcIkBhbmd1bGFyL2Zvcm1zXCI7XG5cbmltcG9ydCB7IEF1dG9jb21wbGV0ZUZpZWxkIH0gZnJvbSBcIi4uLy4uL2NvbmZpZ3VyYXRpb25zL2ZpZWxkcy9hdXRvY29tcGxldGUtZmllbGRcIjtcbmltcG9ydCB7IEJsb2JGaWVsZCB9IGZyb20gXCIuLi8uLi9jb25maWd1cmF0aW9ucy9maWVsZHMvYmxvYi1maWVsZFwiO1xuaW1wb3J0IHsgQm9vbGVhbkZpZWxkIH0gZnJvbSBcIi4uLy4uL2NvbmZpZ3VyYXRpb25zL2ZpZWxkcy9ib29sZWFuLWZpZWxkXCI7XG5pbXBvcnQgeyBDYWxlbmRhckZpZWxkIH0gZnJvbSBcIi4uLy4uL2NvbmZpZ3VyYXRpb25zL2ZpZWxkcy9jYWxlbmRhci1maWVsZFwiO1xuaW1wb3J0IHsgQ2hlY2tib3hGaWVsZCB9IGZyb20gXCIuLi8uLi9jb25maWd1cmF0aW9ucy9maWVsZHMvY2hlY2tib3gtZmllbGRcIjtcbmltcG9ydCB7IENoaXBzRmllbGQgfSBmcm9tIFwiLi4vLi4vY29uZmlndXJhdGlvbnMvZmllbGRzL2NoaXBzLWZpZWxkXCI7XG5pbXBvcnQgeyBDb3VudHJ5UGhvbmVQaWNrZXJGaWVsZCB9IGZyb20gXCIuLi8uLi9jb25maWd1cmF0aW9ucy9maWVsZHMvY291bnRyeS1waG9uZS1waWNrZXItZmllbGRcIjtcbmltcG9ydCB7IEN1cnJlbmN5RmllbGQgfSBmcm9tIFwiLi4vLi4vY29uZmlndXJhdGlvbnMvZmllbGRzL2N1cnJlbmN5LWZpZWxkXCI7XG5pbXBvcnQgeyBFZGl0b3JGaWVsZCB9IGZyb20gXCIuLi8uLi9jb25maWd1cmF0aW9ucy9maWVsZHMvZWRpdG9yLWZpZWxkXCI7XG5pbXBvcnQgeyBMb29rdXBGaWVsZCB9IGZyb20gXCIuLi8uLi9jb25maWd1cmF0aW9ucy9maWVsZHMvbG9va3VwLWZpZWxkXCI7XG5pbXBvcnQgeyBOdW1iZXJGaWVsZCB9IGZyb20gXCIuLi8uLi9jb25maWd1cmF0aW9ucy9maWVsZHMvbnVtYmVyLWZpZWxkXCI7XG5pbXBvcnQgeyBQYXNzd29yZEZpZWxkIH0gZnJvbSBcIi4uLy4uL2NvbmZpZ3VyYXRpb25zL2ZpZWxkcy9wYXNzd29yZC1maWVsZFwiO1xuaW1wb3J0IHsgUmFkaW9CdXR0b25GaWVsZCB9IGZyb20gXCIuLi8uLi9jb25maWd1cmF0aW9ucy9maWVsZHMvcmFkaW8tYnV0dG9uLWZpZWxkXCI7XG5pbXBvcnQgeyBTZWxlY3RGaWVsZCB9IGZyb20gXCIuLi8uLi9jb25maWd1cmF0aW9ucy9maWVsZHMvc2VsZWN0LWZpZWxkXCI7XG5pbXBvcnQgeyBTbGlkZXJGaWVsZCB9IGZyb20gXCIuLi8uLi9jb25maWd1cmF0aW9ucy9maWVsZHMvc2xpZGVyLWZpZWxkXCI7XG5pbXBvcnQgeyBUZXh0QXJlYUZpZWxkIH0gZnJvbSBcIi4uLy4uL2NvbmZpZ3VyYXRpb25zL2ZpZWxkcy90ZXh0LWFyZWEtZmllbGRcIjtcbmltcG9ydCB7IFRleHRBcmVhSUFGaWVsZCB9IGZyb20gXCIuLi8uLi9jb25maWd1cmF0aW9ucy9maWVsZHMvdGV4dC1hcmVhLWlhLWZpZWxkXCI7XG5pbXBvcnQgeyBUZXh0RmllbGQgfSBmcm9tIFwiLi4vLi4vY29uZmlndXJhdGlvbnMvZmllbGRzL3RleHQtZmllbGRcIjtcblxuZXhwb3J0IGludGVyZmFjZSBCYXNlRmllbGRDb21wb25lbnRDb25maWcge1xuICAgIGZpZWxkOlxuICAgICAgICB8IEF1dG9jb21wbGV0ZUZpZWxkXG4gICAgICAgIHwgQm9vbGVhbkZpZWxkXG4gICAgICAgIHwgQmxvYkZpZWxkXG4gICAgICAgIHwgQ2FsZW5kYXJGaWVsZFxuICAgICAgICB8IENoZWNrYm94RmllbGRcbiAgICAgICAgfCBDaGlwc0ZpZWxkXG4gICAgICAgIHwgQ291bnRyeVBob25lUGlja2VyRmllbGRcbiAgICAgICAgfCBDdXJyZW5jeUZpZWxkXG4gICAgICAgIHwgRWRpdG9yRmllbGRcbiAgICAgICAgfCBMb29rdXBGaWVsZFxuICAgICAgICB8IE51bWJlckZpZWxkXG4gICAgICAgIHwgUGFzc3dvcmRGaWVsZFxuICAgICAgICB8IFJhZGlvQnV0dG9uRmllbGRcbiAgICAgICAgfCBTZWxlY3RGaWVsZFxuICAgICAgICB8IFNsaWRlckZpZWxkXG4gICAgICAgIHwgVGV4dEFyZWFGaWVsZFxuICAgICAgICB8IFRleHRBcmVhSUFGaWVsZFxuICAgICAgICB8IFRleHRGaWVsZDtcbiAgICBmb3JtQ29udHJvbDogRm9ybUNvbnRyb2w7XG59XG5cbmV4cG9ydCBjbGFzcyBCYXNlRmllbGRDb21wb25lbnQge1xuICAgIHB1YmxpYyBpc0Z1bmN0aW9uKHZhbHVlOiBhbnkpOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuIHZhbHVlIGluc3RhbmNlb2YgRnVuY3Rpb247XG4gICAgfVxuXG4gICAgcHVibGljIHRyaWdnZXIoY2FsbGJhY2s6IGFueSkge1xuICAgICAgICByZXR1cm4gY2FsbGJhY2soKTtcbiAgICB9XG59XG4iXX0=
|