@colijnit/corecomponents_v12 12.0.40 → 12.0.43
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/colijnit-corecomponents_v12.umd.js +302 -28
- package/bundles/colijnit-corecomponents_v12.umd.js.map +1 -1
- package/colijnit-corecomponents_v12.d.ts +6 -5
- package/colijnit-corecomponents_v12.metadata.json +1 -1
- package/esm2015/colijnit-corecomponents_v12.js +7 -6
- package/esm2015/lib/components/filter-item/filter-item.component.js +59 -28
- package/esm2015/lib/components/filter-item/filter-item.module.js +5 -2
- package/esm2015/lib/components/input-date-range-picker/input-date-range-picker.component.js +7 -1
- package/esm2015/lib/core/enum/keyboard-key.enum.js +75 -0
- package/esm2015/lib/directives/clickoutside/click-outside-master.service.js +57 -0
- package/esm2015/lib/directives/clickoutside/click-outside.directive.js +71 -0
- package/esm2015/lib/directives/clickoutside/clickoutside.module.js +19 -0
- package/esm2015/public-api.js +3 -1
- package/fesm2015/colijnit-corecomponents_v12.js +278 -30
- package/fesm2015/colijnit-corecomponents_v12.js.map +1 -1
- package/lib/components/filter-item/filter-item.component.d.ts +5 -2
- package/lib/components/filter-item/style/_layout.scss +25 -19
- package/lib/components/filter-item/style/_material-definition.scss +1 -1
- package/lib/components/input-date-range-picker/input-date-range-picker.component.d.ts +2 -0
- package/lib/components/input-radio-button/style/_layout.scss +5 -5
- package/lib/components/input-radio-button/style/_material-definition.scss +6 -6
- package/lib/components/input-radio-button/style/_theme.scss +21 -2
- package/lib/core/enum/keyboard-key.enum.d.ts +69 -0
- package/lib/directives/clickoutside/click-outside-master.service.d.ts +15 -0
- package/lib/directives/clickoutside/click-outside.directive.d.ts +18 -0
- package/lib/directives/clickoutside/clickoutside.module.d.ts +2 -0
- package/lib/style/_variables.scss +5 -1
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
|
@@ -12,14 +12,15 @@ export { BaseSelectionGridComponent as ɵn } from './lib/components/grid/base/ba
|
|
|
12
12
|
export { BaseToolbarGridComponent as ɵp } from './lib/components/grid/base/base-toolbar-grid.component';
|
|
13
13
|
export { PopupShowerService as ɵx } from './lib/components/popup/service/popup-shower.service';
|
|
14
14
|
export { BaseSimpleGridComponent as ɵy } from './lib/components/simple-grid/base-simple-grid.component';
|
|
15
|
-
export { SimpleGridCellComponent as
|
|
15
|
+
export { SimpleGridCellComponent as ɵba } from './lib/components/simple-grid/simple-grid-cell.component';
|
|
16
16
|
export { ValidationErrorComponent as ɵu } from './lib/components/validation-error/validation-error.component';
|
|
17
17
|
export { ValidationErrorModule as ɵt } from './lib/components/validation-error/validation-error.module';
|
|
18
18
|
export { InputBoolean as ɵi } from './lib/core/decorator/input-boolean.decorator';
|
|
19
19
|
export { FormInputUserModelChangeListenerService as ɵk } from './lib/core/service/form-input-user-change-listener.service';
|
|
20
20
|
export { NgZoneWrapperService as ɵl } from './lib/core/service/ng-zone-wrapper.service';
|
|
21
|
-
export {
|
|
22
|
-
export {
|
|
21
|
+
export { ClickOutsideMasterService as ɵbe } from './lib/directives/clickoutside/click-outside-master.service';
|
|
22
|
+
export { ClickOutsideDirective as ɵbd } from './lib/directives/clickoutside/click-outside.directive';
|
|
23
|
+
export { ObserveVisibilityDirective as ɵz } from './lib/directives/observe-visibility/observe-visibility.directive';
|
|
23
24
|
export { CoRippleDirective as ɵc, MD_RIPPLE_GLOBAL_OPTIONS as ɵb } from './lib/directives/ripple/ripple.directive';
|
|
24
25
|
export { RippleModule as ɵa } from './lib/directives/ripple/ripple.module';
|
|
25
26
|
export { CoScrollDispatcherService as ɵe } from './lib/directives/ripple/scroll-dispatcher.service';
|
|
@@ -29,6 +30,6 @@ export { StopClickDirective as ɵh } from './lib/directives/stopclick/stop-click
|
|
|
29
30
|
export { StopClickModule as ɵg } from './lib/directives/stopclick/stop-click.module';
|
|
30
31
|
export { AppendPipe as ɵs } from './lib/pipes/append.pipe';
|
|
31
32
|
export { AppendPipeModule as ɵr } from './lib/pipes/append.pipe.module';
|
|
32
|
-
export { PrependPipe as
|
|
33
|
-
export { PrependPipeModule as
|
|
34
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
33
|
+
export { PrependPipe as ɵbc } from './lib/pipes/prepend.pipe';
|
|
34
|
+
export { PrependPipeModule as ɵbb } from './lib/pipes/prepend.pipe.module';
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29saWpuaXQtY29yZWNvbXBvbmVudHNfdjEyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcHJvamVjdHMvY29yZWNvbXBvbmVudHMvc3JjL2NvbGlqbml0LWNvcmVjb21wb25lbnRzX3YxMi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDO0FBRTdCLE9BQU8sRUFBQyxrQkFBa0IsSUFBSSxFQUFFLEVBQUMsTUFBTSw0Q0FBNEMsQ0FBQztBQUNwRixPQUFPLEVBQUMsVUFBVSxJQUFJLEVBQUUsRUFBQyxNQUFNLG1DQUFtQyxDQUFDO0FBQ25FLE9BQU8sRUFBQyxzQkFBc0IsSUFBSSxFQUFFLEVBQUMsTUFBTSwrREFBK0QsQ0FBQztBQUMzRyxPQUFPLEVBQUMsbUJBQW1CLElBQUksRUFBRSxFQUFDLE1BQU0sNERBQTRELENBQUM7QUFDckcsT0FBTyxFQUFDLGlCQUFpQixJQUFJLEVBQUUsRUFBQyxNQUFNLGdEQUFnRCxDQUFDO0FBQ3ZGLE9BQU8sRUFBQywyQkFBMkIsSUFBSSxFQUFFLEVBQUMsTUFBTSw0REFBNEQsQ0FBQztBQUM3RyxPQUFPLEVBQUMsMEJBQTBCLElBQUksRUFBRSxFQUFDLE1BQU0sMERBQTBELENBQUM7QUFDMUcsT0FBTyxFQUFDLHdCQUF3QixJQUFJLEVBQUUsRUFBQyxNQUFNLHdEQUF3RCxDQUFDO0FBQ3RHLE9BQU8sRUFBQyxrQkFBa0IsSUFBSSxFQUFFLEVBQUMsTUFBTSxxREFBcUQsQ0FBQztBQUM3RixPQUFPLEVBQUMsdUJBQXVCLElBQUksRUFBRSxFQUFDLE1BQU0seURBQXlELENBQUM7QUFDdEcsT0FBTyxFQUFDLHVCQUF1QixJQUFJLEdBQUcsRUFBQyxNQUFNLHlEQUF5RCxDQUFDO0FBQ3ZHLE9BQU8sRUFBQyx3QkFBd0IsSUFBSSxFQUFFLEVBQUMsTUFBTSw4REFBOEQsQ0FBQztBQUM1RyxPQUFPLEVBQUMscUJBQXFCLElBQUksRUFBRSxFQUFDLE1BQU0sMkRBQTJELENBQUM7QUFDdEcsT0FBTyxFQUFDLFlBQVksSUFBSSxFQUFFLEVBQUMsTUFBTSw4Q0FBOEMsQ0FBQztBQUNoRixPQUFPLEVBQUMsdUNBQXVDLElBQUksRUFBRSxFQUFDLE1BQU0sNERBQTRELENBQUM7QUFDekgsT0FBTyxFQUFDLG9CQUFvQixJQUFJLEVBQUUsRUFBQyxNQUFNLDRDQUE0QyxDQUFDO0FBQ3RGLE9BQU8sRUFBQyx5QkFBeUIsSUFBSSxHQUFHLEVBQUMsTUFBTSw0REFBNEQsQ0FBQztBQUM1RyxPQUFPLEVBQUMscUJBQXFCLElBQUksR0FBRyxFQUFDLE1BQU0sdURBQXVELENBQUM7QUFDbkcsT0FBTyxFQUFDLDBCQUEwQixJQUFJLEVBQUUsRUFBQyxNQUFNLGtFQUFrRSxDQUFDO0FBQ2xILE9BQU8sRUFBQyxpQkFBaUIsSUFBSSxFQUFFLEVBQUMsd0JBQXdCLElBQUksRUFBRSxFQUFDLE1BQU0sMENBQTBDLENBQUM7QUFDaEgsT0FBTyxFQUFDLFlBQVksSUFBSSxFQUFFLEVBQUMsTUFBTSx1Q0FBdUMsQ0FBQztBQUN6RSxPQUFPLEVBQUMseUJBQXlCLElBQUksRUFBRSxFQUFDLE1BQU0sbURBQW1ELENBQUM7QUFDbEcsT0FBTyxFQUFDLHFCQUFxQixJQUFJLEVBQUUsRUFBQyxNQUFNLDhDQUE4QyxDQUFDO0FBQ3pGLE9BQU8sRUFBQyxzQkFBc0IsSUFBSSxFQUFFLEVBQUMsTUFBTSxnREFBZ0QsQ0FBQztBQUM1RixPQUFPLEVBQUMsa0JBQWtCLElBQUksRUFBRSxFQUFDLE1BQU0saURBQWlELENBQUM7QUFDekYsT0FBTyxFQUFDLGVBQWUsSUFBSSxFQUFFLEVBQUMsTUFBTSw4Q0FBOEMsQ0FBQztBQUNuRixPQUFPLEVBQUMsVUFBVSxJQUFJLEVBQUUsRUFBQyxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBQyxnQkFBZ0IsSUFBSSxFQUFFLEVBQUMsTUFBTSxnQ0FBZ0MsQ0FBQztBQUN0RSxPQUFPLEVBQUMsV0FBVyxJQUFJLEdBQUcsRUFBQyxNQUFNLDBCQUEwQixDQUFDO0FBQzVELE9BQU8sRUFBQyxpQkFBaUIsSUFBSSxHQUFHLEVBQUMsTUFBTSxpQ0FBaUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcblxuZXhwb3J0IHtCYXNlSW5wdXRDb21wb25lbnQgYXMgybVtfSBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Jhc2UvYmFzZS1pbnB1dC5jb21wb25lbnQnO1xuZXhwb3J0IHtCYXNlTW9kdWxlIGFzIMm1an0gZnJvbSAnLi9saWIvY29tcG9uZW50cy9iYXNlL2Jhc2UubW9kdWxlJztcbmV4cG9ydCB7Q29tbWl0QnV0dG9uc0NvbXBvbmVudCBhcyDJtXd9IGZyb20gJy4vbGliL2NvbXBvbmVudHMvYmFzZS9jb21taXQtYnV0dG9ucy9jb21taXQtYnV0dG9ucy5jb21wb25lbnQnO1xuZXhwb3J0IHtDb21taXRCdXR0b25zTW9kdWxlIGFzIMm1dn0gZnJvbSAnLi9saWIvY29tcG9uZW50cy9iYXNlL2NvbW1pdC1idXR0b25zL2NvbW1pdC1idXR0b25zLm1vZHVsZSc7XG5leHBvcnQge0Jhc2VHcmlkQ29tcG9uZW50IGFzIMm1cX0gZnJvbSAnLi9saWIvY29tcG9uZW50cy9ncmlkL2Jhc2UvYmFzZS1ncmlkLmNvbXBvbmVudCc7XG5leHBvcnQge0Jhc2VJbmxpbmVFZGl0R3JpZENvbXBvbmVudCBhcyDJtW99IGZyb20gJy4vbGliL2NvbXBvbmVudHMvZ3JpZC9iYXNlL2Jhc2UtaW5saW5lLWVkaXQtZ3JpZC5jb21wb25lbnQnO1xuZXhwb3J0IHtCYXNlU2VsZWN0aW9uR3JpZENvbXBvbmVudCBhcyDJtW59IGZyb20gJy4vbGliL2NvbXBvbmVudHMvZ3JpZC9iYXNlL2Jhc2Utc2VsZWN0aW9uLWdyaWQuY29tcG9uZW50JztcbmV4cG9ydCB7QmFzZVRvb2xiYXJHcmlkQ29tcG9uZW50IGFzIMm1cH0gZnJvbSAnLi9saWIvY29tcG9uZW50cy9ncmlkL2Jhc2UvYmFzZS10b29sYmFyLWdyaWQuY29tcG9uZW50JztcbmV4cG9ydCB7UG9wdXBTaG93ZXJTZXJ2aWNlIGFzIMm1eH0gZnJvbSAnLi9saWIvY29tcG9uZW50cy9wb3B1cC9zZXJ2aWNlL3BvcHVwLXNob3dlci5zZXJ2aWNlJztcbmV4cG9ydCB7QmFzZVNpbXBsZUdyaWRDb21wb25lbnQgYXMgybV5fSBmcm9tICcuL2xpYi9jb21wb25lbnRzL3NpbXBsZS1ncmlkL2Jhc2Utc2ltcGxlLWdyaWQuY29tcG9uZW50JztcbmV4cG9ydCB7U2ltcGxlR3JpZENlbGxDb21wb25lbnQgYXMgybViYX0gZnJvbSAnLi9saWIvY29tcG9uZW50cy9zaW1wbGUtZ3JpZC9zaW1wbGUtZ3JpZC1jZWxsLmNvbXBvbmVudCc7XG5leHBvcnQge1ZhbGlkYXRpb25FcnJvckNvbXBvbmVudCBhcyDJtXV9IGZyb20gJy4vbGliL2NvbXBvbmVudHMvdmFsaWRhdGlvbi1lcnJvci92YWxpZGF0aW9uLWVycm9yLmNvbXBvbmVudCc7XG5leHBvcnQge1ZhbGlkYXRpb25FcnJvck1vZHVsZSBhcyDJtXR9IGZyb20gJy4vbGliL2NvbXBvbmVudHMvdmFsaWRhdGlvbi1lcnJvci92YWxpZGF0aW9uLWVycm9yLm1vZHVsZSc7XG5leHBvcnQge0lucHV0Qm9vbGVhbiBhcyDJtWl9IGZyb20gJy4vbGliL2NvcmUvZGVjb3JhdG9yL2lucHV0LWJvb2xlYW4uZGVjb3JhdG9yJztcbmV4cG9ydCB7Rm9ybUlucHV0VXNlck1vZGVsQ2hhbmdlTGlzdGVuZXJTZXJ2aWNlIGFzIMm1a30gZnJvbSAnLi9saWIvY29yZS9zZXJ2aWNlL2Zvcm0taW5wdXQtdXNlci1jaGFuZ2UtbGlzdGVuZXIuc2VydmljZSc7XG5leHBvcnQge05nWm9uZVdyYXBwZXJTZXJ2aWNlIGFzIMm1bH0gZnJvbSAnLi9saWIvY29yZS9zZXJ2aWNlL25nLXpvbmUtd3JhcHBlci5zZXJ2aWNlJztcbmV4cG9ydCB7Q2xpY2tPdXRzaWRlTWFzdGVyU2VydmljZSBhcyDJtWJlfSBmcm9tICcuL2xpYi9kaXJlY3RpdmVzL2NsaWNrb3V0c2lkZS9jbGljay1vdXRzaWRlLW1hc3Rlci5zZXJ2aWNlJztcbmV4cG9ydCB7Q2xpY2tPdXRzaWRlRGlyZWN0aXZlIGFzIMm1YmR9IGZyb20gJy4vbGliL2RpcmVjdGl2ZXMvY2xpY2tvdXRzaWRlL2NsaWNrLW91dHNpZGUuZGlyZWN0aXZlJztcbmV4cG9ydCB7T2JzZXJ2ZVZpc2liaWxpdHlEaXJlY3RpdmUgYXMgybV6fSBmcm9tICcuL2xpYi9kaXJlY3RpdmVzL29ic2VydmUtdmlzaWJpbGl0eS9vYnNlcnZlLXZpc2liaWxpdHkuZGlyZWN0aXZlJztcbmV4cG9ydCB7Q29SaXBwbGVEaXJlY3RpdmUgYXMgybVjLE1EX1JJUFBMRV9HTE9CQUxfT1BUSU9OUyBhcyDJtWJ9IGZyb20gJy4vbGliL2RpcmVjdGl2ZXMvcmlwcGxlL3JpcHBsZS5kaXJlY3RpdmUnO1xuZXhwb3J0IHtSaXBwbGVNb2R1bGUgYXMgybVhfSBmcm9tICcuL2xpYi9kaXJlY3RpdmVzL3JpcHBsZS9yaXBwbGUubW9kdWxlJztcbmV4cG9ydCB7Q29TY3JvbGxEaXNwYXRjaGVyU2VydmljZSBhcyDJtWV9IGZyb20gJy4vbGliL2RpcmVjdGl2ZXMvcmlwcGxlL3Njcm9sbC1kaXNwYXRjaGVyLnNlcnZpY2UnO1xuZXhwb3J0IHtDb1Njcm9sbGFibGVEaXJlY3RpdmUgYXMgybVmfSBmcm9tICcuL2xpYi9kaXJlY3RpdmVzL3JpcHBsZS9zY3JvbGxhYmxlLmRpcmVjdGl2ZSc7XG5leHBvcnQge0NvVmlld3BvcnRSdWxlclNlcnZpY2UgYXMgybVkfSBmcm9tICcuL2xpYi9kaXJlY3RpdmVzL3JpcHBsZS92aWV3cG9ydC1ydWxlci5zZXJ2aWNlJztcbmV4cG9ydCB7U3RvcENsaWNrRGlyZWN0aXZlIGFzIMm1aH0gZnJvbSAnLi9saWIvZGlyZWN0aXZlcy9zdG9wY2xpY2svc3RvcC1jbGljay5kaXJlY3RpdmUnO1xuZXhwb3J0IHtTdG9wQ2xpY2tNb2R1bGUgYXMgybVnfSBmcm9tICcuL2xpYi9kaXJlY3RpdmVzL3N0b3BjbGljay9zdG9wLWNsaWNrLm1vZHVsZSc7XG5leHBvcnQge0FwcGVuZFBpcGUgYXMgybVzfSBmcm9tICcuL2xpYi9waXBlcy9hcHBlbmQucGlwZSc7XG5leHBvcnQge0FwcGVuZFBpcGVNb2R1bGUgYXMgybVyfSBmcm9tICcuL2xpYi9waXBlcy9hcHBlbmQucGlwZS5tb2R1bGUnO1xuZXhwb3J0IHtQcmVwZW5kUGlwZSBhcyDJtWJjfSBmcm9tICcuL2xpYi9waXBlcy9wcmVwZW5kLnBpcGUnO1xuZXhwb3J0IHtQcmVwZW5kUGlwZU1vZHVsZSBhcyDJtWJifSBmcm9tICcuL2xpYi9waXBlcy9wcmVwZW5kLnBpcGUubW9kdWxlJzsiXX0=
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { __awaiter } from "tslib";
|
|
1
2
|
import { Component, EventEmitter, HostBinding, Input, Output, ViewEncapsulation } from "@angular/core";
|
|
2
3
|
import { CoreComponentsIcon } from "../../core/enum/core-components-icon.enum";
|
|
3
4
|
import { IconCacheService } from "../icon/icon-cache.service";
|
|
@@ -11,12 +12,12 @@ export class FilterItemComponent {
|
|
|
11
12
|
this.customContent = false;
|
|
12
13
|
// Set to true to show all results. Set to false to get 'show more' and 'show less' buttons to expand and contract.
|
|
13
14
|
this.showAllResults = false;
|
|
14
|
-
this.
|
|
15
|
+
this.singleSelect = false;
|
|
16
|
+
this.searchPlaceholder = 'Search...';
|
|
15
17
|
this.showMoreLabel = 'Show more';
|
|
16
18
|
this.showLessLabel = 'Show less';
|
|
17
19
|
this.noResultsLabel = "No results";
|
|
18
20
|
this.collectionChange = new EventEmitter();
|
|
19
|
-
this.filterTextChange = new EventEmitter();
|
|
20
21
|
this.filteredCollection = [];
|
|
21
22
|
this.limitTo = 10;
|
|
22
23
|
this.filterText = "";
|
|
@@ -56,26 +57,47 @@ export class FilterItemComponent {
|
|
|
56
57
|
}
|
|
57
58
|
return ((_a = this.filteredCollection) === null || _a === void 0 ? void 0 : _a.length) <= this.limitTo && ((_b = this.filteredCollection) === null || _b === void 0 ? void 0 : _b.length) > this.initialLimit;
|
|
58
59
|
}
|
|
60
|
+
handleModelChange(model) {
|
|
61
|
+
if (this.singleSelect) {
|
|
62
|
+
this.collection.forEach(m => {
|
|
63
|
+
if (m.code !== model.code && m.description !== model.description) {
|
|
64
|
+
m.checked = false;
|
|
65
|
+
}
|
|
66
|
+
});
|
|
67
|
+
}
|
|
68
|
+
model.checked = !model.checked;
|
|
69
|
+
this.collectionChange.emit(this.collection);
|
|
70
|
+
}
|
|
59
71
|
// Applies filter to the collection.
|
|
60
72
|
applyFilter(text) {
|
|
61
73
|
var _a, _b;
|
|
62
|
-
this
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
const labelText = (_a = item.description) === null || _a === void 0 ? void 0 : _a.toString().toLowerCase();
|
|
71
|
-
const isHiddenByFilter = ((labelText === null || labelText === void 0 ? void 0 : labelText.indexOf(filterText)) === -1);
|
|
72
|
-
if (isHiddenByFilter) {
|
|
73
|
-
return false;
|
|
74
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
75
|
+
if (!isNaN(this.minSearchCharsToLoadCollection) && this.collectionLoadFn) {
|
|
76
|
+
if (text.length === this.minSearchCharsToLoadCollection && text.length > this.filterText.length) {
|
|
77
|
+
this.collection = yield this.collectionLoadFn(text);
|
|
78
|
+
}
|
|
79
|
+
else if (text.length < this.minSearchCharsToLoadCollection) {
|
|
80
|
+
this.collection = undefined;
|
|
81
|
+
}
|
|
74
82
|
}
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
return
|
|
83
|
+
this.filterText = text;
|
|
84
|
+
if (!this.collection) {
|
|
85
|
+
return [];
|
|
78
86
|
}
|
|
87
|
+
const filterText = (_a = this.filterText) === null || _a === void 0 ? void 0 : _a.toString().toLowerCase();
|
|
88
|
+
let filteredItemCount = 0;
|
|
89
|
+
this.filteredCollection = (_b = this.collection) === null || _b === void 0 ? void 0 : _b.filter((item) => {
|
|
90
|
+
var _a;
|
|
91
|
+
const labelText = (_a = item.description) === null || _a === void 0 ? void 0 : _a.toString().toLowerCase();
|
|
92
|
+
const isHiddenByFilter = ((labelText === null || labelText === void 0 ? void 0 : labelText.indexOf(filterText)) === -1);
|
|
93
|
+
if (isHiddenByFilter) {
|
|
94
|
+
return false;
|
|
95
|
+
}
|
|
96
|
+
else {
|
|
97
|
+
filteredItemCount++;
|
|
98
|
+
return true;
|
|
99
|
+
}
|
|
100
|
+
});
|
|
79
101
|
});
|
|
80
102
|
}
|
|
81
103
|
}
|
|
@@ -97,29 +119,36 @@ FilterItemComponent.decorators = [
|
|
|
97
119
|
<ng-template #collectionContent>
|
|
98
120
|
<div class="co-filter-item-collection-content">
|
|
99
121
|
<co-input-text
|
|
100
|
-
*ngIf="collection?.length > 10"
|
|
122
|
+
*ngIf="collection?.length > 10 || minSearchCharsToLoadCollection"
|
|
101
123
|
[placeholder]="searchPlaceholder"
|
|
102
|
-
[
|
|
103
|
-
(modelChange)="applyFilter(
|
|
124
|
+
[model]="filterText"
|
|
125
|
+
(modelChange)="applyFilter($event)"
|
|
104
126
|
>
|
|
105
127
|
</co-input-text>
|
|
106
128
|
<div class="no-results" *ngIf="filteredCollection?.length === 0">
|
|
107
129
|
<span [textContent]="noResultsLabel"></span>
|
|
108
130
|
</div>
|
|
109
131
|
<div class="co-filter-item-collection-results">
|
|
110
|
-
<
|
|
111
|
-
|
|
132
|
+
<ng-container
|
|
133
|
+
*ngFor="let option of filteredCollection; let index = index">
|
|
112
134
|
<div class="co-filter-item-collection-result-item" *ngIf="index < limitTo || showAllResults">
|
|
113
|
-
<co-input-checkbox
|
|
114
|
-
[
|
|
115
|
-
|
|
135
|
+
<co-input-checkbox *ngIf="!singleSelect"
|
|
136
|
+
[label]="option.description"
|
|
137
|
+
[model]="option.checked"
|
|
138
|
+
(modelChange)="handleModelChange(option)"
|
|
116
139
|
></co-input-checkbox>
|
|
140
|
+
<co-input-radio-button *ngIf="singleSelect"
|
|
141
|
+
[name]="'radiogroup'"
|
|
142
|
+
[label]="option.description"
|
|
143
|
+
[model]="option.checked"
|
|
144
|
+
(modelChange)="handleModelChange(option)"
|
|
145
|
+
></co-input-radio-button>
|
|
117
146
|
<div class="co-filter-item-amount" *ngIf="option.count"
|
|
118
147
|
[textContent]="option.count.toString() | append: ')' | prepend: ' ('"
|
|
119
148
|
></div>
|
|
120
149
|
</div>
|
|
121
150
|
|
|
122
|
-
</
|
|
151
|
+
</ng-container>
|
|
123
152
|
</div>
|
|
124
153
|
<div class="co-filter-show-more-or-less" *ngIf="!showAllResults">
|
|
125
154
|
<div class="co-filter-show-more clickable"
|
|
@@ -155,14 +184,16 @@ FilterItemComponent.propDecorators = {
|
|
|
155
184
|
placeholder: [{ type: Input }],
|
|
156
185
|
initialLimit: [{ type: Input }],
|
|
157
186
|
expanded: [{ type: Input }],
|
|
187
|
+
minSearchCharsToLoadCollection: [{ type: Input }],
|
|
188
|
+
collectionLoadFn: [{ type: Input }],
|
|
158
189
|
customContent: [{ type: Input }],
|
|
159
190
|
showAllResults: [{ type: Input }],
|
|
191
|
+
singleSelect: [{ type: Input }],
|
|
160
192
|
searchPlaceholder: [{ type: Input }],
|
|
161
193
|
showMoreLabel: [{ type: Input }],
|
|
162
194
|
showLessLabel: [{ type: Input }],
|
|
163
195
|
noResultsLabel: [{ type: Input }],
|
|
164
196
|
collectionChange: [{ type: Output }],
|
|
165
|
-
filterTextChange: [{ type: Output }],
|
|
166
197
|
showClass: [{ type: HostBinding, args: ["class.co-filter-item",] }]
|
|
167
198
|
};
|
|
168
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-item.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/filter-item/filter-item.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, HostBinding, Input, OnInit, Output, ViewEncapsulation } from \"@angular/core\";\r\nimport { CoreComponentsIcon } from \"../../core/enum/core-components-icon.enum\";\r\nimport { FilterItemViewmodel } from \"../../core/interface/filter-item-viewmodel\";\r\nimport { IconCacheService } from \"../icon/icon-cache.service\";\r\n\r\n@Component({\r\n  selector: \"co-filter-item\",\r\n  template: `\r\n    <div class=\"co-filter-item-header\">\r\n      <co-collapsible\r\n        [headerTitle]=\"placeholder\"\r\n        [expandButtonLast]=\"true\"\r\n        [iconData]=\"iconService.getIcon(icons.ArrowPointDown)\"\r\n        [expanded]=\"expanded\"\r\n      >\r\n        <div class=\"co-filter-item-collapsable-content\">\r\n          <div class=\"co-filter-item-custom-content\" *ngIf=\"customContent; else collectionContent\">\r\n            <ng-content></ng-content>\r\n          </div>\r\n          <ng-template #collectionContent>\r\n            <div class=\"co-filter-item-collection-content\">\r\n              <co-input-text\r\n                *ngIf=\"collection?.length > 10\"\r\n                [placeholder]=\"searchPlaceholder\"\r\n                [(model)]=\"filterText\"\r\n                (modelChange)=\"applyFilter(filterText)\"\r\n              >\r\n              </co-input-text>\r\n              <div class=\"no-results\" *ngIf=\"filteredCollection?.length === 0\">\r\n                <span [textContent]=\"noResultsLabel\"></span>\r\n              </div>\r\n              <div class=\"co-filter-item-collection-results\">\r\n                <div class=\"co-filter-item-collection-result-items\"\r\n                     *ngFor=\"let option of filteredCollection; let index = index\">\r\n                  <div class=\"co-filter-item-collection-result-item\" *ngIf=\"index < limitTo || showAllResults\">\r\n                    <co-input-checkbox [label]=\"option.description\"\r\n                                       [(model)]=\"option.checked\"\r\n                                       (modelChange)=\"collectionChange.emit(collection)\"\r\n                    ></co-input-checkbox>\r\n                    <div class=\"co-filter-item-amount\" *ngIf=\"option.count\"\r\n                         [textContent]=\"option.count.toString() | append: ')' | prepend: '      ('\"\r\n                    ></div>\r\n                  </div>\r\n\r\n                </div>\r\n              </div>\r\n              <div class=\"co-filter-show-more-or-less\" *ngIf=\"!showAllResults\">\r\n                <div class=\"co-filter-show-more clickable\"\r\n                     *ngIf=\"moreToShow()\">\r\n                  <a (click)=\"increaseLimit()\">\r\n                    <co-icon [iconData]=\"iconService.getIcon(icons.ArrowPointDown)\"></co-icon>\r\n                    <span [textContent]=\"showMoreLabel\"></span>\r\n                  </a>\r\n                </div>\r\n                <div class=\"co-filter-show-less clickable\"\r\n                     *ngIf=\"lessToShow()\">\r\n                  <a (click)=\"setToInitialLimit()\">\r\n                    <co-icon [iconData]=\"iconService.getIcon(icons.ArrowPointUp)\"></co-icon>\r\n                    <span [textContent]=\"showLessLabel\"></span>\r\n                  </a>\r\n                </div>\r\n              </div>\r\n            </div>\r\n          </ng-template>\r\n        </div>\r\n      </co-collapsible>\r\n    </div>\r\n\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class FilterItemComponent implements OnInit {\r\n  public icons: typeof CoreComponentsIcon = CoreComponentsIcon;\r\n\r\n  @Input()\r\n  public set collection(value: FilterItemViewmodel[]) {\r\n    this._collection = value;\r\n    this.filteredCollection = this._collection?.slice();\r\n  }\r\n\r\n  public get collection(): FilterItemViewmodel[] {\r\n    return this._collection;\r\n  }\r\n\r\n  @Input()\r\n  public placeholder: string;\r\n\r\n  @Input()\r\n  public initialLimit: number = 10;\r\n\r\n  @Input()\r\n  public expanded: boolean = false;\r\n\r\n  // Set to false to use filter item with a multi selectable collection. Set to true to specify custom content\r\n  @Input()\r\n  public customContent: boolean = false;\r\n\r\n  // Set to true to show all results. Set to false to get 'show more' and 'show less' buttons to expand and contract.\r\n  @Input()\r\n  public showAllResults: boolean = false;\r\n\r\n  @Input()\r\n  public searchPlaceholder: string = \"Search...\";\r\n\r\n  @Input()\r\n  public showMoreLabel: string = 'Show more';\r\n\r\n  @Input()\r\n  public showLessLabel: string = 'Show less';\r\n\r\n  @Input()\r\n  public noResultsLabel: string = \"No results\";\r\n\r\n  @Output()\r\n  public collectionChange: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  @Output()\r\n  public filterTextChange: EventEmitter<string> = new EventEmitter<string>();\r\n\r\n  @HostBinding(\"class.co-filter-item\")\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  public filteredCollection: FilterItemViewmodel[] = [];\r\n  public limitTo: number = 10;\r\n  public filterText: string = \"\";\r\n\r\n  private _collection: FilterItemViewmodel[] = [];\r\n\r\n  constructor(public iconService: IconCacheService) {\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    this.setToInitialLimit();\r\n  }\r\n\r\n  public setToInitialLimit(): void {\r\n    this.limitTo = this.initialLimit;\r\n  }\r\n\r\n  public increaseLimit(): void {\r\n    this.limitTo += 10;\r\n  }\r\n\r\n  public moreToShow(): boolean {\r\n    if (this.showAllResults) {\r\n      return false;\r\n    }\r\n    return this.filteredCollection?.length > this.limitTo;\r\n  }\r\n\r\n  public lessToShow() {\r\n    if (this.showAllResults) {\r\n      return false;\r\n    }\r\n    return this.filteredCollection?.length <= this.limitTo && this.filteredCollection?.length > this.initialLimit;\r\n  }\r\n\r\n\r\n  // Applies filter to the collection.\r\n  public applyFilter(text: string): [] {\r\n    this.filterTextChange.emit(text);\r\n\r\n    if (!this.collection) {\r\n      return [];\r\n    }\r\n\r\n    const filterText: string = this.filterText?.toString().toLowerCase();\r\n    let filteredItemCount: number = 0;\r\n    this.filteredCollection = this.collection?.filter((item) => {\r\n      const labelText: string = item.description?.toString().toLowerCase();\r\n      const isHiddenByFilter: boolean = (labelText?.indexOf(filterText) === -1);\r\n      if (isHiddenByFilter) {\r\n        return false;\r\n      } else {\r\n        filteredItemCount++;\r\n        return true;\r\n      }\r\n    });\r\n  }\r\n}\r\n"]}
|
|
199
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-item.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/filter-item/filter-item.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, HostBinding, Input, OnInit, Output, ViewEncapsulation } from \"@angular/core\";\r\nimport { CoreComponentsIcon } from \"../../core/enum/core-components-icon.enum\";\r\nimport { FilterItemViewmodel } from \"../../core/interface/filter-item-viewmodel\";\r\nimport { IconCacheService } from \"../icon/icon-cache.service\";\r\n\r\n@Component({\r\n  selector: \"co-filter-item\",\r\n  template: `\r\n    <div class=\"co-filter-item-header\">\r\n      <co-collapsible\r\n        [headerTitle]=\"placeholder\"\r\n        [expandButtonLast]=\"true\"\r\n        [iconData]=\"iconService.getIcon(icons.ArrowPointDown)\"\r\n        [expanded]=\"expanded\"\r\n      >\r\n        <div class=\"co-filter-item-collapsable-content\">\r\n          <div class=\"co-filter-item-custom-content\" *ngIf=\"customContent; else collectionContent\">\r\n            <ng-content></ng-content>\r\n          </div>\r\n          <ng-template #collectionContent>\r\n            <div class=\"co-filter-item-collection-content\">\r\n              <co-input-text\r\n                *ngIf=\"collection?.length > 10 || minSearchCharsToLoadCollection\"\r\n                [placeholder]=\"searchPlaceholder\"\r\n                [model]=\"filterText\"\r\n                (modelChange)=\"applyFilter($event)\"\r\n              >\r\n              </co-input-text>\r\n              <div class=\"no-results\" *ngIf=\"filteredCollection?.length === 0\">\r\n                <span [textContent]=\"noResultsLabel\"></span>\r\n              </div>\r\n              <div class=\"co-filter-item-collection-results\">\r\n                <ng-container\r\n                  *ngFor=\"let option of filteredCollection; let index = index\">\r\n                  <div class=\"co-filter-item-collection-result-item\" *ngIf=\"index < limitTo || showAllResults\">\r\n                    <co-input-checkbox *ngIf=\"!singleSelect\"\r\n                                       [label]=\"option.description\"\r\n                                       [model]=\"option.checked\"\r\n                                       (modelChange)=\"handleModelChange(option)\"\r\n                    ></co-input-checkbox>\r\n                    <co-input-radio-button *ngIf=\"singleSelect\"\r\n                                           [name]=\"'radiogroup'\"\r\n                                           [label]=\"option.description\"\r\n                                           [model]=\"option.checked\"\r\n                                           (modelChange)=\"handleModelChange(option)\"\r\n                    ></co-input-radio-button>\r\n                    <div class=\"co-filter-item-amount\" *ngIf=\"option.count\"\r\n                         [textContent]=\"option.count.toString() | append: ')' | prepend: '      ('\"\r\n                    ></div>\r\n                  </div>\r\n\r\n                </ng-container>\r\n              </div>\r\n              <div class=\"co-filter-show-more-or-less\" *ngIf=\"!showAllResults\">\r\n                <div class=\"co-filter-show-more clickable\"\r\n                     *ngIf=\"moreToShow()\">\r\n                  <a (click)=\"increaseLimit()\">\r\n                    <co-icon [iconData]=\"iconService.getIcon(icons.ArrowPointDown)\"></co-icon>\r\n                    <span [textContent]=\"showMoreLabel\"></span>\r\n                  </a>\r\n                </div>\r\n                <div class=\"co-filter-show-less clickable\"\r\n                     *ngIf=\"lessToShow()\">\r\n                  <a (click)=\"setToInitialLimit()\">\r\n                    <co-icon [iconData]=\"iconService.getIcon(icons.ArrowPointUp)\"></co-icon>\r\n                    <span [textContent]=\"showLessLabel\"></span>\r\n                  </a>\r\n                </div>\r\n              </div>\r\n            </div>\r\n          </ng-template>\r\n        </div>\r\n      </co-collapsible>\r\n    </div>\r\n\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class FilterItemComponent implements OnInit {\r\n  public icons: typeof CoreComponentsIcon = CoreComponentsIcon;\r\n\r\n  @Input()\r\n  public set collection(value: FilterItemViewmodel[]) {\r\n    this._collection = value;\r\n    this.filteredCollection = this._collection?.slice();\r\n  }\r\n\r\n  public get collection(): FilterItemViewmodel[] {\r\n    return this._collection;\r\n  }\r\n\r\n  @Input()\r\n  public placeholder: string;\r\n\r\n  @Input()\r\n  public initialLimit: number = 10;\r\n\r\n  @Input()\r\n  public expanded: boolean = false;\r\n\r\n  @Input()\r\n  public minSearchCharsToLoadCollection: number;\r\n\r\n  @Input()\r\n  public collectionLoadFn: Function;\r\n\r\n  // Set to false to use filter item with a multi selectable collection. Set to true to specify custom content\r\n  @Input()\r\n  public customContent: boolean = false;\r\n\r\n  // Set to true to show all results. Set to false to get 'show more' and 'show less' buttons to expand and contract.\r\n  @Input()\r\n  public showAllResults: boolean = false;\r\n\r\n  @Input()\r\n  public singleSelect: boolean = false;\r\n\r\n  @Input()\r\n  public searchPlaceholder: string = 'Search...';\r\n\r\n  @Input()\r\n  public showMoreLabel: string = 'Show more';\r\n\r\n  @Input()\r\n  public showLessLabel: string = 'Show less';\r\n\r\n  @Input()\r\n  public noResultsLabel: string = \"No results\";\r\n\r\n  @Output()\r\n  public collectionChange: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  @HostBinding(\"class.co-filter-item\")\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  public filteredCollection: FilterItemViewmodel[] = [];\r\n  public limitTo: number = 10;\r\n  public filterText: string = \"\";\r\n\r\n  private _collection: FilterItemViewmodel[] = [];\r\n\r\n  constructor(public iconService: IconCacheService) {\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    this.setToInitialLimit();\r\n  }\r\n\r\n  public setToInitialLimit(): void {\r\n    this.limitTo = this.initialLimit;\r\n  }\r\n\r\n  public increaseLimit(): void {\r\n    this.limitTo += 10;\r\n  }\r\n\r\n  public moreToShow(): boolean {\r\n    if (this.showAllResults) {\r\n      return false;\r\n    }\r\n    return this.filteredCollection?.length > this.limitTo;\r\n  }\r\n\r\n  public lessToShow() {\r\n    if (this.showAllResults) {\r\n      return false;\r\n    }\r\n    return this.filteredCollection?.length <= this.limitTo && this.filteredCollection?.length > this.initialLimit;\r\n  }\r\n\r\n  public handleModelChange(model: FilterItemViewmodel) {\r\n    if (this.singleSelect) {\r\n      this.collection.forEach(m => {\r\n        if (m.code !== model.code && m.description !== model.description) {\r\n          m.checked = false;\r\n        }\r\n      });\r\n    }\r\n    model.checked = !model.checked;\r\n    this.collectionChange.emit(this.collection);\r\n  }\r\n\r\n  // Applies filter to the collection.\r\n  public async applyFilter(text: string): Promise<[]> {\r\n    if (!isNaN(this.minSearchCharsToLoadCollection) && this.collectionLoadFn) {\r\n      if (text.length === this.minSearchCharsToLoadCollection && text.length > this.filterText.length) {\r\n        this.collection = await this.collectionLoadFn(text);\r\n      } else if (text.length < this.minSearchCharsToLoadCollection) {\r\n        this.collection = undefined;\r\n      }\r\n    }\r\n    this.filterText = text;\r\n    if (!this.collection) {\r\n      return [];\r\n    }\r\n\r\n    const filterText: string = this.filterText?.toString().toLowerCase();\r\n    let filteredItemCount: number = 0;\r\n    this.filteredCollection = this.collection?.filter((item) => {\r\n      const labelText: string = item.description?.toString().toLowerCase();\r\n      const isHiddenByFilter: boolean = (labelText?.indexOf(filterText) === -1);\r\n      if (isHiddenByFilter) {\r\n        return false;\r\n      } else {\r\n        filteredItemCount++;\r\n        return true;\r\n      }\r\n    });\r\n  }\r\n}\r\n"]}
|
|
@@ -9,6 +9,7 @@ import { InputCheckboxMultiSelectModule } from "../input-checkbox-multi-select/i
|
|
|
9
9
|
import { InputCheckboxModule } from "../input-checkbox/input-checkbox.module";
|
|
10
10
|
import { InputTextModule } from "../input-text/input-text.module";
|
|
11
11
|
import { FilterItemComponent } from "./filter-item.component";
|
|
12
|
+
import { InputRadioButtonModule } from '../input-radio-button/input-radio-button.module';
|
|
12
13
|
export class FilterItemModule {
|
|
13
14
|
}
|
|
14
15
|
FilterItemModule.decorators = [
|
|
@@ -22,7 +23,9 @@ FilterItemModule.decorators = [
|
|
|
22
23
|
IconModule,
|
|
23
24
|
ScrollingModule,
|
|
24
25
|
AppendPipeModule,
|
|
25
|
-
PrependPipeModule
|
|
26
|
+
PrependPipeModule,
|
|
27
|
+
InputTextModule,
|
|
28
|
+
InputRadioButtonModule
|
|
26
29
|
],
|
|
27
30
|
declarations: [
|
|
28
31
|
FilterItemComponent
|
|
@@ -32,4 +35,4 @@ FilterItemModule.decorators = [
|
|
|
32
35
|
]
|
|
33
36
|
},] }
|
|
34
37
|
];
|
|
35
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLWl0ZW0ubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2ZpbHRlci1pdGVtL2ZpbHRlci1pdGVtLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDekQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDbEUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDcEUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFDdEUsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ2pELE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLG1FQUFtRSxDQUFDO0FBQ25ILE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHlDQUF5QyxDQUFDO0FBQzlFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUNsRSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUM5RCxPQUFPLEVBQUMsc0JBQXNCLEVBQUMsTUFBTSxpREFBaUQsQ0FBQztBQXVCdkYsTUFBTSxPQUFPLGdCQUFnQjs7O1lBckI1QixRQUFRLFNBQUM7Z0JBQ1IsT0FBTyxFQUFFO29CQUNQLFlBQVk7b0JBQ1osaUJBQWlCO29CQUNqQixlQUFlO29CQUNmLDhCQUE4QjtvQkFDOUIsbUJBQW1CO29CQUNuQixVQUFVO29CQUNWLGVBQWU7b0JBQ2YsZ0JBQWdCO29CQUNoQixpQkFBaUI7b0JBQ2pCLGVBQWU7b0JBQ2Ysc0JBQXNCO2lCQUN2QjtnQkFDRCxZQUFZLEVBQUU7b0JBQ1osbUJBQW1CO2lCQUNwQjtnQkFDRCxPQUFPLEVBQUU7b0JBQ1AsbUJBQW1CO2lCQUNwQjthQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU2Nyb2xsaW5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL3Njcm9sbGluZyc7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcclxuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBBcHBlbmRQaXBlTW9kdWxlIH0gZnJvbSAnLi4vLi4vcGlwZXMvYXBwZW5kLnBpcGUubW9kdWxlJztcclxuaW1wb3J0IHsgUHJlcGVuZFBpcGVNb2R1bGUgfSBmcm9tICcuLi8uLi9waXBlcy9wcmVwZW5kLnBpcGUubW9kdWxlJztcclxuaW1wb3J0IHsgQ29sbGFwc2libGVNb2R1bGUgfSBmcm9tIFwiLi4vY29sbGFwc2libGUvY29sbGFwc2libGUubW9kdWxlXCI7XHJcbmltcG9ydCB7IEljb25Nb2R1bGUgfSBmcm9tIFwiLi4vaWNvbi9pY29uLm1vZHVsZVwiO1xyXG5pbXBvcnQgeyBJbnB1dENoZWNrYm94TXVsdGlTZWxlY3RNb2R1bGUgfSBmcm9tIFwiLi4vaW5wdXQtY2hlY2tib3gtbXVsdGktc2VsZWN0L2lucHV0LWNoZWNrYm94LW11bHRpLXNlbGVjdC5tb2R1bGVcIjtcclxuaW1wb3J0IHsgSW5wdXRDaGVja2JveE1vZHVsZSB9IGZyb20gXCIuLi9pbnB1dC1jaGVja2JveC9pbnB1dC1jaGVja2JveC5tb2R1bGVcIjtcclxuaW1wb3J0IHsgSW5wdXRUZXh0TW9kdWxlIH0gZnJvbSBcIi4uL2lucHV0LXRleHQvaW5wdXQtdGV4dC5tb2R1bGVcIjtcclxuaW1wb3J0IHsgRmlsdGVySXRlbUNvbXBvbmVudCB9IGZyb20gXCIuL2ZpbHRlci1pdGVtLmNvbXBvbmVudFwiO1xyXG5pbXBvcnQge0lucHV0UmFkaW9CdXR0b25Nb2R1bGV9IGZyb20gJy4uL2lucHV0LXJhZGlvLWJ1dHRvbi9pbnB1dC1yYWRpby1idXR0b24ubW9kdWxlJztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgaW1wb3J0czogW1xyXG4gICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgQ29sbGFwc2libGVNb2R1bGUsXHJcbiAgICBJbnB1dFRleHRNb2R1bGUsXHJcbiAgICBJbnB1dENoZWNrYm94TXVsdGlTZWxlY3RNb2R1bGUsXHJcbiAgICBJbnB1dENoZWNrYm94TW9kdWxlLFxyXG4gICAgSWNvbk1vZHVsZSxcclxuICAgIFNjcm9sbGluZ01vZHVsZSxcclxuICAgIEFwcGVuZFBpcGVNb2R1bGUsXHJcbiAgICBQcmVwZW5kUGlwZU1vZHVsZSxcclxuICAgIElucHV0VGV4dE1vZHVsZSxcclxuICAgIElucHV0UmFkaW9CdXR0b25Nb2R1bGVcclxuICBdLFxyXG4gIGRlY2xhcmF0aW9uczogW1xyXG4gICAgRmlsdGVySXRlbUNvbXBvbmVudFxyXG4gIF0sXHJcbiAgZXhwb3J0czogW1xyXG4gICAgRmlsdGVySXRlbUNvbXBvbmVudFxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIEZpbHRlckl0ZW1Nb2R1bGUge1xyXG5cclxufVxyXG4iXX0=
|
|
@@ -8,6 +8,8 @@ export class InputDateRangePickerComponent extends BaseInputComponent {
|
|
|
8
8
|
this.startDateChange = new EventEmitter();
|
|
9
9
|
this.endDateChange = new EventEmitter();
|
|
10
10
|
this.dateRangeChange = new EventEmitter();
|
|
11
|
+
this.close = new EventEmitter();
|
|
12
|
+
this.select = new EventEmitter();
|
|
11
13
|
}
|
|
12
14
|
showClass() {
|
|
13
15
|
return true;
|
|
@@ -29,6 +31,8 @@ InputDateRangePickerComponent.decorators = [
|
|
|
29
31
|
[placeholder]="placeholder"
|
|
30
32
|
[ngModel]="model"
|
|
31
33
|
(ngModelChange)="rangeChange()"
|
|
34
|
+
(close)="close.next($event)"
|
|
35
|
+
(select)="select.next($event)"
|
|
32
36
|
[(startDate)]="startDate"
|
|
33
37
|
[(endDate)]="endDate"
|
|
34
38
|
></ejs-daterangepicker>
|
|
@@ -46,6 +50,8 @@ InputDateRangePickerComponent.propDecorators = {
|
|
|
46
50
|
startDateChange: [{ type: Output }],
|
|
47
51
|
endDateChange: [{ type: Output }],
|
|
48
52
|
dateRangeChange: [{ type: Output }],
|
|
53
|
+
close: [{ type: Output }],
|
|
54
|
+
select: [{ type: Output }],
|
|
49
55
|
showClass: [{ type: HostBinding, args: ["class.co-input-date-range-picker",] }]
|
|
50
56
|
};
|
|
51
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
57
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtZGF0ZS1yYW5nZS1waWNrZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2lucHV0LWRhdGUtcmFuZ2UtcGlja2VyL2lucHV0LWRhdGUtcmFuZ2UtcGlja2VyLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLFlBQVksRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxpQkFBaUIsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUNyRyxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSw4QkFBOEIsQ0FBQztBQW9CaEUsTUFBTSxPQUFPLDZCQUE4QixTQUFRLGtCQUF3QjtJQWxCM0U7O1FBcUJTLGVBQVUsR0FBVyxZQUFZLENBQUM7UUFHbEMsZ0JBQVcsR0FBVyxFQUFFLENBQUM7UUFTekIsb0JBQWUsR0FBdUIsSUFBSSxZQUFZLEVBQVEsQ0FBQztRQUcvRCxrQkFBYSxHQUF1QixJQUFJLFlBQVksRUFBUSxDQUFDO1FBRzdELG9CQUFlLEdBQXlCLElBQUksWUFBWSxFQUFVLENBQUM7UUFHbkUsVUFBSyxHQUFxQixJQUFJLFlBQVksRUFBTSxDQUFDO1FBR2pELFdBQU0sR0FBcUIsSUFBSSxZQUFZLEVBQU0sQ0FBQztJQWUzRCxDQUFDO0lBWlEsU0FBUztRQUNkLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVNLFdBQVc7UUFDaEIsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQzFDLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUV0QyxJQUFJLElBQUksQ0FBQyxTQUFTLElBQUksSUFBSSxDQUFDLE9BQU8sRUFBRTtZQUNsQyxJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUM7U0FDM0Q7SUFDSCxDQUFDOzs7WUEzREYsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSxxQkFBcUI7Z0JBQy9CLFFBQVEsRUFBRTs7Ozs7Ozs7Ozs7OztHQWFUO2dCQUNELGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO2FBQ3RDOzs7eUJBR0UsS0FBSzswQkFHTCxLQUFLO3dCQUdMLEtBQUs7c0JBR0wsS0FBSzs4QkFHTCxNQUFNOzRCQUdOLE1BQU07OEJBR04sTUFBTTtvQkFHTixNQUFNO3FCQUdOLE1BQU07d0JBR04sV0FBVyxTQUFDLGtDQUFrQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIEhvc3RCaW5kaW5nLCBJbnB1dCwgT3V0cHV0LCBWaWV3RW5jYXBzdWxhdGlvbn0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHtCYXNlSW5wdXRDb21wb25lbnR9IGZyb20gXCIuLi9iYXNlL2Jhc2UtaW5wdXQuY29tcG9uZW50XCI7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogXCJjby1pbnB1dC1kYXRlLXJhbmdlXCIsXHJcbiAgdGVtcGxhdGU6IGBcclxuICAgIDxlanMtZGF0ZXJhbmdlcGlja2VyXHJcbiAgICAgIFtmb3JtYXRdPVwiZGF0ZUZvcm1hdFwiXHJcbiAgICAgIFtwbGFjZWhvbGRlcl09XCJwbGFjZWhvbGRlclwiXHJcbiAgICAgIFtuZ01vZGVsXT1cIm1vZGVsXCJcclxuICAgICAgKG5nTW9kZWxDaGFuZ2UpPVwicmFuZ2VDaGFuZ2UoKVwiXHJcbiAgICAgIChjbG9zZSk9XCJjbG9zZS5uZXh0KCRldmVudClcIlxyXG4gICAgICAoc2VsZWN0KT1cInNlbGVjdC5uZXh0KCRldmVudClcIlxyXG4gICAgICBbKHN0YXJ0RGF0ZSldPVwic3RhcnREYXRlXCJcclxuICAgICAgWyhlbmREYXRlKV09XCJlbmREYXRlXCJcclxuICAgID48L2Vqcy1kYXRlcmFuZ2VwaWNrZXI+XHJcbiAgICA8ZGl2IGNsYXNzPVwicmVxdWlyZWQtaW5kaWNhdG9yXCI+PC9kaXY+XHJcbiAgICA8bmctdGVtcGxhdGUgI3ZhbGlkYXRpb25FcnJvcj48L25nLXRlbXBsYXRlPlxyXG4gIGAsXHJcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZVxyXG59KVxyXG5leHBvcnQgY2xhc3MgSW5wdXREYXRlUmFuZ2VQaWNrZXJDb21wb25lbnQgZXh0ZW5kcyBCYXNlSW5wdXRDb21wb25lbnQ8RGF0ZT4ge1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBkYXRlRm9ybWF0OiBzdHJpbmcgPSBcImRkLU1NLXl5eXlcIjtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgcGxhY2Vob2xkZXI6IHN0cmluZyA9IFwiXCI7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIHN0YXJ0RGF0ZTogRGF0ZTtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgZW5kRGF0ZTogRGF0ZTtcclxuXHJcbiAgQE91dHB1dCgpXHJcbiAgcHVibGljIHN0YXJ0RGF0ZUNoYW5nZTogRXZlbnRFbWl0dGVyPERhdGU+ID0gbmV3IEV2ZW50RW1pdHRlcjxEYXRlPigpO1xyXG5cclxuICBAT3V0cHV0KClcclxuICBwdWJsaWMgZW5kRGF0ZUNoYW5nZTogRXZlbnRFbWl0dGVyPERhdGU+ID0gbmV3IEV2ZW50RW1pdHRlcjxEYXRlPigpO1xyXG5cclxuICBAT3V0cHV0KClcclxuICBwdWJsaWMgZGF0ZVJhbmdlQ2hhbmdlOiBFdmVudEVtaXR0ZXI8RGF0ZVtdPiA9IG5ldyBFdmVudEVtaXR0ZXI8RGF0ZVtdPigpO1xyXG5cclxuICBAT3V0cHV0KClcclxuICBwdWJsaWMgY2xvc2U6IEV2ZW50RW1pdHRlcjx7fT4gPSBuZXcgRXZlbnRFbWl0dGVyPHt9PigpO1xyXG5cclxuICBAT3V0cHV0KClcclxuICBwdWJsaWMgc2VsZWN0OiBFdmVudEVtaXR0ZXI8e30+ID0gbmV3IEV2ZW50RW1pdHRlcjx7fT4oKTtcclxuXHJcbiAgQEhvc3RCaW5kaW5nKFwiY2xhc3MuY28taW5wdXQtZGF0ZS1yYW5nZS1waWNrZXJcIilcclxuICBwdWJsaWMgc2hvd0NsYXNzKCk6IGJvb2xlYW4ge1xyXG4gICAgcmV0dXJuIHRydWU7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgcmFuZ2VDaGFuZ2UoKTogdm9pZCB7XHJcbiAgICB0aGlzLnN0YXJ0RGF0ZUNoYW5nZS5lbWl0KHRoaXMuc3RhcnREYXRlKTtcclxuICAgIHRoaXMuZW5kRGF0ZUNoYW5nZS5lbWl0KHRoaXMuZW5kRGF0ZSk7XHJcblxyXG4gICAgaWYgKHRoaXMuc3RhcnREYXRlICYmIHRoaXMuZW5kRGF0ZSkge1xyXG4gICAgICB0aGlzLmRhdGVSYW5nZUNoYW5nZS5lbWl0KFt0aGlzLnN0YXJ0RGF0ZSwgdGhpcy5lbmREYXRlXSk7XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
// Human-readable JS keyboard codes, as in KeyboardEvent.key string values.
|
|
2
|
+
export var KeyboardKey;
|
|
3
|
+
(function (KeyboardKey) {
|
|
4
|
+
KeyboardKey["Down"] = "ArrowDown";
|
|
5
|
+
KeyboardKey["Up"] = "ArrowUp";
|
|
6
|
+
KeyboardKey["Left"] = "ArrowLeft";
|
|
7
|
+
KeyboardKey["Right"] = "ArrowRight";
|
|
8
|
+
KeyboardKey["Tab"] = "Tab";
|
|
9
|
+
KeyboardKey["Escape"] = "Escape";
|
|
10
|
+
KeyboardKey["Enter"] = "Enter";
|
|
11
|
+
KeyboardKey["Home"] = "Home";
|
|
12
|
+
KeyboardKey["End"] = "End";
|
|
13
|
+
KeyboardKey["Delete"] = "Delete";
|
|
14
|
+
KeyboardKey["Insert"] = "Insert";
|
|
15
|
+
KeyboardKey["ShiftLeft"] = "ShiftLeft";
|
|
16
|
+
KeyboardKey["ShiftRight"] = "ShiftRight";
|
|
17
|
+
KeyboardKey["Backspace"] = "Backspace";
|
|
18
|
+
KeyboardKey["SpaceBar"] = "Space";
|
|
19
|
+
KeyboardKey["Period"] = "Period";
|
|
20
|
+
KeyboardKey["DecimalPoint"] = "NumpadDecimal";
|
|
21
|
+
KeyboardKey["SemiColon"] = "Semicolon";
|
|
22
|
+
KeyboardKey["ControlRight"] = "ControlRight";
|
|
23
|
+
KeyboardKey["ControlLeft"] = "ControlLeft";
|
|
24
|
+
KeyboardKey["Comma"] = "Comma";
|
|
25
|
+
////Minus,
|
|
26
|
+
////MinusFireFox,
|
|
27
|
+
////Substract,
|
|
28
|
+
KeyboardKey["Zero"] = "Digit0";
|
|
29
|
+
KeyboardKey["One"] = "Digit1";
|
|
30
|
+
KeyboardKey["Two"] = "Digit2";
|
|
31
|
+
KeyboardKey["Three"] = "Digit3";
|
|
32
|
+
KeyboardKey["Four"] = "Digit4";
|
|
33
|
+
KeyboardKey["Five"] = "Digit5";
|
|
34
|
+
KeyboardKey["Six"] = "Digit6";
|
|
35
|
+
KeyboardKey["Seven"] = "Digit7";
|
|
36
|
+
KeyboardKey["Eight"] = "Digit8";
|
|
37
|
+
KeyboardKey["Nine"] = "Digit9";
|
|
38
|
+
KeyboardKey["NumpadZero"] = "Numpad0";
|
|
39
|
+
KeyboardKey["NumpadOne"] = "Numpad1";
|
|
40
|
+
KeyboardKey["NumpadTwo"] = "Numpad2";
|
|
41
|
+
KeyboardKey["NumpadThree"] = "Numpad3";
|
|
42
|
+
KeyboardKey["NumpadFour"] = "Numpad4";
|
|
43
|
+
KeyboardKey["NumpadFive"] = "Numpad5";
|
|
44
|
+
KeyboardKey["NumpadSix"] = "Numpad6";
|
|
45
|
+
KeyboardKey["NumpadSeven"] = "Numpad7";
|
|
46
|
+
KeyboardKey["NumpadEight"] = "Numpad8";
|
|
47
|
+
KeyboardKey["NumpadNine"] = "Numpad9";
|
|
48
|
+
KeyboardKey["A"] = "KeyA";
|
|
49
|
+
KeyboardKey["B"] = "KeyB";
|
|
50
|
+
KeyboardKey["C"] = "KeyC";
|
|
51
|
+
KeyboardKey["D"] = "KeyD";
|
|
52
|
+
KeyboardKey["E"] = "KeyE";
|
|
53
|
+
KeyboardKey["F"] = "KeyF";
|
|
54
|
+
KeyboardKey["G"] = "KeyG";
|
|
55
|
+
KeyboardKey["H"] = "KeyH";
|
|
56
|
+
KeyboardKey["I"] = "KeyI";
|
|
57
|
+
KeyboardKey["J"] = "KeyJ";
|
|
58
|
+
KeyboardKey["K"] = "KeyK";
|
|
59
|
+
KeyboardKey["L"] = "KeyL";
|
|
60
|
+
KeyboardKey["M"] = "KeyM";
|
|
61
|
+
KeyboardKey["N"] = "KeyN";
|
|
62
|
+
KeyboardKey["O"] = "KeyO";
|
|
63
|
+
KeyboardKey["P"] = "KeyP";
|
|
64
|
+
KeyboardKey["Q"] = "KeyQ";
|
|
65
|
+
KeyboardKey["R"] = "KeyR";
|
|
66
|
+
KeyboardKey["S"] = "KeyS";
|
|
67
|
+
KeyboardKey["T"] = "KeyT";
|
|
68
|
+
KeyboardKey["U"] = "KeyU";
|
|
69
|
+
KeyboardKey["V"] = "KeyV";
|
|
70
|
+
KeyboardKey["W"] = "KeyW";
|
|
71
|
+
KeyboardKey["X"] = "KeyX";
|
|
72
|
+
KeyboardKey["Y"] = "KeyY";
|
|
73
|
+
KeyboardKey["Z"] = "KeyZ";
|
|
74
|
+
})(KeyboardKey || (KeyboardKey = {}));
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2V5Ym9hcmQta2V5LmVudW0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlY29tcG9uZW50cy9zcmMvbGliL2NvcmUvZW51bS9rZXlib2FyZC1rZXkuZW51bS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSwyRUFBMkU7QUFDM0UsTUFBTSxDQUFOLElBQVksV0EyRVg7QUEzRUQsV0FBWSxXQUFXO0lBQ25CLGlDQUFrQixDQUFBO0lBQ2xCLDZCQUFjLENBQUE7SUFDZCxpQ0FBa0IsQ0FBQTtJQUNsQixtQ0FBb0IsQ0FBQTtJQUNwQiwwQkFBVyxDQUFBO0lBQ1gsZ0NBQWlCLENBQUE7SUFDakIsOEJBQWUsQ0FBQTtJQUNmLDRCQUFhLENBQUE7SUFDYiwwQkFBVyxDQUFBO0lBQ1gsZ0NBQWlCLENBQUE7SUFDakIsZ0NBQWlCLENBQUE7SUFDakIsc0NBQXVCLENBQUE7SUFDdkIsd0NBQXlCLENBQUE7SUFDekIsc0NBQXVCLENBQUE7SUFDdkIsaUNBQWtCLENBQUE7SUFDbEIsZ0NBQWlCLENBQUE7SUFDakIsNkNBQThCLENBQUE7SUFFOUIsc0NBQXVCLENBQUE7SUFDdkIsNENBQTZCLENBQUE7SUFDN0IsMENBQTJCLENBQUE7SUFDM0IsOEJBQWUsQ0FBQTtJQUVmLFVBQVU7SUFDVixpQkFBaUI7SUFDakIsY0FBYztJQUVkLDhCQUFlLENBQUE7SUFDZiw2QkFBYyxDQUFBO0lBQ2QsNkJBQWMsQ0FBQTtJQUNkLCtCQUFnQixDQUFBO0lBQ2hCLDhCQUFlLENBQUE7SUFDZiw4QkFBZSxDQUFBO0lBQ2YsNkJBQWMsQ0FBQTtJQUNkLCtCQUFnQixDQUFBO0lBQ2hCLCtCQUFnQixDQUFBO0lBQ2hCLDhCQUFlLENBQUE7SUFDZixxQ0FBc0IsQ0FBQTtJQUN0QixvQ0FBcUIsQ0FBQTtJQUNyQixvQ0FBcUIsQ0FBQTtJQUNyQixzQ0FBdUIsQ0FBQTtJQUN2QixxQ0FBc0IsQ0FBQTtJQUN0QixxQ0FBc0IsQ0FBQTtJQUN0QixvQ0FBcUIsQ0FBQTtJQUNyQixzQ0FBdUIsQ0FBQTtJQUN2QixzQ0FBdUIsQ0FBQTtJQUN2QixxQ0FBc0IsQ0FBQTtJQUV0Qix5QkFBVSxDQUFBO0lBQ1YseUJBQVUsQ0FBQTtJQUNWLHlCQUFVLENBQUE7SUFDVix5QkFBVSxDQUFBO0lBQ1YseUJBQVUsQ0FBQTtJQUNWLHlCQUFVLENBQUE7SUFDVix5QkFBVSxDQUFBO0lBQ1YseUJBQVUsQ0FBQTtJQUNWLHlCQUFVLENBQUE7SUFDVix5QkFBVSxDQUFBO0lBQ1YseUJBQVUsQ0FBQTtJQUNWLHlCQUFVLENBQUE7SUFDVix5QkFBVSxDQUFBO0lBQ1YseUJBQVUsQ0FBQTtJQUNWLHlCQUFVLENBQUE7SUFDVix5QkFBVSxDQUFBO0lBQ1YseUJBQVUsQ0FBQTtJQUNWLHlCQUFVLENBQUE7SUFDVix5QkFBVSxDQUFBO0lBQ1YseUJBQVUsQ0FBQTtJQUNWLHlCQUFVLENBQUE7SUFDVix5QkFBVSxDQUFBO0lBQ1YseUJBQVUsQ0FBQTtJQUNWLHlCQUFVLENBQUE7SUFDVix5QkFBVSxDQUFBO0lBQ1YseUJBQVUsQ0FBQTtBQUNkLENBQUMsRUEzRVcsV0FBVyxLQUFYLFdBQVcsUUEyRXRCIiwic291cmNlc0NvbnRlbnQiOlsiLy8gSHVtYW4tcmVhZGFibGUgSlMga2V5Ym9hcmQgY29kZXMsIGFzIGluIEtleWJvYXJkRXZlbnQua2V5IHN0cmluZyB2YWx1ZXMuXHJcbmV4cG9ydCBlbnVtIEtleWJvYXJkS2V5IHtcclxuICAgIERvd24gPSBcIkFycm93RG93blwiLFxyXG4gICAgVXAgPSBcIkFycm93VXBcIixcclxuICAgIExlZnQgPSBcIkFycm93TGVmdFwiLFxyXG4gICAgUmlnaHQgPSBcIkFycm93UmlnaHRcIixcclxuICAgIFRhYiA9IFwiVGFiXCIsXHJcbiAgICBFc2NhcGUgPSBcIkVzY2FwZVwiLFxyXG4gICAgRW50ZXIgPSBcIkVudGVyXCIsXHJcbiAgICBIb21lID0gXCJIb21lXCIsXHJcbiAgICBFbmQgPSBcIkVuZFwiLFxyXG4gICAgRGVsZXRlID0gXCJEZWxldGVcIixcclxuICAgIEluc2VydCA9IFwiSW5zZXJ0XCIsXHJcbiAgICBTaGlmdExlZnQgPSBcIlNoaWZ0TGVmdFwiLFxyXG4gICAgU2hpZnRSaWdodCA9IFwiU2hpZnRSaWdodFwiLFxyXG4gICAgQmFja3NwYWNlID0gXCJCYWNrc3BhY2VcIixcclxuICAgIFNwYWNlQmFyID0gXCJTcGFjZVwiLFxyXG4gICAgUGVyaW9kID0gXCJQZXJpb2RcIixcclxuICAgIERlY2ltYWxQb2ludCA9IFwiTnVtcGFkRGVjaW1hbFwiLFxyXG5cclxuICAgIFNlbWlDb2xvbiA9IFwiU2VtaWNvbG9uXCIsXHJcbiAgICBDb250cm9sUmlnaHQgPSBcIkNvbnRyb2xSaWdodFwiLFxyXG4gICAgQ29udHJvbExlZnQgPSBcIkNvbnRyb2xMZWZ0XCIsXHJcbiAgICBDb21tYSA9IFwiQ29tbWFcIixcclxuXHJcbiAgICAvLy8vTWludXMsXHJcbiAgICAvLy8vTWludXNGaXJlRm94LFxyXG4gICAgLy8vL1N1YnN0cmFjdCxcclxuXHJcbiAgICBaZXJvID0gXCJEaWdpdDBcIixcclxuICAgIE9uZSA9IFwiRGlnaXQxXCIsXHJcbiAgICBUd28gPSBcIkRpZ2l0MlwiLFxyXG4gICAgVGhyZWUgPSBcIkRpZ2l0M1wiLFxyXG4gICAgRm91ciA9IFwiRGlnaXQ0XCIsXHJcbiAgICBGaXZlID0gXCJEaWdpdDVcIixcclxuICAgIFNpeCA9IFwiRGlnaXQ2XCIsXHJcbiAgICBTZXZlbiA9IFwiRGlnaXQ3XCIsXHJcbiAgICBFaWdodCA9IFwiRGlnaXQ4XCIsXHJcbiAgICBOaW5lID0gXCJEaWdpdDlcIixcclxuICAgIE51bXBhZFplcm8gPSBcIk51bXBhZDBcIixcclxuICAgIE51bXBhZE9uZSA9IFwiTnVtcGFkMVwiLFxyXG4gICAgTnVtcGFkVHdvID0gXCJOdW1wYWQyXCIsXHJcbiAgICBOdW1wYWRUaHJlZSA9IFwiTnVtcGFkM1wiLFxyXG4gICAgTnVtcGFkRm91ciA9IFwiTnVtcGFkNFwiLFxyXG4gICAgTnVtcGFkRml2ZSA9IFwiTnVtcGFkNVwiLFxyXG4gICAgTnVtcGFkU2l4ID0gXCJOdW1wYWQ2XCIsXHJcbiAgICBOdW1wYWRTZXZlbiA9IFwiTnVtcGFkN1wiLFxyXG4gICAgTnVtcGFkRWlnaHQgPSBcIk51bXBhZDhcIixcclxuICAgIE51bXBhZE5pbmUgPSBcIk51bXBhZDlcIixcclxuXHJcbiAgICBBID0gXCJLZXlBXCIsXHJcbiAgICBCID0gXCJLZXlCXCIsXHJcbiAgICBDID0gXCJLZXlDXCIsXHJcbiAgICBEID0gXCJLZXlEXCIsXHJcbiAgICBFID0gXCJLZXlFXCIsXHJcbiAgICBGID0gXCJLZXlGXCIsXHJcbiAgICBHID0gXCJLZXlHXCIsXHJcbiAgICBIID0gXCJLZXlIXCIsXHJcbiAgICBJID0gXCJLZXlJXCIsXHJcbiAgICBKID0gXCJLZXlKXCIsXHJcbiAgICBLID0gXCJLZXlLXCIsXHJcbiAgICBMID0gXCJLZXlMXCIsXHJcbiAgICBNID0gXCJLZXlNXCIsXHJcbiAgICBOID0gXCJLZXlOXCIsXHJcbiAgICBPID0gXCJLZXlPXCIsXHJcbiAgICBQID0gXCJLZXlQXCIsXHJcbiAgICBRID0gXCJLZXlRXCIsXHJcbiAgICBSID0gXCJLZXlSXCIsXHJcbiAgICBTID0gXCJLZXlTXCIsXHJcbiAgICBUID0gXCJLZXlUXCIsXHJcbiAgICBVID0gXCJLZXlVXCIsXHJcbiAgICBWID0gXCJLZXlWXCIsXHJcbiAgICBXID0gXCJLZXlXXCIsXHJcbiAgICBYID0gXCJLZXlYXCIsXHJcbiAgICBZID0gXCJLZXlZXCIsXHJcbiAgICBaID0gXCJLZXlaXCIsXHJcbn1cclxuIl19
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import { Injectable, NgZone } from "@angular/core";
|
|
2
|
+
import { EventUtils } from "../../core/utils/event-utils";
|
|
3
|
+
import { KeyboardKey } from "../../core/enum/keyboard-key.enum";
|
|
4
|
+
import { ArrayUtils } from "../../core/utils/array-utils";
|
|
5
|
+
export class ClickOutsideMasterService {
|
|
6
|
+
constructor(_ngZone) {
|
|
7
|
+
this._ngZone = _ngZone;
|
|
8
|
+
this._clickOutsideRefs = [];
|
|
9
|
+
this.onClick = (event) => {
|
|
10
|
+
this._currentClick = event;
|
|
11
|
+
const first = this._clickOutsideRefs[0];
|
|
12
|
+
const targets = this._clickOutsideRefs.filter(co => co.alwaysTrigger);
|
|
13
|
+
if (first) {
|
|
14
|
+
targets.push(first);
|
|
15
|
+
}
|
|
16
|
+
setTimeout(() => {
|
|
17
|
+
targets.forEach(clickOutside => this.checkEmit(clickOutside, event));
|
|
18
|
+
});
|
|
19
|
+
};
|
|
20
|
+
this.onKeyDown = (event) => {
|
|
21
|
+
if (event.key === KeyboardKey.Escape) {
|
|
22
|
+
const first = this._clickOutsideRefs[0];
|
|
23
|
+
if (first) {
|
|
24
|
+
this.checkEmit(first, event, true);
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
};
|
|
28
|
+
document.addEventListener('click', this.onClick, true);
|
|
29
|
+
window.addEventListener('keydown', this.onKeyDown, EventUtils.passiveBubble);
|
|
30
|
+
}
|
|
31
|
+
get currentClick() {
|
|
32
|
+
return this._currentClick;
|
|
33
|
+
}
|
|
34
|
+
ngOnDestroy() {
|
|
35
|
+
document.removeEventListener('click', this.onClick, true);
|
|
36
|
+
window.removeEventListener('keydown', this.onKeyDown, EventUtils.passiveBubble);
|
|
37
|
+
}
|
|
38
|
+
checkEmit(clickOutside, event, force) {
|
|
39
|
+
if (clickOutside && (clickOutside.currentClick !== this.currentClick || force) && this._clickOutsideRefs.indexOf(clickOutside) !== -1) {
|
|
40
|
+
this._ngZone.run(() => clickOutside.clickOutside.emit(event));
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
addClickOutside(clickOutside) {
|
|
44
|
+
this.removeClickOutside(clickOutside);
|
|
45
|
+
this._clickOutsideRefs.unshift(clickOutside);
|
|
46
|
+
}
|
|
47
|
+
removeClickOutside(clickOutside) {
|
|
48
|
+
ArrayUtils.RemoveElement(clickOutside, this._clickOutsideRefs);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
ClickOutsideMasterService.decorators = [
|
|
52
|
+
{ type: Injectable }
|
|
53
|
+
];
|
|
54
|
+
ClickOutsideMasterService.ctorParameters = () => [
|
|
55
|
+
{ type: NgZone }
|
|
56
|
+
];
|
|
57
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xpY2stb3V0c2lkZS1tYXN0ZXIuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmVjb21wb25lbnRzL3NyYy9saWIvZGlyZWN0aXZlcy9jbGlja291dHNpZGUvY2xpY2stb3V0c2lkZS1tYXN0ZXIuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsVUFBVSxFQUFFLE1BQU0sRUFBWSxNQUFNLGVBQWUsQ0FBQztBQUU1RCxPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0sOEJBQThCLENBQUM7QUFDeEQsT0FBTyxFQUFDLFdBQVcsRUFBQyxNQUFNLG1DQUFtQyxDQUFDO0FBQzlELE9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSw4QkFBOEIsQ0FBQztBQUl4RCxNQUFNLE9BQU8seUJBQXlCO0lBVWxDLFlBQTZCLE9BQWU7UUFBZixZQUFPLEdBQVAsT0FBTyxDQUFRO1FBSnBDLHNCQUFpQixHQUE0QixFQUFFLENBQUM7UUFjakQsWUFBTyxHQUFHLENBQUMsS0FBaUIsRUFBUSxFQUFFO1lBQ3pDLElBQUksQ0FBQyxhQUFhLEdBQUcsS0FBSyxDQUFDO1lBQzNCLE1BQU0sS0FBSyxHQUEwQixJQUFJLENBQUMsaUJBQWlCLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDL0QsTUFBTSxPQUFPLEdBQTRCLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsYUFBYSxDQUFDLENBQUM7WUFDL0YsSUFBSSxLQUFLLEVBQUU7Z0JBQ1AsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQzthQUN2QjtZQUNELFVBQVUsQ0FBQyxHQUFHLEVBQUU7Z0JBQ1osT0FBTyxDQUFDLE9BQU8sQ0FBQyxZQUFZLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsWUFBWSxFQUFFLEtBQUssQ0FBQyxDQUFDLENBQUM7WUFDekUsQ0FBQyxDQUFDLENBQUM7UUFDUCxDQUFDLENBQUE7UUFRTSxjQUFTLEdBQUcsQ0FBQyxLQUFvQixFQUFRLEVBQUU7WUFDOUMsSUFBSSxLQUFLLENBQUMsR0FBRyxLQUFLLFdBQVcsQ0FBQyxNQUFNLEVBQUU7Z0JBQ2xDLE1BQU0sS0FBSyxHQUEwQixJQUFJLENBQUMsaUJBQWlCLENBQUMsQ0FBQyxDQUFDLENBQUM7Z0JBQy9ELElBQUksS0FBSyxFQUFFO29CQUNQLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxFQUFFLEtBQUssRUFBRSxJQUFJLENBQUMsQ0FBQztpQkFDdEM7YUFDSjtRQUNMLENBQUMsQ0FBQTtRQWxDRyxRQUFRLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxFQUFFLElBQUksQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFDdkQsTUFBTSxDQUFDLGdCQUFnQixDQUFDLFNBQVMsRUFBRSxJQUFJLENBQUMsU0FBUyxFQUFFLFVBQVUsQ0FBQyxhQUFhLENBQUMsQ0FBQztJQUNqRixDQUFDO0lBWEQsSUFBVyxZQUFZO1FBQ25CLE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBQztJQUM5QixDQUFDO0lBV0QsV0FBVztRQUNQLFFBQVEsQ0FBQyxtQkFBbUIsQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLE9BQU8sRUFBRSxJQUFJLENBQUMsQ0FBQztRQUMxRCxNQUFNLENBQUMsbUJBQW1CLENBQUMsU0FBUyxFQUFFLElBQUksQ0FBQyxTQUFTLEVBQUUsVUFBVSxDQUFDLGFBQWEsQ0FBQyxDQUFDO0lBQ3BGLENBQUM7SUFjTSxTQUFTLENBQUMsWUFBbUMsRUFBRSxLQUFZLEVBQUUsS0FBZTtRQUMvRSxJQUFJLFlBQVksSUFBSSxDQUFDLFlBQVksQ0FBQyxZQUFZLEtBQUssSUFBSSxDQUFDLFlBQVksSUFBSSxLQUFLLENBQUMsSUFBSSxJQUFJLENBQUMsaUJBQWlCLENBQUMsT0FBTyxDQUFDLFlBQVksQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUFFO1lBQ25JLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDLFlBQVksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7U0FDakU7SUFDTCxDQUFDO0lBV00sZUFBZSxDQUFDLFlBQW1DO1FBQ3RELElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxZQUFZLENBQUMsQ0FBQztRQUN0QyxJQUFJLENBQUMsaUJBQWlCLENBQUMsT0FBTyxDQUFDLFlBQVksQ0FBQyxDQUFDO0lBQ2pELENBQUM7SUFFTSxrQkFBa0IsQ0FBQyxZQUFtQztRQUN6RCxVQUFVLENBQUMsYUFBYSxDQUFDLFlBQVksRUFBRSxJQUFJLENBQUMsaUJBQWlCLENBQUMsQ0FBQztJQUNuRSxDQUFDOzs7WUF2REosVUFBVTs7O1lBUFMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7SW5qZWN0YWJsZSwgTmdab25lLCBPbkRlc3Ryb3l9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7Q2xpY2tPdXRzaWRlRGlyZWN0aXZlfSBmcm9tIFwiLi9jbGljay1vdXRzaWRlLmRpcmVjdGl2ZVwiO1xyXG5pbXBvcnQge0V2ZW50VXRpbHN9IGZyb20gXCIuLi8uLi9jb3JlL3V0aWxzL2V2ZW50LXV0aWxzXCI7XHJcbmltcG9ydCB7S2V5Ym9hcmRLZXl9IGZyb20gXCIuLi8uLi9jb3JlL2VudW0va2V5Ym9hcmQta2V5LmVudW1cIjtcclxuaW1wb3J0IHtBcnJheVV0aWxzfSBmcm9tIFwiLi4vLi4vY29yZS91dGlscy9hcnJheS11dGlsc1wiO1xyXG5cclxuXHJcbkBJbmplY3RhYmxlKClcclxuZXhwb3J0IGNsYXNzIENsaWNrT3V0c2lkZU1hc3RlclNlcnZpY2UgaW1wbGVtZW50cyBPbkRlc3Ryb3kge1xyXG5cclxuICAgIHB1YmxpYyBnZXQgY3VycmVudENsaWNrKCk6IE1vdXNlRXZlbnQge1xyXG4gICAgICAgIHJldHVybiB0aGlzLl9jdXJyZW50Q2xpY2s7XHJcbiAgICB9XHJcblxyXG4gICAgcHJpdmF0ZSBfY2xpY2tPdXRzaWRlUmVmczogQ2xpY2tPdXRzaWRlRGlyZWN0aXZlW10gPSBbXTtcclxuXHJcbiAgICBwcml2YXRlIF9jdXJyZW50Q2xpY2s6IE1vdXNlRXZlbnQ7XHJcblxyXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSByZWFkb25seSBfbmdab25lOiBOZ1pvbmUpIHtcclxuICAgICAgICBkb2N1bWVudC5hZGRFdmVudExpc3RlbmVyKCdjbGljaycsIHRoaXMub25DbGljaywgdHJ1ZSk7XHJcbiAgICAgICAgd2luZG93LmFkZEV2ZW50TGlzdGVuZXIoJ2tleWRvd24nLCB0aGlzLm9uS2V5RG93biwgRXZlbnRVdGlscy5wYXNzaXZlQnViYmxlKTtcclxuICAgIH1cclxuXHJcbiAgICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcclxuICAgICAgICBkb2N1bWVudC5yZW1vdmVFdmVudExpc3RlbmVyKCdjbGljaycsIHRoaXMub25DbGljaywgdHJ1ZSk7XHJcbiAgICAgICAgd2luZG93LnJlbW92ZUV2ZW50TGlzdGVuZXIoJ2tleWRvd24nLCB0aGlzLm9uS2V5RG93biwgRXZlbnRVdGlscy5wYXNzaXZlQnViYmxlKTtcclxuICAgIH1cclxuXHJcbiAgICBwdWJsaWMgb25DbGljayA9IChldmVudDogTW91c2VFdmVudCk6IHZvaWQgPT4ge1xyXG4gICAgICAgIHRoaXMuX2N1cnJlbnRDbGljayA9IGV2ZW50O1xyXG4gICAgICAgIGNvbnN0IGZpcnN0OiBDbGlja091dHNpZGVEaXJlY3RpdmUgPSB0aGlzLl9jbGlja091dHNpZGVSZWZzWzBdO1xyXG4gICAgICAgIGNvbnN0IHRhcmdldHM6IENsaWNrT3V0c2lkZURpcmVjdGl2ZVtdID0gdGhpcy5fY2xpY2tPdXRzaWRlUmVmcy5maWx0ZXIoY28gPT4gY28uYWx3YXlzVHJpZ2dlcik7XHJcbiAgICAgICAgaWYgKGZpcnN0KSB7XHJcbiAgICAgICAgICAgIHRhcmdldHMucHVzaChmaXJzdCk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIHNldFRpbWVvdXQoKCkgPT4ge1xyXG4gICAgICAgICAgICB0YXJnZXRzLmZvckVhY2goY2xpY2tPdXRzaWRlID0+IHRoaXMuY2hlY2tFbWl0KGNsaWNrT3V0c2lkZSwgZXZlbnQpKTtcclxuICAgICAgICB9KTtcclxuICAgIH1cclxuXHJcbiAgICBwdWJsaWMgY2hlY2tFbWl0KGNsaWNrT3V0c2lkZTogQ2xpY2tPdXRzaWRlRGlyZWN0aXZlLCBldmVudDogRXZlbnQsIGZvcmNlPzogYm9vbGVhbik6IHZvaWQge1xyXG4gICAgICAgIGlmIChjbGlja091dHNpZGUgJiYgKGNsaWNrT3V0c2lkZS5jdXJyZW50Q2xpY2sgIT09IHRoaXMuY3VycmVudENsaWNrIHx8IGZvcmNlKSAmJiB0aGlzLl9jbGlja091dHNpZGVSZWZzLmluZGV4T2YoY2xpY2tPdXRzaWRlKSAhPT0gLTEpIHtcclxuICAgICAgICAgICAgdGhpcy5fbmdab25lLnJ1bigoKSA9PiBjbGlja091dHNpZGUuY2xpY2tPdXRzaWRlLmVtaXQoZXZlbnQpKTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcblxyXG4gICAgcHVibGljIG9uS2V5RG93biA9IChldmVudDogS2V5Ym9hcmRFdmVudCk6IHZvaWQgPT4ge1xyXG4gICAgICAgIGlmIChldmVudC5rZXkgPT09IEtleWJvYXJkS2V5LkVzY2FwZSkge1xyXG4gICAgICAgICAgICBjb25zdCBmaXJzdDogQ2xpY2tPdXRzaWRlRGlyZWN0aXZlID0gdGhpcy5fY2xpY2tPdXRzaWRlUmVmc1swXTtcclxuICAgICAgICAgICAgaWYgKGZpcnN0KSB7XHJcbiAgICAgICAgICAgICAgICB0aGlzLmNoZWNrRW1pdChmaXJzdCwgZXZlbnQsIHRydWUpO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG5cclxuICAgIHB1YmxpYyBhZGRDbGlja091dHNpZGUoY2xpY2tPdXRzaWRlOiBDbGlja091dHNpZGVEaXJlY3RpdmUpOiB2b2lkIHtcclxuICAgICAgICB0aGlzLnJlbW92ZUNsaWNrT3V0c2lkZShjbGlja091dHNpZGUpO1xyXG4gICAgICAgIHRoaXMuX2NsaWNrT3V0c2lkZVJlZnMudW5zaGlmdChjbGlja091dHNpZGUpO1xyXG4gICAgfVxyXG5cclxuICAgIHB1YmxpYyByZW1vdmVDbGlja091dHNpZGUoY2xpY2tPdXRzaWRlOiBDbGlja091dHNpZGVEaXJlY3RpdmUpOiB2b2lkIHtcclxuICAgICAgICBBcnJheVV0aWxzLlJlbW92ZUVsZW1lbnQoY2xpY2tPdXRzaWRlLCB0aGlzLl9jbGlja091dHNpZGVSZWZzKTtcclxuICAgIH1cclxufVxyXG4iXX0=
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { Directive, ElementRef, EventEmitter, Input, NgZone, Output } from "@angular/core";
|
|
3
|
+
import { EventUtils } from "../../core/utils/event-utils";
|
|
4
|
+
import { ClickOutsideMasterService } from "./click-outside-master.service";
|
|
5
|
+
import { InputBoolean } from "../../core/decorator/input-boolean.decorator";
|
|
6
|
+
export class ClickOutsideDirective {
|
|
7
|
+
constructor(elementRef, _ngZone, _master) {
|
|
8
|
+
this.elementRef = elementRef;
|
|
9
|
+
this._ngZone = _ngZone;
|
|
10
|
+
this._master = _master;
|
|
11
|
+
this.clickOutside = new EventEmitter();
|
|
12
|
+
this._enabled = true;
|
|
13
|
+
this._initialized = false;
|
|
14
|
+
this.onClick = (event) => {
|
|
15
|
+
if (this._enabled) {
|
|
16
|
+
this._currentClick = event;
|
|
17
|
+
}
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
get currentClick() {
|
|
21
|
+
return this._currentClick;
|
|
22
|
+
}
|
|
23
|
+
set enabled(enabled) {
|
|
24
|
+
enabled = enabled === undefined || enabled;
|
|
25
|
+
// noinspection SuspiciousTypeOfGuard
|
|
26
|
+
if (typeof enabled === 'boolean' && this._enabled !== enabled) {
|
|
27
|
+
this._enabled = enabled;
|
|
28
|
+
if (this._initialized) {
|
|
29
|
+
this._enabled ? this._master.addClickOutside(this) : this._master.removeClickOutside(this);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
ngAfterViewInit() {
|
|
34
|
+
setTimeout(() => {
|
|
35
|
+
this._ngZone.runOutsideAngular(() => {
|
|
36
|
+
if (this.elementRef && this.elementRef.nativeElement) {
|
|
37
|
+
this.elementRef.nativeElement.addEventListener('click', this.onClick, EventUtils.passiveCapture);
|
|
38
|
+
if (this._enabled) {
|
|
39
|
+
this._master.addClickOutside(this);
|
|
40
|
+
}
|
|
41
|
+
this._initialized = true;
|
|
42
|
+
}
|
|
43
|
+
});
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
ngOnDestroy() {
|
|
47
|
+
this._master.removeClickOutside(this);
|
|
48
|
+
this.elementRef.nativeElement.removeEventListener('click', this.onClick, EventUtils.passiveCapture);
|
|
49
|
+
this.elementRef = undefined;
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
ClickOutsideDirective.decorators = [
|
|
53
|
+
{ type: Directive, args: [{
|
|
54
|
+
selector: "[clickOutside]",
|
|
55
|
+
exportAs: 'clickOutside'
|
|
56
|
+
},] }
|
|
57
|
+
];
|
|
58
|
+
ClickOutsideDirective.ctorParameters = () => [
|
|
59
|
+
{ type: ElementRef },
|
|
60
|
+
{ type: NgZone },
|
|
61
|
+
{ type: ClickOutsideMasterService }
|
|
62
|
+
];
|
|
63
|
+
ClickOutsideDirective.propDecorators = {
|
|
64
|
+
enabled: [{ type: Input, args: ["clickOutside",] }],
|
|
65
|
+
alwaysTrigger: [{ type: Input }],
|
|
66
|
+
clickOutside: [{ type: Output }]
|
|
67
|
+
};
|
|
68
|
+
__decorate([
|
|
69
|
+
InputBoolean()
|
|
70
|
+
], ClickOutsideDirective.prototype, "alwaysTrigger", void 0);
|
|
71
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xpY2stb3V0c2lkZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlY29tcG9uZW50cy9zcmMvbGliL2RpcmVjdGl2ZXMvY2xpY2tvdXRzaWRlL2NsaWNrLW91dHNpZGUuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQWdCLFNBQVMsRUFBRSxVQUFVLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQWEsTUFBTSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ25ILE9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSw4QkFBOEIsQ0FBQztBQUN4RCxPQUFPLEVBQUMseUJBQXlCLEVBQUMsTUFBTSxnQ0FBZ0MsQ0FBQztBQUN6RSxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0sOENBQThDLENBQUM7QUFNMUUsTUFBTSxPQUFPLHFCQUFxQjtJQStCOUIsWUFDVyxVQUFzQixFQUNyQixPQUFlLEVBQ2YsT0FBa0M7UUFGbkMsZUFBVSxHQUFWLFVBQVUsQ0FBWTtRQUNyQixZQUFPLEdBQVAsT0FBTyxDQUFRO1FBQ2YsWUFBTyxHQUFQLE9BQU8sQ0FBMkI7UUFYOUIsaUJBQVksR0FBd0IsSUFBSSxZQUFZLEVBQVMsQ0FBQztRQUl0RSxhQUFRLEdBQVksSUFBSSxDQUFDO1FBRXpCLGlCQUFZLEdBQVksS0FBSyxDQUFDO1FBNEIvQixZQUFPLEdBQUcsQ0FBQyxLQUFpQixFQUFRLEVBQUU7WUFDekMsSUFBSSxJQUFJLENBQUMsUUFBUSxFQUFFO2dCQUNmLElBQUksQ0FBQyxhQUFhLEdBQUcsS0FBSyxDQUFDO2FBQzlCO1FBQ0wsQ0FBQyxDQUFDO0lBMUJDLENBQUM7SUFqQ0osSUFBVyxZQUFZO1FBQ25CLE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBQztJQUM5QixDQUFDO0lBRUQsSUFDVyxPQUFPLENBQUMsT0FBZ0I7UUFDL0IsT0FBTyxHQUFHLE9BQU8sS0FBSyxTQUFTLElBQUksT0FBTyxDQUFDO1FBQzNDLHFDQUFxQztRQUNyQyxJQUFJLE9BQU8sT0FBTyxLQUFLLFNBQVMsSUFBSSxJQUFJLENBQUMsUUFBUSxLQUFLLE9BQU8sRUFBRTtZQUMzRCxJQUFJLENBQUMsUUFBUSxHQUFHLE9BQU8sQ0FBQztZQUN4QixJQUFJLElBQUksQ0FBQyxZQUFZLEVBQUU7Z0JBQ25CLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxDQUFDO2FBQzlGO1NBQ0o7SUFDTCxDQUFDO0lBcUJELGVBQWU7UUFDWCxVQUFVLENBQUMsR0FBRyxFQUFFO1lBQ1osSUFBSSxDQUFDLE9BQU8sQ0FBQyxpQkFBaUIsQ0FBQyxHQUFHLEVBQUU7Z0JBQ2hDLElBQUksSUFBSSxDQUFDLFVBQVUsSUFBSSxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsRUFBRTtvQkFDbEQsSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxFQUFFLElBQUksQ0FBQyxPQUFPLEVBQUUsVUFBVSxDQUFDLGNBQWMsQ0FBQyxDQUFDO29CQUNqRyxJQUFJLElBQUksQ0FBQyxRQUFRLEVBQUU7d0JBQ2YsSUFBSSxDQUFDLE9BQU8sQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLENBQUM7cUJBQ3RDO29CQUNELElBQUksQ0FBQyxZQUFZLEdBQUcsSUFBSSxDQUFDO2lCQUM1QjtZQUNMLENBQUMsQ0FBQyxDQUFDO1FBQ1AsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRUQsV0FBVztRQUNQLElBQUksQ0FBQyxPQUFPLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDdEMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUMsbUJBQW1CLENBQUMsT0FBTyxFQUFFLElBQUksQ0FBQyxPQUFPLEVBQUUsVUFBVSxDQUFDLGNBQWMsQ0FBQyxDQUFDO1FBQ3BHLElBQUksQ0FBQyxVQUFVLEdBQUcsU0FBUyxDQUFDO0lBQ2hDLENBQUM7OztZQTNESixTQUFTLFNBQUM7Z0JBQ1AsUUFBUSxFQUFFLGdCQUFnQjtnQkFDMUIsUUFBUSxFQUFFLGNBQWM7YUFDM0I7OztZQVJpQyxVQUFVO1lBQXVCLE1BQU07WUFFakUseUJBQXlCOzs7c0JBYTVCLEtBQUssU0FBQyxjQUFjOzRCQWFwQixLQUFLOzJCQUdMLE1BQU07O0FBRlA7SUFGQyxZQUFZLEVBQUU7NERBRWUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0FmdGVyVmlld0luaXQsIERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgTmdab25lLCBPbkRlc3Ryb3ksIE91dHB1dH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHtFdmVudFV0aWxzfSBmcm9tIFwiLi4vLi4vY29yZS91dGlscy9ldmVudC11dGlsc1wiO1xyXG5pbXBvcnQge0NsaWNrT3V0c2lkZU1hc3RlclNlcnZpY2V9IGZyb20gXCIuL2NsaWNrLW91dHNpZGUtbWFzdGVyLnNlcnZpY2VcIjtcclxuaW1wb3J0IHtJbnB1dEJvb2xlYW59IGZyb20gXCIuLi8uLi9jb3JlL2RlY29yYXRvci9pbnB1dC1ib29sZWFuLmRlY29yYXRvclwiO1xyXG5cclxuQERpcmVjdGl2ZSh7XHJcbiAgICBzZWxlY3RvcjogXCJbY2xpY2tPdXRzaWRlXVwiLFxyXG4gICAgZXhwb3J0QXM6ICdjbGlja091dHNpZGUnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDbGlja091dHNpZGVEaXJlY3RpdmUgaW1wbGVtZW50cyBPbkRlc3Ryb3ksIEFmdGVyVmlld0luaXQge1xyXG5cclxuICAgIHB1YmxpYyBnZXQgY3VycmVudENsaWNrKCk6IE1vdXNlRXZlbnQge1xyXG4gICAgICAgIHJldHVybiB0aGlzLl9jdXJyZW50Q2xpY2s7XHJcbiAgICB9XHJcblxyXG4gICAgQElucHV0KFwiY2xpY2tPdXRzaWRlXCIpXHJcbiAgICBwdWJsaWMgc2V0IGVuYWJsZWQoZW5hYmxlZDogYm9vbGVhbikge1xyXG4gICAgICAgIGVuYWJsZWQgPSBlbmFibGVkID09PSB1bmRlZmluZWQgfHwgZW5hYmxlZDtcclxuICAgICAgICAvLyBub2luc3BlY3Rpb24gU3VzcGljaW91c1R5cGVPZkd1YXJkXHJcbiAgICAgICAgaWYgKHR5cGVvZiBlbmFibGVkID09PSAnYm9vbGVhbicgJiYgdGhpcy5fZW5hYmxlZCAhPT0gZW5hYmxlZCkge1xyXG4gICAgICAgICAgICB0aGlzLl9lbmFibGVkID0gZW5hYmxlZDtcclxuICAgICAgICAgICAgaWYgKHRoaXMuX2luaXRpYWxpemVkKSB7XHJcbiAgICAgICAgICAgICAgICB0aGlzLl9lbmFibGVkID8gdGhpcy5fbWFzdGVyLmFkZENsaWNrT3V0c2lkZSh0aGlzKSA6IHRoaXMuX21hc3Rlci5yZW1vdmVDbGlja091dHNpZGUodGhpcyk7XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICB9XHJcbiAgICB9XHJcblxyXG4gICAgQElucHV0Qm9vbGVhbigpXHJcbiAgICBASW5wdXQoKVxyXG4gICAgcHVibGljIGFsd2F5c1RyaWdnZXI6IGJvb2xlYW47XHJcblxyXG4gICAgQE91dHB1dCgpXHJcbiAgICBwdWJsaWMgcmVhZG9ubHkgY2xpY2tPdXRzaWRlOiBFdmVudEVtaXR0ZXI8RXZlbnQ+ID0gbmV3IEV2ZW50RW1pdHRlcjxFdmVudD4oKTtcclxuXHJcbiAgICBwcml2YXRlIF9jdXJyZW50Q2xpY2s6IE1vdXNlRXZlbnQ7XHJcblxyXG4gICAgcHJpdmF0ZSBfZW5hYmxlZDogYm9vbGVhbiA9IHRydWU7XHJcblxyXG4gICAgcHJpdmF0ZSBfaW5pdGlhbGl6ZWQ6IGJvb2xlYW4gPSBmYWxzZTtcclxuXHJcbiAgICBjb25zdHJ1Y3RvcihcclxuICAgICAgICBwdWJsaWMgZWxlbWVudFJlZjogRWxlbWVudFJlZixcclxuICAgICAgICBwcml2YXRlIF9uZ1pvbmU6IE5nWm9uZSxcclxuICAgICAgICBwcml2YXRlIF9tYXN0ZXI6IENsaWNrT3V0c2lkZU1hc3RlclNlcnZpY2VcclxuICAgICkge31cclxuXHJcbiAgICBuZ0FmdGVyVmlld0luaXQoKTogdm9pZCB7XHJcbiAgICAgICAgc2V0VGltZW91dCgoKSA9PiB7XHJcbiAgICAgICAgICAgIHRoaXMuX25nWm9uZS5ydW5PdXRzaWRlQW5ndWxhcigoKSA9PiB7XHJcbiAgICAgICAgICAgICAgICBpZiAodGhpcy5lbGVtZW50UmVmICYmIHRoaXMuZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50KSB7XHJcbiAgICAgICAgICAgICAgICAgICAgdGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQuYWRkRXZlbnRMaXN0ZW5lcignY2xpY2snLCB0aGlzLm9uQ2xpY2ssIEV2ZW50VXRpbHMucGFzc2l2ZUNhcHR1cmUpO1xyXG4gICAgICAgICAgICAgICAgICAgIGlmICh0aGlzLl9lbmFibGVkKSB7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIHRoaXMuX21hc3Rlci5hZGRDbGlja091dHNpZGUodGhpcyk7XHJcbiAgICAgICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICAgICAgICAgIHRoaXMuX2luaXRpYWxpemVkID0gdHJ1ZTtcclxuICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgfSk7XHJcbiAgICAgICAgfSk7XHJcbiAgICB9XHJcblxyXG4gICAgbmdPbkRlc3Ryb3koKTogdm9pZCB7XHJcbiAgICAgICAgdGhpcy5fbWFzdGVyLnJlbW92ZUNsaWNrT3V0c2lkZSh0aGlzKTtcclxuICAgICAgICB0aGlzLmVsZW1lbnRSZWYubmF0aXZlRWxlbWVudC5yZW1vdmVFdmVudExpc3RlbmVyKCdjbGljaycsIHRoaXMub25DbGljaywgRXZlbnRVdGlscy5wYXNzaXZlQ2FwdHVyZSk7XHJcbiAgICAgICAgdGhpcy5lbGVtZW50UmVmID0gdW5kZWZpbmVkO1xyXG4gICAgfVxyXG5cclxuICAgIHB1YmxpYyBvbkNsaWNrID0gKGV2ZW50OiBNb3VzZUV2ZW50KTogdm9pZCA9PiB7XHJcbiAgICAgICAgaWYgKHRoaXMuX2VuYWJsZWQpIHtcclxuICAgICAgICAgICAgdGhpcy5fY3VycmVudENsaWNrID0gZXZlbnQ7XHJcbiAgICAgICAgfVxyXG4gICAgfTtcclxufVxyXG4iXX0=
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { NgModule } from "@angular/core";
|
|
2
|
+
import { ClickOutsideDirective } from "./click-outside.directive";
|
|
3
|
+
import { ClickOutsideMasterService } from "./click-outside-master.service";
|
|
4
|
+
export class ClickoutsideModule {
|
|
5
|
+
}
|
|
6
|
+
ClickoutsideModule.decorators = [
|
|
7
|
+
{ type: NgModule, args: [{
|
|
8
|
+
declarations: [
|
|
9
|
+
ClickOutsideDirective
|
|
10
|
+
],
|
|
11
|
+
providers: [
|
|
12
|
+
ClickOutsideMasterService
|
|
13
|
+
],
|
|
14
|
+
exports: [
|
|
15
|
+
ClickOutsideDirective
|
|
16
|
+
]
|
|
17
|
+
},] }
|
|
18
|
+
];
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xpY2tvdXRzaWRlLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmVjb21wb25lbnRzL3NyYy9saWIvZGlyZWN0aXZlcy9jbGlja291dHNpZGUvY2xpY2tvdXRzaWRlLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxxQkFBcUIsRUFBQyxNQUFNLDJCQUEyQixDQUFDO0FBQ2hFLE9BQU8sRUFBQyx5QkFBeUIsRUFBQyxNQUFNLGdDQUFnQyxDQUFDO0FBYXpFLE1BQU0sT0FBTyxrQkFBa0I7OztZQVg5QixRQUFRLFNBQUM7Z0JBQ04sWUFBWSxFQUFFO29CQUNWLHFCQUFxQjtpQkFDeEI7Z0JBQ0QsU0FBUyxFQUFFO29CQUNQLHlCQUF5QjtpQkFDNUI7Z0JBQ0QsT0FBTyxFQUFFO29CQUNMLHFCQUFxQjtpQkFDeEI7YUFDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TmdNb2R1bGV9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7Q2xpY2tPdXRzaWRlRGlyZWN0aXZlfSBmcm9tIFwiLi9jbGljay1vdXRzaWRlLmRpcmVjdGl2ZVwiO1xyXG5pbXBvcnQge0NsaWNrT3V0c2lkZU1hc3RlclNlcnZpY2V9IGZyb20gXCIuL2NsaWNrLW91dHNpZGUtbWFzdGVyLnNlcnZpY2VcIjtcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgICBkZWNsYXJhdGlvbnM6IFtcclxuICAgICAgICBDbGlja091dHNpZGVEaXJlY3RpdmVcclxuICAgIF0sXHJcbiAgICBwcm92aWRlcnM6IFtcclxuICAgICAgICBDbGlja091dHNpZGVNYXN0ZXJTZXJ2aWNlXHJcbiAgICBdLFxyXG4gICAgZXhwb3J0czogW1xyXG4gICAgICAgIENsaWNrT3V0c2lkZURpcmVjdGl2ZVxyXG4gICAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgQ2xpY2tvdXRzaWRlTW9kdWxlIHtcclxufSJdfQ==
|