UNPKG

@netgrif/components-core

Version:

Netgrif Application engine frontend core Angular library

123 lines 15.3 kB
import { Subject } from 'rxjs'; import { EditableElementaryPredicate } from './editable-elementary-predicate'; import { IncrementingCounter } from '../../../utility/incrementing-counter'; import { Query } from '../query/query'; import { EditablePredicate } from './editable-predicate'; import { Predicate } from './predicate'; /** * A complex, editable `Predicate`. Represents an inner node in the predicate tree, that can process changes of `Query` objects * held by its child nodes. It can notify the parent tree node about changes to the held `Query`. */ export class EditableClausePredicate extends EditablePredicate { _operator; _bracketSubPredicateText; _predicates; _childUpdated$; _childCounter; _query; constructor(_operator, parentNotifier, initiallyVisible = true, _bracketSubPredicateText = false) { super(parentNotifier, initiallyVisible); this._operator = _operator; this._bracketSubPredicateText = _bracketSubPredicateText; this._predicates = new Map(); this._childUpdated$ = new Subject(); this._childCounter = new IncrementingCounter(); this._query = Query.emptyQuery(); this.initializeFilterTextSegmentsGenerator(); this._childUpdated$.subscribe(() => { this.updateQueryAndNotify(); }); } get query() { return this._query; } destroy() { super.destroy(); this._childUpdated$.complete(); } show() { super.show(); this.showAll(); } /** * Shows the predicates with the given ids. Skips ids that don't exist. * @param predicateIds the ids of the predicates that should be shown. */ showPredicates(predicateIds) { predicateIds.forEach(id => { if (this._predicates.has(id)) { this._predicates.get(id).show(); } }); } /** * Adds new child predicate of type {@link EditableElementaryPredicate} * @param initiallyVisible whether the new predicate should be initially visible */ addNewElementaryPredicate(initiallyVisible = true) { return this.addPredicate(new EditableElementaryPredicate(this._childUpdated$, initiallyVisible)); } /** * Adds new child predicate of type {@link EditableClausePredicate} * @param operator the operator of the child clause predicate * @param initiallyVisible whether the new predicate should be initially visible */ addNewClausePredicate(operator, initiallyVisible = true) { return this.addPredicate(new EditableClausePredicate(operator, this._childUpdated$, initiallyVisible)); } /** * Generates an id for the new predicate, adds it into the map and updates the query * * If you want to add an editable predicate, use one of the other methods, so that this predicate can react to changes. * @param predicate the new predicate */ addPredicate(predicate) { const id = this._childCounter.next(); this._predicates.set(id, predicate); this.updateQueryAndNotify(); return id; } removePredicate(id) { const r = this._predicates.delete(id); this.updateQueryAndNotify(); return r; } getPredicateMap() { return this._predicates; } /** * Updates the `Query` and notifies the parent. */ updateQueryAndNotify() { this.updateQuery(); this.notifyParentPredicate(); } /** * Updates the value of the [_query]{@link ClausePredicate#_query} attribute. * * See [combineQueries()]{@link Query#combineQueries} for more information. */ updateQuery() { this._query = Query.combineQueries(this.queries, this._operator); } /** * @returns the `Array` of {@link Query} objects stored within this object's [_predicates]{@link ClausePredicate#_predicates} attribute. */ get queries() { return Array.from(this._predicates.values()).map(p => p.query); } /** * Sets this predicate and all its sub-predicates to visible. */ showAll() { for (const p of this._predicates.values()) { p.show(); } } initializeFilterTextSegmentsGenerator() { this._filterTextSegmentsGenerator = () => { return Predicate.combineTextSegmentsWithBooleanOperator(this._predicates.values(), this._operator, this._bracketSubPredicateText); }; } } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editable-clause-predicate.js","sourceRoot":"","sources":["../../../../../../../projects/netgrif-components-core/src/lib/search/models/predicate/editable-clause-predicate.ts"],"names":[],"mappings":"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","sourcesContent":["import {BooleanOperator} from '../boolean-operator';\nimport {Subject} from 'rxjs';\nimport {EditableElementaryPredicate} from './editable-elementary-predicate';\nimport {IncrementingCounter} from '../../../utility/incrementing-counter';\nimport {Query} from '../query/query';\nimport {EditablePredicate} from './editable-predicate';\nimport {Predicate} from './predicate';\n\n\n/**\n * A complex, editable `Predicate`. Represents an inner node in the predicate tree, that can process changes of `Query` objects\n * held by its child nodes. It can notify the parent tree node about changes to the held `Query`.\n */\nexport class EditableClausePredicate extends EditablePredicate {\n\n    protected _predicates: Map<number, Predicate>;\n    protected _childUpdated$: Subject<void>;\n    protected _childCounter: IncrementingCounter;\n    protected _query: Query;\n\n    constructor(protected _operator: BooleanOperator,\n                parentNotifier?: Subject<void>,\n                initiallyVisible = true,\n                protected _bracketSubPredicateText = false) {\n        super(parentNotifier, initiallyVisible);\n        this._predicates = new Map<number, Predicate>();\n        this._childUpdated$ = new Subject<void>();\n        this._childCounter = new IncrementingCounter();\n        this._query = Query.emptyQuery();\n        this.initializeFilterTextSegmentsGenerator();\n\n        this._childUpdated$.subscribe(() => {\n            this.updateQueryAndNotify();\n        });\n    }\n\n    get query(): Query {\n        return this._query;\n    }\n\n    public destroy(): void {\n        super.destroy();\n        this._childUpdated$.complete();\n    }\n\n    public show() {\n        super.show();\n        this.showAll();\n    }\n\n    /**\n     * Shows the predicates with the given ids. Skips ids that don't exist.\n     * @param predicateIds the ids of the predicates that should be shown.\n     */\n    public showPredicates(predicateIds: Array<number>): void {\n        predicateIds.forEach(id => {\n            if (this._predicates.has(id)) {\n                this._predicates.get(id).show();\n            }\n        });\n    }\n\n    /**\n     * Adds new child predicate of type {@link EditableElementaryPredicate}\n     * @param initiallyVisible whether the new predicate should be initially visible\n     */\n    addNewElementaryPredicate(initiallyVisible = true): number {\n        return this.addPredicate(new EditableElementaryPredicate(this._childUpdated$, initiallyVisible));\n    }\n\n    /**\n     * Adds new child predicate of type {@link EditableClausePredicate}\n     * @param operator the operator of the child clause predicate\n     * @param initiallyVisible whether the new predicate should be initially visible\n     */\n    addNewClausePredicate(operator: BooleanOperator, initiallyVisible = true): number {\n        return this.addPredicate(new EditableClausePredicate(operator, this._childUpdated$, initiallyVisible));\n    }\n\n    /**\n     * Generates an id for the new predicate, adds it into the map and updates the query\n     *\n     * If you want to add an editable predicate, use one of the other methods, so that this predicate can react to changes.\n     * @param predicate the new predicate\n     */\n    public addPredicate(predicate: Predicate): number {\n        const id = this._childCounter.next();\n        this._predicates.set(id, predicate);\n        this.updateQueryAndNotify();\n        return id;\n    }\n\n    removePredicate(id: number): boolean {\n        const r = this._predicates.delete(id);\n        this.updateQueryAndNotify();\n        return r;\n    }\n\n    public getPredicateMap(): Map<number, Predicate> {\n        return this._predicates;\n    }\n\n    /**\n     * Updates the `Query` and notifies the parent.\n     */\n    protected updateQueryAndNotify(): void {\n        this.updateQuery();\n        this.notifyParentPredicate();\n    }\n\n    /**\n     * Updates the value of the [_query]{@link ClausePredicate#_query} attribute.\n     *\n     * See [combineQueries()]{@link Query#combineQueries} for more information.\n     */\n    protected updateQuery(): void {\n        this._query = Query.combineQueries(this.queries, this._operator);\n    }\n\n    /**\n     * @returns the `Array` of {@link Query} objects stored within this object's [_predicates]{@link ClausePredicate#_predicates} attribute.\n     */\n    protected get queries(): Array<Query> {\n        return Array.from(this._predicates.values()).map(p => p.query);\n    }\n\n    /**\n     * Sets this predicate and all its sub-predicates to visible.\n     */\n    protected showAll(): void {\n        for (const p of this._predicates.values()) {\n            p.show();\n        }\n    }\n\n    private initializeFilterTextSegmentsGenerator() {\n        this._filterTextSegmentsGenerator = () => {\n            return Predicate.combineTextSegmentsWithBooleanOperator(this._predicates.values(),\n                this._operator, this._bracketSubPredicateText);\n        };\n    }\n}\n"]}