name: Build

on:
  workflow_dispatch:
  push:
    branches:
      - main
  pull_request:
  schedule:
    - cron: '0 4 * * 1'

jobs:
  build:
    name: Build ${{ matrix.firmware.name }}
    runs-on: ubuntu-latest
    strategy:
      matrix:
        firmware:
          - file: v2board_esp8266_d1_mini_lite.yaml
            name: V2.0 Board ESP8266 D1 Mini Lite Security+ 2.0
            manifest_filename: v2board_esp8266_d1_mini_lite-manifest.json
          - file: v2board_esp8266_d1_mini.yaml
            name: V2.0 Board ESP8266 D1 Mini Security+ 2.0
            manifest_filename: v2board_esp8266_d1_mini-manifest.json
          - file: v2board_esp32_d1_mini.yaml
            name: V2.0 Board ESP32 D1 Mini Security+ 2.0
            manifest_filename: v2board_esp32_d1_mini-manifest.json
          - file: v2board_esp32_lolin_s2_mini.yaml
            name: V2.0 Board ESP32 lolin S2 mini Security+ 2.0
            manifest_filename: v2board_esp32_lolin_s2_mini-manifest.json
          - file: v25board_esp8266_d1_mini_lite.yaml
            name: V2.5 Board ESP8266 D1 Mini Lite Security+ 2.0
            manifest_filename: v25board_esp8266_d1_mini_lite-manifest.json
          - file: v25board_esp8266_d1_mini_lite_secplusv1.yaml
            name: V2.5 Board ESP8266 D1 Mini Lite Security+ 1.0
            manifest_filename: v25board_esp8266_d1_mini_lite_secplusv1-manifest.json
          - file: v25board_esp8266_d1_mini.yaml
            name: V2.5 Board ESP8266 D1 Mini Security+ 2.0
            manifest_filename: v25board_esp8266_d1_mini-manifest.json
          - file: v25board_esp8266_d1_mini_secplusv1.yaml
            name: V2.5 Board ESP8266 D1 Mini Security+ 1.0
            manifest_filename: v25board_esp8266_d1_mini_secplusv1-manifest.json
          - file: v25board_esp32_d1_mini.yaml
            name: V2.5 Board ESP32 D1 Mini Security+ 2.0
            manifest_filename: v25board_esp32_d1_mini-manifest.json
          - file: v25board_esp32_d1_mini_secplusv1.yaml
            name: V2.5 Board ESP32 D1 Mini Security+ 1.0
            manifest_filename: v25board_esp32_d1_mini_secplusv1-manifest.json
          - file: v25iboard.yaml
            name: V2.5i Board Security+ 2.0
            manifest_filename: v25iboard-manifest.json
          - file: v25iboard_secplusv1.yaml
            name: V2.5i Board Security+ 1.0
            manifest_filename: v25iboard_secplusv1-manifest.json
          - file: v25iboard_drycontact.yaml
            name: V2.5i Board Dry Contact
            manifest_filename: v25iboard_drycontact-manifest.json
      fail-fast: false
    steps:
      - name: Checkout source code
        uses: actions/checkout@v3.3.0
      - name: Build firmware
        uses: ratgdo/esphome-build-action@main
        id: esphome-build
        with:
          yaml_file: ${{ matrix.firmware.file }}
          version: latest
      - name: Copy firmware and manifest
        run: |
          mkdir output
          mv ${{ steps.esphome-build.outputs.name }} output/
          jq -s '{"name": "${{ matrix.firmware.name }}", "new_install_improv_wait_time": 15, "new_install_prompt_erase": true, "version": "${{ steps.esphome-build.outputs.esphome-version }}", "home_assistant_domain": "esphome", "new_install_skip_erase": false, "builds":.}' output/${{ steps.esphome-build.outputs.name }}/manifest.json > output/${{ matrix.firmware.manifest_filename }}

      - name: Upload artifact
        uses: actions/upload-artifact@v3.1.2
        with:
          name: ${{ matrix.firmware.name }}
          path: output


  consolidate:
    if: github.event_name != 'pull_request' && github.ref == 'refs/heads/main'
    name: Consolidate firmwares
    runs-on: ubuntu-latest
    needs: build
    steps:
      - name: Checkout source code
        uses: actions/checkout@v3
      - name: Download built firmwares
        uses: actions/download-artifact@v3
        with:
          path: firmwares
      - name: Copy files
        run: |-
          mkdir output
          cp -R static/* output/
          cp -R firmwares/*/* output/
      - name: Upload GitHub Pages artifact
        uses: actions/upload-pages-artifact@v2.0.0
        with:
          path: output

  deploy:
    if: github.event_name != 'pull_request' && github.ref == 'refs/heads/main'
    name: Deploy to GitHub Pages
    runs-on: ubuntu-latest
    needs: consolidate
    permissions:
      pages: write
      id-token: write
    environment:
      name: github-pages
      url: ${{ steps.deployment.outputs.page_url }}
    steps:
      - name: Setup Pages
        uses: actions/configure-pages@v2
      - name: Deploy to GitHub Pages
        id: deployment
        uses: actions/deploy-pages@v1.2.9