You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					29 lines
				
				1.0 KiB
			
		
		
			
		
	
	
					29 lines
				
				1.0 KiB
			| 
								 
											3 years ago
										 
									 | 
							
								/* eslint-disable no-cond-assign, no-continue */
							 | 
						||
| 
								 | 
							
								import css from './css';
							 | 
						||
| 
								 | 
							
								import height from './height';
							 | 
						||
| 
								 | 
							
								import isDocument from './isDocument';
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * Find the first scrollable parent of an element.
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * @param element Starting element
							 | 
						||
| 
								 | 
							
								 * @param firstPossible Stop at the first scrollable parent, even if it's not currently scrollable
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								export default function scrollParent(element, firstPossible) {
							 | 
						||
| 
								 | 
							
								  var position = css(element, 'position');
							 | 
						||
| 
								 | 
							
								  var excludeStatic = position === 'absolute';
							 | 
						||
| 
								 | 
							
								  var ownerDoc = element.ownerDocument;
							 | 
						||
| 
								 | 
							
								  if (position === 'fixed') return ownerDoc || document; // @ts-ignore
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  while ((element = element.parentNode) && !isDocument(element)) {
							 | 
						||
| 
								 | 
							
								    var isStatic = excludeStatic && css(element, 'position') === 'static';
							 | 
						||
| 
								 | 
							
								    var style = (css(element, 'overflow') || '') + (css(element, 'overflow-y') || '') + css(element, 'overflow-x');
							 | 
						||
| 
								 | 
							
								    if (isStatic) continue;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    if (/(auto|scroll)/.test(style) && (firstPossible || height(element) < element.scrollHeight)) {
							 | 
						||
| 
								 | 
							
								      return element;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  return ownerDoc || document;
							 | 
						||
| 
								 | 
							
								}
							 |