diff --git a/.github/workflows/test-local.yaml b/.github/workflows/test-local.yaml index c993ba2ce..18ea351e3 100644 --- a/.github/workflows/test-local.yaml +++ b/.github/workflows/test-local.yaml @@ -119,61 +119,3 @@ jobs: CYPRESS_DATA_PROVIDER: ${{ matrix.data_provider }} CYPRESS_UI_FRAMEWORK: ${{ matrix.ui_framework }} CYPRESS_AUTH_PROVIDER: ${{ steps.build_step.outputs.auth_provider }} - remix: - runs-on: ubuntu-latest - name: remix - concurrency: - group: ${{ github.ref }}-e2e-local-remix-${{ matrix.data_provider }}-${{ matrix.ui_framework }} - cancel-in-progress: true - strategy: - fail-fast: false - matrix: - data_provider: - [ - custom-json-rest, - strapi-v4, - nestjsx-crud, - airtable, - supabase, - appwrite, - hasura, - ] - ui_framework: [tailwindcss, antd, mui, no] - steps: - - name: Checkout - uses: actions/checkout@v3 - - uses: actions/setup-node@v3 - with: - node-version: 18 - - name: Install - run: npm install - - name: Build Examples - id: build_step - run: node ./.github/workflows/build-template.js - env: - FRAMEWORK: remix - DATA_PROVIDER: ${{ matrix.data_provider }} - UI_FRAMEWORK: ${{ matrix.ui_framework }} - - name: Install Deps - run: | - cd ${{ steps.build_step.outputs.project_path }} - npm install - npm run build - HOST=0.0.0.0 npm run start & - - name: Run Cypress on local - uses: cypress-io/github-action@v6 - with: - install: false - record: true - start: "npm ls" - wait-on: "http://0.0.0.0:3000" - group: e2e-local-remix-${{ matrix.data_provider }}-${{ matrix.ui_framework }}-${{ steps.build_step.outputs.auth_provider }} - env: - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - CYPRESS_RECORD_KEY: ${{ secrets.CYPRESS_RECORD_KEY }} - CYPRESS_USER_AGENT: ${{ secrets.CI_USER_AGENT }} - CYPRESS_FRAMEWORK: remix - CYPRESS_DATA_PROVIDER: ${{ matrix.data_provider }} - CYPRESS_UI_FRAMEWORK: ${{ matrix.ui_framework }} - CYPRESS_AUTH_PROVIDER: ${{ steps.build_step.outputs.auth_provider }} diff --git a/.github/workflows/test-remote.yaml b/.github/workflows/test-remote.yaml index 1b8c0db04..c33920ece 100644 --- a/.github/workflows/test-remote.yaml +++ b/.github/workflows/test-remote.yaml @@ -121,61 +121,3 @@ jobs: CYPRESS_DATA_PROVIDER: ${{ matrix.data_provider }} CYPRESS_UI_FRAMEWORK: ${{ matrix.ui_framework }} CYPRESS_AUTH_PROVIDER: ${{ steps.download_step.outputs.auth_provider }} - refine-remix: - runs-on: ubuntu-latest - name: Remix - concurrency: - group: ${{ github.ref }}-e2e-remote-remix-${{ matrix.data_provider }}-${{ matrix.ui_framework }} - cancel-in-progress: true - strategy: - fail-fast: false - matrix: - data_provider: - [ - custom-json-rest, - strapi-v4, - nestjsx-crud, - airtable, - supabase, - appwrite, - hasura, - ] - ui_framework: [tailwindcss, antd, mui, no] - steps: - - name: Checkout - uses: actions/checkout@v3 - - uses: actions/setup-node@v3 - with: - node-version: 18 - - name: Install - run: npm install - - name: Download Example - id: download_step - run: node ./.github/workflows/build-remote.js - env: - FRAMEWORK: remix - CI_USER_AGENT: ${{ secrets.CI_USER_AGENT }} - DATA_PROVIDER: ${{ matrix.data_provider }} - UI_FRAMEWORK: ${{ matrix.ui_framework }} - - name: Install & Build Deps - run: | - cd ${{ steps.download_step.outputs.project_path }} - npm install - npm run build - HOST=0.0.0.0 npm run start & - - name: Run Cypress on local - uses: cypress-io/github-action@v6 - with: - install: false - record: true - start: "npm ls" - wait-on: "http://localhost:3000" - group: e2e-remote-remix-${{ matrix.data_provider }}-${{ matrix.ui_framework }}-${{ steps.download_step.outputs.auth_provider }} - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - CYPRESS_RECORD_KEY: ${{ secrets.CYPRESS_RECORD_KEY }} - CYPRESS_USER_AGENT: ${{ secrets.CI_USER_AGENT }} - CYPRESS_FRAMEWORK: remix - CYPRESS_DATA_PROVIDER: ${{ matrix.data_provider }} - CYPRESS_UI_FRAMEWORK: ${{ matrix.ui_framework }} - CYPRESS_AUTH_PROVIDER: ${{ steps.download_step.outputs.auth_provider }} diff --git a/cypress/e2e/build-test.cy.js b/cypress/e2e/build-test.cy.js index c87966225..e3def8655 100644 --- a/cypress/e2e/build-test.cy.js +++ b/cypress/e2e/build-test.cy.js @@ -11,15 +11,6 @@ const shouldSkip = () => { return true; } - if ( - Cypress.env("FRAMEWORK") === "remix" && - Cypress.env("UI_FRAMEWORK") === "antd" - ) { - cy.log("Remix with Antd has known issues, skipping."); - - return true; - } - return false; }; @@ -120,11 +111,8 @@ describe("build test", () => { cy.contains("Blog Posts", { matchCase: false }).should("exist"); // document title check - // ignore remix and nextjs - if ( - Cypress.env("FRAMEWORK") !== "remix" && - Cypress.env("FRAMEWORK") !== "nextjs" - ) { + // ignore nextjs + if (Cypress.env("FRAMEWORK") !== "nextjs") { cy.title().should("eq", "Blog posts | Refine"); } diff --git a/presets.js b/presets.js index e2a34c3fe..d05bf4178 100644 --- a/presets.js +++ b/presets.js @@ -39,18 +39,6 @@ module.exports = { "headless-example": "no", }, }, - { - name: "refine-headless-remix", - type: "refine-remix", - answers: { - "ui-framework": "no", - "data-provider": "data-provider-custom-json-rest", - "auth-provider": "none", - "antd-example": "no", - "mui-example": "no", - "headless-example": "no", - }, - }, { name: "refine-antd-nextjs", type: "refine-nextjs", @@ -124,17 +112,5 @@ module.exports = { "headless-example": "no", }, }, - { - name: "remix-tailwindcss", - type: "refine-remix", - answers: { - "ui-framework": "tailwindcss", - "data-provider": "data-provider-custom-json-rest", - "auth-provider": "none", - "antd-example": "no", - "mui-example": "no", - "headless-example": "no", - }, - }, ], }; diff --git a/refine-nextjs/plugins/_base/extend.js b/refine-nextjs/plugins/_base/extend.js index 1c6282bda..19ceda266 100644 --- a/refine-nextjs/plugins/_base/extend.js +++ b/refine-nextjs/plugins/_base/extend.js @@ -182,6 +182,8 @@ module.exports = { base.blogPostCategoryIdFormField = `"categoryId"`; } else if (dataProvider === "data-provider-supabase") { base.blogPostCategoryIdFormField = `"categoryId"`; + } else if (dataProvider === "data-provider-appwrite") { + base.blogPostCategoryIdFormField = `"category"`; } else { if (uiFramework === "mui" || isHeadless) { base.blogPostCategoryIdFormField = `"category.id"`; @@ -191,7 +193,7 @@ module.exports = { } // ## blogPostCategoryTableField - if (base.isGraphQL) { + if (base.isGraphQL || dataProvider === "data-provider-appwrite") { if (isHeadless) { base.blogPostCategoryTableField = `"category.title"`; } diff --git a/refine-nextjs/plugins/antd-example/src/app/blog-posts/edit/[id]/page.tsx b/refine-nextjs/plugins/antd-example/src/app/blog-posts/edit/[id]/page.tsx index 9e9ffbff1..7034cf2b7 100644 --- a/refine-nextjs/plugins/antd-example/src/app/blog-posts/edit/[id]/page.tsx +++ b/refine-nextjs/plugins/antd-example/src/app/blog-posts/edit/[id]/page.tsx @@ -31,6 +31,18 @@ export default function BlogPostEdit() { meta: { select: '*, categories(id,title)', }, +<%_ } _%> +<%_ if (answers["data-provider"] === "data-provider-appwrite") { _%> + queryOptions: { + select: ({ data }) => { + return { + data: { + ...data, + category: data.category.$id, + }, + }; + }, + }, <%_ } _%> }); @@ -38,7 +50,11 @@ export default function BlogPostEdit() { const { selectProps: categorySelectProps } = useSelect({ resource: "categories", +<%_ if (answers["data-provider"] === "data-provider-appwrite") { _%> + defaultValue: blogPostsData?.<%- blogPostCategoryFieldName %>, +<%_ } else { _%> defaultValue: blogPostsData?.<%- blogPostCategoryFieldName %>?.id, +<%_ } _%> <%_ if (answers["data-provider"] === "data-provider-hasura") { _%> meta: { fields: BLOG_POSTS_CATEGORIES_SELECT_QUERY, diff --git a/refine-nextjs/plugins/antd-example/src/app/blog-posts/page.tsx b/refine-nextjs/plugins/antd-example/src/app/blog-posts/page.tsx index c0e1e35ef..a04124e6d 100644 --- a/refine-nextjs/plugins/antd-example/src/app/blog-posts/page.tsx +++ b/refine-nextjs/plugins/antd-example/src/app/blog-posts/page.tsx @@ -45,7 +45,7 @@ export default function BlogPostList() { <%_ } _%> }); -<%_ if (!isGraphQL) { _%> +<%_ if (!isGraphQL && answers["data-provider"] !== "data-provider-appwrite") { _%> const { data: categoryData, isLoading: categoryIsLoading } = useMany({ resource: "categories", ids: tableProps?.dataSource?.map((item) => item?.<%- blogPostCategoryFieldName %>?.id).filter(Boolean) ?? [], @@ -71,7 +71,7 @@ export default function BlogPostList() { } title={"Category"} - <%_ if (!isGraphQL) { _%> + <%_ if (!isGraphQL && answers["data-provider"] !== "data-provider-appwrite") { _%> render={(value) => categoryIsLoading ? ( <>Loading... @@ -86,7 +86,9 @@ export default function BlogPostList() { - dataIndex={["created_at"]} + dataIndex={["created_at"]} +<%_ } else if (answers["data-provider"] === "data-provider-appwrite") { _%> + dataIndex={["$createdAt"]} <%_ } else { _%> dataIndex={["createdAt"]} <%_ } _%> diff --git a/refine-nextjs/plugins/antd-example/src/app/blog-posts/show/[id]/page.tsx b/refine-nextjs/plugins/antd-example/src/app/blog-posts/show/[id]/page.tsx index a26fdad80..cca792751 100644 --- a/refine-nextjs/plugins/antd-example/src/app/blog-posts/show/[id]/page.tsx +++ b/refine-nextjs/plugins/antd-example/src/app/blog-posts/show/[id]/page.tsx @@ -46,7 +46,7 @@ export default function BlogPostShow() { const record = data?.data; -<%_ if (!isGraphQL) { _%> +<%_ if (!isGraphQL && answers["data-provider"] !== "data-provider-appwrite") { _%> const { data: categoryData, isLoading: categoryIsLoading } = useOne({ resource: "categories", id: record?.<%- blogPostCategoryFieldName %>?.id || "", @@ -65,7 +65,7 @@ export default function BlogPostShow() { {"Content"} {"Category"} -<%_ if (isGraphQL) { _%> +<%_ if (isGraphQL || answers["data-provider"] === "data-provider-appwrite") { _%> ?.title} /> <%_ } else { _%> {"Status"} {"CreatedAt"} +<%_ if (answers["data-provider"] === "data-provider-appwrite") { _%> + +<%_ } else if (answers["data-provider"] === "data-provider-hasura") { _%> + +<%_ } else { _%> +<%_ } _%> ); }; diff --git a/refine-nextjs/plugins/data-provider-appwrite/src/providers/data-provider/index.ts b/refine-nextjs/plugins/data-provider-appwrite/src/providers/data-provider/index.ts index 7d9aaf090..82a3bc4ee 100644 --- a/refine-nextjs/plugins/data-provider-appwrite/src/providers/data-provider/index.ts +++ b/refine-nextjs/plugins/data-provider-appwrite/src/providers/data-provider/index.ts @@ -4,9 +4,9 @@ import { dataProvider, liveProvider } from "@refinedev/appwrite"; import { appwriteClient } from "@utils/appwrite/client"; export const appwriteDataProvider = dataProvider(appwriteClient, { - databaseId: "database", + databaseId: "default", }); export const appwriteLiveProvider = liveProvider(appwriteClient, { - databaseId: "database", + databaseId: "default", }); diff --git a/refine-nextjs/plugins/data-provider-appwrite/src/utils/constants.ts b/refine-nextjs/plugins/data-provider-appwrite/src/utils/constants.ts index 8be31586b..b376660d5 100644 --- a/refine-nextjs/plugins/data-provider-appwrite/src/utils/constants.ts +++ b/refine-nextjs/plugins/data-provider-appwrite/src/utils/constants.ts @@ -1,3 +1,3 @@ -export const APPWRITE_URL = "https://refine.appwrite.org/v1"; -export const APPWRITE_PROJECT = "61c4368b4e349"; +export const APPWRITE_URL = "https://cloud.appwrite.io/v1"; +export const APPWRITE_PROJECT = "6697687d002cbd31ba6b"; export const APPWRITE_JWT_KEY = "appwrite-jwt"; diff --git a/refine-nextjs/plugins/headless-example/src/app/blog-posts/create/page.tsx b/refine-nextjs/plugins/headless-example/src/app/blog-posts/create/page.tsx index 805ef3a1a..8356533fa 100644 --- a/refine-nextjs/plugins/headless-example/src/app/blog-posts/create/page.tsx +++ b/refine-nextjs/plugins/headless-example/src/app/blog-posts/create/page.tsx @@ -111,7 +111,11 @@ export default function BlogPostCreate() { ))} +<%_ if (answers["data-provider"] === "data-provider-appwrite") { _%> + {(errors as any)?.<%- blogPostCategoryFieldName %>?.message as string} +<%_ } else { _%> {(errors as any)?.<%- blogPostCategoryFieldName %>?.id?.message as string} +<%_ } _%>