1 | import { Component, Input, Output, ChangeDetectionStrategy, ChangeDetectorRef, Renderer2, ElementRef, NgZone, ViewChildren, Directive, Injectable, NgModule } from '@angular/core';
|
2 | import { Observable, Subject } from 'rxjs';
|
3 | import { debounceTime } from 'rxjs/operators';
|
4 | import { CommonModule } from '@angular/common';
|
5 | import { 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 | */
|
15 | function 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 | */
|
37 | function getPixelSize(elRef, direction) {
|
38 | return elRef.nativeElement[(direction === 'horizontal') ? 'offsetWidth' : 'offsetHeight'];
|
39 | }
|
40 | /**
|
41 | * @param {?} v
|
42 | * @return {?}
|
43 | */
|
44 | function getInputBoolean(v) {
|
45 | return (typeof (v) === 'boolean') ? v : (v === 'false' ? false : true);
|
46 | }
|
47 | /**
|
48 | * @param {?} total
|
49 | * @return {?}
|
50 | */
|
51 | function 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 | */
|
90 | class 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 | }
|
640 | SplitComponent.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 */
|
662 | SplitComponent.ctorParameters = () => [
|
663 | { type: NgZone },
|
664 | { type: ElementRef },
|
665 | { type: ChangeDetectorRef },
|
666 | { type: Renderer2 }
|
667 | ];
|
668 | SplitComponent.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 | */
|
685 | class 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 | }
|
816 | SplitAreaDirective.decorators = [
|
817 | { type: Directive, args: [{
|
818 | selector: 'as-split-area, [as-split-area]'
|
819 | },] }
|
820 | ];
|
821 | /** @nocollapse */
|
822 | SplitAreaDirective.ctorParameters = () => [
|
823 | { type: NgZone },
|
824 | { type: ElementRef },
|
825 | { type: Renderer2 },
|
826 | { type: SplitComponent }
|
827 | ];
|
828 | SplitAreaDirective.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 | */
|
842 | class 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 | }
|
862 | UndetectedEventPlugin.decorators = [
|
863 | { type: Injectable }
|
864 | ];
|
865 |
|
866 | /**
|
867 | * @fileoverview added by tsickle
|
868 | * @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
|
869 | */
|
870 | class 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 | }
|
894 | AngularSplitModule.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 |
|
920 | export { 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 |