Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

chore: Create query selector #37018

Merged
merged 6 commits into from
Oct 24, 2024
Merged

Conversation

jsartisan
Copy link
Contributor

@jsartisan jsartisan commented Oct 23, 2024

/ok-to-test tags="@tag.All"

This PR updates the WidgetQueryGeneratorForm to only allow queries so that it looks like a query selector. This is needed for chat widget where the widget can only bind Appsmith AI queries.

CleanShot 2024-10-23 at 12 30 32

PS: The above image is an example where TableWidget had allowedDatasourcestypes as "Mysql" ( just for testing )

Summary by CodeRabbit

Summary by CodeRabbit

  • New Features

    • Introduced a new dropdown variant "Connect to query" for improved datasource selection.
    • Enhanced handling of dynamic query options and datasource filtering based on context.
  • Improvements

    • Updated the Widget Query Generator Form to support new properties for better data management.
    • Improved control flow in dropdown options to ensure appropriate options are displayed based on the current context.
    • Enhanced the One Click Binding Control to utilize new properties for better interaction with the Widget Query Generator Form.
  • Bug Fixes

    • Refined logic for displaying datasource options, preventing unnecessary options from appearing.

Tip

🟢 🟢 🟢 All cypress tests have passed! 🎉 🎉 🎉
Workflow run: https://github.com/appsmithorg/appsmith/actions/runs/11493055126
Commit: d6e322c
Cypress dashboard.
Tags: @tag.All
Spec:


Thu, 24 Oct 2024 06:53:37 UTC

@jsartisan jsartisan requested review from ayushpahwa and a team as code owners October 23, 2024 06:54
@github-actions github-actions bot added the skip-changelog Adding this label to a PR prevents it from being listed in the changelog label Oct 23, 2024
Copy link
Contributor

coderabbitai bot commented Oct 23, 2024

Walkthrough

The changes in this pull request primarily involve modifications to the datasourceActions.ts file, particularly the createTempDatasourceFromForm function, which now accepts a more structured payload. Additionally, the DROPDOWN_VARIANT enum has been updated to include a new variant, and various hooks related to datasource options have been enhanced to better handle dynamic values and filtering based on context. The WidgetQueryGeneratorForm component has also been updated to incorporate new properties for improved data management.

Changes

File Change Summary
app/client/src/actions/datasourceActions.ts Updated createTempDatasourceFromForm to accept a structured payload and modified its return type accordingly.
app/client/src/components/editorComponents/WidgetQueryGeneratorForm/CommonControls/DatasourceDropdown/types.ts Added CONNECT_TO_QUERY variant to DROPDOWN_VARIANT enum.
app/client/src/components/editorComponents/WidgetQueryGeneratorForm/CommonControls/DatasourceDropdown/useSource/useConnectToOptions.tsx Enhanced getBindingValue and useConnectToOptions to handle dynamic values and new filtering logic.
app/client/src/components/editorComponents/WidgetQueryGeneratorForm/CommonControls/DatasourceDropdown/useSource/useDatasourceOptions.tsx Added conditional filtering based on datasourceDropdownVariant to control displayed datasource options.
app/client/src/components/editorComponents/WidgetQueryGeneratorForm/CommonControls/DatasourceDropdown/useSource/useOtherOptions.tsx Introduced logic to prevent displaying options based on datasourceDropdownVariant.
app/client/src/components/editorComponents/WidgetQueryGeneratorForm/index.tsx Updated WidgetQueryGeneratorFormContextType to include new properties for better data management.
app/client/src/components/propertyControls/OneClickBindingControl.tsx Updated to utilize WidgetQueryGeneratorFormContextType for type safety and to pass new props.
app/client/packages/dsl/src/index.ts Added export for isDynamicValue function from ./migrate/utils.

Possibly related PRs

Suggested labels

Enhancement, Bug, Low, Production, Widgets Product, Community Reported, Needs Triaging, Task, Widgets & Accelerators Pod

Poem

In the land of code where changes flow,
New structures rise, and options grow.
With dropdowns dancing, and hooks in play,
Data sources shine in a vibrant array.
So here's to the updates, both bold and bright,
Crafting a future that's pure delight! 🌟


Thank you for using CodeRabbit. We offer it for free to the OSS community and would appreciate your support in helping us grow. If you find it useful, would you consider giving us a shout-out on your favorite social media?

❤️ Share
🪧 Tips

Chat

There are 3 ways to chat with CodeRabbit:

  • Review comments: Directly reply to a review comment made by CodeRabbit. Example:
    • I pushed a fix in commit <commit_id>, please review it.
    • Generate unit testing code for this file.
    • Open a follow-up GitHub issue for this discussion.
  • Files and specific lines of code (under the "Files changed" tab): Tag @coderabbitai in a new review comment at the desired location with your query. Examples:
    • @coderabbitai generate unit testing code for this file.
    • @coderabbitai modularize this function.
  • PR comments: Tag @coderabbitai in a new PR comment to ask questions about the PR branch. For the best results, please provide a very specific query, as very limited context is provided in this mode. Examples:
    • @coderabbitai gather interesting stats about this repository and render them as a table. Additionally, render a pie chart showing the language distribution in the codebase.
    • @coderabbitai read src/utils.ts and generate unit testing code.
    • @coderabbitai read the files in the src/scheduler package and generate a class diagram using mermaid and a README in the markdown format.
    • @coderabbitai help me debug CodeRabbit configuration file.

Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments.

CodeRabbit Commands (Invoked using PR comments)

  • @coderabbitai pause to pause the reviews on a PR.
  • @coderabbitai resume to resume the paused reviews.
  • @coderabbitai review to trigger an incremental review. This is useful when automatic reviews are disabled for the repository.
  • @coderabbitai full review to do a full review from scratch and review all the files again.
  • @coderabbitai summary to regenerate the summary of the PR.
  • @coderabbitai resolve resolve all the CodeRabbit review comments.
  • @coderabbitai configuration to show the current CodeRabbit configuration for the repository.
  • @coderabbitai help to get help.

Other keywords and placeholders

  • Add @coderabbitai ignore anywhere in the PR description to prevent this PR from being reviewed.
  • Add @coderabbitai summary to generate the high-level summary at a specific location in the PR description.
  • Add @coderabbitai anywhere in the PR title to generate the title automatically.

Documentation and Community

  • Visit our Documentation for detailed information on how to use CodeRabbit.
  • Join our Discord Community to get help, request features, and share feedback.
  • Follow us on X/Twitter for updates and announcements.

Copy link

⚠️ Cyclic Dependency Check:

This PR has increased the number of cyclic dependencies by 2, when compared with the release branch.

Refer this document to identify the cyclic dependencies introduced by this PR.

@jsartisan jsartisan requested a review from riodeuno October 23, 2024 06:59
Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 4

🧹 Outside diff range and nitpick comments (3)
app/client/src/components/propertyControls/OneClickBindingControl.tsx (1)

75-77: Maintain consistent prop formatting.

While the functionality is correct, consider maintaining consistent prop formatting. The allowedDatasourceTypes prop uses multiple lines while getQueryBindingValue is on a single line.

-        allowedDatasourceTypes={
-          this.props.controlConfig?.allowedDatasourceTypes
-        }
+        allowedDatasourceTypes={this.props.controlConfig?.allowedDatasourceTypes}

Also applies to: 87-87

app/client/src/components/editorComponents/WidgetQueryGeneratorForm/CommonControls/DatasourceDropdown/useSource/useOtherOptions.tsx (1)

38-40: LGTM! Consider enhancing the comment.

The early return pattern is clean and efficient.

Consider making the comment more specific:

-// we don't want to show the options for connect to query variant
+// Skip additional options when in query-only mode to restrict functionality
app/client/src/components/editorComponents/WidgetQueryGeneratorForm/index.tsx (1)

116-117: Consider adding JSDoc documentation for the new props.

While the types are well-defined, adding JSDoc documentation would improve maintainability by explaining the purpose and expected values of these props.

+ /** Allowed types of datasources that can be selected */
  allowedDatasourceTypes?: WidgetQueryGeneratorFormContextType["allowedDatasourceTypes"];
+ /** Function to extract binding value from query data */
  getQueryBindingValue?: WidgetQueryGeneratorFormContextType["getQueryBindingValue"];
📜 Review details

Configuration used: .coderabbit.yaml
Review profile: CHILL

📥 Commits

Files that changed from the base of the PR and between 203b322 and 30ac2c7.

📒 Files selected for processing (7)
  • app/client/src/actions/datasourceActions.ts (1 hunks)
  • app/client/src/components/editorComponents/WidgetQueryGeneratorForm/CommonControls/DatasourceDropdown/types.ts (1 hunks)
  • app/client/src/components/editorComponents/WidgetQueryGeneratorForm/CommonControls/DatasourceDropdown/useSource/useConnectToOptions.tsx (6 hunks)
  • app/client/src/components/editorComponents/WidgetQueryGeneratorForm/CommonControls/DatasourceDropdown/useSource/useDatasourceOptions.tsx (2 hunks)
  • app/client/src/components/editorComponents/WidgetQueryGeneratorForm/CommonControls/DatasourceDropdown/useSource/useOtherOptions.tsx (1 hunks)
  • app/client/src/components/editorComponents/WidgetQueryGeneratorForm/index.tsx (6 hunks)
  • app/client/src/components/propertyControls/OneClickBindingControl.tsx (4 hunks)
🧰 Additional context used
🔇 Additional comments (11)
app/client/src/components/editorComponents/WidgetQueryGeneratorForm/CommonControls/DatasourceDropdown/types.ts (1)

4-4: LGTM! Verify switch statements.

The new enum variant follows consistent naming patterns and aligns with the PR objective.

Let's verify that all switch statements handling this enum are updated:

✅ Verification successful

The previous command might have failed because we need to first understand how the enum is used. Let's search for its definition and usages to verify the impact of the new variant.


The new enum variant is properly handled in all usages

The search results show that the new CONNECT_TO_QUERY variant is correctly handled in the codebase:

  • In useOtherOptions.tsx: Special case handling to return empty options
  • In useDatasourceOptions.tsx: Early return with empty arrays
  • No switch statements found that would require updates
  • All components using the enum are importing it correctly

The implementation is consistent with the intended behavior of restricting options for the chat widget.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Search for switch statements using DROPDOWN_VARIANT
ast-grep --pattern 'switch ($expr) { $$$ }' | rg -A 5 'DROPDOWN_VARIANT'

Length of output: 72


Script:

#!/bin/bash
# Let's try a different approach to find usages of the enum
# First, find the enum name
rg -l "enum.*DROPDOWN_VARIANT" 

# Then search for all usages of DROPDOWN_VARIANT
rg "DROPDOWN_VARIANT" -A 5

# Also search specifically for the new enum value
rg "CONNECT_TO_QUERY"

Length of output: 15061

app/client/src/components/propertyControls/OneClickBindingControl.tsx (2)

1-3: LGTM! Clean type import.

The type import is well-structured and follows TypeScript best practices.


116-117: LGTM! Well-structured type definitions.

The type definitions are properly inherited from WidgetQueryGeneratorFormContextType and correctly marked as optional.

app/client/src/components/editorComponents/WidgetQueryGeneratorForm/index.tsx (1)

20-21: LGTM! Clean type definitions and interface changes.

The exported interface with new optional properties provides good type safety for query-specific functionality.

Also applies to: 23-23, 57-58

app/client/src/components/editorComponents/WidgetQueryGeneratorForm/CommonControls/DatasourceDropdown/useSource/useConnectToOptions.tsx (4)

7-7: LGTM: Required imports added for new functionality.

The additions of getPlugins and isDynamicValue imports support the new filtering and dynamic value detection features.

Also applies to: 29-29


213-218: LGTM: Dynamic value handling added.

The addition of dynamic value detection improves the binding logic by properly handling dynamic expressions.


164-164: Verify context type definitions.

The new context variables are being used correctly, but let's ensure they're properly typed in the context definition.

#!/bin/bash
# Search for WidgetQueryGeneratorFormContext type definition
ast-grep --pattern 'interface WidgetQueryGeneratorFormContextType {
  $$$
  allowedDatasourceTypes?: $_
  $$$
}'

Also applies to: 166-166


192-204: Verify plugin filtering logic completeness.

The datasource type filtering looks correct but might need additional error handling.

Let's verify the plugin types being used:

✅ Verification successful

Let me gather more information about the plugin filtering logic to verify its completeness.

This will help us understand the Plugin interface structure and how plugins are handled in the codebase.

Let me also check for any existing error handling patterns:


Let me try again with corrected file type flags:


Let me try one final search without file type restrictions:


Plugin filtering logic is complete and safe

The current implementation is correct and includes proper error handling:

  • The allowedDatasourceTypes check is optional (wrapped in an if statement)
  • The plugin filtering has a null-safe implementation (wrapped in if(plugin))
  • The filtering maintains the original queries if no matching plugin is found
  • The code follows the established pattern seen across the codebase for plugin filtering
🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Search for plugin type definitions and usage
rg -A 2 "allowedDatasourceTypes" --type typescript

Length of output: 4258


Script:

#!/bin/bash
# Search for plugin type definitions and related error handling
ast-grep --pattern 'interface Plugin {
  $$$
  name: $_
  id: $_
  $$$
}'

# Check how plugins are used in the context
rg -B 2 -A 2 "plugins\.find\(" --type typescript

Length of output: 161


Script:

#!/bin/bash
# Look for error handling patterns around plugin filtering
rg -B 2 -A 2 "filteredQueries = filteredQueries\.filter" --type typescript

Length of output: 111


Script:

#!/bin/bash
# Search for plugin type definitions and related error handling
ast-grep --pattern 'interface Plugin {
  $$$
  name: $_
  id: $_
  $$$
}'

# Check how plugins are used in the context
rg -B 2 -A 2 'plugins\.find\(' --type ts --type tsx

# Look for error handling patterns around plugin filtering
rg -B 2 -A 2 'filteredQueries = filteredQueries\.filter' --type ts --type tsx

# Check for any null checks or error handling around plugin usage
rg -A 2 'if \(!plugin\)' --type ts --type tsx

Length of output: 341


Script:

#!/bin/bash
# Search for plugin usage patterns
rg -B 2 -A 2 'plugins\.find\('

# Look for error handling patterns
rg -A 2 'if \(!plugin\)'

# Check the entire file content for context
fd -g "*useConnectToOptions.tsx" -x cat {}

Length of output: 25089

app/client/src/components/editorComponents/WidgetQueryGeneratorForm/CommonControls/DatasourceDropdown/useSource/useDatasourceOptions.tsx (3)

37-37: LGTM!

Clean import addition that aligns with the component's needs.


61-65: Verify impact on dependent components.

The early return for CONNECT_TO_QUERY variant effectively disables datasource selection. While this aligns with the PR objectives, we should verify that dependent components handle empty options gracefully.


45-46: Verify context provider implementation.

The context usage looks good, but let's verify the provider implementation.

✅ Verification successful

Let me gather more information about the context implementation to verify if datasourceDropdownVariant is properly included.


Let me try a different approach to find the context type and implementation.


Let me check one final thing to verify if datasourceDropdownVariant is properly defined in the context type.


Let me try one last search with a different pattern to find the context value definition.


Context implementation is properly defined

The datasourceDropdownVariant property is correctly defined in the WidgetQueryGeneratorFormContextType interface (line 54) as type DROPDOWN_VARIANT, making the context usage in the reviewed code valid and type-safe.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Search for the WidgetQueryGeneratorFormContext provider implementation
ast-grep --pattern 'const WidgetQueryGeneratorFormContext = React.createContext<$_>($_)'

Length of output: 553


Script:

#!/bin/bash
# Check the context type definition and default value
rg -A 10 "type WidgetQueryGeneratorFormContextType" app/client/src/components/editorComponents/WidgetQueryGeneratorForm/index.tsx

# Also check where the context value is provided
ast-grep --pattern 'value={$_}' app/client/src/components/editorComponents/WidgetQueryGeneratorForm/index.tsx

Length of output: 243


Script:

#!/bin/bash
# Search for type definition and context value with more context
rg -B 2 -A 15 "WidgetQueryGeneratorFormContext" app/client/src/components/editorComponents/WidgetQueryGeneratorForm/index.tsx

# Also check for the interface or type definition
rg "interface.*WidgetQueryGeneratorFormContextType" app/client/src/components/editorComponents/WidgetQueryGeneratorForm/index.tsx

Length of output: 2467


Script:

#!/bin/bash
# Get the complete context type definition with more lines
rg -A 20 "interface WidgetQueryGeneratorFormContextType" app/client/src/components/editorComponents/WidgetQueryGeneratorForm/index.tsx

# Also check where contextValue is defined
rg -B 5 "const contextValue = {" app/client/src/components/editorComponents/WidgetQueryGeneratorForm/index.tsx

Length of output: 936


Script:

#!/bin/bash
# Search for contextValue assignment with proper escaping
rg -B 5 "contextValue =" app/client/src/components/editorComponents/WidgetQueryGeneratorForm/index.tsx

# Also get the complete interface definition
ast-grep --pattern 'interface WidgetQueryGeneratorFormContextType {
  $$$
}'

Length of output: 4445

Comment on lines +35 to +38
export const createTempDatasourceFromForm = (payload: {
pluginId: string;
type: PluginType;
}) => {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

💡 Codebase verification

Type change needs to be reverted - saga expects broader type

The saga implementation expects CreateDatasourceConfig | Datasource type but the action creator now accepts a narrower type with just pluginId and type. This mismatch will cause runtime issues as the saga merges additional properties from the payload.

Key issues:

  • The saga uses actionPayload.payload properties beyond just pluginId and type
  • The payload is merged with initialPayload at line 1098, expecting additional configuration
  • All callers are passing only the restricted payload which may lead to incomplete datasource creation
🔗 Analysis chain

Type-safe payload structure improvement.

The new payload structure with explicit pluginId and type properties improves type safety and better reflects the function's purpose in creating temporary datasources for queries.

Let's verify the usage of this function to ensure all callers have been updated:


Let me gather more information about the saga implementation to understand how the new payload type is handled.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Search for createTempDatasourceFromForm usage
rg "createTempDatasourceFromForm" -A 2

Length of output: 6009


Script:

#!/bin/bash
# Check the saga implementation to see how it handles the new payload type
ast-grep --pattern 'function* createTempDatasourceFromFormSaga($$$) {
  $$$
}'

Length of output: 5849

@@ -77,17 +79,19 @@ export function sortQueries(
export function getBindingValue(
widget: WidgetProps,
query: ActionData | ModuleInstanceData,
getQueryBindingValue: (query: ActionData | ModuleInstanceData) => string = (
Copy link
Contributor Author

@jsartisan jsartisan Oct 23, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

For chat widget, we don't want ${query.config.name}.data, we just want ${query.config.name}. So updated this function so that binding can be controlled by widget.

Copy link

⚠️ Cyclic Dependency Check:

This PR has increased the number of cyclic dependencies by 2, when compared with the release branch.

Refer this document to identify the cyclic dependencies introduced by this PR.

Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 1

🧹 Outside diff range and nitpick comments (1)
app/client/src/components/editorComponents/WidgetQueryGeneratorForm/CommonControls/DatasourceDropdown/useSource/types.ts (1)

4-6: Consider adding JSDoc for better documentation.

The type definition is clean and follows best practices. Consider adding JSDoc to document the purpose and expected return format.

+/**
+ * Function type for generating binding value string from query data
+ * @param query - The query data from either an action or module instance
+ * @returns A string representation of the binding value
+ */
 export type GetQueryBindingValue = (
   query: ActionData | ModuleInstanceData,
 ) => string;
📜 Review details

Configuration used: .coderabbit.yaml
Review profile: CHILL

📥 Commits

Files that changed from the base of the PR and between 30ac2c7 and 3845646.

📒 Files selected for processing (3)
  • app/client/src/components/editorComponents/WidgetQueryGeneratorForm/CommonControls/DatasourceDropdown/useSource/types.ts (1 hunks)
  • app/client/src/components/editorComponents/WidgetQueryGeneratorForm/CommonControls/DatasourceDropdown/useSource/useConnectToOptions.tsx (6 hunks)
  • app/client/src/components/editorComponents/WidgetQueryGeneratorForm/index.tsx (6 hunks)
🚧 Files skipped from review as they are similar to previous changes (1)
  • app/client/src/components/editorComponents/WidgetQueryGeneratorForm/index.tsx
🧰 Additional context used
🔇 Additional comments (4)
app/client/src/components/editorComponents/WidgetQueryGeneratorForm/CommonControls/DatasourceDropdown/useSource/types.ts (1)

1-2: LGTM! Clean imports using type imports.

app/client/src/components/editorComponents/WidgetQueryGeneratorForm/CommonControls/DatasourceDropdown/useSource/useConnectToOptions.tsx (3)

7-7: LGTM: Clean import additions

The new imports for plugins and dynamic value utilities are well-organized and necessary for the enhanced functionality.

Also applies to: 29-30


83-84: Previous review comment about null checks is still applicable

Also applies to: 88-88, 94-94


215-218: LGTM: Proper dynamic value handling

The addition of dynamic value checking enhances the binding logic while maintaining existing functionality.

Comment on lines 192 to 208
// filter query based on allowedDatasourceType
if (allowedDatasourceTypes) {
const plugin = plugins.find((plugin) =>
allowedDatasourceTypes.includes(plugin.name),
);

if (plugin) {
filteredQueries = filteredQueries.filter(
(query) => query.config.pluginId === plugin.id,
);
}
}

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

⚠️ Potential issue

Enhance allowedDatasourceTypes filtering logic

The current implementation might not handle multiple allowed datasource types correctly as it only checks for the first matching plugin.

Consider this more robust implementation:

- const plugin = plugins.find((plugin) =>
-   allowedDatasourceTypes.includes(plugin.name),
- );
- 
- if (plugin) {
-   filteredQueries = filteredQueries.filter(
-     (query) => query.config.pluginId === plugin.id,
-   );
- }
+ const allowedPluginIds = plugins
+   .filter((plugin) => allowedDatasourceTypes.includes(plugin.name))
+   .map((plugin) => plugin.id);
+ 
+ if (allowedPluginIds.length > 0) {
+   filteredQueries = filteredQueries.filter((query) =>
+     allowedPluginIds.includes(query.config.pluginId),
+   );
+ }
📝 Committable suggestion

‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation. Thoroughly test & benchmark the code to ensure it meets the requirements.

Suggested change
// filter query based on allowedDatasourceType
if (allowedDatasourceTypes) {
const plugin = plugins.find((plugin) =>
allowedDatasourceTypes.includes(plugin.name),
);
if (plugin) {
filteredQueries = filteredQueries.filter(
(query) => query.config.pluginId === plugin.id,
);
}
}
// filter query based on allowedDatasourceType
if (allowedDatasourceTypes) {
const allowedPluginIds = plugins
.filter((plugin) => allowedDatasourceTypes.includes(plugin.name))
.map((plugin) => plugin.id);
if (allowedPluginIds.length > 0) {
filteredQueries = filteredQueries.filter((query) =>
allowedPluginIds.includes(query.config.pluginId),
);
}
}

@jsartisan jsartisan requested a review from a team as a code owner October 23, 2024 10:13
Copy link

⚠️ Cyclic Dependency Check:

This PR has increased the number of cyclic dependencies by 1, when compared with the release branch.

Refer this document to identify the cyclic dependencies introduced by this PR.

Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 0

🧹 Outside diff range and nitpick comments (3)
app/client/src/components/editorComponents/WidgetQueryGeneratorForm/index.tsx (1)

57-58: Consider adding JSDoc comments for the new interface properties.

The new properties would benefit from documentation explaining their purpose and expected values.

+ /** Array of allowed datasource types to filter available options */
  allowedDatasourceTypes?: string[];
+ /** Function to generate binding value from query data */
  getQueryBindingValue?: (query: ActionData | ModuleInstanceData) => string;
app/client/src/components/editorComponents/WidgetQueryGeneratorForm/CommonControls/DatasourceDropdown/useSource/useConnectToOptions.tsx (2)

215-218: Add type safety for the value parameter.

Consider adding type annotation for better type safety:

-  onSelect: function (value: string, valueOption?: DropdownOptionType) {
+  onSelect: function (value: string | undefined, valueOption?: DropdownOptionType) {
-    const isDynamic = isDynamicValue(value);
+    const isDynamic = value ? isDynamicValue(value) : false;

164-164: Add type validation for allowedDatasourceTypes.

Consider adding runtime type validation for the allowedDatasourceTypes context value to prevent potential runtime errors.

if (allowedDatasourceTypes && !Array.isArray(allowedDatasourceTypes)) {
  console.warn('allowedDatasourceTypes should be an array');
  return filteredQueries;
}

Also applies to: 166-166

📜 Review details

Configuration used: .coderabbit.yaml
Review profile: CHILL

📥 Commits

Files that changed from the base of the PR and between 3845646 and e5fe6d6.

📒 Files selected for processing (3)
  • app/client/packages/dsl/src/index.ts (1 hunks)
  • app/client/src/components/editorComponents/WidgetQueryGeneratorForm/CommonControls/DatasourceDropdown/useSource/useConnectToOptions.tsx (6 hunks)
  • app/client/src/components/editorComponents/WidgetQueryGeneratorForm/index.tsx (6 hunks)
🧰 Additional context used
🔇 Additional comments (6)
app/client/packages/dsl/src/index.ts (1)

14-14: LGTM! Verify function export.

The new export follows the established pattern and is appropriately grouped with other migrate-related exports.

✅ Verification successful

The previous ast-grep pattern didn't yield results, so I'm trying a different approach:

  1. First, locating the exact utils file path
  2. Then searching for isDynamicValue with context to verify its existence and export status

This will help us confirm whether the function exists and is properly exported.


Export verified and correctly implemented

The isDynamicValue function exists in app/client/packages/dsl/src/migrate/utils.ts and is properly exported as a const arrow function. It's actively used across multiple migration files for checking dynamic bindings, confirming its utility and proper implementation.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Verify the isDynamicValue function exists in the utils file
ast-grep --pattern 'export function isDynamicValue($_) { $$$ }'

Length of output: 65


Script:

#!/bin/bash
# Let's try a different approach to locate the isDynamicValue function
# First, let's find the utils file in the migrate directory
fd utils.ts -p app/client/packages/dsl/src/migrate

# Then let's use ripgrep to search for isDynamicValue with context
rg "isDynamicValue" -A 3 app/client/packages/dsl/src/migrate

Length of output: 8198

app/client/src/components/editorComponents/WidgetQueryGeneratorForm/index.tsx (4)

20-21: LGTM: Clean type imports and interface export.

The new imports and interface export changes look good. Making the interface public is appropriate since it's needed by external components.

Also applies to: 23-23


116-117: LGTM: Props interface properly extends context types.

Good practice using the context type definitions for the props to maintain type consistency.


257-258: Previous optimization comment still applies.

The existing review comment about optimizing useMemo dependencies is still valid. The new properties should also be considered for optimization.

Also applies to: 278-280


129-129: Verify the impact of optional props.

The new optional props might affect the component's behavior when undefined. Consider adding default values or handling undefined cases explicitly.

Also applies to: 134-134

app/client/src/components/editorComponents/WidgetQueryGeneratorForm/CommonControls/DatasourceDropdown/useSource/useConnectToOptions.tsx (1)

29-29: LGTM: Clean function signature update with proper defaults.

The addition of the getQueryBindingValue parameter provides good flexibility while maintaining backward compatibility.

Also applies to: 82-84

@@ -32,9 +32,10 @@ export const createDatasourceFromForm = (
};
};

export const createTempDatasourceFromForm = (
Copy link
Contributor Author

@jsartisan jsartisan Oct 23, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Types are a little weird in data source code. The code just uses plugin id and type in the function, yet we pass Datasource | CreateDatasourceConfig here. I think this is done just to satisfy the typescript.

@riodeuno
Copy link
Contributor

@jsartisan What happens if the Appsmith AI Datasource doesn't exist? Or if the user want's to use their own datasource?

@jsartisan
Copy link
Contributor Author

jsartisan commented Oct 23, 2024

@riodeuno

What happens if the Appsmith AI Datasource doesn't exist?

You will see an empty dropdown in that case. That state is not properly handled in UI as of now. Btw, as soon as you drop the chat widget, we create a new Appsmith AI query ( @KelvinOm do we also create datasource if it does not exists? )

if the user wants to use their own datasource?

This case won't happen. the AIChat widget explicitly require AppsmithAI datasoruce cause that datasources is handling lot of stuff under the hood. So, it can't be binded with other datasources like MySQL, postgres.

The way the widget tells that it only needs AppsmithAI is by specifying in the propertyPaneConfig like this:

{
	propertyName: "chatQuery",
	helpText: "The query to be used for the chat",
	label: "Chat Query",
	controlType: "ONE_CLICK_BINDING_CONTROL",
	controlConfig: {
	  showEditFieldsModal: false, 
	  datasourceDropdownVariant: DROPDOWN_VARIANT.CONNECT_TO_QUERY
	  excludePrimaryColumnFromQueryGeneration: true,
	  isConnectableToWidget: false,
	  allowedDatasourceTypes: [PluginName.APPSMITH_AI], // <-------------------
	  getQueryBindingValue: (query: ActionData | ModuleInstanceData) => {
	    return query.config.name;
	  },
	},
}

@KelvinOm
Copy link
Collaborator

do we also create datasource if it does not exists?

@jsartisan Yes, if datasource is not exists, then we create it, if there is one, we add query to it.

@jsartisan jsartisan added the ok-to-test Required label for CI label Oct 23, 2024
@jsartisan jsartisan force-pushed the chore/create-query-selector-control branch from 58b3bae to d6e322c Compare October 24, 2024 05:14
Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 1

📜 Review details

Configuration used: .coderabbit.yaml
Review profile: CHILL

📥 Commits

Files that changed from the base of the PR and between 58b3bae and d6e322c.

📒 Files selected for processing (8)
  • app/client/packages/dsl/src/index.ts (1 hunks)
  • app/client/src/actions/datasourceActions.ts (1 hunks)
  • app/client/src/components/editorComponents/WidgetQueryGeneratorForm/CommonControls/DatasourceDropdown/types.ts (1 hunks)
  • app/client/src/components/editorComponents/WidgetQueryGeneratorForm/CommonControls/DatasourceDropdown/useSource/useConnectToOptions.tsx (6 hunks)
  • app/client/src/components/editorComponents/WidgetQueryGeneratorForm/CommonControls/DatasourceDropdown/useSource/useDatasourceOptions.tsx (2 hunks)
  • app/client/src/components/editorComponents/WidgetQueryGeneratorForm/CommonControls/DatasourceDropdown/useSource/useOtherOptions.tsx (1 hunks)
  • app/client/src/components/editorComponents/WidgetQueryGeneratorForm/index.tsx (6 hunks)
  • app/client/src/components/propertyControls/OneClickBindingControl.tsx (4 hunks)
🚧 Files skipped from review as they are similar to previous changes (7)
  • app/client/packages/dsl/src/index.ts
  • app/client/src/actions/datasourceActions.ts
  • app/client/src/components/editorComponents/WidgetQueryGeneratorForm/CommonControls/DatasourceDropdown/types.ts
  • app/client/src/components/editorComponents/WidgetQueryGeneratorForm/CommonControls/DatasourceDropdown/useSource/useConnectToOptions.tsx
  • app/client/src/components/editorComponents/WidgetQueryGeneratorForm/CommonControls/DatasourceDropdown/useSource/useDatasourceOptions.tsx
  • app/client/src/components/editorComponents/WidgetQueryGeneratorForm/index.tsx
  • app/client/src/components/propertyControls/OneClickBindingControl.tsx
🔇 Additional comments (2)
app/client/src/components/editorComponents/WidgetQueryGeneratorForm/CommonControls/DatasourceDropdown/useSource/useOtherOptions.tsx (2)

38-40: LGTM! Early return pattern improves readability.

The early return for CONNECT_TO_QUERY variant aligns with the PR's objective to restrict functionality for the chat widget.


57-68: Previous review comment about consolidating analytics events is still applicable.

Comment on lines +42 to +70
const options = [];

const entryPoint = DatasourceCreateEntryPoints.ONE_CLICK_BINDING;
options.push({
icon: <Icon name="plus" size="md" />,
id: "Connect new datasource",
label: "Connect new datasource",
value: "Connect new datasource",
onSelect: () => {
history.push(
integrationEditorURL({
basePageId,
selectedTab: INTEGRATION_TABS.NEW,
}),
);

AnalyticsUtil.logEvent("NAVIGATE_TO_CREATE_NEW_DATASOURCE_PAGE", {
entryPoint,
});
},
AnalyticsUtil.logEvent("BIND_OTHER_ACTIONS", {
widgetName: widget.widgetName,
widgetType: widget.type,
propertyName: propertyName,
selectedAction: "Connect new datasource",
});

const entryPoint = DatasourceCreateEntryPoints.ONE_CLICK_BINDING;

AnalyticsUtil.logEvent("NAVIGATE_TO_CREATE_NEW_DATASOURCE_PAGE", {
entryPoint,
});
},
];
});
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

🛠️ Refactor suggestion

Consider extracting the connect datasource option to a separate function.

The options array initialization and the connect datasource option configuration could be extracted to improve readability and maintainability.

+ const getConnectDatasourceOption = (basePageId: string) => ({
+   icon: <Icon name="plus" size="md" />,
+   id: "Connect new datasource",
+   label: "Connect new datasource",
+   value: "Connect new datasource",
+   onSelect: () => {
+     history.push(
+       integrationEditorURL({
+         basePageId,
+         selectedTab: INTEGRATION_TABS.NEW,
+       }),
+     );
+     // Analytics events here
+   },
+ });

  const otherOptions = useMemo(() => {
    if (datasourceDropdownVariant === DROPDOWN_VARIANT.CONNECT_TO_QUERY)
      return [];

    const options = [];
-   options.push({
-     icon: <Icon name="plus" size="md" />,
-     // ... rest of the configuration
-   });
+   options.push(getConnectDatasourceOption(basePageId));

Committable suggestion was skipped due to low confidence.

@jsartisan jsartisan merged commit 23a5772 into release Oct 24, 2024
85 checks passed
@jsartisan jsartisan deleted the chore/create-query-selector-control branch October 24, 2024 07:49
@coderabbitai coderabbitai bot mentioned this pull request Oct 25, 2024
2 tasks
@coderabbitai coderabbitai bot mentioned this pull request Nov 14, 2024
2 tasks
github-actions bot pushed a commit to Zeral-Zhang/appsmith that referenced this pull request Nov 20, 2024
/ok-to-test tags="@tag.All"

This PR updates the WidgetQueryGeneratorForm to only allow queries so
that it looks like a query selector. This is needed for chat widget
where the widget can only bind Appsmith AI queries.

![CleanShot 2024-10-23 at 12 30
32](https://github.com/user-attachments/assets/c1237435-3e9e-4cfd-8c2e-c762c76089bd)

PS: The above image is an example where TableWidget had
allowedDatasourcestypes as "Mysql" ( just for testing )

<!-- This is an auto-generated comment: release notes by coderabbit.ai
-->
## Summary by CodeRabbit

## Summary by CodeRabbit

- **New Features**
- Introduced a new dropdown variant "Connect to query" for improved
datasource selection.
- Enhanced handling of dynamic query options and datasource filtering
based on context.

- **Improvements**
- Updated the Widget Query Generator Form to support new properties for
better data management.
- Improved control flow in dropdown options to ensure appropriate
options are displayed based on the current context.
- Enhanced the One Click Binding Control to utilize new properties for
better interaction with the Widget Query Generator Form.

- **Bug Fixes**
- Refined logic for displaying datasource options, preventing
unnecessary options from appearing.
<!-- end of auto-generated comment: release notes by coderabbit.ai -->

<!-- This is an auto-generated comment: Cypress test results  -->
> [!TIP]
> 🟢 🟢 🟢 All cypress tests have passed! 🎉 🎉 🎉
> Workflow run:
<https://github.com/appsmithorg/appsmith/actions/runs/11493055126>
> Commit: d6e322c
> <a
href="https://internal.appsmith.com/app/cypress-dashboard/rundetails-65890b3c81d7400d08fa9ee5?branch=master&workflowId=11493055126&attempt=2"
target="_blank">Cypress dashboard</a>.
> Tags: `@tag.All`
> Spec:
> <hr>Thu, 24 Oct 2024 06:53:37 UTC
<!-- end of auto-generated comment: Cypress test results  -->
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
ok-to-test Required label for CI skip-changelog Adding this label to a PR prevents it from being listed in the changelog
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants