import FormComponent from './form-component'; import { inject as service } from '@ember/service'; import { get, set } from '@ember/object'; export default FormComponent.extend({ repo: service('repository/policy/component'), datacenterRepo: service('repository/dc/component'), type: 'policy', name: 'policy', allowServiceIdentity: true, classNames: ['policy-form'], isScoped: false, init: function() { this._super(...arguments); set(this, 'isScoped', get(this, 'item.Datacenters.length') > 0); set(this, 'datacenters', this.datacenterRepo.findAll()); this.templates = [ { name: 'Policy', template: '', }, { name: 'Service Identity', template: 'service-identity', }, ]; }, actions: { change: function(e) { try { this._super(...arguments); } catch (err) { const scoped = this.isScoped; const name = err.target.name; switch (name) { case 'policy[isScoped]': if (scoped) { set(this, 'previousDatacenters', get(this.item, 'Datacenters')); set(this.item, 'Datacenters', null); } else { set(this.item, 'Datacenters', this.previousDatacenters); set(this, 'previousDatacenters', null); } set(this, 'isScoped', !scoped); break; default: this.onerror(err); } this.onchange({ target: this.form }); } }, }, });