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

General feedback about Strapi 5 support #434

Open
olrtg opened this issue Oct 10, 2024 · 19 comments
Open

General feedback about Strapi 5 support #434

olrtg opened this issue Oct 10, 2024 · 19 comments
Labels
question Further information is requested

Comments

@olrtg
Copy link
Contributor

olrtg commented Oct 10, 2024

I'm creating this general issue to collect some feedback from other people about the work done in past PRs to support Strapi 5 and how we can improve it. If you want it, maybe I create separate issues to track these individually.

After installing the module myself and using v5 for a while in a personal project I've found the following:

  • Maybe It'll be good to document that if people want to try v5 out, aside from switching to the edge version, they should also set the version manually in the nuxt.config.ts file:
    export default defineNuxtConfig({
      strapi: {
        version: 'v5',
      },
    })
  • For some reason, if you pass an interface instead of a type as the generic type of the useStrapi<T>() composable it will not give you the correct types. This didn't happen to me on the v4 composable and I don't even know if this is fixable (because it seems to be a TS thing) but I guess at least we should tell people to use types instead of interfaces in the docs, or even better, try to find a workaround. In my opinion, users should not be bothered with this and they should be able to use both if they want. I've created a small repro here: https://tsplay.dev/WYxeQm.
  • If I do a find request to a collection to query all elements, the locale key has a null value, which differs from the current type locale?: string, I think it should be locale?: string | null instead:
    Image

For now, that's what I've found. Let me know what you think!

Related PRs:

@olrtg olrtg added the question Further information is requested label Oct 10, 2024
@reslear
Copy link
Contributor

reslear commented Oct 15, 2024

  1. maybe
  2. same
  3. agree

also need export StrapiLocale for setting out request
instead types error import type { StrapiLocale } from '@nuxtjs/strapi/dist/runtime'

@BayBreezy
Copy link
Contributor

  1. Yes, the fact that v5 is not the default should be somewhere in the docs. Could be tricky as the default version of Strapi is now 5. The module has not been fully tested for v5.
  2. I am no TS expert so I am not even sure how to approach this 🤣. That is a weird one tho. Why would types work and not interfaces?
  3. Correct! locale can be null.

@reslear would the StrapiLocale be a composable? Not sure what you mean there.

@benjamincanac
Copy link
Member

As you guys might know, I'm not actively maintaining this repository. Would you mind telling me once everything is good so I can release a major version?

@reslear
Copy link
Contributor

reslear commented Oct 16, 2024

✅ 1, 3 - fixed

  1. i was thinking maybe we could just do it like v4 without generics ?
    like data | data []

  2. I'm also thinking of exporting types like

    import type { StrapiLocale } from '#nuxt-strapi/types';
  3. I also keep the same types between projects, I suggest adding StrapiDynamicZone, StrapiComponent, StrapiImage, StrapiSeo.

  4. For dynamic editor I suggest to add information about

@olrtg
Copy link
Contributor Author

olrtg commented Oct 16, 2024

@reslear 2 sounds great to me. About the other points idk. I just started using this module and Strapi, so I don't know much yet.

@Zellokr
Copy link

Zellokr commented Oct 17, 2024

Hi guys, I'm trying to use useStrapi module (V5), nuxt can't find useStrapi, however I can use useStrapiUser, UseStrapiToken, useStrapiAuth, etc... do you know why?

Copy link
Member

@Zellokr Do you use the latest Edge version?

@Zellokr
Copy link

Zellokr commented Oct 17, 2024

Yes, as devDepencencies Image

Copy link
Member

Could you try npm:@nuxtjs/[email protected] (latest release), sometimes the latest tag don't work that well.

@Zellokr
Copy link

Zellokr commented Oct 17, 2024

It works, however type error "V5" in nuxt.config.ts still appears.

Thank you! :)

@MarijnFK
Copy link

MarijnFK commented Oct 23, 2024

✅ 1, 3 - fixed

  1. i was thinking maybe we could just do it like v4 without generics ?
    like data | data []

  2. I'm also thinking of exporting types like
    import type { StrapiLocale } from '#nuxt-strapi/types';

  3. I also keep the same types between projects, I suggest adding StrapiDynamicZone, StrapiComponent, StrapiImage, StrapiSeo.

  4. For dynamic editor I suggest to add information about

  1. sounds great. With the latest i can't import any types from "@nuxtjs/strapi", i.e. import type { Strapi4ResponseData } from "@nuxtjs/strapi"; This did work in strapi v4, but seems broken now.

@derrickmehaffy
Copy link

Stopping by here from the Strapi team (as I work for Strapi) to mention that if anyone needs any information clarity on how something works or help maintain or build support for Strapi 5 please don't hesitate to stop by our Discord: https://discord.strapi.io

Or if you are in dire need of some information for this module you can email me directly: [email protected] (please don't send emails asking for normal application support but if it's related to this module then it's all good).

Thanks!

Copy link
Member

Just released a v2.0.0, let me know if you encounter any issue with it!

@BayBreezy
Copy link
Contributor

Okie! Will do

@benjamincanac
Copy link
Member

Could you guys have a look at #445? Thanks!

@reslear
Copy link
Contributor

reslear commented Nov 28, 2024

Could you guys have a look at #445? Thanks!

the code looks good, we need to write instructions so that we can test directly from pr. or maybe build night version to npm

@SvenWesterlaken
Copy link
Contributor

SvenWesterlaken commented Dec 1, 2024

I found a small deprecated part in the documentation, might as well post it here so it can be considered for change:

https://strapi.nuxtjs.org/advanced#file-upload is the old way, which is not supported by strapi v5 anymore as stated per: https://docs.strapi.io/dev-docs/migration/v4-to-v5/breaking-changes/no-upload-at-entry-creation

I am currently updating my applications using this piece of code. So, if I find some time soon, I could change the documentation with a section for the old v4 way as a reference and the new way for strapi v5.

@kasperjha
Copy link

Hi guys, I'm trying to use useStrapi module (V5), nuxt can't find useStrapi, however I can use useStrapiUser, UseStrapiToken, useStrapiAuth, etc... do you know why?

I also cannot import useStrapi. The composable is not present in imports.d.ts. I'm on the latest edge version and have specified version: "v5" in nuxt config.

@Dumk0
Copy link

Dumk0 commented Jan 19, 2025

Hi.
I have an issue with data type. I am using Strapi V5 and nuxt strapi module with version: 'v5' param in my config file.

My users.vue page:

<script setup lang="ts">
const { find } = useStrapi();

type User = {
  username: string,
  jobTitle: string,
  phone: string,
  email: string,
}
const users = await find<User>('users', { fields: ['username', 'jobTitle', 'phone', 'email'] });
</script>

<template>
  <div>
    <div v-for="user in users">
      Username: {{user.username}}
    </div>
  </div>
</template>

This causes the error: ERROR(vue-tsc) Property 'username' does not exist on type '({ username: string; jobTitle: string; phone: string; email: string; } & StrapiSystemFields)[] | Strapi5ResponseMeta'.
Property 'username' does not exist on type '({ username: string; jobTitle: string; phone: string; email: string; } & StrapiSystemFields)[]'.

Despite the error in console, I get expected HTML result. And if I print users variable, I get this result:

[ { "id": 1, "documentId": "y8dvgdwjsrx341cnaho72gc3", "username": "Arna ", "jobTitle": "Accountant", "phone": "123455", "email": "[email protected]" }, { "id": 2, "documentId": "hs8pzrbgwcsly3geazvnm7sl", "username": "John", "jobTitle": "Officer", "phone": "123456", "email": "[email protected]" } ]

If I change my template to:

<template>
  <div>
    <div v-for="user in users.data">
      Username: {{user.username}}
    </div>
  </div>
</template>

then there is no errors, but also no content!

If I understand it right, users variable expected to be instance of <Strapi5ResponseMany> (with data and meta properties), but in reality it is just <User[]>.

UPDATE: only /api/users resource has this problem, the issue is coming from the Strapi Users plugin - Strapi/Strapi #12911

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
question Further information is requested
Projects
None yet
Development

No branches or pull requests

10 participants