48 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			48 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| (async () => {
 | |
| 
 | |
|   const uiResizer = document.getElementById('resizer');
 | |
|   const uiLeftColumn = uiResizer.previousElementSibling;
 | |
|   const uiRightColumn = uiResizer.nextElementSibling;
 | |
|   const uiParent = uiResizer.parentElement;
 | |
| 
 | |
|   let isResizing = false;
 | |
|   let abortSignal = null;
 | |
| 
 | |
|   function onMouseMove(e) {
 | |
|     // we resize the columns by applying felx: <ratio> to the columns
 | |
| 
 | |
|     // compute the percentage the mouse is in the parent
 | |
|     const percentage = (e.clientX - uiParent.offsetLeft) / uiParent.clientWidth;
 | |
|     // clamp the percentage between 0.1 and 0.9
 | |
|     const clampedPercentage = Math.max(0.1, Math.min(0.9, percentage));
 | |
|     // set the flex property of the columns
 | |
|     uiLeftColumn.style.flex = `${clampedPercentage}`;
 | |
|     uiRightColumn.style.flex = `${1 - clampedPercentage}`;
 | |
|   }
 | |
| 
 | |
|   function onMouseUp(e) {
 | |
|     // restore user selection
 | |
|     document.body.style.userSelect = '';
 | |
| 
 | |
|     // remove the mousemove and mouseup events
 | |
|     if (abortSignal) {
 | |
|       abortSignal.abort();
 | |
|       abortSignal = null;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   uiResizer.addEventListener('mousedown', e => {
 | |
|     e.preventDefault();
 | |
|     isResizing = true;
 | |
| 
 | |
|     // prevent text selection
 | |
|     document.body.style.userSelect = 'none';
 | |
| 
 | |
|     // register the mousemove and mouseup events
 | |
|     abortSignal = new AbortController();
 | |
|     document.addEventListener('mousemove', onMouseMove, { signal: abortSignal.signal });
 | |
|     document.addEventListener('mouseup', onMouseUp, { signal: abortSignal.signal });
 | |
|   });
 | |
| 
 | |
| })();
 | 
