orderable.directive.js 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274
  1. /**
  2. * @fileoverview added by tsickle
  3. * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
  4. */
  5. import * as tslib_1 from "tslib";
  6. import { Directive, Output, EventEmitter, ContentChildren, QueryList, KeyValueDiffers, Inject } from '@angular/core';
  7. import { DraggableDirective } from './draggable.directive';
  8. import { DOCUMENT } from '@angular/common';
  9. var OrderableDirective = /** @class */ (function () {
  10. function OrderableDirective(differs, document) {
  11. this.document = document;
  12. this.reorder = new EventEmitter();
  13. this.targetChanged = new EventEmitter();
  14. this.differ = differs.find({}).create();
  15. }
  16. /**
  17. * @return {?}
  18. */
  19. OrderableDirective.prototype.ngAfterContentInit = /**
  20. * @return {?}
  21. */
  22. function () {
  23. // HACK: Investigate Better Way
  24. this.updateSubscriptions();
  25. this.draggables.changes.subscribe(this.updateSubscriptions.bind(this));
  26. };
  27. /**
  28. * @return {?}
  29. */
  30. OrderableDirective.prototype.ngOnDestroy = /**
  31. * @return {?}
  32. */
  33. function () {
  34. this.draggables.forEach((/**
  35. * @param {?} d
  36. * @return {?}
  37. */
  38. function (d) {
  39. d.dragStart.unsubscribe();
  40. d.dragging.unsubscribe();
  41. d.dragEnd.unsubscribe();
  42. }));
  43. };
  44. /**
  45. * @return {?}
  46. */
  47. OrderableDirective.prototype.updateSubscriptions = /**
  48. * @return {?}
  49. */
  50. function () {
  51. var _this = this;
  52. /** @type {?} */
  53. var diffs = this.differ.diff(this.createMapDiffs());
  54. if (diffs) {
  55. /** @type {?} */
  56. var subscribe = (/**
  57. * @param {?} __0
  58. * @return {?}
  59. */
  60. function (_a) {
  61. var currentValue = _a.currentValue, previousValue = _a.previousValue;
  62. unsubscribe_1({ previousValue: previousValue });
  63. if (currentValue) {
  64. currentValue.dragStart.subscribe(_this.onDragStart.bind(_this));
  65. currentValue.dragging.subscribe(_this.onDragging.bind(_this));
  66. currentValue.dragEnd.subscribe(_this.onDragEnd.bind(_this));
  67. }
  68. });
  69. /** @type {?} */
  70. var unsubscribe_1 = (/**
  71. * @param {?} __0
  72. * @return {?}
  73. */
  74. function (_a) {
  75. var previousValue = _a.previousValue;
  76. if (previousValue) {
  77. previousValue.dragStart.unsubscribe();
  78. previousValue.dragging.unsubscribe();
  79. previousValue.dragEnd.unsubscribe();
  80. }
  81. });
  82. diffs.forEachAddedItem(subscribe);
  83. // diffs.forEachChangedItem(subscribe.bind(this));
  84. diffs.forEachRemovedItem(unsubscribe_1);
  85. }
  86. };
  87. /**
  88. * @return {?}
  89. */
  90. OrderableDirective.prototype.onDragStart = /**
  91. * @return {?}
  92. */
  93. function () {
  94. var e_1, _a;
  95. this.positions = {};
  96. /** @type {?} */
  97. var i = 0;
  98. try {
  99. for (var _b = tslib_1.__values(this.draggables.toArray()), _c = _b.next(); !_c.done; _c = _b.next()) {
  100. var dragger = _c.value;
  101. /** @type {?} */
  102. var elm = dragger.element;
  103. /** @type {?} */
  104. var left = parseInt(elm.offsetLeft.toString(), 0);
  105. this.positions[dragger.dragModel.prop] = {
  106. left: left,
  107. right: left + parseInt(elm.offsetWidth.toString(), 0),
  108. index: i++,
  109. element: elm
  110. };
  111. }
  112. }
  113. catch (e_1_1) { e_1 = { error: e_1_1 }; }
  114. finally {
  115. try {
  116. if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
  117. }
  118. finally { if (e_1) throw e_1.error; }
  119. }
  120. };
  121. /**
  122. * @param {?} __0
  123. * @return {?}
  124. */
  125. OrderableDirective.prototype.onDragging = /**
  126. * @param {?} __0
  127. * @return {?}
  128. */
  129. function (_a) {
  130. var element = _a.element, model = _a.model, event = _a.event;
  131. /** @type {?} */
  132. var prevPos = this.positions[model.prop];
  133. /** @type {?} */
  134. var target = this.isTarget(model, event);
  135. if (target) {
  136. if (this.lastDraggingIndex !== target.i) {
  137. this.targetChanged.emit({
  138. prevIndex: this.lastDraggingIndex,
  139. newIndex: target.i,
  140. initialIndex: prevPos.index
  141. });
  142. this.lastDraggingIndex = target.i;
  143. }
  144. }
  145. else if (this.lastDraggingIndex !== prevPos.index) {
  146. this.targetChanged.emit({
  147. prevIndex: this.lastDraggingIndex,
  148. initialIndex: prevPos.index
  149. });
  150. this.lastDraggingIndex = prevPos.index;
  151. }
  152. };
  153. /**
  154. * @param {?} __0
  155. * @return {?}
  156. */
  157. OrderableDirective.prototype.onDragEnd = /**
  158. * @param {?} __0
  159. * @return {?}
  160. */
  161. function (_a) {
  162. var element = _a.element, model = _a.model, event = _a.event;
  163. /** @type {?} */
  164. var prevPos = this.positions[model.prop];
  165. /** @type {?} */
  166. var target = this.isTarget(model, event);
  167. if (target) {
  168. this.reorder.emit({
  169. prevIndex: prevPos.index,
  170. newIndex: target.i,
  171. model: model
  172. });
  173. }
  174. this.lastDraggingIndex = undefined;
  175. element.style.left = 'auto';
  176. };
  177. /**
  178. * @param {?} model
  179. * @param {?} event
  180. * @return {?}
  181. */
  182. OrderableDirective.prototype.isTarget = /**
  183. * @param {?} model
  184. * @param {?} event
  185. * @return {?}
  186. */
  187. function (model, event) {
  188. /** @type {?} */
  189. var i = 0;
  190. /** @type {?} */
  191. var x = event.x || event.clientX;
  192. /** @type {?} */
  193. var y = event.y || event.clientY;
  194. /** @type {?} */
  195. var targets = this.document.elementsFromPoint(x, y);
  196. var _loop_1 = function (prop) {
  197. // current column position which throws event.
  198. /** @type {?} */
  199. var pos = this_1.positions[prop];
  200. // since we drag the inner span, we need to find it in the elements at the cursor
  201. if (model.prop !== prop && targets.find((/**
  202. * @param {?} el
  203. * @return {?}
  204. */
  205. function (el) { return el === pos.element; }))) {
  206. return { value: {
  207. pos: pos,
  208. i: i
  209. } };
  210. }
  211. i++;
  212. };
  213. var this_1 = this;
  214. for (var prop in this.positions) {
  215. var state_1 = _loop_1(prop);
  216. if (typeof state_1 === "object")
  217. return state_1.value;
  218. }
  219. };
  220. /**
  221. * @private
  222. * @return {?}
  223. */
  224. OrderableDirective.prototype.createMapDiffs = /**
  225. * @private
  226. * @return {?}
  227. */
  228. function () {
  229. return this.draggables.toArray().reduce((/**
  230. * @param {?} acc
  231. * @param {?} curr
  232. * @return {?}
  233. */
  234. function (acc, curr) {
  235. acc[curr.dragModel.$$id] = curr;
  236. return acc;
  237. }), {});
  238. };
  239. OrderableDirective.decorators = [
  240. { type: Directive, args: [{ selector: '[orderable]' },] }
  241. ];
  242. /** @nocollapse */
  243. OrderableDirective.ctorParameters = function () { return [
  244. { type: KeyValueDiffers },
  245. { type: undefined, decorators: [{ type: Inject, args: [DOCUMENT,] }] }
  246. ]; };
  247. OrderableDirective.propDecorators = {
  248. reorder: [{ type: Output }],
  249. targetChanged: [{ type: Output }],
  250. draggables: [{ type: ContentChildren, args: [DraggableDirective, { descendants: true },] }]
  251. };
  252. return OrderableDirective;
  253. }());
  254. export { OrderableDirective };
  255. if (false) {
  256. /** @type {?} */
  257. OrderableDirective.prototype.reorder;
  258. /** @type {?} */
  259. OrderableDirective.prototype.targetChanged;
  260. /** @type {?} */
  261. OrderableDirective.prototype.draggables;
  262. /** @type {?} */
  263. OrderableDirective.prototype.positions;
  264. /** @type {?} */
  265. OrderableDirective.prototype.differ;
  266. /** @type {?} */
  267. OrderableDirective.prototype.lastDraggingIndex;
  268. /**
  269. * @type {?}
  270. * @private
  271. */
  272. OrderableDirective.prototype.document;
  273. }
  274. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"orderable.directive.js","sourceRoot":"ng://@swimlane/ngx-datatable/","sources":["lib/directives/orderable.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  Output,\n  EventEmitter,\n  ContentChildren,\n  QueryList,\n  KeyValueDiffers,\n  AfterContentInit,\n  OnDestroy,\n  Inject\n} from '@angular/core';\nimport { DraggableDirective } from './draggable.directive';\nimport { DOCUMENT } from '@angular/common';\n\n@Directive({ selector: '[orderable]' })\nexport class OrderableDirective implements AfterContentInit, OnDestroy {\n  @Output() reorder: EventEmitter<any> = new EventEmitter();\n  @Output() targetChanged: EventEmitter<any> = new EventEmitter();\n\n  @ContentChildren(DraggableDirective, { descendants: true })\n  draggables: QueryList<DraggableDirective>;\n\n  positions: any;\n  differ: any;\n  lastDraggingIndex: number;\n\n  constructor(differs: KeyValueDiffers, @Inject(DOCUMENT) private document: any) {\n    this.differ = differs.find({}).create();\n  }\n\n  ngAfterContentInit(): void {\n    // HACK: Investigate Better Way\n    this.updateSubscriptions();\n    this.draggables.changes.subscribe(this.updateSubscriptions.bind(this));\n  }\n\n  ngOnDestroy(): void {\n    this.draggables.forEach(d => {\n      d.dragStart.unsubscribe();\n      d.dragging.unsubscribe();\n      d.dragEnd.unsubscribe();\n    });\n  }\n\n  updateSubscriptions(): void {\n    const diffs = this.differ.diff(this.createMapDiffs());\n\n    if (diffs) {\n      const subscribe = ({ currentValue, previousValue }: any) => {\n        unsubscribe({ previousValue });\n\n        if (currentValue) {\n          currentValue.dragStart.subscribe(this.onDragStart.bind(this));\n          currentValue.dragging.subscribe(this.onDragging.bind(this));\n          currentValue.dragEnd.subscribe(this.onDragEnd.bind(this));\n        }\n      };\n\n      const unsubscribe = ({ previousValue }: any) => {\n        if (previousValue) {\n          previousValue.dragStart.unsubscribe();\n          previousValue.dragging.unsubscribe();\n          previousValue.dragEnd.unsubscribe();\n        }\n      };\n\n      diffs.forEachAddedItem(subscribe);\n      // diffs.forEachChangedItem(subscribe.bind(this));\n      diffs.forEachRemovedItem(unsubscribe);\n    }\n  }\n\n  onDragStart(): void {\n    this.positions = {};\n\n    let i = 0;\n    for (const dragger of this.draggables.toArray()) {\n      const elm = dragger.element;\n      const left = parseInt(elm.offsetLeft.toString(), 0);\n      this.positions[dragger.dragModel.prop] = {\n        left,\n        right: left + parseInt(elm.offsetWidth.toString(), 0),\n        index: i++,\n        element: elm\n      };\n    }\n  }\n\n  onDragging({ element, model, event }: any): void {\n    const prevPos = this.positions[model.prop];\n    const target = this.isTarget(model, event);\n\n    if (target) {\n      if (this.lastDraggingIndex !== target.i) {\n        this.targetChanged.emit({\n          prevIndex: this.lastDraggingIndex,\n          newIndex: target.i,\n          initialIndex: prevPos.index\n        });\n        this.lastDraggingIndex = target.i;\n      }\n    } else if (this.lastDraggingIndex !== prevPos.index) {\n      this.targetChanged.emit({\n        prevIndex: this.lastDraggingIndex,\n        initialIndex: prevPos.index\n      });\n      this.lastDraggingIndex = prevPos.index;\n    }\n  }\n\n  onDragEnd({ element, model, event }: any): void {\n    const prevPos = this.positions[model.prop];\n\n    const target = this.isTarget(model, event);\n    if (target) {\n      this.reorder.emit({\n        prevIndex: prevPos.index,\n        newIndex: target.i,\n        model\n      });\n    }\n\n    this.lastDraggingIndex = undefined;\n    element.style.left = 'auto';\n  }\n\n  isTarget(model: any, event: any): any {\n    let i = 0;\n    const x = event.x || event.clientX;\n    const y = event.y || event.clientY;\n    const targets = this.document.elementsFromPoint(x, y);\n\n    for (const prop in this.positions) {\n      // current column position which throws event.\n      const pos = this.positions[prop];\n\n      // since we drag the inner span, we need to find it in the elements at the cursor\n      if (model.prop !== prop && targets.find((el: any) => el === pos.element)) {\n        return {\n          pos,\n          i\n        };\n      }\n\n      i++;\n    }\n  }\n\n  private createMapDiffs(): { [key: string]: DraggableDirective } {\n    return this.draggables.toArray().reduce((acc, curr) => {\n      acc[curr.dragModel.$$id] = curr;\n      return acc;\n    }, {});\n  }\n}\n"]}