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.0 KiB
						
					
					
				
			
		
		
	
	
							36 lines
						
					
					
						
							1.0 KiB
						
					
					
				export default class extends HTMLElement {
 | 
						|
  connectedCallback () {
 | 
						|
    if (this.dataset.indeterminate === 'true') {
 | 
						|
      this.checkbox.indeterminate = true
 | 
						|
      this.checkbox.readOnly = true
 | 
						|
    }
 | 
						|
 | 
						|
    this.checkbox.addEventListener('click', () => {
 | 
						|
      this.checkbox.setAttribute('name', this.dataset.name)
 | 
						|
 | 
						|
      if (this.showIndeterminateEl) {
 | 
						|
        this.showIndeterminateEl.classList.add('hidden')
 | 
						|
      }
 | 
						|
 | 
						|
      if (this.checkbox.readOnly) {
 | 
						|
        this.checkbox.checked = this.checkbox.readOnly = false
 | 
						|
      } else if (!this.checkbox.checked) {
 | 
						|
        if (this.showIndeterminateEl) {
 | 
						|
          this.showIndeterminateEl.classList.remove('hidden')
 | 
						|
        }
 | 
						|
 | 
						|
        this.checkbox.setAttribute('name', this.dataset.indeterminateName)
 | 
						|
        this.checkbox.checked = this.checkbox.readOnly = this.checkbox.indeterminate = true
 | 
						|
      }
 | 
						|
    })
 | 
						|
  }
 | 
						|
 | 
						|
  get checkbox () {
 | 
						|
    return this.querySelector('input[type="checkbox"]')
 | 
						|
  }
 | 
						|
 | 
						|
  get showIndeterminateEl () {
 | 
						|
    return document.getElementById(this.dataset.showIndeterminateId)
 | 
						|
  }
 | 
						|
}
 |