@vendure/admin-ui 2.0.6 → 2.0.8
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/catalog/components/collection-detail/collection-detail.component.d.ts +3 -1
- package/catalog/components/create-product-variant-dialog/create-product-variant-dialog.component.d.ts +6 -4
- package/catalog/components/facet-detail/facet-detail.component.d.ts +3 -1
- package/catalog/components/product-detail/product-detail.component.d.ts +3 -1
- package/catalog/components/product-variant-list/product-variant-list-bulk-actions.d.ts +1 -2
- package/catalog/components/stock-location-detail/stock-location-detail.component.d.ts +3 -1
- package/core/common/utilities/custom-field-default-value.d.ts +6 -0
- package/core/common/version.d.ts +1 -1
- package/core/providers/data-table/data-table-filter-collection.d.ts +10 -6
- package/core/providers/data-table/data-table-filter.d.ts +13 -2
- package/core/public_api.d.ts +1 -0
- package/core/shared/components/asset-gallery/asset-gallery.component.d.ts +2 -1
- package/core/shared/components/asset-preview/asset-preview.component.d.ts +9 -1
- package/core/shared/components/asset-preview-dialog/asset-preview-dialog.component.d.ts +2 -0
- package/customer/components/customer-detail/customer-detail.component.d.ts +3 -1
- package/customer/components/customer-group-detail/customer-group-detail.component.d.ts +3 -1
- package/customer/components/customer-list/customer-list.component.d.ts +1 -0
- package/esm2022/catalog/components/asset-detail/asset-detail.component.mjs +4 -4
- package/esm2022/catalog/components/asset-list/asset-list.component.mjs +1 -1
- package/esm2022/catalog/components/assets/assets.component.mjs +2 -2
- package/esm2022/catalog/components/collection-detail/collection-detail.component.mjs +3 -3
- package/esm2022/catalog/components/collection-list/collection-list.component.mjs +2 -1
- package/esm2022/catalog/components/create-product-variant-dialog/create-product-variant-dialog.component.mjs +8 -5
- package/esm2022/catalog/components/facet-detail/facet-detail.component.mjs +3 -3
- package/esm2022/catalog/components/facet-list/facet-list.component.mjs +2 -1
- package/esm2022/catalog/components/product-detail/product-detail.component.mjs +3 -3
- package/esm2022/catalog/components/product-list/product-list.component.mjs +2 -7
- package/esm2022/catalog/components/product-variant-detail/product-variant-detail.component.mjs +3 -3
- package/esm2022/catalog/components/product-variant-list/product-variant-list-bulk-actions.mjs +1 -1
- package/esm2022/catalog/components/product-variant-list/product-variant-list.component.mjs +2 -7
- package/esm2022/catalog/components/product-variants-editor/product-variants-editor.component.mjs +1 -1
- package/esm2022/catalog/components/stock-location-detail/stock-location-detail.component.mjs +3 -3
- package/esm2022/catalog/components/stock-location-list/stock-location-list.component.mjs +2 -7
- package/esm2022/core/common/utilities/create-updated-translatable.mjs +5 -23
- package/esm2022/core/common/utilities/custom-field-default-value.mjs +28 -0
- package/esm2022/core/common/version.mjs +2 -2
- package/esm2022/core/components/base-nav/base-nav.component.mjs +1 -1
- package/esm2022/core/components/channel-switcher/channel-switcher.component.mjs +3 -3
- package/esm2022/core/providers/dashboard-widget/register-dashboard-widget.mjs +1 -1
- package/esm2022/core/providers/data-table/data-table-filter-collection.mjs +51 -22
- package/esm2022/core/providers/data-table/data-table-filter.mjs +8 -1
- package/esm2022/core/providers/local-storage/local-storage.service.mjs +1 -1
- package/esm2022/core/public_api.mjs +2 -1
- package/esm2022/core/shared/components/action-bar-items/action-bar-items.component.mjs +1 -1
- package/esm2022/core/shared/components/asset-gallery/asset-gallery.component.mjs +8 -5
- package/esm2022/core/shared/components/asset-picker-dialog/asset-picker-dialog.component.mjs +3 -3
- package/esm2022/core/shared/components/asset-preview/asset-preview.component.mjs +36 -3
- package/esm2022/core/shared/components/asset-preview-dialog/asset-preview-dialog.component.mjs +4 -3
- package/esm2022/core/shared/components/card/card.component.mjs +1 -1
- package/esm2022/core/shared/components/chip/chip.component.mjs +2 -2
- package/esm2022/core/shared/components/data-table-2/data-table2.component.mjs +1 -1
- package/esm2022/core/shared/components/data-table-filter-label/data-table-filter-label.component.mjs +3 -3
- package/esm2022/core/shared/components/data-table-filters/data-table-filters.component.mjs +23 -4
- package/esm2022/core/shared/components/facet-value-chip/facet-value-chip.component.mjs +2 -2
- package/esm2022/core/shared/components/tabbed-custom-fields/tabbed-custom-fields.component.mjs +2 -2
- package/esm2022/customer/components/customer-detail/customer-detail.component.mjs +3 -3
- package/esm2022/customer/components/customer-group-detail/customer-group-detail.component.mjs +3 -3
- package/esm2022/customer/components/customer-group-detail-dialog/customer-group-detail-dialog.component.mjs +3 -2
- package/esm2022/customer/components/customer-group-list/customer-group-list.component.mjs +2 -1
- package/esm2022/customer/components/customer-list/customer-list.component.mjs +34 -30
- package/esm2022/dashboard/components/dashboard-widget/dashboard-widget.component.mjs +1 -1
- package/esm2022/marketing/components/promotion-detail/promotion-detail.component.mjs +3 -3
- package/esm2022/marketing/components/promotion-list/promotion-list.component.mjs +2 -1
- package/esm2022/order/components/order-detail/order-detail.component.mjs +3 -3
- package/esm2022/order/components/order-list/order-list.component.mjs +2 -1
- package/esm2022/settings/components/admin-detail/admin-detail.component.mjs +3 -3
- package/esm2022/settings/components/administrator-list/administrator-list.component.mjs +2 -1
- package/esm2022/settings/components/channel-detail/channel-detail.component.mjs +10 -10
- package/esm2022/settings/components/channel-list/channel-list.component.mjs +2 -1
- package/esm2022/settings/components/country-detail/country-detail.component.mjs +3 -3
- package/esm2022/settings/components/country-list/country-list.component.mjs +3 -2
- package/esm2022/settings/components/global-settings/global-settings.component.mjs +3 -3
- package/esm2022/settings/components/payment-method-detail/payment-method-detail.component.mjs +3 -3
- package/esm2022/settings/components/payment-method-list/payment-method-list.component.mjs +2 -1
- package/esm2022/settings/components/profile/profile.component.mjs +3 -3
- package/esm2022/settings/components/role-list/role-list.component.mjs +2 -1
- package/esm2022/settings/components/seller-detail/seller-detail.component.mjs +3 -3
- package/esm2022/settings/components/seller-list/seller-list.component.mjs +2 -1
- package/esm2022/settings/components/shipping-method-detail/shipping-method-detail.component.mjs +3 -3
- package/esm2022/settings/components/shipping-method-list/shipping-method-list.component.mjs +2 -1
- package/esm2022/settings/components/tax-category-detail/tax-category-detail.component.mjs +3 -3
- package/esm2022/settings/components/tax-category-list/tax-category-list-bulk-actions.mjs +1 -1
- package/esm2022/settings/components/tax-category-list/tax-category-list.component.mjs +2 -1
- package/esm2022/settings/components/tax-rate-detail/tax-rate-detail.component.mjs +3 -3
- package/esm2022/settings/components/tax-rate-list/tax-rate-list.component.mjs +2 -1
- package/esm2022/settings/components/zone-detail/zone-detail.component.mjs +3 -3
- package/esm2022/settings/components/zone-list/zone-list.component.mjs +2 -1
- package/esm2022/settings/settings.module.mjs +1 -1
- package/esm2022/system/components/job-state-label/job-state-label.component.mjs +1 -1
- package/fesm2022/vendure-admin-ui-catalog.mjs +22 -32
- package/fesm2022/vendure-admin-ui-catalog.mjs.map +1 -1
- package/fesm2022/vendure-admin-ui-core.mjs +165 -65
- package/fesm2022/vendure-admin-ui-core.mjs.map +1 -1
- package/fesm2022/vendure-admin-ui-customer.mjs +34 -29
- package/fesm2022/vendure-admin-ui-customer.mjs.map +1 -1
- package/fesm2022/vendure-admin-ui-dashboard.mjs.map +1 -1
- package/fesm2022/vendure-admin-ui-marketing.mjs +3 -2
- package/fesm2022/vendure-admin-ui-marketing.mjs.map +1 -1
- package/fesm2022/vendure-admin-ui-order.mjs +3 -2
- package/fesm2022/vendure-admin-ui-order.mjs.map +1 -1
- package/fesm2022/vendure-admin-ui-settings.mjs +30 -20
- package/fesm2022/vendure-admin-ui-settings.mjs.map +1 -1
- package/fesm2022/vendure-admin-ui-system.mjs.map +1 -1
- package/marketing/components/promotion-detail/promotion-detail.component.d.ts +3 -1
- package/order/components/order-detail/order-detail.component.d.ts +3 -1
- package/package.json +8 -8
- package/settings/components/admin-detail/admin-detail.component.d.ts +3 -1
- package/settings/components/channel-detail/channel-detail.component.d.ts +5 -3
- package/settings/components/country-detail/country-detail.component.d.ts +3 -1
- package/settings/components/global-settings/global-settings.component.d.ts +3 -1
- package/settings/components/payment-method-detail/payment-method-detail.component.d.ts +3 -1
- package/settings/components/profile/profile.component.d.ts +3 -1
- package/settings/components/seller-detail/seller-detail.component.d.ts +3 -1
- package/settings/components/shipping-method-detail/shipping-method-detail.component.d.ts +3 -1
- package/settings/components/tax-category-detail/tax-category-detail.component.d.ts +3 -1
- package/settings/components/tax-rate-detail/tax-rate-detail.component.d.ts +3 -1
- package/settings/components/zone-detail/zone-detail.component.d.ts +3 -1
- package/static/i18n-messages/it.json +169 -169
|
@@ -278,4 +278,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.3", ngImpor
|
|
|
278
278
|
type: ContentChildren,
|
|
279
279
|
args: [TemplateRef]
|
|
280
280
|
}] } });
|
|
281
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table2.component.js","sourceRoot":"","sources":["../../../../../../src/lib/core/src/shared/components/data-table-2/data-table2.component.ts","../../../../../../src/lib/core/src/shared/components/data-table-2/data-table2.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEH,uBAAuB,EAEvB,SAAS,EACT,YAAY,EACZ,eAAe,EACf,YAAY,EACZ,KAAK,EAGL,MAAM,EAGN,WAAW,GACd,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAEnD,OAAO,EAAE,oBAAoB,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AAK3D,OAAO,EAAE,uBAAuB,EAAE,MAAM,gDAAgD,CAAC;AAEzF,OAAO,EAAE,yBAAyB,EAAE,MAAM,+BAA+B,CAAC;AAC1E,OAAO,EAAE,mCAAmC,EAAE,MAAM,4CAA4C,CAAC;AACjG,OAAO,EAAE,yBAAyB,EAAE,MAAM,+BAA+B,CAAC;;;;;;;;;;;;;;AAE1E;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6DG;AAQH,MAAM,OAAO,mBAAmB;IA6B5B,YACc,iBAAoC,EACpC,mBAAwC,EACxC,WAAwB;QAFxB,sBAAiB,GAAjB,iBAAiB,CAAmB;QACpC,wBAAmB,GAAnB,mBAAmB,CAAqB;QACxC,gBAAW,GAAX,WAAW,CAAa;QAxB7B,gBAAW,GAAG,CAAC,CAAC,CAAC;QAChB,eAAU,GAAG,IAAI,YAAY,EAAU,CAAC;QACxC,uBAAkB,GAAG,IAAI,YAAY,EAAU,CAAC;QAY1D,qEAAqE;QACrE,+CAA+C;QAC/C,kBAAa,GAAG,KAAK,CAAC;QACtB,wBAAmB,GAAG,KAAK,CAAC;QAwCpB,qBAAgB,GAAG,CAAC,KAAoB,EAAE,EAAE;YAChD,IAAI,KAAK,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE;gBACvC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;gBAC1B,IAAI,CAAC,iBAAiB,CAAC,YAAY,EAAE,CAAC;aACzC;QACL,CAAC,CAAC;QAEM,mBAAc,GAAG,CAAC,KAAoB,EAAE,EAAE;YAC9C,IAAI,IAAI,CAAC,aAAa,EAAE;gBACpB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;gBAC3B,IAAI,CAAC,iBAAiB,CAAC,YAAY,EAAE,CAAC;aACzC;QACL,CAAC,CAAC;QA3CE,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM;aACrC,OAAO,EAAE;aACT,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC;IAC9D,CAAC;IAED,IAAI,gBAAgB;QAChB,OAAO,IAAI,CAAC,uBAAuB,EAAE,gBAAgB,CAAC;IAC1D,CAAC;IAED,IAAI,UAAU;QACV,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,IAAI,EAAE,CAAC,EAAE,GAAG,CAAC,IAAI,CAAC,kBAAkB,IAAI,EAAE,CAAC,CAAC,CAAC;IACzE,CAAC;IAED,IAAI,oBAAoB;QACpB,OAAO,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;IACrD,CAAC;IAED,IAAI,aAAa;QACb,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC;QAChC,MAAM,eAAe,GAAG,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAClD,KAAK,MAAM,CAAC,EAAE,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,EAAE;YACtE,MAAM,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;YAC9C,MAAM,YAAY,GAAG,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;YACzD,IAAI,YAAY,KAAK,CAAC,CAAC,IAAI,MAAM,EAAE;gBAC/B,OAAO,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC;gBAChC,OAAO,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC;aACpC;SACJ;QACD,OAAO,OAAO,CAAC;IACnB,CAAC;IAgBD,WAAW,CAAC,OAAsB;QAC9B,IAAI,OAAO,CAAC,KAAK,EAAE;YACf,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,GAAG,CAAC,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC,CAAC;YAC/D,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC,KAAK,CAAC,YAAY,EAAE,MAAM,CAAC;YACzE,IAAI,CAAC,gBAAgB,EAAE,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SACtD;IACL,CAAC;IAED,WAAW;QACP,IAAI,IAAI,CAAC,gBAAgB,EAAE;YACvB,QAAQ,CAAC,mBAAmB,CAAC,SAAS,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;YAC/D,QAAQ,CAAC,mBAAmB,CAAC,OAAO,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;SAC9D;QACD,IAAI,CAAC,YAAY,EAAE,WAAW,EAAE,CAAC;IACrC,CAAC;IAED,kBAAkB;QACd,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC;QAC1C,MAAM,eAAe,GAAG,IAAI,CAAC,mBAAmB,CAAC,GAAG,CAAC,iBAAiB,CAAC,IAAI,EAAE,CAAC;QAE9E,IAAI,CAAC,IAAI,CAAC,EAAE,EAAE;YACV,OAAO,CAAC,IAAI,CAAC,gDAAgD,CAAC,CAAC;SAClE;QACD,MAAM,sBAAsB,GAAG,GAAG,EAAE;YAChC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE;gBAC3B,eAAe,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE,UAAU,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,mBAAmB,EAAE,KAAK,EAAE,CAAC;aACxF;YACD,eAAe,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU;iBAChD,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,OAAO,IAAI,CAAC,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,OAAO,IAAI,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC;iBACnF,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;YACpB,IAAI,CAAC,mBAAmB,CAAC,GAAG,CAAC,iBAAiB,EAAE,eAAe,CAAC,CAAC;QACrE,CAAC,CAAC;QAEF,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;YAC7B,IAAI,eAAe,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,UAAU,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE;gBAC5D,MAAM,CAAC,aAAa,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;aAChD;YACD,MAAM,CAAC,cAAc,CAAC,sBAAsB,CAAC,CAAC;QAClD,CAAC,CAAC,CAAC;QAEH,IAAI,IAAI,CAAC,gBAAgB,EAAE;YACvB,QAAQ,CAAC,gBAAgB,CAAC,SAAS,EAAE,IAAI,CAAC,gBAAgB,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;YAC/E,QAAQ,CAAC,gBAAgB,CAAC,OAAO,EAAE,IAAI,CAAC,cAAc,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;YAC3E,IAAI,CAAC,uBAAuB,CAAC,gBAAgB,CAAC,GAAG,EAAE;gBAC/C,IAAI,CAAC,iBAAiB,CAAC,YAAY,EAAE,CAAC;YAC1C,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SACrD;QACD,IAAI,CAAC,mBAAmB,GAAG,eAAe,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,mBAAmB,IAAI,KAAK,CAAC;QACpF,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,SAAS,CAAC,GAAG,EAAE;YAChC,IAAI,CAAC,iBAAiB,CAAC,YAAY,EAAE,CAAC;QAC1C,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,gBAAgB,EAAE,iBAAiB,CAAC,SAAS,CAAC,GAAG,EAAE,CACxE,IAAI,CAAC,iBAAiB,CAAC,YAAY,EAAE,CACxC,CAAC;QAEF,IAAI,IAAI,CAAC,gBAAgB,IAAI,IAAI,CAAC,YAAY,EAAE;YAC5C,MAAM,UAAU,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM;iBACrC,UAAU,EAAE;iBACZ,SAAS,CAAC,CAAC,EAAE,UAAU,EAAE,EAAE,EAAE,CAAC,UAAU,CAAC,eAAe,CAAC;iBACzD,IAAI,CAAC,oBAAoB,EAAE,CAAC;iBAC5B,SAAS,CAAC,eAAe,CAAC,EAAE;gBACzB,IAAI,CAAC,gBAAgB,EAAE,cAAc,EAAE,CAAC;YAC5C,CAAC,CAAC,CAAC;YACP,IAAI,CAAC,YAAY,EAAE,GAAG,CAAC,UAAU,CAAC,CAAC;SACtC;IACL,CAAC;IAED,eAAe,CAAC,KAAmE;QAC/E,MAAM,YAAY,GAAG,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QAC9E,MAAM,eAAe,GAAG,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAClD,IAAI,YAAY,KAAK,KAAK,CAAC,QAAQ,EAAE;YACjC,OAAO,eAAe,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;SAC1D;aAAM;YACH,eAAe,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC;SACpE;QACD,IAAI,CAAC,mBAAmB,CAAC,GAAG,CAAC,iBAAiB,EAAE,eAAe,CAAC,CAAC;IACrE,CAAC;IAED,cAAc;QACV,MAAM,eAAe,GAAG,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAClD,eAAe,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,KAAK,GAAG,EAAE,CAAC;QACpC,eAAe,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,UAAU,GAAG,EAAE,CAAC;QACzC,IAAI,CAAC,mBAAmB,CAAC,GAAG,CAAC,iBAAiB,EAAE,eAAe,CAAC,CAAC;IACrE,CAAC;IAED,qBAAqB;QACjB,IAAI,CAAC,mBAAmB,GAAG,CAAC,IAAI,CAAC,mBAAmB,CAAC;QACrD,MAAM,eAAe,GAAG,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAClD,eAAe,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,mBAAmB,GAAG,IAAI,CAAC,mBAAmB,CAAC;QACxE,IAAI,CAAC,mBAAmB,CAAC,GAAG,CAAC,iBAAiB,EAAE,eAAe,CAAC,CAAC;IACrE,CAAC;IAED,SAAS,CAAC,KAAa,EAAE,IAAS;QAC9B,IAAK,IAAY,CAAC,EAAE,IAAI,IAAI,EAAE;YAC1B,OAAQ,IAAY,CAAC,EAAE,CAAC;SAC3B;aAAM;YACH,OAAO,KAAK,CAAC;SAChB;IACL,CAAC;IAED,gBAAgB;QACZ,IAAI,CAAC,gBAAgB,EAAE,eAAe,EAAE,CAAC;IAC7C,CAAC;IAED,UAAU,CAAC,IAAO,EAAE,KAAiB;QACjC,IAAI,CAAC,gBAAgB,EAAE,eAAe,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;IACxD,CAAC;IAES,kBAAkB;QACxB,MAAM,eAAe,GAAG,IAAI,CAAC,mBAAmB,CAAC,GAAG,CAAC,iBAAiB,CAAC,IAAI,EAAE,CAAC;QAC9E,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE;YAC3B,eAAe,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE,UAAU,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,mBAAmB,EAAE,KAAK,EAAE,CAAC;SACxF;QACD,OAAO,eAAe,CAAC;IAC3B,CAAC;8GAnMQ,mBAAmB;kGAAnB,mBAAmB,0UAFjB,CAAC,iBAAiB,CAAC,uEAiBhB,yBAAyB,0FACzB,uBAAuB,0KAJpB,yBAAyB,qDACzB,mCAAmC,+CAKnC,WAAW,kDCpHhC,u9NA8IA;;2FD5Ca,mBAAmB;kBAP/B,SAAS;+BACI,kBAAkB,mBAGX,uBAAuB,CAAC,MAAM,aACpC,CAAC,iBAAiB,CAAC;oKAGrB,EAAE;sBAAV,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACI,UAAU;sBAAnB,MAAM;gBACG,kBAAkB;sBAA3B,MAAM;gBAEqC,OAAO;sBAAlD,eAAe;uBAAC,yBAAyB;gBAE1C,kBAAkB;sBADjB,eAAe;uBAAC,mCAAmC;gBAEX,eAAe;sBAAvD,YAAY;uBAAC,yBAAyB;gBACA,uBAAuB;sBAA7D,YAAY;uBAAC,uBAAuB;gBACD,oBAAoB;sBAAvD,YAAY;uBAAC,oBAAoB;gBACJ,YAAY;sBAAzC,eAAe;uBAAC,WAAW","sourcesContent":["import {\n    AfterContentInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    ContentChildren,\n    EventEmitter,\n    Input,\n    OnChanges,\n    OnDestroy,\n    Output,\n    QueryList,\n    SimpleChanges,\n    TemplateRef,\n} from '@angular/core';\nimport { PaginationService } from 'ngx-pagination';\nimport { Observable, Subscription } from 'rxjs';\nimport { distinctUntilChanged, map } from 'rxjs/operators';\nimport { LanguageCode } from '../../../common/generated-types';\nimport { DataService } from '../../../data/providers/data.service';\nimport { DataTableFilterCollection } from '../../../providers/data-table/data-table-filter-collection';\nimport { DataTableConfig, LocalStorageService } from '../../../providers/local-storage/local-storage.service';\nimport { BulkActionMenuComponent } from '../bulk-action-menu/bulk-action-menu.component';\n\nimport { DataTable2ColumnComponent } from './data-table-column.component';\nimport { DataTableCustomFieldColumnComponent } from './data-table-custom-field-column.component';\nimport { DataTable2SearchComponent } from './data-table-search.component';\n\n/**\n * @description\n * A table for displaying PaginatedList results. It is designed to be used inside components which\n * extend the {@link BaseListComponent} or {@link TypedBaseListComponent} class.\n *\n * @example\n * ```HTML\n * <vdr-data-table-2\n *     id=\"product-review-list\"\n *     [items]=\"items$ | async\"\n *     [itemsPerPage]=\"itemsPerPage$ | async\"\n *     [totalItems]=\"totalItems$ | async\"\n *     [currentPage]=\"currentPage$ | async\"\n *     [filters]=\"filters\"\n *     (pageChange)=\"setPageNumber($event)\"\n *     (itemsPerPageChange)=\"setItemsPerPage($event)\"\n * >\n *     <vdr-bulk-action-menu\n *         locationId=\"product-review-list\"\n *         [hostComponent]=\"this\"\n *         [selectionManager]=\"selectionManager\"\n *     />\n *     <vdr-dt2-search\n *         [searchTermControl]=\"searchTermControl\"\n *         searchTermPlaceholder=\"Filter by title\"\n *     />\n *     <vdr-dt2-column [heading]=\"'common.id' | translate\" [hiddenByDefault]=\"true\">\n *         <ng-template let-review=\"item\">\n *             {{ review.id }}\n *         </ng-template>\n *     </vdr-dt2-column>\n *     <vdr-dt2-column\n *         [heading]=\"'common.created-at' | translate\"\n *         [hiddenByDefault]=\"true\"\n *         [sort]=\"sorts.get('createdAt')\"\n *     >\n *         <ng-template let-review=\"item\">\n *             {{ review.createdAt | localeDate : 'short' }}\n *         </ng-template>\n *     </vdr-dt2-column>\n *     <vdr-dt2-column\n *         [heading]=\"'common.updated-at' | translate\"\n *         [hiddenByDefault]=\"true\"\n *         [sort]=\"sorts.get('updatedAt')\"\n *     >\n *         <ng-template let-review=\"item\">\n *             {{ review.updatedAt | localeDate : 'short' }}\n *         </ng-template>\n *     </vdr-dt2-column>\n *     <vdr-dt2-column [heading]=\"'common.name' | translate\" [optional]=\"false\" [sort]=\"sorts.get('name')\">\n *         <ng-template let-review=\"item\">\n *             <a class=\"button-ghost\" [routerLink]=\"['./', review.id]\"\n *                 ><span>{{ review.name }}</span>\n *                 <clr-icon shape=\"arrow right\"></clr-icon>\n *             </a>\n *         </ng-template>\n *     </vdr-dt2-column>\n * </vdr-data-table-2>\n * ```\n *\n * @docsCategory components\n */\n@Component({\n    selector: 'vdr-data-table-2',\n    templateUrl: 'data-table2.component.html',\n    styleUrls: ['data-table2.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [PaginationService],\n})\nexport class DataTable2Component<T> implements AfterContentInit, OnChanges, OnDestroy {\n    @Input() id: string;\n    @Input() items: T[];\n    @Input() itemsPerPage: number;\n    @Input() currentPage: number;\n    @Input() totalItems: number;\n    @Input() emptyStateLabel: string;\n    @Input() filters: DataTableFilterCollection;\n    @Input() activeIndex = -1;\n    @Output() pageChange = new EventEmitter<number>();\n    @Output() itemsPerPageChange = new EventEmitter<number>();\n\n    @ContentChildren(DataTable2ColumnComponent) columns: QueryList<DataTable2ColumnComponent<T>>;\n    @ContentChildren(DataTableCustomFieldColumnComponent)\n    customFieldColumns: QueryList<DataTableCustomFieldColumnComponent<T>>;\n    @ContentChild(DataTable2SearchComponent) searchComponent: DataTable2SearchComponent;\n    @ContentChild(BulkActionMenuComponent) bulkActionMenuComponent: BulkActionMenuComponent;\n    @ContentChild('vdrDt2CustomSearch') customSearchTemplate: TemplateRef<any>;\n    @ContentChildren(TemplateRef) templateRefs: QueryList<TemplateRef<any>>;\n    rowTemplate: TemplateRef<any>;\n    currentStart: number;\n    currentEnd: number;\n    // This is used to apply a `user-select: none` CSS rule to the table,\n    // which allows shift-click multi-row selection\n    disableSelect = false;\n    showSearchFilterRow = false;\n    protected uiLanguage$: Observable<LanguageCode>;\n    private subscription: Subscription | undefined;\n\n    constructor(\n        protected changeDetectorRef: ChangeDetectorRef,\n        protected localStorageService: LocalStorageService,\n        protected dataService: DataService,\n    ) {\n        this.uiLanguage$ = this.dataService.client\n            .uiState()\n            .stream$.pipe(map(({ uiState }) => uiState.language));\n    }\n\n    get selectionManager() {\n        return this.bulkActionMenuComponent?.selectionManager;\n    }\n\n    get allColumns() {\n        return [...(this.columns ?? []), ...(this.customFieldColumns ?? [])];\n    }\n\n    get visibleSortedColumns() {\n        return this.sortedColumns.filter(c => c.visible);\n    }\n\n    get sortedColumns() {\n        const columns = this.allColumns;\n        const dataTableConfig = this.getDataTableConfig();\n        for (const [id, index] of Object.entries(dataTableConfig[this.id].order)) {\n            const column = columns.find(c => c.id === id);\n            const currentIndex = columns.findIndex(c => c.id === id);\n            if (currentIndex !== -1 && column) {\n                columns.splice(currentIndex, 1);\n                columns.splice(index, 0, column);\n            }\n        }\n        return columns;\n    }\n\n    private shiftDownHandler = (event: KeyboardEvent) => {\n        if (event.shiftKey && !this.disableSelect) {\n            this.disableSelect = true;\n            this.changeDetectorRef.markForCheck();\n        }\n    };\n\n    private shiftUpHandler = (event: KeyboardEvent) => {\n        if (this.disableSelect) {\n            this.disableSelect = false;\n            this.changeDetectorRef.markForCheck();\n        }\n    };\n\n    ngOnChanges(changes: SimpleChanges) {\n        if (changes.items) {\n            this.currentStart = this.itemsPerPage * (this.currentPage - 1);\n            this.currentEnd = this.currentStart + changes.items.currentValue?.length;\n            this.selectionManager?.setCurrentItems(this.items);\n        }\n    }\n\n    ngOnDestroy() {\n        if (this.selectionManager) {\n            document.removeEventListener('keydown', this.shiftDownHandler);\n            document.removeEventListener('keyup', this.shiftUpHandler);\n        }\n        this.subscription?.unsubscribe();\n    }\n\n    ngAfterContentInit(): void {\n        this.rowTemplate = this.templateRefs.last;\n        const dataTableConfig = this.localStorageService.get('dataTableConfig') ?? {};\n\n        if (!this.id) {\n            console.warn(`No id was assigned to the data table component`);\n        }\n        const updateColumnVisibility = () => {\n            if (!dataTableConfig[this.id]) {\n                dataTableConfig[this.id] = { visibility: [], order: {}, showSearchFilterRow: false };\n            }\n            dataTableConfig[this.id].visibility = this.allColumns\n                .filter(c => (c.visible && c.hiddenByDefault) || (!c.visible && !c.hiddenByDefault))\n                .map(c => c.id);\n            this.localStorageService.set('dataTableConfig', dataTableConfig);\n        };\n\n        this.allColumns.forEach(column => {\n            if (dataTableConfig?.[this.id]?.visibility.includes(column.id)) {\n                column.setVisibility(column.hiddenByDefault);\n            }\n            column.onColumnChange(updateColumnVisibility);\n        });\n\n        if (this.selectionManager) {\n            document.addEventListener('keydown', this.shiftDownHandler, { passive: true });\n            document.addEventListener('keyup', this.shiftUpHandler, { passive: true });\n            this.bulkActionMenuComponent.onClearSelection(() => {\n                this.changeDetectorRef.markForCheck();\n            });\n            this.selectionManager.setCurrentItems(this.items);\n        }\n        this.showSearchFilterRow = dataTableConfig?.[this.id]?.showSearchFilterRow ?? false;\n        this.columns.changes.subscribe(() => {\n            this.changeDetectorRef.markForCheck();\n        });\n\n        this.subscription = this.selectionManager?.selectionChanges$.subscribe(() =>\n            this.changeDetectorRef.markForCheck(),\n        );\n\n        if (this.selectionManager && this.subscription) {\n            const channelSub = this.dataService.client\n                .userStatus()\n                .mapStream(({ userStatus }) => userStatus.activeChannelId)\n                .pipe(distinctUntilChanged())\n                .subscribe(activeChannelId => {\n                    this.selectionManager?.clearSelection();\n                });\n            this.subscription?.add(channelSub);\n        }\n    }\n\n    onColumnReorder(event: { column: DataTable2ColumnComponent<any>; newIndex: number }) {\n        const naturalIndex = this.allColumns.findIndex(c => c.id === event.column.id);\n        const dataTableConfig = this.getDataTableConfig();\n        if (naturalIndex === event.newIndex) {\n            delete dataTableConfig[this.id].order[event.column.id];\n        } else {\n            dataTableConfig[this.id].order[event.column.id] = event.newIndex;\n        }\n        this.localStorageService.set('dataTableConfig', dataTableConfig);\n    }\n\n    onColumnsReset() {\n        const dataTableConfig = this.getDataTableConfig();\n        dataTableConfig[this.id].order = {};\n        dataTableConfig[this.id].visibility = [];\n        this.localStorageService.set('dataTableConfig', dataTableConfig);\n    }\n\n    toggleSearchFilterRow() {\n        this.showSearchFilterRow = !this.showSearchFilterRow;\n        const dataTableConfig = this.getDataTableConfig();\n        dataTableConfig[this.id].showSearchFilterRow = this.showSearchFilterRow;\n        this.localStorageService.set('dataTableConfig', dataTableConfig);\n    }\n\n    trackByFn(index: number, item: any) {\n        if ((item as any).id != null) {\n            return (item as any).id;\n        } else {\n            return index;\n        }\n    }\n\n    onToggleAllClick() {\n        this.selectionManager?.toggleSelectAll();\n    }\n\n    onRowClick(item: T, event: MouseEvent) {\n        this.selectionManager?.toggleSelection(item, event);\n    }\n\n    protected getDataTableConfig(): DataTableConfig {\n        const dataTableConfig = this.localStorageService.get('dataTableConfig') ?? {};\n        if (!dataTableConfig[this.id]) {\n            dataTableConfig[this.id] = { visibility: [], order: {}, showSearchFilterRow: false };\n        }\n        return dataTableConfig;\n    }\n}\n","<div class=\"bulk-actions\">\r\n    <ng-content select=\"vdr-bulk-action-menu\"></ng-content>\r\n</div>\r\n<div class=\"table-wrapper\">\r\n    <table\r\n        class=\"\"\r\n        [class.no-select]=\"disableSelect\"\r\n    >\r\n        <thead [class.items-selected]=\"selectionManager?.selection.length\">\r\n            <tr class=\"heading-row\">\r\n                <th *ngIf=\"selectionManager\" class=\"selection-col\">\r\n                    <input\r\n                        type=\"checkbox\"\r\n                        clrCheckbox\r\n                        [checked]=\"selectionManager?.areAllCurrentItemsSelected()\"\r\n                        (change)=\"onToggleAllClick()\"\r\n                    />\r\n                </th>\r\n                <th\r\n                    *ngFor=\"let column of visibleSortedColumns; last as isLast\"\r\n                    [class.expand]=\"column.expand\"\r\n                >\r\n                    <div class=\"cell-content\" [ngClass]=\"column.align\">\r\n                        <span>{{ column.heading }}</span>\r\n                        <div *ngIf=\"column.sort as sort\" class=\"sort-toggle\">\r\n                            <button (click)=\"sort.toggleSortOrder()\" [class.active]=\"sort.sortOrder\">\r\n                                <clr-icon *ngIf=\"!sort.sortOrder\" shape=\"two-way-arrows left\"></clr-icon>\r\n                                <clr-icon *ngIf=\"sort.sortOrder === 'ASC'\" shape=\"arrow up\"></clr-icon>\r\n                                <clr-icon *ngIf=\"sort.sortOrder === 'DESC'\" shape=\"arrow down\"></clr-icon>\r\n                            </button>\r\n                            <div class=\"sort-label\" *ngIf=\"sort.sortOrder\">{{ sort.sortOrder }}</div>\r\n                        </div>\r\n                    </div>\r\n                </th>\r\n                <th>\r\n                    <div class=\"column-picker\">\r\n                        <vdr-data-table-colum-picker\r\n                            [uiLanguage]=\"uiLanguage$ | async\"\r\n                            [columns]=\"sortedColumns\"\r\n                            (reorder)=\"onColumnReorder($event)\"\r\n                            (resetColumns)=\"onColumnsReset()\"\r\n                        ></vdr-data-table-colum-picker>\r\n                    </div>\r\n                </th>\r\n            </tr>\r\n            <tr *ngIf=\"searchComponent || customSearchTemplate || filters?.length\">\r\n                <th\r\n                    [attr.colspan]=\"visibleSortedColumns.length + (selectionManager ? 2 : 1)\"\r\n                    class=\"filter-row\"\r\n                    [class.active]=\"showSearchFilterRow\"\r\n                >\r\n                    <button\r\n                        class=\"button-ghost toggle-search-filter-row\"\r\n                        [class.active]=\"showSearchFilterRow\"\r\n                        (click)=\"toggleSearchFilterRow()\"\r\n                        [title]=\"'common.search-and-filter-list' | translate\"\r\n                    >\r\n                        <clr-icon shape=\"search\"></clr-icon>\r\n                    </button>\r\n                    <div class=\"filter-row-wrapper\" [class.hidden]=\"!showSearchFilterRow\">\r\n                        <ng-container *ngTemplateOutlet=\"searchComponent?.template\"></ng-container>\r\n                        <ng-container *ngTemplateOutlet=\"customSearchTemplate\"></ng-container>\r\n                        <ng-container *ngIf=\"filters\">\r\n                            <div class=\"filters\">\r\n                                <vdr-data-table-filters\r\n                                    *ngFor=\"let activeFilter of filters.activeFilters\"\r\n                                    [filterWithValue]=\"activeFilter\"\r\n                                    [filters]=\"filters\"\r\n                                    class=\"mt-1\"\r\n                                ></vdr-data-table-filters>\r\n                                <vdr-data-table-filters\r\n                                    *ngIf=\"filters.length\"\r\n                                    [filters]=\"filters\"\r\n                                    class=\"mt-1\"\r\n                                ></vdr-data-table-filters>\r\n                            </div>\r\n                        </ng-container>\r\n                    </div>\r\n                </th>\r\n            </tr>\r\n        </thead>\r\n        <tbody>\r\n            <tr\r\n                *ngFor=\"\r\n                    let item of items\r\n                        | paginate\r\n                            : {\r\n                                  id: id,\r\n                                  itemsPerPage: itemsPerPage,\r\n                                  currentPage: currentPage,\r\n                                  totalItems: totalItems\r\n                              };\r\n                    index as i;\r\n                    trackBy: trackByFn\r\n                \"\r\n            >\r\n                <td *ngIf=\"selectionManager\" class=\"selection-col\" [class.active]=\"activeIndex === i\">\r\n                    <input\r\n                        type=\"checkbox\"\r\n                        clrCheckbox\r\n                        [checked]=\"selectionManager?.isSelected(item)\"\r\n                        (click)=\"onRowClick(item, $event)\"\r\n                    />\r\n                </td>\r\n                <td *ngFor=\"let column of visibleSortedColumns\" [class.active]=\"activeIndex === i\">\r\n                    <div class=\"cell-content\" [ngClass]=\"column.align\">\r\n                        <ng-container\r\n                            *ngTemplateOutlet=\"column.template; context: { item: item, index: i }\"\r\n                        ></ng-container>\r\n                    </div>\r\n                </td>\r\n                <td [class.active]=\"activeIndex === i\"><!-- column select --></td>\r\n            </tr>\r\n            <ng-container>\r\n                <tr *ngIf=\"!items?.length\">\r\n                    <td [attr.colspan]=\"visibleSortedColumns.length + (selectionManager ? 2 : 1)\">\r\n                        <vdr-empty-placeholder [emptyStateLabel]=\"emptyStateLabel\"></vdr-empty-placeholder>\r\n                    </td>\r\n                </tr>\r\n            </ng-container>\r\n        </tbody>\r\n    </table>\r\n</div>\r\n<div class=\"table-footer\">\r\n    <vdr-items-per-page-controls\r\n        *ngIf=\"totalItems\"\r\n        [itemsPerPage]=\"itemsPerPage\"\r\n        (itemsPerPageChange)=\"itemsPerPageChange.emit($event)\"\r\n    ></vdr-items-per-page-controls>\r\n    <div *ngIf=\"totalItems\" class=\"total-items-count\">\r\n        {{ 'common.total-items' | translate : { currentStart, currentEnd, totalItems } }}\r\n    </div>\r\n\r\n    <vdr-pagination-controls\r\n        *ngIf=\"totalItems\"\r\n        [id]=\"id\"\r\n        [currentPage]=\"currentPage\"\r\n        [itemsPerPage]=\"itemsPerPage\"\r\n        [totalItems]=\"totalItems\"\r\n        (pageChange)=\"pageChange.emit($event)\"\r\n    ></vdr-pagination-controls>\r\n</div>\r\n"]}
|
|
281
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table2.component.js","sourceRoot":"","sources":["../../../../../../src/lib/core/src/shared/components/data-table-2/data-table2.component.ts","../../../../../../src/lib/core/src/shared/components/data-table-2/data-table2.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    AfterContentInit,\r\n    ChangeDetectionStrategy,\r\n    ChangeDetectorRef,\r\n    Component,\r\n    ContentChild,\r\n    ContentChildren,\r\n    EventEmitter,\r\n    Input,\r\n    OnChanges,\r\n    OnDestroy,\r\n    Output,\r\n    QueryList,\r\n    SimpleChanges,\r\n    TemplateRef,\r\n} from '@angular/core';\r\nimport { PaginationService } from 'ngx-pagination';\r\nimport { Observable, Subscription } from 'rxjs';\r\nimport { distinctUntilChanged, map } from 'rxjs/operators';\r\nimport { LanguageCode } from '../../../common/generated-types';\r\nimport { DataService } from '../../../data/providers/data.service';\r\nimport { DataTableFilterCollection } from '../../../providers/data-table/data-table-filter-collection';\r\nimport { DataTableConfig, LocalStorageService } from '../../../providers/local-storage/local-storage.service';\r\nimport { BulkActionMenuComponent } from '../bulk-action-menu/bulk-action-menu.component';\r\n\r\nimport { DataTable2ColumnComponent } from './data-table-column.component';\r\nimport { DataTableCustomFieldColumnComponent } from './data-table-custom-field-column.component';\r\nimport { DataTable2SearchComponent } from './data-table-search.component';\r\n\r\n/**\r\n * @description\r\n * A table for displaying PaginatedList results. It is designed to be used inside components which\r\n * extend the {@link BaseListComponent} or {@link TypedBaseListComponent} class.\r\n *\r\n * @example\r\n * ```HTML\r\n * <vdr-data-table-2\r\n *     id=\"product-review-list\"\r\n *     [items]=\"items$ | async\"\r\n *     [itemsPerPage]=\"itemsPerPage$ | async\"\r\n *     [totalItems]=\"totalItems$ | async\"\r\n *     [currentPage]=\"currentPage$ | async\"\r\n *     [filters]=\"filters\"\r\n *     (pageChange)=\"setPageNumber($event)\"\r\n *     (itemsPerPageChange)=\"setItemsPerPage($event)\"\r\n * >\r\n *     <vdr-bulk-action-menu\r\n *         locationId=\"product-review-list\"\r\n *         [hostComponent]=\"this\"\r\n *         [selectionManager]=\"selectionManager\"\r\n *     />\r\n *     <vdr-dt2-search\r\n *         [searchTermControl]=\"searchTermControl\"\r\n *         searchTermPlaceholder=\"Filter by title\"\r\n *     />\r\n *     <vdr-dt2-column [heading]=\"'common.id' | translate\" [hiddenByDefault]=\"true\">\r\n *         <ng-template let-review=\"item\">\r\n *             {{ review.id }}\r\n *         </ng-template>\r\n *     </vdr-dt2-column>\r\n *     <vdr-dt2-column\r\n *         [heading]=\"'common.created-at' | translate\"\r\n *         [hiddenByDefault]=\"true\"\r\n *         [sort]=\"sorts.get('createdAt')\"\r\n *     >\r\n *         <ng-template let-review=\"item\">\r\n *             {{ review.createdAt | localeDate : 'short' }}\r\n *         </ng-template>\r\n *     </vdr-dt2-column>\r\n *     <vdr-dt2-column\r\n *         [heading]=\"'common.updated-at' | translate\"\r\n *         [hiddenByDefault]=\"true\"\r\n *         [sort]=\"sorts.get('updatedAt')\"\r\n *     >\r\n *         <ng-template let-review=\"item\">\r\n *             {{ review.updatedAt | localeDate : 'short' }}\r\n *         </ng-template>\r\n *     </vdr-dt2-column>\r\n *     <vdr-dt2-column [heading]=\"'common.name' | translate\" [optional]=\"false\" [sort]=\"sorts.get('name')\">\r\n *         <ng-template let-review=\"item\">\r\n *             <a class=\"button-ghost\" [routerLink]=\"['./', review.id]\"\r\n *                 ><span>{{ review.name }}</span>\r\n *                 <clr-icon shape=\"arrow right\"></clr-icon>\r\n *             </a>\r\n *         </ng-template>\r\n *     </vdr-dt2-column>\r\n * </vdr-data-table-2>\r\n * ```\r\n *\r\n * @docsCategory components\r\n */\r\n@Component({\r\n    selector: 'vdr-data-table-2',\r\n    templateUrl: 'data-table2.component.html',\r\n    styleUrls: ['data-table2.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    providers: [PaginationService],\r\n})\r\nexport class DataTable2Component<T> implements AfterContentInit, OnChanges, OnDestroy {\r\n    @Input() id: string;\r\n    @Input() items: T[];\r\n    @Input() itemsPerPage: number;\r\n    @Input() currentPage: number;\r\n    @Input() totalItems: number;\r\n    @Input() emptyStateLabel: string;\r\n    @Input() filters: DataTableFilterCollection;\r\n    @Input() activeIndex = -1;\r\n    @Output() pageChange = new EventEmitter<number>();\r\n    @Output() itemsPerPageChange = new EventEmitter<number>();\r\n\r\n    @ContentChildren(DataTable2ColumnComponent) columns: QueryList<DataTable2ColumnComponent<T>>;\r\n    @ContentChildren(DataTableCustomFieldColumnComponent)\r\n    customFieldColumns: QueryList<DataTableCustomFieldColumnComponent<T>>;\r\n    @ContentChild(DataTable2SearchComponent) searchComponent: DataTable2SearchComponent;\r\n    @ContentChild(BulkActionMenuComponent) bulkActionMenuComponent: BulkActionMenuComponent;\r\n    @ContentChild('vdrDt2CustomSearch') customSearchTemplate: TemplateRef<any>;\r\n    @ContentChildren(TemplateRef) templateRefs: QueryList<TemplateRef<any>>;\r\n    rowTemplate: TemplateRef<any>;\r\n    currentStart: number;\r\n    currentEnd: number;\r\n    // This is used to apply a `user-select: none` CSS rule to the table,\r\n    // which allows shift-click multi-row selection\r\n    disableSelect = false;\r\n    showSearchFilterRow = false;\r\n    protected uiLanguage$: Observable<LanguageCode>;\r\n    private subscription: Subscription | undefined;\r\n\r\n    constructor(\r\n        protected changeDetectorRef: ChangeDetectorRef,\r\n        protected localStorageService: LocalStorageService,\r\n        protected dataService: DataService,\r\n    ) {\r\n        this.uiLanguage$ = this.dataService.client\r\n            .uiState()\r\n            .stream$.pipe(map(({ uiState }) => uiState.language));\r\n    }\r\n\r\n    get selectionManager() {\r\n        return this.bulkActionMenuComponent?.selectionManager;\r\n    }\r\n\r\n    get allColumns() {\r\n        return [...(this.columns ?? []), ...(this.customFieldColumns ?? [])];\r\n    }\r\n\r\n    get visibleSortedColumns() {\r\n        return this.sortedColumns.filter(c => c.visible);\r\n    }\r\n\r\n    get sortedColumns() {\r\n        const columns = this.allColumns;\r\n        const dataTableConfig = this.getDataTableConfig();\r\n        for (const [id, index] of Object.entries(dataTableConfig[this.id].order)) {\r\n            const column = columns.find(c => c.id === id);\r\n            const currentIndex = columns.findIndex(c => c.id === id);\r\n            if (currentIndex !== -1 && column) {\r\n                columns.splice(currentIndex, 1);\r\n                columns.splice(index, 0, column);\r\n            }\r\n        }\r\n        return columns;\r\n    }\r\n\r\n    private shiftDownHandler = (event: KeyboardEvent) => {\r\n        if (event.shiftKey && !this.disableSelect) {\r\n            this.disableSelect = true;\r\n            this.changeDetectorRef.markForCheck();\r\n        }\r\n    };\r\n\r\n    private shiftUpHandler = (event: KeyboardEvent) => {\r\n        if (this.disableSelect) {\r\n            this.disableSelect = false;\r\n            this.changeDetectorRef.markForCheck();\r\n        }\r\n    };\r\n\r\n    ngOnChanges(changes: SimpleChanges) {\r\n        if (changes.items) {\r\n            this.currentStart = this.itemsPerPage * (this.currentPage - 1);\r\n            this.currentEnd = this.currentStart + changes.items.currentValue?.length;\r\n            this.selectionManager?.setCurrentItems(this.items);\r\n        }\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        if (this.selectionManager) {\r\n            document.removeEventListener('keydown', this.shiftDownHandler);\r\n            document.removeEventListener('keyup', this.shiftUpHandler);\r\n        }\r\n        this.subscription?.unsubscribe();\r\n    }\r\n\r\n    ngAfterContentInit(): void {\r\n        this.rowTemplate = this.templateRefs.last;\r\n        const dataTableConfig = this.localStorageService.get('dataTableConfig') ?? {};\r\n\r\n        if (!this.id) {\r\n            console.warn(`No id was assigned to the data table component`);\r\n        }\r\n        const updateColumnVisibility = () => {\r\n            if (!dataTableConfig[this.id]) {\r\n                dataTableConfig[this.id] = { visibility: [], order: {}, showSearchFilterRow: false };\r\n            }\r\n            dataTableConfig[this.id].visibility = this.allColumns\r\n                .filter(c => (c.visible && c.hiddenByDefault) || (!c.visible && !c.hiddenByDefault))\r\n                .map(c => c.id);\r\n            this.localStorageService.set('dataTableConfig', dataTableConfig);\r\n        };\r\n\r\n        this.allColumns.forEach(column => {\r\n            if (dataTableConfig?.[this.id]?.visibility.includes(column.id)) {\r\n                column.setVisibility(column.hiddenByDefault);\r\n            }\r\n            column.onColumnChange(updateColumnVisibility);\r\n        });\r\n\r\n        if (this.selectionManager) {\r\n            document.addEventListener('keydown', this.shiftDownHandler, { passive: true });\r\n            document.addEventListener('keyup', this.shiftUpHandler, { passive: true });\r\n            this.bulkActionMenuComponent.onClearSelection(() => {\r\n                this.changeDetectorRef.markForCheck();\r\n            });\r\n            this.selectionManager.setCurrentItems(this.items);\r\n        }\r\n        this.showSearchFilterRow = dataTableConfig?.[this.id]?.showSearchFilterRow ?? false;\r\n        this.columns.changes.subscribe(() => {\r\n            this.changeDetectorRef.markForCheck();\r\n        });\r\n\r\n        this.subscription = this.selectionManager?.selectionChanges$.subscribe(() =>\r\n            this.changeDetectorRef.markForCheck(),\r\n        );\r\n\r\n        if (this.selectionManager && this.subscription) {\r\n            const channelSub = this.dataService.client\r\n                .userStatus()\r\n                .mapStream(({ userStatus }) => userStatus.activeChannelId)\r\n                .pipe(distinctUntilChanged())\r\n                .subscribe(activeChannelId => {\r\n                    this.selectionManager?.clearSelection();\r\n                });\r\n            this.subscription?.add(channelSub);\r\n        }\r\n    }\r\n\r\n    onColumnReorder(event: { column: DataTable2ColumnComponent<any>; newIndex: number }) {\r\n        const naturalIndex = this.allColumns.findIndex(c => c.id === event.column.id);\r\n        const dataTableConfig = this.getDataTableConfig();\r\n        if (naturalIndex === event.newIndex) {\r\n            delete dataTableConfig[this.id].order[event.column.id];\r\n        } else {\r\n            dataTableConfig[this.id].order[event.column.id] = event.newIndex;\r\n        }\r\n        this.localStorageService.set('dataTableConfig', dataTableConfig);\r\n    }\r\n\r\n    onColumnsReset() {\r\n        const dataTableConfig = this.getDataTableConfig();\r\n        dataTableConfig[this.id].order = {};\r\n        dataTableConfig[this.id].visibility = [];\r\n        this.localStorageService.set('dataTableConfig', dataTableConfig);\r\n    }\r\n\r\n    toggleSearchFilterRow() {\r\n        this.showSearchFilterRow = !this.showSearchFilterRow;\r\n        const dataTableConfig = this.getDataTableConfig();\r\n        dataTableConfig[this.id].showSearchFilterRow = this.showSearchFilterRow;\r\n        this.localStorageService.set('dataTableConfig', dataTableConfig);\r\n    }\r\n\r\n    trackByFn(index: number, item: any) {\r\n        if ((item as any).id != null) {\r\n            return (item as any).id;\r\n        } else {\r\n            return index;\r\n        }\r\n    }\r\n\r\n    onToggleAllClick() {\r\n        this.selectionManager?.toggleSelectAll();\r\n    }\r\n\r\n    onRowClick(item: T, event: MouseEvent) {\r\n        this.selectionManager?.toggleSelection(item, event);\r\n    }\r\n\r\n    protected getDataTableConfig(): DataTableConfig {\r\n        const dataTableConfig = this.localStorageService.get('dataTableConfig') ?? {};\r\n        if (!dataTableConfig[this.id]) {\r\n            dataTableConfig[this.id] = { visibility: [], order: {}, showSearchFilterRow: false };\r\n        }\r\n        return dataTableConfig;\r\n    }\r\n}\r\n","<div class=\"bulk-actions\">\r\n    <ng-content select=\"vdr-bulk-action-menu\"></ng-content>\r\n</div>\r\n<div class=\"table-wrapper\">\r\n    <table\r\n        class=\"\"\r\n        [class.no-select]=\"disableSelect\"\r\n    >\r\n        <thead [class.items-selected]=\"selectionManager?.selection.length\">\r\n            <tr class=\"heading-row\">\r\n                <th *ngIf=\"selectionManager\" class=\"selection-col\">\r\n                    <input\r\n                        type=\"checkbox\"\r\n                        clrCheckbox\r\n                        [checked]=\"selectionManager?.areAllCurrentItemsSelected()\"\r\n                        (change)=\"onToggleAllClick()\"\r\n                    />\r\n                </th>\r\n                <th\r\n                    *ngFor=\"let column of visibleSortedColumns; last as isLast\"\r\n                    [class.expand]=\"column.expand\"\r\n                >\r\n                    <div class=\"cell-content\" [ngClass]=\"column.align\">\r\n                        <span>{{ column.heading }}</span>\r\n                        <div *ngIf=\"column.sort as sort\" class=\"sort-toggle\">\r\n                            <button (click)=\"sort.toggleSortOrder()\" [class.active]=\"sort.sortOrder\">\r\n                                <clr-icon *ngIf=\"!sort.sortOrder\" shape=\"two-way-arrows left\"></clr-icon>\r\n                                <clr-icon *ngIf=\"sort.sortOrder === 'ASC'\" shape=\"arrow up\"></clr-icon>\r\n                                <clr-icon *ngIf=\"sort.sortOrder === 'DESC'\" shape=\"arrow down\"></clr-icon>\r\n                            </button>\r\n                            <div class=\"sort-label\" *ngIf=\"sort.sortOrder\">{{ sort.sortOrder }}</div>\r\n                        </div>\r\n                    </div>\r\n                </th>\r\n                <th>\r\n                    <div class=\"column-picker\">\r\n                        <vdr-data-table-colum-picker\r\n                            [uiLanguage]=\"uiLanguage$ | async\"\r\n                            [columns]=\"sortedColumns\"\r\n                            (reorder)=\"onColumnReorder($event)\"\r\n                            (resetColumns)=\"onColumnsReset()\"\r\n                        ></vdr-data-table-colum-picker>\r\n                    </div>\r\n                </th>\r\n            </tr>\r\n            <tr *ngIf=\"searchComponent || customSearchTemplate || filters?.length\">\r\n                <th\r\n                    [attr.colspan]=\"visibleSortedColumns.length + (selectionManager ? 2 : 1)\"\r\n                    class=\"filter-row\"\r\n                    [class.active]=\"showSearchFilterRow\"\r\n                >\r\n                    <button\r\n                        class=\"button-ghost toggle-search-filter-row\"\r\n                        [class.active]=\"showSearchFilterRow\"\r\n                        (click)=\"toggleSearchFilterRow()\"\r\n                        [title]=\"'common.search-and-filter-list' | translate\"\r\n                    >\r\n                        <clr-icon shape=\"search\"></clr-icon>\r\n                    </button>\r\n                    <div class=\"filter-row-wrapper\" [class.hidden]=\"!showSearchFilterRow\">\r\n                        <ng-container *ngTemplateOutlet=\"searchComponent?.template\"></ng-container>\r\n                        <ng-container *ngTemplateOutlet=\"customSearchTemplate\"></ng-container>\r\n                        <ng-container *ngIf=\"filters\">\r\n                            <div class=\"filters\">\r\n                                <vdr-data-table-filters\r\n                                    *ngFor=\"let activeFilter of filters.activeFilters\"\r\n                                    [filterWithValue]=\"activeFilter\"\r\n                                    [filters]=\"filters\"\r\n                                    class=\"mt-1\"\r\n                                ></vdr-data-table-filters>\r\n                                <vdr-data-table-filters\r\n                                    *ngIf=\"filters.length\"\r\n                                    [filters]=\"filters\"\r\n                                    class=\"mt-1\"\r\n                                ></vdr-data-table-filters>\r\n                            </div>\r\n                        </ng-container>\r\n                    </div>\r\n                </th>\r\n            </tr>\r\n        </thead>\r\n        <tbody>\r\n            <tr\r\n                *ngFor=\"\r\n                    let item of items\r\n                        | paginate\r\n                            : {\r\n                                  id: id,\r\n                                  itemsPerPage: itemsPerPage,\r\n                                  currentPage: currentPage,\r\n                                  totalItems: totalItems\r\n                              };\r\n                    index as i;\r\n                    trackBy: trackByFn\r\n                \"\r\n            >\r\n                <td *ngIf=\"selectionManager\" class=\"selection-col\" [class.active]=\"activeIndex === i\">\r\n                    <input\r\n                        type=\"checkbox\"\r\n                        clrCheckbox\r\n                        [checked]=\"selectionManager?.isSelected(item)\"\r\n                        (click)=\"onRowClick(item, $event)\"\r\n                    />\r\n                </td>\r\n                <td *ngFor=\"let column of visibleSortedColumns\" [class.active]=\"activeIndex === i\">\r\n                    <div class=\"cell-content\" [ngClass]=\"column.align\">\r\n                        <ng-container\r\n                            *ngTemplateOutlet=\"column.template; context: { item: item, index: i }\"\r\n                        ></ng-container>\r\n                    </div>\r\n                </td>\r\n                <td [class.active]=\"activeIndex === i\"><!-- column select --></td>\r\n            </tr>\r\n            <ng-container>\r\n                <tr *ngIf=\"!items?.length\">\r\n                    <td [attr.colspan]=\"visibleSortedColumns.length + (selectionManager ? 2 : 1)\">\r\n                        <vdr-empty-placeholder [emptyStateLabel]=\"emptyStateLabel\"></vdr-empty-placeholder>\r\n                    </td>\r\n                </tr>\r\n            </ng-container>\r\n        </tbody>\r\n    </table>\r\n</div>\r\n<div class=\"table-footer\">\r\n    <vdr-items-per-page-controls\r\n        *ngIf=\"totalItems\"\r\n        [itemsPerPage]=\"itemsPerPage\"\r\n        (itemsPerPageChange)=\"itemsPerPageChange.emit($event)\"\r\n    ></vdr-items-per-page-controls>\r\n    <div *ngIf=\"totalItems\" class=\"total-items-count\">\r\n        {{ 'common.total-items' | translate : { currentStart, currentEnd, totalItems } }}\r\n    </div>\r\n\r\n    <vdr-pagination-controls\r\n        *ngIf=\"totalItems\"\r\n        [id]=\"id\"\r\n        [currentPage]=\"currentPage\"\r\n        [itemsPerPage]=\"itemsPerPage\"\r\n        [totalItems]=\"totalItems\"\r\n        (pageChange)=\"pageChange.emit($event)\"\r\n    ></vdr-pagination-controls>\r\n</div>\r\n"]}
|
package/esm2022/core/shared/components/data-table-filter-label/data-table-filter-label.component.mjs
CHANGED
|
@@ -21,12 +21,12 @@ export class DataTableFilterLabelComponent {
|
|
|
21
21
|
}));
|
|
22
22
|
}
|
|
23
23
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.3", ngImport: i0, type: DataTableFilterLabelComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
24
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.3", type: DataTableFilterLabelComponent, selector: "vdr-data-table-filter-label", inputs: { filterWithValue: "filterWithValue" }, ngImport: i0, template: "<span><vdr-localized-text [text]=\"filterWithValue.filter.label\" />:</span>\r\n<div>\r\n <ng-container *ngIf=\"filterWithValue.isSelect()\">\r\n {{ filterWithValue.value?.join(', ') }}\r\n </ng-container>\r\n <ng-container *ngIf=\"filterWithValue.isText()\">\r\n <span *ngIf=\"filterWithValue.value?.operator === 'contains'\">{{\r\n 'common.operator-contains' | translate\r\n }}</span>\r\n <span *ngIf=\"filterWithValue.value?.operator === 'eq'\">{{ 'common.operator-eq' | translate }}</span>\r\n <span *ngIf=\"filterWithValue.value?.operator === 'notContains'\">{{\r\n 'common.operator-notContains' | translate\r\n }}</span>\r\n <span *ngIf=\"filterWithValue.value?.operator === 'notEq'\">{{\r\n 'common.operator-not-eq' | translate\r\n }}</span>\r\n <span *ngIf=\"filterWithValue.value?.operator === 'regex'\">{{\r\n 'common.operator-regex' | translate\r\n }}</span>\r\n <span> \"{{ filterWithValue.value?.term }}\"</span>\r\n </ng-container>\r\n <ng-container *ngIf=\"filterWithValue.isBoolean()\">\r\n <span *ngIf=\"filterWithValue?.value\">{{ 'common.boolean-true' | translate }}</span>\r\n <span *ngIf=\"!filterWithValue?.value\">{{ 'common.boolean-false' | translate }}</span>\r\n </ng-container>\r\n <ng-container *ngIf=\"filterWithValue.isDateRange()\">\r\n <span *ngIf=\"filterWithValue.value?.start && filterWithValue.value?.end\">\r\n {{ filterWithValue.value?.start | localeDate : 'shortDate' }} -\r\n {{ filterWithValue.value?.end | localeDate : 'shortDate' }}\r\n </span>\r\n <span *ngIf=\"filterWithValue.value?.start && !filterWithValue.value?.end\">\r\n > {{ filterWithValue.value?.start | localeDate : 'shortDate' }}\r\n </span>\r\n <span *ngIf=\"filterWithValue.value?.end && !filterWithValue.value?.start\">\r\n < {{ filterWithValue.value?.end | localeDate : 'shortDate' }}\r\n </span>\r\n </ng-container>\r\n <ng-container *ngIf=\"filterWithValue.isNumber()\">\r\n <span *ngIf=\"filterWithValue.value?.operator === 'eq'\"> = </span>\r\n <span *ngIf=\"filterWithValue.value?.operator === 'gt'\"> > </span>\r\n <span *ngIf=\"filterWithValue.value?.operator === 'lt'\"> < </span>\r\n <span *ngIf=\"$any(filterWithValue.filter.type).inputType === 'currency'\">{{\r\n +filterWithValue.value?.amount | localeCurrency\r\n }}</span>\r\n <span *ngIf=\"$any(filterWithValue.filter.type).inputType !== 'currency'\">{{\r\n +filterWithValue.value?.amount\r\n }}</span>\r\n </ng-container>\r\n <ng-container *ngIf=\"filterWithValue.isCustom()\">\r\n <span>{{ customFilterLabel$ | async }}</span>\r\n </ng-container>\r\n</div>\r\n", styles: [":host{display:flex;gap:calc(var(--space-unit) / 2)}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.LocalizedTextComponent, selector: "vdr-localized-text", inputs: ["text"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }, { kind: "pipe", type: i4.LocaleDatePipe, name: "localeDate" }, { kind: "pipe", type: i5.LocaleCurrencyPipe, name: "localeCurrency" }], changeDetection: i0.ChangeDetectionStrategy.Default }); }
|
|
24
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.3", type: DataTableFilterLabelComponent, selector: "vdr-data-table-filter-label", inputs: { filterWithValue: "filterWithValue" }, ngImport: i0, template: "<span><vdr-localized-text [text]=\"filterWithValue.filter.label\" />:</span>\r\n<div>\r\n <ng-container *ngIf=\"filterWithValue.isSelect()\">\r\n {{ filterWithValue.value?.join(', ') }}\r\n </ng-container>\r\n <ng-container *ngIf=\"filterWithValue.isId()\">\r\n <span *ngIf=\"filterWithValue.value?.operator === 'eq'\">{{ 'common.operator-eq' | translate }}</span>\r\n <span *ngIf=\"filterWithValue.value?.operator === 'notEq'\">{{\r\n 'common.operator-not-eq' | translate\r\n }}</span>\r\n <span> \"{{ filterWithValue.value?.term }}\"</span>\r\n </ng-container>\r\n <ng-container *ngIf=\"filterWithValue.isText()\">\r\n <span *ngIf=\"filterWithValue.value?.operator === 'contains'\">{{\r\n 'common.operator-contains' | translate\r\n }}</span>\r\n <span *ngIf=\"filterWithValue.value?.operator === 'eq'\">{{ 'common.operator-eq' | translate }}</span>\r\n <span *ngIf=\"filterWithValue.value?.operator === 'notContains'\">{{\r\n 'common.operator-notContains' | translate\r\n }}</span>\r\n <span *ngIf=\"filterWithValue.value?.operator === 'notEq'\">{{\r\n 'common.operator-not-eq' | translate\r\n }}</span>\r\n <span *ngIf=\"filterWithValue.value?.operator === 'regex'\">{{\r\n 'common.operator-regex' | translate\r\n }}</span>\r\n <span> \"{{ filterWithValue.value?.term }}\"</span>\r\n </ng-container>\r\n <ng-container *ngIf=\"filterWithValue.isBoolean()\">\r\n <span *ngIf=\"filterWithValue?.value\">{{ 'common.boolean-true' | translate }}</span>\r\n <span *ngIf=\"!filterWithValue?.value\">{{ 'common.boolean-false' | translate }}</span>\r\n </ng-container>\r\n <ng-container *ngIf=\"filterWithValue.isDateRange()\">\r\n <span *ngIf=\"filterWithValue.value?.start && filterWithValue.value?.end\">\r\n {{ filterWithValue.value?.start | localeDate : 'shortDate' }} -\r\n {{ filterWithValue.value?.end | localeDate : 'shortDate' }}\r\n </span>\r\n <span *ngIf=\"filterWithValue.value?.start && !filterWithValue.value?.end\">\r\n > {{ filterWithValue.value?.start | localeDate : 'shortDate' }}\r\n </span>\r\n <span *ngIf=\"filterWithValue.value?.end && !filterWithValue.value?.start\">\r\n < {{ filterWithValue.value?.end | localeDate : 'shortDate' }}\r\n </span>\r\n </ng-container>\r\n <ng-container *ngIf=\"filterWithValue.isNumber()\">\r\n <span *ngIf=\"filterWithValue.value?.operator === 'eq'\"> = </span>\r\n <span *ngIf=\"filterWithValue.value?.operator === 'gt'\"> > </span>\r\n <span *ngIf=\"filterWithValue.value?.operator === 'lt'\"> < </span>\r\n <span *ngIf=\"$any(filterWithValue.filter.type).inputType === 'currency'\">{{\r\n +filterWithValue.value?.amount | localeCurrency\r\n }}</span>\r\n <span *ngIf=\"$any(filterWithValue.filter.type).inputType !== 'currency'\">{{\r\n +filterWithValue.value?.amount\r\n }}</span>\r\n </ng-container>\r\n <ng-container *ngIf=\"filterWithValue.isCustom()\">\r\n <span>{{ customFilterLabel$ | async }}</span>\r\n </ng-container>\r\n</div>\r\n", styles: [":host{display:flex;gap:calc(var(--space-unit) / 2)}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.LocalizedTextComponent, selector: "vdr-localized-text", inputs: ["text"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }, { kind: "pipe", type: i4.LocaleDatePipe, name: "localeDate" }, { kind: "pipe", type: i5.LocaleCurrencyPipe, name: "localeCurrency" }], changeDetection: i0.ChangeDetectionStrategy.Default }); }
|
|
25
25
|
}
|
|
26
26
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.3", ngImport: i0, type: DataTableFilterLabelComponent, decorators: [{
|
|
27
27
|
type: Component,
|
|
28
|
-
args: [{ selector: 'vdr-data-table-filter-label', changeDetection: ChangeDetectionStrategy.Default, template: "<span><vdr-localized-text [text]=\"filterWithValue.filter.label\" />:</span>\r\n<div>\r\n <ng-container *ngIf=\"filterWithValue.isSelect()\">\r\n {{ filterWithValue.value?.join(', ') }}\r\n </ng-container>\r\n <ng-container *ngIf=\"filterWithValue.isText()\">\r\n <span *ngIf=\"filterWithValue.value?.operator === 'contains'\">{{\r\n 'common.operator-contains' | translate\r\n }}</span>\r\n <span *ngIf=\"filterWithValue.value?.operator === 'eq'\">{{ 'common.operator-eq' | translate }}</span>\r\n <span *ngIf=\"filterWithValue.value?.operator === 'notContains'\">{{\r\n 'common.operator-notContains' | translate\r\n }}</span>\r\n <span *ngIf=\"filterWithValue.value?.operator === 'notEq'\">{{\r\n 'common.operator-not-eq' | translate\r\n }}</span>\r\n <span *ngIf=\"filterWithValue.value?.operator === 'regex'\">{{\r\n 'common.operator-regex' | translate\r\n }}</span>\r\n <span> \"{{ filterWithValue.value?.term }}\"</span>\r\n </ng-container>\r\n <ng-container *ngIf=\"filterWithValue.isBoolean()\">\r\n <span *ngIf=\"filterWithValue?.value\">{{ 'common.boolean-true' | translate }}</span>\r\n <span *ngIf=\"!filterWithValue?.value\">{{ 'common.boolean-false' | translate }}</span>\r\n </ng-container>\r\n <ng-container *ngIf=\"filterWithValue.isDateRange()\">\r\n <span *ngIf=\"filterWithValue.value?.start && filterWithValue.value?.end\">\r\n {{ filterWithValue.value?.start | localeDate : 'shortDate' }} -\r\n {{ filterWithValue.value?.end | localeDate : 'shortDate' }}\r\n </span>\r\n <span *ngIf=\"filterWithValue.value?.start && !filterWithValue.value?.end\">\r\n > {{ filterWithValue.value?.start | localeDate : 'shortDate' }}\r\n </span>\r\n <span *ngIf=\"filterWithValue.value?.end && !filterWithValue.value?.start\">\r\n < {{ filterWithValue.value?.end | localeDate : 'shortDate' }}\r\n </span>\r\n </ng-container>\r\n <ng-container *ngIf=\"filterWithValue.isNumber()\">\r\n <span *ngIf=\"filterWithValue.value?.operator === 'eq'\"> = </span>\r\n <span *ngIf=\"filterWithValue.value?.operator === 'gt'\"> > </span>\r\n <span *ngIf=\"filterWithValue.value?.operator === 'lt'\"> < </span>\r\n <span *ngIf=\"$any(filterWithValue.filter.type).inputType === 'currency'\">{{\r\n +filterWithValue.value?.amount | localeCurrency\r\n }}</span>\r\n <span *ngIf=\"$any(filterWithValue.filter.type).inputType !== 'currency'\">{{\r\n +filterWithValue.value?.amount\r\n }}</span>\r\n </ng-container>\r\n <ng-container *ngIf=\"filterWithValue.isCustom()\">\r\n <span>{{ customFilterLabel$ | async }}</span>\r\n </ng-container>\r\n</div>\r\n", styles: [":host{display:flex;gap:calc(var(--space-unit) / 2)}\n"] }]
|
|
28
|
+
args: [{ selector: 'vdr-data-table-filter-label', changeDetection: ChangeDetectionStrategy.Default, template: "<span><vdr-localized-text [text]=\"filterWithValue.filter.label\" />:</span>\r\n<div>\r\n <ng-container *ngIf=\"filterWithValue.isSelect()\">\r\n {{ filterWithValue.value?.join(', ') }}\r\n </ng-container>\r\n <ng-container *ngIf=\"filterWithValue.isId()\">\r\n <span *ngIf=\"filterWithValue.value?.operator === 'eq'\">{{ 'common.operator-eq' | translate }}</span>\r\n <span *ngIf=\"filterWithValue.value?.operator === 'notEq'\">{{\r\n 'common.operator-not-eq' | translate\r\n }}</span>\r\n <span> \"{{ filterWithValue.value?.term }}\"</span>\r\n </ng-container>\r\n <ng-container *ngIf=\"filterWithValue.isText()\">\r\n <span *ngIf=\"filterWithValue.value?.operator === 'contains'\">{{\r\n 'common.operator-contains' | translate\r\n }}</span>\r\n <span *ngIf=\"filterWithValue.value?.operator === 'eq'\">{{ 'common.operator-eq' | translate }}</span>\r\n <span *ngIf=\"filterWithValue.value?.operator === 'notContains'\">{{\r\n 'common.operator-notContains' | translate\r\n }}</span>\r\n <span *ngIf=\"filterWithValue.value?.operator === 'notEq'\">{{\r\n 'common.operator-not-eq' | translate\r\n }}</span>\r\n <span *ngIf=\"filterWithValue.value?.operator === 'regex'\">{{\r\n 'common.operator-regex' | translate\r\n }}</span>\r\n <span> \"{{ filterWithValue.value?.term }}\"</span>\r\n </ng-container>\r\n <ng-container *ngIf=\"filterWithValue.isBoolean()\">\r\n <span *ngIf=\"filterWithValue?.value\">{{ 'common.boolean-true' | translate }}</span>\r\n <span *ngIf=\"!filterWithValue?.value\">{{ 'common.boolean-false' | translate }}</span>\r\n </ng-container>\r\n <ng-container *ngIf=\"filterWithValue.isDateRange()\">\r\n <span *ngIf=\"filterWithValue.value?.start && filterWithValue.value?.end\">\r\n {{ filterWithValue.value?.start | localeDate : 'shortDate' }} -\r\n {{ filterWithValue.value?.end | localeDate : 'shortDate' }}\r\n </span>\r\n <span *ngIf=\"filterWithValue.value?.start && !filterWithValue.value?.end\">\r\n > {{ filterWithValue.value?.start | localeDate : 'shortDate' }}\r\n </span>\r\n <span *ngIf=\"filterWithValue.value?.end && !filterWithValue.value?.start\">\r\n < {{ filterWithValue.value?.end | localeDate : 'shortDate' }}\r\n </span>\r\n </ng-container>\r\n <ng-container *ngIf=\"filterWithValue.isNumber()\">\r\n <span *ngIf=\"filterWithValue.value?.operator === 'eq'\"> = </span>\r\n <span *ngIf=\"filterWithValue.value?.operator === 'gt'\"> > </span>\r\n <span *ngIf=\"filterWithValue.value?.operator === 'lt'\"> < </span>\r\n <span *ngIf=\"$any(filterWithValue.filter.type).inputType === 'currency'\">{{\r\n +filterWithValue.value?.amount | localeCurrency\r\n }}</span>\r\n <span *ngIf=\"$any(filterWithValue.filter.type).inputType !== 'currency'\">{{\r\n +filterWithValue.value?.amount\r\n }}</span>\r\n </ng-container>\r\n <ng-container *ngIf=\"filterWithValue.isCustom()\">\r\n <span>{{ customFilterLabel$ | async }}</span>\r\n </ng-container>\r\n</div>\r\n", styles: [":host{display:flex;gap:calc(var(--space-unit) / 2)}\n"] }]
|
|
29
29
|
}], propDecorators: { filterWithValue: [{
|
|
30
30
|
type: Input
|
|
31
31
|
}] } });
|
|
32
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table-filter-label.component.js","sourceRoot":"","sources":["../../../../../../src/lib/core/src/shared/components/data-table-filter-label/data-table-filter-label.component.ts","../../../../../../src/lib/core/src/shared/components/data-table-filter-label/data-table-filter-label.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,KAAK,EAAU,MAAM,eAAe,CAAC;AAClF,OAAO,EAAE,IAAI,EAAE,KAAK,EAAc,EAAE,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;;;;;;;AAWvE,MAAM,OAAO,6BAA6B;IAItC,QAAQ;QACJ,MAAM,kBAAkB,GAAG,IAAI,OAAO,EAAQ,CAAC;QAC/C,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,kBAAkB,CAAC,IAAI,EAAE,CAAC,CAAC;QAC/D,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC,EAAE,kBAAkB,CAAC,CAAC,IAAI,CAC9E,SAAS,CAAC,GAAG,EAAE;YACX,IAAI,IAAI,CAAC,eAAe,EAAE,MAAM,CAAC,IAAI,CAAC,IAAI,KAAK,QAAQ,EAAE;gBACrD,MAAM,WAAW,GAAG,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;gBAC1F,OAAO,OAAO,WAAW,KAAK,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;aAChF;iBAAM;gBACH,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC;aACjB;QACL,CAAC,CAAC,CACL,CAAC;IACN,CAAC;8GAjBQ,6BAA6B;kGAA7B,6BAA6B,mHCZ1C,6sGA2DA;;2FD/Ca,6BAA6B;kBANzC,SAAS;+BACI,6BAA6B,mBAGtB,uBAAuB,CAAC,OAAO;8BAGvC,eAAe;sBAAvB,KAAK","sourcesContent":["import { ChangeDetectionStrategy, Component, Input, OnInit } from '@angular/core';\r\nimport { from, merge, Observable, of, Subject, switchMap } from 'rxjs';\r\nimport { LanguageCode, LocalizedString } from '../../../common/generated-types';\r\nimport { DataTableFilter } from '../../../providers/data-table/data-table-filter';\r\nimport { FilterWithValue } from '../../../providers/data-table/data-table-filter-collection';\r\n\r\n@Component({\r\n    selector: 'vdr-data-table-filter-label',\r\n    templateUrl: './data-table-filter-label.component.html',\r\n    styleUrls: ['./data-table-filter-label.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.Default,\r\n})\r\nexport class DataTableFilterLabelComponent implements OnInit {\r\n    @Input() filterWithValue: FilterWithValue;\r\n    protected customFilterLabel$?: Observable<string>;\r\n\r\n    ngOnInit() {\r\n        const filterValueUpdate$ = new Subject<void>();\r\n        this.filterWithValue.onUpdate(() => filterValueUpdate$.next());\r\n        this.customFilterLabel$ = merge(of(this.filterWithValue), filterValueUpdate$).pipe(\r\n            switchMap(() => {\r\n                if (this.filterWithValue?.filter.type.kind === 'custom') {\r\n                    const labelResult = this.filterWithValue.filter.type.getLabel(this.filterWithValue.value);\r\n                    return typeof labelResult === 'string' ? of(labelResult) : from(labelResult);\r\n                } else {\r\n                    return of('');\r\n                }\r\n            }),\r\n        );\r\n    }\r\n}\r\n","<span><vdr-localized-text [text]=\"filterWithValue.filter.label\" />:</span>\r\n<div>\r\n    <ng-container *ngIf=\"filterWithValue.isSelect()\">\r\n        {{ filterWithValue.value?.join(', ') }}\r\n    </ng-container>\r\n    <ng-container *ngIf=\"filterWithValue.isId()\">\r\n        <span *ngIf=\"filterWithValue.value?.operator === 'eq'\">{{ 'common.operator-eq' | translate }}</span>\r\n        <span *ngIf=\"filterWithValue.value?.operator === 'notEq'\">{{\r\n            'common.operator-not-eq' | translate\r\n        }}</span>\r\n        <span> \"{{ filterWithValue.value?.term }}\"</span>\r\n    </ng-container>\r\n    <ng-container *ngIf=\"filterWithValue.isText()\">\r\n        <span *ngIf=\"filterWithValue.value?.operator === 'contains'\">{{\r\n            'common.operator-contains' | translate\r\n        }}</span>\r\n        <span *ngIf=\"filterWithValue.value?.operator === 'eq'\">{{ 'common.operator-eq' | translate }}</span>\r\n        <span *ngIf=\"filterWithValue.value?.operator === 'notContains'\">{{\r\n            'common.operator-notContains' | translate\r\n        }}</span>\r\n        <span *ngIf=\"filterWithValue.value?.operator === 'notEq'\">{{\r\n            'common.operator-not-eq' | translate\r\n        }}</span>\r\n        <span *ngIf=\"filterWithValue.value?.operator === 'regex'\">{{\r\n            'common.operator-regex' | translate\r\n        }}</span>\r\n        <span> \"{{ filterWithValue.value?.term }}\"</span>\r\n    </ng-container>\r\n    <ng-container *ngIf=\"filterWithValue.isBoolean()\">\r\n        <span *ngIf=\"filterWithValue?.value\">{{ 'common.boolean-true' | translate }}</span>\r\n        <span *ngIf=\"!filterWithValue?.value\">{{ 'common.boolean-false' | translate }}</span>\r\n    </ng-container>\r\n    <ng-container *ngIf=\"filterWithValue.isDateRange()\">\r\n        <span *ngIf=\"filterWithValue.value?.start && filterWithValue.value?.end\">\r\n            {{ filterWithValue.value?.start | localeDate : 'shortDate' }} -\r\n            {{ filterWithValue.value?.end | localeDate : 'shortDate' }}\r\n        </span>\r\n        <span *ngIf=\"filterWithValue.value?.start && !filterWithValue.value?.end\">\r\n            > {{ filterWithValue.value?.start | localeDate : 'shortDate' }}\r\n        </span>\r\n        <span *ngIf=\"filterWithValue.value?.end && !filterWithValue.value?.start\">\r\n            < {{ filterWithValue.value?.end | localeDate : 'shortDate' }}\r\n        </span>\r\n    </ng-container>\r\n    <ng-container *ngIf=\"filterWithValue.isNumber()\">\r\n        <span *ngIf=\"filterWithValue.value?.operator === 'eq'\"> = </span>\r\n        <span *ngIf=\"filterWithValue.value?.operator === 'gt'\"> > </span>\r\n        <span *ngIf=\"filterWithValue.value?.operator === 'lt'\"> < </span>\r\n        <span *ngIf=\"$any(filterWithValue.filter.type).inputType === 'currency'\">{{\r\n            +filterWithValue.value?.amount | localeCurrency\r\n        }}</span>\r\n        <span *ngIf=\"$any(filterWithValue.filter.type).inputType !== 'currency'\">{{\r\n            +filterWithValue.value?.amount\r\n        }}</span>\r\n    </ng-container>\r\n    <ng-container *ngIf=\"filterWithValue.isCustom()\">\r\n        <span>{{ customFilterLabel$ | async }}</span>\r\n    </ng-container>\r\n</div>\r\n"]}
|
|
@@ -25,7 +25,9 @@ export class DataTableFiltersComponent {
|
|
|
25
25
|
}
|
|
26
26
|
onFKeyPress(event) {
|
|
27
27
|
if (event.target instanceof HTMLElement) {
|
|
28
|
-
if (event.target.tagName === 'INPUT' ||
|
|
28
|
+
if (event.target.tagName === 'INPUT' ||
|
|
29
|
+
event.target.tagName === 'TEXTAREA' ||
|
|
30
|
+
event.target.classList.contains('vdr-prosemirror')) {
|
|
29
31
|
return;
|
|
30
32
|
}
|
|
31
33
|
}
|
|
@@ -53,6 +55,17 @@ export class DataTableFiltersComponent {
|
|
|
53
55
|
}
|
|
54
56
|
selectFilter(filter, value) {
|
|
55
57
|
this.selectedFilter = filter;
|
|
58
|
+
if (filter.isId()) {
|
|
59
|
+
this.formControl = new FormGroup({
|
|
60
|
+
operator: new FormControl(value?.operator ?? 'eq'),
|
|
61
|
+
term: new FormControl(value?.term ?? ''),
|
|
62
|
+
}, control => {
|
|
63
|
+
if (!control.value.term) {
|
|
64
|
+
return { noSelection: true };
|
|
65
|
+
}
|
|
66
|
+
return null;
|
|
67
|
+
});
|
|
68
|
+
}
|
|
56
69
|
if (filter.isText()) {
|
|
57
70
|
this.formControl = new FormGroup({
|
|
58
71
|
operator: new FormControl(value?.operator ?? 'contains'),
|
|
@@ -154,6 +167,12 @@ export class DataTableFiltersComponent {
|
|
|
154
167
|
term: this.formControl.value.term,
|
|
155
168
|
};
|
|
156
169
|
break;
|
|
170
|
+
case 'id':
|
|
171
|
+
value = {
|
|
172
|
+
operator: this.formControl.value.operator,
|
|
173
|
+
term: this.formControl.value.term,
|
|
174
|
+
};
|
|
175
|
+
break;
|
|
157
176
|
case 'custom':
|
|
158
177
|
value = this.customComponent?.instance.formControl.value;
|
|
159
178
|
this.formControl.setValue(value);
|
|
@@ -179,11 +198,11 @@ export class DataTableFiltersComponent {
|
|
|
179
198
|
}
|
|
180
199
|
}
|
|
181
200
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.3", ngImport: i0, type: DataTableFiltersComponent, deps: [{ token: i1.I18nService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
182
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.3", type: DataTableFiltersComponent, selector: "vdr-data-table-filters", inputs: { filters: "filters", filterWithValue: "filterWithValue" }, host: { listeners: { "window:keydown.f": "onFKeyPress($event)" } }, viewQueries: [{ propertyName: "dropdown", first: true, predicate: ["dropdown"], descendants: true, static: true }, { propertyName: "customComponentHost", first: true, predicate: ["customComponentHost"], descendants: true, read: CustomFilterComponentDirective }], ngImport: i0, template: "<vdr-dropdown [manualToggle]=\"true\" #dropdown>\r\n <div class=\"filter-button\" [ngClass]=\"state\">\r\n <clr-icon shape=\"plus\" size=\"12\" *ngIf=\"state === 'new'\"></clr-icon>\r\n <button *ngIf=\"state === 'active'\" class=\"remove\" (click)=\"deactivate()\">\r\n <clr-icon shape=\"times\" size=\"12\"></clr-icon>\r\n </button>\r\n <button vdrDropdownTrigger class=\"\">\r\n <span *ngIf=\"state === 'new'\">{{ 'common.add-filter' | translate }} <span class=\"filter-hotkey\">f</span></span>\r\n <span *ngIf=\"state === 'active'\">\r\n <vdr-data-table-filter-label\r\n [filterWithValue]=\"filterWithValue\"\r\n ></vdr-data-table-filter-label>\r\n </span>\r\n <clr-icon shape=\"ellipsis-vertical\" size=\"12\"></clr-icon>\r\n </button>\r\n </div>\r\n <vdr-dropdown-menu vdrPosition=\"bottom-left\">\r\n <div *ngIf=\"!selectedFilter\">\r\n <div class=\"filter-heading\">Filter by:</div>\r\n <div *ngFor=\"let filter of filters.getFilters()\">\r\n <button vdrDropdownItem (click)=\"selectFilter(filter)\">\r\n <vdr-localized-text [text]=\"filter?.label\" />\r\n </button>\r\n </div>\r\n </div>\r\n\r\n <div class=\"filter-heading\" *ngIf=\"selectedFilter\">\r\n Filter by <vdr-localized-text [text]=\"selectedFilter.label\" />:\r\n </div>\r\n <div class=\"mx-2 mt-1\">\r\n <div vdrCustomFilterComponentHost #customComponentHost></div>\r\n </div>\r\n <form *ngIf=\"selectedFilter\" class=\"\" [cdkTrapFocus]=\"true\" [cdkTrapFocusAutoCapture]=\"true\">\r\n <ng-container *ngIf=\"selectedFilter.type.kind !== 'custom'\">\r\n <div class=\"mx-2 mt-1\" [ngSwitch]=\"selectedFilter.type.kind\">\r\n <div *ngSwitchCase=\"'select'\" [formGroup]=\"formControl\">\r\n <label *ngFor=\"let option of $any(selectedFilter.type).options; index as i\">\r\n <input type=\"checkbox\" [formControlName]=\"i\" />\r\n <span>{{ option.label | translate }}</span>\r\n </label>\r\n </div>\r\n <div *ngSwitchCase=\"'boolean'\">\r\n <label\r\n ><input type=\"checkbox\" [formControl]=\"formControl\" clrToggle />\r\n <span *ngIf=\"formControl.value\">{{ 'common.boolean-true' | translate }}</span>\r\n <span *ngIf=\"!formControl.value\">{{ 'common.boolean-false' | translate }}</span>\r\n </label>\r\n </div>\r\n <div *ngSwitchCase=\"'text'\">\r\n <div [formGroup]=\"formControl\">\r\n <div>\r\n <select name=\"options\" formControlName=\"operator\" class=\"mb-1\">\r\n <option value=\"contains\">\r\n {{ 'common.operator-contains' | translate }}\r\n </option>\r\n <option value=\"eq\">{{ 'common.operator-eq' | translate }}</option>\r\n <option value=\"notContains\">\r\n {{ 'common.operator-not-contains' | translate }}\r\n </option>\r\n <option value=\"notEq\">{{ 'common.operator-not-eq' | translate }}</option>\r\n <option value=\"regex\">{{ 'common.operator-regex' | translate }}</option>\r\n </select>\r\n </div>\r\n <input type=\"text\" formControlName=\"term\" />\r\n </div>\r\n </div>\r\n <div *ngSwitchCase=\"'number'\">\r\n <div [formGroup]=\"formControl\">\r\n <div>\r\n <select name=\"options\" formControlName=\"operator\" class=\"mb-1\">\r\n <option value=\"eq\">{{ 'common.operator-eq' | translate }}</option>\r\n <option value=\"gt\">{{ 'common.operator-gt' | translate }}</option>\r\n <option value=\"lt\">{{ 'common.operator-lt' | translate }}</option>\r\n </select>\r\n </div>\r\n <input\r\n *ngIf=\"$any(selectedFilter.type).inputType !== 'currency'\"\r\n type=\"text\"\r\n formControlName=\"amount\"\r\n />\r\n <vdr-currency-input\r\n *ngIf=\"$any(selectedFilter.type).inputType === 'currency'\"\r\n formControlName=\"amount\"\r\n />\r\n </div>\r\n </div>\r\n <div *ngSwitchCase=\"'dateRange'\">\r\n <div [formGroup]=\"formControl\">\r\n <label>\r\n <div>{{ 'common.start-date' | translate }}</div>\r\n </label>\r\n <vdr-datetime-picker formControlName=\"start\"></vdr-datetime-picker>\r\n <label>\r\n <div>{{ 'common.end-date' | translate }}</div>\r\n </label>\r\n <vdr-datetime-picker formControlName=\"end\"></vdr-datetime-picker>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n <div class=\"apply-wrapper mt-2\">\r\n <button class=\"button\" (click)=\"activate()\" [disabled]=\"!formControl?.valid\">\r\n <span>{{ 'common.apply' | translate }}</span>\r\n <clr-icon shape=\"check\"></clr-icon>\r\n </button>\r\n </div>\r\n </form>\r\n </vdr-dropdown-menu>\r\n</vdr-dropdown>\r\n", styles: [":host{display:block}.filter-button{display:flex;flex-direction:row;justify-content:flex-end;align-items:center;padding:0 var(--space-unit);height:calc(var(--space-unit) * 3);font-size:var(--font-size-xs);border-radius:var(--border-radius-lg);background-color:var(--color-button-small-bg);color:var(--color-button-small-text)}.filter-button>button{border:none;gap:12px;cursor:pointer;background-color:transparent;display:flex;align-items:center;height:calc(var(--space-unit) * 2);border-radius:var(--border-radius-lg);color:var(--color-button-small-text)}.filter-button.active{background-color:var(--color-primary-700);color:var(--color-primary-100)}.filter-button.active>button{color:var(--color-primary-100)}label{display:flex;align-items:center;gap:var(--space-unit);margin-bottom:calc(var(--space-unit) * .5)}.filter-heading{font-size:var(--font-size-xs);text-transform:uppercase;color:var(--color-weight-600);margin:0 calc(var(--space-unit) * 2)}.apply-wrapper{display:flex;justify-content:flex-end;padding-right:calc(var(--space-unit) * 2)}.filter-hotkey{font-size:var(--font-size-xs);color:var(--color-weight-500);border:1px solid var(--color-weight-200);background-color:var(--color-weight-100);border-radius:var(--border-radius);padding:0 3px;text-transform:uppercase;margin-inline-start:3px}\n"], dependencies: [{ kind: "directive", type: i2.ClrIconCustomTag, selector: "clr-icon" }, { kind: "directive", type: i2.ClrLabel, selector: "label", inputs: ["for"] }, { kind: "directive", type: i2.ClrCheckbox, selector: "[clrCheckbox],[clrToggle]" }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i3.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i4.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i4.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i4.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i4.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: i4.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i4.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i4.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i5.CdkTrapFocus, selector: "[cdkTrapFocus]", inputs: ["cdkTrapFocus", "cdkTrapFocusAutoCapture"], exportAs: ["cdkTrapFocus"] }, { kind: "component", type: i6.CurrencyInputComponent, selector: "vdr-currency-input", inputs: ["disabled", "readonly", "value", "currencyCode"], outputs: ["valueChange"] }, { kind: "directive", type: i7.FormFieldControlDirective, selector: "input, textarea, select" }, { kind: "component", type: i8.DropdownComponent, selector: "vdr-dropdown", inputs: ["manualToggle"] }, { kind: "component", type: i9.DropdownMenuComponent, selector: "vdr-dropdown-menu", inputs: ["vdrPosition", "customClasses"] }, { kind: "directive", type: i10.DropdownTriggerDirective, selector: "[vdrDropdownTrigger]" }, { kind: "directive", type: i11.DropdownItemDirective, selector: "[vdrDropdownItem]" }, { kind: "component", type: i12.DatetimePickerComponent, selector: "vdr-datetime-picker", inputs: ["yearRange", "weekStartDay", "timeGranularityInterval", "min", "max", "readonly"] }, { kind: "component", type: i13.DataTableFilterLabelComponent, selector: "vdr-data-table-filter-label", inputs: ["filterWithValue"] }, { kind: "directive", type: i14.CustomFilterComponentDirective, selector: "[vdrCustomFilterComponentHost]" }, { kind: "component", type: i15.LocalizedTextComponent, selector: "vdr-localized-text", inputs: ["text"] }, { kind: "pipe", type: i16.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
201
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.3", type: DataTableFiltersComponent, selector: "vdr-data-table-filters", inputs: { filters: "filters", filterWithValue: "filterWithValue" }, host: { listeners: { "window:keydown.f": "onFKeyPress($event)" } }, viewQueries: [{ propertyName: "dropdown", first: true, predicate: ["dropdown"], descendants: true, static: true }, { propertyName: "customComponentHost", first: true, predicate: ["customComponentHost"], descendants: true, read: CustomFilterComponentDirective }], ngImport: i0, template: "<vdr-dropdown [manualToggle]=\"true\" #dropdown>\r\n <div class=\"filter-button\" [ngClass]=\"state\">\r\n <clr-icon shape=\"plus\" size=\"12\" *ngIf=\"state === 'new'\"></clr-icon>\r\n <button *ngIf=\"state === 'active'\" class=\"remove\" (click)=\"deactivate()\">\r\n <clr-icon shape=\"times\" size=\"12\"></clr-icon>\r\n </button>\r\n <button vdrDropdownTrigger class=\"\">\r\n <span *ngIf=\"state === 'new'\">{{ 'common.add-filter' | translate }} <span class=\"filter-hotkey\">f</span></span>\r\n <span *ngIf=\"state === 'active'\">\r\n <vdr-data-table-filter-label\r\n [filterWithValue]=\"filterWithValue\"\r\n ></vdr-data-table-filter-label>\r\n </span>\r\n <clr-icon shape=\"ellipsis-vertical\" size=\"12\"></clr-icon>\r\n </button>\r\n </div>\r\n <vdr-dropdown-menu vdrPosition=\"bottom-left\">\r\n <div *ngIf=\"!selectedFilter\">\r\n <div class=\"filter-heading\">Filter by:</div>\r\n <div *ngFor=\"let filter of filters.getFilters()\">\r\n <button vdrDropdownItem (click)=\"selectFilter(filter)\">\r\n <vdr-localized-text [text]=\"filter?.label\" />\r\n </button>\r\n </div>\r\n </div>\r\n\r\n <div class=\"filter-heading\" *ngIf=\"selectedFilter\">\r\n Filter by <vdr-localized-text [text]=\"selectedFilter.label\" />:\r\n </div>\r\n <div class=\"mx-2 mt-1\">\r\n <div vdrCustomFilterComponentHost #customComponentHost></div>\r\n </div>\r\n <form *ngIf=\"selectedFilter\" class=\"\" [cdkTrapFocus]=\"true\" [cdkTrapFocusAutoCapture]=\"true\">\r\n <ng-container *ngIf=\"selectedFilter.type.kind !== 'custom'\">\r\n <div class=\"mx-2 mt-1\" [ngSwitch]=\"selectedFilter.type.kind\">\r\n <div *ngSwitchCase=\"'select'\" [formGroup]=\"formControl\">\r\n <label *ngFor=\"let option of $any(selectedFilter.type).options; index as i\">\r\n <input type=\"checkbox\" [formControlName]=\"i\" />\r\n <span>{{ option.label | translate }}</span>\r\n </label>\r\n </div>\r\n <div *ngSwitchCase=\"'boolean'\">\r\n <label\r\n ><input type=\"checkbox\" [formControl]=\"formControl\" clrToggle />\r\n <span *ngIf=\"formControl.value\">{{ 'common.boolean-true' | translate }}</span>\r\n <span *ngIf=\"!formControl.value\">{{ 'common.boolean-false' | translate }}</span>\r\n </label>\r\n </div>\r\n <div *ngSwitchCase=\"'text'\">\r\n <div [formGroup]=\"formControl\">\r\n <div>\r\n <select name=\"options\" formControlName=\"operator\" class=\"mb-1\">\r\n <option value=\"contains\">\r\n {{ 'common.operator-contains' | translate }}\r\n </option>\r\n <option value=\"eq\">{{ 'common.operator-eq' | translate }}</option>\r\n <option value=\"notContains\">\r\n {{ 'common.operator-not-contains' | translate }}\r\n </option>\r\n <option value=\"notEq\">{{ 'common.operator-not-eq' | translate }}</option>\r\n <option value=\"regex\">{{ 'common.operator-regex' | translate }}</option>\r\n </select>\r\n </div>\r\n <input type=\"text\" formControlName=\"term\" />\r\n </div>\r\n </div>\r\n <div *ngSwitchCase=\"'id'\">\r\n <div [formGroup]=\"formControl\">\r\n <div>\r\n <select name=\"options\" formControlName=\"operator\" class=\"mb-1\">\r\n <option value=\"eq\">{{ 'common.operator-eq' | translate }}</option>\r\n <option value=\"notEq\">{{ 'common.operator-not-eq' | translate }}</option>\r\n </select>\r\n </div>\r\n <input type=\"text\" formControlName=\"term\" />\r\n </div>\r\n </div>\r\n <div *ngSwitchCase=\"'number'\">\r\n <div [formGroup]=\"formControl\">\r\n <div>\r\n <select name=\"options\" formControlName=\"operator\" class=\"mb-1\">\r\n <option value=\"eq\">{{ 'common.operator-eq' | translate }}</option>\r\n <option value=\"gt\">{{ 'common.operator-gt' | translate }}</option>\r\n <option value=\"lt\">{{ 'common.operator-lt' | translate }}</option>\r\n </select>\r\n </div>\r\n <input\r\n *ngIf=\"$any(selectedFilter.type).inputType !== 'currency'\"\r\n type=\"text\"\r\n formControlName=\"amount\"\r\n />\r\n <vdr-currency-input\r\n *ngIf=\"$any(selectedFilter.type).inputType === 'currency'\"\r\n formControlName=\"amount\"\r\n />\r\n </div>\r\n </div>\r\n <div *ngSwitchCase=\"'dateRange'\">\r\n <div [formGroup]=\"formControl\">\r\n <label>\r\n <div>{{ 'common.start-date' | translate }}</div>\r\n </label>\r\n <vdr-datetime-picker formControlName=\"start\"></vdr-datetime-picker>\r\n <label>\r\n <div>{{ 'common.end-date' | translate }}</div>\r\n </label>\r\n <vdr-datetime-picker formControlName=\"end\"></vdr-datetime-picker>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n <div class=\"apply-wrapper mt-2\">\r\n <button class=\"button\" (click)=\"activate()\" [disabled]=\"!formControl?.valid\">\r\n <span>{{ 'common.apply' | translate }}</span>\r\n <clr-icon shape=\"check\"></clr-icon>\r\n </button>\r\n </div>\r\n </form>\r\n </vdr-dropdown-menu>\r\n</vdr-dropdown>\r\n", styles: [":host{display:block}.filter-button{display:flex;flex-direction:row;justify-content:flex-end;align-items:center;padding:0 var(--space-unit);height:calc(var(--space-unit) * 3);font-size:var(--font-size-xs);border-radius:var(--border-radius-lg);background-color:var(--color-button-small-bg);color:var(--color-button-small-text)}.filter-button>button{border:none;gap:12px;cursor:pointer;background-color:transparent;display:flex;align-items:center;height:calc(var(--space-unit) * 2);border-radius:var(--border-radius-lg);color:var(--color-button-small-text)}.filter-button.active{background-color:var(--color-primary-700);color:var(--color-primary-100)}.filter-button.active>button{color:var(--color-primary-100)}label{display:flex;align-items:center;gap:var(--space-unit);margin-bottom:calc(var(--space-unit) * .5)}.filter-heading{font-size:var(--font-size-xs);text-transform:uppercase;color:var(--color-weight-600);margin:0 calc(var(--space-unit) * 2)}.apply-wrapper{display:flex;justify-content:flex-end;padding-right:calc(var(--space-unit) * 2)}.filter-hotkey{font-size:var(--font-size-xs);color:var(--color-weight-500);border:1px solid var(--color-weight-200);background-color:var(--color-weight-100);border-radius:var(--border-radius);padding:0 3px;text-transform:uppercase;margin-inline-start:3px}\n"], dependencies: [{ kind: "directive", type: i2.ClrIconCustomTag, selector: "clr-icon" }, { kind: "directive", type: i2.ClrLabel, selector: "label", inputs: ["for"] }, { kind: "directive", type: i2.ClrCheckbox, selector: "[clrCheckbox],[clrToggle]" }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i3.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i4.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i4.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i4.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i4.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: i4.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i4.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i4.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i5.CdkTrapFocus, selector: "[cdkTrapFocus]", inputs: ["cdkTrapFocus", "cdkTrapFocusAutoCapture"], exportAs: ["cdkTrapFocus"] }, { kind: "component", type: i6.CurrencyInputComponent, selector: "vdr-currency-input", inputs: ["disabled", "readonly", "value", "currencyCode"], outputs: ["valueChange"] }, { kind: "directive", type: i7.FormFieldControlDirective, selector: "input, textarea, select" }, { kind: "component", type: i8.DropdownComponent, selector: "vdr-dropdown", inputs: ["manualToggle"] }, { kind: "component", type: i9.DropdownMenuComponent, selector: "vdr-dropdown-menu", inputs: ["vdrPosition", "customClasses"] }, { kind: "directive", type: i10.DropdownTriggerDirective, selector: "[vdrDropdownTrigger]" }, { kind: "directive", type: i11.DropdownItemDirective, selector: "[vdrDropdownItem]" }, { kind: "component", type: i12.DatetimePickerComponent, selector: "vdr-datetime-picker", inputs: ["yearRange", "weekStartDay", "timeGranularityInterval", "min", "max", "readonly"] }, { kind: "component", type: i13.DataTableFilterLabelComponent, selector: "vdr-data-table-filter-label", inputs: ["filterWithValue"] }, { kind: "directive", type: i14.CustomFilterComponentDirective, selector: "[vdrCustomFilterComponentHost]" }, { kind: "component", type: i15.LocalizedTextComponent, selector: "vdr-localized-text", inputs: ["text"] }, { kind: "pipe", type: i16.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
183
202
|
}
|
|
184
203
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.3", ngImport: i0, type: DataTableFiltersComponent, decorators: [{
|
|
185
204
|
type: Component,
|
|
186
|
-
args: [{ selector: 'vdr-data-table-filters', changeDetection: ChangeDetectionStrategy.OnPush, template: "<vdr-dropdown [manualToggle]=\"true\" #dropdown>\r\n <div class=\"filter-button\" [ngClass]=\"state\">\r\n <clr-icon shape=\"plus\" size=\"12\" *ngIf=\"state === 'new'\"></clr-icon>\r\n <button *ngIf=\"state === 'active'\" class=\"remove\" (click)=\"deactivate()\">\r\n <clr-icon shape=\"times\" size=\"12\"></clr-icon>\r\n </button>\r\n <button vdrDropdownTrigger class=\"\">\r\n <span *ngIf=\"state === 'new'\">{{ 'common.add-filter' | translate }} <span class=\"filter-hotkey\">f</span></span>\r\n <span *ngIf=\"state === 'active'\">\r\n <vdr-data-table-filter-label\r\n [filterWithValue]=\"filterWithValue\"\r\n ></vdr-data-table-filter-label>\r\n </span>\r\n <clr-icon shape=\"ellipsis-vertical\" size=\"12\"></clr-icon>\r\n </button>\r\n </div>\r\n <vdr-dropdown-menu vdrPosition=\"bottom-left\">\r\n <div *ngIf=\"!selectedFilter\">\r\n <div class=\"filter-heading\">Filter by:</div>\r\n <div *ngFor=\"let filter of filters.getFilters()\">\r\n <button vdrDropdownItem (click)=\"selectFilter(filter)\">\r\n <vdr-localized-text [text]=\"filter?.label\" />\r\n </button>\r\n </div>\r\n </div>\r\n\r\n <div class=\"filter-heading\" *ngIf=\"selectedFilter\">\r\n Filter by <vdr-localized-text [text]=\"selectedFilter.label\" />:\r\n </div>\r\n <div class=\"mx-2 mt-1\">\r\n <div vdrCustomFilterComponentHost #customComponentHost></div>\r\n </div>\r\n <form *ngIf=\"selectedFilter\" class=\"\" [cdkTrapFocus]=\"true\" [cdkTrapFocusAutoCapture]=\"true\">\r\n <ng-container *ngIf=\"selectedFilter.type.kind !== 'custom'\">\r\n <div class=\"mx-2 mt-1\" [ngSwitch]=\"selectedFilter.type.kind\">\r\n <div *ngSwitchCase=\"'select'\" [formGroup]=\"formControl\">\r\n <label *ngFor=\"let option of $any(selectedFilter.type).options; index as i\">\r\n <input type=\"checkbox\" [formControlName]=\"i\" />\r\n <span>{{ option.label | translate }}</span>\r\n </label>\r\n </div>\r\n <div *ngSwitchCase=\"'boolean'\">\r\n <label\r\n ><input type=\"checkbox\" [formControl]=\"formControl\" clrToggle />\r\n <span *ngIf=\"formControl.value\">{{ 'common.boolean-true' | translate }}</span>\r\n <span *ngIf=\"!formControl.value\">{{ 'common.boolean-false' | translate }}</span>\r\n </label>\r\n </div>\r\n <div *ngSwitchCase=\"'text'\">\r\n <div [formGroup]=\"formControl\">\r\n <div>\r\n <select name=\"options\" formControlName=\"operator\" class=\"mb-1\">\r\n <option value=\"contains\">\r\n {{ 'common.operator-contains' | translate }}\r\n </option>\r\n <option value=\"eq\">{{ 'common.operator-eq' | translate }}</option>\r\n <option value=\"notContains\">\r\n {{ 'common.operator-not-contains' | translate }}\r\n </option>\r\n <option value=\"notEq\">{{ 'common.operator-not-eq' | translate }}</option>\r\n <option value=\"regex\">{{ 'common.operator-regex' | translate }}</option>\r\n </select>\r\n </div>\r\n <input type=\"text\" formControlName=\"term\" />\r\n </div>\r\n </div>\r\n <div *ngSwitchCase=\"'number'\">\r\n <div [formGroup]=\"formControl\">\r\n <div>\r\n <select name=\"options\" formControlName=\"operator\" class=\"mb-1\">\r\n <option value=\"eq\">{{ 'common.operator-eq' | translate }}</option>\r\n <option value=\"gt\">{{ 'common.operator-gt' | translate }}</option>\r\n <option value=\"lt\">{{ 'common.operator-lt' | translate }}</option>\r\n </select>\r\n </div>\r\n <input\r\n *ngIf=\"$any(selectedFilter.type).inputType !== 'currency'\"\r\n type=\"text\"\r\n formControlName=\"amount\"\r\n />\r\n <vdr-currency-input\r\n *ngIf=\"$any(selectedFilter.type).inputType === 'currency'\"\r\n formControlName=\"amount\"\r\n />\r\n </div>\r\n </div>\r\n <div *ngSwitchCase=\"'dateRange'\">\r\n <div [formGroup]=\"formControl\">\r\n <label>\r\n <div>{{ 'common.start-date' | translate }}</div>\r\n </label>\r\n <vdr-datetime-picker formControlName=\"start\"></vdr-datetime-picker>\r\n <label>\r\n <div>{{ 'common.end-date' | translate }}</div>\r\n </label>\r\n <vdr-datetime-picker formControlName=\"end\"></vdr-datetime-picker>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n <div class=\"apply-wrapper mt-2\">\r\n <button class=\"button\" (click)=\"activate()\" [disabled]=\"!formControl?.valid\">\r\n <span>{{ 'common.apply' | translate }}</span>\r\n <clr-icon shape=\"check\"></clr-icon>\r\n </button>\r\n </div>\r\n </form>\r\n </vdr-dropdown-menu>\r\n</vdr-dropdown>\r\n", styles: [":host{display:block}.filter-button{display:flex;flex-direction:row;justify-content:flex-end;align-items:center;padding:0 var(--space-unit);height:calc(var(--space-unit) * 3);font-size:var(--font-size-xs);border-radius:var(--border-radius-lg);background-color:var(--color-button-small-bg);color:var(--color-button-small-text)}.filter-button>button{border:none;gap:12px;cursor:pointer;background-color:transparent;display:flex;align-items:center;height:calc(var(--space-unit) * 2);border-radius:var(--border-radius-lg);color:var(--color-button-small-text)}.filter-button.active{background-color:var(--color-primary-700);color:var(--color-primary-100)}.filter-button.active>button{color:var(--color-primary-100)}label{display:flex;align-items:center;gap:var(--space-unit);margin-bottom:calc(var(--space-unit) * .5)}.filter-heading{font-size:var(--font-size-xs);text-transform:uppercase;color:var(--color-weight-600);margin:0 calc(var(--space-unit) * 2)}.apply-wrapper{display:flex;justify-content:flex-end;padding-right:calc(var(--space-unit) * 2)}.filter-hotkey{font-size:var(--font-size-xs);color:var(--color-weight-500);border:1px solid var(--color-weight-200);background-color:var(--color-weight-100);border-radius:var(--border-radius);padding:0 3px;text-transform:uppercase;margin-inline-start:3px}\n"] }]
|
|
205
|
+
args: [{ selector: 'vdr-data-table-filters', changeDetection: ChangeDetectionStrategy.OnPush, template: "<vdr-dropdown [manualToggle]=\"true\" #dropdown>\r\n <div class=\"filter-button\" [ngClass]=\"state\">\r\n <clr-icon shape=\"plus\" size=\"12\" *ngIf=\"state === 'new'\"></clr-icon>\r\n <button *ngIf=\"state === 'active'\" class=\"remove\" (click)=\"deactivate()\">\r\n <clr-icon shape=\"times\" size=\"12\"></clr-icon>\r\n </button>\r\n <button vdrDropdownTrigger class=\"\">\r\n <span *ngIf=\"state === 'new'\">{{ 'common.add-filter' | translate }} <span class=\"filter-hotkey\">f</span></span>\r\n <span *ngIf=\"state === 'active'\">\r\n <vdr-data-table-filter-label\r\n [filterWithValue]=\"filterWithValue\"\r\n ></vdr-data-table-filter-label>\r\n </span>\r\n <clr-icon shape=\"ellipsis-vertical\" size=\"12\"></clr-icon>\r\n </button>\r\n </div>\r\n <vdr-dropdown-menu vdrPosition=\"bottom-left\">\r\n <div *ngIf=\"!selectedFilter\">\r\n <div class=\"filter-heading\">Filter by:</div>\r\n <div *ngFor=\"let filter of filters.getFilters()\">\r\n <button vdrDropdownItem (click)=\"selectFilter(filter)\">\r\n <vdr-localized-text [text]=\"filter?.label\" />\r\n </button>\r\n </div>\r\n </div>\r\n\r\n <div class=\"filter-heading\" *ngIf=\"selectedFilter\">\r\n Filter by <vdr-localized-text [text]=\"selectedFilter.label\" />:\r\n </div>\r\n <div class=\"mx-2 mt-1\">\r\n <div vdrCustomFilterComponentHost #customComponentHost></div>\r\n </div>\r\n <form *ngIf=\"selectedFilter\" class=\"\" [cdkTrapFocus]=\"true\" [cdkTrapFocusAutoCapture]=\"true\">\r\n <ng-container *ngIf=\"selectedFilter.type.kind !== 'custom'\">\r\n <div class=\"mx-2 mt-1\" [ngSwitch]=\"selectedFilter.type.kind\">\r\n <div *ngSwitchCase=\"'select'\" [formGroup]=\"formControl\">\r\n <label *ngFor=\"let option of $any(selectedFilter.type).options; index as i\">\r\n <input type=\"checkbox\" [formControlName]=\"i\" />\r\n <span>{{ option.label | translate }}</span>\r\n </label>\r\n </div>\r\n <div *ngSwitchCase=\"'boolean'\">\r\n <label\r\n ><input type=\"checkbox\" [formControl]=\"formControl\" clrToggle />\r\n <span *ngIf=\"formControl.value\">{{ 'common.boolean-true' | translate }}</span>\r\n <span *ngIf=\"!formControl.value\">{{ 'common.boolean-false' | translate }}</span>\r\n </label>\r\n </div>\r\n <div *ngSwitchCase=\"'text'\">\r\n <div [formGroup]=\"formControl\">\r\n <div>\r\n <select name=\"options\" formControlName=\"operator\" class=\"mb-1\">\r\n <option value=\"contains\">\r\n {{ 'common.operator-contains' | translate }}\r\n </option>\r\n <option value=\"eq\">{{ 'common.operator-eq' | translate }}</option>\r\n <option value=\"notContains\">\r\n {{ 'common.operator-not-contains' | translate }}\r\n </option>\r\n <option value=\"notEq\">{{ 'common.operator-not-eq' | translate }}</option>\r\n <option value=\"regex\">{{ 'common.operator-regex' | translate }}</option>\r\n </select>\r\n </div>\r\n <input type=\"text\" formControlName=\"term\" />\r\n </div>\r\n </div>\r\n <div *ngSwitchCase=\"'id'\">\r\n <div [formGroup]=\"formControl\">\r\n <div>\r\n <select name=\"options\" formControlName=\"operator\" class=\"mb-1\">\r\n <option value=\"eq\">{{ 'common.operator-eq' | translate }}</option>\r\n <option value=\"notEq\">{{ 'common.operator-not-eq' | translate }}</option>\r\n </select>\r\n </div>\r\n <input type=\"text\" formControlName=\"term\" />\r\n </div>\r\n </div>\r\n <div *ngSwitchCase=\"'number'\">\r\n <div [formGroup]=\"formControl\">\r\n <div>\r\n <select name=\"options\" formControlName=\"operator\" class=\"mb-1\">\r\n <option value=\"eq\">{{ 'common.operator-eq' | translate }}</option>\r\n <option value=\"gt\">{{ 'common.operator-gt' | translate }}</option>\r\n <option value=\"lt\">{{ 'common.operator-lt' | translate }}</option>\r\n </select>\r\n </div>\r\n <input\r\n *ngIf=\"$any(selectedFilter.type).inputType !== 'currency'\"\r\n type=\"text\"\r\n formControlName=\"amount\"\r\n />\r\n <vdr-currency-input\r\n *ngIf=\"$any(selectedFilter.type).inputType === 'currency'\"\r\n formControlName=\"amount\"\r\n />\r\n </div>\r\n </div>\r\n <div *ngSwitchCase=\"'dateRange'\">\r\n <div [formGroup]=\"formControl\">\r\n <label>\r\n <div>{{ 'common.start-date' | translate }}</div>\r\n </label>\r\n <vdr-datetime-picker formControlName=\"start\"></vdr-datetime-picker>\r\n <label>\r\n <div>{{ 'common.end-date' | translate }}</div>\r\n </label>\r\n <vdr-datetime-picker formControlName=\"end\"></vdr-datetime-picker>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n <div class=\"apply-wrapper mt-2\">\r\n <button class=\"button\" (click)=\"activate()\" [disabled]=\"!formControl?.valid\">\r\n <span>{{ 'common.apply' | translate }}</span>\r\n <clr-icon shape=\"check\"></clr-icon>\r\n </button>\r\n </div>\r\n </form>\r\n </vdr-dropdown-menu>\r\n</vdr-dropdown>\r\n", styles: [":host{display:block}.filter-button{display:flex;flex-direction:row;justify-content:flex-end;align-items:center;padding:0 var(--space-unit);height:calc(var(--space-unit) * 3);font-size:var(--font-size-xs);border-radius:var(--border-radius-lg);background-color:var(--color-button-small-bg);color:var(--color-button-small-text)}.filter-button>button{border:none;gap:12px;cursor:pointer;background-color:transparent;display:flex;align-items:center;height:calc(var(--space-unit) * 2);border-radius:var(--border-radius-lg);color:var(--color-button-small-text)}.filter-button.active{background-color:var(--color-primary-700);color:var(--color-primary-100)}.filter-button.active>button{color:var(--color-primary-100)}label{display:flex;align-items:center;gap:var(--space-unit);margin-bottom:calc(var(--space-unit) * .5)}.filter-heading{font-size:var(--font-size-xs);text-transform:uppercase;color:var(--color-weight-600);margin:0 calc(var(--space-unit) * 2)}.apply-wrapper{display:flex;justify-content:flex-end;padding-right:calc(var(--space-unit) * 2)}.filter-hotkey{font-size:var(--font-size-xs);color:var(--color-weight-500);border:1px solid var(--color-weight-200);background-color:var(--color-weight-100);border-radius:var(--border-radius);padding:0 3px;text-transform:uppercase;margin-inline-start:3px}\n"] }]
|
|
187
206
|
}], ctorParameters: function () { return [{ type: i1.I18nService }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { filters: [{
|
|
188
207
|
type: Input
|
|
189
208
|
}], filterWithValue: [{
|
|
@@ -198,4 +217,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.3", ngImpor
|
|
|
198
217
|
type: HostListener,
|
|
199
218
|
args: ['window:keydown.f', ['$event']]
|
|
200
219
|
}] } });
|
|
201
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table-filters.component.js","sourceRoot":"","sources":["../../../../../../src/lib/core/src/shared/components/data-table-filters/data-table-filters.component.ts","../../../../../../src/lib/core/src/shared/components/data-table-filters/data-table-filters.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    AfterViewInit,\r\n    ChangeDetectionStrategy,\r\n    ChangeDetectorRef,\r\n    Component,\r\n    ComponentRef,\r\n    HostListener,\r\n    Input,\r\n    ViewChild,\r\n} from '@angular/core';\r\nimport { AbstractControl, FormArray, FormControl, FormGroup } from '@angular/forms';\r\nimport { assertNever } from '@vendure/common/lib/shared-utils';\r\nimport { FormInputComponent } from '../../../common/component-registry-types';\r\nimport { DateOperators, LanguageCode } from '../../../common/generated-types';\r\nimport { DataTableFilter, KindValueMap } from '../../../providers/data-table/data-table-filter';\r\nimport {\r\n    DataTableFilterCollection,\r\n    FilterWithValue,\r\n} from '../../../providers/data-table/data-table-filter-collection';\r\nimport { I18nService } from '../../../providers/i18n/i18n.service';\r\nimport { DropdownComponent } from '../dropdown/dropdown.component';\r\nimport { CustomFilterComponentDirective } from './custom-filter-component.directive';\r\n\r\n@Component({\r\n    selector: 'vdr-data-table-filters',\r\n    templateUrl: './data-table-filters.component.html',\r\n    styleUrls: ['./data-table-filters.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class DataTableFiltersComponent implements AfterViewInit {\r\n    @Input() filters: DataTableFilterCollection;\r\n    @Input() filterWithValue?: FilterWithValue;\r\n    @ViewChild('dropdown', { static: true }) dropdown: DropdownComponent;\r\n    @ViewChild('customComponentHost', { static: false, read: CustomFilterComponentDirective })\r\n    set customComponentHost(content: CustomFilterComponentDirective) {\r\n        this._customComponentHost = content;\r\n    }\r\n    _customComponentHost: CustomFilterComponentDirective;\r\n    protected state: 'new' | 'active' = 'new';\r\n    protected formControl: AbstractControl;\r\n    protected selectedFilter: DataTableFilter | undefined;\r\n    protected customComponent?: ComponentRef<FormInputComponent>;\r\n\r\n    @HostListener('window:keydown.f', ['$event'])\r\n    onFKeyPress(event: KeyboardEvent) {\r\n        if (event.target instanceof HTMLElement) {\r\n            if (event.target.tagName === 'INPUT' || event.target.tagName === 'TEXTAREA') {\r\n                return;\r\n            }\r\n        }\r\n        if (!this.dropdown.isOpen && this.state === 'new') {\r\n            this.dropdown.toggleOpen();\r\n        }\r\n    }\r\n\r\n    constructor(private i18nService: I18nService, private changeDetectorRef: ChangeDetectorRef) {}\r\n\r\n    ngAfterViewInit() {\r\n        this.dropdown.onOpenChange(isOpen => {\r\n            if (!isOpen && this.state === 'new') {\r\n                this.selectedFilter = undefined;\r\n            }\r\n        });\r\n        if (this.filterWithValue) {\r\n            const { filter, value } = this.filterWithValue;\r\n            this.selectFilter(filter, value);\r\n            this.state = 'active';\r\n        }\r\n        setTimeout(() => this.changeDetectorRef.markForCheck());\r\n    }\r\n\r\n    selectFilter(filter: DataTableFilter, value?: any) {\r\n        this.selectedFilter = filter;\r\n        if (filter.isText()) {\r\n            this.formControl = new FormGroup(\r\n                {\r\n                    operator: new FormControl(value?.operator ?? 'contains'),\r\n                    term: new FormControl(value?.term ?? ''),\r\n                },\r\n                control => {\r\n                    if (!control.value.term) {\r\n                        return { noSelection: true };\r\n                    }\r\n                    return null;\r\n                },\r\n            );\r\n        }\r\n        if (filter.isNumber()) {\r\n            this.formControl = new FormGroup(\r\n                {\r\n                    operator: new FormControl(value?.operator ?? 'gt'),\r\n                    amount: new FormControl(value?.amount ?? ''),\r\n                },\r\n                control => {\r\n                    if (!control.value.amount) {\r\n                        return { noSelection: true };\r\n                    }\r\n                    return null;\r\n                },\r\n            );\r\n        } else if (filter.isSelect()) {\r\n            this.formControl = new FormArray(\r\n                filter.type.options.map(o => new FormControl(value?.includes(o.value) ?? false)),\r\n                control => (control.value.some(Boolean) ? null : { noSelection: true }),\r\n            );\r\n        } else if (filter.isBoolean()) {\r\n            this.formControl = new FormControl(value ?? false);\r\n        } else if (filter.isDateRange()) {\r\n            this.formControl = new FormGroup(\r\n                {\r\n                    start: new FormControl(value?.start ?? null),\r\n                    end: new FormControl(value?.end ?? null),\r\n                },\r\n                control => {\r\n                    const val = control.value;\r\n                    if (val.start && val.end && val.start > val.end) {\r\n                        return { invalidRange: true };\r\n                    }\r\n                    if (!val.start && !val.end) {\r\n                        return { noSelection: true };\r\n                    }\r\n                    return null;\r\n                },\r\n            );\r\n        } else if (filter.isCustom() && this._customComponentHost) {\r\n            // this.#customComponentHost.viewContainerRef.clear();\r\n            this.customComponent = this._customComponentHost.viewContainerRef.createComponent(\r\n                filter.type.component,\r\n            );\r\n            this.formControl = new FormControl<any>(value ?? []);\r\n            this.customComponent.instance.config = {};\r\n            this.customComponent.instance.formControl = new FormControl<any>(value ?? []);\r\n        }\r\n    }\r\n\r\n    activate() {\r\n        if (!this.selectedFilter) {\r\n            return;\r\n        }\r\n        let value: any;\r\n        const type = this.selectedFilter?.type;\r\n        switch (type.kind) {\r\n            case 'boolean':\r\n                value = !!this.formControl.value as KindValueMap[typeof type.kind]['raw'];\r\n                break;\r\n            case 'dateRange': {\r\n                let dateOperators: DateOperators;\r\n                const start = this.formControl.value.start ?? undefined;\r\n                const end = this.formControl.value.end ?? undefined;\r\n                if (start && end) {\r\n                    dateOperators = {\r\n                        between: { start, end },\r\n                    };\r\n                } else if (start) {\r\n                    dateOperators = {\r\n                        after: start,\r\n                    };\r\n                } else {\r\n                    dateOperators = {\r\n                        before: end,\r\n                    };\r\n                }\r\n                value = { start, end } as KindValueMap[typeof type.kind]['raw'];\r\n                break;\r\n            }\r\n            case 'number':\r\n                value = {\r\n                    amount: Number(this.formControl.value.amount),\r\n                    operator: this.formControl.value.operator,\r\n                } as KindValueMap[typeof type.kind]['raw'];\r\n                break;\r\n\r\n            case 'select':\r\n                const options = this.formControl.value\r\n                    .map((v, i) => (v ? type.options[i].value : undefined))\r\n                    .filter(v => !!v);\r\n                value = options as KindValueMap[typeof type.kind]['raw'];\r\n                break;\r\n            case 'text':\r\n                value = {\r\n                    operator: this.formControl.value.operator,\r\n                    term: this.formControl.value.term,\r\n                } as KindValueMap[typeof type.kind]['raw'];\r\n                break;\r\n            case 'custom':\r\n                value = this.customComponent?.instance.formControl.value;\r\n                this.formControl.setValue(value);\r\n                if (this.state === 'new') {\r\n                    this._customComponentHost.viewContainerRef.clear();\r\n                }\r\n                break;\r\n            default:\r\n                assertNever(type);\r\n        }\r\n        if (this.state === 'new') {\r\n            this.selectedFilter.activate(value);\r\n        } else {\r\n            this.filterWithValue?.updateValue(value);\r\n        }\r\n        this.dropdown.toggleOpen();\r\n    }\r\n\r\n    deactivate() {\r\n        if (this.filterWithValue) {\r\n            const index = this.filters.activeFilters.indexOf(this.filterWithValue);\r\n            this.filters.removeActiveFilterAtIndex(index);\r\n        }\r\n    }\r\n}\r\n","<vdr-dropdown [manualToggle]=\"true\" #dropdown>\r\n    <div class=\"filter-button\" [ngClass]=\"state\">\r\n        <clr-icon shape=\"plus\" size=\"12\" *ngIf=\"state === 'new'\"></clr-icon>\r\n        <button *ngIf=\"state === 'active'\" class=\"remove\" (click)=\"deactivate()\">\r\n            <clr-icon shape=\"times\" size=\"12\"></clr-icon>\r\n        </button>\r\n        <button vdrDropdownTrigger class=\"\">\r\n            <span *ngIf=\"state === 'new'\">{{ 'common.add-filter' | translate }} <span class=\"filter-hotkey\">f</span></span>\r\n            <span *ngIf=\"state === 'active'\">\r\n                <vdr-data-table-filter-label\r\n                    [filterWithValue]=\"filterWithValue\"\r\n                ></vdr-data-table-filter-label>\r\n            </span>\r\n            <clr-icon shape=\"ellipsis-vertical\" size=\"12\"></clr-icon>\r\n        </button>\r\n    </div>\r\n    <vdr-dropdown-menu vdrPosition=\"bottom-left\">\r\n        <div *ngIf=\"!selectedFilter\">\r\n            <div class=\"filter-heading\">Filter by:</div>\r\n            <div *ngFor=\"let filter of filters.getFilters()\">\r\n                <button vdrDropdownItem (click)=\"selectFilter(filter)\">\r\n                    <vdr-localized-text [text]=\"filter?.label\" />\r\n                </button>\r\n            </div>\r\n        </div>\r\n\r\n        <div class=\"filter-heading\" *ngIf=\"selectedFilter\">\r\n            Filter by <vdr-localized-text [text]=\"selectedFilter.label\" />:\r\n        </div>\r\n        <div class=\"mx-2 mt-1\">\r\n            <div vdrCustomFilterComponentHost #customComponentHost></div>\r\n        </div>\r\n        <form *ngIf=\"selectedFilter\" class=\"\" [cdkTrapFocus]=\"true\" [cdkTrapFocusAutoCapture]=\"true\">\r\n            <ng-container *ngIf=\"selectedFilter.type.kind !== 'custom'\">\r\n                <div class=\"mx-2 mt-1\" [ngSwitch]=\"selectedFilter.type.kind\">\r\n                    <div *ngSwitchCase=\"'select'\" [formGroup]=\"formControl\">\r\n                        <label *ngFor=\"let option of $any(selectedFilter.type).options; index as i\">\r\n                            <input type=\"checkbox\" [formControlName]=\"i\" />\r\n                            <span>{{ option.label | translate }}</span>\r\n                        </label>\r\n                    </div>\r\n                    <div *ngSwitchCase=\"'boolean'\">\r\n                        <label\r\n                            ><input type=\"checkbox\" [formControl]=\"formControl\" clrToggle />\r\n                            <span *ngIf=\"formControl.value\">{{ 'common.boolean-true' | translate }}</span>\r\n                            <span *ngIf=\"!formControl.value\">{{ 'common.boolean-false' | translate }}</span>\r\n                        </label>\r\n                    </div>\r\n                    <div *ngSwitchCase=\"'text'\">\r\n                        <div [formGroup]=\"formControl\">\r\n                            <div>\r\n                                <select name=\"options\" formControlName=\"operator\" class=\"mb-1\">\r\n                                    <option value=\"contains\">\r\n                                        {{ 'common.operator-contains' | translate }}\r\n                                    </option>\r\n                                    <option value=\"eq\">{{ 'common.operator-eq' | translate }}</option>\r\n                                    <option value=\"notContains\">\r\n                                        {{ 'common.operator-not-contains' | translate }}\r\n                                    </option>\r\n                                    <option value=\"notEq\">{{ 'common.operator-not-eq' | translate }}</option>\r\n                                    <option value=\"regex\">{{ 'common.operator-regex' | translate }}</option>\r\n                                </select>\r\n                            </div>\r\n                            <input type=\"text\" formControlName=\"term\" />\r\n                        </div>\r\n                    </div>\r\n                    <div *ngSwitchCase=\"'number'\">\r\n                        <div [formGroup]=\"formControl\">\r\n                            <div>\r\n                                <select name=\"options\" formControlName=\"operator\" class=\"mb-1\">\r\n                                    <option value=\"eq\">{{ 'common.operator-eq' | translate }}</option>\r\n                                    <option value=\"gt\">{{ 'common.operator-gt' | translate }}</option>\r\n                                    <option value=\"lt\">{{ 'common.operator-lt' | translate }}</option>\r\n                                </select>\r\n                            </div>\r\n                            <input\r\n                                *ngIf=\"$any(selectedFilter.type).inputType !== 'currency'\"\r\n                                type=\"text\"\r\n                                formControlName=\"amount\"\r\n                            />\r\n                            <vdr-currency-input\r\n                                *ngIf=\"$any(selectedFilter.type).inputType === 'currency'\"\r\n                                formControlName=\"amount\"\r\n                            />\r\n                        </div>\r\n                    </div>\r\n                    <div *ngSwitchCase=\"'dateRange'\">\r\n                        <div [formGroup]=\"formControl\">\r\n                            <label>\r\n                                <div>{{ 'common.start-date' | translate }}</div>\r\n                            </label>\r\n                            <vdr-datetime-picker formControlName=\"start\"></vdr-datetime-picker>\r\n                            <label>\r\n                                <div>{{ 'common.end-date' | translate }}</div>\r\n                            </label>\r\n                            <vdr-datetime-picker formControlName=\"end\"></vdr-datetime-picker>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </ng-container>\r\n            <div class=\"apply-wrapper mt-2\">\r\n                <button class=\"button\" (click)=\"activate()\" [disabled]=\"!formControl?.valid\">\r\n                    <span>{{ 'common.apply' | translate }}</span>\r\n                    <clr-icon shape=\"check\"></clr-icon>\r\n                </button>\r\n            </div>\r\n        </form>\r\n    </vdr-dropdown-menu>\r\n</vdr-dropdown>\r\n"]}
|
|
220
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table-filters.component.js","sourceRoot":"","sources":["../../../../../../src/lib/core/src/shared/components/data-table-filters/data-table-filters.component.ts","../../../../../../src/lib/core/src/shared/components/data-table-filters/data-table-filters.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    AfterViewInit,\r\n    ChangeDetectionStrategy,\r\n    ChangeDetectorRef,\r\n    Component,\r\n    ComponentRef,\r\n    HostListener,\r\n    Input,\r\n    ViewChild,\r\n} from '@angular/core';\r\nimport { AbstractControl, FormArray, FormControl, FormGroup } from '@angular/forms';\r\nimport { assertNever } from '@vendure/common/lib/shared-utils';\r\nimport { FormInputComponent } from '../../../common/component-registry-types';\r\nimport { DateOperators } from '../../../common/generated-types';\r\nimport { DataTableFilter, KindValueMap } from '../../../providers/data-table/data-table-filter';\r\nimport {\r\n    DataTableFilterCollection,\r\n    FilterWithValue,\r\n} from '../../../providers/data-table/data-table-filter-collection';\r\nimport { I18nService } from '../../../providers/i18n/i18n.service';\r\nimport { DropdownComponent } from '../dropdown/dropdown.component';\r\nimport { CustomFilterComponentDirective } from './custom-filter-component.directive';\r\n\r\n@Component({\r\n    selector: 'vdr-data-table-filters',\r\n    templateUrl: './data-table-filters.component.html',\r\n    styleUrls: ['./data-table-filters.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class DataTableFiltersComponent implements AfterViewInit {\r\n    @Input() filters: DataTableFilterCollection;\r\n    @Input() filterWithValue?: FilterWithValue;\r\n    @ViewChild('dropdown', { static: true }) dropdown: DropdownComponent;\r\n    @ViewChild('customComponentHost', { static: false, read: CustomFilterComponentDirective })\r\n    set customComponentHost(content: CustomFilterComponentDirective) {\r\n        this._customComponentHost = content;\r\n    }\r\n    _customComponentHost: CustomFilterComponentDirective;\r\n    protected state: 'new' | 'active' = 'new';\r\n    protected formControl: AbstractControl;\r\n    protected selectedFilter: DataTableFilter | undefined;\r\n    protected customComponent?: ComponentRef<FormInputComponent>;\r\n\r\n    @HostListener('window:keydown.f', ['$event'])\r\n    onFKeyPress(event: KeyboardEvent) {\r\n        if (event.target instanceof HTMLElement) {\r\n            if (\r\n                event.target.tagName === 'INPUT' ||\r\n                event.target.tagName === 'TEXTAREA' ||\r\n                event.target.classList.contains('vdr-prosemirror')\r\n            ) {\r\n                return;\r\n            }\r\n        }\r\n        if (!this.dropdown.isOpen && this.state === 'new') {\r\n            this.dropdown.toggleOpen();\r\n        }\r\n    }\r\n\r\n    constructor(private i18nService: I18nService, private changeDetectorRef: ChangeDetectorRef) {}\r\n\r\n    ngAfterViewInit() {\r\n        this.dropdown.onOpenChange(isOpen => {\r\n            if (!isOpen && this.state === 'new') {\r\n                this.selectedFilter = undefined;\r\n            }\r\n        });\r\n        if (this.filterWithValue) {\r\n            const { filter, value } = this.filterWithValue;\r\n            this.selectFilter(filter, value);\r\n            this.state = 'active';\r\n        }\r\n        setTimeout(() => this.changeDetectorRef.markForCheck());\r\n    }\r\n\r\n    selectFilter(filter: DataTableFilter, value?: any) {\r\n        this.selectedFilter = filter;\r\n        if (filter.isId()) {\r\n            this.formControl = new FormGroup(\r\n                {\r\n                    operator: new FormControl(value?.operator ?? 'eq'),\r\n                    term: new FormControl(value?.term ?? ''),\r\n                },\r\n                control => {\r\n                    if (!control.value.term) {\r\n                        return { noSelection: true };\r\n                    }\r\n                    return null;\r\n                },\r\n            );\r\n        }\r\n        if (filter.isText()) {\r\n            this.formControl = new FormGroup(\r\n                {\r\n                    operator: new FormControl(value?.operator ?? 'contains'),\r\n                    term: new FormControl(value?.term ?? ''),\r\n                },\r\n                control => {\r\n                    if (!control.value.term) {\r\n                        return { noSelection: true };\r\n                    }\r\n                    return null;\r\n                },\r\n            );\r\n        }\r\n        if (filter.isNumber()) {\r\n            this.formControl = new FormGroup(\r\n                {\r\n                    operator: new FormControl(value?.operator ?? 'gt'),\r\n                    amount: new FormControl(value?.amount ?? ''),\r\n                },\r\n                control => {\r\n                    if (!control.value.amount) {\r\n                        return { noSelection: true };\r\n                    }\r\n                    return null;\r\n                },\r\n            );\r\n        } else if (filter.isSelect()) {\r\n            this.formControl = new FormArray(\r\n                filter.type.options.map(o => new FormControl(value?.includes(o.value) ?? false)),\r\n                control => (control.value.some(Boolean) ? null : { noSelection: true }),\r\n            );\r\n        } else if (filter.isBoolean()) {\r\n            this.formControl = new FormControl(value ?? false);\r\n        } else if (filter.isDateRange()) {\r\n            this.formControl = new FormGroup(\r\n                {\r\n                    start: new FormControl(value?.start ?? null),\r\n                    end: new FormControl(value?.end ?? null),\r\n                },\r\n                control => {\r\n                    const val = control.value;\r\n                    if (val.start && val.end && val.start > val.end) {\r\n                        return { invalidRange: true };\r\n                    }\r\n                    if (!val.start && !val.end) {\r\n                        return { noSelection: true };\r\n                    }\r\n                    return null;\r\n                },\r\n            );\r\n        } else if (filter.isCustom() && this._customComponentHost) {\r\n            // this.#customComponentHost.viewContainerRef.clear();\r\n            this.customComponent = this._customComponentHost.viewContainerRef.createComponent(\r\n                filter.type.component,\r\n            );\r\n            this.formControl = new FormControl<any>(value ?? []);\r\n            this.customComponent.instance.config = {};\r\n            this.customComponent.instance.formControl = new FormControl<any>(value ?? []);\r\n        }\r\n    }\r\n\r\n    activate() {\r\n        if (!this.selectedFilter) {\r\n            return;\r\n        }\r\n        let value: any;\r\n        const type = this.selectedFilter?.type;\r\n        switch (type.kind) {\r\n            case 'boolean':\r\n                value = !!this.formControl.value as KindValueMap[typeof type.kind]['raw'];\r\n                break;\r\n            case 'dateRange': {\r\n                let dateOperators: DateOperators;\r\n                const start = this.formControl.value.start ?? undefined;\r\n                const end = this.formControl.value.end ?? undefined;\r\n                if (start && end) {\r\n                    dateOperators = {\r\n                        between: { start, end },\r\n                    };\r\n                } else if (start) {\r\n                    dateOperators = {\r\n                        after: start,\r\n                    };\r\n                } else {\r\n                    dateOperators = {\r\n                        before: end,\r\n                    };\r\n                }\r\n                value = { start, end } as KindValueMap[typeof type.kind]['raw'];\r\n                break;\r\n            }\r\n            case 'number':\r\n                value = {\r\n                    amount: Number(this.formControl.value.amount),\r\n                    operator: this.formControl.value.operator,\r\n                } as KindValueMap[typeof type.kind]['raw'];\r\n                break;\r\n\r\n            case 'select':\r\n                const options = this.formControl.value\r\n                    .map((v, i) => (v ? type.options[i].value : undefined))\r\n                    .filter(v => !!v);\r\n                value = options as KindValueMap[typeof type.kind]['raw'];\r\n                break;\r\n            case 'text':\r\n                value = {\r\n                    operator: this.formControl.value.operator,\r\n                    term: this.formControl.value.term,\r\n                } as KindValueMap[typeof type.kind]['raw'];\r\n                break;\r\n            case 'id':\r\n                value = {\r\n                    operator: this.formControl.value.operator,\r\n                    term: this.formControl.value.term,\r\n                } as KindValueMap[typeof type.kind]['raw'];\r\n                break;\r\n            case 'custom':\r\n                value = this.customComponent?.instance.formControl.value;\r\n                this.formControl.setValue(value);\r\n                if (this.state === 'new') {\r\n                    this._customComponentHost.viewContainerRef.clear();\r\n                }\r\n                break;\r\n            default:\r\n                assertNever(type);\r\n        }\r\n        if (this.state === 'new') {\r\n            this.selectedFilter.activate(value);\r\n        } else {\r\n            this.filterWithValue?.updateValue(value);\r\n        }\r\n        this.dropdown.toggleOpen();\r\n    }\r\n\r\n    deactivate() {\r\n        if (this.filterWithValue) {\r\n            const index = this.filters.activeFilters.indexOf(this.filterWithValue);\r\n            this.filters.removeActiveFilterAtIndex(index);\r\n        }\r\n    }\r\n}\r\n","<vdr-dropdown [manualToggle]=\"true\" #dropdown>\r\n    <div class=\"filter-button\" [ngClass]=\"state\">\r\n        <clr-icon shape=\"plus\" size=\"12\" *ngIf=\"state === 'new'\"></clr-icon>\r\n        <button *ngIf=\"state === 'active'\" class=\"remove\" (click)=\"deactivate()\">\r\n            <clr-icon shape=\"times\" size=\"12\"></clr-icon>\r\n        </button>\r\n        <button vdrDropdownTrigger class=\"\">\r\n            <span *ngIf=\"state === 'new'\">{{ 'common.add-filter' | translate }} <span class=\"filter-hotkey\">f</span></span>\r\n            <span *ngIf=\"state === 'active'\">\r\n                <vdr-data-table-filter-label\r\n                    [filterWithValue]=\"filterWithValue\"\r\n                ></vdr-data-table-filter-label>\r\n            </span>\r\n            <clr-icon shape=\"ellipsis-vertical\" size=\"12\"></clr-icon>\r\n        </button>\r\n    </div>\r\n    <vdr-dropdown-menu vdrPosition=\"bottom-left\">\r\n        <div *ngIf=\"!selectedFilter\">\r\n            <div class=\"filter-heading\">Filter by:</div>\r\n            <div *ngFor=\"let filter of filters.getFilters()\">\r\n                <button vdrDropdownItem (click)=\"selectFilter(filter)\">\r\n                    <vdr-localized-text [text]=\"filter?.label\" />\r\n                </button>\r\n            </div>\r\n        </div>\r\n\r\n        <div class=\"filter-heading\" *ngIf=\"selectedFilter\">\r\n            Filter by <vdr-localized-text [text]=\"selectedFilter.label\" />:\r\n        </div>\r\n        <div class=\"mx-2 mt-1\">\r\n            <div vdrCustomFilterComponentHost #customComponentHost></div>\r\n        </div>\r\n        <form *ngIf=\"selectedFilter\" class=\"\" [cdkTrapFocus]=\"true\" [cdkTrapFocusAutoCapture]=\"true\">\r\n            <ng-container *ngIf=\"selectedFilter.type.kind !== 'custom'\">\r\n                <div class=\"mx-2 mt-1\" [ngSwitch]=\"selectedFilter.type.kind\">\r\n                    <div *ngSwitchCase=\"'select'\" [formGroup]=\"formControl\">\r\n                        <label *ngFor=\"let option of $any(selectedFilter.type).options; index as i\">\r\n                            <input type=\"checkbox\" [formControlName]=\"i\" />\r\n                            <span>{{ option.label | translate }}</span>\r\n                        </label>\r\n                    </div>\r\n                    <div *ngSwitchCase=\"'boolean'\">\r\n                        <label\r\n                            ><input type=\"checkbox\" [formControl]=\"formControl\" clrToggle />\r\n                            <span *ngIf=\"formControl.value\">{{ 'common.boolean-true' | translate }}</span>\r\n                            <span *ngIf=\"!formControl.value\">{{ 'common.boolean-false' | translate }}</span>\r\n                        </label>\r\n                    </div>\r\n                    <div *ngSwitchCase=\"'text'\">\r\n                        <div [formGroup]=\"formControl\">\r\n                            <div>\r\n                                <select name=\"options\" formControlName=\"operator\" class=\"mb-1\">\r\n                                    <option value=\"contains\">\r\n                                        {{ 'common.operator-contains' | translate }}\r\n                                    </option>\r\n                                    <option value=\"eq\">{{ 'common.operator-eq' | translate }}</option>\r\n                                    <option value=\"notContains\">\r\n                                        {{ 'common.operator-not-contains' | translate }}\r\n                                    </option>\r\n                                    <option value=\"notEq\">{{ 'common.operator-not-eq' | translate }}</option>\r\n                                    <option value=\"regex\">{{ 'common.operator-regex' | translate }}</option>\r\n                                </select>\r\n                            </div>\r\n                            <input type=\"text\" formControlName=\"term\" />\r\n                        </div>\r\n                    </div>\r\n                    <div *ngSwitchCase=\"'id'\">\r\n                        <div [formGroup]=\"formControl\">\r\n                            <div>\r\n                                <select name=\"options\" formControlName=\"operator\" class=\"mb-1\">\r\n                                    <option value=\"eq\">{{ 'common.operator-eq' | translate }}</option>\r\n                                    <option value=\"notEq\">{{ 'common.operator-not-eq' | translate }}</option>\r\n                                </select>\r\n                            </div>\r\n                            <input type=\"text\" formControlName=\"term\" />\r\n                        </div>\r\n                    </div>\r\n                    <div *ngSwitchCase=\"'number'\">\r\n                        <div [formGroup]=\"formControl\">\r\n                            <div>\r\n                                <select name=\"options\" formControlName=\"operator\" class=\"mb-1\">\r\n                                    <option value=\"eq\">{{ 'common.operator-eq' | translate }}</option>\r\n                                    <option value=\"gt\">{{ 'common.operator-gt' | translate }}</option>\r\n                                    <option value=\"lt\">{{ 'common.operator-lt' | translate }}</option>\r\n                                </select>\r\n                            </div>\r\n                            <input\r\n                                *ngIf=\"$any(selectedFilter.type).inputType !== 'currency'\"\r\n                                type=\"text\"\r\n                                formControlName=\"amount\"\r\n                            />\r\n                            <vdr-currency-input\r\n                                *ngIf=\"$any(selectedFilter.type).inputType === 'currency'\"\r\n                                formControlName=\"amount\"\r\n                            />\r\n                        </div>\r\n                    </div>\r\n                    <div *ngSwitchCase=\"'dateRange'\">\r\n                        <div [formGroup]=\"formControl\">\r\n                            <label>\r\n                                <div>{{ 'common.start-date' | translate }}</div>\r\n                            </label>\r\n                            <vdr-datetime-picker formControlName=\"start\"></vdr-datetime-picker>\r\n                            <label>\r\n                                <div>{{ 'common.end-date' | translate }}</div>\r\n                            </label>\r\n                            <vdr-datetime-picker formControlName=\"end\"></vdr-datetime-picker>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </ng-container>\r\n            <div class=\"apply-wrapper mt-2\">\r\n                <button class=\"button\" (click)=\"activate()\" [disabled]=\"!formControl?.valid\">\r\n                    <span>{{ 'common.apply' | translate }}</span>\r\n                    <clr-icon shape=\"check\"></clr-icon>\r\n                </button>\r\n            </div>\r\n        </form>\r\n    </vdr-dropdown-menu>\r\n</vdr-dropdown>\r\n"]}
|