angular-resizable.directive.js 82 KB

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