mirror of
				https://github.com/optim-enterprises-bv/vault.git
				synced 2025-11-03 20:17:59 +00:00 
			
		
		
		
	* Update browserslist * Add browserslistrc * ember-cli-update --to 3.26, fix conflicts * Run codemodes that start with ember-* * More codemods - before cp* * More codemods (curly data-test-*) * WIP ember-basic-dropdown template errors * updates ember-basic-dropdown and related deps to fix build issues * updates basic dropdown instances to new version API * updates more deps -- ember-template-lint is working again * runs no-implicit-this codemod * creates and runs no-quoteless-attributes codemod * runs angle brackets codemod * updates lint:hbs globs to only touch hbs files * removes yield only templates * creates and runs deprecated args transform * supresses lint error for invokeAction on LinkTo component * resolves remaining ambiguous path lint errors * resolves simple-unless lint errors * adds warnings for deprecated tagName arg on LinkTo components * adds warnings for remaining curly component invocation * updates global template lint rules * resolves remaining template lint errors * disables some ember specfic lint rules that target pre octane patterns * js lint fix run * resolves remaining js lint errors * fixes test run * adds npm-run-all dep * fixes test attribute issues * fixes console acceptance tests * fixes tests * adds yield only wizard/tutorial-active template * fixes more tests * attempts to fix more flaky tests * removes commented out settled in transit test * updates deprecations workflow and adds initializer to filter by version * updates flaky policies acl old test * updates to flaky transit test * bumps ember deps down to LTS version * runs linters after main merge * fixes client count tests after bad merge conflict fixes * fixes client count history test * more updates to lint config * another round of hbs lint fixes after extending stylistic rule * updates lint-staged commands * removes indent eslint rule since it seems to break things * fixes bad attribute in transform-edit-form template * test fixes * fixes enterprise tests * adds changelog * removes deprecated ember-concurrency-test-waiters dep and adds @ember/test-waiters * flaky test fix Co-authored-by: hashishaw <cshaw@hashicorp.com>
		
			
				
	
	
		
			56 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			56 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
import Component from '@ember/component';
 | 
						|
import { set, get, defineProperty, computed } from '@ember/object';
 | 
						|
import layout from '../templates/components/toggle-button';
 | 
						|
 | 
						|
/**
 | 
						|
 * @module ToggleButton
 | 
						|
 * `ToggleButton` components are used to expand and collapse content with a toggle.
 | 
						|
 *
 | 
						|
 * @example
 | 
						|
 * ```js
 | 
						|
 *   <ToggleButton @openLabel="Encrypt Output with PGP" @closedLabel="Encrypt Output with PGP" @toggleTarget={{this}} @toggleAttr="showOptions"/>
 | 
						|
 *  {{#if showOptions}}
 | 
						|
 *     <div>
 | 
						|
 *       <p>
 | 
						|
 *         I will be toggled!
 | 
						|
 *       </p>
 | 
						|
 *     </div>
 | 
						|
 *   {{/if}}
 | 
						|
 * ```
 | 
						|
 *
 | 
						|
 * @param toggleAttr=null {String} - The attribute upon which to toggle.
 | 
						|
 * @param openLabel=Hide options {String} - The message to display when the toggle is open.
 | 
						|
 * @param closedLabel=More options {String} - The message to display when the toggle is closed.
 | 
						|
 */
 | 
						|
export default Component.extend({
 | 
						|
  layout,
 | 
						|
  tagName: 'button',
 | 
						|
  type: 'button',
 | 
						|
  toggleTarget: null,
 | 
						|
  toggleAttr: null,
 | 
						|
  classNameBindings: ['buttonClass'],
 | 
						|
  attributeBindings: ['type'],
 | 
						|
  buttonClass: 'has-text-info',
 | 
						|
  classNames: ['button', 'is-transparent'],
 | 
						|
  openLabel: 'Hide options',
 | 
						|
  closedLabel: 'More options',
 | 
						|
  init() {
 | 
						|
    this._super(...arguments);
 | 
						|
    const toggleAttr = this.toggleAttr;
 | 
						|
    defineProperty(
 | 
						|
      this,
 | 
						|
      'isOpen',
 | 
						|
      computed(`toggleTarget.${toggleAttr}`, 'toggleAttr', 'toggleTarget', function () {
 | 
						|
        const props = { toggleTarget: this.toggleTarget, toggleAttr: this.toggleAttr };
 | 
						|
        return get(props.toggleTarget, props.toggleAttr);
 | 
						|
      })
 | 
						|
    );
 | 
						|
  },
 | 
						|
  click() {
 | 
						|
    const target = this.toggleTarget;
 | 
						|
    const attr = this.toggleAttr;
 | 
						|
    const current = get(target, attr);
 | 
						|
    set(target, attr, !current);
 | 
						|
  },
 | 
						|
});
 |