@klippa/ngx-enhancy-forms 18.25.3 → 18.25.4

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.
@@ -108,21 +108,23 @@ export class SortableItemsComponent extends ValueAccessorBase {
108
108
  };
109
109
  }
110
110
  ngAfterViewInit() {
111
+ this.setDragItemListeners();
111
112
  this.dragItems.changes.subscribe(() => {
112
- this.dragItems.forEach(e => {
113
- this.ngZone.runOutsideAngular(() => {
114
- e.nativeElement.removeEventListener('dragstart', this.onDragStart);
115
- e.nativeElement.removeEventListener('dragover', this.onDragOver);
116
- e.nativeElement.removeEventListener('dragenter', this.onDragEnter);
117
- e.nativeElement.removeEventListener('dragend', this.onDragEnd);
118
- e.nativeElement.addEventListener('dragstart', this.onDragStart);
119
- e.nativeElement.addEventListener('dragover', this.onDragOver);
120
- e.nativeElement.addEventListener('dragenter', this.onDragEnter);
121
- e.nativeElement.addEventListener('dragend', this.onDragEnd);
122
- this.dragItems.forEach((dragItem, i) => {
123
- dragItem.nativeElement.querySelector('.visual').style.transform = `translateY(0%)`;
124
- });
125
- });
113
+ this.setDragItemListeners();
114
+ });
115
+ }
116
+ setDragItemListeners() {
117
+ this.dragItems.forEach(e => {
118
+ this.ngZone.runOutsideAngular(() => {
119
+ e.nativeElement.removeEventListener('dragstart', this.onDragStart);
120
+ e.nativeElement.removeEventListener('dragover', this.onDragOver);
121
+ e.nativeElement.removeEventListener('dragenter', this.onDragEnter);
122
+ e.nativeElement.removeEventListener('dragend', this.onDragEnd);
123
+ e.nativeElement.addEventListener('dragstart', this.onDragStart);
124
+ e.nativeElement.addEventListener('dragover', this.onDragOver);
125
+ e.nativeElement.addEventListener('dragenter', this.onDragEnter);
126
+ e.nativeElement.addEventListener('dragend', this.onDragEnd);
127
+ e.nativeElement.querySelector('.visual').style.transform = `translateY(0%)`;
126
128
  });
127
129
  });
128
130
  }
@@ -184,4 +186,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
184
186
  type: ViewChildren,
185
187
  args: ['dragItem']
186
188
  }] } });
187
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sortable-items.component.js","sourceRoot":"","sources":["../../../../../../../projects/klippa/ngx-enhancy-forms/src/lib/elements/sortable-items/sortable-items.component.ts","../../../../../../../projects/klippa/ngx-enhancy-forms/src/lib/elements/sortable-items/sortable-items.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n\tAfterViewInit,\n\tComponent,\n\tContentChild,\n\tElementRef,\n\tHost,\n\tInput,\n\tNgZone,\n\tOnInit,\n\tOptional,\n\tQueryList,\n\tTemplateRef,\n\tViewChildren,\n} from '@angular/core';\nimport {ControlContainer, NG_VALUE_ACCESSOR} from '@angular/forms';\nimport {isValueSet} from '../../util/values';\nimport {ValueAccessorBase} from '../value-accessor-base/value-accessor-base.component';\nimport {FormElementComponent} from '../../form/form-element/form-element.component';\n\n@Component({\n\tselector: 'klp-form-sortable-items',\n\ttemplateUrl: './sortable-items.component.html',\n\tstyleUrls: ['./sortable-items.component.scss'],\n\tproviders: [\n\t\t{\n\t\t\tprovide: NG_VALUE_ACCESSOR,\n\t\t\tuseExisting: SortableItemsComponent,\n\t\t\tmulti: true,\n\t\t},\n\t],\n})\nexport class SortableItemsComponent\n\textends ValueAccessorBase<Array<any>>\n\timplements OnInit, AfterViewInit\n{\n\t@ContentChild(TemplateRef) template: TemplateRef<any>;\n\t@Input() sortableItemSize: 'sm' | 'lg' = 'lg';\n\n\t@ViewChildren('dragItem') dragItems: QueryList<ElementRef>;\n\tpublic dragSourceIndex: number;\n\tprivate currentDragPosition: number;\n\n\tprivate scrollInterval = null;\n\n\tconstructor(\n\t\t@Host() @Optional() protected parent: FormElementComponent,\n\t\t@Host() @Optional() protected controlContainer: ControlContainer,\n\t\tprivate ngZone: NgZone)\n\t{\n\t\tsuper(parent, controlContainer);\n\t}\n\n\tngAfterViewInit(): void {\n\t\tthis.dragItems.changes.subscribe(() => {\n\t\t\tthis.dragItems.forEach(e => {\n\t\t\t\tthis.ngZone.runOutsideAngular(() => {\n\t\t\t\t\te.nativeElement.removeEventListener('dragstart', this.onDragStart);\n\t\t\t\t\te.nativeElement.removeEventListener('dragover', this.onDragOver);\n\t\t\t\t\te.nativeElement.removeEventListener('dragenter', this.onDragEnter);\n\t\t\t\t\te.nativeElement.removeEventListener('dragend', this.onDragEnd);\n\n\t\t\t\t\te.nativeElement.addEventListener('dragstart', this.onDragStart);\n\t\t\t\t\te.nativeElement.addEventListener('dragover', this.onDragOver);\n\t\t\t\t\te.nativeElement.addEventListener('dragenter', this.onDragEnter);\n\t\t\t\t\te.nativeElement.addEventListener('dragend', this.onDragEnd);\n\n\t\t\t\t\tthis.dragItems.forEach((dragItem, i) => {\n\t\t\t\t\t\tdragItem.nativeElement.querySelector('.visual').style.transform = `translateY(0%)`;\n\t\t\t\t\t});\n\n\t\t\t\t});\n\t\t\t});\n\t\t});\n\t}\n\n\tprivate onDragOver = (ev) => {\n\t\tev.preventDefault();\n\t}\n\n\tprivate onDragEnter = (ev) => {\n\t\tif (ev.clientY < 80) {\n\t\t\tthis.scrollPage(40);\n\t\t} else if (window.innerHeight - ev.clientY < 80) {\n\t\t\tthis.scrollPage(-40);\n\t\t} else {\n\t\t\tthis.stopScrolling();\n\t\t}\n\t\tev.dataTransfer.dropEffect = 'move';\n\t\tconst targetIndex = this.dragItems.map(e => e.nativeElement).findIndex(e => e === (ev.target as HTMLElement));\n\t\tif (targetIndex === -1) {\n\t\t\treturn;\n\t\t}\n\t\tthis.currentDragPosition = targetIndex;\n\t\tthis.dragItems.forEach((dragItem, i) => {\n\t\t\tif (this.dragSourceIndex === i) {\n\n\t\t\t\tif (this.dragSourceIndex > this.currentDragPosition) {\n\t\t\t\t\tconst heightsAbove = this.dragItems.filter((e, i) => {\n\t\t\t\t\t\tif (i >= this.dragSourceIndex) {\n\t\t\t\t\t\t\treturn false;\n\t\t\t\t\t\t}\n\t\t\t\t\t\treturn i > this.currentDragPosition - 1;\n\t\t\t\t\t}).reduce((acc, cur, i) => {\n\t\t\t\t\t\treturn acc + cur.nativeElement.getBoundingClientRect().height;\n\t\t\t\t\t}, 0);\n\t\t\t\t\tdragItem.nativeElement.querySelector('.visual').style.transform = `translateY(${-heightsAbove}px)`;\n\t\t\t\t}\n\n\t\t\t\telse if (this.dragSourceIndex < this.currentDragPosition) {\n\t\t\t\t\tconst heightsAbove = this.dragItems.filter((e, i) => {\n\t\t\t\t\t\tif (i <= this.dragSourceIndex) {\n\t\t\t\t\t\t\treturn false;\n\t\t\t\t\t\t}\n\t\t\t\t\t\treturn i <= this.currentDragPosition;\n\t\t\t\t\t}).reduce((acc, cur, i) => {\n\t\t\t\t\t\treturn acc + cur.nativeElement.getBoundingClientRect().height;\n\t\t\t\t\t}, 0);\n\t\t\t\t\tdragItem.nativeElement.querySelector('.visual').style.transform = `translateY(${heightsAbove}px)`;\n\t\t\t\t}\n\n\t\t\t\telse {\n\t\t\t\t\tdragItem.nativeElement.querySelector('.visual').style.transform = `translateY(${0}px)`;\n\t\t\t\t}\n\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tconst heightOfCurrentlyDraggedItem = (this.dragItems.get(this.dragSourceIndex).nativeElement.getBoundingClientRect().height);\n\t\t\tif (this.shouldShoveDown(i)) {\n\t\t\t\tdragItem.nativeElement.querySelector('.visual').style.transform = `translateY(${heightOfCurrentlyDraggedItem}px)`;\n\t\t\t}\n\t\t\telse if (this.shouldShoveUp(i)) {\n\t\t\t\tdragItem.nativeElement.querySelector('.visual').style.transform = `translateY(${-heightOfCurrentlyDraggedItem}px)`;\n\t\t\t}\n\t\t\telse {\n\t\t\t\tdragItem.nativeElement.querySelector('.visual').style.transform = `translateY(0%)`;\n\t\t\t}\n\t\t});\n\n\t\tthis.currentDragPosition = targetIndex;\n\t}\n\n\tprivate onDragStart = (ev) => {\n\t\tev.dataTransfer.effectAllowed = 'move';\n\t\tthis.ngZone.run(() => {\n\t\t\tthis.dragSourceIndex = this.dragItems.map(e => e.nativeElement).findIndex(e => e === ev.target);\n\t\t\tthis.currentDragPosition = this.dragSourceIndex;\n\t\t});\n\t};\n\n\tprivate onDragEnd = (ev) => {\n\t\tthis.stopScrolling();\n\t\tconst movedElement = this.innerValue[this.dragSourceIndex];\n\t\tconst isMovedToLastPlace = this.currentDragPosition === this.innerValue.length - 1;\n\t\tthis.ngZone.run(() => {\n\t\t\tthis.innerValue = this.innerValue\n\t\t\t.filter((e, i) => i !== this.dragSourceIndex)\n\t\t\t.reduce((acc, cur, i) => {\n\t\t\t\tif (i === this.currentDragPosition) {\n\t\t\t\t\treturn [...acc, movedElement, cur];\n\t\t\t\t}\n\t\t\t\treturn [...acc, cur];\n\t\t\t}, []);\n\t\t\tif (isMovedToLastPlace) {\n\t\t\t\tthis.innerValue = [...this.innerValue, movedElement];\n\t\t\t}\n\t\t\tthis.dragItems.forEach((dragItem, i) => {\n\t\t\t\tdragItem.nativeElement.querySelector('.visual').style.transform = `translateY(0%)`;\n\t\t\t});\n\t\t\tthis.currentDragPosition = -1;\n\t\t\tthis.dragSourceIndex = -1;\n\t\t\tthis.setInnerValueAndNotify(this.innerValue);\n\t\t});\n\t}\n\n\tshouldShoveDown(index: number): boolean {\n\t\treturn this.dragSourceIndex > index && this.currentDragPosition <= index;\n\t}\n\n\tshouldShoveUp(index: number): boolean {\n\t\treturn this.dragSourceIndex < index && this.currentDragPosition >= index;\n\t}\n\n\tprivate scrollPage(scrollAmount: number): void {\n\t\tif (!isValueSet(this.scrollInterval)) {\n\t\t\tthis.scrollInterval = setInterval(() => {\n\t\t\t\twindow.scroll({\n\t\t\t\t\ttop: document.scrollingElement.scrollTop - scrollAmount,\n\t\t\t\t\tbehavior: 'smooth',\n\t\t\t\t});\n\t\t\t\tif (document.scrollingElement.scrollTop <= 100) {\n\t\t\t\t\tthis.stopScrolling();\n\t\t\t\t}\n\t\t\t}, 100);\n\t\t}\n\t}\n\n\tprivate stopScrolling(): void {\n\t\tclearInterval(this.scrollInterval);\n\t\tthis.scrollInterval = null;\n\t}\n}\n","<ng-template #listItem>\n\t<li *ngFor=\"let item of innerValue; index as index\"\n\t\t\tclass=\"sortableItem\"\n\t\t\t[draggable]=\"!disabled\"\n\t\t\t[ngClass]=\"{\n\t\t\tlargeSortableItem: sortableItemSize === 'lg',\n\t\t \tsmallSortableItem: sortableItemSize === 'sm',\n\t\t \t}\"\n\t\t\t#dragItem\n\t>\n\t\t<div class=\"visual\">\n\t\t\t<ng-container [ngTemplateOutlet]=\"template\" [ngTemplateOutletContext]=\"{ item: item, index:index }\"></ng-container>\n\t\t</div>\n\t</li>\n</ng-template>\n\n<ol *ngIf='!disabled'\n\t\tclass=\"itemsContainer\"\n\t\t[ngClass]=\"{dragInProgress: dragSourceIndex >= 0}\"\n>\n\t<ng-container *ngTemplateOutlet=\"listItem\"></ng-container>\n</ol>\n\n<ol *ngIf='disabled' class=\"itemsContainer disabled-mouse-cursor\">\n\t<ng-container *ngTemplateOutlet=\"listItem\"></ng-container>\n</ol>\n"]}
189
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sortable-items.component.js","sourceRoot":"","sources":["../../../../../../../projects/klippa/ngx-enhancy-forms/src/lib/elements/sortable-items/sortable-items.component.ts","../../../../../../../projects/klippa/ngx-enhancy-forms/src/lib/elements/sortable-items/sortable-items.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEN,SAAS,EACT,YAAY,EAEZ,IAAI,EACJ,KAAK,EAGL,QAAQ,EAER,WAAW,EACX,YAAY,GACZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAmB,iBAAiB,EAAC,MAAM,gBAAgB,CAAC;AACnE,OAAO,EAAC,UAAU,EAAC,MAAM,mBAAmB,CAAC;AAC7C,OAAO,EAAC,iBAAiB,EAAC,MAAM,sDAAsD,CAAC;;;;;AAevF,MAAM,OAAO,sBACZ,SAAQ,iBAA6B;IAYrC,YAC+B,MAA4B,EAC5B,gBAAkC,EACxD,MAAc;QAEtB,KAAK,CAAC,MAAM,EAAE,gBAAgB,CAAC,CAAC;QAJF,WAAM,GAAN,MAAM,CAAsB;QAC5B,qBAAgB,GAAhB,gBAAgB,CAAkB;QACxD,WAAM,GAAN,MAAM,CAAQ;QAXd,qBAAgB,GAAgB,IAAI,CAAC;QAMtC,mBAAc,GAAG,IAAI,CAAC;QAmCtB,eAAU,GAAG,CAAC,EAAE,EAAE,EAAE;YAC3B,EAAE,CAAC,cAAc,EAAE,CAAC;QACrB,CAAC,CAAA;QAEO,gBAAW,GAAG,CAAC,EAAE,EAAE,EAAE;YAC5B,IAAI,EAAE,CAAC,OAAO,GAAG,EAAE,EAAE,CAAC;gBACrB,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;YACrB,CAAC;iBAAM,IAAI,MAAM,CAAC,WAAW,GAAG,EAAE,CAAC,OAAO,GAAG,EAAE,EAAE,CAAC;gBACjD,IAAI,CAAC,UAAU,CAAC,CAAC,EAAE,CAAC,CAAC;YACtB,CAAC;iBAAM,CAAC;gBACP,IAAI,CAAC,aAAa,EAAE,CAAC;YACtB,CAAC;YACD,EAAE,CAAC,YAAY,CAAC,UAAU,GAAG,MAAM,CAAC;YACpC,MAAM,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAM,EAAE,CAAC,MAAsB,CAAC,CAAC;YAC9G,IAAI,WAAW,KAAK,CAAC,CAAC,EAAE,CAAC;gBACxB,OAAO;YACR,CAAC;YACD,IAAI,CAAC,mBAAmB,GAAG,WAAW,CAAC;YACvC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,CAAC,EAAE,EAAE;gBACtC,IAAI,IAAI,CAAC,eAAe,KAAK,CAAC,EAAE,CAAC;oBAEhC,IAAI,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,mBAAmB,EAAE,CAAC;wBACrD,MAAM,YAAY,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;4BACnD,IAAI,CAAC,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;gCAC/B,OAAO,KAAK,CAAC;4BACd,CAAC;4BACD,OAAO,CAAC,GAAG,IAAI,CAAC,mBAAmB,GAAG,CAAC,CAAC;wBACzC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,CAAC,EAAE,EAAE;4BACzB,OAAO,GAAG,GAAG,GAAG,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,MAAM,CAAC;wBAC/D,CAAC,EAAE,CAAC,CAAC,CAAC;wBACN,QAAQ,CAAC,aAAa,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,SAAS,GAAG,cAAc,CAAC,YAAY,KAAK,CAAC;oBACpG,CAAC;yBAEI,IAAI,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,mBAAmB,EAAE,CAAC;wBAC1D,MAAM,YAAY,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;4BACnD,IAAI,CAAC,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;gCAC/B,OAAO,KAAK,CAAC;4BACd,CAAC;4BACD,OAAO,CAAC,IAAI,IAAI,CAAC,mBAAmB,CAAC;wBACtC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,CAAC,EAAE,EAAE;4BACzB,OAAO,GAAG,GAAG,GAAG,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,MAAM,CAAC;wBAC/D,CAAC,EAAE,CAAC,CAAC,CAAC;wBACN,QAAQ,CAAC,aAAa,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,SAAS,GAAG,cAAc,YAAY,KAAK,CAAC;oBACnG,CAAC;yBAEI,CAAC;wBACL,QAAQ,CAAC,aAAa,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,SAAS,GAAG,cAAc,CAAC,KAAK,CAAC;oBACxF,CAAC;oBAED,OAAO;gBACR,CAAC;gBAED,MAAM,4BAA4B,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,MAAM,CAAC,CAAC;gBAC7H,IAAI,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,EAAE,CAAC;oBAC7B,QAAQ,CAAC,aAAa,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,SAAS,GAAG,cAAc,4BAA4B,KAAK,CAAC;gBACnH,CAAC;qBACI,IAAI,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,CAAC;oBAChC,QAAQ,CAAC,aAAa,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,SAAS,GAAG,cAAc,CAAC,4BAA4B,KAAK,CAAC;gBACpH,CAAC;qBACI,CAAC;oBACL,QAAQ,CAAC,aAAa,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,SAAS,GAAG,gBAAgB,CAAC;gBACpF,CAAC;YACF,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,mBAAmB,GAAG,WAAW,CAAC;QACxC,CAAC,CAAA;QAEO,gBAAW,GAAG,CAAC,EAAE,EAAE,EAAE;YAC5B,EAAE,CAAC,YAAY,CAAC,aAAa,GAAG,MAAM,CAAC;YACvC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE;gBACpB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,EAAE,CAAC,MAAM,CAAC,CAAC;gBAChG,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,eAAe,CAAC;YACjD,CAAC,CAAC,CAAC;QACJ,CAAC,CAAC;QAEM,cAAS,GAAG,CAAC,EAAE,EAAE,EAAE;YAC1B,IAAI,CAAC,aAAa,EAAE,CAAC;YACrB,MAAM,YAAY,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;YAC3D,MAAM,kBAAkB,GAAG,IAAI,CAAC,mBAAmB,KAAK,IAAI,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC;YACnF,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE;gBACpB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU;qBAChC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,IAAI,CAAC,eAAe,CAAC;qBAC5C,MAAM,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,CAAC,EAAE,EAAE;oBACvB,IAAI,CAAC,KAAK,IAAI,CAAC,mBAAmB,EAAE,CAAC;wBACpC,OAAO,CAAC,GAAG,GAAG,EAAE,YAAY,EAAE,GAAG,CAAC,CAAC;oBACpC,CAAC;oBACD,OAAO,CAAC,GAAG,GAAG,EAAE,GAAG,CAAC,CAAC;gBACtB,CAAC,EAAE,EAAE,CAAC,CAAC;gBACP,IAAI,kBAAkB,EAAE,CAAC;oBACxB,IAAI,CAAC,UAAU,GAAG,CAAC,GAAG,IAAI,CAAC,UAAU,EAAE,YAAY,CAAC,CAAC;gBACtD,CAAC;gBACD,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,CAAC,EAAE,EAAE;oBACtC,QAAQ,CAAC,aAAa,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,SAAS,GAAG,gBAAgB,CAAC;gBACpF,CAAC,CAAC,CAAC;gBACH,IAAI,CAAC,mBAAmB,GAAG,CAAC,CAAC,CAAC;gBAC9B,IAAI,CAAC,eAAe,GAAG,CAAC,CAAC,CAAC;gBAC1B,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YAC9C,CAAC,CAAC,CAAC;QACJ,CAAC,CAAA;IA7HD,CAAC;IAED,eAAe;QACd,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC5B,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,SAAS,CAAC,GAAG,EAAE;YACrC,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC7B,CAAC,CAAC,CAAC;IACJ,CAAC;IAEO,oBAAoB;QAC3B,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;YAC1B,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,GAAG,EAAE;gBAClC,CAAC,CAAC,aAAa,CAAC,mBAAmB,CAAC,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;gBACnE,CAAC,CAAC,aAAa,CAAC,mBAAmB,CAAC,UAAU,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;gBACjE,CAAC,CAAC,aAAa,CAAC,mBAAmB,CAAC,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;gBACnE,CAAC,CAAC,aAAa,CAAC,mBAAmB,CAAC,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;gBAE/D,CAAC,CAAC,aAAa,CAAC,gBAAgB,CAAC,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;gBAChE,CAAC,CAAC,aAAa,CAAC,gBAAgB,CAAC,UAAU,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;gBAC9D,CAAC,CAAC,aAAa,CAAC,gBAAgB,CAAC,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;gBAChE,CAAC,CAAC,aAAa,CAAC,gBAAgB,CAAC,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;gBAE5D,CAAC,CAAC,aAAa,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,SAAS,GAAG,gBAAgB,CAAC;YAC7E,CAAC,CAAC,CAAC;QACJ,CAAC,CAAC,CAAC;IACJ,CAAC;IAsGD,eAAe,CAAC,KAAa;QAC5B,OAAO,IAAI,CAAC,eAAe,GAAG,KAAK,IAAI,IAAI,CAAC,mBAAmB,IAAI,KAAK,CAAC;IAC1E,CAAC;IAED,aAAa,CAAC,KAAa;QAC1B,OAAO,IAAI,CAAC,eAAe,GAAG,KAAK,IAAI,IAAI,CAAC,mBAAmB,IAAI,KAAK,CAAC;IAC1E,CAAC;IAEO,UAAU,CAAC,YAAoB;QACtC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,cAAc,CAAC,EAAE,CAAC;YACtC,IAAI,CAAC,cAAc,GAAG,WAAW,CAAC,GAAG,EAAE;gBACtC,MAAM,CAAC,MAAM,CAAC;oBACb,GAAG,EAAE,QAAQ,CAAC,gBAAgB,CAAC,SAAS,GAAG,YAAY;oBACvD,QAAQ,EAAE,QAAQ;iBAClB,CAAC,CAAC;gBACH,IAAI,QAAQ,CAAC,gBAAgB,CAAC,SAAS,IAAI,GAAG,EAAE,CAAC;oBAChD,IAAI,CAAC,aAAa,EAAE,CAAC;gBACtB,CAAC;YACF,CAAC,EAAE,GAAG,CAAC,CAAC;QACT,CAAC;IACF,CAAC;IAEO,aAAa;QACpB,aAAa,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QACnC,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;IAC5B,CAAC;8GA3KW,sBAAsB;kGAAtB,sBAAsB,oGARvB;YACV;gBACC,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,sBAAsB;gBACnC,KAAK,EAAE,IAAI;aACX;SACD,gEAMa,WAAW,iKCnC1B,+zBA0BA;;2FDKa,sBAAsB;kBAZlC,SAAS;+BACC,yBAAyB,aAGxB;wBACV;4BACC,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,wBAAwB;4BACnC,KAAK,EAAE,IAAI;yBACX;qBACD;;0BAgBC,IAAI;;0BAAI,QAAQ;;0BAChB,IAAI;;0BAAI,QAAQ;8DAXS,QAAQ;sBAAlC,YAAY;uBAAC,WAAW;gBAChB,gBAAgB;sBAAxB,KAAK;gBAEoB,SAAS;sBAAlC,YAAY;uBAAC,UAAU","sourcesContent":["import {\n\tAfterViewInit,\n\tComponent,\n\tContentChild,\n\tElementRef,\n\tHost,\n\tInput,\n\tNgZone,\n\tOnInit,\n\tOptional,\n\tQueryList,\n\tTemplateRef,\n\tViewChildren,\n} from '@angular/core';\nimport {ControlContainer, NG_VALUE_ACCESSOR} from '@angular/forms';\nimport {isValueSet} from '../../util/values';\nimport {ValueAccessorBase} from '../value-accessor-base/value-accessor-base.component';\nimport {FormElementComponent} from '../../form/form-element/form-element.component';\n\n@Component({\n\tselector: 'klp-form-sortable-items',\n\ttemplateUrl: './sortable-items.component.html',\n\tstyleUrls: ['./sortable-items.component.scss'],\n\tproviders: [\n\t\t{\n\t\t\tprovide: NG_VALUE_ACCESSOR,\n\t\t\tuseExisting: SortableItemsComponent,\n\t\t\tmulti: true,\n\t\t},\n\t],\n})\nexport class SortableItemsComponent\n\textends ValueAccessorBase<Array<any>>\n\timplements OnInit, AfterViewInit\n{\n\t@ContentChild(TemplateRef) template: TemplateRef<any>;\n\t@Input() sortableItemSize: 'sm' | 'lg' = 'lg';\n\n\t@ViewChildren('dragItem') dragItems: QueryList<ElementRef>;\n\tpublic dragSourceIndex: number;\n\tprivate currentDragPosition: number;\n\n\tprivate scrollInterval = null;\n\n\tconstructor(\n\t\t@Host() @Optional() protected parent: FormElementComponent,\n\t\t@Host() @Optional() protected controlContainer: ControlContainer,\n\t\tprivate ngZone: NgZone)\n\t{\n\t\tsuper(parent, controlContainer);\n\t}\n\n\tngAfterViewInit(): void {\n\t\tthis.setDragItemListeners();\n\t\tthis.dragItems.changes.subscribe(() => {\n\t\t\tthis.setDragItemListeners();\n\t\t});\n\t}\n\n\tprivate setDragItemListeners(): void {\n\t\tthis.dragItems.forEach(e => {\n\t\t\tthis.ngZone.runOutsideAngular(() => {\n\t\t\t\te.nativeElement.removeEventListener('dragstart', this.onDragStart);\n\t\t\t\te.nativeElement.removeEventListener('dragover', this.onDragOver);\n\t\t\t\te.nativeElement.removeEventListener('dragenter', this.onDragEnter);\n\t\t\t\te.nativeElement.removeEventListener('dragend', this.onDragEnd);\n\n\t\t\t\te.nativeElement.addEventListener('dragstart', this.onDragStart);\n\t\t\t\te.nativeElement.addEventListener('dragover', this.onDragOver);\n\t\t\t\te.nativeElement.addEventListener('dragenter', this.onDragEnter);\n\t\t\t\te.nativeElement.addEventListener('dragend', this.onDragEnd);\n\n\t\t\t\te.nativeElement.querySelector('.visual').style.transform = `translateY(0%)`;\n\t\t\t});\n\t\t});\n\t}\n\n\tprivate onDragOver = (ev) => {\n\t\tev.preventDefault();\n\t}\n\n\tprivate onDragEnter = (ev) => {\n\t\tif (ev.clientY < 80) {\n\t\t\tthis.scrollPage(40);\n\t\t} else if (window.innerHeight - ev.clientY < 80) {\n\t\t\tthis.scrollPage(-40);\n\t\t} else {\n\t\t\tthis.stopScrolling();\n\t\t}\n\t\tev.dataTransfer.dropEffect = 'move';\n\t\tconst targetIndex = this.dragItems.map(e => e.nativeElement).findIndex(e => e === (ev.target as HTMLElement));\n\t\tif (targetIndex === -1) {\n\t\t\treturn;\n\t\t}\n\t\tthis.currentDragPosition = targetIndex;\n\t\tthis.dragItems.forEach((dragItem, i) => {\n\t\t\tif (this.dragSourceIndex === i) {\n\n\t\t\t\tif (this.dragSourceIndex > this.currentDragPosition) {\n\t\t\t\t\tconst heightsAbove = this.dragItems.filter((e, i) => {\n\t\t\t\t\t\tif (i >= this.dragSourceIndex) {\n\t\t\t\t\t\t\treturn false;\n\t\t\t\t\t\t}\n\t\t\t\t\t\treturn i > this.currentDragPosition - 1;\n\t\t\t\t\t}).reduce((acc, cur, i) => {\n\t\t\t\t\t\treturn acc + cur.nativeElement.getBoundingClientRect().height;\n\t\t\t\t\t}, 0);\n\t\t\t\t\tdragItem.nativeElement.querySelector('.visual').style.transform = `translateY(${-heightsAbove}px)`;\n\t\t\t\t}\n\n\t\t\t\telse if (this.dragSourceIndex < this.currentDragPosition) {\n\t\t\t\t\tconst heightsAbove = this.dragItems.filter((e, i) => {\n\t\t\t\t\t\tif (i <= this.dragSourceIndex) {\n\t\t\t\t\t\t\treturn false;\n\t\t\t\t\t\t}\n\t\t\t\t\t\treturn i <= this.currentDragPosition;\n\t\t\t\t\t}).reduce((acc, cur, i) => {\n\t\t\t\t\t\treturn acc + cur.nativeElement.getBoundingClientRect().height;\n\t\t\t\t\t}, 0);\n\t\t\t\t\tdragItem.nativeElement.querySelector('.visual').style.transform = `translateY(${heightsAbove}px)`;\n\t\t\t\t}\n\n\t\t\t\telse {\n\t\t\t\t\tdragItem.nativeElement.querySelector('.visual').style.transform = `translateY(${0}px)`;\n\t\t\t\t}\n\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tconst heightOfCurrentlyDraggedItem = (this.dragItems.get(this.dragSourceIndex).nativeElement.getBoundingClientRect().height);\n\t\t\tif (this.shouldShoveDown(i)) {\n\t\t\t\tdragItem.nativeElement.querySelector('.visual').style.transform = `translateY(${heightOfCurrentlyDraggedItem}px)`;\n\t\t\t}\n\t\t\telse if (this.shouldShoveUp(i)) {\n\t\t\t\tdragItem.nativeElement.querySelector('.visual').style.transform = `translateY(${-heightOfCurrentlyDraggedItem}px)`;\n\t\t\t}\n\t\t\telse {\n\t\t\t\tdragItem.nativeElement.querySelector('.visual').style.transform = `translateY(0%)`;\n\t\t\t}\n\t\t});\n\n\t\tthis.currentDragPosition = targetIndex;\n\t}\n\n\tprivate onDragStart = (ev) => {\n\t\tev.dataTransfer.effectAllowed = 'move';\n\t\tthis.ngZone.run(() => {\n\t\t\tthis.dragSourceIndex = this.dragItems.map(e => e.nativeElement).findIndex(e => e === ev.target);\n\t\t\tthis.currentDragPosition = this.dragSourceIndex;\n\t\t});\n\t};\n\n\tprivate onDragEnd = (ev) => {\n\t\tthis.stopScrolling();\n\t\tconst movedElement = this.innerValue[this.dragSourceIndex];\n\t\tconst isMovedToLastPlace = this.currentDragPosition === this.innerValue.length - 1;\n\t\tthis.ngZone.run(() => {\n\t\t\tthis.innerValue = this.innerValue\n\t\t\t.filter((e, i) => i !== this.dragSourceIndex)\n\t\t\t.reduce((acc, cur, i) => {\n\t\t\t\tif (i === this.currentDragPosition) {\n\t\t\t\t\treturn [...acc, movedElement, cur];\n\t\t\t\t}\n\t\t\t\treturn [...acc, cur];\n\t\t\t}, []);\n\t\t\tif (isMovedToLastPlace) {\n\t\t\t\tthis.innerValue = [...this.innerValue, movedElement];\n\t\t\t}\n\t\t\tthis.dragItems.forEach((dragItem, i) => {\n\t\t\t\tdragItem.nativeElement.querySelector('.visual').style.transform = `translateY(0%)`;\n\t\t\t});\n\t\t\tthis.currentDragPosition = -1;\n\t\t\tthis.dragSourceIndex = -1;\n\t\t\tthis.setInnerValueAndNotify(this.innerValue);\n\t\t});\n\t}\n\n\tshouldShoveDown(index: number): boolean {\n\t\treturn this.dragSourceIndex > index && this.currentDragPosition <= index;\n\t}\n\n\tshouldShoveUp(index: number): boolean {\n\t\treturn this.dragSourceIndex < index && this.currentDragPosition >= index;\n\t}\n\n\tprivate scrollPage(scrollAmount: number): void {\n\t\tif (!isValueSet(this.scrollInterval)) {\n\t\t\tthis.scrollInterval = setInterval(() => {\n\t\t\t\twindow.scroll({\n\t\t\t\t\ttop: document.scrollingElement.scrollTop - scrollAmount,\n\t\t\t\t\tbehavior: 'smooth',\n\t\t\t\t});\n\t\t\t\tif (document.scrollingElement.scrollTop <= 100) {\n\t\t\t\t\tthis.stopScrolling();\n\t\t\t\t}\n\t\t\t}, 100);\n\t\t}\n\t}\n\n\tprivate stopScrolling(): void {\n\t\tclearInterval(this.scrollInterval);\n\t\tthis.scrollInterval = null;\n\t}\n}\n","<ng-template #listItem>\n\t<li *ngFor=\"let item of innerValue; index as index\"\n\t\t\tclass=\"sortableItem\"\n\t\t\t[draggable]=\"!disabled\"\n\t\t\t[ngClass]=\"{\n\t\t\tlargeSortableItem: sortableItemSize === 'lg',\n\t\t \tsmallSortableItem: sortableItemSize === 'sm',\n\t\t \t}\"\n\t\t\t#dragItem\n\t>\n\t\t<div class=\"visual\">\n\t\t\t<ng-container [ngTemplateOutlet]=\"template\" [ngTemplateOutletContext]=\"{ item: item, index:index }\"></ng-container>\n\t\t</div>\n\t</li>\n</ng-template>\n\n<ol *ngIf='!disabled'\n\t\tclass=\"itemsContainer\"\n\t\t[ngClass]=\"{dragInProgress: dragSourceIndex >= 0}\"\n>\n\t<ng-container *ngTemplateOutlet=\"listItem\"></ng-container>\n</ol>\n\n<ol *ngIf='disabled' class=\"itemsContainer disabled-mouse-cursor\">\n\t<ng-container *ngTemplateOutlet=\"listItem\"></ng-container>\n</ol>\n"]}
@@ -1608,21 +1608,23 @@ class SortableItemsComponent extends ValueAccessorBase {
1608
1608
  };
1609
1609
  }
1610
1610
  ngAfterViewInit() {
1611
+ this.setDragItemListeners();
1611
1612
  this.dragItems.changes.subscribe(() => {
1612
- this.dragItems.forEach(e => {
1613
- this.ngZone.runOutsideAngular(() => {
1614
- e.nativeElement.removeEventListener('dragstart', this.onDragStart);
1615
- e.nativeElement.removeEventListener('dragover', this.onDragOver);
1616
- e.nativeElement.removeEventListener('dragenter', this.onDragEnter);
1617
- e.nativeElement.removeEventListener('dragend', this.onDragEnd);
1618
- e.nativeElement.addEventListener('dragstart', this.onDragStart);
1619
- e.nativeElement.addEventListener('dragover', this.onDragOver);
1620
- e.nativeElement.addEventListener('dragenter', this.onDragEnter);
1621
- e.nativeElement.addEventListener('dragend', this.onDragEnd);
1622
- this.dragItems.forEach((dragItem, i) => {
1623
- dragItem.nativeElement.querySelector('.visual').style.transform = `translateY(0%)`;
1624
- });
1625
- });
1613
+ this.setDragItemListeners();
1614
+ });
1615
+ }
1616
+ setDragItemListeners() {
1617
+ this.dragItems.forEach(e => {
1618
+ this.ngZone.runOutsideAngular(() => {
1619
+ e.nativeElement.removeEventListener('dragstart', this.onDragStart);
1620
+ e.nativeElement.removeEventListener('dragover', this.onDragOver);
1621
+ e.nativeElement.removeEventListener('dragenter', this.onDragEnter);
1622
+ e.nativeElement.removeEventListener('dragend', this.onDragEnd);
1623
+ e.nativeElement.addEventListener('dragstart', this.onDragStart);
1624
+ e.nativeElement.addEventListener('dragover', this.onDragOver);
1625
+ e.nativeElement.addEventListener('dragenter', this.onDragEnter);
1626
+ e.nativeElement.addEventListener('dragend', this.onDragEnd);
1627
+ e.nativeElement.querySelector('.visual').style.transform = `translateY(0%)`;
1626
1628
  });
1627
1629
  });
1628
1630
  }