@datarailsshared/datarailsshared 1.4.47-dragons → 1.4.48-bratans
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/bundles/datarailsshared-datarailsshared.umd.js +100 -56
- package/bundles/datarailsshared-datarailsshared.umd.js.map +1 -1
- package/datarailsshared-datarailsshared-1.4.48-bratans.tgz +0 -0
- package/datarailsshared-datarailsshared.d.ts +1 -0
- package/datarailsshared-datarailsshared.metadata.json +1 -1
- package/esm2015/datarailsshared-datarailsshared.js +2 -1
- package/esm2015/lib/dr-inputs/button/button.component.js +2 -2
- package/esm2015/lib/dr-inputs/date-pickers/dr-date-picker-with-timeframe/dr-date-picker-with-timeframe.component.js +19 -9
- package/esm2015/lib/dr-inputs/date-pickers/dr-date-picker_custom-header/dr-date-picker_custom-header.component.js +23 -8
- package/esm2015/lib/dr-inputs/date-pickers/dr-show-timeframe.pipe.js +12 -0
- package/esm2015/lib/dr-inputs/date-pickers/services/dr-date-picker.service.js +32 -4
- package/esm2015/lib/dr-inputs/dr-inputs.module.js +4 -2
- package/esm2015/lib/dr-tabs/dr-tabs.component.js +3 -5
- package/esm2015/lib/models/datePicker.js +3 -1
- package/esm2015/public-api.js +1 -2
- package/fesm2015/datarailsshared-datarailsshared.js +88 -48
- package/fesm2015/datarailsshared-datarailsshared.js.map +1 -1
- package/lib/dr-inputs/button/button.component.d.ts +1 -1
- package/lib/dr-inputs/date-pickers/dr-date-picker-with-timeframe/dr-date-picker-with-timeframe.component.d.ts +3 -1
- package/lib/dr-inputs/date-pickers/dr-date-picker_custom-header/dr-date-picker_custom-header.component.d.ts +2 -1
- package/lib/dr-inputs/date-pickers/dr-show-timeframe.pipe.d.ts +6 -0
- package/lib/dr-inputs/date-pickers/services/dr-date-picker.service.d.ts +2 -0
- package/lib/dr-tabs/dr-tabs.component.d.ts +0 -1
- package/lib/models/datePicker.d.ts +4 -1
- package/package.json +1 -1
- package/public-api.d.ts +0 -1
- package/datarailsshared-datarailsshared-1.4.47-dragons.tgz +0 -0
- package/esm2015/lib/utils/dr-shared-utils.js +0 -27
- package/lib/utils/dr-shared-utils.d.ts +0 -8
|
@@ -7,6 +7,7 @@ export { DrDatePickerFormatDirective as ɵf } from './lib/dr-inputs/date-pickers
|
|
|
7
7
|
export { DrDatePickerWithTimeframeComponent as ɵe } from './lib/dr-inputs/date-pickers/dr-date-picker-with-timeframe/dr-date-picker-with-timeframe.component';
|
|
8
8
|
export { DrDatePickerComponent as ɵc } from './lib/dr-inputs/date-pickers/dr-date-picker/dr-date-picker.component';
|
|
9
9
|
export { DrDatePickerCustomHeaderComponent as ɵg } from './lib/dr-inputs/date-pickers/dr-date-picker_custom-header/dr-date-picker_custom-header.component';
|
|
10
|
+
export { DrShowTimeframePipe as ɵh } from './lib/dr-inputs/date-pickers/dr-show-timeframe.pipe';
|
|
10
11
|
export { DrDatePickerService as ɵd } from './lib/dr-inputs/date-pickers/services/dr-date-picker.service';
|
|
11
12
|
export { POPUP_ANIMATION as ɵb } from './lib/models/constants';
|
|
12
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
13
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YXJhaWxzc2hhcmVkLWRhdGFyYWlsc3NoYXJlZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvZGF0YXJhaWxzc2hhcmVkLWRhdGFyYWlsc3NoYXJlZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDO0FBRTdCLE9BQU8sRUFBQyxVQUFVLElBQUksRUFBRSxFQUFDLE1BQU0saUNBQWlDLENBQUM7QUFDakUsT0FBTyxFQUFDLDJCQUEyQixJQUFJLEVBQUUsRUFBQyxNQUFNLHlFQUF5RSxDQUFDO0FBQzFILE9BQU8sRUFBQyxrQ0FBa0MsSUFBSSxFQUFFLEVBQUMsTUFBTSxvR0FBb0csQ0FBQztBQUM1SixPQUFPLEVBQUMscUJBQXFCLElBQUksRUFBRSxFQUFDLE1BQU0sc0VBQXNFLENBQUM7QUFDakgsT0FBTyxFQUFDLGlDQUFpQyxJQUFJLEVBQUUsRUFBQyxNQUFNLGtHQUFrRyxDQUFDO0FBQ3pKLE9BQU8sRUFBQyxtQkFBbUIsSUFBSSxFQUFFLEVBQUMsTUFBTSxxREFBcUQsQ0FBQztBQUM5RixPQUFPLEVBQUMsbUJBQW1CLElBQUksRUFBRSxFQUFDLE1BQU0sOERBQThELENBQUM7QUFDdkcsT0FBTyxFQUFDLGVBQWUsSUFBSSxFQUFFLEVBQUMsTUFBTSx3QkFBd0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcblxuZXhwb3J0IHtjb21wb25lbnRzIGFzIMm1YX0gZnJvbSAnLi9saWIvZGF0ZS10YWdzL2RhdGUtdGFnLm1vZHVsZSc7XG5leHBvcnQge0RyRGF0ZVBpY2tlckZvcm1hdERpcmVjdGl2ZSBhcyDJtWZ9IGZyb20gJy4vbGliL2RyLWlucHV0cy9kYXRlLXBpY2tlcnMvZGlyZWN0aXZlcy9kci1kYXRlLXBpY2tlci1mb3JtYXQuZGlyZWN0aXZlJztcbmV4cG9ydCB7RHJEYXRlUGlja2VyV2l0aFRpbWVmcmFtZUNvbXBvbmVudCBhcyDJtWV9IGZyb20gJy4vbGliL2RyLWlucHV0cy9kYXRlLXBpY2tlcnMvZHItZGF0ZS1waWNrZXItd2l0aC10aW1lZnJhbWUvZHItZGF0ZS1waWNrZXItd2l0aC10aW1lZnJhbWUuY29tcG9uZW50JztcbmV4cG9ydCB7RHJEYXRlUGlja2VyQ29tcG9uZW50IGFzIMm1Y30gZnJvbSAnLi9saWIvZHItaW5wdXRzL2RhdGUtcGlja2Vycy9kci1kYXRlLXBpY2tlci9kci1kYXRlLXBpY2tlci5jb21wb25lbnQnO1xuZXhwb3J0IHtEckRhdGVQaWNrZXJDdXN0b21IZWFkZXJDb21wb25lbnQgYXMgybVnfSBmcm9tICcuL2xpYi9kci1pbnB1dHMvZGF0ZS1waWNrZXJzL2RyLWRhdGUtcGlja2VyX2N1c3RvbS1oZWFkZXIvZHItZGF0ZS1waWNrZXJfY3VzdG9tLWhlYWRlci5jb21wb25lbnQnO1xuZXhwb3J0IHtEclNob3dUaW1lZnJhbWVQaXBlIGFzIMm1aH0gZnJvbSAnLi9saWIvZHItaW5wdXRzL2RhdGUtcGlja2Vycy9kci1zaG93LXRpbWVmcmFtZS5waXBlJztcbmV4cG9ydCB7RHJEYXRlUGlja2VyU2VydmljZSBhcyDJtWR9IGZyb20gJy4vbGliL2RyLWlucHV0cy9kYXRlLXBpY2tlcnMvc2VydmljZXMvZHItZGF0ZS1waWNrZXIuc2VydmljZSc7XG5leHBvcnQge1BPUFVQX0FOSU1BVElPTiBhcyDJtWJ9IGZyb20gJy4vbGliL21vZGVscy9jb25zdGFudHMnOyJdfQ==
|
|
@@ -42,7 +42,7 @@ DrButtonComponent.decorators = [
|
|
|
42
42
|
{ type: Component, args: [{
|
|
43
43
|
selector: 'dr-button',
|
|
44
44
|
template: "<button (click)=\"onClick($event)\" [disabled]=\"_disabled\" [attr.is-loading]=\"_isLoading\" [attr.bold]=\"isBold\"\n [attr.icon]=\"!!icon\" [attr.iconAfterLabel]=\"!!iconAfterLabel\" [attr.theme]=\"theme\">\n <ng-container *ngIf=\"!_isLoading\">\n <i *ngIf=\"icon\" class=\"dr\" [class]=\"icon\" [style.color]=\"iconColor || 'inherit'\"></i>\n <ng-content></ng-content>\n <i *ngIf=\"theme === 'dropdown'\" class=\"dr-icon-arrow-down\"></i>\n <i *ngIf=\"iconAfterLabel\" class=\"dr dr-last\" [class]=\"iconAfterLabel\" [style.color]=\"iconColor || 'inherit'\"></i>\n </ng-container>\n <i *ngIf=\"_isLoading\" class=\"dr dr-spinner dr-icon-load\"></i>\n</button>\n",
|
|
45
|
-
styles: [":host{display:inline-block}:host.disabled,:host.loading{pointer-events:none}:host button[theme]{cursor:pointer;border-radius:16px;padding:5px 16px;font-family:\"Poppins\";font-style:normal;font-weight:400;font-size:14px;line-height:22px;color:#4e566c;border:1px solid #7F7FDD;display:flex;justify-content:space-between;align-items:center;height:32px}:host button[theme] .dr{padding:0;margin-left:5.35px;margin-right:8.64px}:host button[theme] .dr-spinner{animation-name:rotate;animation-iteration-count:infinite;animation-duration:1s}@keyframes rotate{0%{transform:rotate()}to{transform:rotate(360deg)}}:host button[theme][theme~=split-secondary-first],:host button[theme][theme~=split-secondary-last],:host button[theme][theme~=secondary]{padding:5px 16px;background:#FFFFFF;border-radius:16px;min-width:90px}:host button[theme][theme~=split-secondary-first]:hover:not([disabled]),:host button[theme][theme~=split-secondary-last]:hover:not([disabled]),:host button[theme][theme~=secondary]:hover:not([disabled]){color:#4e566c;transition:.2ms ease-in all;background:#F2F2FB;box-shadow:0 4px 14px #0000001a;border:1px solid #4646CE}:host button[theme][theme~=split-secondary-first]:active,:host button[theme][theme~=split-secondary-last]:active,:host button[theme][theme~=secondary]:active{box-shadow:none;background:#F2F2FB}:host button[theme][theme~=split-secondary-first][disabled],:host button[theme][theme~=split-secondary-last][disabled],:host button[theme][theme~=secondary][disabled]{background:#F0F1F4;color:#727583;border:none;cursor:default;pointer-events:none}:host button[theme][theme~=split-secondary-first][is-loading=true],:host button[theme][theme~=split-secondary-last][is-loading=true],:host button[theme][theme~=secondary][is-loading=true]{justify-content:center;padding:5px 16px;pointer-events:none}:host button[theme][theme~=split-primary-first],:host button[theme][theme~=split-primary-last],:host button[theme][theme~=primary]{background:#4646CE;color:#fff;border:none;min-width:90px}:host button[theme][theme~=split-primary-first]:hover:not([disabled]),:host button[theme][theme~=split-primary-last]:hover:not([disabled]),:host button[theme][theme~=primary]:hover:not([disabled]){transition:.2ms ease-in all;background:linear-gradient(96.89deg,#25258C 0%,#4646CE 100%);box-shadow:0 4px 14px #0000001a;border:none}:host button[theme][theme~=split-primary-first]:active,:host button[theme][theme~=split-primary-last]:active,:host button[theme][theme~=primary]:active{background:#25258C}:host button[theme][theme~=split-primary-first][disabled],:host button[theme][theme~=split-primary-last][disabled],:host button[theme][theme~=primary][disabled]{background:#F0F1F4;color:#727583;border:none;cursor:default;pointer-events:none}:host button[theme][theme~=split-primary-first][is-loading=true],:host button[theme][theme~=split-primary-last][is-loading=true],:host button[theme][theme~=primary][is-loading=true]{justify-content:center;padding:5px 16px;pointer-events:none}:host button[theme][theme~=split-primary-first] .dr,:host button[theme][theme~=split-primary-last] .dr,:host button[theme][theme~=primary] .dr{margin:0}:host button[theme][theme~=split-secondary-first],:host button[theme][theme~=split-secondary-first]:hover,:host button[theme][theme~=split-primary-first],:host button[theme][theme~=split-primary-first]:hover{min-width:unset;border-bottom-right-radius:0;border-top-right-radius:0;padding-left:10px;padding-right:8px}:host button[theme][theme~=split-secondary-first][icon=true],:host button[theme][theme~=split-secondary-first]:hover[icon=true],:host button[theme][theme~=split-primary-first][icon=true],:host button[theme][theme~=split-primary-first]:hover[icon=true]{padding-left:6px;padding-right:2px}:host button[theme][theme~=split-primary-first],:host button[theme][theme~=split-primary-first]:hover{border-right:1px solid #fff!important}:host button[theme][theme~=split-secondary-first],:host button[theme][theme~=split-secondary-first]:hover{border-right:none!important}:host button[theme][theme~=split-secondary-last],:host button[theme][theme~=split-secondary-last]:hover,:host button[theme][theme~=split-primary-last],:host button[theme][theme~=split-primary-last]:hover{min-width:unset;border-bottom-left-radius:0;border-top-left-radius:0;padding-left:8px;padding-right:10px}:host button[theme][theme~=split-secondary-last][icon=true],:host button[theme][theme~=split-secondary-last]:hover[icon=true],:host button[theme][theme~=split-primary-last][icon=true],:host button[theme][theme~=split-primary-last]:hover[icon=true]{padding-left:2px;padding-right:6px}:host button[theme][theme~=split-secondary-last] .dr,:host button[theme][theme~=split-secondary-last]:hover .dr,:host button[theme][theme~=split-primary-last] .dr,:host button[theme][theme~=split-primary-last]:hover .dr{margin:0}:host button[theme][theme~=split-primary-last],:host button[theme][theme~=split-primary-last]:hover{border-left:none}:host button[theme][theme~=split-secondary-last],:host button[theme][theme~=split-secondary-last]:hover{margin-left:-1px}:host button[theme][theme~=danger]{background:#BF1D30;color:#fff;border:none;min-width:90px}:host button[theme][theme~=danger]:hover:not([disabled]){transition:.2ms ease-in all;background:linear-gradient(96.89deg,#740e1a 0%,#BF1D30 100%);box-shadow:0 4px 14px #0000001a;border-radius:16px;border:none}:host button[theme][theme~=danger]:active{background:#740e1a}:host button[theme][theme~=danger][disabled]{background:#F0F1F4;color:#727583;border:none;cursor:default;pointer-events:none}:host button[theme][theme~=danger][is-loading=true]{justify-content:center;padding:5px 16px;pointer-events:none}:host button[theme][theme~=ghost]{background:none;border:none;color:#151b3f;padding:4px 8px}:host button[theme][theme~=ghost] .dr{margin-left:4.5px;margin-right:12.5px}:host button[theme][theme~=ghost]:hover:not([disabled]){color:#4646ce;background:#F2F2FB;border-radius:4px}:host button[theme][theme~=ghost][disabled]{color:#727583;cursor:default;pointer-events:none}:host button[theme][theme~=text-link]{background:none;border:none;color:#0b5af9}:host button[theme][theme~=text-link][disabled]{color:#727583;pointer-events:none}:host button[theme][theme~=primary-icon]{padding:8px;width:28px;height:28px;justify-content:center;color:#fff;background:#4646CE;border:none}:host button[theme][theme~=primary-icon]:hover,:host button[theme][theme~=primary-icon]:active{background:linear-gradient(96.89deg,#131318 0%,#4646CE 100%)}:host button[theme][theme~=primary-icon][disabled]{color:#bcbcbc;background:#E5E6EA;cursor:default;pointer-events:none}:host button[theme][theme~=primary-icon] .dr{margin:0}:host button[theme][theme~=secondary-icon]{background:white;padding:8px;width:28px;height:28px;justify-content:center;color:#4e566c;border:1px solid #7F7FDD}:host button[theme][theme~=secondary-icon]:hover,:host button[theme][theme~=secondary-icon]:active{color:#4646ce;background:#F2F2FB}:host button[theme][theme~=secondary-icon][disabled]{color:#bcbcbc;background:#E5E6EA;border:none;cursor:default;pointer-events:none}:host button[theme][theme~=secondary-icon] .dr{margin:0}:host button[theme][theme~=simple-text]{color:#0c142b;border:none;background:none}:host button[theme][theme~=simple-text] .dr{margin:0 8px 0 0}:host button[theme][theme~=icon]{background:none;padding:8px;width:28px;height:28px;justify-content:center;color:#4e566c;border:none}:host button[theme][theme~=icon]:hover,:host button[theme][theme~=icon]:active{background:#F0F3FC;color:#4646ce}:host button[theme][theme~=icon][disabled]{color:#bcbcbc;border:none;cursor:default;pointer-events:none}:host button[theme][theme~=icon][disabled]:hover,:host button[theme][theme~=icon][disabled]:active{background:none}:host button[theme][theme~=icon] .dr{margin:0}:host button[theme][theme~=dropdown]
|
|
45
|
+
styles: [":host{display:inline-block}:host.disabled,:host.loading{pointer-events:none}:host button[theme]{cursor:pointer;border-radius:16px;padding:5px 16px;font-family:\"Poppins\";font-style:normal;font-weight:400;font-size:14px;line-height:22px;color:#4e566c;border:1px solid #7F7FDD;display:flex;justify-content:space-between;align-items:center;height:32px}:host button[theme] .dr{padding:0;margin-left:5.35px;margin-right:8.64px}:host button[theme] .dr-spinner{animation-name:rotate;animation-iteration-count:infinite;animation-duration:1s}@keyframes rotate{0%{transform:rotate()}to{transform:rotate(360deg)}}:host button[theme][theme~=split-secondary-first],:host button[theme][theme~=split-secondary-last],:host button[theme][theme~=secondary]{padding:5px 16px;background:#FFFFFF;border-radius:16px;min-width:90px}:host button[theme][theme~=split-secondary-first]:hover:not([disabled]),:host button[theme][theme~=split-secondary-last]:hover:not([disabled]),:host button[theme][theme~=secondary]:hover:not([disabled]){color:#4e566c;transition:.2ms ease-in all;background:#F2F2FB;box-shadow:0 4px 14px #0000001a;border:1px solid #4646CE}:host button[theme][theme~=split-secondary-first]:active,:host button[theme][theme~=split-secondary-last]:active,:host button[theme][theme~=secondary]:active{box-shadow:none;background:#F2F2FB}:host button[theme][theme~=split-secondary-first][disabled],:host button[theme][theme~=split-secondary-last][disabled],:host button[theme][theme~=secondary][disabled]{background:#F0F1F4;color:#727583;border:none;cursor:default;pointer-events:none}:host button[theme][theme~=split-secondary-first][is-loading=true],:host button[theme][theme~=split-secondary-last][is-loading=true],:host button[theme][theme~=secondary][is-loading=true]{justify-content:center;padding:5px 16px;pointer-events:none}:host button[theme][theme~=split-primary-first],:host button[theme][theme~=split-primary-last],:host button[theme][theme~=primary]{background:#4646CE;color:#fff;border:none;min-width:90px}:host button[theme][theme~=split-primary-first]:hover:not([disabled]),:host button[theme][theme~=split-primary-last]:hover:not([disabled]),:host button[theme][theme~=primary]:hover:not([disabled]){transition:.2ms ease-in all;background:linear-gradient(96.89deg,#25258C 0%,#4646CE 100%);box-shadow:0 4px 14px #0000001a;border:none}:host button[theme][theme~=split-primary-first]:active,:host button[theme][theme~=split-primary-last]:active,:host button[theme][theme~=primary]:active{background:#25258C}:host button[theme][theme~=split-primary-first][disabled],:host button[theme][theme~=split-primary-last][disabled],:host button[theme][theme~=primary][disabled]{background:#F0F1F4;color:#727583;border:none;cursor:default;pointer-events:none}:host button[theme][theme~=split-primary-first][is-loading=true],:host button[theme][theme~=split-primary-last][is-loading=true],:host button[theme][theme~=primary][is-loading=true]{justify-content:center;padding:5px 16px;pointer-events:none}:host button[theme][theme~=split-primary-first] .dr,:host button[theme][theme~=split-primary-last] .dr,:host button[theme][theme~=primary] .dr{margin:0}:host button[theme][theme~=split-secondary-first],:host button[theme][theme~=split-secondary-first]:hover,:host button[theme][theme~=split-primary-first],:host button[theme][theme~=split-primary-first]:hover{min-width:unset;border-bottom-right-radius:0;border-top-right-radius:0;padding-left:10px;padding-right:8px}:host button[theme][theme~=split-secondary-first][icon=true],:host button[theme][theme~=split-secondary-first]:hover[icon=true],:host button[theme][theme~=split-primary-first][icon=true],:host button[theme][theme~=split-primary-first]:hover[icon=true]{padding-left:6px;padding-right:2px}:host button[theme][theme~=split-primary-first],:host button[theme][theme~=split-primary-first]:hover{border-right:1px solid #fff!important}:host button[theme][theme~=split-secondary-first],:host button[theme][theme~=split-secondary-first]:hover{border-right:none!important}:host button[theme][theme~=split-secondary-last],:host button[theme][theme~=split-secondary-last]:hover,:host button[theme][theme~=split-primary-last],:host button[theme][theme~=split-primary-last]:hover{min-width:unset;border-bottom-left-radius:0;border-top-left-radius:0;padding-left:8px;padding-right:10px}:host button[theme][theme~=split-secondary-last][icon=true],:host button[theme][theme~=split-secondary-last]:hover[icon=true],:host button[theme][theme~=split-primary-last][icon=true],:host button[theme][theme~=split-primary-last]:hover[icon=true]{padding-left:2px;padding-right:6px}:host button[theme][theme~=split-secondary-last] .dr,:host button[theme][theme~=split-secondary-last]:hover .dr,:host button[theme][theme~=split-primary-last] .dr,:host button[theme][theme~=split-primary-last]:hover .dr{margin:0}:host button[theme][theme~=split-primary-last],:host button[theme][theme~=split-primary-last]:hover{border-left:none}:host button[theme][theme~=split-secondary-last],:host button[theme][theme~=split-secondary-last]:hover{margin-left:-1px}:host button[theme][theme~=danger]{background:#BF1D30;color:#fff;border:none;min-width:90px}:host button[theme][theme~=danger]:hover:not([disabled]){transition:.2ms ease-in all;background:linear-gradient(96.89deg,#740e1a 0%,#BF1D30 100%);box-shadow:0 4px 14px #0000001a;border-radius:16px;border:none}:host button[theme][theme~=danger]:active{background:#740e1a}:host button[theme][theme~=danger][disabled]{background:#F0F1F4;color:#727583;border:none;cursor:default;pointer-events:none}:host button[theme][theme~=danger][is-loading=true]{justify-content:center;padding:5px 16px;pointer-events:none}:host button[theme][theme~=ghost]{background:none;border:none;color:#151b3f;padding:4px 8px}:host button[theme][theme~=ghost] .dr{margin-left:4.5px;margin-right:12.5px}:host button[theme][theme~=ghost]:hover:not([disabled]){color:#4646ce;background:#F2F2FB;border-radius:4px}:host button[theme][theme~=ghost][disabled]{color:#727583;cursor:default;pointer-events:none}:host button[theme][theme~=text-link]{background:none;border:none;color:#0b5af9}:host button[theme][theme~=text-link][disabled]{color:#727583;pointer-events:none}:host button[theme][theme~=primary-icon]{padding:8px;width:28px;height:28px;justify-content:center;color:#fff;background:#4646CE;border:none}:host button[theme][theme~=primary-icon]:hover,:host button[theme][theme~=primary-icon]:active{background:linear-gradient(96.89deg,#131318 0%,#4646CE 100%)}:host button[theme][theme~=primary-icon][disabled]{color:#bcbcbc;background:#E5E6EA;cursor:default;pointer-events:none}:host button[theme][theme~=primary-icon] .dr{margin:0}:host button[theme][theme~=secondary-icon]{background:white;padding:8px;width:28px;height:28px;justify-content:center;color:#4e566c;border:1px solid #7F7FDD}:host button[theme][theme~=secondary-icon]:hover,:host button[theme][theme~=secondary-icon]:active{color:#4646ce;background:#F2F2FB}:host button[theme][theme~=secondary-icon][disabled]{color:#bcbcbc;background:#E5E6EA;border:none;cursor:default;pointer-events:none}:host button[theme][theme~=secondary-icon] .dr{margin:0}:host button[theme][theme~=simple-text]{color:#0c142b;border:none;background:none}:host button[theme][theme~=simple-text] .dr{margin:0 8px 0 0}:host button[theme][theme~=icon]{background:none;padding:8px;width:28px;height:28px;justify-content:center;color:#4e566c;border:none}:host button[theme][theme~=icon]:hover,:host button[theme][theme~=icon]:active{background:#F0F3FC;color:#4646ce}:host button[theme][theme~=icon][disabled]{color:#bcbcbc;border:none;cursor:default;pointer-events:none}:host button[theme][theme~=icon][disabled]:hover,:host button[theme][theme~=icon][disabled]:active{background:none}:host button[theme][theme~=icon] .dr{margin:0}:host button[theme][theme~=dropdown]{padding:0 8px;background:#FFFFFF;border-radius:6px;border:1px solid #C3C4CE;min-width:unset;box-shadow:none}:host button[theme][theme~=dropdown]:hover{border-color:#85889c}:host button[theme][theme~=dropdown]:active{border-color:#4646ce}:host button[theme][theme~=dropdown] i:first-child{margin-right:3px}:host button[theme][theme~=dropdown] i:last-child{margin-left:3px}:host button[theme][theme~=link-btn]{padding:5px 8px;border:none;background:none;border-radius:5px;color:#0c142b}:host button[theme][theme~=link-btn] .dr{margin:0 4px 0 0}:host button[theme][theme~=link-btn] .dr-last{margin-right:0;margin-left:4px}:host button[theme][theme~=link-btn]:hover{background:#F2F2FB;color:#4646ce}:host button[theme][theme~=link-btn]:active{background:#F2F2FB;color:#25258c}:host button[theme][theme~=link-btn]:disabled{background:none;color:#727583}:host button[theme][theme~=link-btn]:disabled .dr{color:#bcbcbc}:host button[theme][bold=true]{font-weight:600}:host button[theme][icon=true]{padding-left:8px}:host button[theme][icon=false]{justify-content:center}\n"]
|
|
46
46
|
},] }
|
|
47
47
|
];
|
|
48
48
|
DrButtonComponent.ctorParameters = () => [];
|
|
@@ -77,4 +77,4 @@ DrButtonComponent.propDecorators = {
|
|
|
77
77
|
<dr-button [isDisabled]="false" [icon]="'dr-icon-refresh'" [theme]="'ghost'">Ghost</dr-button>
|
|
78
78
|
<dr-button [isDisabled]="false" [theme]="'text-link'">Text Link</dr-button>
|
|
79
79
|
*/
|
|
80
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
80
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RyLWlucHV0cy9idXR0b24vYnV0dG9uLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQVVwRixNQUFNLE9BQU8saUJBQWlCO0lBc0M1QjtRQXBDQSxjQUFTLEdBQUcsSUFBSSxDQUFDO1FBQ2pCLGVBQVUsR0FBRyxLQUFLLENBQUM7UUFDbkIsa0JBQWEsR0FBYSxFQUFFLENBQUM7UUFHcEIsVUFBSyxHQUFlLFNBQVMsQ0FBQztRQUc5QixXQUFNLEdBQVksS0FBSyxDQUFDO1FBa0J2QixVQUFLLEdBQUcsSUFBSSxZQUFZLEVBQUUsQ0FBQztJQVVyQixDQUFDO0lBMUJqQixJQUFhLFFBQVEsQ0FBQyxLQUFLO1FBQ3pCLElBQUksS0FBSyxFQUFFO1lBQ1QsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7U0FDckM7YUFBTTtZQUNMLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxJQUFJLEtBQUssVUFBVSxDQUFDLENBQUM7U0FDN0U7UUFDRCxJQUFJLENBQUMsU0FBUyxHQUFHLEtBQUssQ0FBQztJQUN6QixDQUFDO0lBQ0QsSUFBYSxTQUFTLENBQUMsS0FBSztRQUMxQixJQUFJLEtBQUssRUFBRTtZQUNULElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1NBQ3BDO2FBQU07WUFDTCxJQUFJLENBQUMsYUFBYSxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsSUFBSSxLQUFLLFNBQVMsQ0FBQyxDQUFDO1NBQzVFO1FBQ0QsSUFBSSxDQUFDLFVBQVUsR0FBRyxDQUFDLENBQUMsS0FBSyxDQUFDO0lBQzVCLENBQUM7SUFHRCxJQUNJLFlBQVk7UUFDZCxPQUFPLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ3RDLENBQUM7SUFDRCxHQUFHLENBQUMsR0FBVztRQUNiLElBQUksQ0FBQyxhQUFhLEdBQUcsR0FBRyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUN0QyxDQUFDO0lBSU0sT0FBTyxDQUFDLE1BQU07UUFDbkIsTUFBTSxDQUFDLGNBQWMsRUFBRSxDQUFDO1FBQ3hCLE1BQU0sQ0FBQyxlQUFlLEVBQUUsQ0FBQztRQUN6QixJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUMxQixDQUFDOzs7WUFqREYsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSxXQUFXO2dCQUNyQixndEJBQXNDOzthQUV2Qzs7OztvQkFPRSxLQUFLO29CQUNMLEtBQUs7bUJBQ0wsS0FBSzs2QkFDTCxLQUFLO3FCQUNMLEtBQUs7d0JBQ0wsS0FBSzt1QkFDTCxLQUFLO3dCQVFMLEtBQUs7b0JBUUwsTUFBTTsyQkFFTixXQUFXLFNBQUMsT0FBTzs7QUFnQnRCLGFBQWE7QUFDYjs7Ozs7Ozs7Ozs7Ozs7Ozs7RUFpQkUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSG9zdEJpbmRpbmcsIElucHV0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbnR5cGUgQnV0dG9uVHlwZSA9ICdwcmltYXJ5JyB8ICdzZWNvbmRhcnknIHwgJ2RhbmdlcicgfCAncHJpbWFyeS1pY29uJyB8XG4gICdzZWNvbmRhcnktaWNvbicgfCAnaWNvbicgfCAnZ2hvc3QnIHwgJ2xpbmstYnRuJyB8ICd0ZXh0LWxpbmsnIHwgJ3NpbXBsZS10ZXh0JyB8XG4gICdzcGxpdC1wcmltYXJ5LWZpcnN0JyB8ICdzcGxpdC1wcmltYXJ5LWxhc3QnIHwgJ3NwbGl0LXNlY29uZGFyeS1maXJzdCcgfCAnc3BsaXQtc2Vjb25kYXJ5LWxhc3QnIHwgJ2Ryb3Bkb3duJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZHItYnV0dG9uJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2J1dHRvbi5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2J1dHRvbi5jb21wb25lbnQuc2NzcyddXG59KVxuZXhwb3J0IGNsYXNzIERyQnV0dG9uQ29tcG9uZW50IHtcblxuICBfZGlzYWJsZWQgPSBudWxsO1xuICBfaXNMb2FkaW5nID0gZmFsc2U7XG4gIF9lbGVtZW50Q2xhc3M6IHN0cmluZ1tdID0gW107XG5cbiAgQElucHV0KCkgdGl0bGU6IHN0cmluZztcbiAgQElucHV0KCkgdGhlbWU6IEJ1dHRvblR5cGUgPSAncHJpbWFyeSc7XG4gIEBJbnB1dCgpIGljb246IHN0cmluZztcbiAgQElucHV0KCkgaWNvbkFmdGVyTGFiZWw6IHN0cmluZztcbiAgQElucHV0KCkgaXNCb2xkOiBib29sZWFuID0gZmFsc2U7XG4gIEBJbnB1dCgpIGljb25Db2xvcjogc3RyaW5nO1xuICBASW5wdXQoKSBzZXQgZGlzYWJsZWQodmFsdWUpIHtcbiAgICBpZiAodmFsdWUpIHtcbiAgICAgIHRoaXMuX2VsZW1lbnRDbGFzcy5wdXNoKCdkaXNhYmxlZCcpO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLl9lbGVtZW50Q2xhc3MgPSB0aGlzLl9lbGVtZW50Q2xhc3MuZmlsdGVyKGl0ZW0gPT4gaXRlbSAhPT0gJ2Rpc2FibGVkJyk7XG4gICAgfVxuICAgIHRoaXMuX2Rpc2FibGVkID0gdmFsdWU7XG4gIH1cbiAgQElucHV0KCkgc2V0IGlzTG9hZGluZyh2YWx1ZSkge1xuICAgIGlmICh2YWx1ZSkge1xuICAgICAgdGhpcy5fZWxlbWVudENsYXNzLnB1c2goJ2xvYWRpbmcnKTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5fZWxlbWVudENsYXNzID0gdGhpcy5fZWxlbWVudENsYXNzLmZpbHRlcihpdGVtID0+IGl0ZW0gIT09ICdsb2FkaW5nJyk7XG4gICAgfVxuICAgIHRoaXMuX2lzTG9hZGluZyA9ICEhdmFsdWU7XG4gIH1cbiAgQE91dHB1dCgpIGNsaWNrID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuXG4gIEBIb3N0QmluZGluZygnY2xhc3MnKVxuICBnZXQgZWxlbWVudENsYXNzKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuX2VsZW1lbnRDbGFzcy5qb2luKCcgJyk7XG4gIH1cbiAgc2V0KHZhbDogc3RyaW5nKSB7XG4gICAgdGhpcy5fZWxlbWVudENsYXNzID0gdmFsLnNwbGl0KCcgJyk7XG4gIH1cblxuICBjb25zdHJ1Y3RvcigpIHsgfVxuXG4gIHB1YmxpYyBvbkNsaWNrKCRldmVudCkge1xuICAgICRldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xuICAgICRldmVudC5zdG9wUHJvcGFnYXRpb24oKTtcbiAgICB0aGlzLmNsaWNrLmVtaXQoJGV2ZW50KTtcbiAgfVxufVxuLy8gIEV4YW1wbGVzOlxuLypcbjxkci1idXR0b24gW2ljb25dPVwiJ2RyLWljb24tYXJyb3ctZG93bidcIj5oZWxsbzwvZHItYnV0dG9uPlxuPGRyLWJ1dHRvbiBbaWNvbl09XCInZHItaWNvbi1yZWZyZXNoJ1wiIFt0aGVtZV09XCIncHJpbWFyeS1pY29uJ1wiPjwvZHItYnV0dG9uPlxuPGRyLWJ1dHRvbiBbaWNvbl09XCInZHItaWNvbi1yZWZyZXNoJ1wiIFtpc0Rpc2FibGVkXT1cInRydWVcIiBbdGhlbWVdPVwiJ3ByaW1hcnktaWNvbidcIj48L2RyLWJ1dHRvbj5cbjxkci1idXR0b24gW3RoZW1lXT1cIidzZWNvbmRhcnknXCIgW2ljb25dPVwiJ2RyLWljb24tZXhjZWwnXCIgW2ljb25Db2xvcl09XCInIzAzQTY3OCdcIj48L2RyLWJ1dHRvbj5cblxuPGRyLWJ1dHRvbiBbaWNvbl09XCInZHItaWNvbi1yZWZyZXNoJ1wiIFt0aGVtZV09XCInc2Vjb25kYXJ5LWljb24nXCI+PC9kci1idXR0b24+XG48ZHItYnV0dG9uIFtpY29uXT1cIidkci1pY29uLXNoYXJlJ1wiIFtpc0Rpc2FibGVkXT1cInRydWVcIiBbdGhlbWVdPVwiJ3NlY29uZGFyeS1pY29uJ1wiPjwvZHItYnV0dG9uPlxuXG48ZHItYnV0dG9uIFtpY29uXT1cIidkci1pY29uLXNoYXJlJ1wiIFt0aGVtZV09XCInaWNvbidcIj48L2RyLWJ1dHRvbj5cbjxkci1idXR0b24gW2ljb25dPVwiJ2RyLWljb24tc2hhcmUnXCIgW2lzRGlzYWJsZWRdPVwidHJ1ZVwiIFt0aGVtZV09XCInaWNvbidcIj48L2RyLWJ1dHRvbj5cblxuPGRyLWJ1dHRvbiBbaXNEaXNhYmxlZF09XCJmYWxzZVwiIFtpY29uXT1cIidkci1pY29uLXJlZnJlc2gnXCI+UHJpbWFyeTwvZHItYnV0dG9uPlxuPGRyLWJ1dHRvbiBbaXNEaXNhYmxlZF09XCJmYWxzZVwiID5QcmltYXJ5PC9kci1idXR0b24+XG48ZHItYnV0dG9uIFtpc0Rpc2FibGVkXT1cImZhbHNlXCIgW2ljb25dPVwiJ2RyLWljb24tcmVmcmVzaCdcIiBbdGhlbWVdPVwiJ3NlY29uZGFyeSdcIj5TZWNvbmRhcnk8L2RyLWJ1dHRvbj5cbjxkci1idXR0b24gW2lzRGlzYWJsZWRdPVwiZmFsc2VcIiBbaWNvbl09XCInZHItaWNvbi1yZWZyZXNoJ1wiIFt0aGVtZV09XCInZ2hvc3QnXCI+R2hvc3Q8L2RyLWJ1dHRvbj5cbjxkci1idXR0b24gW2lzRGlzYWJsZWRdPVwiZmFsc2VcIiBbdGhlbWVdPVwiJ3RleHQtbGluaydcIj5UZXh0IExpbms8L2RyLWJ1dHRvbj5cbiovXG4iXX0=
|
|
@@ -18,12 +18,14 @@ export class DrDatePickerWithTimeframeComponent extends DrDatePickerComponent {
|
|
|
18
18
|
[TimeframeOption.YEAR]: (forward) => this.pagingDateChange('addCalendarYears', 1, forward),
|
|
19
19
|
[TimeframeOption.QUARTER]: (forward) => this.pagingDateChange('addCalendarMonths', 3, forward),
|
|
20
20
|
[TimeframeOption.MONTH]: (forward) => this.pagingDateChange('addCalendarMonths', 1, forward),
|
|
21
|
-
[TimeframeOption.DAY]: (forward) => this.pagingDateChange('addCalendarDays', 1, forward)
|
|
21
|
+
[TimeframeOption.DAY]: (forward) => this.pagingDateChange('addCalendarDays', 1, forward),
|
|
22
|
+
[TimeframeOption.WEEK]: (forward) => this.pagingDateChange('addCalendarDays', 7, forward)
|
|
22
23
|
};
|
|
23
24
|
datePickerService.isTimeframeSelectionEnabled = true;
|
|
24
25
|
datePickerService.format$
|
|
25
26
|
.pipe(takeUntil(this.destroyed$))
|
|
26
27
|
.subscribe((value) => {
|
|
28
|
+
datePickerService.format$.getValue();
|
|
27
29
|
this.onChangeFormat.emit(datePickerService.normalizeValue(value));
|
|
28
30
|
});
|
|
29
31
|
}
|
|
@@ -37,19 +39,26 @@ export class DrDatePickerWithTimeframeComponent extends DrDatePickerComponent {
|
|
|
37
39
|
this.cdr.markForCheck();
|
|
38
40
|
}
|
|
39
41
|
}
|
|
42
|
+
set availableTimeframes(value) {
|
|
43
|
+
if (value && value.length) {
|
|
44
|
+
this.datePickerService.availableTimeframes = value;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
40
47
|
get displayedFormattedValue() {
|
|
41
|
-
var _a;
|
|
42
48
|
if (!this.value) {
|
|
43
49
|
return this.placeholder;
|
|
44
50
|
}
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
:
|
|
51
|
+
const formatCached = this.datePickerService.format$.getValue();
|
|
52
|
+
switch (true) {
|
|
53
|
+
case formatCached === null || formatCached === void 0 ? void 0 : formatCached.includes('Q'):
|
|
54
|
+
return this.datePickerService.getQuarterDisplay(this.value);
|
|
55
|
+
case formatCached === null || formatCached === void 0 ? void 0 : formatCached.includes('W'):
|
|
56
|
+
return this.datePickerService.getWeekDisplay(this.value);
|
|
57
|
+
default:
|
|
58
|
+
return this.value.format(formatCached);
|
|
59
|
+
}
|
|
48
60
|
}
|
|
49
61
|
ngOnInit() {
|
|
50
|
-
if (this.dateFormatConfig) {
|
|
51
|
-
this.datePickerService.formatConfig = Object.assign(Object.assign({}, this.datePickerService.formatConfig), this.dateFormatConfig);
|
|
52
|
-
}
|
|
53
62
|
this.datePickerService.isTimeframeSelectionEnabled = this.canSelectTimeframe;
|
|
54
63
|
this.cdr.markForCheck();
|
|
55
64
|
}
|
|
@@ -84,6 +93,7 @@ DrDatePickerWithTimeframeComponent.propDecorators = {
|
|
|
84
93
|
isDashboardDatepicker: [{ type: Input }],
|
|
85
94
|
dateFormatConfig: [{ type: Input }],
|
|
86
95
|
canSelectTimeframe: [{ type: Input }],
|
|
96
|
+
availableTimeframes: [{ type: Input }],
|
|
87
97
|
onChangeFormat: [{ type: Output }]
|
|
88
98
|
};
|
|
89
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-date-picker-with-timeframe.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/dr-date-picker-with-timeframe/dr-date-picker-with-timeframe.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ChangeDetectionStrategy, ChangeDetectorRef, Component, HostBinding, Input, OnInit, OnDestroy, Output, EventEmitter } from '@angular/core';\nimport { DrDatePickerComponent } from '../dr-date-picker/dr-date-picker.component';\nimport { DateAdapter } from '@angular/material/core';\nimport { DrDatePickerService } from '../services/dr-date-picker.service';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { IDatePickerFormatConfig, TimeframeOption } from '../../../models/datePicker';\nimport { takeUntil } from 'rxjs/operators';\n\n@Component({\n  selector: 'dr-date-picker-with-timeframe',\n  templateUrl: './dr-date-picker-with-timeframe.component.html',\n  styleUrls: ['./dr-date-picker-with-timeframe.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    { provide: NG_VALUE_ACCESSOR, useExisting: DrDatePickerWithTimeframeComponent, multi: true },\n    { provide: DrDatePickerService }\n  ],\n})\nexport class DrDatePickerWithTimeframeComponent extends DrDatePickerComponent implements ControlValueAccessor, AfterViewInit, OnDestroy, OnInit {\n\n  @HostBinding('class.dr-date-picker-on-dashboard') get isDashboardClassDisplayed(): boolean {\n    return this.isDashboardDatepicker;\n  };\n\n  @Input() isDashboardDatepicker = false;\n  @Input() set dateFormatConfig (value: IDatePickerFormatConfig) {\n    if (value) {\n            this.datePickerService.formatConfig = { ...this.datePickerService.formatConfig, ...value };\n            this.cdr.markForCheck();\n        }\n    }\n    @Input()  canSelectTimeframe = true;\n\n  @Output() onChangeFormat = new EventEmitter<string>();\n\n  public readonly pagingSetup = {\n    [TimeframeOption.YEAR]: (forward) =>  this.pagingDateChange('addCalendarYears', 1, forward),\n    [TimeframeOption.QUARTER]: (forward) =>  this.pagingDateChange('addCalendarMonths', 3, forward),\n    [TimeframeOption.MONTH]: (forward) =>  this.pagingDateChange('addCalendarMonths', 1, forward),\n    [TimeframeOption.DAY]: (forward) =>  this.pagingDateChange('addCalendarDays', 1, forward)\n  }\n\n  public get displayedFormattedValue(): string {\n    if (!this.value) {\n      return this.placeholder;\n    }\n    return this.datePickerService.format$.getValue()?.includes('Q')\n      ? this.datePickerService.getQuarterDisplay(this.value)\n      : this.value.format(this.datePickerService.format$.getValue())\n  }\n\n  constructor(\n    protected cdr: ChangeDetectorRef,\n    protected dateAdapter: DateAdapter<any>,\n    public datePickerService: DrDatePickerService\n  ) {\n    super(cdr, dateAdapter, datePickerService);\n    datePickerService.isTimeframeSelectionEnabled = true;\n\n    datePickerService.format$\n      .pipe(takeUntil(this.destroyed$))\n      .subscribe((value) => {\n        this.onChangeFormat.emit(datePickerService.normalizeValue(value));\n      });\n  }\n\n  ngOnInit() {\n    if (this.dateFormatConfig) {\n      this.datePickerService.formatConfig = { ...this.datePickerService.formatConfig, ...this.dateFormatConfig };\n    }\n    this.datePickerService.isTimeframeSelectionEnabled = this.canSelectTimeframe;\n    this.cdr.markForCheck();\n  }\n\n  pagingClicked(forward: boolean): void {\n    this.pagingSetup[this.datePickerService.timeframe] && this.pagingSetup[this.datePickerService.timeframe](forward);\n    this.datePicker.close();\n  }\n\n  pagingDateChange(actionCall: string, amount: number, forward: boolean) {\n    const newValue = this.dateAdapter[actionCall](this.innerValue, forward ? amount : -amount);\n    this.setValueFromMoment(newValue);\n  }\n}\n"]}
|
|
99
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-date-picker-with-timeframe.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/dr-date-picker-with-timeframe/dr-date-picker-with-timeframe.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ChangeDetectionStrategy, ChangeDetectorRef, Component, HostBinding, Input, OnInit, OnDestroy, Output, EventEmitter } from '@angular/core';\nimport { DrDatePickerComponent } from '../dr-date-picker/dr-date-picker.component';\nimport { DateAdapter } from '@angular/material/core';\nimport { DrDatePickerService } from '../services/dr-date-picker.service';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { IDatePickerFormatConfig, TimeframeOption } from '../../../models/datePicker';\nimport { takeUntil } from 'rxjs/operators';\n\n@Component({\n  selector: 'dr-date-picker-with-timeframe',\n  templateUrl: './dr-date-picker-with-timeframe.component.html',\n  styleUrls: ['./dr-date-picker-with-timeframe.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    { provide: NG_VALUE_ACCESSOR, useExisting: DrDatePickerWithTimeframeComponent, multi: true },\n    { provide: DrDatePickerService }\n  ],\n})\nexport class DrDatePickerWithTimeframeComponent extends DrDatePickerComponent implements ControlValueAccessor, AfterViewInit, OnDestroy, OnInit {\n\n  @HostBinding('class.dr-date-picker-on-dashboard') get isDashboardClassDisplayed(): boolean {\n    return this.isDashboardDatepicker;\n  };\n\n  @Input() isDashboardDatepicker = false;\n  @Input() set dateFormatConfig (value: IDatePickerFormatConfig) {\n    if (value) {\n            this.datePickerService.formatConfig = { ...this.datePickerService.formatConfig, ...value };\n            this.cdr.markForCheck();\n        }\n    }\n    @Input() canSelectTimeframe = true;\n    @Input() set availableTimeframes (value: TimeframeOption[]){\n            if (value && value.length) {\n                this.datePickerService.availableTimeframes = value;\n            }\n        }\n\n  @Output() onChangeFormat = new EventEmitter<string>();\n\n  public readonly pagingSetup = {\n    [TimeframeOption.YEAR]: (forward) =>  this.pagingDateChange('addCalendarYears', 1, forward),\n    [TimeframeOption.QUARTER]: (forward) =>  this.pagingDateChange('addCalendarMonths', 3, forward),\n    [TimeframeOption.MONTH]: (forward) =>  this.pagingDateChange('addCalendarMonths', 1, forward),\n    [TimeframeOption.DAY]: (forward) =>  this.pagingDateChange('addCalendarDays', 1, forward),\n    [TimeframeOption.WEEK]: (forward) =>  this.pagingDateChange('addCalendarDays', 7, forward)\n\n  }\n\n  public get displayedFormattedValue(): string {\n    if (!this.value) {\n      return this.placeholder;\n    }\n    const formatCached = this.datePickerService.format$.getValue()\n    switch (true) {\n        case formatCached?.includes('Q'):\n            return this.datePickerService.getQuarterDisplay(this.value);\n        case formatCached?.includes('W'):\n            return this.datePickerService.getWeekDisplay(this.value);\n        default:\n            return this.value.format(formatCached);\n    }\n  }\n\n  constructor(\n    protected cdr: ChangeDetectorRef,\n    protected dateAdapter: DateAdapter<any>,\n    public datePickerService: DrDatePickerService\n  ) {\n    super(cdr, dateAdapter, datePickerService);\n    datePickerService.isTimeframeSelectionEnabled = true;\n\n    datePickerService.format$\n      .pipe(takeUntil(this.destroyed$))\n      .subscribe((value) => {\n        datePickerService.format$.getValue();\n        this.onChangeFormat.emit(datePickerService.normalizeValue(value));\n      });\n  }\n\n  ngOnInit() {\n    this.datePickerService.isTimeframeSelectionEnabled = this.canSelectTimeframe;\n    this.cdr.markForCheck();\n  }\n\n  pagingClicked(forward: boolean): void {\n    this.pagingSetup[this.datePickerService.timeframe] && this.pagingSetup[this.datePickerService.timeframe](forward);\n    this.datePicker.close();\n  }\n\n  pagingDateChange(actionCall: string, amount: number, forward: boolean) {\n    const newValue = this.dateAdapter[actionCall](this.innerValue, forward ? amount : -amount);\n    this.setValueFromMoment(newValue);\n  }\n}\n"]}
|
|
@@ -3,7 +3,7 @@ import { Subject } from "rxjs";
|
|
|
3
3
|
import { takeUntil } from 'rxjs/operators';
|
|
4
4
|
import { MatCalendar } from '@angular/material/datepicker';
|
|
5
5
|
import { DateAdapter, MAT_DATE_FORMATS } from '@angular/material/core';
|
|
6
|
-
import { CalendarView, CustomDateFormat } from "../../../models/datePicker";
|
|
6
|
+
import { CalendarView, CustomDateFormat, TimeframeOption } from "../../../models/datePicker";
|
|
7
7
|
import { DrDatePickerService } from "../services/dr-date-picker.service";
|
|
8
8
|
const moment = require('moment');
|
|
9
9
|
export class DrDatePickerCustomHeaderComponent {
|
|
@@ -17,25 +17,37 @@ export class DrDatePickerCustomHeaderComponent {
|
|
|
17
17
|
this.quarters = [1, 2, 3, 4];
|
|
18
18
|
this.selectedQuarter = 1;
|
|
19
19
|
this.timeframeOptions = [{
|
|
20
|
-
|
|
20
|
+
timeframe: TimeframeOption.DAY,
|
|
21
21
|
value: CalendarView.FOR_DAYS,
|
|
22
|
+
title: 'Day',
|
|
22
23
|
format: this.datePickerService.formatConfig.day,
|
|
23
24
|
periodLabel: () => this._dateAdapter
|
|
24
25
|
.format(this._calendar.activeDate, this._dateFormats.display.monthYearLabel)
|
|
25
26
|
.toLocaleUpperCase()
|
|
26
27
|
}, {
|
|
27
|
-
|
|
28
|
+
timeframe: TimeframeOption.WEEK,
|
|
29
|
+
value: CalendarView.FOR_DAYS,
|
|
30
|
+
title: 'Week',
|
|
31
|
+
format: this.datePickerService.formatConfig.week,
|
|
32
|
+
periodLabel: () => this._dateAdapter
|
|
33
|
+
.format(this._calendar.activeDate, this._dateFormats.display.monthYearLabel)
|
|
34
|
+
.toLocaleUpperCase()
|
|
35
|
+
}, {
|
|
36
|
+
timeframe: TimeframeOption.MONTH,
|
|
28
37
|
value: CalendarView.FOR_MONTHS,
|
|
38
|
+
title: 'Month',
|
|
29
39
|
format: this.datePickerService.formatConfig.month,
|
|
30
40
|
periodLabel: () => String(moment(this._calendar.activeDate).year())
|
|
31
41
|
}, {
|
|
32
|
-
|
|
42
|
+
timeframe: TimeframeOption.QUARTER,
|
|
33
43
|
value: CalendarView.FOR_QUARTERS,
|
|
44
|
+
title: 'Quarter',
|
|
34
45
|
format: this.datePickerService.formatConfig.quarter,
|
|
35
46
|
periodLabel: () => String(moment(this._calendar.activeDate).year())
|
|
36
47
|
}, {
|
|
37
|
-
|
|
48
|
+
timeframe: TimeframeOption.YEAR,
|
|
38
49
|
value: CalendarView.FOR_YEARS,
|
|
50
|
+
title: 'Year',
|
|
39
51
|
format: this.datePickerService.formatConfig.year,
|
|
40
52
|
periodLabel: () => {
|
|
41
53
|
const currentYear = moment(this._calendar.activeDate).year();
|
|
@@ -61,6 +73,9 @@ export class DrDatePickerCustomHeaderComponent {
|
|
|
61
73
|
this.selectedTimeframe = this.timeframeOptions.filter(option => option.format == value)[0].value;
|
|
62
74
|
_calendar.currentView = this.selectedTimeframe;
|
|
63
75
|
this.setPeriodLabels();
|
|
76
|
+
if (this.selectedTimeframe === CalendarView.FOR_QUARTERS) {
|
|
77
|
+
this.selectedQuarter = moment(this._calendar.activeDate).quarter();
|
|
78
|
+
}
|
|
64
79
|
});
|
|
65
80
|
_calendar.viewChanged.pipe(takeUntil(this._destroyed)).subscribe(() => this.setPeriodLabels());
|
|
66
81
|
}
|
|
@@ -71,7 +86,7 @@ export class DrDatePickerCustomHeaderComponent {
|
|
|
71
86
|
setPeriodLabels() {
|
|
72
87
|
const currentTimeframeOption = this.timeframeOptions.filter(option => option.value === this._calendar.currentView)[0];
|
|
73
88
|
const fullPeriodLabel = currentTimeframeOption.periodLabel();
|
|
74
|
-
if (this._calendar.currentView ===
|
|
89
|
+
if (this._calendar.currentView === CalendarView.FOR_DAYS) {
|
|
75
90
|
this.periodMonthLabel = fullPeriodLabel.slice(0, 3);
|
|
76
91
|
this.periodYearLabel = fullPeriodLabel.slice(4);
|
|
77
92
|
}
|
|
@@ -115,7 +130,7 @@ export class DrDatePickerCustomHeaderComponent {
|
|
|
115
130
|
DrDatePickerCustomHeaderComponent.decorators = [
|
|
116
131
|
{ type: Component, args: [{
|
|
117
132
|
selector: 'dr-date-picker_custom-header.component',
|
|
118
|
-
template: "<div *ngIf=\"datePickerService.isTimeframeSelectionEnabled\" class=\"dr-datepicker__timeframe-select__wrapper\">\n <dr-select\n class=\"dr-datepicker__timeframe-select\"\n [(ngModel)]=\"selectedTimeframe\"\n [items]=\"timeframeOptions\"\n bindLabel=\"title\"\n bindValue=\"value\"\n (ngModelChange)=\"setTimeframe()\">\n </dr-select>\n</div>\n\n<div class=\"dr-date-paging\">\n <div class=\"dr-date-paging flip-page-button\"\n (click)=\"pagingClicked(false)\">\n <i class=\"dr-icon-arrow-left presentation_buttons-navigate_input\"></i>\n </div>\n <span class=\"example-header-label\">\n <span (click)=\"switchViewOnClickOnPeriodLabel(calendarView.FOR_MONTHS)\">{{periodMonthLabel + ' '}}</span>\n <span (click)=\"switchViewOnClickOnPeriodLabel(calendarView.FOR_YEARS)\">{{periodYearLabel}}</span>\n </span>\n <div class=\"dr-date-paging flip-page-button\"\n (click)=\"pagingClicked(true)\">\n <i class=\"dr-icon-arrow-right presentation_buttons-navigate_input\"></i>\n </div>\n</div>\n<div #quarterlyDatePicker class=\"dr-quarterly-datepicker\" *ngIf=\"currentViewIsQuarter\">\n <div *ngFor=\"let quarter of quarters\"\n class=\"quarter-selector\" (click)=\"onSelectQuarter(quarter)\"\n [class]=\"quarter == selectedQuarter ? 'selected' : ''\"\n >Q{{quarter}}</div>\n</div>\n\n",
|
|
133
|
+
template: "<div *ngIf=\"datePickerService.isTimeframeSelectionEnabled\" class=\"dr-datepicker__timeframe-select__wrapper\">\n <dr-select\n class=\"dr-datepicker__timeframe-select\"\n [(ngModel)]=\"selectedTimeframe\"\n [items]=\"timeframeOptions | drShowTimeframePipe: datePickerService.availableTimeframes\"\n bindLabel=\"title\"\n bindValue=\"value\"\n (ngModelChange)=\"setTimeframe()\">\n </dr-select>\n</div>\n\n<div class=\"dr-date-paging\">\n <div class=\"dr-date-paging flip-page-button\"\n (click)=\"pagingClicked(false)\">\n <i class=\"dr-icon-arrow-left presentation_buttons-navigate_input\"></i>\n </div>\n <span class=\"example-header-label\">\n <span (click)=\"switchViewOnClickOnPeriodLabel(calendarView.FOR_MONTHS)\">{{periodMonthLabel + ' '}}</span>\n <span (click)=\"switchViewOnClickOnPeriodLabel(calendarView.FOR_YEARS)\">{{periodYearLabel}}</span>\n </span>\n <div class=\"dr-date-paging flip-page-button\"\n (click)=\"pagingClicked(true)\">\n <i class=\"dr-icon-arrow-right presentation_buttons-navigate_input\"></i>\n </div>\n</div>\n<div #quarterlyDatePicker class=\"dr-quarterly-datepicker\" *ngIf=\"currentViewIsQuarter\">\n <div *ngFor=\"let quarter of quarters\"\n class=\"quarter-selector\" (click)=\"onSelectQuarter(quarter)\"\n [class]=\"quarter == selectedQuarter ? 'selected' : ''\"\n >Q{{quarter}}</div>\n</div>\n\n",
|
|
119
134
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
120
135
|
styles: [":host{height:54px;align-items:center;font-family:\"Poppins\";font-style:normal;font-weight:600;font-size:14px;line-height:22px}.dr-datepicker__timeframe-select__wrapper{background-color:#f9faff;padding:16px 32px;border-radius:18px 18px 0 0}.dr-date-paging{display:flex;flex-direction:row;justify-content:space-between;align-items:center;padding:16px 8px;grid-gap:4px;gap:4px}.dr-date-paging.flip-page-button{width:20px;height:20px;padding:0;color:#4e566c}.dr-date-paging.flip-page-button:hover{border-radius:50%;background:#F2F2FB;color:#4646ce}.example-header-label{cursor:pointer}.dr-quarterly-datepicker{display:flex;justify-content:space-between;padding:10px}.dr-quarterly-datepicker .quarter-selector{display:block;width:74px;height:40px;text-align:center;border-radius:40px;font-weight:400;padding-top:9px}.dr-quarterly-datepicker .quarter-selector:hover{background:#F2F2FB;color:#4646ce;font-weight:600;cursor:pointer}.dr-quarterly-datepicker .quarter-selector.selected{background-color:#4646ce;color:#f3f7ff;font-weight:600}\n"]
|
|
121
136
|
},] }
|
|
@@ -127,4 +142,4 @@ DrDatePickerCustomHeaderComponent.ctorParameters = () => [
|
|
|
127
142
|
{ type: ChangeDetectorRef },
|
|
128
143
|
{ type: DrDatePickerService }
|
|
129
144
|
];
|
|
130
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-date-picker_custom-header.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/dr-date-picker_custom-header/dr-date-picker_custom-header.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, OnDestroy, ChangeDetectorRef, Component, Inject } from \"@angular/core\";\nimport { Subject } from \"rxjs\";\nimport { take, takeUntil } from 'rxjs/operators';\nimport { MatCalendar, MatCalendarView } from '@angular/material/datepicker';\nimport { DateAdapter, MAT_DATE_FORMATS} from '@angular/material/core';\nimport { CalendarView, CustomDateFormat, TCalendarView } from \"../../../models/datePicker\";\nimport { DrDatePickerService } from \"../services/dr-date-picker.service\";\n\nconst moment = require('moment');\n\nexport interface ITimeframeOption {\n      title: string,\n      value: TCalendarView,\n      format: string,\n      periodLabel: () => string\n}\n\n@Component({\n    selector: 'dr-date-picker_custom-header.component',\n    templateUrl: 'dr-date-picker_custom-header.component.html',\n    styleUrls: ['./dr-date-picker_custom-header.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n  })\n\nexport class DrDatePickerCustomHeaderComponent<Moment> implements OnDestroy {\n    private _destroyed = new Subject<void>();\n    quarters = [1, 2, 3, 4];\n    selectedQuarter = 1;\n    timeframeOptions: ITimeframeOption[] = [{\n      title: 'Day',\n      value: CalendarView.FOR_DAYS,\n      format: this.datePickerService.formatConfig.day,\n      periodLabel: () => this._dateAdapter\n        .format(this._calendar.activeDate, this._dateFormats.display.monthYearLabel)\n        .toLocaleUpperCase()\n    },{\n      title: 'Month',\n      value: CalendarView.FOR_MONTHS,\n      format: this.datePickerService.formatConfig.month,\n      periodLabel: () => String(moment(this._calendar.activeDate).year())\n    },{\n      title: 'Quarter',\n      value: CalendarView.FOR_QUARTERS,\n      format: this.datePickerService.formatConfig.quarter,\n      periodLabel: () => String(moment(this._calendar.activeDate).year())\n    },{\n      title: 'Year',\n      value: CalendarView.FOR_YEARS,\n      format: this.datePickerService.formatConfig.year,\n      periodLabel:  () => {\n        const currentYear = moment(this._calendar.activeDate).year();\n        const startPeriod = Math.floor(currentYear/24)*24;\n        return startPeriod + '-' + (startPeriod + 23);\n      }\n    }]\n\n    pagingSetup = {\n      [CalendarView.FOR_MONTHS]: (forward) =>  this.pagingDateChange('addCalendarYears', 1, forward),\n      [CalendarView.FOR_QUARTERS]: (forward) =>  this.pagingDateChange('addCalendarYears', 1, forward),\n      [CalendarView.FOR_DAYS]: (forward) =>  this.pagingDateChange('addCalendarMonths', 1, forward),\n      [CalendarView.FOR_YEARS]: (forward) =>  this.pagingDateChange('addCalendarYears', 24, forward)\n    }\n\n    selectedTimeframe: TCalendarView = CalendarView.FOR_DAYS;\n    timeframeSelection = false;\n    periodMonthLabel = '';\n    periodYearLabel = '';\n\n    public readonly calendarView = CalendarView;\n\n    constructor(\n        private _calendar: MatCalendar<Moment>,\n        private _dateAdapter: DateAdapter<Moment>,\n        @Inject(MAT_DATE_FORMATS) private _dateFormats: CustomDateFormat,\n        private cdr: ChangeDetectorRef,\n        public datePickerService: DrDatePickerService) {\n          _calendar.stateChanges.pipe(takeUntil(this._destroyed)).subscribe(() => this.setPeriodLabels());\n          this.datePickerService.format$\n            .pipe(takeUntil(this._destroyed))\n            .subscribe( value => {\n              this.selectedTimeframe = this.timeframeOptions.filter(option => option.format == value)[0].value;\n              _calendar.currentView = this.selectedTimeframe as MatCalendarView;\n              this.setPeriodLabels();\n            });\n          _calendar.viewChanged.pipe(takeUntil(this._destroyed)).subscribe(() => this.setPeriodLabels());\n    }\n\n    ngOnDestroy() {\n      this._destroyed.next();\n      this._destroyed.complete();\n    }\n\n    setPeriodLabels() {\n      const currentTimeframeOption = this.timeframeOptions.filter(option => option.value === this._calendar.currentView)[0];\n      const fullPeriodLabel = currentTimeframeOption.periodLabel();\n      if (this._calendar.currentView === 'month') {\n        this.periodMonthLabel = fullPeriodLabel.slice(0,3);\n        this.periodYearLabel = fullPeriodLabel.slice(4);\n      } else {\n        this.periodMonthLabel = '';\n        this.periodYearLabel = fullPeriodLabel;\n      }\n      this.cdr.markForCheck();\n    }\n\n    setTimeframe() {\n      this.timeframeSelection = false;\n      this._calendar.currentView = this.selectedTimeframe as MatCalendarView;\n      const chosenTimeframeOption = this.timeframeOptions.filter(option => option.value === this.selectedTimeframe)[0];\n      this.datePickerService.updateTimeframeAndFormat(chosenTimeframeOption.format);\n\n      if (this.selectedTimeframe === CalendarView.FOR_QUARTERS) {\n        this.selectedQuarter = moment(this._calendar.activeDate).quarter();\n      }\n    }\n\n    get currentViewIsQuarter() {\n      return ![CalendarView.FOR_DAYS, CalendarView.FOR_MONTHS, CalendarView.FOR_YEARS].includes(this._calendar.currentView as CalendarView);\n    }\n\n    switchViewOnClickOnPeriodLabel(view: CalendarView.FOR_MONTHS | CalendarView.FOR_YEARS) {\n      this._calendar.currentView = view;\n    }\n\n    onSelectQuarter(quarterNumber: number) {\n      const monthsInQuarter = 3;\n      this.selectedQuarter = moment(this._calendar.activeDate).quarter();\n\n      const unadaptedDate = this._dateAdapter.addCalendarMonths(this._calendar.activeDate,\n      monthsInQuarter * (quarterNumber - this.selectedQuarter));\n      this._calendar.activeDate = unadaptedDate;\n      this.datePickerService.updatedQuarter$.next(moment(unadaptedDate));\n      this.datePickerService.calendarInstance.close();\n    }\n\n    pagingClicked(forward) {\n      this.pagingSetup[this._calendar.currentView] && this.pagingSetup[this._calendar.currentView](forward);\n    }\n\n    pagingDateChange(actionCall: string, amount: number, forward: boolean) {\n      this._calendar.activeDate = this._dateAdapter[actionCall](this._calendar.activeDate, forward? amount: - amount);\n      this.setPeriodLabels();\n    }\n  }\n"]}
|
|
145
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-date-picker_custom-header.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/dr-date-picker_custom-header/dr-date-picker_custom-header.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, OnDestroy, ChangeDetectorRef, Component, Inject } from \"@angular/core\";\nimport { Subject } from \"rxjs\";\nimport { take, takeUntil } from 'rxjs/operators';\nimport { MatCalendar, MatCalendarView } from '@angular/material/datepicker';\nimport { DateAdapter, MAT_DATE_FORMATS} from '@angular/material/core';\nimport { CalendarView, CustomDateFormat, TCalendarView, TimeframeOption } from \"../../../models/datePicker\";\nimport { DrDatePickerService } from \"../services/dr-date-picker.service\";\n\nconst moment = require('moment');\n\nexport interface ITimeframeOption {\n    timeframe:TimeframeOption,\n    title: string,\n    value: TCalendarView,\n    format: string,\n    periodLabel: () => string\n}\n\n@Component({\n    selector: 'dr-date-picker_custom-header.component',\n    templateUrl: 'dr-date-picker_custom-header.component.html',\n    styleUrls: ['./dr-date-picker_custom-header.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n  })\n\nexport class DrDatePickerCustomHeaderComponent<Moment> implements OnDestroy {\n    private _destroyed = new Subject<void>();\n    quarters = [1, 2, 3, 4];\n    selectedQuarter = 1;\n    timeframeOptions: ITimeframeOption[] = [{\n        timeframe: TimeframeOption.DAY,\n        value: CalendarView.FOR_DAYS,\n        title: 'Day',\n        format: this.datePickerService.formatConfig.day,\n        periodLabel: () => this._dateAdapter\n            .format(this._calendar.activeDate, this._dateFormats.display.monthYearLabel)\n            .toLocaleUpperCase()\n    },{\n        timeframe: TimeframeOption.WEEK,\n        value: CalendarView.FOR_DAYS,\n        title: 'Week',\n        format: this.datePickerService.formatConfig.week,\n        periodLabel: () => this._dateAdapter\n          .format(this._calendar.activeDate, this._dateFormats.display.monthYearLabel)\n          .toLocaleUpperCase()\n    },{\n        timeframe: TimeframeOption.MONTH,\n        value: CalendarView.FOR_MONTHS,\n        title: 'Month',\n        format: this.datePickerService.formatConfig.month,\n        periodLabel: () => String(moment(this._calendar.activeDate).year())\n    },{\n        timeframe: TimeframeOption.QUARTER,\n        value: CalendarView.FOR_QUARTERS,\n        title: 'Quarter',\n        format: this.datePickerService.formatConfig.quarter,\n        periodLabel: () => String(moment(this._calendar.activeDate).year())\n    },{\n        timeframe: TimeframeOption.YEAR,\n        value: CalendarView.FOR_YEARS,\n        title: 'Year',\n        format: this.datePickerService.formatConfig.year,\n        periodLabel:  () => {\n            const currentYear = moment(this._calendar.activeDate).year();\n            const startPeriod = Math.floor(currentYear/24)*24;\n            return startPeriod + '-' + (startPeriod + 23);\n        }\n    }]\n\n    pagingSetup = {\n        [CalendarView.FOR_MONTHS]: (forward) =>  this.pagingDateChange('addCalendarYears', 1, forward),\n        [CalendarView.FOR_QUARTERS]: (forward) =>  this.pagingDateChange('addCalendarYears', 1, forward),\n        [CalendarView.FOR_DAYS]: (forward) =>  this.pagingDateChange('addCalendarMonths', 1, forward),\n        [CalendarView.FOR_YEARS]: (forward) =>  this.pagingDateChange('addCalendarYears', 24, forward)\n    }\n\n    selectedTimeframe: TCalendarView = CalendarView.FOR_DAYS;\n    timeframeSelection = false;\n    periodMonthLabel = '';\n    periodYearLabel = '';\n\n    public readonly calendarView = CalendarView;\n\n    constructor(\n        private _calendar: MatCalendar<Moment>,\n        private _dateAdapter: DateAdapter<Moment>,\n        @Inject(MAT_DATE_FORMATS) private _dateFormats: CustomDateFormat,\n        private cdr: ChangeDetectorRef,\n        public datePickerService: DrDatePickerService) {\n            _calendar.stateChanges.pipe(takeUntil(this._destroyed)).subscribe(() => this.setPeriodLabels());\n            this.datePickerService.format$\n                .pipe(takeUntil(this._destroyed))\n                .subscribe( value => {\n                    this.selectedTimeframe = this.timeframeOptions.filter(option => option.format == value)[0].value;\n                    _calendar.currentView = this.selectedTimeframe as MatCalendarView;\n                    this.setPeriodLabels();\n                    if (this.selectedTimeframe === CalendarView.FOR_QUARTERS) {\n                        this.selectedQuarter = moment(this._calendar.activeDate).quarter();\n                    }\n                });\n                _calendar.viewChanged.pipe(takeUntil(this._destroyed)).subscribe(() => this.setPeriodLabels());\n    }\n\n    ngOnDestroy() {\n        this._destroyed.next();\n        this._destroyed.complete();\n    }\n\n    setPeriodLabels() {\n        const currentTimeframeOption = this.timeframeOptions.filter(option => option.value === this._calendar.currentView)[0];\n        const fullPeriodLabel = currentTimeframeOption.periodLabel();\n        if (this._calendar.currentView === CalendarView.FOR_DAYS) {\n            this.periodMonthLabel = fullPeriodLabel.slice(0,3);\n            this.periodYearLabel = fullPeriodLabel.slice(4);\n        } else {\n            this.periodMonthLabel = '';\n            this.periodYearLabel = fullPeriodLabel;\n        }\n        this.cdr.markForCheck();\n    }\n\n    setTimeframe() {\n        this.timeframeSelection = false;\n        this._calendar.currentView = this.selectedTimeframe as MatCalendarView;\n        const chosenTimeframeOption = this.timeframeOptions.filter(option => option.value === this.selectedTimeframe)[0];\n        this.datePickerService.updateTimeframeAndFormat(chosenTimeframeOption.format);\n\n        if (this.selectedTimeframe === CalendarView.FOR_QUARTERS) {\n            this.selectedQuarter = moment(this._calendar.activeDate).quarter();\n        }\n    }\n\n    get currentViewIsQuarter() {\n        return ![CalendarView.FOR_DAYS, CalendarView.FOR_MONTHS, CalendarView.FOR_YEARS].includes(this._calendar.currentView as CalendarView);\n    }\n\n    switchViewOnClickOnPeriodLabel(view: CalendarView.FOR_MONTHS | CalendarView.FOR_YEARS) {\n        this._calendar.currentView = view;\n    }\n\n    onSelectQuarter(quarterNumber: number) {\n        const monthsInQuarter = 3;\n        this.selectedQuarter = moment(this._calendar.activeDate).quarter();\n\n        const unadaptedDate = this._dateAdapter.addCalendarMonths(this._calendar.activeDate,\n        monthsInQuarter * (quarterNumber - this.selectedQuarter));\n        this._calendar.activeDate = unadaptedDate;\n        this.datePickerService.updatedQuarter$.next(moment(unadaptedDate));\n        this.datePickerService.calendarInstance.close();\n    }\n\n    pagingClicked(forward) {\n        this.pagingSetup[this._calendar.currentView] && this.pagingSetup[this._calendar.currentView](forward);\n    }\n\n    pagingDateChange(actionCall: string, amount: number, forward: boolean) {\n        this._calendar.activeDate = this._dateAdapter[actionCall](this._calendar.activeDate, forward? amount: - amount);\n        this.setPeriodLabels();\n    }\n  }\n"]}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { Pipe } from '@angular/core';
|
|
2
|
+
export class DrShowTimeframePipe {
|
|
3
|
+
transform(arr, showOptions) {
|
|
4
|
+
return arr.filter(item => showOptions.includes(item.timeframe));
|
|
5
|
+
}
|
|
6
|
+
}
|
|
7
|
+
DrShowTimeframePipe.decorators = [
|
|
8
|
+
{ type: Pipe, args: [{
|
|
9
|
+
name: 'drShowTimeframePipe'
|
|
10
|
+
},] }
|
|
11
|
+
];
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItc2hvdy10aW1lZnJhbWUucGlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RyLWlucHV0cy9kYXRlLXBpY2tlcnMvZHItc2hvdy10aW1lZnJhbWUucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQztBQU9wRCxNQUFNLE9BQU8sbUJBQW1CO0lBQzlCLFNBQVMsQ0FBQyxHQUF1QixFQUFFLFdBQThCO1FBQy9ELE9BQU8sR0FBRyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLFdBQVcsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUM7SUFDbEUsQ0FBQzs7O1lBTkYsSUFBSSxTQUFDO2dCQUNKLElBQUksRUFBRSxxQkFBcUI7YUFDNUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQaXBlLCBQaXBlVHJhbnNmb3JtIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUaW1lZnJhbWVPcHRpb24gfSBmcm9tICcuLi8uLi9tb2RlbHMvZGF0ZVBpY2tlcic7XG5pbXBvcnQgeyBJVGltZWZyYW1lT3B0aW9uIH0gZnJvbSAnLi9kci1kYXRlLXBpY2tlcl9jdXN0b20taGVhZGVyL2RyLWRhdGUtcGlja2VyX2N1c3RvbS1oZWFkZXIuY29tcG9uZW50JztcblxuQFBpcGUoe1xuICBuYW1lOiAnZHJTaG93VGltZWZyYW1lUGlwZSdcbn0pXG5leHBvcnQgY2xhc3MgRHJTaG93VGltZWZyYW1lUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xuICB0cmFuc2Zvcm0oYXJyOiBJVGltZWZyYW1lT3B0aW9uW10sIHNob3dPcHRpb25zOiBUaW1lZnJhbWVPcHRpb25bXSk6IElUaW1lZnJhbWVPcHRpb25bXSB7XG4gICAgcmV0dXJuIGFyci5maWx0ZXIoaXRlbSA9PiBzaG93T3B0aW9ucy5pbmNsdWRlcyhpdGVtLnRpbWVmcmFtZSkpO1xuICB9XG59Il19
|
|
@@ -1,25 +1,53 @@
|
|
|
1
1
|
import { Injectable } from "@angular/core";
|
|
2
2
|
import { Subject, BehaviorSubject } from "rxjs";
|
|
3
3
|
import { DateFromats, TimeframeOption } from "../../../models/datePicker";
|
|
4
|
-
import { DrSharedUtils } from "../../../utils/dr-shared-utils";
|
|
5
4
|
export class DrDatePickerService {
|
|
6
5
|
constructor() {
|
|
7
6
|
this.isTimeframeSelectionEnabled = false;
|
|
8
7
|
this.timeframe = TimeframeOption.DAY;
|
|
9
8
|
this.format$ = new BehaviorSubject(DateFromats.MAT_DEFAULT_DATE_FORMAT);
|
|
10
9
|
this.updatedQuarter$ = new Subject();
|
|
10
|
+
this.availableTimeframes = [
|
|
11
|
+
TimeframeOption.DAY,
|
|
12
|
+
TimeframeOption.WEEK,
|
|
13
|
+
TimeframeOption.MONTH,
|
|
14
|
+
TimeframeOption.QUARTER,
|
|
15
|
+
TimeframeOption.YEAR
|
|
16
|
+
];
|
|
11
17
|
this.formatConfig = {
|
|
12
18
|
day: DateFromats.MAT_DEFAULT_DATE_FORMAT,
|
|
13
19
|
month: DateFromats.MONTH_YEAR_FORMAT,
|
|
14
20
|
year: DateFromats.YEAR_FORMAT,
|
|
15
21
|
quarter: DateFromats.QUARTER_FORMAT,
|
|
22
|
+
week: DateFromats.WEEK_FORMAT
|
|
16
23
|
};
|
|
17
24
|
}
|
|
18
25
|
getQuarterDisplay(value) {
|
|
19
|
-
return 'Q' + value.
|
|
26
|
+
return 'Q' + value.format(this.formatConfig.quarter);
|
|
27
|
+
}
|
|
28
|
+
getWeekDisplay(value) {
|
|
29
|
+
return 'W' + value.format(this.formatConfig.week);
|
|
20
30
|
}
|
|
21
31
|
getTimeframe(format) {
|
|
22
|
-
|
|
32
|
+
const defaultFrame = TimeframeOption.DAY;
|
|
33
|
+
if (!format) {
|
|
34
|
+
return defaultFrame;
|
|
35
|
+
}
|
|
36
|
+
const lowerCaseFormat = format.toLowerCase();
|
|
37
|
+
switch (true) {
|
|
38
|
+
case lowerCaseFormat.includes('q'):
|
|
39
|
+
return TimeframeOption.QUARTER;
|
|
40
|
+
case lowerCaseFormat.includes('d'):
|
|
41
|
+
return TimeframeOption.DAY;
|
|
42
|
+
case lowerCaseFormat.includes('m'):
|
|
43
|
+
return TimeframeOption.MONTH;
|
|
44
|
+
case lowerCaseFormat.includes('w'):
|
|
45
|
+
return TimeframeOption.WEEK;
|
|
46
|
+
case lowerCaseFormat.includes('y'):
|
|
47
|
+
return TimeframeOption.YEAR;
|
|
48
|
+
default:
|
|
49
|
+
return defaultFrame;
|
|
50
|
+
}
|
|
23
51
|
}
|
|
24
52
|
getConfiguredFormat(timeframe) {
|
|
25
53
|
return this.formatConfig[timeframe];
|
|
@@ -36,4 +64,4 @@ export class DrDatePickerService {
|
|
|
36
64
|
DrDatePickerService.decorators = [
|
|
37
65
|
{ type: Injectable }
|
|
38
66
|
];
|
|
39
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
67
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItZGF0ZS1waWNrZXIuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RyLWlucHV0cy9kYXRlLXBpY2tlcnMvc2VydmljZXMvZHItZGF0ZS1waWNrZXIuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRzNDLE9BQU8sRUFBRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQ2hELE9BQU8sRUFBMkIsV0FBVyxFQUFvQixlQUFlLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUdySCxNQUFNLE9BQU8sbUJBQW1CO0lBRGhDO1FBRUksZ0NBQTJCLEdBQUcsS0FBSyxDQUFDO1FBQ3BDLGNBQVMsR0FBcUIsZUFBZSxDQUFDLEdBQUcsQ0FBQztRQUNsRCxZQUFPLEdBQUcsSUFBSSxlQUFlLENBQVMsV0FBVyxDQUFDLHVCQUF1QixDQUFDLENBQUM7UUFDM0Usb0JBQWUsR0FBRyxJQUFJLE9BQU8sRUFBVSxDQUFDO1FBRXhDLHdCQUFtQixHQUFHO1lBQ2xCLGVBQWUsQ0FBQyxHQUFHO1lBQ25CLGVBQWUsQ0FBQyxJQUFJO1lBQ3BCLGVBQWUsQ0FBQyxLQUFLO1lBQ3JCLGVBQWUsQ0FBQyxPQUFPO1lBQ3ZCLGVBQWUsQ0FBQyxJQUFJO1NBQ3ZCLENBQUM7UUFFSyxpQkFBWSxHQUE0QjtZQUMzQyxHQUFHLEVBQUUsV0FBVyxDQUFDLHVCQUF1QjtZQUN4QyxLQUFLLEVBQUUsV0FBVyxDQUFDLGlCQUFpQjtZQUNwQyxJQUFJLEVBQUUsV0FBVyxDQUFDLFdBQVc7WUFDN0IsT0FBTyxFQUFFLFdBQVcsQ0FBQyxjQUFjO1lBQ25DLElBQUksRUFBRSxXQUFXLENBQUMsV0FBVztTQUNoQyxDQUFDO0lBK0NOLENBQUM7SUE3Q0csaUJBQWlCLENBQUMsS0FBYTtRQUMzQixPQUFPLEdBQUcsR0FBRyxLQUFLLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDekQsQ0FBQztJQUVELGNBQWMsQ0FBQyxLQUFhO1FBQ3hCLE9BQU8sR0FBRyxHQUFHLEtBQUssQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN0RCxDQUFDO0lBRUQsWUFBWSxDQUFDLE1BQWM7UUFDdkIsTUFBTSxZQUFZLEdBQUcsZUFBZSxDQUFDLEdBQUcsQ0FBQztRQUV6QyxJQUFJLENBQUMsTUFBTSxFQUFFO1lBQ1QsT0FBTyxZQUFZLENBQUM7U0FDdkI7UUFFRCxNQUFNLGVBQWUsR0FBRyxNQUFNLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDekMsUUFBUSxJQUFJLEVBQUU7WUFDVixLQUFLLGVBQWUsQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDO2dCQUM5QixPQUFPLGVBQWUsQ0FBQyxPQUFPLENBQUM7WUFDbkMsS0FBSyxlQUFlLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQztnQkFDOUIsT0FBTyxlQUFlLENBQUMsR0FBRyxDQUFDO1lBQy9CLEtBQUssZUFBZSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUM7Z0JBQzlCLE9BQU8sZUFBZSxDQUFDLEtBQUssQ0FBQztZQUNqQyxLQUFLLGVBQWUsQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDO2dCQUM5QixPQUFPLGVBQWUsQ0FBQyxJQUFJLENBQUM7WUFDaEMsS0FBSyxlQUFlLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQztnQkFDOUIsT0FBTyxlQUFlLENBQUMsSUFBSSxDQUFDO1lBQ2hDO2dCQUNJLE9BQU8sWUFBWSxDQUFDO1NBQzNCO0lBQ1QsQ0FBQztJQUVELG1CQUFtQixDQUFDLFNBQTJCO1FBQzNDLE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUN4QyxDQUFDO0lBRUQsd0JBQXdCLENBQUMsTUFBYztRQUNuQyxNQUFNLGdCQUFnQixHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxJQUFJLElBQUksQ0FBQyxPQUFPLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQTtRQUMvRSxJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztRQUNyRCxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsbUJBQW1CLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUM7SUFDaEUsQ0FBQztJQUVELGNBQWMsQ0FBQyxLQUFLO1FBQ2hCLE9BQU8sS0FBSyxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsR0FBRyxDQUFDLENBQUM7SUFDcEMsQ0FBQzs7O1lBbkVKLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IE1hdERhdGVwaWNrZXIgfSBmcm9tIFwiQGFuZ3VsYXIvbWF0ZXJpYWwvZGF0ZXBpY2tlclwiO1xuaW1wb3J0IHsgTW9tZW50IH0gZnJvbSAnbW9tZW50JztcbmltcG9ydCB7IFN1YmplY3QsIEJlaGF2aW9yU3ViamVjdCB9IGZyb20gXCJyeGpzXCI7XG5pbXBvcnQgeyBJRGF0ZVBpY2tlckZvcm1hdENvbmZpZywgRGF0ZUZyb21hdHMsIFRUaW1lZnJhbWVPcHRpb24sIFRpbWVmcmFtZU9wdGlvbiB9IGZyb20gXCIuLi8uLi8uLi9tb2RlbHMvZGF0ZVBpY2tlclwiO1xuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgRHJEYXRlUGlja2VyU2VydmljZSB7XG4gICAgaXNUaW1lZnJhbWVTZWxlY3Rpb25FbmFibGVkID0gZmFsc2U7XG4gICAgdGltZWZyYW1lOiBUVGltZWZyYW1lT3B0aW9uID0gVGltZWZyYW1lT3B0aW9uLkRBWTtcbiAgICBmb3JtYXQkID0gbmV3IEJlaGF2aW9yU3ViamVjdDxzdHJpbmc+KERhdGVGcm9tYXRzLk1BVF9ERUZBVUxUX0RBVEVfRk9STUFUKTtcbiAgICB1cGRhdGVkUXVhcnRlciQgPSBuZXcgU3ViamVjdDxNb21lbnQ+KCk7XG4gICAgY2FsZW5kYXJJbnN0YW5jZTogTWF0RGF0ZXBpY2tlcjxhbnk+O1xuICAgIGF2YWlsYWJsZVRpbWVmcmFtZXMgPSBbXG4gICAgICAgIFRpbWVmcmFtZU9wdGlvbi5EQVksXG4gICAgICAgIFRpbWVmcmFtZU9wdGlvbi5XRUVLLFxuICAgICAgICBUaW1lZnJhbWVPcHRpb24uTU9OVEgsXG4gICAgICAgIFRpbWVmcmFtZU9wdGlvbi5RVUFSVEVSLFxuICAgICAgICBUaW1lZnJhbWVPcHRpb24uWUVBUlxuICAgIF07XG5cbiAgICBwdWJsaWMgZm9ybWF0Q29uZmlnOiBJRGF0ZVBpY2tlckZvcm1hdENvbmZpZyA9IHtcbiAgICAgICAgZGF5OiBEYXRlRnJvbWF0cy5NQVRfREVGQVVMVF9EQVRFX0ZPUk1BVCxcbiAgICAgICAgbW9udGg6IERhdGVGcm9tYXRzLk1PTlRIX1lFQVJfRk9STUFULFxuICAgICAgICB5ZWFyOiBEYXRlRnJvbWF0cy5ZRUFSX0ZPUk1BVCxcbiAgICAgICAgcXVhcnRlcjogRGF0ZUZyb21hdHMuUVVBUlRFUl9GT1JNQVQsXG4gICAgICAgIHdlZWs6IERhdGVGcm9tYXRzLldFRUtfRk9STUFUXG4gICAgfTtcblxuICAgIGdldFF1YXJ0ZXJEaXNwbGF5KHZhbHVlOiBNb21lbnQpOiBzdHJpbmcge1xuICAgICAgICByZXR1cm4gJ1EnICsgdmFsdWUuZm9ybWF0KHRoaXMuZm9ybWF0Q29uZmlnLnF1YXJ0ZXIpO1xuICAgIH1cblxuICAgIGdldFdlZWtEaXNwbGF5KHZhbHVlOiBNb21lbnQpOiBzdHJpbmcge1xuICAgICAgICByZXR1cm4gJ1cnICsgdmFsdWUuZm9ybWF0KHRoaXMuZm9ybWF0Q29uZmlnLndlZWspO1xuICAgIH1cblxuICAgIGdldFRpbWVmcmFtZShmb3JtYXQ6IHN0cmluZykge1xuICAgICAgICBjb25zdCBkZWZhdWx0RnJhbWUgPSBUaW1lZnJhbWVPcHRpb24uREFZO1xuXG4gICAgICAgIGlmICghZm9ybWF0KSB7XG4gICAgICAgICAgICByZXR1cm4gZGVmYXVsdEZyYW1lO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3QgbG93ZXJDYXNlRm9ybWF0ID0gZm9ybWF0LnRvTG93ZXJDYXNlKCk7XG4gICAgICAgICAgICBzd2l0Y2ggKHRydWUpIHtcbiAgICAgICAgICAgICAgICBjYXNlIGxvd2VyQ2FzZUZvcm1hdC5pbmNsdWRlcygncScpOlxuICAgICAgICAgICAgICAgICAgICByZXR1cm4gVGltZWZyYW1lT3B0aW9uLlFVQVJURVI7XG4gICAgICAgICAgICAgICAgY2FzZSBsb3dlckNhc2VGb3JtYXQuaW5jbHVkZXMoJ2QnKTpcbiAgICAgICAgICAgICAgICAgICAgcmV0dXJuIFRpbWVmcmFtZU9wdGlvbi5EQVk7XG4gICAgICAgICAgICAgICAgY2FzZSBsb3dlckNhc2VGb3JtYXQuaW5jbHVkZXMoJ20nKTpcbiAgICAgICAgICAgICAgICAgICAgcmV0dXJuIFRpbWVmcmFtZU9wdGlvbi5NT05USDtcbiAgICAgICAgICAgICAgICBjYXNlIGxvd2VyQ2FzZUZvcm1hdC5pbmNsdWRlcygndycpOlxuICAgICAgICAgICAgICAgICAgICByZXR1cm4gVGltZWZyYW1lT3B0aW9uLldFRUs7IFxuICAgICAgICAgICAgICAgIGNhc2UgbG93ZXJDYXNlRm9ybWF0LmluY2x1ZGVzKCd5Jyk6XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiBUaW1lZnJhbWVPcHRpb24uWUVBUjtcbiAgICAgICAgICAgICAgICBkZWZhdWx0OlxuICAgICAgICAgICAgICAgICAgICByZXR1cm4gZGVmYXVsdEZyYW1lO1xuICAgICAgICAgICAgfVxuICAgIH1cblxuICAgIGdldENvbmZpZ3VyZWRGb3JtYXQodGltZWZyYW1lOiBUVGltZWZyYW1lT3B0aW9uKSB7XG4gICAgICAgIHJldHVybiB0aGlzLmZvcm1hdENvbmZpZ1t0aW1lZnJhbWVdO1xuICAgIH1cblxuICAgIHVwZGF0ZVRpbWVmcmFtZUFuZEZvcm1hdChmb3JtYXQ6IHN0cmluZyk6IHZvaWQge1xuICAgICAgICBjb25zdCBub3JtYWxpemVkRm9ybWF0ID0gdGhpcy5ub3JtYWxpemVWYWx1ZShmb3JtYXQgfHwgdGhpcy5mb3JtYXQkLmdldFZhbHVlKCkpXG4gICAgICAgIHRoaXMudGltZWZyYW1lID0gdGhpcy5nZXRUaW1lZnJhbWUobm9ybWFsaXplZEZvcm1hdCk7XG4gICAgICAgIHRoaXMuZm9ybWF0JC5uZXh0KHRoaXMuZ2V0Q29uZmlndXJlZEZvcm1hdCh0aGlzLnRpbWVmcmFtZSkpO1xuICAgIH1cblxuICAgIG5vcm1hbGl6ZVZhbHVlKHZhbHVlKSB7XG4gICAgICAgIHJldHVybiB2YWx1ZS5yZXBsYWNlKC9kL2csICdEJyk7XG4gICAgfVxufVxuIl19
|
|
@@ -16,6 +16,7 @@ import { DrDatePickerFormatDirective } from './date-pickers/directives/dr-date-p
|
|
|
16
16
|
import { DrToggleButtonComponent } from './dr-toggle-button/dr-toggle-button.component';
|
|
17
17
|
import { DrModelDebounceChangeDirective } from './dr-model-debounce-change.directive';
|
|
18
18
|
import { DrDatePickerCustomHeaderComponent } from './date-pickers/dr-date-picker_custom-header/dr-date-picker_custom-header.component';
|
|
19
|
+
import { DrShowTimeframePipe } from './date-pickers/dr-show-timeframe.pipe';
|
|
19
20
|
// !!! Please do not use such approach in other places
|
|
20
21
|
// Hard fix for 'none' calendar view selection
|
|
21
22
|
MatCalendar.prototype.focusActiveCell = function () {
|
|
@@ -35,7 +36,8 @@ const components = [
|
|
|
35
36
|
DrDatePickerWithTimeframeComponent,
|
|
36
37
|
DrDatePickerFormatDirective,
|
|
37
38
|
DrDatePickerCustomHeaderComponent,
|
|
38
|
-
DrModelDebounceChangeDirective
|
|
39
|
+
DrModelDebounceChangeDirective,
|
|
40
|
+
DrShowTimeframePipe
|
|
39
41
|
];
|
|
40
42
|
export class DrInputsModule {
|
|
41
43
|
}
|
|
@@ -52,4 +54,4 @@ DrInputsModule.decorators = [
|
|
|
52
54
|
]
|
|
53
55
|
},] }
|
|
54
56
|
];
|
|
55
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
57
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItaW5wdXRzLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RyLWlucHV0cy9kci1pbnB1dHMubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUUvQyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFFdEQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDakUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDcEUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDbEUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDN0UsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDM0UsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDcEUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFFOUQsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ2hGLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHdEQUF3RCxDQUFDO0FBQy9GLE9BQU8sRUFBRSxrQ0FBa0MsRUFBRSxNQUFNLHNGQUFzRixDQUFDO0FBQzFJLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLDJEQUEyRCxDQUFDO0FBQ3hHLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLCtDQUErQyxDQUFDO0FBQ3hGLE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBQ3RGLE9BQU8sRUFBRSxpQ0FBaUMsRUFBRSxNQUFNLG9GQUFvRixDQUFDO0FBRXZJLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBRTVFLHNEQUFzRDtBQUN0RCw4Q0FBOEM7QUFDOUMsV0FBVyxDQUFDLFNBQVMsQ0FBQyxlQUFlLEdBQUc7O0lBQ3RDLE1BQUEsSUFBSSxDQUFDLHdCQUF3QixFQUFFLDBDQUFFLGdCQUFnQixDQUFDLEtBQUssQ0FBQyxDQUFDO0FBQzNELENBQUMsQ0FBQTtBQUVELE1BQU0sVUFBVSxHQUFHO0lBQ2pCLGlCQUFpQjtJQUNqQixvQkFBb0I7SUFDcEIsbUJBQW1CO0lBQ25CLGlCQUFpQjtJQUNqQixnQkFBZ0I7SUFDaEIsaUJBQWlCO0lBQ2pCLGlCQUFpQjtJQUNqQix1QkFBdUI7SUFDdkIscUJBQXFCO0lBQ3JCLGtDQUFrQztJQUNsQywyQkFBMkI7SUFDM0IsaUNBQWlDO0lBQ2pDLDhCQUE4QjtJQUM5QixtQkFBbUI7Q0FDcEIsQ0FBQztBQWNGLE1BQU0sT0FBTyxjQUFjOzs7WUFaMUIsUUFBUSxTQUFDO2dCQUNSLFlBQVksRUFBRSxVQUFVO2dCQUN4QixPQUFPLEVBQUUsVUFBVTtnQkFDbkIsT0FBTyxFQUFFO29CQUNQLFdBQVc7b0JBQ1gsbUJBQW1CO29CQUNuQixZQUFZO29CQUNaLGNBQWM7b0JBQ2QsbUJBQW1CO2lCQUNwQjthQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlLCBSZWFjdGl2ZUZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcblxuaW1wb3J0IHsgTmdTZWxlY3RNb2R1bGUgfSBmcm9tICdAbmctc2VsZWN0L25nLXNlbGVjdCc7XG5cbmltcG9ydCB7IERySW5wdXRDb21wb25lbnQgfSBmcm9tICcuL2RyLWlucHV0L2RyLWlucHV0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEclNlbGVjdENvbXBvbmVudCB9IGZyb20gJy4vZHItc2VsZWN0L2RyLXNlbGVjdC5jb21wb25lbnQnO1xuaW1wb3J0IHsgQ2hlY2tib3hDb21wb25lbnQgfSBmcm9tICcuL2NoZWNrYm94L2NoZWNrYm94LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBSYWRpb0J1dHRvbkNvbXBvbmVudCB9IGZyb20gJy4vcmFkaW8tYnV0dG9uL3JhZGlvLWJ1dHRvbi5jb21wb25lbnQnO1xuaW1wb3J0IHsgUmFkaW9Hcm91cENvbXBvbmVudCB9IGZyb20gJy4vcmFkaW8tYnV0dG9uL3JhZGlvLWdyb3VwLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEclRvZ2dsZUNvbXBvbmVudCB9IGZyb20gJy4vZHItdG9nZ2xlL2RyLXRvZ2dsZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgRHJCdXR0b25Db21wb25lbnQgfSBmcm9tICcuL2J1dHRvbi9idXR0b24uY29tcG9uZW50JztcblxuaW1wb3J0IHsgTWF0Q2FsZW5kYXIsIE1hdERhdGVwaWNrZXJNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kYXRlcGlja2VyJztcbmltcG9ydCB7IERyRGF0ZVBpY2tlckNvbXBvbmVudCB9IGZyb20gJy4vZGF0ZS1waWNrZXJzL2RyLWRhdGUtcGlja2VyL2RyLWRhdGUtcGlja2VyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEckRhdGVQaWNrZXJXaXRoVGltZWZyYW1lQ29tcG9uZW50IH0gZnJvbSAnLi9kYXRlLXBpY2tlcnMvZHItZGF0ZS1waWNrZXItd2l0aC10aW1lZnJhbWUvZHItZGF0ZS1waWNrZXItd2l0aC10aW1lZnJhbWUuY29tcG9uZW50JztcbmltcG9ydCB7IERyRGF0ZVBpY2tlckZvcm1hdERpcmVjdGl2ZSB9IGZyb20gJy4vZGF0ZS1waWNrZXJzL2RpcmVjdGl2ZXMvZHItZGF0ZS1waWNrZXItZm9ybWF0LmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBEclRvZ2dsZUJ1dHRvbkNvbXBvbmVudCB9IGZyb20gJy4vZHItdG9nZ2xlLWJ1dHRvbi9kci10b2dnbGUtYnV0dG9uLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEck1vZGVsRGVib3VuY2VDaGFuZ2VEaXJlY3RpdmUgfSBmcm9tICcuL2RyLW1vZGVsLWRlYm91bmNlLWNoYW5nZS5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgRHJEYXRlUGlja2VyQ3VzdG9tSGVhZGVyQ29tcG9uZW50IH0gZnJvbSAnLi9kYXRlLXBpY2tlcnMvZHItZGF0ZS1waWNrZXJfY3VzdG9tLWhlYWRlci9kci1kYXRlLXBpY2tlcl9jdXN0b20taGVhZGVyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEckRhdGVQaWNrZXJTZXJ2aWNlIH0gZnJvbSAnLi9kYXRlLXBpY2tlcnMvc2VydmljZXMvZHItZGF0ZS1waWNrZXIuc2VydmljZSc7XG5pbXBvcnQgeyBEclNob3dUaW1lZnJhbWVQaXBlIH0gZnJvbSAnLi9kYXRlLXBpY2tlcnMvZHItc2hvdy10aW1lZnJhbWUucGlwZSc7XG5cbi8vICEhISBQbGVhc2UgZG8gbm90IHVzZSBzdWNoIGFwcHJvYWNoIGluIG90aGVyIHBsYWNlc1xuLy8gSGFyZCBmaXggZm9yICdub25lJyBjYWxlbmRhciB2aWV3IHNlbGVjdGlvblxuTWF0Q2FsZW5kYXIucHJvdG90eXBlLmZvY3VzQWN0aXZlQ2VsbCA9IGZ1bmN0aW9uKCkge1xuICB0aGlzLl9nZXRDdXJyZW50Vmlld0NvbXBvbmVudCgpPy5fZm9jdXNBY3RpdmVDZWxsKGZhbHNlKTtcbn1cblxuY29uc3QgY29tcG9uZW50cyA9IFtcbiAgRHJCdXR0b25Db21wb25lbnQsXG4gIFJhZGlvQnV0dG9uQ29tcG9uZW50LFxuICBSYWRpb0dyb3VwQ29tcG9uZW50LFxuICBDaGVja2JveENvbXBvbmVudCxcbiAgRHJJbnB1dENvbXBvbmVudCxcbiAgRHJTZWxlY3RDb21wb25lbnQsXG4gIERyVG9nZ2xlQ29tcG9uZW50LFxuICBEclRvZ2dsZUJ1dHRvbkNvbXBvbmVudCxcbiAgRHJEYXRlUGlja2VyQ29tcG9uZW50LFxuICBEckRhdGVQaWNrZXJXaXRoVGltZWZyYW1lQ29tcG9uZW50LFxuICBEckRhdGVQaWNrZXJGb3JtYXREaXJlY3RpdmUsXG4gIERyRGF0ZVBpY2tlckN1c3RvbUhlYWRlckNvbXBvbmVudCxcbiAgRHJNb2RlbERlYm91bmNlQ2hhbmdlRGlyZWN0aXZlLFxuICBEclNob3dUaW1lZnJhbWVQaXBlXG5dO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IGNvbXBvbmVudHMsXG4gIGV4cG9ydHM6IGNvbXBvbmVudHMsXG4gIGltcG9ydHM6IFtcbiAgICBGb3Jtc01vZHVsZSxcbiAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlLFxuICAgIENvbW1vbk1vZHVsZSxcbiAgICBOZ1NlbGVjdE1vZHVsZSxcbiAgICBNYXREYXRlcGlja2VyTW9kdWxlXG4gIF1cbn0pXG5cbmV4cG9ydCBjbGFzcyBEcklucHV0c01vZHVsZSB7XG5cbn1cbiJdfQ==
|
|
@@ -3,7 +3,6 @@ import { DrTabComponent } from './dr-tab.component';
|
|
|
3
3
|
export class DrTabsComponent {
|
|
4
4
|
constructor() {
|
|
5
5
|
this.selectedTab = 0;
|
|
6
|
-
this.noBodyPadding = false;
|
|
7
6
|
this.selectedTabChange = new EventEmitter();
|
|
8
7
|
}
|
|
9
8
|
selectedIndexChange($event) {
|
|
@@ -14,8 +13,8 @@ export class DrTabsComponent {
|
|
|
14
13
|
DrTabsComponent.decorators = [
|
|
15
14
|
{ type: Component, args: [{
|
|
16
15
|
selector: 'dr-tabs',
|
|
17
|
-
template: "<mat-tab-group disableRipple [selectedIndex]=\"selectedTab\"\n (selectedIndexChange)=\"selectedIndexChange($event)\"\n [class.with-radio]=\"withRadio\"\n [class.vertical]=\"vertical\"\n [
|
|
18
|
-
styles: [":host{width:100%}:host ::ng-deep .mat-tab-group,:host ::ng-deep .mat-tab-body-wrapper{height:100%}:host ::ng-deep .mat-tab-
|
|
16
|
+
template: "<mat-tab-group disableRipple [selectedIndex]=\"selectedTab\"\n (selectedIndexChange)=\"selectedIndexChange($event)\"\n [class.with-radio]=\"withRadio\"\n [class.vertical]=\"vertical\"\n [animationDuration]=\" vertical ? '0ms' : '500ms'\">\n <mat-tab *ngFor=\"let tab of tabsContentList; let index = index\" label=\"{{tab.label}}\" [disabled]=\"tab.disabled\" >\n <ng-container *ngIf=\"withRadio\">\n <ng-template mat-tab-label>\n <dr-radio-button [value]=\"index\"\n [(ngModel)]=\"selectedTab\">\n </dr-radio-button>\n {{tab.label}}\n </ng-template>\n </ng-container>\n\n <ng-container *ngTemplateOutlet=\"tab.contentTemplate\" ></ng-container>\n </mat-tab>\n</mat-tab-group>\n",
|
|
17
|
+
styles: [":host{width:100%}:host ::ng-deep .mat-tab-group,:host ::ng-deep .mat-tab-body-wrapper{height:100%}:host ::ng-deep .mat-tab-nav-bar,:host ::ng-deep .mat-tab-header{border-bottom:1px solid #D5DAE5}:host ::ng-deep .mat-tab-labels{padding:0 17px}:host ::ng-deep .mat-tab-label{padding:0 8px;min-width:0;height:38px;opacity:1}:host ::ng-deep .mat-tab-label:not(:last-child){margin-right:21px}:host ::ng-deep .mat-tab-label-active .mat-tab-label-content{color:#579bf2;font-weight:700}:host ::ng-deep .mat-tab-label-content{font-weight:400;font-size:14px;line-height:22px;color:#51566f;font-family:\"Poppins\",sans-serif}:host ::ng-deep .mat-ink-bar{height:3px;border-radius:5px;background-color:#579bf2!important}:host ::ng-deep .with-radio .mat-tab-labels{padding:0;margin-bottom:8px}:host ::ng-deep .with-radio .mat-tab-label{padding:8px 16px;min-width:0;flex-grow:1;justify-content:start;height:38px;opacity:1}:host ::ng-deep .with-radio .mat-tab-label:not(:last-child){margin-right:8px}:host ::ng-deep .with-radio .mat-tab-label-active{background:#F6F7F8;border-radius:3px}:host ::ng-deep .with-radio .mat-tab-label-active .mat-tab-label-content{color:#0c142b;font-weight:600}:host ::ng-deep .with-radio .mat-ink-bar{display:none!important}:host ::ng-deep .vertical.mat-tab-group{flex-direction:row}:host ::ng-deep .vertical .mat-tab-header{border-bottom:none}:host ::ng-deep .vertical .mat-tab-labels{flex-direction:column;padding:0;border-right:1px solid #D5DAE5}:host ::ng-deep .vertical .mat-ink-bar{display:none!important}:host ::ng-deep .vertical .mat-tab-label{border-bottom:1px solid #D5DAE5;margin:0!important}:host ::ng-deep .vertical .mat-tab-label:before{content:\"\";width:2px;height:100%;display:flex;position:absolute;top:0;left:0}:host ::ng-deep .vertical .mat-tab-label-active{background-color:#f3f7ff}:host ::ng-deep .vertical .mat-tab-label-active:before{background-color:#151a41}:host ::ng-deep .vertical .mat-tab-label-active .mat-tab-label-content{font-weight:normal;color:#151a41}:host ::ng-deep .vertical .mat-tab-body-wrapper{width:100%;padding:16px}\n"]
|
|
19
18
|
},] }
|
|
20
19
|
];
|
|
21
20
|
DrTabsComponent.ctorParameters = () => [];
|
|
@@ -23,8 +22,7 @@ DrTabsComponent.propDecorators = {
|
|
|
23
22
|
selectedTab: [{ type: Input }],
|
|
24
23
|
withRadio: [{ type: Input }],
|
|
25
24
|
vertical: [{ type: Input }],
|
|
26
|
-
noBodyPadding: [{ type: Input }],
|
|
27
25
|
selectedTabChange: [{ type: Output }],
|
|
28
26
|
tabsContentList: [{ type: ContentChildren, args: [DrTabComponent,] }]
|
|
29
27
|
};
|
|
30
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItdGFicy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kYXRhcmFpbHNzaGFyZWQvc3JjL2xpYi9kci10YWJzL2RyLXRhYnMuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxTQUFTLEVBQ1QsZUFBZSxFQUVmLEtBQUssRUFDTCxZQUFZLEVBQ1osTUFBTSxHQUNQLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQU9wRCxNQUFNLE9BQU8sZUFBZTtJQVExQjtRQU5TLGdCQUFXLEdBQVcsQ0FBQyxDQUFDO1FBR3ZCLHNCQUFpQixHQUFzQixJQUFJLFlBQVksRUFBTyxDQUFDO0lBR3pELENBQUM7SUFFakIsbUJBQW1CLENBQUMsTUFBTTtRQUN4QixJQUFJLENBQUMsV0FBVyxHQUFHLE1BQU0sQ0FBQztRQUMxQixJQUFJLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ3RDLENBQUM7OztZQWxCRixTQUFTLFNBQUM7Z0JBQ1QsUUFBUSxFQUFFLFNBQVM7Z0JBQ25CLDJ5QkFBdUM7O2FBRXhDOzs7OzBCQUdFLEtBQUs7d0JBQ0wsS0FBSzt1QkFDTCxLQUFLO2dDQUNMLE1BQU07OEJBQ04sZUFBZSxTQUFDLGNBQWMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDb21wb25lbnQsXG4gIENvbnRlbnRDaGlsZHJlbixcbiAgUXVlcnlMaXN0LFxuICBJbnB1dCxcbiAgRXZlbnRFbWl0dGVyLFxuICBPdXRwdXQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRHJUYWJDb21wb25lbnQgfSBmcm9tICcuL2RyLXRhYi5jb21wb25lbnQnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdkci10YWJzJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2RyLXRhYnMuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9kci10YWJzLmNvbXBvbmVudC5zY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIERyVGFic0NvbXBvbmVudCB7XG5cbiAgQElucHV0KCkgc2VsZWN0ZWRUYWI6IG51bWJlciA9IDA7XG4gIEBJbnB1dCgpIHdpdGhSYWRpbzogYm9vbGVhbjtcbiAgQElucHV0KCkgdmVydGljYWw6IGJvb2xlYW47XG4gIEBPdXRwdXQoKSBzZWxlY3RlZFRhYkNoYW5nZTogRXZlbnRFbWl0dGVyPGFueT4gPSBuZXcgRXZlbnRFbWl0dGVyPGFueT4oKTtcbiAgQENvbnRlbnRDaGlsZHJlbihEclRhYkNvbXBvbmVudCkgcHVibGljIHRhYnNDb250ZW50TGlzdDogUXVlcnlMaXN0PERyVGFiQ29tcG9uZW50PjtcblxuICBjb25zdHJ1Y3RvcigpIHsgfVxuXG4gIHNlbGVjdGVkSW5kZXhDaGFuZ2UoJGV2ZW50KSB7XG4gICAgdGhpcy5zZWxlY3RlZFRhYiA9ICRldmVudDtcbiAgICB0aGlzLnNlbGVjdGVkVGFiQ2hhbmdlLmVtaXQoJGV2ZW50KTtcbiAgfVxuXG59XG4iXX0=
|