mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-31 22:28:05 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			45 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			45 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import {isDocumentFragmentOrElementNode} from '../utils/dom.ts';
 | |
| 
 | |
| type DirElement = HTMLInputElement | HTMLTextAreaElement;
 | |
| 
 | |
| // for performance considerations, it only uses performant syntax
 | |
| function attachDirAuto(el: DirElement) {
 | |
|   if (el.type !== 'hidden' &&
 | |
|       el.type !== 'checkbox' &&
 | |
|       el.type !== 'radio' &&
 | |
|       el.type !== 'range' &&
 | |
|       el.type !== 'color') {
 | |
|     el.dir = 'auto';
 | |
|   }
 | |
| }
 | |
| 
 | |
| export function initDirAuto(): void {
 | |
|   const observer = new MutationObserver((mutationList) => {
 | |
|     const len = mutationList.length;
 | |
|     for (let i = 0; i < len; i++) {
 | |
|       const mutation = mutationList[i];
 | |
|       const len = mutation.addedNodes.length;
 | |
|       for (let i = 0; i < len; i++) {
 | |
|         const addedNode = mutation.addedNodes[i] as HTMLElement;
 | |
|         if (!isDocumentFragmentOrElementNode(addedNode)) continue;
 | |
|         if (addedNode.nodeName === 'INPUT' || addedNode.nodeName === 'TEXTAREA') {
 | |
|           attachDirAuto(addedNode as DirElement);
 | |
|         }
 | |
|         const children = addedNode.querySelectorAll<DirElement>('input, textarea');
 | |
|         const len = children.length;
 | |
|         for (let childIdx = 0; childIdx < len; childIdx++) {
 | |
|           attachDirAuto(children[childIdx]);
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|   });
 | |
| 
 | |
|   const docNodes = document.querySelectorAll<DirElement>('input, textarea');
 | |
|   const len = docNodes.length;
 | |
|   for (let i = 0; i < len; i++) {
 | |
|     attachDirAuto(docNodes[i]);
 | |
|   }
 | |
| 
 | |
|   observer.observe(document, {subtree: true, childList: true});
 | |
| }
 |