mirror of
				https://github.com/optim-enterprises-bv/vault.git
				synced 2025-11-03 12:07:54 +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>
		
			
				
	
	
		
			129 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			129 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
import { inject as service } from '@ember/service';
 | 
						|
import { or } from '@ember/object/computed';
 | 
						|
import { isBlank } from '@ember/utils';
 | 
						|
import Component from '@ember/component';
 | 
						|
import { set } from '@ember/object';
 | 
						|
import FocusOnInsertMixin from 'vault/mixins/focus-on-insert';
 | 
						|
 | 
						|
const LIST_ROOT_ROUTE = 'vault.cluster.secrets.backend.list-root';
 | 
						|
const SHOW_ROUTE = 'vault.cluster.secrets.backend.show';
 | 
						|
 | 
						|
export const addToList = (list, itemToAdd) => {
 | 
						|
  if (!list || !Array.isArray(list)) return list;
 | 
						|
  list.push(itemToAdd);
 | 
						|
  return list.uniq();
 | 
						|
};
 | 
						|
 | 
						|
export const removeFromList = (list, itemToRemove) => {
 | 
						|
  if (!list) return list;
 | 
						|
  const index = list.indexOf(itemToRemove);
 | 
						|
  if (index < 0) return list;
 | 
						|
  const newList = list.removeAt(index, 1);
 | 
						|
  return newList.uniq();
 | 
						|
};
 | 
						|
 | 
						|
export default Component.extend(FocusOnInsertMixin, {
 | 
						|
  store: service(),
 | 
						|
  flashMessages: service(),
 | 
						|
  router: service(),
 | 
						|
 | 
						|
  mode: null,
 | 
						|
  onDataChange() {},
 | 
						|
  onRefresh() {},
 | 
						|
  model: null,
 | 
						|
  requestInFlight: or('model.isLoading', 'model.isReloading', 'model.isSaving'),
 | 
						|
 | 
						|
  init() {
 | 
						|
    this._super(...arguments);
 | 
						|
    this.set('backendType', 'transform');
 | 
						|
  },
 | 
						|
 | 
						|
  willDestroyElement() {
 | 
						|
    this._super(...arguments);
 | 
						|
    if (this.model && this.model.isError) {
 | 
						|
      this.model.rollbackAttributes();
 | 
						|
    }
 | 
						|
  },
 | 
						|
 | 
						|
  transitionToRoute() {
 | 
						|
    this.router.transitionTo(...arguments);
 | 
						|
  },
 | 
						|
 | 
						|
  modelPrefixFromType(modelType) {
 | 
						|
    let modelPrefix = '';
 | 
						|
    if (modelType && modelType.startsWith('transform/')) {
 | 
						|
      modelPrefix = `${modelType.replace('transform/', '')}/`;
 | 
						|
    }
 | 
						|
    return modelPrefix;
 | 
						|
  },
 | 
						|
 | 
						|
  listTabFromType(modelType) {
 | 
						|
    let tab;
 | 
						|
    if (modelType && modelType.startsWith('transform/')) {
 | 
						|
      tab = `${modelType.replace('transform/', '')}`;
 | 
						|
    }
 | 
						|
    return tab;
 | 
						|
  },
 | 
						|
 | 
						|
  persist(method, successCallback) {
 | 
						|
    const model = this.model;
 | 
						|
    return model[method]()
 | 
						|
      .then(() => {
 | 
						|
        successCallback(model);
 | 
						|
      })
 | 
						|
      .catch((e) => {
 | 
						|
        model.set('displayErrors', e.errors);
 | 
						|
        throw e;
 | 
						|
      });
 | 
						|
  },
 | 
						|
 | 
						|
  applyDelete(callback = () => {}) {
 | 
						|
    const tab = this.listTabFromType(this.model.constructor.modelName);
 | 
						|
    this.persist('destroyRecord', () => {
 | 
						|
      this.hasDataChanges();
 | 
						|
      callback();
 | 
						|
      this.transitionToRoute(LIST_ROOT_ROUTE, { queryParams: { tab } });
 | 
						|
    });
 | 
						|
  },
 | 
						|
 | 
						|
  applyChanges(type, callback = () => {}) {
 | 
						|
    const modelId = this.model.id || this.model.name; // transform comes in as model.name
 | 
						|
    const modelPrefix = this.modelPrefixFromType(this.model.constructor.modelName);
 | 
						|
    // prevent from submitting if there's no key
 | 
						|
    // maybe do something fancier later
 | 
						|
    if (type === 'create' && isBlank(modelId)) {
 | 
						|
      return;
 | 
						|
    }
 | 
						|
 | 
						|
    this.persist('save', () => {
 | 
						|
      this.hasDataChanges();
 | 
						|
      callback();
 | 
						|
      this.transitionToRoute(SHOW_ROUTE, `${modelPrefix}${modelId}`);
 | 
						|
    });
 | 
						|
  },
 | 
						|
 | 
						|
  hasDataChanges() {
 | 
						|
    this.onDataChange(this.model?.hasDirtyAttributes);
 | 
						|
  },
 | 
						|
 | 
						|
  actions: {
 | 
						|
    createOrUpdate(type, event) {
 | 
						|
      event.preventDefault();
 | 
						|
 | 
						|
      this.applyChanges(type);
 | 
						|
    },
 | 
						|
 | 
						|
    setValue(key, event) {
 | 
						|
      set(this.model, key, event.target.checked);
 | 
						|
    },
 | 
						|
 | 
						|
    refresh() {
 | 
						|
      this.onRefresh();
 | 
						|
    },
 | 
						|
 | 
						|
    delete() {
 | 
						|
      this.applyDelete();
 | 
						|
    },
 | 
						|
  },
 | 
						|
});
 |