mirror of https://github.com/docusealco/docuseal
				
				
				
			
			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.
		
		
		
		
		
			
		
			
				
					
					
						
							39 lines
						
					
					
						
							918 B
						
					
					
				
			
		
		
	
	
							39 lines
						
					
					
						
							918 B
						
					
					
				| export default class extends HTMLElement {
 | |
|   static observedAttributes = ['class']
 | |
| 
 | |
|   connectedCallback () {
 | |
|     this.trigger()
 | |
|   }
 | |
| 
 | |
|   attributeChangedCallback (attributeName, oldValue, newValue) {
 | |
|     if (attributeName === 'class' && oldValue !== newValue) {
 | |
|       this.trigger()
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   trigger () {
 | |
|     const hasHiddenClass = this.classList.contains('hidden')
 | |
|     const elements = this.querySelectorAll('input, textarea, select')
 | |
| 
 | |
|     elements.forEach((element) => {
 | |
|       if (hasHiddenClass) {
 | |
|         element.disabled = true
 | |
| 
 | |
|         if (!element.dataset.wasRequired) {
 | |
|           element.dataset.wasRequired = element.required
 | |
|         }
 | |
| 
 | |
|         element.required = false
 | |
|       } else {
 | |
|         element.disabled = false
 | |
| 
 | |
|         if (element.dataset.wasRequired) {
 | |
|           element.required = element.dataset.wasRequired === 'true'
 | |
| 
 | |
|           delete element.dataset.wasRequired
 | |
|         }
 | |
|       }
 | |
|     })
 | |
|   }
 | |
| }
 |