@fundamental-ngx/cdk 0.54.2-rc.9 → 0.55.0-rc.0
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/fesm2022/fundamental-ngx-cdk-data-source.mjs +7 -7
- package/fesm2022/fundamental-ngx-cdk-forms.mjs +21 -14
- package/fesm2022/fundamental-ngx-cdk-forms.mjs.map +1 -1
- package/fesm2022/fundamental-ngx-cdk-utils.mjs +361 -312
- package/fesm2022/fundamental-ngx-cdk-utils.mjs.map +1 -1
- package/fesm2022/fundamental-ngx-cdk.mjs +4 -4
- package/forms/cva/cva.directive.d.ts +7 -3
- package/package.json +8 -16
- package/utils/abstract-fd-ngx-class.d.ts +1 -1
- package/utils/directives/overflow-list/overflow-list.directive.d.ts +7 -0
- package/utils/drag-and-drop/dnd-item/dnd-item.directive.d.ts +1 -1
- package/utils/drag-and-drop/dnd-keyboard-group/dnd-keyboard-group.directive.d.ts +1 -1
- package/utils/drag-and-drop/dnd-keyboard-item/dnd-keyboard-item.directive.d.ts +1 -1
- package/utils/drag-and-drop/dnd-list/dnd-list.directive.d.ts +1 -1
- package/utils/drag-and-drop/drag-and-drop.module.d.ts +7 -7
- package/utils/toast/base-toast-positions.d.ts +16 -16
- package/utils/toast/classes/base-toast-animated-container.component.d.ts +1 -1
- package/utils/toast/classes/base-toast-container.component.d.ts +1 -1
- package/utils/toast/classes/duration-dismissible/base-toast-duration-dismissible-container.component.d.ts +1 -1
- package/esm2022/data-source/base/abstract-data-provider.class.mjs +0 -142
- package/esm2022/data-source/base/base-data-source.class.mjs +0 -112
- package/esm2022/data-source/data-source.directive.mjs +0 -95
- package/esm2022/data-source/data-source.module.mjs +0 -16
- package/esm2022/data-source/fundamental-ngx-cdk-data-source.mjs +0 -5
- package/esm2022/data-source/helpers/apply-datasource-directive.mjs +0 -7
- package/esm2022/data-source/helpers/common.mjs +0 -17
- package/esm2022/data-source/helpers/is-datasource.mjs +0 -7
- package/esm2022/data-source/index.mjs +0 -9
- package/esm2022/data-source/models/data-source-provider.mjs +0 -2
- package/esm2022/data-source/models/data-source.mjs +0 -2
- package/esm2022/data-source/models/index.mjs +0 -4
- package/esm2022/data-source/models/matching-strategy.mjs +0 -7
- package/esm2022/data-source/tokens.mjs +0 -6
- package/esm2022/forms/cva/cva-control.class.mjs +0 -42
- package/esm2022/forms/cva/cva.directive.mjs +0 -321
- package/esm2022/forms/forms.module.mjs +0 -16
- package/esm2022/forms/fundamental-ngx-cdk-forms.mjs +0 -5
- package/esm2022/forms/helpers/state.mjs +0 -7
- package/esm2022/forms/index.mjs +0 -13
- package/esm2022/forms/models/control-type.model.mjs +0 -2
- package/esm2022/forms/models/cva.mjs +0 -2
- package/esm2022/forms/models/form-error.mjs +0 -2
- package/esm2022/forms/models/form-field.mjs +0 -9
- package/esm2022/forms/models/form-state.mjs +0 -2
- package/esm2022/forms/models/select-item.mjs +0 -14
- package/esm2022/forms/tokens/form-field-control.token.mjs +0 -3
- package/esm2022/forms/tokens/form-field.token.mjs +0 -3
- package/esm2022/fundamental-ngx-cdk.mjs +0 -5
- package/esm2022/fundamental-ngx.module.mjs +0 -19
- package/esm2022/index.mjs +0 -5
- package/esm2022/utils/abstract-fd-ngx-class.mjs +0 -61
- package/esm2022/utils/async-strategy/function-strategy.class.mjs +0 -12
- package/esm2022/utils/async-strategy/index.mjs +0 -7
- package/esm2022/utils/async-strategy/observable-strategy.class.mjs +0 -13
- package/esm2022/utils/async-strategy/promise-strategy.class.mjs +0 -12
- package/esm2022/utils/async-strategy/select-strategy.class.mjs +0 -23
- package/esm2022/utils/async-strategy/subscription-strategy.interface.mjs +0 -2
- package/esm2022/utils/async-strategy/value-strategy.class.mjs +0 -10
- package/esm2022/utils/coercion/array.mjs +0 -7
- package/esm2022/utils/components/dynamic-portal/dynamic-portal.component.mjs +0 -98
- package/esm2022/utils/components/index.mjs +0 -2
- package/esm2022/utils/consts/error-messages.mjs +0 -6
- package/esm2022/utils/consts/index.mjs +0 -5
- package/esm2022/utils/consts/overflow-priority-score.mjs +0 -8
- package/esm2022/utils/consts/unicode-letters.regex.mjs +0 -11
- package/esm2022/utils/consts/unicode-numbers.regex.mjs +0 -8
- package/esm2022/utils/datatypes/color-accent.datatype.mjs +0 -2
- package/esm2022/utils/datatypes/hash.datatype.mjs +0 -2
- package/esm2022/utils/datatypes/index.mjs +0 -5
- package/esm2022/utils/datatypes/object-nesting.types.mjs +0 -2
- package/esm2022/utils/datatypes/size.datatype.mjs +0 -2
- package/esm2022/utils/decorators/apply-css-class.decorator.mjs +0 -61
- package/esm2022/utils/decorators/apply-css-style.decorator.mjs +0 -26
- package/esm2022/utils/decorators/coerce-boolean.mjs +0 -7
- package/esm2022/utils/decorators/coerce-css-pixel.mjs +0 -4
- package/esm2022/utils/decorators/index.mjs +0 -6
- package/esm2022/utils/decorators/setter-alternator.mjs +0 -18
- package/esm2022/utils/deprecated-selector.class.mjs +0 -35
- package/esm2022/utils/directives/auto-complete/auto-complete.directive.mjs +0 -135
- package/esm2022/utils/directives/auto-complete/auto-complete.module.mjs +0 -17
- package/esm2022/utils/directives/breakpoints/breakpoint.directive.mjs +0 -156
- package/esm2022/utils/directives/breakpoints/responsive-breakpoints.mjs +0 -19
- package/esm2022/utils/directives/clicked/clicked-behavior.module.mjs +0 -35
- package/esm2022/utils/directives/clicked/clicked-event.plugin.mjs +0 -79
- package/esm2022/utils/directives/clicked/clicked.directive.mjs +0 -36
- package/esm2022/utils/directives/clicked/element-click.observable.mjs +0 -21
- package/esm2022/utils/directives/clicked/fdk-clicked-provider.service.mjs +0 -48
- package/esm2022/utils/directives/clicked/index.mjs +0 -6
- package/esm2022/utils/directives/clicked/provide-fdk-clicked.mjs +0 -29
- package/esm2022/utils/directives/disabled/default-disabled-view-modifier.mjs +0 -12
- package/esm2022/utils/directives/disabled/disabled-behavior.directive.mjs +0 -84
- package/esm2022/utils/directives/disabled/disabled-behavior.interface.mjs +0 -2
- package/esm2022/utils/directives/disabled/disabled-behavior.module.mjs +0 -16
- package/esm2022/utils/directives/disabled/disabled-view-modifier.interface.mjs +0 -2
- package/esm2022/utils/directives/disabled/disabled.observer.mjs +0 -35
- package/esm2022/utils/directives/disabled/fdk-disabled-provider.service.mjs +0 -101
- package/esm2022/utils/directives/disabled/fdk-disabled.token.mjs +0 -3
- package/esm2022/utils/directives/disabled/index.mjs +0 -9
- package/esm2022/utils/directives/disabled/set-disabled-state.mjs +0 -18
- package/esm2022/utils/directives/focus-key-manager/focus-key-manager-helpers.module.mjs +0 -17
- package/esm2022/utils/directives/focus-key-manager/focus-key-manager-item.directive.mjs +0 -67
- package/esm2022/utils/directives/focus-key-manager/focus-key-manager-list.directive.mjs +0 -88
- package/esm2022/utils/directives/focus-key-manager/focus-key-manager.tokens.mjs +0 -3
- package/esm2022/utils/directives/focus-key-manager/index.mjs +0 -5
- package/esm2022/utils/directives/focusable-grid/focusable-grid.directive.mjs +0 -164
- package/esm2022/utils/directives/focusable-grid/focusable-grid.module.mjs +0 -17
- package/esm2022/utils/directives/focusable-grid/focusable-grid.tokens.mjs +0 -3
- package/esm2022/utils/directives/focusable-grid/index.mjs +0 -4
- package/esm2022/utils/directives/focusable-item/focusable-item.directive.mjs +0 -198
- package/esm2022/utils/directives/focusable-item/focusable-item.module.mjs +0 -16
- package/esm2022/utils/directives/focusable-item/focusable-item.tokens.mjs +0 -3
- package/esm2022/utils/directives/focusable-item/focusable-list.position.mjs +0 -2
- package/esm2022/utils/directives/focusable-item/focusable.item.mjs +0 -2
- package/esm2022/utils/directives/focusable-item/focusable.observer.mjs +0 -46
- package/esm2022/utils/directives/focusable-item/get-item-element.mjs +0 -14
- package/esm2022/utils/directives/focusable-item/index.mjs +0 -9
- package/esm2022/utils/directives/focusable-item/indirect-focusable-item.directive.mjs +0 -44
- package/esm2022/utils/directives/focusable-item/is-element-focusable-by-default.mjs +0 -32
- package/esm2022/utils/directives/focusable-item/is-item-focusable.mjs +0 -8
- package/esm2022/utils/directives/focusable-list/focusable-list.directive.mjs +0 -300
- package/esm2022/utils/directives/focusable-list/focusable-list.module.mjs +0 -17
- package/esm2022/utils/directives/focusable-list/focusable-list.tokens.mjs +0 -3
- package/esm2022/utils/directives/focusable-list/index.mjs +0 -6
- package/esm2022/utils/directives/focusable-list/indirect-focusable-list.directive.mjs +0 -59
- package/esm2022/utils/directives/focusable-list/scroll.mjs +0 -43
- package/esm2022/utils/directives/ignore-click-on-selection/ignore-click-on-selection.directive.mjs +0 -55
- package/esm2022/utils/directives/ignore-click-on-selection/ignore-click-on-selection.module.mjs +0 -16
- package/esm2022/utils/directives/ignore-click-on-selection/tokens.mjs +0 -3
- package/esm2022/utils/directives/index.mjs +0 -35
- package/esm2022/utils/directives/initial-focus/initial-focus.directive.mjs +0 -99
- package/esm2022/utils/directives/initial-focus/initial-focus.module.mjs +0 -16
- package/esm2022/utils/directives/intersection-spy/intersection-spy.directive.mjs +0 -42
- package/esm2022/utils/directives/line-clamp/line-clamp.directive.mjs +0 -213
- package/esm2022/utils/directives/line-clamp/line-clamp.module.mjs +0 -16
- package/esm2022/utils/directives/only-digits/only-digits.directive.mjs +0 -206
- package/esm2022/utils/directives/only-digits/only-digits.module.mjs +0 -16
- package/esm2022/utils/directives/overflow-list/overflow-list-item.directive.mjs +0 -18
- package/esm2022/utils/directives/overflow-list/overflow-list.directive.mjs +0 -114
- package/esm2022/utils/directives/overflow-list/overflow-list.module.mjs +0 -17
- package/esm2022/utils/directives/readonly/default-readonly-view-modifier.mjs +0 -12
- package/esm2022/utils/directives/readonly/fdk-readonly-provider.service.mjs +0 -101
- package/esm2022/utils/directives/readonly/fdk-readonly.token.mjs +0 -3
- package/esm2022/utils/directives/readonly/index.mjs +0 -10
- package/esm2022/utils/directives/readonly/readonly-behavior.directive.mjs +0 -67
- package/esm2022/utils/directives/readonly/readonly-behavior.interface.mjs +0 -2
- package/esm2022/utils/directives/readonly/readonly-behavior.module.mjs +0 -16
- package/esm2022/utils/directives/readonly/readonly-view-modifier.interface.mjs +0 -2
- package/esm2022/utils/directives/readonly/readonly.observer.mjs +0 -33
- package/esm2022/utils/directives/readonly/set-readonly-state.mjs +0 -14
- package/esm2022/utils/directives/repeat/repeat.directive.mjs +0 -34
- package/esm2022/utils/directives/repeat/repeat.module.mjs +0 -16
- package/esm2022/utils/directives/resize/resize-handle.directive.mjs +0 -18
- package/esm2022/utils/directives/resize/resize.directive.mjs +0 -241
- package/esm2022/utils/directives/resize/resize.module.mjs +0 -17
- package/esm2022/utils/directives/resize-observer/index.mjs +0 -2
- package/esm2022/utils/directives/resize-observer/resize-observer.directive.mjs +0 -29
- package/esm2022/utils/directives/selectable-list/index.mjs +0 -8
- package/esm2022/utils/directives/selectable-list/select-component-root.token.mjs +0 -3
- package/esm2022/utils/directives/selectable-list/selectable-item.directive.mjs +0 -147
- package/esm2022/utils/directives/selectable-list/selectable-item.token.mjs +0 -3
- package/esm2022/utils/directives/selectable-list/selectable-list.directive.mjs +0 -85
- package/esm2022/utils/directives/selectable-list/selectable-list.module.mjs +0 -17
- package/esm2022/utils/directives/selectable-list/selectable-list.tokens.mjs +0 -3
- package/esm2022/utils/directives/selectable-list/selection.service.mjs +0 -138
- package/esm2022/utils/directives/template/template.directive.mjs +0 -25
- package/esm2022/utils/directives/template/template.module.mjs +0 -16
- package/esm2022/utils/directives/truncate/truncate.directive.mjs +0 -94
- package/esm2022/utils/directives/truncate/truncate.module.mjs +0 -16
- package/esm2022/utils/drag-and-drop/dnd-item/dnd-item.directive.mjs +0 -274
- package/esm2022/utils/drag-and-drop/dnd-keyboard-group/dnd-keyboard-group.directive.mjs +0 -88
- package/esm2022/utils/drag-and-drop/dnd-keyboard-item/dnd-keyboard-item.directive.mjs +0 -83
- package/esm2022/utils/drag-and-drop/dnd-list/dnd-list.directive.mjs +0 -378
- package/esm2022/utils/drag-and-drop/dnd.interfaces.mjs +0 -2
- package/esm2022/utils/drag-and-drop/drag-and-drop.module.mjs +0 -22
- package/esm2022/utils/drag-and-drop/index.mjs +0 -8
- package/esm2022/utils/drag-and-drop/tokens.mjs +0 -4
- package/esm2022/utils/dynamic-component/dynamic-component-config.mjs +0 -2
- package/esm2022/utils/dynamic-component/dynamic-component-container.mjs +0 -32
- package/esm2022/utils/dynamic-component/dynamic-component-injector.mjs +0 -20
- package/esm2022/utils/dynamic-component/dynamic-component.service.mjs +0 -100
- package/esm2022/utils/dynamic-component/index.mjs +0 -5
- package/esm2022/utils/functions/consumer-provider-factory.mjs +0 -12
- package/esm2022/utils/functions/element-size.mjs +0 -23
- package/esm2022/utils/functions/get-document-font-size.mjs +0 -9
- package/esm2022/utils/functions/index.mjs +0 -14
- package/esm2022/utils/functions/intersection-observable.mjs +0 -26
- package/esm2022/utils/functions/is-compact-density.mjs +0 -11
- package/esm2022/utils/functions/is-odd.mjs +0 -9
- package/esm2022/utils/functions/key-util.mjs +0 -90
- package/esm2022/utils/functions/module-deprecations-provider.mjs +0 -18
- package/esm2022/utils/functions/parser-file-size.mjs +0 -37
- package/esm2022/utils/functions/random-color-accent.mjs +0 -5
- package/esm2022/utils/functions/resize-observable.mjs +0 -33
- package/esm2022/utils/functions/scroll.mjs +0 -19
- package/esm2022/utils/functions/uuidv4-generator.mjs +0 -12
- package/esm2022/utils/fundamental-ngx-cdk-utils.mjs +0 -5
- package/esm2022/utils/helpers/destroy-observable.mjs +0 -12
- package/esm2022/utils/helpers/dfs.mjs +0 -47
- package/esm2022/utils/helpers/get-native-element.mjs +0 -19
- package/esm2022/utils/helpers/index.mjs +0 -6
- package/esm2022/utils/helpers/range-selector.mjs +0 -117
- package/esm2022/utils/helpers/warn-once.mjs +0 -9
- package/esm2022/utils/index.mjs +0 -25
- package/esm2022/utils/interfaces/content-density.mjs +0 -2
- package/esm2022/utils/interfaces/css-class-builder.interface.mjs +0 -2
- package/esm2022/utils/interfaces/css-style-builder.interface.mjs +0 -2
- package/esm2022/utils/interfaces/has-element-ref.interface.mjs +0 -2
- package/esm2022/utils/interfaces/index.mjs +0 -8
- package/esm2022/utils/interfaces/keyboard-support-item.interface.mjs +0 -2
- package/esm2022/utils/interfaces/module-deprecation.interface.mjs +0 -2
- package/esm2022/utils/interfaces/require.interface.mjs +0 -2
- package/esm2022/utils/list-item/list-item-utils.mjs +0 -3
- package/esm2022/utils/models/nullable.mjs +0 -2
- package/esm2022/utils/pipes/async-or-sync.pipe.mjs +0 -35
- package/esm2022/utils/pipes/displayFn.pipe.mjs +0 -18
- package/esm2022/utils/pipes/filter-strings.pipe.mjs +0 -31
- package/esm2022/utils/pipes/index.mjs +0 -12
- package/esm2022/utils/pipes/is-compact.pipe.mjs +0 -16
- package/esm2022/utils/pipes/make-async.pipe.mjs +0 -24
- package/esm2022/utils/pipes/pipe.module.mjs +0 -65
- package/esm2022/utils/pipes/safe.pipe.mjs +0 -37
- package/esm2022/utils/pipes/search-highlight.pipe.mjs +0 -40
- package/esm2022/utils/pipes/truncate.pipe.mjs +0 -18
- package/esm2022/utils/pipes/two-digits.pipe.mjs +0 -23
- package/esm2022/utils/pipes/value-by-path.pipe.mjs +0 -16
- package/esm2022/utils/services/content-density.service.mjs +0 -35
- package/esm2022/utils/services/destroyed.service.mjs +0 -26
- package/esm2022/utils/services/focus-trap.service.mjs +0 -92
- package/esm2022/utils/services/index.mjs +0 -10
- package/esm2022/utils/services/keyboard-support/keyboard-support.service.mjs +0 -73
- package/esm2022/utils/services/local-storage.service.mjs +0 -38
- package/esm2022/utils/services/observers/attribute.observer.mjs +0 -81
- package/esm2022/utils/services/resize-observer.service.mjs +0 -92
- package/esm2022/utils/services/rtl.service.mjs +0 -32
- package/esm2022/utils/services/tabbable-element.service.mjs +0 -43
- package/esm2022/utils/toast/base-toast-animations.mjs +0 -22
- package/esm2022/utils/toast/base-toast-positions.mjs +0 -108
- package/esm2022/utils/toast/base-toast.service.mjs +0 -261
- package/esm2022/utils/toast/classes/action-dismissible/base-toast-action-dismissible-ref.mjs +0 -36
- package/esm2022/utils/toast/classes/base-toast-animated-container.component.mjs +0 -87
- package/esm2022/utils/toast/classes/base-toast-config.mjs +0 -23
- package/esm2022/utils/toast/classes/base-toast-container.component.mjs +0 -72
- package/esm2022/utils/toast/classes/base-toast-overlay-container.mjs +0 -25
- package/esm2022/utils/toast/classes/base-toast-ref.mjs +0 -45
- package/esm2022/utils/toast/classes/duration-dismissible/base-toast-duration-dismissible-config.mjs +0 -19
- package/esm2022/utils/toast/classes/duration-dismissible/base-toast-duration-dismissible-container.component.mjs +0 -39
- package/esm2022/utils/toast/classes/duration-dismissible/base-toast-duration-dismissible-ref.mjs +0 -23
- package/esm2022/utils/toast/classes/duration-dismissible/base-toast-duration-dismissible.service.mjs +0 -25
- package/esm2022/utils/toast/index.mjs +0 -16
- package/esm2022/utils/toast/interfaces/toast-container-component.interface.mjs +0 -2
- package/esm2022/utils/toast/interfaces/toast-duration-dismissible-container-component.interface.mjs +0 -2
- package/esm2022/utils/toast/interfaces/toast-text-component.interface.mjs +0 -2
- package/esm2022/utils/tokens/module-deprecations.token.mjs +0 -3
- package/esm2022/utils/tokens/viewport-size.observable.mjs +0 -20
- package/esm2022/utils/typecheck.mjs +0 -75
- package/esm2022/utils/utils.module.mjs +0 -131
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import { NgModule } from '@angular/core';
|
|
2
|
-
import { TruncateDirective, TruncatedTitleDirective } from './truncate.directive';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
export class TruncateModule {
|
|
5
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: TruncateModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
6
|
-
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.0.3", ngImport: i0, type: TruncateModule, imports: [TruncateDirective, TruncatedTitleDirective], exports: [TruncateDirective, TruncatedTitleDirective] }); }
|
|
7
|
-
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: TruncateModule }); }
|
|
8
|
-
}
|
|
9
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: TruncateModule, decorators: [{
|
|
10
|
-
type: NgModule,
|
|
11
|
-
args: [{
|
|
12
|
-
imports: [TruncateDirective, TruncatedTitleDirective],
|
|
13
|
-
exports: [TruncateDirective, TruncatedTitleDirective]
|
|
14
|
-
}]
|
|
15
|
-
}] });
|
|
16
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1bmNhdGUubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jZGsvdXRpbHMvZGlyZWN0aXZlcy90cnVuY2F0ZS90cnVuY2F0ZS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV6QyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQzs7QUFNbEYsTUFBTSxPQUFPLGNBQWM7OEdBQWQsY0FBYzsrR0FBZCxjQUFjLFlBSGIsaUJBQWlCLEVBQUUsdUJBQXVCLGFBQzFDLGlCQUFpQixFQUFFLHVCQUF1QjsrR0FFM0MsY0FBYzs7MkZBQWQsY0FBYztrQkFKMUIsUUFBUTttQkFBQztvQkFDTixPQUFPLEVBQUUsQ0FBQyxpQkFBaUIsRUFBRSx1QkFBdUIsQ0FBQztvQkFDckQsT0FBTyxFQUFFLENBQUMsaUJBQWlCLEVBQUUsdUJBQXVCLENBQUM7aUJBQ3hEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgVHJ1bmNhdGVEaXJlY3RpdmUsIFRydW5jYXRlZFRpdGxlRGlyZWN0aXZlIH0gZnJvbSAnLi90cnVuY2F0ZS5kaXJlY3RpdmUnO1xuXG5ATmdNb2R1bGUoe1xuICAgIGltcG9ydHM6IFtUcnVuY2F0ZURpcmVjdGl2ZSwgVHJ1bmNhdGVkVGl0bGVEaXJlY3RpdmVdLFxuICAgIGV4cG9ydHM6IFtUcnVuY2F0ZURpcmVjdGl2ZSwgVHJ1bmNhdGVkVGl0bGVEaXJlY3RpdmVdXG59KVxuZXhwb3J0IGNsYXNzIFRydW5jYXRlTW9kdWxlIHt9XG4iXX0=
|
|
@@ -1,274 +0,0 @@
|
|
|
1
|
-
import { DragDrop } from '@angular/cdk/drag-drop';
|
|
2
|
-
import { Directive, ElementRef, EventEmitter, HostBinding, Input, Output, Renderer2, forwardRef } from '@angular/core';
|
|
3
|
-
import { Subscription } from 'rxjs';
|
|
4
|
-
import { delay } from 'rxjs/operators';
|
|
5
|
-
import { DND_ITEM } from '../tokens';
|
|
6
|
-
import * as i0 from "@angular/core";
|
|
7
|
-
import * as i1 from "@angular/cdk/drag-drop";
|
|
8
|
-
export class DndItemDirective {
|
|
9
|
-
/** Defines if element is draggable */
|
|
10
|
-
set draggable(draggable) {
|
|
11
|
-
this._draggable = draggable;
|
|
12
|
-
this.changeCDKDragState();
|
|
13
|
-
}
|
|
14
|
-
/** @hidden */
|
|
15
|
-
constructor(elementRef, _dragDrop, _renderer) {
|
|
16
|
-
this.elementRef = elementRef;
|
|
17
|
-
this._dragDrop = _dragDrop;
|
|
18
|
-
this._renderer = _renderer;
|
|
19
|
-
/**
|
|
20
|
-
* Whether to apply "fd-dnd-item" class.
|
|
21
|
-
* @default true
|
|
22
|
-
*/
|
|
23
|
-
this.applyDragItemClass = true;
|
|
24
|
-
/** Event thrown when the element is moved by 1px */
|
|
25
|
-
this.moved = new EventEmitter();
|
|
26
|
-
/** Event thrown when the element is released */
|
|
27
|
-
this.released = new EventEmitter();
|
|
28
|
-
/** Event thrown when the element is started to be dragged */
|
|
29
|
-
this.started = new EventEmitter();
|
|
30
|
-
/**
|
|
31
|
-
* Defines if the item is prevented from being moved by other elements.
|
|
32
|
-
* So nothing can be placed just before and just after it
|
|
33
|
-
*/
|
|
34
|
-
this.stickInPlace = false;
|
|
35
|
-
/** Class added to element, when it's dragged. */
|
|
36
|
-
this.classWhenElementDragged = 'fd-dnd-on-drag';
|
|
37
|
-
/** Defines if every element in list is draggable */
|
|
38
|
-
this.listDraggable = true;
|
|
39
|
-
/** @hidden */
|
|
40
|
-
this._draggable = true;
|
|
41
|
-
/** @hidden */
|
|
42
|
-
this._subscriptions = new Subscription();
|
|
43
|
-
}
|
|
44
|
-
/** @hidden */
|
|
45
|
-
getElementCoordinates(isBefore) {
|
|
46
|
-
/** Takes distance from the beginning of window page */
|
|
47
|
-
const rect = this.elementRef.nativeElement.getBoundingClientRect();
|
|
48
|
-
const position = isBefore ? 'before' : 'after';
|
|
49
|
-
/** Vertically distance is counted by distance from top of the side + half of the element height */
|
|
50
|
-
return {
|
|
51
|
-
x: rect.left,
|
|
52
|
-
position,
|
|
53
|
-
y: rect.top,
|
|
54
|
-
stickToPosition: this.stickInPlace,
|
|
55
|
-
width: rect.width,
|
|
56
|
-
height: rect.height
|
|
57
|
-
};
|
|
58
|
-
}
|
|
59
|
-
/** @hidden */
|
|
60
|
-
ngAfterContentInit() {
|
|
61
|
-
this._setCDKDrag();
|
|
62
|
-
this._listenElementEvents();
|
|
63
|
-
}
|
|
64
|
-
/** @hidden */
|
|
65
|
-
ngOnDestroy() {
|
|
66
|
-
this._subscriptions.unsubscribe();
|
|
67
|
-
this._dragRef.dispose();
|
|
68
|
-
}
|
|
69
|
-
/** @hidden */
|
|
70
|
-
onCdkMove(position) {
|
|
71
|
-
this.moved.emit(position);
|
|
72
|
-
}
|
|
73
|
-
/** @hidden */
|
|
74
|
-
onCdkDragReleased() {
|
|
75
|
-
/** Remove class which is added, when element is dragged */
|
|
76
|
-
this.elementRef.nativeElement.classList.remove(this.classWhenElementDragged);
|
|
77
|
-
this.released.emit();
|
|
78
|
-
/** Resets the position of element. */
|
|
79
|
-
this._dragRef.reset();
|
|
80
|
-
/** Removes placeholder element */
|
|
81
|
-
this.removePlaceholder();
|
|
82
|
-
}
|
|
83
|
-
/** @hidden */
|
|
84
|
-
onCdkDragStart() {
|
|
85
|
-
/** Adds class */
|
|
86
|
-
this.elementRef.nativeElement.classList.add(this.classWhenElementDragged);
|
|
87
|
-
if (!this._placeholderElement) {
|
|
88
|
-
this.createPlaceholder();
|
|
89
|
-
}
|
|
90
|
-
this.started.emit();
|
|
91
|
-
}
|
|
92
|
-
/** @hidden */
|
|
93
|
-
removePlaceholder() {
|
|
94
|
-
if (this._placeholderElement && this._placeholderElement.parentNode) {
|
|
95
|
-
// IE11 workaround
|
|
96
|
-
this._placeholderElement.parentNode.removeChild(this._placeholderElement);
|
|
97
|
-
this._placeholderElement = null;
|
|
98
|
-
}
|
|
99
|
-
}
|
|
100
|
-
/** @hidden */
|
|
101
|
-
removeLine() {
|
|
102
|
-
if (this._lineElement && this._lineElement.parentNode) {
|
|
103
|
-
// IE11 workaround
|
|
104
|
-
this._lineElement.parentNode.removeChild(this._lineElement);
|
|
105
|
-
this._lineElement = null;
|
|
106
|
-
}
|
|
107
|
-
}
|
|
108
|
-
/** @hidden */
|
|
109
|
-
removeReplaceIndicator() {
|
|
110
|
-
if (this._replaceIndicator && this._replaceIndicator.parentNode) {
|
|
111
|
-
// IE11 workaround
|
|
112
|
-
this._replaceIndicator.parentNode.removeChild(this._replaceIndicator);
|
|
113
|
-
this._replaceIndicator = null;
|
|
114
|
-
}
|
|
115
|
-
}
|
|
116
|
-
/** @hidden */
|
|
117
|
-
createReplaceIndicator() {
|
|
118
|
-
this._replaceIndicator = document.createElement('DIV');
|
|
119
|
-
this._replaceIndicator.classList.add('fd-replace-indicator');
|
|
120
|
-
let container = this.elementRef.nativeElement;
|
|
121
|
-
if (this.containerSelector) {
|
|
122
|
-
const newContainer = this.elementRef.nativeElement.querySelector(this.containerSelector);
|
|
123
|
-
if (newContainer) {
|
|
124
|
-
container = newContainer;
|
|
125
|
-
}
|
|
126
|
-
}
|
|
127
|
-
container.appendChild(this._replaceIndicator);
|
|
128
|
-
}
|
|
129
|
-
/** @hidden */
|
|
130
|
-
createLine(position, gridMode) {
|
|
131
|
-
/** Creating of line element */
|
|
132
|
-
this._lineElement = document.createElement('div');
|
|
133
|
-
this._lineElement.classList.add('drop-area__line');
|
|
134
|
-
if (gridMode) {
|
|
135
|
-
this._lineElement.classList.add('drop-area__line--vertical');
|
|
136
|
-
}
|
|
137
|
-
else {
|
|
138
|
-
this._lineElement.classList.add('drop-area__line--horizontal');
|
|
139
|
-
}
|
|
140
|
-
if (position === 'after') {
|
|
141
|
-
this._lineElement.classList.add('after');
|
|
142
|
-
}
|
|
143
|
-
if (position === 'before') {
|
|
144
|
-
this._lineElement.classList.add('before');
|
|
145
|
-
}
|
|
146
|
-
/** Putting element to the container */
|
|
147
|
-
let container = this.elementRef.nativeElement;
|
|
148
|
-
if (this.containerSelector) {
|
|
149
|
-
const newContainer = this.elementRef.nativeElement.querySelector(this.containerSelector);
|
|
150
|
-
if (newContainer) {
|
|
151
|
-
container = newContainer;
|
|
152
|
-
}
|
|
153
|
-
}
|
|
154
|
-
container.appendChild(this._lineElement);
|
|
155
|
-
}
|
|
156
|
-
/** @hidden */
|
|
157
|
-
changeCDKDragState() {
|
|
158
|
-
if (this._dragRef) {
|
|
159
|
-
this._dragRef.disabled = !(this._draggable && this.listDraggable);
|
|
160
|
-
}
|
|
161
|
-
}
|
|
162
|
-
/**
|
|
163
|
-
* Sets the disabled state of the dnd item.
|
|
164
|
-
* @param state
|
|
165
|
-
*/
|
|
166
|
-
setDisabledState(state) {
|
|
167
|
-
if (state) {
|
|
168
|
-
this._renderer.addClass(this.elementRef.nativeElement, 'fd-dnd-item--disabled');
|
|
169
|
-
}
|
|
170
|
-
else {
|
|
171
|
-
this._renderer.removeClass(this.elementRef.nativeElement, 'fd-dnd-item--disabled');
|
|
172
|
-
}
|
|
173
|
-
}
|
|
174
|
-
/** @hidden */
|
|
175
|
-
createPlaceholder() {
|
|
176
|
-
const placeholder = this.elementRef.nativeElement.cloneNode(true);
|
|
177
|
-
/** Cloning container element */
|
|
178
|
-
this._placeholderElement = placeholder;
|
|
179
|
-
placeholder.classList.add('fd-dnd-placeholder');
|
|
180
|
-
this._setPlaceholderStyles();
|
|
181
|
-
/** Including element to the container
|
|
182
|
-
* IE11 equivalent to `this.element.nativeElement.after(clone);`
|
|
183
|
-
*/
|
|
184
|
-
this._placeAfter(this.elementRef.nativeElement, placeholder);
|
|
185
|
-
}
|
|
186
|
-
/** @hidden */
|
|
187
|
-
_setPlaceholderStyles() {
|
|
188
|
-
const offset = this._getOffsetToParent(this.elementRef.nativeElement);
|
|
189
|
-
if (!offset || !this._placeholderElement) {
|
|
190
|
-
return;
|
|
191
|
-
}
|
|
192
|
-
this._placeholderElement.style.top = offset.y + 'px';
|
|
193
|
-
this._placeholderElement.style.left = offset.x + 'px';
|
|
194
|
-
this._placeholderElement.style.position = 'absolute';
|
|
195
|
-
this._placeholderElement.style.zIndex = '0';
|
|
196
|
-
this._placeholderElement.style.opacity = '0.3';
|
|
197
|
-
this._placeholderElement.style.width = this.elementRef.nativeElement.offsetWidth + 'px';
|
|
198
|
-
this._placeholderElement.style.height = this.elementRef.nativeElement.offsetHeight + 'px';
|
|
199
|
-
}
|
|
200
|
-
/** @hidden */
|
|
201
|
-
_getOffsetToParent(element) {
|
|
202
|
-
const parentElement = element.parentElement;
|
|
203
|
-
if (!parentElement) {
|
|
204
|
-
return;
|
|
205
|
-
}
|
|
206
|
-
const parentElmRect = parentElement.getBoundingClientRect();
|
|
207
|
-
const elmRect = element.getBoundingClientRect();
|
|
208
|
-
const parentTop = parentElmRect.top;
|
|
209
|
-
const parentLeft = parentElmRect.left;
|
|
210
|
-
return {
|
|
211
|
-
x: Math.abs(elmRect.left - parentLeft),
|
|
212
|
-
y: Math.abs(elmRect.top - parentTop)
|
|
213
|
-
};
|
|
214
|
-
}
|
|
215
|
-
/** @hidden */
|
|
216
|
-
_setCDKDrag() {
|
|
217
|
-
this._dragRef = this._dragDrop.createDrag(this.elementRef);
|
|
218
|
-
this._dragRef.disabled = !this._draggable;
|
|
219
|
-
this._subscriptions.add(this._dragRef.moved.subscribe((event) => this.onCdkMove(event.pointerPosition)));
|
|
220
|
-
this._subscriptions.add(this._dragRef.released.subscribe(() => this.onCdkDragReleased()));
|
|
221
|
-
this._subscriptions.add(this._dragRef.started.subscribe(() => this.onCdkDragStart()));
|
|
222
|
-
}
|
|
223
|
-
/** IE11 equivalent of Node.after() Method */
|
|
224
|
-
_placeAfter(element, cloneNode) {
|
|
225
|
-
const docFrag = document.createDocumentFragment();
|
|
226
|
-
docFrag.appendChild(cloneNode);
|
|
227
|
-
element.parentNode?.insertBefore(docFrag, element.nextSibling);
|
|
228
|
-
}
|
|
229
|
-
/** @hidden */
|
|
230
|
-
_listenElementEvents() {
|
|
231
|
-
this._subscriptions.add(this.released
|
|
232
|
-
.pipe(
|
|
233
|
-
// postpone blur
|
|
234
|
-
delay(0))
|
|
235
|
-
.subscribe(() => {
|
|
236
|
-
if (this.containerSelector) {
|
|
237
|
-
this.elementRef.nativeElement.children[0].blur();
|
|
238
|
-
}
|
|
239
|
-
this.elementRef.nativeElement.blur();
|
|
240
|
-
}));
|
|
241
|
-
}
|
|
242
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: DndItemDirective, deps: [{ token: i0.ElementRef }, { token: i1.DragDrop }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
243
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.0.3", type: DndItemDirective, selector: "[fdkDndItem], [fd-dnd-item]", inputs: { item: ["fdkDndItem", "item"], applyDragItemClass: "applyDragItemClass", containerSelector: "containerSelector", stickInPlace: "stickInPlace", draggable: "draggable", classWhenElementDragged: "classWhenElementDragged" }, outputs: { moved: "moved", released: "released", started: "started" }, host: { properties: { "class.fd-dnd-item": "this.applyDragItemClass" } }, providers: [DragDrop, { provide: DND_ITEM, useExisting: forwardRef(() => DndItemDirective) }], ngImport: i0 }); }
|
|
244
|
-
}
|
|
245
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: DndItemDirective, decorators: [{
|
|
246
|
-
type: Directive,
|
|
247
|
-
args: [{
|
|
248
|
-
selector: '[fdkDndItem], [fd-dnd-item]',
|
|
249
|
-
providers: [DragDrop, { provide: DND_ITEM, useExisting: forwardRef(() => DndItemDirective) }]
|
|
250
|
-
}]
|
|
251
|
-
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.DragDrop }, { type: i0.Renderer2 }], propDecorators: { item: [{
|
|
252
|
-
type: Input,
|
|
253
|
-
args: ['fdkDndItem']
|
|
254
|
-
}], applyDragItemClass: [{
|
|
255
|
-
type: Input
|
|
256
|
-
}, {
|
|
257
|
-
type: HostBinding,
|
|
258
|
-
args: ['class.fd-dnd-item']
|
|
259
|
-
}], containerSelector: [{
|
|
260
|
-
type: Input
|
|
261
|
-
}], moved: [{
|
|
262
|
-
type: Output
|
|
263
|
-
}], released: [{
|
|
264
|
-
type: Output
|
|
265
|
-
}], started: [{
|
|
266
|
-
type: Output
|
|
267
|
-
}], stickInPlace: [{
|
|
268
|
-
type: Input
|
|
269
|
-
}], draggable: [{
|
|
270
|
-
type: Input
|
|
271
|
-
}], classWhenElementDragged: [{
|
|
272
|
-
type: Input
|
|
273
|
-
}] } });
|
|
274
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dnd-item.directive.js","sourceRoot":"","sources":["../../../../../../../libs/cdk/utils/drag-and-drop/dnd-item/dnd-item.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { DragDrop, DragRef } from '@angular/cdk/drag-drop';\nimport {\n    AfterContentInit,\n    Directive,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    Input,\n    OnDestroy,\n    Output,\n    Renderer2,\n    forwardRef\n} from '@angular/core';\nimport { Subscription } from 'rxjs';\nimport { delay } from 'rxjs/operators';\nimport { Nullable } from '../../models/nullable';\nimport { DndItem, ElementChord, ElementPosition, LinkPosition } from '../dnd.interfaces';\nimport { DND_ITEM } from '../tokens';\n\n@Directive({\n    selector: '[fdkDndItem], [fd-dnd-item]',\n    providers: [DragDrop, { provide: DND_ITEM, useExisting: forwardRef(() => DndItemDirective) }]\n})\nexport class DndItemDirective<T = any> implements DndItem, AfterContentInit, OnDestroy {\n    /** Item reference. Used for cases when `[items]` array of dnd list is different than `dndItems` content children. */\n    @Input('fdkDndItem')\n    item: Nullable<T>;\n    /**\n     * Whether to apply \"fd-dnd-item\" class.\n     * @default true\n     */\n    @Input()\n    @HostBinding('class.fd-dnd-item')\n    applyDragItemClass = true;\n\n    /** Container selector */\n    @Input()\n    containerSelector?: string;\n\n    /** Event thrown when the element is moved by 1px */\n    @Output()\n    readonly moved = new EventEmitter<ElementPosition>();\n\n    /** Event thrown when the element is released */\n    @Output()\n    readonly released = new EventEmitter<void>();\n\n    /** Event thrown when the element is started to be dragged */\n    @Output()\n    readonly started = new EventEmitter<void>();\n\n    /**\n     *  Defines if the item is prevented from being moved by other elements.\n     * So nothing can be placed just before and just after it\n     */\n    @Input()\n    stickInPlace = false;\n\n    /** Defines if element is draggable */\n    @Input()\n    set draggable(draggable: boolean) {\n        this._draggable = draggable;\n        this.changeCDKDragState();\n    }\n\n    /** Class added to element, when it's dragged. */\n    @Input()\n    classWhenElementDragged = 'fd-dnd-on-drag';\n\n    /** Defines if every element in list is draggable */\n    listDraggable = true;\n\n    /** @hidden\n     * Drag reference, object created from DND CDK Service\n     */\n    private _dragRef: DragRef;\n\n    /** @hidden */\n    private _draggable = true;\n\n    /** @hidden */\n    private _subscriptions = new Subscription();\n\n    /** @hidden */\n    private _placeholderElement: HTMLElement | null;\n\n    /** @hidden */\n    private _lineElement: HTMLElement | null;\n\n    /** @hidden */\n    private _replaceIndicator: HTMLElement | null;\n\n    /** @hidden */\n    constructor(\n        public readonly elementRef: ElementRef,\n        private readonly _dragDrop: DragDrop,\n        private readonly _renderer: Renderer2\n    ) {}\n\n    /** @hidden */\n    getElementCoordinates(isBefore: boolean): ElementChord {\n        /** Takes distance from the beginning of window page */\n        const rect = this.elementRef.nativeElement.getBoundingClientRect();\n\n        const position: LinkPosition = isBefore ? 'before' : 'after';\n\n        /** Vertically distance is counted by distance from top of the side + half of the element height */\n        return {\n            x: rect.left,\n            position,\n            y: rect.top,\n            stickToPosition: this.stickInPlace,\n            width: rect.width,\n            height: rect.height\n        };\n    }\n\n    /** @hidden */\n    ngAfterContentInit(): void {\n        this._setCDKDrag();\n        this._listenElementEvents();\n    }\n\n    /** @hidden */\n    ngOnDestroy(): void {\n        this._subscriptions.unsubscribe();\n        this._dragRef.dispose();\n    }\n\n    /** @hidden */\n    onCdkMove(position: ElementPosition): void {\n        this.moved.emit(position);\n    }\n\n    /** @hidden */\n    onCdkDragReleased(): void {\n        /** Remove class which is added, when element is dragged */\n        this.elementRef.nativeElement.classList.remove(this.classWhenElementDragged);\n        this.released.emit();\n\n        /** Resets the position of element. */\n        this._dragRef.reset();\n\n        /** Removes placeholder element */\n        this.removePlaceholder();\n    }\n\n    /** @hidden */\n    onCdkDragStart(): void {\n        /** Adds class */\n        this.elementRef.nativeElement.classList.add(this.classWhenElementDragged);\n\n        if (!this._placeholderElement) {\n            this.createPlaceholder();\n        }\n        this.started.emit();\n    }\n\n    /** @hidden */\n    removePlaceholder(): void {\n        if (this._placeholderElement && this._placeholderElement.parentNode) {\n            // IE11 workaround\n            this._placeholderElement.parentNode.removeChild(this._placeholderElement);\n            this._placeholderElement = null;\n        }\n    }\n\n    /** @hidden */\n    removeLine(): void {\n        if (this._lineElement && this._lineElement.parentNode) {\n            // IE11 workaround\n            this._lineElement.parentNode.removeChild(this._lineElement);\n            this._lineElement = null;\n        }\n    }\n\n    /** @hidden */\n    removeReplaceIndicator(): void {\n        if (this._replaceIndicator && this._replaceIndicator.parentNode) {\n            // IE11 workaround\n            this._replaceIndicator.parentNode.removeChild(this._replaceIndicator);\n            this._replaceIndicator = null;\n        }\n    }\n\n    /** @hidden */\n    createReplaceIndicator(): void {\n        this._replaceIndicator = document.createElement('DIV');\n        this._replaceIndicator.classList.add('fd-replace-indicator');\n\n        let container = this.elementRef.nativeElement;\n        if (this.containerSelector) {\n            const newContainer = this.elementRef.nativeElement.querySelector(this.containerSelector);\n            if (newContainer) {\n                container = newContainer;\n            }\n        }\n\n        container.appendChild(this._replaceIndicator);\n    }\n\n    /** @hidden */\n    createLine(position: LinkPosition, gridMode: boolean): void {\n        /** Creating of line element */\n        this._lineElement = document.createElement('div');\n        this._lineElement.classList.add('drop-area__line');\n\n        if (gridMode) {\n            this._lineElement.classList.add('drop-area__line--vertical');\n        } else {\n            this._lineElement.classList.add('drop-area__line--horizontal');\n        }\n        if (position === 'after') {\n            this._lineElement.classList.add('after');\n        }\n        if (position === 'before') {\n            this._lineElement.classList.add('before');\n        }\n\n        /** Putting element to the container */\n        let container = this.elementRef.nativeElement;\n        if (this.containerSelector) {\n            const newContainer = this.elementRef.nativeElement.querySelector(this.containerSelector);\n            if (newContainer) {\n                container = newContainer;\n            }\n        }\n\n        container.appendChild(this._lineElement);\n    }\n\n    /** @hidden */\n    changeCDKDragState(): void {\n        if (this._dragRef) {\n            this._dragRef.disabled = !(this._draggable && this.listDraggable);\n        }\n    }\n\n    /**\n     * Sets the disabled state of the dnd item.\n     * @param state\n     */\n    setDisabledState(state: boolean): void {\n        if (state) {\n            this._renderer.addClass(this.elementRef.nativeElement, 'fd-dnd-item--disabled');\n        } else {\n            this._renderer.removeClass(this.elementRef.nativeElement, 'fd-dnd-item--disabled');\n        }\n    }\n\n    /** @hidden */\n    private createPlaceholder(): void {\n        const placeholder = this.elementRef.nativeElement.cloneNode(true);\n        /** Cloning container element */\n        this._placeholderElement = placeholder;\n\n        placeholder.classList.add('fd-dnd-placeholder');\n        this._setPlaceholderStyles();\n\n        /** Including element to the container\n         *  IE11 equivalent to `this.element.nativeElement.after(clone);`\n         */\n        this._placeAfter(this.elementRef.nativeElement, placeholder);\n    }\n\n    /** @hidden */\n    private _setPlaceholderStyles(): void {\n        const offset = this._getOffsetToParent(this.elementRef.nativeElement);\n\n        if (!offset || !this._placeholderElement) {\n            return;\n        }\n\n        this._placeholderElement.style.top = offset.y + 'px';\n        this._placeholderElement.style.left = offset.x + 'px';\n        this._placeholderElement.style.position = 'absolute';\n        this._placeholderElement.style.zIndex = '0';\n        this._placeholderElement.style.opacity = '0.3';\n\n        this._placeholderElement.style.width = this.elementRef.nativeElement.offsetWidth + 'px';\n        this._placeholderElement.style.height = this.elementRef.nativeElement.offsetHeight + 'px';\n    }\n\n    /** @hidden */\n    private _getOffsetToParent(element: Element): { x: number; y: number } | undefined {\n        const parentElement = element.parentElement;\n        if (!parentElement) {\n            return;\n        }\n\n        const parentElmRect = parentElement.getBoundingClientRect();\n        const elmRect = element.getBoundingClientRect();\n\n        const parentTop = parentElmRect.top;\n        const parentLeft = parentElmRect.left;\n\n        return {\n            x: Math.abs(elmRect.left - parentLeft),\n            y: Math.abs(elmRect.top - parentTop)\n        };\n    }\n\n    /** @hidden */\n    private _setCDKDrag(): void {\n        this._dragRef = this._dragDrop.createDrag(this.elementRef);\n        this._dragRef.disabled = !this._draggable;\n        this._subscriptions.add(this._dragRef.moved.subscribe((event) => this.onCdkMove(event.pointerPosition)));\n        this._subscriptions.add(this._dragRef.released.subscribe(() => this.onCdkDragReleased()));\n        this._subscriptions.add(this._dragRef.started.subscribe(() => this.onCdkDragStart()));\n    }\n\n    /** IE11 equivalent of Node.after() Method */\n    private _placeAfter(element: Element, cloneNode: Node): void {\n        const docFrag = document.createDocumentFragment();\n        docFrag.appendChild(cloneNode);\n        element.parentNode?.insertBefore(docFrag, element.nextSibling);\n    }\n\n    /** @hidden */\n    private _listenElementEvents(): void {\n        this._subscriptions.add(\n            this.released\n                .pipe(\n                    // postpone blur\n                    delay(0)\n                )\n                .subscribe(() => {\n                    if (this.containerSelector) {\n                        this.elementRef.nativeElement.children[0].blur();\n                    }\n                    this.elementRef.nativeElement.blur();\n                })\n        );\n    }\n}\n"]}
|
|
@@ -1,88 +0,0 @@
|
|
|
1
|
-
import { moveItemInArray, transferArrayItem } from '@angular/cdk/drag-drop';
|
|
2
|
-
import { DOWN_ARROW, LEFT_ARROW, RIGHT_ARROW, UP_ARROW } from '@angular/cdk/keycodes';
|
|
3
|
-
import { ChangeDetectorRef, Directive, Input, Optional } from '@angular/core';
|
|
4
|
-
import { Subject } from 'rxjs';
|
|
5
|
-
import { KeyUtil } from '../../functions';
|
|
6
|
-
import { RtlService } from '../../services/rtl.service';
|
|
7
|
-
import * as i0 from "@angular/core";
|
|
8
|
-
import * as i1 from "../../services/rtl.service";
|
|
9
|
-
/**
|
|
10
|
-
* This directive is used to provide drag & drop with keyboard support.
|
|
11
|
-
* It should be used together with directive fdDndKeyboardItem.
|
|
12
|
-
*/
|
|
13
|
-
export class DndKeyboardGroupDirective {
|
|
14
|
-
/** @hidden */
|
|
15
|
-
constructor(_cdr, _rtlService) {
|
|
16
|
-
this._cdr = _cdr;
|
|
17
|
-
this._rtlService = _rtlService;
|
|
18
|
-
/** Whether to disable drag & drop */
|
|
19
|
-
this.disableKeyboardDragDrop = false;
|
|
20
|
-
/** Used to apply indexes when moving between groups */
|
|
21
|
-
this.orientation = 'vertical';
|
|
22
|
-
/** @hidden */
|
|
23
|
-
this._onDndItemFocus$ = new Subject();
|
|
24
|
-
/** Custom function to call when moving item inside the group */
|
|
25
|
-
this.customMoveFn = (group, fromIndex, toIndex) => moveItemInArray(group, fromIndex, toIndex);
|
|
26
|
-
/** Custom function to call when moving item between groups */
|
|
27
|
-
this.customTransferFn = (group, nextGroup, fromIndex, toIndex) => transferArrayItem(group, nextGroup, fromIndex, toIndex);
|
|
28
|
-
}
|
|
29
|
-
/** Process drag & drop */
|
|
30
|
-
processDragDrop(event, itemIndex, groupIndex) {
|
|
31
|
-
if (this.disableKeyboardDragDrop || !event.altKey) {
|
|
32
|
-
return;
|
|
33
|
-
}
|
|
34
|
-
const isRtl = this._rtlService.rtl.value;
|
|
35
|
-
const group = this.groups[groupIndex];
|
|
36
|
-
const indexInNextGroup = this.orientation === 'vertical' ? 0 : itemIndex;
|
|
37
|
-
const nextGroupExists = this.groups.length > groupIndex + 1;
|
|
38
|
-
const prevGroupExists = !!groupIndex;
|
|
39
|
-
if (KeyUtil.isKeyCode(event, RIGHT_ARROW) && (isRtl ? prevGroupExists : nextGroupExists)) {
|
|
40
|
-
event.preventDefault();
|
|
41
|
-
const nextGroupIndex = groupIndex + (isRtl ? -1 : 1);
|
|
42
|
-
const nextGroup = this.groups[nextGroupIndex];
|
|
43
|
-
this.customTransferFn(group, nextGroup, itemIndex, indexInNextGroup);
|
|
44
|
-
this._focusDndItem(nextGroupIndex, indexInNextGroup);
|
|
45
|
-
}
|
|
46
|
-
else if (KeyUtil.isKeyCode(event, LEFT_ARROW) && (isRtl ? nextGroupExists : prevGroupExists)) {
|
|
47
|
-
event.preventDefault();
|
|
48
|
-
const nextGroupIndex = groupIndex + (isRtl ? 1 : -1);
|
|
49
|
-
const nextGroup = this.groups[nextGroupIndex];
|
|
50
|
-
this.customTransferFn(group, nextGroup, itemIndex, indexInNextGroup);
|
|
51
|
-
this._focusDndItem(nextGroupIndex, indexInNextGroup);
|
|
52
|
-
}
|
|
53
|
-
else if (KeyUtil.isKeyCode(event, DOWN_ARROW)) {
|
|
54
|
-
event.preventDefault();
|
|
55
|
-
this.customMoveFn(group, itemIndex, itemIndex + 1);
|
|
56
|
-
this._focusDndItem(groupIndex, itemIndex + 1);
|
|
57
|
-
}
|
|
58
|
-
else if (KeyUtil.isKeyCode(event, UP_ARROW)) {
|
|
59
|
-
event.preventDefault();
|
|
60
|
-
this.customMoveFn(group, itemIndex, itemIndex - 1);
|
|
61
|
-
this._focusDndItem(groupIndex, itemIndex - 1);
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
/** @hidden Focus after moving elements with keyboard */
|
|
65
|
-
_focusDndItem(groupIndex, itemIndex) {
|
|
66
|
-
this._cdr.detectChanges();
|
|
67
|
-
this._onDndItemFocus$.next([groupIndex, itemIndex]);
|
|
68
|
-
}
|
|
69
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: DndKeyboardGroupDirective, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.RtlService, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
70
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.0.3", type: DndKeyboardGroupDirective, selector: "[fdkDndKeyboardGroup], [fdDndKeyboardGroup]", inputs: { groups: "groups", disableKeyboardDragDrop: "disableKeyboardDragDrop", orientation: "orientation", customMoveFn: "customMoveFn", customTransferFn: "customTransferFn" }, ngImport: i0 }); }
|
|
71
|
-
}
|
|
72
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: DndKeyboardGroupDirective, decorators: [{
|
|
73
|
-
type: Directive,
|
|
74
|
-
args: [{ selector: '[fdkDndKeyboardGroup], [fdDndKeyboardGroup]' }]
|
|
75
|
-
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.RtlService, decorators: [{
|
|
76
|
-
type: Optional
|
|
77
|
-
}] }], propDecorators: { groups: [{
|
|
78
|
-
type: Input
|
|
79
|
-
}], disableKeyboardDragDrop: [{
|
|
80
|
-
type: Input
|
|
81
|
-
}], orientation: [{
|
|
82
|
-
type: Input
|
|
83
|
-
}], customMoveFn: [{
|
|
84
|
-
type: Input
|
|
85
|
-
}], customTransferFn: [{
|
|
86
|
-
type: Input
|
|
87
|
-
}] } });
|
|
88
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dnd-keyboard-group.directive.js","sourceRoot":"","sources":["../../../../../../../libs/cdk/utils/drag-and-drop/dnd-keyboard-group/dnd-keyboard-group.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { moveItemInArray, transferArrayItem } from '@angular/cdk/drag-drop';\nimport { DOWN_ARROW, LEFT_ARROW, RIGHT_ARROW, UP_ARROW } from '@angular/cdk/keycodes';\nimport { ChangeDetectorRef, Directive, Input, Optional } from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { KeyUtil } from '../../functions';\nimport { RtlService } from '../../services/rtl.service';\n\n/**\n * This directive is used to provide drag & drop with keyboard support.\n * It should be used together with directive fdDndKeyboardItem.\n */\n@Directive({ selector: '[fdkDndKeyboardGroup], [fdDndKeyboardGroup]' })\nexport class DndKeyboardGroupDirective {\n    /** Group of items */\n    @Input()\n    groups: any[][];\n\n    /** Whether to disable drag & drop */\n    @Input()\n    disableKeyboardDragDrop = false;\n\n    /** Used to apply indexes when moving between groups */\n    @Input()\n    orientation: 'horizontal' | 'vertical' = 'vertical';\n\n    /** @hidden */\n    _onDndItemFocus$ = new Subject<[number, number]>();\n\n    /** @hidden */\n    constructor(\n        private readonly _cdr: ChangeDetectorRef,\n        @Optional() private readonly _rtlService: RtlService\n    ) {}\n\n    /** Custom function to call when moving item inside the group */\n    @Input()\n    customMoveFn = (group: any[], fromIndex: number, toIndex: number): void =>\n        moveItemInArray(group, fromIndex, toIndex);\n\n    /** Custom function to call when moving item between groups */\n    @Input()\n    customTransferFn = (group: any[], nextGroup: any[], fromIndex: number, toIndex: number): void =>\n        transferArrayItem(group, nextGroup, fromIndex, toIndex);\n\n    /** Process drag & drop */\n    processDragDrop(event: KeyboardEvent, itemIndex: number, groupIndex: number): void {\n        if (this.disableKeyboardDragDrop || !event.altKey) {\n            return;\n        }\n\n        const isRtl = this._rtlService.rtl.value;\n\n        const group = this.groups[groupIndex];\n        const indexInNextGroup = this.orientation === 'vertical' ? 0 : itemIndex;\n\n        const nextGroupExists = this.groups.length > groupIndex + 1;\n        const prevGroupExists = !!groupIndex;\n\n        if (KeyUtil.isKeyCode(event, RIGHT_ARROW) && (isRtl ? prevGroupExists : nextGroupExists)) {\n            event.preventDefault();\n\n            const nextGroupIndex = groupIndex + (isRtl ? -1 : 1);\n            const nextGroup = this.groups[nextGroupIndex];\n\n            this.customTransferFn(group, nextGroup, itemIndex, indexInNextGroup);\n            this._focusDndItem(nextGroupIndex, indexInNextGroup);\n        } else if (KeyUtil.isKeyCode(event, LEFT_ARROW) && (isRtl ? nextGroupExists : prevGroupExists)) {\n            event.preventDefault();\n\n            const nextGroupIndex = groupIndex + (isRtl ? 1 : -1);\n            const nextGroup = this.groups[nextGroupIndex];\n\n            this.customTransferFn(group, nextGroup, itemIndex, indexInNextGroup);\n            this._focusDndItem(nextGroupIndex, indexInNextGroup);\n        } else if (KeyUtil.isKeyCode(event, DOWN_ARROW)) {\n            event.preventDefault();\n\n            this.customMoveFn(group, itemIndex, itemIndex + 1);\n            this._focusDndItem(groupIndex, itemIndex + 1);\n        } else if (KeyUtil.isKeyCode(event, UP_ARROW)) {\n            event.preventDefault();\n\n            this.customMoveFn(group, itemIndex, itemIndex - 1);\n            this._focusDndItem(groupIndex, itemIndex - 1);\n        }\n    }\n\n    /** @hidden Focus after moving elements with keyboard */\n    private _focusDndItem(groupIndex: number, itemIndex: number): void {\n        this._cdr.detectChanges();\n\n        this._onDndItemFocus$.next([groupIndex, itemIndex]);\n    }\n}\n"]}
|
|
@@ -1,83 +0,0 @@
|
|
|
1
|
-
import { Directive, ElementRef, HostListener, Input } from '@angular/core';
|
|
2
|
-
import { Subject } from 'rxjs';
|
|
3
|
-
import { DndKeyboardGroupDirective } from '../dnd-keyboard-group/dnd-keyboard-group.directive';
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
import * as i1 from "../dnd-keyboard-group/dnd-keyboard-group.directive";
|
|
6
|
-
/**
|
|
7
|
-
* This directive is used to provide drag & drop with keyboard support.
|
|
8
|
-
* It should be used together with directive fdDndKeyboardGroup.
|
|
9
|
-
* We are using _groups from fdDndKeyboardGroup and adding a possibility to move cards.
|
|
10
|
-
* Please see example below:
|
|
11
|
-
* @Component({
|
|
12
|
-
* selector: 'cdk-drag-drop-example',
|
|
13
|
-
* template: `<div
|
|
14
|
-
* cdkDragListGroup
|
|
15
|
-
* fdDndKeyboardGroup
|
|
16
|
-
* [groups]="groups"
|
|
17
|
-
* >
|
|
18
|
-
* <div
|
|
19
|
-
* *ngFor="let group of groups; let groupIndex = index"
|
|
20
|
-
* cdkDragList
|
|
21
|
-
* >
|
|
22
|
-
* Group #{{ groupIndex }}
|
|
23
|
-
* <div
|
|
24
|
-
* *ngFor="let item of group; let index = index"
|
|
25
|
-
* cdkDrag
|
|
26
|
-
* fdDndKeyboardItem
|
|
27
|
-
* [itemIndex]="index"
|
|
28
|
-
* [groupIndex]="groupIndex"
|
|
29
|
-
* [dndKeyboardDisabled]="flag for disable/enable keyboard navigation if needed"
|
|
30
|
-
* tabindex="0"
|
|
31
|
-
* >
|
|
32
|
-
* Item #{{ item }}
|
|
33
|
-
* </div>
|
|
34
|
-
* </div>
|
|
35
|
-
* </div>`,
|
|
36
|
-
* })
|
|
37
|
-
* export class CdkDragDropExample {
|
|
38
|
-
* groups = [
|
|
39
|
-
* [1, 2, 3],
|
|
40
|
-
* [4, 5, 6],
|
|
41
|
-
* ];
|
|
42
|
-
* }
|
|
43
|
-
*/
|
|
44
|
-
export class DndKeyboardItemDirective {
|
|
45
|
-
/** @hidden */
|
|
46
|
-
constructor(_dndGroup, _elementRef) {
|
|
47
|
-
this._dndGroup = _dndGroup;
|
|
48
|
-
this._elementRef = _elementRef;
|
|
49
|
-
/** @hidden */
|
|
50
|
-
this._onDestroy$ = new Subject();
|
|
51
|
-
}
|
|
52
|
-
/** @hidden */
|
|
53
|
-
_onKeyDown(event) {
|
|
54
|
-
this._dndGroup.processDragDrop(event, this.itemIndex, this.groupIndex);
|
|
55
|
-
}
|
|
56
|
-
/** @hidden */
|
|
57
|
-
ngOnInit() {
|
|
58
|
-
this._dndGroup._onDndItemFocus$.subscribe(([groupIndex, itemIndex]) => {
|
|
59
|
-
if (this.groupIndex === groupIndex && this.itemIndex === itemIndex) {
|
|
60
|
-
this._elementRef.nativeElement.focus();
|
|
61
|
-
}
|
|
62
|
-
});
|
|
63
|
-
}
|
|
64
|
-
/** @hidden */
|
|
65
|
-
ngOnDestroy() {
|
|
66
|
-
this._onDestroy$.next();
|
|
67
|
-
this._onDestroy$.complete();
|
|
68
|
-
}
|
|
69
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: DndKeyboardItemDirective, deps: [{ token: i1.DndKeyboardGroupDirective }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
70
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.0.3", type: DndKeyboardItemDirective, selector: "[fdkDndKeyboardItem], [fdDndKeyboardItem]", inputs: { itemIndex: "itemIndex", groupIndex: "groupIndex" }, host: { listeners: { "keydown": "_onKeyDown($event)" } }, ngImport: i0 }); }
|
|
71
|
-
}
|
|
72
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: DndKeyboardItemDirective, decorators: [{
|
|
73
|
-
type: Directive,
|
|
74
|
-
args: [{ selector: '[fdkDndKeyboardItem], [fdDndKeyboardItem]' }]
|
|
75
|
-
}], ctorParameters: () => [{ type: i1.DndKeyboardGroupDirective }, { type: i0.ElementRef }], propDecorators: { itemIndex: [{
|
|
76
|
-
type: Input
|
|
77
|
-
}], groupIndex: [{
|
|
78
|
-
type: Input
|
|
79
|
-
}], _onKeyDown: [{
|
|
80
|
-
type: HostListener,
|
|
81
|
-
args: ['keydown', ['$event']]
|
|
82
|
-
}] } });
|
|
83
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG5kLWtleWJvYXJkLWl0ZW0uZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jZGsvdXRpbHMvZHJhZy1hbmQtZHJvcC9kbmQta2V5Ym9hcmQtaXRlbS9kbmQta2V5Ym9hcmQtaXRlbS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBcUIsTUFBTSxlQUFlLENBQUM7QUFDOUYsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUUvQixPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSxvREFBb0QsQ0FBQzs7O0FBRS9GOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBcUNHO0FBRUgsTUFBTSxPQUFPLHdCQUF3QjtJQVlqQyxjQUFjO0lBQ2QsWUFDcUIsU0FBb0MsRUFDcEMsV0FBdUI7UUFEdkIsY0FBUyxHQUFULFNBQVMsQ0FBMkI7UUFDcEMsZ0JBQVcsR0FBWCxXQUFXLENBQVk7UUFONUMsY0FBYztRQUNHLGdCQUFXLEdBQUcsSUFBSSxPQUFPLEVBQVEsQ0FBQztJQU1oRCxDQUFDO0lBRUosY0FBYztJQUVkLFVBQVUsQ0FBQyxLQUFvQjtRQUMzQixJQUFJLENBQUMsU0FBUyxDQUFDLGVBQWUsQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLFNBQVMsRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7SUFDM0UsQ0FBQztJQUVELGNBQWM7SUFDZCxRQUFRO1FBQ0osSUFBSSxDQUFDLFNBQVMsQ0FBQyxnQkFBZ0IsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLFVBQVUsRUFBRSxTQUFTLENBQUMsRUFBRSxFQUFFO1lBQ2xFLElBQUksSUFBSSxDQUFDLFVBQVUsS0FBSyxVQUFVLElBQUksSUFBSSxDQUFDLFNBQVMsS0FBSyxTQUFTLEVBQUUsQ0FBQztnQkFDakUsSUFBSSxDQUFDLFdBQVcsQ0FBQyxhQUFhLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDM0MsQ0FBQztRQUNMLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVELGNBQWM7SUFDZCxXQUFXO1FBQ1AsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUN4QixJQUFJLENBQUMsV0FBVyxDQUFDLFFBQVEsRUFBRSxDQUFDO0lBQ2hDLENBQUM7OEdBckNRLHdCQUF3QjtrR0FBeEIsd0JBQXdCOzsyRkFBeEIsd0JBQXdCO2tCQURwQyxTQUFTO21CQUFDLEVBQUUsUUFBUSxFQUFFLDJDQUEyQyxFQUFFO3VIQUloRSxTQUFTO3NCQURSLEtBQUs7Z0JBS04sVUFBVTtzQkFEVCxLQUFLO2dCQWNOLFVBQVU7c0JBRFQsWUFBWTt1QkFBQyxTQUFTLEVBQUUsQ0FBQyxRQUFRLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIEhvc3RMaXN0ZW5lciwgSW5wdXQsIE9uRGVzdHJveSwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTdWJqZWN0IH0gZnJvbSAncnhqcyc7XG5cbmltcG9ydCB7IERuZEtleWJvYXJkR3JvdXBEaXJlY3RpdmUgfSBmcm9tICcuLi9kbmQta2V5Ym9hcmQtZ3JvdXAvZG5kLWtleWJvYXJkLWdyb3VwLmRpcmVjdGl2ZSc7XG5cbi8qKlxuICogVGhpcyBkaXJlY3RpdmUgaXMgdXNlZCB0byBwcm92aWRlIGRyYWcgJiBkcm9wIHdpdGgga2V5Ym9hcmQgc3VwcG9ydC5cbiAqIEl0IHNob3VsZCBiZSB1c2VkIHRvZ2V0aGVyIHdpdGggZGlyZWN0aXZlIGZkRG5kS2V5Ym9hcmRHcm91cC5cbiAqIFdlIGFyZSB1c2luZyBfZ3JvdXBzIGZyb20gZmREbmRLZXlib2FyZEdyb3VwIGFuZCBhZGRpbmcgYSBwb3NzaWJpbGl0eSB0byBtb3ZlIGNhcmRzLlxuICogUGxlYXNlIHNlZSBleGFtcGxlIGJlbG93OlxuICogQENvbXBvbmVudCh7XG4gKiBzZWxlY3RvcjogJ2Nkay1kcmFnLWRyb3AtZXhhbXBsZScsXG4gKiB0ZW1wbGF0ZTogYDxkaXZcbiAqICAgICAgICAgICAgICAgY2RrRHJhZ0xpc3RHcm91cFxuICogICAgICAgICAgICAgICBmZERuZEtleWJvYXJkR3JvdXBcbiAqICAgICAgICAgICAgICAgW2dyb3Vwc109XCJncm91cHNcIlxuICogICAgICAgICAgID5cbiAqICAgICAgICAgICAgICAgPGRpdlxuICogICAgICAgICAgICAgICAgICAgKm5nRm9yPVwibGV0IGdyb3VwIG9mIGdyb3VwczsgbGV0IGdyb3VwSW5kZXggPSBpbmRleFwiXG4gKiAgICAgICAgICAgICAgICAgICBjZGtEcmFnTGlzdFxuICogICAgICAgICAgICAgICA+XG4gKiAgICAgICAgICAgICAgICAgICBHcm91cCAje3sgZ3JvdXBJbmRleCB9fVxuICogICAgICAgICAgICAgICAgICAgPGRpdlxuICogICAgICAgICAgICAgICAgICAgICAgICpuZ0Zvcj1cImxldCBpdGVtIG9mIGdyb3VwOyBsZXQgaW5kZXggPSBpbmRleFwiXG4gKiAgICAgICAgICAgICAgICAgICAgICAgY2RrRHJhZ1xuICogICAgICAgICAgICAgICAgICAgICAgIGZkRG5kS2V5Ym9hcmRJdGVtXG4gKiAgICAgICAgICAgICAgICAgICAgICAgW2l0ZW1JbmRleF09XCJpbmRleFwiXG4gKiAgICAgICAgICAgICAgICAgICAgICAgW2dyb3VwSW5kZXhdPVwiZ3JvdXBJbmRleFwiXG4gKiAgICAgICAgICAgICAgICAgICAgICAgW2RuZEtleWJvYXJkRGlzYWJsZWRdPVwiZmxhZyBmb3IgZGlzYWJsZS9lbmFibGUga2V5Ym9hcmQgbmF2aWdhdGlvbiBpZiBuZWVkZWRcIlxuICogICAgICAgICAgICAgICAgICAgICAgIHRhYmluZGV4PVwiMFwiXG4gKiAgICAgICAgICAgICAgICAgICA+XG4gKiAgICAgICAgICAgICAgICAgICAgICAgSXRlbSAje3sgaXRlbSB9fVxuICogICAgICAgICAgICAgICAgICAgPC9kaXY+XG4gKiAgICAgICAgICAgICAgIDwvZGl2PlxuICogICAgICAgICAgIDwvZGl2PmAsXG4gKiB9KVxuICogZXhwb3J0IGNsYXNzIENka0RyYWdEcm9wRXhhbXBsZSB7XG4gKiAgIGdyb3VwcyA9IFtcbiAqICAgICAgICBbMSwgMiwgM10sXG4gKiAgICAgICAgWzQsIDUsIDZdLFxuICogICAgICBdO1xuICogICB9XG4gKi9cbkBEaXJlY3RpdmUoeyBzZWxlY3RvcjogJ1tmZGtEbmRLZXlib2FyZEl0ZW1dLCBbZmREbmRLZXlib2FyZEl0ZW1dJyB9KVxuZXhwb3J0IGNsYXNzIERuZEtleWJvYXJkSXRlbURpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcbiAgICAvKiogaXRlbSBpbmRleCBpbiBncm91cChjb2x1bW4pICovXG4gICAgQElucHV0KClcbiAgICBpdGVtSW5kZXg6IG51bWJlcjtcblxuICAgIC8qKiBncm91cChjb2x1bW4pIGluZGV4ICovXG4gICAgQElucHV0KClcbiAgICBncm91cEluZGV4OiBudW1iZXI7XG5cbiAgICAvKiogQGhpZGRlbiAqL1xuICAgIHByaXZhdGUgcmVhZG9ubHkgX29uRGVzdHJveSQgPSBuZXcgU3ViamVjdDx2b2lkPigpO1xuXG4gICAgLyoqIEBoaWRkZW4gKi9cbiAgICBjb25zdHJ1Y3RvcihcbiAgICAgICAgcHJpdmF0ZSByZWFkb25seSBfZG5kR3JvdXA6IERuZEtleWJvYXJkR3JvdXBEaXJlY3RpdmUsXG4gICAgICAgIHByaXZhdGUgcmVhZG9ubHkgX2VsZW1lbnRSZWY6IEVsZW1lbnRSZWZcbiAgICApIHt9XG5cbiAgICAvKiogQGhpZGRlbiAqL1xuICAgIEBIb3N0TGlzdGVuZXIoJ2tleWRvd24nLCBbJyRldmVudCddKVxuICAgIF9vbktleURvd24oZXZlbnQ6IEtleWJvYXJkRXZlbnQpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5fZG5kR3JvdXAucHJvY2Vzc0RyYWdEcm9wKGV2ZW50LCB0aGlzLml0ZW1JbmRleCwgdGhpcy5ncm91cEluZGV4KTtcbiAgICB9XG5cbiAgICAvKiogQGhpZGRlbiAqL1xuICAgIG5nT25Jbml0KCk6IHZvaWQge1xuICAgICAgICB0aGlzLl9kbmRHcm91cC5fb25EbmRJdGVtRm9jdXMkLnN1YnNjcmliZSgoW2dyb3VwSW5kZXgsIGl0ZW1JbmRleF0pID0+IHtcbiAgICAgICAgICAgIGlmICh0aGlzLmdyb3VwSW5kZXggPT09IGdyb3VwSW5kZXggJiYgdGhpcy5pdGVtSW5kZXggPT09IGl0ZW1JbmRleCkge1xuICAgICAgICAgICAgICAgIHRoaXMuX2VsZW1lbnRSZWYubmF0aXZlRWxlbWVudC5mb2N1cygpO1xuICAgICAgICAgICAgfVxuICAgICAgICB9KTtcbiAgICB9XG5cbiAgICAvKiogQGhpZGRlbiAqL1xuICAgIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgICAgICB0aGlzLl9vbkRlc3Ryb3kkLm5leHQoKTtcbiAgICAgICAgdGhpcy5fb25EZXN0cm95JC5jb21wbGV0ZSgpO1xuICAgIH1cbn1cbiJdfQ==
|