angular-resizable.directive.js 88 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102
  1. /**
  2. * @fileoverview added by tsickle
  3. * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
  4. */
  5. import * as tslib_1 from "tslib";
  6. import { Directive, ElementRef, Renderer2, Input, Output, EventEmitter } from '@angular/core';
  7. import { fromEvent } from 'rxjs';
  8. import { HelperBlock } from './widgets/helper-block';
  9. import { ResizeHandle } from './widgets/resize-handle';
  10. import { Position } from './models/position';
  11. import { Size } from './models/size';
  12. var AngularResizableDirective = /** @class */ (function () {
  13. function AngularResizableDirective(el, renderer) {
  14. this.el = el;
  15. this.renderer = renderer;
  16. this._resizable = true;
  17. this._handles = {};
  18. this._handleType = [];
  19. this._handleResizing = null;
  20. this._direction = null;
  21. this._directionChanged = null;
  22. this._aspectRatio = 0;
  23. this._containment = null;
  24. this._origMousePos = null;
  25. /**
  26. * Original Size and Position
  27. */
  28. this._origSize = null;
  29. this._origPos = null;
  30. /**
  31. * Current Size and Position
  32. */
  33. this._currSize = null;
  34. this._currPos = null;
  35. /**
  36. * Initial Size and Position
  37. */
  38. this._initSize = null;
  39. this._initPos = null;
  40. /**
  41. * Snap to gird
  42. */
  43. this._gridSize = null;
  44. this._bounding = null;
  45. /**
  46. * Bugfix: iFrames, and context unrelated elements block all events, and are unusable
  47. * https://github.com/xieziyu/angular2-draggable/issues/84
  48. */
  49. this._helperBlock = null;
  50. this.draggingSub = null;
  51. this._adjusted = false;
  52. /**
  53. * Which handles can be used for resizing.
  54. * \@example
  55. * [rzHandles] = "'n,e,s,w,se,ne,sw,nw'"
  56. * equals to: [rzHandles] = "'all'"
  57. *
  58. *
  59. */
  60. this.rzHandles = 'e,s,se';
  61. /**
  62. * Whether the element should be constrained to a specific aspect ratio.
  63. * Multiple types supported:
  64. * boolean: When set to true, the element will maintain its original aspect ratio.
  65. * number: Force the element to maintain a specific aspect ratio during resizing.
  66. */
  67. this.rzAspectRatio = false;
  68. /**
  69. * Constrains resizing to within the bounds of the specified element or region.
  70. * Multiple types supported:
  71. * Selector: The resizable element will be contained to the bounding box of the first element found by the selector.
  72. * If no element is found, no containment will be set.
  73. * Element: The resizable element will be contained to the bounding box of this element.
  74. * String: Possible values: "parent".
  75. */
  76. this.rzContainment = null;
  77. /**
  78. * Snaps the resizing element to a grid, every x and y pixels.
  79. * A number for both width and height or an array values like [ x, y ]
  80. */
  81. this.rzGrid = null;
  82. /**
  83. * The minimum width the resizable should be allowed to resize to.
  84. */
  85. this.rzMinWidth = null;
  86. /**
  87. * The minimum height the resizable should be allowed to resize to.
  88. */
  89. this.rzMinHeight = null;
  90. /**
  91. * The maximum width the resizable should be allowed to resize to.
  92. */
  93. this.rzMaxWidth = null;
  94. /**
  95. * The maximum height the resizable should be allowed to resize to.
  96. */
  97. this.rzMaxHeight = null;
  98. /**
  99. * Whether to prevent default event
  100. */
  101. this.preventDefaultEvent = true;
  102. /**
  103. * emitted when start resizing
  104. */
  105. this.rzStart = new EventEmitter();
  106. /**
  107. * emitted when start resizing
  108. */
  109. this.rzResizing = new EventEmitter();
  110. /**
  111. * emitted when stop resizing
  112. */
  113. this.rzStop = new EventEmitter();
  114. this._helperBlock = new HelperBlock(el.nativeElement, renderer);
  115. }
  116. Object.defineProperty(AngularResizableDirective.prototype, "ngResizable", {
  117. /** Disables the resizable if set to false. */
  118. set: /**
  119. * Disables the resizable if set to false.
  120. * @param {?} v
  121. * @return {?}
  122. */
  123. function (v) {
  124. if (v !== undefined && v !== null && v !== '') {
  125. this._resizable = !!v;
  126. this.updateResizable();
  127. }
  128. },
  129. enumerable: true,
  130. configurable: true
  131. });
  132. /**
  133. * @param {?} changes
  134. * @return {?}
  135. */
  136. AngularResizableDirective.prototype.ngOnChanges = /**
  137. * @param {?} changes
  138. * @return {?}
  139. */
  140. function (changes) {
  141. if (changes['rzHandles'] && !changes['rzHandles'].isFirstChange()) {
  142. this.updateResizable();
  143. }
  144. if (changes['rzAspectRatio'] && !changes['rzAspectRatio'].isFirstChange()) {
  145. this.updateAspectRatio();
  146. }
  147. if (changes['rzContainment'] && !changes['rzContainment'].isFirstChange()) {
  148. this.updateContainment();
  149. }
  150. };
  151. /**
  152. * @return {?}
  153. */
  154. AngularResizableDirective.prototype.ngOnInit = /**
  155. * @return {?}
  156. */
  157. function () {
  158. this.updateResizable();
  159. };
  160. /**
  161. * @return {?}
  162. */
  163. AngularResizableDirective.prototype.ngOnDestroy = /**
  164. * @return {?}
  165. */
  166. function () {
  167. this.removeHandles();
  168. this._containment = null;
  169. this._helperBlock.dispose();
  170. this._helperBlock = null;
  171. };
  172. /**
  173. * @return {?}
  174. */
  175. AngularResizableDirective.prototype.ngAfterViewInit = /**
  176. * @return {?}
  177. */
  178. function () {
  179. /** @type {?} */
  180. var elm = this.el.nativeElement;
  181. this._initSize = Size.getCurrent(elm);
  182. this._initPos = Position.getCurrent(elm);
  183. this._currSize = Size.copy(this._initSize);
  184. this._currPos = Position.copy(this._initPos);
  185. this.updateAspectRatio();
  186. this.updateContainment();
  187. };
  188. /** A method to reset size */
  189. /**
  190. * A method to reset size
  191. * @return {?}
  192. */
  193. AngularResizableDirective.prototype.resetSize = /**
  194. * A method to reset size
  195. * @return {?}
  196. */
  197. function () {
  198. this._currSize = Size.copy(this._initSize);
  199. this._currPos = Position.copy(this._initPos);
  200. this.doResize();
  201. };
  202. /** A method to get current status */
  203. /**
  204. * A method to get current status
  205. * @return {?}
  206. */
  207. AngularResizableDirective.prototype.getStatus = /**
  208. * A method to get current status
  209. * @return {?}
  210. */
  211. function () {
  212. if (!this._currPos || !this._currSize) {
  213. return null;
  214. }
  215. return {
  216. size: {
  217. width: this._currSize.width,
  218. height: this._currSize.height
  219. },
  220. position: {
  221. top: this._currPos.y,
  222. left: this._currPos.x
  223. }
  224. };
  225. };
  226. /**
  227. * @private
  228. * @return {?}
  229. */
  230. AngularResizableDirective.prototype.updateResizable = /**
  231. * @private
  232. * @return {?}
  233. */
  234. function () {
  235. /** @type {?} */
  236. var element = this.el.nativeElement;
  237. // clear handles:
  238. this.renderer.removeClass(element, 'ng-resizable');
  239. this.removeHandles();
  240. // create new ones:
  241. if (this._resizable) {
  242. this.renderer.addClass(element, 'ng-resizable');
  243. this.createHandles();
  244. }
  245. };
  246. /** Use it to update aspect */
  247. /**
  248. * Use it to update aspect
  249. * @private
  250. * @return {?}
  251. */
  252. AngularResizableDirective.prototype.updateAspectRatio = /**
  253. * Use it to update aspect
  254. * @private
  255. * @return {?}
  256. */
  257. function () {
  258. if (typeof this.rzAspectRatio === 'boolean') {
  259. if (this.rzAspectRatio && this._currSize.height) {
  260. this._aspectRatio = (this._currSize.width / this._currSize.height);
  261. }
  262. else {
  263. this._aspectRatio = 0;
  264. }
  265. }
  266. else {
  267. /** @type {?} */
  268. var r = Number(this.rzAspectRatio);
  269. this._aspectRatio = isNaN(r) ? 0 : r;
  270. }
  271. };
  272. /** Use it to update containment */
  273. /**
  274. * Use it to update containment
  275. * @private
  276. * @return {?}
  277. */
  278. AngularResizableDirective.prototype.updateContainment = /**
  279. * Use it to update containment
  280. * @private
  281. * @return {?}
  282. */
  283. function () {
  284. if (!this.rzContainment) {
  285. this._containment = null;
  286. return;
  287. }
  288. if (typeof this.rzContainment === 'string') {
  289. if (this.rzContainment === 'parent') {
  290. this._containment = this.el.nativeElement.parentElement;
  291. }
  292. else {
  293. this._containment = document.querySelector(this.rzContainment);
  294. }
  295. }
  296. else {
  297. this._containment = this.rzContainment;
  298. }
  299. };
  300. /** Use it to create handle divs */
  301. /**
  302. * Use it to create handle divs
  303. * @private
  304. * @return {?}
  305. */
  306. AngularResizableDirective.prototype.createHandles = /**
  307. * Use it to create handle divs
  308. * @private
  309. * @return {?}
  310. */
  311. function () {
  312. var e_1, _a, e_2, _b;
  313. if (!this.rzHandles) {
  314. return;
  315. }
  316. /** @type {?} */
  317. var tmpHandleTypes;
  318. if (typeof this.rzHandles === 'string') {
  319. if (this.rzHandles === 'all') {
  320. tmpHandleTypes = ['n', 'e', 's', 'w', 'ne', 'se', 'nw', 'sw'];
  321. }
  322. else {
  323. tmpHandleTypes = this.rzHandles.replace(/ /g, '').toLowerCase().split(',');
  324. }
  325. try {
  326. for (var tmpHandleTypes_1 = tslib_1.__values(tmpHandleTypes), tmpHandleTypes_1_1 = tmpHandleTypes_1.next(); !tmpHandleTypes_1_1.done; tmpHandleTypes_1_1 = tmpHandleTypes_1.next()) {
  327. var type = tmpHandleTypes_1_1.value;
  328. // default handle theme: ng-resizable-$type.
  329. /** @type {?} */
  330. var handle = this.createHandleByType(type, "ng-resizable-" + type);
  331. if (handle) {
  332. this._handleType.push(type);
  333. this._handles[type] = handle;
  334. }
  335. }
  336. }
  337. catch (e_1_1) { e_1 = { error: e_1_1 }; }
  338. finally {
  339. try {
  340. if (tmpHandleTypes_1_1 && !tmpHandleTypes_1_1.done && (_a = tmpHandleTypes_1.return)) _a.call(tmpHandleTypes_1);
  341. }
  342. finally { if (e_1) throw e_1.error; }
  343. }
  344. }
  345. else {
  346. tmpHandleTypes = Object.keys(this.rzHandles);
  347. try {
  348. for (var tmpHandleTypes_2 = tslib_1.__values(tmpHandleTypes), tmpHandleTypes_2_1 = tmpHandleTypes_2.next(); !tmpHandleTypes_2_1.done; tmpHandleTypes_2_1 = tmpHandleTypes_2.next()) {
  349. var type = tmpHandleTypes_2_1.value;
  350. // custom handle theme.
  351. /** @type {?} */
  352. var handle = this.createHandleByType(type, this.rzHandles[type]);
  353. if (handle) {
  354. this._handleType.push(type);
  355. this._handles[type] = handle;
  356. }
  357. }
  358. }
  359. catch (e_2_1) { e_2 = { error: e_2_1 }; }
  360. finally {
  361. try {
  362. if (tmpHandleTypes_2_1 && !tmpHandleTypes_2_1.done && (_b = tmpHandleTypes_2.return)) _b.call(tmpHandleTypes_2);
  363. }
  364. finally { if (e_2) throw e_2.error; }
  365. }
  366. }
  367. };
  368. /** Use it to create a handle */
  369. /**
  370. * Use it to create a handle
  371. * @private
  372. * @param {?} type
  373. * @param {?} css
  374. * @return {?}
  375. */
  376. AngularResizableDirective.prototype.createHandleByType = /**
  377. * Use it to create a handle
  378. * @private
  379. * @param {?} type
  380. * @param {?} css
  381. * @return {?}
  382. */
  383. function (type, css) {
  384. /** @type {?} */
  385. var _el = this.el.nativeElement;
  386. if (!type.match(/^(se|sw|ne|nw|n|e|s|w)$/)) {
  387. console.error('Invalid handle type:', type);
  388. return null;
  389. }
  390. return new ResizeHandle(_el, this.renderer, type, css, this.onMouseDown.bind(this));
  391. };
  392. /**
  393. * @private
  394. * @return {?}
  395. */
  396. AngularResizableDirective.prototype.removeHandles = /**
  397. * @private
  398. * @return {?}
  399. */
  400. function () {
  401. var e_3, _a;
  402. try {
  403. for (var _b = tslib_1.__values(this._handleType), _c = _b.next(); !_c.done; _c = _b.next()) {
  404. var type = _c.value;
  405. this._handles[type].dispose();
  406. }
  407. }
  408. catch (e_3_1) { e_3 = { error: e_3_1 }; }
  409. finally {
  410. try {
  411. if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
  412. }
  413. finally { if (e_3) throw e_3.error; }
  414. }
  415. this._handleType = [];
  416. this._handles = {};
  417. };
  418. /**
  419. * @param {?} event
  420. * @param {?} handle
  421. * @return {?}
  422. */
  423. AngularResizableDirective.prototype.onMouseDown = /**
  424. * @param {?} event
  425. * @param {?} handle
  426. * @return {?}
  427. */
  428. function (event, handle) {
  429. // skip right click;
  430. if (event instanceof MouseEvent && event.button === 2) {
  431. return;
  432. }
  433. if (this.preventDefaultEvent) {
  434. // prevent default events
  435. event.stopPropagation();
  436. event.preventDefault();
  437. }
  438. if (!this._handleResizing) {
  439. this._origMousePos = Position.fromEvent(event);
  440. this.startResize(handle);
  441. this.subscribeEvents();
  442. }
  443. };
  444. /**
  445. * @private
  446. * @return {?}
  447. */
  448. AngularResizableDirective.prototype.subscribeEvents = /**
  449. * @private
  450. * @return {?}
  451. */
  452. function () {
  453. var _this = this;
  454. this.draggingSub = fromEvent(document, 'mousemove', { passive: false }).subscribe(function (event) { return _this.onMouseMove((/** @type {?} */ (event))); });
  455. this.draggingSub.add(fromEvent(document, 'touchmove', { passive: false }).subscribe(function (event) { return _this.onMouseMove((/** @type {?} */ (event))); }));
  456. this.draggingSub.add(fromEvent(document, 'mouseup', { passive: false }).subscribe(function () { return _this.onMouseLeave(); }));
  457. // fix for issue #164
  458. /** @type {?} */
  459. var isIEOrEdge = /msie\s|trident\//i.test(window.navigator.userAgent);
  460. if (!isIEOrEdge) {
  461. this.draggingSub.add(fromEvent(document, 'mouseleave', { passive: false }).subscribe(function () { return _this.onMouseLeave(); }));
  462. }
  463. this.draggingSub.add(fromEvent(document, 'touchend', { passive: false }).subscribe(function () { return _this.onMouseLeave(); }));
  464. this.draggingSub.add(fromEvent(document, 'touchcancel', { passive: false }).subscribe(function () { return _this.onMouseLeave(); }));
  465. };
  466. /**
  467. * @private
  468. * @return {?}
  469. */
  470. AngularResizableDirective.prototype.unsubscribeEvents = /**
  471. * @private
  472. * @return {?}
  473. */
  474. function () {
  475. this.draggingSub.unsubscribe();
  476. this.draggingSub = null;
  477. };
  478. /**
  479. * @return {?}
  480. */
  481. AngularResizableDirective.prototype.onMouseLeave = /**
  482. * @return {?}
  483. */
  484. function () {
  485. if (this._handleResizing) {
  486. this.stopResize();
  487. this._origMousePos = null;
  488. this.unsubscribeEvents();
  489. }
  490. };
  491. /**
  492. * @param {?} event
  493. * @return {?}
  494. */
  495. AngularResizableDirective.prototype.onMouseMove = /**
  496. * @param {?} event
  497. * @return {?}
  498. */
  499. function (event) {
  500. if (this._handleResizing && this._resizable && this._origMousePos && this._origPos && this._origSize) {
  501. this.resizeTo(Position.fromEvent(event));
  502. this.onResizing();
  503. }
  504. };
  505. /**
  506. * @private
  507. * @param {?} handle
  508. * @return {?}
  509. */
  510. AngularResizableDirective.prototype.startResize = /**
  511. * @private
  512. * @param {?} handle
  513. * @return {?}
  514. */
  515. function (handle) {
  516. /** @type {?} */
  517. var elm = this.el.nativeElement;
  518. this._origSize = Size.getCurrent(elm);
  519. this._origPos = Position.getCurrent(elm); // x: left, y: top
  520. this._currSize = Size.copy(this._origSize);
  521. this._currPos = Position.copy(this._origPos);
  522. if (this._containment) {
  523. this.getBounding();
  524. }
  525. this.getGridSize();
  526. // Add a transparent helper div:
  527. this._helperBlock.add();
  528. this._handleResizing = handle;
  529. this.updateDirection();
  530. this.rzStart.emit(this.getResizingEvent());
  531. };
  532. /**
  533. * @private
  534. * @return {?}
  535. */
  536. AngularResizableDirective.prototype.stopResize = /**
  537. * @private
  538. * @return {?}
  539. */
  540. function () {
  541. // Remove the helper div:
  542. this._helperBlock.remove();
  543. this.rzStop.emit(this.getResizingEvent());
  544. this._handleResizing = null;
  545. this._direction = null;
  546. this._origSize = null;
  547. this._origPos = null;
  548. if (this._containment) {
  549. this.resetBounding();
  550. }
  551. };
  552. /**
  553. * @private
  554. * @return {?}
  555. */
  556. AngularResizableDirective.prototype.onResizing = /**
  557. * @private
  558. * @return {?}
  559. */
  560. function () {
  561. this.rzResizing.emit(this.getResizingEvent());
  562. };
  563. /**
  564. * @private
  565. * @return {?}
  566. */
  567. AngularResizableDirective.prototype.getResizingEvent = /**
  568. * @private
  569. * @return {?}
  570. */
  571. function () {
  572. return {
  573. host: this.el.nativeElement,
  574. handle: this._handleResizing ? this._handleResizing.el : null,
  575. size: {
  576. width: this._currSize.width,
  577. height: this._currSize.height
  578. },
  579. position: {
  580. top: this._currPos.y,
  581. left: this._currPos.x
  582. },
  583. direction: tslib_1.__assign({}, this._directionChanged),
  584. };
  585. };
  586. /**
  587. * @private
  588. * @return {?}
  589. */
  590. AngularResizableDirective.prototype.updateDirection = /**
  591. * @private
  592. * @return {?}
  593. */
  594. function () {
  595. this._direction = {
  596. n: !!this._handleResizing.type.match(/n/),
  597. s: !!this._handleResizing.type.match(/s/),
  598. w: !!this._handleResizing.type.match(/w/),
  599. e: !!this._handleResizing.type.match(/e/)
  600. };
  601. this._directionChanged = tslib_1.__assign({}, this._direction);
  602. // if aspect ration should be preserved:
  603. if (this.rzAspectRatio) {
  604. // if north then west (unless ne)
  605. if (this._directionChanged.n && !this._directionChanged.e) {
  606. this._directionChanged.w = true;
  607. }
  608. // if south then east (unless sw)
  609. if (this._directionChanged.s && !this._directionChanged.w) {
  610. this._directionChanged.e = true;
  611. }
  612. // if east then south (unless ne)
  613. if (this._directionChanged.e && !this._directionChanged.n) {
  614. this._directionChanged.s = true;
  615. }
  616. // if west then south (unless nw)
  617. if (this._directionChanged.w && !this._directionChanged.n) {
  618. this._directionChanged.s = true;
  619. }
  620. }
  621. };
  622. /**
  623. * @private
  624. * @param {?} p
  625. * @return {?}
  626. */
  627. AngularResizableDirective.prototype.resizeTo = /**
  628. * @private
  629. * @param {?} p
  630. * @return {?}
  631. */
  632. function (p) {
  633. p.subtract(this._origMousePos);
  634. /** @type {?} */
  635. var tmpX = Math.round(p.x / this._gridSize.x) * this._gridSize.x;
  636. /** @type {?} */
  637. var tmpY = Math.round(p.y / this._gridSize.y) * this._gridSize.y;
  638. if (this._direction.n) {
  639. // n, ne, nw
  640. this._currPos.y = this._origPos.y + tmpY;
  641. this._currSize.height = this._origSize.height - tmpY;
  642. }
  643. else if (this._direction.s) {
  644. // s, se, sw
  645. this._currSize.height = this._origSize.height + tmpY;
  646. }
  647. if (this._direction.e) {
  648. // e, ne, se
  649. this._currSize.width = this._origSize.width + tmpX;
  650. }
  651. else if (this._direction.w) {
  652. // w, nw, sw
  653. this._currSize.width = this._origSize.width - tmpX;
  654. this._currPos.x = this._origPos.x + tmpX;
  655. }
  656. this.checkBounds();
  657. this.checkSize();
  658. this.adjustByRatio();
  659. this.doResize();
  660. };
  661. /**
  662. * @private
  663. * @return {?}
  664. */
  665. AngularResizableDirective.prototype.doResize = /**
  666. * @private
  667. * @return {?}
  668. */
  669. function () {
  670. /** @type {?} */
  671. var container = this.el.nativeElement;
  672. if (!this._direction || this._direction.n || this._direction.s || this._aspectRatio) {
  673. this.renderer.setStyle(container, 'height', this._currSize.height + 'px');
  674. }
  675. if (!this._direction || this._direction.w || this._direction.e || this._aspectRatio) {
  676. this.renderer.setStyle(container, 'width', this._currSize.width + 'px');
  677. }
  678. this.renderer.setStyle(container, 'left', this._currPos.x + 'px');
  679. this.renderer.setStyle(container, 'top', this._currPos.y + 'px');
  680. };
  681. /**
  682. * @private
  683. * @return {?}
  684. */
  685. AngularResizableDirective.prototype.adjustByRatio = /**
  686. * @private
  687. * @return {?}
  688. */
  689. function () {
  690. if (this._aspectRatio && !this._adjusted) {
  691. if (this._direction.e || this._direction.w) {
  692. /** @type {?} */
  693. var newHeight = Math.floor(this._currSize.width / this._aspectRatio);
  694. if (this._direction.n) {
  695. this._currPos.y += this._currSize.height - newHeight;
  696. }
  697. this._currSize.height = newHeight;
  698. }
  699. else {
  700. /** @type {?} */
  701. var newWidth = Math.floor(this._aspectRatio * this._currSize.height);
  702. if (this._direction.n) {
  703. this._currPos.x += this._currSize.width - newWidth;
  704. }
  705. this._currSize.width = newWidth;
  706. }
  707. }
  708. };
  709. /**
  710. * @private
  711. * @return {?}
  712. */
  713. AngularResizableDirective.prototype.checkBounds = /**
  714. * @private
  715. * @return {?}
  716. */
  717. function () {
  718. if (this._containment) {
  719. /** @type {?} */
  720. var maxWidth = this._bounding.width - this._bounding.pr - this._bounding.deltaL - this._bounding.translateX - this._currPos.x;
  721. /** @type {?} */
  722. var maxHeight = this._bounding.height - this._bounding.pb - this._bounding.deltaT - this._bounding.translateY - this._currPos.y;
  723. if (this._direction.n && (this._currPos.y + this._bounding.translateY < 0)) {
  724. this._currPos.y = -this._bounding.translateY;
  725. this._currSize.height = this._origSize.height + this._origPos.y + this._bounding.translateY;
  726. }
  727. if (this._direction.w && (this._currPos.x + this._bounding.translateX) < 0) {
  728. this._currPos.x = -this._bounding.translateX;
  729. this._currSize.width = this._origSize.width + this._origPos.x + this._bounding.translateX;
  730. }
  731. if (this._currSize.width > maxWidth) {
  732. this._currSize.width = maxWidth;
  733. }
  734. if (this._currSize.height > maxHeight) {
  735. this._currSize.height = maxHeight;
  736. }
  737. /**
  738. * Fix Issue: Additional check for aspect ratio
  739. * https://github.com/xieziyu/angular2-draggable/issues/132
  740. */
  741. if (this._aspectRatio) {
  742. this._adjusted = false;
  743. if ((this._direction.w || this._direction.e) &&
  744. (this._currSize.width / this._aspectRatio) >= maxHeight) {
  745. /** @type {?} */
  746. var newWidth = Math.floor(maxHeight * this._aspectRatio);
  747. if (this._direction.w) {
  748. this._currPos.x += this._currSize.width - newWidth;
  749. }
  750. this._currSize.width = newWidth;
  751. this._currSize.height = maxHeight;
  752. this._adjusted = true;
  753. }
  754. if ((this._direction.n || this._direction.s) &&
  755. (this._currSize.height * this._aspectRatio) >= maxWidth) {
  756. /** @type {?} */
  757. var newHeight = Math.floor(maxWidth / this._aspectRatio);
  758. if (this._direction.n) {
  759. this._currPos.y += this._currSize.height - newHeight;
  760. }
  761. this._currSize.width = maxWidth;
  762. this._currSize.height = newHeight;
  763. this._adjusted = true;
  764. }
  765. }
  766. }
  767. };
  768. /**
  769. * @private
  770. * @return {?}
  771. */
  772. AngularResizableDirective.prototype.checkSize = /**
  773. * @private
  774. * @return {?}
  775. */
  776. function () {
  777. /** @type {?} */
  778. var minHeight = !this.rzMinHeight ? 1 : this.rzMinHeight;
  779. /** @type {?} */
  780. var minWidth = !this.rzMinWidth ? 1 : this.rzMinWidth;
  781. if (this._currSize.height < minHeight) {
  782. this._currSize.height = minHeight;
  783. if (this._direction.n) {
  784. this._currPos.y = this._origPos.y + (this._origSize.height - minHeight);
  785. }
  786. }
  787. if (this._currSize.width < minWidth) {
  788. this._currSize.width = minWidth;
  789. if (this._direction.w) {
  790. this._currPos.x = this._origPos.x + (this._origSize.width - minWidth);
  791. }
  792. }
  793. if (this.rzMaxHeight && this._currSize.height > this.rzMaxHeight) {
  794. this._currSize.height = this.rzMaxHeight;
  795. if (this._direction.n) {
  796. this._currPos.y = this._origPos.y + (this._origSize.height - this.rzMaxHeight);
  797. }
  798. }
  799. if (this.rzMaxWidth && this._currSize.width > this.rzMaxWidth) {
  800. this._currSize.width = this.rzMaxWidth;
  801. if (this._direction.w) {
  802. this._currPos.x = this._origPos.x + (this._origSize.width - this.rzMaxWidth);
  803. }
  804. }
  805. };
  806. /**
  807. * @private
  808. * @return {?}
  809. */
  810. AngularResizableDirective.prototype.getBounding = /**
  811. * @private
  812. * @return {?}
  813. */
  814. function () {
  815. /** @type {?} */
  816. var el = this._containment;
  817. /** @type {?} */
  818. var computed = window.getComputedStyle(el);
  819. if (computed) {
  820. /** @type {?} */
  821. var p = computed.getPropertyValue('position');
  822. /** @type {?} */
  823. var nativeEl = window.getComputedStyle(this.el.nativeElement);
  824. /** @type {?} */
  825. var transforms = nativeEl.getPropertyValue('transform').replace(/[^-\d,]/g, '').split(',');
  826. this._bounding = {};
  827. this._bounding.width = el.clientWidth;
  828. this._bounding.height = el.clientHeight;
  829. this._bounding.pr = parseInt(computed.getPropertyValue('padding-right'), 10);
  830. this._bounding.pb = parseInt(computed.getPropertyValue('padding-bottom'), 10);
  831. this._bounding.deltaL = this.el.nativeElement.offsetLeft - this._currPos.x;
  832. this._bounding.deltaT = this.el.nativeElement.offsetTop - this._currPos.y;
  833. if (transforms.length >= 6) {
  834. this._bounding.translateX = parseInt(transforms[4], 10);
  835. this._bounding.translateY = parseInt(transforms[5], 10);
  836. }
  837. else {
  838. this._bounding.translateX = 0;
  839. this._bounding.translateY = 0;
  840. }
  841. this._bounding.position = computed.getPropertyValue('position');
  842. if (p === 'static') {
  843. this.renderer.setStyle(el, 'position', 'relative');
  844. }
  845. }
  846. };
  847. /**
  848. * @private
  849. * @return {?}
  850. */
  851. AngularResizableDirective.prototype.resetBounding = /**
  852. * @private
  853. * @return {?}
  854. */
  855. function () {
  856. if (this._bounding && this._bounding.position === 'static') {
  857. this.renderer.setStyle(this._containment, 'position', 'relative');
  858. }
  859. this._bounding = null;
  860. };
  861. /**
  862. * @private
  863. * @return {?}
  864. */
  865. AngularResizableDirective.prototype.getGridSize = /**
  866. * @private
  867. * @return {?}
  868. */
  869. function () {
  870. // set default value:
  871. this._gridSize = { x: 1, y: 1 };
  872. if (this.rzGrid) {
  873. if (typeof this.rzGrid === 'number') {
  874. this._gridSize = { x: this.rzGrid, y: this.rzGrid };
  875. }
  876. else if (Array.isArray(this.rzGrid)) {
  877. this._gridSize = { x: this.rzGrid[0], y: this.rzGrid[1] };
  878. }
  879. }
  880. };
  881. AngularResizableDirective.decorators = [
  882. { type: Directive, args: [{
  883. selector: '[ngResizable]',
  884. exportAs: 'ngResizable'
  885. },] }
  886. ];
  887. /** @nocollapse */
  888. AngularResizableDirective.ctorParameters = function () { return [
  889. { type: ElementRef },
  890. { type: Renderer2 }
  891. ]; };
  892. AngularResizableDirective.propDecorators = {
  893. ngResizable: [{ type: Input }],
  894. rzHandles: [{ type: Input }],
  895. rzAspectRatio: [{ type: Input }],
  896. rzContainment: [{ type: Input }],
  897. rzGrid: [{ type: Input }],
  898. rzMinWidth: [{ type: Input }],
  899. rzMinHeight: [{ type: Input }],
  900. rzMaxWidth: [{ type: Input }],
  901. rzMaxHeight: [{ type: Input }],
  902. preventDefaultEvent: [{ type: Input }],
  903. rzStart: [{ type: Output }],
  904. rzResizing: [{ type: Output }],
  905. rzStop: [{ type: Output }]
  906. };
  907. return AngularResizableDirective;
  908. }());
  909. export { AngularResizableDirective };
  910. if (false) {
  911. /**
  912. * @type {?}
  913. * @private
  914. */
  915. AngularResizableDirective.prototype._resizable;
  916. /**
  917. * @type {?}
  918. * @private
  919. */
  920. AngularResizableDirective.prototype._handles;
  921. /**
  922. * @type {?}
  923. * @private
  924. */
  925. AngularResizableDirective.prototype._handleType;
  926. /**
  927. * @type {?}
  928. * @private
  929. */
  930. AngularResizableDirective.prototype._handleResizing;
  931. /**
  932. * @type {?}
  933. * @private
  934. */
  935. AngularResizableDirective.prototype._direction;
  936. /**
  937. * @type {?}
  938. * @private
  939. */
  940. AngularResizableDirective.prototype._directionChanged;
  941. /**
  942. * @type {?}
  943. * @private
  944. */
  945. AngularResizableDirective.prototype._aspectRatio;
  946. /**
  947. * @type {?}
  948. * @private
  949. */
  950. AngularResizableDirective.prototype._containment;
  951. /**
  952. * @type {?}
  953. * @private
  954. */
  955. AngularResizableDirective.prototype._origMousePos;
  956. /**
  957. * Original Size and Position
  958. * @type {?}
  959. * @private
  960. */
  961. AngularResizableDirective.prototype._origSize;
  962. /**
  963. * @type {?}
  964. * @private
  965. */
  966. AngularResizableDirective.prototype._origPos;
  967. /**
  968. * Current Size and Position
  969. * @type {?}
  970. * @private
  971. */
  972. AngularResizableDirective.prototype._currSize;
  973. /**
  974. * @type {?}
  975. * @private
  976. */
  977. AngularResizableDirective.prototype._currPos;
  978. /**
  979. * Initial Size and Position
  980. * @type {?}
  981. * @private
  982. */
  983. AngularResizableDirective.prototype._initSize;
  984. /**
  985. * @type {?}
  986. * @private
  987. */
  988. AngularResizableDirective.prototype._initPos;
  989. /**
  990. * Snap to gird
  991. * @type {?}
  992. * @private
  993. */
  994. AngularResizableDirective.prototype._gridSize;
  995. /**
  996. * @type {?}
  997. * @private
  998. */
  999. AngularResizableDirective.prototype._bounding;
  1000. /**
  1001. * Bugfix: iFrames, and context unrelated elements block all events, and are unusable
  1002. * https://github.com/xieziyu/angular2-draggable/issues/84
  1003. * @type {?}
  1004. * @private
  1005. */
  1006. AngularResizableDirective.prototype._helperBlock;
  1007. /**
  1008. * @type {?}
  1009. * @private
  1010. */
  1011. AngularResizableDirective.prototype.draggingSub;
  1012. /**
  1013. * @type {?}
  1014. * @private
  1015. */
  1016. AngularResizableDirective.prototype._adjusted;
  1017. /**
  1018. * Which handles can be used for resizing.
  1019. * \@example
  1020. * [rzHandles] = "'n,e,s,w,se,ne,sw,nw'"
  1021. * equals to: [rzHandles] = "'all'"
  1022. *
  1023. *
  1024. * @type {?}
  1025. */
  1026. AngularResizableDirective.prototype.rzHandles;
  1027. /**
  1028. * Whether the element should be constrained to a specific aspect ratio.
  1029. * Multiple types supported:
  1030. * boolean: When set to true, the element will maintain its original aspect ratio.
  1031. * number: Force the element to maintain a specific aspect ratio during resizing.
  1032. * @type {?}
  1033. */
  1034. AngularResizableDirective.prototype.rzAspectRatio;
  1035. /**
  1036. * Constrains resizing to within the bounds of the specified element or region.
  1037. * Multiple types supported:
  1038. * Selector: The resizable element will be contained to the bounding box of the first element found by the selector.
  1039. * If no element is found, no containment will be set.
  1040. * Element: The resizable element will be contained to the bounding box of this element.
  1041. * String: Possible values: "parent".
  1042. * @type {?}
  1043. */
  1044. AngularResizableDirective.prototype.rzContainment;
  1045. /**
  1046. * Snaps the resizing element to a grid, every x and y pixels.
  1047. * A number for both width and height or an array values like [ x, y ]
  1048. * @type {?}
  1049. */
  1050. AngularResizableDirective.prototype.rzGrid;
  1051. /**
  1052. * The minimum width the resizable should be allowed to resize to.
  1053. * @type {?}
  1054. */
  1055. AngularResizableDirective.prototype.rzMinWidth;
  1056. /**
  1057. * The minimum height the resizable should be allowed to resize to.
  1058. * @type {?}
  1059. */
  1060. AngularResizableDirective.prototype.rzMinHeight;
  1061. /**
  1062. * The maximum width the resizable should be allowed to resize to.
  1063. * @type {?}
  1064. */
  1065. AngularResizableDirective.prototype.rzMaxWidth;
  1066. /**
  1067. * The maximum height the resizable should be allowed to resize to.
  1068. * @type {?}
  1069. */
  1070. AngularResizableDirective.prototype.rzMaxHeight;
  1071. /**
  1072. * Whether to prevent default event
  1073. * @type {?}
  1074. */
  1075. AngularResizableDirective.prototype.preventDefaultEvent;
  1076. /**
  1077. * emitted when start resizing
  1078. * @type {?}
  1079. */
  1080. AngularResizableDirective.prototype.rzStart;
  1081. /**
  1082. * emitted when start resizing
  1083. * @type {?}
  1084. */
  1085. AngularResizableDirective.prototype.rzResizing;
  1086. /**
  1087. * emitted when stop resizing
  1088. * @type {?}
  1089. */
  1090. AngularResizableDirective.prototype.rzStop;
  1091. /**
  1092. * @type {?}
  1093. * @private
  1094. */
  1095. AngularResizableDirective.prototype.el;
  1096. /**
  1097. * @type {?}
  1098. * @private
  1099. */
  1100. AngularResizableDirective.prototype.renderer;
  1101. }
  1102. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"angular-resizable.directive.js","sourceRoot":"ng://angular2-draggable/","sources":["lib/angular-resizable.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive, ElementRef, Renderer2,\n  Input, Output, OnInit, EventEmitter, OnChanges, SimpleChanges,\n  OnDestroy, AfterViewInit\n} from '@angular/core';\n\nimport { Subscription, fromEvent } from 'rxjs';\nimport { HelperBlock } from './widgets/helper-block';\nimport { ResizeHandle } from './widgets/resize-handle';\nimport { ResizeHandleType } from './models/resize-handle-type';\nimport { Position, IPosition } from './models/position';\nimport { Size } from './models/size';\nimport { IResizeEvent } from './models/resize-event';\n\n@Directive({\n  selector: '[ngResizable]',\n  exportAs: 'ngResizable'\n})\nexport class AngularResizableDirective implements OnInit, OnChanges, OnDestroy, AfterViewInit {\n  private _resizable = true;\n  private _handles: { [key: string]: ResizeHandle } = {};\n  private _handleType: string[] = [];\n  private _handleResizing: ResizeHandle = null;\n  private _direction: { 'n': boolean, 's': boolean, 'w': boolean, 'e': boolean } = null;\n  private _directionChanged: { 'n': boolean, 's': boolean, 'w': boolean, 'e': boolean } = null;\n  private _aspectRatio = 0;\n  private _containment: HTMLElement = null;\n  private _origMousePos: Position = null;\n\n  /** Original Size and Position */\n  private _origSize: Size = null;\n  private _origPos: Position = null;\n\n  /** Current Size and Position */\n  private _currSize: Size = null;\n  private _currPos: Position = null;\n\n  /** Initial Size and Position */\n  private _initSize: Size = null;\n  private _initPos: Position = null;\n\n  /** Snap to gird */\n  private _gridSize: IPosition = null;\n\n  private _bounding: any = null;\n\n  /**\n   * Bugfix: iFrames, and context unrelated elements block all events, and are unusable\n   * https://github.com/xieziyu/angular2-draggable/issues/84\n   */\n  private _helperBlock: HelperBlock = null;\n\n  private draggingSub: Subscription = null;\n  private _adjusted = false;\n\n  /** Disables the resizable if set to false. */\n  @Input() set ngResizable(v: any) {\n    if (v !== undefined && v !== null && v !== '') {\n      this._resizable = !!v;\n      this.updateResizable();\n    }\n  }\n\n  /**\n   * Which handles can be used for resizing.\n   * @example\n   * [rzHandles] = \"'n,e,s,w,se,ne,sw,nw'\"\n   * equals to: [rzHandles] = \"'all'\"\n   *\n   * */\n  @Input() rzHandles: ResizeHandleType = 'e,s,se';\n\n  /**\n   * Whether the element should be constrained to a specific aspect ratio.\n   *  Multiple types supported:\n   *  boolean: When set to true, the element will maintain its original aspect ratio.\n   *  number: Force the element to maintain a specific aspect ratio during resizing.\n   */\n  @Input() rzAspectRatio: boolean | number = false;\n\n  /**\n   * Constrains resizing to within the bounds of the specified element or region.\n   *  Multiple types supported:\n   *  Selector: The resizable element will be contained to the bounding box of the first element found by the selector.\n   *            If no element is found, no containment will be set.\n   *  Element: The resizable element will be contained to the bounding box of this element.\n   *  String: Possible values: \"parent\".\n   */\n  @Input() rzContainment: string | HTMLElement = null;\n\n  /**\n   * Snaps the resizing element to a grid, every x and y pixels.\n   * A number for both width and height or an array values like [ x, y ]\n   */\n  @Input() rzGrid: number | number[] = null;\n\n  /** The minimum width the resizable should be allowed to resize to. */\n  @Input() rzMinWidth: number = null;\n\n  /** The minimum height the resizable should be allowed to resize to. */\n  @Input() rzMinHeight: number = null;\n\n  /** The maximum width the resizable should be allowed to resize to. */\n  @Input() rzMaxWidth: number = null;\n\n  /** The maximum height the resizable should be allowed to resize to. */\n  @Input() rzMaxHeight: number = null;\n\n  /** Whether to prevent default event */\n  @Input() preventDefaultEvent = true;\n\n  /** emitted when start resizing */\n  @Output() rzStart = new EventEmitter<IResizeEvent>();\n\n  /** emitted when start resizing */\n  @Output() rzResizing = new EventEmitter<IResizeEvent>();\n\n  /** emitted when stop resizing */\n  @Output() rzStop = new EventEmitter<IResizeEvent>();\n\n  constructor(private el: ElementRef<HTMLElement>, private renderer: Renderer2) {\n    this._helperBlock = new HelperBlock(el.nativeElement, renderer);\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['rzHandles'] && !changes['rzHandles'].isFirstChange()) {\n      this.updateResizable();\n    }\n\n    if (changes['rzAspectRatio'] && !changes['rzAspectRatio'].isFirstChange()) {\n      this.updateAspectRatio();\n    }\n\n    if (changes['rzContainment'] && !changes['rzContainment'].isFirstChange()) {\n      this.updateContainment();\n    }\n  }\n\n  ngOnInit() {\n    this.updateResizable();\n  }\n\n  ngOnDestroy() {\n    this.removeHandles();\n    this._containment = null;\n    this._helperBlock.dispose();\n    this._helperBlock = null;\n  }\n\n  ngAfterViewInit() {\n    const elm = this.el.nativeElement;\n    this._initSize = Size.getCurrent(elm);\n    this._initPos = Position.getCurrent(elm);\n    this._currSize = Size.copy(this._initSize);\n    this._currPos = Position.copy(this._initPos);\n    this.updateAspectRatio();\n    this.updateContainment();\n  }\n\n  /** A method to reset size */\n  public resetSize() {\n    this._currSize = Size.copy(this._initSize);\n    this._currPos = Position.copy(this._initPos);\n    this.doResize();\n  }\n\n  /** A method to get current status */\n  public getStatus() {\n    if (!this._currPos || !this._currSize) {\n      return null;\n    }\n\n    return {\n      size: {\n        width: this._currSize.width,\n        height: this._currSize.height\n      },\n      position: {\n        top: this._currPos.y,\n        left: this._currPos.x\n      }\n    };\n  }\n\n  private updateResizable() {\n    const element = this.el.nativeElement;\n\n    // clear handles:\n    this.renderer.removeClass(element, 'ng-resizable');\n    this.removeHandles();\n\n    // create new ones:\n    if (this._resizable) {\n      this.renderer.addClass(element, 'ng-resizable');\n      this.createHandles();\n    }\n  }\n\n  /** Use it to update aspect */\n  private updateAspectRatio() {\n    if (typeof this.rzAspectRatio === 'boolean') {\n      if (this.rzAspectRatio && this._currSize.height) {\n        this._aspectRatio = (this._currSize.width / this._currSize.height);\n      } else {\n        this._aspectRatio = 0;\n      }\n    } else {\n      let r = Number(this.rzAspectRatio);\n      this._aspectRatio = isNaN(r) ? 0 : r;\n    }\n  }\n\n  /** Use it to update containment */\n  private updateContainment() {\n    if (!this.rzContainment) {\n      this._containment = null;\n      return;\n    }\n\n    if (typeof this.rzContainment === 'string') {\n      if (this.rzContainment === 'parent') {\n        this._containment = this.el.nativeElement.parentElement;\n      } else {\n        this._containment = document.querySelector<HTMLElement>(this.rzContainment);\n      }\n    } else {\n      this._containment = this.rzContainment;\n    }\n  }\n\n  /** Use it to create handle divs */\n  private createHandles() {\n    if (!this.rzHandles) {\n      return;\n    }\n\n    let tmpHandleTypes: string[];\n    if (typeof this.rzHandles === 'string') {\n      if (this.rzHandles === 'all') {\n        tmpHandleTypes = ['n', 'e', 's', 'w', 'ne', 'se', 'nw', 'sw'];\n      } else {\n        tmpHandleTypes = this.rzHandles.replace(/ /g, '').toLowerCase().split(',');\n      }\n\n      for (let type of tmpHandleTypes) {\n        // default handle theme: ng-resizable-$type.\n        let handle = this.createHandleByType(type, `ng-resizable-${type}`);\n        if (handle) {\n          this._handleType.push(type);\n          this._handles[type] = handle;\n        }\n      }\n    } else {\n      tmpHandleTypes = Object.keys(this.rzHandles);\n      for (let type of tmpHandleTypes) {\n        // custom handle theme.\n        let handle = this.createHandleByType(type, this.rzHandles[type]);\n        if (handle) {\n          this._handleType.push(type);\n          this._handles[type] = handle;\n        }\n      }\n    }\n\n  }\n\n  /** Use it to create a handle */\n  private createHandleByType(type: string, css: string): ResizeHandle {\n    const _el = this.el.nativeElement;\n\n    if (!type.match(/^(se|sw|ne|nw|n|e|s|w)$/)) {\n      console.error('Invalid handle type:', type);\n      return null;\n    }\n\n    return new ResizeHandle(_el, this.renderer, type, css, this.onMouseDown.bind(this));\n  }\n\n  private removeHandles() {\n    for (let type of this._handleType) {\n      this._handles[type].dispose();\n    }\n\n    this._handleType = [];\n    this._handles = {};\n  }\n\n  onMouseDown(event: MouseEvent | TouchEvent, handle: ResizeHandle) {\n    // skip right click;\n    if (event instanceof MouseEvent && event.button === 2) {\n      return;\n    }\n\n    if (this.preventDefaultEvent) {\n      // prevent default events\n      event.stopPropagation();\n      event.preventDefault();\n    }\n\n    if (!this._handleResizing) {\n      this._origMousePos = Position.fromEvent(event);\n      this.startResize(handle);\n\n      this.subscribeEvents();\n    }\n  }\n\n  private subscribeEvents() {\n    this.draggingSub = fromEvent(document, 'mousemove', { passive: false }).subscribe(event => this.onMouseMove(event as MouseEvent));\n    this.draggingSub.add(fromEvent(document, 'touchmove', { passive: false }).subscribe(event => this.onMouseMove(event as TouchEvent)));\n    this.draggingSub.add(fromEvent(document, 'mouseup', { passive: false }).subscribe(() => this.onMouseLeave()));\n    // fix for issue #164\n    let isIEOrEdge = /msie\\s|trident\\//i.test(window.navigator.userAgent);\n    if (!isIEOrEdge) {\n      this.draggingSub.add(fromEvent(document, 'mouseleave', { passive: false }).subscribe(() => this.onMouseLeave()));\n    }\n    this.draggingSub.add(fromEvent(document, 'touchend', { passive: false }).subscribe(() => this.onMouseLeave()));\n    this.draggingSub.add(fromEvent(document, 'touchcancel', { passive: false }).subscribe(() => this.onMouseLeave()));\n  }\n\n  private unsubscribeEvents() {\n    this.draggingSub.unsubscribe();\n    this.draggingSub = null;\n  }\n\n  onMouseLeave() {\n    if (this._handleResizing) {\n      this.stopResize();\n      this._origMousePos = null;\n      this.unsubscribeEvents();\n    }\n  }\n\n  onMouseMove(event: MouseEvent | TouchEvent) {\n    if (this._handleResizing && this._resizable && this._origMousePos && this._origPos && this._origSize) {\n      this.resizeTo(Position.fromEvent(event));\n      this.onResizing();\n    }\n  }\n\n  private startResize(handle: ResizeHandle) {\n    const elm = this.el.nativeElement;\n    this._origSize = Size.getCurrent(elm);\n    this._origPos = Position.getCurrent(elm); // x: left, y: top\n    this._currSize = Size.copy(this._origSize);\n    this._currPos = Position.copy(this._origPos);\n    if (this._containment) {\n      this.getBounding();\n    }\n    this.getGridSize();\n\n    // Add a transparent helper div:\n    this._helperBlock.add();\n    this._handleResizing = handle;\n    this.updateDirection();\n    this.rzStart.emit(this.getResizingEvent());\n  }\n\n  private stopResize() {\n    // Remove the helper div:\n    this._helperBlock.remove();\n    this.rzStop.emit(this.getResizingEvent());\n    this._handleResizing = null;\n    this._direction = null;\n    this._origSize = null;\n    this._origPos = null;\n    if (this._containment) {\n      this.resetBounding();\n    }\n  }\n\n  private onResizing() {\n    this.rzResizing.emit(this.getResizingEvent());\n  }\n\n  private getResizingEvent(): IResizeEvent {\n    return {\n      host: this.el.nativeElement,\n      handle: this._handleResizing ? this._handleResizing.el : null,\n      size: {\n        width: this._currSize.width,\n        height: this._currSize.height\n      },\n      position: {\n        top: this._currPos.y,\n        left: this._currPos.x\n      },\n      direction: { ...this._directionChanged },\n    };\n  }\n\n  private updateDirection() {\n    this._direction = {\n      n: !!this._handleResizing.type.match(/n/),\n      s: !!this._handleResizing.type.match(/s/),\n      w: !!this._handleResizing.type.match(/w/),\n      e: !!this._handleResizing.type.match(/e/)\n    };\n\n    this._directionChanged = { ...this._direction };\n\n    // if aspect ration should be preserved:\n    if (this.rzAspectRatio) {\n\n      // if north then west (unless ne)\n      if (this._directionChanged.n && !this._directionChanged.e) {\n        this._directionChanged.w = true;\n      }\n\n      // if south then east (unless sw)\n      if (this._directionChanged.s && !this._directionChanged.w) {\n        this._directionChanged.e = true;\n      }\n\n      // if east then south (unless ne)\n      if (this._directionChanged.e && !this._directionChanged.n) {\n        this._directionChanged.s = true;\n      }\n\n      // if west then south (unless nw)\n      if (this._directionChanged.w && !this._directionChanged.n) {\n        this._directionChanged.s = true;\n      }\n    }\n  }\n\n  private resizeTo(p: Position) {\n    p.subtract(this._origMousePos);\n\n    const tmpX = Math.round(p.x / this._gridSize.x) * this._gridSize.x;\n    const tmpY = Math.round(p.y / this._gridSize.y) * this._gridSize.y;\n\n    if (this._direction.n) {\n      // n, ne, nw\n      this._currPos.y = this._origPos.y + tmpY;\n      this._currSize.height = this._origSize.height - tmpY;\n    } else if (this._direction.s) {\n      // s, se, sw\n      this._currSize.height = this._origSize.height + tmpY;\n    }\n\n    if (this._direction.e) {\n      // e, ne, se\n      this._currSize.width = this._origSize.width + tmpX;\n    } else if (this._direction.w) {\n      // w, nw, sw\n      this._currSize.width = this._origSize.width - tmpX;\n      this._currPos.x = this._origPos.x + tmpX;\n    }\n\n    this.checkBounds();\n    this.checkSize();\n    this.adjustByRatio();\n    this.doResize();\n  }\n\n  private doResize() {\n    const container = this.el.nativeElement;\n    if (!this._direction || this._direction.n || this._direction.s || this._aspectRatio) {\n      this.renderer.setStyle(container, 'height', this._currSize.height + 'px');\n    }\n    if (!this._direction || this._direction.w || this._direction.e || this._aspectRatio) {\n      this.renderer.setStyle(container, 'width', this._currSize.width + 'px');\n    }\n    this.renderer.setStyle(container, 'left', this._currPos.x + 'px');\n    this.renderer.setStyle(container, 'top', this._currPos.y + 'px');\n  }\n\n  private adjustByRatio() {\n    if (this._aspectRatio && !this._adjusted) {\n      if (this._direction.e || this._direction.w) {\n        const newHeight = Math.floor(this._currSize.width / this._aspectRatio);\n\n        if (this._direction.n) {\n          this._currPos.y += this._currSize.height - newHeight;\n        }\n\n        this._currSize.height = newHeight;\n      } else {\n        const newWidth = Math.floor(this._aspectRatio * this._currSize.height);\n\n        if (this._direction.n) {\n          this._currPos.x += this._currSize.width - newWidth;\n        }\n\n        this._currSize.width = newWidth;\n      }\n    }\n  }\n\n  private checkBounds() {\n    if (this._containment) {\n      const maxWidth = this._bounding.width - this._bounding.pr - this._bounding.deltaL - this._bounding.translateX - this._currPos.x;\n      const maxHeight = this._bounding.height - this._bounding.pb - this._bounding.deltaT - this._bounding.translateY - this._currPos.y;\n\n      if (this._direction.n && (this._currPos.y + this._bounding.translateY < 0)) {\n        this._currPos.y = -this._bounding.translateY;\n        this._currSize.height = this._origSize.height + this._origPos.y + this._bounding.translateY;\n      }\n\n      if (this._direction.w && (this._currPos.x + this._bounding.translateX) < 0) {\n        this._currPos.x = -this._bounding.translateX;\n        this._currSize.width = this._origSize.width + this._origPos.x + this._bounding.translateX;\n      }\n\n      if (this._currSize.width > maxWidth) {\n        this._currSize.width = maxWidth;\n      }\n\n      if (this._currSize.height > maxHeight) {\n        this._currSize.height = maxHeight;\n      }\n\n      /**\n       * Fix Issue: Additional check for aspect ratio\n       * https://github.com/xieziyu/angular2-draggable/issues/132\n       */\n      if (this._aspectRatio) {\n        this._adjusted = false;\n\n        if ((this._direction.w || this._direction.e) &&\n            (this._currSize.width / this._aspectRatio) >= maxHeight) {\n          const newWidth = Math.floor(maxHeight * this._aspectRatio);\n\n          if (this._direction.w) {\n            this._currPos.x += this._currSize.width - newWidth;\n          }\n\n          this._currSize.width = newWidth;\n          this._currSize.height = maxHeight;\n          this._adjusted = true;\n        }\n\n        if ((this._direction.n || this._direction.s) &&\n            (this._currSize.height * this._aspectRatio) >= maxWidth) {\n          const newHeight = Math.floor(maxWidth / this._aspectRatio);\n\n          if (this._direction.n) {\n            this._currPos.y += this._currSize.height - newHeight;\n          }\n\n          this._currSize.width = maxWidth;\n          this._currSize.height = newHeight;\n          this._adjusted = true;\n        }\n      }\n    }\n  }\n\n  private checkSize() {\n    const minHeight = !this.rzMinHeight ? 1 : this.rzMinHeight;\n    const minWidth = !this.rzMinWidth ? 1 : this.rzMinWidth;\n\n    if (this._currSize.height < minHeight) {\n      this._currSize.height = minHeight;\n\n      if (this._direction.n) {\n        this._currPos.y = this._origPos.y + (this._origSize.height - minHeight);\n      }\n    }\n\n    if (this._currSize.width < minWidth) {\n      this._currSize.width = minWidth;\n\n      if (this._direction.w) {\n        this._currPos.x = this._origPos.x + (this._origSize.width - minWidth);\n      }\n    }\n\n    if (this.rzMaxHeight && this._currSize.height > this.rzMaxHeight) {\n      this._currSize.height = this.rzMaxHeight;\n\n      if (this._direction.n) {\n        this._currPos.y = this._origPos.y + (this._origSize.height - this.rzMaxHeight);\n      }\n    }\n\n    if (this.rzMaxWidth && this._currSize.width > this.rzMaxWidth) {\n      this._currSize.width = this.rzMaxWidth;\n\n      if (this._direction.w) {\n        this._currPos.x = this._origPos.x + (this._origSize.width - this.rzMaxWidth);\n      }\n    }\n  }\n\n  private getBounding() {\n    const el = this._containment;\n    const computed = window.getComputedStyle(el);\n    if (computed) {\n      let p = computed.getPropertyValue('position');\n\n      const nativeEl = window.getComputedStyle(this.el.nativeElement);\n      let transforms = nativeEl.getPropertyValue('transform').replace(/[^-\\d,]/g, '').split(',');\n\n      this._bounding = {};\n      this._bounding.width = el.clientWidth;\n      this._bounding.height = el.clientHeight;\n      this._bounding.pr = parseInt(computed.getPropertyValue('padding-right'), 10);\n      this._bounding.pb = parseInt(computed.getPropertyValue('padding-bottom'), 10);\n      this._bounding.deltaL = this.el.nativeElement.offsetLeft - this._currPos.x;\n      this._bounding.deltaT = this.el.nativeElement.offsetTop - this._currPos.y;\n\n      if (transforms.length >= 6) {\n        this._bounding.translateX = parseInt(transforms[4], 10);\n        this._bounding.translateY = parseInt(transforms[5], 10);\n      } else {\n        this._bounding.translateX = 0;\n        this._bounding.translateY = 0;\n      }\n\n      this._bounding.position = computed.getPropertyValue('position');\n\n      if (p === 'static') {\n        this.renderer.setStyle(el, 'position', 'relative');\n      }\n    }\n  }\n\n  private resetBounding() {\n    if (this._bounding && this._bounding.position === 'static') {\n      this.renderer.setStyle(this._containment, 'position', 'relative');\n    }\n    this._bounding = null;\n  }\n\n  private getGridSize() {\n    // set default value:\n    this._gridSize = { x: 1, y: 1 };\n\n    if (this.rzGrid) {\n      if (typeof this.rzGrid === 'number') {\n        this._gridSize = { x: this.rzGrid, y: this.rzGrid };\n      } else if (Array.isArray(this.rzGrid)) {\n        this._gridSize = { x: this.rzGrid[0], y: this.rzGrid[1] };\n      }\n    }\n  }\n}\n"]}