mirror of
				https://github.com/optim-enterprises-bv/vault.git
				synced 2025-11-04 04:28:08 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			56 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			56 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
/**
 | 
						|
 * Copyright (c) HashiCorp, Inc.
 | 
						|
 * SPDX-License-Identifier: MPL-2.0
 | 
						|
 */
 | 
						|
 | 
						|
/**
 | 
						|
 * @module Toggle
 | 
						|
 * Toggle components are used to indicate boolean values which can be toggled on or off.
 | 
						|
 * They are a stylistic alternative to checkboxes, but still use the input[type="checkbox"] under the hood.
 | 
						|
 *
 | 
						|
 * @example
 | 
						|
 * ```js
 | 
						|
 * <Toggle @requiredParam={requiredParam} @optionalParam={optionalParam} @param1={{param1}}/>
 | 
						|
 * ```
 | 
						|
 * @param {function} onChange - onChange is triggered on checkbox change (select, deselect). Must manually mutate checked value
 | 
						|
 * @param {string} name - name is passed along to the form field, as well as to generate the ID of the input & "for" value of the label
 | 
						|
 * @param {boolean} [checked=false] - checked status of the input, and must be passed in and mutated from the parent
 | 
						|
 * @param {boolean} [disabled=false] - disabled makes the switch unclickable
 | 
						|
 * @param {string} [size='medium'] - Sizing can be small or medium
 | 
						|
 * @param {string} [status='normal'] - Status can be normal or success, which makes the switch have a blue background when checked=true
 | 
						|
 */
 | 
						|
 | 
						|
import Component from '@glimmer/component';
 | 
						|
import { action } from '@ember/object';
 | 
						|
import { tracked } from '@glimmer/tracking';
 | 
						|
 | 
						|
export default class ToggleComponent extends Component {
 | 
						|
  // tracked because the Input mutates the property and therefor cannot be a getter
 | 
						|
  @tracked
 | 
						|
  checked = this.args.checked || false;
 | 
						|
 | 
						|
  get disabled() {
 | 
						|
    return this.args.disabled || false;
 | 
						|
  }
 | 
						|
 | 
						|
  get name() {
 | 
						|
    return this.args.name || '';
 | 
						|
  }
 | 
						|
 | 
						|
  get safeId() {
 | 
						|
    return `toggle-${this.name.replace(/\W/g, '')}`;
 | 
						|
  }
 | 
						|
  get inputClasses() {
 | 
						|
    const size = this.args.size || 'normal';
 | 
						|
    const status = this.args.status || 'normal';
 | 
						|
    const sizeClass = `is-${size}`;
 | 
						|
    const statusClass = `is-${status}`;
 | 
						|
    return `toggle ${statusClass} ${sizeClass}`;
 | 
						|
  }
 | 
						|
 | 
						|
  @action
 | 
						|
  handleChange(e) {
 | 
						|
    this.args.onChange(e.target.checked);
 | 
						|
  }
 | 
						|
}
 |