Merge pull request #1255 from mabashian/templates-forms-disabled

Fixed bug where job/workflow templates add forms were disabled
This commit is contained in:
Michael Abashian 2018-04-05 14:13:30 -04:00 committed by GitHub
commit d1b504e34d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 73 additions and 59 deletions

View File

@ -10,14 +10,14 @@
'ProcessErrors', 'GetBasePath', 'md5Setup', 'ParseTypeChange', 'Wait',
'Empty', 'ToJSON', 'CallbackHelpInit', 'GetChoices', '$state', 'availableLabels',
'CreateSelect2', '$q', 'i18n', 'Inventory', 'Project', 'InstanceGroupsService',
'MultiCredentialService', 'ConfigData',
'MultiCredentialService', 'ConfigData', 'resolvedModels',
function(
$filter, $scope,
$stateParams, JobTemplateForm, GenerateForm, Rest, Alert,
ProcessErrors, GetBasePath, md5Setup, ParseTypeChange, Wait,
Empty, ToJSON, CallbackHelpInit, GetChoices,
$state, availableLabels, CreateSelect2, $q, i18n, Inventory, Project, InstanceGroupsService,
MultiCredentialService, ConfigData
MultiCredentialService, ConfigData, resolvedModels
) {
// Inject dynamic view
@ -28,37 +28,38 @@
selectPlaybook, checkSCMStatus,
callback;
init();
function init(){
// apply form definition's default field values
GenerateForm.applyDefaults(form, $scope);
const jobTemplate = resolvedModels[0];
$scope.can_edit = true;
$scope.allow_callbacks = false;
$scope.playbook_options = [];
$scope.mode = "add";
$scope.parseType = 'yaml';
$scope.credentialNotPresent = false;
$scope.canGetAllRelatedResources = true;
$scope.canAddJobTemplate = jobTemplate.options('actions.POST');
md5Setup({
scope: $scope,
master: master,
check_field: 'allow_callbacks',
default_val: false
});
CallbackHelpInit({ scope: $scope });
// apply form definition's default field values
GenerateForm.applyDefaults(form, $scope);
$scope.surveyTooltip = i18n._('Please save before adding a survey to this job template.');
$scope.can_edit = true;
$scope.allow_callbacks = false;
$scope.playbook_options = [];
$scope.mode = "add";
$scope.parseType = 'yaml';
$scope.credentialNotPresent = false;
$scope.canGetAllRelatedResources = true;
MultiCredentialService.getCredentialTypes()
.then(({ data }) => {
$scope.multiCredential = {
credentialTypes: data.results,
selectedCredentials: []
};
});
}
md5Setup({
scope: $scope,
master: master,
check_field: 'allow_callbacks',
default_val: false
});
CallbackHelpInit({ scope: $scope });
$scope.surveyTooltip = i18n._('Please save before adding a survey to this job template.');
MultiCredentialService.getCredentialTypes()
.then(({ data }) => {
$scope.multiCredential = {
credentialTypes: data.results,
selectedCredentials: []
};
});
callback = function() {
// Make sure the form controller knows there was a change

View File

@ -8,43 +8,47 @@ export default [
'$scope', 'WorkflowForm', 'GenerateForm', 'Alert', 'ProcessErrors',
'Wait', '$state', 'CreateSelect2', 'TemplatesService',
'ToJSON', 'ParseTypeChange', '$q', 'Rest', 'GetBasePath', 'availableLabels', 'i18n',
'resolvedModels',
function($scope, WorkflowForm, GenerateForm, Alert, ProcessErrors,
Wait, $state, CreateSelect2, TemplatesService, ToJSON,
ParseTypeChange, $q, Rest, GetBasePath, availableLabels, i18n) {
ParseTypeChange, $q, Rest, GetBasePath, availableLabels, i18n,
resolvedModels) {
// Inject dynamic view
let form = WorkflowForm(),
generator = GenerateForm;
function init() {
$scope.canEditOrg = true;
$scope.parseType = 'yaml';
$scope.can_edit = true;
// apply form definition's default field values
GenerateForm.applyDefaults(form, $scope);
const workflowTemplate = resolvedModels[1];
// Make the variables textarea look pretty
ParseTypeChange({
scope: $scope,
field_id: 'workflow_job_template_variables',
onChange: function() {
// Make sure the form controller knows there was a change
$scope[form.name + '_form'].$setDirty();
}
});
$scope.canAddWorkflowJobTemplate = workflowTemplate.options('actions.POST');
$scope.labelOptions = availableLabels
.map((i) => ({label: i.name, value: i.id}));
$scope.canEditOrg = true;
$scope.parseType = 'yaml';
$scope.can_edit = true;
// apply form definition's default field values
GenerateForm.applyDefaults(form, $scope);
CreateSelect2({
element:'#workflow_job_template_labels',
multiple: true,
addNew: true
});
// Make the variables textarea look pretty
ParseTypeChange({
scope: $scope,
field_id: 'workflow_job_template_variables',
onChange: function() {
// Make sure the form controller knows there was a change
$scope[form.name + '_form'].$setDirty();
}
});
$scope.workflowEditorTooltip = i18n._("Please save before defining the workflow graph.");
$scope.surveyTooltip = i18n._('Please save before adding a survey to this workflow.');
}
$scope.labelOptions = availableLabels
.map((i) => ({label: i.name, value: i.id}));
CreateSelect2({
element:'#workflow_job_template_labels',
multiple: true,
addNew: true
});
$scope.workflowEditorTooltip = i18n._("Please save before defining the workflow graph.");
$scope.surveyTooltip = i18n._('Please save before adding a survey to this workflow.');
$scope.formSave = function () {
let fld, data = {};
@ -167,7 +171,5 @@ export default [
$scope.formCancel = function () {
$state.transitionTo('templates');
};
init();
}
];

View File

@ -16,7 +16,8 @@ describe('Controller: WorkflowAdd', () => {
Wait,
ParseTypeChange,
ToJSON,
availableLabels;
availableLabels,
resolvedModels;
beforeEach(angular.mock.module('awApp'));
beforeEach(angular.mock.module('RestServices'));
@ -48,7 +49,16 @@ describe('Controller: WorkflowAdd', () => {
name: "foo",
id: "1"
}];
resolvedModels = [
{},
{
options: () => {
return true;
}
}
];
Alert = jasmine.createSpy('Alert');
ProcessErrors = jasmine.createSpy('ProcessErrors');
CreateSelect2 = jasmine.createSpy('CreateSelect2');
@ -65,6 +75,7 @@ describe('Controller: WorkflowAdd', () => {
$provide.value('ParseTypeChange', ParseTypeChange);
$provide.value('ToJSON', ToJSON);
$provide.value('availableLabels', availableLabels);
$provide.value('resolvedModels', resolvedModels);
}));
beforeEach(angular.mock.inject( ($rootScope, $controller, $q, $httpBackend, _state_, _ConfigService_, _GetChoices_, _Alert_, _GenerateForm_, _ProcessErrors_, _CreateSelect2_, _Wait_, _ParseTypeChange_, _ToJSON_, _availableLabels_) => {