From 89657680133a55409e9c2bd4340a2e061bdde979 Mon Sep 17 00:00:00 2001 From: Collin Barrett Date: Sat, 15 Jun 2024 11:45:36 -0500 Subject: [PATCH] =?UTF-8?q?refactor(web):=20=E2=99=BB=EF=B8=8F=20customize?= =?UTF-8?q?=20stapp=20Build=20&=20Deploy=20Action?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- ...re-static-web-apps-blue-bush-0df07ac0f.yml | 46 -------- .github/workflows/web.yml | 106 ++++++++++++++++++ web/next.config.mjs | 4 +- web/package.json | 8 +- 4 files changed, 115 insertions(+), 49 deletions(-) delete mode 100644 .github/workflows/azure-static-web-apps-blue-bush-0df07ac0f.yml create mode 100644 .github/workflows/web.yml diff --git a/.github/workflows/azure-static-web-apps-blue-bush-0df07ac0f.yml b/.github/workflows/azure-static-web-apps-blue-bush-0df07ac0f.yml deleted file mode 100644 index 6e22f272a2..0000000000 --- a/.github/workflows/azure-static-web-apps-blue-bush-0df07ac0f.yml +++ /dev/null @@ -1,46 +0,0 @@ -name: Azure Static Web Apps CI/CD - -on: - push: - branches: - - nextjs - pull_request: - types: [opened, synchronize, reopened, closed] - branches: - - nextjs - -jobs: - build_and_deploy_job: - if: github.event_name == 'push' || (github.event_name == 'pull_request' && github.event.action != 'closed') - runs-on: ubuntu-latest - name: Build and Deploy Job - steps: - - uses: actions/checkout@v3 - with: - submodules: true - lfs: false - - name: Build And Deploy - id: builddeploy - uses: Azure/static-web-apps-deploy@v1 - with: - azure_static_web_apps_api_token: ${{ secrets.AZURE_STATIC_WEB_APPS_API_TOKEN_BLUE_BUSH_0DF07AC0F }} - repo_token: ${{ secrets.GITHUB_TOKEN }} # Used for Github integrations (i.e. PR comments) - action: "upload" - ###### Repository/Build Configurations - These values can be configured to match your app requirements. ###### - # For more information regarding Static Web App workflow configurations, please visit: https://aka.ms/swaworkflowconfig - app_location: "./web" # App source code path - api_location: "" # Api source code path - optional - output_location: "" # Built app content directory - optional - ###### End of Repository/Build Configurations ###### - - close_pull_request_job: - if: github.event_name == 'pull_request' && github.event.action == 'closed' - runs-on: ubuntu-latest - name: Close Pull Request Job - steps: - - name: Close Pull Request - id: closepullrequest - uses: Azure/static-web-apps-deploy@v1 - with: - azure_static_web_apps_api_token: ${{ secrets.AZURE_STATIC_WEB_APPS_API_TOKEN_BLUE_BUSH_0DF07AC0F }} - action: "close" diff --git a/.github/workflows/web.yml b/.github/workflows/web.yml new file mode 100644 index 0000000000..8e5a790266 --- /dev/null +++ b/.github/workflows/web.yml @@ -0,0 +1,106 @@ +name: Web - Build & Deploy + +on: + push: + branches: + # - main # TODO: uncomment when merging nextjs to main + - nextjs # TODO: remove when merging nextjs to main + paths: + - .github/workflows/web.yml + - web/** + # TODO: uncomment when merging nextjs to main + # pull_request: + # types: [opened, synchronize, reopened, closed] + # branches: + # - main + # paths: + # - .github/workflows/web.yml + # - web/** + +jobs: + build_and_deploy_staging: + # name: Build & Deploy to Staging + name: Build & Deploy to Next.js Staging + + runs-on: ubuntu-latest + + # if: github.event_name == 'pull_request' && github.event.action != 'closed' + if: github.event_name == 'push' + + environment: + name: nextjs-web + # url: ${{ steps.builddeploy.outputs.static_web_app_url }} + url: https://next.filterlists.com + + steps: + - name: Checkout + uses: actions/checkout@v4 + + - name: Setup Node + uses: actions/setup-node@v4 + with: + node-version: lts/* + cache: npm + cache-dependency-path: web/package-lock.json + + - name: Install + run: npm ci + working-directory: ./web + + - name: Run Prettier + run: npm run prettier + working-directory: ./web + + - name: Run ESLint + run: npm run lint + working-directory: ./web + + - name: Build & Deploy + id: builddeploy + uses: Azure/static-web-apps-deploy@v1 + with: + azure_static_web_apps_api_token: ${{ secrets.AZURE_STATIC_WEB_APPS_API_TOKEN_STAPP_FILTERLISTS_NEXTJS_PROD }} + repo_token: ${{ secrets.GITHUB_TOKEN }} + action: upload + app_location: ./web + output_location: "" + + # build_and_deploy_production: + # name: Build & Deploy to Production + + # runs-on: ubuntu-latest + + # if: github.event_name == 'push' + + # environment: + # name: production-web + # url: https://filterlists.com + + # steps: + # - name: Checkout + # uses: actions/checkout@v4 + + # - name: Build & Deploy + # id: builddeploy + # uses: Azure/static-web-apps-deploy@v1 + # with: + # azure_static_web_apps_api_token: ${{ secrets.AZURE_STATIC_WEB_APPS_API_TOKEN_STAPP_FILTERLISTS_PROD }} + # repo_token: ${{ secrets.GITHUB_TOKEN }} + # action: upload + # app_location: ./web + # output_location: "" + + # close_pull_request: + # name: Close Pull Request + + # runs-on: ubuntu-latest + + # if: github.event_name == 'pull_request' && github.event.action == 'closed' + + # steps: + # - name: Close Pull Request + # uses: Azure/static-web-apps-deploy@v1 + # with: + # azure_static_web_apps_api_token: ${{ secrets.AZURE_STATIC_WEB_APPS_API_TOKEN_STAPP_FILTERLISTS_PROD }} + # action: close + # app_location: ./web diff --git a/web/next.config.mjs b/web/next.config.mjs index 4678774e6d..8c8bab67b5 100644 --- a/web/next.config.mjs +++ b/web/next.config.mjs @@ -1,4 +1,6 @@ /** @type {import('next').NextConfig} */ -const nextConfig = {}; +const nextConfig = { + output: "standalone", +}; export default nextConfig; diff --git a/web/package.json b/web/package.json index d251c4b6c8..9c5db765dc 100644 --- a/web/package.json +++ b/web/package.json @@ -4,9 +4,10 @@ "private": true, "scripts": { "dev": "next dev", - "build": "next build", + "build": "next build && cp -r .next/static .next/standalone/.next/ && cp -r public .next/standalone/", "start": "next start", - "lint": "next lint" + "lint": "next lint", + "prettier": "npx prettier --check ." }, "dependencies": { "@radix-ui/react-icons": "^1.3.0", @@ -29,5 +30,8 @@ "prettier": "3.3.2", "tailwindcss": "^3.4.1", "typescript": "^5" + }, + "engines": { + "node": ">=v18.17.0" } }