@sarasanalytics-com/design-system 0.0.154 → 0.0.155
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/README.md +24 -24
- package/esm2022/interfaces/avatar-interface.mjs +1 -1
- package/esm2022/interfaces/button-interface.mjs +1 -1
- package/esm2022/interfaces/card-carousel-interface.mjs +1 -1
- package/esm2022/interfaces/chip-interface.mjs +1 -1
- package/esm2022/interfaces/form-layout.interface.mjs +1 -1
- package/esm2022/interfaces/grid-interface.mjs +1 -1
- package/esm2022/interfaces/guide-card-interface.mjs +1 -1
- package/esm2022/interfaces/header-interface.mjs +1 -1
- package/esm2022/interfaces/icon-interface.mjs +1 -1
- package/esm2022/interfaces/layout-section-interface.mjs +1 -1
- package/esm2022/interfaces/left-nav-interface.mjs +1 -1
- package/esm2022/interfaces/menu.interface.mjs +1 -1
- package/esm2022/interfaces/message-banner.mjs +1 -1
- package/esm2022/interfaces/option-interface.mjs +1 -1
- package/esm2022/interfaces/scrolling-card-interface.mjs +1 -1
- package/esm2022/interfaces/select-interface.mjs +1 -1
- package/esm2022/interfaces/status-dot.interface.mjs +1 -1
- package/esm2022/interfaces/tab-interface.mjs +1 -1
- package/esm2022/interfaces/toast-interface.mjs +1 -1
- package/esm2022/interfaces/typography-animation-interface.mjs +1 -1
- package/esm2022/lib/accordion/accordion.component.mjs +3 -3
- package/esm2022/lib/avatar/avatar.component.mjs +3 -3
- package/esm2022/lib/button/button.component.mjs +3 -3
- package/esm2022/lib/calendar-header/calendar-header.component.mjs +3 -3
- package/esm2022/lib/card/card-body/card-body.component.mjs +1 -1
- package/esm2022/lib/card/card-custom-header/card-custom-header.component.mjs +1 -1
- package/esm2022/lib/card/card-footer-actions/card-footer-actions.component.mjs +3 -3
- package/esm2022/lib/card/card-icon/card-icon.component.mjs +1 -1
- package/esm2022/lib/card/card-title-actions/card-title-actions.component.mjs +1 -1
- package/esm2022/lib/card/card.component.mjs +3 -3
- package/esm2022/lib/card/checkbox-card/checkbox-card.component.mjs +3 -3
- package/esm2022/lib/card/guide-card/guide-card.component.mjs +3 -3
- package/esm2022/lib/card/menu-card/menu-card.component.mjs +3 -3
- package/esm2022/lib/card/thumbnail-card/thumbnail-card.component.mjs +3 -3
- package/esm2022/lib/card-carousel/card-carousel.component.mjs +3 -3
- package/esm2022/lib/categories-nav/categories-nav.component.mjs +3 -3
- package/esm2022/lib/checkbox/checkbox.component.mjs +3 -3
- package/esm2022/lib/chips/chips.component.mjs +3 -3
- package/esm2022/lib/component-library.component.mjs +9 -9
- package/esm2022/lib/component-library.service.mjs +1 -1
- package/esm2022/lib/dashboard-loader/dashboard-loader.component.mjs +1 -1
- package/esm2022/lib/data-grid/data-grid.component.mjs +3 -3
- package/esm2022/lib/datepicker/datepicker.component.mjs +3 -3
- package/esm2022/lib/dialog/dialog.component.mjs +3 -3
- package/esm2022/lib/dropdown/category-dropdown/category-dropdown.component.mjs +242 -0
- package/esm2022/lib/dropdown/ng-select/ng-select.component.mjs +111 -0
- package/esm2022/lib/filter/filter.component.mjs +3 -3
- package/esm2022/lib/form-input/form-input.component.mjs +4 -5
- package/esm2022/lib/form-select/form-select.component.mjs +3 -3
- package/esm2022/lib/grid-cell/grid-cell.component.mjs +10 -10
- package/esm2022/lib/header/header.component.mjs +3 -3
- package/esm2022/lib/icon/icon.component.mjs +3 -3
- package/esm2022/lib/icon/icon.service.mjs +1 -1
- package/esm2022/lib/layout-section/layout-section.component.mjs +3 -3
- package/esm2022/lib/left-nav/left-nav.component.mjs +3 -3
- package/esm2022/lib/list/list.component.mjs +3 -3
- package/esm2022/lib/menu/menu-list/menu-item.component.mjs +3 -3
- package/esm2022/lib/menu/menu.component.mjs +3 -3
- package/esm2022/lib/menu/menu.directive.mjs +1 -1
- package/esm2022/lib/message-banner/message-banner.component.mjs +3 -3
- package/esm2022/lib/message-banner-v2/message-banner-v2.component.mjs +3 -3
- package/esm2022/lib/mini-card/mini-card.component.mjs +3 -3
- package/esm2022/lib/page-layout/page-layout.component.mjs +3 -3
- package/esm2022/lib/progress-bar/progress-bar.component.mjs +3 -3
- package/esm2022/lib/query-builder/query-builder-demo.component.mjs +45 -45
- package/esm2022/lib/query-builder/query-builder.component.mjs +3 -3
- package/esm2022/lib/query-builder/query-builder.service.mjs +1 -1
- package/esm2022/lib/query-builder-formly/query-builder-formly.component.mjs +191 -0
- package/esm2022/lib/query-builder-textarea/query-builder-textarea-demo.component.mjs +39 -39
- package/esm2022/lib/query-builder-textarea/query-builder-textarea.component.mjs +3 -3
- package/esm2022/lib/radio-button/radio-button.component.mjs +3 -3
- package/esm2022/lib/scrolling-cards/scrolling-cards.component.mjs +3 -3
- package/esm2022/lib/skeleton/skeleton-base.component.mjs +1 -1
- package/esm2022/lib/skeleton/skeleton-container.component.mjs +9 -9
- package/esm2022/lib/skeleton/skeleton-loader.component.mjs +193 -193
- package/esm2022/lib/skeleton/skeleton-presets.mjs +1 -1
- package/esm2022/lib/skeleton/skeleton-shapes.component.mjs +1 -1
- package/esm2022/lib/spinner/spinner.component.mjs +1 -1
- package/esm2022/lib/status-dot/status-dot.component.mjs +17 -17
- package/esm2022/lib/stepper/stepper.component.mjs +3 -3
- package/esm2022/lib/tabs/tabs.component.mjs +3 -3
- package/esm2022/lib/toast/toast.component.mjs +3 -3
- package/esm2022/lib/tool-tip/tool-tip.component.mjs +3 -3
- package/esm2022/lib/typography-animation/typography-animation.component.mjs +3 -3
- package/esm2022/public-api.mjs +4 -1
- package/esm2022/utils/validators.mjs +1 -1
- package/fesm2022/sarasanalytics-com-design-system.mjs +893 -411
- package/fesm2022/sarasanalytics-com-design-system.mjs.map +1 -1
- package/lib/dropdown/category-dropdown/category-dropdown.component.d.ts +40 -0
- package/lib/dropdown/ng-select/ng-select.component.d.ts +20 -0
- package/lib/query-builder-formly/query-builder-formly.component.d.ts +81 -0
- package/package.json +1 -1
- package/public-api.d.ts +3 -0
- package/styles/styles.css +432 -460
|
@@ -104,4 +104,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImpor
|
|
|
104
104
|
providedIn: 'root'
|
|
105
105
|
}]
|
|
106
106
|
}], ctorParameters: () => [] });
|
|
107
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
107
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicXVlcnktYnVpbGRlci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tcG9uZW50LWxpYnJhcnkvc3JjL2xpYi9xdWVyeS1idWlsZGVyL3F1ZXJ5LWJ1aWxkZXIuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQU0zQyxNQUFNLE9BQU8sbUJBQW1CO0lBRTlCLGdCQUFnQixDQUFDO0lBRWpCOzs7O09BSUc7SUFDSCxhQUFhLENBQUMsS0FBaUI7UUFDN0IsSUFBSSxDQUFDLEtBQUssSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLElBQUksS0FBSyxDQUFDLEtBQUssQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFLENBQUM7WUFDdkQsT0FBTyxFQUFFLENBQUM7UUFDWixDQUFDO1FBRUQsT0FBTyxLQUFLLENBQUMsS0FBSzthQUNmLEdBQUcsQ0FBQyxDQUFDLElBQVMsRUFBRSxFQUFFO1lBQ2pCLElBQUksSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO2dCQUNuQixPQUFPLElBQUksSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFrQixDQUFDLEdBQUcsQ0FBQztZQUN2RCxDQUFDO2lCQUFNLENBQUM7Z0JBQ04sT0FBTyxHQUFHLElBQUksQ0FBQyxLQUFLLElBQUksSUFBSSxDQUFDLFFBQVEsSUFBSSxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDeEQsQ0FBQztRQUNILENBQUMsQ0FBQzthQUNELElBQUksQ0FBQyxJQUFJLEtBQUssQ0FBQyxTQUFTLENBQUMsV0FBVyxFQUFFLEdBQUcsQ0FBQyxDQUFDO0lBQ2hELENBQUM7SUFFRDs7OztPQUlHO0lBQ0gsV0FBVyxDQUFDLEtBQWlCO1FBQzNCLElBQUksQ0FBQyxLQUFLLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxJQUFJLEtBQUssQ0FBQyxLQUFLLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBRSxDQUFDO1lBQ3ZELE9BQU8sRUFBRSxDQUFDO1FBQ1osQ0FBQztRQUVELE9BQU87WUFDTCxTQUFTLEVBQUUsS0FBSyxDQUFDLFNBQVM7WUFDMUIsS0FBSyxFQUFFLEtBQUssQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBUyxFQUFFLEVBQUU7Z0JBQ25DLElBQUksSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO29CQUNuQixPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBa0IsQ0FBQyxDQUFDO2dCQUM5QyxDQUFDO3FCQUFNLENBQUM7b0JBQ04sT0FBTzt3QkFDTCxLQUFLLEVBQUUsSUFBSSxDQUFDLEtBQUs7d0JBQ2pCLFFBQVEsRUFBRSxJQUFJLENBQUMsUUFBUTt3QkFDdkIsS0FBSyxFQUFFLElBQUksQ0FBQyxLQUFLO3FCQUNsQixDQUFDO2dCQUNKLENBQUM7WUFDSCxDQUFDLENBQUM7U0FDSCxDQUFDO0lBQ0osQ0FBQztJQUVEOzs7O09BSUc7SUFDSCxZQUFZLENBQUMsS0FBaUI7UUFDNUIsSUFBSSxDQUFDLEtBQUssSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLElBQUksS0FBSyxDQUFDLEtBQUssQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFLENBQUM7WUFDdkQsT0FBTyxLQUFLLENBQUM7UUFDZixDQUFDO1FBRUQsT0FBTyxLQUFLLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDLElBQVMsRUFBRSxFQUFFO1lBQ3JDLElBQUksSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO2dCQUNuQixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBa0IsQ0FBQyxDQUFDO1lBQy9DLENBQUM7aUJBQU0sQ0FBQztnQkFDTixPQUFPLElBQUksQ0FBQyxLQUFLLElBQUksSUFBSSxDQUFDLFFBQVEsSUFBSSxJQUFJLENBQUMsS0FBSyxLQUFLLFNBQVMsSUFBSSxJQUFJLENBQUMsS0FBSyxLQUFLLElBQUksQ0FBQztZQUN4RixDQUFDO1FBQ0gsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQ7Ozs7T0FJRztJQUNILGdCQUFnQixDQUFDLFlBQTBCLEtBQUs7UUFDOUMsT0FBTztZQUNMLFNBQVM7WUFDVCxLQUFLLEVBQUUsRUFBRTtTQUNWLENBQUM7SUFDSixDQUFDO0lBRUQ7Ozs7OztPQU1HO0lBQ0gsaUJBQWlCLENBQUMsS0FBYSxFQUFFLFFBQWdCLEVBQUUsS0FBVTtRQUMzRCxPQUFPO1lBQ0wsU0FBUyxFQUFFLEtBQUs7WUFDaEIsS0FBSyxFQUFFO2dCQUNMO29CQUNFLEtBQUs7b0JBQ0wsUUFBUTtvQkFDUixLQUFLO2lCQUNOO2FBQ0Y7U0FDRixDQUFDO0lBQ0osQ0FBQzs4R0FwR1UsbUJBQW1CO2tIQUFuQixtQkFBbUIsY0FGbEIsTUFBTTs7MkZBRVAsbUJBQW1CO2tCQUgvQixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFF1ZXJ5R3JvdXAsIFF1ZXJ5UnVsZSB9IGZyb20gJy4vcXVlcnktYnVpbGRlci5jb21wb25lbnQnO1xuXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290J1xufSlcbmV4cG9ydCBjbGFzcyBRdWVyeUJ1aWxkZXJTZXJ2aWNlIHtcbiAgXG4gIGNvbnN0cnVjdG9yKCkgeyB9XG5cbiAgLyoqXG4gICAqIENvbnZlcnRzIGEgcXVlcnkgZ3JvdXAgdG8gYSBodW1hbi1yZWFkYWJsZSBzdHJpbmdcbiAgICogQHBhcmFtIHF1ZXJ5IFRoZSBxdWVyeSBncm91cCB0byBjb252ZXJ0XG4gICAqIEByZXR1cm5zIEEgc3RyaW5nIHJlcHJlc2VudGF0aW9uIG9mIHRoZSBxdWVyeVxuICAgKi9cbiAgcXVlcnlUb1N0cmluZyhxdWVyeTogUXVlcnlHcm91cCk6IHN0cmluZyB7XG4gICAgaWYgKCFxdWVyeSB8fCAhcXVlcnkucnVsZXMgfHwgcXVlcnkucnVsZXMubGVuZ3RoID09PSAwKSB7XG4gICAgICByZXR1cm4gJyc7XG4gICAgfVxuXG4gICAgcmV0dXJuIHF1ZXJ5LnJ1bGVzXG4gICAgICAubWFwKChydWxlOiBhbnkpID0+IHtcbiAgICAgICAgaWYgKHJ1bGUuY29uZGl0aW9uKSB7XG4gICAgICAgICAgcmV0dXJuIGAoJHt0aGlzLnF1ZXJ5VG9TdHJpbmcocnVsZSBhcyBRdWVyeUdyb3VwKX0pYDtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICByZXR1cm4gYCR7cnVsZS5maWVsZH0gJHtydWxlLm9wZXJhdG9yfSAke3J1bGUudmFsdWV9YDtcbiAgICAgICAgfVxuICAgICAgfSlcbiAgICAgIC5qb2luKGAgJHtxdWVyeS5jb25kaXRpb24udG9VcHBlckNhc2UoKX0gYCk7XG4gIH1cblxuICAvKipcbiAgICogQ29udmVydHMgYSBxdWVyeSBncm91cCB0byBhIEpTT04gb2JqZWN0IHRoYXQgY2FuIGJlIHVzZWQgaW4gQVBJIHJlcXVlc3RzXG4gICAqIEBwYXJhbSBxdWVyeSBUaGUgcXVlcnkgZ3JvdXAgdG8gY29udmVydFxuICAgKiBAcmV0dXJucyBBIEpTT04gb2JqZWN0IHJlcHJlc2VudGF0aW9uIG9mIHRoZSBxdWVyeVxuICAgKi9cbiAgcXVlcnlUb0pzb24ocXVlcnk6IFF1ZXJ5R3JvdXApOiBhbnkge1xuICAgIGlmICghcXVlcnkgfHwgIXF1ZXJ5LnJ1bGVzIHx8IHF1ZXJ5LnJ1bGVzLmxlbmd0aCA9PT0gMCkge1xuICAgICAgcmV0dXJuIHt9O1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICBjb25kaXRpb246IHF1ZXJ5LmNvbmRpdGlvbixcbiAgICAgIHJ1bGVzOiBxdWVyeS5ydWxlcy5tYXAoKHJ1bGU6IGFueSkgPT4ge1xuICAgICAgICBpZiAocnVsZS5jb25kaXRpb24pIHtcbiAgICAgICAgICByZXR1cm4gdGhpcy5xdWVyeVRvSnNvbihydWxlIGFzIFF1ZXJ5R3JvdXApO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICBmaWVsZDogcnVsZS5maWVsZCxcbiAgICAgICAgICAgIG9wZXJhdG9yOiBydWxlLm9wZXJhdG9yLFxuICAgICAgICAgICAgdmFsdWU6IHJ1bGUudmFsdWVcbiAgICAgICAgICB9O1xuICAgICAgICB9XG4gICAgICB9KVxuICAgIH07XG4gIH1cblxuICAvKipcbiAgICogVmFsaWRhdGVzIGEgcXVlcnkgZ3JvdXAgdG8gZW5zdXJlIGFsbCBydWxlcyBoYXZlIHZhbGlkIHZhbHVlc1xuICAgKiBAcGFyYW0gcXVlcnkgVGhlIHF1ZXJ5IGdyb3VwIHRvIHZhbGlkYXRlXG4gICAqIEByZXR1cm5zIFRydWUgaWYgdGhlIHF1ZXJ5IGlzIHZhbGlkLCBmYWxzZSBvdGhlcndpc2VcbiAgICovXG4gIGlzUXVlcnlWYWxpZChxdWVyeTogUXVlcnlHcm91cCk6IGJvb2xlYW4ge1xuICAgIGlmICghcXVlcnkgfHwgIXF1ZXJ5LnJ1bGVzIHx8IHF1ZXJ5LnJ1bGVzLmxlbmd0aCA9PT0gMCkge1xuICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cblxuICAgIHJldHVybiBxdWVyeS5ydWxlcy5ldmVyeSgocnVsZTogYW55KSA9PiB7XG4gICAgICBpZiAocnVsZS5jb25kaXRpb24pIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuaXNRdWVyeVZhbGlkKHJ1bGUgYXMgUXVlcnlHcm91cCk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICByZXR1cm4gcnVsZS5maWVsZCAmJiBydWxlLm9wZXJhdG9yICYmIHJ1bGUudmFsdWUgIT09IHVuZGVmaW5lZCAmJiBydWxlLnZhbHVlICE9PSBudWxsO1xuICAgICAgfVxuICAgIH0pO1xuICB9XG5cbiAgLyoqXG4gICAqIENyZWF0ZXMgYW4gZW1wdHkgcXVlcnkgZ3JvdXBcbiAgICogQHBhcmFtIGNvbmRpdGlvbiBUaGUgY29uZGl0aW9uIHRvIHVzZSAoYW5kL29yKVxuICAgKiBAcmV0dXJucyBBbiBlbXB0eSBxdWVyeSBncm91cFxuICAgKi9cbiAgY3JlYXRlRW1wdHlRdWVyeShjb25kaXRpb246ICdhbmQnIHwgJ29yJyA9ICdhbmQnKTogUXVlcnlHcm91cCB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGNvbmRpdGlvbixcbiAgICAgIHJ1bGVzOiBbXVxuICAgIH07XG4gIH1cblxuICAvKipcbiAgICogQ3JlYXRlcyBhIHNpbXBsZSBxdWVyeSB3aXRoIGEgc2luZ2xlIHJ1bGVcbiAgICogQHBhcmFtIGZpZWxkIFRoZSBmaWVsZCB0byBmaWx0ZXIgb25cbiAgICogQHBhcmFtIG9wZXJhdG9yIFRoZSBvcGVyYXRvciB0byB1c2VcbiAgICogQHBhcmFtIHZhbHVlIFRoZSB2YWx1ZSB0byBmaWx0ZXIgYnlcbiAgICogQHJldHVybnMgQSBxdWVyeSBncm91cCB3aXRoIGEgc2luZ2xlIHJ1bGVcbiAgICovXG4gIGNyZWF0ZVNpbXBsZVF1ZXJ5KGZpZWxkOiBzdHJpbmcsIG9wZXJhdG9yOiBzdHJpbmcsIHZhbHVlOiBhbnkpOiBRdWVyeUdyb3VwIHtcbiAgICByZXR1cm4ge1xuICAgICAgY29uZGl0aW9uOiAnYW5kJyxcbiAgICAgIHJ1bGVzOiBbXG4gICAgICAgIHtcbiAgICAgICAgICBmaWVsZCxcbiAgICAgICAgICBvcGVyYXRvcixcbiAgICAgICAgICB2YWx1ZVxuICAgICAgICB9XG4gICAgICBdXG4gICAgfTtcbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,191 @@
|
|
|
1
|
+
import { Component } from '@angular/core';
|
|
2
|
+
import { FieldArrayType } from '@ngx-formly/core';
|
|
3
|
+
import { CommonModule } from '@angular/common';
|
|
4
|
+
import { FormlyModule } from '@ngx-formly/core';
|
|
5
|
+
import { ReactiveFormsModule } from '@angular/forms';
|
|
6
|
+
import { get, keys } from 'lodash';
|
|
7
|
+
import { ButtonComponent } from '../button/button.component';
|
|
8
|
+
import { IconComponent } from '../icon/icon.component';
|
|
9
|
+
import { MatFormFieldModule } from '@angular/material/form-field';
|
|
10
|
+
import { MatSelectModule } from '@angular/material/select';
|
|
11
|
+
import { MatOptionModule } from '@angular/material/core';
|
|
12
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
13
|
+
import * as i0 from "@angular/core";
|
|
14
|
+
import * as i1 from "@ngx-formly/core";
|
|
15
|
+
export class QueryBuilderFormlyComponent extends FieldArrayType {
|
|
16
|
+
constructor() {
|
|
17
|
+
super(...arguments);
|
|
18
|
+
// reset(): void {
|
|
19
|
+
// this.formControl.reset();
|
|
20
|
+
// }
|
|
21
|
+
/**
|
|
22
|
+
* Duplicates the row at the given index.
|
|
23
|
+
* A deep–clone of that row’s model is inserted right after the original row.
|
|
24
|
+
*/
|
|
25
|
+
this.copied = false;
|
|
26
|
+
}
|
|
27
|
+
ngOnInit() {
|
|
28
|
+
}
|
|
29
|
+
getRowCondition(index) {
|
|
30
|
+
if (index === 0)
|
|
31
|
+
return 'and';
|
|
32
|
+
const ruleGroup = this.formControl.at(index);
|
|
33
|
+
return ruleGroup.get('condition')?.value || 'and';
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* Sets the condition for a specific row
|
|
37
|
+
* @param index The index of the row
|
|
38
|
+
* @param condition The condition to set (and/or)
|
|
39
|
+
*/
|
|
40
|
+
setRowCondition(index, condition) {
|
|
41
|
+
if (index === 0)
|
|
42
|
+
return; // First row doesn't have a condition
|
|
43
|
+
const ruleGroup = this.formControl.at(index);
|
|
44
|
+
ruleGroup.get('condition')?.setValue(condition);
|
|
45
|
+
}
|
|
46
|
+
copyRule() {
|
|
47
|
+
}
|
|
48
|
+
createField(field) {
|
|
49
|
+
if (field.type === 'dynamic-type' || field.type === '') {
|
|
50
|
+
field.type = 'sa-input';
|
|
51
|
+
field.props.type = 'text';
|
|
52
|
+
field.props.placeholder = 'Enter/Select';
|
|
53
|
+
}
|
|
54
|
+
return field;
|
|
55
|
+
}
|
|
56
|
+
getFilterType(subField) {
|
|
57
|
+
const parentValue = get(subField, 'formControl.parent.value');
|
|
58
|
+
if (!parentValue)
|
|
59
|
+
return undefined;
|
|
60
|
+
// Look through all keys of the parent value
|
|
61
|
+
for (const key of keys(parentValue)) {
|
|
62
|
+
const val = parentValue[key];
|
|
63
|
+
if (val && typeof val === 'object' && 'filterType' in val) {
|
|
64
|
+
return val.filterType;
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
return undefined;
|
|
68
|
+
}
|
|
69
|
+
copy(index) {
|
|
70
|
+
const rowModel = this.formControl.at(index)?.value;
|
|
71
|
+
if (!rowModel)
|
|
72
|
+
return;
|
|
73
|
+
// Deep-clone model
|
|
74
|
+
const cloned = JSON.parse(JSON.stringify(rowModel));
|
|
75
|
+
// Insert row after the current one
|
|
76
|
+
this.add(index + 1, cloned);
|
|
77
|
+
// 👇 Force Formly to refresh the dynamic field
|
|
78
|
+
const newRow = this.formControl.at(index + 1);
|
|
79
|
+
const attr = newRow?.get('attribute')?.value;
|
|
80
|
+
if (attr) {
|
|
81
|
+
const attrCtrl = newRow?.get('attribute');
|
|
82
|
+
attrCtrl.setValue(attrCtrl.value);
|
|
83
|
+
// Re-trigger field type rebuild for filterValue
|
|
84
|
+
const filterValueField = this.field.fieldGroup[index + 1].fieldGroup
|
|
85
|
+
.find(f => f.key === 'filterValue');
|
|
86
|
+
if (filterValueField) {
|
|
87
|
+
const typeMap = {
|
|
88
|
+
SELECT: 'sa-ng-select',
|
|
89
|
+
STRING: 'sa-input',
|
|
90
|
+
NUMBER: 'sa-input',
|
|
91
|
+
DATE: 'sa-date-picker',
|
|
92
|
+
CURRENCY: 'sa-currency-input',
|
|
93
|
+
BOOLEAN: 'sa-ng-select',
|
|
94
|
+
};
|
|
95
|
+
const newType = typeMap[attr.filterType] || 'sa-input';
|
|
96
|
+
filterValueField.type = newType;
|
|
97
|
+
filterValueField.props = {
|
|
98
|
+
...this.createFieldProps(attr.filterType),
|
|
99
|
+
hasDynamicType: true,
|
|
100
|
+
disabled: false, // initial
|
|
101
|
+
attribute: attr,
|
|
102
|
+
};
|
|
103
|
+
// 🔄 Notify Formly of type change
|
|
104
|
+
filterValueField.options?.fieldChanges?.next({
|
|
105
|
+
type: 'type',
|
|
106
|
+
field: filterValueField,
|
|
107
|
+
value: newType,
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
createFieldProps(type) {
|
|
113
|
+
switch (type) {
|
|
114
|
+
case 'SELECT':
|
|
115
|
+
return {
|
|
116
|
+
placeholder: 'Select',
|
|
117
|
+
multiple: false,
|
|
118
|
+
bindLabel: 'label',
|
|
119
|
+
bindValue: 'value',
|
|
120
|
+
appearance: 'outline',
|
|
121
|
+
isClearable: true,
|
|
122
|
+
isSearchable: false,
|
|
123
|
+
closeOnselect: true,
|
|
124
|
+
required: true,
|
|
125
|
+
disabled: false,
|
|
126
|
+
};
|
|
127
|
+
case 'STRING':
|
|
128
|
+
return {
|
|
129
|
+
placeholder: 'Enter value',
|
|
130
|
+
appearance: 'outline',
|
|
131
|
+
type: 'text'
|
|
132
|
+
};
|
|
133
|
+
case 'NUMBER':
|
|
134
|
+
return {
|
|
135
|
+
placeholder: 'Enter value',
|
|
136
|
+
appearance: 'outline',
|
|
137
|
+
type: 'number'
|
|
138
|
+
};
|
|
139
|
+
case 'DATE':
|
|
140
|
+
return {
|
|
141
|
+
placeholder: 'Select date',
|
|
142
|
+
appearance: 'outline',
|
|
143
|
+
type: 'date'
|
|
144
|
+
};
|
|
145
|
+
case 'CURRENCY':
|
|
146
|
+
return {
|
|
147
|
+
placeholder: 'Enter value',
|
|
148
|
+
appearance: 'outline',
|
|
149
|
+
};
|
|
150
|
+
case 'BOOLEAN':
|
|
151
|
+
return {
|
|
152
|
+
placeholder: 'Enter value',
|
|
153
|
+
appearance: 'outline',
|
|
154
|
+
type: 'boolean',
|
|
155
|
+
options: [
|
|
156
|
+
{ value: true, label: 'True' },
|
|
157
|
+
{ value: false, label: 'False' },
|
|
158
|
+
],
|
|
159
|
+
bindLabel: 'label',
|
|
160
|
+
bindValue: 'value',
|
|
161
|
+
disabled: false,
|
|
162
|
+
};
|
|
163
|
+
default:
|
|
164
|
+
return {
|
|
165
|
+
placeholder: 'Enter value',
|
|
166
|
+
appearance: 'outline',
|
|
167
|
+
};
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
reset() {
|
|
171
|
+
this.field.fieldGroup.splice(0, this.field.fieldGroup.length); // clear
|
|
172
|
+
this.add(); // start fresh with one row
|
|
173
|
+
}
|
|
174
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: QueryBuilderFormlyComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
175
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.4", type: QueryBuilderFormlyComponent, isStandalone: true, selector: "sa-query-builder-formly", providers: [], usesInheritance: true, ngImport: i0, template: "<div class=\"sa-query-builder-container\">\n <div class=\"query-builder-body\">\n @for(subField of field.fieldGroup; track $index) {\n <div class=\"row align-items-baseline\">\n @if ($index === 0) {\n <span class=\"where-text flex-1\">Where</span>\n }\n @for (subField of subField.fieldGroup; track $index) {\n @if(!!subField.props['hasDynamicType']){\n @switch (getFilterType(subField)) {\n @case ('STRING') {\n <formly-field [field]=\"subField\"></formly-field>\n }\n @case ('NUMBER') {\n <formly-field [field]=\"subField\"></formly-field>\n }\n @case ('BOOLEAN') {\n <formly-field [field]=\"subField\"></formly-field>\n }\n @case ('CURRENCY') {\n <formly-field [field]=\"subField\"></formly-field>\n }\n @case ('DATE') {\n\n }\n @case ('SELECT') {\n <formly-field [field]=\"createField(subField)\"></formly-field>\n }\n @default {\n <formly-field [field]=\"createField(subField)\"></formly-field>\n }\n }\n }@else{\n <formly-field\n class=\"col\"\n [field]=\"subField\"\n >\n </formly-field>\n }\n }\n @if(props?.['showCopyButton']){\n <sa-icon icon=\"copyOutlined\" class=\"copy-icon pointer\" (click)=\"copy($index)\"></sa-icon>\n }\n <sa-icon icon=\"deleteIcon\" class=\"delete-icon pointer\" (click)=\"remove($index)\"></sa-icon>\n </div>\n }\n \n <!-- Buttons -->\n <div class=\"rule-button-container\">\n <sa-button icon=\"add\" iconPosition=\"left\" text=\"Add filter\"\n (onClickEvent)=\"add()\"\n [state]=\"field?.fieldGroup?.length === (props?.['maxRows'] || 5) ? 'disabled' : 'default'\"\n type=\"outline\" size=\"medium\">\n </sa-button>\n <span class=\"filters-count\">({{field?.fieldGroup?.length}}/{{props?.['maxRows'] || 5}} filters)</span>\n @if(props?.['showResetButton']){\n <sa-button iconPosition=\"left\" text=\"Reset\"\n (onClickEvent)=\"reset()\"\n type=\"primary\" size=\"medium\">\n </sa-button>\n }\n </div> \n </div>\n</div>", styles: [".sa-query-builder-container{display:flex}.sa-query-builder-container .query-builder-body{display:flex;flex-direction:column;gap:var(--small-12px);width:-webkit-fill-available}.query-builder-body .row{display:flex;height:2.25rem;justify-content:center;align-items:center;flex:1 0 0;gap:var(--small-8px);width:-webkit-fill-available}.query-builder-form-wrapper{width:-webkit-fill-available}::ng-deep .query-builder-form-wrapper .sa-input-field.idle{border-radius:var(--small-4px);border:1px solid var(--grey-100, #EAECF0);background:var(--white, #FFF);height:2.438rem}::ng-deep .query-builder-form-wrapper .sa-input-container{height:3.438rem}::ng-deep .query-builder-form-wrapper .sa-input-container .disabled .sa-input-field input{color:var(--text-low-emphasis, #9B98A3);font-family:var(--font-family, Roboto);font-size:13px;font-style:normal;font-weight:400;line-height:var(--medium-20px);letter-spacing:.25px}.where-text{color:var(--text-medium-emphasis, #6D6979);font-family:var(--font-family-roboto);font-size:var(--small-14px);font-style:normal;font-weight:var(--font-weight-500);line-height:var(--medium-20px);letter-spacing:.1px;width:80px}.flex-1{flex:1 1 0;min-width:80px}.flex-2{flex:2 1 0;min-width:120px}.flex-4{flex:4 1 0;min-width:200px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "ngmodule", type: FormlyModule }, { kind: "component", type: i1.FormlyField, selector: "formly-field", inputs: ["field"] }, { kind: "component", type: ButtonComponent, selector: "sa-button", inputs: ["id", "type", "state", "size", "text", "ImagePath", "icon", "iconPosition", "href", "hrefTarget", "width", "isSubmit", "buttonIconSize", "showSpinner"], outputs: ["onClickEvent", "onMouseInEvent", "onMouseOutEvent"] }, { kind: "component", type: IconComponent, selector: "sa-icon", inputs: ["img", "icon", "size", "color", "iconPath", "iconUrl", "customClass", "href", "hrefTarget", "iconPosition"], outputs: ["onClickEvent"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "ngmodule", type: MatSelectModule }, { kind: "ngmodule", type: MatOptionModule }, { kind: "ngmodule", type: MatIconModule }] }); }
|
|
176
|
+
}
|
|
177
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: QueryBuilderFormlyComponent, decorators: [{
|
|
178
|
+
type: Component,
|
|
179
|
+
args: [{ selector: 'sa-query-builder-formly', standalone: true, providers: [], imports: [
|
|
180
|
+
CommonModule,
|
|
181
|
+
ReactiveFormsModule,
|
|
182
|
+
FormlyModule,
|
|
183
|
+
ButtonComponent,
|
|
184
|
+
IconComponent,
|
|
185
|
+
MatFormFieldModule,
|
|
186
|
+
MatSelectModule,
|
|
187
|
+
MatOptionModule,
|
|
188
|
+
MatIconModule
|
|
189
|
+
], template: "<div class=\"sa-query-builder-container\">\n <div class=\"query-builder-body\">\n @for(subField of field.fieldGroup; track $index) {\n <div class=\"row align-items-baseline\">\n @if ($index === 0) {\n <span class=\"where-text flex-1\">Where</span>\n }\n @for (subField of subField.fieldGroup; track $index) {\n @if(!!subField.props['hasDynamicType']){\n @switch (getFilterType(subField)) {\n @case ('STRING') {\n <formly-field [field]=\"subField\"></formly-field>\n }\n @case ('NUMBER') {\n <formly-field [field]=\"subField\"></formly-field>\n }\n @case ('BOOLEAN') {\n <formly-field [field]=\"subField\"></formly-field>\n }\n @case ('CURRENCY') {\n <formly-field [field]=\"subField\"></formly-field>\n }\n @case ('DATE') {\n\n }\n @case ('SELECT') {\n <formly-field [field]=\"createField(subField)\"></formly-field>\n }\n @default {\n <formly-field [field]=\"createField(subField)\"></formly-field>\n }\n }\n }@else{\n <formly-field\n class=\"col\"\n [field]=\"subField\"\n >\n </formly-field>\n }\n }\n @if(props?.['showCopyButton']){\n <sa-icon icon=\"copyOutlined\" class=\"copy-icon pointer\" (click)=\"copy($index)\"></sa-icon>\n }\n <sa-icon icon=\"deleteIcon\" class=\"delete-icon pointer\" (click)=\"remove($index)\"></sa-icon>\n </div>\n }\n \n <!-- Buttons -->\n <div class=\"rule-button-container\">\n <sa-button icon=\"add\" iconPosition=\"left\" text=\"Add filter\"\n (onClickEvent)=\"add()\"\n [state]=\"field?.fieldGroup?.length === (props?.['maxRows'] || 5) ? 'disabled' : 'default'\"\n type=\"outline\" size=\"medium\">\n </sa-button>\n <span class=\"filters-count\">({{field?.fieldGroup?.length}}/{{props?.['maxRows'] || 5}} filters)</span>\n @if(props?.['showResetButton']){\n <sa-button iconPosition=\"left\" text=\"Reset\"\n (onClickEvent)=\"reset()\"\n type=\"primary\" size=\"medium\">\n </sa-button>\n }\n </div> \n </div>\n</div>", styles: [".sa-query-builder-container{display:flex}.sa-query-builder-container .query-builder-body{display:flex;flex-direction:column;gap:var(--small-12px);width:-webkit-fill-available}.query-builder-body .row{display:flex;height:2.25rem;justify-content:center;align-items:center;flex:1 0 0;gap:var(--small-8px);width:-webkit-fill-available}.query-builder-form-wrapper{width:-webkit-fill-available}::ng-deep .query-builder-form-wrapper .sa-input-field.idle{border-radius:var(--small-4px);border:1px solid var(--grey-100, #EAECF0);background:var(--white, #FFF);height:2.438rem}::ng-deep .query-builder-form-wrapper .sa-input-container{height:3.438rem}::ng-deep .query-builder-form-wrapper .sa-input-container .disabled .sa-input-field input{color:var(--text-low-emphasis, #9B98A3);font-family:var(--font-family, Roboto);font-size:13px;font-style:normal;font-weight:400;line-height:var(--medium-20px);letter-spacing:.25px}.where-text{color:var(--text-medium-emphasis, #6D6979);font-family:var(--font-family-roboto);font-size:var(--small-14px);font-style:normal;font-weight:var(--font-weight-500);line-height:var(--medium-20px);letter-spacing:.1px;width:80px}.flex-1{flex:1 1 0;min-width:80px}.flex-2{flex:2 1 0;min-width:120px}.flex-4{flex:4 1 0;min-width:200px}\n"] }]
|
|
190
|
+
}] });
|
|
191
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"query-builder-formly.component.js","sourceRoot":"","sources":["../../../../../projects/component-library/src/lib/query-builder-formly/query-builder-formly.component.ts","../../../../../projects/component-library/src/lib/query-builder-formly/query-builder-formly.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit } from '@angular/core';\nimport { FieldArrayType, FormlyFieldConfig } from '@ngx-formly/core';\nimport { CommonModule } from '@angular/common'; \nimport { FormlyModule } from '@ngx-formly/core';\nimport { FormGroup, ReactiveFormsModule } from '@angular/forms';\nimport { get, keys } from 'lodash';\nimport { ButtonComponent } from '../button/button.component';\nimport { IconComponent } from '../icon/icon.component';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatSelectModule } from '@angular/material/select';\nimport { MatOptionModule } from '@angular/material/core';\nimport { MatIconModule } from '@angular/material/icon';\n\n\n@Component({\n  selector: 'sa-query-builder-formly',\n  templateUrl: './query-builder-formly.component.html',\n  styleUrls: ['./query-builder-formly.component.scss'],\n  standalone: true,\n  providers: [],\n  imports: [\n    CommonModule,\n    ReactiveFormsModule,\n    FormlyModule,\n    ButtonComponent,\n    IconComponent,\n    MatFormFieldModule,\n    MatSelectModule,\n    MatOptionModule,\n    MatIconModule    \n  ]\n})\nexport class QueryBuilderFormlyComponent extends FieldArrayType implements OnInit {\n  \n  ngOnInit(): void {\n    \n    \n  }\n  \n  getRowCondition(index: number): 'and' | 'or' {\n      if (index === 0) return 'and'; \n      \n      const ruleGroup = this.formControl.at(index) as FormGroup;\n      return ruleGroup.get('condition')?.value || 'and';\n    }\n\n    /**\n   * Sets the condition for a specific row\n   * @param index The index of the row\n   * @param condition The condition to set (and/or)\n   */\n  setRowCondition(index: number, condition: 'and' | 'or'): void {\n    if (index === 0) return; // First row doesn't have a condition\n    \n    const ruleGroup = this.formControl.at(index) as FormGroup;\n    ruleGroup.get('condition')?.setValue(condition);\n  }\n\n  copyRule(): void {\n    \n  }\n\n  createField(field: FormlyFieldConfig): FormlyFieldConfig {\n    if(field.type === 'dynamic-type' || field.type === '') {\n      field.type = 'sa-input';\n      field.props.type = 'text';\n      field.props.placeholder = 'Enter/Select';\n    }\n    return field;\n  }\n\n  getFilterType(subField: FormlyFieldConfig): string | undefined {\n    const parentValue = get(subField, 'formControl.parent.value');\n    if (!parentValue) return undefined;\n  \n    // Look through all keys of the parent value\n    for (const key of keys(parentValue)) {\n      const val = parentValue[key];\n      if (val && typeof val === 'object' && 'filterType' in val) {\n        return val.filterType;\n      }\n    }\n    return undefined;\n  }\n\n  // reset(): void {\n  //   this.formControl.reset();\n  // }\n\n  /**\n   * Duplicates the row at the given index.\n   * A deep–clone of that row’s model is inserted right after the original row.\n   */\n  copied: boolean = false;\n  copy(index: number): void {\n    const rowModel = this.formControl.at(index)?.value;\n    if (!rowModel) return;\n  \n    // Deep-clone model\n    const cloned = JSON.parse(JSON.stringify(rowModel));\n  \n    // Insert row after the current one\n    this.add(index + 1, cloned);\n  \n    // 👇 Force Formly to refresh the dynamic field\n    const newRow = this.formControl.at(index + 1);\n    const attr = newRow?.get('attribute')?.value;\n  \n    if (attr) {\n      const attrCtrl = newRow?.get('attribute');\n      attrCtrl.setValue(attrCtrl.value);\n      // Re-trigger field type rebuild for filterValue\n      const filterValueField = this.field.fieldGroup[index + 1].fieldGroup\n        .find(f => f.key === 'filterValue');\n  \n        if (filterValueField) {\n          const typeMap = {\n            SELECT: 'sa-ng-select',\n            STRING: 'sa-input',\n            NUMBER: 'sa-input',\n            DATE: 'sa-date-picker',\n            CURRENCY: 'sa-currency-input',\n            BOOLEAN: 'sa-ng-select',\n          };\n        \n          const newType = typeMap[attr.filterType] || 'sa-input';\n          filterValueField.type = newType;\n          filterValueField.props = {\n            ...this.createFieldProps(attr.filterType),\n            hasDynamicType: true,\n            disabled: false,  // initial\n            attribute: attr,\n          };\n        \n          // 🔄 Notify Formly of type change\n          filterValueField.options?.fieldChanges?.next({\n            type: 'type',\n            field: filterValueField,\n            value: newType,\n          });\n        \n        }\n        \n    }\n  }\n  createFieldProps(type: string) {\n    switch (type) {\n      case 'SELECT':\n        return {\n          placeholder: 'Select',\n          multiple: false,\n          bindLabel: 'label',\n          bindValue: 'value',\n          appearance: 'outline',\n          isClearable: true,\n          isSearchable: false,\n          closeOnselect: true,\n          required: true,\n          disabled: false,\n        };\n      case 'STRING':\n        return {\n          placeholder: 'Enter value',\n          appearance: 'outline',\n          type: 'text'\n        };\n      case 'NUMBER':\n        return {\n          placeholder: 'Enter value',\n          appearance: 'outline',\n          type: 'number'\n        };\n      case 'DATE':\n        return {\n          placeholder: 'Select date',\n          appearance: 'outline',\n          type: 'date'\n        };\n      case 'CURRENCY':\n        return {\n          placeholder: 'Enter value',\n          appearance: 'outline',\n        };\n      case 'BOOLEAN':\n        return {\n          placeholder: 'Enter value',\n          appearance: 'outline',\n          type: 'boolean',\n          options: [\n            { value: true, label: 'True' },\n            { value: false, label: 'False' },\n          ],\n          bindLabel: 'label',\n          bindValue: 'value',\n          disabled: false,\n        };\n      default:\n        return {\n          placeholder: 'Enter value',\n          appearance: 'outline',\n        };\n    }\n  }\n\n  reset() {\n    this.field.fieldGroup.splice(0, this.field.fieldGroup.length); // clear\n    this.add(); // start fresh with one row\n  }\n\n}\n","<div class=\"sa-query-builder-container\">\n  <div class=\"query-builder-body\">\n    @for(subField of field.fieldGroup; track $index) {\n      <div class=\"row align-items-baseline\">\n        @if ($index === 0) {\n          <span class=\"where-text flex-1\">Where</span>\n        }\n        @for (subField of subField.fieldGroup; track $index) {\n          @if(!!subField.props['hasDynamicType']){\n            @switch (getFilterType(subField)) {\n              @case ('STRING') {\n                <formly-field [field]=\"subField\"></formly-field>\n                }\n                @case ('NUMBER') {\n                <formly-field [field]=\"subField\"></formly-field>\n                }\n                @case ('BOOLEAN') {\n                  <formly-field [field]=\"subField\"></formly-field>\n                  }\n                  @case ('CURRENCY') {\n                    <formly-field [field]=\"subField\"></formly-field>\n                  }\n                  @case ('DATE') {\n\n                  }\n                  @case ('SELECT') {\n                  <formly-field [field]=\"createField(subField)\"></formly-field>\n                  }\n                  @default {\n                  <formly-field [field]=\"createField(subField)\"></formly-field>\n                  }\n            }\n          }@else{\n            <formly-field\n            class=\"col\"\n            [field]=\"subField\"\n          >\n          </formly-field>\n          }\n        }\n        @if(props?.['showCopyButton']){\n        <sa-icon icon=\"copyOutlined\" class=\"copy-icon pointer\" (click)=\"copy($index)\"></sa-icon>\n        }\n        <sa-icon icon=\"deleteIcon\" class=\"delete-icon pointer\" (click)=\"remove($index)\"></sa-icon>\n      </div>\n    }\n  \n    <!-- Buttons -->\n    <div class=\"rule-button-container\">\n      <sa-button icon=\"add\" iconPosition=\"left\" text=\"Add filter\"\n      (onClickEvent)=\"add()\"\n      [state]=\"field?.fieldGroup?.length === (props?.['maxRows'] || 5) ? 'disabled' : 'default'\"\n      type=\"outline\" size=\"medium\">\n      </sa-button>\n      <span class=\"filters-count\">({{field?.fieldGroup?.length}}/{{props?.['maxRows'] || 5}} filters)</span>\n      @if(props?.['showResetButton']){\n      <sa-button iconPosition=\"left\" text=\"Reset\"\n      (onClickEvent)=\"reset()\"\n      type=\"primary\" size=\"medium\">\n      </sa-button>\n      }\n    </div>    \n    </div>\n</div>"]}
|
|
@@ -78,25 +78,25 @@ export class QueryBuilderTextareaDemoComponent {
|
|
|
78
78
|
console.log('Query changed:', query);
|
|
79
79
|
}
|
|
80
80
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: QueryBuilderTextareaDemoComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
81
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.4", type: QueryBuilderTextareaDemoComponent, isStandalone: true, selector: "sa-query-builder-textarea-demo", ngImport: i0, template: `
|
|
82
|
-
<mat-card>
|
|
83
|
-
<mat-card-header>
|
|
84
|
-
<mat-card-title>Query Builder Textarea Demo</mat-card-title>
|
|
85
|
-
</mat-card-header>
|
|
86
|
-
<mat-card-content>
|
|
87
|
-
<sa-query-builder-textarea
|
|
88
|
-
[config]="queryConfig"
|
|
89
|
-
(queryChange)="onQueryChange($event)">
|
|
90
|
-
</sa-query-builder-textarea>
|
|
91
|
-
|
|
92
|
-
<mat-divider class="my-4"></mat-divider>
|
|
93
|
-
|
|
94
|
-
<div class="output-section">
|
|
95
|
-
<h3>Query Output</h3>
|
|
96
|
-
<pre>{{ currentQuery | json }}</pre>
|
|
97
|
-
</div>
|
|
98
|
-
</mat-card-content>
|
|
99
|
-
</mat-card>
|
|
81
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.4", type: QueryBuilderTextareaDemoComponent, isStandalone: true, selector: "sa-query-builder-textarea-demo", ngImport: i0, template: `
|
|
82
|
+
<mat-card>
|
|
83
|
+
<mat-card-header>
|
|
84
|
+
<mat-card-title>Query Builder Textarea Demo</mat-card-title>
|
|
85
|
+
</mat-card-header>
|
|
86
|
+
<mat-card-content>
|
|
87
|
+
<sa-query-builder-textarea
|
|
88
|
+
[config]="queryConfig"
|
|
89
|
+
(queryChange)="onQueryChange($event)">
|
|
90
|
+
</sa-query-builder-textarea>
|
|
91
|
+
|
|
92
|
+
<mat-divider class="my-4"></mat-divider>
|
|
93
|
+
|
|
94
|
+
<div class="output-section">
|
|
95
|
+
<h3>Query Output</h3>
|
|
96
|
+
<pre>{{ currentQuery | json }}</pre>
|
|
97
|
+
</div>
|
|
98
|
+
</mat-card-content>
|
|
99
|
+
</mat-card>
|
|
100
100
|
`, isInline: true, styles: [".my-4{margin-top:1rem;margin-bottom:1rem}.output-section{margin-top:1rem}pre{background-color:#f5f5f5;padding:1rem;border-radius:4px;overflow:auto;max-height:300px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i1.JsonPipe, name: "json" }, { kind: "component", type: QueryBuilderTextareaComponent, selector: "sa-query-builder-textarea", inputs: ["config"], outputs: ["queryChange", "suggestionSelected"] }, { kind: "ngmodule", type: MatCardModule }, { kind: "component", type: i2.MatCard, selector: "mat-card", inputs: ["appearance"], exportAs: ["matCard"] }, { kind: "directive", type: i2.MatCardContent, selector: "mat-card-content" }, { kind: "component", type: i2.MatCardHeader, selector: "mat-card-header" }, { kind: "directive", type: i2.MatCardTitle, selector: "mat-card-title, [mat-card-title], [matCardTitle]" }, { kind: "ngmodule", type: MatDividerModule }, { kind: "component", type: i3.MatDivider, selector: "mat-divider", inputs: ["vertical", "inset"] }] }); }
|
|
101
101
|
}
|
|
102
102
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: QueryBuilderTextareaDemoComponent, decorators: [{
|
|
@@ -106,25 +106,25 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImpor
|
|
|
106
106
|
QueryBuilderTextareaComponent,
|
|
107
107
|
MatCardModule,
|
|
108
108
|
MatDividerModule
|
|
109
|
-
], template: `
|
|
110
|
-
<mat-card>
|
|
111
|
-
<mat-card-header>
|
|
112
|
-
<mat-card-title>Query Builder Textarea Demo</mat-card-title>
|
|
113
|
-
</mat-card-header>
|
|
114
|
-
<mat-card-content>
|
|
115
|
-
<sa-query-builder-textarea
|
|
116
|
-
[config]="queryConfig"
|
|
117
|
-
(queryChange)="onQueryChange($event)">
|
|
118
|
-
</sa-query-builder-textarea>
|
|
119
|
-
|
|
120
|
-
<mat-divider class="my-4"></mat-divider>
|
|
121
|
-
|
|
122
|
-
<div class="output-section">
|
|
123
|
-
<h3>Query Output</h3>
|
|
124
|
-
<pre>{{ currentQuery | json }}</pre>
|
|
125
|
-
</div>
|
|
126
|
-
</mat-card-content>
|
|
127
|
-
</mat-card>
|
|
109
|
+
], template: `
|
|
110
|
+
<mat-card>
|
|
111
|
+
<mat-card-header>
|
|
112
|
+
<mat-card-title>Query Builder Textarea Demo</mat-card-title>
|
|
113
|
+
</mat-card-header>
|
|
114
|
+
<mat-card-content>
|
|
115
|
+
<sa-query-builder-textarea
|
|
116
|
+
[config]="queryConfig"
|
|
117
|
+
(queryChange)="onQueryChange($event)">
|
|
118
|
+
</sa-query-builder-textarea>
|
|
119
|
+
|
|
120
|
+
<mat-divider class="my-4"></mat-divider>
|
|
121
|
+
|
|
122
|
+
<div class="output-section">
|
|
123
|
+
<h3>Query Output</h3>
|
|
124
|
+
<pre>{{ currentQuery | json }}</pre>
|
|
125
|
+
</div>
|
|
126
|
+
</mat-card-content>
|
|
127
|
+
</mat-card>
|
|
128
128
|
`, styles: [".my-4{margin-top:1rem;margin-bottom:1rem}.output-section{margin-top:1rem}pre{background-color:#f5f5f5;padding:1rem;border-radius:4px;overflow:auto;max-height:300px}\n"] }]
|
|
129
129
|
}] });
|
|
130
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
130
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicXVlcnktYnVpbGRlci10ZXh0YXJlYS1kZW1vLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvbXBvbmVudC1saWJyYXJ5L3NyYy9saWIvcXVlcnktYnVpbGRlci10ZXh0YXJlYS9xdWVyeS1idWlsZGVyLXRleHRhcmVhLWRlbW8uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUM3RCxPQUFPLEVBQUUsNkJBQTZCLEVBQTJDLE1BQU0sb0NBQW9DLENBQUM7Ozs7O0FBa0Q1SCxNQUFNLE9BQU8saUNBQWlDO0lBaEQ5QztRQWlERSxnQkFBVyxHQUF3QjtZQUNqQyxNQUFNLEVBQUU7Z0JBQ047b0JBQ0UsR0FBRyxFQUFFLE1BQU07b0JBQ1gsS0FBSyxFQUFFLE1BQU07b0JBQ2IsSUFBSSxFQUFFLFFBQVE7aUJBQ2Y7Z0JBQ0Q7b0JBQ0UsR0FBRyxFQUFFLEtBQUs7b0JBQ1YsS0FBSyxFQUFFLEtBQUs7b0JBQ1osSUFBSSxFQUFFLFFBQVE7b0JBQ2QsU0FBUyxFQUFFLENBQUMsR0FBRyxFQUFFLElBQUksRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsU0FBUyxDQUFDO2lCQUN4RDtnQkFDRDtvQkFDRSxHQUFHLEVBQUUsT0FBTztvQkFDWixLQUFLLEVBQUUsT0FBTztvQkFDZCxJQUFJLEVBQUUsUUFBUTtvQkFDZCxTQUFTLEVBQUUsQ0FBQyxHQUFHLEVBQUUsSUFBSSxFQUFFLFVBQVUsQ0FBQztpQkFDbkM7Z0JBQ0Q7b0JBQ0UsR0FBRyxFQUFFLFdBQVc7b0JBQ2hCLEtBQUssRUFBRSxZQUFZO29CQUNuQixJQUFJLEVBQUUsTUFBTTtvQkFDWixTQUFTLEVBQUUsQ0FBQyxHQUFHLEVBQUUsSUFBSSxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxTQUFTLENBQUM7aUJBQ3hEO2dCQUNEO29CQUNFLEdBQUcsRUFBRSxVQUFVO29CQUNmLEtBQUssRUFBRSxXQUFXO29CQUNsQixJQUFJLEVBQUUsU0FBUztpQkFDaEI7Z0JBQ0Q7b0JBQ0UsR0FBRyxFQUFFLFFBQVE7b0JBQ2IsS0FBSyxFQUFFLFFBQVE7b0JBQ2YsSUFBSSxFQUFFLFFBQVE7b0JBQ2QsT0FBTyxFQUFFO3dCQUNQLEVBQUUsS0FBSyxFQUFFLFFBQVEsRUFBRSxLQUFLLEVBQUUsUUFBUSxFQUFFO3dCQUNwQyxFQUFFLEtBQUssRUFBRSxVQUFVLEVBQUUsS0FBSyxFQUFFLFVBQVUsRUFBRTt3QkFDeEMsRUFBRSxLQUFLLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUU7cUJBQ3ZDO2lCQUNGO2dCQUNEO29CQUNFLEdBQUcsRUFBRSxXQUFXO29CQUNoQixLQUFLLEVBQUUsV0FBVztvQkFDbEIsSUFBSSxFQUFFLFFBQVE7b0JBQ2QsT0FBTyxFQUFFO3dCQUNQLEVBQUUsS0FBSyxFQUFFLFFBQVEsRUFBRSxLQUFLLEVBQUUsUUFBUSxFQUFFO3dCQUNwQyxFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLFNBQVMsRUFBRTt3QkFDdEMsRUFBRSxLQUFLLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUU7cUJBQ3ZDO2lCQUNGO2FBQ0Y7WUFDRCxTQUFTLEVBQUU7Z0JBQ1QsRUFBRSxLQUFLLEVBQUUsR0FBRyxFQUFFLEtBQUssRUFBRSxHQUFHLEVBQUU7Z0JBQzFCLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFO2dCQUM1QixFQUFFLEtBQUssRUFBRSxHQUFHLEVBQUUsS0FBSyxFQUFFLEdBQUcsRUFBRTtnQkFDMUIsRUFBRSxLQUFLLEVBQUUsR0FBRyxFQUFFLEtBQUssRUFBRSxHQUFHLEVBQUU7Z0JBQzFCLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFO2dCQUM1QixFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRTtnQkFDNUIsRUFBRSxLQUFLLEVBQUUsVUFBVSxFQUFFLEtBQUssRUFBRSxVQUFVLEVBQUU7YUFDekM7WUFDRCxnQkFBZ0IsRUFBRSxLQUFLO1NBQ3hCLENBQUM7UUFFRixpQkFBWSxHQUE4QixJQUFJLENBQUM7S0FNaEQ7SUFKQyxhQUFhLENBQUMsS0FBeUI7UUFDckMsSUFBSSxDQUFDLFlBQVksR0FBRyxLQUFLLENBQUM7UUFDMUIsT0FBTyxDQUFDLEdBQUcsQ0FBQyxnQkFBZ0IsRUFBRSxLQUFLLENBQUMsQ0FBQztJQUN2QyxDQUFDOzhHQXJFVSxpQ0FBaUM7a0dBQWpDLGlDQUFpQywwRkF2Q2xDOzs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBbUJULCtPQXhCQyxZQUFZLGtGQUNaLDZCQUE2Qix5SUFDN0IsYUFBYSxrWkFDYixnQkFBZ0I7OzJGQXlDUCxpQ0FBaUM7a0JBaEQ3QyxTQUFTOytCQUNFLGdDQUFnQyxjQUM5QixJQUFJLFdBQ1A7d0JBQ1AsWUFBWTt3QkFDWiw2QkFBNkI7d0JBQzdCLGFBQWE7d0JBQ2IsZ0JBQWdCO3FCQUNqQixZQUNTOzs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBbUJUIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTWF0Q2FyZE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NhcmQnO1xuaW1wb3J0IHsgTWF0RGl2aWRlck1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RpdmlkZXInO1xuaW1wb3J0IHsgUXVlcnlCdWlsZGVyVGV4dGFyZWFDb21wb25lbnQsIFRleHRhcmVhUXVlcnlHcm91cCwgVGV4dGFyZWFRdWVyeUNvbmZpZyB9IGZyb20gJy4vcXVlcnktYnVpbGRlci10ZXh0YXJlYS5jb21wb25lbnQnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdzYS1xdWVyeS1idWlsZGVyLXRleHRhcmVhLWRlbW8nLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIFF1ZXJ5QnVpbGRlclRleHRhcmVhQ29tcG9uZW50LFxuICAgIE1hdENhcmRNb2R1bGUsXG4gICAgTWF0RGl2aWRlck1vZHVsZVxuICBdLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxtYXQtY2FyZD5cbiAgICAgIDxtYXQtY2FyZC1oZWFkZXI+XG4gICAgICAgIDxtYXQtY2FyZC10aXRsZT5RdWVyeSBCdWlsZGVyIFRleHRhcmVhIERlbW88L21hdC1jYXJkLXRpdGxlPlxuICAgICAgPC9tYXQtY2FyZC1oZWFkZXI+XG4gICAgICA8bWF0LWNhcmQtY29udGVudD5cbiAgICAgICAgPHNhLXF1ZXJ5LWJ1aWxkZXItdGV4dGFyZWFcbiAgICAgICAgICBbY29uZmlnXT1cInF1ZXJ5Q29uZmlnXCJcbiAgICAgICAgICAocXVlcnlDaGFuZ2UpPVwib25RdWVyeUNoYW5nZSgkZXZlbnQpXCI+XG4gICAgICAgIDwvc2EtcXVlcnktYnVpbGRlci10ZXh0YXJlYT5cblxuICAgICAgICA8bWF0LWRpdmlkZXIgY2xhc3M9XCJteS00XCI+PC9tYXQtZGl2aWRlcj5cblxuICAgICAgICA8ZGl2IGNsYXNzPVwib3V0cHV0LXNlY3Rpb25cIj5cbiAgICAgICAgICA8aDM+UXVlcnkgT3V0cHV0PC9oMz5cbiAgICAgICAgICA8cHJlPnt7IGN1cnJlbnRRdWVyeSB8IGpzb24gfX08L3ByZT5cbiAgICAgICAgPC9kaXY+XG4gICAgICA8L21hdC1jYXJkLWNvbnRlbnQ+XG4gICAgPC9tYXQtY2FyZD5cbiAgYCxcbiAgc3R5bGVzOiBbYFxuICAgIC5teS00IHtcbiAgICAgIG1hcmdpbi10b3A6IDFyZW07XG4gICAgICBtYXJnaW4tYm90dG9tOiAxcmVtO1xuICAgIH1cbiAgICBcbiAgICAub3V0cHV0LXNlY3Rpb24ge1xuICAgICAgbWFyZ2luLXRvcDogMXJlbTtcbiAgICB9XG4gICAgXG4gICAgcHJlIHtcbiAgICAgIGJhY2tncm91bmQtY29sb3I6ICNmNWY1ZjU7XG4gICAgICBwYWRkaW5nOiAxcmVtO1xuICAgICAgYm9yZGVyLXJhZGl1czogNHB4O1xuICAgICAgb3ZlcmZsb3c6IGF1dG87XG4gICAgICBtYXgtaGVpZ2h0OiAzMDBweDtcbiAgICB9XG4gIGBdXG59KVxuZXhwb3J0IGNsYXNzIFF1ZXJ5QnVpbGRlclRleHRhcmVhRGVtb0NvbXBvbmVudCB7XG4gIHF1ZXJ5Q29uZmlnOiBUZXh0YXJlYVF1ZXJ5Q29uZmlnID0ge1xuICAgIGZpZWxkczogW1xuICAgICAge1xuICAgICAgICBrZXk6ICduYW1lJyxcbiAgICAgICAgbGFiZWw6ICdOYW1lJyxcbiAgICAgICAgdHlwZTogJ3N0cmluZydcbiAgICAgIH0sXG4gICAgICB7XG4gICAgICAgIGtleTogJ2FnZScsXG4gICAgICAgIGxhYmVsOiAnQWdlJyxcbiAgICAgICAgdHlwZTogJ251bWJlcicsXG4gICAgICAgIG9wZXJhdG9yczogWyc9JywgJyE9JywgJz4nLCAnPCcsICc+PScsICc8PScsICdiZXR3ZWVuJ11cbiAgICAgIH0sXG4gICAgICB7XG4gICAgICAgIGtleTogJ2VtYWlsJyxcbiAgICAgICAgbGFiZWw6ICdFbWFpbCcsXG4gICAgICAgIHR5cGU6ICdzdHJpbmcnLFxuICAgICAgICBvcGVyYXRvcnM6IFsnPScsICchPScsICdjb250YWlucyddXG4gICAgICB9LFxuICAgICAge1xuICAgICAgICBrZXk6ICdjcmVhdGVkQXQnLFxuICAgICAgICBsYWJlbDogJ0NyZWF0ZWQgQXQnLFxuICAgICAgICB0eXBlOiAnZGF0ZScsXG4gICAgICAgIG9wZXJhdG9yczogWyc9JywgJyE9JywgJz4nLCAnPCcsICc+PScsICc8PScsICdiZXR3ZWVuJ11cbiAgICAgIH0sXG4gICAgICB7XG4gICAgICAgIGtleTogJ2lzQWN0aXZlJyxcbiAgICAgICAgbGFiZWw6ICdJcyBBY3RpdmUnLFxuICAgICAgICB0eXBlOiAnYm9vbGVhbidcbiAgICAgIH0sXG4gICAgICB7XG4gICAgICAgIGtleTogJ3N0YXR1cycsXG4gICAgICAgIGxhYmVsOiAnU3RhdHVzJyxcbiAgICAgICAgdHlwZTogJ3NlbGVjdCcsXG4gICAgICAgIG9wdGlvbnM6IFtcbiAgICAgICAgICB7IGxhYmVsOiAnQWN0aXZlJywgdmFsdWU6ICdhY3RpdmUnIH0sXG4gICAgICAgICAgeyBsYWJlbDogJ0luYWN0aXZlJywgdmFsdWU6ICdpbmFjdGl2ZScgfSxcbiAgICAgICAgICB7IGxhYmVsOiAnUGVuZGluZycsIHZhbHVlOiAncGVuZGluZycgfVxuICAgICAgICBdXG4gICAgICB9LFxuICAgICAge1xuICAgICAgICBrZXk6ICdsaWZlY3ljbGUnLFxuICAgICAgICBsYWJlbDogJ0xpZmVjeWNsZScsXG4gICAgICAgIHR5cGU6ICdzZWxlY3QnLFxuICAgICAgICBvcHRpb25zOiBbXG4gICAgICAgICAgeyBsYWJlbDogJ0FjdGl2ZScsIHZhbHVlOiAnYWN0aXZlJyB9LFxuICAgICAgICAgIHsgbGFiZWw6ICdBdCBSaXNrJywgdmFsdWU6ICdhdF9yaXNrJyB9LFxuICAgICAgICAgIHsgbGFiZWw6ICdDaHVybmVkJywgdmFsdWU6ICdjaHVybmVkJyB9XG4gICAgICAgIF1cbiAgICAgIH1cbiAgICBdLFxuICAgIG9wZXJhdG9yczogW1xuICAgICAgeyB2YWx1ZTogJz0nLCBsYWJlbDogJz0nIH0sXG4gICAgICB7IHZhbHVlOiAnIT0nLCBsYWJlbDogJyE9JyB9LFxuICAgICAgeyB2YWx1ZTogJz4nLCBsYWJlbDogJz4nIH0sXG4gICAgICB7IHZhbHVlOiAnPCcsIGxhYmVsOiAnPCcgfSxcbiAgICAgIHsgdmFsdWU6ICc+PScsIGxhYmVsOiAnPj0nIH0sXG4gICAgICB7IHZhbHVlOiAnPD0nLCBsYWJlbDogJzw9JyB9LFxuICAgICAgeyB2YWx1ZTogJ2NvbnRhaW5zJywgbGFiZWw6ICdjb250YWlucycgfVxuICAgIF0sXG4gICAgZGVmYXVsdENvbmRpdGlvbjogJ2FuZCdcbiAgfTtcblxuICBjdXJyZW50UXVlcnk6IFRleHRhcmVhUXVlcnlHcm91cCB8IG51bGwgPSBudWxsO1xuXG4gIG9uUXVlcnlDaGFuZ2UocXVlcnk6IFRleHRhcmVhUXVlcnlHcm91cCk6IHZvaWQge1xuICAgIHRoaXMuY3VycmVudFF1ZXJ5ID0gcXVlcnk7XG4gICAgY29uc29sZS5sb2coJ1F1ZXJ5IGNoYW5nZWQ6JywgcXVlcnkpO1xuICB9XG59XG4iXX0=
|