@ecodev/natural 59.0.1 → 60.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/classes/abstract-controller.mjs +6 -5
- package/esm2022/lib/classes/abstract-detail.mjs +7 -6
- package/esm2022/lib/classes/abstract-editable-list.mjs +6 -5
- package/esm2022/lib/classes/abstract-list.mjs +6 -5
- package/esm2022/lib/classes/abstract-navigable-list.mjs +6 -5
- package/esm2022/lib/classes/apollo-utils.mjs +1 -1
- package/esm2022/lib/classes/cumulative-changes.mjs +4 -4
- package/esm2022/lib/classes/signing.mjs +2 -2
- package/esm2022/lib/classes/tld.mjs +1 -1
- package/esm2022/lib/classes/utility.mjs +2 -2
- package/esm2022/lib/directives/http-prefix.directive.mjs +3 -3
- package/esm2022/lib/modules/alert/alert.service.mjs +3 -3
- package/esm2022/lib/modules/alert/confirm.component.mjs +3 -3
- package/esm2022/lib/modules/avatar/component/avatar.component.mjs +4 -4
- package/esm2022/lib/modules/avatar/service/avatar.service.mjs +3 -3
- package/esm2022/lib/modules/avatar/sources/gravatar.mjs +2 -2
- package/esm2022/lib/modules/columns-picker/columns-picker.component.mjs +4 -4
- package/esm2022/lib/modules/common/directives/linkable-tab.directive.mjs +3 -3
- package/esm2022/lib/modules/common/directives/src-density.directive.mjs +5 -5
- package/esm2022/lib/modules/common/pipes/capitalize.pipe.mjs +3 -3
- package/esm2022/lib/modules/common/pipes/ellipsis.pipe.mjs +3 -3
- package/esm2022/lib/modules/common/pipes/enum.pipe.mjs +3 -3
- package/esm2022/lib/modules/common/pipes/time-ago.pipe.mjs +3 -3
- package/esm2022/lib/modules/common/services/memory-storage.mjs +3 -3
- package/esm2022/lib/modules/common/services/seo.service.mjs +4 -4
- package/esm2022/lib/modules/detail-header/detail-header.component.mjs +3 -3
- package/esm2022/lib/modules/dialog-trigger/dialog-trigger.component.mjs +3 -3
- package/esm2022/lib/modules/dropdown-components/abstract-association-select-component.directive.mjs +8 -7
- package/esm2022/lib/modules/dropdown-components/public-api.mjs +1 -1
- package/esm2022/lib/modules/dropdown-components/type-boolean/type-boolean.component.mjs +3 -3
- package/esm2022/lib/modules/dropdown-components/type-date/type-date.component.mjs +3 -3
- package/esm2022/lib/modules/dropdown-components/type-date-range/type-date-range.component.mjs +5 -5
- package/esm2022/lib/modules/dropdown-components/type-hierarchic-selector/type-hierarchic-selector.component.mjs +3 -3
- package/esm2022/lib/modules/dropdown-components/type-natural-select/type-natural-select.component.mjs +3 -3
- package/esm2022/lib/modules/dropdown-components/type-number/type-number.component.mjs +5 -5
- package/esm2022/lib/modules/dropdown-components/type-options/type-options.component.mjs +3 -3
- package/esm2022/lib/modules/dropdown-components/type-select/type-select.component.mjs +7 -7
- package/esm2022/lib/modules/dropdown-components/type-text/type-text.component.mjs +3 -3
- package/esm2022/lib/modules/dropdown-components/types.mjs +1 -1
- package/esm2022/lib/modules/file/abstract-file.mjs +6 -5
- package/esm2022/lib/modules/file/component/file.component.mjs +9 -7
- package/esm2022/lib/modules/file/file-drop.directive.mjs +3 -3
- package/esm2022/lib/modules/file/file-select.directive.mjs +3 -3
- package/esm2022/lib/modules/file/file.service.mjs +3 -3
- package/esm2022/lib/modules/fixed-button/fixed-button.component.mjs +3 -3
- package/esm2022/lib/modules/fixed-button-detail/fixed-button-detail.component.mjs +3 -3
- package/esm2022/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.component.mjs +3 -3
- package/esm2022/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.service.mjs +3 -3
- package/esm2022/lib/modules/hierarchic-selector/hierarchic-selector-dialog/hierarchic-selector-dialog.component.mjs +3 -3
- package/esm2022/lib/modules/hierarchic-selector/hierarchic-selector-dialog/hierarchic-selector-dialog.service.mjs +3 -3
- package/esm2022/lib/modules/icon/icon.directive.mjs +3 -3
- package/esm2022/lib/modules/logger/error-handler.mjs +3 -3
- package/esm2022/lib/modules/matomo/matomo.service.mjs +6 -8
- package/esm2022/lib/modules/panels/abstract-panel.mjs +6 -5
- package/esm2022/lib/modules/panels/panels.component.mjs +3 -3
- package/esm2022/lib/modules/panels/panels.service.mjs +3 -3
- package/esm2022/lib/modules/relations/relations.component.mjs +5 -5
- package/esm2022/lib/modules/search/classes/transformers.mjs +4 -4
- package/esm2022/lib/modules/search/dropdown-container/dropdown-container.component.mjs +3 -3
- package/esm2022/lib/modules/search/dropdown-container/dropdown.service.mjs +3 -3
- package/esm2022/lib/modules/search/facet-selector/facet-selector.component.mjs +3 -3
- package/esm2022/lib/modules/search/group/group.component.mjs +3 -3
- package/esm2022/lib/modules/search/input/input.component.mjs +3 -3
- package/esm2022/lib/modules/search/search/search.component.mjs +3 -3
- package/esm2022/lib/modules/select/abstract-select.component.mjs +6 -5
- package/esm2022/lib/modules/select/select/select.component.mjs +3 -3
- package/esm2022/lib/modules/select/select-enum/select-enum.component.mjs +3 -3
- package/esm2022/lib/modules/select/select-hierarchic/select-hierarchic.component.mjs +5 -5
- package/esm2022/lib/modules/sidenav/sidenav/sidenav.component.mjs +3 -3
- package/esm2022/lib/modules/sidenav/sidenav-container/sidenav-container.component.mjs +3 -3
- package/esm2022/lib/modules/sidenav/sidenav-content/sidenav-content.component.mjs +3 -3
- package/esm2022/lib/modules/sidenav/sidenav-stack.service.mjs +3 -3
- package/esm2022/lib/modules/sidenav/sidenav.service.mjs +3 -3
- package/esm2022/lib/modules/stamp/stamp.component.mjs +3 -3
- package/esm2022/lib/modules/table-button/table-button.component.mjs +6 -6
- package/esm2022/lib/services/debounce.service.mjs +3 -3
- package/esm2022/lib/services/enum.service.mjs +3 -3
- package/esm2022/lib/services/link-mutation.service.mjs +5 -5
- package/esm2022/lib/services/persistence.service.mjs +3 -3
- package/esm2022/lib/services/swiss-parsing-date-adapter.service.mjs +3 -3
- package/esm2022/public-api.mjs +2 -2
- package/fesm2022/ecodev-natural.mjs +260 -251
- package/fesm2022/ecodev-natural.mjs.map +1 -1
- package/lib/classes/abstract-controller.d.ts +1 -1
- package/lib/classes/abstract-detail.d.ts +1 -1
- package/lib/classes/abstract-editable-list.d.ts +1 -1
- package/lib/classes/abstract-list.d.ts +1 -1
- package/lib/classes/abstract-navigable-list.d.ts +1 -1
- package/lib/classes/apollo-utils.d.ts +1 -2
- package/lib/classes/cumulative-changes.d.ts +2 -3
- package/lib/classes/tld.d.ts +1 -1
- package/lib/modules/columns-picker/columns-picker.component.d.ts +2 -2
- package/lib/modules/common/services/seo.service.d.ts +1 -1
- package/lib/modules/dropdown-components/abstract-association-select-component.directive.d.ts +1 -1
- package/lib/modules/dropdown-components/public-api.d.ts +1 -1
- package/lib/modules/dropdown-components/types.d.ts +2 -2
- package/lib/modules/file/abstract-file.d.ts +1 -1
- package/lib/modules/matomo/matomo.service.d.ts +2 -2
- package/lib/modules/panels/abstract-panel.d.ts +1 -1
- package/lib/modules/search/classes/transformers.d.ts +3 -3
- package/lib/modules/select/abstract-select.component.d.ts +1 -1
- package/package.json +10 -10
- package/public-api.d.ts +1 -1
- package/src/lib/_natural.theme.scss +9 -9
- package/src/lib/modules/alert/_alert.theme.scss +2 -2
- package/src/lib/modules/file/component/_file.theme.scss +5 -5
- package/src/lib/modules/search/dropdown-container/_dropdown-container.theme.scss +1 -1
- package/src/lib/styles/_table.scss +2 -2
package/esm2022/lib/modules/dropdown-components/abstract-association-select-component.directive.mjs
CHANGED
|
@@ -61,10 +61,10 @@ export class AbstractAssociationSelectComponent {
|
|
|
61
61
|
if (condition.have && !condition.have.not) {
|
|
62
62
|
return 'is';
|
|
63
63
|
}
|
|
64
|
-
else if (condition.have
|
|
64
|
+
else if (condition.have?.not) {
|
|
65
65
|
return 'isnot';
|
|
66
66
|
}
|
|
67
|
-
else if (condition.empty
|
|
67
|
+
else if (condition.empty?.not) {
|
|
68
68
|
return 'any';
|
|
69
69
|
}
|
|
70
70
|
else if (condition.empty && !condition.empty.not) {
|
|
@@ -86,13 +86,14 @@ export class AbstractAssociationSelectComponent {
|
|
|
86
86
|
throw new Error('Unsupported operator key: ' + key);
|
|
87
87
|
}
|
|
88
88
|
}
|
|
89
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
90
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "
|
|
89
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: AbstractAssociationSelectComponent, deps: [{ token: NATURAL_DROPDOWN_DATA }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
90
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.1.0", type: AbstractAssociationSelectComponent, isStandalone: true, ngImport: i0 }); }
|
|
91
91
|
}
|
|
92
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
93
|
-
type: Directive
|
|
92
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: AbstractAssociationSelectComponent, decorators: [{
|
|
93
|
+
type: Directive,
|
|
94
|
+
args: [{ standalone: true }]
|
|
94
95
|
}], ctorParameters: () => [{ type: undefined, decorators: [{
|
|
95
96
|
type: Inject,
|
|
96
97
|
args: [NATURAL_DROPDOWN_DATA]
|
|
97
98
|
}] }] });
|
|
98
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-association-select-component.directive.js","sourceRoot":"","sources":["../../../../../../projects/natural/src/lib/modules/dropdown-components/abstract-association-select-component.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, Inject} from '@angular/core';\nimport {BehaviorSubject, merge, Observable} from 'rxjs';\nimport {FilterGroupConditionField} from '../search/classes/graphql-doctrine.types';\nimport {NATURAL_DROPDOWN_DATA, NaturalDropdownData} from '../search/dropdown-container/dropdown.service';\nimport {DropdownComponent} from '../search/types/dropdown-component';\nimport {FormControl, FormGroup, ValidatorFn, Validators} from '@angular/forms';\nimport {PossibleDiscreteOperatorKeys, possibleDiscreteOperators} from './types';\nimport {startWith} from 'rxjs/operators';\n\n@Directive()\nexport abstract class AbstractAssociationSelectComponent<C> implements DropdownComponent {\n    public readonly configuration: C;\n    public readonly renderedValue = new BehaviorSubject<string>('');\n\n    public requireValueCtrl = false;\n    public readonly operators = possibleDiscreteOperators;\n    public readonly operatorCtrl = new FormControl<PossibleDiscreteOperatorKeys>('is', {nonNullable: true});\n    public readonly valueCtrl = new FormControl();\n    public readonly form = new FormGroup({\n        operator: this.operatorCtrl,\n        value: this.valueCtrl,\n    });\n\n    public constructor(@Inject(NATURAL_DROPDOWN_DATA) data: NaturalDropdownData<C>) {\n        this.configuration = data.configuration;\n\n        // Immediately initValidators and everytime the operator change later\n        this.operatorCtrl.valueChanges.pipe(startWith(null)).subscribe(() => this.initValidators());\n\n        merge(this.operatorCtrl.valueChanges, this.valueCtrl.valueChanges).subscribe(() => {\n            const rendered = this.getRenderedValue();\n            this.renderedValue.next(rendered);\n        });\n\n        this.reloadCondition(data.condition);\n    }\n\n    /**\n     * Reload the value from API (`operatorCtrl` should not be touched)\n     */\n    protected abstract reloadValue(condition: FilterGroupConditionField): Observable<unknown>;\n\n    protected abstract renderValueWithoutOperator(): string;\n\n    public abstract getCondition(): FilterGroupConditionField;\n\n    public isValid(): boolean {\n        return this.form.valid;\n    }\n\n    public isDirty(): boolean {\n        return this.form.dirty;\n    }\n\n    private initValidators(): void {\n        const whitelist: PossibleDiscreteOperatorKeys[] = ['is', 'isnot'];\n        this.requireValueCtrl = whitelist.includes(this.operatorCtrl.value);\n        const validators: ValidatorFn[] = this.requireValueCtrl ? [Validators.required] : [];\n\n        this.valueCtrl.setValidators(validators);\n        this.valueCtrl.updateValueAndValidity();\n    }\n\n    private reloadCondition(condition: FilterGroupConditionField | null): void {\n        if (!condition) {\n            return;\n        }\n\n        const operatorKey = this.conditionToOperatorKey(condition);\n        this.operatorCtrl.setValue(operatorKey);\n\n        this.reloadValue(condition).subscribe(value => {\n            this.valueCtrl.setValue(value);\n            this.renderedValue.next(this.getRenderedValue());\n        });\n    }\n\n    protected getRenderedValue(): string {\n        const operator = this.operators.find(v => v.key === this.operatorCtrl.value);\n        if (!operator || !this.isValid()) {\n            return '';\n        }\n\n        const selection = this.renderValueWithoutOperator();\n\n        return [operator.label, selection].filter(v => v).join(' ');\n    }\n\n    protected conditionToOperatorKey(condition: FilterGroupConditionField): PossibleDiscreteOperatorKeys {\n        if (condition.have && !condition.have.not) {\n            return 'is';\n        } else if (condition.have && condition.have.not) {\n            return 'isnot';\n        } else if (condition.empty && condition.empty.not) {\n            return 'any';\n        } else if (condition.empty && !condition.empty.not) {\n            return 'none';\n        }\n\n        return 'is';\n    }\n\n    protected operatorKeyToCondition(key: PossibleDiscreteOperatorKeys, values: string[]): FilterGroupConditionField {\n        switch (key) {\n            case 'is':\n                return {have: {values: values}};\n            case 'isnot':\n                return {have: {values: values, not: true}};\n            case 'any':\n                return {empty: {not: true}};\n            case 'none':\n                return {empty: {not: false}};\n            default:\n                throw new Error('Unsupported operator key: ' + (key as string));\n        }\n    }\n}\n"]}
|
|
99
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-association-select-component.directive.js","sourceRoot":"","sources":["../../../../../../projects/natural/src/lib/modules/dropdown-components/abstract-association-select-component.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, Inject} from '@angular/core';\nimport {BehaviorSubject, merge, Observable} from 'rxjs';\nimport {FilterGroupConditionField} from '../search/classes/graphql-doctrine.types';\nimport {NATURAL_DROPDOWN_DATA, NaturalDropdownData} from '../search/dropdown-container/dropdown.service';\nimport {DropdownComponent} from '../search/types/dropdown-component';\nimport {FormControl, FormGroup, ValidatorFn, Validators} from '@angular/forms';\nimport {PossibleDiscreteOperatorKeys, possibleDiscreteOperators} from './types';\nimport {startWith} from 'rxjs/operators';\n\n@Directive({standalone: true})\nexport abstract class AbstractAssociationSelectComponent<C> implements DropdownComponent {\n    public readonly configuration: C;\n    public readonly renderedValue = new BehaviorSubject<string>('');\n\n    public requireValueCtrl = false;\n    public readonly operators = possibleDiscreteOperators;\n    public readonly operatorCtrl = new FormControl<PossibleDiscreteOperatorKeys>('is', {nonNullable: true});\n    public readonly valueCtrl = new FormControl();\n    public readonly form = new FormGroup({\n        operator: this.operatorCtrl,\n        value: this.valueCtrl,\n    });\n\n    public constructor(@Inject(NATURAL_DROPDOWN_DATA) data: NaturalDropdownData<C>) {\n        this.configuration = data.configuration;\n\n        // Immediately initValidators and everytime the operator change later\n        this.operatorCtrl.valueChanges.pipe(startWith(null)).subscribe(() => this.initValidators());\n\n        merge(this.operatorCtrl.valueChanges, this.valueCtrl.valueChanges).subscribe(() => {\n            const rendered = this.getRenderedValue();\n            this.renderedValue.next(rendered);\n        });\n\n        this.reloadCondition(data.condition);\n    }\n\n    /**\n     * Reload the value from API (`operatorCtrl` should not be touched)\n     */\n    protected abstract reloadValue(condition: FilterGroupConditionField): Observable<unknown>;\n\n    protected abstract renderValueWithoutOperator(): string;\n\n    public abstract getCondition(): FilterGroupConditionField;\n\n    public isValid(): boolean {\n        return this.form.valid;\n    }\n\n    public isDirty(): boolean {\n        return this.form.dirty;\n    }\n\n    private initValidators(): void {\n        const whitelist: PossibleDiscreteOperatorKeys[] = ['is', 'isnot'];\n        this.requireValueCtrl = whitelist.includes(this.operatorCtrl.value);\n        const validators: ValidatorFn[] = this.requireValueCtrl ? [Validators.required] : [];\n\n        this.valueCtrl.setValidators(validators);\n        this.valueCtrl.updateValueAndValidity();\n    }\n\n    private reloadCondition(condition: FilterGroupConditionField | null): void {\n        if (!condition) {\n            return;\n        }\n\n        const operatorKey = this.conditionToOperatorKey(condition);\n        this.operatorCtrl.setValue(operatorKey);\n\n        this.reloadValue(condition).subscribe(value => {\n            this.valueCtrl.setValue(value);\n            this.renderedValue.next(this.getRenderedValue());\n        });\n    }\n\n    protected getRenderedValue(): string {\n        const operator = this.operators.find(v => v.key === this.operatorCtrl.value);\n        if (!operator || !this.isValid()) {\n            return '';\n        }\n\n        const selection = this.renderValueWithoutOperator();\n\n        return [operator.label, selection].filter(v => v).join(' ');\n    }\n\n    protected conditionToOperatorKey(condition: FilterGroupConditionField): PossibleDiscreteOperatorKeys {\n        if (condition.have && !condition.have.not) {\n            return 'is';\n        } else if (condition.have?.not) {\n            return 'isnot';\n        } else if (condition.empty?.not) {\n            return 'any';\n        } else if (condition.empty && !condition.empty.not) {\n            return 'none';\n        }\n\n        return 'is';\n    }\n\n    protected operatorKeyToCondition(key: PossibleDiscreteOperatorKeys, values: string[]): FilterGroupConditionField {\n        switch (key) {\n            case 'is':\n                return {have: {values: values}};\n            case 'isnot':\n                return {have: {values: values, not: true}};\n            case 'any':\n                return {empty: {not: true}};\n            case 'none':\n                return {empty: {not: false}};\n            default:\n                throw new Error('Unsupported operator key: ' + (key as string));\n        }\n    }\n}\n"]}
|
|
@@ -11,4 +11,4 @@ export { TypeTextComponent, InvalidWithValueStateMatcher } from './type-text/typ
|
|
|
11
11
|
export { TypeBooleanComponent } from './type-boolean/type-boolean.component';
|
|
12
12
|
export { TypeOptionsComponent } from './type-options/type-options.component';
|
|
13
13
|
export { possibleComparableOperators } from './types';
|
|
14
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9tb2R1bGVzL2Ryb3Bkb3duLWNvbXBvbmVudHMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUNILE9BQU8sRUFBMEMsbUJBQW1CLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQztBQUVqSCxPQUFPLEVBRUgsMEJBQTBCLEdBQzdCLE1BQU0scURBQXFELENBQUM7QUFFN0QsT0FBTyxFQUEwQixtQkFBbUIsRUFBQyxNQUFNLHFDQUFxQyxDQUFDO0FBRWpHLE9BQU8sRUFFSCwrQkFBK0IsR0FDbEMsTUFBTSwrREFBK0QsQ0FBQztBQUV2RSxPQUFPLEVBQXdCLGlCQUFpQixFQUFDLE1BQU0saUNBQWlDLENBQUM7QUFFekYsT0FBTyxFQUE2QixzQkFBc0IsRUFBQyxNQUFNLDZDQUE2QyxDQUFDO0FBRS9HLE9BQU8sRUFBQyxpQkFBaUIsRUFBRSw0QkFBNEIsRUFBQyxNQUFNLGlDQUFpQyxDQUFDO0FBRWhHLE9BQU8sRUFBMkIsb0JBQW9CLEVBQUMsTUFBTSx1Q0FBdUMsQ0FBQztBQUNyRyxPQUFPLEVBQXVDLG9CQUFvQixFQUFDLE1BQU0sdUNBQXVDLENBQUM7QUFDakgsT0FBTyxFQUFDLDJCQUEyQixFQUFnQyxNQUFNLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgbmF0dXJhbC1zZWFyY2ggZHJvcGRvd24gY29tcG9uZW50c1xuICovXG5leHBvcnQge1R5cGVTZWxlY3RDb25maWd1cmF0aW9uLCBUeXBlU2VsZWN0SXRlbSwgVHlwZVNlbGVjdENvbXBvbmVudH0gZnJvbSAnLi90eXBlLXNlbGVjdC90eXBlLXNlbGVjdC5jb21wb25lbnQnO1xuXG5leHBvcnQge1xuICAgIFR5cGVTZWxlY3ROYXR1cmFsQ29uZmlndXJhdGlvbixcbiAgICBUeXBlTmF0dXJhbFNlbGVjdENvbXBvbmVudCxcbn0gZnJvbSAnLi90eXBlLW5hdHVyYWwtc2VsZWN0L3R5cGUtbmF0dXJhbC1zZWxlY3QuY29tcG9uZW50JztcblxuZXhwb3J0IHtUeXBlTnVtYmVyQ29uZmlndXJhdGlvbiwgVHlwZU51bWJlckNvbXBvbmVudH0gZnJvbSAnLi90eXBlLW51bWJlci90eXBlLW51bWJlci5jb21wb25lbnQnO1xuXG5leHBvcnQge1xuICAgIFR5cGVIaWVyYXJjaGljU2VsZWN0b3JDb25maWd1cmF0aW9uLFxuICAgIFR5cGVIaWVyYXJjaGljU2VsZWN0b3JDb21wb25lbnQsXG59IGZyb20gJy4vdHlwZS1oaWVyYXJjaGljLXNlbGVjdG9yL3R5cGUtaGllcmFyY2hpYy1zZWxlY3Rvci5jb21wb25lbnQnO1xuXG5leHBvcnQge1R5cGVEYXRlQ29uZmlndXJhdGlvbiwgVHlwZURhdGVDb21wb25lbnR9IGZyb20gJy4vdHlwZS1kYXRlL3R5cGUtZGF0ZS5jb21wb25lbnQnO1xuXG5leHBvcnQge1R5cGVEYXRlUmFuZ2VDb25maWd1cmF0aW9uLCBUeXBlRGF0ZVJhbmdlQ29tcG9uZW50fSBmcm9tICcuL3R5cGUtZGF0ZS1yYW5nZS90eXBlLWRhdGUtcmFuZ2UuY29tcG9uZW50JztcblxuZXhwb3J0IHtUeXBlVGV4dENvbXBvbmVudCwgSW52YWxpZFdpdGhWYWx1ZVN0YXRlTWF0Y2hlcn0gZnJvbSAnLi90eXBlLXRleHQvdHlwZS10ZXh0LmNvbXBvbmVudCc7XG5cbmV4cG9ydCB7VHlwZUJvb2xlYW5Db25maWd1cmF0aW9uLCBUeXBlQm9vbGVhbkNvbXBvbmVudH0gZnJvbSAnLi90eXBlLWJvb2xlYW4vdHlwZS1ib29sZWFuLmNvbXBvbmVudCc7XG5leHBvcnQge1R5cGVPcHRpb25zQ29uZmlndXJhdGlvbiwgVHlwZU9wdGlvbiwgVHlwZU9wdGlvbnNDb21wb25lbnR9IGZyb20gJy4vdHlwZS1vcHRpb25zL3R5cGUtb3B0aW9ucy5jb21wb25lbnQnO1xuZXhwb3J0IHtwb3NzaWJsZUNvbXBhcmFibGVPcGVyYXRvcnMsIFBvc3NpYmxlQ29tcGFyYWJsZU9wZXJ0b3JLZXlzfSBmcm9tICcuL3R5cGVzJztcbiJdfQ==
|
|
@@ -29,10 +29,10 @@ export class TypeBooleanComponent extends TypeOptionsComponent {
|
|
|
29
29
|
};
|
|
30
30
|
super(typeOptionsData, dropdownRef);
|
|
31
31
|
}
|
|
32
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
33
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "
|
|
32
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: TypeBooleanComponent, deps: [{ token: NATURAL_DROPDOWN_DATA }, { token: i1.NaturalDropdownRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
33
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.0", type: TypeBooleanComponent, isStandalone: true, selector: "ng-component", usesInheritance: true, ngImport: i0, template: "<mat-button-toggle-group [formControl]=\"formControl\">\n @for (option of configuration.options; track option) {\n <mat-button-toggle [value]=\"option\">{{ option.display }}</mat-button-toggle>\n }\n</mat-button-toggle-group>\n", dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: MatButtonToggleModule }, { kind: "directive", type: i3.MatButtonToggleGroup, selector: "mat-button-toggle-group", inputs: ["appearance", "name", "vertical", "value", "multiple", "disabled", "hideSingleSelectionIndicator", "hideMultipleSelectionIndicator"], outputs: ["valueChange", "change"], exportAs: ["matButtonToggleGroup"] }, { kind: "component", type: i3.MatButtonToggle, selector: "mat-button-toggle", inputs: ["aria-label", "aria-labelledby", "id", "name", "value", "tabIndex", "disableRipple", "appearance", "checked", "disabled"], outputs: ["change"], exportAs: ["matButtonToggle"] }] }); }
|
|
34
34
|
}
|
|
35
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
35
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: TypeBooleanComponent, decorators: [{
|
|
36
36
|
type: Component,
|
|
37
37
|
args: [{ standalone: true, imports: [FormsModule, ReactiveFormsModule, CommonModule, MatButtonToggleModule], template: "<mat-button-toggle-group [formControl]=\"formControl\">\n @for (option of configuration.options; track option) {\n <mat-button-toggle [value]=\"option\">{{ option.display }}</mat-button-toggle>\n }\n</mat-button-toggle-group>\n" }]
|
|
38
38
|
}], ctorParameters: () => [{ type: undefined, decorators: [{
|
|
@@ -152,10 +152,10 @@ export class TypeDateComponent {
|
|
|
152
152
|
return '';
|
|
153
153
|
}
|
|
154
154
|
}
|
|
155
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
156
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "
|
|
155
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: TypeDateComponent, deps: [{ token: NATURAL_DROPDOWN_DATA }, { token: i1.DateAdapter }, { token: MAT_DATE_FORMATS }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
156
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.0", type: TypeDateComponent, isStandalone: true, selector: "ng-component", ngImport: i0, template: "<form [formGroup]=\"form\">\n <mat-form-field>\n <mat-label i18n=\"Mathematical operator < > =\">Op\u00E9rateur</mat-label>\n <mat-select [formControl]=\"operatorCtrl\" [required]=\"true\" panelWidth=\"\">\n @for (item of operators; track item) {\n <mat-option [value]=\"item.key\">\n {{ item.label }}\n </mat-option>\n }\n </mat-select>\n </mat-form-field>\n\n <mat-form-field>\n <mat-label i18n>Date</mat-label>\n <input\n [formControl]=\"valueCtrl\"\n [matDatepicker]=\"value\"\n [max]=\"configuration.max\"\n [min]=\"configuration.min\"\n [required]=\"true\"\n matInput\n />\n <mat-datepicker-toggle [for]=\"value\" matIconSuffix />\n <mat-datepicker #value />\n @if (valueCtrl.hasError('min')) {\n <mat-error>< {{ configuration.min }}</mat-error>\n }\n @if (valueCtrl.hasError('max')) {\n <mat-error>> {{ configuration.max }}</mat-error>\n }\n @if (valueCtrl.hasError('required')) {\n <mat-error>*</mat-error>\n }\n </mat-form-field>\n\n <mat-checkbox [formControl]=\"todayCtrl\" i18n>Aujourd'hui</mat-checkbox>\n</form>\n", styles: ["form{display:grid;grid:auto auto/4em auto;grid-gap:0 1em}form>mat-checkbox{grid-column-start:2;margin-bottom:.3em}\n"], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatLabel, selector: "mat-label" }, { kind: "directive", type: i3.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i3.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: MatSelectModule }, { kind: "component", type: i4.MatSelect, selector: "mat-select", inputs: ["aria-describedby", "panelClass", "disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator", "placeholder", "required", "multiple", "disableOptionCentering", "compareWith", "value", "aria-label", "aria-labelledby", "errorStateMatcher", "typeaheadDebounceInterval", "sortComparator", "id", "panelWidth"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["matSelect"] }, { kind: "component", type: i1.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "ngmodule", type: MatOptionModule }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i5.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "ngmodule", type: MatDatepickerModule }, { kind: "component", type: i6.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i6.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i6.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "ngmodule", type: MatCheckboxModule }, { kind: "component", type: i7.MatCheckbox, selector: "mat-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "disableRipple", "tabIndex", "color", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }] }); }
|
|
157
157
|
}
|
|
158
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
158
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: TypeDateComponent, decorators: [{
|
|
159
159
|
type: Component,
|
|
160
160
|
args: [{ standalone: true, imports: [
|
|
161
161
|
FormsModule,
|
package/esm2022/lib/modules/dropdown-components/type-date-range/type-date-range.component.mjs
CHANGED
|
@@ -15,7 +15,7 @@ import * as i4 from "@angular/material/input";
|
|
|
15
15
|
import * as i5 from "@angular/material/datepicker";
|
|
16
16
|
class InvalidWithValueStateMatcher {
|
|
17
17
|
isErrorState(control, form) {
|
|
18
|
-
return (form && form.invalid && (form.value.to || form.value.from)) ||
|
|
18
|
+
return (form && form.invalid && (form.value.to || form.value.from)) || control?.invalid;
|
|
19
19
|
}
|
|
20
20
|
}
|
|
21
21
|
function parseFromControl(control, key) {
|
|
@@ -123,10 +123,10 @@ export class TypeDateRangeComponent {
|
|
|
123
123
|
return '';
|
|
124
124
|
}
|
|
125
125
|
}
|
|
126
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
127
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "
|
|
126
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: TypeDateRangeComponent, deps: [{ token: NATURAL_DROPDOWN_DATA }, { token: i1.DateAdapter }, { token: MAT_DATE_FORMATS }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
127
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.0", type: TypeDateRangeComponent, isStandalone: true, selector: "ng-component", ngImport: i0, template: "<form [formGroup]=\"form\">\n <mat-form-field>\n <input\n matInput\n [matDatepicker]=\"from\"\n placeholder=\"De\"\n i18n-placeholder\n [formControl]=\"fromCtrl\"\n [errorStateMatcher]=\"matcher\"\n [min]=\"configuration.min\"\n [max]=\"configuration.max\"\n />\n <mat-datepicker-toggle matIconSuffix [for]=\"from\" />\n <mat-datepicker #from />\n @if (form.hasError('toGreaterThanFrom')) {\n <mat-error>{{ render(fromCtrl.value) }} > {{ render(toCtrl.value) }}</mat-error>\n }\n @if (fromCtrl.hasError('min') && !form.hasError('toGreaterThanFrom')) {\n <mat-error>< {{ configuration.min }}</mat-error>\n }\n @if (fromCtrl.hasError('max') && !form.hasError('toGreaterThanFrom')) {\n <mat-error>> {{ configuration.max }}</mat-error>\n }\n @if (fromCtrl.hasError('required')) {\n <mat-error>*</mat-error>\n }\n </mat-form-field>\n\n <mat-form-field>\n <input\n matInput\n [matDatepicker]=\"to\"\n placeholder=\"\u00E0\"\n i18n-placeholder\n [formControl]=\"toCtrl\"\n [errorStateMatcher]=\"matcher\"\n [min]=\"configuration.min\"\n [max]=\"configuration.max\"\n />\n <mat-datepicker-toggle matIconSuffix [for]=\"to\" />\n <mat-datepicker #to />\n @if (toCtrl.hasError('min') && !form.hasError('toGreaterThanFrom')) {\n <mat-error> < {{ configuration.min }}</mat-error>\n }\n @if (toCtrl.hasError('max') && !form.hasError('toGreaterThanFrom')) {\n <mat-error> > {{ configuration.max }}</mat-error>\n }\n @if (toCtrl.hasError('required')) {\n <mat-error>*</mat-error>\n }\n </mat-form-field>\n</form>\n", dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i3.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i4.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "ngmodule", type: MatDatepickerModule }, { kind: "component", type: i5.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i5.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i5.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }] }); }
|
|
128
128
|
}
|
|
129
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
129
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: TypeDateRangeComponent, decorators: [{
|
|
130
130
|
type: Component,
|
|
131
131
|
args: [{ standalone: true, imports: [FormsModule, ReactiveFormsModule, MatFormFieldModule, MatInputModule, MatDatepickerModule], template: "<form [formGroup]=\"form\">\n <mat-form-field>\n <input\n matInput\n [matDatepicker]=\"from\"\n placeholder=\"De\"\n i18n-placeholder\n [formControl]=\"fromCtrl\"\n [errorStateMatcher]=\"matcher\"\n [min]=\"configuration.min\"\n [max]=\"configuration.max\"\n />\n <mat-datepicker-toggle matIconSuffix [for]=\"from\" />\n <mat-datepicker #from />\n @if (form.hasError('toGreaterThanFrom')) {\n <mat-error>{{ render(fromCtrl.value) }} > {{ render(toCtrl.value) }}</mat-error>\n }\n @if (fromCtrl.hasError('min') && !form.hasError('toGreaterThanFrom')) {\n <mat-error>< {{ configuration.min }}</mat-error>\n }\n @if (fromCtrl.hasError('max') && !form.hasError('toGreaterThanFrom')) {\n <mat-error>> {{ configuration.max }}</mat-error>\n }\n @if (fromCtrl.hasError('required')) {\n <mat-error>*</mat-error>\n }\n </mat-form-field>\n\n <mat-form-field>\n <input\n matInput\n [matDatepicker]=\"to\"\n placeholder=\"\u00E0\"\n i18n-placeholder\n [formControl]=\"toCtrl\"\n [errorStateMatcher]=\"matcher\"\n [min]=\"configuration.min\"\n [max]=\"configuration.max\"\n />\n <mat-datepicker-toggle matIconSuffix [for]=\"to\" />\n <mat-datepicker #to />\n @if (toCtrl.hasError('min') && !form.hasError('toGreaterThanFrom')) {\n <mat-error> < {{ configuration.min }}</mat-error>\n }\n @if (toCtrl.hasError('max') && !form.hasError('toGreaterThanFrom')) {\n <mat-error> > {{ configuration.max }}</mat-error>\n }\n @if (toCtrl.hasError('required')) {\n <mat-error>*</mat-error>\n }\n </mat-form-field>\n</form>\n" }]
|
|
132
132
|
}], ctorParameters: () => [{ type: undefined, decorators: [{
|
|
@@ -136,4 +136,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
|
|
|
136
136
|
type: Inject,
|
|
137
137
|
args: [MAT_DATE_FORMATS]
|
|
138
138
|
}] }] });
|
|
139
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"type-date-range.component.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/dropdown-components/type-date-range/type-date-range.component.ts","../../../../../../../projects/natural/src/lib/modules/dropdown-components/type-date-range/type-date-range.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, Inject} from '@angular/core';\nimport {\n    AbstractControl,\n    FormControl,\n    FormGroup,\n    FormGroupDirective,\n    NgForm,\n    ValidationErrors,\n    ValidatorFn,\n    Validators,\n    FormsModule,\n    ReactiveFormsModule,\n} from '@angular/forms';\nimport {DateAdapter, ErrorStateMatcher, MAT_DATE_FORMATS, MatDateFormats} from '@angular/material/core';\nimport {BehaviorSubject, merge} from 'rxjs';\nimport {DropdownComponent} from '../../search/types/dropdown-component';\nimport {NATURAL_DROPDOWN_DATA, NaturalDropdownData} from '../../search/dropdown-container/dropdown.service';\nimport {FilterGroupConditionField} from '../../search/classes/graphql-doctrine.types';\nimport {dateMax, dateMin, serialize} from '../utils';\nimport {MatDatepickerModule} from '@angular/material/datepicker';\nimport {MatInputModule} from '@angular/material/input';\nimport {MatFormFieldModule} from '@angular/material/form-field';\n\nexport type TypeDateRangeConfiguration<D = any> = {\n    min?: D | null;\n    max?: D | null;\n};\n\nclass InvalidWithValueStateMatcher implements ErrorStateMatcher {\n    public isErrorState(control: FormControl<unknown> | null, form: FormGroupDirective | NgForm | null): boolean {\n        return (form && form.invalid && (form.value.to || form.value.from)) || (control && control.invalid);\n    }\n}\n\nfunction parseFromControl<D>(control: AbstractControl, key: string): D | null {\n    const c = control.get(key);\n    if (!c) {\n        return null;\n    }\n\n    return c.value;\n}\n\n/**\n * From >= To\n */\nfunction toGreaterThanFrom<D>(dateAdapter: DateAdapter<D>): ValidatorFn {\n    return (control: AbstractControl): ValidationErrors | null => {\n        const from = parseFromControl<D>(control, 'from');\n        const to = parseFromControl<D>(control, 'to');\n\n        if (from && to && dateAdapter.compareDate(from, to) > 0) {\n            return {toGreaterThanFrom: true};\n        }\n\n        return null;\n    };\n}\n\n/**\n * Date range with mandatory bounding dates.\n *\n * If you need optional bounding date, then use `TypeDateComponent` instead.\n */\n@Component({\n    templateUrl: './type-date-range.component.html',\n    standalone: true,\n    imports: [FormsModule, ReactiveFormsModule, MatFormFieldModule, MatInputModule, MatDatepickerModule],\n})\nexport class TypeDateRangeComponent<D = any> implements DropdownComponent {\n    public readonly renderedValue = new BehaviorSubject<string>('');\n    public readonly configuration: Required<TypeDateRangeConfiguration<D>>;\n    public readonly matcher = new InvalidWithValueStateMatcher();\n    public readonly fromCtrl = new FormControl<D | null>(null);\n    public readonly toCtrl = new FormControl<D | null>(null);\n    public readonly form = new FormGroup({\n        from: this.fromCtrl,\n        to: this.toCtrl,\n    });\n\n    private readonly defaults: Required<TypeDateRangeConfiguration<D>> = {\n        min: null,\n        max: null,\n    };\n\n    public constructor(\n        @Inject(NATURAL_DROPDOWN_DATA) data: NaturalDropdownData<TypeDateRangeConfiguration<D>>,\n        private dateAdapter: DateAdapter<D>,\n        @Inject(MAT_DATE_FORMATS) private dateFormats: MatDateFormats,\n    ) {\n        this.configuration = {...this.defaults, ...data.configuration};\n\n        merge(this.fromCtrl.valueChanges, this.toCtrl.valueChanges).subscribe(() => {\n            this.renderedValue.next(this.getRenderedValue());\n        });\n\n        this.initValidators();\n        this.reloadCondition(data.condition);\n    }\n\n    public getCondition(): FilterGroupConditionField {\n        const from = serialize<D>(this.dateAdapter, this.fromCtrl.value);\n        const to = serialize<D>(this.dateAdapter, this.toCtrl.value);\n\n        if (from && to) {\n            return {between: {from, to}};\n        } else {\n            return {};\n        }\n    }\n\n    public isValid(): boolean {\n        return this.form.valid;\n    }\n\n    public isDirty(): boolean {\n        return this.form.dirty;\n    }\n\n    private reloadCondition(condition: FilterGroupConditionField | null): void {\n        if (!condition) {\n            return;\n        }\n\n        const value = {\n            from: null as D | null,\n            to: null as D | null,\n        };\n\n        if (condition.between) {\n            value.from = this.dateAdapter.parse(condition.between.from, null);\n            value.to = this.dateAdapter.parse(condition.between.to, null);\n        }\n\n        this.form.setValue(value);\n    }\n\n    private initValidators(): void {\n        const validators: ValidatorFn[] = [Validators.required];\n        if (this.configuration.min) {\n            validators.push(dateMin<D>(this.dateAdapter, this.configuration.min));\n        }\n\n        if (this.configuration.max) {\n            validators.push(dateMax<D>(this.dateAdapter, this.configuration.max));\n        }\n\n        this.fromCtrl.setValidators(validators);\n        this.toCtrl.setValidators(validators);\n\n        this.form.setValidators([\n            toGreaterThanFrom<D>(this.dateAdapter), // From < To\n        ]);\n    }\n\n    public render(value: D | null): string {\n        return value ? this.dateAdapter.format(value, this.dateFormats.display.dateInput) : '';\n    }\n\n    private getRenderedValue(): string {\n        const from = this.render(this.fromCtrl.value);\n        const to = this.render(this.toCtrl.value);\n\n        if (from && to) {\n            return from + ' - ' + to;\n        } else {\n            return '';\n        }\n    }\n}\n","<form [formGroup]=\"form\">\n    <mat-form-field>\n        <input\n            matInput\n            [matDatepicker]=\"from\"\n            placeholder=\"De\"\n            i18n-placeholder\n            [formControl]=\"fromCtrl\"\n            [errorStateMatcher]=\"matcher\"\n            [min]=\"configuration.min\"\n            [max]=\"configuration.max\"\n        />\n        <mat-datepicker-toggle matIconSuffix [for]=\"from\" />\n        <mat-datepicker #from />\n        @if (form.hasError('toGreaterThanFrom')) {\n            <mat-error>{{ render(fromCtrl.value) }} > {{ render(toCtrl.value) }}</mat-error>\n        }\n        @if (fromCtrl.hasError('min') && !form.hasError('toGreaterThanFrom')) {\n            <mat-error>< {{ configuration.min }}</mat-error>\n        }\n        @if (fromCtrl.hasError('max') && !form.hasError('toGreaterThanFrom')) {\n            <mat-error>> {{ configuration.max }}</mat-error>\n        }\n        @if (fromCtrl.hasError('required')) {\n            <mat-error>*</mat-error>\n        }\n    </mat-form-field>\n\n    <mat-form-field>\n        <input\n            matInput\n            [matDatepicker]=\"to\"\n            placeholder=\"à\"\n            i18n-placeholder\n            [formControl]=\"toCtrl\"\n            [errorStateMatcher]=\"matcher\"\n            [min]=\"configuration.min\"\n            [max]=\"configuration.max\"\n        />\n        <mat-datepicker-toggle matIconSuffix [for]=\"to\" />\n        <mat-datepicker #to />\n        @if (toCtrl.hasError('min') && !form.hasError('toGreaterThanFrom')) {\n            <mat-error> < {{ configuration.min }}</mat-error>\n        }\n        @if (toCtrl.hasError('max') && !form.hasError('toGreaterThanFrom')) {\n            <mat-error> > {{ configuration.max }}</mat-error>\n        }\n        @if (toCtrl.hasError('required')) {\n            <mat-error>*</mat-error>\n        }\n    </mat-form-field>\n</form>\n"]}
|
|
139
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"type-date-range.component.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/dropdown-components/type-date-range/type-date-range.component.ts","../../../../../../../projects/natural/src/lib/modules/dropdown-components/type-date-range/type-date-range.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, Inject} from '@angular/core';\nimport {\n    AbstractControl,\n    FormControl,\n    FormGroup,\n    FormGroupDirective,\n    NgForm,\n    ValidationErrors,\n    ValidatorFn,\n    Validators,\n    FormsModule,\n    ReactiveFormsModule,\n} from '@angular/forms';\nimport {DateAdapter, ErrorStateMatcher, MAT_DATE_FORMATS, MatDateFormats} from '@angular/material/core';\nimport {BehaviorSubject, merge} from 'rxjs';\nimport {DropdownComponent} from '../../search/types/dropdown-component';\nimport {NATURAL_DROPDOWN_DATA, NaturalDropdownData} from '../../search/dropdown-container/dropdown.service';\nimport {FilterGroupConditionField} from '../../search/classes/graphql-doctrine.types';\nimport {dateMax, dateMin, serialize} from '../utils';\nimport {MatDatepickerModule} from '@angular/material/datepicker';\nimport {MatInputModule} from '@angular/material/input';\nimport {MatFormFieldModule} from '@angular/material/form-field';\n\nexport type TypeDateRangeConfiguration<D = any> = {\n    min?: D | null;\n    max?: D | null;\n};\n\nclass InvalidWithValueStateMatcher implements ErrorStateMatcher {\n    public isErrorState(control: FormControl<unknown> | null, form: FormGroupDirective | NgForm | null): boolean {\n        return (form && form.invalid && (form.value.to || form.value.from)) || control?.invalid;\n    }\n}\n\nfunction parseFromControl<D>(control: AbstractControl, key: string): D | null {\n    const c = control.get(key);\n    if (!c) {\n        return null;\n    }\n\n    return c.value;\n}\n\n/**\n * From >= To\n */\nfunction toGreaterThanFrom<D>(dateAdapter: DateAdapter<D>): ValidatorFn {\n    return (control: AbstractControl): ValidationErrors | null => {\n        const from = parseFromControl<D>(control, 'from');\n        const to = parseFromControl<D>(control, 'to');\n\n        if (from && to && dateAdapter.compareDate(from, to) > 0) {\n            return {toGreaterThanFrom: true};\n        }\n\n        return null;\n    };\n}\n\n/**\n * Date range with mandatory bounding dates.\n *\n * If you need optional bounding date, then use `TypeDateComponent` instead.\n */\n@Component({\n    templateUrl: './type-date-range.component.html',\n    standalone: true,\n    imports: [FormsModule, ReactiveFormsModule, MatFormFieldModule, MatInputModule, MatDatepickerModule],\n})\nexport class TypeDateRangeComponent<D = any> implements DropdownComponent {\n    public readonly renderedValue = new BehaviorSubject<string>('');\n    public readonly configuration: Required<TypeDateRangeConfiguration<D>>;\n    public readonly matcher = new InvalidWithValueStateMatcher();\n    public readonly fromCtrl = new FormControl<D | null>(null);\n    public readonly toCtrl = new FormControl<D | null>(null);\n    public readonly form = new FormGroup({\n        from: this.fromCtrl,\n        to: this.toCtrl,\n    });\n\n    private readonly defaults: Required<TypeDateRangeConfiguration<D>> = {\n        min: null,\n        max: null,\n    };\n\n    public constructor(\n        @Inject(NATURAL_DROPDOWN_DATA) data: NaturalDropdownData<TypeDateRangeConfiguration<D>>,\n        private dateAdapter: DateAdapter<D>,\n        @Inject(MAT_DATE_FORMATS) private dateFormats: MatDateFormats,\n    ) {\n        this.configuration = {...this.defaults, ...data.configuration};\n\n        merge(this.fromCtrl.valueChanges, this.toCtrl.valueChanges).subscribe(() => {\n            this.renderedValue.next(this.getRenderedValue());\n        });\n\n        this.initValidators();\n        this.reloadCondition(data.condition);\n    }\n\n    public getCondition(): FilterGroupConditionField {\n        const from = serialize<D>(this.dateAdapter, this.fromCtrl.value);\n        const to = serialize<D>(this.dateAdapter, this.toCtrl.value);\n\n        if (from && to) {\n            return {between: {from, to}};\n        } else {\n            return {};\n        }\n    }\n\n    public isValid(): boolean {\n        return this.form.valid;\n    }\n\n    public isDirty(): boolean {\n        return this.form.dirty;\n    }\n\n    private reloadCondition(condition: FilterGroupConditionField | null): void {\n        if (!condition) {\n            return;\n        }\n\n        const value = {\n            from: null as D | null,\n            to: null as D | null,\n        };\n\n        if (condition.between) {\n            value.from = this.dateAdapter.parse(condition.between.from, null);\n            value.to = this.dateAdapter.parse(condition.between.to, null);\n        }\n\n        this.form.setValue(value);\n    }\n\n    private initValidators(): void {\n        const validators: ValidatorFn[] = [Validators.required];\n        if (this.configuration.min) {\n            validators.push(dateMin<D>(this.dateAdapter, this.configuration.min));\n        }\n\n        if (this.configuration.max) {\n            validators.push(dateMax<D>(this.dateAdapter, this.configuration.max));\n        }\n\n        this.fromCtrl.setValidators(validators);\n        this.toCtrl.setValidators(validators);\n\n        this.form.setValidators([\n            toGreaterThanFrom<D>(this.dateAdapter), // From < To\n        ]);\n    }\n\n    public render(value: D | null): string {\n        return value ? this.dateAdapter.format(value, this.dateFormats.display.dateInput) : '';\n    }\n\n    private getRenderedValue(): string {\n        const from = this.render(this.fromCtrl.value);\n        const to = this.render(this.toCtrl.value);\n\n        if (from && to) {\n            return from + ' - ' + to;\n        } else {\n            return '';\n        }\n    }\n}\n","<form [formGroup]=\"form\">\n    <mat-form-field>\n        <input\n            matInput\n            [matDatepicker]=\"from\"\n            placeholder=\"De\"\n            i18n-placeholder\n            [formControl]=\"fromCtrl\"\n            [errorStateMatcher]=\"matcher\"\n            [min]=\"configuration.min\"\n            [max]=\"configuration.max\"\n        />\n        <mat-datepicker-toggle matIconSuffix [for]=\"from\" />\n        <mat-datepicker #from />\n        @if (form.hasError('toGreaterThanFrom')) {\n            <mat-error>{{ render(fromCtrl.value) }} > {{ render(toCtrl.value) }}</mat-error>\n        }\n        @if (fromCtrl.hasError('min') && !form.hasError('toGreaterThanFrom')) {\n            <mat-error>< {{ configuration.min }}</mat-error>\n        }\n        @if (fromCtrl.hasError('max') && !form.hasError('toGreaterThanFrom')) {\n            <mat-error>> {{ configuration.max }}</mat-error>\n        }\n        @if (fromCtrl.hasError('required')) {\n            <mat-error>*</mat-error>\n        }\n    </mat-form-field>\n\n    <mat-form-field>\n        <input\n            matInput\n            [matDatepicker]=\"to\"\n            placeholder=\"à\"\n            i18n-placeholder\n            [formControl]=\"toCtrl\"\n            [errorStateMatcher]=\"matcher\"\n            [min]=\"configuration.min\"\n            [max]=\"configuration.max\"\n        />\n        <mat-datepicker-toggle matIconSuffix [for]=\"to\" />\n        <mat-datepicker #to />\n        @if (toCtrl.hasError('min') && !form.hasError('toGreaterThanFrom')) {\n            <mat-error> < {{ configuration.min }}</mat-error>\n        }\n        @if (toCtrl.hasError('max') && !form.hasError('toGreaterThanFrom')) {\n            <mat-error> > {{ configuration.max }}</mat-error>\n        }\n        @if (toCtrl.hasError('required')) {\n            <mat-error>*</mat-error>\n        }\n    </mat-form-field>\n</form>\n"]}
|
|
@@ -63,10 +63,10 @@ export class TypeHierarchicSelectorComponent extends AbstractAssociationSelectCo
|
|
|
63
63
|
noEmptySelection(selection) {
|
|
64
64
|
return selection[this.configuration.key].length ? selection : null;
|
|
65
65
|
}
|
|
66
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
67
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "
|
|
66
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: TypeHierarchicSelectorComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
67
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.0", type: TypeHierarchicSelectorComponent, isStandalone: true, selector: "ng-component", usesInheritance: true, ngImport: i0, template: "<form [formGroup]=\"form\">\n <mat-form-field style=\"max-width: 7em; margin-right: 1em\">\n <mat-label i18n=\"Mathematical operator < > =\">Op\u00E9rateur</mat-label>\n <mat-select [formControl]=\"operatorCtrl\" [required]=\"true\" panelWidth=\"\">\n @for (item of operators; track item) {\n <mat-option [value]=\"item.key\">\n {{ item.label }}\n </mat-option>\n }\n </mat-select>\n </mat-form-field>\n\n @if (requireValueCtrl) {\n <natural-hierarchic-selector\n (selectionChange)=\"selectionChange($event)\"\n [config]=\"configuration.config\"\n [filters]=\"configuration.filters\"\n [multiple]=\"true\"\n [selected]=\"valueCtrl.value || {}\"\n style=\"margin-right: 20px\"\n />\n }\n</form>\n", dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i2.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i2.MatLabel, selector: "mat-label" }, { kind: "ngmodule", type: MatSelectModule }, { kind: "component", type: i3.MatSelect, selector: "mat-select", inputs: ["aria-describedby", "panelClass", "disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator", "placeholder", "required", "multiple", "disableOptionCentering", "compareWith", "value", "aria-label", "aria-labelledby", "errorStateMatcher", "typeaheadDebounceInterval", "sortComparator", "id", "panelWidth"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["matSelect"] }, { kind: "component", type: i4.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "ngmodule", type: MatOptionModule }, { kind: "component", type: NaturalHierarchicSelectorComponent, selector: "natural-hierarchic-selector", inputs: ["displayWith", "config", "multiple", "selected", "allowUnselect", "filters", "searchFacets", "searchSelections"], outputs: ["searchSelectionChange", "selectionChange"] }] }); }
|
|
68
68
|
}
|
|
69
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
69
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: TypeHierarchicSelectorComponent, decorators: [{
|
|
70
70
|
type: Component,
|
|
71
71
|
args: [{ standalone: true, imports: [
|
|
72
72
|
FormsModule,
|
|
@@ -31,10 +31,10 @@ export class TypeNaturalSelectComponent extends AbstractAssociationSelectCompone
|
|
|
31
31
|
const selectedName = selected?.fullName || selected?.name || '';
|
|
32
32
|
return selectedName;
|
|
33
33
|
}
|
|
34
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
35
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "
|
|
34
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: TypeNaturalSelectComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
35
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.0", type: TypeNaturalSelectComponent, isStandalone: true, selector: "ng-component", usesInheritance: true, ngImport: i0, template: "<form [formGroup]=\"form\">\n <mat-form-field style=\"max-width: 7em; margin-right: 1em\">\n <mat-label i18n=\"Mathematical operator < > =\">Op\u00E9rateur</mat-label>\n <mat-select [formControl]=\"operatorCtrl\" [required]=\"true\" panelWidth=\"\">\n @for (item of operators; track item) {\n <mat-option [value]=\"item.key\">\n {{ item.label }}\n </mat-option>\n }\n </mat-select>\n </mat-form-field>\n\n @if (configuration && requireValueCtrl) {\n <natural-select\n style=\"display: inline\"\n [formControl]=\"valueCtrl\"\n [placeholder]=\"configuration.placeholder\"\n [service]=\"configuration.service\"\n [filter]=\"configuration.filter\"\n />\n }\n</form>\n", dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i2.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i2.MatLabel, selector: "mat-label" }, { kind: "ngmodule", type: MatSelectModule }, { kind: "component", type: i3.MatSelect, selector: "mat-select", inputs: ["aria-describedby", "panelClass", "disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator", "placeholder", "required", "multiple", "disableOptionCentering", "compareWith", "value", "aria-label", "aria-labelledby", "errorStateMatcher", "typeaheadDebounceInterval", "sortComparator", "id", "panelWidth"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["matSelect"] }, { kind: "component", type: i4.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "ngmodule", type: MatOptionModule }, { kind: "component", type: NaturalSelectComponent, selector: "natural-select", inputs: ["service", "optionRequired", "searchField", "searchOperator", "filter", "disabled"] }] }); }
|
|
36
36
|
}
|
|
37
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
37
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: TypeNaturalSelectComponent, decorators: [{
|
|
38
38
|
type: Component,
|
|
39
39
|
args: [{ standalone: true, imports: [
|
|
40
40
|
FormsModule,
|
|
@@ -71,7 +71,7 @@ export class TypeNumberComponent {
|
|
|
71
71
|
validators.push(Validators.max(this.configuration.max));
|
|
72
72
|
}
|
|
73
73
|
if (this.configuration.step) {
|
|
74
|
-
const decimals = ('' + this.configuration.step)
|
|
74
|
+
const decimals = /\.(\d+)$/.exec('' + this.configuration.step)?.[1] ?? '';
|
|
75
75
|
const decimalCount = decimals.length;
|
|
76
76
|
validators.push(decimal(decimalCount));
|
|
77
77
|
}
|
|
@@ -98,14 +98,14 @@ export class TypeNumberComponent {
|
|
|
98
98
|
return operator.label + ' ' + this.valueCtrl.value;
|
|
99
99
|
}
|
|
100
100
|
}
|
|
101
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
102
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "
|
|
101
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: TypeNumberComponent, deps: [{ token: NATURAL_DROPDOWN_DATA }, { token: i1.NaturalDropdownRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
102
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.0", type: TypeNumberComponent, isStandalone: true, selector: "ng-component", ngImport: i0, template: "<form [formGroup]=\"form\">\n <mat-form-field style=\"max-width: 4em; margin-right: 1em\">\n <mat-label i18n=\"Mathematical operator < > =\">Op\u00E9rateur</mat-label>\n <mat-select [formControl]=\"operatorCtrl\" [required]=\"true\" panelWidth=\"\">\n @for (item of operators; track item) {\n <mat-option [value]=\"item.key\">\n {{ item.label }}\n </mat-option>\n }\n </mat-select>\n </mat-form-field>\n\n <mat-form-field>\n <mat-label i18n>Valeur</mat-label>\n <input\n (keydown.enter)=\"close()\"\n [errorStateMatcher]=\"matcher\"\n [formControl]=\"valueCtrl\"\n [attr.max]=\"configuration.max\"\n [attr.min]=\"configuration.min\"\n [required]=\"true\"\n [step]=\"configuration.step\"\n matInput\n type=\"number\"\n />\n @if (valueCtrl.hasError('min')) {\n <mat-error>< {{ configuration.min }}</mat-error>\n }\n @if (valueCtrl.hasError('max')) {\n <mat-error>> {{ configuration.max }}</mat-error>\n }\n </mat-form-field>\n</form>\n", styles: [":host input::-webkit-outer-spin-button,:host input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}\n"], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatLabel, selector: "mat-label" }, { kind: "directive", type: i3.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "ngmodule", type: MatSelectModule }, { kind: "component", type: i4.MatSelect, selector: "mat-select", inputs: ["aria-describedby", "panelClass", "disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator", "placeholder", "required", "multiple", "disableOptionCentering", "compareWith", "value", "aria-label", "aria-labelledby", "errorStateMatcher", "typeaheadDebounceInterval", "sortComparator", "id", "panelWidth"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["matSelect"] }, { kind: "component", type: i5.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "ngmodule", type: MatOptionModule }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i6.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }] }); }
|
|
103
103
|
}
|
|
104
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
104
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: TypeNumberComponent, decorators: [{
|
|
105
105
|
type: Component,
|
|
106
106
|
args: [{ standalone: true, imports: [FormsModule, ReactiveFormsModule, MatFormFieldModule, MatSelectModule, MatOptionModule, MatInputModule], template: "<form [formGroup]=\"form\">\n <mat-form-field style=\"max-width: 4em; margin-right: 1em\">\n <mat-label i18n=\"Mathematical operator < > =\">Op\u00E9rateur</mat-label>\n <mat-select [formControl]=\"operatorCtrl\" [required]=\"true\" panelWidth=\"\">\n @for (item of operators; track item) {\n <mat-option [value]=\"item.key\">\n {{ item.label }}\n </mat-option>\n }\n </mat-select>\n </mat-form-field>\n\n <mat-form-field>\n <mat-label i18n>Valeur</mat-label>\n <input\n (keydown.enter)=\"close()\"\n [errorStateMatcher]=\"matcher\"\n [formControl]=\"valueCtrl\"\n [attr.max]=\"configuration.max\"\n [attr.min]=\"configuration.min\"\n [required]=\"true\"\n [step]=\"configuration.step\"\n matInput\n type=\"number\"\n />\n @if (valueCtrl.hasError('min')) {\n <mat-error>< {{ configuration.min }}</mat-error>\n }\n @if (valueCtrl.hasError('max')) {\n <mat-error>> {{ configuration.max }}</mat-error>\n }\n </mat-form-field>\n</form>\n", styles: [":host input::-webkit-outer-spin-button,:host input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}\n"] }]
|
|
107
107
|
}], ctorParameters: () => [{ type: undefined, decorators: [{
|
|
108
108
|
type: Inject,
|
|
109
109
|
args: [NATURAL_DROPDOWN_DATA]
|
|
110
110
|
}] }, { type: i1.NaturalDropdownRef }] });
|
|
111
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"type-number.component.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/dropdown-components/type-number/type-number.component.ts","../../../../../../../projects/natural/src/lib/modules/dropdown-components/type-number/type-number.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, Inject} from '@angular/core';\nimport {FormControl, FormGroup, ValidatorFn, Validators, FormsModule, ReactiveFormsModule} from '@angular/forms';\nimport {BehaviorSubject, merge} from 'rxjs';\nimport {FilterGroupConditionField} from '../../search/classes/graphql-doctrine.types';\nimport {NaturalDropdownRef} from '../../search/dropdown-container/dropdown-ref';\nimport {NATURAL_DROPDOWN_DATA, NaturalDropdownData} from '../../search/dropdown-container/dropdown.service';\nimport {DropdownComponent} from '../../search/types/dropdown-component';\nimport {possibleComparableOperators, PossibleComparableOpertorKeys} from '../types';\nimport {InvalidWithValueStateMatcher} from '../type-text/type-text.component';\nimport {decimal} from '../../../classes/validators';\nimport {MatInputModule} from '@angular/material/input';\nimport {MatOptionModule} from '@angular/material/core';\nimport {MatSelectModule} from '@angular/material/select';\nimport {MatFormFieldModule} from '@angular/material/form-field';\n\nexport type TypeNumberConfiguration = {\n    min?: number | null;\n    max?: number | null;\n    step?: number | null;\n};\n\n@Component({\n    templateUrl: './type-number.component.html',\n    styleUrl: './type-number.component.scss',\n    standalone: true,\n    imports: [FormsModule, ReactiveFormsModule, MatFormFieldModule, MatSelectModule, MatOptionModule, MatInputModule],\n})\nexport class TypeNumberComponent implements DropdownComponent {\n    public readonly renderedValue = new BehaviorSubject<string>('');\n    public readonly configuration: Required<TypeNumberConfiguration>;\n    public readonly operatorCtrl = new FormControl<PossibleComparableOpertorKeys>('equal', {nonNullable: true});\n    public readonly valueCtrl = new FormControl();\n    public readonly matcher = new InvalidWithValueStateMatcher();\n    public readonly form = new FormGroup({\n        operator: this.operatorCtrl,\n        value: this.valueCtrl,\n    });\n    public readonly operators = possibleComparableOperators;\n\n    private readonly defaults: Required<TypeNumberConfiguration> = {\n        min: null,\n        max: null,\n        step: null,\n    };\n\n    public constructor(\n        @Inject(NATURAL_DROPDOWN_DATA) data: NaturalDropdownData<TypeNumberConfiguration>,\n        protected dropdownRef: NaturalDropdownRef,\n    ) {\n        this.configuration = {...this.defaults, ...data.configuration};\n\n        merge(this.operatorCtrl.valueChanges, this.valueCtrl.valueChanges).subscribe(() => {\n            const rendered = this.getRenderedValue();\n            this.renderedValue.next(rendered);\n        });\n\n        this.initValidators();\n        this.reloadCondition(data.condition);\n    }\n\n    public getCondition(): FilterGroupConditionField {\n        const condition: FilterGroupConditionField = {};\n        condition[this.operatorCtrl.value] = {\n            value: this.valueCtrl.value,\n        };\n\n        return condition;\n    }\n\n    public isValid(): boolean {\n        return this.form.valid;\n    }\n\n    public isDirty(): boolean {\n        return this.form.dirty;\n    }\n\n    public close(): void {\n        if (this.isValid()) {\n            this.dropdownRef.close({condition: this.getCondition()});\n        } else {\n            this.dropdownRef.close(); // undefined value, discard changes / prevent to add a condition (on new fields\n        }\n    }\n\n    private initValidators(): void {\n        const validators: ValidatorFn[] = [Validators.required];\n        if (typeof this.configuration.min === 'number') {\n            validators.push(Validators.min(this.configuration.min));\n        }\n\n        if (typeof this.configuration.max === 'number') {\n            validators.push(Validators.max(this.configuration.max));\n        }\n\n        if (this.configuration.step) {\n            const decimals = ('' + this.configuration.step).match(/\\.(\\d+)$/)?.[1] ?? '';\n            const decimalCount = decimals.length;\n            validators.push(decimal(decimalCount));\n        }\n\n        this.valueCtrl.setValidators(validators);\n    }\n\n    private reloadCondition(condition: FilterGroupConditionField | null): void {\n        if (!condition) {\n            return;\n        }\n\n        for (const operator of this.operators) {\n            const reloadedCondition = condition[operator.key];\n            if (reloadedCondition) {\n                this.operatorCtrl.setValue(operator.key);\n                this.valueCtrl.setValue(reloadedCondition.value);\n            }\n        }\n    }\n\n    private getRenderedValue(): string {\n        const operator = this.operators.find(v => v.key === this.operatorCtrl.value);\n        if (this.valueCtrl.value === null || !operator) {\n            return '';\n        } else {\n            return operator.label + ' ' + this.valueCtrl.value;\n        }\n    }\n}\n","<form [formGroup]=\"form\">\n    <mat-form-field style=\"max-width: 4em; margin-right: 1em\">\n        <mat-label i18n=\"Mathematical operator < > =\">Opérateur</mat-label>\n        <mat-select [formControl]=\"operatorCtrl\" [required]=\"true\" panelWidth=\"\">\n            @for (item of operators; track item) {\n                <mat-option [value]=\"item.key\">\n                    {{ item.label }}\n                </mat-option>\n            }\n        </mat-select>\n    </mat-form-field>\n\n    <mat-form-field>\n        <mat-label i18n>Valeur</mat-label>\n        <input\n            (keydown.enter)=\"close()\"\n            [errorStateMatcher]=\"matcher\"\n            [formControl]=\"valueCtrl\"\n            [attr.max]=\"configuration.max\"\n            [attr.min]=\"configuration.min\"\n            [required]=\"true\"\n            [step]=\"configuration.step\"\n            matInput\n            type=\"number\"\n        />\n        @if (valueCtrl.hasError('min')) {\n            <mat-error>< {{ configuration.min }}</mat-error>\n        }\n        @if (valueCtrl.hasError('max')) {\n            <mat-error>> {{ configuration.max }}</mat-error>\n        }\n    </mat-form-field>\n</form>\n"]}
|
|
111
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"type-number.component.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/dropdown-components/type-number/type-number.component.ts","../../../../../../../projects/natural/src/lib/modules/dropdown-components/type-number/type-number.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, Inject} from '@angular/core';\nimport {FormControl, FormGroup, ValidatorFn, Validators, FormsModule, ReactiveFormsModule} from '@angular/forms';\nimport {BehaviorSubject, merge} from 'rxjs';\nimport {FilterGroupConditionField} from '../../search/classes/graphql-doctrine.types';\nimport {NaturalDropdownRef} from '../../search/dropdown-container/dropdown-ref';\nimport {NATURAL_DROPDOWN_DATA, NaturalDropdownData} from '../../search/dropdown-container/dropdown.service';\nimport {DropdownComponent} from '../../search/types/dropdown-component';\nimport {possibleComparableOperators, PossibleComparableOpertorKeys} from '../types';\nimport {InvalidWithValueStateMatcher} from '../type-text/type-text.component';\nimport {decimal} from '../../../classes/validators';\nimport {MatInputModule} from '@angular/material/input';\nimport {MatOptionModule} from '@angular/material/core';\nimport {MatSelectModule} from '@angular/material/select';\nimport {MatFormFieldModule} from '@angular/material/form-field';\n\nexport type TypeNumberConfiguration = {\n    min?: number | null;\n    max?: number | null;\n    step?: number | null;\n};\n\n@Component({\n    templateUrl: './type-number.component.html',\n    styleUrl: './type-number.component.scss',\n    standalone: true,\n    imports: [FormsModule, ReactiveFormsModule, MatFormFieldModule, MatSelectModule, MatOptionModule, MatInputModule],\n})\nexport class TypeNumberComponent implements DropdownComponent {\n    public readonly renderedValue = new BehaviorSubject<string>('');\n    public readonly configuration: Required<TypeNumberConfiguration>;\n    public readonly operatorCtrl = new FormControl<PossibleComparableOpertorKeys>('equal', {nonNullable: true});\n    public readonly valueCtrl = new FormControl();\n    public readonly matcher = new InvalidWithValueStateMatcher();\n    public readonly form = new FormGroup({\n        operator: this.operatorCtrl,\n        value: this.valueCtrl,\n    });\n    public readonly operators = possibleComparableOperators;\n\n    private readonly defaults: Required<TypeNumberConfiguration> = {\n        min: null,\n        max: null,\n        step: null,\n    };\n\n    public constructor(\n        @Inject(NATURAL_DROPDOWN_DATA) data: NaturalDropdownData<TypeNumberConfiguration>,\n        protected dropdownRef: NaturalDropdownRef,\n    ) {\n        this.configuration = {...this.defaults, ...data.configuration};\n\n        merge(this.operatorCtrl.valueChanges, this.valueCtrl.valueChanges).subscribe(() => {\n            const rendered = this.getRenderedValue();\n            this.renderedValue.next(rendered);\n        });\n\n        this.initValidators();\n        this.reloadCondition(data.condition);\n    }\n\n    public getCondition(): FilterGroupConditionField {\n        const condition: FilterGroupConditionField = {};\n        condition[this.operatorCtrl.value] = {\n            value: this.valueCtrl.value,\n        };\n\n        return condition;\n    }\n\n    public isValid(): boolean {\n        return this.form.valid;\n    }\n\n    public isDirty(): boolean {\n        return this.form.dirty;\n    }\n\n    public close(): void {\n        if (this.isValid()) {\n            this.dropdownRef.close({condition: this.getCondition()});\n        } else {\n            this.dropdownRef.close(); // undefined value, discard changes / prevent to add a condition (on new fields\n        }\n    }\n\n    private initValidators(): void {\n        const validators: ValidatorFn[] = [Validators.required];\n        if (typeof this.configuration.min === 'number') {\n            validators.push(Validators.min(this.configuration.min));\n        }\n\n        if (typeof this.configuration.max === 'number') {\n            validators.push(Validators.max(this.configuration.max));\n        }\n\n        if (this.configuration.step) {\n            const decimals = /\\.(\\d+)$/.exec('' + this.configuration.step)?.[1] ?? '';\n            const decimalCount = decimals.length;\n            validators.push(decimal(decimalCount));\n        }\n\n        this.valueCtrl.setValidators(validators);\n    }\n\n    private reloadCondition(condition: FilterGroupConditionField | null): void {\n        if (!condition) {\n            return;\n        }\n\n        for (const operator of this.operators) {\n            const reloadedCondition = condition[operator.key];\n            if (reloadedCondition) {\n                this.operatorCtrl.setValue(operator.key);\n                this.valueCtrl.setValue(reloadedCondition.value);\n            }\n        }\n    }\n\n    private getRenderedValue(): string {\n        const operator = this.operators.find(v => v.key === this.operatorCtrl.value);\n        if (this.valueCtrl.value === null || !operator) {\n            return '';\n        } else {\n            return operator.label + ' ' + this.valueCtrl.value;\n        }\n    }\n}\n","<form [formGroup]=\"form\">\n    <mat-form-field style=\"max-width: 4em; margin-right: 1em\">\n        <mat-label i18n=\"Mathematical operator < > =\">Opérateur</mat-label>\n        <mat-select [formControl]=\"operatorCtrl\" [required]=\"true\" panelWidth=\"\">\n            @for (item of operators; track item) {\n                <mat-option [value]=\"item.key\">\n                    {{ item.label }}\n                </mat-option>\n            }\n        </mat-select>\n    </mat-form-field>\n\n    <mat-form-field>\n        <mat-label i18n>Valeur</mat-label>\n        <input\n            (keydown.enter)=\"close()\"\n            [errorStateMatcher]=\"matcher\"\n            [formControl]=\"valueCtrl\"\n            [attr.max]=\"configuration.max\"\n            [attr.min]=\"configuration.min\"\n            [required]=\"true\"\n            [step]=\"configuration.step\"\n            matInput\n            type=\"number\"\n        />\n        @if (valueCtrl.hasError('min')) {\n            <mat-error>< {{ configuration.min }}</mat-error>\n        }\n        @if (valueCtrl.hasError('max')) {\n            <mat-error>> {{ configuration.max }}</mat-error>\n        }\n    </mat-form-field>\n</form>\n"]}
|
|
@@ -49,10 +49,10 @@ export class TypeOptionsComponent {
|
|
|
49
49
|
isDirty() {
|
|
50
50
|
return this.formControl.dirty;
|
|
51
51
|
}
|
|
52
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
53
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "
|
|
52
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: TypeOptionsComponent, deps: [{ token: NATURAL_DROPDOWN_DATA }, { token: i1.NaturalDropdownRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
53
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.0", type: TypeOptionsComponent, isStandalone: true, selector: "ng-component", ngImport: i0, template: "<mat-button-toggle-group [formControl]=\"formControl\">\n @for (option of configuration.options; track option) {\n <mat-button-toggle [value]=\"option\">{{ option.display }}</mat-button-toggle>\n }\n</mat-button-toggle-group>\n", dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: MatButtonToggleModule }, { kind: "directive", type: i3.MatButtonToggleGroup, selector: "mat-button-toggle-group", inputs: ["appearance", "name", "vertical", "value", "multiple", "disabled", "hideSingleSelectionIndicator", "hideMultipleSelectionIndicator"], outputs: ["valueChange", "change"], exportAs: ["matButtonToggleGroup"] }, { kind: "component", type: i3.MatButtonToggle, selector: "mat-button-toggle", inputs: ["aria-label", "aria-labelledby", "id", "name", "value", "tabIndex", "disableRipple", "appearance", "checked", "disabled"], outputs: ["change"], exportAs: ["matButtonToggle"] }] }); }
|
|
54
54
|
}
|
|
55
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
55
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: TypeOptionsComponent, decorators: [{
|
|
56
56
|
type: Component,
|
|
57
57
|
args: [{ standalone: true, imports: [FormsModule, ReactiveFormsModule, MatButtonToggleModule], template: "<mat-button-toggle-group [formControl]=\"formControl\">\n @for (option of configuration.options; track option) {\n <mat-button-toggle [value]=\"option\">{{ option.display }}</mat-button-toggle>\n }\n</mat-button-toggle-group>\n" }]
|
|
58
58
|
}], ctorParameters: () => [{ type: undefined, decorators: [{
|