13 Commits

Author SHA1 Message Date
minori 122172e445 deps: update eslint to 10.0.0
Node.js CI / CI (pull_request) Failing after 22s
Security Scan and Upload / Security & DefectDojo Upload (pull_request) Successful in 1m23s
2026-02-17 07:07:48 -08:00
minori c96fb350cf deps: update eslint to 9.39.2
Node.js CI / CI (pull_request) Successful in 30s
Security Scan and Upload / Security & DefectDojo Upload (pull_request) Successful in 1m25s
2026-02-04 08:32:53 -08:00
hikari 8ec8811a93 docs: update feedback section to use support forum
Node.js CI / CI (push) Successful in 25s
Security Scan and Upload / Security & DefectDojo Upload (push) Successful in 1m28s
2026-01-26 12:37:26 -08:00
naomi 0e2293ad37 feat: automated upload of .gitea/workflows/ci.yml
Node.js CI / CI (push) Successful in 23s
Security Scan and Upload / Security & DefectDojo Upload (push) Successful in 59s
2025-12-22 19:43:02 +01:00
naomi 5451460bb9 feat: automated upload of .gitea/workflows/ci.yml
Node.js CI / CI (push) Has been cancelled
Security Scan and Upload / Security & DefectDojo Upload (push) Has been cancelled
2025-12-22 19:36:29 +01:00
naomi 88f1ddc101 feat: automated upload of .gitea/workflows/ci.yml
Security Scan and Upload / Security & DefectDojo Upload (push) Has been cancelled
Node.js CI / Lint and Test (push) Has been cancelled
2025-12-22 19:26:14 +01:00
naomi 1f79e0ff95 feat: automated upload of .npmrc
Node.js CI / Lint and Test (push) Has been cancelled
Security Scan and Upload / Security & DefectDojo Upload (push) Has been cancelled
2025-12-22 19:17:02 +01:00
naomi acfacc4b41 feat: automated upload of .gitea/workflows/security.yml
Node.js CI / Lint and Test (push) Successful in 26s
Security Scan and Upload / Security & DefectDojo Upload (push) Successful in 58s
2025-12-18 03:09:19 +01:00
naomi 5083390568 feat: add analytics
Node.js CI / Lint and Test (push) Successful in 41s
2025-10-08 15:44:36 -07:00
naomi 95166435e3 release: v1.0.1
Node.js CI / Lint and Test (push) Successful in 39s
2025-07-19 18:47:11 -07:00
naomi e8ec6b4ca0 fix: no await
Node.js CI / Lint and Test (push) Has been cancelled
2025-07-19 18:46:45 -07:00
naomi f4381f503c fix: instantiate server
Node.js CI / Lint and Test (push) Failing after 31s
2025-07-19 18:32:17 -07:00
naomi 833ab15515 fix: art must be under 3500 characters to comply with discord limits
Node.js CI / Lint and Test (push) Successful in 36s
2025-07-19 16:29:28 -07:00
9 changed files with 501 additions and 312 deletions
+15 -6
View File
@@ -8,22 +8,31 @@ on:
- main - main
jobs: jobs:
lint: ci:
name: Lint and Test name: CI
runs-on: ubuntu-latest
steps: steps:
- name: Checkout Source Files - name: Checkout Source Files
uses: actions/checkout@v4 uses: actions/checkout@v4
- name: Use Node.js v22 - name: Use Node.js v24
uses: actions/setup-node@v4 uses: actions/setup-node@v4
with: with:
node-version: 22 node-version: 24
- name: Setup pnpm - name: Setup pnpm
uses: pnpm/action-setup@v2 uses: pnpm/action-setup@v2
with: with:
version: 9 version: 10
- name: Ensure Dependencies are Pinned
uses: naomi-lgbt/dependency-pin-check@main
with:
language: javascript
dev-dependencies: true
peer-dependencies: true
optional-dependencies: true
- name: Install Dependencies - name: Install Dependencies
run: pnpm install run: pnpm install
@@ -35,4 +44,4 @@ jobs:
run: pnpm run build run: pnpm run build
- name: Run Tests - name: Run Tests
run: pnpm run test run: pnpm run test
+177
View File
@@ -0,0 +1,177 @@
name: Security Scan and Upload
on:
push:
branches: [ main ]
pull_request:
branches: [ main ]
schedule:
- cron: '0 0 * * 1'
workflow_dispatch:
jobs:
security-audit:
name: Security & DefectDojo Upload
runs-on: ubuntu-latest
continue-on-error: true
steps:
- name: Checkout code
uses: actions/checkout@v4
# --- AUTO-SETUP PROJECT ---
- name: Ensure DefectDojo Product Exists
env:
DD_URL: ${{ secrets.DD_URL }}
DD_TOKEN: ${{ secrets.DD_TOKEN }}
PRODUCT_NAME: ${{ github.repository }}
PRODUCT_TYPE_ID: 1
run: |
sudo apt-get install jq -y > /dev/null
echo "Checking connection to $DD_URL..."
# Check if product exists - capture HTTP code to debug connection issues
RESPONSE=$(curl --write-out "%{http_code}" --silent --output /tmp/response.json \
-H "Authorization: Token $DD_TOKEN" \
"$DD_URL/api/v2/products/?name=$PRODUCT_NAME")
# If response is not 200, print error
if [ "$RESPONSE" != "200" ]; then
echo "::error::Failed to query DefectDojo. HTTP Code: $RESPONSE"
cat /tmp/response.json
exit 1
fi
COUNT=$(cat /tmp/response.json | jq -r '.count')
if [ "$COUNT" = "0" ]; then
echo "Creating product '$PRODUCT_NAME'..."
curl -s -X POST "$DD_URL/api/v2/products/" \
-H "Authorization: Token $DD_TOKEN" \
-H "Content-Type: application/json" \
-d '{ "name": "'"$PRODUCT_NAME"'", "description": "Auto-created by Gitea Actions", "prod_type": '$PRODUCT_TYPE_ID' }'
else
echo "Product '$PRODUCT_NAME' already exists."
fi
# --- 1. TRIVY (Dependencies & Misconfig) ---
- name: Install Trivy
run: |
sudo apt-get install wget apt-transport-https gnupg lsb-release -y
wget -qO - https://aquasecurity.github.io/trivy-repo/deb/public.key | sudo apt-key add -
echo "deb https://aquasecurity.github.io/trivy-repo/deb $(lsb_release -sc) main" | sudo tee -a /etc/apt/sources.list.d/trivy.list
sudo apt-get update && sudo apt-get install trivy -y
- name: Run Trivy (FS Scan)
run: |
trivy fs . --scanners vuln,misconfig --format json --output trivy-results.json --exit-code 0
- name: Upload Trivy to DefectDojo
env:
DD_URL: ${{ secrets.DD_URL }}
DD_TOKEN: ${{ secrets.DD_TOKEN }}
run: |
echo "Uploading Trivy results..."
# Generate today's date in YYYY-MM-DD format
TODAY=$(date +%Y-%m-%d)
HTTP_CODE=$(curl --write-out "%{http_code}" --output response.txt --silent -X POST "$DD_URL/api/v2/import-scan/" \
-H "Authorization: Token $DD_TOKEN" \
-F "active=true" \
-F "verified=true" \
-F "scan_type=Trivy Scan" \
-F "engagement_name=CI/CD Pipeline" \
-F "product_name=${{ github.repository }}" \
-F "scan_date=$TODAY" \
-F "auto_create_context=true" \
-F "file=@trivy-results.json")
if [[ "$HTTP_CODE" != "200" && "$HTTP_CODE" != "201" ]]; then
echo "::error::Upload Failed with HTTP $HTTP_CODE"
echo "--- SERVER RESPONSE ---"
cat response.txt
echo "-----------------------"
exit 1
else
echo "Upload Success!"
fi
# --- 2. GITLEAKS (Secrets) ---
- name: Install Gitleaks
run: |
wget -qO gitleaks.tar.gz https://github.com/gitleaks/gitleaks/releases/download/v8.18.0/gitleaks_8.18.0_linux_x64.tar.gz
tar -xzf gitleaks.tar.gz
sudo mv gitleaks /usr/local/bin/ && chmod +x /usr/local/bin/gitleaks
- name: Run Gitleaks
run: gitleaks detect --source . -v --report-path gitleaks-results.json --report-format json --no-git || true
- name: Upload Gitleaks to DefectDojo
env:
DD_URL: ${{ secrets.DD_URL }}
DD_TOKEN: ${{ secrets.DD_TOKEN }}
run: |
echo "Uploading Gitleaks results..."
TODAY=$(date +%Y-%m-%d)
HTTP_CODE=$(curl --write-out "%{http_code}" --output response.txt --silent -X POST "$DD_URL/api/v2/import-scan/" \
-H "Authorization: Token $DD_TOKEN" \
-F "active=true" \
-F "verified=true" \
-F "scan_type=Gitleaks Scan" \
-F "engagement_name=CI/CD Pipeline" \
-F "product_name=${{ github.repository }}" \
-F "scan_date=$TODAY" \
-F "auto_create_context=true" \
-F "file=@gitleaks-results.json")
if [[ "$HTTP_CODE" != "200" && "$HTTP_CODE" != "201" ]]; then
echo "::error::Upload Failed with HTTP $HTTP_CODE"
echo "--- SERVER RESPONSE ---"
cat response.txt
echo "-----------------------"
exit 1
else
echo "Upload Success!"
fi
# --- 3. SEMGREP (SAST) ---
- name: Install Semgrep (via pipx)
run: |
sudo apt-get install pipx -y
pipx install semgrep
# Add pipx binary path to GITHUB_PATH so next steps can see 'semgrep'
echo "$HOME/.local/bin" >> $GITHUB_PATH
- name: Run Semgrep
run: semgrep scan --config=p/security-audit --config=p/owasp-top-ten --json --output semgrep-results.json . || true
- name: Upload Semgrep to DefectDojo
env:
DD_URL: ${{ secrets.DD_URL }}
DD_TOKEN: ${{ secrets.DD_TOKEN }}
run: |
echo "Uploading Semgrep results..."
TODAY=$(date +%Y-%m-%d)
HTTP_CODE=$(curl --write-out "%{http_code}" --output response.txt --silent -X POST "$DD_URL/api/v2/import-scan/" \
-H "Authorization: Token $DD_TOKEN" \
-F "active=true" \
-F "verified=true" \
-F "scan_type=Semgrep JSON Report" \
-F "engagement_name=CI/CD Pipeline" \
-F "product_name=${{ github.repository }}" \
-F "scan_date=$TODAY" \
-F "auto_create_context=true" \
-F "file=@semgrep-results.json")
if [[ "$HTTP_CODE" != "200" && "$HTTP_CODE" != "201" ]]; then
echo "::error::Upload Failed with HTTP $HTTP_CODE"
echo "--- SERVER RESPONSE ---"
cat response.txt
echo "-----------------------"
exit 1
else
echo "Upload Success!"
fi
+25
View File
@@ -0,0 +1,25 @@
# Package Manager Configuration
# Force pnpm usage - breaks npm/yarn intentionally
node-linker=pnpm
# Security: Disable all lifecycle scripts
ignore-scripts=true
enable-pre-post-scripts=false
# Security: Require packages to be 10+ days old before installation
minimum-release-age=14400
# Security: Verify package integrity hashes
verify-store-integrity=true
# Security: Enforce strict trust policies
trust-policy=strict
# Security: Strict peer dependency resolution
strict-peer-dependencies=true
# Performance: Use symlinks for node_modules
symlink=true
# Lockfile: Ensure lockfile is not modified during install
frozen-lockfile=false
+1 -1
View File
@@ -8,7 +8,7 @@ This page is currently deployed. [Add to your Discord!](https://discord.com/oaut
## Feedback and Bugs ## Feedback and Bugs
If you have feedback or a bug report, please feel free to open a GitHub issue! If you have feedback or a bug report, please [log a ticket on our forum](https://support.nhcarrigan.com).
## Contributing ## Contributing
+4 -3
View File
@@ -1,6 +1,6 @@
{ {
"name": "chibika", "name": "chibika",
"version": "1.0.0", "version": "1.0.1",
"description": "A bot that shares ASCII art.", "description": "A bot that shares ASCII art.",
"main": "index.js", "main": "index.js",
"type": "module", "type": "module",
@@ -17,12 +17,13 @@
"devDependencies": { "devDependencies": {
"@nhcarrigan/eslint-config": "5.2.0", "@nhcarrigan/eslint-config": "5.2.0",
"@nhcarrigan/typescript-config": "4.0.0", "@nhcarrigan/typescript-config": "4.0.0",
"eslint": "9.31.0", "eslint": "10.0.0",
"typescript": "5.8.3", "typescript": "5.8.3",
"vitest": "3.2.4" "vitest": "3.2.4"
}, },
"dependencies": { "dependencies": {
"@nhcarrigan/logger": "1.0.0", "@nhcarrigan/discord-analytics": "0.0.6",
"@nhcarrigan/logger": "1.1.1",
"discord.js": "14.21.0", "discord.js": "14.21.0",
"fastify": "5.4.0" "fastify": "5.4.0"
} }
+252 -193
View File
@@ -8,9 +8,12 @@ importers:
.: .:
dependencies: dependencies:
'@nhcarrigan/discord-analytics':
specifier: 0.0.6
version: 0.0.6(@nhcarrigan/logger@1.1.1)(discord.js@14.21.0)
'@nhcarrigan/logger': '@nhcarrigan/logger':
specifier: 1.0.0 specifier: 1.1.1
version: 1.0.0 version: 1.1.1
discord.js: discord.js:
specifier: 14.21.0 specifier: 14.21.0
version: 14.21.0 version: 14.21.0
@@ -20,13 +23,13 @@ importers:
devDependencies: devDependencies:
'@nhcarrigan/eslint-config': '@nhcarrigan/eslint-config':
specifier: 5.2.0 specifier: 5.2.0
version: 5.2.0(@typescript-eslint/utils@8.37.0(eslint@9.31.0)(typescript@5.8.3))(eslint@9.31.0)(playwright@1.54.1)(react@19.1.0)(typescript@5.8.3)(vitest@3.2.4(@types/node@24.0.15)) version: 5.2.0(@typescript-eslint/utils@8.37.0(eslint@10.0.0)(typescript@5.8.3))(eslint@10.0.0)(playwright@1.54.1)(react@19.1.0)(typescript@5.8.3)(vitest@3.2.4(@types/node@24.0.15))
'@nhcarrigan/typescript-config': '@nhcarrigan/typescript-config':
specifier: 4.0.0 specifier: 4.0.0
version: 4.0.0(typescript@5.8.3) version: 4.0.0(typescript@5.8.3)
eslint: eslint:
specifier: 9.31.0 specifier: 10.0.0
version: 9.31.0 version: 10.0.0
typescript: typescript:
specifier: 5.8.3 specifier: 5.8.3
version: 5.8.3 version: 5.8.3
@@ -244,10 +247,20 @@ packages:
peerDependencies: peerDependencies:
eslint: ^6.0.0 || ^7.0.0 || >=8.0.0 eslint: ^6.0.0 || ^7.0.0 || >=8.0.0
'@eslint-community/eslint-utils@4.9.1':
resolution: {integrity: sha512-phrYmNiYppR7znFEdqgfWHXR6NCkZEK7hwWDHZUjit/2/U0r6XvkDl0SYnoM51Hq7FhCGdLDT6zxCCOY1hexsQ==}
engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0}
peerDependencies:
eslint: ^6.0.0 || ^7.0.0 || >=8.0.0
'@eslint-community/regexpp@4.12.1': '@eslint-community/regexpp@4.12.1':
resolution: {integrity: sha512-CCZCDJuduB9OUkFkY2IgppNZMi2lBQgD2qzwXkEia16cge2pijY/aXi96CJMquDMn3nJdlPV1A5KrJEXwfLNzQ==} resolution: {integrity: sha512-CCZCDJuduB9OUkFkY2IgppNZMi2lBQgD2qzwXkEia16cge2pijY/aXi96CJMquDMn3nJdlPV1A5KrJEXwfLNzQ==}
engines: {node: ^12.0.0 || ^14.0.0 || >=16.0.0} engines: {node: ^12.0.0 || ^14.0.0 || >=16.0.0}
'@eslint-community/regexpp@4.12.2':
resolution: {integrity: sha512-EriSTlt5OC9/7SXkRSCAhfSxxoSUgBm33OH+IkwbdpgoqsSsUg7y3uh+IICI/Qg4BBWr3U2i39RpmycbxMq4ew==}
engines: {node: ^12.0.0 || ^14.0.0 || >=16.0.0}
'@eslint/compat@1.2.4': '@eslint/compat@1.2.4':
resolution: {integrity: sha512-S8ZdQj/N69YAtuqFt7653jwcvuUj131+6qGLUyDqfDg1OIoBQ66OCuXC473YQfO2AaxITTutiRQiDwoo7ZLYyg==} resolution: {integrity: sha512-S8ZdQj/N69YAtuqFt7653jwcvuUj131+6qGLUyDqfDg1OIoBQ66OCuXC473YQfO2AaxITTutiRQiDwoo7ZLYyg==}
engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0} engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0}
@@ -257,41 +270,33 @@ packages:
eslint: eslint:
optional: true optional: true
'@eslint/config-array@0.21.0': '@eslint/config-array@0.23.1':
resolution: {integrity: sha512-ENIdc4iLu0d93HeYirvKmrzshzofPw6VkZRKQGe9Nv46ZnWUzcF1xV01dcvEg/1wXUR61OmmlSfyeyO7EvjLxQ==} resolution: {integrity: sha512-uVSdg/V4dfQmTjJzR0szNczjOH/J+FyUMMjYtr07xFRXR7EDf9i1qdxrD0VusZH9knj1/ecxzCQQxyic5NzAiA==}
engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0} engines: {node: ^20.19.0 || ^22.13.0 || >=24}
'@eslint/config-helpers@0.3.0': '@eslint/config-helpers@0.5.2':
resolution: {integrity: sha512-ViuymvFmcJi04qdZeDc2whTHryouGcDlaxPqarTD0ZE10ISpxGUVZGZDx4w01upyIynL3iu6IXH2bS1NhclQMw==} resolution: {integrity: sha512-a5MxrdDXEvqnIq+LisyCX6tQMPF/dSJpCfBgBauY+pNZ28yCtSsTvyTYrMhaI+LK26bVyCJfJkT0u8KIj2i1dQ==}
engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0} engines: {node: ^20.19.0 || ^22.13.0 || >=24}
'@eslint/core@0.15.1': '@eslint/core@1.1.0':
resolution: {integrity: sha512-bkOp+iumZCCbt1K1CmWf0R9pM5yKpDv+ZXtvSyQpudrI9kuFLp+bM2WOPXImuD/ceQuaa8f5pj93Y7zyECIGNA==} resolution: {integrity: sha512-/nr9K9wkr3P1EzFTdFdMoLuo1PmIxjmwvPozwoSodjNBdefGujXQUF93u1DDZpEaTuDvMsIQddsd35BwtrW9Xw==}
engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0} engines: {node: ^20.19.0 || ^22.13.0 || >=24}
'@eslint/eslintrc@3.2.0': '@eslint/eslintrc@3.2.0':
resolution: {integrity: sha512-grOjVNN8P3hjJn/eIETF1wwd12DdnwFDoyceUJLYYdkpbwq3nLi+4fqrTAONx7XDALqlL220wC/RHSC/QTI/0w==} resolution: {integrity: sha512-grOjVNN8P3hjJn/eIETF1wwd12DdnwFDoyceUJLYYdkpbwq3nLi+4fqrTAONx7XDALqlL220wC/RHSC/QTI/0w==}
engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0} engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0}
'@eslint/eslintrc@3.3.1':
resolution: {integrity: sha512-gtF186CXhIl1p4pJNGZw8Yc6RlshoePRvE0X91oPGb3vZ8pM3qOS9W9NGPat9LziaBV7XrJWGylNQXkGcnM3IQ==}
engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0}
'@eslint/js@9.17.0': '@eslint/js@9.17.0':
resolution: {integrity: sha512-Sxc4hqcs1kTu0iID3kcZDW3JHq2a77HO9P8CP6YEA/FpH3Ll8UXE2r/86Rz9YJLKme39S9vU5OWNjC6Xl0Cr3w==} resolution: {integrity: sha512-Sxc4hqcs1kTu0iID3kcZDW3JHq2a77HO9P8CP6YEA/FpH3Ll8UXE2r/86Rz9YJLKme39S9vU5OWNjC6Xl0Cr3w==}
engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0} engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0}
'@eslint/js@9.31.0': '@eslint/object-schema@3.0.1':
resolution: {integrity: sha512-LOm5OVt7D4qiKCqoiPbA7LWmI+tbw1VbTUowBcUMgQSuM6poJufkFkYDcQpo5KfgD39TnNySV26QjOh7VFpSyw==} resolution: {integrity: sha512-P9cq2dpr+LU8j3qbLygLcSZrl2/ds/pUpfnHNNuk5HW7mnngHs+6WSq5C9mO3rqRX8A1poxqLTC9cu0KOyJlBg==}
engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0} engines: {node: ^20.19.0 || ^22.13.0 || >=24}
'@eslint/object-schema@2.1.6': '@eslint/plugin-kit@0.6.0':
resolution: {integrity: sha512-RBMg5FRL0I0gs51M/guSAj5/e14VQ4tpZnQNWwuDT66P14I43ItmPfIZRhO9fUVIPOAQXU47atlywZ/czoqFPA==} resolution: {integrity: sha512-bIZEUzOI1jkhviX2cp5vNyXQc6olzb2ohewQubuYlMXZ2Q/XjBO0x0XhGPvc9fjSIiUN0vw+0hq53BJ4eQSJKQ==}
engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0} engines: {node: ^20.19.0 || ^22.13.0 || >=24}
'@eslint/plugin-kit@0.3.3':
resolution: {integrity: sha512-1+WqvgNMhmlAambTvT3KPtCl/Ibr68VldY2XY40SL1CE0ZXiakFR/cbTspaF5HsnpDMvcYYoJHfl4980NBjGag==}
engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0}
'@fastify/ajv-compiler@4.0.2': '@fastify/ajv-compiler@4.0.2':
resolution: {integrity: sha512-Rkiu/8wIjpsf46Rr+Fitd3HRP+VsxUFDDeag0hs9L0ksfnwx2g7SPQQTFL0E8Qv+rfXzQOxBJnjUB9ITUDjfWQ==} resolution: {integrity: sha512-Rkiu/8wIjpsf46Rr+Fitd3HRP+VsxUFDDeag0hs9L0ksfnwx2g7SPQQTFL0E8Qv+rfXzQOxBJnjUB9ITUDjfWQ==}
@@ -331,9 +336,19 @@ packages:
resolution: {integrity: sha512-bV0Tgo9K4hfPCek+aMAn81RppFKv2ySDQeMoSZuvTASywNTnVJCArCZE2FWqpvIatKu7VMRLWlR1EazvVhDyhQ==} resolution: {integrity: sha512-bV0Tgo9K4hfPCek+aMAn81RppFKv2ySDQeMoSZuvTASywNTnVJCArCZE2FWqpvIatKu7VMRLWlR1EazvVhDyhQ==}
engines: {node: '>=18.18'} engines: {node: '>=18.18'}
'@isaacs/cliui@9.0.0':
resolution: {integrity: sha512-AokJm4tuBHillT+FpMtxQ60n8ObyXBatq7jD2/JA9dxbDDokKQm8KMht5ibGzLVU9IJDIKK4TPKgMHEYMn3lMg==}
engines: {node: '>=18'}
'@jridgewell/sourcemap-codec@1.5.4': '@jridgewell/sourcemap-codec@1.5.4':
resolution: {integrity: sha512-VT2+G1VQs/9oz078bLrYbecdZKs912zQlkelYpuf+SXF+QvZDYJlbx/LSx+meSAwdDFnF8FVXW92AVjjkVmgFw==} resolution: {integrity: sha512-VT2+G1VQs/9oz078bLrYbecdZKs912zQlkelYpuf+SXF+QvZDYJlbx/LSx+meSAwdDFnF8FVXW92AVjjkVmgFw==}
'@nhcarrigan/discord-analytics@0.0.6':
resolution: {integrity: sha512-Mci/zSY2nE24BM2cZx5EiYqwpRTTCBznFfs2BphejzDAaWPt1P12V5ln7OSUbFLGhvTD/Qwi0za3yPv6shQLoA==}
peerDependencies:
'@nhcarrigan/logger': '>=1.1.0-hotfix'
discord.js: ^14.0.0
'@nhcarrigan/eslint-config@5.2.0': '@nhcarrigan/eslint-config@5.2.0':
resolution: {integrity: sha512-YpTTqhviKMlRwKF+RC/GYiA5i2jTCmg8uftuiufldneNV5HMbGpTfBbV7tpa8++5mpYJc4+eZaf40QbDiz84dQ==} resolution: {integrity: sha512-YpTTqhviKMlRwKF+RC/GYiA5i2jTCmg8uftuiufldneNV5HMbGpTfBbV7tpa8++5mpYJc4+eZaf40QbDiz84dQ==}
engines: {node: '>=22', pnpm: '>=9'} engines: {node: '>=22', pnpm: '>=9'}
@@ -344,8 +359,8 @@ packages:
typescript: '>=5' typescript: '>=5'
vitest: '>=2' vitest: '>=2'
'@nhcarrigan/logger@1.0.0': '@nhcarrigan/logger@1.1.1':
resolution: {integrity: sha512-2e19Bie+ZKb6yKPKjhawqsENkhHatYkvBAmFZx9eToOXdOca+CYi51tldRMtejg6e0+4hOOf2bo5zdBQKmH0dw==} resolution: {integrity: sha512-P6OEQFHDtf6psybYGljuCxkSW6DLQCsx1aZZ3w4YKBXHBFjDbhuvpM9K1kPhVN48hakitx2WPLEoIFr6YZELYw==}
'@nhcarrigan/typescript-config@4.0.0': '@nhcarrigan/typescript-config@4.0.0':
resolution: {integrity: sha512-969HVha7A/Sg77fuMwOm6p14a+7C5iE6g55OD71srqwKIgksQl+Ex/hAI/pyzTQFDQ/FBJbpnHlR4Ov25QV/rw==} resolution: {integrity: sha512-969HVha7A/Sg77fuMwOm6p14a+7C5iE6g55OD71srqwKIgksQl+Ex/hAI/pyzTQFDQ/FBJbpnHlR4Ov25QV/rw==}
@@ -496,6 +511,9 @@ packages:
'@types/deep-eql@4.0.2': '@types/deep-eql@4.0.2':
resolution: {integrity: sha512-c9h9dVVMigMPc4bwTvC5dxqtqJZwQPePsWjPlpSOnojbor6pGqdk541lfA7AqFQr5pB1BRdq0juY9db81BwyFw==} resolution: {integrity: sha512-c9h9dVVMigMPc4bwTvC5dxqtqJZwQPePsWjPlpSOnojbor6pGqdk541lfA7AqFQr5pB1BRdq0juY9db81BwyFw==}
'@types/esrecurse@4.3.1':
resolution: {integrity: sha512-xJBAbDifo5hpffDBuHl0Y8ywswbiAp/Wi7Y/GtAgSlZyIABppyurxVueOPE8LUQOxdlgi6Zqce7uoEpqNTeiUw==}
'@types/estree@1.0.8': '@types/estree@1.0.8':
resolution: {integrity: sha512-dWHzHa2WqEXI/O1E9OjrocMTKJl2mSrEolh1Iomrv6U+JuNwaHXsXx9bLu5gG7BUWFIN0skIQJQ/L1rIex4X6w==} resolution: {integrity: sha512-dWHzHa2WqEXI/O1E9OjrocMTKJl2mSrEolh1Iomrv6U+JuNwaHXsXx9bLu5gG7BUWFIN0skIQJQ/L1rIex4X6w==}
@@ -703,10 +721,6 @@ packages:
ajv@8.17.1: ajv@8.17.1:
resolution: {integrity: sha512-B/gBuNg5SiMTrPkC+A2+cW0RszwxYmn6VYxB/inlBStS5nx6xHIt/ehKRhIMhqusl7a8LjQoZnjCs5vhwxOQ1g==} resolution: {integrity: sha512-B/gBuNg5SiMTrPkC+A2+cW0RszwxYmn6VYxB/inlBStS5nx6xHIt/ehKRhIMhqusl7a8LjQoZnjCs5vhwxOQ1g==}
ansi-styles@4.3.0:
resolution: {integrity: sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==}
engines: {node: '>=8'}
are-docs-informative@0.0.2: are-docs-informative@0.0.2:
resolution: {integrity: sha512-ixiS0nLNNG5jNQzgZJNoUpBKdo9yTYZMGJ+QgT2jmjR7G7+QHRCc4v6LQ3NgE7EBJq+o0ams3waJwkrlBom8Ig==} resolution: {integrity: sha512-ixiS0nLNNG5jNQzgZJNoUpBKdo9yTYZMGJ+QgT2jmjR7G7+QHRCc4v6LQ3NgE7EBJq+o0ams3waJwkrlBom8Ig==}
engines: {node: '>=14'} engines: {node: '>=14'}
@@ -772,12 +786,20 @@ packages:
balanced-match@1.0.2: balanced-match@1.0.2:
resolution: {integrity: sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==} resolution: {integrity: sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==}
balanced-match@4.0.2:
resolution: {integrity: sha512-x0K50QvKQ97fdEz2kPehIerj+YTeptKF9hyYkKf6egnwmMWAkADiO0QCzSp0R5xN8FTZgYaBfSaue46Ej62nMg==}
engines: {node: 20 || >=22}
brace-expansion@1.1.12: brace-expansion@1.1.12:
resolution: {integrity: sha512-9T9UjW3r0UW5c1Q7GTwllptXwhvYmEzFhzMfZ9H7FQWt+uZePjZPjBP/W1ZEyZ1twGWom5/56TF4lPcqjnDHcg==} resolution: {integrity: sha512-9T9UjW3r0UW5c1Q7GTwllptXwhvYmEzFhzMfZ9H7FQWt+uZePjZPjBP/W1ZEyZ1twGWom5/56TF4lPcqjnDHcg==}
brace-expansion@2.0.2: brace-expansion@2.0.2:
resolution: {integrity: sha512-Jt0vHyM+jmUBqojB7E1NIYadt0vI0Qxjxd2TErW94wDz+E2LAm5vKMXXwg6ZZBTHPuUlDgQHKXvjGBdfcF1ZDQ==} resolution: {integrity: sha512-Jt0vHyM+jmUBqojB7E1NIYadt0vI0Qxjxd2TErW94wDz+E2LAm5vKMXXwg6ZZBTHPuUlDgQHKXvjGBdfcF1ZDQ==}
brace-expansion@5.0.2:
resolution: {integrity: sha512-Pdk8c9poy+YhOgVWw1JNN22/HcivgKWwpxKq04M/jTmHyCZn12WPJebZxdjSa5TmBqISrUSgNYU3eRORljfCCw==}
engines: {node: 20 || >=22}
braces@3.0.3: braces@3.0.3:
resolution: {integrity: sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==} resolution: {integrity: sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==}
engines: {node: '>=8'} engines: {node: '>=8'}
@@ -818,10 +840,6 @@ packages:
resolution: {integrity: sha512-5nFxhUrX0PqtyogoYOA8IPswy5sZFTOsBFl/9bNsmDLgsxYTzSZQJDPppDnZPTQbzSEm0hqGjWPzRemQCYbD6A==} resolution: {integrity: sha512-5nFxhUrX0PqtyogoYOA8IPswy5sZFTOsBFl/9bNsmDLgsxYTzSZQJDPppDnZPTQbzSEm0hqGjWPzRemQCYbD6A==}
engines: {node: '>=18'} engines: {node: '>=18'}
chalk@4.1.2:
resolution: {integrity: sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==}
engines: {node: '>=10'}
check-error@2.1.1: check-error@2.1.1:
resolution: {integrity: sha512-OAlb+T7V4Op9OwdkjmguYRqncdlx5JiofwOAUkmTF+jNdHwzTaTs4sRAGpzLF3oOz5xAyDGrPgeIDFQmDOTiJw==} resolution: {integrity: sha512-OAlb+T7V4Op9OwdkjmguYRqncdlx5JiofwOAUkmTF+jNdHwzTaTs4sRAGpzLF3oOz5xAyDGrPgeIDFQmDOTiJw==}
engines: {node: '>= 16'} engines: {node: '>= 16'}
@@ -834,13 +852,6 @@ packages:
resolution: {integrity: sha512-GfisEZEJvzKrmGWkvfhgzcz/BllN1USeqD2V6tg14OAOgaCD2Z/PUEuxnAZ/nPvmaHRG7a8y77p1T/IRQ4D1Hw==} resolution: {integrity: sha512-GfisEZEJvzKrmGWkvfhgzcz/BllN1USeqD2V6tg14OAOgaCD2Z/PUEuxnAZ/nPvmaHRG7a8y77p1T/IRQ4D1Hw==}
engines: {node: '>=4'} engines: {node: '>=4'}
color-convert@2.0.1:
resolution: {integrity: sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==}
engines: {node: '>=7.0.0'}
color-name@1.1.4:
resolution: {integrity: sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==}
comment-parser@1.4.1: comment-parser@1.4.1:
resolution: {integrity: sha512-buhp5kePrmda3vhc5B9t7pUQXAb2Tnd0qgpkIhPhkHXxJpiPJ11H0ZEU0oBpJ2QztSbzG/ZxMj/CHsYJqRHmyg==} resolution: {integrity: sha512-buhp5kePrmda3vhc5B9t7pUQXAb2Tnd0qgpkIhPhkHXxJpiPJ11H0ZEU0oBpJ2QztSbzG/ZxMj/CHsYJqRHmyg==}
engines: {node: '>= 12.0.0'} engines: {node: '>= 12.0.0'}
@@ -855,6 +866,10 @@ packages:
core-js-compat@3.44.0: core-js-compat@3.44.0:
resolution: {integrity: sha512-JepmAj2zfl6ogy34qfWtcE7nHKAJnKsQFRn++scjVS2bZFllwptzw61BZcZFYBPpUznLfAvh0LGhxKppk04ClA==} resolution: {integrity: sha512-JepmAj2zfl6ogy34qfWtcE7nHKAJnKsQFRn++scjVS2bZFllwptzw61BZcZFYBPpUznLfAvh0LGhxKppk04ClA==}
cron-parser@4.9.0:
resolution: {integrity: sha512-p0SaNjrHOnQeR8/VnfGbmg9te2kfyYSQ7Sc/j/6DtPL3JQvKxmjO9TSjNFpujqV3vEYYBvNNvXSxzyksBWAx1Q==}
engines: {node: '>=12.0.0'}
cross-spawn@7.0.6: cross-spawn@7.0.6:
resolution: {integrity: sha512-uV2QOWP2nWzsy2aMp8aRibhi9dlzF5Hgh5SHaB9OiTGEyDTiJJyx0uy51QXdyWbtAHNua4XJzUKca3OzKUd3vA==} resolution: {integrity: sha512-uV2QOWP2nWzsy2aMp8aRibhi9dlzF5Hgh5SHaB9OiTGEyDTiJJyx0uy51QXdyWbtAHNua4XJzUKca3OzKUd3vA==}
engines: {node: '>= 8'} engines: {node: '>= 8'}
@@ -1052,9 +1067,9 @@ packages:
peerDependencies: peerDependencies:
eslint: '>=8.56.0' eslint: '>=8.56.0'
eslint-scope@8.4.0: eslint-scope@9.1.0:
resolution: {integrity: sha512-sNXOfKCn74rt8RICKMvJS7XKV/Xk9kA7DyJr8mJik3S7Cwgy3qlkkmyS2uQB3jiJg6VNdZd/pDBJu0nvG2NlTg==} resolution: {integrity: sha512-CkWE42hOJsNj9FJRaoMX9waUFYhqY4jmyLFdAdzZr6VaCg3ynLYx4WnOdkaIifGfH4gsUcBTn4OZbHXkpLD0FQ==}
engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0} engines: {node: ^20.19.0 || ^22.13.0 || >=24}
eslint-visitor-keys@1.3.0: eslint-visitor-keys@1.3.0:
resolution: {integrity: sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==} resolution: {integrity: sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==}
@@ -1068,9 +1083,13 @@ packages:
resolution: {integrity: sha512-Uhdk5sfqcee/9H/rCOJikYz67o0a2Tw2hGRPOG2Y1R2dg7brRe1uG0yaNQDHu+TO/uQPF/5eCapvYSmHUjt7JQ==} resolution: {integrity: sha512-Uhdk5sfqcee/9H/rCOJikYz67o0a2Tw2hGRPOG2Y1R2dg7brRe1uG0yaNQDHu+TO/uQPF/5eCapvYSmHUjt7JQ==}
engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0} engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0}
eslint@9.31.0: eslint-visitor-keys@5.0.0:
resolution: {integrity: sha512-QldCVh/ztyKJJZLr4jXNUByx3gR+TDYZCRXEktiZoUR3PGy4qCmSbkxcIle8GEwGpb5JBZazlaJ/CxLidXdEbQ==} resolution: {integrity: sha512-A0XeIi7CXU7nPlfHS9loMYEKxUaONu/hTEzHTGba9Huu94Cq1hPivf+DE5erJozZOky0LfvXAyrV/tcswpLI0Q==}
engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0} engines: {node: ^20.19.0 || ^22.13.0 || >=24}
eslint@10.0.0:
resolution: {integrity: sha512-O0piBKY36YSJhlFSG8p9VUdPV/SxxS4FYDWVpr/9GJuMaepzwlf4J8I4ov1b+ySQfDTPhc3DtLaxcT1fN0yqCg==}
engines: {node: ^20.19.0 || ^22.13.0 || >=24}
hasBin: true hasBin: true
peerDependencies: peerDependencies:
jiti: '*' jiti: '*'
@@ -1082,6 +1101,10 @@ packages:
resolution: {integrity: sha512-j6PAQ2uUr79PZhBjP5C5fhl8e39FmRnOjsD5lGnWrFU8i2G776tBK7+nP8KuQUTTyAZUwfQqXAgrVH5MbH9CYQ==} resolution: {integrity: sha512-j6PAQ2uUr79PZhBjP5C5fhl8e39FmRnOjsD5lGnWrFU8i2G776tBK7+nP8KuQUTTyAZUwfQqXAgrVH5MbH9CYQ==}
engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0} engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0}
espree@11.1.0:
resolution: {integrity: sha512-WFWYhO1fV4iYkqOOvq8FbqIhr2pYfoDY0kCotMkDeNtGpiGGkZ1iov2u8ydjtgM8yF8rzK7oaTbw2NAzbAbehw==}
engines: {node: ^20.19.0 || ^22.13.0 || >=24}
espree@6.2.1: espree@6.2.1:
resolution: {integrity: sha512-ysCxRQY3WaXJz9tdbWOwuWr5Y/XrPTGX9Kiz3yoUXwW0VZ4w30HTkQLaGx/+ttFjF8i+ACbArnB4ce68a9m5hw==} resolution: {integrity: sha512-ysCxRQY3WaXJz9tdbWOwuWr5Y/XrPTGX9Kiz3yoUXwW0VZ4w30HTkQLaGx/+ttFjF8i+ACbArnB4ce68a9m5hw==}
engines: {node: '>=6.0.0'} engines: {node: '>=6.0.0'}
@@ -1090,6 +1113,10 @@ packages:
resolution: {integrity: sha512-ca9pw9fomFcKPvFLXhBKUK90ZvGibiGOvRJNbjljY7s7uq/5YO4BOzcYtJqExdx99rF6aAcnRxHmcUHcz6sQsg==} resolution: {integrity: sha512-ca9pw9fomFcKPvFLXhBKUK90ZvGibiGOvRJNbjljY7s7uq/5YO4BOzcYtJqExdx99rF6aAcnRxHmcUHcz6sQsg==}
engines: {node: '>=0.10'} engines: {node: '>=0.10'}
esquery@1.7.0:
resolution: {integrity: sha512-Ap6G0WQwcU/LHsvLwON1fAQX9Zp0A2Y6Y/cJBl9r/JbW90Zyg4/zbG6zzKa2OTALELarYHmKu0GhpM5EO+7T0g==}
engines: {node: '>=0.10'}
esrecurse@4.3.0: esrecurse@4.3.0:
resolution: {integrity: sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==} resolution: {integrity: sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==}
engines: {node: '>=4.0'} engines: {node: '>=4.0'}
@@ -1254,10 +1281,6 @@ packages:
resolution: {integrity: sha512-R3pbpkcIqv2Pm3dUwgjclDRVmWpTJW2DcMzcIhEXEx1oh/CEMObMm3KLmRJOdvhM7o4uQBnwr8pzRK2sJWIqfg==} resolution: {integrity: sha512-R3pbpkcIqv2Pm3dUwgjclDRVmWpTJW2DcMzcIhEXEx1oh/CEMObMm3KLmRJOdvhM7o4uQBnwr8pzRK2sJWIqfg==}
engines: {node: '>= 0.4'} engines: {node: '>= 0.4'}
has-flag@4.0.0:
resolution: {integrity: sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==}
engines: {node: '>=8'}
has-property-descriptors@1.0.2: has-property-descriptors@1.0.2:
resolution: {integrity: sha512-55JNKuIW+vq4Ke1BjOTjM2YctQIvCT7GFzHwmfZPGo5wnrgkid0YQtnAleFSqumZm4az3n2BS+erby5ipJdgrg==} resolution: {integrity: sha512-55JNKuIW+vq4Ke1BjOTjM2YctQIvCT7GFzHwmfZPGo5wnrgkid0YQtnAleFSqumZm4az3n2BS+erby5ipJdgrg==}
@@ -1421,6 +1444,10 @@ packages:
resolution: {integrity: sha512-H0dkQoCa3b2VEeKQBOxFph+JAbcrQdE7KC0UkqwpLmv2EC4P41QXP+rqo9wYodACiG5/WM5s9oDApTU8utwj9g==} resolution: {integrity: sha512-H0dkQoCa3b2VEeKQBOxFph+JAbcrQdE7KC0UkqwpLmv2EC4P41QXP+rqo9wYodACiG5/WM5s9oDApTU8utwj9g==}
engines: {node: '>= 0.4'} engines: {node: '>= 0.4'}
jackspeak@4.2.3:
resolution: {integrity: sha512-ykkVRwrYvFm1nb2AJfKKYPr0emF6IiXDYUaFx4Zn9ZuIH7MrzEZ3sD5RlqGXNRpHtvUHJyOnCEFxOlNDtGo7wg==}
engines: {node: 20 || >=22}
js-tokens@4.0.0: js-tokens@4.0.0:
resolution: {integrity: sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==} resolution: {integrity: sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==}
@@ -1491,15 +1518,15 @@ packages:
resolution: {integrity: sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==} resolution: {integrity: sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==}
engines: {node: '>=10'} engines: {node: '>=10'}
lodash.merge@4.6.2:
resolution: {integrity: sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==}
lodash.snakecase@4.1.1: lodash.snakecase@4.1.1:
resolution: {integrity: sha512-QZ1d4xoBHYUeuouhEq3lk3Uq7ldgyFXGBhg04+oRLnIz8o9T65Eh+8YdroUwn846zchkA9yDsDl5CVVaV2nqYw==} resolution: {integrity: sha512-QZ1d4xoBHYUeuouhEq3lk3Uq7ldgyFXGBhg04+oRLnIz8o9T65Eh+8YdroUwn846zchkA9yDsDl5CVVaV2nqYw==}
lodash@4.17.21: lodash@4.17.21:
resolution: {integrity: sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==} resolution: {integrity: sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==}
long-timeout@0.1.1:
resolution: {integrity: sha512-BFRuQUqc7x2NWxfJBCyUrN8iYUYznzL9JROmRz1gZ6KlOIgmoD+njPVbb+VNn2nGMKggMsK79iUNErillsrx7w==}
loose-envify@1.4.0: loose-envify@1.4.0:
resolution: {integrity: sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==} resolution: {integrity: sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==}
hasBin: true hasBin: true
@@ -1507,6 +1534,10 @@ packages:
loupe@3.1.4: loupe@3.1.4:
resolution: {integrity: sha512-wJzkKwJrheKtknCOKNEtDK4iqg/MxmZheEMtSTYvnzRdEYaZzmgH976nenp8WdJRdx5Vc1X/9MO0Oszl6ezeXg==} resolution: {integrity: sha512-wJzkKwJrheKtknCOKNEtDK4iqg/MxmZheEMtSTYvnzRdEYaZzmgH976nenp8WdJRdx5Vc1X/9MO0Oszl6ezeXg==}
luxon@3.7.2:
resolution: {integrity: sha512-vtEhXh/gNjI9Yg1u4jX/0YVPMvxzHuGgCm6tC5kZyb08yjGWGnqAjGJvcXbqQR2P3MyMEFnRbpcdFS6PBcLqew==}
engines: {node: '>=12'}
magic-bytes.js@1.12.1: magic-bytes.js@1.12.1:
resolution: {integrity: sha512-ThQLOhN86ZkJ7qemtVRGYM+gRgR8GEXNli9H/PMvpnZsE44Xfh3wx9kGJaldg314v85m+bFW6WBMaVHJc/c3zA==} resolution: {integrity: sha512-ThQLOhN86ZkJ7qemtVRGYM+gRgR8GEXNli9H/PMvpnZsE44Xfh3wx9kGJaldg314v85m+bFW6WBMaVHJc/c3zA==}
@@ -1529,6 +1560,10 @@ packages:
resolution: {integrity: sha512-I9jwMn07Sy/IwOj3zVkVik2JTvgpaykDZEigL6Rx6N9LbMywwUSMtxET+7lVoDLLd3O3IXwJwvuuns8UB/HeAg==} resolution: {integrity: sha512-I9jwMn07Sy/IwOj3zVkVik2JTvgpaykDZEigL6Rx6N9LbMywwUSMtxET+7lVoDLLd3O3IXwJwvuuns8UB/HeAg==}
engines: {node: '>=4'} engines: {node: '>=4'}
minimatch@10.2.1:
resolution: {integrity: sha512-MClCe8IL5nRRmawL6ib/eT4oLyeKMGCghibcDWK+J0hh0Q8kqSdia6BvbRMVk6mPa6WqUa5uR2oxt6C5jd533A==}
engines: {node: 20 || >=22}
minimatch@3.1.2: minimatch@3.1.2:
resolution: {integrity: sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==} resolution: {integrity: sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==}
@@ -1553,6 +1588,10 @@ packages:
node-releases@2.0.19: node-releases@2.0.19:
resolution: {integrity: sha512-xxOWJsBKtzAq7DY0J+DTzuz58K8e7sJbdgwkbMWQe8UYB6ekmsQ45q0M/tJDsGaZmbC+l7n57UV8Hl5tHxO9uw==} resolution: {integrity: sha512-xxOWJsBKtzAq7DY0J+DTzuz58K8e7sJbdgwkbMWQe8UYB6ekmsQ45q0M/tJDsGaZmbC+l7n57UV8Hl5tHxO9uw==}
node-schedule@2.1.1:
resolution: {integrity: sha512-OXdegQq03OmXEjt2hZP33W2YPs/E5BcFQks46+G2gAxs4gHOIVD1u7EqlYLYSKsaIpyKCK9Gbk0ta1/gjRSMRQ==}
engines: {node: '>=6'}
normalize-package-data@2.5.0: normalize-package-data@2.5.0:
resolution: {integrity: sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==} resolution: {integrity: sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==}
@@ -1882,6 +1921,9 @@ packages:
sonic-boom@4.2.0: sonic-boom@4.2.0:
resolution: {integrity: sha512-INb7TM37/mAcsGmc9hyyI6+QR3rR1zVRu36B0NeGXKnOOLiZOfER5SA+N7X7k3yUYRzLWafduTDvJAfDswwEww==} resolution: {integrity: sha512-INb7TM37/mAcsGmc9hyyI6+QR3rR1zVRu36B0NeGXKnOOLiZOfER5SA+N7X7k3yUYRzLWafduTDvJAfDswwEww==}
sorted-array-functions@1.3.0:
resolution: {integrity: sha512-2sqgzeFlid6N4Z2fUQ1cvFmTOLRi/sEDzSQ0OKYchqgoPmQBVyM3959qYx3fpS6Esef80KjmpgPeEr028dP3OA==}
source-map-js@1.2.1: source-map-js@1.2.1:
resolution: {integrity: sha512-UXWMKhLOwVKb728IUtQPXxfYU+usdybtUrK/8uGE8CQMvrhOpwvzDBwj0QhSL7MQc7vIsISBG8VQ8+IDQxpfQA==} resolution: {integrity: sha512-UXWMKhLOwVKb728IUtQPXxfYU+usdybtUrK/8uGE8CQMvrhOpwvzDBwj0QhSL7MQc7vIsISBG8VQ8+IDQxpfQA==}
engines: {node: '>=0.10.0'} engines: {node: '>=0.10.0'}
@@ -1949,10 +1991,6 @@ packages:
strip-literal@3.0.0: strip-literal@3.0.0:
resolution: {integrity: sha512-TcccoMhJOM3OebGhSBEmp3UZ2SfDMZUEBdRA/9ynfLi8yYajyWX3JiXArcJt4Umh4vISpspkQIY8ZZoCqjbviA==} resolution: {integrity: sha512-TcccoMhJOM3OebGhSBEmp3UZ2SfDMZUEBdRA/9ynfLi8yYajyWX3JiXArcJt4Umh4vISpspkQIY8ZZoCqjbviA==}
supports-color@7.2.0:
resolution: {integrity: sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==}
engines: {node: '>=8'}
supports-preserve-symlinks-flag@1.0.0: supports-preserve-symlinks-flag@1.0.0:
resolution: {integrity: sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==} resolution: {integrity: sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==}
engines: {node: '>= 0.4'} engines: {node: '>= 0.4'}
@@ -2335,34 +2373,43 @@ snapshots:
'@esbuild/win32-x64@0.25.8': '@esbuild/win32-x64@0.25.8':
optional: true optional: true
'@eslint-community/eslint-plugin-eslint-comments@4.4.1(eslint@9.31.0)': '@eslint-community/eslint-plugin-eslint-comments@4.4.1(eslint@10.0.0)':
dependencies: dependencies:
escape-string-regexp: 4.0.0 escape-string-regexp: 4.0.0
eslint: 9.31.0 eslint: 10.0.0
ignore: 5.3.2 ignore: 5.3.2
'@eslint-community/eslint-utils@4.7.0(eslint@9.31.0)': '@eslint-community/eslint-utils@4.7.0(eslint@10.0.0)':
dependencies: dependencies:
eslint: 9.31.0 eslint: 10.0.0
eslint-visitor-keys: 3.4.3
'@eslint-community/eslint-utils@4.9.1(eslint@10.0.0)':
dependencies:
eslint: 10.0.0
eslint-visitor-keys: 3.4.3 eslint-visitor-keys: 3.4.3
'@eslint-community/regexpp@4.12.1': {} '@eslint-community/regexpp@4.12.1': {}
'@eslint/compat@1.2.4(eslint@9.31.0)': '@eslint-community/regexpp@4.12.2': {}
optionalDependencies:
eslint: 9.31.0
'@eslint/config-array@0.21.0': '@eslint/compat@1.2.4(eslint@10.0.0)':
optionalDependencies:
eslint: 10.0.0
'@eslint/config-array@0.23.1':
dependencies: dependencies:
'@eslint/object-schema': 2.1.6 '@eslint/object-schema': 3.0.1
debug: 4.4.1 debug: 4.4.1
minimatch: 3.1.2 minimatch: 10.2.1
transitivePeerDependencies: transitivePeerDependencies:
- supports-color - supports-color
'@eslint/config-helpers@0.3.0': {} '@eslint/config-helpers@0.5.2':
dependencies:
'@eslint/core': 1.1.0
'@eslint/core@0.15.1': '@eslint/core@1.1.0':
dependencies: dependencies:
'@types/json-schema': 7.0.15 '@types/json-schema': 7.0.15
@@ -2380,29 +2427,13 @@ snapshots:
transitivePeerDependencies: transitivePeerDependencies:
- supports-color - supports-color
'@eslint/eslintrc@3.3.1':
dependencies:
ajv: 6.12.6
debug: 4.4.1
espree: 10.4.0
globals: 14.0.0
ignore: 5.3.2
import-fresh: 3.3.1
js-yaml: 4.1.0
minimatch: 3.1.2
strip-json-comments: 3.1.1
transitivePeerDependencies:
- supports-color
'@eslint/js@9.17.0': {} '@eslint/js@9.17.0': {}
'@eslint/js@9.31.0': {} '@eslint/object-schema@3.0.1': {}
'@eslint/object-schema@2.1.6': {} '@eslint/plugin-kit@0.6.0':
'@eslint/plugin-kit@0.3.3':
dependencies: dependencies:
'@eslint/core': 0.15.1 '@eslint/core': 1.1.0
levn: 0.4.1 levn: 0.4.1
'@fastify/ajv-compiler@4.0.2': '@fastify/ajv-compiler@4.0.2':
@@ -2441,26 +2472,34 @@ snapshots:
'@humanwhocodes/retry@0.4.3': {} '@humanwhocodes/retry@0.4.3': {}
'@isaacs/cliui@9.0.0': {}
'@jridgewell/sourcemap-codec@1.5.4': {} '@jridgewell/sourcemap-codec@1.5.4': {}
'@nhcarrigan/eslint-config@5.2.0(@typescript-eslint/utils@8.37.0(eslint@9.31.0)(typescript@5.8.3))(eslint@9.31.0)(playwright@1.54.1)(react@19.1.0)(typescript@5.8.3)(vitest@3.2.4(@types/node@24.0.15))': '@nhcarrigan/discord-analytics@0.0.6(@nhcarrigan/logger@1.1.1)(discord.js@14.21.0)':
dependencies: dependencies:
'@eslint-community/eslint-plugin-eslint-comments': 4.4.1(eslint@9.31.0) '@nhcarrigan/logger': 1.1.1
'@eslint/compat': 1.2.4(eslint@9.31.0) discord.js: 14.21.0
node-schedule: 2.1.1
'@nhcarrigan/eslint-config@5.2.0(@typescript-eslint/utils@8.37.0(eslint@10.0.0)(typescript@5.8.3))(eslint@10.0.0)(playwright@1.54.1)(react@19.1.0)(typescript@5.8.3)(vitest@3.2.4(@types/node@24.0.15))':
dependencies:
'@eslint-community/eslint-plugin-eslint-comments': 4.4.1(eslint@10.0.0)
'@eslint/compat': 1.2.4(eslint@10.0.0)
'@eslint/eslintrc': 3.2.0 '@eslint/eslintrc': 3.2.0
'@eslint/js': 9.17.0 '@eslint/js': 9.17.0
'@stylistic/eslint-plugin': 2.12.1(eslint@9.31.0)(typescript@5.8.3) '@stylistic/eslint-plugin': 2.12.1(eslint@10.0.0)(typescript@5.8.3)
'@typescript-eslint/eslint-plugin': 8.19.0(@typescript-eslint/parser@8.19.0(eslint@9.31.0)(typescript@5.8.3))(eslint@9.31.0)(typescript@5.8.3) '@typescript-eslint/eslint-plugin': 8.19.0(@typescript-eslint/parser@8.19.0(eslint@10.0.0)(typescript@5.8.3))(eslint@10.0.0)(typescript@5.8.3)
'@typescript-eslint/parser': 8.19.0(eslint@9.31.0)(typescript@5.8.3) '@typescript-eslint/parser': 8.19.0(eslint@10.0.0)(typescript@5.8.3)
'@vitest/eslint-plugin': 1.1.24(@typescript-eslint/utils@8.37.0(eslint@9.31.0)(typescript@5.8.3))(eslint@9.31.0)(typescript@5.8.3)(vitest@3.2.4(@types/node@24.0.15)) '@vitest/eslint-plugin': 1.1.24(@typescript-eslint/utils@8.37.0(eslint@10.0.0)(typescript@5.8.3))(eslint@10.0.0)(typescript@5.8.3)(vitest@3.2.4(@types/node@24.0.15))
eslint: 9.31.0 eslint: 10.0.0
eslint-plugin-deprecation: 3.0.0(eslint@9.31.0)(typescript@5.8.3) eslint-plugin-deprecation: 3.0.0(eslint@10.0.0)(typescript@5.8.3)
eslint-plugin-import: 2.31.0(@typescript-eslint/parser@8.19.0(eslint@9.31.0)(typescript@5.8.3))(eslint@9.31.0) eslint-plugin-import: 2.31.0(@typescript-eslint/parser@8.19.0(eslint@10.0.0)(typescript@5.8.3))(eslint@10.0.0)
eslint-plugin-jsdoc: 50.6.1(eslint@9.31.0) eslint-plugin-jsdoc: 50.6.1(eslint@10.0.0)
eslint-plugin-playwright: 2.1.0(eslint@9.31.0) eslint-plugin-playwright: 2.1.0(eslint@10.0.0)
eslint-plugin-react: 7.37.3(eslint@9.31.0) eslint-plugin-react: 7.37.3(eslint@10.0.0)
eslint-plugin-sort-keys-fix: 1.1.2 eslint-plugin-sort-keys-fix: 1.1.2
eslint-plugin-unicorn: 56.0.1(eslint@9.31.0) eslint-plugin-unicorn: 56.0.1(eslint@10.0.0)
globals: 15.14.0 globals: 15.14.0
playwright: 1.54.1 playwright: 1.54.1
react: 19.1.0 react: 19.1.0
@@ -2472,7 +2511,7 @@ snapshots:
- eslint-import-resolver-webpack - eslint-import-resolver-webpack
- supports-color - supports-color
'@nhcarrigan/logger@1.0.0': {} '@nhcarrigan/logger@1.1.1': {}
'@nhcarrigan/typescript-config@4.0.0(typescript@5.8.3)': '@nhcarrigan/typescript-config@4.0.0(typescript@5.8.3)':
dependencies: dependencies:
@@ -2563,10 +2602,10 @@ snapshots:
'@sapphire/snowflake@3.5.3': {} '@sapphire/snowflake@3.5.3': {}
'@stylistic/eslint-plugin@2.12.1(eslint@9.31.0)(typescript@5.8.3)': '@stylistic/eslint-plugin@2.12.1(eslint@10.0.0)(typescript@5.8.3)':
dependencies: dependencies:
'@typescript-eslint/utils': 8.37.0(eslint@9.31.0)(typescript@5.8.3) '@typescript-eslint/utils': 8.37.0(eslint@10.0.0)(typescript@5.8.3)
eslint: 9.31.0 eslint: 10.0.0
eslint-visitor-keys: 4.2.1 eslint-visitor-keys: 4.2.1
espree: 10.4.0 espree: 10.4.0
estraverse: 5.3.0 estraverse: 5.3.0
@@ -2581,6 +2620,8 @@ snapshots:
'@types/deep-eql@4.0.2': {} '@types/deep-eql@4.0.2': {}
'@types/esrecurse@4.3.1': {}
'@types/estree@1.0.8': {} '@types/estree@1.0.8': {}
'@types/json-schema@7.0.15': {} '@types/json-schema@7.0.15': {}
@@ -2597,15 +2638,15 @@ snapshots:
dependencies: dependencies:
'@types/node': 24.0.15 '@types/node': 24.0.15
'@typescript-eslint/eslint-plugin@8.19.0(@typescript-eslint/parser@8.19.0(eslint@9.31.0)(typescript@5.8.3))(eslint@9.31.0)(typescript@5.8.3)': '@typescript-eslint/eslint-plugin@8.19.0(@typescript-eslint/parser@8.19.0(eslint@10.0.0)(typescript@5.8.3))(eslint@10.0.0)(typescript@5.8.3)':
dependencies: dependencies:
'@eslint-community/regexpp': 4.12.1 '@eslint-community/regexpp': 4.12.1
'@typescript-eslint/parser': 8.19.0(eslint@9.31.0)(typescript@5.8.3) '@typescript-eslint/parser': 8.19.0(eslint@10.0.0)(typescript@5.8.3)
'@typescript-eslint/scope-manager': 8.19.0 '@typescript-eslint/scope-manager': 8.19.0
'@typescript-eslint/type-utils': 8.19.0(eslint@9.31.0)(typescript@5.8.3) '@typescript-eslint/type-utils': 8.19.0(eslint@10.0.0)(typescript@5.8.3)
'@typescript-eslint/utils': 8.19.0(eslint@9.31.0)(typescript@5.8.3) '@typescript-eslint/utils': 8.19.0(eslint@10.0.0)(typescript@5.8.3)
'@typescript-eslint/visitor-keys': 8.19.0 '@typescript-eslint/visitor-keys': 8.19.0
eslint: 9.31.0 eslint: 10.0.0
graphemer: 1.4.0 graphemer: 1.4.0
ignore: 5.3.2 ignore: 5.3.2
natural-compare: 1.4.0 natural-compare: 1.4.0
@@ -2614,14 +2655,14 @@ snapshots:
transitivePeerDependencies: transitivePeerDependencies:
- supports-color - supports-color
'@typescript-eslint/parser@8.19.0(eslint@9.31.0)(typescript@5.8.3)': '@typescript-eslint/parser@8.19.0(eslint@10.0.0)(typescript@5.8.3)':
dependencies: dependencies:
'@typescript-eslint/scope-manager': 8.19.0 '@typescript-eslint/scope-manager': 8.19.0
'@typescript-eslint/types': 8.19.0 '@typescript-eslint/types': 8.19.0
'@typescript-eslint/typescript-estree': 8.19.0(typescript@5.8.3) '@typescript-eslint/typescript-estree': 8.19.0(typescript@5.8.3)
'@typescript-eslint/visitor-keys': 8.19.0 '@typescript-eslint/visitor-keys': 8.19.0
debug: 4.4.1 debug: 4.4.1
eslint: 9.31.0 eslint: 10.0.0
typescript: 5.8.3 typescript: 5.8.3
transitivePeerDependencies: transitivePeerDependencies:
- supports-color - supports-color
@@ -2654,12 +2695,12 @@ snapshots:
dependencies: dependencies:
typescript: 5.8.3 typescript: 5.8.3
'@typescript-eslint/type-utils@8.19.0(eslint@9.31.0)(typescript@5.8.3)': '@typescript-eslint/type-utils@8.19.0(eslint@10.0.0)(typescript@5.8.3)':
dependencies: dependencies:
'@typescript-eslint/typescript-estree': 8.19.0(typescript@5.8.3) '@typescript-eslint/typescript-estree': 8.19.0(typescript@5.8.3)
'@typescript-eslint/utils': 8.19.0(eslint@9.31.0)(typescript@5.8.3) '@typescript-eslint/utils': 8.19.0(eslint@10.0.0)(typescript@5.8.3)
debug: 4.4.1 debug: 4.4.1
eslint: 9.31.0 eslint: 10.0.0
ts-api-utils: 1.4.3(typescript@5.8.3) ts-api-utils: 1.4.3(typescript@5.8.3)
typescript: 5.8.3 typescript: 5.8.3
transitivePeerDependencies: transitivePeerDependencies:
@@ -2716,35 +2757,35 @@ snapshots:
transitivePeerDependencies: transitivePeerDependencies:
- supports-color - supports-color
'@typescript-eslint/utils@7.18.0(eslint@9.31.0)(typescript@5.8.3)': '@typescript-eslint/utils@7.18.0(eslint@10.0.0)(typescript@5.8.3)':
dependencies: dependencies:
'@eslint-community/eslint-utils': 4.7.0(eslint@9.31.0) '@eslint-community/eslint-utils': 4.7.0(eslint@10.0.0)
'@typescript-eslint/scope-manager': 7.18.0 '@typescript-eslint/scope-manager': 7.18.0
'@typescript-eslint/types': 7.18.0 '@typescript-eslint/types': 7.18.0
'@typescript-eslint/typescript-estree': 7.18.0(typescript@5.8.3) '@typescript-eslint/typescript-estree': 7.18.0(typescript@5.8.3)
eslint: 9.31.0 eslint: 10.0.0
transitivePeerDependencies: transitivePeerDependencies:
- supports-color - supports-color
- typescript - typescript
'@typescript-eslint/utils@8.19.0(eslint@9.31.0)(typescript@5.8.3)': '@typescript-eslint/utils@8.19.0(eslint@10.0.0)(typescript@5.8.3)':
dependencies: dependencies:
'@eslint-community/eslint-utils': 4.7.0(eslint@9.31.0) '@eslint-community/eslint-utils': 4.7.0(eslint@10.0.0)
'@typescript-eslint/scope-manager': 8.19.0 '@typescript-eslint/scope-manager': 8.19.0
'@typescript-eslint/types': 8.19.0 '@typescript-eslint/types': 8.19.0
'@typescript-eslint/typescript-estree': 8.19.0(typescript@5.8.3) '@typescript-eslint/typescript-estree': 8.19.0(typescript@5.8.3)
eslint: 9.31.0 eslint: 10.0.0
typescript: 5.8.3 typescript: 5.8.3
transitivePeerDependencies: transitivePeerDependencies:
- supports-color - supports-color
'@typescript-eslint/utils@8.37.0(eslint@9.31.0)(typescript@5.8.3)': '@typescript-eslint/utils@8.37.0(eslint@10.0.0)(typescript@5.8.3)':
dependencies: dependencies:
'@eslint-community/eslint-utils': 4.7.0(eslint@9.31.0) '@eslint-community/eslint-utils': 4.7.0(eslint@10.0.0)
'@typescript-eslint/scope-manager': 8.37.0 '@typescript-eslint/scope-manager': 8.37.0
'@typescript-eslint/types': 8.37.0 '@typescript-eslint/types': 8.37.0
'@typescript-eslint/typescript-estree': 8.37.0(typescript@5.8.3) '@typescript-eslint/typescript-estree': 8.37.0(typescript@5.8.3)
eslint: 9.31.0 eslint: 10.0.0
typescript: 5.8.3 typescript: 5.8.3
transitivePeerDependencies: transitivePeerDependencies:
- supports-color - supports-color
@@ -2764,10 +2805,10 @@ snapshots:
'@typescript-eslint/types': 8.37.0 '@typescript-eslint/types': 8.37.0
eslint-visitor-keys: 4.2.1 eslint-visitor-keys: 4.2.1
'@vitest/eslint-plugin@1.1.24(@typescript-eslint/utils@8.37.0(eslint@9.31.0)(typescript@5.8.3))(eslint@9.31.0)(typescript@5.8.3)(vitest@3.2.4(@types/node@24.0.15))': '@vitest/eslint-plugin@1.1.24(@typescript-eslint/utils@8.37.0(eslint@10.0.0)(typescript@5.8.3))(eslint@10.0.0)(typescript@5.8.3)(vitest@3.2.4(@types/node@24.0.15))':
dependencies: dependencies:
'@typescript-eslint/utils': 8.37.0(eslint@9.31.0)(typescript@5.8.3) '@typescript-eslint/utils': 8.37.0(eslint@10.0.0)(typescript@5.8.3)
eslint: 9.31.0 eslint: 10.0.0
optionalDependencies: optionalDependencies:
typescript: 5.8.3 typescript: 5.8.3
vitest: 3.2.4(@types/node@24.0.15) vitest: 3.2.4(@types/node@24.0.15)
@@ -2848,10 +2889,6 @@ snapshots:
json-schema-traverse: 1.0.0 json-schema-traverse: 1.0.0
require-from-string: 2.0.2 require-from-string: 2.0.2
ansi-styles@4.3.0:
dependencies:
color-convert: 2.0.1
are-docs-informative@0.0.2: {} are-docs-informative@0.0.2: {}
argparse@2.0.1: {} argparse@2.0.1: {}
@@ -2942,6 +2979,10 @@ snapshots:
balanced-match@1.0.2: {} balanced-match@1.0.2: {}
balanced-match@4.0.2:
dependencies:
jackspeak: 4.2.3
brace-expansion@1.1.12: brace-expansion@1.1.12:
dependencies: dependencies:
balanced-match: 1.0.2 balanced-match: 1.0.2
@@ -2951,6 +2992,10 @@ snapshots:
dependencies: dependencies:
balanced-match: 1.0.2 balanced-match: 1.0.2
brace-expansion@5.0.2:
dependencies:
balanced-match: 4.0.2
braces@3.0.3: braces@3.0.3:
dependencies: dependencies:
fill-range: 7.1.1 fill-range: 7.1.1
@@ -2995,11 +3040,6 @@ snapshots:
loupe: 3.1.4 loupe: 3.1.4
pathval: 2.0.1 pathval: 2.0.1
chalk@4.1.2:
dependencies:
ansi-styles: 4.3.0
supports-color: 7.2.0
check-error@2.1.1: {} check-error@2.1.1: {}
ci-info@4.3.0: {} ci-info@4.3.0: {}
@@ -3008,12 +3048,6 @@ snapshots:
dependencies: dependencies:
escape-string-regexp: 1.0.5 escape-string-regexp: 1.0.5
color-convert@2.0.1:
dependencies:
color-name: 1.1.4
color-name@1.1.4: {}
comment-parser@1.4.1: {} comment-parser@1.4.1: {}
concat-map@0.0.1: {} concat-map@0.0.1: {}
@@ -3024,6 +3058,10 @@ snapshots:
dependencies: dependencies:
browserslist: 4.25.1 browserslist: 4.25.1
cron-parser@4.9.0:
dependencies:
luxon: 3.7.2
cross-spawn@7.0.6: cross-spawn@7.0.6:
dependencies: dependencies:
path-key: 3.1.1 path-key: 3.1.1
@@ -3261,27 +3299,27 @@ snapshots:
transitivePeerDependencies: transitivePeerDependencies:
- supports-color - supports-color
eslint-module-utils@2.12.1(@typescript-eslint/parser@8.19.0(eslint@9.31.0)(typescript@5.8.3))(eslint-import-resolver-node@0.3.9)(eslint@9.31.0): eslint-module-utils@2.12.1(@typescript-eslint/parser@8.19.0(eslint@10.0.0)(typescript@5.8.3))(eslint-import-resolver-node@0.3.9)(eslint@10.0.0):
dependencies: dependencies:
debug: 3.2.7 debug: 3.2.7
optionalDependencies: optionalDependencies:
'@typescript-eslint/parser': 8.19.0(eslint@9.31.0)(typescript@5.8.3) '@typescript-eslint/parser': 8.19.0(eslint@10.0.0)(typescript@5.8.3)
eslint: 9.31.0 eslint: 10.0.0
eslint-import-resolver-node: 0.3.9 eslint-import-resolver-node: 0.3.9
transitivePeerDependencies: transitivePeerDependencies:
- supports-color - supports-color
eslint-plugin-deprecation@3.0.0(eslint@9.31.0)(typescript@5.8.3): eslint-plugin-deprecation@3.0.0(eslint@10.0.0)(typescript@5.8.3):
dependencies: dependencies:
'@typescript-eslint/utils': 7.18.0(eslint@9.31.0)(typescript@5.8.3) '@typescript-eslint/utils': 7.18.0(eslint@10.0.0)(typescript@5.8.3)
eslint: 9.31.0 eslint: 10.0.0
ts-api-utils: 1.4.3(typescript@5.8.3) ts-api-utils: 1.4.3(typescript@5.8.3)
tslib: 2.8.1 tslib: 2.8.1
typescript: 5.8.3 typescript: 5.8.3
transitivePeerDependencies: transitivePeerDependencies:
- supports-color - supports-color
eslint-plugin-import@2.31.0(@typescript-eslint/parser@8.19.0(eslint@9.31.0)(typescript@5.8.3))(eslint@9.31.0): eslint-plugin-import@2.31.0(@typescript-eslint/parser@8.19.0(eslint@10.0.0)(typescript@5.8.3))(eslint@10.0.0):
dependencies: dependencies:
'@rtsao/scc': 1.1.0 '@rtsao/scc': 1.1.0
array-includes: 3.1.9 array-includes: 3.1.9
@@ -3290,9 +3328,9 @@ snapshots:
array.prototype.flatmap: 1.3.3 array.prototype.flatmap: 1.3.3
debug: 3.2.7 debug: 3.2.7
doctrine: 2.1.0 doctrine: 2.1.0
eslint: 9.31.0 eslint: 10.0.0
eslint-import-resolver-node: 0.3.9 eslint-import-resolver-node: 0.3.9
eslint-module-utils: 2.12.1(@typescript-eslint/parser@8.19.0(eslint@9.31.0)(typescript@5.8.3))(eslint-import-resolver-node@0.3.9)(eslint@9.31.0) eslint-module-utils: 2.12.1(@typescript-eslint/parser@8.19.0(eslint@10.0.0)(typescript@5.8.3))(eslint-import-resolver-node@0.3.9)(eslint@10.0.0)
hasown: 2.0.2 hasown: 2.0.2
is-core-module: 2.16.1 is-core-module: 2.16.1
is-glob: 4.0.3 is-glob: 4.0.3
@@ -3304,20 +3342,20 @@ snapshots:
string.prototype.trimend: 1.0.9 string.prototype.trimend: 1.0.9
tsconfig-paths: 3.15.0 tsconfig-paths: 3.15.0
optionalDependencies: optionalDependencies:
'@typescript-eslint/parser': 8.19.0(eslint@9.31.0)(typescript@5.8.3) '@typescript-eslint/parser': 8.19.0(eslint@10.0.0)(typescript@5.8.3)
transitivePeerDependencies: transitivePeerDependencies:
- eslint-import-resolver-typescript - eslint-import-resolver-typescript
- eslint-import-resolver-webpack - eslint-import-resolver-webpack
- supports-color - supports-color
eslint-plugin-jsdoc@50.6.1(eslint@9.31.0): eslint-plugin-jsdoc@50.6.1(eslint@10.0.0):
dependencies: dependencies:
'@es-joy/jsdoccomment': 0.49.0 '@es-joy/jsdoccomment': 0.49.0
are-docs-informative: 0.0.2 are-docs-informative: 0.0.2
comment-parser: 1.4.1 comment-parser: 1.4.1
debug: 4.4.1 debug: 4.4.1
escape-string-regexp: 4.0.0 escape-string-regexp: 4.0.0
eslint: 9.31.0 eslint: 10.0.0
espree: 10.4.0 espree: 10.4.0
esquery: 1.6.0 esquery: 1.6.0
parse-imports: 2.2.1 parse-imports: 2.2.1
@@ -3327,12 +3365,12 @@ snapshots:
transitivePeerDependencies: transitivePeerDependencies:
- supports-color - supports-color
eslint-plugin-playwright@2.1.0(eslint@9.31.0): eslint-plugin-playwright@2.1.0(eslint@10.0.0):
dependencies: dependencies:
eslint: 9.31.0 eslint: 10.0.0
globals: 13.24.0 globals: 13.24.0
eslint-plugin-react@7.37.3(eslint@9.31.0): eslint-plugin-react@7.37.3(eslint@10.0.0):
dependencies: dependencies:
array-includes: 3.1.9 array-includes: 3.1.9
array.prototype.findlast: 1.2.5 array.prototype.findlast: 1.2.5
@@ -3340,7 +3378,7 @@ snapshots:
array.prototype.tosorted: 1.1.4 array.prototype.tosorted: 1.1.4
doctrine: 2.1.0 doctrine: 2.1.0
es-iterator-helpers: 1.2.1 es-iterator-helpers: 1.2.1
eslint: 9.31.0 eslint: 10.0.0
estraverse: 5.3.0 estraverse: 5.3.0
hasown: 2.0.2 hasown: 2.0.2
jsx-ast-utils: 3.3.5 jsx-ast-utils: 3.3.5
@@ -3361,14 +3399,14 @@ snapshots:
natural-compare: 1.4.0 natural-compare: 1.4.0
requireindex: 1.2.0 requireindex: 1.2.0
eslint-plugin-unicorn@56.0.1(eslint@9.31.0): eslint-plugin-unicorn@56.0.1(eslint@10.0.0):
dependencies: dependencies:
'@babel/helper-validator-identifier': 7.27.1 '@babel/helper-validator-identifier': 7.27.1
'@eslint-community/eslint-utils': 4.7.0(eslint@9.31.0) '@eslint-community/eslint-utils': 4.7.0(eslint@10.0.0)
ci-info: 4.3.0 ci-info: 4.3.0
clean-regexp: 1.0.0 clean-regexp: 1.0.0
core-js-compat: 3.44.0 core-js-compat: 3.44.0
eslint: 9.31.0 eslint: 10.0.0
esquery: 1.6.0 esquery: 1.6.0
globals: 15.14.0 globals: 15.14.0
indent-string: 4.0.0 indent-string: 4.0.0
@@ -3381,8 +3419,10 @@ snapshots:
semver: 7.7.2 semver: 7.7.2
strip-indent: 3.0.0 strip-indent: 3.0.0
eslint-scope@8.4.0: eslint-scope@9.1.0:
dependencies: dependencies:
'@types/esrecurse': 4.3.1
'@types/estree': 1.0.8
esrecurse: 4.3.0 esrecurse: 4.3.0
estraverse: 5.3.0 estraverse: 5.3.0
@@ -3392,30 +3432,28 @@ snapshots:
eslint-visitor-keys@4.2.1: {} eslint-visitor-keys@4.2.1: {}
eslint@9.31.0: eslint-visitor-keys@5.0.0: {}
eslint@10.0.0:
dependencies: dependencies:
'@eslint-community/eslint-utils': 4.7.0(eslint@9.31.0) '@eslint-community/eslint-utils': 4.9.1(eslint@10.0.0)
'@eslint-community/regexpp': 4.12.1 '@eslint-community/regexpp': 4.12.2
'@eslint/config-array': 0.21.0 '@eslint/config-array': 0.23.1
'@eslint/config-helpers': 0.3.0 '@eslint/config-helpers': 0.5.2
'@eslint/core': 0.15.1 '@eslint/core': 1.1.0
'@eslint/eslintrc': 3.3.1 '@eslint/plugin-kit': 0.6.0
'@eslint/js': 9.31.0
'@eslint/plugin-kit': 0.3.3
'@humanfs/node': 0.16.6 '@humanfs/node': 0.16.6
'@humanwhocodes/module-importer': 1.0.1 '@humanwhocodes/module-importer': 1.0.1
'@humanwhocodes/retry': 0.4.3 '@humanwhocodes/retry': 0.4.3
'@types/estree': 1.0.8 '@types/estree': 1.0.8
'@types/json-schema': 7.0.15
ajv: 6.12.6 ajv: 6.12.6
chalk: 4.1.2
cross-spawn: 7.0.6 cross-spawn: 7.0.6
debug: 4.4.1 debug: 4.4.1
escape-string-regexp: 4.0.0 escape-string-regexp: 4.0.0
eslint-scope: 8.4.0 eslint-scope: 9.1.0
eslint-visitor-keys: 4.2.1 eslint-visitor-keys: 5.0.0
espree: 10.4.0 espree: 11.1.0
esquery: 1.6.0 esquery: 1.7.0
esutils: 2.0.3 esutils: 2.0.3
fast-deep-equal: 3.1.3 fast-deep-equal: 3.1.3
file-entry-cache: 8.0.0 file-entry-cache: 8.0.0
@@ -3425,8 +3463,7 @@ snapshots:
imurmurhash: 0.1.4 imurmurhash: 0.1.4
is-glob: 4.0.3 is-glob: 4.0.3
json-stable-stringify-without-jsonify: 1.0.1 json-stable-stringify-without-jsonify: 1.0.1
lodash.merge: 4.6.2 minimatch: 10.2.1
minimatch: 3.1.2
natural-compare: 1.4.0 natural-compare: 1.4.0
optionator: 0.9.4 optionator: 0.9.4
transitivePeerDependencies: transitivePeerDependencies:
@@ -3438,6 +3475,12 @@ snapshots:
acorn-jsx: 5.3.2(acorn@8.15.0) acorn-jsx: 5.3.2(acorn@8.15.0)
eslint-visitor-keys: 4.2.1 eslint-visitor-keys: 4.2.1
espree@11.1.0:
dependencies:
acorn: 8.15.0
acorn-jsx: 5.3.2(acorn@8.15.0)
eslint-visitor-keys: 5.0.0
espree@6.2.1: espree@6.2.1:
dependencies: dependencies:
acorn: 7.4.1 acorn: 7.4.1
@@ -3448,6 +3491,10 @@ snapshots:
dependencies: dependencies:
estraverse: 5.3.0 estraverse: 5.3.0
esquery@1.7.0:
dependencies:
estraverse: 5.3.0
esrecurse@4.3.0: esrecurse@4.3.0:
dependencies: dependencies:
estraverse: 5.3.0 estraverse: 5.3.0
@@ -3635,8 +3682,6 @@ snapshots:
has-bigints@1.1.0: {} has-bigints@1.1.0: {}
has-flag@4.0.0: {}
has-property-descriptors@1.0.2: has-property-descriptors@1.0.2:
dependencies: dependencies:
es-define-property: 1.0.1 es-define-property: 1.0.1
@@ -3802,6 +3847,10 @@ snapshots:
has-symbols: 1.1.0 has-symbols: 1.1.0
set-function-name: 2.0.2 set-function-name: 2.0.2
jackspeak@4.2.3:
dependencies:
'@isaacs/cliui': 9.0.0
js-tokens@4.0.0: {} js-tokens@4.0.0: {}
js-tokens@9.0.1: {} js-tokens@9.0.1: {}
@@ -3866,18 +3915,20 @@ snapshots:
dependencies: dependencies:
p-locate: 5.0.0 p-locate: 5.0.0
lodash.merge@4.6.2: {}
lodash.snakecase@4.1.1: {} lodash.snakecase@4.1.1: {}
lodash@4.17.21: {} lodash@4.17.21: {}
long-timeout@0.1.1: {}
loose-envify@1.4.0: loose-envify@1.4.0:
dependencies: dependencies:
js-tokens: 4.0.0 js-tokens: 4.0.0
loupe@3.1.4: {} loupe@3.1.4: {}
luxon@3.7.2: {}
magic-bytes.js@1.12.1: {} magic-bytes.js@1.12.1: {}
magic-string@0.30.17: magic-string@0.30.17:
@@ -3895,6 +3946,10 @@ snapshots:
min-indent@1.0.1: {} min-indent@1.0.1: {}
minimatch@10.2.1:
dependencies:
brace-expansion: 5.0.2
minimatch@3.1.2: minimatch@3.1.2:
dependencies: dependencies:
brace-expansion: 1.1.12 brace-expansion: 1.1.12
@@ -3913,6 +3968,12 @@ snapshots:
node-releases@2.0.19: {} node-releases@2.0.19: {}
node-schedule@2.1.1:
dependencies:
cron-parser: 4.9.0
long-timeout: 0.1.1
sorted-array-functions: 1.3.0
normalize-package-data@2.5.0: normalize-package-data@2.5.0:
dependencies: dependencies:
hosted-git-info: 2.8.9 hosted-git-info: 2.8.9
@@ -4287,6 +4348,8 @@ snapshots:
dependencies: dependencies:
atomic-sleep: 1.0.0 atomic-sleep: 1.0.0
sorted-array-functions@1.3.0: {}
source-map-js@1.2.1: {} source-map-js@1.2.1: {}
spdx-correct@3.2.0: spdx-correct@3.2.0:
@@ -4375,10 +4438,6 @@ snapshots:
dependencies: dependencies:
js-tokens: 9.0.1 js-tokens: 9.0.1
supports-color@7.2.0:
dependencies:
has-flag: 4.0.0
supports-preserve-symlinks-flag@1.0.0: {} supports-preserve-symlinks-flag@1.0.0: {}
synckit@0.9.3: synckit@0.9.3:
-109
View File
@@ -604,61 +604,6 @@ export const anime: Array<Ascii> = [
⣿⠁⣿⠀⠀⡀⠀⣿⣿⡇⣿⣿⣿⣿⠏⠀⠀⠀⠂⢀⣼⣿⣿⣿⣿⣿⣿⠁⢀⣦⡘⢿⡏⢠⣿⡇⣴⣿⣿⣿⡦⢰⣿⣿⣿⣿⣿⣿⣿⣿⠃⣿⣿⣿⣿⣿⣿⣿⣿ ⣿⠁⣿⠀⠀⡀⠀⣿⣿⡇⣿⣿⣿⣿⠏⠀⠀⠀⠂⢀⣼⣿⣿⣿⣿⣿⣿⠁⢀⣦⡘⢿⡏⢠⣿⡇⣴⣿⣿⣿⡦⢰⣿⣿⣿⣿⣿⣿⣿⣿⠃⣿⣿⣿⣿⣿⣿⣿⣿
⣿⣰⡏⠀⠀⡇⢰⢹⣿⡇⢻⣿⣿⡿⠀⠀⠀⠀⣠⣾⣿⣿⣿⣿⣿⣿⠁⡀⢿⣿⣿⣾⢁⣾⣿⡇⣿⣿⣿⣿⠁⣾⣿⣿⣿⣿⣿⣿⣿⡏⣰⣿⣿⣿⣿⣿⣿⣿⣿ ⣿⣰⡏⠀⠀⡇⢰⢹⣿⡇⢻⣿⣿⡿⠀⠀⠀⠀⣠⣾⣿⣿⣿⣿⣿⣿⠁⡀⢿⣿⣿⣾⢁⣾⣿⡇⣿⣿⣿⣿⠁⣾⣿⣿⣿⣿⣿⣿⣿⡏⣰⣿⣿⣿⣿⣿⣿⣿⣿
⣇⣿⠁⠀⠀⡇⠸⣸⣿⣷⠸⣿⣿⠀⠀⠀⠀⣼⠟⠙⢿⣿⣿⣿⡿⢁⣶⣿⣦⡍⠿⠇⣼⣿⣿⡃⣿⣿⣿⣿⠀⣿⣿⣿⣿⣿⣿⣿⡿⢠⣿⣿⣿⣿⣿⣿⣿⣿⣿`, ⣇⣿⠁⠀⠀⡇⠸⣸⣿⣷⠸⣿⣿⠀⠀⠀⠀⣼⠟⠙⢿⣿⣿⣿⡿⢁⣶⣿⣦⡍⠿⠇⣼⣿⣿⡃⣿⣿⣿⣿⠀⣿⣿⣿⣿⣿⣿⣿⡿⢠⣿⣿⣿⣿⣿⣿⣿⣿⣿`,
},
{
author: "https://emojicombos.com/anime-ascii-art",
text: `⢘⣿⣽⡿⣟⣯⢘⣯⢻⡭⢯⡝⣎⠷⣙⢮⡱⢣⡙⢦⡙⢆⠳⣌⠲⡡⢆⡑⢢⡘⣐⢂⡒⡐⢢⠐⢢⠐⢢⠐⡄⠢⡐⡀⠆⡐⠠⠐⠠⢀⠂⠄⠠⠀⠄⠠⠀⠄⠠⢀⠠⢀⠀⡀⢀⠀⡀⠀⠀⡀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⢘⣿⣾⣽⣟⡾⢨⡗⣯⢞⡧⣝⢎⡳⣍⠶⣩⢇⡹⢢⡙⣌⠳⣄⢣⡑⢎⠬⣁⠖⡈⢆⡔⠡⢆⡉⢆⠩⡐⢌⠰⡁⠤⣁⠒⡈⠄⠃⠌⢠⠈⠄⠡⠈⠄⠡⠈⠄⡁⠂⠠⢀⠂⠀⠄⡀⠄⠈⢀⠀⠐⠀⡀⠀⢀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⢘⣯⣿⣞⣯⣟⢰⡻⣜⢯⡞⡼⣍⠶⣍⠞⣥⢚⢬⢣⢱⢊⠵⣈⠦⡙⣌⠲⣁⠎⣑⠢⢌⡑⢢⠘⡄⢣⠘⡄⢒⠨⡐⠄⢒⠈⡄⢉⡐⠠⠈⠄⠡⠈⠄⠡⢈⠐⡀⢁⠂⠄⠐⠈⡀⢀⠐⠈⢀⠠⠈⠀⢀⠀⠀⠀⠀⠂⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⠸⣯⣷⣟⡿⣞⠰⣯⡝⣮⣓⢳⢎⡽⣌⠻⣤⢋⢦⢣⢣⠚⡜⡤⢣⠱⣌⠓⣌⠲⣁⠎⡔⡨⡁⢎⠰⣁⠒⡈⠆⡡⢐⠉⡄⠒⡀⠆⠠⠑⡈⠤⠁⠌⠠⢁⠂⡐⢀⠂⠠⢈⠠⠁⡀⠄⠠⠈⠀⡀⠄⠈⠀⠀⠐⠈⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⢸⣟⣷⣯⣿⡽⣘⢧⣛⢦⡝⣎⡳⡜⣬⠳⣌⣋⢦⢃⡇⢫⠴⣑⢣⠓⣌⠳⢌⠲⣈⠖⣠⠑⡌⢢⠑⡄⠃⡜⠠⢁⣂⣘⣠⣥⣤⣬⣤⣥⣤⣤⣥⣬⣐⣀⣂⠐⠠⠀⡁⠠⢀⠐⠀⠄⠂⡀⠁⡀⠀⠂⠁⠠⠀⠀⡀⠄⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⠸⣿⢿⡿⣽⣳⠸⣏⢾⡱⢞⡥⢳⡙⢦⡛⡴⡘⠦⣍⠼⣡⠚⡤⢣⡙⢤⢋⠬⡱⠐⡬⢄⠣⡘⠄⣃⣬⣵⣶⣿⡿⠿⣿⣟⣛⣛⣿⣿⣟⣿⣻⣛⣛⣻⣿⠿⠿⣿⣶⣦⣥⣀⡂⠈⢀⠐⠀⡐⠀⠐⠀⡐⠀⠠⠀⠀⠀⠀⢀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⠈⠉⠋⠘⠓⠉⠸⣝⠶⣹⢣⢞⡣⡝⢦⡓⣥⠫⡕⣊⠖⣡⢋⠴⢣⠜⡢⢍⡒⡡⢍⠰⢌⣢⣵⣿⡿⢟⣫⠽⣀⣾⠿⣽⠾⣽⣛⡾⢧⣟⣦⢭⣙⠯⣷⢯⡿⣟⡷⣾⣭⡽⣛⡿⣿⣦⣤⡐⠀⠐⠈⢀⠀⠄⠀⡀⠄⠂⠈⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⢀⣤⣁⣐⣀⡈⢀⣟⠺⡥⢏⢮⡱⣙⢦⡹⢤⠓⣥⢣⠚⡥⢪⡑⢣⠎⡱⠢⢌⡱⣈⣴⣿⡿⣻⣵⢾⠿⣩⣞⡷⣯⢿⣹⣟⠇⣼⣻⣟⣮⣟⣯⣟⣳⡌⠋⢿⡽⣽⣣⢿⡵⣮⣍⡳⢾⣝⡻⣷⣤⡐⠀⢀⠠⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⢨⣷⣿⣿⣯⠇⣺⢜⣫⠵⣋⠶⡱⣍⠦⣓⠬⣋⡔⢣⡹⣐⠣⡜⡡⢎⠱⡑⣪⣾⣿⠟⣽⢾⡽⡾⢉⣴⣟⡾⣽⢯⣟⣷⣻⣀⡿⣷⢾⣳⣟⣮⣟⡷⣿⣧⣤⡿⣿⡽⣯⣟⣷⣻⣟⣶⡉⠟⣷⣭⣻⢷⣄⠀⠀⠐⠀⠀⠂⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⢘⣯⣿⡷⣿⡃⢜⣣⢎⡳⣍⢳⡱⢎⡱⢎⡱⢆⡙⢦⠱⣌⠳⢌⡱⢌⢃⣴⣿⢟⢡⡾⣽⢯⣟⢡⢾⣟⣾⣟⡿⣯⣟⣯⡟⢯⡿⣽⢯⣷⣻⢾⣽⣻⢷⣯⣷⡐⢯⣿⡓⢿⣾⣳⣟⢾⣽⣛⡉⢿⣻⣷⣝⢷⣄⠀⢀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⢨⣷⣿⣻⣟⡇⢸⡱⢎⡵⢎⠧⡜⢎⡱⢎⡱⢊⡝⢢⠓⣌⠲⢡⠒⣠⣿⢟⣵⢣⡾⣽⢯⡿⢂⣿⣻⣞⡿⣞⢠⣽⣟⣿⠀⣿⣻⣽⣻⢾⡽⣻⡆⣎⣟⣾⣳⡧⠸⣿⣷⡌⢷⣟⡾⣯⣞⣽⡶⣄⣿⢾⣿⣦⡝⢷⣄⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⢨⣷⣿⣻⣯⠇⣸⢱⣋⠶⣩⠚⣥⢋⢖⢣⡱⢋⡜⣡⢋⠴⣉⠆⣵⡿⣫⣿⢃⣾⡝⢻⣯⣁⣾⢯⡷⣯⣻⠇⣞⡿⣾⠇⣯⡷⣟⠾⣽⢯⢿⢹⣞⢿⢸⡷⣯⢿⢠⢻⣯⣷⡈⢾⣟⣷⢰⡹⣽⣻⡘⣿⢾⣽⣻⣮⠙⣷⡄⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⢰⡿⣟⣷⣿⡃⠴⢣⢎⡳⣡⠛⣤⢋⡜⣢⠑⢧⡘⢤⠋⡔⢂⣾⡟⣽⡿⡍⣼⡟⢰⣟⣯⣟⣿⢰⢺⡿⣽⢰⣻⣽⣿⢸⣗⡿⢯⣀⡿⣯⣟⡷⣞⣾⣻⡽⣾⠙⡆⡎⣷⣟⣧⢈⢿⡾⣏⠧⣹⢷⣧⠘⣟⡾⡝⣋⣷⡙⣿⣦⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⢰⡿⣿⣻⣞⡇⢸⠣⣎⠵⣂⠟⡤⢓⠼⣠⠛⡤⣙⠢⢍⢂⣾⡟⣾⢯⡿⢰⣿⢡⣿⡛⢸⡽⣞⠿⣸⣿⠃⣸⣷⣻⡎⣼⡧⢃⣶⣻⣽⣳⣯⢿⡽⣞⡷⣻⡽⣶⡀⡻⡸⣽⡾⣇⣆⢿⣽⣻⣭⣟⡾⣇⢹⣻⢷⡹⡎⣷⡈⣟⣷⡀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⢨⣿⣟⣷⣿⡃⢌⡳⢌⠶⣉⠞⣰⢋⠖⣡⢋⡔⠢⢍⡂⣼⡟⣼⣟⣯⡇⣾⡏⡜⡍⣥⡾⣽⣻⢾⡽⣾⠀⢻⣼⢷⠇⣻⡆⣿⣳⣟⣾⣳⢯⡿⣽⢯⣻⢷⣻⢽⡇⢿⣆⢍⡛⢿⢸⡌⣷⣻⣞⡾⣽⢯⡘⣞⣿⠳⣶⢿⣧⠘⢮⢿⡄⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⢨⣷⣿⣯⣷⡇⢘⢲⠩⡖⣩⠚⡤⢋⡜⢤⠣⢌⠓⠤⢰⡿⣹⣟⡾⡷⠁⣿⢠⡷⢧⢿⣻⢷⣯⢿⣽⡇⡇⡿⢋⡥⠆⠿⣇⢻⣵⣻⢾⣽⣫⢿⣽⣫⣟⣯⢷⠘⣏⢺⣿⡘⣋⣓⡎⣽⢘⡳⠟⢻⣽⣻⡅⡿⣯⣇⢹⡿⣿⣦⠈⢯⣻⡔⢀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⠸⣷⡿⣽⡷⡇⢨⡃⠷⡘⢥⢋⡔⢣⠜⡢⡑⢊⠜⡀⣿⣇⣿⡿⡝⣰⢿⣧⢘⣿⡟⣸⢿⣯⣟⡿⠟⣀⡇⣶⣻⢶⠁⣿⣿⢈⣳⢯⠏⣾⣽⣻⢾⣳⣟⢾⣻⠌⣟⢸⣿⣇⢿⣽⡃⣿⣇⢿⣻⢿⡽⣷⡷⢸⢿⣿⡌⣿⢯⣷⡀⠈⣯⢿⡀⠠⡀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⢸⣯⣿⢿⡽⡇⢰⡉⡖⡩⢆⠣⡜⡡⢎⠱⡈⢅⣊⣤⣭⣭⡙⡟⣸⡿⢸⡏⣎⣿⢅⢾⣟⣃⣭⡴⣿⢸⡇⡷⣯⢿⢸⣿⣿⡜⣯⢿⣆⢹⣷⣻⢯⡷⣯⢿⣽⣠⡏⣾⣿⣿⠘⢾⡇⢿⣿⡌⣿⢯⡿⣽⣻⢘⣯⡿⡇⢽⡿⣟⡇⠀⠘⣿⣷⡀⠈⠂⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⢸⣯⣿⣟⡿⡇⢰⠱⢌⡱⢊⡑⢆⡱⢈⢆⣴⣿⣷⠀⠠⢈⢣⢰⢏⣔⣸⡃⣾⡟⢸⢺⡿⣽⡾⣟⡶⣸⣷⢹⣯⠿⢨⣿⣟⣇⢻⣻⢾⡌⣷⢿⣯⣟⣿⣻⢾⢩⡇⣿⠾⠿⠇⠺⠿⢸⣿⣧⢻⣯⣟⣷⡿⠈⣷⣿⡇⢾⣿⣿⡷⠀⠀⠸⡿⣧⠀⠀⠈⠢⡀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⠸⢛⣡⣭⣶⣶⣦⣥⣌⡒⠡⠜⡠⢂⡁⡾⠿⠿⣿⣇⢁⠂⠌⡆⣿⡏⢻⡁⣿⡇⣾⠸⣟⣿⣽⣟⡇⣿⠟⠈⠀⠀⠀⠀⠈⠹⡊⢯⣟⡷⡸⣯⢷⣻⣶⣻⠏⣸⠰⠊⣀⣤⣤⣤⡄⣀⠈⠙⠜⣷⣿⢯⣿⢀⢻⣷⡇⢾⣟⣯⡟⠀⠀⠀⢹⣽⡄⠀⠀⠀⠀⠀⢄⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⣶⡿⠿⢛⣛⡙⠛⠻⠿⢿⣷⣮⡐⠡⠄⢻⡀⢢⠈⠿⠠⠘⣠⡟⣠⡅⣼⡇⣿⡄⣿⡎⣿⣟⣾⡽⠃⠁⣀⣄⢶⣿⠉⣿⣷⣶⣬⡈⢾⡽⣧⠸⣯⢷⣯⢏⣰⢇⣠⡾⠛⠉⠉⢠⢅⢿⣷⣆⠀⠸⣯⣿⠇⣾⢸⣿⡇⣾⣟⣿⡏⠀⠀⠀⠀⣿⣇⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⢫⣴⡿⣟⡷⣇⢰⡶⣦⣖⣬⡙⠻⢷⣬⡀⠳⣄⢈⡠⠴⠶⡶⠶⡹⡇⢾⡇⣽⡆⣿⡧⢸⣿⡟⠀⠀⠀⠁⢰⡔⣮⠃⣿⣿⣿⣿⣿⣌⢽⣳⡇⠺⣟⡾⣏⢋⣾⣿⠁⠀⠀⠀⢀⠋⠀⣿⣿⣧⠀⠸⢣⣤⣿⢨⡷⢰⣿⢿⣿⠁⠀⠀⠀⠀⢸⣿⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⢸⣟⣿⡽⣟⣇⢺⣽⢷⣻⣾⣽⣣⠀⡈⢉⠓⢤⣷⣿⣧⢛⢬⢣⢱⡁⣾⣇⢸⡇⢿⣿⡆⢻⠀⢀⠰⠀⠀⠀⢉⡈⠂⢹⣿⣿⣿⣿⣿⣷⣜⡹⠧⢙⠞⣡⣿⣿⣿⡄⣄⠀⣠⣾⣷⡄⣿⣿⣿⠀⠀⣿⢸⣿⠰⢡⢻⣿⣿⠟⠀⠀⠀⠀⠀⢸⡟⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⢸⣯⡿⣽⢿⡎⣼⢯⣟⣯⣷⣿⣽⠂⡀⠃⠌⣏⢙⠿⣿⡌⡖⢣⠆⠇⣿⣿⣂⢟⢸⣿⣿⡎⠂⠘⡌⠀⠀⢀⡼⣿⡆⣸⣿⣿⣿⣿⣿⣿⡿⣡⢛⣩⣾⣿⣿⣿⣿⣿⣜⡿⠷⠦⣙⣴⣿⣿⡿⢀⣼⣿⢸⢿⣤⣿⢸⣿⠏⠀⠀⠀⠀⠀⠀⠸⠁⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⢸⡷⣿⢯⣟⡷⣸⡿⣞⣷⣯⣷⣻⠄⠠⡉⠄⠸⣌⡒⠭⠱⣉⠥⣪⡅⣯⣷⡿⣮⠀⢻⣾⣟⢸⣦⣑⣜⠿⣿⡿⢗⣵⣿⣿⣿⣿⣿⣿⣿⣷⣶⣿⣿⣿⣿⣏⣿⣿⣷⣝⣻⢿⡿⢿⣿⣛⣯⣿⣿⣿⣿⢸⣻⣞⣇⣘⣡⡄⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⠸⣟⣿⡿⣯⡷⣹⢿⣽⣻⡾⣿⣽⠂⠡⠐⣈⠐⡈⢉⢩⣽⣶⣿⢿⡇⣟⣯⡿⣽⣻⣟⡷⢸⢸⣿⣿⣯⣝⣛⣛⣛⣿⣽⣾⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⢸⣳⢯⣟⣿⡿⡇⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⣤⣛⣋⣛⣳⣋⣬⣭⣬⣥⣯⡽⣬⣃⣤⣁⡀⢂⠐⠠⢸⣿⣳⣿⣻⢀⣿⣳⡿⣽⣳⢯⣟⠸⢸⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣼⣫⣟⡾⣯⣿⣧⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⢋⠛⡙⢋⠛⠙⠋⠛⠙⠛⠺⠙⠛⠟⠯⠛⠄⠂⠈⠐⢸⣿⣟⣾⢿⢈⣿⢿⡽⣷⢯⣟⣾⡃⢸⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⡟⣥⣶⣶⢶⣶⢶⡖⢹⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⡇⡷⣯⢿⡽⣷⣿⡄⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⠢⠑⠘⠢⢉⠬⠡⠍⣊⠑⠆⠩⠒⢌⠢⠱⡈⠆⠍⠂⢸⣿⣟⣯⣿⢸⣯⢿⡽⣯⣟⣾⣳⠇⢸⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⢸⣷⣻⣾⣟⣾⣯⢿⡃⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⡇⡿⣭⣟⣿⣟⣿⣧⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⠰⡐⢂⠖⡠⢂⠔⡰⢀⠆⡒⡄⠦⢠⠒⠤⠰⡐⠤⠂⣼⣿⢯⣟⡞⣸⢯⡿⣽⣳⣟⣾⣭⡇⢘⢿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⡇⡿⣾⣽⣷⢿⣻⣾⣟⡇⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⠃⡿⣵⣻⣾⣻⣿⣿⡀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⣶⣶⣶⡶⣶⣲⢶⣲⣦⣶⣴⣴⣦⣦⣴⣤⢦⠀⠀⠀⣿⣯⣿⣯⡇⣽⣻⢿⣽⣳⣟⣾⣳⣟⢸⢁⢻⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣇⣹⣟⣾⢿⣻⣽⣾⡽⠇⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⡟⣱⠇⣟⣷⣻⣼⣟⣷⣿⣇⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⠉⢐⣶⣶⣶⣦⡏⠓⠋⠓⠛⠙⠛⠛⠙⠚⠉⠀⡐⠀⣿⣿⣷⣟⠇⣾⣽⣻⣞⣷⣻⡞⣧⣿⠸⢨⣇⢻⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⡀⣿⡽⣿⢯⣷⣯⡟⢸⣿⣿⣿⣿⣿⣿⣿⣿⡿⢫⡼⢯⣇⢻⣞⣷⣻⣾⣟⣯⣿⡀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⠀⢌⣿⣟⣿⣾⡇⠀⡐⢀⠂⡐⠠⠀⢀⠐⠈⢀⠀⢰⣿⢿⣷⣻⢇⣿⣞⣷⣟⡾⣷⠃⡿⣟⠀⣾⡽⣧⢙⢿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣷⣌⠿⣝⣯⠷⢋⣴⣿⣿⣿⣿⣿⣿⣿⢟⠩⡎⢰⣟⢸⣯⢸⣟⡾⣽⣞⣯⡿⣿⣇⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⠀⢨⣿⣾⣟⣷⡇⢀⠐⡀⢂⠄⡁⠂⠀⠠⠈⠀⡀⢼⢻⣿⣟⡿⢸⣷⣻⢾⣽⣻⣽⢂⢹⣿⡇⣯⡿⡽⢸⣷⢩⣛⠿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣷⣶⣶⣾⣿⣿⣿⣿⣿⡿⢟⣫⡵⡏⢸⣧⢈⣿⡀⣿⢸⣾⠇⣿⢯⣿⣽⣻⣿⡀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⠀⢢⣿⣽⡿⣯⡇⠀⢂⠐⡀⠂⠄⡁⠀⠁⡀⠁⢀⡏⣬⣿⣿⡓⣸⣷⣻⣟⣾⣳⢿⢸⢸⣿⡇⣿⣽⡇⣻⡎⢸⣽⣻⢰⣮⡭⠟⡛⣻⣿⣿⣿⣿⣿⣿⡿⠿⠿⠿⢛⣋⣑⡆⢿⣳⣟⡗⢸⣯⣄⣿⣧⠸⢸⢾⡃⣿⣻⣯⣿⣟⣷⡇⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⠀⠰⣿⣳⣿⢿⡇⠐⡀⠂⠄⡉⠐⠀⠀⠐⠀⡀⡼⣰⣿⣻⣽⠃⣿⣽⢷⣻⡾⣽⣿⠸⡄⣿⡆⣟⣿⢁⡷⣏⢰⣿⡉⡖⣩⡖⣿⡷⢹⣿⣿⣿⣿⣿⣿⣿⣿⣶⡄⣾⣿⡿⢋⣵⡂⢹⣿⢸⣿⡍⢿⣿⣇⢸⣿⠁⢸⣿⣻⣷⣻⣿⣻⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⠀⢘⣿⢿⣽⣟⡇⠀⠀⠁⠂⠀⠁⠀⠀⠂⠀⢠⢳⣿⣿⢯⡿⢠⣿⢾⣟⣷⣻⡽⣿⢘⡇⢿⣇⢸⡿⣬⣿⣧⢸⢯⣿⠸⣿⣧⡹⢿⢸⣿⣿⣿⣿⣿⣿⣿⣿⣿⠇⣛⣭⣶⣿⣿⡟⢸⣷⡈⣿⣯⡌⣿⣯⢸⣿⢸⢸⣿⣽⡷⣿⣽⣿⡀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⠀⢨⡿⣟⣿⣞⡇⠀⠀⡀⠄⠀⠄⠐⠀⠀⠀⢤⣿⣿⢾⣻⠇⢸⣯⢿⡾⣽⢯⡿⣽⡎⣷⢸⣿⠘⢡⣟⣿⡷⢸⣻⢯⣇⢻⣿⣿⣶⣬⣟⡛⣿⢟⣭⣭⣽⣶⣾⣿⣿⣿⣿⣿⣿⡇⡟⣾⡅⢻⣿⣷⡘⡧⢸⡏⢸⡎⣷⣿⣻⣽⡾⣷⡇⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⠀⠰⣿⣟⡿⣾⡅⠀⠀⠀⠀⡀⠀⠀⠀⠀⢠⣾⣿⣻⣟⡿⢸⢸⣯⢿⡽⣯⢿⣽⣻⡇⣿⡈⣿⡆⢼⣟⣯⢿⡌⣟⣯⡟⢀⣿⣿⣿⣿⣿⡇⡆⣾⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣟⢠⢿⣽⣻⡌⣷⡿⣷⡀⣿⢃⣿⡇⣟⣾⣻⣽⢿⣳⡇⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⠀⢘⡷⣯⣿⢷⡃⠀⠀⠀⠁⠀⠀⠀⠀⢠⣿⣿⣳⣟⡾⢡⣿⢸⡷⣯⢿⣽⡻⣞⡷⡆⠿⢧⠹⣷⠸⣯⣟⡿⢆⣹⣤⡶⣼⣿⣿⣿⣿⣿⡇⡇⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⡌⣭⣚⡳⢷⡘⢟⠷⢡⡟⣸⣏⡇⢾⣳⢯⣟⣯⢿⡅⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⠀⢨⣟⡷⣯⡿⡅⠀⠀⠀⠀⠀⠀⠀⢀⣿⣟⣾⣳⣭⢃⣞⡷⠈⡿⣭⣟⡾⣽⣫⢿⡅⣛⣟⡆⢿⡆⣭⡶⢞⣫⣭⣶⣇⣿⣿⣿⣿⣿⣿⡧⣿⢽⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⡨⣭⣛⣻⠶⡶⠟⡼⢑⣛⣻⡃⢿⣽⡻⣾⡽⣻⢳⣆⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⠀⢠⡿⣽⢯⣷⡃⠀⠀⠀⠀⠀⠀⢀⣾⡿⣽⢞⣧⡟⣯⠞⣰⡿⡸⣳⣻⢞⡷⣯⢯⢷⢸⣿⣷⡈⣷⡰⣾⣿⣿⣿⣿⡞⢿⣿⣿⣿⣿⣿⣿⢿⢸⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⡿⣩⣿⣿⣿⣿⣿⡟⡸⢡⣿⣿⣿⡇⣻⣞⣽⣳⠿⡝⣈⢿⣇⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⠀⢐⡿⣽⣻⢶⡃⠀⠀⠀⠀⠀⢀⣾⢯⣟⣭⡟⣮⡽⡞⣼⡿⣱⣧⡑⢯⣻⡽⣞⢯⣯⠈⣿⣿⣷⡈⢇⢹⣿⣧⢹⣇⡹⣮⡛⢿⣿⣿⣿⣿⢸⢸⣿⣿⣿⣿⣿⣿⣿⡿⢟⢡⣾⣿⡟⣸⣿⣿⣟⣀⣵⣿⣿⣿⣿⠃⡷⣞⣳⢯⠟⣰⣿⡞⣿⣆⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⠀⢠⣟⡷⣯⣏⡇⠀⠀⠀⠀⢀⣾⢯⣟⡞⣧⢿⣱⡛⣼⡿⣱⣿⡿⣷⡌⠳⣽⢫⣟⡞⣇⢹⣿⣿⣿⣮⡀⢻⣿⡌⣿⣷⡜⢿⣷⣭⡛⠿⣿⢸⢈⣿⣿⣿⡿⠿⣛⣭⢖⣥⣾⣿⢏⣼⣿⣿⣿⣿⣿⣿⣿⣿⣿⡟⡸⡽⡏⠟⣠⣾⣿⣿⣿⢸⣿⡄⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠠
⠀⠠⣟⡾⣵⢫⡆⠀⠀⠀⠀⣾⣭⣟⡮⣽⢎⡷⡓⣼⡿⣱⣟⣷⢿⣟⣿⣷⣠⠻⢼⡻⡽⡄⢿⣻⣿⣿⣿⣿⣿⣧⢹⣿⣿⣮⣙⢿⣿⣷⢣⡟⣬⣿⣧⣶⣶⠿⣫⣴⣿⣿⠟⣡⣾⣿⣿⣿⡟⢸⣿⣿⣿⣿⡿⣷⣴⣵⣶⣿⣿⣽⣿⡿⣿⡇⣿⣧⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠌⡀
⠀⠐⣯⣳⢏⡷⡁⠀⠀⠀⣼⡳⣽⢎⡷⣹⢎⡷⢱⣿⢣⣿⣞⡿⣯⡿⣟⣾⡟⢻⣶⡬⢉⣙⣂⣿⣿⡷⣿⣻⣿⢿⣆⠻⣿⣿⣿⣶⣍⣛⡞⡇⣿⠿⢛⣩⣶⣿⣿⣿⠟⣣⣾⣿⣿⣿⣿⣿⠇⣿⣿⣿⣿⢃⣼⣿⣿⣿⣿⡿⣿⡿⣽⡿⣟⣷⢹⣿⡀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠌⡀⠀
⠀⢈⡷⣭⣻⢼⡁⠀⠀⣸⢧⡻⣵⢫⣞⡱⣫⢆⣿⡏⣾⡽⣾⣽⣳⣿⣻⣽⢰⣿⢿⢃⣿⣻⣟⣯⣷⢿⣻⣽⢯⣿⢿⣧⠘⢯⣿⣾⣻⢟⡴⣡⣵⣾⡿⣿⣿⣟⠟⣡⣾⣿⢿⣿⣻⣽⣻⣽⢰⣿⣯⣿⢂⣾⣿⢿⣿⣽⢯⣿⡷⣿⣽⣟⡿⣽⢸⣿⡇⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠠⢈⠐⠀⠀
⠀⠠⣟⢶⡹⢦⠃⠀⢰⡹⣎⢷⢣⣏⠶⣍⠇⣼⡿⣸⢷⣻⢷⣫⢷⣯⢷⡏⡴⣿⠏⡼⣟⣷⣻⢯⣟⣯⢿⣞⣯⣟⣿⣻⣷⡈⢿⣳⡇⡟⣸⣿⢿⣽⡿⠿⢙⣴⡾⣿⣽⡾⣿⣽⢯⣟⣿⡟⢸⣯⢿⢃⣾⣟⣾⡿⣾⣟⡿⣞⡿⣽⣳⣯⣟⡿⡞⣿⣇⡄⠀⠀⠀⠀⠀⠀⠀⠀⠄⡁⢂⠀⠀⠀
⠀⠐⣽⣊⠷⣍⠆⠀⣧⣛⡼⢣⠯⣜⠳⣜⢰⣿⢣⣟⣳⢯⣟⡽⣻⣞⣯⡅⣿⡝⢸⡿⣽⣳⣟⣯⣟⡾⣯⣟⡾⣽⣞⡷⣿⣽⣊⠹⡃⡇⣿⢯⠟⢓⣥⡾⣟⣷⣟⣷⢯⣿⡽⣞⣿⢯⣷⠏⣼⢿⢃⡾⣷⣻⣾⡽⣷⢯⡿⣽⣻⣽⣳⣟⡾⣽⡇⣿⣿⢡⠀⠀⠀⠀⠀⠀⠄⡁⢂⠐⠠⠀⠀⠀
⠀⠈⢶⢩⡓⢎⠆⢸⡱⣎⡵⣋⠗⣮⡙⡆⣿⡟⢮⣳⢻⡞⣭⣟⣳⢯⣾⢰⢯⠇⡿⣽⣳⢯⡾⣵⢯⣻⣵⣻⣞⡷⣽⣏⡷⣯⢯⣟⡇⡇⣿⣻⡞⣿⢾⣽⣻⠾⣽⣞⣯⢷⡿⣽⢾⣻⢾⠃⣾⣏⣸⣟⣷⣻⣼⣻⡽⣯⢟⡷⡽⣞⣧⢿⣹⣳⠇⣿⣿⢨⡀⠀⠀⠀⠀⠌⠐⡀⠂⠌⡀⠀⠀⠀
⠀⠀⠀⠀⠀⠀⠀⣧⢓⣎⠶⢩⠞⡴⣩⢸⣿⢣⢯⡽⣳⣛⠷⡾⣭⢷⣫⢘⡯⢰⡟⣧⣟⢯⡽⣞⢯⣳⡞⡷⣞⡽⣧⢿⣹⣞⣻⡼⢃⡇⣿⣱⠿⣭⣟⡾⣽⢻⣧⡟⣞⣯⡙⣾⢯⣻⢿⡤⡝⣞⡷⣯⣞⢷⣭⢷⣻⡽⢯⣻⡽⣽⣚⡯⢷⣫⠇⣿⣿⣎⡅⠀⠀⠀⠌⠠⠁⠄⡁⠂⠄⠀⠀⠀
⠀⠀⠤⠤⡄⢆⢰⢪⡝⡬⠋⣠⢛⡴⡁⣾⡟⣬⢳⡝⣧⢟⣯⢳⡏⣯⢳⢨⠷⣲⢟⣧⢯⣏⡷⢯⣻⣵⡻⣝⡾⣵⣛⡾⣵⣫⠷⡽⣸⢃⣷⢫⣟⣳⢯⡽⣞⣻⢖⣿⣹⣞⡁⣯⣻⣝⡾⡝⢰⣏⡿⣼⣞⣻⣎⡿⣼⣝⡯⣷⣹⣞⣭⡟⣭⢷⡃⣿⣿⡇⡽⠀⠀⡈⠄⠡⢈⠐⡀⢁⠂⠀⠀⠀`,
}, },
{ {
author: "https://emojicombos.com/anime-ascii-art", author: "https://emojicombos.com/anime-ascii-art",
@@ -784,60 +729,6 @@ export const anime: Array<Ascii> = [
⣿⢡⢡⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⡿⠛⠻⣿⡇⡇⣤⣦⣄⣿⣿⣿⣿⡜⢸⣿⣿⢸⡞⣿⣿⣿⣿⣿⢿⣿⣿⣿⢸ ⣿⢡⢡⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⡿⠛⠻⣿⡇⡇⣤⣦⣄⣿⣿⣿⣿⡜⢸⣿⣿⢸⡞⣿⣿⣿⣿⣿⢿⣿⣿⣿⢸
⣿⡌⣀⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣇⠀⢀⣿⣿⢡⢿⣿⣿⣿⣿⣿⣿⣧⢁⢻⣿⢸⡇⣿⣿⣿⣿⢃⣾⣿⣿⡟⣼ ⣿⡌⣀⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣇⠀⢀⣿⣿⢡⢿⣿⣿⣿⣿⣿⣿⣧⢁⢻⣿⢸⡇⣿⣿⣿⣿⢃⣾⣿⣿⡟⣼
⡇⡇⣿⠁⠀⢹⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⡄⠸⣿⣿⣿⣿⣿⣿⣿⣧⠀⠹⢸⢹⣿⣿⠿⢣⣾⣿⣿⣿⡇⢹`, ⡇⡇⣿⠁⠀⢹⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⡄⠸⣿⣿⣿⣿⣿⣿⣿⣧⠀⠹⢸⢹⣿⣿⠿⢣⣾⣿⣿⣿⡇⢹`,
},
{
author: "https://emojicombos.com/anime-ascii-art",
text: `⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣷⣷⡆⣿⣿⣿⣾⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣷⣿⣾⣿⣷⡗⢠⣶⣾⣶⣿⣾⣷⣿⣾⣿⣾⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿
⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣇⢿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⡟⣴⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿
⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣟⣛⣊⣛⣛⣛⣿⣿⣿⣿⣿⣛⣛⣛⣛⣛⠛⠛⣛⣛⣫⣭⣭⣥⣶⣶⣶⣶⣶⣶⣶⣶⣶⣶⣶⢦⣭⣭⣝⣛⣛⠛⢛⣛⣛⣛⣻⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿
⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⢟⣛⣛⣛⣛⡿⠿⠿⠿⣛⣫⣥⣶⡾⣿⢿⣻⢿⡽⣯⣿⣻⢾⡽⣯⢿⡽⣯⢿⡽⣞⣯⢿⣯⣟⣿⣻⣽⢿⣶⣬⣛⠿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿
⢿⣿⡿⣿⣿⢿⡿⣿⢿⡿⣿⢿⡿⣿⢿⡿⣿⠿⣯⢿⣟⡿⣻⢯⣿⣻⡽⣿⡽⡿⣯⢿⡿⣽⢯⣶⢳⡶⡆⢼⡿⣟⡿⣯⢿⡿⣿⣻⣟⣿⣻⢷⣿⡽⣟⣯⣿⣻⣽⢷⣻⣟⡿⣽⣟⡿⣽⣻⣟⣯⣟⡿⣾⣽⢾⣟⣾⢿⣽⣻⣽⣾⣆⠉⠬⣭⡝⣯⡝⣯⢻⡝⣯⢟⡽⢯⡟⢯⡿⡽⢯⡟⣿
⣻⣽⣟⣿⣿⣯⣿⢿⣯⣿⢯⣿⢿⣯⡿⣽⣯⡿⣟⡿⣞⣿⣻⣯⢷⣻⣽⢷⣻⣽⣟⣯⡿⠽⠛⠚⣋⣋⡁⢾⣟⣿⣽⣟⣯⣟⣷⢿⣽⣾⣻⣟⣾⣻⢯⣟⣾⣽⢾⣯⣟⡾⣟⡷⣯⣟⣯⣷⣻⢾⣽⣻⣯⠘⣿⣽⡾⣟⣾⣽⣳⣟⣾⡿⣗⣄⠻⢷⣻⡽⣯⢿⣽⣫⣟⣯⣟⣯⣽⣻⢯⣟⡷
⣽⢾⣯⣿⢷⣯⡿⣿⡽⣟⣿⢯⣟⡾⣿⡽⣾⡽⣯⣟⣯⢷⡿⣽⣻⣽⢾⡻⠝⢚⣩⣤⣶⣾⢿⣿⣟⣯⠇⣹⡿⣞⣷⣯⣟⡾⣯⡿⣞⡷⣟⣾⢯⣟⣯⢿⡾⣽⣟⣾⣽⣻⢿⡽⣷⣻⣽⢾⣽⣯⣷⣟⣯⣷⡈⢷⣿⣻⣽⢾⣻⣞⣯⢿⣟⣷⣶⡉⢷⡻⣭⣟⣶⣻⣼⣳⣞⡷⣽⡞⣟⡾⣽
⣽⣻⢷⣿⣻⣽⣟⣷⢿⣻⢾⣯⢿⣽⣳⣟⣷⣻⢷⣻⣞⣯⣟⡷⠏⣩⣤⣶⣿⢿⣟⣯⡿⣞⣯⡷⡯⢋⠀⣽⢿⣽⣳⡿⣞⣿⢷⣻⣯⢿⣽⡾⣿⡽⣾⣻⣽⣻⢾⣻⣾⡽⣯⣟⣷⣻⣽⣻⣾⣽⡄⠻⢾⡽⣷⡌⢷⣻⣽⣟⣯⢿⣞⣯⣟⡾⣷⣿⡄⠻⣵⣻⢮⡷⣏⣷⡻⣞⣷⢻⡽⣽⢞
⣾⣽⣯⣿⢯⣷⢿⣞⣿⣻⣟⣾⣻⣞⣷⣻⢾⣽⢯⣷⡻⢎⣡⣶⣿⣻⢿⣽⣾⣯⢿⡽⣟⣯⢷⡟⠁⠦⡁⢾⣟⡷⣯⡟⣯⣟⣯⣷⣟⡿⣾⣽⣳⡿⣽⡷⣇⢿⣻⢷⣯⢿⣷⣻⣞⣯⣷⢝⢾⣯⢿⣷⣌⠻⣽⣷⡌⢻⣷⣻⢾⣯⣟⡷⣟⣿⣽⡾⡿⠄⠱⣯⢷⣻⡽⡾⣽⣛⡾⣯⡽⣞⣯
⢾⣳⣯⣿⣟⣯⢿⣾⣳⣟⣾⣳⣯⢿⡾⣽⣻⣞⠟⣠⣶⣿⡿⣷⣯⣿⢯⠟⣉⣴⡾⣟⣯⣟⠏⠀⣩⣶⣧⢸⣿⣻⣽⡇⣻⣽⢾⣳⣯⢿⡿⡌⣷⣻⢯⣿⣽⡈⠻⣟⣾⢿⣞⣷⣻⡽⣾⣳⣕⢍⢿⣞⣿⣧⣌⢳⣿⡄⢿⢯⡿⣞⣯⡓⣿⣳⢯⣿⢿⡞⡄⢱⢯⣗⡿⣝⣳⢯⣷⢫⣷⢻⣼
⡿⣽⣞⣿⣾⣻⡿⣾⡽⣾⢷⣯⣟⣯⢿⡳⢋⣴⣾⣟⣯⣷⣿⣿⠽⠋⢡⣾⢿⣽⣻⣽⣻⢎⡴⣾⢿⣽⣿⠘⣷⣯⣷⡇⠼⣟⣯⡿⣞⣿⣽⣷⡘⣯⣿⢾⣽⣇⠡⠙⣯⣿⣻⣞⡷⣟⣷⣻⣽⡷⣅⢝⢾⣽⣻⣦⡙⢿⡌⢻⣽⣻⣽⠃⣿⣽⣻⣾⡏⡹⡴⢀⢻⢮⣟⡽⡽⣞⣳⡟⣞⡿⣼
⣽⣻⣯⣿⡷⣿⣻⢷⣿⣻⣯⢿⣞⣯⢋⣵⣿⣻⣽⣾⠿⢙⣡⢄⡔⣴⣿⣻⢿⣾⣽⣳⣯⢾⣻⣽⡛⢰⣿⡀⣿⣳⣯⡗⢌⣿⣳⣟⣯⣟⣾⢷⣷⠘⡽⣟⣿⣾⡆⠡⠌⢷⡿⣽⣻⢯⣟⡷⣯⣫⣪⡢⡑⢝⢷⣻⢿⣄⠻⡄⢿⣽⣻⠌⣻⣞⣷⢯⣷⠁⡇⡏⡌⣟⡾⣽⣻⣭⢷⣻⡽⣞⢷
⣽⣻⡷⣿⣟⣿⣽⣿⡾⣟⣾⣟⠏⣡⣿⣽⣳⠿⢋⣡⣶⠟⣱⣿⡸⣿⡽⣿⣻⣞⡷⣟⣾⢿⣽⣻⢃⣷⢿⡇⢸⣿⣞⡇⠎⣼⡿⣽⢾⣻⡾⣿⣽⡀⡘⢿⣳⣯⣿⠆⢉⠄⠻⣿⣽⣻⣽⣻⡽⣷⣟⣿⣎⢦⠱⡹⠻⣟⣷⡄⠈⣷⣻⢨⢹⣾⣽⣻⣽⣸⢹⣰⡇⢸⡽⡾⣵⡻⣞⣧⠿⣽⣞
⣽⣻⡽⣿⣯⣿⣟⣾⣟⣿⡳⢡⣾⣿⠟⢋⣥⡾⣿⡽⢣⣾⣿⣿⣿⢆⣤⣛⡳⠿⣟⢯⣿⣟⣿⡇⣼⣯⣿⢿⠘⣷⡯⠿⠨⣔⣿⣿⣯⣿⢿⣾⢷⡇⣷⡈⢟⣾⣻⣿⡄⢊⠤⠙⡾⣯⣷⢿⣽⣷⣻⢾⣽⢷⣷⣎⣦⡈⠛⢿⣆⠘⡵⢂⢺⡇⢺⣿⡽⣿⣼⣿⣼⢸⡽⣽⡳⣟⡽⣞⣻⠷⣞
⣽⣻⡽⣿⣳⣟⣾⣯⢿⠞⣴⡿⢛⣠⣾⣟⣷⣻⡽⣱⣿⣿⣿⢟⣵⣿⣿⣿⣿⢣⣿⣿⣿⣿⣿⢦⣶⡶⠶⢶⠂⢲⣬⣭⠁⠤⢸⣯⡷⣯⡿⣞⣿⣦⢸⣿⡌⢷⣿⠯⠛⡀⠊⣁⠈⢛⡙⠻⢷⣯⣟⡿⣾⣻⢾⡽⣯⢷⡈⢢⠙⢷⣄⠉⢆⡷⢸⣿⡽⣯⢿⣽⣾⢈⡷⢯⣽⣫⡽⣏⣷⣻⡽
⣽⣻⡽⣿⣿⣯⣿⣾⢋⠜⣫⣴⣿⣻⡷⣟⣾⡿⢰⡿⠿⠿⠣⡾⠿⢿⣛⣛⡛⣸⣿⣭⣭⣭⡏⣐⣶⣾⢿⠏⣸⠘⣷⣻⡇⠘⡄⣿⣽⢷⣿⣻⢷⣟⠘⣿⣿⣂⢻⣞⣿⣧⡀⠠⠍⡄⠹⣿⣶⣦⣙⠻⣷⣟⣯⣿⡽⣿⣷⡄⢉⠆⡙⢦⠈⣿⢸⣯⡿⣽⣯⣿⢿⠀⣟⣟⣮⢷⣻⢽⡞⣵⣻
⣽⣻⣟⣿⣿⡾⣷⠃⣠⣾⣿⣷⡿⣟⡿⣯⡷⢡⣶⡿⠏⣴⣿⢿⡿⣟⣯⡿⠁⣿⣳⡿⣯⢿⠇⣾⢯⠟⣩⢀⣶⣦⢠⣍⡳⡈⠔⢸⣯⡿⣾⡽⣯⣿⡅⣿⣿⣿⣦⡙⢾⣿⣷⡘⣄⠨⠅⡌⢳⣿⡽⣷⣼⣻⣞⣷⣟⣷⣻⣷⡈⠰⢡⠊⡑⡌⢸⣷⣟⣯⢷⡿⣿⢀⡿⣞⡽⡾⣭⢷⣻⣳⡽
⢾⣽⣯⣿⣿⣽⢃⣾⣿⣟⣷⡿⣿⣟⣿⣻⠃⣾⣟⢃⣼⡿⣽⣯⢿⡿⡝⢠⢀⡿⣷⣟⣿⣻⠀⣟⣡⣾⠏⣼⣿⣿⡄⢟⣿⣧⠘⡀⢿⣽⣳⣿⡽⣷⣇⢻⣿⣿⣿⣶⡈⢳⣟⣧⡸⣷⣌⢐⡂⠙⣿⣽⣾⢯⡿⣾⣽⣞⣯⣿⣳⠈⢆⠱⣂⠄⡈⢾⣟⡾⣿⣽⣿⢨⢷⣏⡿⣽⣹⢯⢷⣛⣾
⣻⢾⡷⣿⣿⣯⣿⣿⡿⣾⢿⣽⣟⡿⣾⡽⢰⣿⢃⡾⣽⣻⣽⡾⣟⡟⢀⠆⢸⡿⣽⡾⣯⢿⠐⣿⣯⣿⢠⣿⣿⣿⣿⡈⢾⣿⣆⠡⠌⢷⣟⣾⡽⣿⢾⠸⣿⣿⣿⣿⣿⣆⠙⣿⣧⠹⣿⣷⣄⠃⠌⠳⣿⣻⣽⣟⣾⣽⣻⣞⡿⣷⡈⠒⣌⠒⡥⢈⢾⣻⡽⣷⣻⢨⢷⢾⣽⣳⢯⣟⣯⣟⢾
⣽⣻⣟⣿⣽⡿⣯⣷⢿⣻⡿⣾⣽⣿⣳⡇⣼⢃⣾⢿⡽⣯⣷⢿⡝⠠⢌⠎⢸⣟⡷⣿⣟⡯⢘⡿⣾⡇⣼⣿⣿⣿⣿⣷⡐⣯⢿⡄⢊⠘⣿⢾⣽⣻⡿⡇⢿⣿⣿⣿⣿⣿⣷⣄⠻⣧⠹⣿⣿⣷⣌⠡⠈⢿⣳⣯⢿⣞⡷⣯⢿⣽⣷⡈⠄⡓⢌⠦⡀⢻⣽⣟⣯⠸⣯⣞⢷⡯⣟⡾⣵⣞⡿
⢾⣽⣞⣿⣟⣿⣽⣯⢿⣻⣽⣟⣯⣷⢿⡇⠇⣼⣯⣟⡿⣽⣯⡟⠠⡘⠆⠎⢸⣿⡽⣟⣾⡇⠐⣿⢿⠁⣿⣿⣿⣿⣿⣿⣷⡩⢿⣧⢀⠊⢽⣯⣟⡷⣿⣳⢸⣿⣿⣿⣿⣿⣿⣿⣷⡌⠧⠙⠿⠿⢿⣓⣤⡀⠙⠯⢿⣻⢿⡽⣟⣾⣽⣧⠀⡈⠒⢢⠱⡀⢻⣾⡗⢸⣳⣞⣯⢿⣹⣽⣳⣻⢾
⣻⢾⣯⣿⣾⣟⡷⣿⣯⢿⣽⢾⣻⣯⡿⡇⢰⣿⣳⢯⣿⣳⣯⠁⠦⡙⢌⠣⢸⣯⣟⣿⣳⠂⡄⣿⣻⢰⣿⣿⣿⣿⣿⣿⣿⣧⡙⣿⡌⣦⠃⢻⣞⣿⡽⣿⡄⣿⣿⣿⣯⣭⣭⣷⢶⠶⠦⠐⠘⠛⠉⠉⠀⠀⣀⠀⠰⢯⣿⣻⣟⣾⡽⣿⣆⠀⠳⠄⠣⠑⡄⢻⡇⢸⢷⢾⣭⣟⣳⢯⣷⢻⣾
⣽⣻⣞⣿⣷⣻⡿⣷⣯⢿⣯⣿⢿⣷⣻⡇⣼⡷⣟⣿⣳⣿⠃⠌⣒⠩⡌⡱⢸⣟⣾⣽⣻⢀⠆⢸⡿⠸⠿⠯⠭⣭⣭⣭⣭⣭⣥⠈⡇⢹⣧⠁⢹⡾⣿⢿⣇⢹⣿⣿⣿⣗⡀⠀⠀⠀⠀⠀⠀⠀⠀⡀⠀⠘⣿⡆⣷⡌⢿⣳⣿⣳⡿⣯⢿⡄⣿⣿⣦⡈⡐⠀⠃⢼⣯⣟⡾⣭⣟⣯⣞⣿⢺
⢾⣽⢯⣿⡾⣟⣿⣳⣯⡿⣷⣻⣿⢯⣿⢃⣿⣽⢯⡿⣽⡞⢀⠨⠰⡑⢢⡑⠈⣿⢾⣽⣻⠤⢘⠘⣿⢠⡀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠙⠄⣿⣷⡀⠹⣿⣻⣿⠌⣿⣿⣿⣿⣿⣿⠀⠀⠄⠂⠐⠈⡐⠀⠡⠀⢻⡅⣿⠠⡠⠙⣾⢯⣿⡽⣯⣇⠸⢍⣹⡇⣿⣦⠀⢻⢶⣯⢟⣳⡽⣞⣧⣟⢯
⣻⢾⣯⣿⣟⣿⢷⣯⡷⣿⢯⣷⣿⣻⣽⠰⣿⣞⣿⣻⢿⢁⣾⠀⢣⠱⣁⠚⡄⡿⣟⣾⣽⡂⢸⡇⢃⢸⣧⠘⣿⡆⠀⡀⡀⢀⠀⠄⠰⣄⠸⣿⣿⣄⠹⣿⡽⡇⢻⣿⣿⣿⣿⣿⡀⢈⠀⡇⠠⢁⠠⠈⡐⠠⢸⣸⡇⠰⡡⢃⠈⢿⣳⣿⢯⣿⠆⢿⣿⡇⣷⣻⡇⢈⡿⣞⣯⢿⣽⣻⢾⣭⢿
⢿⣿⡾⣿⣿⣿⣿⣿⢿⣿⡿⣿⣿⣿⡿⢸⣿⣿⣿⣿⡏⣸⣿⠀⠏⠤⢋⢧⡀⢸⣿⢿⣿⡇⢸⣿⠀⠀⣿⣧⢸⣧⠀⠀⡃⢀⠘⠀⠀⣿⣦⠸⣿⣿⣦⠸⣿⣷⠸⣿⣿⣿⣿⣿⣧⠀⠠⣿⠀⠀⠄⢀⡇⠀⣿⣿⠃⣃⢳⠋⠘⡀⠻⣿⡿⣿⣷⢸⣿⢃⣿⣿⡇⢸⡿⣿⡿⡿⣿⣟⡿⣿⢿
⣻⢾⣻⣿⢯⣿⢾⣯⣟⡷⣟⣿⣻⣞⡿⢸⣟⣾⣽⠞⣰⡿⣽⡆⢌⠣⣉⠦⡘⡈⣾⡿⣽⡇⢸⡿⣆⠐⠘⢿⣆⢿⡄⠀⢣⠀⠂⢸⡀⢹⣿⣧⣽⣿⣿⣦⠑⣿⡇⢿⣿⣿⣿⣿⣹⡿⣿⣽⣷⣬⣴⣿⠷⣴⣿⣿⠠⡘⠤⢃⠃⡔⡀⡙⢿⣻⢿⡄⠏⣾⢷⡿⣇⢸⣽⣳⢿⣽⣳⢯⡿⣽⢾
⣻⣟⡷⣿⣿⣻⡿⣾⢯⣿⣻⣟⣿⡽⣟⢸⣯⢷⡏⢰⣿⣻⢯⣇⢈⢒⢡⢒⡡⣁⢱⣿⢷⣯⢸⣿⡽⠀⢃⠈⢿⣎⣿⣴⣿⣧⣶⣿⡇⢾⣿⣿⣿⣿⣿⣿⣷⡘⢧⠘⣿⣿⣿⣿⣷⡿⣄⠈⠛⠻⠟⢋⣰⢟⣽⡇⠰⢡⠃⣸⠰⡘⢠⡇⣌⠻⣯⣷⢸⡿⣯⣿⢧⢸⣳⢯⣟⡾⣽⢯⣟⡷⣻
⣟⣾⣟⣿⣷⢯⣿⣟⡿⣞⣷⣯⣿⡽⣯⢸⣻⣿⢁⣿⣯⣟⣿⣻⡀⠎⢢⠅⣒⢡⠀⣿⣟⣾⡼⣷⣟⠠⣉⢆⠈⢿⣯⡻⣎⠉⠛⠛⠀⣸⣿⣿⣿⣿⣿⣿⣿⣿⣦⡁⢹⣿⣿⣿⣿⣿⣿⣭⣶⣶⣮⣵⣾⣿⡿⢁⠡⣃⢂⡿⢠⠁⣾⠇⢛⣥⠙⣿⠀⣿⣻⣽⣻⢸⡽⣻⢾⡽⣯⣟⡾⣽⣻
⡿⢾⡽⣿⣾⢿⣻⡾⣟⣿⣽⣾⢯⣟⣿⠰⣿⠇⣼⣟⣾⢿⣳⡿⣧⠘⠤⢩⡐⢊⡔⠈⣿⣞⡿⣷⣻⢀⠲⡈⠖⡀⢻⣿⣯⣥⣤⣴⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣦⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⡆⢠⢃⡄⣸⡗⢠⢰⡟⠠⢸⢻⡀⠌⠂⢿⡽⣷⣿⢸⡽⢯⡿⣽⣳⢯⣟⡷⣯
⣻⢿⣻⣿⡽⣿⣻⢿⣽⡾⣟⣾⢿⣻⣽⡆⡿⢰⣯⣿⢾⣟⡿⣽⡿⣆⠨⢡⠌⠣⣌⠁⠘⣯⣟⣿⣽⠀⣒⠩⠜⡰⠀⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⠃⢆⣊⢀⣿⡇⢀⣾⠃⠰⠈⣿⡇⢈⢧⣸⣟⣷⢿⢨⣟⣯⣟⡷⣯⣟⡾⣽⣳
⣻⣟⡷⣿⣟⣿⣯⡿⣞⣿⢯⣿⣿⣯⢿⡇⠁⣼⣿⣞⣿⣯⣿⢯⣟⣿⡄⠃⡜⢡⠢⡁⢣⡘⡿⣞⣿⠀⠤⠃⠘⣄⠃⢿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⠿⠿⣟⣛⣭⣭⡙⣿⣿⣿⣿⣿⣿⡿⠈⢆⠄⣼⡿⡇⣸⡟⠠⠘⡀⣿⣳⢈⢸⣟⣾⢯⣿⠐⣯⢾⣽⣳⣟⡾⣽⣳⢯
⣳⢿⡽⣿⣟⣯⣿⢿⣽⣾⢿⣳⡿⣯⡿⣿⠀⣿⣿⣞⣿⣳⣿⢯⣟⣾⢿⡄⠘⠤⠓⡄⢹⣷⡘⣽⡿⡇⠈⡇⠘⡄⢣⠈⠻⢿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣶⣶⡄⢼⣿⣿⣿⣿⣿⢇⣿⣿⣿⡿⠟⠋⠁⠜⡨⢰⣿⢻⢁⣿⠃⠰⡀⠄⣿⢿⡄⢺⣯⣟⣿⣽⠀⣿⣻⣞⡷⣯⣟⡷⣯⢿
⣽⣻⣿⣷⡿⠿⠺⠿⢯⣿⣻⢿⣽⣿⡽⣿⣞⣿⣳⡟⣋⣍⠻⣯⣟⣾⢯⣿⡄⠡⢋⠔⢸⣷⢷⡈⢿⣧⠘⡰⠀⡅⢣⠡⠘⢤⠈⣉⠙⡛⠿⠿⢿⣿⣿⣿⣿⣿⣿⣿⣶⣭⣭⣯⠭⠵⣚⣛⣭⣶⣾⡇⠈⢠⠙⢀⡟⢆⣿⡿⡏⢀⠳⣀⠀⢻⣯⣷⠩⣷⣻⣾⣽⠀⣷⣻⢾⣽⣳⢯⡿⣽⣻
⣻⣟⣷⡋⣴⣿⣿⣿⣶⣶⣭⣛⠾⢯⣟⣷⣿⢷⣻⢰⣿⣿⣧⢹⢾⣯⢿⣞⣿⣆⠈⢎⠘⣯⣟⣿⠈⢻⡄⢢⠁⡘⢢⡑⠈⠆⡥⠀⡓⣌⠒⢬⠀⢄⠢⡐⠤⠩⠉⡉⢍⠀⡀⠀⣠⣿⣿⣿⣿⣿⡿⢁⠀⢆⡉⡼⡉⣼⣿⡍⠠⠌⣒⠡⡀⢸⡷⣟⡆⣿⣳⢿⣾⠄⡿⣽⣻⢾⡽⣯⣟⣷⣻
⣳⣟⣿⣧⠻⢿⣿⣿⣿⣿⣿⣿⣿⣶⣍⡻⢽⣿⣿⡘⣿⣿⣿⡌⢿⣯⣿⢾⣳⡿⣧⡈⠀⣿⣟⣾⠨⢀⠁⠠⢃⠘⠰⢌⠀⢑⠰⢂⠱⣀⠫⠤⣉⠀⠣⠘⣈⠠⡑⠌⣠⣴⣶⣿⣿⣿⣿⣿⣿⠋⡀⠆⠰⡈⢰⣣⢱⣿⣳⢃⠞⡢⠄⣁⣄⠘⠿⣟⣯⡿⣽⣻⣾⠇⣟⣷⣻⣯⣟⣷⣻⢾⣽
⣿⣯⣿⡿⣿⡶⠮⠭⠝⠛⠻⠿⢿⣿⣿⣿⣶⣶⣶⣥⣘⠿⣿⣿⣎⠳⣯⢿⣯⣟⣿⣻⣄⢹⠾⢛⡀⠈⢆⡀⠥⡀⠍⢢⠀⣦⡁⠣⠄⠠⢃⡁⡔⢢⢣⡝⡰⠂⣈⣐⣛⣛⠿⣿⣿⣿⣿⠟⠁⡠⢔⠃⡰⢁⡏⢤⣿⡻⠅⢐⣨⣶⠟⣫⢐⠮⣄⡈⠳⣿⣻⣽⣾⡇⣟⣾⣽⢾⡽⣾⣽⣻⢾
⣿⠷⣋⣭⣴⣶⣾⣿⣿⣿⣶⣶⡦⣠⣶⣾⣶⣝⠻⣿⣿⣿⣾⣿⣿⣷⡍⣿⢾⣽⣾⠿⢉⣴⣾⣿⡇⠀⢎⡐⢢⡁⠘⢤⠁⣬⡑⠂⣴⠠⢸⢰⡉⢧⢣⠜⡑⣼⣿⣿⣯⣟⣻⣶⣭⡛⢡⡐⢮⣑⠃⠤⢁⡾⠌⣾⣟⠇⣴⠿⡫⢄⡳⠬⢉⣂⣥⣥⡀⢹⢷⣿⣾⡇⢻⣞⣯⡿⣽⢷⣯⣟⣿
⣵⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⡇⣿⣿⠿⢿⣿⣧⣹⣿⣿⣿⣿⣿⣿⣧⢹⣿⣳⠏⣴⣿⣿⣿⣿⣷⢀⠦⣉⠒⣌⠀⠎⡐⢸⠰⠃⣿⠀⣿⢠⡙⢦⢍⠞⢰⣿⣿⣿⣿⣿⣿⣿⠟⢄⡲⢍⠶⡡⢀⢃⣾⠱⣸⣿⡛⠘⢥⡚⠔⣩⣴⣿⣿⣿⣿⣿⣿⣦⢻⣞⡿⡇⢸⣯⡷⣿⢯⣟⡾⣽⢾
⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⢨⣿⣿⣿⣿⣯⡄⢝⢿⣿⣿⣿⣿⡿⡈⠛⡃⣘⠻⢿⣿⣿⣿⣿⡀⠲⢄⢋⠤⠃⡈⠱⡈⠸⠁⣿⠀⣿⢠⠹⣌⡚⢄⣿⣿⣿⣿⣿⣿⡿⡁⠞⣬⠱⣎⢣⠅⠀⣾⢃⢣⣿⠓⣠⠙⢆⣵⣾⣿⣿⣿⣿⣿⣿⣿⣿⣿⣆⠻⣿⣧⢸⣳⡿⣯⢿⣞⡿⣽⣻
⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⡇⣿⠟⣭⣭⣭⣭⣛⢊⣃⣽⣿⣿⣿⣷⣷⡈⠱⣊⠵⣂⠙⣿⣿⣿⣇⠱⠨⢌⡒⡁⢡⠑⡀⢸⠁⣿⠐⢸⡀⢯⡰⠩⣸⣿⣿⣿⣿⣿⠟⠤⣍⢫⡔⣫⠔⠃⠀⢰⢿⡶⣿⡽⠠⢆⣵⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⡌⣻⣽⢸⣳⢿⣻⣟⣾⡽⣷⣻
⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⡌⢼⣿⣿⣿⣿⡿⣸⣿⣿⣿⣿⣿⣿⣿⣷⡀⠈⡳⢌⣃⠸⣿⣿⣿⡀⡙⠤⢊⠅⢈⣆⠑⡀⠃⣿⡘⢸⡆⡣⢕⢣⣿⣿⣿⣿⣿⠏⡨⢞⡰⡃⢊⡵⠊⠀⠂⣼⢯⣿⡽⢀⣴⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣷⢘⣿⠄⣿⣻⡷⣿⣞⣿⣳⢿
⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⠸⣿⣿⣏⣶⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣷⢠⠑⡮⢰⢰⠘⢿⣿⣇⠨⠥⣉⠆⢸⣿⣆⠀⠀⣿⡇⠎⡇⢱⠋⣼⣿⣿⣿⣿⢃⢎⠵⠃⣡⠖⡩⢂⣤⡾⢠⣿⢿⣽⢃⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⡇⢹⡆⣻⣽⣻⣷⣯⡷⣟⣿
⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣷⣝⡻⠿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⡿⢀⠯⣔⢣⢸⢘⣠⢩⣝⠀⠣⡔⠊⢸⣿⣿⡆⠀⢸⡇⡃⢿⢠⠃⣿⣿⣿⣿⠃⡎⢎⣴⠟⡁⣢⣴⠟⣫⠀⢹⡾⣿⢃⣾⣿⣿⣿⣿⣿⣿⣿⣿⣯⣻⣿⣿⣿⣿⣿⣿⣿⣿⣿⠘⡇⢼⣻⡷⣯⣷⢿⣻⣾
⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⢡⣶⣶⡆⡐⣀⠙⢿⣿⣿⣿⣿⠇⣊⠶⣌⠃⡇⡜⢰⠋⣿⣷⡐⢌⢣⢸⣿⣿⣿⡀⠈⣿⠘⠸⡄⢸⣿⣿⣿⠃⢊⡴⠋⢁⣠⡾⢟⢅⡚⠔⢠⣿⢿⠋⣼⡿⢿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣷⣽⣻⠿⣿⣿⣿⣿⣿⡗⣶⣌⢻⣿⣽⢿⣻⢷⣻
⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⢃⣾⣟⡿⢠⠁⡄⢣⠈⢻⣿⣿⠏⣔⢊⠶⡌⡘⡰⡉⣼⠠⢹⣿⣧⠈⢆⠌⣿⣿⣿⠁⠄⢸⡎⠅⢇⢸⣿⡿⢁⡔⠋⢐⣴⡿⢋⡔⡣⢊⣴⡏⢰⣯⠇⢰⣟⢿⣿⣿⣾⣽⣟⣿⢿⣿⣿⣿⣿⣿⣿⣷⣷⣻⢽⣟⣿⣷⣻⣿⡆⣿⢾⣟⣿⢯⣿
⣝⢿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⡟⢣⣾⣿⣿⠁⡆⢈⠔⡡⢊⠄⠻⣋⠲⠬⣍⠖⡴⢡⠓⣰⠇⡆⣼⣿⣿⣆⠘⡀⣿⣿⡇⣷⠘⡄⢳⠘⠸⢸⣿⠃⡊⢔⣴⠟⡩⣔⠣⣈⣴⣿⣿⡇⢸⡯⠀⣿⣿⣎⢷⣯⣟⡿⣿⣿⣿⣾⣯⣟⣿⢿⣿⣿⣿⣿⣷⣯⣟⡿⢏⣿⣇⢻⡿⣯⣿⣟⣾
⣿⣷⣮⡝⣻⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣦⣝⢳⡏⡘⡄⢈⠆⡱⠈⣠⢚⠴⣋⠳⣠⢎⠴⡉⣰⢏⠼⢀⣿⣿⣿⣿⡆⠡⢸⣿⢸⣿⡧⢘⠘⡆⠇⣿⠇⢄⣵⠟⡡⢎⢑⣠⣾⣿⣿⣿⣿⡆⢹⠁⣼⣿⣿⣿⣧⡻⣿⣿⣷⣿⣿⣿⣿⣿⣿⣿⣷⣿⣽⡿⣿⣿⣿⣿⣿⣿⣿⡘⣿⣻⣷⣿⣾
⣿⣿⢋⣼⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣷⡅⠄⡳⢌⠤⣰⢉⢦⡙⠦⣡⠞⣡⢃⢊⡼⢣⠎⠎⣼⣿⣿⣿⣿⣷⢠⠈⡇⣿⣿⣿⡆⠣⢱⡀⢏⣴⠟⣡⠚⣁⣴⡿⢿⣯⣡⣿⣿⣿⣿⠀⣰⣯⣽⣛⣿⣿⠷⠘⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣷⣿⣽⣻⢿⣿⣿⣷⡜⢷⣿⣳⣿
⣿⢧⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⡄⣅⣋⠚⠤⣋⣢⣵⠞⣅⠳⢈⣴⠟⢑⣣⢊⣾⣿⣿⣿⣿⣿⣿⢸⢇⡠⣿⣿⣿⣿⡄⢃⠃⢘⢅⠓⠀⣚⣭⣵⣾⣿⣿⣿⣿⠿⣛⣭⣾⣿⣿⣿⣿⣿⣿⣿⣿⣮⢻⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣎⢻⣟⣿
⣿⣾⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣷⢰⣶⣶⣶⡍⠍⠆⣓⣤⡾⠟⢡⡙⠎⣠⣿⣿⣿⣿⣿⣿⣿⣿⡞⣾⣷⣌⠻⢿⣿⣿⠄⠴⢉⡤⣾⠿⠿⢿⣛⣛⣫⣭⣵⣶⣿⣿⣿⣿⣿⡙⣿⣿⣿⣿⣿⣿⣿⣷⡙⢿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣧⣸⣿`,
}, },
{ {
author: "https://emojicombos.com/anime-ascii-art", author: "https://emojicombos.com/anime-ascii-art",
+7
View File
@@ -4,12 +4,14 @@
* @author Naomi Carrigan * @author Naomi Carrigan
*/ */
import { DiscordAnalytics } from "@nhcarrigan/discord-analytics";
import { import {
Client, Client,
Events, Events,
GatewayIntentBits, GatewayIntentBits,
} from "discord.js"; } from "discord.js";
import { chatInputInteractionCreate } from "./events/interactionCreate.js"; import { chatInputInteractionCreate } from "./events/interactionCreate.js";
import { instantiateServer } from "./server/serve.js";
import { logger } from "./utils/logger.js"; import { logger } from "./utils/logger.js";
const chibika = new Client({ const chibika = new Client({
@@ -18,14 +20,18 @@ const chibika = new Client({
], ],
}); });
const analytics = new DiscordAnalytics(chibika, logger);
chibika.once(Events.ClientReady, () => { chibika.once(Events.ClientReady, () => {
void logger.log( void logger.log(
"debug", "debug",
`Logged in as ${chibika.user?.username ?? "unknown"}`, `Logged in as ${chibika.user?.username ?? "unknown"}`,
); );
analytics.startCron();
}); });
chibika.on(Events.InteractionCreate, (interaction) => { chibika.on(Events.InteractionCreate, (interaction) => {
void analytics.logGatewayEvent(Events.InteractionCreate, { ...interaction });
if (interaction.isChatInputCommand()) { if (interaction.isChatInputCommand()) {
if (!interaction.inCachedGuild()) { if (!interaction.inCachedGuild()) {
void interaction.reply({ void interaction.reply({
@@ -38,3 +44,4 @@ chibika.on(Events.InteractionCreate, (interaction) => {
}); });
await chibika.login(process.env.DISCORD_TOKEN); await chibika.login(process.env.DISCORD_TOKEN);
instantiateServer();
+20
View File
@@ -35,3 +35,23 @@ describe("assets", () => {
expect(uniqueEmoji.size, "emoji has duplicate art").toBe(emoji.length); expect(uniqueEmoji.size, "emoji has duplicate art").toBe(emoji.length);
}); });
}); });
describe("length", () => {
it.each(anime)("anime art should have correct length", (art) => {
expect.assertions(2);
expect(art.text.length, `${anime.indexOf(art)} has no content!`).toBeGreaterThan(0);
expect(art.text.length, `${anime.indexOf(art)} has too much content!`).toBeLessThanOrEqual(3500);
});
it.each(cats)("cats art should have correct length", (art) => {
expect.assertions(2);
expect(art.text.length, `${cats.indexOf(art)} has no content!`).toBeGreaterThan(0);
expect(art.text.length, `${cats.indexOf(art)} has too much content!`).toBeLessThanOrEqual(3500);
});
it.each(emoji)("emoji art should have correct length", (art) => {
expect.assertions(2);
expect(art.text.length, `${emoji.indexOf(art)} has no content!`).toBeGreaterThan(0);
expect(art.text.length, `${emoji.indexOf(art)} has too much content!`).toBeLessThanOrEqual(3500);
});
});