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
						
					
					
						
							1.1 KiB
						
					
					
				
			
		
		
	
	
							36 lines
						
					
					
						
							1.1 KiB
						
					
					
				| import { target, targetable } from '@github/catalyst/lib/targetable'
 | |
| 
 | |
| export default targetable(class extends HTMLElement {
 | |
|   static [target.static] = [
 | |
|     'visiblePasswordIcon',
 | |
|     'hiddenPasswordIcon',
 | |
|     'passwordInput',
 | |
|     'togglePasswordVisibility'
 | |
|   ]
 | |
| 
 | |
|   connectedCallback () {
 | |
|     this.togglePasswordVisibility.addEventListener('click', this.handleTogglePasswordVisibility)
 | |
|     document.addEventListener('turbo:submit-start', this.setInitialPasswordType)
 | |
|   }
 | |
| 
 | |
|   disconnectedCallback () {
 | |
|     this.togglePasswordVisibility.removeEventListener('click', this.handleTogglePasswordVisibility)
 | |
|     document.removeEventListener('turbo:submit-start', this.setInitialPasswordType)
 | |
|   }
 | |
| 
 | |
|   handleTogglePasswordVisibility = () => {
 | |
|     this.passwordInput.type = this.passwordInput.type === 'password' ? 'text' : 'password'
 | |
|     this.toggleIcon()
 | |
|   }
 | |
| 
 | |
|   setInitialPasswordType = () => {
 | |
|     this.passwordInput.type = 'password'
 | |
|     this.toggleIcon()
 | |
|   }
 | |
| 
 | |
|   toggleIcon = () => {
 | |
|     this.visiblePasswordIcon.classList.toggle('hidden', this.passwordInput.type === 'password')
 | |
|     this.hiddenPasswordIcon.classList.toggle('hidden', this.passwordInput.type === 'text')
 | |
|   }
 | |
| })
 |