From 8463d02740f9e300c8d306c7012edec39067d2ff Mon Sep 17 00:00:00 2001 From: Hetu Nandu Date: Tue, 8 Oct 2024 16:12:27 +0530 Subject: [PATCH] chore: [Plugin Action Editor] Combine Plugin Editor UI state (#36651) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit ## Description Removes the parallel apiPaneReducer and queryPaneReducer and combines it into pluginActionEditor Fixes #36153 ## Automation /ok-to-test tags="@tag.All" ### :mag: Cypress test results > [!TIP] > 🟢 🟢 🟢 All cypress tests have passed! 🎉 🎉 🎉 > Workflow run: > Commit: 3a204e2902f9733be05e3b7087869d2e91ad52eb > Cypress dashboard. > Tags: `@tag.All` > Spec: >
Tue, 08 Oct 2024 10:15:30 UTC ## Communication Should the DevRel and Marketing teams inform users about this change? - [ ] Yes - [x] No ## Summary by CodeRabbit ## Release Notes - **New Features** - Introduced a new constant `POST_BODY_FORM_DATA_KEY` for improved data handling. - Added several action creators and selectors for enhanced management of the plugin action editor's state. - Implemented state management for the plugin action editor's debugger. - Added the ability to execute commands related to plugins in the `CodeEditor` component. - Introduced a new enumeration `DEBUGGER_TAB_KEYS` for better organization of debugger tabs. - **Improvements** - Refactored import statements for better organization and reduced complexity. - Enhanced the `PluginActionResponse` component to focus on plugin action state management. - Updated the tab management logic in various components to reflect the new plugin action state. - Improved state management in the `QueryEditor` and `APIEditor` components to accurately represent action processing states. - Added error handling in the `ActionSettings` component for missing configuration. - **Bug Fixes** - Updated logic in hooks to ensure proper state management for plugin actions. - Adjusted navigation and tab selection methods to align with the new plugin action state management. - Corrected test selectors for error tabs in Cypress tests to ensure accurate UI interactions. --- .../OtherUIFeatures/Widget_Error_spec.js | 4 +- .../cypress/locators/commonlocators.json | 2 +- app/client/cypress/support/ApiCommands.js | 2 +- .../cypress/support/Objects/CommonLocators.ts | 4 +- app/client/cypress/support/Pages/ApiPage.ts | 2 +- .../cypress/support/Pages/DataSources.ts | 4 +- .../hooks/useSelectedFormTab.ts | 27 +- .../hooks/useChangeActionCall.test.tsx | 8 +- .../hooks/useChangeActionCall.ts | 3 +- .../PluginActionResponse.tsx | 18 +- .../src/PluginActionEditor/constants.ts | 1 + app/client/src/PluginActionEditor/index.ts | 2 + .../src/PluginActionEditor/store/index.ts | 4 + .../store/pluginActionEditorActions.ts | 57 ++++ .../store/pluginActionEditorSelectors.ts | 61 +++++ .../store/pluginEditorReducer.ts | 177 ++++++++++++ app/client/src/actions/apiPaneActions.ts | 67 ----- app/client/src/actions/pluginActionActions.ts | 45 ++- app/client/src/actions/queryPaneActions.ts | 38 --- .../hooks/usePluginActionResponseTabs.tsx | 10 +- app/client/src/ce/actions/helpers.ts | 10 +- .../src/ce/constants/ReduxActionConstants.tsx | 4 + .../src/ce/navigation/FocusElements/AppIDE.ts | 63 ++--- .../Applications/CreateNewAppsOption.test.tsx | 2 +- app/client/src/ce/reducers/index.tsx | 6 +- .../ce/reducers/uiReducers/apiPaneReducer.ts | 256 ------------------ .../src/ce/reducers/uiReducers/index.tsx | 8 +- .../reducers/uiReducers/queryPaneReducer.ts | 231 ---------------- .../src/ce/selectors/appIDESelectors.ts | 16 ++ .../src/ce/selectors/entitiesSelector.ts | 22 -- .../editorComponents/ApiResponseView.test.tsx | 2 +- .../editorComponents/ApiResponseView.tsx | 20 +- .../CodeEditor/EvaluatedValuePopup.tsx | 6 +- .../editorComponents/CodeEditor/index.tsx | 2 +- .../editorComponents/Debugger/DebugCTA.tsx | 2 +- .../Debugger/DebuggerTabs.tsx | 2 +- .../editorComponents/Debugger/Schema.tsx | 6 +- .../editorComponents/Debugger/constants.ts | 8 + .../editorComponents/Debugger/helpers.tsx | 13 +- .../Debugger/hooks/useDebuggerTriggerClick.ts | 29 +- .../editorComponents/EntityBottomTabs.tsx | 5 +- .../editorComponents/JSResponseView.test.tsx | 3 +- .../editorComponents/JSResponseView.tsx | 5 +- .../ee/reducers/uiReducers/apiPaneReducer.tsx | 3 - .../reducers/uiReducers/queryPaneReducer.ts | 3 - app/client/src/navigation/FocusElements.ts | 7 +- .../src/pages/Editor/APIEditor/Editor.tsx | 17 +- .../pages/Editor/APIEditor/PostBodyData.tsx | 13 +- .../src/pages/Editor/ActionSettings.tsx | 17 +- .../Editor/DataSourceEditor/Debugger.tsx | 10 +- .../DataSourceEditor/NewActionButton.tsx | 2 +- .../ActionPane/ApiPaneNavigation.ts | 27 +- .../ActionPane/QueryPaneNavigation.ts | 8 +- .../pages/Editor/EntityNavigation/types.ts | 2 +- .../CreateNewDatasourceTab.tsx | 3 +- app/client/src/pages/Editor/JSEditor/Form.tsx | 4 +- .../src/pages/Editor/QueryEditor/Editor.tsx | 17 +- .../Editor/QueryEditor/EditorJSONtoForm.tsx | 12 +- .../QueryEditor/QueryDebuggerTabs.test.tsx | 2 +- .../Editor/QueryEditor/QueryDebuggerTabs.tsx | 62 +++-- .../Editor/QueryEditor/QueryResponseTab.tsx | 19 +- .../src/pages/Editor/QueryEditor/index.tsx | 2 +- .../sagas/ActionExecution/PluginActionSaga.ts | 50 ++-- .../src/sagas/ActionExecution/errorUtils.ts | 2 +- app/client/src/sagas/ActionSagas.ts | 6 +- app/client/src/sagas/ApiPaneSagas.ts | 9 +- app/client/src/sagas/JSPaneSagas.ts | 2 +- app/client/src/sagas/QueryPaneSagas.ts | 2 +- app/client/src/selectors/apiPaneSelectors.ts | 29 -- app/client/src/selectors/editorSelectors.tsx | 15 +- .../src/selectors/queryPaneSelectors.ts | 38 --- app/client/src/utils/replayHelpers.tsx | 9 +- 72 files changed, 665 insertions(+), 984 deletions(-) create mode 100644 app/client/src/PluginActionEditor/constants.ts create mode 100644 app/client/src/PluginActionEditor/store/index.ts create mode 100644 app/client/src/PluginActionEditor/store/pluginActionEditorActions.ts create mode 100644 app/client/src/PluginActionEditor/store/pluginActionEditorSelectors.ts create mode 100644 app/client/src/PluginActionEditor/store/pluginEditorReducer.ts delete mode 100644 app/client/src/actions/apiPaneActions.ts delete mode 100644 app/client/src/actions/queryPaneActions.ts delete mode 100644 app/client/src/ce/reducers/uiReducers/apiPaneReducer.ts delete mode 100644 app/client/src/ce/reducers/uiReducers/queryPaneReducer.ts create mode 100644 app/client/src/components/editorComponents/Debugger/constants.ts delete mode 100644 app/client/src/ee/reducers/uiReducers/apiPaneReducer.tsx delete mode 100644 app/client/src/ee/reducers/uiReducers/queryPaneReducer.ts delete mode 100644 app/client/src/selectors/apiPaneSelectors.ts delete mode 100644 app/client/src/selectors/queryPaneSelectors.ts diff --git a/app/client/cypress/e2e/Regression/ClientSide/OtherUIFeatures/Widget_Error_spec.js b/app/client/cypress/e2e/Regression/ClientSide/OtherUIFeatures/Widget_Error_spec.js index 2f35d8795cb..1a67eb90f1c 100644 --- a/app/client/cypress/e2e/Regression/ClientSide/OtherUIFeatures/Widget_Error_spec.js +++ b/app/client/cypress/e2e/Regression/ClientSide/OtherUIFeatures/Widget_Error_spec.js @@ -24,7 +24,7 @@ describe("Widget error state", { tags: ["@tag.Widget"] }, function () { //Check if the current value is shown in the debugger _.debuggerHelper.OpenDebugger(); - cy.get("[data-testid=t--tab-ERROR]").click(); + cy.get("[data-testid=t--tab-ERROR_TAB]").click(); //This feature is disabled in updated error log - epic 17720 // _.debuggerHelper.LogStateContains("Test"); }); @@ -37,7 +37,7 @@ describe("Widget error state", { tags: ["@tag.Widget"] }, function () { cy.get(widgetLocators.buttonWidget).click(); cy.get(".t--toast-debug-button").click(); - cy.get("[data-testid='t--tab-ERROR']").should( + cy.get("[data-testid='t--tab-ERROR_TAB']").should( "have.attr", "aria-selected", "true", diff --git a/app/client/cypress/locators/commonlocators.json b/app/client/cypress/locators/commonlocators.json index 9fe519e15ad..fdac92e3af4 100644 --- a/app/client/cypress/locators/commonlocators.json +++ b/app/client/cypress/locators/commonlocators.json @@ -164,7 +164,7 @@ "labelSectionTxt": ".CodeMirror-code .cm-variable", "lintError": ".CodeMirror-lint-mark-error", "debugger": ".t--debugger-count", - "errorTab": "[data-testid=t--tab-ERROR]", + "errorTab": "[data-testid=t--tab-ERROR_TAB]", "debugErrorMsg": "[data-testid=t--debugger-log-message]", "tableButtonVariant": ".t--property-control-buttonvariant", "debuggerLabel": "span.debugger-label", diff --git a/app/client/cypress/support/ApiCommands.js b/app/client/cypress/support/ApiCommands.js index 9c24c425d32..d0d52ec712b 100644 --- a/app/client/cypress/support/ApiCommands.js +++ b/app/client/cypress/support/ApiCommands.js @@ -94,7 +94,7 @@ Cypress.Commands.add( } cy.get(".string-value").contains(baseurl.concat(path)); cy.get(".string-value").contains(verb); - cy.get("[data-testid=t--tab-response]").first().click({ force: true }); + cy.get("[data-testid=t--tab-RESPONSE_TAB]").first().click({ force: true }); }, ); diff --git a/app/client/cypress/support/Objects/CommonLocators.ts b/app/client/cypress/support/Objects/CommonLocators.ts index 9bcf7c1cfec..a8f5d904148 100644 --- a/app/client/cypress/support/Objects/CommonLocators.ts +++ b/app/client/cypress/support/Objects/CommonLocators.ts @@ -89,8 +89,8 @@ export class CommonLocators { _createNew = ".t--add-item"; _uploadFiles = "div.uppy-Dashboard-AddFiles input"; _uploadBtn = "button.uppy-StatusBar-actionBtn--upload"; - _errorTab = "[data-testid=t--tab-ERROR]"; - _responseTab = "[data-testid=t--tab-response]"; + _errorTab = "[data-testid=t--tab-ERROR_TAB]"; + _responseTab = "[data-testid=t--tab-RESPONSE_TAB]"; _modal = ".t--modal-widget"; _closeModal = "button:contains('Close')"; _entityProperties = (entityNameinLeftSidebar: string) => diff --git a/app/client/cypress/support/Pages/ApiPage.ts b/app/client/cypress/support/Pages/ApiPage.ts index bb394a58287..57b7d33abbb 100644 --- a/app/client/cypress/support/Pages/ApiPage.ts +++ b/app/client/cypress/support/Pages/ApiPage.ts @@ -82,7 +82,7 @@ export class ApiPage { private _paginationTypeLabels = ".t--apiFormPaginationType label"; _saveAsDS = ".t--store-as-datasource"; _responseStatus = ".t--response-status-code"; - public _responseTabHeader = "[data-testid=t--tab-headers]"; + public _responseTabHeader = "[data-testid=t--tab-HEADERS_TAB]"; public _headersTabContent = ".t--headers-tab"; public _autoGeneratedHeaderInfoIcon = (key: string) => `.t--auto-generated-${key}-info`; diff --git a/app/client/cypress/support/Pages/DataSources.ts b/app/client/cypress/support/Pages/DataSources.ts index 35777482759..b41cbd05b34 100644 --- a/app/client/cypress/support/Pages/DataSources.ts +++ b/app/client/cypress/support/Pages/DataSources.ts @@ -201,7 +201,7 @@ export class DataSources { ".t--datasource-name:contains('" + dsName + "')"; _mandatoryMark = "//span[text()='*']"; _deleteDSHostPort = ".t--delete-field"; - _dsTabSchema = "[data-testid='t--tab-schema']"; + _dsTabSchema = "[data-testid='t--tab-SCHEMA_TAB']"; private _pageSelectionMenu = "[data-testId='t--page-selection']"; private _pageSelectMenuItem = ".ads-v2-menu__menu-item"; @@ -1854,7 +1854,7 @@ export class DataSources { cy.intercept("GET", "/api/v1/datasources/*/structure?ignoreCache=*").as( `getDatasourceStructureUpdated_${ds_entity_name}`, ); - cy.get("[data-testid=t--tab-schema]").first().click({ force: true }); + cy.get("[data-testid=t--tab-SCHEMA_TAB]").first().click({ force: true }); this.RefreshDatasourceSchema(); this.assertHelper .WaitForNetworkCall(`@getDatasourceStructureUpdated_${ds_entity_name}`) diff --git a/app/client/src/PluginActionEditor/components/PluginActionForm/components/CommonEditorForm/hooks/useSelectedFormTab.ts b/app/client/src/PluginActionEditor/components/PluginActionForm/components/CommonEditorForm/hooks/useSelectedFormTab.ts index b7421a6dfc5..6e3aada35dd 100644 --- a/app/client/src/PluginActionEditor/components/PluginActionForm/components/CommonEditorForm/hooks/useSelectedFormTab.ts +++ b/app/client/src/PluginActionEditor/components/PluginActionForm/components/CommonEditorForm/hooks/useSelectedFormTab.ts @@ -1,25 +1,22 @@ import { useCallback } from "react"; import { useDispatch, useSelector } from "react-redux"; -import { getApiPaneConfigSelectedTabIndex } from "selectors/apiPaneSelectors"; -import { API_EDITOR_TABS } from "constants/ApiEditorConstants/CommonApiConstants"; -import { setApiPaneConfigSelectedTabIndex } from "actions/apiPaneActions"; +import { + getPluginActionConfigSelectedTab, + setPluginActionEditorSelectedTab, +} from "PluginActionEditor/store"; -export function useSelectedFormTab(): [string, (id: string) => void] { +export function useSelectedFormTab(): [ + string | undefined, + (id: string) => void, +] { const dispatch = useDispatch(); - // the redux form has been configured with indexes, but the new ads components need strings to work. - // these functions convert them back and forth as needed. - const selectedIndex = useSelector(getApiPaneConfigSelectedTabIndex); - const selectedValue = Object.values(API_EDITOR_TABS)[selectedIndex]; - const setSelectedIndex = useCallback( + const selectedValue = useSelector(getPluginActionConfigSelectedTab); + const setSelectedTab = useCallback( (value: string) => { - const index = Object.values(API_EDITOR_TABS).indexOf( - value as API_EDITOR_TABS, - ); - - dispatch(setApiPaneConfigSelectedTabIndex(index)); + dispatch(setPluginActionEditorSelectedTab(value)); }, [dispatch], ); - return [selectedValue, setSelectedIndex]; + return [selectedValue, setSelectedTab]; } diff --git a/app/client/src/PluginActionEditor/components/PluginActionForm/hooks/useChangeActionCall.test.tsx b/app/client/src/PluginActionEditor/components/PluginActionForm/hooks/useChangeActionCall.test.tsx index 98c144af91a..f68dfa38cd5 100644 --- a/app/client/src/PluginActionEditor/components/PluginActionForm/hooks/useChangeActionCall.test.tsx +++ b/app/client/src/PluginActionEditor/components/PluginActionForm/hooks/useChangeActionCall.test.tsx @@ -2,8 +2,7 @@ import { renderHook } from "@testing-library/react-hooks/dom"; import { useDispatch } from "react-redux"; import { PluginType } from "entities/Action"; import { usePluginActionContext } from "PluginActionEditor"; -import { changeApi } from "actions/apiPaneActions"; -import { changeQuery } from "actions/queryPaneActions"; +import { changeApi, changeQuery } from "../../../store"; import usePrevious from "utils/hooks/usePrevious"; import { useChangeActionCall } from "./useChangeActionCall"; @@ -11,11 +10,8 @@ jest.mock("react-redux", () => ({ useDispatch: jest.fn(), })); -jest.mock("actions/apiPaneActions", () => ({ +jest.mock("../../../store", () => ({ changeApi: jest.fn(), -})); - -jest.mock("actions/queryPaneActions", () => ({ changeQuery: jest.fn(), })); diff --git a/app/client/src/PluginActionEditor/components/PluginActionForm/hooks/useChangeActionCall.ts b/app/client/src/PluginActionEditor/components/PluginActionForm/hooks/useChangeActionCall.ts index 88a56e14d90..be76f258b79 100644 --- a/app/client/src/PluginActionEditor/components/PluginActionForm/hooks/useChangeActionCall.ts +++ b/app/client/src/PluginActionEditor/components/PluginActionForm/hooks/useChangeActionCall.ts @@ -1,9 +1,8 @@ import { useEffect } from "react"; import { useDispatch } from "react-redux"; -import { changeApi } from "actions/apiPaneActions"; -import { changeQuery } from "actions/queryPaneActions"; import { PluginType } from "entities/Action"; import { usePluginActionContext } from "PluginActionEditor"; +import { changeApi, changeQuery } from "PluginActionEditor/store"; import usePrevious from "utils/hooks/usePrevious"; export const useChangeActionCall = () => { diff --git a/app/client/src/PluginActionEditor/components/PluginActionResponse/PluginActionResponse.tsx b/app/client/src/PluginActionEditor/components/PluginActionResponse/PluginActionResponse.tsx index 9359c8130f3..d2c5b0a2525 100644 --- a/app/client/src/PluginActionEditor/components/PluginActionResponse/PluginActionResponse.tsx +++ b/app/client/src/PluginActionEditor/components/PluginActionResponse/PluginActionResponse.tsx @@ -3,9 +3,9 @@ import { IDEBottomView, ViewHideBehaviour } from "IDE"; import { ActionExecutionResizerHeight } from "pages/Editor/APIEditor/constants"; import EntityBottomTabs from "components/editorComponents/EntityBottomTabs"; import { useDispatch, useSelector } from "react-redux"; -import { getApiPaneDebuggerState } from "selectors/apiPaneSelectors"; -import { setApiPaneDebuggerState } from "actions/apiPaneActions"; -import { DEBUGGER_TAB_KEYS } from "components/editorComponents/Debugger/helpers"; +import { setPluginActionEditorDebuggerState } from "../../store"; +import { getPluginActionDebuggerState } from "../../store"; +import { DEBUGGER_TAB_KEYS } from "components/editorComponents/Debugger/constants"; import AnalyticsUtil from "ee/utils/AnalyticsUtil"; import { usePluginActionResponseTabs } from "./hooks"; @@ -16,11 +16,11 @@ function PluginActionResponse() { // TODO combine API and Query Debugger state const { open, responseTabHeight, selectedTab } = useSelector( - getApiPaneDebuggerState, + getPluginActionDebuggerState, ); const toggleHide = useCallback( - () => dispatch(setApiPaneDebuggerState({ open: !open })), + () => dispatch(setPluginActionEditorDebuggerState({ open: !open })), [dispatch, open], ); @@ -32,14 +32,18 @@ function PluginActionResponse() { }); } - dispatch(setApiPaneDebuggerState({ open: true, selectedTab: tabKey })); + dispatch( + setPluginActionEditorDebuggerState({ open: true, selectedTab: tabKey }), + ); }, [dispatch], ); const updateResponsePaneHeight = useCallback( (height: number) => { - dispatch(setApiPaneDebuggerState({ responseTabHeight: height })); + dispatch( + setPluginActionEditorDebuggerState({ responseTabHeight: height }), + ); }, [dispatch], ); diff --git a/app/client/src/PluginActionEditor/constants.ts b/app/client/src/PluginActionEditor/constants.ts new file mode 100644 index 00000000000..cba99efea29 --- /dev/null +++ b/app/client/src/PluginActionEditor/constants.ts @@ -0,0 +1 @@ +export const POST_BODY_FORM_DATA_KEY = "displayFormat"; diff --git a/app/client/src/PluginActionEditor/index.ts b/app/client/src/PluginActionEditor/index.ts index e8083e1b0f0..f0f9b933f1a 100644 --- a/app/client/src/PluginActionEditor/index.ts +++ b/app/client/src/PluginActionEditor/index.ts @@ -11,3 +11,5 @@ export type { PluginActionNameEditorProps, } from "./components/PluginActionNameEditor"; export { default as PluginActionNameEditor } from "./components/PluginActionNameEditor"; + +export type { PluginActionEditorState } from "./store/pluginEditorReducer"; diff --git a/app/client/src/PluginActionEditor/store/index.ts b/app/client/src/PluginActionEditor/store/index.ts new file mode 100644 index 00000000000..e1680cfdbf9 --- /dev/null +++ b/app/client/src/PluginActionEditor/store/index.ts @@ -0,0 +1,4 @@ +export { default as pluginActionReducer } from "./pluginEditorReducer"; + +export * from "./pluginActionEditorActions"; +export * from "./pluginActionEditorSelectors"; diff --git a/app/client/src/PluginActionEditor/store/pluginActionEditorActions.ts b/app/client/src/PluginActionEditor/store/pluginActionEditorActions.ts new file mode 100644 index 00000000000..6b3a9d667f7 --- /dev/null +++ b/app/client/src/PluginActionEditor/store/pluginActionEditorActions.ts @@ -0,0 +1,57 @@ +import type { PluginEditorDebuggerState } from "./pluginEditorReducer"; +import { + type ReduxAction, + ReduxActionTypes, +} from "ee/constants/ReduxActionConstants"; +import type { Action } from "entities/Action"; + +export const setPluginActionEditorDebuggerState = ( + payload: Partial, +) => ({ + type: ReduxActionTypes.SET_PLUGIN_ACTION_EDITOR_DEBUGGER_STATE, + payload, +}); + +export const setPluginActionEditorSelectedTab = (payload: string) => ({ + type: ReduxActionTypes.SET_PLUGIN_ACTION_EDITOR_FORM_SELECTED_TAB, + payload: { + selectedTab: payload, + }, +}); + +export const updatePostBodyContentType = ( + title: string, + apiId: string, +): ReduxAction<{ title: string; apiId: string }> => ({ + type: ReduxActionTypes.UPDATE_API_ACTION_BODY_CONTENT_TYPE, + payload: { title, apiId }, +}); + +export const changeApi = ( + id: string, + isSaas: boolean, + newApi?: boolean, +): ReduxAction<{ id: string; isSaas: boolean; newApi?: boolean }> => { + return { + type: ReduxActionTypes.API_PANE_CHANGE_API, + payload: { id, isSaas, newApi }, + }; +}; + +export interface ChangeQueryPayload { + baseQueryId: string; + packageId?: string; + applicationId?: string; + basePageId?: string; + moduleId?: string; + workflowId?: string; + newQuery?: boolean; + action?: Action; +} + +export const changeQuery = (payload: ChangeQueryPayload) => { + return { + type: ReduxActionTypes.QUERY_PANE_CHANGE, + payload, + }; +}; diff --git a/app/client/src/PluginActionEditor/store/pluginActionEditorSelectors.ts b/app/client/src/PluginActionEditor/store/pluginActionEditorSelectors.ts new file mode 100644 index 00000000000..a4cd810f1c3 --- /dev/null +++ b/app/client/src/PluginActionEditor/store/pluginActionEditorSelectors.ts @@ -0,0 +1,61 @@ +import type { AppState } from "ee/reducers"; +import { createSelector } from "reselect"; + +import { POST_BODY_FORM_DATA_KEY } from "../constants"; + +export const getActionEditorSavingMap = (state: AppState) => + state.ui.pluginActionEditor.isSaving; + +export const isActionSaving = (id: string) => + createSelector([getActionEditorSavingMap], (savingMap) => { + return id in savingMap && savingMap[id]; + }); + +const getActionDirtyState = (state: AppState) => + state.ui.pluginActionEditor.isDirty; + +export const isActionDirty = (id: string) => + createSelector([getActionDirtyState], (actionDirtyMap) => { + return id in actionDirtyMap && actionDirtyMap[id]; + }); + +const getActionRunningState = (state: AppState) => + state.ui.pluginActionEditor.isRunning; + +export const isActionRunning = (id: string) => + createSelector( + [getActionRunningState], + (isRunningMap) => id in isRunningMap && isRunningMap[id], + ); + +const getActionDeletingState = (state: AppState) => + state.ui.pluginActionEditor.isDeleting; + +export const isActionDeleting = (id: string) => + createSelector( + [getActionDeletingState], + (deletingMap) => id in deletingMap && deletingMap[id], + ); + +type GetFormData = ( + state: AppState, + id: string, +) => { label: string; value: string } | undefined; + +export const getPostBodyFormat: GetFormData = (state, id) => { + const formData = state.ui.pluginActionEditor.formData; + + if (id in formData) { + return formData[id][POST_BODY_FORM_DATA_KEY]; + } + + return undefined; +}; +export const getPluginActionConfigSelectedTab = (state: AppState) => + state.ui.pluginActionEditor.selectedConfigTab; + +export const getPluginActionDebuggerState = (state: AppState) => + state.ui.pluginActionEditor.debugger; + +export const isPluginActionCreating = (state: AppState) => + state.ui.pluginActionEditor.isCreating; diff --git a/app/client/src/PluginActionEditor/store/pluginEditorReducer.ts b/app/client/src/PluginActionEditor/store/pluginEditorReducer.ts new file mode 100644 index 00000000000..781ce8d7165 --- /dev/null +++ b/app/client/src/PluginActionEditor/store/pluginEditorReducer.ts @@ -0,0 +1,177 @@ +import { createImmerReducer } from "utils/ReducerUtils"; +import type { ReduxAction } from "ee/constants/ReduxActionConstants"; +import { + ReduxActionTypes, + ReduxActionErrorTypes, +} from "ee/constants/ReduxActionConstants"; +import type { Action } from "entities/Action"; +import { ActionExecutionResizerHeight } from "pages/Editor/APIEditor/constants"; +import { DEBUGGER_TAB_KEYS } from "components/editorComponents/Debugger/constants"; +import type { ActionResponse } from "api/ActionAPI"; +import { omit, set } from "lodash"; +import { objectKeys } from "@appsmith/utils"; +import type { UpdateActionPropertyActionPayload } from "actions/pluginActionActions"; + +export interface PluginEditorDebuggerState { + open: boolean; + responseTabHeight: number; + selectedTab?: string; +} + +export interface PluginActionEditorState { + isCreating: boolean; + isRunning: Record; + isSaving: Record; + isDeleting: Record; + isDirty: Record; + runErrorMessage: Record; + selectedConfigTab?: string; + formData: Record>; + debugger: PluginEditorDebuggerState; +} + +const initialState: PluginActionEditorState = { + isCreating: false, + isRunning: {}, + isSaving: {}, + isDeleting: {}, + isDirty: {}, + runErrorMessage: {}, + formData: {}, + debugger: { + open: false, + responseTabHeight: ActionExecutionResizerHeight, + }, +}; + +export const handlers = { + [ReduxActionTypes.CREATE_ACTION_INIT]: (state: PluginActionEditorState) => { + state.isCreating = true; + }, + [ReduxActionTypes.CREATE_ACTION_SUCCESS]: ( + state: PluginActionEditorState, + ) => { + state.isCreating = false; + }, + [ReduxActionErrorTypes.CREATE_ACTION_ERROR]: ( + state: PluginActionEditorState, + ) => { + state.isCreating = false; + }, + [ReduxActionTypes.UPDATE_ACTION_PROPERTY]: ( + state: PluginActionEditorState, + action: ReduxAction, + ) => { + set(state, ["isDirty", action.payload.id], true); + }, + [ReduxActionTypes.UPDATE_ACTION_INIT]: ( + state: PluginActionEditorState, + action: ReduxAction<{ id: string }>, + ) => { + set(state, ["isSaving", action.payload.id], true); + }, + [ReduxActionTypes.UPDATE_ACTION_SUCCESS]: ( + state: PluginActionEditorState, + action: ReduxAction<{ data: Action }>, + ) => { + set(state, ["isSaving", action.payload.data.id], false); + set(state, ["isDirty", action.payload.data.id], false); + }, + [ReduxActionErrorTypes.UPDATE_ACTION_ERROR]: ( + state: PluginActionEditorState, + action: ReduxAction<{ id: string }>, + ) => { + set(state, ["isSaving", action.payload.id], false); + }, + [ReduxActionTypes.DELETE_ACTION_INIT]: ( + state: PluginActionEditorState, + action: ReduxAction<{ id: string }>, + ) => { + set(state, ["isDeleting", action.payload.id], true); + }, + [ReduxActionTypes.DELETE_ACTION_SUCCESS]: ( + state: PluginActionEditorState, + action: ReduxAction<{ id: string }>, + ) => { + set(state, ["isDeleting", action.payload.id], false); + }, + [ReduxActionErrorTypes.DELETE_ACTION_ERROR]: ( + state: PluginActionEditorState, + action: ReduxAction<{ id: string }>, + ) => { + set(state, ["isDeleting", action.payload.id], false); + }, + [ReduxActionTypes.RUN_ACTION_REQUEST]: ( + state: PluginActionEditorState, + action: ReduxAction<{ id: string }>, + ) => { + set(state, ["isRunning", action.payload.id], true); + set(state, ["debugger", "selectedTab"], DEBUGGER_TAB_KEYS.RESPONSE_TAB); + set(state, ["debugger", "open"], true); + }, + [ReduxActionTypes.RUN_ACTION_CANCELLED]: ( + state: PluginActionEditorState, + action: ReduxAction<{ id: string }>, + ) => { + set(state, ["isRunning", action.payload.id], false); + }, + + [ReduxActionTypes.RUN_ACTION_SUCCESS]: ( + state: PluginActionEditorState, + action: ReduxAction>, + ) => { + const actionId = objectKeys(action.payload)[0]; + + set(state, ["isRunning", actionId], false); + set(state, ["runErrorMessage"], omit(state.runErrorMessage, [actionId])); + }, + [ReduxActionErrorTypes.RUN_ACTION_ERROR]: ( + state: PluginActionEditorState, + action: ReduxAction<{ id: string; error: Error }>, + ) => { + const { error, id } = action.payload; + + set(state, ["isRunning", id], false); + set(state, ["runErrorMessage", id], error.message); + }, + /** + * This redux action sets the extra form data field for an action. This is used to select the + * appropriate body type tab selection in the Rest API plugin based on the content-type. + * This redux action can be extended to other functionalities as well in the future. + */ + [ReduxActionTypes.SET_EXTRA_FORMDATA]: ( + state: PluginActionEditorState, + action: ReduxAction<{ + id: string; + values: Record; + }>, + ) => { + const { id, values } = action.payload; + + set(state, ["formData", id], values); + }, + [ReduxActionTypes.SET_PLUGIN_ACTION_EDITOR_FORM_SELECTED_TAB]: ( + state: PluginActionEditorState, + action: ReduxAction<{ selectedTab: string }>, + ) => { + const { selectedTab } = action.payload; + + state.selectedConfigTab = selectedTab; + }, + [ReduxActionTypes.SET_PLUGIN_ACTION_EDITOR_DEBUGGER_STATE]: ( + state: PluginActionEditorState, + action: ReduxAction>, + ) => { + state.debugger = { + ...state.debugger, + ...action.payload, + }; + }, + [ReduxActionTypes.RESET_EDITOR_REQUEST]: (state: PluginActionEditorState) => { + state.isSaving = {}; + }, +}; + +const pluginActionEditorReducer = createImmerReducer(initialState, handlers); + +export default pluginActionEditorReducer; diff --git a/app/client/src/actions/apiPaneActions.ts b/app/client/src/actions/apiPaneActions.ts deleted file mode 100644 index 30c2ee87751..00000000000 --- a/app/client/src/actions/apiPaneActions.ts +++ /dev/null @@ -1,67 +0,0 @@ -import type { ReduxAction } from "ee/constants/ReduxActionConstants"; -import { ReduxActionTypes } from "ee/constants/ReduxActionConstants"; -import type { EventLocation } from "ee/utils/analyticsUtilTypes"; -import type { SlashCommandPayload } from "entities/Action"; -import type { ApiPaneDebuggerState } from "ee/reducers/uiReducers/apiPaneReducer"; - -export const changeApi = ( - id: string, - isSaas: boolean, - newApi?: boolean, -): ReduxAction<{ id: string; isSaas: boolean; newApi?: boolean }> => { - return { - type: ReduxActionTypes.API_PANE_CHANGE_API, - payload: { id, isSaas, newApi }, - }; -}; - -export const createNewApiAction = ( - pageId: string, - from: EventLocation, - apiType?: string, -): ReduxAction<{ pageId: string; from: EventLocation; apiType?: string }> => ({ - type: ReduxActionTypes.CREATE_NEW_API_ACTION, - payload: { pageId, from, apiType }, -}); - -export const createNewQueryAction = ( - pageId: string, - from: EventLocation, - datasourceId: string, - queryDefaultTableName?: string, -): ReduxAction<{ - pageId: string; - from: EventLocation; - datasourceId: string; - queryDefaultTableName?: string; -}> => ({ - type: ReduxActionTypes.CREATE_NEW_QUERY_ACTION, - payload: { pageId, from, datasourceId, queryDefaultTableName }, -}); - -export const updateBodyContentType = ( - title: string, - apiId: string, -): ReduxAction<{ title: string; apiId: string }> => ({ - type: ReduxActionTypes.UPDATE_API_ACTION_BODY_CONTENT_TYPE, - payload: { title, apiId }, -}); - -export const executeCommandAction = (payload: SlashCommandPayload) => ({ - type: ReduxActionTypes.EXECUTE_COMMAND, - payload: payload, -}); - -export const setApiPaneConfigSelectedTabIndex: ( - payload: number, -) => ReduxAction<{ selectedTabIndex: number }> = (payload: number) => ({ - type: ReduxActionTypes.SET_API_PANE_CONFIG_SELECTED_TAB, - payload: { selectedTabIndex: payload }, -}); - -export const setApiPaneDebuggerState = ( - payload: Partial, -) => ({ - type: ReduxActionTypes.SET_API_PANE_DEBUGGER_STATE, - payload, -}); diff --git a/app/client/src/actions/pluginActionActions.ts b/app/client/src/actions/pluginActionActions.ts index 81a0edf9d06..ca6c9988d52 100644 --- a/app/client/src/actions/pluginActionActions.ts +++ b/app/client/src/actions/pluginActionActions.ts @@ -7,7 +7,11 @@ import { ReduxActionTypes, } from "ee/constants/ReduxActionConstants"; import type { JSUpdate } from "utils/JSPaneUtils"; -import type { Action, ActionViewMode } from "entities/Action"; +import type { + Action, + ActionViewMode, + SlashCommandPayload, +} from "entities/Action"; import { ActionExecutionContext } from "entities/Action"; import { batchAction } from "actions/batchActions"; import type { ExecuteErrorPayload } from "constants/AppsmithActionConstants/ActionConstants"; @@ -16,6 +20,7 @@ import type { OtlpSpan } from "UITelemetry/generateTraces"; import type { ApiResponse } from "api/ApiResponses"; import type { JSCollection } from "entities/JSCollection"; import type { ErrorActionPayload } from "sagas/ErrorSagas"; +import type { EventLocation } from "ee/utils/analyticsUtilTypes"; export const createActionRequest = (payload: Partial) => { return { @@ -428,13 +433,31 @@ export const closeQueryActionTabSuccess = (payload: { }; }; -export default { - createAction: createActionRequest, - fetchActions, - runAction: runAction, - deleteAction, - deleteActionSuccess, - updateAction, - updateActionSuccess, - bindDataOnCanvas, -}; +export const createNewApiAction = ( + pageId: string, + from: EventLocation, + apiType?: string, +): ReduxAction<{ pageId: string; from: EventLocation; apiType?: string }> => ({ + type: ReduxActionTypes.CREATE_NEW_API_ACTION, + payload: { pageId, from, apiType }, +}); + +export const createNewQueryAction = ( + pageId: string, + from: EventLocation, + datasourceId: string, + queryDefaultTableName?: string, +): ReduxAction<{ + pageId: string; + from: EventLocation; + datasourceId: string; + queryDefaultTableName?: string; +}> => ({ + type: ReduxActionTypes.CREATE_NEW_QUERY_ACTION, + payload: { pageId, from, datasourceId, queryDefaultTableName }, +}); + +export const executeCommandAction = (payload: SlashCommandPayload) => ({ + type: ReduxActionTypes.EXECUTE_COMMAND, + payload: payload, +}); diff --git a/app/client/src/actions/queryPaneActions.ts b/app/client/src/actions/queryPaneActions.ts deleted file mode 100644 index 67a2b88f1c0..00000000000 --- a/app/client/src/actions/queryPaneActions.ts +++ /dev/null @@ -1,38 +0,0 @@ -import type { ReduxAction } from "ee/constants/ReduxActionConstants"; -import { ReduxActionTypes } from "ee/constants/ReduxActionConstants"; -import type { Action } from "entities/Action"; -import type { QueryPaneDebuggerState } from "ee/reducers/uiReducers/queryPaneReducer"; - -export interface ChangeQueryPayload { - baseQueryId: string; - packageId?: string; - applicationId?: string; - basePageId?: string; - moduleId?: string; - workflowId?: string; - newQuery?: boolean; - action?: Action; -} - -export const changeQuery = (payload: ChangeQueryPayload) => { - return { - type: ReduxActionTypes.QUERY_PANE_CHANGE, - payload, - }; -}; - -export const setQueryPaneConfigSelectedTabIndex: ( - payload: string, -) => ReduxAction<{ selectedTabIndex: string }> = (payload: string) => ({ - type: ReduxActionTypes.SET_QUERY_PANE_CONFIG_SELECTED_TAB, - payload: { selectedTabIndex: payload }, -}); - -export const setQueryPaneDebuggerState = ( - payload: Partial, -) => { - return { - type: ReduxActionTypes.SET_QUERY_PANE_DEBUGGER_STATE, - payload, - }; -}; diff --git a/app/client/src/ce/PluginActionEditor/components/PluginActionResponse/hooks/usePluginActionResponseTabs.tsx b/app/client/src/ce/PluginActionEditor/components/PluginActionResponse/hooks/usePluginActionResponseTabs.tsx index 54e4fdf45e1..b303bd34a05 100644 --- a/app/client/src/ce/PluginActionEditor/components/PluginActionResponse/hooks/usePluginActionResponseTabs.tsx +++ b/app/client/src/ce/PluginActionEditor/components/PluginActionResponse/hooks/usePluginActionResponseTabs.tsx @@ -4,7 +4,7 @@ import type { BottomTab } from "components/editorComponents/EntityBottomTabs"; import { getIDEViewMode } from "selectors/ideSelectors"; import { useSelector } from "react-redux"; import { EditorViewMode } from "ee/entities/IDE/constants"; -import { DEBUGGER_TAB_KEYS } from "components/editorComponents/Debugger/helpers"; +import { DEBUGGER_TAB_KEYS } from "components/editorComponents/Debugger/constants"; import { createMessage, DEBUGGER_ERRORS, @@ -20,7 +20,7 @@ import { ApiResponseHeaders } from "PluginActionEditor/components/PluginActionRe import { noop } from "lodash"; import { EditorTheme } from "components/editorComponents/CodeEditor/EditorConfig"; import { getErrorCount } from "selectors/debuggerSelectors"; -import { getApiPaneDebuggerState } from "selectors/apiPaneSelectors"; +import { getPluginActionDebuggerState } from "PluginActionEditor/store"; import { doesPluginRequireDatasource } from "ee/entities/Engine/actionHelpers"; import useShowSchema from "components/editorComponents/ActionRightPane/useShowSchema"; import Schema from "components/editorComponents/Debugger/Schema"; @@ -38,7 +38,7 @@ function usePluginActionResponseTabs() { const showSchema = useShowSchema(plugin.id) && pluginRequireDatasource; - const { responseTabHeight } = useSelector(getApiPaneDebuggerState); + const { responseTabHeight } = useSelector(getPluginActionDebuggerState); const tabs: BottomTab[] = []; @@ -110,7 +110,7 @@ function usePluginActionResponseTabs() { if (showSchema) { newTabs.push({ - key: "schema", + key: DEBUGGER_TAB_KEYS.SCHEMA_TAB, title: "Schema", panelComponent: ( ; - isSaving: Record; // RN - isDeleting: Record; - isDirty: Record; - // TODO: Fix this the next time the file is edited - // eslint-disable-next-line @typescript-eslint/no-explicit-any - extraformData: Record; - selectedConfigTabIndex: number; - debugger: ApiPaneDebuggerState; -} - -export const handlers = { - [ReduxActionTypes.FETCH_ACTIONS_INIT]: (state: ApiPaneReduxState) => ({ - ...state, - isFetching: true, - }), - [ReduxActionTypes.FETCH_ACTIONS_SUCCESS]: (state: ApiPaneReduxState) => ({ - ...state, - isFetching: false, - }), - [ReduxActionErrorTypes.FETCH_ACTIONS_ERROR]: (state: ApiPaneReduxState) => ({ - ...state, - isFetching: false, - }), - [ReduxActionTypes.CREATE_ACTION_INIT]: ( - state: ApiPaneReduxState, - ): ApiPaneReduxState => ({ - ...state, - isCreating: true, - }), - [ReduxActionTypes.CREATE_ACTION_SUCCESS]: ( - state: ApiPaneReduxState, - ): ApiPaneReduxState => ({ - ...state, - isCreating: false, - }), - [ReduxActionErrorTypes.CREATE_ACTION_ERROR]: ( - state: ApiPaneReduxState, - ): ApiPaneReduxState => ({ - ...state, - isCreating: false, - }), - [ReduxActionTypes.RUN_ACTION_REQUEST]: ( - state: ApiPaneReduxState, - action: ReduxAction<{ id: string }>, - ) => ({ - ...state, - isRunning: { - ...state.isRunning, - [action.payload.id]: true, - }, - debugger: { - ...state.debugger, - open: true, - }, - }), - [ReduxActionTypes.RUN_ACTION_SUCCESS]: ( - state: ApiPaneReduxState, - // TODO: Fix this the next time the file is edited - // eslint-disable-next-line @typescript-eslint/no-explicit-any - action: ReduxAction<{ [id: string]: any }>, - ) => { - const actionId = Object.keys(action.payload)[0]; - - return { - ...state, - isRunning: { - ...state.isRunning, - [actionId]: false, - }, - }; - }, - [ReduxActionErrorTypes.RUN_ACTION_ERROR]: ( - state: ApiPaneReduxState, - action: ReduxAction<{ id: string }>, - ) => ({ - ...state, - isRunning: { - ...state.isRunning, - [action.payload.id]: false, - }, - }), - [ReduxActionTypes.RUN_ACTION_CANCELLED]: ( - state: ApiPaneReduxState, - action: ReduxAction<{ id: string }>, - ): ApiPaneReduxState => ({ - ...state, - isRunning: { - ...state.isRunning, - [action.payload.id]: false, - }, - }), - [ReduxActionTypes.UPDATE_ACTION_PROPERTY]: ( - state: ApiPaneReduxState, - action: ReduxAction, - ) => ({ - ...state, - isDirty: { - ...state.isDirty, - [action.payload.id]: true, - }, - }), - [ReduxActionTypes.UPDATE_ACTION_INIT]: ( - state: ApiPaneReduxState, - action: ReduxAction<{ id: string }>, - ) => ({ - ...state, - isSaving: { - ...state.isSaving, - [action.payload.id]: true, - }, - }), - [ReduxActionTypes.UPDATE_ACTION_SUCCESS]: ( - state: ApiPaneReduxState, - action: ReduxAction<{ data: Action }>, - ) => ({ - ...state, - isSaving: { - ...state.isSaving, - [action.payload.data.id]: false, - }, - isDirty: { - ...state.isDirty, - [action.payload.data.id]: false, - }, - }), - [ReduxActionErrorTypes.UPDATE_ACTION_ERROR]: ( - state: ApiPaneReduxState, - action: ReduxAction<{ id: string }>, - ) => ({ - ...state, - isSaving: { - ...state.isSaving, - [action.payload.id]: false, - }, - }), - [ReduxActionTypes.DELETE_ACTION_INIT]: ( - state: ApiPaneReduxState, - action: ReduxAction<{ id: string }>, - ) => ({ - ...state, - isDeleting: { - ...state.isDeleting, - [action.payload.id]: true, - }, - }), - [ReduxActionTypes.DELETE_ACTION_SUCCESS]: ( - state: ApiPaneReduxState, - action: ReduxAction<{ id: string }>, - ) => ({ - ...state, - isDeleting: { - ...state.isDeleting, - [action.payload.id]: false, - }, - }), - [ReduxActionErrorTypes.DELETE_ACTION_ERROR]: ( - state: ApiPaneReduxState, - action: ReduxAction<{ id: string }>, - ) => ({ - ...state, - isDeleting: { - ...state.isDeleting, - [action.payload.id]: false, - }, - }), - - /** - * This redux action sets the extraformData field for an action. This is used to select the - * appropriate body type tab selection in the Rest API plugin based on the content-type. - * This redux action can be extended to other functionalities as well in the future. - * - * @param {ApiPaneReduxState} state - * @param {ReduxAction} action - * @returns {ApiPaneReduxState} - */ - [ReduxActionTypes.SET_EXTRA_FORMDATA]: ( - state: ApiPaneReduxState, - action: ReduxAction<{ id: string; values: Record }>, - ): ApiPaneReduxState => { - const { id, values } = action.payload; - - return { - ...state, - extraformData: { - ...state.extraformData, - [id]: values, - }, - }; - }, - [ReduxActionTypes.SET_API_PANE_CONFIG_SELECTED_TAB]: ( - state: ApiPaneReduxState, - action: ReduxAction<{ selectedTabIndex: number }>, - ) => { - const { selectedTabIndex } = action.payload; - - return { - ...state, - selectedConfigTabIndex: selectedTabIndex, - }; - }, - [ReduxActionTypes.SET_API_PANE_DEBUGGER_STATE]: ( - state: ApiPaneReduxState, - action: ReduxAction>, - ) => { - return { - ...state, - debugger: { - ...state.debugger, - ...action.payload, - }, - }; - }, - [ReduxActionTypes.RESET_EDITOR_REQUEST]: (state: ApiPaneReduxState) => { - return { - ...state, - isSaving: {}, - }; - }, -}; - -const apiPaneReducer = createReducer(initialState, handlers); - -export default apiPaneReducer; diff --git a/app/client/src/ce/reducers/uiReducers/index.tsx b/app/client/src/ce/reducers/uiReducers/index.tsx index 0a746521b70..35c9294b396 100644 --- a/app/client/src/ce/reducers/uiReducers/index.tsx +++ b/app/client/src/ce/reducers/uiReducers/index.tsx @@ -3,7 +3,6 @@ import errorReducer from "reducers/uiReducers/errorReducer"; import propertyPaneReducer from "reducers/uiReducers/propertyPaneReducer"; import appViewReducer from "reducers/uiReducers/appViewReducer"; import applicationsReducer from "ee/reducers/uiReducers/applicationsReducer"; -import apiPaneReducer from "ee/reducers/uiReducers/apiPaneReducer"; import datasourcePaneReducer from "reducers/uiReducers/datasourcePaneReducer"; import authReducer from "reducers/uiReducers/authReducer"; import workspaceReducer from "ee/reducers/uiReducers/workspaceReducer"; @@ -12,7 +11,6 @@ import buildingBlockReducer from "reducers/uiReducers/buildingBlockReducer"; import usersReducer from "reducers/uiReducers/usersReducer"; import { widgetDraggingReducer } from "reducers/uiReducers/dragResizeReducer"; import importReducer from "reducers/uiReducers/importReducer"; -import queryPaneReducer from "ee/reducers/uiReducers/queryPaneReducer"; import helpReducer from "reducers/uiReducers/helpReducer"; import apiNameReducer from "ee/reducers/uiReducers/apiNameReducer"; import explorerReducer from "ee/reducers/uiReducers/explorerReducer"; @@ -48,8 +46,9 @@ import layoutConversionReducer from "reducers/uiReducers/layoutConversionReducer import oneClickBindingReducer from "reducers/uiReducers/oneClickBindingReducer"; import activeFieldReducer from "reducers/uiReducers/activeFieldEditorReducer"; import selectedWorkspaceReducer from "ee/reducers/uiReducers/selectedWorkspaceReducer"; -import ideReducer from "../../../reducers/uiReducers/ideReducer"; +import ideReducer from "reducers/uiReducers/ideReducer"; import consolidatedPageLoadReducer from "reducers/uiReducers/consolidatedPageLoadReducer"; +import { pluginActionReducer } from "PluginActionEditor/store"; export const uiReducerObject = { analytics: analyticsReducer, @@ -59,7 +58,6 @@ export const uiReducerObject = { tableFilterPane: tableFilterPaneReducer, appView: appViewReducer, applications: applicationsReducer, - apiPane: apiPaneReducer, auth: authReducer, templates: templateReducer, buildingBlocks: buildingBlockReducer, @@ -68,7 +66,6 @@ export const uiReducerObject = { users: usersReducer, widgetDragResize: widgetDraggingReducer, imports: importReducer, - queryPane: queryPaneReducer, datasourcePane: datasourcePaneReducer, datasourceName: datasourceNameReducer, help: helpReducer, @@ -104,4 +101,5 @@ export const uiReducerObject = { activeField: activeFieldReducer, ide: ideReducer, consolidatedPageLoad: consolidatedPageLoadReducer, + pluginActionEditor: pluginActionReducer, }; diff --git a/app/client/src/ce/reducers/uiReducers/queryPaneReducer.ts b/app/client/src/ce/reducers/uiReducers/queryPaneReducer.ts deleted file mode 100644 index 83b6d37aab2..00000000000 --- a/app/client/src/ce/reducers/uiReducers/queryPaneReducer.ts +++ /dev/null @@ -1,231 +0,0 @@ -import { createReducer } from "utils/ReducerUtils"; -import type { ReduxAction } from "ee/constants/ReduxActionConstants"; -import { - ReduxActionTypes, - ReduxActionErrorTypes, -} from "ee/constants/ReduxActionConstants"; -import { omit } from "lodash"; -import type { Action } from "entities/Action"; -import type { ActionResponse } from "api/ActionAPI"; -import { ActionExecutionResizerHeight } from "pages/Editor/APIEditor/constants"; -import { DEBUGGER_TAB_KEYS } from "../../../components/editorComponents/Debugger/helpers"; - -export const initialState: QueryPaneReduxState = { - isRunning: {}, - isSaving: {}, - isDeleting: {}, - runErrorMessage: {}, - debugger: { - open: false, - responseTabHeight: ActionExecutionResizerHeight, - }, - selectedConfigTabIndex: "0", -}; - -export interface QueryPaneDebuggerState { - open: boolean; - responseTabHeight: number; - selectedTab?: string; -} - -export interface QueryPaneReduxState { - isRunning: Record; - isSaving: Record; // RR - isDeleting: Record; - runErrorMessage: Record; - selectedConfigTabIndex: string; - debugger: QueryPaneDebuggerState; -} - -export const handlers = { - [ReduxActionTypes.CREATE_ACTION_INIT]: (state: QueryPaneReduxState) => { - return { - ...state, - isCreating: true, - }; - }, - [ReduxActionTypes.CREATE_ACTION_SUCCESS]: (state: QueryPaneReduxState) => { - return { - ...state, - isCreating: false, - }; - }, - [ReduxActionErrorTypes.CREATE_ACTION_ERROR]: (state: QueryPaneReduxState) => { - return { - ...state, - isCreating: false, - }; - }, - [ReduxActionTypes.QUERY_PANE_CHANGE]: ( - state: QueryPaneReduxState, - action: ReduxAction<{ id: string }>, - ) => ({ - ...state, - lastUsed: action.payload.id, - }), - [ReduxActionTypes.UPDATE_ACTION_INIT]: ( - state: QueryPaneReduxState, - action: ReduxAction<{ id: string }>, - ) => ({ - ...state, - isSaving: { - ...state.isSaving, - [action.payload.id]: true, - }, - }), - [ReduxActionTypes.UPDATE_ACTION_SUCCESS]: ( - state: QueryPaneReduxState, - action: ReduxAction<{ data: Action }>, - ) => ({ - ...state, - isSaving: { - ...state.isSaving, - [action.payload.data.id]: false, - }, - }), - [ReduxActionErrorTypes.UPDATE_ACTION_ERROR]: ( - state: QueryPaneReduxState, - action: ReduxAction<{ id: string }>, - ) => ({ - ...state, - isSaving: { - ...state.isSaving, - [action.payload.id]: false, - }, - }), - [ReduxActionTypes.DELETE_ACTION_INIT]: ( - state: QueryPaneReduxState, - action: ReduxAction<{ id: string }>, - ) => ({ - ...state, - isDeleting: { - ...state.isDeleting, - [action.payload.id]: true, - }, - }), - [ReduxActionTypes.DELETE_ACTION_SUCCESS]: ( - state: QueryPaneReduxState, - action: ReduxAction<{ id: string }>, - ) => ({ - ...state, - isDeleting: { - ...state.isDeleting, - [action.payload.id]: false, - }, - }), - [ReduxActionErrorTypes.DELETE_ACTION_ERROR]: ( - state: QueryPaneReduxState, - action: ReduxAction<{ id: string }>, - ) => ({ - ...state, - isDeleting: { - ...state.isDeleting, - [action.payload.id]: false, - }, - }), - [ReduxActionTypes.RUN_ACTION_REQUEST]: ( - // TODO: Fix this the next time the file is edited - // eslint-disable-next-line @typescript-eslint/no-explicit-any - state: any, - action: ReduxAction<{ id: string }>, - ): QueryPaneReduxState => { - return { - ...state, - isRunning: { - ...state.isRunning, - [action.payload.id]: true, - }, - debugger: { - ...state.debugger, - selectedTab: DEBUGGER_TAB_KEYS.RESPONSE_TAB, - open: true, - }, - }; - }, - - [ReduxActionTypes.RUN_ACTION_CANCELLED]: ( - // TODO: Fix this the next time the file is edited - // eslint-disable-next-line @typescript-eslint/no-explicit-any - state: any, - action: ReduxAction<{ id: string }>, - ) => { - return { - ...state, - isRunning: { - ...state.isRunning, - [action.payload.id]: false, - }, - }; - }, - - [ReduxActionTypes.RUN_ACTION_SUCCESS]: ( - // TODO: Fix this the next time the file is edited - // eslint-disable-next-line @typescript-eslint/no-explicit-any - state: any, - action: ReduxAction<{ [id: string]: ActionResponse }>, - ) => { - const actionId = Object.keys(action.payload)[0]; - - return { - ...state, - isRunning: { - ...state.isRunning, - [actionId]: false, - }, - runErrorMessage: omit(state.runErrorMessage, [actionId]), - }; - }, - [ReduxActionErrorTypes.RUN_ACTION_ERROR]: ( - // TODO: Fix this the next time the file is edited - // eslint-disable-next-line @typescript-eslint/no-explicit-any - state: any, - action: ReduxAction<{ id: string; error: Error }>, - ) => { - const { error, id } = action.payload; - - return { - ...state, - isRunning: { - ...state.isRunning, - [id]: false, - }, - runErrorMessage: { - ...state.runError, - [id]: error.message, - }, - }; - }, - [ReduxActionTypes.SET_QUERY_PANE_CONFIG_SELECTED_TAB]: ( - state: QueryPaneReduxState, - action: ReduxAction<{ selectedTabIndex: number }>, - ) => { - const { selectedTabIndex } = action.payload; - - return { - ...state, - selectedConfigTabIndex: selectedTabIndex, - }; - }, - [ReduxActionTypes.SET_QUERY_PANE_DEBUGGER_STATE]: ( - state: QueryPaneReduxState, - action: ReduxAction>, - ) => { - return { - ...state, - debugger: { - ...state.debugger, - ...action.payload, - }, - }; - }, - [ReduxActionTypes.RESET_EDITOR_REQUEST]: (state: QueryPaneReduxState) => { - return { - ...state, - isSaving: {}, - }; - }, -}; - -const queryPaneReducer = createReducer(initialState, handlers); - -export default queryPaneReducer; diff --git a/app/client/src/ce/selectors/appIDESelectors.ts b/app/client/src/ce/selectors/appIDESelectors.ts index d7df0c96b1e..3d17b4894ef 100644 --- a/app/client/src/ce/selectors/appIDESelectors.ts +++ b/app/client/src/ce/selectors/appIDESelectors.ts @@ -7,6 +7,9 @@ import { } from "ee/selectors/entitiesSelector"; import { getJSTabs, getQueryTabs } from "selectors/ideSelectors"; import type { AppState } from "ee/reducers"; +import { identifyEntityFromPath } from "navigation/FocusEntity"; +import { getCurrentPageId } from "selectors/editorSelectors"; +import { getQueryEntityItemUrl } from "ee/pages/Editor/IDE/EditorPane/Query/utils"; export type EditorSegmentList = Array<{ group: string | "NA"; @@ -68,3 +71,16 @@ export const selectQuerySegmentEditorTabs = (state: AppState) => { return tabs.map((tab) => keyedItems[tab]).filter(Boolean); }; + +export const getLastQueryTab = createSelector( + selectQuerySegmentEditorTabs, + getCurrentPageId, + (tabs, pageId) => { + if (tabs.length) { + const url = getQueryEntityItemUrl(tabs[tabs.length - 1], pageId); + const urlWithoutQueryParams = url.split("?")[0]; + + return identifyEntityFromPath(urlWithoutQueryParams); + } + }, +); diff --git a/app/client/src/ce/selectors/entitiesSelector.ts b/app/client/src/ce/selectors/entitiesSelector.ts index afe96173b64..4f50d471cb0 100644 --- a/app/client/src/ce/selectors/entitiesSelector.ts +++ b/app/client/src/ce/selectors/entitiesSelector.ts @@ -869,28 +869,6 @@ export function getPageNameByPageId(state: AppState, pageId: string): string { return page ? page.pageName : ""; } -const getQueryPaneSavingMap = (state: AppState) => state.ui.queryPane.isSaving; - -export const getApiPaneSavingMap = (state: AppState) => - state.ui.apiPane.isSaving; -const getActionDirtyState = (state: AppState) => state.ui.apiPane.isDirty; - -export const isActionSaving = (id: string) => - createSelector( - [getQueryPaneSavingMap, getApiPaneSavingMap], - (querySavingMap, apiSavingsMap) => { - return ( - (id in querySavingMap && querySavingMap[id]) || - (id in apiSavingsMap && apiSavingsMap[id]) - ); - }, - ); - -export const isActionDirty = (id: string) => - createSelector([getActionDirtyState], (actionDirtyMap) => { - return id in actionDirtyMap && actionDirtyMap[id]; - }); - export const getAppData = (state: AppState) => state.entities.app; export const getAppStoreData = (state: AppState): AppStoreState => diff --git a/app/client/src/components/editorComponents/ApiResponseView.test.tsx b/app/client/src/components/editorComponents/ApiResponseView.test.tsx index cd747429b4f..b440e9a409c 100644 --- a/app/client/src/components/editorComponents/ApiResponseView.test.tsx +++ b/app/client/src/components/editorComponents/ApiResponseView.test.tsx @@ -50,7 +50,7 @@ const storeState = { errorCount: 0, }, }, - apiPane: { + pluginActionEditor: { debugger: { open: true, responseTabHeight: 200, diff --git a/app/client/src/components/editorComponents/ApiResponseView.tsx b/app/client/src/components/editorComponents/ApiResponseView.tsx index 623973d2373..e459b509c03 100644 --- a/app/client/src/components/editorComponents/ApiResponseView.tsx +++ b/app/client/src/components/editorComponents/ApiResponseView.tsx @@ -14,13 +14,15 @@ import ErrorLogs from "./Debugger/Errors"; import AnalyticsUtil from "ee/utils/AnalyticsUtil"; import type { BottomTab } from "./EntityBottomTabs"; import EntityBottomTabs from "./EntityBottomTabs"; -import { DEBUGGER_TAB_KEYS } from "./Debugger/helpers"; +import { DEBUGGER_TAB_KEYS } from "./Debugger/constants"; import { getErrorCount } from "selectors/debuggerSelectors"; import { ActionExecutionResizerHeight } from "pages/Editor/APIEditor/constants"; import type { Action } from "entities/Action"; import { EMPTY_RESPONSE } from "./emptyResponse"; -import { setApiPaneDebuggerState } from "actions/apiPaneActions"; -import { getApiPaneDebuggerState } from "selectors/apiPaneSelectors"; +import { + getPluginActionDebuggerState, + setPluginActionEditorDebuggerState, +} from "PluginActionEditor/store"; import { getIDEViewMode } from "selectors/ideSelectors"; import { EditorViewMode } from "ee/entities/IDE/constants"; import useDebuggerTriggerClick from "./Debugger/hooks/useDebuggerTriggerClick"; @@ -49,7 +51,7 @@ function ApiResponseView(props: Props) { const dispatch = useDispatch(); const errorCount = useSelector(getErrorCount); const { open, responseTabHeight, selectedTab } = useSelector( - getApiPaneDebuggerState, + getPluginActionDebuggerState, ); const ideViewMode = useSelector(getIDEViewMode); @@ -72,7 +74,9 @@ function ApiResponseView(props: Props) { }); } - dispatch(setApiPaneDebuggerState({ open: true, selectedTab: tabKey })); + dispatch( + setPluginActionEditorDebuggerState({ open: true, selectedTab: tabKey }), + ); }, [dispatch], ); @@ -80,7 +84,9 @@ function ApiResponseView(props: Props) { // update the height of the response pane on resize. const updateResponsePaneHeight = useCallback( (height: number) => { - dispatch(setApiPaneDebuggerState({ responseTabHeight: height })); + dispatch( + setPluginActionEditorDebuggerState({ responseTabHeight: height }), + ); }, [dispatch], ); @@ -135,7 +141,7 @@ function ApiResponseView(props: Props) { // close the debugger //TODO: move this to a common place const toggleHide = useCallback( - () => dispatch(setApiPaneDebuggerState({ open: !open })), + () => dispatch(setPluginActionEditorDebuggerState({ open: !open })), [dispatch, open], ); diff --git a/app/client/src/components/editorComponents/CodeEditor/EvaluatedValuePopup.tsx b/app/client/src/components/editorComponents/CodeEditor/EvaluatedValuePopup.tsx index 8e19d836f53..1f691141b9b 100644 --- a/app/client/src/components/editorComponents/CodeEditor/EvaluatedValuePopup.tsx +++ b/app/client/src/components/editorComponents/CodeEditor/EvaluatedValuePopup.tsx @@ -29,7 +29,7 @@ import { getEntityNameAndPropertyPath } from "ee/workers/Evaluation/evaluationUt import { getPathNavigationUrl } from "selectors/navigationSelectors"; import { Button, Icon, Link, toast, Tooltip } from "@appsmith/ads"; import type { EvaluationError } from "utils/DynamicBindingUtils"; -import { DEBUGGER_TAB_KEYS } from "../Debugger/helpers"; +import { DEBUGGER_TAB_KEYS } from "../Debugger/constants"; const modifiers: IPopoverSharedProps["modifiers"] = { offset: { @@ -92,6 +92,7 @@ const CurrentValueWrapper = styled.div<{ colorTheme: EditorTheme }>` display: flex; align-items: center; justify-content: space-between; + &:hover { .copyIconWrapper { display: flex; @@ -99,6 +100,7 @@ const CurrentValueWrapper = styled.div<{ colorTheme: EditorTheme }>` } /* for audit logs */ + .pushed-content .object-key-val, .variable-row { border-left: 1px solid var(--ads-v2-color-border) !important; @@ -173,6 +175,7 @@ const StyledIcon = styled(Icon)` &.open-collapse { transform: rotate(90deg); } + float: right; `; @@ -281,6 +284,7 @@ interface PreparedStatementValue { value: string; parameters: Record; } + export function PreparedStatementViewer(props: { evaluatedValue: PreparedStatementValue; }) { diff --git a/app/client/src/components/editorComponents/CodeEditor/index.tsx b/app/client/src/components/editorComponents/CodeEditor/index.tsx index fb825654305..2e67b7514e5 100644 --- a/app/client/src/components/editorComponents/CodeEditor/index.tsx +++ b/app/client/src/components/editorComponents/CodeEditor/index.tsx @@ -95,7 +95,6 @@ import { getRecentEntityIds } from "selectors/globalSearchSelectors"; import type { AutocompleteDataType } from "utils/autocomplete/AutocompleteDataType"; import type { Placement } from "@blueprintjs/popover2"; import { getLintAnnotations, getLintTooltipDirection } from "./lintHelpers"; -import { executeCommandAction } from "actions/apiPaneActions"; import { startingEntityUpdate } from "actions/editorActions"; import type { SlashCommandPayload } from "entities/Action"; import type { Indices } from "constants/Layers"; @@ -163,6 +162,7 @@ import { import CodeMirrorTernService from "utils/autocomplete/CodemirrorTernService"; import { getEachEntityInformation } from "ee/utils/autocomplete/EntityDefinitions"; import { getCurrentPageId } from "selectors/editorSelectors"; +import { executeCommandAction } from "actions/pluginActionActions"; type ReduxStateProps = ReturnType; type ReduxDispatchProps = ReturnType; diff --git a/app/client/src/components/editorComponents/Debugger/DebugCTA.tsx b/app/client/src/components/editorComponents/Debugger/DebugCTA.tsx index 9aafa87a247..a6c6e4a23ab 100644 --- a/app/client/src/components/editorComponents/Debugger/DebugCTA.tsx +++ b/app/client/src/components/editorComponents/Debugger/DebugCTA.tsx @@ -7,7 +7,7 @@ import AnalyticsUtil from "ee/utils/AnalyticsUtil"; import { getTypographyByKey } from "@appsmith/ads-old"; import type { Message } from "entities/AppsmithConsole"; import ContextualMenu from "./ContextualMenu"; -import { DEBUGGER_TAB_KEYS } from "./helpers"; +import { DEBUGGER_TAB_KEYS } from "./constants"; import type { FieldEntityInformation } from "../CodeEditor/EditorConfig"; import { Button } from "@appsmith/ads"; diff --git a/app/client/src/components/editorComponents/Debugger/DebuggerTabs.tsx b/app/client/src/components/editorComponents/Debugger/DebuggerTabs.tsx index 325b6e29d2d..b4a71622d2c 100644 --- a/app/client/src/components/editorComponents/Debugger/DebuggerTabs.tsx +++ b/app/client/src/components/editorComponents/Debugger/DebuggerTabs.tsx @@ -20,7 +20,7 @@ import { DEBUGGER_LOGS, INSPECT_ENTITY, } from "ee/constants/messages"; -import { DEBUGGER_TAB_KEYS } from "./helpers"; +import { DEBUGGER_TAB_KEYS } from "./constants"; import EntityBottomTabs from "../EntityBottomTabs"; import { ActionExecutionResizerHeight } from "pages/Editor/APIEditor/constants"; import { IDEBottomView, ViewHideBehaviour, ViewDisplayMode } from "IDE"; diff --git a/app/client/src/components/editorComponents/Debugger/Schema.tsx b/app/client/src/components/editorComponents/Debugger/Schema.tsx index 46e5b3cc366..ffd16c40e30 100644 --- a/app/client/src/components/editorComponents/Debugger/Schema.tsx +++ b/app/client/src/components/editorComponents/Debugger/Schema.tsx @@ -12,7 +12,7 @@ import DatasourceField from "pages/Editor/DatasourceInfo/DatasourceField"; import { find } from "lodash"; import type { AppState } from "ee/reducers"; import RenderInterimDataState from "pages/Editor/DatasourceInfo/RenderInterimDataState"; -import { getQueryPaneDebuggerState } from "selectors/queryPaneSelectors"; +import { getPluginActionDebuggerState } from "PluginActionEditor/store"; interface Props { datasourceId: string; @@ -24,7 +24,7 @@ const Schema = (props: Props) => { const datasourceStructure = useSelector((state) => getDatasourceStructureById(state, props.datasourceId), ); - const { responseTabHeight } = useSelector(getQueryPaneDebuggerState); + const { responseTabHeight } = useSelector(getPluginActionDebuggerState); const [selectedTable, setSelectedTable] = useState(); const selectedTableItems = find(datasourceStructure?.tables, [ @@ -53,7 +53,7 @@ const Schema = (props: Props) => { if (!selectedTable && datasourceStructure?.tables?.length && !isLoading) { setSelectedTable(datasourceStructure.tables[0].name); } - }, [selectedTable, props.datasourceId, isLoading]); + }, [selectedTable, props.datasourceId, isLoading, datasourceStructure]); if (!datasourceStructure) { return ( diff --git a/app/client/src/components/editorComponents/Debugger/constants.ts b/app/client/src/components/editorComponents/Debugger/constants.ts new file mode 100644 index 00000000000..c69ccdb217e --- /dev/null +++ b/app/client/src/components/editorComponents/Debugger/constants.ts @@ -0,0 +1,8 @@ +export enum DEBUGGER_TAB_KEYS { + SCHEMA_TAB = "SCHEMA_TAB", + RESPONSE_TAB = "RESPONSE_TAB", + HEADER_TAB = "HEADERS_TAB", + ERROR_TAB = "ERROR_TAB", + LOGS_TAB = "LOGS_TAB", + INSPECT_TAB = "INSPECT_TAB", +} diff --git a/app/client/src/components/editorComponents/Debugger/helpers.tsx b/app/client/src/components/editorComponents/Debugger/helpers.tsx index 287a30a901b..3dcc6bfb984 100644 --- a/app/client/src/components/editorComponents/Debugger/helpers.tsx +++ b/app/client/src/components/editorComponents/Debugger/helpers.tsx @@ -7,8 +7,8 @@ import { createMessage, OPEN_THE_DEBUGGER, PRESS } from "ee/constants/messages"; import type { DependencyMap } from "utils/DynamicBindingUtils"; import { isChildPropertyPath } from "utils/DynamicBindingUtils"; import { - matchBuilderPath, matchApiPath, + matchBuilderPath, matchQueryPath, } from "constants/routes"; import { getEntityNameAndPropertyPath } from "ee/workers/Evaluation/evaluationUtils"; @@ -22,8 +22,8 @@ const BlankStateWrapper = styled.div` justify-content: center; align-items: center; color: var(--ads-v2-color-fg); - ${getTypographyByKey("p1")} + ${getTypographyByKey("p1")} .debugger-shortcut { color: var(--ads-v2-color-fg); ${getTypographyByKey("h5")} @@ -51,15 +51,6 @@ export function BlankState(props: { ); } -export enum DEBUGGER_TAB_KEYS { - SCHEMA_TAB = "schema", - RESPONSE_TAB = "response", - HEADER_TAB = "headers", - ERROR_TAB = "ERROR", - LOGS_TAB = "LOGS_TAB", - INSPECT_TAB = "INSPECT_TAB", -} - export const SeverityIcon: Record = { [Severity.INFO]: "success", [Severity.ERROR]: "close-circle", diff --git a/app/client/src/components/editorComponents/Debugger/hooks/useDebuggerTriggerClick.ts b/app/client/src/components/editorComponents/Debugger/hooks/useDebuggerTriggerClick.ts index f6ae639baf9..11e38440fc0 100644 --- a/app/client/src/components/editorComponents/Debugger/hooks/useDebuggerTriggerClick.ts +++ b/app/client/src/components/editorComponents/Debugger/hooks/useDebuggerTriggerClick.ts @@ -1,15 +1,15 @@ import { useLocation } from "react-router"; -import { DEBUGGER_TAB_KEYS } from "../helpers"; +import { DEBUGGER_TAB_KEYS } from "../constants"; import { setCanvasDebuggerState } from "actions/debuggerActions"; import AnalyticsUtil from "ee/utils/AnalyticsUtil"; import type { FocusEntityInfo } from "navigation/FocusEntity"; import { FocusEntity, identifyEntityFromPath } from "navigation/FocusEntity"; import { setJsPaneDebuggerState } from "actions/jsPaneActions"; -import { setApiPaneDebuggerState } from "actions/apiPaneActions"; -import { setQueryPaneDebuggerState } from "actions/queryPaneActions"; import { getJsPaneDebuggerState } from "selectors/jsPaneSelectors"; -import { getApiPaneDebuggerState } from "selectors/apiPaneSelectors"; -import { getQueryPaneDebuggerState } from "selectors/queryPaneSelectors"; +import { + getPluginActionDebuggerState, + setPluginActionEditorDebuggerState, +} from "PluginActionEditor/store"; import { getCanvasDebuggerState } from "selectors/debuggerSelectors"; import { getIDEViewMode } from "selectors/ideSelectors"; import { useDispatch, useSelector } from "react-redux"; @@ -30,26 +30,15 @@ const canvasDebuggerConfig: Config = { get: getCanvasDebuggerState, }; -const queryDebuggerConfig: Config = { - set: setQueryPaneDebuggerState, - get: getQueryPaneDebuggerState, +const pluginActionEditorDebuggerConfig: Config = { + set: setPluginActionEditorDebuggerState, + get: getPluginActionDebuggerState, }; const getConfig = (focusInfo: FocusEntityInfo): Config => { switch (focusInfo.entity) { case FocusEntity.QUERY: - if (focusInfo.params.baseApiId) { - if (focusInfo.params.pluginPackageName) { - return queryDebuggerConfig; - } - - return { - set: setApiPaneDebuggerState, - get: getApiPaneDebuggerState, - }; - } - - return queryDebuggerConfig; + return pluginActionEditorDebuggerConfig; case FocusEntity.JS_OBJECT: return { set: setJsPaneDebuggerState, diff --git a/app/client/src/components/editorComponents/EntityBottomTabs.tsx b/app/client/src/components/editorComponents/EntityBottomTabs.tsx index 9e2f05ba043..e649ba41d1a 100644 --- a/app/client/src/components/editorComponents/EntityBottomTabs.tsx +++ b/app/client/src/components/editorComponents/EntityBottomTabs.tsx @@ -1,6 +1,6 @@ import React from "react"; import AnalyticsUtil from "ee/utils/AnalyticsUtil"; -import { DEBUGGER_TAB_KEYS } from "./Debugger/helpers"; +import { DEBUGGER_TAB_KEYS } from "./Debugger/constants"; import { Tab, TabPanel, Tabs, TabsList } from "@appsmith/ads"; import styled from "styled-components"; import { LIST_HEADER_HEIGHT, FOOTER_MARGIN } from "./Debugger/DebuggerLogs"; @@ -9,11 +9,14 @@ import type { RefObject } from "react"; const TabPanelWrapper = styled(TabPanel)` margin-top: 0; height: calc(100% - ${LIST_HEADER_HEIGHT}); + &.ads-v2-tabs__panel { overflow: auto; } + & .t--code-editor-wrapper.codeWrapper { height: calc(100% - ${FOOTER_MARGIN}); + & .CodeMirror-scroll { box-sizing: border-box; } diff --git a/app/client/src/components/editorComponents/JSResponseView.test.tsx b/app/client/src/components/editorComponents/JSResponseView.test.tsx index 1ca5857b41e..5d3e177cc17 100644 --- a/app/client/src/components/editorComponents/JSResponseView.test.tsx +++ b/app/client/src/components/editorComponents/JSResponseView.test.tsx @@ -13,6 +13,7 @@ import type { JSCollectionData } from "ee/reducers/entityReducers/jsActionsReduc import { PluginType } from "entities/Action"; import "@testing-library/jest-dom/extend-expect"; import { EMPTY_RESPONSE_LAST_HALF } from "ee/constants/messages"; +import { DEBUGGER_TAB_KEYS } from "./Debugger/constants"; jest.mock("ee/utils/actionExecutionUtils"); @@ -43,7 +44,7 @@ const storeState = { debugger: { open: true, responseTabHeight: 200, - selectedTab: "response", + selectedTab: DEBUGGER_TAB_KEYS.RESPONSE_TAB, }, }, editor: { diff --git a/app/client/src/components/editorComponents/JSResponseView.tsx b/app/client/src/components/editorComponents/JSResponseView.tsx index 91d8519abe0..96d5fbbf006 100644 --- a/app/client/src/components/editorComponents/JSResponseView.tsx +++ b/app/client/src/components/editorComponents/JSResponseView.tsx @@ -23,7 +23,7 @@ import { Flex, Text } from "@appsmith/ads"; import LoadingOverlayScreen from "components/editorComponents/LoadingOverlayScreen"; import type { JSCollectionData } from "ee/reducers/entityReducers/jsActionsReducer"; import type { EvaluationError } from "utils/DynamicBindingUtils"; -import { DEBUGGER_TAB_KEYS } from "./Debugger/helpers"; +import { DEBUGGER_TAB_KEYS } from "./Debugger/constants"; import type { BottomTab } from "./EntityBottomTabs"; import EntityBottomTabs from "./EntityBottomTabs"; import { getIsSavingEntity } from "selectors/editorSelectors"; @@ -56,6 +56,7 @@ const ResponseTabWrapper = styled.div` opacity: 0.8; pointer-events: none; } + .response-run { margin: 0 10px; } @@ -190,7 +191,7 @@ function JSResponseView(props: Props) { const tabs: BottomTab[] = [ { - key: "response", + key: DEBUGGER_TAB_KEYS.RESPONSE_TAB, title: createMessage(DEBUGGER_RESPONSE), panelComponent: ( <> diff --git a/app/client/src/ee/reducers/uiReducers/apiPaneReducer.tsx b/app/client/src/ee/reducers/uiReducers/apiPaneReducer.tsx deleted file mode 100644 index dd2ecbe891d..00000000000 --- a/app/client/src/ee/reducers/uiReducers/apiPaneReducer.tsx +++ /dev/null @@ -1,3 +0,0 @@ -export * from "ce/reducers/uiReducers/apiPaneReducer"; -import { default as CE_apiPaneReducer } from "ce/reducers/uiReducers/apiPaneReducer"; -export default CE_apiPaneReducer; diff --git a/app/client/src/ee/reducers/uiReducers/queryPaneReducer.ts b/app/client/src/ee/reducers/uiReducers/queryPaneReducer.ts deleted file mode 100644 index c2e8eabefee..00000000000 --- a/app/client/src/ee/reducers/uiReducers/queryPaneReducer.ts +++ /dev/null @@ -1,3 +0,0 @@ -export * from "ce/reducers/uiReducers/queryPaneReducer"; -import { default as CE_queryPaneReducer } from "ce/reducers/uiReducers/queryPaneReducer"; -export default CE_queryPaneReducer; diff --git a/app/client/src/navigation/FocusElements.ts b/app/client/src/navigation/FocusElements.ts index 94b5c071d2d..9a44d305963 100644 --- a/app/client/src/navigation/FocusElements.ts +++ b/app/client/src/navigation/FocusElements.ts @@ -2,7 +2,7 @@ import type { ReduxAction } from "ee/constants/ReduxActionConstants"; import type { AppState } from "ee/reducers"; export enum FocusElement { - ApiPaneConfigTabs = "ApiPaneConfigTabs", + PluginActionConfigTabs = "PluginActionConfigTabs", CodeEditorHistory = "CodeEditorHistory", EntityCollapsibleState = "EntityCollapsibleState", EntityExplorerWidth = "EntityExplorerWidth", @@ -10,8 +10,6 @@ export enum FocusElement { DatasourceViewMode = "DatasourceViewMode", SelectedDatasource = "SelectedDatasource", DebuggerContext = "DebuggerContext", - ApiRightPaneTabs = "ApiRightPaneTabs", - QueryPaneConfigTabs = "QueryPaneConfigTabs", JSPaneConfigTabs = "JSPaneConfigTabs", PropertySections = "PropertySections", PropertyField = "PropertyField", @@ -26,8 +24,7 @@ export enum FocusElement { SelectedJSObject = "SelectedJSObject", SelectedEntity = "SelectedEntity", IDETabs = "IDETabs", - QueryDebugger = "QueryDebugger", - ApiDebugger = "ApiDebugger", + PluginActionDebugger = "PluginActionDebugger", JSDebugger = "JSDebugger", } diff --git a/app/client/src/pages/Editor/APIEditor/Editor.tsx b/app/client/src/pages/Editor/APIEditor/Editor.tsx index f939edc0be2..a1a79bb7b73 100644 --- a/app/client/src/pages/Editor/APIEditor/Editor.tsx +++ b/app/client/src/pages/Editor/APIEditor/Editor.tsx @@ -21,7 +21,12 @@ import Spinner from "components/editorComponents/Spinner"; import type { CSSProperties } from "styled-components"; import styled from "styled-components"; import CenteredWrapper from "components/designSystems/appsmith/CenteredWrapper"; -import { changeApi } from "actions/apiPaneActions"; +import { + changeApi, + isActionDeleting, + isActionRunning, + isPluginActionCreating, +} from "PluginActionEditor/store"; import * as Sentry from "@sentry/react"; import EntityNotFoundPane from "pages/Editor/EntityNotFoundPane"; import type { ApplicationPayload } from "entities/Application"; @@ -237,7 +242,9 @@ const mapStateToProps = (state: AppState, props: any): ReduxStateProps => { const apiAction = getActionByBaseId(state, props?.match?.params?.baseApiId); const apiName = apiAction?.name ?? ""; const apiId = apiAction?.id ?? ""; - const { isCreating, isDeleting, isRunning } = state.ui.apiPane; + const isCreating = isPluginActionCreating(state); + const isDeleting = isActionDeleting(apiId)(state); + const isRunning = isActionRunning(apiId)(state); const pluginId = _.get(apiAction, "pluginId", ""); return { @@ -251,9 +258,9 @@ const mapStateToProps = (state: AppState, props: any): ReduxStateProps => { pluginId, paginationType: _.get(apiAction, "actionConfiguration.paginationType"), apiAction, - isRunning: isRunning[apiId], - isDeleting: isDeleting[apiId], - isCreating: isCreating, + isRunning, + isDeleting, + isCreating, applicationId: getCurrentApplicationId(state), }; }; diff --git a/app/client/src/pages/Editor/APIEditor/PostBodyData.tsx b/app/client/src/pages/Editor/APIEditor/PostBodyData.tsx index a874d99c8a6..72009d651d6 100644 --- a/app/client/src/pages/Editor/APIEditor/PostBodyData.tsx +++ b/app/client/src/pages/Editor/APIEditor/PostBodyData.tsx @@ -19,7 +19,10 @@ import { TabBehaviour, } from "components/editorComponents/CodeEditor/EditorConfig"; import { Classes } from "@appsmith/ads-old"; -import { updateBodyContentType } from "actions/apiPaneActions"; +import { + getPostBodyFormat, + updatePostBodyContentType, +} from "PluginActionEditor/store"; import type { CodeEditorExpected } from "components/editorComponents/CodeEditor"; import { AutocompleteDataType } from "utils/autocomplete/AutocompleteDataType"; import { createMessage, API_PANE_NO_BODY } from "ee/constants/messages"; @@ -199,14 +202,14 @@ const selector = formValueSelector(API_EDITOR_FORM_NAME); // eslint-disable-next-line @typescript-eslint/no-explicit-any const mapDispatchToProps = (dispatch: any) => ({ updateBodyContentType: (contentType: string, apiId: string) => - dispatch(updateBodyContentType(contentType, apiId)), + dispatch(updatePostBodyContentType(contentType, apiId)), }); export default connect((state: AppState) => { const apiId = selector(state, "id"); - const extraFormData = state.ui.apiPane.extraformData[apiId] || {}; - // Defaults to NONE when extraformData is empty - const displayFormat = extraFormData["displayFormat"] || { + const postBodyFormat = getPostBodyFormat(state, apiId); + // Defaults to NONE when format is not set + const displayFormat = postBodyFormat || { label: POST_BODY_FORMAT_OPTIONS.NONE, value: POST_BODY_FORMAT_OPTIONS.NONE, }; diff --git a/app/client/src/pages/Editor/ActionSettings.tsx b/app/client/src/pages/Editor/ActionSettings.tsx index 003b085d397..60ec02bcc08 100644 --- a/app/client/src/pages/Editor/ActionSettings.tsx +++ b/app/client/src/pages/Editor/ActionSettings.tsx @@ -4,6 +4,7 @@ import FormControl from "./FormControl"; import log from "loglevel"; import type { EditorTheme } from "components/editorComponents/CodeEditor/EditorConfig"; import styled from "styled-components"; +import { Text } from "@appsmith/ads"; interface ActionSettingsProps { // TODO: Fix this the next time the file is edited @@ -21,9 +22,11 @@ const ActionSettingsWrapper = styled.div` width: 100%; max-width: 600px; padding-bottom: 1px; + .form-config-top { flex-grow: 1; } + .t--form-control-SWITCH { display: flex; flex-shrink: 0; @@ -35,10 +38,16 @@ const ActionSettingsWrapper = styled.div` function ActionSettings(props: ActionSettingsProps): JSX.Element { return ( - {/* TODO: Fix this the next time the file is edited */} - {/* eslint-disable-next-line @typescript-eslint/no-explicit-any */} - {props.actionSettingsConfig.map((section: any) => - renderEachConfig(section, props.formName), + {!props.actionSettingsConfig ? ( + + Error: No settings config found + + ) : ( + /* TODO: Fix this the next time the file is edited */ + /* eslint-disable-next-line @typescript-eslint/no-explicit-any */ + props.actionSettingsConfig.map((section: any) => + renderEachConfig(section, props.formName), + ) )} ); diff --git a/app/client/src/pages/Editor/DataSourceEditor/Debugger.tsx b/app/client/src/pages/Editor/DataSourceEditor/Debugger.tsx index 01d2634f678..f02daa78013 100644 --- a/app/client/src/pages/Editor/DataSourceEditor/Debugger.tsx +++ b/app/client/src/pages/Editor/DataSourceEditor/Debugger.tsx @@ -13,7 +13,7 @@ import { showDebugger, } from "actions/debuggerActions"; import EntityBottomTabs from "components/editorComponents/EntityBottomTabs"; -import { DEBUGGER_TAB_KEYS } from "components/editorComponents/Debugger/helpers"; +import { DEBUGGER_TAB_KEYS } from "components/editorComponents/Debugger/constants"; import Errors from "components/editorComponents/Debugger/Errors"; import DebuggerLogs from "components/editorComponents/Debugger/DebuggerLogs"; import EntityDeps from "components/editorComponents/Debugger/EntityDependecies"; @@ -37,30 +37,38 @@ export const ResizerContentContainer = styled.div` flex: 1; position: relative; display: flex; + &.db-form-resizer-content, &.saas-form-resizer-content, &.api-datasource-content-container { flex-direction: column; padding: 0 var(--ads-v2-spaces-7) 0 var(--ads-v2-spaces-7); + & .t--ds-form-header { border-bottom: 1px solid var(--ads-v2-color-border); } } + &.db-form-resizer-content.db-form-resizer-content-show-tabs, &.saas-form-resizer-content.saas-form-resizer-content-show-tabs { padding: 0; + & .t--ds-form-header { border-bottom: none; } } + &.saas-form-resizer-content.saas-form-resizer-content-show-tabs form { padding-bottom: 0; } + border-top: none; + .db-form-content-container { display: flex; flex-direction: column; width: 100%; + form { flex-grow: 1; } diff --git a/app/client/src/pages/Editor/DataSourceEditor/NewActionButton.tsx b/app/client/src/pages/Editor/DataSourceEditor/NewActionButton.tsx index 99dc3bfbe52..d59d1fdd260 100644 --- a/app/client/src/pages/Editor/DataSourceEditor/NewActionButton.tsx +++ b/app/client/src/pages/Editor/DataSourceEditor/NewActionButton.tsx @@ -18,7 +18,7 @@ import { NEW_API_BUTTON_TEXT, NEW_QUERY_BUTTON_TEXT, } from "ee/constants/messages"; -import { createNewQueryAction } from "actions/apiPaneActions"; +import { createNewQueryAction } from "actions/pluginActionActions"; import { useDispatch, useSelector } from "react-redux"; import { getCurrentPageId, getPageList } from "selectors/editorSelectors"; import type { Datasource } from "entities/Datasource"; diff --git a/app/client/src/pages/Editor/EntityNavigation/ActionPane/ApiPaneNavigation.ts b/app/client/src/pages/Editor/EntityNavigation/ActionPane/ApiPaneNavigation.ts index 2fa0dbb5cfe..4671eaae08b 100644 --- a/app/client/src/pages/Editor/EntityNavigation/ActionPane/ApiPaneNavigation.ts +++ b/app/client/src/pages/Editor/EntityNavigation/ActionPane/ApiPaneNavigation.ts @@ -2,16 +2,15 @@ import { call, delay, put } from "redux-saga/effects"; import type { EntityInfo, IApiPaneNavigationConfig } from "../types"; import { ActionPaneNavigation } from "./exports"; import { API_EDITOR_TABS } from "constants/ApiEditorConstants/CommonApiConstants"; -import { setApiPaneConfigSelectedTabIndex } from "actions/apiPaneActions"; +import { setPluginActionEditorSelectedTab } from "PluginActionEditor/store"; import { NAVIGATION_DELAY } from "../costants"; -import { isNumber } from "lodash"; export default class ApiPaneNavigation extends ActionPaneNavigation { constructor(entityInfo: EntityInfo) { super(entityInfo); this.getConfig = this.getConfig.bind(this); this.navigate = this.navigate.bind(this); - this.getTabIndex = this.getTabIndex.bind(this); + this.getTab = this.getTab.bind(this); } *getConfig() { @@ -19,17 +18,18 @@ export default class ApiPaneNavigation extends ActionPaneNavigation { if (!this.entityInfo.propertyPath) return {}; - const tabIndex: number | undefined = yield call( - this.getTabIndex, + const tab: string | undefined = yield call( + this.getTab, this.entityInfo.propertyPath, ); config = { - tabIndex, + tab, }; return config; } + *navigate() { const config: IApiPaneNavigationConfig = yield call(this.getConfig); @@ -37,17 +37,16 @@ export default class ApiPaneNavigation extends ActionPaneNavigation { if (!this.entityInfo.propertyPath) return; - if (isNumber(config.tabIndex)) { - yield put(setApiPaneConfigSelectedTabIndex(config.tabIndex)); + if (config.tab) { + yield put(setPluginActionEditorSelectedTab(config.tab)); yield delay(NAVIGATION_DELAY); } yield call(this.scrollToView, this.entityInfo.propertyPath); } - *getTabIndex(propertyPath: string) { - let currentTab; - let index; + *getTab(propertyPath: string) { + let currentTab: string | undefined; const modifiedProperty = propertyPath.replace( "config", "actionConfiguration", @@ -79,10 +78,6 @@ export default class ApiPaneNavigation extends ActionPaneNavigation { } } - if (currentTab) { - index = Object.values(API_EDITOR_TABS).indexOf(currentTab); - } - - return index; + return currentTab; } } diff --git a/app/client/src/pages/Editor/EntityNavigation/ActionPane/QueryPaneNavigation.ts b/app/client/src/pages/Editor/EntityNavigation/ActionPane/QueryPaneNavigation.ts index 68fc9ab0e9c..2d3ee6dc913 100644 --- a/app/client/src/pages/Editor/EntityNavigation/ActionPane/QueryPaneNavigation.ts +++ b/app/client/src/pages/Editor/EntityNavigation/ActionPane/QueryPaneNavigation.ts @@ -2,13 +2,15 @@ import { call, delay, put, race, select, take } from "redux-saga/effects"; import type { EntityInfo, IQueryPaneNavigationConfig } from "../types"; import { ActionPaneNavigation } from "./exports"; import { NAVIGATION_DELAY } from "../costants"; -import { setQueryPaneConfigSelectedTabIndex } from "actions/queryPaneActions"; import { EDITOR_TABS } from "constants/QueryEditorConstants"; import { getFormEvaluationState } from "selectors/formSelectors"; import type { FormEvaluationState } from "reducers/evaluationReducers/formEvaluationReducer"; import { isEmpty } from "lodash"; import { ReduxActionTypes } from "ee/constants/ReduxActionConstants"; -import { isActionSaving } from "ee/selectors/entitiesSelector"; +import { + isActionSaving, + setPluginActionEditorSelectedTab, +} from "PluginActionEditor/store"; export default class QueryPaneNavigation extends ActionPaneNavigation { constructor(entityInfo: EntityInfo) { @@ -44,7 +46,7 @@ export default class QueryPaneNavigation extends ActionPaneNavigation { if (!this.entityInfo.propertyPath) return; if (config.tab) { - yield put(setQueryPaneConfigSelectedTabIndex(config.tab)); + yield put(setPluginActionEditorSelectedTab(config.tab)); } yield call(this.waitForFormUpdate); diff --git a/app/client/src/pages/Editor/EntityNavigation/types.ts b/app/client/src/pages/Editor/EntityNavigation/types.ts index 5d6a173e57d..13de1aa9803 100644 --- a/app/client/src/pages/Editor/EntityNavigation/types.ts +++ b/app/client/src/pages/Editor/EntityNavigation/types.ts @@ -33,7 +33,7 @@ export interface IMatchedSection { } export interface IApiPaneNavigationConfig { - tabIndex?: number; + tab?: string; } export interface IQueryPaneNavigationConfig { diff --git a/app/client/src/pages/Editor/IntegrationEditor/CreateNewDatasourceTab.tsx b/app/client/src/pages/Editor/IntegrationEditor/CreateNewDatasourceTab.tsx index 5c304abc7b0..8bbdc69257f 100644 --- a/app/client/src/pages/Editor/IntegrationEditor/CreateNewDatasourceTab.tsx +++ b/app/client/src/pages/Editor/IntegrationEditor/CreateNewDatasourceTab.tsx @@ -39,6 +39,7 @@ import { useEditorType } from "ee/hooks"; import { useParentEntityInfo } from "ee/hooks/datasourceEditorHooks"; import AIDataSources from "./AIDataSources"; import Debugger from "../DataSourceEditor/Debugger"; +import { isPluginActionCreating } from "PluginActionEditor/store"; const NewIntegrationsContainer = styled.div` ${thinScrollbar}; @@ -381,7 +382,7 @@ const mapStateToProps = (state: AppState) => { return { dataSources: getDatasources(state), mockDatasources: getMockDatasources(state), - isCreating: state.ui.apiPane.isCreating, + isCreating: isPluginActionCreating(state), applicationId: getCurrentApplicationId(state), canCreateDatasource, showDebugger, diff --git a/app/client/src/pages/Editor/JSEditor/Form.tsx b/app/client/src/pages/Editor/JSEditor/Form.tsx index a2cc86b4072..5121ac1164d 100644 --- a/app/client/src/pages/Editor/JSEditor/Form.tsx +++ b/app/client/src/pages/Editor/JSEditor/Form.tsx @@ -70,8 +70,9 @@ import { getHasManageActionPermission, } from "ee/utils/BusinessFeatures/permissionPageHelpers"; import type { JSCollectionData } from "ee/reducers/entityReducers/jsActionsReducer"; -import { DEBUGGER_TAB_KEYS } from "../../../components/editorComponents/Debugger/helpers"; +import { DEBUGGER_TAB_KEYS } from "components/editorComponents/Debugger/constants"; import RunHistory from "ee/components/RunHistory"; + interface JSFormProps { jsCollectionData: JSCollectionData; contextMenu: React.ReactNode; @@ -99,6 +100,7 @@ const SecondaryWrapper = styled.div` flex-direction: column; flex: 1; overflow: hidden; + &&& { .ads-v2-tabs, &.js-editor-tab { diff --git a/app/client/src/pages/Editor/QueryEditor/Editor.tsx b/app/client/src/pages/Editor/QueryEditor/Editor.tsx index 8e6322c78a7..abb9038a2cd 100644 --- a/app/client/src/pages/Editor/QueryEditor/Editor.tsx +++ b/app/client/src/pages/Editor/QueryEditor/Editor.tsx @@ -41,6 +41,11 @@ import { merge } from "lodash"; import { getPathAndValueFromActionDiffObject } from "../../../utils/getPathAndValueFromActionDiffObject"; import { getCurrentEnvironmentDetails } from "ee/selectors/environmentSelectors"; import { QueryEditorContext } from "./QueryEditorContext"; +import { + isActionDeleting, + isActionRunning, + isPluginActionCreating, +} from "PluginActionEditor/store"; const EmptyStateContainer = styled.div` display: flex; @@ -253,7 +258,7 @@ class QueryEditor extends React.Component { const mapStateToProps = (state: AppState, props: OwnProps): ReduxStateProps => { const { baseApiId, baseQueryId } = props.match.params; const baseActionId = baseQueryId || baseApiId || ""; - const { runErrorMessage } = state.ui.queryPane; + const { runErrorMessage } = state.ui.pluginActionEditor; const { plugins } = state.entities; const { editorConfigs } = plugins; @@ -272,6 +277,10 @@ const mapStateToProps = (state: AppState, props: OwnProps): ReduxStateProps => { pluginId = action.pluginId; } + const isCreating = isPluginActionCreating(state); + const isDeleting = isActionDeleting(actionId)(state); + const isRunning = isActionRunning(actionId)(state); + // TODO: Fix this the next time the file is edited // eslint-disable-next-line @typescript-eslint/no-explicit-any let editorConfig: any; @@ -319,12 +328,12 @@ const mapStateToProps = (state: AppState, props: OwnProps): ReduxStateProps => { ? getDatasourceByPluginId(state, action?.pluginId) : getDBAndRemoteDatasources(state), responses: getActionResponses(state), - isRunning: state.ui.queryPane.isRunning[actionId], - isDeleting: state.ui.queryPane.isDeleting[actionId], + isCreating, + isRunning, + isDeleting, isSaas: !!baseApiId, formData, editorConfig, - isCreating: state.ui.apiPane.isCreating, uiComponent, applicationId: getCurrentApplicationId(state), actionObjectDiff, diff --git a/app/client/src/pages/Editor/QueryEditor/EditorJSONtoForm.tsx b/app/client/src/pages/Editor/QueryEditor/EditorJSONtoForm.tsx index 370964cc6dc..02650c405a6 100644 --- a/app/client/src/pages/Editor/QueryEditor/EditorJSONtoForm.tsx +++ b/app/client/src/pages/Editor/QueryEditor/EditorJSONtoForm.tsx @@ -23,8 +23,10 @@ import type { Plugin } from "api/PluginApi"; import type { UIComponentTypes } from "api/PluginApi"; import { EDITOR_TABS } from "constants/QueryEditorConstants"; import type { FormEvalOutput } from "reducers/evaluationReducers/formEvaluationReducer"; -import { getQueryPaneConfigSelectedTabIndex } from "selectors/queryPaneSelectors"; -import { setQueryPaneConfigSelectedTabIndex } from "actions/queryPaneActions"; +import { + getPluginActionConfigSelectedTab, + setPluginActionEditorSelectedTab, +} from "PluginActionEditor/store"; import type { SourceEntity } from "entities/AppsmithConsole"; import { ENTITY_TYPE as SOURCE_ENTITY_TYPE } from "ee/entities/AppsmithConsole/utils"; import { DocsLink, openDoc } from "../../../constants/DocumentationLinks"; @@ -230,11 +232,11 @@ export function EditorJSONtoForm(props: Props) { id: currentActionConfig ? currentActionConfig.id : "", }; - const selectedConfigTab = useSelector(getQueryPaneConfigSelectedTabIndex); + const selectedTab = useSelector(getPluginActionConfigSelectedTab); const setSelectedConfigTab = useCallback( (selectedIndex: string) => { - dispatch(setQueryPaneConfigSelectedTabIndex(selectedIndex)); + dispatch(setPluginActionEditorSelectedTab(selectedIndex)); }, [dispatch], ); @@ -264,7 +266,7 @@ export function EditorJSONtoForm(props: Props) { diff --git a/app/client/src/pages/Editor/QueryEditor/QueryDebuggerTabs.test.tsx b/app/client/src/pages/Editor/QueryEditor/QueryDebuggerTabs.test.tsx index 6d31b9f64f0..23de0834cd0 100644 --- a/app/client/src/pages/Editor/QueryEditor/QueryDebuggerTabs.test.tsx +++ b/app/client/src/pages/Editor/QueryEditor/QueryDebuggerTabs.test.tsx @@ -42,7 +42,7 @@ const storeState = { errorCount: 0, }, }, - queryPane: { + pluginActionEditor: { debugger: { open: true, responseTabHeight: 200, diff --git a/app/client/src/pages/Editor/QueryEditor/QueryDebuggerTabs.tsx b/app/client/src/pages/Editor/QueryEditor/QueryDebuggerTabs.tsx index 160ce631ac0..f3b66675e77 100644 --- a/app/client/src/pages/Editor/QueryEditor/QueryDebuggerTabs.tsx +++ b/app/client/src/pages/Editor/QueryEditor/QueryDebuggerTabs.tsx @@ -5,7 +5,7 @@ import { useDispatch, useSelector } from "react-redux"; import styled from "styled-components"; import { getErrorCount } from "selectors/debuggerSelectors"; import { Text, TextType } from "@appsmith/ads-old"; -import { DEBUGGER_TAB_KEYS } from "components/editorComponents/Debugger/helpers"; +import { DEBUGGER_TAB_KEYS } from "components/editorComponents/Debugger/constants"; import { DEBUGGER_ERRORS, DEBUGGER_LOGS, @@ -27,12 +27,14 @@ import { import { DatasourceComponentTypes } from "api/PluginApi"; import { fetchDatasourceStructure } from "actions/datasourceActions"; import { DatasourceStructureContext } from "entities/Datasource"; -import { getQueryPaneDebuggerState } from "selectors/queryPaneSelectors"; -import { setQueryPaneDebuggerState } from "actions/queryPaneActions"; +import { + getPluginActionDebuggerState, + setPluginActionEditorDebuggerState, +} from "PluginActionEditor/store"; import { actionResponseDisplayDataFormats } from "../utils"; import { getIDEViewMode } from "selectors/ideSelectors"; import { EditorViewMode } from "ee/entities/IDE/constants"; -import { IDEBottomView, ViewHideBehaviour } from "../../../IDE"; +import { IDEBottomView, ViewHideBehaviour } from "IDE"; const ResultsCount = styled.div` position: absolute; @@ -68,7 +70,7 @@ function QueryDebuggerTabs({ const dispatch = useDispatch(); const { open, responseTabHeight, selectedTab } = useSelector( - getQueryPaneDebuggerState, + getPluginActionDebuggerState, ); const { responseDisplayFormat } = @@ -107,7 +109,12 @@ function QueryDebuggerTabs({ ), ); } - }, []); + }, [ + currentActionConfig, + datasourceStructure, + dispatch, + pluginDatasourceForm, + ]); // These useEffects are used to open the response tab by default for page load queries // as for page load queries, query response is available and can be shown in response tab @@ -121,25 +128,30 @@ function QueryDebuggerTabs({ !showResponseOnFirstLoad ) { dispatch( - setQueryPaneDebuggerState({ + setPluginActionEditorDebuggerState({ open: true, selectedTab: DEBUGGER_TAB_KEYS.RESPONSE_TAB, }), ); setShowResponseOnFirstLoad(true); } - }, [responseDisplayFormat, actionResponse, showResponseOnFirstLoad]); + }, [ + responseDisplayFormat, + actionResponse, + showResponseOnFirstLoad, + dispatch, + ]); useEffect(() => { if (showSchema && !selectedTab) { dispatch( - setQueryPaneDebuggerState({ + setPluginActionEditorDebuggerState({ open: true, selectedTab: DEBUGGER_TAB_KEYS.SCHEMA_TAB, }), ); } - }, [showSchema, currentActionConfig?.id, selectedTab]); + }, [showSchema, selectedTab, dispatch]); // When multiple page load queries exist, we want to response tab by default for all of them // Hence this useEffect will reset showResponseOnFirstLoad flag used to track whether to show response tab or not @@ -170,17 +182,27 @@ function QueryDebuggerTabs({ } } - const setQueryResponsePaneHeight = useCallback((height: number) => { - dispatch(setQueryPaneDebuggerState({ responseTabHeight: height })); - }, []); + const setQueryResponsePaneHeight = useCallback( + (height: number) => { + dispatch( + setPluginActionEditorDebuggerState({ responseTabHeight: height }), + ); + }, + [dispatch], + ); const onToggle = useCallback(() => { - dispatch(setQueryPaneDebuggerState({ open: !open })); - }, [open]); + dispatch(setPluginActionEditorDebuggerState({ open: !open })); + }, [dispatch, open]); - const setSelectedResponseTab = useCallback((tabKey: string) => { - dispatch(setQueryPaneDebuggerState({ open: true, selectedTab: tabKey })); - }, []); + const setSelectedResponseTab = useCallback( + (tabKey: string) => { + dispatch( + setPluginActionEditorDebuggerState({ open: true, selectedTab: tabKey }), + ); + }, + [dispatch], + ); const ideViewMode = useSelector(getIDEViewMode); @@ -204,7 +226,7 @@ function QueryDebuggerTabs({ if (currentActionConfig) { responseTabs.unshift({ - key: "response", + key: DEBUGGER_TAB_KEYS.RESPONSE_TAB, title: createMessage(DEBUGGER_RESPONSE), panelComponent: ( ` ${HelpSection} { margin-bottom: 10px; } + position: relative; `; @@ -97,7 +100,7 @@ const QueryResponseTab = (props: Props) => { const actionResponse = useSelector((state) => getActionData(state, currentActionConfig.id), ); - const { responseTabHeight } = useSelector(getQueryPaneDebuggerState); + const { responseTabHeight } = useSelector(getPluginActionDebuggerState); const { responseDataTypes, responseDisplayFormat } = actionResponseDisplayDataFormats(actionResponse); @@ -216,8 +219,12 @@ const QueryResponseTab = (props: Props) => { } const navigateToSettings = useCallback(() => { - dispatch(setQueryPaneConfigSelectedTabIndex(EDITOR_TABS.SETTINGS)); - }, []); + dispatch( + setPluginActionEditorDebuggerState({ + selectedTab: EDITOR_TABS.SETTINGS, + }), + ); + }, [dispatch]); const preparedStatementCalloutLinks: CalloutLinkProps[] = [ { diff --git a/app/client/src/pages/Editor/QueryEditor/index.tsx b/app/client/src/pages/Editor/QueryEditor/index.tsx index 03457a6228e..2d458fb90c9 100644 --- a/app/client/src/pages/Editor/QueryEditor/index.tsx +++ b/app/client/src/pages/Editor/QueryEditor/index.tsx @@ -13,7 +13,7 @@ import { getIsEditorInitialized, getPagePermissions, } from "selectors/editorSelectors"; -import { changeQuery } from "actions/queryPaneActions"; +import { changeQuery } from "PluginActionEditor/store"; import { DatasourceCreateEntryPoints } from "constants/Datasource"; import { getActionByBaseId, diff --git a/app/client/src/sagas/ActionExecution/PluginActionSaga.ts b/app/client/src/sagas/ActionExecution/PluginActionSaga.ts index 0c220b23ec4..5e2d426dc2b 100644 --- a/app/client/src/sagas/ActionExecution/PluginActionSaga.ts +++ b/app/client/src/sagas/ActionExecution/PluginActionSaga.ts @@ -44,8 +44,6 @@ import { getDatasource, getJSCollectionFromAllEntities, getPlugin, - isActionDirty, - isActionSaving, } from "ee/selectors/entitiesSelector"; import { getIsGitSyncModalOpen } from "selectors/gitSyncSelectors"; import { @@ -72,7 +70,7 @@ import { } from "sagas/ErrorSagas"; import AnalyticsUtil from "ee/utils/AnalyticsUtil"; import type { Action } from "entities/Action"; -import { ActionExecutionContext, PluginType } from "entities/Action"; +import { ActionExecutionContext } from "entities/Action"; import LOG_TYPE from "entities/AppsmithConsole/logtype"; import { ACTION_EXECUTION_CANCELLED, @@ -99,7 +97,7 @@ import { getLayoutOnLoadActions, getLayoutOnLoadIssues, } from "selectors/editorSelectors"; -import * as log from "loglevel"; +import log from "loglevel"; import { EMPTY_RESPONSE } from "components/editorComponents/emptyResponse"; import type { AppState } from "ee/reducers"; import { DEFAULT_EXECUTE_ACTION_TIMEOUT_MS } from "ee/constants/ApiConstants"; @@ -140,17 +138,13 @@ import { setDefaultActionDisplayFormat } from "./PluginActionSagaUtils"; import { checkAndLogErrorsIfCyclicDependency } from "sagas/helper"; import { toast } from "@appsmith/ads"; import type { TRunDescription } from "workers/Evaluation/fns/actionFns"; -import { DEBUGGER_TAB_KEYS } from "components/editorComponents/Debugger/helpers"; +import { DEBUGGER_TAB_KEYS } from "components/editorComponents/Debugger/constants"; import { FILE_SIZE_LIMIT_FOR_BLOBS } from "constants/WidgetConstants"; import type { ActionData } from "ee/reducers/entityReducers/actionsReducer"; import { handleStoreOperations } from "./StoreActionSaga"; import { fetchPageAction } from "actions/pageActions"; import type { Datasource } from "entities/Datasource"; import { softRefreshDatasourceStructure } from "actions/datasourceActions"; -import { - changeQuery, - setQueryPaneDebuggerState, -} from "actions/queryPaneActions"; import { getCurrentEnvironmentDetails, getCurrentEnvironmentName, @@ -171,7 +165,12 @@ import { } from "ee/utils/actionExecutionUtils"; import type { JSAction, JSCollection } from "entities/JSCollection"; import { getAllowedActionAnalyticsKeys } from "constants/AppsmithActionConstants/formConfig/ActionAnalyticsConfig"; -import { setApiPaneDebuggerState } from "../../actions/apiPaneActions"; +import { + changeQuery, + isActionDirty, + isActionSaving, + setPluginActionEditorDebuggerState, +} from "PluginActionEditor/store"; enum ActionResponseDataTypes { BINARY = "BINARY", @@ -801,7 +800,12 @@ export function* runActionSaga( // open response tab in debugger on exection of action. if (!reduxAction.payload.skipOpeningDebugger) { - yield call(openDebugger, plugin.type); + yield put( + setPluginActionEditorDebuggerState({ + open: true, + selectedTab: DEBUGGER_TAB_KEYS.RESPONSE_TAB, + }), + ); } let payload = EMPTY_RESPONSE; @@ -1193,7 +1197,12 @@ function* executePageLoadAction( // open response tab in debugger on exection of action on page load. // Only if current page is the page on which the action is executed. if (window.location.pathname.includes(pageAction.id)) - yield call(openDebugger, plugin.type); + yield put( + setPluginActionEditorDebuggerState({ + open: true, + selectedTab: DEBUGGER_TAB_KEYS.RESPONSE_TAB, + }), + ); if (isError) { AppsmithConsole.addErrors([ @@ -1577,23 +1586,6 @@ function triggerFileUploadInstrumentation( }); } -//Open debugger with response tab selected. -function* openDebugger(pluginType: PluginType) { - if (pluginType === PluginType.API) { - yield put( - setApiPaneDebuggerState({ - open: true, - selectedTab: DEBUGGER_TAB_KEYS.RESPONSE_TAB, - }), - ); - } else { - setQueryPaneDebuggerState({ - open: true, - selectedTab: DEBUGGER_TAB_KEYS.RESPONSE_TAB, - }); - } -} - // Function to clear the action responses for the actions which are not executeOnLoad. function* clearTriggerActionResponse() { const currentPageActions: ActionData[] = yield select(getCurrentActions); diff --git a/app/client/src/sagas/ActionExecution/errorUtils.ts b/app/client/src/sagas/ActionExecution/errorUtils.ts index 7ee5ddeb9bc..822c6e5d022 100644 --- a/app/client/src/sagas/ActionExecution/errorUtils.ts +++ b/app/client/src/sagas/ActionExecution/errorUtils.ts @@ -9,7 +9,7 @@ import type { ActionTriggerKeys } from "ee/workers/Evaluation/fns"; import { getActionTriggerFunctionNames } from "ee/workers/Evaluation/fns"; import AnalyticsUtil from "ee/utils/AnalyticsUtil"; import { setDebuggerSelectedTab, showDebugger } from "actions/debuggerActions"; -import { DEBUGGER_TAB_KEYS } from "components/editorComponents/Debugger/helpers"; +import { DEBUGGER_TAB_KEYS } from "components/editorComponents/Debugger/constants"; import store from "store"; import showToast from "sagas/ToastSagas"; import { call, put } from "redux-saga/effects"; diff --git a/app/client/src/sagas/ActionSagas.ts b/app/client/src/sagas/ActionSagas.ts index 4672069bc12..8bb94aa0c5b 100644 --- a/app/client/src/sagas/ActionSagas.ts +++ b/app/client/src/sagas/ActionSagas.ts @@ -28,6 +28,8 @@ import { updateCanvasWithDSL } from "ee/sagas/PageSagas"; import { closeQueryActionTab, closeQueryActionTabSuccess, + createNewApiAction, + createNewQueryAction, type FetchActionsPayload, type SetActionPropertyPayload, } from "actions/pluginActionActions"; @@ -101,10 +103,6 @@ import { import AppsmithConsole from "utils/AppsmithConsole"; import { ENTITY_TYPE } from "ee/entities/AppsmithConsole/utils"; import LOG_TYPE from "entities/AppsmithConsole/logtype"; -import { - createNewApiAction, - createNewQueryAction, -} from "actions/apiPaneActions"; import type { Plugin } from "api/PluginApi"; import { shouldBeDefined } from "utils/helpers"; import { diff --git a/app/client/src/sagas/ApiPaneSagas.ts b/app/client/src/sagas/ApiPaneSagas.ts index 96550ff7c81..cf6f4cf7904 100644 --- a/app/client/src/sagas/ApiPaneSagas.ts +++ b/app/client/src/sagas/ApiPaneSagas.ts @@ -29,7 +29,7 @@ import { import { DEFAULT_CREATE_API_CONFIG } from "constants/ApiEditorConstants/ApiEditorConstants"; import { DEFAULT_CREATE_GRAPHQL_CONFIG } from "constants/ApiEditorConstants/GraphQLEditorConstants"; import history from "utils/history"; -import { initialize, autofill, change, reset } from "redux-form"; +import { autofill, change, initialize, reset } from "redux-form"; import type { Property } from "api/ActionAPI"; import { getQueryParams } from "utils/URLUtils"; import { getPluginIdOfPackageName } from "sagas/selectors"; @@ -61,7 +61,7 @@ import { import { updateReplayEntity } from "actions/pageActions"; import { ENTITY_TYPE } from "ee/entities/AppsmithConsole/utils"; import type { Plugin } from "api/PluginApi"; -import { getDisplayFormat } from "selectors/apiPaneSelectors"; +import { getPostBodyFormat } from "../PluginActionEditor/store"; import { apiEditorIdURL, datasourcesEditorIdURL } from "ee/RouteBuilder"; import { getCurrentBasePageId } from "selectors/editorSelectors"; import { validateResponse } from "./ErrorSagas"; @@ -83,6 +83,7 @@ import { checkAndGetPluginFormConfigsSaga } from "./PluginSagas"; import { convertToBasePageIdSelector } from "selectors/pageListSelectors"; import type { ApplicationPayload } from "entities/Application"; import { klonaLiteWithTelemetry } from "utils/helpers"; +import { POST_BODY_FORM_DATA_KEY } from "../PluginActionEditor/constants"; function* syncApiParamsSaga( actionPayload: ReduxActionWithMeta, @@ -256,7 +257,7 @@ function* updateExtraFormDataSaga() { const { values } = formData; // when initializing, check if theres a display format present. - const extraFormData: GetFormData = yield select(getDisplayFormat, values.id); + const extraFormData: GetFormData = yield select(getPostBodyFormat, values.id); const headers: Array<{ key: string; value: string }> = get(values, "actionConfiguration.headers") || []; @@ -367,7 +368,7 @@ function* setApiBodyTabHeaderFormat(apiId: string, apiContentType?: string) { payload: { id: apiId, values: { - displayFormat, + [POST_BODY_FORM_DATA_KEY]: displayFormat, }, }, }); diff --git a/app/client/src/sagas/JSPaneSagas.ts b/app/client/src/sagas/JSPaneSagas.ts index c36ba5073ad..5d7fcec2b86 100644 --- a/app/client/src/sagas/JSPaneSagas.ts +++ b/app/client/src/sagas/JSPaneSagas.ts @@ -86,7 +86,7 @@ import { UserCancelledActionExecutionError } from "sagas/ActionExecution/errorUt import type { EventLocation } from "ee/utils/analyticsUtilTypes"; import AnalyticsUtil from "ee/utils/AnalyticsUtil"; import { checkAndLogErrorsIfCyclicDependency } from "./helper"; -import { DEBUGGER_TAB_KEYS } from "components/editorComponents/Debugger/helpers"; +import { DEBUGGER_TAB_KEYS } from "components/editorComponents/Debugger/constants"; import { getJSActionPathNameToDisplay, isBrowserExecutionAllowed, diff --git a/app/client/src/sagas/QueryPaneSagas.ts b/app/client/src/sagas/QueryPaneSagas.ts index 6195973f9fd..39bea13dfc1 100644 --- a/app/client/src/sagas/QueryPaneSagas.ts +++ b/app/client/src/sagas/QueryPaneSagas.ts @@ -77,7 +77,7 @@ import type { FeatureFlags } from "ee/entities/FeatureFlag"; import { selectFeatureFlags } from "ee/selectors/featureFlagsSelectors"; import { isGACEnabled } from "ee/utils/planHelpers"; import { getHasManageActionPermission } from "ee/utils/BusinessFeatures/permissionPageHelpers"; -import type { ChangeQueryPayload } from "actions/queryPaneActions"; +import type { ChangeQueryPayload } from "PluginActionEditor/store"; import { getApplicationByIdFromWorkspaces, getCurrentApplicationIdForCreateNewApp, diff --git a/app/client/src/selectors/apiPaneSelectors.ts b/app/client/src/selectors/apiPaneSelectors.ts deleted file mode 100644 index 92d53733783..00000000000 --- a/app/client/src/selectors/apiPaneSelectors.ts +++ /dev/null @@ -1,29 +0,0 @@ -import type { AppState } from "ee/reducers"; -import { createSelector } from "reselect"; -import { combinedPreviewModeSelector } from "./editorSelectors"; - -type GetFormData = ( - state: AppState, - apiId: string, -) => { label: string; value: string }; - -export const getDisplayFormat: GetFormData = (state, apiId) => { - const displayFormat = state.ui.apiPane.extraformData[apiId]; - - return displayFormat; -}; - -export const getApiPaneConfigSelectedTabIndex = (state: AppState) => - state.ui.apiPane.selectedConfigTabIndex; - -export const getIsRunning = (state: AppState, apiId: string) => - state.ui.apiPane.isRunning[apiId]; - -export const getApiPaneDebuggerState = (state: AppState) => - state.ui.apiPane.debugger; - -export const showApiPaneDebugger = createSelector( - (state) => state.ui.apiPane.debugger.open, - combinedPreviewModeSelector, - (isOpen, isPreview) => isOpen && !isPreview, -); diff --git a/app/client/src/selectors/editorSelectors.tsx b/app/client/src/selectors/editorSelectors.tsx index 355a1197c3d..ee3560dd503 100644 --- a/app/client/src/selectors/editorSelectors.tsx +++ b/app/client/src/selectors/editorSelectors.tsx @@ -27,8 +27,8 @@ import { } from "selectors/dataTreeSelectors"; import type { MainCanvasReduxState } from "reducers/uiReducers/mainCanvasReducer"; +import { getActionEditorSavingMap } from "PluginActionEditor/store"; import { - getApiPaneSavingMap, getCanvasWidgets, getJSCollections, } from "ee/selectors/entitiesSelector"; @@ -48,6 +48,7 @@ import { protectedModeSelector } from "./gitSyncSelectors"; import { getIsAnvilLayout } from "layoutSystems/anvil/integrations/selectors"; import { getCurrentApplication } from "ee/selectors/applicationSelectors"; import type { Page } from "entities/Page"; +import { objectKeys } from "@appsmith/utils"; const getIsDraggingOrResizing = (state: AppState) => state.ui.widgetDragResize.isResizing || state.ui.widgetDragResize.isDragging; @@ -76,7 +77,7 @@ export const getLoadingError = (state: AppState) => export const getIsPageSaving = createSelector( [ - getApiPaneSavingMap, + getActionEditorSavingMap, (state: AppState) => state.ui.jsPane.isSaving, (state: AppState) => state.ui.appTheming.isSaving, (state: AppState) => state.ui.applications.isSavingNavigationSetting, @@ -84,23 +85,23 @@ export const getIsPageSaving = createSelector( (state: AppState) => state.ui.editor.loadingStates.saving, ], ( - savingApis, + savingActions, savingJSObjects, isSavingAppTheme, isSavingNavigationSetting, isEditorSavingEntity, isEditorSaving, ) => { - const areApisSaving = Object.keys(savingApis).some( - (apiId) => savingApis[apiId], + const areActionsSaving = objectKeys(savingActions).some( + (actionId) => savingActions[actionId], ); - const areJsObjectsSaving = Object.keys(savingJSObjects).some( + const areJsObjectsSaving = objectKeys(savingJSObjects).some( (collectionId) => savingJSObjects[collectionId], ); return ( isEditorSavingEntity || - areApisSaving || + areActionsSaving || areJsObjectsSaving || isSavingAppTheme || isEditorSaving || diff --git a/app/client/src/selectors/queryPaneSelectors.ts b/app/client/src/selectors/queryPaneSelectors.ts deleted file mode 100644 index b87485f2be7..00000000000 --- a/app/client/src/selectors/queryPaneSelectors.ts +++ /dev/null @@ -1,38 +0,0 @@ -import type { AppState } from "ee/reducers"; -import { getCurrentPageId } from "./editorSelectors"; -import type { FocusEntityInfo } from "../navigation/FocusEntity"; -import { identifyEntityFromPath } from "../navigation/FocusEntity"; -import { getQueryEntityItemUrl } from "ee/pages/Editor/IDE/EditorPane/Query/utils"; -import { selectQuerySegmentEditorTabs } from "ee/selectors/appIDESelectors"; - -export const getQueryPaneConfigSelectedTabIndex = (state: AppState) => - state.ui.queryPane.selectedConfigTabIndex; - -export const getQueryPaneDebuggerState = (state: AppState) => - state.ui.queryPane.debugger; - -export const getQueryRunErrorMessage = (state: AppState, id: string) => { - const { runErrorMessage } = state.ui.queryPane; - - return runErrorMessage[id]; -}; - -export const getQueryIsRunning = (state: AppState, id: string): boolean => { - const { isRunning } = state.ui.queryPane; - - return !!isRunning[id]; -}; - -export const getLastQueryTab = ( - state: AppState, -): FocusEntityInfo | undefined => { - const tabs = selectQuerySegmentEditorTabs(state); - const pageId = getCurrentPageId(state); - - if (tabs.length) { - const url = getQueryEntityItemUrl(tabs[tabs.length - 1], pageId); - const urlWithoutQueryParams = url.split("?")[0]; - - return identifyEntityFromPath(urlWithoutQueryParams); - } -}; diff --git a/app/client/src/utils/replayHelpers.tsx b/app/client/src/utils/replayHelpers.tsx index 121235ec143..8b871586af6 100644 --- a/app/client/src/utils/replayHelpers.tsx +++ b/app/client/src/utils/replayHelpers.tsx @@ -16,8 +16,7 @@ import { ACTION_CONFIGURATION_CHANGED, } from "ee/constants/messages"; import { toast } from "@appsmith/ads"; -import { setApiPaneConfigSelectedTabIndex } from "../actions/apiPaneActions"; -import { API_EDITOR_TABS } from "../constants/ApiEditorConstants/CommonApiConstants"; +import { setPluginActionEditorSelectedTab } from "PluginActionEditor/store"; import store from "../store"; /** @@ -173,11 +172,7 @@ export function switchTab(replayId: string): boolean { if (element.getAttribute("data-state") == "active") return false; - // eslint-disable-next-line @typescript-eslint/ban-ts-comment - // @ts-ignore - const index = Object.values(API_EDITOR_TABS).indexOf(replayId); - - store.dispatch(setApiPaneConfigSelectedTabIndex(index)); + store.dispatch(setPluginActionEditorSelectedTab(replayId)); return true; }