mirror of https://github.com/rancher/ui.git
82 lines
2.1 KiB
JavaScript
82 lines
2.1 KiB
JavaScript
import { on } from '@ember/object/evented';
|
|
import { computed, observer } from '@ember/object';
|
|
import Component from '@ember/component';
|
|
import NodeDriver from 'shared/mixins/node-driver';
|
|
import layout from './template';
|
|
|
|
export default Component.extend(NodeDriver, {
|
|
layout,
|
|
// Set by Driver
|
|
driverName : 'other',
|
|
driver : null,
|
|
|
|
otherDriver : null,
|
|
availableDrivers : null,
|
|
typeDocumentations : null,
|
|
schemas : null,
|
|
driverOpts : null,
|
|
|
|
bootstrap() {
|
|
let model = this.get('globalStore').createRecord({
|
|
type: 'machineTemplate',
|
|
isOfTypeOther: true,
|
|
});
|
|
|
|
this.setProperties({
|
|
otherDriver: this.get('otherChoices.firstObject.value'),
|
|
model: model
|
|
});
|
|
},
|
|
validate() {
|
|
let errors = [];
|
|
|
|
if ( !this.get('model.name') ) {
|
|
errors.push('Name is required');
|
|
}
|
|
|
|
this.set('errors', errors);
|
|
return errors.length === 0;
|
|
},
|
|
|
|
willDestroyElement() {
|
|
this.setProperties({
|
|
otherDriver: null,
|
|
driverOpts : null,
|
|
});
|
|
},
|
|
|
|
fieldNames: computed('otherDriver', 'model', function() {
|
|
let driver = this.get('otherDriver');
|
|
|
|
if ( driver ) {
|
|
return Object.keys(this.get('globalStore').getById('schema', driver.toLowerCase()).get('resourceFields'));
|
|
}
|
|
}),
|
|
|
|
driverChanged: on('init', observer('otherDriver','model', function() {
|
|
if (this.get('otherDriver')) {
|
|
let driver = this.get('otherDriver').split('C')[0];
|
|
let machineTemplate = this.get('model');
|
|
let config = this.get('globalStore').createRecord({
|
|
type : this.get('otherDriver'),
|
|
});
|
|
|
|
machineTemplate.setProperties({
|
|
driver: driver,
|
|
[this.get('otherDriver')]: config
|
|
});
|
|
|
|
this.set('driverOpts', machineTemplate.get(`${this.get('otherDriver')}`));
|
|
}
|
|
})),
|
|
|
|
otherChoices: computed('availableDrivers.@each.{hasUi,name}', function() {
|
|
let out = [];
|
|
this.get('availableDrivers').filterBy('hasUi',false).forEach((driver) => {
|
|
out.push({label: driver.name, value: driver.name+'Config'});
|
|
});
|
|
|
|
return out.sortBy('name');
|
|
}),
|
|
});
|