UNPKG

98.2 kBJavaScriptView Raw
1import { Component, Input, Output, ChangeDetectionStrategy, ChangeDetectorRef, Renderer2, ElementRef, NgZone, ViewChildren, Directive, Injectable, NgModule } from '@angular/core';
2import { Observable, Subject } from 'rxjs';
3import { debounceTime } from 'rxjs/operators';
4import { CommonModule } from '@angular/common';
5import { EVENT_MANAGER_PLUGINS } from '@angular/platform-browser';
6
7/**
8 * @fileoverview added by tsickle
9 * @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
10 */
11/**
12 * @param {?} event
13 * @return {?}
14 */
15function getPointFromEvent(event) {
16 // TouchEvent
17 if (((/** @type {?} */ (event))).touches !== undefined && ((/** @type {?} */ (event))).touches.length > 0) {
18 return {
19 x: ((/** @type {?} */ (event))).touches[0].clientX,
20 y: ((/** @type {?} */ (event))).touches[0].clientY,
21 };
22 }
23 // MouseEvent
24 else if (((/** @type {?} */ (event))).clientX !== undefined && ((/** @type {?} */ (event))).clientY !== undefined) {
25 return {
26 x: ((/** @type {?} */ (event))).clientX,
27 y: ((/** @type {?} */ (event))).clientY,
28 };
29 }
30 return null;
31}
32/**
33 * @param {?} elRef
34 * @param {?} direction
35 * @return {?}
36 */
37function getPixelSize(elRef, direction) {
38 return elRef.nativeElement[(direction === 'horizontal') ? 'offsetWidth' : 'offsetHeight'];
39}
40/**
41 * @param {?} v
42 * @return {?}
43 */
44function getInputBoolean(v) {
45 return (typeof (v) === 'boolean') ? v : (v === 'false' ? false : true);
46}
47/**
48 * @param {?} total
49 * @return {?}
50 */
51function isValidTotalSize(total) {
52 return total > .999 && total < 1.001;
53}
54
55/**
56 * @fileoverview added by tsickle
57 * @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
58 */
59/**
60 * angular-split
61 *
62 * Areas size are set in percentage of the split container.
63 * Gutters size are set in pixels.
64 *
65 * So we set css 'flex-basis' property like this (where 0 <= area.size <= 1):
66 * calc( { area.size * 100 }% - { area.size * nbGutter * gutterSize }px );
67 *
68 * Examples with 3 visible areas and 2 gutters:
69 *
70 * | 10px 10px |
71 * |---------------------[]---------------------[]------------------------------------|
72 * | calc(20% - 4px) calc(20% - 4px) calc(60% - 12px) |
73 *
74 *
75 * | 10px 10px |
76 * |--------------------------[]--------------------------[]--------------------------|
77 * | calc(33.33% - 6.667px) calc(33.33% - 6.667px) calc(33.33% - 6.667px) |
78 *
79 *
80 * |10px 10px |
81 * |[]----------------------------------------------------[]--------------------------|
82 * |0 calc(66.66% - 13.333px) calc(33%% - 6.667px) |
83 *
84 *
85 * 10px 10px |
86 * |[][]------------------------------------------------------------------------------|
87 * |0 0 calc(100% - 20px) |
88 *
89 */
90class SplitComponent {
91 /**
92 * @param {?} ngZone
93 * @param {?} elRef
94 * @param {?} cdRef
95 * @param {?} renderer
96 */
97 constructor(ngZone, elRef, cdRef, renderer) {
98 this.ngZone = ngZone;
99 this.elRef = elRef;
100 this.cdRef = cdRef;
101 this.renderer = renderer;
102 this._direction = 'horizontal';
103 ////
104 this._gutterSize = 11;
105 ////
106 this._useTransition = false;
107 ////
108 this._disabled = false;
109 ////
110 this._dir = 'ltr';
111 this.dragProgressSubject = new Subject();
112 this.dragProgress$ = this.dragProgressSubject.asObservable();
113 ////
114 this.isDragging = false;
115 this.currentGutterNum = 0;
116 this.startPoint = null;
117 this.endPoint = null;
118 this.displayedAreas = [];
119 this.hidedAreas = [];
120 this.dragListeners = [];
121 this.dragStartValues = {
122 sizePixelContainer: 0,
123 sizePixelA: 0,
124 sizePixelB: 0,
125 sizePercentA: 0,
126 sizePercentB: 0,
127 };
128 // To force adding default class, could be override by user @Input() or not
129 this.direction = this._direction;
130 }
131 /**
132 * @param {?} v
133 * @return {?}
134 */
135 set direction(v) {
136 this._direction = (v === 'vertical') ? 'vertical' : 'horizontal';
137 this.renderer.addClass(this.elRef.nativeElement, `is-${this._direction}`);
138 this.renderer.removeClass(this.elRef.nativeElement, `is-${(this._direction === 'vertical') ? 'horizontal' : 'vertical'}`);
139 this.build(false, false);
140 }
141 /**
142 * @return {?}
143 */
144 get direction() {
145 return this._direction;
146 }
147 /**
148 * @param {?} v
149 * @return {?}
150 */
151 set gutterSize(v) {
152 v = Number(v);
153 this._gutterSize = (!isNaN(v) && v > 0) ? v : 11;
154 this.build(false, false);
155 }
156 /**
157 * @return {?}
158 */
159 get gutterSize() {
160 return this._gutterSize;
161 }
162 /**
163 * @param {?} v
164 * @return {?}
165 */
166 set useTransition(v) {
167 this._useTransition = getInputBoolean(v);
168 if (this._useTransition)
169 this.renderer.addClass(this.elRef.nativeElement, 'is-transition');
170 else
171 this.renderer.removeClass(this.elRef.nativeElement, 'is-transition');
172 }
173 /**
174 * @return {?}
175 */
176 get useTransition() {
177 return this._useTransition;
178 }
179 /**
180 * @param {?} v
181 * @return {?}
182 */
183 set disabled(v) {
184 this._disabled = getInputBoolean(v);
185 if (this._disabled)
186 this.renderer.addClass(this.elRef.nativeElement, 'is-disabled');
187 else
188 this.renderer.removeClass(this.elRef.nativeElement, 'is-disabled');
189 }
190 /**
191 * @return {?}
192 */
193 get disabled() {
194 return this._disabled;
195 }
196 /**
197 * @param {?} v
198 * @return {?}
199 */
200 set dir(v) {
201 v = (v === 'rtl') ? 'rtl' : 'ltr';
202 this._dir = v;
203 this.renderer.setAttribute(this.elRef.nativeElement, 'dir', this._dir);
204 }
205 /**
206 * @return {?}
207 */
208 get dir() {
209 return this._dir;
210 }
211 /**
212 * @return {?}
213 */
214 get dragStart() {
215 return new Observable(subscriber => this.dragStartSubscriber = subscriber);
216 }
217 /**
218 * @return {?}
219 */
220 get dragEnd() {
221 return new Observable(subscriber => this.dragEndSubscriber = subscriber);
222 }
223 /**
224 * @return {?}
225 */
226 get gutterClick() {
227 return new Observable(subscriber => this.gutterClickSubscriber = subscriber);
228 }
229 /**
230 * @return {?}
231 */
232 get transitionEnd() {
233 return new Observable(subscriber => this.transitionEndSubscriber = subscriber).pipe(debounceTime(20));
234 }
235 /**
236 * @return {?}
237 */
238 ngAfterViewInit() {
239 this.ngZone.runOutsideAngular(() => {
240 // To avoid transition at first rendering
241 setTimeout(() => this.renderer.addClass(this.elRef.nativeElement, 'is-init'));
242 });
243 }
244 /**
245 * @return {?}
246 */
247 getNbGutters() {
248 return (this.displayedAreas.length === 0) ? 0 : this.displayedAreas.length - 1;
249 }
250 /**
251 * @param {?} component
252 * @return {?}
253 */
254 addArea(component) {
255 /** @type {?} */
256 const newArea = {
257 component,
258 order: 0,
259 size: 0,
260 };
261 if (component.visible === true) {
262 this.displayedAreas.push(newArea);
263 this.build(true, true);
264 }
265 else {
266 this.hidedAreas.push(newArea);
267 }
268 }
269 /**
270 * @param {?} component
271 * @return {?}
272 */
273 removeArea(component) {
274 if (this.displayedAreas.some(a => a.component === component)) {
275 /** @type {?} */
276 const area = this.displayedAreas.find(a => a.component === component);
277 this.displayedAreas.splice(this.displayedAreas.indexOf(area), 1);
278 this.build(true, true);
279 }
280 else if (this.hidedAreas.some(a => a.component === component)) {
281 /** @type {?} */
282 const area = this.hidedAreas.find(a => a.component === component);
283 this.hidedAreas.splice(this.hidedAreas.indexOf(area), 1);
284 }
285 }
286 /**
287 * @param {?} component
288 * @param {?} resetOrders
289 * @param {?} resetSizes
290 * @return {?}
291 */
292 updateArea(component, resetOrders, resetSizes) {
293 // Only refresh if area is displayed (No need to check inside 'hidedAreas')
294 /** @type {?} */
295 const area = this.displayedAreas.find(a => a.component === component);
296 if (!area) {
297 return;
298 }
299 this.build(resetOrders, resetSizes);
300 }
301 /**
302 * @param {?} component
303 * @return {?}
304 */
305 showArea(component) {
306 /** @type {?} */
307 const area = this.hidedAreas.find(a => a.component === component);
308 if (!area) {
309 return;
310 }
311 /** @type {?} */
312 const areas = this.hidedAreas.splice(this.hidedAreas.indexOf(area), 1);
313 this.displayedAreas.push(...areas);
314 this.build(true, true);
315 }
316 /**
317 * @param {?} comp
318 * @return {?}
319 */
320 hideArea(comp) {
321 /** @type {?} */
322 const area = this.displayedAreas.find(a => a.component === comp);
323 if (!area) {
324 return;
325 }
326 /** @type {?} */
327 const areas = this.displayedAreas.splice(this.displayedAreas.indexOf(area), 1);
328 areas.forEach(area => {
329 area.order = 0;
330 area.size = 0;
331 });
332 this.hidedAreas.push(...areas);
333 this.build(true, true);
334 }
335 /**
336 * @return {?}
337 */
338 getVisibleAreaSizes() {
339 return this.displayedAreas.map(a => a.size * 100);
340 }
341 /**
342 * @param {?} sizes
343 * @return {?}
344 */
345 setVisibleAreaSizes(sizes) {
346 if (sizes.length !== this.displayedAreas.length) {
347 return false;
348 }
349 sizes = sizes.map(s => s / 100);
350 /** @type {?} */
351 const total = sizes.reduce((total, v) => total + v, 0);
352 if (!isValidTotalSize(total)) {
353 return false;
354 }
355 this.displayedAreas.forEach((area, i) => {
356 // @ts-ignore
357 area.component._size = sizes[i];
358 });
359 this.build(false, true);
360 return true;
361 }
362 /**
363 * @param {?} resetOrders
364 * @param {?} resetSizes
365 * @return {?}
366 */
367 build(resetOrders, resetSizes) {
368 this.stopDragging();
369 // ¤ AREAS ORDER
370 if (resetOrders === true) {
371 // If user provided 'order' for each area, use it to sort them.
372 if (this.displayedAreas.every(a => a.component.order !== null)) {
373 this.displayedAreas.sort((a, b) => ((/** @type {?} */ (a.component.order))) - ((/** @type {?} */ (b.component.order))));
374 }
375 // Then set real order with multiples of 2, numbers between will be used by gutters.
376 this.displayedAreas.forEach((area, i) => {
377 area.order = i * 2;
378 area.component.setStyleOrder(area.order);
379 });
380 }
381 // ¤ AREAS SIZE PERCENT
382 if (resetSizes === true) {
383 /** @type {?} */
384 const totalUserSize = (/** @type {?} */ (this.displayedAreas.reduce((total, s) => s.component.size ? total + s.component.size : total, 0)));
385 // If user provided 'size' for each area and total == 1, use it.
386 if (this.displayedAreas.every(a => a.component.size !== null) && isValidTotalSize(totalUserSize)) {
387 this.displayedAreas.forEach(area => {
388 area.size = (/** @type {?} */ (area.component.size));
389 });
390 }
391 // Else set equal sizes for all areas.
392 else {
393 /** @type {?} */
394 const size = 1 / this.displayedAreas.length;
395 this.displayedAreas.forEach(area => {
396 area.size = size;
397 });
398 }
399 }
400 // ¤
401 // If some real area sizes are less than gutterSize,
402 // set them to zero and dispatch size to others.
403 /** @type {?} */
404 let percentToDispatch = 0;
405 // Get container pixel size
406 /** @type {?} */
407 const containerSizePixel = getPixelSize(this.elRef, this.direction);
408 this.displayedAreas.forEach(area => {
409 if (area.size * containerSizePixel < this.gutterSize) {
410 percentToDispatch += area.size;
411 area.size = 0;
412 }
413 });
414 if (percentToDispatch > 0 && this.displayedAreas.length > 0) {
415 /** @type {?} */
416 const nbAreasNotZero = this.displayedAreas.filter(a => a.size !== 0).length;
417 if (nbAreasNotZero > 0) {
418 /** @type {?} */
419 const percentToAdd = percentToDispatch / nbAreasNotZero;
420 this.displayedAreas.filter(a => a.size !== 0).forEach(area => {
421 area.size += percentToAdd;
422 });
423 }
424 // All area sizes (container percentage) are less than guterSize,
425 // It means containerSize < ngGutters * gutterSize
426 else {
427 this.displayedAreas[this.displayedAreas.length - 1].size = 1;
428 }
429 }
430 this.refreshStyleSizes();
431 this.cdRef.markForCheck();
432 }
433 /**
434 * @return {?}
435 */
436 refreshStyleSizes() {
437 /** @type {?} */
438 const sumGutterSize = this.getNbGutters() * this.gutterSize;
439 this.displayedAreas.forEach(area => {
440 area.component.setStyleFlexbasis(`calc( ${area.size * 100}% - ${area.size * sumGutterSize}px )`);
441 });
442 }
443 /**
444 * @param {?} event
445 * @param {?} gutterNum
446 * @return {?}
447 */
448 clickGutter(event, gutterNum) {
449 event.preventDefault();
450 event.stopPropagation();
451 if (this.startPoint && this.startPoint.x === event.clientX && this.startPoint.y === event.clientY) {
452 this.currentGutterNum = gutterNum;
453 this.notify('click');
454 }
455 }
456 /**
457 * @param {?} event
458 * @param {?} gutterOrder
459 * @param {?} gutterNum
460 * @return {?}
461 */
462 startDragging(event, gutterOrder, gutterNum) {
463 event.preventDefault();
464 event.stopPropagation();
465 this.startPoint = getPointFromEvent(event);
466 if (!this.startPoint || this.disabled) {
467 return;
468 }
469 /** @type {?} */
470 const areaA = this.displayedAreas.find(a => a.order === gutterOrder - 1);
471 /** @type {?} */
472 const areaB = this.displayedAreas.find(a => a.order === gutterOrder + 1);
473 if (!areaA || !areaB) {
474 return;
475 }
476 this.dragStartValues.sizePixelContainer = getPixelSize(this.elRef, this.direction);
477 this.dragStartValues.sizePixelA = getPixelSize(areaA.component.elRef, this.direction);
478 this.dragStartValues.sizePixelB = getPixelSize(areaB.component.elRef, this.direction);
479 this.dragStartValues.sizePercentA = areaA.size;
480 this.dragStartValues.sizePercentB = areaB.size;
481 this.currentGutterNum = gutterNum;
482 this.ngZone.runOutsideAngular(() => {
483 this.dragListeners.push(this.renderer.listen('document', 'mouseup', this.stopDragging.bind(this)));
484 this.dragListeners.push(this.renderer.listen('document', 'touchend', this.stopDragging.bind(this)));
485 this.dragListeners.push(this.renderer.listen('document', 'touchcancel', this.stopDragging.bind(this)));
486 this.dragListeners.push(this.renderer.listen('document', 'mousemove', (e) => this.dragEvent(e, areaA, areaB)));
487 this.dragListeners.push(this.renderer.listen('document', 'touchmove', (e) => this.dragEvent(e, areaA, areaB)));
488 });
489 areaA.component.lockEvents();
490 areaB.component.lockEvents();
491 this.isDragging = true;
492 this.renderer.addClass(this.elRef.nativeElement, 'is-dragging');
493 this.renderer.addClass(this.gutterEls.toArray()[this.currentGutterNum - 1].nativeElement, 'is-dragged');
494 this.notify('start');
495 }
496 /**
497 * @param {?} event
498 * @param {?} areaA
499 * @param {?} areaB
500 * @return {?}
501 */
502 dragEvent(event, areaA, areaB) {
503 event.preventDefault();
504 event.stopPropagation();
505 if (!this.isDragging) {
506 return;
507 }
508 this.endPoint = getPointFromEvent(event);
509 if (!this.endPoint) {
510 return;
511 }
512 // ¤ AREAS SIZE PIXEL
513 /** @type {?} */
514 let offsetPixel = (this.direction === 'horizontal') ? (this.startPoint.x - this.endPoint.x) : (this.startPoint.y - this.endPoint.y);
515 if (this.dir === 'rtl') {
516 offsetPixel = -offsetPixel;
517 }
518 /** @type {?} */
519 let newSizePixelA = this.dragStartValues.sizePixelA - offsetPixel;
520 /** @type {?} */
521 let newSizePixelB = this.dragStartValues.sizePixelB + offsetPixel;
522 if (newSizePixelA < this.gutterSize && newSizePixelB < this.gutterSize) {
523 // WTF.. get out of here!
524 return;
525 }
526 else if (newSizePixelA < this.gutterSize) {
527 newSizePixelB += newSizePixelA;
528 newSizePixelA = 0;
529 }
530 else if (newSizePixelB < this.gutterSize) {
531 newSizePixelA += newSizePixelB;
532 newSizePixelB = 0;
533 }
534 // ¤ AREAS SIZE PERCENT
535 if (newSizePixelA === 0) {
536 areaB.size += areaA.size;
537 areaA.size = 0;
538 }
539 else if (newSizePixelB === 0) {
540 areaA.size += areaB.size;
541 areaB.size = 0;
542 }
543 else {
544 // NEW_PERCENT = START_PERCENT / START_PIXEL * NEW_PIXEL;
545 if (this.dragStartValues.sizePercentA === 0) {
546 areaB.size = this.dragStartValues.sizePercentB / this.dragStartValues.sizePixelB * newSizePixelB;
547 areaA.size = this.dragStartValues.sizePercentB - areaB.size;
548 }
549 else if (this.dragStartValues.sizePercentB === 0) {
550 areaA.size = this.dragStartValues.sizePercentA / this.dragStartValues.sizePixelA * newSizePixelA;
551 areaB.size = this.dragStartValues.sizePercentA - areaA.size;
552 }
553 else {
554 areaA.size = this.dragStartValues.sizePercentA / this.dragStartValues.sizePixelA * newSizePixelA;
555 areaB.size = (this.dragStartValues.sizePercentA + this.dragStartValues.sizePercentB) - areaA.size;
556 }
557 }
558 this.refreshStyleSizes();
559 // If moved from starting point, notify progress
560 if (this.startPoint.x !== this.endPoint.x || this.startPoint.y !== this.endPoint.y) {
561 this.notify('progress');
562 }
563 }
564 /**
565 * @param {?=} event
566 * @return {?}
567 */
568 stopDragging(event) {
569 if (event) {
570 event.preventDefault();
571 event.stopPropagation();
572 }
573 if (this.isDragging === false) {
574 return;
575 }
576 this.displayedAreas.forEach(area => {
577 area.component.unlockEvents();
578 });
579 while (this.dragListeners.length > 0) {
580 /** @type {?} */
581 const fct = this.dragListeners.pop();
582 if (fct) {
583 fct();
584 }
585 }
586 // If moved from starting point, notify end
587 if (event && this.endPoint && (this.startPoint.x !== this.endPoint.x || this.startPoint.y !== this.endPoint.y)) {
588 this.notify('end');
589 }
590 this.isDragging = false;
591 this.renderer.removeClass(this.elRef.nativeElement, 'is-dragging');
592 this.renderer.removeClass(this.gutterEls.toArray()[this.currentGutterNum - 1].nativeElement, 'is-dragged');
593 // Needed to let (click)="clickGutter(...)" event run and verify if mouse moved or not
594 this.ngZone.runOutsideAngular(() => {
595 setTimeout(() => {
596 this.startPoint = null;
597 this.endPoint = null;
598 });
599 });
600 }
601 /**
602 * @param {?} type
603 * @return {?}
604 */
605 notify(type) {
606 /** @type {?} */
607 const sizes = this.displayedAreas.map(a => a.size * 100);
608 if (type === 'start') {
609 if (this.dragStartSubscriber) {
610 this.ngZone.run(() => this.dragStartSubscriber.next({ gutterNum: this.currentGutterNum, sizes }));
611 }
612 }
613 else if (type === 'end') {
614 if (this.dragEndSubscriber) {
615 this.ngZone.run(() => this.dragEndSubscriber.next({ gutterNum: this.currentGutterNum, sizes }));
616 }
617 }
618 else if (type === 'click') {
619 if (this.gutterClickSubscriber) {
620 this.ngZone.run(() => this.gutterClickSubscriber.next({ gutterNum: this.currentGutterNum, sizes }));
621 }
622 }
623 else if (type === 'transitionEnd') {
624 if (this.transitionEndSubscriber) {
625 this.ngZone.run(() => this.transitionEndSubscriber.next(sizes));
626 }
627 }
628 else if (type === 'progress') {
629 // Stay outside zone to allow users do what they want about change detection mechanism.
630 this.dragProgressSubject.next({ gutterNum: this.currentGutterNum, sizes });
631 }
632 }
633 /**
634 * @return {?}
635 */
636 ngOnDestroy() {
637 this.stopDragging();
638 }
639}
640SplitComponent.decorators = [
641 { type: Component, args: [{
642 selector: 'as-split',
643 changeDetection: ChangeDetectionStrategy.OnPush,
644 template: `
645 <ng-content></ng-content>
646 <ng-template ngFor [ngForOf]="displayedAreas" let-index="index" let-last="last">
647 <div *ngIf="last === false"
648 #gutterEls
649 class="as-split-gutter"
650 [style.flex-basis.px]="gutterSize"
651 [style.order]="index*2+1"
652 (as-split-undetected.click)="clickGutter($event, index+1)"
653 (as-split-undetected.mousedown)="startDragging($event, index*2+1, index+1)"
654 (as-split-undetected.touchstart)="startDragging($event, index*2+1, index+1)">
655 <div class="as-split-gutter-icon"></div>
656 </div>
657 </ng-template>`,
658 styles: [":host{display:flex;flex-wrap:nowrap;justify-content:flex-start;align-items:stretch;overflow:hidden;width:100%;height:100%}:host>.as-split-gutter{flex-grow:0;flex-shrink:0;background-color:#eee;display:flex;align-items:center;justify-content:center}:host>.as-split-gutter>.as-split-gutter-icon{width:100%;height:100%;background-position:center center;background-repeat:no-repeat}:host ::ng-deep>.as-split-area{flex-grow:0;flex-shrink:0;overflow-x:hidden;overflow-y:auto}:host ::ng-deep>.as-split-area.is-hided{flex-basis:0!important;overflow-x:hidden;overflow-y:hidden}:host.is-horizontal{flex-direction:row}:host.is-horizontal>.as-split-gutter{flex-direction:row;cursor:col-resize;height:100%}:host.is-horizontal>.as-split-gutter>.as-split-gutter-icon{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAUAAAAeCAYAAADkftS9AAAAIklEQVQoU2M4c+bMfxAGAgYYmwGrIIiDjrELjpo5aiZeMwF+yNnOs5KSvgAAAABJRU5ErkJggg==)}:host.is-horizontal ::ng-deep>.as-split-area{height:100%}:host.is-vertical{flex-direction:column}:host.is-vertical>.as-split-gutter{flex-direction:column;cursor:row-resize;width:100%}:host.is-vertical>.as-split-gutter .as-split-gutter-icon{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAB4AAAAFCAMAAABl/6zIAAAABlBMVEUAAADMzMzIT8AyAAAAAXRSTlMAQObYZgAAABRJREFUeAFjYGRkwIMJSeMHlBkOABP7AEGzSuPKAAAAAElFTkSuQmCC)}:host.is-vertical ::ng-deep>.as-split-area{width:100%}:host.is-vertical ::ng-deep>.as-split-area.is-hided{max-width:0}:host.is-disabled>.as-split-gutter{cursor:default}:host.is-disabled>.as-split-gutter .as-split-gutter-icon{background-image:url(\"\")}:host.is-transition.is-init:not(.is-dragging) ::ng-deep>.as-split-area,:host.is-transition.is-init:not(.is-dragging)>.as-split-gutter{transition:flex-basis .3s}"]
659 }] }
660];
661/** @nocollapse */
662SplitComponent.ctorParameters = () => [
663 { type: NgZone },
664 { type: ElementRef },
665 { type: ChangeDetectorRef },
666 { type: Renderer2 }
667];
668SplitComponent.propDecorators = {
669 direction: [{ type: Input }],
670 gutterSize: [{ type: Input }],
671 useTransition: [{ type: Input }],
672 disabled: [{ type: Input }],
673 dir: [{ type: Input }],
674 dragStart: [{ type: Output }],
675 dragEnd: [{ type: Output }],
676 gutterClick: [{ type: Output }],
677 transitionEnd: [{ type: Output }],
678 gutterEls: [{ type: ViewChildren, args: ['gutterEls',] }]
679};
680
681/**
682 * @fileoverview added by tsickle
683 * @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
684 */
685class SplitAreaDirective {
686 /**
687 * @param {?} ngZone
688 * @param {?} elRef
689 * @param {?} renderer
690 * @param {?} split
691 */
692 constructor(ngZone, elRef, renderer, split) {
693 this.ngZone = ngZone;
694 this.elRef = elRef;
695 this.renderer = renderer;
696 this.split = split;
697 this._order = null;
698 ////
699 this._size = null;
700 ////
701 this._visible = true;
702 this.lockListeners = [];
703 this.renderer.addClass(this.elRef.nativeElement, 'as-split-area');
704 }
705 /**
706 * @param {?} v
707 * @return {?}
708 */
709 set order(v) {
710 v = Number(v);
711 this._order = !isNaN(v) ? v : null;
712 this.split.updateArea(this, true, false);
713 }
714 /**
715 * @return {?}
716 */
717 get order() {
718 return this._order;
719 }
720 /**
721 * @param {?} v
722 * @return {?}
723 */
724 set size(v) {
725 v = Number(v);
726 this._size = (!isNaN(v) && v >= 0 && v <= 100) ? (v / 100) : null;
727 this.split.updateArea(this, false, true);
728 }
729 /**
730 * @return {?}
731 */
732 get size() {
733 return this._size;
734 }
735 /**
736 * @param {?} v
737 * @return {?}
738 */
739 set visible(v) {
740 this._visible = getInputBoolean(v);
741 if (this._visible) {
742 this.split.showArea(this);
743 this.renderer.removeClass(this.elRef.nativeElement, 'is-hided');
744 }
745 else {
746 this.split.hideArea(this);
747 this.renderer.addClass(this.elRef.nativeElement, 'is-hided');
748 }
749 }
750 /**
751 * @return {?}
752 */
753 get visible() {
754 return this._visible;
755 }
756 /**
757 * @return {?}
758 */
759 ngOnInit() {
760 this.split.addArea(this);
761 this.ngZone.runOutsideAngular(() => {
762 this.transitionListener = this.renderer.listen(this.elRef.nativeElement, 'transitionend', (event) => {
763 // Limit only flex-basis transition to trigger the event
764 if (event.propertyName === 'flex-basis') {
765 this.split.notify('transitionEnd');
766 }
767 });
768 });
769 }
770 /**
771 * @param {?} value
772 * @return {?}
773 */
774 setStyleOrder(value) {
775 this.renderer.setStyle(this.elRef.nativeElement, 'order', value);
776 }
777 /**
778 * @param {?} value
779 * @return {?}
780 */
781 setStyleFlexbasis(value) {
782 this.renderer.setStyle(this.elRef.nativeElement, 'flex-basis', value);
783 }
784 /**
785 * @return {?}
786 */
787 lockEvents() {
788 this.ngZone.runOutsideAngular(() => {
789 this.lockListeners.push(this.renderer.listen(this.elRef.nativeElement, 'selectstart', (e) => false));
790 this.lockListeners.push(this.renderer.listen(this.elRef.nativeElement, 'dragstart', (e) => false));
791 });
792 }
793 /**
794 * @return {?}
795 */
796 unlockEvents() {
797 while (this.lockListeners.length > 0) {
798 /** @type {?} */
799 const fct = this.lockListeners.pop();
800 if (fct) {
801 fct();
802 }
803 }
804 }
805 /**
806 * @return {?}
807 */
808 ngOnDestroy() {
809 this.unlockEvents();
810 if (this.transitionListener) {
811 this.transitionListener();
812 }
813 this.split.removeArea(this);
814 }
815}
816SplitAreaDirective.decorators = [
817 { type: Directive, args: [{
818 selector: 'as-split-area, [as-split-area]'
819 },] }
820];
821/** @nocollapse */
822SplitAreaDirective.ctorParameters = () => [
823 { type: NgZone },
824 { type: ElementRef },
825 { type: Renderer2 },
826 { type: SplitComponent }
827];
828SplitAreaDirective.propDecorators = {
829 order: [{ type: Input }],
830 size: [{ type: Input }],
831 visible: [{ type: Input }]
832};
833
834/**
835 * @fileoverview added by tsickle
836 * @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
837 */
838/**
839 * Credit to Michael Strobel from:
840 * https://github.com/kryops/ng2-events
841 */
842class UndetectedEventPlugin {
843 /**
844 * @param {?} eventName
845 * @return {?}
846 */
847 supports(eventName) {
848 return eventName.indexOf('as-split-undetected.') === 0;
849 }
850 /**
851 * @param {?} element
852 * @param {?} eventName
853 * @param {?} handler
854 * @return {?}
855 */
856 addEventListener(element, eventName, handler) {
857 /** @type {?} */
858 const realEventName = eventName.slice(20);
859 return this.manager.getZone().runOutsideAngular(() => this.manager.addEventListener(element, realEventName, handler));
860 }
861}
862UndetectedEventPlugin.decorators = [
863 { type: Injectable }
864];
865
866/**
867 * @fileoverview added by tsickle
868 * @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
869 */
870class AngularSplitModule {
871 /**
872 * @return {?}
873 */
874 static forRoot() {
875 return {
876 ngModule: AngularSplitModule,
877 providers: [{
878 provide: EVENT_MANAGER_PLUGINS,
879 useClass: UndetectedEventPlugin,
880 multi: true
881 }]
882 };
883 }
884 /**
885 * @return {?}
886 */
887 static forChild() {
888 return {
889 ngModule: AngularSplitModule,
890 providers: []
891 };
892 }
893}
894AngularSplitModule.decorators = [
895 { type: NgModule, args: [{
896 imports: [
897 CommonModule
898 ],
899 declarations: [
900 SplitComponent,
901 SplitAreaDirective,
902 ],
903 exports: [
904 SplitComponent,
905 SplitAreaDirective,
906 ]
907 },] }
908];
909
910/**
911 * @fileoverview added by tsickle
912 * @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
913 */
914
915/**
916 * @fileoverview added by tsickle
917 * @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
918 */
919
920export { AngularSplitModule, SplitComponent, SplitAreaDirective, UndetectedEventPlugin as ɵa };
921
922//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"angular-split.js.map","sources":["ng://angular-split/lib/utils.ts","ng://angular-split/lib/component/split.component.ts","ng://angular-split/lib/directive/splitArea.directive.ts","ng://angular-split/lib/service/UndetectedEventPlugin.ts","ng://angular-split/lib/module.ts"],"sourcesContent":["import { ElementRef } from '@angular/core';\r\n\r\nimport { IPoint } from './interface/IPoint';\r\n\r\n\r\nexport function getPointFromEvent(event: MouseEvent | TouchEvent): IPoint {\r\n    // TouchEvent\r\n    if((<TouchEvent> event).touches !== undefined && (<TouchEvent> event).touches.length > 0) {\r\n        return {\r\n            x: (<TouchEvent> event).touches[0].clientX,\r\n            y: (<TouchEvent> event).touches[0].clientY,\r\n        };\r\n    }\r\n    // MouseEvent\r\n    else if((<MouseEvent> event).clientX !== undefined && (<MouseEvent> event).clientY !== undefined) {\r\n        return {\r\n            x: (<MouseEvent> event).clientX,\r\n            y: (<MouseEvent> event).clientY,\r\n        };\r\n    }\r\n    return null;\r\n}\r\n\r\nexport function getPixelSize(elRef: ElementRef, direction: 'horizontal' | 'vertical'): number {\r\n    return elRef.nativeElement[(direction === 'horizontal') ? 'offsetWidth' : 'offsetHeight'];\r\n\r\n}\r\n\r\nexport function getInputBoolean(v: any) {\r\n    return (typeof(v) === 'boolean') ? v : (v === 'false' ? false : true);\r\n}\r\n\r\nexport function isValidTotalSize(total: number): boolean {\r\n    return total > .999 && total < 1.001;\r\n}","import { Component, Input, Output, ChangeDetectionStrategy, ChangeDetectorRef, Renderer2, AfterViewInit, OnDestroy, ElementRef, NgZone, ViewChildren, QueryList } from '@angular/core';\r\nimport { Observable, Subscriber, Subject } from 'rxjs';\r\nimport { debounceTime } from 'rxjs/operators';\r\n\r\nimport { IArea } from '../interface/IArea';\r\nimport { IPoint } from '../interface/IPoint';\r\nimport { SplitAreaDirective } from '../directive/splitArea.directive';\r\nimport { getPointFromEvent, getPixelSize, getInputBoolean, isValidTotalSize } from '../utils';\r\n\r\n/**\r\n * angular-split\r\n * \r\n * Areas size are set in percentage of the split container.\r\n * Gutters size are set in pixels.\r\n * \r\n * So we set css 'flex-basis' property like this (where 0 <= area.size <= 1): \r\n *  calc( { area.size * 100 }% - { area.size * nbGutter * gutterSize }px );\r\n * \r\n * Examples with 3 visible areas and 2 gutters: \r\n * \r\n * |                     10px                   10px                                  |\r\n * |---------------------[]---------------------[]------------------------------------|\r\n * |  calc(20% - 4px)          calc(20% - 4px)              calc(60% - 12px)          |\r\n * \r\n * \r\n * |                          10px                        10px                        |\r\n * |--------------------------[]--------------------------[]--------------------------|\r\n * |  calc(33.33% - 6.667px)      calc(33.33% - 6.667px)      calc(33.33% - 6.667px)  |\r\n * \r\n * \r\n * |10px                                                  10px                        |\r\n * |[]----------------------------------------------------[]--------------------------|\r\n * |0                 calc(66.66% - 13.333px)                  calc(33%% - 6.667px)   |\r\n * \r\n * \r\n *  10px 10px                                                                         |\r\n * |[][]------------------------------------------------------------------------------|\r\n * |0 0                               calc(100% - 20px)                               |\r\n * \r\n */\r\n\r\n@Component({\r\n    selector: 'as-split',\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    styleUrls: [`./split.component.scss`],\r\n    template: `\r\n        <ng-content></ng-content>\r\n        <ng-template ngFor [ngForOf]=\"displayedAreas\" let-index=\"index\" let-last=\"last\">\r\n            <div *ngIf=\"last === false\" \r\n                 #gutterEls\r\n                 class=\"as-split-gutter\"\r\n                 [style.flex-basis.px]=\"gutterSize\"\r\n                 [style.order]=\"index*2+1\"\r\n                 (as-split-undetected.click)=\"clickGutter($event, index+1)\"\r\n                 (as-split-undetected.mousedown)=\"startDragging($event, index*2+1, index+1)\"\r\n                 (as-split-undetected.touchstart)=\"startDragging($event, index*2+1, index+1)\">\r\n                <div class=\"as-split-gutter-icon\"></div>\r\n            </div>\r\n        </ng-template>`,\r\n})\r\nexport class SplitComponent implements AfterViewInit, OnDestroy {\r\n\r\n    private _direction: 'horizontal' | 'vertical' = 'horizontal';\r\n\r\n    @Input() set direction(v: 'horizontal' | 'vertical') {\r\n        this._direction = (v === 'vertical') ? 'vertical' : 'horizontal';\r\n        \r\n        this.renderer.addClass(this.elRef.nativeElement, `is-${ this._direction }`);\r\n        this.renderer.removeClass(this.elRef.nativeElement, `is-${ (this._direction === 'vertical') ? 'horizontal' : 'vertical' }`);\r\n        \r\n        this.build(false, false);\r\n    }\r\n    \r\n    get direction(): 'horizontal' | 'vertical' {\r\n        return this._direction;\r\n    }\r\n    \r\n    ////\r\n\r\n    private _gutterSize: number = 11;\r\n\r\n    @Input() set gutterSize(v: number) {\r\n        v = Number(v);\r\n        this._gutterSize = (!isNaN(v) && v > 0) ? v : 11;\r\n\r\n        this.build(false, false);\r\n    }\r\n    \r\n    get gutterSize(): number {\r\n        return this._gutterSize;\r\n    }\r\n    \r\n    ////\r\n\r\n    private _useTransition: boolean = false;\r\n\r\n    @Input() set useTransition(v: boolean) {\r\n        this._useTransition = getInputBoolean(v);\r\n\r\n        if(this._useTransition) this.renderer.addClass(this.elRef.nativeElement, 'is-transition');\r\n        else                    this.renderer.removeClass(this.elRef.nativeElement, 'is-transition');\r\n    }\r\n    \r\n    get useTransition(): boolean {\r\n        return this._useTransition;\r\n    }\r\n    \r\n    ////\r\n\r\n    private _disabled: boolean = false;\r\n    \r\n    @Input() set disabled(v: boolean) {\r\n        this._disabled = getInputBoolean(v);\r\n\r\n        if(this._disabled)  this.renderer.addClass(this.elRef.nativeElement, 'is-disabled');\r\n        else                this.renderer.removeClass(this.elRef.nativeElement, 'is-disabled');\r\n    }\r\n    \r\n    get disabled(): boolean {\r\n        return this._disabled;\r\n    }\r\n\r\n    ////\r\n\r\n    private _dir: 'ltr' | 'rtl' = 'ltr';\r\n    \r\n    @Input() set dir(v: 'ltr' | 'rtl') {\r\n        v = (v === 'rtl') ? 'rtl' : 'ltr';\r\n        this._dir = v;\r\n        \r\n        this.renderer.setAttribute(this.elRef.nativeElement, 'dir', this._dir);\r\n    }\r\n    \r\n    get dir(): 'ltr' | 'rtl' {\r\n        return this._dir;\r\n    }\r\n\r\n    ////\r\n\r\n    private dragStartSubscriber: Subscriber<{gutterNum: number, sizes: Array<number>}>\r\n    @Output() get dragStart(): Observable<{gutterNum: number, sizes: Array<number>}> {\r\n        return new Observable(subscriber => this.dragStartSubscriber = subscriber);\r\n    }\r\n\r\n    private dragEndSubscriber: Subscriber<{gutterNum: number, sizes: Array<number>}>\r\n    @Output() get dragEnd(): Observable<{gutterNum: number, sizes: Array<number>}> {\r\n        return new Observable(subscriber => this.dragEndSubscriber = subscriber);\r\n    }\r\n\r\n    private gutterClickSubscriber: Subscriber<{gutterNum: number, sizes: Array<number>}>\r\n    @Output() get gutterClick(): Observable<{gutterNum: number, sizes: Array<number>}> {\r\n        return new Observable(subscriber => this.gutterClickSubscriber = subscriber);\r\n    }\r\n\r\n    private transitionEndSubscriber: Subscriber<Array<number>>\r\n    @Output() get transitionEnd(): Observable<Array<number>> {\r\n        return new Observable(subscriber => this.transitionEndSubscriber = subscriber).pipe(\r\n            debounceTime<Array<number>>(20)\r\n        );\r\n    }\r\n    \r\n    private dragProgressSubject: Subject<{gutterNum: number, sizes: Array<number>}> = new Subject();\r\n    dragProgress$: Observable<{gutterNum: number, sizes: Array<number>}> = this.dragProgressSubject.asObservable();\r\n\r\n    ////\r\n\r\n    private isDragging: boolean = false;\r\n    private currentGutterNum: number = 0;\r\n    private startPoint: IPoint | null = null;\r\n    private endPoint: IPoint | null = null;\r\n\r\n    public readonly displayedAreas: Array<IArea> = [];\r\n    private readonly hidedAreas: Array<IArea> = [];\r\n    \r\n    private readonly dragListeners: Array<Function> = [];\r\n    private readonly dragStartValues = {\r\n        sizePixelContainer: 0,\r\n        sizePixelA: 0,\r\n        sizePixelB: 0,\r\n        sizePercentA: 0,\r\n        sizePercentB: 0,\r\n    };\r\n\r\n    @ViewChildren('gutterEls') private gutterEls: QueryList<ElementRef>;\r\n\r\n    constructor(private ngZone: NgZone,\r\n                private elRef: ElementRef,\r\n                private cdRef: ChangeDetectorRef,\r\n                private renderer: Renderer2) {\r\n        // To force adding default class, could be override by user @Input() or not\r\n        this.direction = this._direction;\r\n    }\r\n\r\n    public ngAfterViewInit() {\r\n        this.ngZone.runOutsideAngular(() => {\r\n            // To avoid transition at first rendering\r\n            setTimeout(() => this.renderer.addClass(this.elRef.nativeElement, 'is-init'));\r\n        });\r\n    }\r\n    \r\n    private getNbGutters(): number {\r\n        return (this.displayedAreas.length === 0) ? 0 : this.displayedAreas.length - 1;\r\n    }\r\n\r\n    public addArea(component: SplitAreaDirective): void {\r\n        const newArea: IArea = {\r\n            component, \r\n            order: 0, \r\n            size: 0,\r\n        };\r\n\r\n        if(component.visible === true) {\r\n            this.displayedAreas.push(newArea);\r\n\r\n            this.build(true, true);\r\n        }\r\n        else {\r\n            this.hidedAreas.push(newArea);\r\n        }\r\n    }\r\n\r\n    public removeArea(component: SplitAreaDirective): void {\r\n        if(this.displayedAreas.some(a => a.component === component)) {\r\n            const area = this.displayedAreas.find(a => a.component === component);\r\n            this.displayedAreas.splice(this.displayedAreas.indexOf(area), 1);\r\n\r\n            this.build(true, true);\r\n        }\r\n        else if(this.hidedAreas.some(a => a.component === component)) {\r\n            const area = this.hidedAreas.find(a => a.component === component);\r\n            this.hidedAreas.splice(this.hidedAreas.indexOf(area), 1);\r\n        }\r\n    }\r\n\r\n    public updateArea(component: SplitAreaDirective, resetOrders: boolean, resetSizes: boolean): void {\r\n        // Only refresh if area is displayed (No need to check inside 'hidedAreas')\r\n        const area = this.displayedAreas.find(a => a.component === component);\r\n        if(!area) {\r\n            return;\r\n        }\r\n\r\n        this.build(resetOrders, resetSizes);\r\n    }\r\n\r\n    public showArea(component: SplitAreaDirective): void {\r\n        const area = this.hidedAreas.find(a => a.component === component);\r\n        if(!area) {\r\n            return;\r\n        }\r\n\r\n        const areas = this.hidedAreas.splice(this.hidedAreas.indexOf(area), 1);\r\n        this.displayedAreas.push(...areas);\r\n\r\n        this.build(true, true);\r\n    }\r\n\r\n    public hideArea(comp: SplitAreaDirective): void {\r\n        const area = this.displayedAreas.find(a => a.component === comp);\r\n        if(!area) {\r\n            return;\r\n        }\r\n\r\n        const areas = this.displayedAreas.splice(this.displayedAreas.indexOf(area), 1);\r\n        areas.forEach(area => {\r\n            area.order = 0;\r\n            area.size = 0;\r\n        })\r\n        this.hidedAreas.push(...areas);\r\n\r\n        this.build(true, true);\r\n    }\r\n\r\n    public getVisibleAreaSizes(): Array<number> {\r\n        return this.displayedAreas.map(a => a.size * 100);\r\n    }\r\n\r\n    public setVisibleAreaSizes(sizes: Array<number>): boolean {\r\n        if(sizes.length !== this.displayedAreas.length) {\r\n            return false;\r\n        }\r\n\r\n        sizes = sizes.map(s => s / 100);\r\n\r\n        const total = sizes.reduce((total: number, v: number) => total + v, 0);\r\n        if(!isValidTotalSize(total)) {\r\n            return false;\r\n        }\r\n\r\n        this.displayedAreas.forEach((area, i) => {\r\n            // @ts-ignore\r\n            area.component._size = sizes[i];\r\n        })\r\n\r\n        this.build(false, true);\r\n        return true;\r\n    }\r\n\r\n    private build(resetOrders: boolean, resetSizes: boolean): void {\r\n        this.stopDragging();\r\n\r\n        // Â¤ AREAS ORDER\r\n        \r\n        if(resetOrders === true) {\r\n\r\n            // If user provided 'order' for each area, use it to sort them.\r\n            if(this.displayedAreas.every(a => a.component.order !== null)) {\r\n                this.displayedAreas.sort((a, b) => (<number> a.component.order) - (<number> b.component.order));\r\n            }\r\n    \r\n            // Then set real order with multiples of 2, numbers between will be used by gutters.\r\n            this.displayedAreas.forEach((area, i) => {\r\n                area.order = i * 2;\r\n                area.component.setStyleOrder(area.order);\r\n            });\r\n\r\n        }\r\n\r\n        // Â¤ AREAS SIZE PERCENT\r\n        \r\n        if(resetSizes === true) {\r\n\r\n            const totalUserSize = <number> this.displayedAreas.reduce((total: number, s: IArea) => s.component.size ? total + s.component.size : total, 0);\r\n            \r\n            // If user provided 'size' for each area and total == 1, use it.\r\n            if(this.displayedAreas.every(a => a.component.size !== null) && isValidTotalSize(totalUserSize) ) {\r\n\r\n                this.displayedAreas.forEach(area => {\r\n                    area.size = <number> area.component.size;\r\n                });\r\n            }\r\n            // Else set equal sizes for all areas.\r\n            else {\r\n                const size = 1 / this.displayedAreas.length;\r\n                \r\n                this.displayedAreas.forEach(area => {\r\n                    area.size = size;\r\n                });\r\n            }\r\n        }\r\n        \r\n        // Â¤ \r\n        // If some real area sizes are less than gutterSize, \r\n        // set them to zero and dispatch size to others.\r\n\r\n        let percentToDispatch = 0;\r\n        \r\n        // Get container pixel size\r\n        const containerSizePixel = getPixelSize(this.elRef, this.direction);\r\n\r\n        this.displayedAreas.forEach(area => {\r\n            if(area.size * containerSizePixel < this.gutterSize) {\r\n                percentToDispatch += area.size;\r\n                area.size = 0;\r\n            }\r\n        });\r\n        \r\n        if(percentToDispatch > 0 && this.displayedAreas.length > 0) {\r\n            const nbAreasNotZero = this.displayedAreas.filter(a => a.size !== 0).length;\r\n\r\n            if(nbAreasNotZero > 0) {\r\n                const percentToAdd = percentToDispatch / nbAreasNotZero;\r\n    \r\n                this.displayedAreas.filter(a => a.size !== 0).forEach(area => {\r\n                    area.size += percentToAdd;\r\n                });\r\n            }\r\n            // All area sizes (container percentage) are less than guterSize,\r\n            // It means containerSize < ngGutters * gutterSize\r\n            else {\r\n                this.displayedAreas[this.displayedAreas.length - 1].size = 1;\r\n            }\r\n        }\r\n\r\n        this.refreshStyleSizes();\r\n        this.cdRef.markForCheck();\r\n    }\r\n\r\n    private refreshStyleSizes(): void {\r\n        const sumGutterSize = this.getNbGutters() * this.gutterSize;\r\n\r\n        this.displayedAreas.forEach(area => {\r\n            area.component.setStyleFlexbasis(`calc( ${ area.size * 100 }% - ${ area.size * sumGutterSize }px )`);\r\n        });\r\n    }\r\n\r\n    public clickGutter(event: MouseEvent, gutterNum: number): void {\r\n        event.preventDefault();\r\n        event.stopPropagation();\r\n\r\n        if(this.startPoint && this.startPoint.x === event.clientX && this.startPoint.y === event.clientY) {\r\n            this.currentGutterNum = gutterNum;\r\n\r\n            this.notify('click');\r\n        }\r\n    }\r\n\r\n    public startDragging(event: MouseEvent | TouchEvent, gutterOrder: number, gutterNum: number): void {\r\n        event.preventDefault();\r\n        event.stopPropagation();\r\n\r\n        this.startPoint = getPointFromEvent(event);\r\n        if(!this.startPoint || this.disabled) {\r\n            return;\r\n        }\r\n\r\n        const areaA = this.displayedAreas.find(a => a.order === gutterOrder - 1);\r\n        const areaB = this.displayedAreas.find(a => a.order === gutterOrder + 1);\r\n        \r\n        if(!areaA || !areaB) {\r\n            return;\r\n        }\r\n\r\n        this.dragStartValues.sizePixelContainer = getPixelSize(this.elRef, this.direction);\r\n        this.dragStartValues.sizePixelA = getPixelSize(areaA.component.elRef, this.direction);\r\n        this.dragStartValues.sizePixelB = getPixelSize(areaB.component.elRef, this.direction);\r\n        this.dragStartValues.sizePercentA = areaA.size;\r\n        this.dragStartValues.sizePercentB = areaB.size;\r\n        this.currentGutterNum = gutterNum;\r\n\r\n        this.ngZone.runOutsideAngular(() => {\r\n            this.dragListeners.push( this.renderer.listen('document', 'mouseup', this.stopDragging.bind(this)) );\r\n            this.dragListeners.push( this.renderer.listen('document', 'touchend', this.stopDragging.bind(this)) );\r\n            this.dragListeners.push( this.renderer.listen('document', 'touchcancel', this.stopDragging.bind(this)) );\r\n            \r\n            this.dragListeners.push( this.renderer.listen('document', 'mousemove', (e: MouseEvent) => this.dragEvent(e, areaA, areaB)) );\r\n            this.dragListeners.push( this.renderer.listen('document', 'touchmove', (e: TouchEvent) => this.dragEvent(e, areaA, areaB)) );\r\n        });\r\n\r\n        areaA.component.lockEvents();\r\n        areaB.component.lockEvents();\r\n\r\n        this.isDragging = true;\r\n        this.renderer.addClass(this.elRef.nativeElement, 'is-dragging');\r\n        this.renderer.addClass(this.gutterEls.toArray()[this.currentGutterNum-1].nativeElement, 'is-dragged');\r\n        \r\n        this.notify('start');\r\n    }\r\n\r\n    private dragEvent(event: MouseEvent | TouchEvent, areaA: IArea, areaB: IArea): void {\r\n        event.preventDefault();\r\n        event.stopPropagation();\r\n\r\n        if(!this.isDragging) {\r\n            return;\r\n        }\r\n\r\n        this.endPoint = getPointFromEvent(event);\r\n        if(!this.endPoint) {\r\n            return;\r\n        }\r\n        \r\n        // Â¤ AREAS SIZE PIXEL\r\n\r\n        let offsetPixel = (this.direction === 'horizontal') ? (this.startPoint.x - this.endPoint.x) : (this.startPoint.y - this.endPoint.y);\r\n        if(this.dir === 'rtl') {\r\n            offsetPixel = -offsetPixel;\r\n        }\r\n\r\n        let newSizePixelA = this.dragStartValues.sizePixelA - offsetPixel;\r\n        let newSizePixelB = this.dragStartValues.sizePixelB + offsetPixel;\r\n        \r\n        if(newSizePixelA < this.gutterSize && newSizePixelB < this.gutterSize) {\r\n            // WTF.. get out of here!\r\n            return;\r\n        }\r\n        else if(newSizePixelA < this.gutterSize) {\r\n            newSizePixelB += newSizePixelA;\r\n            newSizePixelA = 0;\r\n        }\r\n        else if(newSizePixelB < this.gutterSize) {\r\n            newSizePixelA += newSizePixelB;\r\n            newSizePixelB = 0;\r\n        }\r\n\r\n        // Â¤ AREAS SIZE PERCENT\r\n\r\n        if(newSizePixelA === 0) {\r\n            areaB.size += areaA.size;\r\n            areaA.size = 0;\r\n        }\r\n        else if(newSizePixelB === 0) {\r\n            areaA.size += areaB.size;\r\n            areaB.size = 0;\r\n        }\r\n        else {\r\n            // NEW_PERCENT = START_PERCENT / START_PIXEL * NEW_PIXEL;\r\n            if(this.dragStartValues.sizePercentA === 0) {\r\n                areaB.size = this.dragStartValues.sizePercentB / this.dragStartValues.sizePixelB * newSizePixelB;\r\n                areaA.size = this.dragStartValues.sizePercentB - areaB.size;\r\n            }\r\n            else if(this.dragStartValues.sizePercentB === 0) {\r\n                areaA.size = this.dragStartValues.sizePercentA / this.dragStartValues.sizePixelA * newSizePixelA;\r\n                areaB.size = this.dragStartValues.sizePercentA - areaA.size;\r\n            }\r\n            else {\r\n                areaA.size = this.dragStartValues.sizePercentA / this.dragStartValues.sizePixelA * newSizePixelA;\r\n                areaB.size = (this.dragStartValues.sizePercentA + this.dragStartValues.sizePercentB) - areaA.size;\r\n            }\r\n        }\r\n\r\n        this.refreshStyleSizes();\r\n        \r\n        // If moved from starting point, notify progress\r\n        if(this.startPoint.x !== this.endPoint.x || this.startPoint.y !== this.endPoint.y) {\r\n            this.notify('progress');\r\n        }\r\n    }\r\n\r\n    private stopDragging(event?: Event): void {\r\n        if(event) {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n        }\r\n        \r\n        if(this.isDragging === false) {\r\n            return;\r\n        }\r\n        \r\n        this.displayedAreas.forEach(area => {\r\n            area.component.unlockEvents();\r\n        });\r\n        \r\n        while(this.dragListeners.length > 0) {\r\n            const fct = this.dragListeners.pop();\r\n            if(fct) {\r\n                fct();\r\n            }\r\n        }\r\n        \r\n        // If moved from starting point, notify end\r\n        if(event && this.endPoint && (this.startPoint.x !== this.endPoint.x || this.startPoint.y !== this.endPoint.y)) {\r\n            this.notify('end');\r\n        }\r\n        \r\n        this.isDragging = false;\r\n        this.renderer.removeClass(this.elRef.nativeElement, 'is-dragging');\r\n        this.renderer.removeClass(this.gutterEls.toArray()[this.currentGutterNum-1].nativeElement, 'is-dragged');\r\n\r\n        // Needed to let (click)=\"clickGutter(...)\" event run and verify if mouse moved or not\r\n        this.ngZone.runOutsideAngular(() => {\r\n            setTimeout(() => {\r\n                this.startPoint = null;\r\n                this.endPoint = null;\r\n            })\r\n        });\r\n    }\r\n\r\n    public notify(type: 'start' | 'progress' | 'end' | 'click' | 'transitionEnd'): void {\r\n        const sizes: Array<number> = this.displayedAreas.map(a => a.size * 100);\r\n\r\n        if(type === 'start') {\r\n            if(this.dragStartSubscriber) {\r\n                this.ngZone.run(() => this.dragStartSubscriber.next({gutterNum: this.currentGutterNum, sizes}));\r\n            }\r\n        }\r\n        else if(type === 'end') {\r\n            if(this.dragEndSubscriber) {\r\n                this.ngZone.run(() => this.dragEndSubscriber.next({gutterNum: this.currentGutterNum, sizes}));\r\n            }\r\n        }\r\n        else if(type === 'click') {\r\n            if(this.gutterClickSubscriber) {\r\n                this.ngZone.run(() => this.gutterClickSubscriber.next({gutterNum: this.currentGutterNum, sizes}));\r\n            }\r\n        }\r\n        else if(type === 'transitionEnd') {\r\n            if(this.transitionEndSubscriber) {\r\n                this.ngZone.run(() => this.transitionEndSubscriber.next(sizes));\r\n            }\r\n        }\r\n        else if(type === 'progress') {\r\n            // Stay outside zone to allow users do what they want about change detection mechanism.\r\n            this.dragProgressSubject.next({gutterNum: this.currentGutterNum, sizes});\r\n        }\r\n    }\r\n\r\n    public ngOnDestroy(): void {\r\n        this.stopDragging();\r\n    }\r\n}\r\n","import { Directive, Input, ElementRef, Renderer2, OnInit, OnDestroy, NgZone } from '@angular/core';\r\n\r\nimport { SplitComponent } from '../component/split.component';\r\nimport { getInputBoolean } from '../utils';\r\n\r\n@Directive({\r\n    selector: 'as-split-area, [as-split-area]'\r\n})\r\nexport class SplitAreaDirective implements OnInit, OnDestroy {\r\n\r\n    private _order: number | null = null;\r\n\r\n    @Input() set order(v: number | null) {\r\n        v = Number(v);\r\n        this._order = !isNaN(v) ? v : null;\r\n\r\n        this.split.updateArea(this, true, false);\r\n    }\r\n    \r\n    get order(): number | null {\r\n        return this._order;\r\n    }\r\n\r\n    ////\r\n\r\n    private _size: number | null = null;\r\n\r\n    @Input() set size(v: number | null) {\r\n        v = Number(v);\r\n        this._size = (!isNaN(v) && v >= 0 && v <= 100) ? (v/100) : null;\r\n\r\n        this.split.updateArea(this, false, true);\r\n    }\r\n    \r\n    get size(): number | null {\r\n        return this._size;\r\n    }\r\n\r\n    ////\r\n\r\n    private _visible: boolean = true;\r\n\r\n    @Input() set visible(v: boolean) {\r\n        this._visible = getInputBoolean(v);\r\n\r\n        if(this._visible) { \r\n            this.split.showArea(this);\r\n            this.renderer.removeClass(this.elRef.nativeElement, 'is-hided');\r\n        }\r\n        else {\r\n            this.split.hideArea(this);\r\n            this.renderer.addClass(this.elRef.nativeElement, 'is-hided');\r\n        }\r\n    }\r\n\r\n    get visible(): boolean {\r\n        return this._visible;\r\n    }\r\n\r\n    ////\r\n\r\n    private transitionListener: Function;\r\n    private readonly lockListeners: Array<Function> = [];\r\n\r\n    constructor(private ngZone: NgZone,\r\n                public elRef: ElementRef,\r\n                private renderer: Renderer2,\r\n                private split: SplitComponent) {\r\n        this.renderer.addClass(this.elRef.nativeElement, 'as-split-area');\r\n    }\r\n\r\n    public ngOnInit(): void {\r\n        this.split.addArea(this);\r\n\r\n        this.ngZone.runOutsideAngular(() => {\r\n            this.transitionListener = this.renderer.listen(this.elRef.nativeElement, 'transitionend', (event: TransitionEvent) => {\r\n                // Limit only flex-basis transition to trigger the event\r\n                if(event.propertyName === 'flex-basis') {\r\n                    this.split.notify('transitionEnd');\r\n                }\r\n            });\r\n        });\r\n    }\r\n\r\n    public setStyleOrder(value: number): void {\r\n        this.renderer.setStyle(this.elRef.nativeElement, 'order', value);\r\n    }\r\n    \r\n    public setStyleFlexbasis(value: string): void {\r\n        this.renderer.setStyle(this.elRef.nativeElement, 'flex-basis', value);\r\n    }\r\n    \r\n    public lockEvents(): void {\r\n        this.ngZone.runOutsideAngular(() => {\r\n            this.lockListeners.push( this.renderer.listen(this.elRef.nativeElement, 'selectstart', (e: Event) => false) );\r\n            this.lockListeners.push( this.renderer.listen(this.elRef.nativeElement, 'dragstart', (e: Event) => false) );\r\n        });\r\n    }\r\n\r\n    public unlockEvents(): void {\r\n        while(this.lockListeners.length > 0) {\r\n            const fct = this.lockListeners.pop();\r\n            if(fct) {\r\n                fct();\r\n            }\r\n        }\r\n    }\r\n\r\n    public ngOnDestroy(): void {\r\n        this.unlockEvents();\r\n\r\n        if(this.transitionListener) {\r\n            this.transitionListener();\r\n        }\r\n\r\n        this.split.removeArea(this);\r\n    }\r\n}\r\n","import { Injectable } from '@angular/core';\r\nimport { EventManager } from '@angular/platform-browser';\r\n\r\n/**\r\n * Credit to Michael Strobel from:\r\n * https://github.com/kryops/ng2-events\r\n */\r\n@Injectable()\r\nexport class UndetectedEventPlugin {\r\n    manager: EventManager;\r\n\r\n    supports(eventName: string): boolean {\r\n        return eventName.indexOf('as-split-undetected.') === 0;\r\n    }\r\n\r\n    addEventListener(element: HTMLElement, eventName: string, handler: Function): Function {\r\n        const realEventName = eventName.slice(20);\r\n\r\n        return this.manager.getZone().runOutsideAngular(() => this.manager.addEventListener(element, realEventName, handler));\r\n    }\r\n}","import { NgModule, ModuleWithProviders } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { EVENT_MANAGER_PLUGINS } from '@angular/platform-browser';\r\n\r\nimport { SplitComponent } from './component/split.component';\r\nimport { SplitAreaDirective } from './directive/splitArea.directive';\r\nimport { UndetectedEventPlugin } from \"./service/UndetectedEventPlugin\";\r\n\r\n@NgModule({\r\n    imports: [\r\n        CommonModule\r\n    ],\r\n    declarations: [\r\n        SplitComponent,\r\n        SplitAreaDirective,\r\n    ],\r\n    exports: [\r\n        SplitComponent,\r\n        SplitAreaDirective,\r\n    ]\r\n})\r\nexport class AngularSplitModule {\r\n\r\n    public static forRoot(): ModuleWithProviders {\r\n        return {\r\n            ngModule: AngularSplitModule,\r\n            providers: [{\r\n                provide: EVENT_MANAGER_PLUGINS,\r\n                useClass: UndetectedEventPlugin,\r\n                multi: true\r\n            }]\r\n        };\r\n    }\r\n\r\n    public static forChild(): ModuleWithProviders {\r\n        return {\r\n            ngModule: AngularSplitModule,\r\n            providers: []\r\n        };\r\n    }\r\n\r\n}\r\n"],"names":[],"mappings":"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"}
\No newline at end of file