Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/shresht7/web-screenshot-action

GitHub Action to take a screenshots of a website 📷
https://github.com/shresht7/web-screenshot-action

github-actions puppeteer screenshot

Last synced: 2 months ago
JSON representation

GitHub Action to take a screenshots of a website 📷

Awesome Lists containing this project

README

        


📷 Web Screenshot Action 📷

[![Release](https://img.shields.io/github/v/release/Shresht7/web-screenshot-action?style=for-the-badge)](https://github.com/Shresht7/web-screenshot-action/releases)
[![License](https://img.shields.io/github/license/Shresht7/web-screenshot-action?style=for-the-badge)](./LICENSE)



Capture screenshots of a website 📷

[![Test](https://github.com/Shresht7/web-screenshot-action/actions/workflows/test.yml/badge.svg)](https://github.com/Shresht7/web-screenshot-action/actions/workflows/test.yml)
[![Validate](https://github.com/Shresht7/web-screenshot-action/actions/workflows/validate.yml/badge.svg)](https://github.com/Shresht7/web-screenshot-action/actions/workflows/validate.yml)
[![Action Readme](https://github.com/Shresht7/web-screenshot-action/actions/workflows/action-readme.yml/badge.svg)](https://github.com/Shresht7/web-screenshot-action/actions/workflows/action-readme.yml)
[![Screenshot](https://github.com/Shresht7/web-screenshot-action/actions/workflows/screenshot.yml/badge.svg)](https://github.com/Shresht7/web-screenshot-action/actions/workflows/screenshot.yml)

Table of Contents

- [📖 Usage](#-usage)
- [📋 Inputs](#-inputs)
- [📋 Outputs](#-outputs)
- [📄 Workflow Example](#-workflow-example)
- [📑 License](#-license)

---

![Example-Screenshot](./screenshot.png)

## 📖 Usage

Use this action in a workflow step and provide the URL you want to take the screenshot of.

```yaml
- name: Take Screenshot
uses: Shresht7/web-screenshot-action@v1
with:
url: https://github.com/Shresht7/web-screenshot-action
```

The screenshot will be saved as `screenshot.png`. The file-path and type can be changed using [input parameters](#-inputs).

if `shouldCreateArtifacts` is set to `true`, an [artifact](https://help.github.com/en/actions/configuring-and-managing-workflows/persisting-workflow-data-using-artifacts) will be created with the generated screenshots.

Intended to be used as a sub-task in some other workflow, this action's only job is to generate the screenshots. What you do with them is up to you. See [example workflow](#-workflow-example).

---

## 📋 Inputs

| Input | Description | Default | Required |
| :---------------------- | :--------------------------------------------------------------------- | ---------------: | :------: |
| `url` | URL to take the screenshot of | `undefined` | ✅ |
| `path` | Save screenshot as | `screenshot.png` | |
| `width` | Viewport width | `1920` | |
| `height` | Viewport height | `1080` | |
| `captureFullPage` | Take screenshot of the entire page | `false` | |
| `captureBeyondViewport` | Capture beyond the viewport constraints | `false` | |
| `omitBackground` | Omit the background allowing for transparent images | `false` | |
| `encoding` | Output screenshot encoding. (`base64` / `binary` / `undefined`) | `undefined` | |
| `shouldCreateArtifacts` | Generate screenshot artifacts | `false` | |
| `delay` | Wait for duration (in milliseconds) before taking a screenshot | `1000` | |
| `darkMode` | Enable dark mode by setting `prefers-color-scheme: dark` media feature | `false` | |

## 📋 Outputs

if `shouldCreateArtifacts` is set to `true`, an [artifact](https://help.github.com/en/actions/configuring-and-managing-workflows/persisting-workflow-data-using-artifacts) will be created with the screenshots.

## 📄 Workflow Example

The [screenshot](#-web-screenshot-action) in this README is auto-generated using this action!

[`.github/workflows/screenshot.yml`](./.github/workflows/screenshot.yml):

[![Screenshot](https://github.com/Shresht7/web-screenshot-action/actions/workflows/screenshot.yml/badge.svg)](https://github.com/Shresht7/web-screenshot-action/actions/workflows/screenshot.yml)

click here to show the workflow


```yaml
# ============================
# SCREENSHOT
# ----------------------------
# Take screenshot of a website
# ============================

name: Screenshot

# Activation Events
# =================

on:
workflow_dispatch: # When a workflow event is dispatched manually

# Jobs
# ====

jobs:
screenshot:
runs-on: ubuntu-latest

name: Screenshot
steps:
# Actions/Checkout ✅
# ===================

# Required for GITHUB_WORKSPACE
- name: Checkout
uses: actions/checkout@v3

# Take Screenshots 📷
# ===================

- name: Screenshot
uses: Shresht7/web-screenshot-action@v1
id: screenshot
with:
url: https://www.github.com/Shresht7/web-screenshot-action
path: screenshot.png

- name: Screenshot-Light
uses: Shresht7/web-screenshot-action@v1
id: screenshot-light
with:
url: https://www.github.com/Shresht7/web-screenshot-action
path: screenshots/screenshot-light.png

- name: Screenshot-Dark
uses: Shresht7/web-screenshot-action@v1
id: screenshot-dark
with:
url: https://www.github.com/Shresht7/web-screenshot-action
path: screenshots/screenshot-dark.png
darkMode: true

# Push to Main 🌐
# ===============

# Check if there are any changes in the current-working-directory
- name: check for changes
id: git-diff
run: |
if git diff --exit-code; then
echo "::set-output name=changes_exist::false"
else
echo "::set-output name=changes_exist::true"
fi

- name: add, commit and push
if: ${{ steps.git-diff.outputs.changes_exist == 'true' }}
run: |
git config user.name 'github-actions[bot]'
git config user.email 'github-actions[bot]@users.noreply.github.com'
git add .
git commit -m 'Update screenshot 📷'
git push

```

---

## 📑 License

> [MIT License](./LICENSE)