ui/lib/shared/addon/components/confirm-delete/component.js

69 lines
1.6 KiB
JavaScript

import { computed } from '@ember/object';
import { inject as service } from '@ember/service';
import { alias } from '@ember/object/computed';
import Component from '@ember/component';
import { alternateLabel } from 'ui/utils/platform';
import ModalBase from 'ui/mixins/modal-base';
import layout from './template';
export default Component.extend(ModalBase, {
layout,
classNames: ['medium-modal'],
resources: alias('modalService.modalOpts.resources'),
alternateLabel: alternateLabel,
settings: service(),
intl: service(),
showProtip: function() {
let show = this.get('modalService.modalOpts.showProtip');
if ( show === undefined ) {
show = true;
}
return show;
}.property('modalService.modalOpts.showProtip'),
actions: {
confirm: function() {
const resources = this.get('resources').slice().reverse();
async.eachLimit(resources, 5, function(resource, cb) {
if ( !resource ) {
return cb();
}
if ( resource.cb ) {
const out = resource.cb();
if ( out && out.finally ) {
out.finally(cb);
} else {
cb();
}
return;
} else {
resource.delete().finally(cb);
}
});
this.send('cancel');
},
},
isEnvironment: computed('resources', function() {
return !!this.get('resources').findBy('type','project');
}),
isCluster: computed('resources', function() {
return !!this.get('resources').findBy('type','cluster');
}),
didRender: function() {
setTimeout(() => {
try {
this.$('BUTTON')[0].focus();
} catch (e) {}
}, 500);
}
});