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

[BUG] getOne method doesn't use meta.gqlVariables in @refinedev/hasura #6374

Closed
vrrashkov opened this issue Sep 28, 2024 · 6 comments · Fixed by #6379, #6336 or #6404
Closed

[BUG] getOne method doesn't use meta.gqlVariables in @refinedev/hasura #6374

vrrashkov opened this issue Sep 28, 2024 · 6 comments · Fixed by #6379, #6336 or #6404
Assignees
Labels
bug Something isn't working

Comments

@vrrashkov
Copy link

vrrashkov commented Sep 28, 2024

Describe the bug

Trying to pass custom variables other than ID to a query is not working. Here is the code that I have. I am using useForm and what in my getOne query to have extra variable not only the ID.

const { formProps: editFormProps, saveButtonProps: editSaveButtonProps } =
  useForm<
    GetFields<UpdateSettingValueMutation>,
    HttpError,
    GetVariables<UpdateSettingValueMutationVariables>
  >({
    action: "edit",
    resource: "settings",
    id: editingId?.toString(),
    meta: {
      gqlQuery: SETTINGS_WITH_VALUES_DATA_QUERY,
      gqlMutation: UPDATE_SETTING_VALUES_MUTATION,
      gqlVariables: {
        extraValue: 1,
      },
    },
    queryMeta: {
      meta: {
        extraValue: 1,
      },
      gqlVariables: {
        extraValue: 1,
      },
    },
    queryOptions: {
      meta: {
        extraValue: 1,
      },
    },
    mutationMode: "pessimistic",
    onMutationSuccess: () => {
      setEditingId(null);
    },
  });

My graphql is this:

export const SETTINGS_WITH_VALUES_DATA_QUERY = gql`
  query SettingsWithValuesDataOne($id: ID!, $extraValue: Int!) {
    setting(id: $id, extraValue: $extraValue) {
        ...SettingsWithValuesDataFields
    }
  }
  ${SETTINGS_WITH_VALUES_DATA_FIELDS},
`;

I am not sure if I am missing something from the documentation but i have tried multiple ways as you can see in the above code and nothing seems to be helping it always sends only variables : {id: "1"} , the extraValue i am trying to pass its not there.

Steps To Reproduce

Test with the code provided

Expected behavior

Custom variables should be included

Packages

  • @refinedev/antd

Additional Context

No response

@vrrashkov vrrashkov added the bug Something isn't working label Sep 28, 2024
@vrrashkov
Copy link
Author

vrrashkov commented Sep 28, 2024

I am trying to do something more simple like this and it still doesnt work it only passes the ID, nothing changes there is no extraValue.

const { data, isLoading, isError } = useOne({
  resource: "settings",
  id: 1,
  meta: {
    gqlQuery: SETTINGS_WITH_VALUES_DATA_QUERY,
    variables: {
      extraValue: 2,
    },
    gqlVariables: {
      extraValue: 2,
    },
  },
  queryOptions: {
    enabled: true,
  },
});

Inside my DataProvider i have this:

   getOne: async (...args) => {
      try {
        return await dataProvider.getOne(...args);
      } catch (error) {
        throw error;
      }
    },

I managed to pass variables by changing it to this:

    getOne: async ({ resource, id, meta }) => {
      try {
        // Extract custom variables from meta
        const customVariables = meta?.variables || {};

        const variables = {
          id,
          ...customVariables,
        };

        const query = meta?.gqlQuery!;

        const response = await client.request<BaseRecord>(query, variables);

        return {
          data: response[meta?.operation!],
        };
      } catch (error) {
        throw error;
      }
    },

But is this correct? I dont want to write custom logic for something that already exists like passing a custom varaible?

@aliemir
Copy link
Member

aliemir commented Sep 29, 2024

Hey @vrrashkov sorry for the issue! Looks like the PR #6222 missed updating the getOne method for meta.gqlVariables. You can see that getMany, getList and mutation methods have the necessary implementation but getOne misses it. This is an issue with @refinedev/hasura rather than @refinedev/antd.

We'll be happy to see your contribution, if you can prepare a PR with the fix. Until this is fixed and released, you can stick with your workaround for the getOne.

I'll update the issue title since this is not related with @refinedev/antd 🙏

@aliemir aliemir changed the title [BUG] Antd useForm not able to set custom Variable in gql query [BUG] getOne method doesn't use meta.gqlVariables in @refinedev/hasura Sep 29, 2024
@BatuhanW BatuhanW self-assigned this Sep 30, 2024
@BatuhanW BatuhanW linked a pull request Sep 30, 2024 that will close this issue
5 tasks
@BatuhanW BatuhanW linked a pull request Oct 14, 2024 that will close this issue
@aliemir aliemir linked a pull request Oct 14, 2024 that will close this issue
@vrrashkov
Copy link
Author

Hey, i tried the new version with the fix, updated to this version "@refinedev/graphql": "^7.0.0", but i am still experiencing the same behaviour. But the thing is I am not using hasura package, the provider i am using is from here.

import { BaseRecord, DataProvider } from "@refinedev/core";

@BatuhanW
Copy link
Member

Hey @vrrashkov can you try passing 2nd parameter, getOne: { buildVariables: (params) => ...your logic } here? Because we are now destructuring meta?.gqlVariables into variables part.

https://github.com/refinedev/refine/blob/master/packages/graphql/src/dataProvider/options.ts

@vrrashkov
Copy link
Author

vrrashkov commented Oct 24, 2024

Hey, I have not tried to check the getOne approach because my main uses are from useForm like this, I do not see buildVariables parameter there

const { formProps: editFormProps, saveButtonProps: editSaveButtonProps } =
    useForm<
      GetFields<UpdateSettingValueMutation>,
      HttpError,
      GetVariables<UpdateSettingValueMutationVariables>
    >({
      action: "edit",
      resource: "settings",
      id: editingId?.toString(),
      meta: {
        gqlQuery: SETTINGS_WITH_VALUES_DATA_QUERY,
        gqlMutation: UPDATE_SETTING_VALUES_MUTATION,
        gqlVariables: {
          environmentId: parseInt(environment.id),
        },
        variables: {
          environmentId: parseInt(environment.id),
        },
      },
      queryMeta: {
        variables: {
          environmentId: parseInt(environment.id),
        },
      },
      queryOptions: {
        enabled: !!editingId,
      },
      mutationMode: "pessimistic",
      onMutationSuccess: () => {
        setEditingId(null);
      },
    });`

EDIT: I see that the provider there is different than what i am using so will try to change that and get back to you if it works.

@vrrashkov
Copy link
Author

@BatuhanW I changed the provider to use urql and now this works as expected. Also this provider look much easier to work with than what i had before :D Thank you!

      meta: {
        gqlQuery: SETTINGS_WITH_VALUES_DATA_QUERY,
        gqlMutation: UPDATE_SETTING_VALUES_MUTATION,
        gqlVariables: {
          environmentId: parseInt(environment.id),
        },
      },

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
3 participants