@acorex/components 4.1.1 → 4.1.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/accordion/accordion.component.mjs +4 -4
- package/esm2020/lib/accordion/accordion.module.mjs +5 -5
- package/esm2020/lib/base/base-page.class.mjs +7 -7
- package/esm2020/lib/base/element.class.mjs +16 -16
- package/esm2020/lib/button/button.component.mjs +4 -4
- package/esm2020/lib/button/button.module.mjs +5 -5
- package/esm2020/lib/calendar/calendar-box/calendar-box.component.mjs +4 -4
- package/esm2020/lib/calendar/calendar-box/calendar-box.module.mjs +5 -5
- package/esm2020/lib/calendar/scheduler/scheduler-views.property.mjs +7 -7
- package/esm2020/lib/calendar/scheduler/scheduler.component.mjs +4 -4
- package/esm2020/lib/calendar/scheduler/scheduler.module.mjs +5 -5
- package/esm2020/lib/calendar/scheduler/toolbars/scheduler-toolbar-navigator.mjs +4 -4
- package/esm2020/lib/calendar/scheduler/toolbars/scheduler-toolbar-views.mjs +4 -4
- package/esm2020/lib/calendar/scheduler/views/agenda/scheduler-agenda-view.component.mjs +4 -4
- package/esm2020/lib/calendar/scheduler/views/daytime/scheduler-daytime-view.component.mjs +4 -4
- package/esm2020/lib/calendar/scheduler/views/month/scheduler-month-view.component.mjs +4 -4
- package/esm2020/lib/calendar/scheduler/views/scheduler-view.component.mjs +4 -4
- package/esm2020/lib/calendar/scheduler/views/timeline/scheduler-timeline-view.component.mjs +4 -4
- package/esm2020/lib/checkbox/checkbox.component.mjs +4 -4
- package/esm2020/lib/checkbox/checkbox.module.mjs +5 -5
- package/esm2020/lib/color-picker/color-box/color-box.component.mjs +4 -4
- package/esm2020/lib/color-picker/color-picker.component.mjs +4 -4
- package/esm2020/lib/color-picker/color-picker.module.mjs +5 -5
- package/esm2020/lib/context-menu/context-menu.component.mjs +4 -4
- package/esm2020/lib/context-menu/context-menu.directive.mjs +4 -4
- package/esm2020/lib/context-menu/context-menu.module.mjs +5 -5
- package/esm2020/lib/data-filter/columns/filter-column-date.component.mjs +4 -4
- package/esm2020/lib/data-filter/columns/filter-column-number.component.mjs +4 -4
- package/esm2020/lib/data-filter/columns/filter-column-selection.component.mjs +4 -4
- package/esm2020/lib/data-filter/columns/filter-column-string.component.mjs +4 -4
- package/esm2020/lib/data-filter/filter-panel/filter-panel.component.mjs +4 -4
- package/esm2020/lib/data-filter/filter.class.mjs +4 -4
- package/esm2020/lib/data-filter/filter.module.mjs +5 -5
- package/esm2020/lib/data-filter/toolbar/filter-toolbar.component.mjs +4 -4
- package/esm2020/lib/data-list/core/data-list.component.mjs +4 -4
- package/esm2020/lib/data-list/list/list.component.mjs +4 -4
- package/esm2020/lib/data-list/list/list.module.mjs +5 -5
- package/esm2020/lib/data-list/list/toolbar-list-view.component.mjs +4 -4
- package/esm2020/lib/data-source/datasource.component.mjs +4 -4
- package/esm2020/lib/data-source/datasource.module.mjs +5 -5
- package/esm2020/lib/date-picker/date-picker.component.mjs +4 -4
- package/esm2020/lib/date-picker/date-picker.module.mjs +5 -5
- package/esm2020/lib/dialog/dialog.component.mjs +4 -4
- package/esm2020/lib/dialog/dialog.module.mjs +5 -5
- package/esm2020/lib/dialog/dialog.service.mjs +4 -4
- package/esm2020/lib/drawer/drawer.component.mjs +4 -4
- package/esm2020/lib/drawer/drawer.module.mjs +5 -5
- package/esm2020/lib/dropdown/dropdown.component.mjs +4 -4
- package/esm2020/lib/dropdown/dropdown.module.mjs +5 -5
- package/esm2020/lib/fieldset/fieldset.component.mjs +4 -4
- package/esm2020/lib/fieldset/fieldset.module.mjs +5 -5
- package/esm2020/lib/form-group/form-group.component.mjs +4 -4
- package/esm2020/lib/form-group/form-group.module.mjs +5 -5
- package/esm2020/lib/label/label.component.mjs +4 -4
- package/esm2020/lib/label/label.module.mjs +5 -5
- package/esm2020/lib/loading/loading-indicator.component.mjs +4 -4
- package/esm2020/lib/loading/loading-panel.component.mjs +4 -4
- package/esm2020/lib/loading/loading.module.mjs +5 -5
- package/esm2020/lib/loading/loading.service.mjs +4 -4
- package/esm2020/lib/menu/menu-item.component.mjs +4 -4
- package/esm2020/lib/menu/menu.component.mjs +4 -4
- package/esm2020/lib/menu/menu.module.mjs +5 -5
- package/esm2020/lib/menu/menu2.component.mjs +4 -4
- package/esm2020/lib/number-box/number-box.component.mjs +4 -4
- package/esm2020/lib/number-box/number-box.module.mjs +5 -5
- package/esm2020/lib/page/content.component.mjs +4 -4
- package/esm2020/lib/page/footer.component.mjs +4 -4
- package/esm2020/lib/page/page.component.mjs +4 -4
- package/esm2020/lib/page/page.module.mjs +5 -5
- package/esm2020/lib/panel-box/panel-box.component.mjs +4 -4
- package/esm2020/lib/panel-box/panel-box.module.mjs +5 -5
- package/esm2020/lib/password-box/password-box.component.mjs +4 -4
- package/esm2020/lib/password-box/password-box.module.mjs +5 -5
- package/esm2020/lib/popover/custom-cdk-overlay.service.mjs +13 -12
- package/esm2020/lib/popover/overlay.service.mjs +4 -4
- package/esm2020/lib/popover/popover.component.mjs +4 -4
- package/esm2020/lib/popover/popover.module.mjs +5 -5
- package/esm2020/lib/popup/popup.component.mjs +4 -4
- package/esm2020/lib/popup/popup.module.mjs +5 -5
- package/esm2020/lib/popup/popup.service.mjs +4 -4
- package/esm2020/lib/progress-bar/progress-bar.component.mjs +4 -4
- package/esm2020/lib/progress-bar/progress-bar.module.mjs +5 -5
- package/esm2020/lib/property-editor/editors/color-editor/color.editor.mjs +4 -4
- package/esm2020/lib/property-editor/editors/color-editor/color.module.mjs +5 -5
- package/esm2020/lib/property-editor/editors/column-editor/column.editor.mjs +4 -4
- package/esm2020/lib/property-editor/editors/column-editor/column.module.mjs +5 -5
- package/esm2020/lib/property-editor/editors/conditional-color-editor/conditional-color.editor.mjs +4 -4
- package/esm2020/lib/property-editor/editors/conditional-color-editor/conditional-color.module.mjs +5 -5
- package/esm2020/lib/property-editor/editors/date-editor/date.editor.mjs +4 -4
- package/esm2020/lib/property-editor/editors/date-editor/date.module.mjs +5 -5
- package/esm2020/lib/property-editor/editors/number-editor/number.editor.mjs +4 -4
- package/esm2020/lib/property-editor/editors/number-editor/number.module.mjs +5 -5
- package/esm2020/lib/property-editor/editors/range-editor/range.editor.mjs +4 -4
- package/esm2020/lib/property-editor/editors/range-editor/range.module.mjs +5 -5
- package/esm2020/lib/property-editor/editors/selectbox-editor/selectbox.editor.mjs +4 -4
- package/esm2020/lib/property-editor/editors/selectbox-editor/selectbox.module.mjs +5 -5
- package/esm2020/lib/property-editor/editors/switch-editor/number.editor.mjs +4 -4
- package/esm2020/lib/property-editor/editors/switch-editor/number.module.mjs +5 -5
- package/esm2020/lib/property-editor/editors/text-editor/text.editor.mjs +4 -4
- package/esm2020/lib/property-editor/editors/text-editor/text.module.mjs +5 -5
- package/esm2020/lib/property-editor/editors/textarea-editor/textarea.editor.mjs +32 -0
- package/esm2020/lib/property-editor/editors/textarea-editor/textarea.module.mjs +24 -0
- package/esm2020/lib/property-editor/editors/time-editor/time.editor.mjs +4 -4
- package/esm2020/lib/property-editor/editors/time-editor/time.module.mjs +5 -5
- package/esm2020/lib/property-editor/property-editor-renderer.directive.mjs +4 -4
- package/esm2020/lib/property-editor/property-editor.class.mjs +4 -4
- package/esm2020/lib/property-editor/property-editor.module.mjs +21 -7
- package/esm2020/lib/query-builder/query-builder-group.component.mjs +4 -4
- package/esm2020/lib/query-builder/query-builder-popup/query-builder-popup.component.mjs +4 -4
- package/esm2020/lib/query-builder/query-builder-rule.component.mjs +4 -4
- package/esm2020/lib/query-builder/query-builder.component.mjs +4 -4
- package/esm2020/lib/query-builder/query-builder.module.mjs +5 -5
- package/esm2020/lib/query-builder/query-builder.service.mjs +4 -4
- package/esm2020/lib/searchbox/searchbox.component.mjs +4 -4
- package/esm2020/lib/searchbox/searchbox.module.mjs +5 -5
- package/esm2020/lib/selectbox/selectbox.component.mjs +5 -5
- package/esm2020/lib/selectbox/selectbox.module.mjs +5 -5
- package/esm2020/lib/selectbox/selectbox2.component.mjs +4 -4
- package/esm2020/lib/selection-list/selection-list.component.mjs +4 -4
- package/esm2020/lib/selection-list/selection-list.module.mjs +5 -5
- package/esm2020/lib/switch/switch.component.mjs +4 -4
- package/esm2020/lib/switch/switch.module.mjs +5 -5
- package/esm2020/lib/tab-page/tab-page-Renderer.component.mjs +4 -4
- package/esm2020/lib/tab-page/tab-page-host.component.mjs +4 -4
- package/esm2020/lib/tab-page/tab-page.module.mjs +5 -5
- package/esm2020/lib/tab-page/tab-page.service.mjs +6 -6
- package/esm2020/lib/tab-strip/tab-strip.component.mjs +4 -4
- package/esm2020/lib/tab-strip/tab-strip.module.mjs +5 -5
- package/esm2020/lib/tab-view/dynamic-tabs.directive.mjs +4 -4
- package/esm2020/lib/tab-view/tab-view.component.mjs +4 -4
- package/esm2020/lib/tab-view/tab-view.module.mjs +5 -5
- package/esm2020/lib/tab-view/tab.component.mjs +4 -4
- package/esm2020/lib/textarea/textarea.component.mjs +4 -4
- package/esm2020/lib/textarea/textarea.module.mjs +5 -5
- package/esm2020/lib/textbox/textbox.component.mjs +4 -4
- package/esm2020/lib/textbox/textbox.module.mjs +5 -5
- package/esm2020/lib/time-picker/time-picker.component.mjs +4 -4
- package/esm2020/lib/time-picker/time-picker.module.mjs +5 -5
- package/esm2020/lib/toast/toast-message/toast-message.component.mjs +4 -4
- package/esm2020/lib/toast/toast-wrapper/toast-wrapper.component.mjs +4 -4
- package/esm2020/lib/toast/toast.module.mjs +5 -5
- package/esm2020/lib/toast/toast.service.mjs +4 -4
- package/esm2020/lib/toolbar/group-button/toolbar-group-button.component.mjs +4 -4
- package/esm2020/lib/toolbar/menu/toolbar-menu.component.mjs +4 -4
- package/esm2020/lib/toolbar/search/toolbar-search.component.mjs +4 -4
- package/esm2020/lib/toolbar/title/toolbar-title.component.mjs +4 -4
- package/esm2020/lib/toolbar/toolbar.component.mjs +4 -4
- package/esm2020/lib/toolbar/toolbar.module.mjs +5 -5
- package/esm2020/lib/tooltip/tooltip.directive.mjs +4 -4
- package/esm2020/lib/tooltip/tooltip.module.mjs +5 -5
- package/esm2020/lib/tree-side-menu/tree-side-menu.component.mjs +4 -4
- package/esm2020/lib/tree-side-menu/tree-side-menu.module.mjs +5 -5
- package/esm2020/lib/tree-view/tree-view.component.mjs +4 -4
- package/esm2020/lib/tree-view/tree-view.module.mjs +5 -5
- package/esm2020/lib/upload-file/upload-file.component.mjs +4 -4
- package/esm2020/lib/upload-file/upload-file.module.mjs +5 -5
- package/esm2020/lib/validation/validation-form.component.mjs +4 -4
- package/esm2020/lib/validation/validation-rule.widget.mjs +4 -4
- package/esm2020/lib/validation/validation.component.mjs +7 -7
- package/esm2020/lib/validation/validation.module.mjs +5 -5
- package/fesm2015/acorex-components.mjs +634 -579
- package/fesm2015/acorex-components.mjs.map +1 -1
- package/fesm2020/acorex-components.mjs +634 -579
- package/fesm2020/acorex-components.mjs.map +1 -1
- package/lib/calendar/calendar-box/calendar-box.component.d.ts +1 -1
- package/lib/popover/custom-cdk-overlay.service.d.ts +3 -2
- package/lib/property-editor/editors/textarea-editor/textarea.editor.d.ts +17 -0
- package/lib/property-editor/editors/textarea-editor/textarea.module.d.ts +12 -0
- package/lib/property-editor/property-editor.module.d.ts +3 -2
- package/package.json +2 -2
|
@@ -38,9 +38,9 @@ export class AXProperyEditorComponent {
|
|
|
38
38
|
this.value = v;
|
|
39
39
|
}
|
|
40
40
|
}
|
|
41
|
-
AXProperyEditorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.
|
|
42
|
-
AXProperyEditorComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.
|
|
43
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.
|
|
41
|
+
AXProperyEditorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AXProperyEditorComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
42
|
+
AXProperyEditorComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.11", type: AXProperyEditorComponent, inputs: { value: "value" }, outputs: { valueChange: "valueChange", onRenderCompleted: "onRenderCompleted" }, ngImport: i0 });
|
|
43
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AXProperyEditorComponent, decorators: [{
|
|
44
44
|
type: Directive
|
|
45
45
|
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { valueChange: [{
|
|
46
46
|
type: Output
|
|
@@ -98,4 +98,4 @@ export function propertyEditor(options) {
|
|
|
98
98
|
AXPropertyDecorators.register(target, key, options);
|
|
99
99
|
};
|
|
100
100
|
}
|
|
101
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"property-editor.class.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/src/lib/property-editor/property-editor.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { Input, Output, EventEmitter, ChangeDetectorRef, Directive } from '@angular/core';\r\nimport { Subject } from 'rxjs';\r\nimport { AXValidatableComponent } from '../base/element.class';\r\n\r\nexport type AXDataType = 'string' | 'number' | 'date' | 'boolean' | 'object';\r\nexport type AXControlType = 'textbox' | 'numberbox' | 'datePicker' | 'switch' | 'custom';\r\n\r\n\r\n\r\nexport interface AXPropertyDef {\r\n    name: string;\r\n    title: string;\r\n    hint?: string;\r\n    defaultValue?: any;\r\n    editorClass: any;\r\n    editorOptions?: any;\r\n    visible?: boolean | (() => boolean);\r\n    order?: number;\r\n}\r\n\r\nexport interface AXPropertyEditorDef {\r\n    title: string;\r\n    hint?: string;\r\n    defaultValue?: any;\r\n    editorClass: any;\r\n    editorOptions?: any;\r\n    visible?: boolean | (() => boolean);\r\n    order?: number;\r\n}\r\n\r\n\r\n\r\n\r\nexport interface AXPropertyConfig {\r\n    property: AXPropertyDef;\r\n    value: any;\r\n}\r\n\r\n\r\nexport interface AXProperyEditorValueChangeEvent {\r\n    property: AXPropertyDef;\r\n    value: any;\r\n}\r\n\r\n\r\n\r\n@Directive()\r\nexport abstract class AXProperyEditorComponent<T>{\r\n\r\n\r\n    readonly: boolean = false;\r\n\r\n\r\n    private _initiated: boolean = false;\r\n    private _valueBound: boolean = false;\r\n\r\n    public get initiated(): boolean {\r\n        return this._initiated && this._valueBound;\r\n    }\r\n\r\n\r\n    validatableComponentRegistered: Subject<AXValidatableComponent> = new Subject<AXValidatableComponent>();\r\n\r\n\r\n    registerForValidationForm(component?: AXValidatableComponent) {\r\n        this.validatableComponentRegistered.next(component);\r\n    }\r\n\r\n\r\n    @Output()\r\n    valueChange: EventEmitter<T> = new EventEmitter<T>();\r\n\r\n\r\n    @Output()\r\n    onRenderCompleted: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n    private _value: T;\r\n    @Input()\r\n    public get value(): T {\r\n        return this._value;\r\n    }\r\n\r\n    public set value(v: T) {\r\n        if (v !== this._value) {\r\n            this._value = v;\r\n            this.valueChange.emit(v);\r\n            this.cdr.detectChanges();\r\n            //TODO: find better solution\r\n            setTimeout(() => {\r\n                this._valueBound = true;\r\n            }, 100);\r\n        }\r\n    }\r\n\r\n    constructor(protected cdr: ChangeDetectorRef) {\r\n        this.onRenderCompleted.subscribe(() => {\r\n            this._initiated = true;\r\n        });\r\n    }\r\n\r\n    uid: string;\r\n\r\n    handleValueChange(v: T) {\r\n        this.value = v;\r\n    }\r\n}\r\n\r\n\r\n\r\nexport class AXPropertyDecorator {\r\n    cls: any;\r\n    property: string;\r\n    options: any;\r\n\r\n    constructor(\r\n        cls: any,\r\n        property: string,\r\n        options: any) {\r\n        this.cls = cls;\r\n        this.property = property;\r\n        this.options = options;\r\n    }\r\n}\r\n\r\n\r\n// @dynamic\r\nexport class AXPropertyDecorators {\r\n    private static REGISTRY = new Array<AXPropertyDecorator>();\r\n\r\n    static register(cls: string, property: string, options?: any) {\r\n        const item = AXPropertyDecorators.REGISTRY.find(c => c.cls === cls && c.property === property);\r\n        if (item) {\r\n            item.options = options;\r\n        }\r\n        else {\r\n            AXPropertyDecorators.REGISTRY.push(new AXPropertyDecorator(cls, property, options));\r\n        }\r\n    }\r\n\r\n\r\n\r\n    static has(cls: string, property: string): boolean {\r\n        return AXPropertyDecorators.REGISTRY.some(c => c.cls === cls && c.property === property);\r\n    }\r\n\r\n    static get(cls: string, property: string): AXPropertyDecorator {\r\n        return AXPropertyDecorators.REGISTRY.find(c => c.cls === cls && c.property === property);\r\n    }\r\n\r\n    static isValid(property: string): boolean {\r\n        if (property) {\r\n            return AXPropertyDecorators.REGISTRY.some(c => c.property === property);\r\n        }\r\n        return false;\r\n    }\r\n\r\n    static getProperties(target: any): AXPropertyDecorator[] {\r\n        const list: AXPropertyDecorator[] = [];\r\n        const p: any[] = Array<any>();\r\n        let superClass = Object.getPrototypeOf(target);\r\n        while (superClass.constructor.name !== 'Object') {\r\n            p.push(superClass.constructor);\r\n            superClass = Object.getPrototypeOf(superClass);\r\n        }\r\n        list.push(...AXPropertyDecorators.REGISTRY.filter(c => p.includes(c.cls.constructor)));\r\n        return list;\r\n    }\r\n}\r\n\r\n\r\n\r\nexport function propertyEditor(options: AXPropertyEditorDef) {\r\n    return (target: any, key: string) => {\r\n        (options as any).name = key;\r\n        AXPropertyDecorators.register(target, key, options);\r\n    };\r\n}\r\n\r\n"]}
|
|
101
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"property-editor.class.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/src/lib/property-editor/property-editor.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { Input, Output, EventEmitter, ChangeDetectorRef, Directive } from '@angular/core';\r\nimport { Subject } from 'rxjs';\r\nimport { AXValidatableComponent } from '../base/element.class';\r\n\r\nexport type AXDataType = 'string' | 'number' | 'date' | 'boolean' | 'object';\r\nexport type AXControlType = 'textbox' | 'numberbox' | 'datePicker' | 'switch' | 'custom';\r\n\r\n\r\n\r\nexport interface AXPropertyDef {\r\n    name: string;\r\n    title: string;\r\n    hint?: string;\r\n    defaultValue?: any;\r\n    editorClass: any;\r\n    editorOptions?: any;\r\n    visible?: boolean | (() => boolean);\r\n    order?: number;\r\n}\r\n\r\nexport interface AXPropertyEditorDef {\r\n    title: string;\r\n    hint?: string;\r\n    defaultValue?: any;\r\n    editorClass: any;\r\n    editorOptions?: any;\r\n    visible?: boolean | (() => boolean);\r\n    order?: number;\r\n}\r\n\r\n\r\n\r\n\r\nexport interface AXPropertyConfig {\r\n    property: AXPropertyDef;\r\n    value: any;\r\n}\r\n\r\n\r\nexport interface AXProperyEditorValueChangeEvent {\r\n    property: AXPropertyDef;\r\n    value: any;\r\n}\r\n\r\n\r\n\r\n@Directive()\r\nexport abstract class AXProperyEditorComponent<T>{\r\n\r\n\r\n    readonly: boolean = false;\r\n\r\n\r\n    private _initiated: boolean = false;\r\n    private _valueBound: boolean = false;\r\n\r\n    public get initiated(): boolean {\r\n        return this._initiated && this._valueBound;\r\n    }\r\n\r\n\r\n    validatableComponentRegistered: Subject<AXValidatableComponent> = new Subject<AXValidatableComponent>();\r\n\r\n\r\n    registerForValidationForm(component?: AXValidatableComponent) {\r\n        this.validatableComponentRegistered.next(component);\r\n    }\r\n\r\n\r\n    @Output()\r\n    valueChange: EventEmitter<T> = new EventEmitter<T>();\r\n\r\n\r\n    @Output()\r\n    onRenderCompleted: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n    private _value: T;\r\n    @Input()\r\n    public get value(): T {\r\n        return this._value;\r\n    }\r\n\r\n    public set value(v: T) {\r\n        if (v !== this._value) {\r\n            this._value = v;\r\n            this.valueChange.emit(v);\r\n            this.cdr.detectChanges();\r\n            //TODO: find better solution\r\n            setTimeout(() => {\r\n                this._valueBound = true;\r\n            }, 100);\r\n        }\r\n    }\r\n\r\n    constructor(protected cdr: ChangeDetectorRef) {\r\n        this.onRenderCompleted.subscribe(() => {\r\n            this._initiated = true;\r\n        });\r\n    }\r\n\r\n    uid: string;\r\n\r\n    handleValueChange(v: T) {\r\n        this.value = v;\r\n    }\r\n}\r\n\r\n\r\n\r\nexport class AXPropertyDecorator {\r\n    cls: any;\r\n    property: string;\r\n    options: any;\r\n\r\n    constructor(\r\n        cls: any,\r\n        property: string,\r\n        options: any) {\r\n        this.cls = cls;\r\n        this.property = property;\r\n        this.options = options;\r\n    }\r\n}\r\n\r\n\r\n// @dynamic\r\nexport class AXPropertyDecorators {\r\n    private static REGISTRY = new Array<AXPropertyDecorator>();\r\n\r\n    static register(cls: string, property: string, options?: any) {\r\n        const item = AXPropertyDecorators.REGISTRY.find(c => c.cls === cls && c.property === property);\r\n        if (item) {\r\n            item.options = options;\r\n        }\r\n        else {\r\n            AXPropertyDecorators.REGISTRY.push(new AXPropertyDecorator(cls, property, options));\r\n        }\r\n    }\r\n\r\n\r\n\r\n    static has(cls: string, property: string): boolean {\r\n        return AXPropertyDecorators.REGISTRY.some(c => c.cls === cls && c.property === property);\r\n    }\r\n\r\n    static get(cls: string, property: string): AXPropertyDecorator {\r\n        return AXPropertyDecorators.REGISTRY.find(c => c.cls === cls && c.property === property);\r\n    }\r\n\r\n    static isValid(property: string): boolean {\r\n        if (property) {\r\n            return AXPropertyDecorators.REGISTRY.some(c => c.property === property);\r\n        }\r\n        return false;\r\n    }\r\n\r\n    static getProperties(target: any): AXPropertyDecorator[] {\r\n        const list: AXPropertyDecorator[] = [];\r\n        const p: any[] = Array<any>();\r\n        let superClass = Object.getPrototypeOf(target);\r\n        while (superClass.constructor.name !== 'Object') {\r\n            p.push(superClass.constructor);\r\n            superClass = Object.getPrototypeOf(superClass);\r\n        }\r\n        list.push(...AXPropertyDecorators.REGISTRY.filter(c => p.includes(c.cls.constructor)));\r\n        return list;\r\n    }\r\n}\r\n\r\n\r\n\r\nexport function propertyEditor(options: AXPropertyEditorDef) {\r\n    return (target: any, key: string) => {\r\n        (options as any).name = key;\r\n        AXPropertyDecorators.register(target, key, options);\r\n    };\r\n}\r\n\r\n"]}
|
|
@@ -21,6 +21,8 @@ import { AXDatePropertyEditorModule } from './editors/date-editor/date.module';
|
|
|
21
21
|
import { AXDatePropertyEditorComponent } from './editors/date-editor/date.editor';
|
|
22
22
|
import { AXTimePropertyEditorModule } from './editors/time-editor/time.module';
|
|
23
23
|
import { AXTimePropertyEditorComponent } from './editors/time-editor/time.editor';
|
|
24
|
+
import { AXTextareaPropertyEditorComponent } from './editors/textarea-editor/textarea.editor';
|
|
25
|
+
import { AXTextareaPropertyEditorModule } from './editors/textarea-editor/textarea.module';
|
|
24
26
|
import * as i0 from "@angular/core";
|
|
25
27
|
import * as i1 from "@angular/router";
|
|
26
28
|
const WDIGET_MODULES = [
|
|
@@ -33,12 +35,14 @@ const WDIGET_MODULES = [
|
|
|
33
35
|
AXColumnPropertyEditorModule,
|
|
34
36
|
AXSwitchPropertyEditorModule,
|
|
35
37
|
AXDatePropertyEditorModule,
|
|
36
|
-
AXTimePropertyEditorModule
|
|
38
|
+
AXTimePropertyEditorModule,
|
|
39
|
+
AXTimePropertyEditorModule,
|
|
40
|
+
AXTextareaPropertyEditorModule
|
|
37
41
|
];
|
|
38
42
|
export class AXProppertyEditorModule {
|
|
39
43
|
}
|
|
40
|
-
AXProppertyEditorModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.
|
|
41
|
-
AXProppertyEditorModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.
|
|
44
|
+
AXProppertyEditorModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AXProppertyEditorModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
45
|
+
AXProppertyEditorModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AXProppertyEditorModule, declarations: [AXPropertyEditorRendererDirective], imports: [AXNumberBoxPropertyEditorModule,
|
|
42
46
|
AXTextPropertyEditorModule,
|
|
43
47
|
AXSelectBoxPropertyEditorModule,
|
|
44
48
|
AXRangePropertyEditorModule,
|
|
@@ -47,14 +51,20 @@ AXProppertyEditorModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0",
|
|
|
47
51
|
AXColumnPropertyEditorModule,
|
|
48
52
|
AXSwitchPropertyEditorModule,
|
|
49
53
|
AXDatePropertyEditorModule,
|
|
50
|
-
AXTimePropertyEditorModule,
|
|
51
|
-
|
|
54
|
+
AXTimePropertyEditorModule,
|
|
55
|
+
AXTimePropertyEditorModule,
|
|
56
|
+
AXTextareaPropertyEditorModule, i1.RouterModule], exports: [AXPropertyEditorRendererDirective] });
|
|
57
|
+
AXProppertyEditorModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AXProppertyEditorModule, providers: [], imports: [[
|
|
52
58
|
WDIGET_MODULES,
|
|
53
59
|
RouterModule.forChild([
|
|
54
60
|
{
|
|
55
61
|
component: AXTextPropertyEditorComponent,
|
|
56
62
|
path: 'ax/editors/text'
|
|
57
63
|
},
|
|
64
|
+
{
|
|
65
|
+
component: AXTextareaPropertyEditorComponent,
|
|
66
|
+
path: 'ax/editors/textarea'
|
|
67
|
+
},
|
|
58
68
|
{
|
|
59
69
|
component: AXSelectBoxPropertyEditorComponent,
|
|
60
70
|
path: 'ax/editors/select'
|
|
@@ -92,7 +102,7 @@ AXProppertyEditorModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0",
|
|
|
92
102
|
},
|
|
93
103
|
])
|
|
94
104
|
]] });
|
|
95
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.
|
|
105
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AXProppertyEditorModule, decorators: [{
|
|
96
106
|
type: NgModule,
|
|
97
107
|
args: [{
|
|
98
108
|
imports: [
|
|
@@ -102,6 +112,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
|
|
|
102
112
|
component: AXTextPropertyEditorComponent,
|
|
103
113
|
path: 'ax/editors/text'
|
|
104
114
|
},
|
|
115
|
+
{
|
|
116
|
+
component: AXTextareaPropertyEditorComponent,
|
|
117
|
+
path: 'ax/editors/textarea'
|
|
118
|
+
},
|
|
105
119
|
{
|
|
106
120
|
component: AXSelectBoxPropertyEditorComponent,
|
|
107
121
|
path: 'ax/editors/select'
|
|
@@ -144,4 +158,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
|
|
|
144
158
|
providers: [],
|
|
145
159
|
}]
|
|
146
160
|
}] });
|
|
147
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"property-editor.module.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/src/lib/property-editor/property-editor.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgModule } from '@angular/core';\r\nimport { AXTextPropertyEditorModule } from './editors/text-editor/text.module';\r\nimport { AXPropertyEditorRendererDirective } from './property-editor-renderer.directive';\r\nimport { RouterModule } from '@angular/router';\r\nimport { AXTextPropertyEditorComponent } from './editors/text-editor/text.editor';\r\nimport { AXNumberBoxPropertyEditorComponent } from './editors/number-editor/number.editor';\r\nimport { AXNumberBoxPropertyEditorModule } from './editors/number-editor/number.module';\r\nimport { AXSelectBoxPropertyEditorComponent } from './editors/selectbox-editor/selectbox.editor';\r\nimport { AXSelectBoxPropertyEditorModule } from './editors/selectbox-editor/selectbox.module';\r\nimport { AXRangePropertyEditorModule } from './editors/range-editor/range.module';\r\nimport { AXRangePropertyEditorComponent } from './editors/range-editor/range.editor';\r\nimport { AXColorPropertyEditorComponent } from './editors/color-editor/color.editor';\r\nimport { AXColorPropertyEditorModule } from './editors/color-editor/color.module';\r\nimport { ColumnPropertyEditorComponent } from './editors/column-editor/column.editor';\r\nimport { AXColumnPropertyEditorModule } from './editors/column-editor/column.module';\r\nimport { AXConditionalColorPropertyEditorComponent } from './editors/conditional-color-editor/conditional-color.editor';\r\nimport { AXConditionalColorPropertyEditorModule } from './editors/conditional-color-editor/conditional-color.module';\r\nimport { AXSwitchPropertyEditorModule } from './editors/switch-editor/number.module';\r\nimport { AXSwitchPropertyEditorComponent } from './editors/switch-editor/number.editor';\r\nimport { AXDatePropertyEditorModule } from './editors/date-editor/date.module';\r\nimport { AXDatePropertyEditorComponent } from './editors/date-editor/date.editor';\r\nimport { AXTimePropertyEditorModule } from './editors/time-editor/time.module';\r\nimport { AXTimePropertyEditorComponent } from './editors/time-editor/time.editor';\r\n\r\n\r\nconst WDIGET_MODULES = [\r\n    AXNumberBoxPropertyEditorModule,\r\n    AXTextPropertyEditorModule,\r\n    AXSelectBoxPropertyEditorModule,\r\n    AXRangePropertyEditorModule,\r\n    AXColorPropertyEditorModule,\r\n    AXConditionalColorPropertyEditorModule,\r\n    AXColumnPropertyEditorModule,\r\n    AXSwitchPropertyEditorModule,\r\n    AXDatePropertyEditorModule,\r\n    AXTimePropertyEditorModule\r\n];\r\n\r\n@NgModule({\r\n    imports: [\r\n        WDIGET_MODULES,\r\n        RouterModule.forChild([\r\n            {\r\n                component: AXTextPropertyEditorComponent,\r\n                path: 'ax/editors/text'\r\n            },\r\n            {\r\n                component: AXSelectBoxPropertyEditorComponent,\r\n                path: 'ax/editors/select'\r\n            },\r\n            {\r\n                component: AXNumberBoxPropertyEditorComponent,\r\n                path: 'ax/editors/number'\r\n            },\r\n            {\r\n                component: AXRangePropertyEditorComponent,\r\n                path: 'ax/editors/range'\r\n            },\r\n            {\r\n                component: AXConditionalColorPropertyEditorComponent,\r\n                path: 'ax/editors/conditional-color'\r\n            },\r\n            {\r\n                component: AXColorPropertyEditorComponent,\r\n                path: 'ax/editors/color'\r\n            },\r\n            {\r\n                component: AXSwitchPropertyEditorComponent,\r\n                path: 'ax/editors/switch'\r\n            },\r\n            {\r\n                component: ColumnPropertyEditorComponent,\r\n                path: 'ax/editors/column'\r\n            }, {\r\n                component: AXDatePropertyEditorComponent,\r\n                path: 'ax/editors/date'\r\n            },\r\n            {\r\n                component: AXTimePropertyEditorComponent,\r\n                path: 'ax/editors/time'\r\n            },\r\n        ])\r\n    ],\r\n    exports: [AXPropertyEditorRendererDirective],\r\n    declarations: [AXPropertyEditorRendererDirective],\r\n    providers: [],\r\n})\r\nexport class AXProppertyEditorModule { }\r\n"]}
|
|
161
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"property-editor.module.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/src/lib/property-editor/property-editor.module.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACzC,OAAO,EAAE,0BAA0B,EAAE,MAAM,mCAAmC,CAAC;AAC/E,OAAO,EAAE,iCAAiC,EAAE,MAAM,sCAAsC,CAAC;AACzF,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,6BAA6B,EAAE,MAAM,mCAAmC,CAAC;AAClF,OAAO,EAAE,kCAAkC,EAAE,MAAM,uCAAuC,CAAC;AAC3F,OAAO,EAAE,+BAA+B,EAAE,MAAM,uCAAuC,CAAC;AACxF,OAAO,EAAE,kCAAkC,EAAE,MAAM,6CAA6C,CAAC;AACjG,OAAO,EAAE,+BAA+B,EAAE,MAAM,6CAA6C,CAAC;AAC9F,OAAO,EAAE,2BAA2B,EAAE,MAAM,qCAAqC,CAAC;AAClF,OAAO,EAAE,8BAA8B,EAAE,MAAM,qCAAqC,CAAC;AACrF,OAAO,EAAE,8BAA8B,EAAE,MAAM,qCAAqC,CAAC;AACrF,OAAO,EAAE,2BAA2B,EAAE,MAAM,qCAAqC,CAAC;AAClF,OAAO,EAAE,6BAA6B,EAAE,MAAM,uCAAuC,CAAC;AACtF,OAAO,EAAE,4BAA4B,EAAE,MAAM,uCAAuC,CAAC;AACrF,OAAO,EAAE,yCAAyC,EAAE,MAAM,6DAA6D,CAAC;AACxH,OAAO,EAAE,sCAAsC,EAAE,MAAM,6DAA6D,CAAC;AACrH,OAAO,EAAE,4BAA4B,EAAE,MAAM,uCAAuC,CAAC;AACrF,OAAO,EAAE,+BAA+B,EAAE,MAAM,uCAAuC,CAAC;AACxF,OAAO,EAAE,0BAA0B,EAAE,MAAM,mCAAmC,CAAC;AAC/E,OAAO,EAAE,6BAA6B,EAAE,MAAM,mCAAmC,CAAC;AAClF,OAAO,EAAE,0BAA0B,EAAE,MAAM,mCAAmC,CAAC;AAC/E,OAAO,EAAE,6BAA6B,EAAE,MAAM,mCAAmC,CAAC;AAClF,OAAO,EAAE,iCAAiC,EAAE,MAAM,2CAA2C,CAAC;AAC9F,OAAO,EAAE,8BAA8B,EAAE,MAAM,2CAA2C,CAAC;;;AAG3F,MAAM,cAAc,GAAG;IACnB,+BAA+B;IAC/B,0BAA0B;IAC1B,+BAA+B;IAC/B,2BAA2B;IAC3B,2BAA2B;IAC3B,sCAAsC;IACtC,4BAA4B;IAC5B,4BAA4B;IAC5B,0BAA0B;IAC1B,0BAA0B;IAC1B,0BAA0B;IAC1B,8BAA8B;CAEjC,CAAC;AAuDF,MAAM,OAAO,uBAAuB;;qHAAvB,uBAAuB;sHAAvB,uBAAuB,iBAHjB,iCAAiC,aAjEhD,+BAA+B;QAC/B,0BAA0B;QAC1B,+BAA+B;QAC/B,2BAA2B;QAC3B,2BAA2B;QAC3B,sCAAsC;QACtC,4BAA4B;QAC5B,4BAA4B;QAC5B,0BAA0B;QAC1B,0BAA0B;QAC1B,0BAA0B;QAC1B,8BAA8B,8BAqDpB,iCAAiC;sHAIlC,uBAAuB,aAFrB,EAAE,YAlDJ;YACL,cAAc;YACd,YAAY,CAAC,QAAQ,CAAC;gBAClB;oBACI,SAAS,EAAE,6BAA6B;oBACxC,IAAI,EAAE,iBAAiB;iBAC1B;gBACD;oBACI,SAAS,EAAE,iCAAiC;oBAC5C,IAAI,EAAE,qBAAqB;iBAC9B;gBACD;oBACI,SAAS,EAAE,kCAAkC;oBAC7C,IAAI,EAAE,mBAAmB;iBAC5B;gBACD;oBACI,SAAS,EAAE,kCAAkC;oBAC7C,IAAI,EAAE,mBAAmB;iBAC5B;gBACD;oBACI,SAAS,EAAE,8BAA8B;oBACzC,IAAI,EAAE,kBAAkB;iBAC3B;gBACD;oBACI,SAAS,EAAE,yCAAyC;oBACpD,IAAI,EAAE,8BAA8B;iBACvC;gBACD;oBACI,SAAS,EAAE,8BAA8B;oBACzC,IAAI,EAAE,kBAAkB;iBAC3B;gBACD;oBACI,SAAS,EAAE,+BAA+B;oBAC1C,IAAI,EAAE,mBAAmB;iBAC5B;gBACD;oBACI,SAAS,EAAE,6BAA6B;oBACxC,IAAI,EAAE,mBAAmB;iBAC5B,EAAE;oBACC,SAAS,EAAE,6BAA6B;oBACxC,IAAI,EAAE,iBAAiB;iBAC1B;gBACD;oBACI,SAAS,EAAE,6BAA6B;oBACxC,IAAI,EAAE,iBAAiB;iBAC1B;aACJ,CAAC;SACL;4FAKQ,uBAAuB;kBArDnC,QAAQ;mBAAC;oBACN,OAAO,EAAE;wBACL,cAAc;wBACd,YAAY,CAAC,QAAQ,CAAC;4BAClB;gCACI,SAAS,EAAE,6BAA6B;gCACxC,IAAI,EAAE,iBAAiB;6BAC1B;4BACD;gCACI,SAAS,EAAE,iCAAiC;gCAC5C,IAAI,EAAE,qBAAqB;6BAC9B;4BACD;gCACI,SAAS,EAAE,kCAAkC;gCAC7C,IAAI,EAAE,mBAAmB;6BAC5B;4BACD;gCACI,SAAS,EAAE,kCAAkC;gCAC7C,IAAI,EAAE,mBAAmB;6BAC5B;4BACD;gCACI,SAAS,EAAE,8BAA8B;gCACzC,IAAI,EAAE,kBAAkB;6BAC3B;4BACD;gCACI,SAAS,EAAE,yCAAyC;gCACpD,IAAI,EAAE,8BAA8B;6BACvC;4BACD;gCACI,SAAS,EAAE,8BAA8B;gCACzC,IAAI,EAAE,kBAAkB;6BAC3B;4BACD;gCACI,SAAS,EAAE,+BAA+B;gCAC1C,IAAI,EAAE,mBAAmB;6BAC5B;4BACD;gCACI,SAAS,EAAE,6BAA6B;gCACxC,IAAI,EAAE,mBAAmB;6BAC5B,EAAE;gCACC,SAAS,EAAE,6BAA6B;gCACxC,IAAI,EAAE,iBAAiB;6BAC1B;4BACD;gCACI,SAAS,EAAE,6BAA6B;gCACxC,IAAI,EAAE,iBAAiB;6BAC1B;yBACJ,CAAC;qBACL;oBACD,OAAO,EAAE,CAAC,iCAAiC,CAAC;oBAC5C,YAAY,EAAE,CAAC,iCAAiC,CAAC;oBACjD,SAAS,EAAE,EAAE;iBAChB","sourcesContent":["import { NgModule } from '@angular/core';\r\nimport { AXTextPropertyEditorModule } from './editors/text-editor/text.module';\r\nimport { AXPropertyEditorRendererDirective } from './property-editor-renderer.directive';\r\nimport { RouterModule } from '@angular/router';\r\nimport { AXTextPropertyEditorComponent } from './editors/text-editor/text.editor';\r\nimport { AXNumberBoxPropertyEditorComponent } from './editors/number-editor/number.editor';\r\nimport { AXNumberBoxPropertyEditorModule } from './editors/number-editor/number.module';\r\nimport { AXSelectBoxPropertyEditorComponent } from './editors/selectbox-editor/selectbox.editor';\r\nimport { AXSelectBoxPropertyEditorModule } from './editors/selectbox-editor/selectbox.module';\r\nimport { AXRangePropertyEditorModule } from './editors/range-editor/range.module';\r\nimport { AXRangePropertyEditorComponent } from './editors/range-editor/range.editor';\r\nimport { AXColorPropertyEditorComponent } from './editors/color-editor/color.editor';\r\nimport { AXColorPropertyEditorModule } from './editors/color-editor/color.module';\r\nimport { ColumnPropertyEditorComponent } from './editors/column-editor/column.editor';\r\nimport { AXColumnPropertyEditorModule } from './editors/column-editor/column.module';\r\nimport { AXConditionalColorPropertyEditorComponent } from './editors/conditional-color-editor/conditional-color.editor';\r\nimport { AXConditionalColorPropertyEditorModule } from './editors/conditional-color-editor/conditional-color.module';\r\nimport { AXSwitchPropertyEditorModule } from './editors/switch-editor/number.module';\r\nimport { AXSwitchPropertyEditorComponent } from './editors/switch-editor/number.editor';\r\nimport { AXDatePropertyEditorModule } from './editors/date-editor/date.module';\r\nimport { AXDatePropertyEditorComponent } from './editors/date-editor/date.editor';\r\nimport { AXTimePropertyEditorModule } from './editors/time-editor/time.module';\r\nimport { AXTimePropertyEditorComponent } from './editors/time-editor/time.editor';\r\nimport { AXTextareaPropertyEditorComponent } from './editors/textarea-editor/textarea.editor';\r\nimport { AXTextareaPropertyEditorModule } from './editors/textarea-editor/textarea.module';\r\n\r\n\r\nconst WDIGET_MODULES = [\r\n    AXNumberBoxPropertyEditorModule,\r\n    AXTextPropertyEditorModule,\r\n    AXSelectBoxPropertyEditorModule,\r\n    AXRangePropertyEditorModule,\r\n    AXColorPropertyEditorModule,\r\n    AXConditionalColorPropertyEditorModule,\r\n    AXColumnPropertyEditorModule,\r\n    AXSwitchPropertyEditorModule,\r\n    AXDatePropertyEditorModule,\r\n    AXTimePropertyEditorModule,\r\n    AXTimePropertyEditorModule,\r\n    AXTextareaPropertyEditorModule\r\n\r\n];\r\n\r\n@NgModule({\r\n    imports: [\r\n        WDIGET_MODULES,\r\n        RouterModule.forChild([\r\n            {\r\n                component: AXTextPropertyEditorComponent,\r\n                path: 'ax/editors/text'\r\n            },\r\n            {\r\n                component: AXTextareaPropertyEditorComponent,\r\n                path: 'ax/editors/textarea'\r\n            },\r\n            {\r\n                component: AXSelectBoxPropertyEditorComponent,\r\n                path: 'ax/editors/select'\r\n            },\r\n            {\r\n                component: AXNumberBoxPropertyEditorComponent,\r\n                path: 'ax/editors/number'\r\n            },\r\n            {\r\n                component: AXRangePropertyEditorComponent,\r\n                path: 'ax/editors/range'\r\n            },\r\n            {\r\n                component: AXConditionalColorPropertyEditorComponent,\r\n                path: 'ax/editors/conditional-color'\r\n            },\r\n            {\r\n                component: AXColorPropertyEditorComponent,\r\n                path: 'ax/editors/color'\r\n            },\r\n            {\r\n                component: AXSwitchPropertyEditorComponent,\r\n                path: 'ax/editors/switch'\r\n            },\r\n            {\r\n                component: ColumnPropertyEditorComponent,\r\n                path: 'ax/editors/column'\r\n            }, {\r\n                component: AXDatePropertyEditorComponent,\r\n                path: 'ax/editors/date'\r\n            },\r\n            {\r\n                component: AXTimePropertyEditorComponent,\r\n                path: 'ax/editors/time'\r\n            },\r\n        ])\r\n    ],\r\n    exports: [AXPropertyEditorRendererDirective],\r\n    declarations: [AXPropertyEditorRendererDirective],\r\n    providers: [],\r\n})\r\nexport class AXProppertyEditorModule { }\r\n"]}
|
|
@@ -99,9 +99,9 @@ export class AXQueryBuilderGroupComponent {
|
|
|
99
99
|
});
|
|
100
100
|
}
|
|
101
101
|
}
|
|
102
|
-
AXQueryBuilderGroupComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.
|
|
103
|
-
AXQueryBuilderGroupComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.
|
|
104
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.
|
|
102
|
+
AXQueryBuilderGroupComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AXQueryBuilderGroupComponent, deps: [{ token: i1.AXQueryBuilderService }], target: i0.ɵɵFactoryTarget.Component });
|
|
103
|
+
AXQueryBuilderGroupComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: AXQueryBuilderGroupComponent, selector: "ax-query-group", inputs: { group: "group", parent: "parent", fields: "fields", mode: "mode" }, outputs: { groupRuleChanged: "groupRuleChanged" }, host: { classAttribute: "ax ax-query-group" }, viewQueries: [{ propertyName: "queryRule", first: true, predicate: ["queryRule"], descendants: true }, { propertyName: "form", first: true, predicate: AXValidationFormComponent, descendants: true }], ngImport: i0, template: "<div class=\"header\">\r\n <div class=\"condition\" *ngIf=\"parent\">\r\n <div class=\"text {{parent.condition}}\">\r\n <span>{{parent.condition }}</span>\r\n </div>\r\n </div>\r\n <div class=\"handler\">\r\n <i class=\"far fa-grip-lines-vertical\"></i>\r\n </div>\r\n\r\n <div class=\"detail {{group.condition}}\" (click)=\"changeDetailMode()\">\r\n <div class=\"collapsed\" *ngIf=\"collapsed;else expandedTemplate\">\r\n {{group.queryString}}\r\n </div>\r\n <ng-template #expandedTemplate>\r\n <div class=\"expanded\">\r\n <strong>{{group.condition == 'OR' ? '\u06CC\u06A9\u06CC \u0627\u0632' : '\u0647\u0645\u0647' }} <span>\u0634\u0631\u0627\u06CC\u0637 \u0632\u06CC\u0631 \u0628\u0631\u0642\u0631\u0627\u0631 \u0628\u0627\u0634\u062F</span> </strong>\r\n </div>\r\n </ng-template>\r\n </div>\r\n <div class=\"buttons-list\">\r\n <div class=\"button remove\" *ngIf=\"parent && mode=='new'\" (click)=\"handleRemoveClick()\">\r\n <i class=\"far fa-times ax-danger-color\"></i>\r\n </div>\r\n <div class=\"button edit\" *ngIf=\"mode=='new'\" (click)=\"handleChangeClick()\">\r\n <i class=\"far fa-retweet ax-danger-color\"></i>\r\n </div>\r\n </div>\r\n</div>\r\n<div class=\"rules\" *ngIf=\"!collapsed\">\r\n <!-- <ax-validation-form #form> -->\r\n\r\n <div *ngFor=\"let item of group.items\" class=\"group-item\">\r\n <ng-container *ngIf=\"item.condition;else ruleTemplate\">\r\n <ax-query-group (groupRuleChanged)=\"ruleChanged($event)\" [mode]=\"mode\" [group]=\"item\" [fields]=\"fields\"\r\n [parent]=\"group\">\r\n </ax-query-group>\r\n </ng-container>\r\n <ng-template #ruleTemplate>\r\n <ax-query-rule #queryRule (ruleChanged)=\"ruleChanged($event)\" [mode]=\"mode\"\r\n (onRuleDelete)=\"ruleDelete($event)\" [rule]=\"item\" [fields]=\"fields\" [parent]=\"group\">\r\n </ax-query-rule>\r\n </ng-template>\r\n </div>\r\n <!-- </ax-validation-form> -->\r\n <div class=\"group-item\" *ngIf=\"mode=='new'\">\r\n <div class=\"ax-query-rule\">\r\n <div class=\"condition\">\r\n </div>\r\n <div class=\"handler\">\r\n <i class=\"far fa-grip-lines-vertical\"></i>\r\n </div>\r\n <div class=\"add-rule\" (click)=\"addRule()\" *ngIf=\"mode=='new'\">\r\n <i class=\"far fa-plus\"></i> <span>\u0634\u0631\u0637</span>\r\n </div>\r\n <div class=\"add-group\" (click)=\"addGroup()\" *ngIf=\"!showGroupCondition && mode=='new'\">\r\n <i class=\"far fa-plus\"></i> <span>\u06AF\u0631\u0648\u0647</span>\r\n </div>\r\n <div *ngIf=\"showGroupCondition && mode=='new'\" class=\"add-condition OR\" (click)=\"addGroupOR()\">\r\n <i class=\"far fa-plus\"></i> <span>OR</span>\r\n </div>\r\n <div *ngIf=\"showGroupCondition && mode=='new'\" class=\"add-condition AND\" (click)=\"addGroupAND()\">\r\n <i class=\"far fa-plus\"></i> <span>AND</span>\r\n </div>\r\n\r\n </div>\r\n </div>\r\n</div>", components: [{ type: AXQueryBuilderGroupComponent, selector: "ax-query-group", inputs: ["group", "parent", "fields", "mode"], outputs: ["groupRuleChanged"] }, { type: i2.AXQueryBuilderRuleComponent, selector: "ax-query-rule", inputs: ["isEditing", "rule", "parent", "mode", "fields"], outputs: ["onRuleDelete", "ruleChanged"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], encapsulation: i0.ViewEncapsulation.None });
|
|
104
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AXQueryBuilderGroupComponent, decorators: [{
|
|
105
105
|
type: Component,
|
|
106
106
|
args: [{ selector: 'ax-query-group', host: { class: 'ax ax-query-group' }, encapsulation: ViewEncapsulation.None, template: "<div class=\"header\">\r\n <div class=\"condition\" *ngIf=\"parent\">\r\n <div class=\"text {{parent.condition}}\">\r\n <span>{{parent.condition }}</span>\r\n </div>\r\n </div>\r\n <div class=\"handler\">\r\n <i class=\"far fa-grip-lines-vertical\"></i>\r\n </div>\r\n\r\n <div class=\"detail {{group.condition}}\" (click)=\"changeDetailMode()\">\r\n <div class=\"collapsed\" *ngIf=\"collapsed;else expandedTemplate\">\r\n {{group.queryString}}\r\n </div>\r\n <ng-template #expandedTemplate>\r\n <div class=\"expanded\">\r\n <strong>{{group.condition == 'OR' ? '\u06CC\u06A9\u06CC \u0627\u0632' : '\u0647\u0645\u0647' }} <span>\u0634\u0631\u0627\u06CC\u0637 \u0632\u06CC\u0631 \u0628\u0631\u0642\u0631\u0627\u0631 \u0628\u0627\u0634\u062F</span> </strong>\r\n </div>\r\n </ng-template>\r\n </div>\r\n <div class=\"buttons-list\">\r\n <div class=\"button remove\" *ngIf=\"parent && mode=='new'\" (click)=\"handleRemoveClick()\">\r\n <i class=\"far fa-times ax-danger-color\"></i>\r\n </div>\r\n <div class=\"button edit\" *ngIf=\"mode=='new'\" (click)=\"handleChangeClick()\">\r\n <i class=\"far fa-retweet ax-danger-color\"></i>\r\n </div>\r\n </div>\r\n</div>\r\n<div class=\"rules\" *ngIf=\"!collapsed\">\r\n <!-- <ax-validation-form #form> -->\r\n\r\n <div *ngFor=\"let item of group.items\" class=\"group-item\">\r\n <ng-container *ngIf=\"item.condition;else ruleTemplate\">\r\n <ax-query-group (groupRuleChanged)=\"ruleChanged($event)\" [mode]=\"mode\" [group]=\"item\" [fields]=\"fields\"\r\n [parent]=\"group\">\r\n </ax-query-group>\r\n </ng-container>\r\n <ng-template #ruleTemplate>\r\n <ax-query-rule #queryRule (ruleChanged)=\"ruleChanged($event)\" [mode]=\"mode\"\r\n (onRuleDelete)=\"ruleDelete($event)\" [rule]=\"item\" [fields]=\"fields\" [parent]=\"group\">\r\n </ax-query-rule>\r\n </ng-template>\r\n </div>\r\n <!-- </ax-validation-form> -->\r\n <div class=\"group-item\" *ngIf=\"mode=='new'\">\r\n <div class=\"ax-query-rule\">\r\n <div class=\"condition\">\r\n </div>\r\n <div class=\"handler\">\r\n <i class=\"far fa-grip-lines-vertical\"></i>\r\n </div>\r\n <div class=\"add-rule\" (click)=\"addRule()\" *ngIf=\"mode=='new'\">\r\n <i class=\"far fa-plus\"></i> <span>\u0634\u0631\u0637</span>\r\n </div>\r\n <div class=\"add-group\" (click)=\"addGroup()\" *ngIf=\"!showGroupCondition && mode=='new'\">\r\n <i class=\"far fa-plus\"></i> <span>\u06AF\u0631\u0648\u0647</span>\r\n </div>\r\n <div *ngIf=\"showGroupCondition && mode=='new'\" class=\"add-condition OR\" (click)=\"addGroupOR()\">\r\n <i class=\"far fa-plus\"></i> <span>OR</span>\r\n </div>\r\n <div *ngIf=\"showGroupCondition && mode=='new'\" class=\"add-condition AND\" (click)=\"addGroupAND()\">\r\n <i class=\"far fa-plus\"></i> <span>AND</span>\r\n </div>\r\n\r\n </div>\r\n </div>\r\n</div>" }]
|
|
107
107
|
}], ctorParameters: function () { return [{ type: i1.AXQueryBuilderService }]; }, propDecorators: { queryRule: [{
|
|
@@ -121,4 +121,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
|
|
|
121
121
|
}], groupRuleChanged: [{
|
|
122
122
|
type: Output
|
|
123
123
|
}] } });
|
|
124
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"query-builder-group.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/src/lib/query-builder/query-builder-group.component.ts","../../../../../../projects/acorex/components/src/lib/query-builder/query-builder-group.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, ViewEncapsulation, Output, EventEmitter, ViewChild } from '@angular/core';\r\nimport { AXValidationFormComponent } from '../validation/validation-form.component';\r\nimport { AXQueryBuilderRuleComponent } from './query-builder-rule.component';\r\nimport { AXQueryBuilderGroup, AXQueryBuilderGroupEvent, AXQueryBuilderRuleEvent, AXQueryBuilderRule } from './query-builder.class';\r\nimport { AXQueryBuilderService } from './query-builder.service';\r\n@Component({\r\n  selector: 'ax-query-group',\r\n  templateUrl: 'query-builder-group.component.html',\r\n  host: { class: 'ax ax-query-group' },\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class AXQueryBuilderGroupComponent implements OnInit {\r\n  @ViewChild('queryRule') queryRule: AXQueryBuilderRuleComponent;\r\n  @ViewChild(AXValidationFormComponent) form: AXValidationFormComponent;\r\n  @Input()\r\n  group: AXQueryBuilderGroup;\r\n\r\n  collapsed: boolean = false;\r\n\r\n  @Input()\r\n  parent: AXQueryBuilderGroup;\r\n\r\n  @Input()\r\n  fields: any[] = [];\r\n\r\n  @Input()\r\n  mode: 'new' | 'edit' = 'new';\r\n\r\n  //ruleIsEditing: boolean = true;\r\n\r\n  @Output()\r\n  groupRuleChanged: EventEmitter<AXQueryBuilderGroupEvent> = new EventEmitter<AXQueryBuilderGroupEvent>();\r\n\r\n  showGroupCondition: boolean = false;\r\n\r\n  constructor(private qs: AXQueryBuilderService) {}\r\n\r\n  ngOnInit() {}\r\n\r\n  ruleDelete(e: AXQueryBuilderRuleEvent) {\r\n    this.group.items = this.group.items.filter((c) => c !== e.items);\r\n    this.ruleChanged(null);\r\n  }\r\n  handleRemoveClick() {\r\n    this.parent.items = this.parent.items.filter((c) => c !== this.group);\r\n    this.groupRuleChanged.emit({ groups: this.group, component: this });\r\n  }\r\n  saveRule() {\r\n    // this.form.validate().then(c => {\r\n    // });\r\n    // return this.queryRule.saveRule();\r\n  }\r\n  addRule() {\r\n    const item: AXQueryBuilderRule = new AXQueryBuilderRule();\r\n    if (this.fields.length > 0) {\r\n      //  item.caption = this.fields[0].caption;\r\n      // item.dataType = this.fields[0].dataType;\r\n      //  item.dataField = this.fields[0].dataField;\r\n    } else {\r\n    }\r\n    item.operator = 'equal';\r\n\r\n    if (item.dataType === 'string') {\r\n      item.value = '';\r\n    }\r\n    if (item.dataType === 'number') {\r\n      item.value = 0;\r\n    }\r\n\r\n    if (this.group.items == undefined) {\r\n      this.group.items = [];\r\n    }\r\n    this.group.items.push(item);\r\n    this.ruleChanged(null);\r\n  }\r\n  addGroup() {\r\n    this.showGroupCondition = true;\r\n  }\r\n  addGroupOR() {\r\n    this.makeGroup('OR');\r\n  }\r\n  addGroupAND() {\r\n    this.makeGroup('AND');\r\n  }\r\n  makeGroup(_condition) {\r\n    let r: AXQueryBuilderGroup = new AXQueryBuilderGroup();\r\n    r.condition = _condition;\r\n    r.items = [];\r\n    r.queryString = '';\r\n    if (this.group.items == undefined) {\r\n      this.group.items = [];\r\n    }\r\n    this.group.items.push(r);\r\n    this.showGroupCondition = false;\r\n    this.ruleChanged(null);\r\n  }\r\n  changeDetailMode() {\r\n    //if (this.parent) {\r\n    this.collapsed = !this.collapsed;\r\n    //  this.ruleIsEditing = false;\r\n    //}\r\n  }\r\n\r\n  handleChangeClick() {\r\n    if (this.group.condition == 'OR') {\r\n      this.group.condition = 'AND';\r\n    } else {\r\n      this.group.condition = 'OR';\r\n    }\r\n    this.ruleChanged(null);\r\n  }\r\n\r\n  ruleChanged(e) {\r\n    ;\r\n    // this.group.queryString = this.qs.getQueryString(this.group, 'simple');\r\n    this.qs.getQueryStringSimple(this.group).then((c) => {\r\n      this.group.queryString = c;\r\n      this.group.queryStringElastic = this.qs.getQueryString(this.group, 'elastic');\r\n      this.groupRuleChanged.emit({ groups: this.group, component: this });\r\n    });\r\n  }\r\n}\r\n","<div class=\"header\">\r\n    <div class=\"condition\" *ngIf=\"parent\">\r\n        <div class=\"text {{parent.condition}}\">\r\n            <span>{{parent.condition }}</span>\r\n        </div>\r\n    </div>\r\n    <div class=\"handler\">\r\n        <i class=\"far fa-grip-lines-vertical\"></i>\r\n    </div>\r\n\r\n    <div class=\"detail {{group.condition}}\" (click)=\"changeDetailMode()\">\r\n        <div class=\"collapsed\" *ngIf=\"collapsed;else expandedTemplate\">\r\n            {{group.queryString}}\r\n        </div>\r\n        <ng-template #expandedTemplate>\r\n            <div class=\"expanded\">\r\n                <strong>{{group.condition == 'OR' ? 'یکی از' : 'همه' }} <span>شرایط زیر برقرار باشد</span> </strong>\r\n            </div>\r\n        </ng-template>\r\n    </div>\r\n    <div class=\"buttons-list\">\r\n        <div class=\"button remove\" *ngIf=\"parent && mode=='new'\" (click)=\"handleRemoveClick()\">\r\n            <i class=\"far fa-times ax-danger-color\"></i>\r\n        </div>\r\n        <div class=\"button edit\" *ngIf=\"mode=='new'\" (click)=\"handleChangeClick()\">\r\n            <i class=\"far fa-retweet ax-danger-color\"></i>\r\n        </div>\r\n    </div>\r\n</div>\r\n<div class=\"rules\" *ngIf=\"!collapsed\">\r\n    <!-- <ax-validation-form #form> -->\r\n\r\n    <div *ngFor=\"let item of group.items\" class=\"group-item\">\r\n        <ng-container *ngIf=\"item.condition;else ruleTemplate\">\r\n            <ax-query-group (groupRuleChanged)=\"ruleChanged($event)\" [mode]=\"mode\" [group]=\"item\" [fields]=\"fields\"\r\n                [parent]=\"group\">\r\n            </ax-query-group>\r\n        </ng-container>\r\n        <ng-template #ruleTemplate>\r\n            <ax-query-rule #queryRule (ruleChanged)=\"ruleChanged($event)\" [mode]=\"mode\"\r\n                (onRuleDelete)=\"ruleDelete($event)\" [rule]=\"item\" [fields]=\"fields\" [parent]=\"group\">\r\n            </ax-query-rule>\r\n        </ng-template>\r\n    </div>\r\n    <!-- </ax-validation-form> -->\r\n    <div class=\"group-item\" *ngIf=\"mode=='new'\">\r\n        <div class=\"ax-query-rule\">\r\n            <div class=\"condition\">\r\n            </div>\r\n            <div class=\"handler\">\r\n                <i class=\"far fa-grip-lines-vertical\"></i>\r\n            </div>\r\n            <div class=\"add-rule\" (click)=\"addRule()\" *ngIf=\"mode=='new'\">\r\n                <i class=\"far fa-plus\"></i>&nbsp;&nbsp;<span>شرط</span>\r\n            </div>\r\n            <div class=\"add-group\" (click)=\"addGroup()\" *ngIf=\"!showGroupCondition && mode=='new'\">\r\n                <i class=\"far fa-plus\"></i>&nbsp;&nbsp;<span>گروه</span>\r\n            </div>\r\n            <div *ngIf=\"showGroupCondition && mode=='new'\" class=\"add-condition OR\" (click)=\"addGroupOR()\">\r\n                <i class=\"far fa-plus\"></i>&nbsp;&nbsp;<span>OR</span>\r\n            </div>\r\n            <div *ngIf=\"showGroupCondition && mode=='new'\" class=\"add-condition AND\" (click)=\"addGroupAND()\">\r\n                <i class=\"far fa-plus\"></i>&nbsp;&nbsp;<span>AND</span>\r\n            </div>\r\n\r\n        </div>\r\n    </div>\r\n</div>"]}
|
|
124
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"query-builder-group.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/src/lib/query-builder/query-builder-group.component.ts","../../../../../../projects/acorex/components/src/lib/query-builder/query-builder-group.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, ViewEncapsulation, Output, EventEmitter, ViewChild } from '@angular/core';\r\nimport { AXValidationFormComponent } from '../validation/validation-form.component';\r\nimport { AXQueryBuilderRuleComponent } from './query-builder-rule.component';\r\nimport { AXQueryBuilderGroup, AXQueryBuilderGroupEvent, AXQueryBuilderRuleEvent, AXQueryBuilderRule } from './query-builder.class';\r\nimport { AXQueryBuilderService } from './query-builder.service';\r\n@Component({\r\n  selector: 'ax-query-group',\r\n  templateUrl: 'query-builder-group.component.html',\r\n  host: { class: 'ax ax-query-group' },\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class AXQueryBuilderGroupComponent implements OnInit {\r\n  @ViewChild('queryRule') queryRule: AXQueryBuilderRuleComponent;\r\n  @ViewChild(AXValidationFormComponent) form: AXValidationFormComponent;\r\n  @Input()\r\n  group: AXQueryBuilderGroup;\r\n\r\n  collapsed: boolean = false;\r\n\r\n  @Input()\r\n  parent: AXQueryBuilderGroup;\r\n\r\n  @Input()\r\n  fields: any[] = [];\r\n\r\n  @Input()\r\n  mode: 'new' | 'edit' = 'new';\r\n\r\n  //ruleIsEditing: boolean = true;\r\n\r\n  @Output()\r\n  groupRuleChanged: EventEmitter<AXQueryBuilderGroupEvent> = new EventEmitter<AXQueryBuilderGroupEvent>();\r\n\r\n  showGroupCondition: boolean = false;\r\n\r\n  constructor(private qs: AXQueryBuilderService) {}\r\n\r\n  ngOnInit() {}\r\n\r\n  ruleDelete(e: AXQueryBuilderRuleEvent) {\r\n    this.group.items = this.group.items.filter((c) => c !== e.items);\r\n    this.ruleChanged(null);\r\n  }\r\n  handleRemoveClick() {\r\n    this.parent.items = this.parent.items.filter((c) => c !== this.group);\r\n    this.groupRuleChanged.emit({ groups: this.group, component: this });\r\n  }\r\n  saveRule() {\r\n    // this.form.validate().then(c => {\r\n    // });\r\n    // return this.queryRule.saveRule();\r\n  }\r\n  addRule() {\r\n    const item: AXQueryBuilderRule = new AXQueryBuilderRule();\r\n    if (this.fields.length > 0) {\r\n      //  item.caption = this.fields[0].caption;\r\n      // item.dataType = this.fields[0].dataType;\r\n      //  item.dataField = this.fields[0].dataField;\r\n    } else {\r\n    }\r\n    item.operator = 'equal';\r\n\r\n    if (item.dataType === 'string') {\r\n      item.value = '';\r\n    }\r\n    if (item.dataType === 'number') {\r\n      item.value = 0;\r\n    }\r\n\r\n    if (this.group.items == undefined) {\r\n      this.group.items = [];\r\n    }\r\n    this.group.items.push(item);\r\n    this.ruleChanged(null);\r\n  }\r\n  addGroup() {\r\n    this.showGroupCondition = true;\r\n  }\r\n  addGroupOR() {\r\n    this.makeGroup('OR');\r\n  }\r\n  addGroupAND() {\r\n    this.makeGroup('AND');\r\n  }\r\n  makeGroup(_condition) {\r\n    let r: AXQueryBuilderGroup = new AXQueryBuilderGroup();\r\n    r.condition = _condition;\r\n    r.items = [];\r\n    r.queryString = '';\r\n    if (this.group.items == undefined) {\r\n      this.group.items = [];\r\n    }\r\n    this.group.items.push(r);\r\n    this.showGroupCondition = false;\r\n    this.ruleChanged(null);\r\n  }\r\n  changeDetailMode() {\r\n    //if (this.parent) {\r\n    this.collapsed = !this.collapsed;\r\n    //  this.ruleIsEditing = false;\r\n    //}\r\n  }\r\n\r\n  handleChangeClick() {\r\n    if (this.group.condition == 'OR') {\r\n      this.group.condition = 'AND';\r\n    } else {\r\n      this.group.condition = 'OR';\r\n    }\r\n    this.ruleChanged(null);\r\n  }\r\n\r\n  ruleChanged(e) {\r\n    ;\r\n    // this.group.queryString = this.qs.getQueryString(this.group, 'simple');\r\n    this.qs.getQueryStringSimple(this.group).then((c) => {\r\n      this.group.queryString = c;\r\n      this.group.queryStringElastic = this.qs.getQueryString(this.group, 'elastic');\r\n      this.groupRuleChanged.emit({ groups: this.group, component: this });\r\n    });\r\n  }\r\n}\r\n","<div class=\"header\">\r\n    <div class=\"condition\" *ngIf=\"parent\">\r\n        <div class=\"text {{parent.condition}}\">\r\n            <span>{{parent.condition }}</span>\r\n        </div>\r\n    </div>\r\n    <div class=\"handler\">\r\n        <i class=\"far fa-grip-lines-vertical\"></i>\r\n    </div>\r\n\r\n    <div class=\"detail {{group.condition}}\" (click)=\"changeDetailMode()\">\r\n        <div class=\"collapsed\" *ngIf=\"collapsed;else expandedTemplate\">\r\n            {{group.queryString}}\r\n        </div>\r\n        <ng-template #expandedTemplate>\r\n            <div class=\"expanded\">\r\n                <strong>{{group.condition == 'OR' ? 'یکی از' : 'همه' }} <span>شرایط زیر برقرار باشد</span> </strong>\r\n            </div>\r\n        </ng-template>\r\n    </div>\r\n    <div class=\"buttons-list\">\r\n        <div class=\"button remove\" *ngIf=\"parent && mode=='new'\" (click)=\"handleRemoveClick()\">\r\n            <i class=\"far fa-times ax-danger-color\"></i>\r\n        </div>\r\n        <div class=\"button edit\" *ngIf=\"mode=='new'\" (click)=\"handleChangeClick()\">\r\n            <i class=\"far fa-retweet ax-danger-color\"></i>\r\n        </div>\r\n    </div>\r\n</div>\r\n<div class=\"rules\" *ngIf=\"!collapsed\">\r\n    <!-- <ax-validation-form #form> -->\r\n\r\n    <div *ngFor=\"let item of group.items\" class=\"group-item\">\r\n        <ng-container *ngIf=\"item.condition;else ruleTemplate\">\r\n            <ax-query-group (groupRuleChanged)=\"ruleChanged($event)\" [mode]=\"mode\" [group]=\"item\" [fields]=\"fields\"\r\n                [parent]=\"group\">\r\n            </ax-query-group>\r\n        </ng-container>\r\n        <ng-template #ruleTemplate>\r\n            <ax-query-rule #queryRule (ruleChanged)=\"ruleChanged($event)\" [mode]=\"mode\"\r\n                (onRuleDelete)=\"ruleDelete($event)\" [rule]=\"item\" [fields]=\"fields\" [parent]=\"group\">\r\n            </ax-query-rule>\r\n        </ng-template>\r\n    </div>\r\n    <!-- </ax-validation-form> -->\r\n    <div class=\"group-item\" *ngIf=\"mode=='new'\">\r\n        <div class=\"ax-query-rule\">\r\n            <div class=\"condition\">\r\n            </div>\r\n            <div class=\"handler\">\r\n                <i class=\"far fa-grip-lines-vertical\"></i>\r\n            </div>\r\n            <div class=\"add-rule\" (click)=\"addRule()\" *ngIf=\"mode=='new'\">\r\n                <i class=\"far fa-plus\"></i>&nbsp;&nbsp;<span>شرط</span>\r\n            </div>\r\n            <div class=\"add-group\" (click)=\"addGroup()\" *ngIf=\"!showGroupCondition && mode=='new'\">\r\n                <i class=\"far fa-plus\"></i>&nbsp;&nbsp;<span>گروه</span>\r\n            </div>\r\n            <div *ngIf=\"showGroupCondition && mode=='new'\" class=\"add-condition OR\" (click)=\"addGroupOR()\">\r\n                <i class=\"far fa-plus\"></i>&nbsp;&nbsp;<span>OR</span>\r\n            </div>\r\n            <div *ngIf=\"showGroupCondition && mode=='new'\" class=\"add-condition AND\" (click)=\"addGroupAND()\">\r\n                <i class=\"far fa-plus\"></i>&nbsp;&nbsp;<span>AND</span>\r\n            </div>\r\n\r\n        </div>\r\n    </div>\r\n</div>"]}
|
|
@@ -159,13 +159,13 @@ export class AXQueryBuilderPopupComponent extends AXBasePopupPageComponent {
|
|
|
159
159
|
];
|
|
160
160
|
}
|
|
161
161
|
}
|
|
162
|
-
AXQueryBuilderPopupComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.
|
|
163
|
-
AXQueryBuilderPopupComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.
|
|
164
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.
|
|
162
|
+
AXQueryBuilderPopupComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AXQueryBuilderPopupComponent, deps: [{ token: i1.AXToastService }], target: i0.ɵɵFactoryTarget.Component });
|
|
163
|
+
AXQueryBuilderPopupComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: AXQueryBuilderPopupComponent, selector: "ng-component", viewQueries: [{ propertyName: "form", first: true, predicate: AXValidationFormComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div>\r\n <ax-validation-form #form>\r\n <div *ngFor=\"let rule of items\">\r\n\r\n <div *ngIf=\" rule.control\" [ngSwitch]=\"rule.control.type\" style=\"padding: 1em;\">\r\n <div *ngSwitchCase=\"'textBox'\">\r\n <ax-form-group>\r\n <ax-label>{{getValue(rule.onDemandLabel)}}</ax-label>\r\n <ax-text-box (onValueChanged)=\"textValueChange($event,rule)\"\r\n placeholder=\"\u0645\u0642\u062F\u0627\u0631 \u0645\u0648\u0631\u062F \u0646\u0638\u0631 \u062E\u0648\u062F \u0631\u0627 \u0648\u0627\u0631\u062F \u06A9\u0646\u06CC\u062F\" size=\"sm\">\r\n <ax-validation>\r\n <ax-validation-rule type=\"required\"></ax-validation-rule>\r\n </ax-validation>\r\n </ax-text-box>\r\n </ax-form-group>\r\n </div>\r\n <div *ngSwitchCase=\"'selectBox'\">\r\n <ax-form-group>\r\n <ax-label>{{getValue(rule.onDemandLabel)}}</ax-label>\r\n <ax-select-box placeholder=\"\u0645\u0642\u062F\u0627\u0631 \u0645\u0648\u0631\u062F \u0646\u0638\u0631 \u062E\u0648\u062F \u0631\u0627 \u0648\u0627\u0631\u062F \u06A9\u0646\u06CC\u062F\"\r\n [textField]=\"getOption('textField',rule)\" [(selectedItems)]=\"rule.valueItem\"\r\n [valueField]=\"getOption('valueField',rule)\" [mode]=\"getOption('mode',rule)\"\r\n (selectedItemsChange)=\"selectedItemsChange($event,rule)\" size=\"sm\" #selectBoxValue\r\n [remoteOperation]=\"getOption('remoteOperation',rule)\">\r\n <ax-validation>\r\n <ax-validation-rule type=\"required\"></ax-validation-rule>\r\n </ax-validation>\r\n <ax-data-source [provideData]=\"getProvideData\" [params]=\"rule\"></ax-data-source>\r\n </ax-select-box>\r\n </ax-form-group>\r\n </div>\r\n <div *ngSwitchCase=\"'numberBox'\">\r\n <ax-form-group>\r\n <ax-label>{{getValue(rule.onDemandLabel)}}</ax-label>\r\n <ax-number-box (onValueChanged)=\"valueChange($event,rule)\"\r\n placeholder=\"\u0645\u0642\u062F\u0627\u0631 \u0645\u0648\u0631\u062F \u0646\u0638\u0631 \u062E\u0648\u062F \u0631\u0627 \u0648\u0627\u0631\u062F \u06A9\u0646\u06CC\u062F\" size=\"sm\">\r\n <ax-validation>\r\n <ax-validation-rule type=\"required\"></ax-validation-rule>\r\n </ax-validation>\r\n </ax-number-box>\r\n </ax-form-group>\r\n </div>\r\n <div *ngSwitchCase=\"'datePicker'\">\r\n\r\n\r\n </div>\r\n <div *ngSwitchCase=\"'boolean'\">\r\n <ax-form-group>\r\n <ax-label>{{getValue(rule.onDemandLabel)}}</ax-label>\r\n <ax-select-box #selectBoxBoolean (selectedItemsChange)=\"valueBooleanChange($event,rule)\"\r\n allowNull=\"false\" [selectedValues]=\"rule.value\" size=\"sm\" mode=\"single\">\r\n <ax-data-source [provideData]=\"provideDataBoolean\">\r\n </ax-data-source>\r\n <ax-validation>\r\n <ax-validation-rule type=\"required\"></ax-validation-rule>\r\n </ax-validation>\r\n </ax-select-box>\r\n </ax-form-group>\r\n\r\n </div>\r\n <div *ngSwitchDefault>\r\n <ax-form-group>\r\n <ax-label>{{getValue(rule.onDemandLabel)}}</ax-label>\r\n <ax-text-box (onValueChanged)=\"textValueChange($event,rule)\"\r\n placeholder=\"\u0645\u0642\u062F\u0627\u0631 \u0645\u0648\u0631\u062F \u0646\u0638\u0631 \u062E\u0648\u062F \u0631\u0627 \u0648\u0627\u0631\u062F \u06A9\u0646\u06CC\u062F\" size=\"sm\">\r\n <ax-validation>\r\n <ax-validation-rule type=\"required\"></ax-validation-rule>\r\n </ax-validation>\r\n </ax-text-box>\r\n\r\n </ax-form-group>\r\n\r\n </div>\r\n </div>\r\n\r\n\r\n\r\n\r\n </div>\r\n\r\n </ax-validation-form>\r\n</div>", components: [{ type: i2.AXValidationFormComponent, selector: "ax-validation-form", inputs: ["validateOn"], outputs: ["onInit"] }, { type: i3.AXFormGroupComponent, selector: "ax-form-group", inputs: ["size"] }, { type: i4.AXLabelComponent, selector: "ax-label", inputs: ["size"] }, { type: i5.AXTextBoxComponent, selector: "ax-text-box", inputs: ["mask", "type", "showMask", "maxLength", "maskGuid", "maskPlaceholder", "maskKeepCharPositions"] }, { type: i6.AXValidationComponent, selector: "ax-validation", inputs: ["rules", "validateOn"], outputs: ["rulesChange", "showMessage"] }, { type: i7.AXValidationRuleComponent, selector: "ax-validation-rule", inputs: ["type", "message", "value", "enabled"] }, { type: i8.AXSelectBoxComponent, selector: "ax-select-box", inputs: ["showDropDownButton", "rowInputTemplate", "showCheckBox", "readonly", "rtl", "disabled", "placeholder", "size", "allowNull", "textAlign", "bufferSize", "remoteOperation", "dataSource", "validation", "disabledCallback", "allowSearch", "textField", "valueField", "disabledField", "mode", "items", "selectedItems", "selectedValues"], outputs: ["dropdownToggle", "itemsChange", "onBlur", "onFocus", "selectionChanged", "selectedItemsChange", "selectedValuesChange"] }, { type: i9.AXDataSourceComponent, selector: "ax-data-source", inputs: ["provideData", "params"] }, { type: i10.AXNumberBoxComponent, selector: "ax-number-box", inputs: ["min", "max", "showSeparator", "showCurrency", "showCounter", "scrollWeel", "showDoubleCounter", "maxLength", "intStep", "decimalNumber", "customStep"] }], directives: [{ type: i11.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i11.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i11.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i11.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i11.NgSwitchDefault, selector: "[ngSwitchDefault]" }] });
|
|
164
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AXQueryBuilderPopupComponent, decorators: [{
|
|
165
165
|
type: Component,
|
|
166
166
|
args: [{ template: "<div>\r\n <ax-validation-form #form>\r\n <div *ngFor=\"let rule of items\">\r\n\r\n <div *ngIf=\" rule.control\" [ngSwitch]=\"rule.control.type\" style=\"padding: 1em;\">\r\n <div *ngSwitchCase=\"'textBox'\">\r\n <ax-form-group>\r\n <ax-label>{{getValue(rule.onDemandLabel)}}</ax-label>\r\n <ax-text-box (onValueChanged)=\"textValueChange($event,rule)\"\r\n placeholder=\"\u0645\u0642\u062F\u0627\u0631 \u0645\u0648\u0631\u062F \u0646\u0638\u0631 \u062E\u0648\u062F \u0631\u0627 \u0648\u0627\u0631\u062F \u06A9\u0646\u06CC\u062F\" size=\"sm\">\r\n <ax-validation>\r\n <ax-validation-rule type=\"required\"></ax-validation-rule>\r\n </ax-validation>\r\n </ax-text-box>\r\n </ax-form-group>\r\n </div>\r\n <div *ngSwitchCase=\"'selectBox'\">\r\n <ax-form-group>\r\n <ax-label>{{getValue(rule.onDemandLabel)}}</ax-label>\r\n <ax-select-box placeholder=\"\u0645\u0642\u062F\u0627\u0631 \u0645\u0648\u0631\u062F \u0646\u0638\u0631 \u062E\u0648\u062F \u0631\u0627 \u0648\u0627\u0631\u062F \u06A9\u0646\u06CC\u062F\"\r\n [textField]=\"getOption('textField',rule)\" [(selectedItems)]=\"rule.valueItem\"\r\n [valueField]=\"getOption('valueField',rule)\" [mode]=\"getOption('mode',rule)\"\r\n (selectedItemsChange)=\"selectedItemsChange($event,rule)\" size=\"sm\" #selectBoxValue\r\n [remoteOperation]=\"getOption('remoteOperation',rule)\">\r\n <ax-validation>\r\n <ax-validation-rule type=\"required\"></ax-validation-rule>\r\n </ax-validation>\r\n <ax-data-source [provideData]=\"getProvideData\" [params]=\"rule\"></ax-data-source>\r\n </ax-select-box>\r\n </ax-form-group>\r\n </div>\r\n <div *ngSwitchCase=\"'numberBox'\">\r\n <ax-form-group>\r\n <ax-label>{{getValue(rule.onDemandLabel)}}</ax-label>\r\n <ax-number-box (onValueChanged)=\"valueChange($event,rule)\"\r\n placeholder=\"\u0645\u0642\u062F\u0627\u0631 \u0645\u0648\u0631\u062F \u0646\u0638\u0631 \u062E\u0648\u062F \u0631\u0627 \u0648\u0627\u0631\u062F \u06A9\u0646\u06CC\u062F\" size=\"sm\">\r\n <ax-validation>\r\n <ax-validation-rule type=\"required\"></ax-validation-rule>\r\n </ax-validation>\r\n </ax-number-box>\r\n </ax-form-group>\r\n </div>\r\n <div *ngSwitchCase=\"'datePicker'\">\r\n\r\n\r\n </div>\r\n <div *ngSwitchCase=\"'boolean'\">\r\n <ax-form-group>\r\n <ax-label>{{getValue(rule.onDemandLabel)}}</ax-label>\r\n <ax-select-box #selectBoxBoolean (selectedItemsChange)=\"valueBooleanChange($event,rule)\"\r\n allowNull=\"false\" [selectedValues]=\"rule.value\" size=\"sm\" mode=\"single\">\r\n <ax-data-source [provideData]=\"provideDataBoolean\">\r\n </ax-data-source>\r\n <ax-validation>\r\n <ax-validation-rule type=\"required\"></ax-validation-rule>\r\n </ax-validation>\r\n </ax-select-box>\r\n </ax-form-group>\r\n\r\n </div>\r\n <div *ngSwitchDefault>\r\n <ax-form-group>\r\n <ax-label>{{getValue(rule.onDemandLabel)}}</ax-label>\r\n <ax-text-box (onValueChanged)=\"textValueChange($event,rule)\"\r\n placeholder=\"\u0645\u0642\u062F\u0627\u0631 \u0645\u0648\u0631\u062F \u0646\u0638\u0631 \u062E\u0648\u062F \u0631\u0627 \u0648\u0627\u0631\u062F \u06A9\u0646\u06CC\u062F\" size=\"sm\">\r\n <ax-validation>\r\n <ax-validation-rule type=\"required\"></ax-validation-rule>\r\n </ax-validation>\r\n </ax-text-box>\r\n\r\n </ax-form-group>\r\n\r\n </div>\r\n </div>\r\n\r\n\r\n\r\n\r\n </div>\r\n\r\n </ax-validation-form>\r\n</div>" }]
|
|
167
167
|
}], ctorParameters: function () { return [{ type: i1.AXToastService }]; }, propDecorators: { form: [{
|
|
168
168
|
type: ViewChild,
|
|
169
169
|
args: [AXValidationFormComponent]
|
|
170
170
|
}] } });
|
|
171
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"query-builder-popup.component.js","sourceRoot":"","sources":["../../../../../../../projects/acorex/components/src/lib/query-builder/query-builder-popup/query-builder-popup.component.ts","../../../../../../../projects/acorex/components/src/lib/query-builder/query-builder-popup/query-builder-popup.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXButtonItem, AXTranslator } from '@acorex/core';\r\nimport { ChangeDetectorRef, Component, ViewChild } from '@angular/core';\r\nimport { AXBasePopupPageComponent } from '../../base/base-page.class';\r\nimport { AXMenuItemClickEvent } from '../../menu/menu.component';\r\nimport { AXQueryBuilderGroup, AXQueryBuilderPopup, AXQueryBuilderRule } from '../query-builder.class';\r\n\r\nimport { AXDataSourceReadParams } from '../../data-source/read-param'\r\nimport { AXToastService } from '../../toast/toast.service';\r\nimport { AXValidationFormComponent } from '../../validation/validation-form.component';\r\n@Component({\r\n    templateUrl: './query-builder-popup.component.html'\r\n})\r\n\r\nexport class AXQueryBuilderPopupComponent extends AXBasePopupPageComponent {\r\n    @ViewChild(AXValidationFormComponent) form: AXValidationFormComponent;\r\n    constructor(private toast: AXToastService) {\r\n        super();\r\n    }\r\n    group: AXQueryBuilderGroup;\r\n    items: AXQueryBuilderRule[] = [];\r\n    groupCopy: AXQueryBuilderGroup;\r\n    complateValue: boolean = true;\r\n    provideData: any;\r\n    makeJsonString(items: any[]) {\r\n        return new Promise((resolve, reject) => {\r\n            items.forEach((element, index, array) => {\r\n                if (element.items) {\r\n                    this.makeJsonString(element.items);\r\n                } else {\r\n                    if (element.control && element.control.options && (element.control.options.dataSource === '' || element.control.options.dataSource === undefined)) {\r\n                        element.control.options.dataSource = this.provideData;\r\n                    }\r\n                }\r\n                if (index === array.length - 1) {\r\n                    resolve(array[0]);\r\n                }\r\n            });\r\n        });\r\n    }\r\n    ngAfterViewInit() {\r\n        var groupString = JSON.stringify(this.group);\r\n        this.groupCopy = JSON.parse(groupString);\r\n        this.makeJsonString(this.groupCopy.items);\r\n        for (let i = 0; i < this.groupCopy.items.length; i++) {\r\n            this.getNoValueRule(this.groupCopy.items[i]);\r\n        }\r\n        if (this.items.length < 1) {\r\n            this.close(this.group);\r\n        }\r\n\r\n    }\r\n    getValue(v) {\r\n        return v.indexOf('????') == 0 ? v.split('|')[1] : v;\r\n    }\r\n    getNoValueRule(gr) {\r\n        // for (let i = 0; i < gr.items.length; i++) {\r\n        if (gr.condition) {\r\n            for (let i = 0; i < gr.items.length; i++) {\r\n                this.getNoValueRule(gr.items[i]);\r\n            }\r\n\r\n        } else {\r\n            if (gr.onDemandLabel?.indexOf('????') == 0) {\r\n                this.items.push(gr);\r\n            }\r\n        }\r\n\r\n        //  }\r\n    }\r\n\r\n    ngOnInit(): void {\r\n\r\n    }\r\n\r\n\r\n    textValueChange(e, rule) {\r\n        rule.value = e.value;\r\n        rule.text = e.value;\r\n\r\n    }\r\n    selectedItemsChange(e, rule) {\r\n        let n = this.getOption('textField', rule);\r\n        rule.text = e[0][n];\r\n        if (rule && rule.control.options.valueField) {\r\n            rule.value = e[0][rule.control.options.valueField];\r\n        } else {\r\n            rule.value = e[0].value;\r\n        }\r\n        rule.valueItem[0] = e[0];\r\n\r\n    }\r\n    valueChange(e, rule) {\r\n        rule.value = e.value;\r\n        rule.text = e.value;\r\n\r\n    }\r\n    valueBooleanChange(e, rule) {\r\n        rule.text = e.value == undefined ? e[0].value : e.value;\r\n        rule.value = e.value == undefined ? e[0].value : e.value;\r\n\r\n    }\r\n    getOption(name: string, rule) {\r\n        return rule.control.options ? rule.control.options[name] : null;\r\n    }\r\n    getProvideData = (e: AXDataSourceReadParams) => {\r\n        if (e.extra && e.extra.control.options && e.extra.control.options.dataSource) {\r\n            return e.extra.control.options.dataSource({ ...e, optionsData: { ...e.extra.control.options } });\r\n        }\r\n    };\r\n\r\n    provideDataBoolean = (e) => {\r\n        return new Promise((resolve) => {\r\n            resolve([\r\n                {\r\n                    value: 'true',\r\n                    text: AXTranslator.get('queryBuilder.true')\r\n                },\r\n                {\r\n                    value: 'false',\r\n                    text: AXTranslator.get('queryBuilder.false')\r\n                }\r\n\r\n            ])\r\n        })\r\n    }\r\n\r\n    findNullValue(gr) {\r\n        for (let i = 0; i < gr.length; i++) {\r\n            if (gr[i].value === null || gr[i].value === undefined || gr[i].value === '') {\r\n                this.complateValue = false;\r\n            }\r\n        }\r\n\r\n\r\n        // if (gr.condition) {\r\n        //     for (let i = 0; i < gr.items.length; i++) {\r\n        //         this.findNullValue(gr.items[i]);\r\n        //     }\r\n\r\n        // } else {\r\n        //     if (gr.onDemandLabel?.indexOf('????') == 0 || gr.value === null || gr.value === undefined || gr.value === '') {\r\n        //         this.complateValue = false;\r\n        //     }\r\n        // }\r\n\r\n    }\r\n\r\n    onFooterButtonClick(e: AXMenuItemClickEvent) {\r\n        if (e.name === 'confirm') {\r\n            this.form.validate().then(c => {\r\n                if (c.result === true) {\r\n                    this.close(this.groupCopy);\r\n                }\r\n            });\r\n        }\r\n        if (e.name === 'cancel') {\r\n            this.close();\r\n        }\r\n\r\n    }\r\n\r\n    getFooterButtons(): AXButtonItem[] {\r\n        return [\r\n            {\r\n                text: AXTranslator.get('common.confirm'),\r\n                name: 'confirm',\r\n                style: 'ax primary',\r\n                icon: 'far fa-check-circle'\r\n            },\r\n            {\r\n                text: AXTranslator.get('common.cancel'),\r\n                name: 'cancel',\r\n                style: 'ax light',\r\n                icon: 'far fa-times-circle'\r\n            }\r\n        ]\r\n    }\r\n}","<div>\r\n    <ax-validation-form #form>\r\n        <div *ngFor=\"let rule of items\">\r\n\r\n            <div *ngIf=\" rule.control\" [ngSwitch]=\"rule.control.type\" style=\"padding: 1em;\">\r\n                <div *ngSwitchCase=\"'textBox'\">\r\n                    <ax-form-group>\r\n                        <ax-label>{{getValue(rule.onDemandLabel)}}</ax-label>\r\n                        <ax-text-box (onValueChanged)=\"textValueChange($event,rule)\"\r\n                            placeholder=\"مقدار مورد نظر خود را وارد کنید\" size=\"sm\">\r\n                            <ax-validation>\r\n                                <ax-validation-rule type=\"required\"></ax-validation-rule>\r\n                            </ax-validation>\r\n                        </ax-text-box>\r\n                    </ax-form-group>\r\n                </div>\r\n                <div *ngSwitchCase=\"'selectBox'\">\r\n                    <ax-form-group>\r\n                        <ax-label>{{getValue(rule.onDemandLabel)}}</ax-label>\r\n                        <ax-select-box placeholder=\"مقدار مورد نظر خود را وارد کنید\"\r\n                            [textField]=\"getOption('textField',rule)\" [(selectedItems)]=\"rule.valueItem\"\r\n                            [valueField]=\"getOption('valueField',rule)\" [mode]=\"getOption('mode',rule)\"\r\n                            (selectedItemsChange)=\"selectedItemsChange($event,rule)\" size=\"sm\" #selectBoxValue\r\n                            [remoteOperation]=\"getOption('remoteOperation',rule)\">\r\n                            <ax-validation>\r\n                                <ax-validation-rule type=\"required\"></ax-validation-rule>\r\n                            </ax-validation>\r\n                            <ax-data-source [provideData]=\"getProvideData\" [params]=\"rule\"></ax-data-source>\r\n                        </ax-select-box>\r\n                    </ax-form-group>\r\n                </div>\r\n                <div *ngSwitchCase=\"'numberBox'\">\r\n                    <ax-form-group>\r\n                        <ax-label>{{getValue(rule.onDemandLabel)}}</ax-label>\r\n                        <ax-number-box (onValueChanged)=\"valueChange($event,rule)\"\r\n                            placeholder=\"مقدار مورد نظر خود را وارد کنید\" size=\"sm\">\r\n                            <ax-validation>\r\n                                <ax-validation-rule type=\"required\"></ax-validation-rule>\r\n                            </ax-validation>\r\n                        </ax-number-box>\r\n                    </ax-form-group>\r\n                </div>\r\n                <div *ngSwitchCase=\"'datePicker'\">\r\n\r\n\r\n                </div>\r\n                <div *ngSwitchCase=\"'boolean'\">\r\n                    <ax-form-group>\r\n                        <ax-label>{{getValue(rule.onDemandLabel)}}</ax-label>\r\n                        <ax-select-box #selectBoxBoolean (selectedItemsChange)=\"valueBooleanChange($event,rule)\"\r\n                            allowNull=\"false\" [selectedValues]=\"rule.value\" size=\"sm\" mode=\"single\">\r\n                            <ax-data-source [provideData]=\"provideDataBoolean\">\r\n                            </ax-data-source>\r\n                            <ax-validation>\r\n                                <ax-validation-rule type=\"required\"></ax-validation-rule>\r\n                            </ax-validation>\r\n                        </ax-select-box>\r\n                    </ax-form-group>\r\n\r\n                </div>\r\n                <div *ngSwitchDefault>\r\n                    <ax-form-group>\r\n                        <ax-label>{{getValue(rule.onDemandLabel)}}</ax-label>\r\n                        <ax-text-box (onValueChanged)=\"textValueChange($event,rule)\"\r\n                            placeholder=\"مقدار مورد نظر خود را وارد کنید\" size=\"sm\">\r\n                            <ax-validation>\r\n                                <ax-validation-rule type=\"required\"></ax-validation-rule>\r\n                            </ax-validation>\r\n                        </ax-text-box>\r\n\r\n                    </ax-form-group>\r\n\r\n                </div>\r\n            </div>\r\n\r\n\r\n\r\n\r\n        </div>\r\n\r\n    </ax-validation-form>\r\n</div>"]}
|
|
171
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"query-builder-popup.component.js","sourceRoot":"","sources":["../../../../../../../projects/acorex/components/src/lib/query-builder/query-builder-popup/query-builder-popup.component.ts","../../../../../../../projects/acorex/components/src/lib/query-builder/query-builder-popup/query-builder-popup.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXButtonItem, AXTranslator } from '@acorex/core';\r\nimport { ChangeDetectorRef, Component, ViewChild } from '@angular/core';\r\nimport { AXBasePopupPageComponent } from '../../base/base-page.class';\r\nimport { AXMenuItemClickEvent } from '../../menu/menu.component';\r\nimport { AXQueryBuilderGroup, AXQueryBuilderPopup, AXQueryBuilderRule } from '../query-builder.class';\r\n\r\nimport { AXDataSourceReadParams } from '../../data-source/read-param'\r\nimport { AXToastService } from '../../toast/toast.service';\r\nimport { AXValidationFormComponent } from '../../validation/validation-form.component';\r\n@Component({\r\n    templateUrl: './query-builder-popup.component.html'\r\n})\r\n\r\nexport class AXQueryBuilderPopupComponent extends AXBasePopupPageComponent {\r\n    @ViewChild(AXValidationFormComponent) form: AXValidationFormComponent;\r\n    constructor(private toast: AXToastService) {\r\n        super();\r\n    }\r\n    group: AXQueryBuilderGroup;\r\n    items: AXQueryBuilderRule[] = [];\r\n    groupCopy: AXQueryBuilderGroup;\r\n    complateValue: boolean = true;\r\n    provideData: any;\r\n    makeJsonString(items: any[]) {\r\n        return new Promise((resolve, reject) => {\r\n            items.forEach((element, index, array) => {\r\n                if (element.items) {\r\n                    this.makeJsonString(element.items);\r\n                } else {\r\n                    if (element.control && element.control.options && (element.control.options.dataSource === '' || element.control.options.dataSource === undefined)) {\r\n                        element.control.options.dataSource = this.provideData;\r\n                    }\r\n                }\r\n                if (index === array.length - 1) {\r\n                    resolve(array[0]);\r\n                }\r\n            });\r\n        });\r\n    }\r\n    ngAfterViewInit() {\r\n        var groupString = JSON.stringify(this.group);\r\n        this.groupCopy = JSON.parse(groupString);\r\n        this.makeJsonString(this.groupCopy.items);\r\n        for (let i = 0; i < this.groupCopy.items.length; i++) {\r\n            this.getNoValueRule(this.groupCopy.items[i]);\r\n        }\r\n        if (this.items.length < 1) {\r\n            this.close(this.group);\r\n        }\r\n\r\n    }\r\n    getValue(v) {\r\n        return v.indexOf('????') == 0 ? v.split('|')[1] : v;\r\n    }\r\n    getNoValueRule(gr) {\r\n        // for (let i = 0; i < gr.items.length; i++) {\r\n        if (gr.condition) {\r\n            for (let i = 0; i < gr.items.length; i++) {\r\n                this.getNoValueRule(gr.items[i]);\r\n            }\r\n\r\n        } else {\r\n            if (gr.onDemandLabel?.indexOf('????') == 0) {\r\n                this.items.push(gr);\r\n            }\r\n        }\r\n\r\n        //  }\r\n    }\r\n\r\n    ngOnInit(): void {\r\n\r\n    }\r\n\r\n\r\n    textValueChange(e, rule) {\r\n        rule.value = e.value;\r\n        rule.text = e.value;\r\n\r\n    }\r\n    selectedItemsChange(e, rule) {\r\n        let n = this.getOption('textField', rule);\r\n        rule.text = e[0][n];\r\n        if (rule && rule.control.options.valueField) {\r\n            rule.value = e[0][rule.control.options.valueField];\r\n        } else {\r\n            rule.value = e[0].value;\r\n        }\r\n        rule.valueItem[0] = e[0];\r\n\r\n    }\r\n    valueChange(e, rule) {\r\n        rule.value = e.value;\r\n        rule.text = e.value;\r\n\r\n    }\r\n    valueBooleanChange(e, rule) {\r\n        rule.text = e.value == undefined ? e[0].value : e.value;\r\n        rule.value = e.value == undefined ? e[0].value : e.value;\r\n\r\n    }\r\n    getOption(name: string, rule) {\r\n        return rule.control.options ? rule.control.options[name] : null;\r\n    }\r\n    getProvideData = (e: AXDataSourceReadParams) => {\r\n        if (e.extra && e.extra.control.options && e.extra.control.options.dataSource) {\r\n            return e.extra.control.options.dataSource({ ...e, optionsData: { ...e.extra.control.options } });\r\n        }\r\n    };\r\n\r\n    provideDataBoolean = (e) => {\r\n        return new Promise((resolve) => {\r\n            resolve([\r\n                {\r\n                    value: 'true',\r\n                    text: AXTranslator.get('queryBuilder.true')\r\n                },\r\n                {\r\n                    value: 'false',\r\n                    text: AXTranslator.get('queryBuilder.false')\r\n                }\r\n\r\n            ])\r\n        })\r\n    }\r\n\r\n    findNullValue(gr) {\r\n        for (let i = 0; i < gr.length; i++) {\r\n            if (gr[i].value === null || gr[i].value === undefined || gr[i].value === '') {\r\n                this.complateValue = false;\r\n            }\r\n        }\r\n\r\n\r\n        // if (gr.condition) {\r\n        //     for (let i = 0; i < gr.items.length; i++) {\r\n        //         this.findNullValue(gr.items[i]);\r\n        //     }\r\n\r\n        // } else {\r\n        //     if (gr.onDemandLabel?.indexOf('????') == 0 || gr.value === null || gr.value === undefined || gr.value === '') {\r\n        //         this.complateValue = false;\r\n        //     }\r\n        // }\r\n\r\n    }\r\n\r\n    onFooterButtonClick(e: AXMenuItemClickEvent) {\r\n        if (e.name === 'confirm') {\r\n            this.form.validate().then(c => {\r\n                if (c.result === true) {\r\n                    this.close(this.groupCopy);\r\n                }\r\n            });\r\n        }\r\n        if (e.name === 'cancel') {\r\n            this.close();\r\n        }\r\n\r\n    }\r\n\r\n    getFooterButtons(): AXButtonItem[] {\r\n        return [\r\n            {\r\n                text: AXTranslator.get('common.confirm'),\r\n                name: 'confirm',\r\n                style: 'ax primary',\r\n                icon: 'far fa-check-circle'\r\n            },\r\n            {\r\n                text: AXTranslator.get('common.cancel'),\r\n                name: 'cancel',\r\n                style: 'ax light',\r\n                icon: 'far fa-times-circle'\r\n            }\r\n        ]\r\n    }\r\n}","<div>\r\n    <ax-validation-form #form>\r\n        <div *ngFor=\"let rule of items\">\r\n\r\n            <div *ngIf=\" rule.control\" [ngSwitch]=\"rule.control.type\" style=\"padding: 1em;\">\r\n                <div *ngSwitchCase=\"'textBox'\">\r\n                    <ax-form-group>\r\n                        <ax-label>{{getValue(rule.onDemandLabel)}}</ax-label>\r\n                        <ax-text-box (onValueChanged)=\"textValueChange($event,rule)\"\r\n                            placeholder=\"مقدار مورد نظر خود را وارد کنید\" size=\"sm\">\r\n                            <ax-validation>\r\n                                <ax-validation-rule type=\"required\"></ax-validation-rule>\r\n                            </ax-validation>\r\n                        </ax-text-box>\r\n                    </ax-form-group>\r\n                </div>\r\n                <div *ngSwitchCase=\"'selectBox'\">\r\n                    <ax-form-group>\r\n                        <ax-label>{{getValue(rule.onDemandLabel)}}</ax-label>\r\n                        <ax-select-box placeholder=\"مقدار مورد نظر خود را وارد کنید\"\r\n                            [textField]=\"getOption('textField',rule)\" [(selectedItems)]=\"rule.valueItem\"\r\n                            [valueField]=\"getOption('valueField',rule)\" [mode]=\"getOption('mode',rule)\"\r\n                            (selectedItemsChange)=\"selectedItemsChange($event,rule)\" size=\"sm\" #selectBoxValue\r\n                            [remoteOperation]=\"getOption('remoteOperation',rule)\">\r\n                            <ax-validation>\r\n                                <ax-validation-rule type=\"required\"></ax-validation-rule>\r\n                            </ax-validation>\r\n                            <ax-data-source [provideData]=\"getProvideData\" [params]=\"rule\"></ax-data-source>\r\n                        </ax-select-box>\r\n                    </ax-form-group>\r\n                </div>\r\n                <div *ngSwitchCase=\"'numberBox'\">\r\n                    <ax-form-group>\r\n                        <ax-label>{{getValue(rule.onDemandLabel)}}</ax-label>\r\n                        <ax-number-box (onValueChanged)=\"valueChange($event,rule)\"\r\n                            placeholder=\"مقدار مورد نظر خود را وارد کنید\" size=\"sm\">\r\n                            <ax-validation>\r\n                                <ax-validation-rule type=\"required\"></ax-validation-rule>\r\n                            </ax-validation>\r\n                        </ax-number-box>\r\n                    </ax-form-group>\r\n                </div>\r\n                <div *ngSwitchCase=\"'datePicker'\">\r\n\r\n\r\n                </div>\r\n                <div *ngSwitchCase=\"'boolean'\">\r\n                    <ax-form-group>\r\n                        <ax-label>{{getValue(rule.onDemandLabel)}}</ax-label>\r\n                        <ax-select-box #selectBoxBoolean (selectedItemsChange)=\"valueBooleanChange($event,rule)\"\r\n                            allowNull=\"false\" [selectedValues]=\"rule.value\" size=\"sm\" mode=\"single\">\r\n                            <ax-data-source [provideData]=\"provideDataBoolean\">\r\n                            </ax-data-source>\r\n                            <ax-validation>\r\n                                <ax-validation-rule type=\"required\"></ax-validation-rule>\r\n                            </ax-validation>\r\n                        </ax-select-box>\r\n                    </ax-form-group>\r\n\r\n                </div>\r\n                <div *ngSwitchDefault>\r\n                    <ax-form-group>\r\n                        <ax-label>{{getValue(rule.onDemandLabel)}}</ax-label>\r\n                        <ax-text-box (onValueChanged)=\"textValueChange($event,rule)\"\r\n                            placeholder=\"مقدار مورد نظر خود را وارد کنید\" size=\"sm\">\r\n                            <ax-validation>\r\n                                <ax-validation-rule type=\"required\"></ax-validation-rule>\r\n                            </ax-validation>\r\n                        </ax-text-box>\r\n\r\n                    </ax-form-group>\r\n\r\n                </div>\r\n            </div>\r\n\r\n\r\n\r\n\r\n        </div>\r\n\r\n    </ax-validation-form>\r\n</div>"]}
|