From 8ac0b50e598d5659654ac92e15b079af29442b39 Mon Sep 17 00:00:00 2001 From: David Resende Date: Tue, 17 Oct 2023 15:43:14 -0400 Subject: [PATCH] Update Service Reconfigure Form to React --- app/controllers/service_controller.rb | 23 ++- .../components/order-service-form/index.jsx | 12 +- .../dialog-fields-builder.js} | 49 +++--- .../helper.js | 31 ++-- .../service-dialog-builder.schema.js} | 0 .../service-dialog-refresh-button.jsx} | 6 +- .../service-reconfigure-form/index.jsx | 149 ++++++++++++++++++ .../dialog_user/dialog_user_controller.js | 62 ++++---- .../dialog_user_reconfigure_controller.js | 25 ++- .../services/dialog_field_refresh_service.js | 3 +- .../packs/component-definitions-common.js | 4 +- .../service/service_reconfigure.html.haml | 2 + .../shared/dialogs/_dialog_user.html.haml | 2 +- .../dialogs/_reconfigure_dialog.html.haml | 4 +- config/routes.rb | 1 + 15 files changed, 267 insertions(+), 106 deletions(-) rename app/javascript/components/{order-service-form/fields.schema.js => service-dialog-builder/dialog-fields-builder.js} (84%) rename app/javascript/components/{order-service-form => service-dialog-builder}/helper.js (89%) rename app/javascript/components/{order-service-form/order-service-form.schema.js => service-dialog-builder/service-dialog-builder.schema.js} (100%) rename app/javascript/components/{order-service-form/order-service-refresh-button.jsx => service-dialog-builder/service-dialog-refresh-button.jsx} (81%) create mode 100644 app/javascript/components/service-reconfigure-form/index.jsx create mode 100644 app/views/service/service_reconfigure.html.haml diff --git a/app/controllers/service_controller.rb b/app/controllers/service_controller.rb index 78123c7911e..81adce03be8 100644 --- a/app/controllers/service_controller.rb +++ b/app/controllers/service_controller.rb @@ -33,6 +33,8 @@ def button service_retire when 'service_retire_now' service_retire_now + when 'service_reconfigure' + javascript_redirect(:action => 'service_reconfigure', :id => params[:id]) end end @@ -56,20 +58,25 @@ def show_generic_object def edit assert_privileges("service_edit") + + $log.warn("testing edit") + checked = find_checked_items checked[0] = params[:id] if checked.blank? && params[:id] @service = find_record_with_rbac(Service, checked[0]) @in_a_form = true - drop_breadcrumb(:name => _("Edit Service\"%{name}\"") % {:name => @service.name}, :url => "/service/edit/#{@service.id}") + drop_breadcrumb(:name => _("Edit Service \"%{name}\"") % {:name => @service.name}, :url => "/service/edit/#{@service.id}") end def service_reconfigure - service = Service.find_by(:id => params[:id]) - service_template = service.service_template - resource_action = service_template.resource_actions.find_by(:action => 'Reconfigure') if service_template + assert_privileges('service_reconfigure') - @right_cell_text = _("Reconfigure Service \"%{name}\"") % {:name => service.name} - dialog_locals = {:resource_action_id => resource_action.id, :target_id => service.id} + @service = find_record_with_rbac(Service, params[:id]) + service_template = @service.service_template + resource_action = service_template.resource_actions.find_by(:action => 'Reconfigure') if service_template + @dialog_locals = {:resource_action_id => resource_action.id, :target_id => @service.id} + @in_a_form = true + drop_breadcrumb(:name => _("Reconfigure Service \"%{name}\"") % {:name => @service.name}, :url => "/service/service_reconfigure/#{@service.id}") end def service_form_fields @@ -211,8 +218,8 @@ def set_right_cell_vars(action) action = "retire" when "reconfigure_dialog" partial = "shared/dialogs/reconfigure_dialog" - header = @right_cell_text - action = nil + header = _("Reconfigure Service \"%{name}\"") % {:name => @service.name} + action = "reconfigure_dialog" when "service_edit" partial = "service_form" header = _("Editing Service \"%{name}\"") % {:name => @service.name} diff --git a/app/javascript/components/order-service-form/index.jsx b/app/javascript/components/order-service-form/index.jsx index 343049a2f52..25063ec2058 100644 --- a/app/javascript/components/order-service-form/index.jsx +++ b/app/javascript/components/order-service-form/index.jsx @@ -3,11 +3,11 @@ import PropTypes from 'prop-types'; import MiqFormRenderer, { useFormApi } from '@@ddf'; import { Button, Loading } from 'carbon-components-react'; import { FormSpy } from '@data-driven-forms/react-form-renderer'; -import createSchema from './order-service-form.schema'; +import createSchema from '../service-dialog-builder/service-dialog-builder.schema'; import { API } from '../../http_api'; import miqRedirectBack from '../../helpers/miq-redirect-back'; -import { buildFields, prepareSubmitData } from './helper'; -import OrderServiceRefreshButton from './order-service-refresh-button'; +import { buildFields, prepareSubmitData } from '../service-dialog-builder/helper'; +import ServiceDialogRefreshButton from '../service-dialog-builder/service-dialog-refresh-button'; import mapper from '../../forms/mappers/componentMapper'; import NotificationMessage from '../notification-message'; @@ -45,9 +45,7 @@ const OrderServiceForm = ({ initialData }) => { }, []); const onSubmit = (values) => { - let submitData = { action: 'order', ...values }; - - submitData = prepareSubmitData(values, setShowDateError); + let submitData = prepareSubmitData('order', values, setShowDateError); if (submitData !== false) { if (apiSubmitEndpoint.includes('/generic_objects/')) { @@ -83,7 +81,7 @@ const OrderServiceForm = ({ initialData }) => { const componentMapper = { ...mapper, - 'refresh-button': OrderServiceRefreshButton, + 'refresh-button': ServiceDialogRefreshButton, }; return ( diff --git a/app/javascript/components/order-service-form/fields.schema.js b/app/javascript/components/service-dialog-builder/dialog-fields-builder.js similarity index 84% rename from app/javascript/components/order-service-form/fields.schema.js rename to app/javascript/components/service-dialog-builder/dialog-fields-builder.js index f869beff815..5dbf4fb43df 100644 --- a/app/javascript/components/order-service-form/fields.schema.js +++ b/app/javascript/components/service-dialog-builder/dialog-fields-builder.js @@ -9,7 +9,7 @@ const generateDynamicFields = (field) => { }; /** Function to build a text box. */ -export const buildTextBox = (field, validate) => { +export const buildTextBox = (field, validate, apiAction) => { let component = {}; generateDynamicFields(field); @@ -21,7 +21,7 @@ export const buildTextBox = (field, validate) => { label: field.label, hideField: !field.visible, isRequired: field.required, - isDisabled: field.read_only, + isDisabled: field.read_only || (!field.reconfigurable && apiAction !== 'order'), initialValue: field.default_value, description: field.description, validate, @@ -34,7 +34,7 @@ export const buildTextBox = (field, validate) => { label: field.label, hideField: !field.visible, isRequired: field.required, - isDisabled: field.read_only, + isDisabled: field.read_only || (!field.reconfigurable && apiAction !== 'order'), initialValue: field.default_value, description: field.description, validate, @@ -92,35 +92,35 @@ export const buildTextBox = (field, validate) => { }; /** Function to build a text area */ -export const buildTextAreaBox = (field, validate) => ({ +export const buildTextAreaBox = (field, validate, apiAction) => ({ component: componentTypes.TEXTAREA, id: field.id, name: field.name, label: field.label, hideField: !field.visible, isRequired: field.required, - isDisabled: field.read_only, + isDisabled: field.read_only || (!field.reconfigurable && apiAction !== 'order'), initialValue: field.default_value, description: field.description, validate, }); /** Function to build a check box. */ -export const buildCheckBox = (field, validate) => ({ +export const buildCheckBox = (field, validate, apiAction) => ({ component: componentTypes.CHECKBOX, id: field.id, name: field.name, label: field.label, hideField: !field.visible, isRequired: field.required, - isDisabled: field.read_only, + isDisabled: field.read_only || (!field.reconfigurable && apiAction !== 'order'), initialValue: field.default_value, description: field.description, validate, }); /** Function to build a drop down select box. */ -export const buildDropDownList = (field, validate) => { +export const buildDropDownList = (field, validate, apiAction) => { let options = []; let placeholder = __(''); let start; @@ -165,7 +165,7 @@ export const buildDropDownList = (field, validate) => { labelText: field.label, hideField: !field.visible, isRequired: field.required, - isDisabled: field.read_only, + isDisabled: field.read_only || (!field.reconfigurable && apiAction !== 'order'), initialValue: field.default_value, description: field.description, validate, @@ -181,7 +181,7 @@ export const buildDropDownList = (field, validate) => { }; /** Function to build a tag control field. */ -export const buildTagControl = (field, validate) => { +export const buildTagControl = (field, validate, apiAction) => { const options = []; field.values.forEach((value) => { if (!value.id) { @@ -196,7 +196,7 @@ export const buildTagControl = (field, validate) => { label: field.label, hideField: !field.visible, isRequired: field.required, - isDisabled: field.read_only, + isDisabled: field.read_only || (!field.reconfigurable && apiAction !== 'order'), initialValue: field.default_value, description: field.description, validate, @@ -205,13 +205,13 @@ export const buildTagControl = (field, validate) => { }; /** Function to build a date control field */ -export const buildDateControl = (field, validate) => ({ +export const buildDateControl = (field, validate, apiAction) => ({ component: componentTypes.DATE_PICKER, id: field.id, name: field.name, label: field.label, isRequired: field.required, - isDisabled: field.read_only, + isDisabled: field.read_only || (!field.reconfigurable && apiAction !== 'order'), initialValue: field.default_value, description: field.description, validate, @@ -219,13 +219,13 @@ export const buildDateControl = (field, validate) => ({ }); /** Function to build a time control field */ -export const buildTimeControl = (field, validate, dateTime) => ([{ +export const buildTimeControl = (field, validate, dateTime, apiAction) => ([{ component: componentTypes.DATE_PICKER, id: field.id, name: field.name, label: field.label, isRequired: field.required, - isDisabled: field.read_only, + isDisabled: field.read_only || (!field.reconfigurable && apiAction !== 'order'), initialValue: dateTime.toISOString(), description: field.description, validate, @@ -236,7 +236,7 @@ export const buildTimeControl = (field, validate, dateTime) => ([{ id: `${field.id}-time`, name: `${field.name}-time`, isRequired: field.required, - isDisabled: field.read_only, + isDisabled: field.read_only || (!field.reconfigurable && apiAction !== 'order'), initialValue: dateTime, validate, twelveHoursFormat: true, @@ -244,7 +244,7 @@ export const buildTimeControl = (field, validate, dateTime) => ([{ }]); /** Function to build radio buttons fields */ -export const buildRadioButtons = (field, validate) => { +export const buildRadioButtons = (field, validate, apiAction) => { const options = []; field.values.forEach((value) => { options.push({ value: value[0], label: value[1] }); @@ -255,7 +255,7 @@ export const buildRadioButtons = (field, validate) => { name: field.name, label: field.label, isRequired: field.required, - isDisabled: field.read_only, + isDisabled: field.read_only || (!field.reconfigurable && apiAction !== 'order'), initialValue: field.default_value, description: field.description, validate, @@ -271,7 +271,8 @@ const fieldSpinner = (fieldName, show) => { /** Function to update the response and build the fileds again after field refresh. */ const updateResponseFields = (response, fieldPosition, fieldName, result) => { - response.content[0].dialog_tabs.map((tab, tabIndex) => { + const responseContent = response.content ? response.content[0].dialog_tabs : response.reconfigure_dialog[0].dialog_tabs; + responseContent.map((tab, tabIndex) => { if (tabIndex === fieldPosition.tabIndex) { tab.dialog_groups.map((group, groupIndex) => { if (groupIndex === fieldPosition.groupIndex) { @@ -280,9 +281,10 @@ const updateResponseFields = (response, fieldPosition, fieldName, result) => { field.data_type = data.data_type; field.options = data.options; field.read_only = data.read_only; + field.reconfigurable = data.reconfigurable; field.required = data.required; field.visible = data.visible; - field.values = [['001', 'one'], ['002', 'two']]; // data.values; + field.values = data.values; field.default_value = data.default_value; field.validator_rule = data.validator_rule; field.validator_type = data.validator_type; @@ -300,7 +302,10 @@ const updateResponseFields = (response, fieldPosition, fieldName, result) => { */ const refreshFields = (response, params, fieldName, initialData, resource, data, setData, fieldPosition) => { fieldSpinner(fieldName, true); - API.post(`/api/service_dialogs/${response.id}`, params).then(({ result }) => { + + const dialogId = response.reconfigure_dialog ? response.reconfigure_dialog[0].id : response.id; + + API.post(`/api/service_dialogs/${dialogId}`, params).then(({ result }) => { const responders = result[fieldName].dialog_field_responders; const newResponse = updateResponseFields(response, fieldPosition, fieldName, result); buildFields(newResponse, data, setData, initialData); @@ -322,7 +327,7 @@ const onRefreshField = (response, field, initialData, data, setData, fieldPositi fields: [field.name], resource_action_id: initialData.resourceActionId, target_id: initialData.targetId, - target_type: initialData.targetType, + target_type: initialData.targetType ? initialData.targetType : 'service', real_target_type: initialData.realTargetType, }; const params = { diff --git a/app/javascript/components/order-service-form/helper.js b/app/javascript/components/service-dialog-builder/helper.js similarity index 89% rename from app/javascript/components/order-service-form/helper.js rename to app/javascript/components/service-dialog-builder/helper.js index adb56861277..48156d6ce90 100644 --- a/app/javascript/components/order-service-form/helper.js +++ b/app/javascript/components/service-dialog-builder/helper.js @@ -10,7 +10,7 @@ import { buildTimeControl, buildRadioButtons, buildRefreshButton, -} from './fields.schema'; +} from './dialog-fields-builder'; const dates = []; const showPastDates = []; @@ -61,30 +61,30 @@ const formatTimeControl = (field) => { return newDate; }; -const buildComponent = (field, validate) => { +const buildComponent = (field, validate, apiAction) => { switch (field.type) { case DIALOG_FIELDS.textBox: - return buildTextBox(field, validate); + return buildTextBox(field, validate, apiAction); case DIALOG_FIELDS.textArea: - return buildTextAreaBox(field, validate); + return buildTextAreaBox(field, validate, apiAction); case DIALOG_FIELDS.checkBox: - return buildCheckBox(field, validate); + return buildCheckBox(field, validate, apiAction); case DIALOG_FIELDS.dropDown: - return buildDropDownList(field, validate); + return buildDropDownList(field, validate, apiAction); case DIALOG_FIELDS.tag: - return buildTagControl(field, validate); + return buildTagControl(field, validate, apiAction); case DIALOG_FIELDS.date: { formatDateControl(field); - return buildDateControl(field, validate); + return buildDateControl(field, validate, apiAction); } case DIALOG_FIELDS.dateTime: { const dateTime = formatTimeControl(field); - return buildTimeControl(field, validate, dateTime); + return buildTimeControl(field, validate, dateTime, apiAction); } case DIALOG_FIELDS.radio: - return buildRadioButtons(field, validate); + return buildRadioButtons(field, validate, apiAction); default: return {}; } @@ -127,7 +127,10 @@ const buildValidator = (field) => { /** Function to build the form fields. */ export const buildFields = (response, data, setData, initialData) => { const dialogTabs = []; - response.content[0].dialog_tabs.forEach((tab, tabIndex) => { + const responseContent = response.content ? response.content[0].dialog_tabs : response.reconfigure_dialog[0].dialog_tabs; + const { apiAction } = initialData; + + responseContent.forEach((tab, tabIndex) => { const dialogSections = []; tab.dialog_groups.forEach((group, groupIndex) => { const dialogFields = []; @@ -135,7 +138,7 @@ export const buildFields = (response, data, setData, initialData) => { const validate = buildValidator(field); const fieldPosition = { tabIndex, groupIndex }; const fieldData = [ - buildComponent(field, validate), + buildComponent(field, validate, apiAction), buildRefreshButton(response, field, initialData, data, setData, fieldPosition), ]; dialogFields.push(fieldData); @@ -274,8 +277,8 @@ const handleCheckboxSubmit = (submitData) => { }; /** Function to handle the form data on form submit. */ -export const prepareSubmitData = (values, setShowDateError) => { - let submitData = { action: 'order', ...values }; +export const prepareSubmitData = (submitAction, values, setShowDateError) => { + let submitData = { action: submitAction, ...values }; stopSubmit = false; invalidDateFields = []; diff --git a/app/javascript/components/order-service-form/order-service-form.schema.js b/app/javascript/components/service-dialog-builder/service-dialog-builder.schema.js similarity index 100% rename from app/javascript/components/order-service-form/order-service-form.schema.js rename to app/javascript/components/service-dialog-builder/service-dialog-builder.schema.js diff --git a/app/javascript/components/order-service-form/order-service-refresh-button.jsx b/app/javascript/components/service-dialog-builder/service-dialog-refresh-button.jsx similarity index 81% rename from app/javascript/components/order-service-form/order-service-refresh-button.jsx rename to app/javascript/components/service-dialog-builder/service-dialog-refresh-button.jsx index 1567164e692..5eedc059179 100644 --- a/app/javascript/components/order-service-form/order-service-refresh-button.jsx +++ b/app/javascript/components/service-dialog-builder/service-dialog-refresh-button.jsx @@ -3,7 +3,7 @@ import { Button, Loading } from 'carbon-components-react'; import { Renew16 } from '@carbon/icons-react'; import PropTypes from 'prop-types'; -const OrderServiceRefreshButton = ({ onRefresh, showRefreshButton, fieldName }) => ( +const ServiceDialogRefreshButton = ({ onRefresh, showRefreshButton, fieldName }) => ( <> {showRefreshButton && ( + + + )} + + + ); +}; + +FormTemplate.propTypes = { + formFields: PropTypes.arrayOf(PropTypes.any).isRequired, +}; + +ServiceReconfigureForm.propTypes = { + dialogLocals: PropTypes.shape({ + resourceActionId: PropTypes.string, + targetId: PropTypes.string, + }), +}; +ServiceReconfigureForm.defaultProps = { + dialogLocals: undefined, +}; + +export default ServiceReconfigureForm; diff --git a/app/javascript/oldjs/controllers/dialog_user/dialog_user_controller.js b/app/javascript/oldjs/controllers/dialog_user/dialog_user_controller.js index 5c573890e7c..f761e21db6c 100644 --- a/app/javascript/oldjs/controllers/dialog_user/dialog_user_controller.js +++ b/app/javascript/oldjs/controllers/dialog_user/dialog_user_controller.js @@ -1,14 +1,14 @@ ManageIQ.angular.app.controller('dialogUserController', ['API', 'dialogFieldRefreshService', 'miqService', 'dialogUserSubmitErrorHandlerService', 'dialogId', 'apiSubmitEndpoint', 'apiAction', 'finishSubmitEndpoint', 'cancelEndpoint', 'resourceActionId', 'targetId', 'targetType', 'realTargetType', 'openUrl', '$http', '$window', 'dialogReplaceData', 'DialogData', function(API, dialogFieldRefreshService, miqService, dialogUserSubmitErrorHandlerService, dialogId, apiSubmitEndpoint, apiAction, finishSubmitEndpoint, cancelEndpoint, resourceActionId, targetId, targetType, realTargetType, openUrl, $http, $window, dialogReplaceData, DialogData) { - var vm = this; + const vm = this; vm.$onInit = function() { - var apiCall = new Promise(function(resolve) { - var url = '/api/service_dialogs/' + dialogId + - '?resource_action_id=' + resourceActionId + - '&target_id=' + targetId + - '&target_type=' + targetType; + const apiCall = new Promise((resolve) => { + const url = `/api/service_dialogs/${dialogId + }?resource_action_id=${resourceActionId + }&target_id=${targetId + }&target_type=${targetType}`; - resolve(API.get(url, {expand: 'resources', attributes: 'content'}).then(init)); + resolve(API.get(url, { expand: 'resources', attributes: 'content' }).then(init)); }); Promise.resolve(apiCall).then(miqService.refreshSelectpicker); @@ -18,16 +18,15 @@ ManageIQ.angular.app.controller('dialogUserController', ['API', 'dialogFieldRefr vm.dialog = dialog.content[0]; vm.dialogLoaded = true; - console.log(vm.dialog); - _.forEach(vm.dialog.dialog_tabs, function(tab) { - _.forEach(tab.dialog_groups, function(group) { - _.forEach(group.dialog_fields, function(field) { - const replaceField = dialogReplaceData ? JSON.parse(dialogReplaceData).find(function (replace) { return replace.name === field.name }) : false; + _.forEach(vm.dialog.dialog_tabs, (tab) => { + _.forEach(tab.dialog_groups, (group) => { + _.forEach(group.dialog_fields, (field) => { + const replaceField = dialogReplaceData ? JSON.parse(dialogReplaceData).find((replace) => replace.name === field.name) : false; if (replaceField) { field.default_value = replaceField.value; } if (field.type === 'DialogFieldDropDownList') { - _.forEach(field.values, function(value) { + _.forEach(field.values, (value) => { if (value[0] === null) { value[1] = __(value[1]); } @@ -50,16 +49,16 @@ ManageIQ.angular.app.controller('dialogUserController', ['API', 'dialogFieldRefr vm.isValid = false; function refreshField(field) { - console.log("111=", field); + console.log('111=', field); // API.post(field.href).then((data) => { // console.log(data); // }); - var idList = { - dialogId: dialogId, - resourceActionId: resourceActionId, - targetId: targetId, - targetType: targetType, - realTargetType: realTargetType, + const idList = { + dialogId, + resourceActionId, + targetId, + targetType, + realTargetType, }; return dialogFieldRefreshService.refreshField(vm.dialogData, [field.name], vm.refreshUrl, idList); @@ -74,23 +73,22 @@ ManageIQ.angular.app.controller('dialogUserController', ['API', 'dialogFieldRefr vm.dialogData.action = apiAction; // miqService.sparkleOn(); - var apiData = DialogData.outputConversion(vm.dialogData); + let apiData = DialogData.outputConversion(vm.dialogData); if (apiSubmitEndpoint.match(/generic_objects/)) { - apiData = {action: apiAction, parameters: _.omit(apiData, 'action')}; + apiData = { action: apiAction, parameters: _.omit(apiData, 'action') }; } else if (apiAction === 'reconfigure') { - apiData = {action: apiAction, resource: _.omit(apiData, 'action')}; + apiData = { action: apiAction, resource: _.omit(apiData, 'action') }; } - return API.post(apiSubmitEndpoint, apiData, {skipErrors: [400]}) - .then(function(response) { - console.log(openUrl); + return API.post(apiSubmitEndpoint, apiData, { skipErrors: [400] }) + .then((response) => { if (vm.openUrl === 'true') { return API.wait_for_task(response.task_id) - .then(function() { + .then(() => { console.log(API.wait_for_task(response.task_id)); - return $http.post('open_url_after_dialog', {targetId: vm.targetId, realTargetType: realTargetType}); + return $http.post('open_url_after_dialog', { targetId: vm.targetId, realTargetType }); }) - .then(function(response) { + .then((response) => { if (response.data.open_url) { $window.open(response.data.open_url); miqService.redirectBack(__('Order Request was Submitted'), 'success', finishSubmitEndpoint); @@ -99,13 +97,11 @@ ManageIQ.angular.app.controller('dialogUserController', ['API', 'dialogFieldRefr miqService.sparkleOff(); } }) - .catch(function() { - return Promise.reject({data: {error: {message: '-'.concat(__('Automate failed to obtain URL.')) }}}); - }); + .catch(() => Promise.reject({ data: { error: { message: '-'.concat(__('Automate failed to obtain URL.')) } } })); } miqService.redirectBack(__('Order Request was Submitted'), 'success', finishSubmitEndpoint); }) - .catch(function(err) { + .catch((err) => { dialogUserSubmitErrorHandlerService.handleError(err); }); } diff --git a/app/javascript/oldjs/controllers/dialog_user/dialog_user_reconfigure_controller.js b/app/javascript/oldjs/controllers/dialog_user/dialog_user_reconfigure_controller.js index 9c6c7b5a50f..341527ec4c1 100644 --- a/app/javascript/oldjs/controllers/dialog_user/dialog_user_reconfigure_controller.js +++ b/app/javascript/oldjs/controllers/dialog_user/dialog_user_reconfigure_controller.js @@ -1,10 +1,10 @@ ManageIQ.angular.app.controller('dialogUserReconfigureController', ['API', 'dialogFieldRefreshService', 'miqService', 'dialogUserSubmitErrorHandlerService', 'resourceActionId', 'targetId', 'DialogData', function(API, dialogFieldRefreshService, miqService, dialogUserSubmitErrorHandlerService, resourceActionId, targetId, DialogData) { - var vm = this; + const vm = this; vm.$onInit = function() { - var apiCall = new Promise(function(resolve) { - var url = '/api/services/' + targetId + - '?attributes=reconfigure_dialog'; + const apiCall = new Promise((resolve) => { + const url = `/api/services/${targetId + }?attributes=reconfigure_dialog`; resolve(API.get(url).then(init)); }); @@ -28,13 +28,12 @@ ManageIQ.angular.app.controller('dialogUserReconfigureController', ['API', 'dial vm.isValid = false; function refreshField(field) { - var idList = { + const idList = { dialogId: vm.dialogId, - resourceActionId: resourceActionId, - targetId: targetId, + resourceActionId, + targetId, targetType: 'service', }; - console.log('vm.dialogData=',vm.dialogData) return dialogFieldRefreshService.refreshField(vm.dialogData, [field.name], vm.refreshUrl, idList); } @@ -46,17 +45,15 @@ ManageIQ.angular.app.controller('dialogUserReconfigureController', ['API', 'dial function submitButtonClicked() { miqService.sparkleOn(); - var apiData = { + const apiData = { action: 'reconfigure', resource: _.omit(DialogData.outputConversion(vm.dialogData), 'action'), }; - var apiSubmitEndpoint = '/api/services/' + targetId; + const apiSubmitEndpoint = `/api/services/${targetId}`; - return API.post(apiSubmitEndpoint, apiData, {skipErrors: [400]}).then(function() { + return API.post(apiSubmitEndpoint, apiData, { skipErrors: [400] }).then(() => { miqService.redirectBack(__('Order Request was Submitted'), 'info', '/service'); - }).catch(function(err) { - return Promise.reject(dialogUserSubmitErrorHandlerService.handleError(err)); - }); + }).catch((err) => Promise.reject(dialogUserSubmitErrorHandlerService.handleError(err))); } function cancelClicked(_event) { diff --git a/app/javascript/oldjs/services/dialog_field_refresh_service.js b/app/javascript/oldjs/services/dialog_field_refresh_service.js index 8a5f316a0ec..1aafcd636d9 100644 --- a/app/javascript/oldjs/services/dialog_field_refresh_service.js +++ b/app/javascript/oldjs/services/dialog_field_refresh_service.js @@ -2,7 +2,6 @@ ManageIQ.angular.app.service('dialogFieldRefreshService', ['API', 'DialogData', var self = this; self.refreshField = function(dialogData, dialogField, url, idList) { - console.log('222') self.areFieldsBeingRefreshed = true; var data = { @@ -17,6 +16,8 @@ ManageIQ.angular.app.service('dialogFieldRefreshService', ['API', 'DialogData', }, }; + console.log(data); + return API.post(url + idList.dialogId, angular.toJson(data)) .then(function(response) { console.log('333=', response); diff --git a/app/javascript/packs/component-definitions-common.js b/app/javascript/packs/component-definitions-common.js index 20b8b380bc5..bb1effc3e12 100644 --- a/app/javascript/packs/component-definitions-common.js +++ b/app/javascript/packs/component-definitions-common.js @@ -82,7 +82,7 @@ import OpsTenantForm from '../components/ops-tenant-form/ops-tenant-form'; import OrcherstrationTemplateForm from '../components/orchestration-template/orcherstration-template-form'; import ProvGrid from '../components/prov-grid'; import OrderServiceForm from '../components/order-service-form'; -import OrderServiceRefreshButton from '../components/order-service-form/order-service-refresh-button'; +import OrderServiceRefreshButton from '../components/service-dialog-builder/service-dialog-refresh-button'; import PxeImageForm from '../components/pxe-image-type-form'; import PxeCustomizationTemplateForm from '../components/pxe-customization-template-form'; import PxeIsoDatastoreForm from '../components/pxe-iso-datastore-form'; @@ -110,6 +110,7 @@ import RequestWorkflowStatus from '../components/request-workflow-status'; import RoutersForm from '../components/routers-form'; import ServiceDialogFromForm from '../components/service-dialog-from-form/service-dialog-from'; import ServiceDetailStdout from '../components/service-detail-stdout'; +import ServiceReconfigureForm from '../components/service-reconfigure-form'; import SettingsTimeProfileForm from '../components/settings-time-profile-form'; import SettingsCategoryForm from '../components/settings-category-form'; import SettingsZone from '../components/settings-zone'; @@ -286,6 +287,7 @@ ManageIQ.component.addReact('ServiceDialogFromForm', ServiceDialogFromForm); ManageIQ.component.addReact('ServiceDetailStdout', ServiceDetailStdout); ManageIQ.component.addReact('SettingsTasksForm', SettingsTasksForm); ManageIQ.component.addReact('EditServiceForm', EditServiceForm); +ManageIQ.component.addReact('ServiceReconfigureForm', ServiceReconfigureForm); ManageIQ.component.addReact('ServiceRequestDefault', ServiceRequestDefault); ManageIQ.component.addReact('SetOwnershipForm', SetOwnershipForm); ManageIQ.component.addReact('ServersDataChart', ServersDataChart); diff --git a/app/views/service/service_reconfigure.html.haml b/app/views/service/service_reconfigure.html.haml new file mode 100644 index 00000000000..46641f3d1f6 --- /dev/null +++ b/app/views/service/service_reconfigure.html.haml @@ -0,0 +1,2 @@ += react 'ServiceReconfigureForm', :dialogLocals => { :resourceActionId => @dialog_locals[:resource_action_id], :targetId => @dialog_locals[:target_id] } += render :partial => "shared/dialogs/reconfigure_dialog" diff --git a/app/views/shared/dialogs/_dialog_user.html.haml b/app/views/shared/dialogs/_dialog_user.html.haml index 837f4a642a5..a1ee30d97a3 100644 --- a/app/views/shared/dialogs/_dialog_user.html.haml +++ b/app/views/shared/dialogs/_dialog_user.html.haml @@ -11,7 +11,7 @@ - target_id ||= dialog[:targetId] - target_type ||= dialog[:targetType] -= react('OrderServiceForm', :initialData => dialog) + = react('OrderServiceForm', :initialData => dialog) .row.wrapper{"ng-controller" => "dialogUserController as vm"} diff --git a/app/views/shared/dialogs/_reconfigure_dialog.html.haml b/app/views/shared/dialogs/_reconfigure_dialog.html.haml index 386b7172941..bfb4aee24e4 100644 --- a/app/views/shared/dialogs/_reconfigure_dialog.html.haml +++ b/app/views/shared/dialogs/_reconfigure_dialog.html.haml @@ -20,6 +20,6 @@ 'on-click' => "vm.cancelClicked($event)"} :javascript - ManageIQ.angular.app.value('resourceActionId', '#{resource_action_id}'); - ManageIQ.angular.app.value('targetId', '#{target_id}'); + ManageIQ.angular.app.value('resourceActionId', '#{@dialog_locals[:resource_action_id]}'); + ManageIQ.angular.app.value('targetId', '#{@dialog_locals[:target_id]}'); miq_bootstrap('.wrapper'); diff --git a/config/routes.rb b/config/routes.rb index 3ea0c966987..cd31dcfc64d 100644 --- a/config/routes.rb +++ b/config/routes.rb @@ -2777,6 +2777,7 @@ :get => %w( dialog_load download_data + service_reconfigure reconfigure_form_fields retire button