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.
		
		
		
		
		
			
		
			
				
					
					
						
							36 lines
						
					
					
						
							826 B
						
					
					
				
			
		
		
	
	
							36 lines
						
					
					
						
							826 B
						
					
					
				| export default class extends HTMLElement {
 | |
|   connectedCallback () {
 | |
|     document.addEventListener('turbo:submit-end', this.onSubmitEnd)
 | |
| 
 | |
|     this.form.addEventListener('submit', this.onSubmit)
 | |
|   }
 | |
| 
 | |
|   disconnectedCallback () {
 | |
|     document.removeEventListener('turbo:submit-end', this.onSubmitEnd)
 | |
| 
 | |
|     this.form.removeEventListener('submit', this.onSubmit)
 | |
|   }
 | |
| 
 | |
|   onSubmit = () => {
 | |
|     this.element.classList.add('invisible')
 | |
|   }
 | |
| 
 | |
|   onSubmitEnd = (event) => {
 | |
|     if (event.target === this.form) {
 | |
|       const resp = event.detail?.formSubmission?.result?.fetchResponse?.response
 | |
| 
 | |
|       if (resp?.status / 100 === 2) {
 | |
|         this.element.classList.remove('invisible')
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   get element () {
 | |
|     return document.getElementById(this.dataset.elementId)
 | |
|   }
 | |
| 
 | |
|   get form () {
 | |
|     return this.closest('form')
 | |
|   }
 | |
| }
 |