From 2d143645b73e85c14025328de45468854baf0913 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov Date: Sun, 24 Aug 2025 16:30:59 +0300 Subject: [PATCH 001/265] tests(e2e): fix top-langs and wakatime cards test data to prevent workflow errors (#4367) --- tests/e2e/e2e.test.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/tests/e2e/e2e.test.js b/tests/e2e/e2e.test.js index ee0deafe132e2..196a89742ecaf 100644 --- a/tests/e2e/e2e.test.js +++ b/tests/e2e/e2e.test.js @@ -38,7 +38,7 @@ const LANGS_DATA = { size: 1721, }, CSS: { - color: "#563d7c", + color: "#663399", name: "CSS", size: 930, }, @@ -54,7 +54,7 @@ const WAKATIME_DATA = { is_already_updating: false, is_coding_activity_visible: true, is_including_today: false, - is_other_usage_visible: true, + is_other_usage_visible: false, is_stuck: false, is_up_to_date: false, is_up_to_date_pending_future: false, From 0cf6b18fa1b0a76aacabbdb44c549a8b4d65b72c Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov Date: Sun, 24 Aug 2025 16:37:01 +0300 Subject: [PATCH 002/265] chore: bump node.js version from 18 to 22 in whole project (#4377) --- .github/workflows/e2e-test.yml | 2 +- .github/workflows/generate-theme-doc.yml | 2 +- .github/workflows/preview-theme.yml | 2 +- .github/workflows/stale-theme-pr-closer.yml | 2 +- .github/workflows/test.yml | 2 +- .github/workflows/update-langs.yml | 2 +- .nvmrc | 2 +- package-lock.json | 2 +- package.json | 2 +- 9 files changed, 9 insertions(+), 9 deletions(-) diff --git a/.github/workflows/e2e-test.yml b/.github/workflows/e2e-test.yml index 2cc1524981b22..5dc71faf93422 100644 --- a/.github/workflows/e2e-test.yml +++ b/.github/workflows/e2e-test.yml @@ -14,7 +14,7 @@ jobs: runs-on: ubuntu-latest strategy: matrix: - node-version: [18.x] + node-version: [22.x] steps: - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 diff --git a/.github/workflows/generate-theme-doc.yml b/.github/workflows/generate-theme-doc.yml index 52aaefd503f30..31e724e675840 100644 --- a/.github/workflows/generate-theme-doc.yml +++ b/.github/workflows/generate-theme-doc.yml @@ -26,7 +26,7 @@ jobs: name: Generate theme doc strategy: matrix: - node-version: [18.x] + node-version: [22.x] steps: - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 diff --git a/.github/workflows/preview-theme.yml b/.github/workflows/preview-theme.yml index f18543720ed40..f24ccd9a5ec00 100644 --- a/.github/workflows/preview-theme.yml +++ b/.github/workflows/preview-theme.yml @@ -27,7 +27,7 @@ jobs: runs-on: ubuntu-latest strategy: matrix: - node-version: [18.x] + node-version: [22.x] steps: - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 diff --git a/.github/workflows/stale-theme-pr-closer.yml b/.github/workflows/stale-theme-pr-closer.yml index 7df8bc314eb14..17c5e3a92e455 100644 --- a/.github/workflows/stale-theme-pr-closer.yml +++ b/.github/workflows/stale-theme-pr-closer.yml @@ -33,7 +33,7 @@ jobs: runs-on: ubuntu-latest strategy: matrix: - node-version: [18.x] + node-version: [22.x] steps: - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 24b40b694f7f9..c13310da12498 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -15,7 +15,7 @@ jobs: runs-on: ubuntu-latest strategy: matrix: - node-version: [18.x] + node-version: [22.x] steps: - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 diff --git a/.github/workflows/update-langs.yml b/.github/workflows/update-langs.yml index 3423c2ff00919..521bdb2eb8953 100644 --- a/.github/workflows/update-langs.yml +++ b/.github/workflows/update-langs.yml @@ -33,7 +33,7 @@ jobs: runs-on: ubuntu-latest strategy: matrix: - node-version: [18.x] + node-version: [22.x] steps: - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 diff --git a/.nvmrc b/.nvmrc index 25bf17fc5aaab..8fdd954df9831 100644 --- a/.nvmrc +++ b/.nvmrc @@ -1 +1 @@ -18 \ No newline at end of file +22 \ No newline at end of file diff --git a/package-lock.json b/package-lock.json index f1107262811d4..597a9abfe82dd 100644 --- a/package-lock.json +++ b/package-lock.json @@ -42,7 +42,7 @@ "prettier": "^3.6.2" }, "engines": { - "node": ">=18.0.0" + "node": ">=22" } }, "node_modules/@aashutoshrathi/word-wrap": { diff --git a/package.json b/package.json index e40ac2ba5a209..76c920c135c8d 100644 --- a/package.json +++ b/package.json @@ -72,6 +72,6 @@ "*.{js,css,md}": "prettier --write" }, "engines": { - "node": ">=18.0.0" + "node": ">=22" } } From ff7e1e283c32915d80962f0ccc4425e105c7656c Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov Date: Sun, 24 Aug 2025 16:39:57 +0300 Subject: [PATCH 003/265] chore: create devcontainer (#4378) --- .devcontainer/devcontainer.json | 32 ++++++++++++++++++++++++++++++++ 1 file changed, 32 insertions(+) create mode 100644 .devcontainer/devcontainer.json diff --git a/.devcontainer/devcontainer.json b/.devcontainer/devcontainer.json new file mode 100644 index 0000000000000..5c51e8bafae6d --- /dev/null +++ b/.devcontainer/devcontainer.json @@ -0,0 +1,32 @@ +{ + "name": "GitHub Readme Stats Dev", + "image": "mcr.microsoft.com/devcontainers/base:ubuntu", + "features": { + "ghcr.io/devcontainers/features/node:1": { "version": "22" } + }, + "forwardPorts": [3000], + "portsAttributes": { + "3000": { "label": "HTTP" } + }, + "appPort": [], + + // Use 'postCreateCommand' to run commands after the container is created. + "postCreateCommand": "npm install -g vercel", + + // Use 'postStartCommand' to run commands after the container is started. + "postStartCommand": "hostname dev && npm install", + + // Configure tool-specific properties. + "customizations": { + "vscode": { + "extensions": [ + "yzhang.markdown-all-in-one", + "esbenp.prettier-vscode", + "dbaeumer.vscode-eslint" + ] + } + }, + + "remoteUser": "root", + "privileged": true +} From 6b457d04f11f2fbf4c733207175aa8411f768d9b Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov Date: Sun, 24 Aug 2025 16:43:02 +0300 Subject: [PATCH 004/265] tests: return cache tests which were removed in 53e4041 (#4368) --- tests/api.test.js | 82 +++++++++++++++++++++++++++++++++++++++++ tests/gist.test.js | 23 +++++++++++- tests/pin.test.js | 26 ++++++++++++- tests/top-langs.test.js | 25 ++++++++++++- 4 files changed, 153 insertions(+), 3 deletions(-) diff --git a/tests/api.test.js b/tests/api.test.js index c155220ce5372..1073014fedbd7 100644 --- a/tests/api.test.js +++ b/tests/api.test.js @@ -168,6 +168,40 @@ describe("Test /api/", () => { ); }); + it("should have proper cache", async () => { + const { req, res } = faker({}, data_stats); + + await api(req, res); + + expect(res.setHeader.mock.calls).toEqual([ + ["Content-Type", "image/svg+xml"], + [ + "Cache-Control", + `max-age=${CONSTANTS.CARD_CACHE_SECONDS}, s-maxage=${ + CONSTANTS.CARD_CACHE_SECONDS + }, stale-while-revalidate=${CONSTANTS.ONE_DAY}`, + ], + ]); + }); + + it("should set proper cache", async () => { + const cache_seconds = CONSTANTS.TWELVE_HOURS; + const { req, res } = faker({ cache_seconds }, data_stats); + await api(req, res); + + expect(res.setHeader.mock.calls).toEqual([ + ["Content-Type", "image/svg+xml"], + [ + "Cache-Control", + `max-age=${ + cache_seconds + }, s-maxage=${cache_seconds}, stale-while-revalidate=${ + CONSTANTS.ONE_DAY + }`, + ], + ]); + }); + it("should set shorter cache when error", async () => { const { req, res } = faker({}, error); await api(req, res); @@ -183,6 +217,54 @@ describe("Test /api/", () => { ]); }); + it("should set proper cache with clamped values", async () => { + { + let { req, res } = faker({ cache_seconds: 200000 }, data_stats); + await api(req, res); + + expect(res.setHeader.mock.calls).toEqual([ + ["Content-Type", "image/svg+xml"], + [ + "Cache-Control", + `max-age=${CONSTANTS.TWO_DAY}, s-maxage=${ + CONSTANTS.TWO_DAY + }, stale-while-revalidate=${CONSTANTS.ONE_DAY}`, + ], + ]); + } + + // note i'm using block scoped vars + { + let { req, res } = faker({ cache_seconds: 0 }, data_stats); + await api(req, res); + + expect(res.setHeader.mock.calls).toEqual([ + ["Content-Type", "image/svg+xml"], + [ + "Cache-Control", + `max-age=${CONSTANTS.ONE_DAY}, s-maxage=${ + CONSTANTS.ONE_DAY + }, stale-while-revalidate=${CONSTANTS.ONE_DAY}`, + ], + ]); + } + + { + let { req, res } = faker({ cache_seconds: -10000 }, data_stats); + await api(req, res); + + expect(res.setHeader.mock.calls).toEqual([ + ["Content-Type", "image/svg+xml"], + [ + "Cache-Control", + `max-age=${CONSTANTS.TWELVE_HOURS}, s-maxage=${ + CONSTANTS.TWELVE_HOURS + }, stale-while-revalidate=${CONSTANTS.ONE_DAY}`, + ], + ]); + } + }); + it("should allow changing ring_color", async () => { const { req, res } = faker( { diff --git a/tests/gist.test.js b/tests/gist.test.js index bdf95156d5f44..8c717d64d1aa1 100644 --- a/tests/gist.test.js +++ b/tests/gist.test.js @@ -4,7 +4,7 @@ import axios from "axios"; import MockAdapter from "axios-mock-adapter"; import { expect, it, describe, afterEach } from "@jest/globals"; import { renderGistCard } from "../src/cards/gist-card.js"; -import { renderError } from "../src/common/utils.js"; +import { CONSTANTS, renderError } from "../src/common/utils.js"; import gist from "../api/gist.js"; const gist_data = { @@ -170,4 +170,25 @@ describe("Test /api/gist", () => { renderError("Something went wrong", "Language not found"), ); }); + + it("should have proper cache", async () => { + const req = { + query: { + id: "bbfce31e0217a3689c8d961a356cb10d", + }, + }; + const res = { + setHeader: jest.fn(), + send: jest.fn(), + }; + mock.onPost("https://api.github.com/graphql").reply(200, gist_data); + + await gist(req, res); + + expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); + expect(res.setHeader).toBeCalledWith( + "Cache-Control", + `max-age=${CONSTANTS.TWO_DAY}, s-maxage=${CONSTANTS.TWO_DAY}`, + ); + }); }); diff --git a/tests/pin.test.js b/tests/pin.test.js index 2583ddfe9e9af..5fe21ffe9c75a 100644 --- a/tests/pin.test.js +++ b/tests/pin.test.js @@ -4,7 +4,7 @@ import axios from "axios"; import MockAdapter from "axios-mock-adapter"; import pin from "../api/pin.js"; import { renderRepoCard } from "../src/cards/repo-card.js"; -import { renderError } from "../src/common/utils.js"; +import { CONSTANTS, renderError } from "../src/common/utils.js"; import { expect, it, describe, afterEach } from "@jest/globals"; const data_repo = { @@ -201,4 +201,28 @@ describe("Test /api/pin", () => { ), ); }); + + it("should have proper cache", async () => { + const req = { + query: { + username: "anuraghazra", + repo: "convoychat", + }, + }; + const res = { + setHeader: jest.fn(), + send: jest.fn(), + }; + mock.onPost("https://api.github.com/graphql").reply(200, data_user); + + await pin(req, res); + + expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); + expect(res.setHeader).toBeCalledWith( + "Cache-Control", + `max-age=${CONSTANTS.PIN_CARD_CACHE_SECONDS}, s-maxage=${ + CONSTANTS.PIN_CARD_CACHE_SECONDS + }`, + ); + }); }); diff --git a/tests/top-langs.test.js b/tests/top-langs.test.js index 1c8a45b7b9d48..907d4bc1275ab 100644 --- a/tests/top-langs.test.js +++ b/tests/top-langs.test.js @@ -4,7 +4,7 @@ import axios from "axios"; import MockAdapter from "axios-mock-adapter"; import topLangs from "../api/top-langs.js"; import { renderTopLanguages } from "../src/cards/top-languages-card.js"; -import { renderError } from "../src/common/utils.js"; +import { CONSTANTS, renderError } from "../src/common/utils.js"; import { expect, it, describe, afterEach } from "@jest/globals"; const data_langs = { @@ -208,4 +208,27 @@ describe("Test /api/top-langs", () => { renderError("Something went wrong", "Locale not found"), ); }); + + it("should have proper cache", async () => { + const req = { + query: { + username: "anuraghazra", + }, + }; + const res = { + setHeader: jest.fn(), + send: jest.fn(), + }; + mock.onPost("https://api.github.com/graphql").reply(200, data_langs); + + await topLangs(req, res); + + expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); + expect(res.setHeader).toBeCalledWith( + "Cache-Control", + `max-age=${CONSTANTS.TOP_LANGS_CACHE_SECONDS / 2}, s-maxage=${ + CONSTANTS.TOP_LANGS_CACHE_SECONDS + }`, + ); + }); }); From 8ae69800568e754f118f5a09bffae48c81862d06 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov Date: Sun, 24 Aug 2025 16:57:23 +0300 Subject: [PATCH 005/265] docs: remove outdated translations (#4369) --- .github/labeler.yml | 5 - docs/readme_cn.md | 365 ---------------------------------- docs/readme_de.md | 388 ------------------------------------ docs/readme_es.md | 427 ---------------------------------------- docs/readme_fr.md | 353 --------------------------------- docs/readme_it.md | 365 ---------------------------------- docs/readme_ja.md | 372 ----------------------------------- docs/readme_kr.md | 456 ------------------------------------------- docs/readme_nl.md | 424 ---------------------------------------- docs/readme_np.md | 422 --------------------------------------- docs/readme_pt-BR.md | 372 ----------------------------------- docs/readme_tr.md | 432 ---------------------------------------- readme.md | 25 --- 13 files changed, 4406 deletions(-) delete mode 100644 docs/readme_cn.md delete mode 100644 docs/readme_de.md delete mode 100644 docs/readme_es.md delete mode 100644 docs/readme_fr.md delete mode 100644 docs/readme_it.md delete mode 100644 docs/readme_ja.md delete mode 100644 docs/readme_kr.md delete mode 100644 docs/readme_nl.md delete mode 100644 docs/readme_np.md delete mode 100644 docs/readme_pt-BR.md delete mode 100644 docs/readme_tr.md diff --git a/.github/labeler.yml b/.github/labeler.yml index 46d637d7b5b2e..fa3c16eb87386 100644 --- a/.github/labeler.yml +++ b/.github/labeler.yml @@ -3,11 +3,6 @@ themes: - any-glob-to-any-file: - themes/index.js -doc-translation: - - changed-files: - - any-glob-to-any-file: - - docs/* - card-i18n: - changed-files: - any-glob-to-any-file: diff --git a/docs/readme_cn.md b/docs/readme_cn.md deleted file mode 100644 index 0773656fc7e7c..0000000000000 --- a/docs/readme_cn.md +++ /dev/null @@ -1,365 +0,0 @@ -

- GitHub Readme Stats -

GitHub Readme Stats

-

在你的 README 中获取动态生成的 GitHub 统计信息!

-

-

- - Tests Passing - - - GitHub Contributors - - - Tests Coverage - - - Issues - - - GitHub pull requests - - - OpenSSF Scorecard - -
-
-

- -

- 查看 Demo - · - 报告 Bug - · - 请求增加功能 -

-

- Français - · - 简体中文 - · - Español - · - Deutsch - · - 日本語 - · - Português Brasileiro - · - Italiano - · - 한국어 - . - Nederlands - . - नेपाली - . - Türkçe -

-

-

喜欢这个项目?请考虑捐赠来帮助它完善! - -# 特性 - -- [GitHub 统计卡片](#github-统计卡片) - - [隐藏指定统计](#隐藏指定统计) - - [将私人项目贡献添加到总提交计数中](#将私人项目贡献添加到总提交计数中) - - [显示图标](#显示图标) - - [主题](#主题) - - [自定义](#自定义) -- [GitHub 更多置顶](#github-更多置顶) - - [使用细则](#使用细则) - - [Demo](#demo) -- [热门语言卡片](#热门语言卡片) - - [使用细则](#使用细则-1) - - [隐藏指定语言](#隐藏指定语言) - - [紧凑的语言卡片布局](#紧凑的语言卡片布局) - - [Demo](#demo-1) - - [全部 Demos](#全部-demos) - - [快速提示 (对齐 Repo 卡片)](#快速提示-对齐-repo-卡片) - - [自己部署](#自己部署) - - [:sparkling\_heart: 支持这个项目](#sparkling_heart-支持这个项目) - -# GitHub 统计卡片 - -将这行代码复制到你的 markdown 文件中,就是如此简单! - -更改 `?username=` 的值为你的 GitHub 用户名。 - -```md -[![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) -``` - -_注: 等级基于用户的统计信息计算得出,详见 [src/calculateRank.js](../src/calculateRank.js)_ - -### 隐藏指定统计 - -想要隐藏指定统计信息,你可以调用参数 `?hide=`,其值用 `,` 分隔。 - -> 选项:`&hide=stars,commits,prs,issues,contribs` - -```md -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&hide=contribs,prs) -``` - -### 将私人项目贡献添加到总提交计数中 - -你可以使用参数 `?count_private=true` 把私人贡献计数添加到总提交计数中。 - -_注:如果你是自己部署本项目,私人贡献将会默认被计数,如果不是自己部署,你需要分享你的私人贡献计数。_ - -> 选项: `&count_private=true` - -```md -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&count_private=true) -``` - -### 显示图标 - -如果想要显示图标,你可以调用 `show_icons=true` 参数,像这样: - -```md -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&show_icons=true) -``` - -### 主题 - -你可以通过现有的主题进行卡片个性化,省去[手动自定义](#自定义)的麻烦。 - -通过调用 `?theme=THEME_NAME` 参数,像这样: - -```md -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&show_icons=true&theme=radical) -``` - -#### 所有现有主题 - -dark, radical, merko, gruvbox, tokyonight, onedark, cobalt, synthwave, highcontrast, dracula - -GitHub Readme Stat Themes - -你可以预览[所有可用主题](../themes/README.md)或者签出[主题配置文件](../themes/index.js), 而且如果你喜欢, **你也可以贡献新的主题** :D - -### 自定义 - -你可以通过使用 URL 参数的方式,为你的 `Stats Card` 或 `Repo Card` 自定义样式。 - -常用选项: - -- `title_color` - 卡片标题颜色 _(十六进制色码)_ -- `text_color` - 内容文本颜色 _(十六进制色码)_ -- `icon_color` - 图标颜色(如果可用)_(十六进制色码)_ -- `bg_color` - 卡片背景颜色 _(十六进制色码)_ **或者** 以 _angle,start,end_ 的形式渐变 -- `hide_border` - 隐藏卡的边框 _(布尔值)_ -- `theme` - 主题名称,从[所有可用主题](../themes/README.md)中选择 -- `cache_seconds` - 手动设置缓存头 _(最小值: 14400,最大值: 86400)_ -- `locale` - 在卡片中设置语言 _(例如 cn, de, es, 等等)_ - -##### bg_color 渐变 - -你可以在 bg_color 选项中提供多个逗号分隔的值来呈现渐变,渐变的格式是 :- - -``` -&bg_color=DEG,COLOR1,COLOR2,COLOR3...COLOR10 -``` - -> 缓存的注意事项: 如果 fork 数和 star 数 少于 1k , Repo 卡片默认缓存是 4 小时 (14400 秒) ,否则是 2 小时(7200)。另请注意缓存被限制为最短 2 小时,最长 24 小时。 - -#### 统计卡片专属选项: - -- `hide` - 隐藏特定统计信息 _(以逗号分隔)_ -- `hide_title` - _(boolean)_ -- `hide_rank` - _(boolean)_ -- `show_icons` - _(boolean)_ -- `include_all_commits` - 统计总提交次数而不是仅统计今年的提交次数 _(boolean)_ -- `count_private` - 统计私人提交 _(boolean)_ -- `line_height` - 设置文本之间的行高 _(number)_ - -#### Repo 卡片专属选项: - -- `show_owner` - 显示 Repo 的所有者名字 _(boolean)_ - -#### 语言卡片专属选项: - -- `hide` - 从卡片中隐藏指定语言 _(Comma seperated values)_ -- `hide_title` - _(boolean)_ -- `layout` - 提供五种布局 `normal` & `compact` & `donut` & `donut-vertical` & `pie` 间切换 -- `card_width` - 手动设置卡片的宽度 _(number)_ - -> :warning: **重要:** -> 如 [Percent Encoding](https://en.wikipedia.org/wiki/Percent-encoding) 所指定,语言名称应使用 uri 转义。 -> (例: `c++` 应该是 `c%2B%2B`, `jupyter notebook` 应该是 `jupyter%20notebook`, 等.) - ---- - -# GitHub 更多置顶 - -GitHub 更多置顶 允许你在使用 GitHub readme profile 时,在个人资料中置顶多于 6 个 repo 。 - -是的!你不再受限于置顶最多 6 个存储库了。 - -### 使用细则 - -复制粘贴这段代码到你的 README 文件中,并更改链接。 - -端点: `api/pin?username=anuraghazra&repo=github-readme-stats` - -```md -[![Readme Card](https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra&repo=github-readme-stats)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Demo - -[![Readme Card](https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra&repo=github-readme-stats)](https://github.com/anuraghazra/github-readme-stats) - -使用 [show_owner](#自定义) 变量将 Repo 所有者的用户名包含在内。 - -[![Readme Card](https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra&repo=github-readme-stats&show_owner=true)](https://github.com/anuraghazra/github-readme-stats) - -# 热门语言卡片 - -热门语言卡片显示了 GitHub 用户常用的编程语言。 - -_注意:热门语言并不表示我的技能水平或类似的水平,它是用来衡量用户在 github 上拥有最多代码的语言的一项指标,它是 github-readme-stats 的新特性_ - -### 使用细则 - -将此代码复制粘贴到您的 `README.md` 文件中,并修改链接。 - -端点: `api/top-langs?username=anuraghazra` - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) -``` - -### 隐藏指定语言 - -可以使用 `?hide=language1,language2` 参数来隐藏指定的语言。 - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&hide=javascript,html)](https://github.com/anuraghazra/github-readme-stats) -``` - -### 紧凑的语言卡片布局 - -你可以使用 `&layout=compact` 参数来改变卡片的样式。 - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&layout=compact)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Demo - -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) - -- 紧凑布局 - -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&layout=compact)](https://github.com/anuraghazra/github-readme-stats) - ---- - -### 全部 Demos - -- 默认 - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra) - -- 隐藏指定统计 - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&hide=contribs,issues) - -- 显示图标 - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&hide=issues&show_icons=true) - -- 包含全部提交 - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&include_all_commits=true) - -- 主题 - -从[默认主题](#主题)中进行选择 - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&show_icons=true&theme=radical) - -- 渐变 - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&bg_color=30,e96443,904e95&title_color=fff&text_color=fff) - -- 自定义统计卡片 - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api/?username=anuraghazra&show_icons=true&title_color=fff&icon_color=79ff97&text_color=9f9f9f&bg_color=151515) - -- 自定义 repo 卡片 - -![Customized Card](https://github-readme-stats.vercel.app/api/pin?username=anuraghazra&repo=github-readme-stats&title_color=fff&icon_color=f9f9f9&text_color=9f9f9f&bg_color=151515) - -- 热门语言 - -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) - ---- - -### 快速提示 (对齐 Repo 卡片) - -你通常无法将图片靠边显示。为此,您可以使用以下方法: - -```html - - - - - - -``` - -## 自己部署 - -#### [查看分步视频教程 作者:@codeSTACKr](https://youtu.be/n6d4KHSKqGk?t=107) - -因为 GitHub 的 API 每个小时只允许 5 千次请求,我的 `https://github-readme-stats.vercel.app/api` 很有可能会触发限制。如果你将其托管在自己的 Vercel 服务器上,那么你就不必为此担心。点击 deploy 按钮来开始你的部署! - -注意: 从 [#58](https://github.com/anuraghazra/github-readme-stats/pull/58) 开始,我们应该能够处理超过 5 千次的请求,并且不会出现宕机问题 :D - -[![Deploy to Vercel](https://vercel.com/button)](https://vercel.com/import/project?template=https://github.com/anuraghazra/github-readme-stats) - -

- 设置 Vercel 的指导 - -1. 前往 [vercel.com](https://vercel.com/) -1. 点击 `Log in` - ![](https://files.catbox.moe/tct1wg.png) -1. 点击 `Continue with GitHub` 通过 GitHub 进行登录 - ![](https://files.catbox.moe/btd78j.jpeg) -1. 登录 GitHub 并允许访问所有存储库(如果系统这样提示) -1. Fork 这个仓库 -1. 返回到你的 [Vercel dashboard](https://vercel.com/dashboard) -1. 选择 `Import Project` - ![](https://files.catbox.moe/qckos0.png) -1. 选择 `Import Git Repository` - ![](https://files.catbox.moe/pqub9q.png) -1. 选择 root 并将所有内容保持不变,并且只需添加名为 PAT_1 的环境变量(如图所示),其中将包含一个个人访问令牌(PAT),你可以在[这里](https://github.com/settings/tokens/new)轻松创建(保留默认,并且只需要命名下,名字随便) - ![](https://files.catbox.moe/0ez4g7.png) -1. 点击 deploy,这就完成了,查看你的域名就可使用 API 了! - -
- -## :sparkling_heart: 支持这个项目 - -我尽己所能地进行开源,并且我尽量回复每个在使用项目时需要帮助的人。很明显,这需要时间,但你可以免费享受这些。 - -然而, 如果你正在使用这个项目并感觉良好,或只是想要支持我继续开发,你可以通过如下方式: - -- 在你的 readme 中使用 github-readme-stats 时,链接指向这里 :D -- Star 并 分享这个项目 :rocket: -- [![paypal.me/anuraghazra](https://ionicabizau.github.io/badges/paypal.svg)](https://www.paypal.me/anuraghazra) - 你可以通过 PayPal 一次性捐款. 我多半会买一杯 ~~咖啡~~ 茶. :tea: - -谢谢! :heart: - ---- - -[![https://vercel.com?utm_source=github_readme_stats_team&utm_campaign=oss](../powered-by-vercel.svg)](https://vercel.com?utm_source=github_readme_stats_team&utm_campaign=oss) - -欢迎贡献! <3 - -用 :heart: 发电,用 JavaScript 制作。 diff --git a/docs/readme_de.md b/docs/readme_de.md deleted file mode 100644 index edc5f8b24c695..0000000000000 --- a/docs/readme_de.md +++ /dev/null @@ -1,388 +0,0 @@ -

- GitHub Readme Stats -

GitHub Readme Statistiken

-

Zeige dynamisch generierte GitHub-Statistiken in deinen Readmes!

-

- -

- - Tests Passing - - - GitHub Contributors - - - Tests Coverage - - - Issues - - - GitHub pull requests - - - OpenSSF Scorecard - -
-
-

- -

- Beispiele ansehen - · - Fehler melden - · - Funktion wünschen -

-

- Français - · - 简体中文 - · - Español - · - Deutsch - · - 日本語 - · - Português Brasileiro - · - Italiano - · - 한국어 - . - Nederlands - . - नेपाली - . - Türkçe -

-

-

Du magst das Projekt? Wie wäre es mit einer kleinen Spende um es weiterhin am Leben zu erhalten? - -# Funktionen - -- [GitHub Statistiken-Karte](#github-statistiken-karte) - - [Verbergen individueller Statistiken](#verbergen-individueller-statistiken) - - [Symbole anzeigen](#symbole-anzeigen) - - [Erscheinungsbild/Themes](#erscheinungsbildthemes) - - [Anpassungen/Personalisierung](#anpassungenpersonalisierung) -- [GitHub Extra-Pins](#github-extra-pins) - - [Benutzung](#benutzung) - - [Beispiele](#beispiele) -- [Top Programmiersprachen-Karte](#top-programmiersprachen-karte) - - [Benutzung](#benutzung-1) - - [Verbirg einzelne Sprachen](#verbirg-einzelne-sprachen) - - [Kompaktes Sprachen-Karte Layout](#kompaktes-sprachen-karte-layout) - - [Beispiel](#beispiel) -- [WakaTime Wochen-Statistik](#wakatime-wochen-statistik) - - [Beispiel](#beispiel-1) - - [Alle Beispiele](#alle-beispiele) - - [Kleiner Tipp (Ausrichten der Repo-Karte)](#kleiner-tipp-ausrichten-der-repo-karte) - - [Betreibe es auf deiner eigenen Vercel-Instanz](#betreibe-es-auf-deiner-eigenen-vercel-instanz) - - [:sparkling\_heart: Unterstütze das Projekt](#sparkling_heart-unterstütze-das-projekt) - -# GitHub Statistiken-Karte - -Kopiere folgendes in deine Readme um die Statistiken zu benutzen. -Passe den Wert des URL-Parameters `?username=` so an, dass dort dein GitHub-Nutzername steht. - -```md -[![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) -``` - -_Hinweis: Die Berechnung des Ranges basiert auf den jeweiligen Benutzerstatistiken, siehe [src/calculateRank.js](../src/calculateRank.js)_ - -### Verbergen individueller Statistiken - -Um eine spezifische Statistik auszublenden, kann dem Query-Parameter `?hide=` ein Array an Optionen, die nicht angezeigt werden sollen, übergeben werden. - -> Optionen: `&hide=stars,commits,prs,issues,contribs` - -```md -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&hide=["contribs","prs"]) -``` - -### Symbole anzeigen - -Um Symbole anzuzeigen kann der URL-Parameter `show_icons=true` wie folgt verwendet werden: - -```md -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&show_icons=true) -``` - -### Erscheinungsbild/Themes - -Mithilfe der eingebauten Themes kann das Aussehen der Karten verändern werden, ohne manuelle Anpassungen vornehmen zu müssen. - -Benutze den `?theme=THEME_NAME`-Parameter wie folgt :- - -```md -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&show_icons=true&theme=radical) -``` - -#### Alle eingebauten Themes :- - -dark, radical, merko, gruvbox, tokyonight, onedark, cobalt, synthwave, highcontrast, dracula - -GitHub Readme Stat Themes - -Du kannst dir eine Vorschau [aller verfügbaren Themes](../themes/README.md) ansehen oder die [theme config Datei](../themes/index.js) ansehen. -Außerdem **kannst du neue Themes erstellen**, Beiträge an diesem Projekt sind gerne gesehen! :D - -### Anpassungen/Personalisierung - -Du kannst das Erscheinungsbild deiner `Stats Card` oder `Repo Card`, mithilfe von URL-Parametern, nach deinen Vorlieben anpassen. - -#### Verbreitete Optionen: - -- `title_color` - Titelfarbe _(hex color)_ -- `text_color` - Textkörperfarbe _(hex color)_ -- `icon_color` - Symbolfarbe (falls verfügbar) _(hex color)_ -- `bg_color` - Hintergrundfarbe _(hex color)_ **oder** ein Farbverlauf in der Form von _winkel,start,ende_ -- `hide_border` - Blendet den Rand der Karte aus _(Boolean)_ -- `theme` - Name des Erscheinungsbildes/Themes [alle verfügbaren Themes](../themes/README.md) -- `cache_seconds` - manuelles festlegen der Cachezeiten _(min: 14400, max: 86400)_ -- `locale` - Stellen Sie die Sprache auf der Karte ein _(z.B. cn, de, es, etc.)_ - -##### Farbverlauf in bg_color - -Du kannst mehrere, mit Kommas separierte, Werte in der bg_color Option angeben, um einen Farbverlauf anzuzeigen. Das Format ist:- - -``` -&bg_color=WINKEL,FARBE1,FARBE2,FARBE3...FARBE10 -``` - -> Hinweis bzgl. des Caches: Wenn die Anzahl der Forks und Stars geringer als 1 Tsd. ist, haben die Repo-Cards eine Standard-Cachezeit von 30 Minuten (1800 Sekunden), ansonsten beträgt diese 2 Stunden (7200 Sekunden). Außerdem ist der Cache auf ein Minimum von 30 Minuten und ein Maximum von 24 Stunden begrenzt. - -#### Exklusive Optionen der Statistiken-Karte: - -- `hide` - Verbirgt die [angegeben Elemente](#verbergen-individueller-statistiken) _(mit Komma abgegrenzte Werte)_ -- `hide_title` - _(Boolean)_ -- `hide_rank` - _(Boolean)_ -- `show_icons` - _(Boolean)_ -- `include_all_commits` - Zähle alle Beiträge anstatt nur das aktuelle Jahr _(Boolean)_ -- `count_private` - Zähle private Beiträge _(Boolean)_ -- `line_height` - Legt die Zeilenhöhe zwischen Text fest _(Zahl)_ - -#### Exklusive Optionen der Repo-Karte: - -- `show_owner` - Zeigt den Besitzer des Repos _(Boolean)_ - -#### Exklusive Optionen der Sprachen-Karte: - -- `hide` - Verbirgt die angegebenen Sprachen von der Karte _(Komma separierte Werte)_ -- `hide_title` - _(Boolean)_ -- `layout` - Wechseln Sie zwischen den fünf verfügbaren Layouts `normal` & `compact` & `donut` & `donut-vertical` & `pie` -- `card_width` - Lege die Breite der Karte manuell fest _(Zahl)_ - -> :warning: **Wichtig:** -> Sprachennamen sollten uri-escaped sein, wie hier angegeben: [Percent Encoding](https://en.wikipedia.org/wiki/Percent-encoding) -> (z.B.: `c++` sollte zu `c%2B%2B` werden, `jupyter notebook` sollte zu `jupyter%20notebook` werden, usw.) - -#### Exklusive Optionen der WakaTime-Karte: - -- `hide_title` - _(Boolean)_ -- `line_height` - Legt die Zeilenhöhe des Texts fest _(Zahl)_ -- `hide_progress` - Verbirgt die Fortschrittsanzeige und Prozentzahl _(Boolean)_ -- `custom_title` - Legt einen benutzerdefinierten Titel fest -- `layout` - Wechselt zwischen zwei verschiedenen Layouts: `default` & `compact` -- `langs_count` - Begrenzt die Anzahl der angezeigten Sprachen auf der Karte -- `api_domain` - Legt eine benutzerdefinierte API Domain fest, z.B. für [Hakatime](https://github.com/mujx/hakatime) oder [Wakapi](https://github.com/muety/wakapi) -- `range` – Fragt eine andere Zeitspanne an, als jene, welche standardmäßig in WakaTime hinterlegt ist. Zum Beispiel `last_7_days`. Siehe [WakaTime API Dokumentation](https://wakatime.com/developers#stats). - ---- - -# GitHub Extra-Pins - -GitHub Extra-Pins ermöglicht es mit Hilfe einer Readme auf deinem Profil mehr als 6 Repositories anzuzeigen. - -Und Bääm! Du bist nicht mehr auf 6 angeheftete Repositories limitiert. - -### Benutzung - -Füge diesen Code in deine Readme-Datei ein und passe die Links an. -Passe den Wert des URL-Parameters `?username=` so an, dass dort dein GitHub-Nutzername steht. -Den Wert des URL-Parameters `?repo=` musst du so anpassen, dass dort der Namen deines Repositorys steht. - -Endpunkt: `api/pin?username=anuraghazra&repo=github-readme-stats` - -```md -[![Readme Card](https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra&repo=github-readme-stats)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Beispiele - -[![Readme Card](https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra&repo=github-readme-stats)](https://github.com/anuraghazra/github-readme-stats) - -Benutze die [show_owner](#anpassungenpersonalisierung) Variable, um den Nutzernamen des Repository-Eigentümers anzuzeigen. - -[![Readme Card](https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra&repo=github-readme-stats&show_owner=true)](https://github.com/anuraghazra/github-readme-stats) - -# Top Programmiersprachen-Karte - -Die Top Programmiersprachen-Karte visualisiert die am meisten benutzten Programmiersprachen eines GitHub-Nutzers. - -_HINWEIS: Die Top Programmiersprachen treffen keine Aussage über persönliche Fähigkeiten oder dergleichen, es ist lediglich eine auf den GitHub-Statistiken des Nutzers basierende Kennzahl, welche Programmiersprache wie häufig verwendet wurde._ - -### Benutzung - -Füge diesen Code in deine Readme-Datei ein und passe die Links an. -Passe den Wert des URL-Parameters `?username=` so an, dass dort dein GitHub-Nutzername steht. - -Endpunkt: `api/top-langs?username=anuraghazra` - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Verbirg einzelne Sprachen - -Du kannst den `?hide=language1,language2` URL-Parameter benutzen, um einzelne Sprachen auszublenden. - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&hide=javascript,html)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Kompaktes Sprachen-Karte Layout - -Du kannst die `&layout=compact` Option nutzen, um das Kartendesign zu ändern. - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&layout=compact)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Beispiel - -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) - -- Kompaktes Layout - -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&layout=compact)](https://github.com/anuraghazra/github-readme-stats) - -# WakaTime Wochen-Statistik - -Ändere `?username=` in den eigenen [WakaTime](https://wakatime.com)-Benutzernamen. - -```md -[![Harlok's WakaTime stats](https://github-readme-stats.vercel.app/api/wakatime?username=ffflabs)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Beispiel - -[![Harlok's WakaTime stats](https://github-readme-stats.vercel.app/api/wakatime?username=ffflabs)](https://github.com/anuraghazra/github-readme-stats) - -[![Harlok's WakaTime stats](https://github-readme-stats.vercel.app/api/wakatime?username=ffflabs&hide_progress=true)](https://github.com/anuraghazra/github-readme-stats) - -- Kompaktes Layout - -[![Harlok's WakaTime stats](https://github-readme-stats.vercel.app/api/wakatime?username=ffflabs&layout=compact)](https://github.com/anuraghazra/github-readme-stats) - ---- - -### Alle Beispiele - -- Default - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra) - -- Ausblenden bestimmter Statistiken - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&hide=["contribs","issues"]) - -- Symbole anzeigen - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&hide=["issues"]&show_icons=true) - -- Alle Beiträge anzeigen - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&include_all_commits=true) - -- Erscheinungsbild/Themes - -Wähle Eines von den [Standard-Themes](#themes) - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&show_icons=true&theme=radical) - -- Farbverlauf - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&bg_color=30,e96443,904e95&title_color=fff&text_color=fff) - -- Statistiken-Karte anpassen - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api/?username=anuraghazra&show_icons=true&title_color=fff&icon_color=79ff97&text_color=9f9f9f&bg_color=151515) - -- Repo-Karte(Extra-Pin) anpassen - -![Customized Card](https://github-readme-stats.vercel.app/api/pin?username=anuraghazra&repo=github-readme-stats&title_color=fff&icon_color=f9f9f9&text_color=9f9f9f&bg_color=151515) - -- Top Programmiersprachen - -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) - ---- - -### Kleiner Tipp (Ausrichten der Repo-Karte) - -Üblicherweise ist es in `.md`-Dateien nicht möglich Bilder nebeneinander anzuzeigen. Um dies zu ermöglichen, kannst du folgendes tun: - -```html - - - - - - -``` - -## Betreibe es auf deiner eigenen Vercel-Instanz - -#### [Schritt für Schritt YouTube Tutorial by @codeSTACKr](https://youtu.be/n6d4KHSKqGk?t=107) - -Da die GitHub API nur 5 Tsd. Aufrufe pro Stunde zulässt, kann es passieren, dass meine `https://github-readme-stats.vercel.app/api` dieses Limit erreicht. -Wenn du es auf deinem eigenen Vercel-Server hostest, brauchst du dich darum nicht zu kümmern. Klicke auf den Deploy-Knopf um loszulegen! - -Hinweis: Seit [#58](https://github.com/anuraghazra/github-readme-stats/pull/58) sollte es möglich sein, mehr als 5 Tsd Aufrufe pro Stunde ohne Downtimes zu verkraften :D - -[![Deploy to Vercel](https://vercel.com/button)](https://vercel.com/import/project?template=https://github.com/anuraghazra/github-readme-stats) - -

- Anleitung zum Einrichten von Vercel 🔨 - -1. Gehe zu [vercel.com](https://vercel.com/) -1. Klicke auf `Log in` - ![](https://files.catbox.moe/tct1wg.png) -1. Melde dich mit deinem GitHub-account an, indem du `Continue with GitHub` klickst - ![](https://files.catbox.moe/btd78j.jpeg) -1. Verbinde dich mit GitHub und erlaube den Zugriff auf alle Repositories (falls gefordert) -1. Forke dieses Repository -1. Gehe zurück zu deinem [Vercel Dashboard](https://vercel.com/dashboard) -1. Klick `Import Project` - ![](https://files.catbox.moe/qckos0.png) -1. Klick `Import Git Repository` - ![](https://files.catbox.moe/pqub9q.png) -1. Wähle root und füge eine Umgebungsvariable namens PAT_1 (siehe Abbildung) die als Wert deinen persönlichen Access Token (PAT) hat hinzu, den du einfach [hier](https://github.com/settings/tokens/new) erzeugen kannst (lasse alles wie es ist, vergebe einen beliebigen Namen) - ![](https://files.catbox.moe/0ez4g7.png) -1. Klicke auf `Deploy`, und das wars. Besuche deine Domains um die API zu benutzen! -
- -## :sparkling_heart: Unterstütze das Projekt - -Ich versuche alles was ich kann als Open-Source zur Verfügung zu stellen, als auch jedem der Hilfe bei der Benutzung dieses Projektes braucht zu antworten. Natürlich beansprucht sowas Zeit und du kannst diesen Dienst kostenlos benutzen. - -Wenn du dieses Projekt nutzt und zufrieden bist, kannst du dennoch Dinge tun um mich weiterhin zu motivieren am Projekt zu arbeiten: - -- Erwähne und verlinke das Projekt in deiner Readme wenn du es benutzt :D -- Geb dem Projekt einen Stern hier auf GitHub und teile es :rocket: -- [![paypal.me/anuraghazra](https://ionicabizau.github.io/badges/paypal.svg)](https://www.paypal.me/anuraghazra) - Du kannst einmalige Spenden via PayPal tätigen. Ich kaufe mir wahrscheinlich einen ~~Kaffee~~ Tee davon. :tea: - -Vielen Dank! :heart: - ---- - -[![https://vercel.com?utm_source=github_readme_stats_team&utm_campaign=oss](../powered-by-vercel.svg)](https://vercel.com?utm_source=github_readme_stats_team&utm_campaign=oss) - - -Mitarbeit an dem Projekt ist immer Willkommen! <3 - -Gemacht mit viel :heart: und JavaScript. diff --git a/docs/readme_es.md b/docs/readme_es.md deleted file mode 100644 index 89f647f7e08c7..0000000000000 --- a/docs/readme_es.md +++ /dev/null @@ -1,427 +0,0 @@ -

- GitHub Readme Stats -

GitHub Readme Stats

-

¡Obtén tus estadísticas de GitHub generadas dinámicamente en tu README!

-

- -

- - Tests Passing - - - GitHub Contributors - - - Tests Coverage - - - Issues - - - GitHub pull requests - - - OpenSSF Scorecard - -
-
-

- -

- Ver un ejemplo - · - Reportar un bug - · - Solicitar una mejora -

-

- Français - · - 简体中文 - · - Español - · - Deutsch - · - 日本語 - · - Português Brasileiro - · - Italiano - · - 한국어 - . - Nederlands - . - Türkçe - . - नेपाली -

-

-

¿Te gusta este proyecto? ¡Por favor, considera donar para ayudar a mejorarlo! - -# Características - -- [Tarjeta de estadísticas de GitHub](#tarjeta-de-estadísticas-de-github) - - [Ocultar estadísticas individualmente](#ocultar-estadísticas-individualmente) - - [Agregar contribuciones privadas al total de commits contados](#agregar-contribuciones-privadas-al-total-de-commits-contados) - - [Mostrar íconos](#mostrar-íconos) - - [Temas](#temas) - - [Personalización](#personalización) -- [Pines adicionales de GitHub](#pines-adicionales-de-github) - - [Utilización](#utilización) - - [Ejemplo](#ejemplo) -- [Tarjeta de Lenguajes Principales](#tarjeta-de-lenguajes-principales) - - [Utilización](#utilización-1) - - [Excluir repositorios individualmente](#excluir-repositorios-individualmente) - - [Ocultar lenguajes individualmente](#ocultar-lenguajes-individualmente) - - [Mostrar más lenguajes](#mostrar-más-lenguajes) - - [Diseño Compacto de Tarjeta de Lenguaje](#diseño-compacto-de-tarjeta-de-lenguaje) - - [Ejemplo](#ejemplo-1) -- [Estadísticas de la semana de WakaTime](#estadísticas-de-la-semana-de-wakatime) - - [Ejemplo](#ejemplo-2) - - [Todos los ejemplos](#todos-los-ejemplos) - - [Consejo rápido (para alinear las tarjetas de repositorio)](#consejo-rápido-para-alinear-las-tarjetas-de-repositorio) - - [Despliega tu propia instancia de Vercel](#despliega-tu-propia-instancia-de-vercel) - - [:sparkling\_heart: Apoya al proyecto](#sparkling_heart-apoya-al-proyecto) - -# Tarjeta de estadísticas de GitHub - -Copia y pega esto en el contenido de tu README.md y listo. ¡Simple! - -Cambia el valor de `?username=` al nombre de tu usuario de GitHub. - -```md -[![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) -``` - -_Nota: Los rangos disponibles son S+ (top 1%), S (top 25%), A++ (top 45%), A+ (top 60%) y B+ (todos). Los valores se calculan utilizando la [función de distribución acumulada](https://es.wikipedia.org/wiki/Funci%C3%B3n_de_distribuci%C3%B3n) utilizando commits, contribuciones, issues, estrellas, pull request, seguidores y repositorios propios. Puedes investigar más sobre la implementación en [src/calculateRank.js](../src/calculateRank.js)._ - -### Ocultar estadísticas individualmente - -Para ocultar alguna estadística específica, puedes utilizar el parámetro `?hide=` con los elementos que quieras ocultar separados por comas. - -> Opciones: `&hide=stars,commits,prs,issues,contribs` - -```md -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&hide=contribs,prs) -``` - -### Agregar contribuciones privadas al total de commits contados - -Puedes agregar el recuento de todas sus contribuciones privadas al recuento total de commits utilizando el parámetro `?count_private=true`. - -_Nota: Si estás desplegando este proyecto tú mismo, las contribuciones privadas se contarán de manera predeterminada; de lo contrario, deberás elegir compartir el recuento de sus contribuciones privadas._ - -> Opciones: `&count_private=true` - -```md -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&count_private=true) -``` - -### Mostrar íconos - -Para habilitar los íconos, puedes utilizar `show_icons=true` como parámetro, de esta manera: - -```md -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&show_icons=true) -``` - -### Temas - -Puedes personalizar el aspecto de la tarjeta sin realizar ninguna [personalización manual](#personalización) con los temas incorporados. - -Utiliza el parámetro `?theme=THEME_NAME`, de esta manera: - -```md -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&show_icons=true&theme=radical) -``` - -#### Todos los temas incorporados - -dark, radical, merko, gruvbox, tokyonight, onedark, cobalt, synthwave, highcontrast, dracula - -GitHub Readme Stat Themes - -Puedes ver una vista previa de [todos los temas disponibles](../themes/README.md) o ver el [archivo de configuración](../themes/index.js) del tema y también **puedes contribuir con nuevos temas** si lo deseas :D - -### Personalización - -Puedes personalizar el aspecto de tu `Tarjeta de Estadísticas` o `Tarjeta de Repo` de la manera que desees con los parámetros URL. - -#### Opciones Comunes: - -- `title_color` - Color del título _(hex color)_ -- `text_color` - Color del contenido _(hex color)_ -- `icon_color` - Color de icono si esta disponible _(hex color)_ -- `bg_color` - Color de fondo _(hex color)_ -- `hide_border` - Oculta el borde de la tarjeta _(booleano)_ -- `theme` - Nombre del tema, elige uno de [todos los temas disponible ](../themes/README.md) -- `cache_seconds` - Cache _(min: 14400, max: 86400)_ -- `locale` - configurar el idioma en la tarjeta _(p.ej. cn, de, es, etc.)_ - -##### Gradiente en `bg_color` - -Puedes pasar mútliples valores separados por coma en la opción `bg_color` para dibujar un gradiente, el formato del gradiente es: - -``` -&bg_color=DEG,COLOR1,COLOR2,COLOR3...COLOR10 -``` - -> Nota sobre la caché: las tarjetas de Repo tienen un caché predeterminado de 4 horas (14400 segundos) si el recuento forks y el recuento de estrellas es inferior a 1k; de lo contrario, son 2 horas (7200 segundos). También ten en cuenta que la caché está sujeta a un mínimo de 2 horas y un máximo de 24 horas - -#### Opciones exclusivas de la Tarjeta de Estadísticas: - -- `hide` - Oculta de las estadísticas [los elementos especificados](#ocultar-estadísticas-individualmente) _(valores separados por comas)_ -- `hide_title` - _(booleano)_ -- `hide_rank` - _(booleano)_ -- `show_icons` - _(booleano)_ -- `include_all_commits` - Cuenta el total de commits en lugar de solo los commits del año actual _(boolean)_ -- `count_private` - Cuenta los commits privadas _(boolean)_ -- `line_height` - Establece el alto de línea entre texto _(número)_ -- `custom_title` - Establece un título personalizado -- [`disable_animations`] - Desactiva todas las animaciones _(booleano)_ - -#### Opciones exclusivas de la Tarjeta de Repo: - -- `show_owner` - Mostrar el nombre del propietario del repositorio _(booleano)_ - -#### Opciones exclusivas de la Tarjeta de Lenguajes: - -- `hide` - Oculta de la tarjeta los lenguajes especificados _(valores separados por comas)_ -- `hide_title` - _(booleano)_ -- `layout` - Cambiar entre los cinco diseños disponibles `normal` & `compact` & `donut` & `donut-vertical` & `pie` -- `card_width` - Establece el ancho de la tarjeta manualmente _(número)_ -- `langs_count` - Muestra más lenguajes en la tarjeta, entre 1-10, por defecto 5 _(número)_ -- `exclude_repo` - Excluye los repositorios especificados _(valores separados por comas)_ -- `custom_title` - Establece un título personalizado - -> :warning: **Importante:** -> Los nombres de los lenguajes deben estar codificados para URLs, como se especifica en [Código porciento](https://es.wikipedia.org/wiki/C%C3%B3digo_porciento) -> (es decir: `c++` debería convertirse en `c%2B%2B`,`jupyter notebook` debería convertirse en `jupyter%20notebook`, etc.) - -#### Opciones exclusivas de la Tarjeta de WakaTime: - -- `hide_title` - _(booleano)_ -- `line_height` - Establece el alto de línea entre texto _(número)_ -- `hide_progress` - Oculta la barra de progreso y el porcentaje _(booleano)_ -- `custom_title` - Establece un título personalizado -- `layout` - Cambia entre los dos diseños disponibles `default` & `compact` -- `langs_count` - Limita el número de idiomas que aparecen en el mapa -- `api_domain` - Establece un dominio de API personalizado para la tarjeta - ---- - -# Pines adicionales de GitHub - -Los pines adicionales de GitHub le permiten fijar más de 6 repositorios en su perfil utilizando un perfil readme de GitHub. - -¡Yey! Ya no está limitado a 6 repositorios pinneados. - -### Utilización - -Copia y pegua este código en tu Readme y cambia los enlaces. - -Endpoint: `api/pin?username=anuraghazra&repo=github-readme-stats` - -```md -[![Readme Card](https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra&repo=github-readme-stats)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Ejemplo - -[![Readme Card](https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra&repo=github-readme-stats)](https://github.com/anuraghazra/github-readme-stats) - -Utiliza la variable [show_owner](#customización) para incluir el nombre de usuario del propietario del repositorio. - -[![Readme Card](https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra&repo=github-readme-stats&show_owner=true)](https://github.com/anuraghazra/github-readme-stats) - -# Tarjeta de Lenguajes Principales - -La tarjeta de lenguajes principales muestra los lenguajes principales del usuario de GitHub que se han utilizado principalmente. - -_NOTA: los lenguajes principales no indican mi nivel de habilidad o algo así, es una métrica de GitHub de los lenguajes que tengo más código en GitHub. Es una nueva característica de github-readme-stats_ - -### Utilización - -Copia y pegua este código en tu Readme y cambia los enlaces. - -Endpoint: `api/top-langs?username=anuraghazra` - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Excluir repositorios individualmente - -Puedes usar el parámetro `?exclude_repo=repo1,repo2` para ocultar repositorios individualmente. - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&exclude_repo=github-readme-stats,anuraghazra.github.io)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Ocultar lenguajes individualmente - -Puedes usar el parámetro `?hide=language1,language2` para ocultar lenguajes individualmente. - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&hide=javascript,html)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Mostrar más lenguajes - -Puedes usar el paramétro `&langs_count=` para incrementar o decrementar el número de lenguajes mostrados en la tarjeta. Los valores admitidos son los números enteros entre 1 y 10 (inclusive), y el valor por defecto es 5. - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&langs_count=8)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Diseño Compacto de Tarjeta de Lenguaje - -Puedes usar la opción `& layout = compact` para cambiar el diseño de la tarjeta. - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&layout=compact)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Ejemplo - -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) - -- Diseño compacto - -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&layout=compact)](https://github.com/anuraghazra/github-readme-stats) - -# Estadísticas de la semana de WakaTime - -cambia el valor del parámetro `?username=` a tu username en [WakaTime](https://wakatime.com). - -```md -[![Harlok's WakaTime stats](https://github-readme-stats.vercel.app/api/wakatime?username=ffflabs)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Ejemplo - -[![Harlok's WakaTime stats](https://github-readme-stats.vercel.app/api/wakatime?username=ffflabs)](https://github.com/anuraghazra/github-readme-stats) - -[![Harlok's WakaTime stats](https://github-readme-stats.vercel.app/api/wakatime?username=ffflabs&hide_progress=true)](https://github.com/anuraghazra/github-readme-stats) - -- Diseño compacto - -[![Harlok's WakaTime stats](https://github-readme-stats.vercel.app/api/wakatime?username=ffflabs&layout=compact)](https://github.com/anuraghazra/github-readme-stats) - ---- - -### Todos los ejemplos - -- Por defecto - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra) - -- Ocultando ciertas estadísticas - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&hide=contribs,issues) - -- Mostrando íconos - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&hide=issues&show_icons=true) - -- Incluyendo todos los commits - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&include_all_commits=true) - -- Temas - -Escoja cualquiera de los [temas por defecto](#themes) - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&show_icons=true&theme=radical) - -- Gradiente - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&bg_color=30,e96443,904e95&title_color=fff&text_color=fff) - -- Personalizando Tarjeta de Estadísticas - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api/?username=anuraghazra&show_icons=true&title_color=fff&icon_color=79ff97&text_color=9f9f9f&bg_color=151515) - -- Estableciendo Idioma de la tarjeta - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api/?username=anuraghazra&locale=es) - -- Personalizando Tarjeta de Repo - -![Customized Card](https://github-readme-stats.vercel.app/api/pin?username=anuraghazra&repo=github-readme-stats&title_color=fff&icon_color=f9f9f9&text_color=9f9f9f&bg_color=151515) - -- Lenguajes Top - -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) - -- Tarjeta de WakaTime - -[![Harlok's WakaTime stats](https://github-readme-stats.vercel.app/api/wakatime?username=ffflabs)](https://github.com/anuraghazra/github-readme-stats) - ---- - -### Consejo rápido (para alinear las tarjetas de repositorio) - -Por lo general, no podrás acomodar las imágenes una al lado de la otra. Para hacerlo, puede usar este enfoque: - -```html - - - - - - -``` - -## Despliega tu propia instancia de Vercel - -#### [Échale un vistazo a este tutorial paso a paso de @codeSTACKr](https://youtu.be/n6d4KHSKqGk?t=107) - -Desde que la API de GitHub permite solo 5k peticiones por hora, es posible que mi `https://github-readme-stats.vercel.app/api` pueda llegar al límite. Si lo alojas en tu propio servidor de Vercel, no tendrás que preocuparte de nada. ¡Clickea en el botón "Deploy" para comenzar! - -NOTA: Debido a [#58](https://github.com/anuraghazra/github-readme-stats/pull/58) podríamos manejar más de 5k peticiones sin tener ningún problema con el downtime :D - -[![Deploy to Vercel](https://vercel.com/button)](https://vercel.com/import/project?template=https://github.com/anuraghazra/github-readme-stats) - -

- Guía para comenzar en Vercel - -1. Ve a [vercel.com](https://vercel.com/) -2. Clickea en `Log in` - ![](https://files.catbox.moe/tct1wg.png) -3. Inicia sesión con GitHub presionando `Continue with GitHub` - ![](https://files.catbox.moe/btd78j.jpeg) -4. Permite el acceso a todos los repositorios (si se te pregunta) -5. Haz un Fork de este repositorio -6. Dirígete de nuevo a tu [Vercel dashboard](https://vercel.com/dashboard) -7. Selecciona `Import Project` - ![](https://files.catbox.moe/qckos0.png) -8. Selecciona `Import Git Repository` - ![](https://files.catbox.moe/pqub9q.png) -9. Selecciona "root" y matén todo como está, simplemente añade tu variable de entorno llamada PAT_1 (como se muestra), la cual contendrá un token de acceso personal (PAT), el cual puedes crear fácilmente [aquí](https://github.com/settings/tokens/new) (mantén todo como está, simplemente asígnale un nombre, puede ser cualquiera que desees) - ![](https://files.catbox.moe/0ez4g7.png) -10. Clickea "Deploy" y ya está listo. ¡Ve tus dominios para usar la API! - -
- -## :sparkling_heart: Apoya al proyecto - -Casi todos mis proyectos son de código abierto e intento responder a todos los usuarios que necesiten ayuda con alguno de estos proyectos. Obviamente, esto toma tiempo. Puedes usar este servicio gratis. - -No obstante, si estás utilizando este proyecto y estás feliz con él o simplemente quieres animarme a que siga creando cosas, aquí tienes algunas maneras de hacerlo: - -- Darme créditos cuando estés utilizando github-readme-stats en tu README, añadiendo un link a este repositorio :D -- Dándole una estrella y compartiendo el proyecto :rocket: -- [![paypal.me/anuraghazra](https://ionicabizau.github.io/badges/paypal.svg)](https://www.paypal.me/anuraghazra) - Puedes hacerme una única donación a través de PayPal. Probablemente me compraré un ~~café~~ té. :tea: - -¡Gracias! :heart: - ---- - -[![https://vercel.com?utm_source=github_readme_stats_team&utm_campaign=oss](../powered-by-vercel.svg)](https://vercel.com?utm_source=github_readme_stats_team&utm_campaign=oss) - -¡Las contribuciones son bienvenidas! <3 - -Hecho con :heart: y JavaScript. diff --git a/docs/readme_fr.md b/docs/readme_fr.md deleted file mode 100644 index 0f035f96e76d7..0000000000000 --- a/docs/readme_fr.md +++ /dev/null @@ -1,353 +0,0 @@ -

- GitHub Readme Stats -

GitHub Readme Stats

-

Obtenez des statistiques GitHub générées dynamiquement sur vos Readme !

-

-

- - Tests Passing - - - GitHub Contributors - - - Tests Coverage - - - Issues - - - GitHub pull requests - - - OpenSSF Scorecard - -
-
-

- -

- Voir la démo - · - Soumettre un bug - · - Demander une nouveauté -

-

- Français - · - 简体中文 - · - Español - · - Deutsch - · - 日本語 - · - Português Brasileiro - · - Italiano - · - 한국어 - . - Nederlands - . - नेपाली - . - Türkçe -

-

-

Vous aimez ce projet? Pensez à faire un don pour l'améliorer! - -# Features - -- [Carte des Stats GitHub](#carte-des-stats-github) - - [Cacher les statistiques individuelles](#cacher-les-statistiques-individuelles) - - [Afficher les icônes](#afficher-les-icônes) - - [Thèmes](#thèmes) - - [Personnalisation](#personnalisation) -- [GitHub Extra Pins](#github-extra-pins) - - [Usage](#usage) - - [Démo](#démo) -- [Carte des langages les + utilisés](#carte-des-langages-les--utilisés) - - [Usage](#usage-1) - - [Cacher certaines langages](#cacher-certaines-langages) - - [Carte compacte des langages](#carte-compacte-des-langages) - - [Démo](#démo-1) - - [Toutes les démos](#toutes-les-démos) - - [Conseil rapide (aligner les cartes des dépôts)](#conseil-rapide-aligner-les-cartes-des-dépôts) - - [Déployer sur votre propre instance Vercel](#déployer-sur-votre-propre-instance-vercel) - - [:sparkling\_heart: Supporter le project](#sparkling_heart-supporter-le-project) - -# Carte des Stats GitHub - -Copiez-collez ceci dans votre Markdown, et c'est tout. C'est simple ! - -Remplacez la valeur `?username=` par le nom d'utilisateur de votre GitHub. - -```md -[![Les Stats GitHub de Anurag](https://github-readme-stats.vercel.app/api?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) -``` - -_Note: Les rangs sont calculés sur la base des statistiques de l'utilisateur, voir [src/calculateRank.js](../src/calculateRank.js)_ - -### Cacher les statistiques individuelles - -Pour masquer des statistiques spécifiques, vous pouvez passer un paramètre de requête `?hide=` avec des valeurs séparées par des virgules. - -> Options: `&hide=stars,commits,prs,issues,contribs` - -```md -![Les Stats GitHub de Anurag](https://github-readme-stats.vercel.app/api?username=anuraghazra&hide=contribs,prs) -``` - -### Afficher les icônes - -Pour activer les icônes, vous pouvez passer `show_icons=true` dans le paramètre de requête, comme ceci : - -```md -![Les Stats GitHub de Anurag](https://github-readme-stats.vercel.app/api?username=anuraghazra&show_icons=true) -``` - -### Thèmes - -Avec les thèmes intégrés, vous pouvez personnaliser l'apparence de la carte sans faire de [personnalisation manuelle](#customization). - -Use `?theme=THEME_NAME` parameter like so :- - -```md -![Les Stats GitHub de Anurag](https://github-readme-stats.vercel.app/api?username=anuraghazra&show_icons=true&theme=radical) -``` - -#### Tous les thèmes intégrés :- - -dark, radical, merko, gruvbox, tokyonight, onedark, cobalt, synthwave, highcontrast, dracula - -GitHub Readme Stat Themes - -Vous pouvez consulter un aperçu de [tous les thèmes disponibles](../themes/README.md) ou consulter le [fichier de configuration des thèmes](../themes/index.js) & **vous pouvez également ajouter de nouveaux thèmes** si vous le souhaitez :D - -### Personnalisation - -Vous pouvez personnaliser l'apparence de votre `Carte des stats` ou `Carte de dépôt` comme vous le souhaitez avec les paramètres d'URL. - -#### Options principales: - -- `title_color` - Couleur du titre de la carte _(hex color)_ -- `text_color` - Couleur du texte _(hex color)_ -- `icon_color` - Couleur des icônes si disponibles _(hex color)_ -- `bg_color` - Couleur du fond de la carte _(hex color)_ **ou** un gradiant de la forme _angle,start,end_ -- `hide_border` - Cache la bordure de la carte _(booléen)_ -- `theme` - Nom du thème, parmis [tous les thèmes disponibles](../themes/README.md) -- `cache_seconds` - Paramétrer le cache manuellement _(min: 14400, max: 86400)_ -- `locale` - définir la langue de la carte _(par exemple. cn, de, es, etc.)_ - -##### Gradient in bg_color - -Vous pouvez fournir plusieurs valeurs (suivie d'une virgule) dans l'option bg_color pour rendre un degradé, le format du degradé est :- - -``` -&bg_color=DEG,COLOR1,COLOR2,COLOR3...COLOR10 -``` - -> Note relative: Les cartes dépôt ont un cache par défaut de 30 minutes (1800 secondes) si le nombre de bifurcations et d'étoiles est inférieur à 1K, alors il est de 2 heures (7200). Notez également que la mémoire cache est limitée à 30 minutes au minimum et à 24 heures au maximum. - -#### Stats Card Exclusive Options: - -- `hide` - Masquer [les éléments spécifiés](#cacher-les-statistiques-individuelles) dans les statistiques _(Comma seperated values)_ -- `hide_title` - Masquer le titre _(boolean)_ -- `hide_rank` - Masquer le rang _(boolean)_ -- `show_icons` - Afficher les icônes _(boolean)_ -- `include_all_commits` - Compter le total de commits au lieu de ne compter que les commits de l'année en cours _(boolean)_ -- `count_private` - Compter les contributions privées _(boolean)_ -- `line_height` - Fixer la hauteur de la ligne entre les textes _(number)_ - -#### Repo Card Exclusive Options: - -- `show_owner` - Affiche le nom du propriétaire du dépôt _(boolean)_ - -#### Language Card Exclusive Options: - -- `hide` - Masquer les langages spécifiés sur la carte _(Comma seperated values)_ -- `hide_title` - Masquer le titre _(boolean)_ -- `layout` - Alterner entre 5 mise en page `normal` & `compact` & `donut` & `donut-vertical` & `pie` -- `card_width` - Fixer la largeur de la carte manuellement _(number)_ - -> :warning: **Important:** -> Les noms des langages doivent être en format uri, comme spécifié dans [Percent Encoding](https://fr.wikipedia.org/wiki/Percent-encoding) -> (c'est-à-dire que: `c++` devrait devenir `c%2B%2B`, `jupyter notebook` devrait devenir `jupyter%20notebook`, etc.) - ---- - -# GitHub Extra Pins - -Les épingles supplémentaires GitHub vous permettent d'épingler plus de 6 dépôts dans votre profil en utilisant un profil GitHub readme. - -Et OUI ! Vous n'êtes plus limité à 6 dépôts épinglés. - -### Usage - -Copiez-collez ce code dans votre readme et modifiez les liens. - -Extrémité: `api/pin?username=anuraghazra&repo=github-readme-stats` - -```md -[![Carte ReadMe](https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra&repo=github-readme-stats)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Démo - -[![Readme Card](https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra&repo=github-readme-stats)](https://github.com/anuraghazra/github-readme-stats) - -Utiliser la variable [show_owner](#customization) pour inclure le nom d'utilisateur du propriétaire du dépôt. - -[![Readme Card](https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra&repo=github-readme-stats&show_owner=true)](https://github.com/anuraghazra/github-readme-stats) - -# Carte des langages les + utilisés - -La carte des langages principaux montre les langages les plus utilisés par les utilisateurs de GitHub. - -_NOTE: Les langages affichés n'indiquent pas mon niveau de compétence ou quelque chose comme ça, c'est une métrique GitHub de quelles langages j'ai le plus de code sur GitHub, c'est une nouvelle fonctionnalité de github-readme-stats_ - -### Usage - -Copiez-collez ce code dans votre readme et modifiez les liens. - -Extrémité: `api/top-langs?username=anuraghazra` - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Cacher certaines langages - -Vous pouvez utiliser le paramètre `?hide=language1,language2` pour masquer les langages individuels. - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&hide=javascript,html)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Carte compacte des langages - -Vous pouvez utiliser l'option `&layout=compact` pour changer le style de la carte. - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&layout=compact)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Démo - -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) - -- Carte compacte - -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&layout=compact)](https://github.com/anuraghazra/github-readme-stats) - ---- - -### Toutes les démos - -- Défaut - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra) - -- Ne pas afficher des stats spécifiques - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&hide=contribs,issues) - -- Afficher les icônes - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&hide=issues&show_icons=true) - -- Inclure tous les commits - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&include_all_commits=true) - -- Thèmes - -Choisissez parmi l'un des [thèmes par défaut](#themes) - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&show_icons=true&theme=radical) - -- Dégradé - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&bg_color=30,e96443,904e95&title_color=fff&text_color=fff) - -- Personnaliser la carte des stats - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api/?username=anuraghazra&show_icons=true&title_color=fff&icon_color=79ff97&text_color=9f9f9f&bg_color=151515) - -- Personnaliser la carte dépôt - -![Customized Card](https://github-readme-stats.vercel.app/api/pin?username=anuraghazra&repo=github-readme-stats&title_color=fff&icon_color=f9f9f9&text_color=9f9f9f&bg_color=151515) - -- Top Langages - -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) - ---- - -### Conseil rapide (aligner les cartes des dépôts) - -En général, vous ne pourrez pas mettre les images côte à côte. Pour ce faire, vous pouvez utiliser cette approche : - -```html - - - - - - -``` - -## Déployer sur votre propre instance Vercel - -#### [Check Out Step By Step Video Tutorial By @codeSTACKr](https://youtu.be/n6d4KHSKqGk?t=107) - -Comme l'API GitHub ne permet que 5k requêtes par heure, il est possible que mon `https://github-readme-stats.vercel.app/api` puisse atteindre le limiteur de débit. Si vous l'hébergez sur votre propre serveur Vercel, alors vous n'avez pas à vous soucier de quoi que ce soit. Cliquez sur le bouton de déploiement pour commencer ! - -NOTE: Depuis [#58](https://github.com/anuraghazra/github-readme-stats/pull/58) nous devrions être en mesure de traiter plus de 5 000 demandes et ne pas avoir de problèmes de temps d'arrêt :D - -[![Deployer avec Vercel](https://vercel.com/button)](https://vercel.com/import/project?template=https://github.com/anuraghazra/github-readme-stats) - -

- Guide pour la mise en place de Vercel 🔨 - -1. Allez sur [vercel.com](https://vercel.com/) -1. Cliquez sur `Log in` - ![](https://files.catbox.moe/tct1wg.png) -1. Connectez-vous avec GitHub en cliquant `Continue with GitHub` - ![](https://files.catbox.moe/btd78j.jpeg) -1. Connectez-vous à GitHub et autorisez l'accès à tous les dépôts, si vous y êtes invité -1. Forkez ce dépôt -1. Retournez au [dashboard Vercel](https://vercel.com/dashboard) -1. Sélectionnez `Import Project` - ![](https://files.catbox.moe/qckos0.png) -1. Sélectionnez `Import Git Repository` - ![](https://files.catbox.moe/pqub9q.png) -1. Choisissez root et gardez tout tel quel, ajoutez simplement votre variable d'environnement nommée PAT_1 (comme indiqué), qui contiendra un jeton d'accès personnel (PAT), que vous pouvez facilement créer [ici](https://github.com/settings/tokens/new) (laissez tout tel quel, nommez le simplement quelque chose, cela peut être tout ce que vous voulez) - ![](https://files.catbox.moe/0ez4g7.png) -1. Cliquez sur "Deploy" et vous êtes prêt à partir. Regardez vos domaines pour utiliser l'API ! - -
- -## :sparkling_heart: Supporter le project - -Je mets open-source presque tout ce que je peux, et j'essaie de répondre à tous ceux qui ont besoin d'aide en utilisant ces projets. Évidemment, cela prend du temps. Vous pouvez utiliser ce service gratuitement. - -Cependant, si vous utilisez ce projet et que vous en êtes satisfait ou si vous voulez simplement m'encourager à continuer à créer, il y a quelques façons de le faire :- - -- Donner un crédit approprié lorsque vous utilisez github-readme-stats sur votre readme, avec un lien vers celui-ci :D -- Mettre une étoile et partager le projet :rocket: -- [![paypal.me/anuraghazra](https://ionicabizau.github.io/badges/paypal.svg)](https://www.paypal.me/anuraghazra) - Vous pouvez faire des dons uniques via PayPal. Je vais probablement acheter un ~~café~~ thé. :tea: - -Merci ! :heart: - ---- - -[![https://vercel.com?utm_source=github_readme_stats_team&utm_campaign=oss](../powered-by-vercel.svg)](https://vercel.com?utm_source=github_readme_stats_team&utm_campaign=oss) - - -Les contributions sont les bienvenues ! <3 - -Fait avec :heart: et JavaScript. diff --git a/docs/readme_it.md b/docs/readme_it.md deleted file mode 100644 index 8f16f4e6bd080..0000000000000 --- a/docs/readme_it.md +++ /dev/null @@ -1,365 +0,0 @@ -

- GitHub Readme Stats -

GitHub Readme Stats

-

Mostra nei tuoi README file le statistiche GitHub generate dinamicamente!

-

-

- - Tests Passing - - - GitHub Contributors - - - Tests Coverage - - - Issues - - - GitHub pull requests - - - OpenSSF Scorecard - -
-
-

- -

- Anteprima - · - Segnala un errore - · - Richiedi una nuova funzionalità -

-

- Français - · - 简体中文 - · - Español - · - Deutsch - · - 日本語 - · - Português Brasileiro - · - Italiano - · - 한국어 - . - Nederlands - . - नेपाली - . - Türkçe -

-

-

Se ti piace questo progetto, considera la possibilità di donare per aiutare a renderlo migliore! - -# Caratteristiche - -- [GitHub Stats Card](#github-stats-card) - - [Nascondere statistiche individuali](#nascondere-statistiche-individuali) - - [Includere i contributi privati nel computo totale](#includere-i-contributi-privati-nel-computo-totale) - - [Mostrare le icone](#mostrare-le-icone) - - [Temi](#temi) - - [Personalizzazione](#personalizzazione) -- [GitHub Extra Pins](#github-extra-pins) - - [Utilizzo](#utilizzo) - - [Demo](#demo) -- [Top Languages Card](#top-languages-card) - - [Utilizzo](#utilizzo-1) - - [Nascondi linguaggi specifici](#nascondi-linguaggi-specifici) - - [Layout compatto](#layout-compatto) - - [Demo](#demo-1) - - [Galleria di esempi](#galleria-di-esempi) - - [Consiglio veloce (Allineare le Card)](#consiglio-veloce-allineare-le-card) - - [Deploy su Vercel](#deploy-su-vercel) - - [:sparkling\_heart: Supporta il progetto](#sparkling_heart-supporta-il-progetto) - - -# GitHub Stats Card - -Per creare una Card con le statistiche GitHub, copia e incolla nel tuo file markdown, tutto qua: è semplice! - -Ricorda di cambiare il valore `?username=` con il tuo nome utente GitHub. - -```md -[![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) -``` - -_Nota: I punteggi sono calcolati sulla base delle tue statistiche, dai un'occhiata a [src/calculateRank.js](../src/calculateRank.js) per ulteriori informazioni_ - -### Nascondere statistiche individuali - -Per nascondere qualche dato, puoi aggiungere i parametri `?hide=`, separando i valori con una virgola. - -> Opzioni: `&hide=stars,commits,prs,issues,contribs` - -```md -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&hide=contribs,prs) -``` - -### Includere i contributi privati nel computo totale - -Puoi aggiungere i tuoi contributi privati al totale dei commit, utilizzando il parametro `?count_private=true`. - -_Nota: se hai deciso di fare il deploy del progetto, i contributi privati verranno inclusi in automatico._ - -> Opzioni: `&count_private=true` - -```md -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&count_private=true) -``` - -### Mostrare le icone - -Per abilitare le icone, puoi specificare `show_icons=true`, ad esempio: - -```md -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&show_icons=true) -``` - -### Temi - -Esistono alcuni temi predefiniti coi quali è possibile personalizzare l'aspetto delle card. In alternativa, è possibile effettuare una [personalizzazione manuale](#personalizzazione). - -Usa il parametro `?theme=NOME_TEMA` in questo modo:- - -```md -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&show_icons=true&theme=radical) -``` - -#### Galleria dei temi:- - -dark, radical, merko, gruvbox, tokyonight, onedark, cobalt, synthwave, highcontrast, dracula - -GitHub Readme Stat Themes - -Puoi avere un'anteprima di [tutti i temi supportati](../themes/README.md) o controllare il [file di configurazione dei temi](../themes/index.js) e **puoi anche contribuire creando un nuovo tema** se vuoi :D - -### Personalizzazione - -Puoi personalizzare l'aspetto delle tue `Stats Card` o delle `Repo Card` in qualsiasi modo, semplicemente modificando i parametri dell'URL. - -#### Opzioni comuni: - -- `title_color` - Colore del titolo _(in esadecimale)_ -- `text_color` - Colore del testo _(in esadecimale)_ -- `icon_color` - Colore delle icone, se disponibili _(in esadecimale)_ -- `bg_color` - Colore dello sfondo _(in esadecimale)_ **oppure** un gradiente nella forma _angolo,inizio,fine_ -- `hide_border` - Nasconde il bordo della carta _(booleano)_ -- `theme` - Nome del tema, dai un'occhiata a [tutti i temi disponibili](../themes/README.md) -- `cache_seconds` - Specifica manualmente il valore di cache, in secondi _(min: 14400, max: 86400)_ -- `locale` - Impostare la lingua nella scheda _(per esempio. cn, de, es, eccetera.)_ - -##### Gradiente nello sfondo - -Puoi fornire valori separati da virgola nel parametro bg_color per creare un gradiente, il cui formato è:- - -``` -&bg_color=DEG,COLOR1,COLOR2,COLOR3...COLOR10 -``` - -> Nota sulla cache: le card hanno un valore di cache di 4 ore (14400 seconds) di default se il numero di fork & il numero di stelle è inferiore a 1000; altrimenti è pari a 2 ore (7200). - -#### Opzioni valide solo per le card delle statistiche: - -- `hide` - Nasconde gli oggetti selezionati _(valori separati da virgola)_ -- `hide_title` - Nasconde il titolo _(booleano)_ -- `hide_rank` - Nasconde il punteggio _(booleano)_ -- `show_icons` - Mostra le icone _(booleano)_ -- `include_all_commits` - Mostra tutti i commit e non solo quelli dell'anno corrente _(booleano)_ -- `count_private` - Include i contributi privati _(booleano)_ -- `line_height` - Specifica il valore dell'altezza di riga _(numero)_ - -#### Opzioni valide solo per le Repo Card: - -- `show_owner` - Mostra il nome utente del proprietario _(booleano)_ - -#### Opzioni valide solo per le card dei linguaggi: - -- `hide` - Nasconde un linguaggio specifico _(valori separati da virgola)_ -- `hide_title` - Nasconde il titolo _(booleano)_ -- `layout` - Specificare il tipo di layout, `normal` (esteso), `compact` (compatto), `donut` (ciambella), `donut-vertical` (ciambella verticale) e `pie` (torta) -- `card_width` - Specifica il valore della larghezza _(numero)_ - -> :warning: **Importante:** -> Per i nomi dei linguaggi, assicurati di effettuare l'encoding giusto nell'uri, come specificato in [Percent Encoding](https://en.wikipedia.org/wiki/Percent-encoding) -> (ad esempio: `c++` diventa `c%2B%2B`, `jupyter notebook` diventa `jupyter%20notebook`, ecc.) - ---- - -# GitHub Extra Pins - -GitHub Extra Pins ti permette di fissare in alto più di 6 repository nel tuo profilo, sfruttando il README del profilo. - -### Utilizzo - -Copia e incolla il seguente codice, premurandoti di cambiare il link. - -Endpoint: `api/pin?username=anuraghazra&repo=github-readme-stats` - -```md -[![Readme Card](https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra&repo=github-readme-stats)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Demo - -[![Readme Card](https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra&repo=github-readme-stats)](https://github.com/anuraghazra/github-readme-stats) - -Usa la variabile [show_owner](#personalizzazione) per includere il nome utente del proprietario - -[![Readme Card](https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra&repo=github-readme-stats&show_owner=true)](https://github.com/anuraghazra/github-readme-stats) - -# Top Languages Card - -La Top Languages Card mostra i linguaggi che utilizzi di più su GitHub. - -_NOTA: questa card non indica il livello di abilità, ma piuttosto quanto codice hai scritto in un determinato linguaggio_ - -### Utilizzo - -Copia e incolla nel tuo file README, cambiando i link. - -Endpoint: `api/top-langs?username=anuraghazra` - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Nascondi linguaggi specifici - -Puoi utilizzare il parametro `?hide=linguaggio1,linguaggio2` per nascondere alcuni linguaggi. - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&hide=javascript,html)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Layout compatto - -Puoi utilizzare l'opzione `&layout=compact` per cambiare l'aspetto della card. - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&layout=compact)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Demo - -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) - -- Layout Compatto - -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&layout=compact)](https://github.com/anuraghazra/github-readme-stats) - ---- - -### Galleria di esempi - -- Default - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra) - -- Nascondere dati specifici - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&hide=contribs,issues) - -- Mostrare le icone - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&hide=issues&show_icons=true) - -- Includere tutti i commit - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&include_all_commits=true) - -- Temi - -Scegli uno dei [temi di default](#themes) - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&show_icons=true&theme=radical) - -- Gradiente - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&bg_color=30,e96443,904e95&title_color=fff&text_color=fff) - -- Personalizzare le Stats Card - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api/?username=anuraghazra&show_icons=true&title_color=fff&icon_color=79ff97&text_color=9f9f9f&bg_color=151515) - -- Personalizzare le Repo Card - -![Customized Card](https://github-readme-stats.vercel.app/api/pin?username=anuraghazra&repo=github-readme-stats&title_color=fff&icon_color=f9f9f9&text_color=9f9f9f&bg_color=151515) - -- Linguaggi più usati - -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) - ---- - -### Consiglio veloce (Allineare le Card) - -Per allineare le card una accanto all'altra, puoi adottare questo approccio: - -```html - - - - - - -``` - -## Deploy su Vercel - -#### [Guarda questo Video Tutorial, realizzato da @codeSTACKr](https://youtu.be/n6d4KHSKqGk?t=107) - -Since the GitHub API only allows 5k requests per hour, it is possible that my `https://github-readme-stats.vercel.app/api` could hit the rate limiter. If you host it on your own Vercel server, then you don't have to worry about anything. Click on the deploy button to get started! - -NOTE: Since [#58](https://github.com/anuraghazra/github-readme-stats/pull/58) we should be able to handle more than 5k requests and have no issues with downtime :D - -[![Deploy to Vercel](https://vercel.com/button)](https://vercel.com/import/project?template=https://github.com/anuraghazra/github-readme-stats) - -

- Guide on setting up Vercel 🔨 - -1. Go to [vercel.com](https://vercel.com/) -1. Click on `Log in` - ![](https://files.catbox.moe/tct1wg.png) -1. Sign in with GitHub by pressing `Continue with GitHub` - ![](https://files.catbox.moe/btd78j.jpeg) -1. Sign into GitHub and allow access to all repositories, if prompted -1. Fork this repo -1. Go back to your [Vercel dashboard](https://vercel.com/dashboard) -1. Select `Import Project` - ![](https://files.catbox.moe/qckos0.png) -1. Select `Import Git Repository` - ![](https://files.catbox.moe/pqub9q.png) -1. Select root and keep everything as is, just add your environment variable named PAT_1 (as shown), which will contain a personal access token (PAT), which you can easily create [here](https://github.com/settings/tokens/new) (leave everything as is, just name it something, it can be anything you want) - ![](https://files.catbox.moe/0ez4g7.png) -1. Click deploy, and you're good to go. See your domains to use the API! - -
- -## :sparkling_heart: Supporta il progetto - -Rendo open-source quasi tutto ciò che posso e provo a rispondere a chiunque sia in difficoltà nell'utilizzare questi progetti. Ovviamente, mi richiede del tempo. -Puoi utilizzare questo servizio gratuitamente. - -Tuttavia, se usi il progetto e ti piace e vuoi sostenermi, puoi:- - -- Dare il giusto riconoscimento quando usi github-readme-stats nei tuoi readme, includendo un link :D -- Mettere una stella e condividere il progetto :rocket: -- [![paypal.me/anuraghazra](https://ionicabizau.github.io/badges/paypal.svg)](https://www.paypal.me/anuraghazra) - Fare una donazione via PayPal. Probabilmente compreròun ~~caffè~~ tè. :tea: - -Grazie! :heart: - ---- - -[![https://vercel.com?utm_source=github_readme_stats_team&utm_campaign=oss](../powered-by-vercel.svg)](https://vercel.com?utm_source=github_readme_stats_team&utm_campaign=oss) - -I contributi sono benvenuti! <3 - -Realizzato col :heart: e in JavaScript. diff --git a/docs/readme_ja.md b/docs/readme_ja.md deleted file mode 100644 index d338785f909d8..0000000000000 --- a/docs/readme_ja.md +++ /dev/null @@ -1,372 +0,0 @@ -

- GitHub Readme Stats -

GitHub Readme Stats

-

あなたの README に自動生成された GitHub の統計情報を載せましょう!

-

-

- - Tests Passing - - - GitHub Contributors - - - Tests Coverage - - - Issues - - - GitHub pull requests - - - OpenSSF Scorecard - -
-
-

- -

- View Demo - · - Report Bug - · - Request Feature -

-

- Français - · - 简体中文 - · - Español - · - Deutsch - · - 日本語 - · - Português Brasileiro - · - Italiano - · - 한국어 - . - Nederlands - . - नेपाली - . - Türkçe -

-

-

このプロジェクトを気に入っていただけましたか?
もしよろしければ、プロジェクトのさらなる改善のために寄付を検討して頂けると嬉しいです!

- -# 主な機能 - -- [GitHub Stats Card](#github-stats-card) - - [特定の統計情報を隠す](#特定の統計情報を隠す) - - [プライベートリポジトリへのコミットをカウントする](#プライベートリポジトリへのコミットをカウントする) - - [アイコンを表示する](#アイコンを表示する) - - [テーマの変更](#テーマの変更) - - [テーマを自分でカスタマイズする](#テーマを自分でカスタマイズする) -- [GitHub Extra Pins](#github-extra-pins) - - [使い方](#使い方) - - [デモ](#デモ) -- [Top Languages Card](#top-languages-card) - - [使い方](#使い方-1) - - [特定の言語を隠す](#特定の言語を隠す) - - [レイアウトをコンパクトにする](#レイアウトをコンパクトにする) - - [デモ](#デモ-1) - - [全てのデモ](#全てのデモ) - - [クイックヒント (カードを並べる)](#クイックヒント-カードを並べる) - - [自分の Vercel インスタンスにデプロイする](#自分の-vercel-インスタンスにデプロイする) - - [:sparkling\_heart: このプロジェクトを支援する](#sparkling_heart-このプロジェクトを支援する) - -# GitHub Stats Card - -以下のコードをコピーして、あなたの Markdown ファイルに貼り付けるだけです。 -簡単ですね! - -`?username=` の値は、あなたの GitHub アカウントのユーザー名に変更してください。 - -```md -[![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) -``` - -_Note: カードに表示されるランクはユーザの統計情報に基づいて計算されています。詳しくは、[src/calculateRank.js](../src/calculateRank.js)をご覧ください。_ - -### 特定の統計情報を隠す - -クエリパラメータ `?hide=` に値をカンマ区切りで渡すことで、特定の統計情報を隠すことができます。 - -> Options: `&hide=stars,commits,prs,issues,contribs` - -```md -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&hide=contribs,prs) -``` - -### プライベートリポジトリへのコミットをカウントする - -クエリパラメータ `?count_private=true` を使用することで、プライベートリポジトリへのコミット数を総数に追加することができます。 - -_Note: このプロジェクトを自分でデプロイしている場合、デフォルトではプライベートリポジトリへのコミットがカウントされます。_ - -> Options: `&count_private=true` - -```md -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&count_private=true) -``` - -### アイコンを表示する - -クエリパラメータ `?show_icons=true` を使用することで、アイコンの表示が有効になります。 - -```md -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&show_icons=true) -``` - -### テーマの変更 - -内蔵されているテーマを使用すれば、[手動のカスタマイズ](#customization)を行うことなくカードの外観を変更することができます。 - -`?theme=THEME_NAME` は以下のように使います。 - -```md -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&show_icons=true&theme=radical) -``` - -#### 内蔵テーマの一覧 - -dark, radical, merko, gruvbox, tokyonight, onedark, cobalt, synthwave, highcontrast, dracula - -GitHub Readme Stat Themes - -その他の使用可能なテーマの[プレビュー](../themes/README.md)や[設定ファイル](../themes/index.js)もご覧ください。もしよろしければ、**新しいテーマを投稿してみてください** :smile: - -### テーマを自分でカスタマイズする - -`Stats Card` や `Repo Card` の外観を URL パラメータを使って好きなようにカスタマイズすることができます。 - -#### 共通のオプション - -- `title_color` - タイトルの色 _(16 進数カラーコード)_ -- `text_color` - 中身のテキストの色 _(16 進数カラーコード)_ -- `icon_color` - アイコンの色(変更可能な場合のみ) _(16 進数カラーコード)_ -- `bg_color` - 背景の色 _(16 進数カラーコード)_ **または** _angle,start,end_ の形式でグラデーションを指定することも可 -- `hide_border` - カードの境界線を非表示にします _(ブール値)_ -- `theme` - [使用可能なテーマ一覧](../themes/README.md) から選んだテーマ名 -- `cache_seconds` - キャッシュ時間の秒数 _(最小値: 14400, 最大値: 86400)_ -- `locale` - カードに言語を設定する _(例えば cn, de, es, 等)_ - -##### bg_color の グラデーション指定 - -bg_color オプションで複数のカンマ区切りの値を指定してグラデーションをレンダリングすることができます。フォーマットは以下の通りになります。 - -``` -&bg_color=DEG,COLOR1,COLOR2,COLOR3...COLOR10 -``` - -> キャッシュに関する注意点: Repo cards のデフォルトのキャッシュは、フォーク数とスター数が 1k 未満の場合は 30 分(1800 秒) で、それ以外の場合は 2 時間(7200) です。また、キャッシュは最低でも 30 分、最大でも 24 時間に制限されていることに注意してください。 - -#### Stats Card だけに存在するオプション - -- `hide` - 特定の統計情報を隠す _(カンマ区切りで指定)_ -- `hide_title` - _(boolean)_ -- `hide_rank` - _(boolean)_ -- `show_icons` - _(boolean)_ -- `include_all_commits` - 今年度のコミット数だけでなく、コミット数の総数をカウントする _(boolean)_ -- `count_private` - プライベートリポジトリへのコミットをカウントする _(boolean)_ -- `line_height` - テキストの行の高さ _(number)_ -- `custom_title` - タイトル文字列を変更する -- `disable_animations` - カードのアニメーションを無効にする _(boolean)_ - -#### Repo Card だけに存在するオプション - -- `show_owner` - リポジトリのオーナーを表示する _(boolean)_ - -#### Language Card だけに存在するオプション - -- `hide` - 特定の言語を隠す _(カンマ区切りで指定)_ -- `hide_title` - _(boolean)_ -- `layout` - `normal` & `compact` & `donut` & `donut-vertical` & `pie` のいずれかのレイアウトに切り替える -- `card_width` - カードの横幅 _(number)_ -- `langs_count` - 表示される言語の数 _(1 ~ 10, 初期値 5)_ -- `exclude_repo` - 指定されたリポジトリを除外する _(カンマ区切りで指定)_ -- `custom_title` - タイトル文字列を変更する - -> :warning: **重要:** -> [Percent Encoding](https://en.wikipedia.org/wiki/Percent-encoding) で指定されているように、プログラミング言語の名前は URL エンコードされている必要があります。 -> (例: `c++` は `c%2B%2B`, `jupyter notebook` は `jupyter%20notebook`, など) - ---- - -# GitHub Extra Pins - -GitHub extra pins を使うと、GitHub の readme プロフィールを使って、自分のプロフィールに 6 つ以上のリポジトリをピン留めすることができます。 - -やったー! もはや、リポジトリをピン留めできる数が 6 つに制限されることはありません。 - -### 使い方 - -以下のコードをあなたの readme にコピー & ペーストし、リンクを変更してください。 - -エンドポイント: `api/pin?username=anuraghazra&repo=github-readme-stats` - -```md -[![Readme Card](https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra&repo=github-readme-stats)](https://github.com/anuraghazra/github-readme-stats) -``` - -### デモ - -[![Readme Card](https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra&repo=github-readme-stats)](https://github.com/anuraghazra/github-readme-stats) - -リポジトリのオーナーのユーザー名を含める場合は、show_owner 変数を使用します。 - -[![Readme Card](https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra&repo=github-readme-stats&show_owner=true)](https://github.com/anuraghazra/github-readme-stats) - -# Top Languages Card - -Top languages card には、その GitHub ユーザーが最も利用している Top languages が表示されます。 - -_NOTE: Top languages は、ユーザのスキルレベルを示すものではなく、GitHub 上でどの言語で最も多くのコードを書いているかを示す GitHub の指標です。_ - -### 使い方 - -以下のコードをあなたの readme にコピー & ペーストし、リンクを変更してください。 - -エンドポイント: `api/top-langs?username=anuraghazra` - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) -``` - -### 特定の言語を隠す - -クエリパラメータ `?hide=language1,language2` 使用することで、特定の言語を非表示にすることができます。 - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&hide=javascript,html)](https://github.com/anuraghazra/github-readme-stats) -``` - -### レイアウトをコンパクトにする - -クエリパラメータ `&layout=compact` を使用することで、カードのデザインを変更することができます。 - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&layout=compact)](https://github.com/anuraghazra/github-readme-stats) -``` - -### デモ - -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) - -- Compact layout の場合 - -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&layout=compact)](https://github.com/anuraghazra/github-readme-stats) - ---- - -### 全てのデモ - -- デフォルト - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra) - -- 特定の統計情報を隠す - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&hide=contribs,issues) - -- アイコンを表示する - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&hide=issues&show_icons=true) - -- コミット数の総数をカウントする - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&include_all_commits=true) - -- テーマの変更 - -任意の[テーマ](#themes)を選択できます。 - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&show_icons=true&theme=radical) - -- グラデーション - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&bg_color=30,e96443,904e95&title_color=fff&text_color=fff) - -- stats card のカスタマイズ - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api/?username=anuraghazra&show_icons=true&title_color=fff&icon_color=79ff97&text_color=9f9f9f&bg_color=151515) - -- repo card のカスタマイズ - -![Customized Card](https://github-readme-stats.vercel.app/api/pin?username=anuraghazra&repo=github-readme-stats&title_color=fff&icon_color=f9f9f9&text_color=9f9f9f&bg_color=151515) - -- Top languages - -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) - ---- - -### クイックヒント (カードを並べる) - -通常、画像を並べてレイアウトすることはできません。画像を並べるには、以下のような方法があります。 - -```html - - - - - - -``` - -## 自分の Vercel インスタンスにデプロイする - -#### [@codeSTACKr によるチュートリアルはこちら](https://youtu.be/n6d4KHSKqGk?t=107) - -GitHub API は 1 時間あたり 5k リクエストしか受け付けていないので、私の `https://github-readme-stats.vercel.app/api` がレートリミッターを超えてしまう可能性があります。自分の Vercel サーバーでホストしているのであれば、何も心配する必要はありません。デプロイボタンをクリックして始めましょう! - -NOTE: [#58](https://github.com/anuraghazra/github-readme-stats/pull/58) 以降は 5k 以上のリクエストに対応できるようになり、ダウンタイムの問題もなくなりました :smile: - -[![Deploy to Vercel](https://vercel.com/button)](https://vercel.com/import/project?template=https://github.com/anuraghazra/github-readme-stats) - -
- Vercelの設定ガイド - -1. [vercel.com](https://vercel.com/)に行きます。 -1. `Log in`をクリックします。 - ![](https://files.catbox.moe/tct1wg.png) -1. `Continue with GitHub` を押して GitHub にサインインします。 - ![](https://files.catbox.moe/btd78j.jpeg) -1. GitHub にサインインし、すべてのリポジトリへのアクセスを許可します。 -1. このリポジトリをフォークします。 -1. [Vercel dashboard](https://vercel.com/dashboard)に戻ります。 -1. `Import Project` を選択します。 - ![](https://files.catbox.moe/qckos0.png) -1. `Import Git Repository` を選択します。 - ![](https://files.catbox.moe/pqub9q.png) -1. root を選択して、すべてをそのままにしておき、PAT_1 という名前の環境変数を(下図のように)追加します。これには個人アクセストークン (PAT) が含まれており、[ここ](https://github.com/settings/tokens/new)で簡単に作成することができます (すべてをそのままにしておいて、何かに名前を付けてください。) - ![](https://files.catbox.moe/0ez4g7.png) -1. デプロイをクリックすれば完了です。API を使用するためにあなたのドメインを参照してください! - -
- -## :sparkling_heart: このプロジェクトを支援する - -私はできる限りのことをオープンソースで行い、また、このプロジェクトを利用する上で困っている皆さん全員に返信するようにしています。もちろん返信には時間が掛かる場合がありますが。 -このプロジェクトは無料でご利用いただけます。 - -しかしながら、もしあなたがこのプロジェクトに満足しているのであれば、あるいはただ、私がソフトウェアを作り続けるよう励ましたいのであれば、いくつかの方法があります。 - -- あなたの readme で github-readme-stats を使用して適切なクレジットを付与し、それにリンクします :smile: -- このプロジェクトにスターを贈り、他の人達にもシェアしてください :rocket: -- [![paypal.me/anuraghazra](https://ionicabizau.github.io/badges/paypal.svg)](https://www.paypal.me/anuraghazra) - PayPal を介して 1 回限りの寄付を行うことができます。私はおそらく ~~コーヒー~~ お茶を買うでしょう。 :tea: - -Thanks! :heart: - ---- - -[![https://vercel.com?utm_source=github_readme_stats_team&utm_campaign=oss](../powered-by-vercel.svg)](https://vercel.com?utm_source=github_readme_stats_team&utm_campaign=oss) - -コントリビュートは大歓迎です! :heart_eyes: - -このプロジェクトは :heart: と JavaScript で作られています。 diff --git a/docs/readme_kr.md b/docs/readme_kr.md deleted file mode 100644 index 178d0342506f2..0000000000000 --- a/docs/readme_kr.md +++ /dev/null @@ -1,456 +0,0 @@ -

- GitHub Readme Stats -

GitHub Readme Stats

-

동적으로 생성되는 GitHub 사용량 통계를 여러분의 README 에 추가해보세요!

-

-

- - Tests Passing - - - GitHub Contributors - - - Tests Coverage - - - Issues - - - GitHub pull requests - - - OpenSSF Scorecard - -
-
-

- -

- 미리보기 확인 - · - 버그 제보하기 - · - 기능 추가 요청하기 -

-

- Français - · - 简体中文 - · - Español - · - Deutsch - · - 日本語 - · - Português Brasileiro - · - Italiano - · - 한국어 - . - Nederlands - . - नेपाली - . - Türkçe -

-

-

기능들이 마음에 드시나요? 괜찮으시다면, 서비스 개선을 위해 기부를 고려해주세요! - -# 기능들 - -- [GitHub 통계](#github-통계) - - [개별 통계 숨기기](#개별-통계-숨기기) - - [총 커밋 수에 비공개 기여도 (private contribs) 수 추가하기](#총-커밋-수에-비공개-기여도-private-contribs-수-추가하기) - - [아이콘 표시하기](#아이콘-표시하기) - - [테마 설정하기](#테마-설정하기) - - [커스터마이징](#커스터마이징) -- [GitHub 저장소 핀](#github-저장소-핀) - - [사용법](#사용법) - - [미리보기](#미리보기) -- [언어 사용량 통계](#언어-사용량-통계) - - [사용법](#사용법-1) - - [통계에서 제외할 저장소 지정하기](#통계에서-제외할-저장소-지정하기) - - [통계에서 특정 언어 제외하기](#통계에서-특정-언어-제외하기) - - [표시할 언어 수 지정하기](#표시할-언어-수-지정하기) - - [컴택트한 카드 레이아웃 설정하기](#컴택트한-카드-레이아웃-설정하기) - - [미리보기](#미리보기-1) -- [WakaTime 주간 통계](#wakatime-주간-통계) - - [미리보기](#미리보기-2) - - [전체 미리보기](#전체-미리보기) - - [꿀팁 (저장소 핀 정렬하기)](#꿀팁-저장소-핀-정렬하기) - - [나만의 Vercel 인스턴스에 직접 배포하기](#나만의-vercel-인스턴스에-직접-배포하기) - - [:sparkling\_heart: 프로젝트 지원하기!](#sparkling_heart-프로젝트-지원하기) - - -# GitHub 통계 - -아래 코드를 복사해서 마크다운 파일에 붙여넣으면 끝이에요, 아주 간단해요! - -`?username=` 속성의 값을 GitHub 계정의 사용자 명(닉네임)으로 바꿔주세요. - -```md -[![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) -``` - -_참고:_ - -_랭크는 S+ (상위 1%), S (상위 25%), A++ (상위 45%), A+ (상위 60%), 그리고 B+ (전체) 로 구성되어 있습니다._ - -_커밋의 수(commits), 기여도(contribution), 이슈의 수(issues), 즐겨찾기(star), 작업내용 반영 요청(Pull Request), -팔로워 수, 그리고 보유 중인 저장소 등의 항목들에 대해 [누적 분포 함수](https://ko.wikipedia.org/wiki/%EB%88%84%EC%A0%81_%EB%B6%84%ED%8F%AC_%ED%95%A8%EC%88%98) 를 이용해 계산됩니다._ - -_[src/calculateRank.js](../src/calculateRank.js) 에서 수행되는 계산 작업의 내용을 확인할 수 있습니다._ - -### 개별 통계 숨기기 - -특정 통계를 숨기려면 `콤마(,)`로 구분된 값들을 `?hide=` 속성의 값으로 넣어주세요. - -> 사용 가능한 항목들: `&hide=stars,commits,prs,issues,contribs` - -```md -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&hide=contribs,prs) -``` - -### 총 커밋 수에 비공개 기여도 (private contribs) 수 추가하기 - -`?count_private=true` 속성을 추가하시면, 여러분의 모든 비공개 기여도까지 반영됩니다. - -_참고: 프로젝트를 직접 배포하신 경우, 비공개 기여도는 기본적으로 반영됩니다. 원하지 않는 경우엔 직접 설정해야 합니다._ - -> 예시: `&count_private=true` - -```md -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&count_private=true) -``` - -### 아이콘 표시하기 - -아이콘 항목을 활성화 하기 위해선, 다음과 같이 `show_icons=true` 속성을 추가해주세요. - -```md -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&show_icons=true) -``` - -### 테마 설정하기 - -내장 테마를 사용하시면, 별도의 [커스터마이징](#커스터마이징) 없이 GitHub 통계 카드를 꾸미실 수 있어요. - -다음과 같이 `?theme=THEME_NAME` 속성을 이용해주세요. - -```md -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&show_icons=true&theme=radical) -``` - -#### 지원하는 내장 테마 목록 - -dark, radical, merko, gruvbox, tokyonight, onedark, cobalt, synthwave, highcontrast, dracula - -GitHub Readme Stat Themes - -[사용 가능한 모든 테마](../themes/README.md) 에서 미리보기를 확인하실 수 있어요. - -원하신다면 [테마 설정하기](../themes/index.js) 항목에서 **새로운 테마를 직접 만드실수 있어요.** :D - -### 커스터마이징 - -여러가지 추가 속성을 통해, 원하는대로 `Stats Card` 또는 `Repo Card` 모양을 커스터마이징할 수 있어요. - -#### 기본 옵션: - -- `title_color` - 카드 타이틀 색상 _(hex color)_ -- `text_color` - 카드 본문 글씨 색상 _(hex color)_ -- `icon_color` - 아이콘 색상 (활성화된 경우) _(hex color)_ -- `bg_color` - 카드의 배경 색상 _(hex color)_ **혹은** 다음 양식으로 그라데이션 주기 _angle,start,end_ -- `hide_border` - 카드의 테두리 표시 여부 _(boolean)_ -- `theme` - 테마의 이름, [사용 가능한 모든 테마](../themes/README.md) 에서 선택 -- `cache_seconds` - 수동으로 캐시 헤더 설정 _(min: 14400, max: 86400)_ -- `locale` - 카드에 표시할 언어 _(e.g. kr, cn, de, es, etc.)_ - -##### 배경에 그라데이션 주기 - -그라데이션이 적용된 카드를 표시하고 싶으시다면, 여러가지 쉼표(,) 로 구분된 값을 추가할 수 있어요. - -양식은 다음과 같습니다. - -``` -&bg_color=DEG,COLOR1,COLOR2,COLOR3...COLOR10 -``` - -> 캐시에 대한 참고사항: -> 포크와 스타 수가 1,000 개 미만인 저장소의 카드는 기본적으로 4시간 (14,400초) 으로 설정되어 있습니다. -> 그 외에는, it's 2시간 (7,200초) 입니다. 또한, 캐시설정 시간의 범위는 최소 2시간, 최대 24시간입니다. - - -#### 통계 카드의 표시 제한 옵션: - -- `hide` - 통계에서 특정한 값 제외 _(Comma-separated values)_ -- `hide_title` - 타이틀 표시 여부 _(boolean)_ -- `hide_rank` - 랭크 표시 여부 _(boolean)_ -- `show_icons` - 아이콘 표시 여부 _(boolean)_ -- `include_all_commits` - 올해가 아닌 전체 연도에 대한 커밋 포함 여부 _(boolean)_ -- `count_private` - 비공개 기여도 포함 여부 _(boolean)_ -- `line_height` - 텍스트 간 줄 높이 설정(자간) _(number)_ -- `custom_title` - 카드의 타이틀 값 설정 -- `disable_animations` - 카드의 모든 에니메이션 활성 여부 _(boolean)_ - -#### 저장소 카드의 표시 제한 옵션: - -- `show_owner` - 저장소 소유자 닉네임 표기 여부 _(boolean)_ - -#### 언어 사용량 통계 카드의 표시 제한 옵션: - -- `hide` - 카드에서 특정 언어 제외 _(Comma-separated values)_ -- `hide_title` - 타이틀 제외 _(boolean)_ -- `layout` - 5가지 값 사용 가능, `normal` & `compact` & `donut` & `donut-vertical` & `pie` 중 표시 형태 선택 -- `card_width` - 카드 너비 직접 설정 _(number)_ -- `langs_count` - 카드에 표시할 언어의 수 (1-10 사이, 기본 값 : 5) _(number)_ -- `exclude_repo` - 통계에 제외할 저장소 지정 _(Comma-separated values)_ -- `custom_title` - 카드의 타이틀 값 설정 - -##### 경고! **매우 중요** -> -> 언어의 이름은 [퍼센트 인코딩](https://ko.wikipedia.org/wiki/%ED%8D%BC%EC%84%BC%ED%8A%B8_%EC%9D%B8%EC%BD%94%EB%94%A9) 에 지정된 URI 방식으로 표기되어야 합니다. -> ( 예를 들면, `c++` 는 `c%2B%2B`, `jupyter notebook` 는 `jupyter%20notebook`, 등등. ) -> [urlencoder.org](https://www.urlencoder.org/) < 서비스를 이용하면 자동으로 생성할 수 있습니다. - -#### WakaTime 카드의 표시 제한 옵션: - -- `hide_title` - 타이틀 제외 _(boolean)_ -- `line_height` - 텍스트 간 줄 높이 설정(자간) _(number)_ -- `hide_progress` - 퍼센트와 표기바 표시 여부 _(boolean)_ -- `custom_title` - 카드의 타이틀 값 설정 -- `layout` - 사용 가능한 두 가지 값, `default` & `compact` 중 표시 형태 선택 - ---- - -# GitHub 저장소 핀 - -GitHub 저장소 여분 핀을 이용하면, 6개 이상의 저장소 핀을 여러분의 프로필에 추가할 수 있어요. - -맞아요! 이제 6개 이상의 핀을 사용할 수 있어요! (핀이 부족할 일이 없답니다!) - -### 사용법 - -이 코드를 복사해서 여러분의 README 에 넣고 링크를 변경해주세요. - -엔드 포인트: `api/pin?username=anuraghazra&repo=github-readme-stats` - -```md -[![Readme Card](https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra&repo=github-readme-stats)](https://github.com/anuraghazra/github-readme-stats) -``` - -### 미리보기 - -[![GitHub 저장소 핀 카드](https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra&repo=github-readme-stats)](https://github.com/anuraghazra/github-readme-stats) - -[show_owner](#커스터마이징) 속성을 통해 저장소 소유자의 닉네임 표시 여부를 설정할 수 있어요. - -[![GitHub 저장소 핀 카드](https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra&repo=github-readme-stats&show_owner=true)](https://github.com/anuraghazra/github-readme-stats) - -# 언어 사용량 통계 - -언어 사용량 통계 카드는 GitHub 사용자가 가장 많이 사용한 언어가 표시됩니다. - -_참고: -언어 사용량 통계는 GitHub 에서 가장 많이 사용된 언어의 표기일 뿐입니다. -숙련도, 혹은 그와 비슷한 지표를 나타내진 않습니다. (새로 추가된 기능입니다!)_ - -### 사용법 - -이 코드를 복사해서 여러분의 README 에 넣고 링크를 변경해주세요. - -엔드 포인트: `api/top-langs?username=anuraghazra` - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) -``` - -### 통계에서 제외할 저장소 지정하기 - -`?exclude_repo=repo1,repo2` 속성을 통해 특정 저장소를 제외할 수 있어요. - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&exclude_repo=github-readme-stats,anuraghazra.github.io)](https://github.com/anuraghazra/github-readme-stats) -``` - -### 통계에서 특정 언어 제외하기 - -`?hide=language1,language2` 속성을 통해 특정 언어를 제외할 수 있어요. - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&hide=javascript,html)](https://github.com/anuraghazra/github-readme-stats) -``` - -### 표시할 언어 수 지정하기 - -`&langs_count=` 속성을 통해 카드에 표시할 언어의 수를 지정할 수 있어요. (1-10 사이, 기본 값 : 5) - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&langs_count=8)](https://github.com/anuraghazra/github-readme-stats) -``` - -### 컴택트한 카드 레이아웃 설정하기 - -`&layout=compact` 속성을 통해 카드의 디자인을 변경할 수 있어요. - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&layout=compact)](https://github.com/anuraghazra/github-readme-stats) -``` - -### 미리보기 - -[![언어 사용량 통계](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) - -- 컴팩트한 레이아웃 - -[![언어 사용량 통계](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&layout=compact)](https://github.com/anuraghazra/github-readme-stats) - -# WakaTime 주간 통계 - -`?username=` 속성의 값을 [WakaTime](https://wakatime.com) 계정의 사용자 명(닉네임)으로 바꿔주세요. - -```md -[![Harlok's WakaTime stats](https://github-readme-stats.vercel.app/api/wakatime?username=ffflabs)](https://github.com/anuraghazra/github-readme-stats) -``` - -### 미리보기 - -[![Harlok 님의 wakatime 통계](https://github-readme-stats.vercel.app/api/wakatime?username=ffflabs)](https://github.com/anuraghazra/github-readme-stats) - -[![Harlok 님의 wakatime 통계](https://github-readme-stats.vercel.app/api/wakatime?username=ffflabs&hide_progress=true)](https://github.com/anuraghazra/github-readme-stats) - -- 컴팩트한 레이아웃 - -[![Harlok 님의 wakatime 통계](https://github-readme-stats.vercel.app/api/wakatime?username=ffflabs&layout=compact)](https://github.com/anuraghazra/github-readme-stats) - ---- - -### 전체 미리보기 - -- 기본 - -![Anurag 님의 GitHub 사용량 통계](https://github-readme-stats.vercel.app/api?username=anuraghazra) - -- 특정 통계 내용 숨김 - -![Anurag 님의 GitHub 사용량 통계](https://github-readme-stats.vercel.app/api?username=anuraghazra&hide=contribs,issues) - -- 아이콘 표시 - -![Anurag 님의 GitHub 사용량 통계](https://github-readme-stats.vercel.app/api?username=anuraghazra&hide=issues&show_icons=true) - -- 전체 커밋 포함 시 - -![Anurag 님의 GitHub 사용량 통계](https://github-readme-stats.vercel.app/api?username=anuraghazra&include_all_commits=true) - -- 테마들 - -[내장 테마](#themes) 에서 직접 선택해보세요 - -![Anurag 님의 GitHub 사용량 통계](https://github-readme-stats.vercel.app/api?username=anuraghazra&show_icons=true&theme=radical) - -- 그라데이션 주기 - -![Anurag 님의 GitHub 사용량 통계](https://github-readme-stats.vercel.app/api?username=anuraghazra&bg_color=30,e96443,904e95&title_color=fff&text_color=fff) - -- 통계 카드 커스터마이징하기 - -![Anurag 님의 GitHub 사용량 통계](https://github-readme-stats.vercel.app/api/?username=anuraghazra&show_icons=true&title_color=fff&icon_color=79ff97&text_color=9f9f9f&bg_color=151515) - -- 언어 사용 지역 설정하기 - -![Anurag 님의 GitHub 사용량 통계](https://github-readme-stats.vercel.app/api/?username=anuraghazra&locale=kr) - -- 저장소 핀 커스터마이징하기 - -![Anurag 님의 GitHub 저장소 핀](https://github-readme-stats.vercel.app/api/pin?username=anuraghazra&repo=github-readme-stats&title_color=fff&icon_color=f9f9f9&text_color=9f9f9f&bg_color=151515) - -- 언어 사용량 통계 - -[![언어 사용량 통계](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) - -- WakaTime 카드 - -[![Harlok 님의 WakaTime 카드](https://github-readme-stats.vercel.app/api/wakatime?username=ffflabs)](https://github.com/anuraghazra/github-readme-stats) - ---- - -### 꿀팁 (저장소 핀 정렬하기) - -아마, 이미지들을 나란히 정렬할 수 없을거에요. - -그럴땐, 이렇게 해보세요! - -```html - - - - - - -``` - -## 나만의 Vercel 인스턴스에 직접 배포하기 - -#### [@codeSTACKr 님의 튜토리얼 영상 보기](https://youtu.be/n6d4KHSKqGk?t=107) - -GitHub API 가 시간 당 요청 개수를 5,000회로 제한한 뒤로, -저의 `https://github-readme-stats.vercel.app/api` 가 사용량 제한에 걸릴 위험이 생겼어요. - -만약, 여러분이 Vercel server 에서 직접 호스트 하신다면, 걱정하실 일은 없을거에요. - -아래의 버튼을 이용해 직접 배포해보세요! - -참고: [#58](https://github.com/anuraghazra/github-readme-stats/pull/58) 풀 리퀘스트 이후로, 저희는 5,000 개 이상의 요청을 처리할 수 있게 됐어요. 더이상 서버 다운에 대한 걱정은 노놉! :D - -[![Vercel 에 배포하기](https://vercel.com/button)](https://vercel.com/import/project?template=https://github.com/anuraghazra/github-readme-stats) - -

- 🔨 Vercel 세팅 가이드! - -1. [vercel.com](https://vercel.com/) 으로 이동하기 -1. `Log in` 버튼 클릭! - ![](https://files.catbox.moe/tct1wg.png) -1. `Continue with GitHub` 버튼을 이용해 GitHub 계정으로 가입하기 - ![](https://files.catbox.moe/btd78j.jpeg) -1. GitHub 에 로그인한 뒤, (권한을 요청한다면) 모든 저장소에 대한 권한을 허용해주세요! -1. 이 저장소를 Fork! -1. [Vercel 대시보드](https://vercel.com/dashboard) 로 돌아가세요! -1. `Import Project` 항목 선택! - ![](https://files.catbox.moe/qckos0.png) -1. `Import Git Repository` 항목 선택! - ![](https://files.catbox.moe/pqub9q.png) -1. 'root' 를 선택하고 넘어간 후, 아래와 같이 개인용 엑세스 토큰 (PAT) 을 저장할 환경변수를 PAT_1 의 값으로 추가해주세요. [이 곳](https://github.com/settings/tokens/new)에서 쉽게 생성할 수 있어요. (모든 항목을 그대로 두고, 이 부분만 원하는 이름으로 변경해주세요.) - ![](https://files.catbox.moe/0ez4g7.png) -1. 마지막으로 'Deploy' 버튼을 클릭하면, 끝! => API 를 사용하기 위한 도메인 주소를 확인하세요! - -
- -## :sparkling_heart: 프로젝트 지원하기! - -저는 가능한 모든 요소들을 오픈소스로 공개하고, -이 서비스를 이용하는데 도움이 필요한 모두에게 도움을 드리려 노력하고 있어요. - -솔직히 말하자면, 시간이 좀 걸린답니다... -물론, 여러분이 이 서비스를 사용하는건 무료에요 ㅎ - -하지만, 만약 여러분이 이 서비스를 잘 이용하시고, -만족하시거나, 제가 이런 요소들을 만드는 데에 도움을 주고 싶으시다면, -여러분께서 도와주실 수 있는 것들이 있어요! - -- github-readme-stats 를 README 에 표시하실 때 확실한 도움을 주세요! 이 저장소로 링크를 걸어주시면 돼요! :D -- 이 프로젝트를 많이 공유해주시고, 즐겨찾기 해주세요! :rocket: -- [![paypal.me/anuraghazra](https://ionicabizau.github.io/badges/paypal.svg)](https://www.paypal.me/anuraghazra) - PayPal 을 이용해 1회성 도네이션을 해주실 수 있어요. 아마도 전 ~~커피, 아... 아니~~ 차를 사서 마시겠죠? ㅎ; :tea: - -감사합니다! :heart: - ---- - -[![https://vercel.com?utm_source=github_readme_stats_team&utm_campaign=oss](../powered-by-vercel.svg)](https://vercel.com?utm_source=github_readme_stats_team&utm_campaign=oss) - -프로젝트에 대한 기여는 언제나 환영이에요! <3 - -Made with :heart: and JavaScript. diff --git a/docs/readme_nl.md b/docs/readme_nl.md deleted file mode 100644 index 7fbec69971517..0000000000000 --- a/docs/readme_nl.md +++ /dev/null @@ -1,424 +0,0 @@ -

- GitHub Readme Stats -

GitHub Readme Stats

-

Krijg dynamisch gegenereerde GitHub statistieken op je readme's!

-

-

- - Tests Passing - - - GitHub Contributors - - - Tests Coverage - - - Issues - - - GitHub pull requests - - - OpenSSF Scorecard - -
-
-

- -

- Bekijk Demo - · - Rapporteer een Bug - · - Vraag een nieuwe toepassing aan -

-

- Français - · - 简体中文 - · - Español - · - Deutsch - · - 日本語 - · - Português Brasileiro - · - Italiano - · - 한국어 - . - Nederlands - . - नेपाली - . - Türkçe -

-

-

Bevalt het project? Doneer om het te verbeteren! - -# Functionaliteiten - -- [GitHub Statistieken Kaart](#github-statistieken-kaart) - - [Verberg individueele statistieken](#verberg-individueele-statistieken) - - [Voeg privé contributies toe aan totale commits.](#voeg-privé-contributies-toe-aan-totale-commits) - - [Laat icoontjes zien](#laat-icoontjes-zien) - - [Thema's](#themas) - - [Opmaak](#opmaak) -- [GitHub Extra Pins](#github-extra-pins) - - [Gebruik](#gebruik) - - [Demo](#demo) -- [Top Programmeertalen Kaart](#top-programmeertalen-kaart) - - [Gebruik](#gebruik-1) - - [Verberg individueele repositories](#verberg-individueele-repositories) - - [Verberg individueele talen](#verberg-individueele-talen) - - [Laat meer programmeertalen zien](#laat-meer-programmeertalen-zien) - - [Compacte Talen Kaart opmaak](#compacte-talen-kaart-opmaak) - - [Demo](#demo-1) -- [Wekelijkse WakaTime Statistieken](#wekelijkse-wakatime-statistieken) - - [Demo](#demo-2) - - [Alle demos](#alle-demos) - - [Kleine tip (Verstel de repo kaart z'n positie)](#kleine-tip-verstel-de-repo-kaart-zn-positie) - - [Deploy je eigen Vercel instatie](#deploy-je-eigen-vercel-instatie) - - [:sparkling\_heart: Ondersteun het project](#sparkling_heart-ondersteun-het-project) - -# GitHub Statistieken Kaart - -Kopieer en plak dit in je markdown content, zo simpel is het! - -Verander de waarde `?username=` naar jou gebruikersnaam. - -```md -[![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) -``` - -_Notitie: Beschikbare rangen zijn S+ (top 1%), S (top 25%), A++ (top 45%), A+ (top 60%), and B+ (iedereen). -De waarden worden berekend met behulp van de zogeheten [cumulative distribution function](https://en.wikipedia.org/wiki/Cumulative_distribution_function) met de waardes van de commits, bijdragens, issues, sterren, PR's, volgers en eigen repositories. -De implementatie hiervan kan bekijken op [src/calculateRank.js](../src/calculateRank.js)_ - -### Verberg individueele statistieken - -Om specifieke statistieken te verbergen, kan je een `?hide=` query parameter toevogen, verdeeld met komma\'s. - - -> Opties: `&hide=stars,commits,prs,issues,contribs` - -```md -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&hide=contribs,prs) -``` - -### Voeg privé contributies toe aan totale commits. - -Je kan de hoeveelheid privé commits toevoegen aan je totale hoeveelheid commits door de query parameter `?count_private=true` te gebruiken. - -_Notitie: Als je dit project zelf deployt, zullen de privé contributies standaard toegevoegt worden aan je totaal, omdat anders je hoeveelheid privé contributies moet delen._ - -> Opties: `&count_private=true` - -```md -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&count_private=true) -``` - -### Laat icoontjes zien - -Om icoontjes te gebruiken kan je `show_icons=true` gebruiken in de query parameter, zoals hier: - -```md -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&show_icons=true) -``` - -### Thema\'s - -Met ingebouwde thema\'s kan je het uiterlijk van de kaart aanpassen zonder enige [handmatige opmaak](#customization). - -Gebruik `?theme=THEME_NAME` parameters zo :- - -```md -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&show_icons=true&theme=radical) -``` - -#### Alle ingeboude thema\'s :- - -dark, radical, merko, gruvbox, tokyonight, onedark, cobalt, synthwave, highcontrast, dracula - -GitHub Readme Statestieken Thema's - -Je kan een preview van alle [beschikbare thema\'s](../themes/README.md) bekijken, of zie het [thema configuratie bestand](../themes/index.js) en **je kan aan nieuwe thema\'s bijdragen** als je dat leuk lijkt :D - -### Opmaak - -Je kan het uiterlijk van je `Statistieken kaart` of `Repo kaart` aanpassen hoe je ook maar wilt met URL parameters. - -#### Veel gebruikte opties: - -- `title_color` - De kleur van de titel van de kaart _(hex kleur)_ -- `text_color` - Tekst kleur _(hex kleur)_ -- `icon_color` - Icoon kleuren, wanneer beschikbaar _(hex kleur)_ -- `bg_color` - Achtergrond kleur van de kaart _(hex kleur)_ **of** een verloop van kleuren in het formaat van _graden,start,einde_ -- `hide_border` - Verbergt de rand van de kaart _(boolean)_ -- `theme` - Naam van het thema, kies uit [alle beschikbare thema\'s](../themes/README.md) -- `cache_seconds` - Stel de cache header handmatig in _(min: 14400, max: 86400)_ -- `locale` - Stel taal van de kaart in _(e.g. cn, de, es, etc.)_ - -##### Kleurenverloop in bg_color (achtergrond kleur): - -Je kan meerdere komma verdeelde waarden in de bg_color optie geven om een kleurenverloop te creeëren, het formaat van het kleurenverloop is:- - -``` -&bg_color=GRADEN,KLEUR1,KLEUR2,KLEUR3...KLEUR10 -``` - -> Notities i.v.b.m. cache: Repo kaarten hebben een standaard cache van 4 uur (14400 seconden) als de fork hoeveelheid en de star hoeveelheid minder is dan 1k, anders is het 2 uur (7200 seconden). Daarnaast ligt de cache vast aan een minimum van 2 uur en een maximum van 24 uur. - -#### Exclusieve opties voor Statistieken Kaart: - -- `hide` - Verbergt gespecificeerde items van de statistieken. _(komma gescheiden waardes)_ -- `hide_title` - _(boolean)_ -- `hide_rank` - _(boolean)_ -- `show_icons` - _(boolean)_ -- `include_all_commits` - Tel alle commits inplaats van alleen de commits van het huidige jaar _(boolean)_ -- `count_private` - Tel privé commits mee _(boolean)_ -- `line_height` - Stel de lijn-hoogte tussen text in _(nummer)_ -- `custom_title` - Stel een aangepaste titel voor je kaart in - -#### Exclusieve opties voor Repo Kaart: - -- `show_owner` - Laat de eigenaar van de repo zien _(boolean)_ - -#### Exclusieve opties voor Programmeertaal Kaart: - -- `hide` - Verbergt specifieke talen van de kaart _(komma gescheiden waardes)_ -- `hide_title` - _(boolean)_ -- `layout` - Kies uit de vijf beschikbare lay-outs `normal` & `compact` & `donut` & `donut-vertical` & `pie` -- `card_width` - Stelt de breedte van de kaart handmatig in. _(nummer)_ -- `langs_count` - Laat meer talen op de kaart zien, waarde tussen 1-10, staat standaard op to 5 _(nummer)_ -- `exclude_repo` - Verbergt specifieke repositories _(komma gescheiden waardes)_ -- `custom_title` - Stelt een eigen titel voor de kaart in - -> :Waarschuwing: **Belangrijk:** -> Namen van programmeertalen moeten worden geuri-escaped, zoals gespecificeerd in [Percent Encoding](https://en.wikipedia.org/wiki/Percent-encoding) -> (Oftewel: `c++` moet `c%2B%2B` worden, `jupyter notebook` moet `jupyter%20notebook` worden, enzovoort...) -> Zie [urlencoder.org](https://www.urlencoder.org/) om dit automatisch te doen. - -#### Exclusieve opties voor WakaTime Kaart: - -- `hide_title` - _(boolean)_ -- `line_height` - Verandert de lijn hoogte tussen tekst _(nummer)_ -- `hide_progress` - Verbergt de progressiebalk en het percentage _(boolean)_ -- `custom_title` - Stelt een eigen titel voor de kaart in -- `layout` - Schakel tussen de twee beschikbare lay-outs `default` en `compact` - ---- - -# GitHub Extra Pins - -GitHub extra pins geven je de mogelijkheid om meer dan 6 repositories op je profiel te pinnen, doormiddel van een GitHub readme profile. - -Joepie! Je bent niet langer aan 6 pins gelimiteerd! - -### Gebruik - -Kopieer en plak deze code in je readme en verander de links. - -Eindpunt: `api/pin?username=anuraghazra&repo=github-readme-stats` - -```md -[![Readme Card](https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra&repo=github-readme-stats)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Demo - -[![Readme Card](https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra&repo=github-readme-stats)](https://github.com/anuraghazra/github-readme-stats) - -Gebruikt [show_owner](#customization) variabele om de repo\'s eigenaar toe te voegen - -[![Readme Card](https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra&repo=github-readme-stats&show_owner=true)](https://github.com/anuraghazra/github-readme-stats) - -# Top Programmeertalen Kaart - -De top programmeertalen kaart laat zien welke talen een GitHub gebruiker het meest gebruikt. - -_Notitie: Top programmeertalen wijzen niet op een vaardigheids niveau, het is puur een GitHub metriek over welke talen de meeste code op GitHub hebben. Het is een nieuwe funktie van github-readme-stats._ - -### Gebruik - -Kopieer en plak deze code in je readme en verander de links. - - -Eindpunt: `api/top-langs?username=anuraghazra` - -```md -[![Top Talen](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Verberg individueele repositories - -Je kan de parameter `?exclude_repo=repo1,repo2` gebruiken om individueele repositories te verbergen. - -```md -[![Top Talen](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&exclude_repo=github-readme-stats,anuraghazra.github.io)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Verberg individueele talen - -Je kan de `?hide=taal1,taal2` parameter gebruiken om individuele programmeer talen te verbergen. - -```md -[![Top Talen](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&hide=javascript,html)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Laat meer programmeertalen zien - -Je kan de `&langs_count=` optie gebruiken om de hoeveelheid talen op je kaart groter en kleiner te maken. Geldige waardes zijn tussen de 1 en 10 (inclusief), en de standaard waarde is 5. - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&langs_count=8)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Compacte Talen Kaart opmaak - -Je kan de `&layout=compact` optie gebruiken om het kaart ontwerp aan te passen. - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&layout=compact)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Demo - -[![Top programmeertalen](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) - -- Compacte opmaak - -[![Top programmeertalen](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&layout=compact)](https://github.com/anuraghazra/github-readme-stats) - -# Wekelijkse WakaTime Statistieken - -Verander de `?username=` waarde naar je [WakaTime](https://wakatime.com) gebruikersnaam. - -```md -[![Harlok's WakaTime stats](https://github-readme-stats.vercel.app/api/wakatime?username=ffflabs)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Demo - -[![Harlok's WakaTime stats](https://github-readme-stats.vercel.app/api/wakatime?username=ffflabs)](https://github.com/anuraghazra/github-readme-stats) - -[![Harlok's WakaTime stats](https://github-readme-stats.vercel.app/api/wakatime?username=ffflabs&hide_progress=true)](https://github.com/anuraghazra/github-readme-stats) - ---- - -### Alle demos - -- Standaard - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra) - -- Verberg specifieke statestieken - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&hide=contribs,issues) - -- Weergeef icoontjes - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&hide=issues&show_icons=true) - -- Voeg alle commits toe - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&include_all_commits=true) - -- Thema\'s - -Kies uit de [standaard thema\'s](#themes) - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&show_icons=true&theme=radical) - -- Kleurenverloop - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&bg_color=30,e96443,904e95&title_color=fff&text_color=fff) - -- Pas statistieken kaart aan - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api/?username=anuraghazra&show_icons=true&title_color=fff&icon_color=79ff97&text_color=9f9f9f&bg_color=151515) - -- Stel je kaart locale (taal) in - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api/?username=anuraghazra&locale=es) - -- Pas repo kaart aan. - -![Customized Card](https://github-readme-stats.vercel.app/api/pin?username=anuraghazra&repo=github-readme-stats&title_color=fff&icon_color=f9f9f9&text_color=9f9f9f&bg_color=151515) - -- Top programmeertalen - -[![Top Programmeertalen](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) - -- WakaTime kaart - -[![Harlok's WakaTime stats](https://github-readme-stats.vercel.app/api/wakatime?username=ffflabs)](https://github.com/anuraghazra/github-readme-stats) - ---- - -### Kleine tip (Verstel de repo kaart z\'n positie) - -Meestal kan je de afbeeldingen niet naast elkaar zetten, op deze manier wel: - -```html - - - - - - -``` - -## Deploy je eigen Vercel instatie - -#### [Check de stapsgewijze video tutorial door @codeSTACKr (In het Engels)](https://youtu.be/n6d4KHSKqGk?t=107) - -Sinds de GitHub API alleen maar 5k verzoeken per uur toestaat, zou mijn `https://github-readme-stats.vercel.app/api` mogelijk de rate limiet behalen. Als je het op je eigen Vercel server host, dan hoef je je nergens zorgen om te maken. Klik op de deploy knop om te beginnen! - -NOTITIE: Sinds [#58](https://github.com/anuraghazra/github-readme-stats/pull/58) zouden we geen problemen meer moeten hebben de 5k verzoeken per uur, en verdere downtime :D - -[![Deploy naar Vercel](https://vercel.com/button)](https://vercel.com/import/project?template=https://github.com/anuraghazra/github-readme-stats) - -

- Versel deploy gids: 🔨 - -1. Ga naar [vercel.com](https://vercel.com/) -2. Klik op `Log in` - ![](https://files.catbox.moe/tct1wg.png) -3. Meld je aan met GitHub door op `Continue with GitHub` te klikken. - ![](https://files.catbox.moe/btd78j.jpeg) -4. Log in op GitHub en sta toegang tot alle repositories toe, wanneer dat gevraagt wordt. -5. Fork deze repo -6. Ga terug naar je [Vercel dashboard](https://vercel.com/dashboard) -7. Selecteer `Import Project` - ![](https://files.catbox.moe/qckos0.png) -8. Selecteer `Import Git Repository` - ![](https://files.catbox.moe/pqub9q.png) -9. Selecteer root en hou alles zoals het is, voeg alleen je environment variable genaamd PAT_1 toe (Zoals hier late zien word), die beheert over een persoonlijke toegangs token (PAT), die je gemakklijk [hier](https://github.com/settings/tokens/new) gemakkelijk kan creeëren. (Laat alles zoals het is, noem het maar iets, mag alles zijn.) - ![](https://files.catbox.moe/0ez4g7.png) -10. Klik deploy, en alles zou moeten werken. Zie je domein om de api te gebruiken! - -
- -## :sparkling_heart: Ondersteun het project - -Ik maak bijna alles open-source wat ik kan, en ik probeer iedereen te helpen die deze projecten gebruiken. Natuurlijk kost dit tijd, je mag deze services gratis gebruiken. - -Hoe dan ook, als je dit project gebruikt en er blij mee bent, of mij wilt aanmoedigen om dingen te blijven maken, zijn er een paar manieren om dit te doen; - - -- Credits geven aan github-readme-stats op je readme, die terug naar het project linkt :D -- Sterren en delen van het project :rocket: -- [![paypal.me/anuraghazra](https://ionicabizau.github.io/badges/paypal.svg)](https://www.paypal.me/anuraghazra) - Je kan eenmalig giften via PayPal, ik koop er waarschijnlijk ~~koffie~~ thee van. :tea: - -Bedankt! :heart: - ---- - -[![https://vercel.com?utm_source=github_readme_stats_team&utm_campaign=oss](../powered-by-vercel.svg)](https://vercel.com?utm_source=github_readme_stats_team&utm_campaign=oss) - -Contributies zijn welkom! <3 - -Gemaakt met :heart: en JavaScript. diff --git a/docs/readme_np.md b/docs/readme_np.md deleted file mode 100644 index f5909ae718219..0000000000000 --- a/docs/readme_np.md +++ /dev/null @@ -1,422 +0,0 @@ -

- GitHub Readme Stats -

GitHub Readme Stats

-

पहुनु होस् द्य्नामिचल्ली गेनेरटे गितहब रेअडमी सतत

-

-

- - Tests Passing - - - GitHub Contributors - - - Tests Coverage - - - Issues - - - GitHub pull requests - - - OpenSSF Scorecard - -
-
-

- -

- डेमो हेर्नुहोस् - · - रिपोर्ट बग - · - अनुरोध सुविधा -

-

- Français - · - 简体中文 - · - Español - · - Deutsch - · - 日本語 - · - Português Brasileiro - · - Italiano - · - 한국어 - . - Nederlands - · - नेपाली - . - Türkçe -

-

-

परियोजना मनपर्‍यो? तपाईं मद्दत गर्न सक्नुहुन्छ यो परियोजना बढ्न - -# विशेषताहरु - -- [गितहब स्टेट कार्ड](#गितहब-स्टेट-कार्ड) - - [लुकाउनु होस् व्यक्तिगत स्टेट](#लुकाउनु-होस्-व्यक्तिगत-स्टेट) - - [जोड्नु होस् निजी टोटल योगदान](#जोड्नु-होस्-निजी-टोटल--योगदान) - - [देखाउनु होस् इकोन](#देखाउनु-होस्-इकोन) - - [विषयवस्तुहरू](#विषयवस्तुहरू) - - [अनुकूलन](#अनुकूलन) -- [गितहब अतिरिक्त पिन्स](#गितहब-अतिरिक्त-पिन्स) - - [प्रयोग](#प्रयोग) - - [डेमो](#डेमो) -- [टोप भाषा कार्ड](#टोप-भाषा-कार्ड) - - [प्रयोग](#प्रयोग-1) - - [Exclude individual repositories](#exclude-individual-repositories) - - [कुनै भाषा चुपौनॆ तरिका](#कुनै-भाषा-चुपौनॆ-तरिका) - - [धेरॆ भाषाहरु हेर्नको लागि](#धेरॆ-भाषाहरु-हेर्नको-लागि) - - [कम्प्याक्ट भाषा कार्ड ळयोउत](#कम्प्याक्ट-भाषा-कार्ड-ळयोउत) - - [डेमो](#डेमो-1) -- [वाका समय वीक स्तट्स](#वाका-समय-वीक-स्तट्स) - - [डेमो](#डेमो-2) - - [सबै डेमोहरु](#सबै-डेमोहरु) - - [टिप् (रेपो कार्डलाए अलिग्न गर्ने )](#टिप्--रेपो-कार्डलाए-अलिग्न-गर्ने-) - - [देप्लोय आफ्नै वेर्चेल इन्स्तंस](#देप्लोय--आफ्नै--वेर्चेल--इन्स्तंस) - - [:sparkling\_heart: सहपोर्ट द प्रोजेक्ट](#sparkling_heart-सहपोर्ट-द-प्रोजेक्ट) - -# गितहब स्टेट कार्ड - -Copy-paste this into your markdown content, and that's it. Simple! - -Change the `?username=` value to your GitHub's username. - -```md -[![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) -``` - -_Note: Ranks are calculated based on user's stats, see [src/calculateRank.js](./src/calculateRank.js)_ - -### लुकाउनु होस् व्यक्तिगत स्टेट - -To hide any specific stats, you can pass a query parameter `?hide=` with comma-separated values. - -> Options: `&hide=stars,commits,prs,issues,contribs` - -```md -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&hide=contribs,prs) -``` - -### जोड्नु होस् निजी टोटल योगदान - -You can add the count of all your private contributions to the total commits count by using the query parameter `?count_private=true`. - -_Note: If you are deploying this project yourself, the private contributions will be counted by default otherwise you need to chose to share your private contribution counts._ - -> Options: `&count_private=true` - -```md -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&count_private=true) -``` - -### देखाउनु होस् इकोन - -To enable icons, you can pass `show_icons=true` in the query param, like so: - -```md -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&show_icons=true) -``` - -### विषयवस्तुहरू - -With inbuilt themes, you can customize the look of the card without doing any [manual customization](#customization). - -Use `?theme=THEME_NAME` parameter like so :- - -```md -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&show_icons=true&theme=radical) -``` - -#### सबै इनबिल्ट विषयवस्तु :- - -dark, radical, merko, gruvbox, tokyonight, onedark, cobalt, synthwave, highcontrast, dracula - -GitHub Readme Stat Themes - - -तपैले सबै थेम्सहरु प्रेविउ गर्न सक्नु हुनेछ । [all available themes](./themes/README.md) नत्र थेम्सहरुको config [theme config file](./themes/index.js) पनि हेर्न सक्नु हुनेछ र **थेम्सहरुमा योगदान पनि गर्नु सक्नु हुनेछ** :D । - -### अनुकूलन - -तपैले `Stats Card` or `Repo Card` को अपपेअरंस कस्टमेज गर्न सक्नु हुनेछ जसमा तपैले URL params पनि प्रयोग गर्नु सक्नु हुनेछ । - -#### साधारण विकल्पहरू: - -- `title_color` - Card's title color _(hex color)_ -- `text_color` - Body text color _(hex color)_ -- `icon_color` - Icons color if available _(hex color)_ -- `bg_color` - Card's background color _(hex color)_ **or** a gradient in the form of _angle,start,end_ -- `hide_border` - Hides the card's border _(boolean)_ -- `theme` - name of the theme, choose from [all available themes](./themes/README.md) -- `cache_seconds` - set the cache header manually _(min: 14400, max: 86400)_ -- `locale` - set the language in the card _(e.g. cn, de, es, etc.)_ - -##### Gradient in bg_color - -You can provide multiple comma-separated values in bg_color option to render a gradient, the format of the gradient is :- - -``` -&bg_color=DEG,COLOR1,COLOR2,COLOR3...COLOR10 -``` - -> Note on cache: Repo cards have a default cache of 4 hours (14400 seconds) if the fork count & star count is less than 1k, otherwise, it's 2 hours (7200 seconds). Also, note that the cache is clamped to a minimum of 2 hours and a maximum of 24 hours - -#### Stats कार्ड विशेष विकल्पहरू: - -- `hide` - Hides the specified items from stats _(Comma-separated values)_ -- `hide_title` - _(boolean)_ -- `hide_rank` - _(boolean)_ -- `show_icons` - _(boolean)_ -- `include_all_commits` - Count total commits instead of just the current year commits _(boolean)_ -- `count_private` - Count private commits _(boolean)_ -- `line_height` - Sets the line-height between text _(number)_ -- `custom_title` - Sets a custom title for the card - -#### Repo कार्ड विशेष विकल्पहरू: - -- `show_owner` - Show the owner name of the repo _(boolean)_ - -#### भाषा कार्ड अनन्य विकल्पहरू : - -- `hide` - Hide the languages specified from the card _(Comma-separated values)_ -- `hide_title` - _(boolean)_ -- `layout` - Switch between five available layouts `normal` & `compact` & `donut` & `donut-vertical` & `pie`. Default: `normal`. -- `card_width` - Set the card's width manually _(number)_ -- `langs_count` - Show more languages on the card, between 1-10, defaults to 5 _(number)_ -- `exclude_repo` - Exclude specified repositories _(Comma-separated values)_ -- `custom_title` - Sets a custom title for the card - -> :warning: **Important:** -> Language names should be uri-escaped, as specified in [Percent Encoding](https://en.wikipedia.org/wiki/Percent-encoding) -> (i.e: `c++` should become `c%2B%2B`, `jupyter notebook` should become `jupyter%20notebook`, etc.) - -#### वकासमय कार्ड विशेष विकल्प: - -- `hide_title` - _(boolean)_ -- `line_height` - Sets the line-height between text _(number)_ -- `hide_progress` - Hides the progress bar and percentage _(boolean)_ -- `custom_title` - Sets a custom title for the card - ---- - -# गितहब अतिरिक्त पिन्स - -GitHub extra pins allow you to pin more than 6 repositories in your profile using a GitHub readme profile. - -GitHub फाल्तु पिनले तपाइँलाए GitHub रीडमी प्रोफाइल प्रयोग गरी तपाइँको प्रोफाइलमा छ ओटा भन्दा बढि प्रोजेक्टहरु पिन गर्न अनुमति दिन्छ । - -हो! तपाईं अब pin पिन गरीएको छ ओटा प्रोजेक्ट सीमित हुनुहुन्छ । - -### प्रयोग - -कोदलाए कपी- पेसेत readme मा गर्नु होला र लिंक परिवतन गर्नु होला | - -Endpoint: `api/pin?username=anuraghazra&repo=github-readme-stats` - -```md -[![Readme Card](https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra&repo=github-readme-stats)](https://github.com/anuraghazra/github-readme-stats) -``` - -### डेमो - -[![Readme Card](https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra&repo=github-readme-stats)](https://github.com/anuraghazra/github-readme-stats) - -Use [show_owner](#customization) variable to include the repo's owner username - -[![Readme Card](https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra&repo=github-readme-stats&show_owner=true)](https://github.com/anuraghazra/github-readme-stats) - -# टोप भाषा कार्ड - -टोप भाषाकार्डले github परयोग गर्नेहरुको प्रोग्रम्मिंग भाषाहरु देखाऊने गर्दछ |. - -_NOTE: टोप भाषाहरुले आफ्नो सिपलाए संकेत गरेको होईन | योचै GitHub Metricबाट धेरै कुन भाषा परयोग भाकोलाए संकेत गरेको हो | -### प्रयोग - -कोदलाए कपी- पेसेत readme मा गर्नु होला र लिंक परिवतन गर्नु होला | - -Endpoint: `api/top-langs?username=anuraghazra` - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Exclude individual repositories - -You can use `?exclude_repo=repo1,repo2` parameter to exclude individual repositories. - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&exclude_repo=github-readme-stats,anuraghazra.github.io)](https://github.com/anuraghazra/github-readme-stats) -``` - -### कुनै भाषा चुपौनॆ तरिका - -You can use `?hide=language1,language2` parameter to hide individual languages. - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&hide=javascript,html)](https://github.com/anuraghazra/github-readme-stats) -``` - -### धेरॆ भाषाहरु हेर्नको लागि - -You can use the `&langs_count=` option to increase or decrease the number of languages shown on the card. Valid values are integers between 1 and 10 (inclusive), and the default is 5. - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&langs_count=8)](https://github.com/anuraghazra/github-readme-stats) -``` - -### कम्प्याक्ट भाषा कार्ड ळयोउत - -तपाइले `&layout=compact` ओप्तिओनपनि कार्ड देसिग्न को लागि परहयोग गर्न सक्नु हुन्क्ष - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&layout=compact)](https://github.com/anuraghazra/github-readme-stats) -``` - -### डेमो - -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) - -- Compact layout - -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&layout=compact)](https://github.com/anuraghazra/github-readme-stats) - -# वाका समय वीक स्तट्स - -Change the `?username=` value to your [WakaTime](https://wakatime.com) username. - -```md -[![Harlok's WakaTime stats](https://github-readme-stats.vercel.app/api/wakatime?username=ffflabs)](https://github.com/anuraghazra/github-readme-stats) -``` - -### डेमो - -[![Harlok's WakaTime stats](https://github-readme-stats.vercel.app/api/wakatime?username=ffflabs)](https://github.com/anuraghazra/github-readme-stats) - -[![Harlok's WakaTime stats](https://github-readme-stats.vercel.app/api/wakatime?username=ffflabs&hide_progress=true)](https://github.com/anuraghazra/github-readme-stats) - ---- - -### सबै डेमोहरु - -- देफौल्ट - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra) - -- हिदिंग स्पेचific स्तट्स - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&hide=contribs,issues) - -- इकोनहरु शो गर्ने - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&hide=issues&show_icons=true) - -- सबै कमितहरु - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&include_all_commits=true) - -- थेम्स - -कुनै एउटा चोज गर्नुस [default themes](#themes) - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&show_icons=true&theme=radical) - -- घ्रदिएन्त - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&bg_color=30,e96443,904e95&title_color=fff&text_color=fff) - -- स्तत्स कार्ड लाए कस्तोमेज गर्ने - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api/?username=anuraghazra&show_icons=true&title_color=fff&icon_color=79ff97&text_color=9f9f9f&bg_color=151515) - -- सेत्तिंग कार्ड लोचले - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api/?username=anuraghazra&locale=es) - -- रेपो कार्डलाई एडित गर्नु - -![Customized Card](https://github-readme-stats.vercel.app/api/pin?username=anuraghazra&repo=github-readme-stats&title_color=fff&icon_color=f9f9f9&text_color=9f9f9f&bg_color=151515) - -- टोप भाषा - -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) - -- वक समय कार्ड - -[![Harlok's WakaTime stats](https://github-readme-stats.vercel.app/api/wakatime?username=ffflabs)](https://github.com/anuraghazra/github-readme-stats) - ---- - -### टिप् (रेपो कार्डलाए अलिग्न गर्ने ) - -तपाइले इमेजलाई सइद बय सइद अलीग्न गर्न सक्नु हुदैन तेसैले येसरी गर्नु होस् : - -```html - - - - - - -``` - -## देप्लोय आफ्नै वेर्चेल इन्स्तंस - -#### [Check Out Step By Step Video Tutorial By @codeSTACKr](https://youtu.be/n6d4KHSKqGk?t=107) - -गितहब को अपिएले पाच हजार रेक़ुएस्त प्रति घण्टा मात्र मिल्क्ष । मेरो - `https://github-readme-stats.vercel.app/api` प्रोजेक्ट मा रेत् लिमिट हुन सक्क्ष । तर तपाइले आफ्नै वेर्चेल सेर्वेर मा होस्ट गर्नु बाको छ बने यो प्रोब्लेम हुदैन। - होस्ट गर्ने तरिका यस पकारका षन । - -NOTE: Since [#58](https://github.com/anuraghazra/github-readme-stats/pull/58) we should be able to handle more than 5k requests and have no issues with downtime :D - -[![Deploy to Vercel](https://vercel.com/button)](https://vercel.com/import/project?template=https://github.com/anuraghazra/github-readme-stats) - -

- Guide on setting up Vercel 🔨 - -1. Go to [vercel.com](https://vercel.com/) -1. Click on `Log in` - ![](https://files.catbox.moe/tct1wg.png) -1. Sign in with GitHub by pressing `Continue with GitHub` - ![](https://files.catbox.moe/btd78j.jpeg) -1. Sign into GitHub and allow access to all repositories, if prompted -1. Fork this repo -1. Go back to your [Vercel dashboard](https://vercel.com/dashboard) -1. Select `Import Project` - ![](https://files.catbox.moe/qckos0.png) -1. Select `Import Git Repository` - ![](https://files.catbox.moe/pqub9q.png) -1. Select root and keep everything as is, just add your environment variable named PAT_1 (as shown), which will contain a personal access token (PAT), which you can easily create [here](https://github.com/settings/tokens/new) (leave everything as is, just name it something, it can be anything you want) - ![](https://files.catbox.moe/0ez4g7.png) -1. Click deploy, and you're good to go. See your domains to use the API! - -
- -## :sparkling_heart: सहपोर्ट द प्रोजेक्ट - -म सके सम्म आफ्नो प्रोजेक्ट हरु ओपेन्सोउर्चे गर्छु र अरु ले पनि सहयोग गर्क्षु । मेले सहयोग गर्दा आफ्नो समय पनि देरै ने दिन्क्षु । तपाइहरु ले यो सेर्विचेस फ्री मा चलाउनु सक्नु हुनेक्ष । - -येदि तपाइले यो प्रोजेक्ट चलाउनु बाकोक्ष बने र मलाई अझै प्रसंसा गर्ने हो बने तपाइले थुप्रै तरिका ले गर्नु सक्नु हुने छ :- - -- यो प्रोजेक्टमा तपाइले प्रहयोग गर्दा मलाई क्रेडिट दिन सक्नु हुनेक्ष । -- तपाइले GitHub ReadMe Stats स्तार्रेड गर्न सक्नु हुनेक्ष :rocket: -- [![paypal.me/anuraghazra](https://ionicabizau.github.io/badges/paypal.svg)](https://www.paypal.me/anuraghazra) - तपाइले पेपाल बाट पनि सहयोग (डक्क्षिन) गर्न सक्नु हुनेक्ष | म ~~कोफी ~~ चिया . :tea: किन्न सक्क्षु । - -धन्याबाद! :heart: - ---- - -![https://vercel.com](https://res.cloudinary.com/anuraghazra/image/upload/v1597827714/powered-by-vercel_1_ug4uro.svg) - -योगधन को लागी स्वगत छ! <3 - -जाभास्क्रिप्ट बाटा बनको :heart: diff --git a/docs/readme_pt-BR.md b/docs/readme_pt-BR.md deleted file mode 100644 index 35c334131ee93..0000000000000 --- a/docs/readme_pt-BR.md +++ /dev/null @@ -1,372 +0,0 @@ -

- GitHub Readme Stats -

GitHub Readme Stats

-

Adicione suas estatísticas no GitHub geradas dinamicamente em seus readmes!

-

-

- - Testes aprovados - - - GitHub Contributors - - - Tests Coverage - - - Issues - - - GitHub pull requests - - - OpenSSF Scorecard - -
-
-

- -

- Ver demonstração - · - Reportar erros - · - Solicitar recursos -

-

- Français - · - 简体中文 - · - Español - · - Deutsch - · - 日本語 - · - Português Brasileiro - · - Italiano - · - 한국어 - . - Nederlands - . - नेपाली - . - Türkçe -

-

-

Gostou do projeto? Por favor considere fazer uma doação para ajudar a melhorá-lo! - -# Características - -- [Cartão de estatísticas do GitHub](#cartão-de-estatísticas-do-github) - - [Ocultando estatísticas específicas](#ocultando-estatísticas-específicas) - - [Adicionando contagem de contribuições privadas à contagem total de commits](#adicionando-contagem-de-contribuições-privadas-à-contagem-total-de-commits) - - [Exibindo ícones](#exibindo-ícones) - - [Temas](#temas) - - [Personalização](#personalização) -- [Pins extras do GitHub](#pins-extras-do-github) - - [Utilização](#utilização) - - [Demonstração](#demonstração) -- [Cartão de principais linguagens de programação](#cartão-de-principais-linguagens-de-programação) - - [Utilização](#utilização-1) - - [Ocultar linguagens individualmente](#ocultar-linguagens-individualmente) - - [Layout de cartão de linguagens compacto](#layout-de-cartão-de-linguagens-compacto) - - [Demonstração](#demonstração-1) -- [Estatística semanal WakaTime](#estatística-semanal-wakatime) - - [Demonstração](#demonstração-2) - - [Todas as demonstrações](#todas-as-demonstrações) - - [Dica (Alinhandos os cartões de repositório)](#dica-alinhandos-os-cartões-de-repositório) - - [Implante em sua própria instância do Vercel](#implante-em-sua-própria-instância-do-vercel) - - [:sparkling\_heart: Apoie o projeto](#sparkling_heart-apoie-o-projeto) - -# Cartão de estatísticas do GitHub - -Copie e cole isso no seu conteúdo de remarcação e é isso. Simples! - -Mude o valor de `?username=` para o seu nome de usuário no GitHub. - -```md -[![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) -``` - -_Nota: As classificações são baseadas nas estatísticas do usuário, veja [src/calculateRank.js](../src/calculateRank.js)_ - -### Ocultando estatísticas específicas - -Para ocultar estatísticas individualmente, você pode passar um parâmetro de consulta `?hide=` com valores separados por vírgula. - -> Opções: `&hide=stars,commits,prs,issues,contribs` - -```md -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&hide=contribs,prs) -``` - -### Adicionando contagem de contribuições privadas à contagem total de commits - -Adicione a contagem de todas as suas contribuições privadas à contagem total de confirmações usando o parâmetro de consulta `?count_private=true`. - -_Nota: Se você estiver implantando este projeto, as contribuições privadas serão contadas por padrão; caso contrário, você precisará compartilhar suas contagens de contribuições privadas._ - -> Opções: `&count_private=true` - -```md -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&count_private=true) -``` - -### Exibindo ícones - -Para habilitar ícones, basta utilizar o parâmetro `show_icons=true` na sua requisição, da seguinte forma: - -```md -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&show_icons=true) -``` - -### Temas - -Com temas predefinidos, pode personalizar a aparência dos cartões sem precisar fazer nenhuma [configuração manual](#personalização). - -Utilize o parâmetro `?theme=THEME_NAME`, da seguinte forma: - -```md -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&show_icons=true&theme=radical) -``` - -#### Todos os temas predefinidos : - -dark, radical, merko, gruvbox, tokyonight, onedark, cobalt, synthwave, highcontrast, dracula - -GitHub Readme Stat Themes - -Visualize [todos o temas disponíveis](../themes/README.md) ou o [arquivo de configuração de tema](../themes/index.js), além de **também poder contribuir com novos temas**, se desejar :D - -### Personalização - -Personalize a aparência do seu `Stats Card` ou `Repo Card` da maneira que desejar com os parâmetros de URL. - -#### Opções comuns - -- `title_color` - Cor do título do cartão _(hex color)_ -- `text_color` - Cor de texto do conteúdo _(hex color)_ -- `icon_color` - Cor dos ícones (se disponível) _(hex color)_ -- `bg_color` - Cor de fundo do cartão _(hex color)_ -- `hide_border` - Esconde a borda do cartão _(boleano)_ -- `theme` - Nome do tema, escolha em [todos os temas disponíveis](../themes/README.md) -- `cache_seconds` - Defina o cabeçalho do cache manualmente _(min: 14400, max: 86400)_ -- `locale` - defina o idioma no cartão _(por exemplo. cn, de, es, etc.)_ - -> Nota sobre o cache: Cartões de repositório tem um cache padrão de 30 minutos (1800 segundos), se o número a contagem de forks e contagem de estrelas é menor que 1 mil o padrão é 2 horas (7200 segundos). Note também que o cache é limitado a um mínimo de 30 minutos e um máximo de 24 horas. - -#### Opções exclusivas do cartão de estatísticas: - -- `hide` - Oculta itens específicos das estatísticas _(Valores separados por vírgulas)_ -- `hide_title` - Ocultar o título _(boolean)_ -- `hide_rank` - Ocultar a classificação _(boolean)_ -- `show_icons` - Mostrar ícones _(boolean)_ -- `include_all_commits` - Contabiliza todos os commits ao invés de apenas os atual ano _(boolean)_ -- `count_private` - Contabiliza commits privados _(boolean)_ -- `line_height` - Define a altura do espaçamento entre o texto _(number)_ - -#### Opções exclusivas do cartão de repositórios: - -- `show_owner` - Exibir o nome da pessoa a quem o repositório pertence _(boolean)_ - -#### Opções exclusivas do cartão de linguagens: - -- `hide` - Oculta linguagens específicas _(Valores separados por vírgulas)_ -- `hide_title` - Oculta o título _(boolean)_ -- `layout` - Alternar entre os cinco layouts disponíveis `normal` & `compact` & `donut` & `donut-vertical` & `pie` -- `card_width` - Define a largura do cartão manualmente _(number)_ - -> :warning: **Importante:** -> Nomes de linguagens devem ser uma sequência escapada de URI, como específicado em [Codificação por cento](https://pt.wikipedia.org/wiki/Codificação_por_cento) -> (Ou seja: `c++` deve se tornar `c%2B%2B`, `jupyter notebook` deve se tornar `jupyter%20notebook`, etc.) - ---- - -# Pins extras do GitHub - -Os Pins extras do GitHub permitem fixar mais de 6 repositórios no seu perfil usando um perfil README.me do GitHub. - -Uhu! Você não está mais limitado a 6 repositórios fixados. - -### Utilização - -Copie e cole esse código no seu README.md e altere os atributos. - -Endpoint: `api/pin?username=anuraghazra&repo=github-readme-stats` - -```md -[![Readme Card](https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra&repo=github-readme-stats)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Demonstração - -[![Readme Card](https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra&repo=github-readme-stats)](https://github.com/anuraghazra/github-readme-stats) - -Utilize a variável [show_owner](#personalização) para incluir o nome de usuário do proprietária do repositório - -[![Readme Card](https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra&repo=github-readme-stats&show_owner=true)](https://github.com/anuraghazra/github-readme-stats) - -# Cartão de principais linguagens de programação - -Exibe uma métrica de linguagens de programação mais usadas pelo usuário do GitHub. - -_Nota: As principais linguagens de programação não fazem declarações sobre habilidades pessoais ou similares, é apenas uma figura-chave com base nas estatísticas do GitHub do usuário indicando a frequência com que cada uma foi utilizada._ - -### Utilização - -Copie e cole esse código no seu README.md e altere os atributos. - -Endpoint: `api/top-langs?username=anuraghazra` - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Ocultar linguagens individualmente - -Utilize o parâmetro `?hide=language1,language2` para ocultar linguagens específicas. - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&hide=javascript,html)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Layout de cartão de linguagens compacto - -Utilize a opção `&layout=compact` para mudar o layout do cartão. - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&layout=compact)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Demonstração - -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) - -- Layout compacto - -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&layout=compact)](https://github.com/anuraghazra/github-readme-stats) - -# Estatística semanal WakaTime - -Altere o valor de `?username=` para o seu username do WakaTime. - -```md -[![Harlok's WakaTime stats](https://github-readme-stats.vercel.app/api/wakatime?username=ffflabs)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Demonstração - -[![Harlok's WakaTime stats](https://github-readme-stats.vercel.app/api/wakatime?username=ffflabs)](https://github.com/anuraghazra/github-readme-stats) - -[![Harlok's WakaTime stats](https://github-readme-stats.vercel.app/api/wakatime?username=ffflabs&hide_progress=true)](https://github.com/anuraghazra/github-readme-stats) - ---- - - - -### Todas as demonstrações - -- Padronizado - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra) - -- Ocultando estatísticas específicas - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&hide=contribs,issues) - -- Mostrando ícones - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&hide=issues&show_icons=true) - -- Incluir todos os commits - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&include_all_commits=true) - -- Temas - -Escolha entre um dos [temas predefinidos](#temas) - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&show_icons=true&theme=radical) - -- Personalizando o cartão de estatísticas - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api/?username=anuraghazra&show_icons=true&title_color=fff&icon_color=79ff97&text_color=9f9f9f&bg_color=151515) - -- Customizando o cartão de repositório - -![Customized Card](https://github-readme-stats.vercel.app/api/pin?username=anuraghazra&repo=github-readme-stats&title_color=fff&icon_color=f9f9f9&text_color=9f9f9f&bg_color=151515) - -- Principais linguagens - -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) - ---- - -### Dica (Alinhandos os cartões de repositório) - -Por padrão, você não poderá organizar as imagens lado a lado. Para fazer isso, você pode usar a seguinte abordagem: - -```html - - - - - - -``` - -## Implante em sua própria instância do Vercel - -#### [Check Out Step By Step Video Tutorial By @codeSTACKr](https://youtu.be/n6d4KHSKqGk?t=107) - -Como a API do GitHub permite apenas 5 mil solicitações por hora, é possível que minha `https://github-readme-stats.vercel.app/api` atinja a cota limite. Se hospedar em seu próprio servidor Vercel, não precisará se preocupar com nada. Clique no botão de implantação para começar! - -Nota: Desde [#58](https://github.com/anuraghazra/github-readme-stats/pull/58) há possibilidade de lidar com mais de 5 mil chamadas por hora, sem interrupções :D - -[![Deploy to Vercel](https://vercel.com/button)](https://vercel.com/import/project?template=https://github.com/anuraghazra/github-readme-stats) - -

- Guia de configuração do Vercel - -1. Acesse [vercel.com](https://vercel.com/) -1. Clique em `Login` - ![](https://files.catbox.moe/tct1wg.png) -1. Acesse com o GitHub clicando em `Continue with GitHub` - ![](https://files.catbox.moe/btd78j.jpeg) -1. Entre no GitHub e permita acesso a todos os repositórios, se solicitado -1. Faça Fork neste repositório -1. Volte ao seu [painel principal do Vercel](https://vercel.com/dashboard) -1. Selecione `Import Project` - ![](https://files.catbox.moe/qckos0.png) -1. Selecione `Import Git Repository` - ![](https://files.catbox.moe/pqub9q.png) -1. Selecione a raiz e mantenha tudo como está, basta adicionar sua variável de ambiente chamada PAT_1 (que será exibida), que conterá um token de acesso pessoal (PAT), que você pode criar facilmente [aqui](https://github.com/settings/tokens/new) (deixe tudo como está, apenas dê um nome, que pode ser o que você quiser) - ![](https://files.catbox.moe/0ez4g7.png) -1. Clique em `deploy` e já estará tudo pronto. Veja seus domínios para usar a API! - -
- -## :sparkling_heart: Apoie o projeto - -Disponibilizo como código aberto quase tudo o que posso e tento responder a todos que precisam de ajuda para utilizar esses projetos. Claro, -isso demanda tempo. Utilize este serviço gratuitamente. - -No entanto, se você utilizar este projeto e estiver satisfeito com ele, ou apenas quiser me encorajar a continuar criando coisas, existem algumas formas fazê-lo: - -- Dando os devidos créditos ao usar github-readme-stats no seu README.me, adicionando uma referência ao projeto :D -- Dando uma estrela (Starring) e compartilhando o projeto 🚀 -- [![paypal.me/anuraghazra](https://ionicabizau.github.io/badges/paypal.svg)](https://www.paypal.me/anuraghazra) - Você pode fazer doações únicas via PayPal. Provavelmente vou comprar um ~~café~~ chá. :tea: - -Obrigado! :heart: - ---- - -[![https://vercel.com?utm_source=github_readme_stats_team&utm_campaign=oss](../powered-by-vercel.svg)](https://vercel.com?utm_source=github_readme_stats_team&utm_campaign=oss) - -Contribuições são bem-vindas! <3 - -Feito com :heart: e JavaScript. diff --git a/docs/readme_tr.md b/docs/readme_tr.md deleted file mode 100644 index f654cd95cf252..0000000000000 --- a/docs/readme_tr.md +++ /dev/null @@ -1,432 +0,0 @@ -

- GitHub Readme Stats -

GitHub Readme Stats

-

Readme'lerinizde dinamik olarak oluşturulmuş GitHub istatistikleri alın!

-

-

- - Tests Passing - - - GitHub Contributors - - - Tests Coverage - - - Issues - - - GitHub pull requests - - - OpenSSF Scorecard - -
-
-

- -

- Demo - · - Hata İlet - · - Özellik Talep Et -

-

- Français - · - 简体中文 - · - Español - · - Deutsch - · - 日本語 - · - Português Brasileiro - · - Italiano - · - 한국어 - . - Nederlands - . - नेपाली - . - Türkçe -

-

-

Projeyi sevdiniz mi? Daha da gelişmesi için lütfen bağış yapın! - -# Features - -- [GitHub İstatistikler Kartı](#github-i̇statistikler-kartı) - - [Bazı İstatitistikleri Gizleme](#bazı-i̇statitistikleri-gizleme) - - [Özel Katkı Sayısını Toplam Commit Sayısına Ekleme](#özel-katkı-sayısını-toplam-commit-sayısına-ekleme) - - [İkonları Göstermek](#i̇konları-göstermek) - - [Temalar](#temalar) - - [Özelleştirmeler](#özelleştirmeler) -- [GitHub Ekstra Pinler](#github-ekstra-pinler) - - [Kullanım](#kullanım) - - [Demo](#demo) -- [En Çok Kullanılan Diller](#en-çok-kullanılan-diller) - - [Kullanım](#kullanım-1) - - [Belirli Repoları Çıkartın](#belirli-repoları-çıkartın) - - [Belirli Dilleri Çıkartın](#belirli-dilleri-çıkartın) - - [Daha Fazla Dil Gösterin](#daha-fazla-dil-gösterin) - - [Kompakt Dil Kartı Düzeni](#kompakt-dil-kartı-düzeni) - - [Demo](#demo-1) -- [WakaTime Haftalık İstatistikler](#wakatime-haftalık-i̇statistikler) - - [Demo](#demo-2) - - [Tüm Demolar](#tüm-demolar) - - [Hızlı İpucu (Repo Kartları Hizlayın)](#hızlı-i̇pucu-repo-kartları-hizlayın) - - [Kendi Vercel Örneğinizde Yayınlayın](#kendi-vercel-örneğinizde-yayınlayın) - - [:sparkling\_heart: Projeyi Destekleyin](#sparkling_heart-projeyi-destekleyin) - -# GitHub İstatistikler Kartı - -Alt kısımdaki kodu Kopyalayın ve yapıştırın. İşte bu kadar. Çok basit! - -`?username=` değerini kendi GitHub kullanıcı adınız ile değiştirin. - -```md -[![Anurag'nın GitHub İstatistikleri](https://github-readme-stats.vercel.app/api?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) -``` -_Not: Şu sıralamalar mevcut: S+ (en üst 1%), S (en üst 25%), A++ (en üst 45%), A+ (en üst 60%), and B+ (herkes). -Buradaki değerler [cumulative distribution function](https://en.wikipedia.org/wiki/Cumulative_distribution_function) ile hesaplanırken; commitler, katkılar, hatalar, yıldızlar, çekme istekleri, takipçiler ve sahip olunan depolar (repository) göz önünde bulundurulamaktadır. -Uygulamanın yapısı [src/calculateRank.js](./src/calculateRank.js)'te daha detaylı incelenebilir._ - -### Bazı İstatitistikleri Gizleme - -Bazı belirli istatistikleri gizlemek için `?hide=` paremetresi içerisinde virgülle ayırarak gönderebilirsiniz. - -> Örnek: `&hide=stars,commits,prs,issues,contribs` - -```md -![mustafacagri's github stats](https://github-readme-stats.vercel.app/api?username=mustafacagri&hide=contribs,prs) -``` - -### Özel Katkı Sayısını Toplam Commit Sayısına Ekleme - -Özel (private) olarak geliştirdiğiniz depolardaki commit sayınızı toplam commit sayınız içerisinde göstermek istiyorsanız `?count_private=true` parametresini gönderebilirsiniz. - -_Not: Eğer projeyi kendiniz yayınlayıp kullanacaksanız, özel depolardaki geliştirmelerinizin sayısını varsayılan olarak toplam commit sayınız içerisinde gösterilecektir. Aksi taktirde özel depolardaki katkı sayınızı paylaşmayı ayrıca seçmeniz gerekecektir. - -> Örnek: `&count_private=true` - -```md -![mustafacagri's github stats](https://github-readme-stats.vercel.app/api?username=mustafacagri&count_private=true) -``` - -### İkonları Göstermek - -Eğer ikonları göstermek istiyorsanız, `show_icons=true` parametresini göndermeniz gerekmektedir. Örnek olarak: - -```md -![mustafacagri's github stats](https://github-readme-stats.vercel.app/api?username=mustafacagri&show_icons=true) -``` - -### Temalar - -Dahili olarak gelen temalarla, herhangi bir [manuel özelleştirme](#özelleştirmeler) yapmadan kartın görünümünü özelleştirebilirsiniz. - -`?theme=THEME_NAME` parametresini kullanabilirsiniz: - -```md -![mustafacagri's github stats](https://github-readme-stats.vercel.app/api?username=mustafacagri&show_icons=true&theme=radical) -``` - -#### Tüm Dahili Temalar :- - -dark, radical, merko, gruvbox, tokyonight, onedark, cobalt, synthwave, highcontrast, dracula - -GitHub Readme Stat Temaları - -Önizleme yapmak için şuralara göz atabilirsiniz: [tüm dahili temalar](./themes/README.md) veya [tema ayar dosyası](./themes/index.js) & **ayrıca siz de yeni bir tema oluşturarak katkı sağlayabilirsiniz** elbette isterseniz :D - -### Özelleştirmeler - - -`Stats Card` ya da `Repo Card` görüntünüzü istediğiniz gibi şu parametreler ile değiştirebilirsiniz: - -#### Yaygın Seçenekler: - -- `title_color` - Kart başlığı rengi _(hex color / hex rengi)_ -- `text_color` - İçerik rengi _(hex color / hex rengi)_ -- `icon_color` - Mümkünse ikon rengi _(hex color / hex rengi)_ -- `bg_color` - Kartın arkaplan rengi _(hex color / hex rengi)_ **ya da** gradient şeklinde _açı,başlangıç,bitiş_ -- `hide_border` - Kartın çerçevelerini gizler _(boolean)_ -- `theme` - Temanın rengi [tüm temalar](./themes/README.md) -- `cache_seconds` - Manuel olarak cache'i belirleyebilirsiniz _(en az: 14400, en fazla: 86400)_ -- `locale` - Karttaki dili seçebilirsiniz _(örneğin; tr, cn, de, es, vb.)_ - -##### bg_color'da Gradient - -bg_color içerisinde birden fazla rengi gradient olarak göstermek için virgülle ayırarak kullanabilirsiniz. Gradient kullanımı için örnek format: - -``` -&bg_color=DEG,COLOR1,COLOR2,COLOR3...COLOR10 -``` - -> Cache Hakkında: Repo kartında fork ve yıldız sayısı 1.000'den küçükse varsayılan cache süresi 4 saat yani 14400 saniyedir. 1.000'den büyükse 2 saat yani 7200 saniyedir. Ayrıca, önbelleğin minimum 2 ve maksimum 24 saate sabitlendiğini unutmayın. - -#### İstatistik Karları Exclusive Özellikler: - -- `hide` - Spesifik özellikleri istatistiklerden gizleyebilirsiniz. _(Virgül ile ayırılmış değerlerle)_ -- `hide_title` - _(boolean)_ -- `hide_rank` - _(boolean)_ Sıralamayı gizler ve kartın genişliğini otomatik olarak tekrar düzenler -- `show_icons` - _(boolean)_ -- `include_all_commits` - _(boolean)_ Sadece bu yılın değil tüm zamanlarda yaptığınız commit sayısını gösterir -- `count_private` - _(boolean)_ Özel depolarda yaptığınız commitleri gösterir -- `line_height` - _(number)_ Satır arası yüksekliği belirler -- `custom_title` - Kart için istediğiniz bir başlığı belirler -- `disable_animations` - _(boolean)_ Kart içerisindeki tüm animasyonları kapatır - -#### Repo Kartları Exclusive Özellikler: - -- `show_owner` - _(boolean)_ Reponun sahibinin ismini gösterir - -#### Dil Kartları Exclusive Özellikler: - -- `hide` - Belirli bir dili listede gizler _(Virgül ile ayırılmış değerlerle)_ -- `hide_title` - _(boolean)_ -- `layout` - Beş uygun tasarım / düzen arasında geçiş yapın `normal` & `compact` & `donut` & `donut-vertical` & `pie` -- `card_width` - Kartın genişliğini manuel olarak belirler _(number)_ -- `langs_count` - 1-10 arasında istediğiniz kadar dil gösterebilirsiniz. Varsayılan: 5 _(number)_ -- `exclude_repo` - Belirli repoları listeden çıkartır _(Virgül ile ayırılmış değerlerle)_ -- `custom_title` - Kart için istediğiniz bir başlığı belirler - -> :warning: **Önemli:** -> Dİl isimleri [Percent Encoding](https://en.wikipedia.org/wiki/Percent-encoding)'te belirtildiği üzere uri-escaped olarak belirtilmelidir. -> (ör: `c++` yerine `c%2B%2B`, `jupyter notebook` yerine `jupyter%20notebook`, vb.) -> [urlencoder.org](https://www.urlencoder.org/) adresini kullanarak otomatik olarak değerleri bu şekle çevirebilirsiniz. - -#### WakaTime Kart Exclusive Özellikler: - -- `hide_title` - _(boolean)_ -- `line_height` - Satır aralığı yüksekliği _(number)_ -- `hide_progress` - Progresbarı ve yüzdeyi gizler _(boolean)_ -- `custom_title` - Kart için istediğiniz bir başlığı belirler -- `layout` - Uygun olan iki tasarım / layout arasında değişiklik yapar `default` & `compact` - ---- - -# GitHub Ekstra Pinler - -GitHub ekstra pinler profilinize 6'dan fazla repoyu / depoyu profilinizde pinleyebilirsiniz. - -Hey! Artık 6 pin ile kısıtlı kalmayacaksınız! - -### Kullanım - -Alttaki kodu kopyalayıp readme dosyanıza urlleri değiştirerek yapıştırın. - -Endpoint: `api/pin?username=mustafacagri&repo=github-readme-stats` - -```md -[![ReadMe Kartı](https://github-readme-stats.vercel.app/api/pin/?username=mustafacagri&repo=github-readme-stats)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Demo - -[![ReadMe Kartı](https://github-readme-stats.vercel.app/api/pin/?username=mustafacagri&repo=github-readme-stats)](https://github.com/anuraghazra/github-readme-stats) - -[show_owner](#özelleştirmeler) ile reponun sahibini gösterebilirsiniz. - -[![ReadMe Kartı](https://github-readme-stats.vercel.app/api/pin/?username=mustafacagri&repo=github-readme-stats&show_owner=true)](https://github.com/anuraghazra/github-readme-stats) - -# En Çok Kullanılan Diller - -En çok kullanılan diller kartı kullanıcının en çok kullandığı dilleri gösterir. - -_NOTE: En çok kullanılan dillerde yer alan bilgiler sizin yeteneğinizi ve benzeri şeyleri göstermek. Bu, kodlarınızda en çok kullandığınız dilleri gösteren bir GitHub metriğidir. Ayrıca, github-readme-stats'ın yeni özelliğidir. - -### Kullanım - -Alttaki kodu kopyalayıp readme dosyanıza urlleri değiştirerek yapıştırın. - -Endpoint: `api/top-langs?username=mustafacagri` - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=mustafacagri)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Belirli Repoları Çıkartın - -`?exclude_repo=repo1,repo2` parametresini kullanarak istediğiniz repoları çıkartabilirsiniz. - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&exclude_repo=github-readme-stats,anuraghazra.github.io)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Belirli Dilleri Çıkartın - -`?hide=language1,language2` parametresini kullanarak istediğiniz dilleri çıkartabilirsiniz. - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=mustafacagri&hide=javascript,html)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Daha Fazla Dil Gösterin - -`&langs_count=` parametresini kullanarak kartınızda gösterilen dil sayısını azaltabilir ya da artırabilirsiniz. Varsayılan değeri 5, kullanılabilir sayı aralığı ise 1-10'dur. - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=mustafacagri&langs_count=8)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Kompakt Dil Kartı Düzeni - -`&layout=compact` parametresiyle kart tasarımınızı değiştirebilirsiniz. - -```md -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=mustafacagri&layout=compact)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Demo - -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=mustafacagri)](https://github.com/anuraghazra/github-readme-stats) - -- Kompakt Düzen / Layout - -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=mustafacagri&layout=compact)](https://github.com/anuraghazra/github-readme-stats) - -# WakaTime Haftalık İstatistikler - -`?username=` değerini [WakaTime](https://wakatime.com)'daki kullanıcı adınızla değiştirin. - -```md -[![Harlok's WakaTime stats](https://github-readme-stats.vercel.app/api/wakatime?username=ffflabs)](https://github.com/anuraghazra/github-readme-stats) -``` - -### Demo - -[![Harlok's WakaTime stats](https://github-readme-stats.vercel.app/api/wakatime?username=ffflabs)](https://github.com/anuraghazra/github-readme-stats) - -[![Harlok's WakaTime stats](https://github-readme-stats.vercel.app/api/wakatime?username=ffflabs&hide_progress=true)](https://github.com/anuraghazra/github-readme-stats) - -- Kompakt Düzen - -[![Harlok's WakaTime stats](https://github-readme-stats.vercel.app/api/wakatime?username=ffflabs&layout=compact)](https://github.com/anuraghazra/github-readme-stats) - ---- - -### Tüm Demolar - -- Varsayılan - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra) - -- Belirli istatistikler gizli - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&hide=contribs,issues) - -- İkonlar gösteriliyor - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&hide=issues&show_icons=true) - -- Tüm commitler dahil - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&include_all_commits=true) - -- Temalar - -[default themes](#themes) adresinden istediğiniz temayı seçin. - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=mustafacagri&show_icons=true&theme=radical) - -- Gradient - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&bg_color=30,e96443,904e95&title_color=fff&text_color=fff) - -- İstatistik Kartını Düzenleyin - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api/?username=anuraghazra&show_icons=true&title_color=fff&icon_color=79ff97&text_color=9f9f9f&bg_color=151515) - -- Kartın dilini seçin - -![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api/?username=anuraghazra&locale=es) - -- Repo kartı düzenleyin - -![Customized Card](https://github-readme-stats.vercel.app/api/pin?username=anuraghazra&repo=github-readme-stats&title_color=fff&icon_color=f9f9f9&text_color=9f9f9f&bg_color=151515) - -- En çok kullanılan diller - -[![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) - -- WakaTime kart - -[![Harlok's WakaTime stats](https://github-readme-stats.vercel.app/api/wakatime?username=ffflabs)](https://github.com/anuraghazra/github-readme-stats) - ---- - -### Hızlı İpucu (Repo Kartları Hizlayın) - -Genellikle resimleri yan yana düzenleyemezsiniz. Bunu yapmak için şu yaklaşımı kullanabilirsiniz: - -```html - - - - - - -``` - -## Kendi Vercel Örneğinizde Yayınlayın - - -#### [@codeSTACKr'ın Yayınladığı Video Eğitimine Göz Atın](https://youtu.be/n6d4KHSKqGk?t=107) - -GitHub API saatte sadece 5.000 isteğe izin verdiği için `https://github-readme-stats.vercel.app/api` adresindeki API'm bu limite muhtemelen takılmış olabilir. Eğer projeyi kendi Vercel sunucunuzda yayınlarsanız, böyle bir sorun yaşamayabilirsiniz. Deploy butonuna tıkla ve deploy başlasın! - - -NOT: [#58](https://github.com/anuraghazra/github-readme-stats/pull/58) geliştirmesi sonrasında anlamadığımız bir şekilde 5.000 istek limitine takılmıyoruz :) - -[![Deploy to Vercel](https://vercel.com/button)](https://vercel.com/import/project?template=https://github.com/anuraghazra/github-readme-stats) - -

- Vercel Kurulum Rehberi 🔨 - -1. [vercel.com](https://vercel.com/) adresine gidin -1. `Log in`'e tıklayın - ![](https://files.catbox.moe/tct1wg.png) -1. `Continue with GitHub`'e basarak GitHub ile giriş yapın - ![](https://files.catbox.moe/btd78j.jpeg) -1. GitHub'a giriş yapın ve eğer çıkarsa tüm repolara izin verin. -1. Bu repoyu fork'layın -1. [Vercel dashboard](https://vercel.com/dashboard)'unuza geri dönün. -1. `Import Project`'i seçin. - ![](https://files.catbox.moe/qckos0.png) -1. `Import Git Repository`'yi seçin. - ![](https://files.catbox.moe/pqub9q.png) -1. Root'u seçin ve her şeyi olduğu gibi bırakın, [burada](https://github.com/settings/tokens/new) kolayca oluşturabileceğiniz kişisel bir erişim belirteci (personal access token) (PAT) içerecek olan PAT_1 adlı ortam değişkeninizi (gösterildiği gibi) ekleyin. (istediğiniz bir isim verin, çok da mühim değil açıkçası) - ![](https://files.catbox.moe/0ez4g7.png) -1. Deploy'u tıklayın ve hazırsınız. -Click deploy, and you're good to go. API'ı kullanmak için alanlarınızı (domainlerinizi) görün! - -
- -## :sparkling_heart: Projeyi Destekleyin - -Neredeyse yapabildiğim her şeyi açık kaynak yapıyorum ve bu projeleri kullanırken yardıma ihtiyacı olan herkese cevap vermeye çalışıyorum. Açıkçası, -bu zaman alıyor. Destekleriniz sayesinde bu hizmeti ücretsiz olarak kullanabilirsiniz. - -Ayrıca, bu projeyi kullanıyor ve memnunsanız veya sadece bir şeyler yaratmaya devam etmem için beni teşvik etmek istiyorsanız, bunu yapmanın birkaç yolu var: - - -- Readme'nizde github-readme-stats'ı kullanırken bu projeye uygun bir link verebilirsiniz. -- Projeye yıldız verebilir ve paylaşabilirsiniz :rocket: -- [![paypal.me/anuraghazra](https://ionicabizau.github.io/badges/paypal.svg)](https://www.paypal.me/anuraghazra) - PayPal ile tek seferlik bağış yapabilirsiniz. Muhtemelen bir ~~kahve~~ ya da çay :tea: alacağım. - -Teşekkürler! :heart: - ---- - -[![https://vercel.com?utm_source=github_readme_stats_team&utm_campaign=oss](../powered-by-vercel.svg)](https://vercel.com?utm_source=github_readme_stats_team&utm_campaign=oss) - - -Katkılara açığız! <3 - -:heart: ve JavaScript ile hazırlandı. diff --git a/readme.md b/readme.md index 363b008b2f8c2..87b2c4c2a2752 100644 --- a/readme.md +++ b/readme.md @@ -40,33 +40,8 @@ · Ask Question

-

- Français - · - 简体中文 - · - Español - · - Deutsch - · - 日本語 - · - Português Brasileiro - · - Italiano - · - 한국어 - · - Nederlands - · - नेपाली - · - Türkçe -

-

Please note that documentation translations may be outdated; try to use English documentation if possible.

-

Love the project? Please consider donating to help it improve!

From a92cc03e92719a88939ce7c8f466706e84b8ac9b Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov Date: Sun, 24 Aug 2025 17:00:08 +0300 Subject: [PATCH 006/265] docs: update cache info to the actual one inside readme (#4370) --- readme.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/readme.md b/readme.md index 87b2c4c2a2752..b6c3e36f004f9 100644 --- a/readme.md +++ b/readme.md @@ -277,7 +277,7 @@ You can customize the appearance of all your cards however you wish with URL par | `border_radius` | Corner rounding on the card. | number | `4.5` | > [!WARNING]\ -> We use caching to decrease the load on our servers (see ). Our cards have a default cache of 6 hours (21600 seconds). Also, note that the cache is clamped to a minimum of 6 hours and a maximum of 24 hours. If you want the data on your statistics card to be updated more often you can [deploy your own instance](#deploy-on-your-own) and set [environment variable](#disable-rate-limit-protections) `CACHE_SECONDS` to a value of your choosing. +> We use caching to decrease the load on our servers (see ). Our cards have the following default cache hours: stats card - 24 hours, top languages card - 144 hours (6 days), pin card - 240 hours (10 days), gist card - 48 hours (2 days). If you want the data on your statistics card to be updated more often you can [deploy your own instance](#deploy-on-your-own) and set [environment variable](#disable-rate-limit-protections) `CACHE_SECONDS` to a value of your choosing. ##### Gradient in bg\_color From 09cb2a596efd13fd5104160767a0fc61a1055a3c Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov Date: Sun, 24 Aug 2025 17:07:23 +0300 Subject: [PATCH 007/265] refactor: fix fetchers names by removing duplicating postfix (#4375) --- .github/labeler.yml | 10 +++++----- api/gist.js | 2 +- api/index.js | 2 +- api/pin.js | 2 +- api/top-langs.js | 2 +- api/wakatime.js | 2 +- src/fetchers/{gist-fetcher.js => gist.js} | 0 src/fetchers/{repo-fetcher.js => repo.js} | 0 src/fetchers/{stats-fetcher.js => stats.js} | 0 .../{top-languages-fetcher.js => top-languages.js} | 0 src/fetchers/{wakatime-fetcher.js => wakatime.js} | 0 tests/fetchGist.test.js | 2 +- tests/fetchRepo.test.js | 2 +- tests/fetchStats.test.js | 2 +- tests/fetchTopLanguages.test.js | 2 +- tests/fetchWakatime.test.js | 2 +- tests/renderGistCard.test.js | 2 +- 17 files changed, 16 insertions(+), 16 deletions(-) rename src/fetchers/{gist-fetcher.js => gist.js} (100%) rename src/fetchers/{repo-fetcher.js => repo.js} (100%) rename src/fetchers/{stats-fetcher.js => stats.js} (100%) rename src/fetchers/{top-languages-fetcher.js => top-languages.js} (100%) rename src/fetchers/{wakatime-fetcher.js => wakatime.js} (100%) diff --git a/.github/labeler.yml b/.github/labeler.yml index fa3c16eb87386..99c277c030165 100644 --- a/.github/labeler.yml +++ b/.github/labeler.yml @@ -28,7 +28,7 @@ lang-card: - any-glob-to-any-file: - api/top-langs.js - src/cards/top-languages-card.js - - src/fetchers/top-languages-fetcher.js + - src/fetchers/top-languages.js - tests/fetchTopLanguages.test.js - tests/renderTopLanguagesCard.test.js - tests/top-langs.test.js @@ -38,7 +38,7 @@ repo-card: - any-glob-to-any-file: - api/pin.js - src/cards/repo-card.js - - src/fetchers/repo-fetcher.js + - src/fetchers/repo.js - tests/fetchRepo.test.js - tests/renderRepoCard.test.js - tests/pin.test.js @@ -48,7 +48,7 @@ stats-card: - any-glob-to-any-file: - api/index.js - src/cards/stats-card.js - - src/fetchers/stats-fetcher.js + - src/fetchers/stats.js - tests/fetchStats.test.js - tests/renderStatsCard.test.js - tests/api.test.js @@ -58,7 +58,7 @@ wakatime-card: - any-glob-to-any-file: - api/wakatime.js - src/cards/wakatime-card.js - - src/fetchers/wakatime-fetcher.js + - src/fetchers/wakatime.js - tests/fetchWakatime.test.js - tests/renderWakatimeCard.test.js - tests/wakatime.test.js @@ -68,7 +68,7 @@ gist-card: - any-glob-to-any-file: - api/gist.js - src/cards/gist-card.js - - src/fetchers/gist-fetcher.js + - src/fetchers/gist.js - tests/fetchGist.test.js - tests/renderGistCard.test.js - tests/gist.test.js diff --git a/api/gist.js b/api/gist.js index 5b03743ce9e6e..560ce1a778e24 100644 --- a/api/gist.js +++ b/api/gist.js @@ -6,7 +6,7 @@ import { } from "../src/common/utils.js"; import { isLocaleAvailable } from "../src/translations.js"; import { renderGistCard } from "../src/cards/gist-card.js"; -import { fetchGist } from "../src/fetchers/gist-fetcher.js"; +import { fetchGist } from "../src/fetchers/gist.js"; export default async (req, res) => { const { diff --git a/api/index.js b/api/index.js index c42bc04891234..c57630ec7a815 100644 --- a/api/index.js +++ b/api/index.js @@ -7,7 +7,7 @@ import { parseBoolean, renderError, } from "../src/common/utils.js"; -import { fetchStats } from "../src/fetchers/stats-fetcher.js"; +import { fetchStats } from "../src/fetchers/stats.js"; import { isLocaleAvailable } from "../src/translations.js"; export default async (req, res) => { diff --git a/api/pin.js b/api/pin.js index bede7d87f5972..6629c29cfa2cb 100644 --- a/api/pin.js +++ b/api/pin.js @@ -6,7 +6,7 @@ import { parseBoolean, renderError, } from "../src/common/utils.js"; -import { fetchRepo } from "../src/fetchers/repo-fetcher.js"; +import { fetchRepo } from "../src/fetchers/repo.js"; import { isLocaleAvailable } from "../src/translations.js"; export default async (req, res) => { diff --git a/api/top-langs.js b/api/top-langs.js index c5bed634c1eab..8038b402a6587 100644 --- a/api/top-langs.js +++ b/api/top-langs.js @@ -6,7 +6,7 @@ import { parseBoolean, renderError, } from "../src/common/utils.js"; -import { fetchTopLanguages } from "../src/fetchers/top-languages-fetcher.js"; +import { fetchTopLanguages } from "../src/fetchers/top-languages.js"; import { isLocaleAvailable } from "../src/translations.js"; export default async (req, res) => { diff --git a/api/wakatime.js b/api/wakatime.js index 73ef9986feeb7..4807445c54172 100644 --- a/api/wakatime.js +++ b/api/wakatime.js @@ -6,7 +6,7 @@ import { parseBoolean, renderError, } from "../src/common/utils.js"; -import { fetchWakatimeStats } from "../src/fetchers/wakatime-fetcher.js"; +import { fetchWakatimeStats } from "../src/fetchers/wakatime.js"; import { isLocaleAvailable } from "../src/translations.js"; export default async (req, res) => { diff --git a/src/fetchers/gist-fetcher.js b/src/fetchers/gist.js similarity index 100% rename from src/fetchers/gist-fetcher.js rename to src/fetchers/gist.js diff --git a/src/fetchers/repo-fetcher.js b/src/fetchers/repo.js similarity index 100% rename from src/fetchers/repo-fetcher.js rename to src/fetchers/repo.js diff --git a/src/fetchers/stats-fetcher.js b/src/fetchers/stats.js similarity index 100% rename from src/fetchers/stats-fetcher.js rename to src/fetchers/stats.js diff --git a/src/fetchers/top-languages-fetcher.js b/src/fetchers/top-languages.js similarity index 100% rename from src/fetchers/top-languages-fetcher.js rename to src/fetchers/top-languages.js diff --git a/src/fetchers/wakatime-fetcher.js b/src/fetchers/wakatime.js similarity index 100% rename from src/fetchers/wakatime-fetcher.js rename to src/fetchers/wakatime.js diff --git a/tests/fetchGist.test.js b/tests/fetchGist.test.js index 13c29a8d2fc39..ee9be987137bf 100644 --- a/tests/fetchGist.test.js +++ b/tests/fetchGist.test.js @@ -2,7 +2,7 @@ import "@testing-library/jest-dom"; import axios from "axios"; import MockAdapter from "axios-mock-adapter"; import { expect, it, describe, afterEach } from "@jest/globals"; -import { fetchGist } from "../src/fetchers/gist-fetcher.js"; +import { fetchGist } from "../src/fetchers/gist.js"; const gist_data = { data: { diff --git a/tests/fetchRepo.test.js b/tests/fetchRepo.test.js index a980917f3d628..604b34b4f06ea 100644 --- a/tests/fetchRepo.test.js +++ b/tests/fetchRepo.test.js @@ -1,7 +1,7 @@ import "@testing-library/jest-dom"; import axios from "axios"; import MockAdapter from "axios-mock-adapter"; -import { fetchRepo } from "../src/fetchers/repo-fetcher.js"; +import { fetchRepo } from "../src/fetchers/repo.js"; import { expect, it, describe, afterEach } from "@jest/globals"; const data_repo = { diff --git a/tests/fetchStats.test.js b/tests/fetchStats.test.js index ca8d7bc37062e..06aefeddee1c9 100644 --- a/tests/fetchStats.test.js +++ b/tests/fetchStats.test.js @@ -2,7 +2,7 @@ import "@testing-library/jest-dom"; import axios from "axios"; import MockAdapter from "axios-mock-adapter"; import { calculateRank } from "../src/calculateRank.js"; -import { fetchStats } from "../src/fetchers/stats-fetcher.js"; +import { fetchStats } from "../src/fetchers/stats.js"; import { expect, it, describe, beforeEach, afterEach } from "@jest/globals"; // Test parameters. diff --git a/tests/fetchTopLanguages.test.js b/tests/fetchTopLanguages.test.js index e7bd54ac87d34..287c8ede23ce6 100644 --- a/tests/fetchTopLanguages.test.js +++ b/tests/fetchTopLanguages.test.js @@ -1,7 +1,7 @@ import "@testing-library/jest-dom"; import axios from "axios"; import MockAdapter from "axios-mock-adapter"; -import { fetchTopLanguages } from "../src/fetchers/top-languages-fetcher.js"; +import { fetchTopLanguages } from "../src/fetchers/top-languages.js"; import { expect, it, describe, afterEach } from "@jest/globals"; const mock = new MockAdapter(axios); diff --git a/tests/fetchWakatime.test.js b/tests/fetchWakatime.test.js index 8e24893dfe0fd..0cfbe4dfde577 100644 --- a/tests/fetchWakatime.test.js +++ b/tests/fetchWakatime.test.js @@ -1,7 +1,7 @@ import "@testing-library/jest-dom"; import axios from "axios"; import MockAdapter from "axios-mock-adapter"; -import { fetchWakatimeStats } from "../src/fetchers/wakatime-fetcher.js"; +import { fetchWakatimeStats } from "../src/fetchers/wakatime.js"; import { expect, it, describe, afterEach } from "@jest/globals"; const mock = new MockAdapter(axios); diff --git a/tests/renderGistCard.test.js b/tests/renderGistCard.test.js index f514bf6dc0d93..9545fdebdfdae 100644 --- a/tests/renderGistCard.test.js +++ b/tests/renderGistCard.test.js @@ -6,7 +6,7 @@ import { themes } from "../themes/index.js"; import "@testing-library/jest-dom"; /** - * @type {import("../src/fetchers/gist-fetcher").GistData} + * @type {import("../src/fetchers/gist").GistData} */ const data = { name: "test", From dd7582db8f27e409f74db3838d7379e6e54472ef Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov Date: Sun, 24 Aug 2025 17:14:18 +0300 Subject: [PATCH 008/265] refactor: fix cards files names by removing duplicating postfix (#4376) --- .github/labeler.yml | 10 +++++----- api/gist.js | 2 +- api/index.js | 2 +- api/pin.js | 2 +- api/top-langs.js | 2 +- api/wakatime.js | 2 +- src/cards/{gist-card.js => gist.js} | 0 src/cards/index.js | 8 ++++---- src/cards/{repo-card.js => repo.js} | 0 src/cards/{stats-card.js => stats.js} | 0 src/cards/{top-languages-card.js => top-languages.js} | 0 src/cards/{wakatime-card.js => wakatime.js} | 0 tests/api.test.js | 2 +- tests/e2e/e2e.test.js | 10 +++++----- tests/gist.test.js | 2 +- tests/pin.test.js | 2 +- tests/renderGistCard.test.js | 2 +- tests/renderRepoCard.test.js | 2 +- tests/renderStatsCard.test.js | 2 +- tests/renderTopLanguagesCard.test.js | 2 +- tests/renderWakatimeCard.test.js | 2 +- tests/top-langs.test.js | 2 +- tests/wakatime.test.js | 2 +- 23 files changed, 29 insertions(+), 29 deletions(-) rename src/cards/{gist-card.js => gist.js} (100%) rename src/cards/{repo-card.js => repo.js} (100%) rename src/cards/{stats-card.js => stats.js} (100%) rename src/cards/{top-languages-card.js => top-languages.js} (100%) rename src/cards/{wakatime-card.js => wakatime.js} (100%) diff --git a/.github/labeler.yml b/.github/labeler.yml index 99c277c030165..ec125284481e7 100644 --- a/.github/labeler.yml +++ b/.github/labeler.yml @@ -27,7 +27,7 @@ lang-card: - changed-files: - any-glob-to-any-file: - api/top-langs.js - - src/cards/top-languages-card.js + - src/cards/top-languages.js - src/fetchers/top-languages.js - tests/fetchTopLanguages.test.js - tests/renderTopLanguagesCard.test.js @@ -37,7 +37,7 @@ repo-card: - changed-files: - any-glob-to-any-file: - api/pin.js - - src/cards/repo-card.js + - src/cards/repo.js - src/fetchers/repo.js - tests/fetchRepo.test.js - tests/renderRepoCard.test.js @@ -47,7 +47,7 @@ stats-card: - changed-files: - any-glob-to-any-file: - api/index.js - - src/cards/stats-card.js + - src/cards/stats.js - src/fetchers/stats.js - tests/fetchStats.test.js - tests/renderStatsCard.test.js @@ -57,7 +57,7 @@ wakatime-card: - changed-files: - any-glob-to-any-file: - api/wakatime.js - - src/cards/wakatime-card.js + - src/cards/wakatime.js - src/fetchers/wakatime.js - tests/fetchWakatime.test.js - tests/renderWakatimeCard.test.js @@ -67,7 +67,7 @@ gist-card: - changed-files: - any-glob-to-any-file: - api/gist.js - - src/cards/gist-card.js + - src/cards/gist.js - src/fetchers/gist.js - tests/fetchGist.test.js - tests/renderGistCard.test.js diff --git a/api/gist.js b/api/gist.js index 560ce1a778e24..006977613a2b4 100644 --- a/api/gist.js +++ b/api/gist.js @@ -5,7 +5,7 @@ import { parseBoolean, } from "../src/common/utils.js"; import { isLocaleAvailable } from "../src/translations.js"; -import { renderGistCard } from "../src/cards/gist-card.js"; +import { renderGistCard } from "../src/cards/gist.js"; import { fetchGist } from "../src/fetchers/gist.js"; export default async (req, res) => { diff --git a/api/index.js b/api/index.js index c57630ec7a815..ef41fa139755f 100644 --- a/api/index.js +++ b/api/index.js @@ -1,4 +1,4 @@ -import { renderStatsCard } from "../src/cards/stats-card.js"; +import { renderStatsCard } from "../src/cards/stats.js"; import { blacklist } from "../src/common/blacklist.js"; import { clampValue, diff --git a/api/pin.js b/api/pin.js index 6629c29cfa2cb..b8fa617ba7860 100644 --- a/api/pin.js +++ b/api/pin.js @@ -1,4 +1,4 @@ -import { renderRepoCard } from "../src/cards/repo-card.js"; +import { renderRepoCard } from "../src/cards/repo.js"; import { blacklist } from "../src/common/blacklist.js"; import { clampValue, diff --git a/api/top-langs.js b/api/top-langs.js index 8038b402a6587..fe5fb4afc3cfb 100644 --- a/api/top-langs.js +++ b/api/top-langs.js @@ -1,4 +1,4 @@ -import { renderTopLanguages } from "../src/cards/top-languages-card.js"; +import { renderTopLanguages } from "../src/cards/top-languages.js"; import { blacklist } from "../src/common/blacklist.js"; import { CONSTANTS, diff --git a/api/wakatime.js b/api/wakatime.js index 4807445c54172..1517cc496011f 100644 --- a/api/wakatime.js +++ b/api/wakatime.js @@ -1,4 +1,4 @@ -import { renderWakatimeCard } from "../src/cards/wakatime-card.js"; +import { renderWakatimeCard } from "../src/cards/wakatime.js"; import { clampValue, CONSTANTS, diff --git a/src/cards/gist-card.js b/src/cards/gist.js similarity index 100% rename from src/cards/gist-card.js rename to src/cards/gist.js diff --git a/src/cards/index.js b/src/cards/index.js index f2c5fb0e3a143..5ca3a97adff02 100644 --- a/src/cards/index.js +++ b/src/cards/index.js @@ -1,4 +1,4 @@ -export { renderRepoCard } from "./repo-card.js"; -export { renderStatsCard } from "./stats-card.js"; -export { renderTopLanguages } from "./top-languages-card.js"; -export { renderWakatimeCard } from "./wakatime-card.js"; +export { renderRepoCard } from "./repo.js"; +export { renderStatsCard } from "./stats.js"; +export { renderTopLanguages } from "./top-languages.js"; +export { renderWakatimeCard } from "./wakatime.js"; diff --git a/src/cards/repo-card.js b/src/cards/repo.js similarity index 100% rename from src/cards/repo-card.js rename to src/cards/repo.js diff --git a/src/cards/stats-card.js b/src/cards/stats.js similarity index 100% rename from src/cards/stats-card.js rename to src/cards/stats.js diff --git a/src/cards/top-languages-card.js b/src/cards/top-languages.js similarity index 100% rename from src/cards/top-languages-card.js rename to src/cards/top-languages.js diff --git a/src/cards/wakatime-card.js b/src/cards/wakatime.js similarity index 100% rename from src/cards/wakatime-card.js rename to src/cards/wakatime.js diff --git a/tests/api.test.js b/tests/api.test.js index 1073014fedbd7..1b576b19b24d4 100644 --- a/tests/api.test.js +++ b/tests/api.test.js @@ -3,7 +3,7 @@ import axios from "axios"; import MockAdapter from "axios-mock-adapter"; import api from "../api/index.js"; import { calculateRank } from "../src/calculateRank.js"; -import { renderStatsCard } from "../src/cards/stats-card.js"; +import { renderStatsCard } from "../src/cards/stats.js"; import { CONSTANTS, renderError } from "../src/common/utils.js"; import { expect, it, describe, afterEach } from "@jest/globals"; diff --git a/tests/e2e/e2e.test.js b/tests/e2e/e2e.test.js index 196a89742ecaf..e3970aae285fd 100644 --- a/tests/e2e/e2e.test.js +++ b/tests/e2e/e2e.test.js @@ -5,11 +5,11 @@ import dotenv from "dotenv"; dotenv.config(); import axios from "axios"; -import { renderRepoCard } from "../../src/cards/repo-card.js"; -import { renderStatsCard } from "../../src/cards/stats-card.js"; -import { renderTopLanguages } from "../../src/cards/top-languages-card.js"; -import { renderWakatimeCard } from "../../src/cards/wakatime-card.js"; -import { renderGistCard } from "../../src/cards/gist-card.js"; +import { renderRepoCard } from "../../src/cards/repo.js"; +import { renderStatsCard } from "../../src/cards/stats.js"; +import { renderTopLanguages } from "../../src/cards/top-languages.js"; +import { renderWakatimeCard } from "../../src/cards/wakatime.js"; +import { renderGistCard } from "../../src/cards/gist.js"; import { expect, describe, beforeAll, test } from "@jest/globals"; const REPO = "curly-fiesta"; diff --git a/tests/gist.test.js b/tests/gist.test.js index 8c717d64d1aa1..fdbf9cf5fc642 100644 --- a/tests/gist.test.js +++ b/tests/gist.test.js @@ -3,7 +3,7 @@ import "@testing-library/jest-dom"; import axios from "axios"; import MockAdapter from "axios-mock-adapter"; import { expect, it, describe, afterEach } from "@jest/globals"; -import { renderGistCard } from "../src/cards/gist-card.js"; +import { renderGistCard } from "../src/cards/gist.js"; import { CONSTANTS, renderError } from "../src/common/utils.js"; import gist from "../api/gist.js"; diff --git a/tests/pin.test.js b/tests/pin.test.js index 5fe21ffe9c75a..e9adcaa8d384b 100644 --- a/tests/pin.test.js +++ b/tests/pin.test.js @@ -3,7 +3,7 @@ import "@testing-library/jest-dom"; import axios from "axios"; import MockAdapter from "axios-mock-adapter"; import pin from "../api/pin.js"; -import { renderRepoCard } from "../src/cards/repo-card.js"; +import { renderRepoCard } from "../src/cards/repo.js"; import { CONSTANTS, renderError } from "../src/common/utils.js"; import { expect, it, describe, afterEach } from "@jest/globals"; diff --git a/tests/renderGistCard.test.js b/tests/renderGistCard.test.js index 9545fdebdfdae..9d3600522d42f 100644 --- a/tests/renderGistCard.test.js +++ b/tests/renderGistCard.test.js @@ -1,4 +1,4 @@ -import { renderGistCard } from "../src/cards/gist-card"; +import { renderGistCard } from "../src/cards/gist.js"; import { describe, expect, it } from "@jest/globals"; import { queryByTestId } from "@testing-library/dom"; import { cssToObject } from "@uppercod/css-to-object"; diff --git a/tests/renderRepoCard.test.js b/tests/renderRepoCard.test.js index abbad4dbe2a3b..04c1090db758a 100644 --- a/tests/renderRepoCard.test.js +++ b/tests/renderRepoCard.test.js @@ -1,7 +1,7 @@ import { queryByTestId } from "@testing-library/dom"; import "@testing-library/jest-dom"; import { cssToObject } from "@uppercod/css-to-object"; -import { renderRepoCard } from "../src/cards/repo-card.js"; +import { renderRepoCard } from "../src/cards/repo.js"; import { expect, it, describe } from "@jest/globals"; import { themes } from "../themes/index.js"; diff --git a/tests/renderStatsCard.test.js b/tests/renderStatsCard.test.js index 973ee0a5a5db6..dab0f86178978 100644 --- a/tests/renderStatsCard.test.js +++ b/tests/renderStatsCard.test.js @@ -4,7 +4,7 @@ import { queryByTestId, } from "@testing-library/dom"; import { cssToObject } from "@uppercod/css-to-object"; -import { renderStatsCard } from "../src/cards/stats-card.js"; +import { renderStatsCard } from "../src/cards/stats.js"; import { expect, it, describe } from "@jest/globals"; import { CustomError } from "../src/common/utils.js"; diff --git a/tests/renderTopLanguagesCard.test.js b/tests/renderTopLanguagesCard.test.js index 8d67c3fb8ab98..55965da066517 100644 --- a/tests/renderTopLanguagesCard.test.js +++ b/tests/renderTopLanguagesCard.test.js @@ -17,7 +17,7 @@ import { renderTopLanguages, MIN_CARD_WIDTH, getDefaultLanguagesCountByLayout, -} from "../src/cards/top-languages-card.js"; +} from "../src/cards/top-languages.js"; import { expect, it, describe } from "@jest/globals"; // adds special assertions like toHaveTextContent diff --git a/tests/renderWakatimeCard.test.js b/tests/renderWakatimeCard.test.js index 7c3710758c5ec..7a3b85bf728bf 100644 --- a/tests/renderWakatimeCard.test.js +++ b/tests/renderWakatimeCard.test.js @@ -1,6 +1,6 @@ import { queryByTestId } from "@testing-library/dom"; import "@testing-library/jest-dom"; -import { renderWakatimeCard } from "../src/cards/wakatime-card.js"; +import { renderWakatimeCard } from "../src/cards/wakatime.js"; import { getCardColors } from "../src/common/utils.js"; import { wakaTimeData } from "./fetchWakatime.test.js"; import { expect, it, describe } from "@jest/globals"; diff --git a/tests/top-langs.test.js b/tests/top-langs.test.js index 907d4bc1275ab..62d4f7a0a71ef 100644 --- a/tests/top-langs.test.js +++ b/tests/top-langs.test.js @@ -3,7 +3,7 @@ import "@testing-library/jest-dom"; import axios from "axios"; import MockAdapter from "axios-mock-adapter"; import topLangs from "../api/top-langs.js"; -import { renderTopLanguages } from "../src/cards/top-languages-card.js"; +import { renderTopLanguages } from "../src/cards/top-languages.js"; import { CONSTANTS, renderError } from "../src/common/utils.js"; import { expect, it, describe, afterEach } from "@jest/globals"; diff --git a/tests/wakatime.test.js b/tests/wakatime.test.js index 944c3e020dd38..ade0dc2b96e54 100644 --- a/tests/wakatime.test.js +++ b/tests/wakatime.test.js @@ -3,7 +3,7 @@ import "@testing-library/jest-dom"; import axios from "axios"; import MockAdapter from "axios-mock-adapter"; import wakatime from "../api/wakatime.js"; -import { renderWakatimeCard } from "../src/cards/wakatime-card.js"; +import { renderWakatimeCard } from "../src/cards/wakatime.js"; import { expect, it, describe, afterEach } from "@jest/globals"; const wakaTimeData = { From 070dbd312c0026d5708e7f3003c63f316e5448dc Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov Date: Sun, 24 Aug 2025 17:25:46 +0300 Subject: [PATCH 009/265] ci: remove redundant checkout step from prs cache clean workflow (#3655) --- .github/workflows/prs-cache-clean.yml | 3 --- 1 file changed, 3 deletions(-) diff --git a/.github/workflows/prs-cache-clean.yml b/.github/workflows/prs-cache-clean.yml index 05cd3cad9a090..9f45918992d01 100644 --- a/.github/workflows/prs-cache-clean.yml +++ b/.github/workflows/prs-cache-clean.yml @@ -22,9 +22,6 @@ jobs: cleanup: runs-on: ubuntu-latest steps: - - name: Checkout - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 - - name: Cleanup run: | gh extension install actions/gh-actions-cache From 411e799d1dcc9409ac47aff52eb1b3fc68101fb9 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov Date: Sun, 24 Aug 2025 17:39:04 +0300 Subject: [PATCH 010/265] tests(wakatime card): fix correct render test (#3506) --- .../renderWakatimeCard.test.js.snap | 158 +++++++++++++++++- tests/renderWakatimeCard.test.js | 5 +- 2 files changed, 159 insertions(+), 4 deletions(-) diff --git a/tests/__snapshots__/renderWakatimeCard.test.js.snap b/tests/__snapshots__/renderWakatimeCard.test.js.snap index f38ac26ef07f7..28329af7edba4 100644 --- a/tests/__snapshots__/renderWakatimeCard.test.js.snap +++ b/tests/__snapshots__/renderWakatimeCard.test.js.snap @@ -1,6 +1,162 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP -exports[`Test Render WakaTime Card should render correctly 1`] = `[Function]`; +exports[`Test Render WakaTime Card should render correctly 1`] = ` +" + + + + + + + + + + + + + WakaTime Stats (last 7 days) + + + + + + + + + + Other: + 19 mins + + + + + + + + + + + + TypeScript: + 1 min + + + + + + + + + + + + + + + " +`; exports[`Test Render WakaTime Card should render correctly with compact layout 1`] = ` " diff --git a/tests/renderWakatimeCard.test.js b/tests/renderWakatimeCard.test.js index 7a3b85bf728bf..1efa4cfc20c84 100644 --- a/tests/renderWakatimeCard.test.js +++ b/tests/renderWakatimeCard.test.js @@ -1,14 +1,13 @@ import { queryByTestId } from "@testing-library/dom"; import "@testing-library/jest-dom"; import { renderWakatimeCard } from "../src/cards/wakatime.js"; -import { getCardColors } from "../src/common/utils.js"; import { wakaTimeData } from "./fetchWakatime.test.js"; import { expect, it, describe } from "@jest/globals"; describe("Test Render WakaTime Card", () => { it("should render correctly", () => { - // const card = renderWakatimeCard(wakaTimeData.data); - expect(getCardColors).toMatchSnapshot(); + const card = renderWakatimeCard(wakaTimeData.data); + expect(card).toMatchSnapshot(); }); it("should render correctly with compact layout", () => { From bbadc0b212c28110e1912485b556f7cfc533a010 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov Date: Sun, 24 Aug 2025 17:44:45 +0300 Subject: [PATCH 011/265] tests(wakatime card): add percent display format test (#3505) --- .../renderWakatimeCard.test.js.snap | 158 ++++++++++++++++++ tests/renderWakatimeCard.test.js | 7 + 2 files changed, 165 insertions(+) diff --git a/tests/__snapshots__/renderWakatimeCard.test.js.snap b/tests/__snapshots__/renderWakatimeCard.test.js.snap index 28329af7edba4..3727c36a39449 100644 --- a/tests/__snapshots__/renderWakatimeCard.test.js.snap +++ b/tests/__snapshots__/renderWakatimeCard.test.js.snap @@ -461,3 +461,161 @@ exports[`Test Render WakaTime Card should render correctly with compact layout w " `; + +exports[`Test Render WakaTime Card should render correctly with percent display format 1`] = ` +" + + + + + + + + + + + + + WakaTime Stats (last 7 days) + + + + + + + + + + Other: + 47.39 % + + + + + + + + + + + + TypeScript: + 50.48 % + + + + + + + + + + + + + + + " +`; diff --git a/tests/renderWakatimeCard.test.js b/tests/renderWakatimeCard.test.js index 1efa4cfc20c84..ca2381485b480 100644 --- a/tests/renderWakatimeCard.test.js +++ b/tests/renderWakatimeCard.test.js @@ -82,4 +82,11 @@ describe("Test Render WakaTime Card", () => { "No coding activity this week", ); }); + + it("should render correctly with percent display format", () => { + const card = renderWakatimeCard(wakaTimeData.data, { + display_format: "percent", + }); + expect(card).toMatchSnapshot(); + }); }); From 5ecf80b4d2a300c776fdd7c0d51cf77a7d7a0cbc Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov Date: Sun, 24 Aug 2025 18:02:00 +0300 Subject: [PATCH 012/265] ci: add theme prs closer workflow (#3534) * ci: add theme prs closer workflow * permissions --- .github/workflows/theme-prs-closer.yml | 41 ++++++++++++++++++++++++++ 1 file changed, 41 insertions(+) create mode 100644 .github/workflows/theme-prs-closer.yml diff --git a/.github/workflows/theme-prs-closer.yml b/.github/workflows/theme-prs-closer.yml new file mode 100644 index 0000000000000..13ca8488adc69 --- /dev/null +++ b/.github/workflows/theme-prs-closer.yml @@ -0,0 +1,41 @@ +name: Theme Pull Requests Closer + +on: + pull_request: + types: + - labeled + +permissions: + actions: read + checks: read + contents: read + deployments: read + issues: read + discussions: read + packages: read + pages: read + pull-requests: write + repository-projects: read + security-events: read + statuses: read + +jobs: + close-prs: + runs-on: ubuntu-latest + + steps: + - name: Check out the code + uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 + + - name: Set up Git + run: | + git config user.name "github-actions[bot]" + git config user.email "github-actions[bot]@users.noreply.github.com" + + - name: Close Pull Requests + run: | + comment_message="We are currently pausing addition of new themes. If this theme is exclusively for your personal use, then instead of adding it to our theme collection, you can use card customization options." + + for pr_number in $(gh pr list -l "themes" -q is:open --json number -q ".[].number"); do + gh pr close $pr_number -c "$comment_message" + done From 0015129e2ccad9d05466eea78e0f9b9d5e4da199 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Sun, 24 Aug 2025 20:37:48 +0300 Subject: [PATCH 013/265] build(deps-dev): bump jest-environment-jsdom from 29.7.0 to 30.0.5 (#4358) Bumps [jest-environment-jsdom](https://github.com/jestjs/jest/tree/HEAD/packages/jest-environment-jsdom) from 29.7.0 to 30.0.5. - [Release notes](https://github.com/jestjs/jest/releases) - [Changelog](https://github.com/jestjs/jest/blob/main/CHANGELOG.md) - [Commits](https://github.com/jestjs/jest/commits/v30.0.5/packages/jest-environment-jsdom) --- updated-dependencies: - dependency-name: jest-environment-jsdom dependency-version: 30.0.5 dependency-type: direct:development update-type: version-update:semver-major ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- package-lock.json | 2227 ++++++++++++++++++++++++++------------------- package.json | 2 +- 2 files changed, 1293 insertions(+), 936 deletions(-) diff --git a/package-lock.json b/package-lock.json index 597a9abfe82dd..5699e7969d81e 100644 --- a/package-lock.json +++ b/package-lock.json @@ -34,7 +34,7 @@ "husky": "^9.1.7", "jest": "^29.7.0", "jest-bench": "^29.7.1", - "jest-environment-jsdom": "^29.7.0", + "jest-environment-jsdom": "^30.0.5", "js-yaml": "^4.1.0", "lint-staged": "^15.5.1", "lodash.snakecase": "^4.1.1", @@ -124,88 +124,37 @@ "node": ">=6.0.0" } }, - "node_modules/@babel/code-frame": { - "version": "7.22.13", - "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.22.13.tgz", - "integrity": "sha512-XktuhWlJ5g+3TJXc5upd9Ks1HutSArik6jf2eAjYFyIOf4ej3RN+184cZbzDvbPnuTJIUhPKKJE3cIsYTiAT3w==", - "dev": true, - "dependencies": { - "@babel/highlight": "^7.22.13", - "chalk": "^2.4.2" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/code-frame/node_modules/ansi-styles": { - "version": "3.2.1", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", - "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", - "dev": true, - "dependencies": { - "color-convert": "^1.9.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/@babel/code-frame/node_modules/chalk": { - "version": "2.4.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", - "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", - "dev": true, - "dependencies": { - "ansi-styles": "^3.2.1", - "escape-string-regexp": "^1.0.5", - "supports-color": "^5.3.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/@babel/code-frame/node_modules/color-convert": { - "version": "1.9.3", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", - "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", + "node_modules/@asamuzakjp/css-color": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/@asamuzakjp/css-color/-/css-color-3.2.0.tgz", + "integrity": "sha512-K1A6z8tS3XsmCMM86xoWdn7Fkdn9m6RSVtocUrJYIwZnFVkng/PvkEoWtOWmP+Scc6saYWHWZYbndEEXxl24jw==", "dev": true, "dependencies": { - "color-name": "1.1.3" + "@csstools/css-calc": "^2.1.3", + "@csstools/css-color-parser": "^3.0.9", + "@csstools/css-parser-algorithms": "^3.0.4", + "@csstools/css-tokenizer": "^3.0.3", + "lru-cache": "^10.4.3" } }, - "node_modules/@babel/code-frame/node_modules/color-name": { - "version": "1.1.3", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", - "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", + "node_modules/@asamuzakjp/css-color/node_modules/lru-cache": { + "version": "10.4.3", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-10.4.3.tgz", + "integrity": "sha512-JNAzZcXrCt42VGLuYz0zfAzDfAvJWW6AfYlDBQyDV5DClI2m5sAmK+OIO7s59XfsRsWHp02jAJrRadPRGTt6SQ==", "dev": true }, - "node_modules/@babel/code-frame/node_modules/escape-string-regexp": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", - "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", - "dev": true, - "engines": { - "node": ">=0.8.0" - } - }, - "node_modules/@babel/code-frame/node_modules/has-flag": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", - "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", - "dev": true, - "engines": { - "node": ">=4" - } - }, - "node_modules/@babel/code-frame/node_modules/supports-color": { - "version": "5.5.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", - "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", + "node_modules/@babel/code-frame": { + "version": "7.27.1", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.27.1.tgz", + "integrity": "sha512-cjQ7ZlQ0Mv3b47hABuTevyTuYN4i+loJKGeV9flcCgIK37cCXRh+L1bd3iBHlynerhQ7BhCkn2BPbQUL+rGqFg==", "dev": true, "dependencies": { - "has-flag": "^3.0.0" + "@babel/helper-validator-identifier": "^7.27.1", + "js-tokens": "^4.0.0", + "picocolors": "^1.1.1" }, "engines": { - "node": ">=4" + "node": ">=6.9.0" } }, "node_modules/@babel/compat-data": { @@ -395,9 +344,9 @@ } }, "node_modules/@babel/helper-validator-identifier": { - "version": "7.22.20", - "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.22.20.tgz", - "integrity": "sha512-Y4OZ+ytlatR8AI+8KZfKuL5urKp7qey08ha31L8b3BwewJAoJamTzyvxPR/5D+KkdJCGPq/+8TukHBlY10FX9A==", + "version": "7.27.1", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.27.1.tgz", + "integrity": "sha512-D2hP9eA+Sqx1kBZgzxZh0y1trbuU+JoDkiEwqhQ36nodYqJwyEIhPSdMNd7lOm/4io72luTPWH20Yda0xOuUow==", "dev": true, "engines": { "node": ">=6.9.0" @@ -426,91 +375,6 @@ "node": ">=6.9.0" } }, - "node_modules/@babel/highlight": { - "version": "7.22.20", - "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.22.20.tgz", - "integrity": "sha512-dkdMCN3py0+ksCgYmGG8jKeGA/8Tk+gJwSYYlFGxG5lmhfKNoAy004YpLxpS1W2J8m/EK2Ew+yOs9pVRwO89mg==", - "dev": true, - "dependencies": { - "@babel/helper-validator-identifier": "^7.22.20", - "chalk": "^2.4.2", - "js-tokens": "^4.0.0" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/highlight/node_modules/ansi-styles": { - "version": "3.2.1", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", - "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", - "dev": true, - "dependencies": { - "color-convert": "^1.9.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/@babel/highlight/node_modules/chalk": { - "version": "2.4.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", - "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", - "dev": true, - "dependencies": { - "ansi-styles": "^3.2.1", - "escape-string-regexp": "^1.0.5", - "supports-color": "^5.3.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/@babel/highlight/node_modules/color-convert": { - "version": "1.9.3", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", - "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", - "dev": true, - "dependencies": { - "color-name": "1.1.3" - } - }, - "node_modules/@babel/highlight/node_modules/color-name": { - "version": "1.1.3", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", - "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", - "dev": true - }, - "node_modules/@babel/highlight/node_modules/escape-string-regexp": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", - "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", - "dev": true, - "engines": { - "node": ">=0.8.0" - } - }, - "node_modules/@babel/highlight/node_modules/has-flag": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", - "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", - "dev": true, - "engines": { - "node": ">=4" - } - }, - "node_modules/@babel/highlight/node_modules/supports-color": { - "version": "5.5.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", - "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", - "dev": true, - "dependencies": { - "has-flag": "^3.0.0" - }, - "engines": { - "node": ">=4" - } - }, "node_modules/@babel/parser": { "version": "7.23.0", "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.23.0.tgz", @@ -776,6 +640,116 @@ "integrity": "sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw==", "dev": true }, + "node_modules/@csstools/color-helpers": { + "version": "5.0.2", + "resolved": "https://registry.npmjs.org/@csstools/color-helpers/-/color-helpers-5.0.2.tgz", + "integrity": "sha512-JqWH1vsgdGcw2RR6VliXXdA0/59LttzlU8UlRT/iUUsEeWfYq8I+K0yhihEUTTHLRm1EXvpsCx3083EU15ecsA==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "engines": { + "node": ">=18" + } + }, + "node_modules/@csstools/css-calc": { + "version": "2.1.4", + "resolved": "https://registry.npmjs.org/@csstools/css-calc/-/css-calc-2.1.4.tgz", + "integrity": "sha512-3N8oaj+0juUw/1H3YwmDDJXCgTB1gKU6Hc/bB502u9zR0q2vd786XJH9QfrKIEgFlZmhZiq6epXl4rHqhzsIgQ==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "engines": { + "node": ">=18" + }, + "peerDependencies": { + "@csstools/css-parser-algorithms": "^3.0.5", + "@csstools/css-tokenizer": "^3.0.4" + } + }, + "node_modules/@csstools/css-color-parser": { + "version": "3.0.10", + "resolved": "https://registry.npmjs.org/@csstools/css-color-parser/-/css-color-parser-3.0.10.tgz", + "integrity": "sha512-TiJ5Ajr6WRd1r8HSiwJvZBiJOqtH86aHpUjq5aEKWHiII2Qfjqd/HCWKPOW8EP4vcspXbHnXrwIDlu5savQipg==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "@csstools/color-helpers": "^5.0.2", + "@csstools/css-calc": "^2.1.4" + }, + "engines": { + "node": ">=18" + }, + "peerDependencies": { + "@csstools/css-parser-algorithms": "^3.0.5", + "@csstools/css-tokenizer": "^3.0.4" + } + }, + "node_modules/@csstools/css-parser-algorithms": { + "version": "3.0.5", + "resolved": "https://registry.npmjs.org/@csstools/css-parser-algorithms/-/css-parser-algorithms-3.0.5.tgz", + "integrity": "sha512-DaDeUkXZKjdGhgYaHNJTV9pV7Y9B3b644jCLs9Upc3VeNGg6LWARAT6O+Q+/COo+2gg/bM5rhpMAtf70WqfBdQ==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "engines": { + "node": ">=18" + }, + "peerDependencies": { + "@csstools/css-tokenizer": "^3.0.4" + } + }, + "node_modules/@csstools/css-tokenizer": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/@csstools/css-tokenizer/-/css-tokenizer-3.0.4.tgz", + "integrity": "sha512-Vd/9EVDiu6PPJt9yAh6roZP6El1xHrdvIVGjyBsHR0RYwNHgL7FJPyIIW4fANJNG6FtyZfvlRPpFI4ZM/lubvw==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "engines": { + "node": ">=18" + } + }, "node_modules/@es-joy/jsdoccomment": { "version": "0.50.2", "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.50.2.tgz", @@ -1185,6 +1159,220 @@ "node": "^14.15.0 || ^16.10.0 || >=18.0.0" } }, + "node_modules/@jest/environment-jsdom-abstract": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/@jest/environment-jsdom-abstract/-/environment-jsdom-abstract-30.0.5.tgz", + "integrity": "sha512-gpWwiVxZunkoglP8DCnT3As9x5O8H6gveAOpvaJd2ATAoSh7ZSSCWbr9LQtUMvr8WD3VjG9YnDhsmkCK5WN1rQ==", + "dev": true, + "dependencies": { + "@jest/environment": "30.0.5", + "@jest/fake-timers": "30.0.5", + "@jest/types": "30.0.5", + "@types/jsdom": "^21.1.7", + "@types/node": "*", + "jest-mock": "30.0.5", + "jest-util": "30.0.5" + }, + "engines": { + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" + }, + "peerDependencies": { + "canvas": "^3.0.0", + "jsdom": "*" + }, + "peerDependenciesMeta": { + "canvas": { + "optional": true + } + } + }, + "node_modules/@jest/environment-jsdom-abstract/node_modules/@jest/environment": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-30.0.5.tgz", + "integrity": "sha512-aRX7WoaWx1oaOkDQvCWImVQ8XNtdv5sEWgk4gxR6NXb7WBUnL5sRak4WRzIQRZ1VTWPvV4VI4mgGjNL9TeKMYA==", + "dev": true, + "dependencies": { + "@jest/fake-timers": "30.0.5", + "@jest/types": "30.0.5", + "@types/node": "*", + "jest-mock": "30.0.5" + }, + "engines": { + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" + } + }, + "node_modules/@jest/environment-jsdom-abstract/node_modules/@jest/fake-timers": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-30.0.5.tgz", + "integrity": "sha512-ZO5DHfNV+kgEAeP3gK3XlpJLL4U3Sz6ebl/n68Uwt64qFFs5bv4bfEEjyRGK5uM0C90ewooNgFuKMdkbEoMEXw==", + "dev": true, + "dependencies": { + "@jest/types": "30.0.5", + "@sinonjs/fake-timers": "^13.0.0", + "@types/node": "*", + "jest-message-util": "30.0.5", + "jest-mock": "30.0.5", + "jest-util": "30.0.5" + }, + "engines": { + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" + } + }, + "node_modules/@jest/environment-jsdom-abstract/node_modules/@jest/schemas": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/@jest/schemas/-/schemas-30.0.5.tgz", + "integrity": "sha512-DmdYgtezMkh3cpU8/1uyXakv3tJRcmcXxBOcO0tbaozPwpmh4YMsnWrQm9ZmZMfa5ocbxzbFk6O4bDPEc/iAnA==", + "dev": true, + "dependencies": { + "@sinclair/typebox": "^0.34.0" + }, + "engines": { + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" + } + }, + "node_modules/@jest/environment-jsdom-abstract/node_modules/@jest/types": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/@jest/types/-/types-30.0.5.tgz", + "integrity": "sha512-aREYa3aku9SSnea4aX6bhKn4bgv3AXkgijoQgbYV3yvbiGt6z+MQ85+6mIhx9DsKW2BuB/cLR/A+tcMThx+KLQ==", + "dev": true, + "dependencies": { + "@jest/pattern": "30.0.1", + "@jest/schemas": "30.0.5", + "@types/istanbul-lib-coverage": "^2.0.6", + "@types/istanbul-reports": "^3.0.4", + "@types/node": "*", + "@types/yargs": "^17.0.33", + "chalk": "^4.1.2" + }, + "engines": { + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" + } + }, + "node_modules/@jest/environment-jsdom-abstract/node_modules/@sinclair/typebox": { + "version": "0.34.38", + "resolved": "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.34.38.tgz", + "integrity": "sha512-HpkxMmc2XmZKhvaKIZZThlHmx1L0I/V1hWK1NubtlFnr6ZqdiOpV72TKudZUNQjZNsyDBay72qFEhEvb+bcwcA==", + "dev": true + }, + "node_modules/@jest/environment-jsdom-abstract/node_modules/@sinonjs/fake-timers": { + "version": "13.0.5", + "resolved": "https://registry.npmjs.org/@sinonjs/fake-timers/-/fake-timers-13.0.5.tgz", + "integrity": "sha512-36/hTbH2uaWuGVERyC6da9YwGWnzUZXuPro/F2LfsdOsLnCojz/iSH8MxUt/FD2S5XBSVPhmArFUXcpCQ2Hkiw==", + "dev": true, + "dependencies": { + "@sinonjs/commons": "^3.0.1" + } + }, + "node_modules/@jest/environment-jsdom-abstract/node_modules/ansi-styles": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz", + "integrity": "sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==", + "dev": true, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, + "node_modules/@jest/environment-jsdom-abstract/node_modules/ci-info": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-4.3.0.tgz", + "integrity": "sha512-l+2bNRMiQgcfILUi33labAZYIWlH1kWDp+ecNo5iisRKrbm0xcRyCww71/YU0Fkw0mAFpz9bJayXPjey6vkmaQ==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/sibiraj-s" + } + ], + "engines": { + "node": ">=8" + } + }, + "node_modules/@jest/environment-jsdom-abstract/node_modules/jest-message-util": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-30.0.5.tgz", + "integrity": "sha512-NAiDOhsK3V7RU0Aa/HnrQo+E4JlbarbmI3q6Pi4KcxicdtjV82gcIUrejOtczChtVQR4kddu1E1EJlW6EN9IyA==", + "dev": true, + "dependencies": { + "@babel/code-frame": "^7.27.1", + "@jest/types": "30.0.5", + "@types/stack-utils": "^2.0.3", + "chalk": "^4.1.2", + "graceful-fs": "^4.2.11", + "micromatch": "^4.0.8", + "pretty-format": "30.0.5", + "slash": "^3.0.0", + "stack-utils": "^2.0.6" + }, + "engines": { + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" + } + }, + "node_modules/@jest/environment-jsdom-abstract/node_modules/jest-mock": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-30.0.5.tgz", + "integrity": "sha512-Od7TyasAAQX/6S+QCbN6vZoWOMwlTtzzGuxJku1GhGanAjz9y+QsQkpScDmETvdc9aSXyJ/Op4rhpMYBWW91wQ==", + "dev": true, + "dependencies": { + "@jest/types": "30.0.5", + "@types/node": "*", + "jest-util": "30.0.5" + }, + "engines": { + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" + } + }, + "node_modules/@jest/environment-jsdom-abstract/node_modules/jest-util": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-30.0.5.tgz", + "integrity": "sha512-pvyPWssDZR0FlfMxCBoc0tvM8iUEskaRFALUtGQYzVEAqisAztmy+R8LnU14KT4XA0H/a5HMVTXat1jLne010g==", + "dev": true, + "dependencies": { + "@jest/types": "30.0.5", + "@types/node": "*", + "chalk": "^4.1.2", + "ci-info": "^4.2.0", + "graceful-fs": "^4.2.11", + "picomatch": "^4.0.2" + }, + "engines": { + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" + } + }, + "node_modules/@jest/environment-jsdom-abstract/node_modules/picomatch": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-4.0.3.tgz", + "integrity": "sha512-5gTmgEY/sqK6gFXLIsQNH19lWb4ebPDLA4SdLP7dsWkIXHWlG66oPuVvXSGFPppYZz8ZDZq0dYYrbHfBCVUb1Q==", + "dev": true, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/sponsors/jonschlinkert" + } + }, + "node_modules/@jest/environment-jsdom-abstract/node_modules/pretty-format": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.0.5.tgz", + "integrity": "sha512-D1tKtYvByrBkFLe2wHJl2bwMJIiT8rW+XA+TiataH79/FszLQMrpGEvzUVkzPau7OCO0Qnrhpe87PqtOAIB8Yw==", + "dev": true, + "dependencies": { + "@jest/schemas": "30.0.5", + "ansi-styles": "^5.2.0", + "react-is": "^18.3.1" + }, + "engines": { + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" + } + }, + "node_modules/@jest/environment-jsdom-abstract/node_modules/react-is": { + "version": "18.3.1", + "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.3.1.tgz", + "integrity": "sha512-/LLMVyas0ljjAtoYiPqYiL8VWXzUUdThrmU5+n20DZv+a+ClRoevUzw5JxU+Ieh5/c87ytoTBV9G1FiKfNJdmg==", + "dev": true + }, "node_modules/@jest/expect": { "version": "29.7.0", "resolved": "https://registry.npmjs.org/@jest/expect/-/expect-29.7.0.tgz", @@ -1242,6 +1430,28 @@ "node": "^14.15.0 || ^16.10.0 || >=18.0.0" } }, + "node_modules/@jest/pattern": { + "version": "30.0.1", + "resolved": "https://registry.npmjs.org/@jest/pattern/-/pattern-30.0.1.tgz", + "integrity": "sha512-gWp7NfQW27LaBQz3TITS8L7ZCQ0TLvtmI//4OwlQRx4rnWxcPNIYjxZpDcN4+UlGxgm3jS5QPz8IPTCkb59wZA==", + "dev": true, + "dependencies": { + "@types/node": "*", + "jest-regex-util": "30.0.1" + }, + "engines": { + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" + } + }, + "node_modules/@jest/pattern/node_modules/jest-regex-util": { + "version": "30.0.1", + "resolved": "https://registry.npmjs.org/jest-regex-util/-/jest-regex-util-30.0.1.tgz", + "integrity": "sha512-jHEQgBXAgc+Gh4g0p3bCevgRCVRkB4VB70zhoAE48gxeSr1hfUOsM/C2WoJgVL7Eyg//hudYENbm3Ne+/dRVVA==", + "dev": true, + "engines": { + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" + } + }, "node_modules/@jest/reporters": { "version": "29.7.0", "resolved": "https://registry.npmjs.org/@jest/reporters/-/reporters-29.7.0.tgz", @@ -1666,9 +1876,9 @@ "dev": true }, "node_modules/@sinonjs/commons": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/@sinonjs/commons/-/commons-3.0.0.tgz", - "integrity": "sha512-jXBtWAF4vmdNmZgD5FoKsVLv3rPgDnLgPbU84LIJ3otV44vJlDRokVng5v8NFJdCf/da9legHcKaRuZs4L7faA==", + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/@sinonjs/commons/-/commons-3.0.1.tgz", + "integrity": "sha512-K3mCHKQ9sVh8o1C9cxkwxaOmXoAMlDxC1mYyHrjqOWEcBjYr76t96zL2zlj5dUGZ3HSw240X1qgH3Mjf1yJWpQ==", "dev": true, "dependencies": { "type-detect": "4.0.8" @@ -1727,15 +1937,6 @@ "integrity": "sha512-7ZgogeTnjuHbo+ct10G9Ffp0mif17idi0IyWNVA/wcwcm7NPOD/WEHVP3n7n3MhXqxoIYm8d6MuZohYWIZ4T3w==", "dev": true }, - "node_modules/@tootallnate/once": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/@tootallnate/once/-/once-2.0.0.tgz", - "integrity": "sha512-XCuKFP5PS55gnMVu3dty8KPatLqUoy/ZYzDzAGCQ8JNFCkLXzmI7vNHCR+XpbZaMWQK/vQubr7PkYq8g470J/A==", - "dev": true, - "engines": { - "node": ">= 10" - } - }, "node_modules/@types/aria-query": { "version": "5.0.1", "resolved": "https://registry.npmjs.org/@types/aria-query/-/aria-query-5.0.1.tgz", @@ -1799,9 +2000,9 @@ } }, "node_modules/@types/istanbul-lib-coverage": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.4.tgz", - "integrity": "sha512-z/QT1XN4K4KYuslS23k62yDIDLwLFkzxOuMplDtObz0+y7VqJCaO2o+SPwHCvLFZh7xazvvoor2tA/hPz9ee7g==", + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.6.tgz", + "integrity": "sha512-2QF/t/auWm0lsy8XtKVPG19v3sSOQlJe/YHZgfjb/KBBHOGSV+J2q/S671rcq9uTBrLAXmZpqJiaQbMT+zNU1w==", "dev": true }, "node_modules/@types/istanbul-lib-report": { @@ -1814,18 +2015,18 @@ } }, "node_modules/@types/istanbul-reports": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/@types/istanbul-reports/-/istanbul-reports-3.0.1.tgz", - "integrity": "sha512-c3mAZEuK0lvBp8tmuL74XRKn1+y2dcwOUpH7x4WrF6gk1GIgiluDRgMYQtw2OFcBvAJWlt6ASU3tSqxp0Uu0Aw==", + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/@types/istanbul-reports/-/istanbul-reports-3.0.4.tgz", + "integrity": "sha512-pk2B1NWalF9toCRu6gjBzR69syFjP4Od8WRAX+0mmf9lAjCRicLOWc+ZrxZHx/0XRjotgkF9t6iaMJ+aXcOdZQ==", "dev": true, "dependencies": { "@types/istanbul-lib-report": "*" } }, "node_modules/@types/jsdom": { - "version": "20.0.0", - "resolved": "https://registry.npmjs.org/@types/jsdom/-/jsdom-20.0.0.tgz", - "integrity": "sha512-YfAchFs0yM1QPDrLm2VHe+WHGtqms3NXnXAMolrgrVP6fgBHHXy1ozAbo/dFtPNtZC/m66bPiCTWYmqp1F14gA==", + "version": "21.1.7", + "resolved": "https://registry.npmjs.org/@types/jsdom/-/jsdom-21.1.7.tgz", + "integrity": "sha512-yOriVnggzrnQ3a9OKOCxaVuSug3w3/SbOj5i7VwXWZEyUNl3bLF9V3MfxGbZKuwqJOQyRfqXyROBB1CoZLFWzA==", "dev": true, "dependencies": { "@types/node": "*", @@ -1846,21 +2047,21 @@ "dev": true }, "node_modules/@types/stack-utils": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/@types/stack-utils/-/stack-utils-2.0.1.tgz", - "integrity": "sha512-Hl219/BT5fLAaz6NDkSuhzasy49dwQS/DSdu4MdggFB8zcXv7vflBI3xp7FEmkmdDkBUI2bPUNeMttp2knYdxw==", + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/@types/stack-utils/-/stack-utils-2.0.3.tgz", + "integrity": "sha512-9aEbYZ3TbYMznPdcdr3SmIrLXwC/AKZXQeCf9Pgao5CKb8CyHuEX5jzWPTkvregvhRJHcpRO6BFoGW9ycaOkYw==", "dev": true }, "node_modules/@types/tough-cookie": { - "version": "4.0.2", - "resolved": "https://registry.npmjs.org/@types/tough-cookie/-/tough-cookie-4.0.2.tgz", - "integrity": "sha512-Q5vtl1W5ue16D+nIaW8JWebSSraJVlK+EthKn7e7UcD4KWsaSJ8BqGPXNaPghgtcn/fhvrN17Tv8ksUsQpiplw==", + "version": "4.0.5", + "resolved": "https://registry.npmjs.org/@types/tough-cookie/-/tough-cookie-4.0.5.tgz", + "integrity": "sha512-/Ad8+nIOV7Rl++6f1BdKxFSMgmoqEoYbHRpPcx3JEfv8VRsQe9Z4mCXeJBzxs7mbHY/XOZZuXlRNfhpVPbs6ZA==", "dev": true }, "node_modules/@types/yargs": { - "version": "17.0.13", - "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-17.0.13.tgz", - "integrity": "sha512-9sWaruZk2JGxIQU+IhI1fhPYRcQ0UuTNuKuCW9bR5fp7qi2Llf7WDzNa17Cy7TKnh3cdxDOiyTu6gaLS0eDatg==", + "version": "17.0.33", + "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-17.0.33.tgz", + "integrity": "sha512-WpxBCKWPLr4xSsHgz511rFJAM+wS28w2zEO1QDNY5zM/S8ok70NNfztH0xwhqKyaK0OHCbN98LDAZuy1ctxDkA==", "dev": true, "dependencies": { "@types/yargs-parser": "*" @@ -1892,12 +2093,6 @@ "integrity": "sha512-dCTxxolI6fu28lzNRVwd7CzJV8EbARITFyCbP/JqLHYLfWHY7GJqXHDdk0GbtfXvsZosPCvjOE4dOIMT4XDFZQ==", "dev": true }, - "node_modules/abab": { - "version": "2.0.6", - "resolved": "https://registry.npmjs.org/abab/-/abab-2.0.6.tgz", - "integrity": "sha512-j2afSsaIENvHZN2B8GOpF566vZ5WVk5opAiMTvWgaQT8DkbOqsTfvNAvHoRGU2zzP8cPoqys+xHTRDWW8L+/BA==", - "dev": true - }, "node_modules/acorn": { "version": "8.15.0", "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.15.0.tgz", @@ -1911,16 +2106,6 @@ "node": ">=0.4.0" } }, - "node_modules/acorn-globals": { - "version": "7.0.1", - "resolved": "https://registry.npmjs.org/acorn-globals/-/acorn-globals-7.0.1.tgz", - "integrity": "sha512-umOSDSDrfHbTNPuNpC2NSnnA3LUrqpevPb4T9jRx4MagXNS0rs+gwiTcAvqCRmsD6utzsrzNt+ebm00SNWiC3Q==", - "dev": true, - "dependencies": { - "acorn": "^8.1.0", - "acorn-walk": "^8.0.2" - } - }, "node_modules/acorn-jsx": { "version": "5.3.2", "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", @@ -1930,25 +2115,13 @@ "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" } }, - "node_modules/acorn-walk": { - "version": "8.2.0", - "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.2.0.tgz", - "integrity": "sha512-k+iyHEuPgSw6SbuDpGQM+06HQUa04DZ3o+F6CSzXMvvI5KMvnaEqXe+YVe555R9nn6GPt404fos4wcgpw12SDA==", - "dev": true, - "engines": { - "node": ">=0.4.0" - } - }, "node_modules/agent-base": { - "version": "6.0.2", - "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz", - "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==", + "version": "7.1.4", + "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-7.1.4.tgz", + "integrity": "sha512-MnA+YT8fwfJPgBx3m60MNqakm30XOkyIoH1y6huTQvC0PwZG7ki8NacLBcrPbNoo8vEZy7Jpuk7+jMO+CUovTQ==", "dev": true, - "dependencies": { - "debug": "4" - }, "engines": { - "node": ">= 6.0.0" + "node": ">= 14" } }, "node_modules/ajv": { @@ -2575,42 +2748,30 @@ "integrity": "sha512-YUifsXXuknHlUsmlgyY0PKzgPOr7/FjCePfHNt0jxm83wHZi44VDMQ7/fGNkjY3/jV1MC+1CmZbaHzugyeRtpg==", "dev": true }, - "node_modules/cssom": { - "version": "0.5.0", - "resolved": "https://registry.npmjs.org/cssom/-/cssom-0.5.0.tgz", - "integrity": "sha512-iKuQcq+NdHqlAcwUY0o/HL69XQrUaQdMjmStJ8JFmUaiiQErlhrmuigkg/CU4E2J0IyUKUrMAgl36TvN67MqTw==", - "dev": true - }, "node_modules/cssstyle": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/cssstyle/-/cssstyle-2.3.0.tgz", - "integrity": "sha512-AZL67abkUzIuvcHqk7c09cezpGNcxUxU4Ioi/05xHk4DQeTkWmGYftIE6ctU6AEt+Gn4n1lDStOtj7FKycP71A==", + "version": "4.6.0", + "resolved": "https://registry.npmjs.org/cssstyle/-/cssstyle-4.6.0.tgz", + "integrity": "sha512-2z+rWdzbbSZv6/rhtvzvqeZQHrBaqgogqt85sqFNbabZOuFbCVFb8kPeEtZjiKkbrm395irpNKiYeFeLiQnFPg==", "dev": true, "dependencies": { - "cssom": "~0.3.6" + "@asamuzakjp/css-color": "^3.2.0", + "rrweb-cssom": "^0.8.0" }, "engines": { - "node": ">=8" + "node": ">=18" } }, - "node_modules/cssstyle/node_modules/cssom": { - "version": "0.3.8", - "resolved": "https://registry.npmjs.org/cssom/-/cssom-0.3.8.tgz", - "integrity": "sha512-b0tGHbfegbhPJpxpiBPU2sCkigAqtM9O121le6bbOlgyV+NyGyCmVfJ6QW9eRjz8CpNfWEOYBIMIGRYkLwsIYg==", - "dev": true - }, "node_modules/data-urls": { - "version": "3.0.2", - "resolved": "https://registry.npmjs.org/data-urls/-/data-urls-3.0.2.tgz", - "integrity": "sha512-Jy/tj3ldjZJo63sVAvg6LHt2mHvl4V6AgRAmNDtLdm7faqtsx+aJG42rsyCo9JCoRVKwPFzKlIPx3DIibwSIaQ==", + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/data-urls/-/data-urls-5.0.0.tgz", + "integrity": "sha512-ZYP5VBHshaDAiVZxjbRVcFJpc+4xGgT0bK3vzy1HLN8jTO975HEbuYzZJcHoQEY5K1a0z8YayJkyVETa08eNTg==", "dev": true, "dependencies": { - "abab": "^2.0.6", - "whatwg-mimetype": "^3.0.0", - "whatwg-url": "^11.0.0" + "whatwg-mimetype": "^4.0.0", + "whatwg-url": "^14.0.0" }, "engines": { - "node": ">=12" + "node": ">=18" } }, "node_modules/debug": { @@ -2632,9 +2793,9 @@ } }, "node_modules/decimal.js": { - "version": "10.4.1", - "resolved": "https://registry.npmjs.org/decimal.js/-/decimal.js-10.4.1.tgz", - "integrity": "sha512-F29o+vci4DodHYT9UrR5IEbfBw9pE5eSapIJdTqXK5+6hq+t8VRxwQyKlW2i+KDKFkkJQRvFyI/QXD83h8LyQw==", + "version": "10.6.0", + "resolved": "https://registry.npmjs.org/decimal.js/-/decimal.js-10.6.0.tgz", + "integrity": "sha512-YpgQiITW3JXGntzdUmyUR1V812Hn8T1YVXhCu+wO3OpS4eU9l4YdD3qjyiKdV6mvV29zapkMeD390UVEf2lkUg==", "dev": true }, "node_modules/dedent": { @@ -2714,18 +2875,6 @@ "integrity": "sha512-NMt+m9zFMPZe0JcY9gN224Qvk6qLIdqex29clBvc/y75ZBX9YA9wNK3frsYvu2DI1xcCIwxwnX+TlsJ2DSOADg==", "dev": true }, - "node_modules/domexception": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/domexception/-/domexception-4.0.0.tgz", - "integrity": "sha512-A2is4PLG+eeSfoTMA95/s4pvAoSo2mKtiM5jlHkAVewmiO8ISFTFKZjH7UAM1Atli/OT/7JHOrJRJiMKUZKYBw==", - "dev": true, - "dependencies": { - "webidl-conversions": "^7.0.0" - }, - "engines": { - "node": ">=12" - } - }, "node_modules/dotenv": { "version": "17.2.1", "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-17.2.1.tgz", @@ -2790,9 +2939,9 @@ "integrity": "sha512-5U0rVMU5Y2n2+ykNLQqMoqklN9ICBT/KsvC1Gz6vqHbz2AXXGkG+Pm5rMWk/8Vjrr/mY9985Hi8DYzn1F09Nyw==" }, "node_modules/entities": { - "version": "4.4.0", - "resolved": "https://registry.npmjs.org/entities/-/entities-4.4.0.tgz", - "integrity": "sha512-oYp7156SP8LkeGD0GF85ad1X9Ai79WtRsZ2gxJqtBuzH+98YUV6jkHEKlZkMbcrjJjIVJNIDP/3WL9wQkoPbWA==", + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/entities/-/entities-6.0.1.tgz", + "integrity": "sha512-aN97NXWF6AWBTahfVOIrB/NShkzi5H7F9r1s9mD3cDj4Ko5f2qhhVoYMibXF7GlLveb/D2ioWay8lxI97Ven3g==", "dev": true, "engines": { "node": ">=0.12" @@ -2881,28 +3030,6 @@ "node": ">=8" } }, - "node_modules/escodegen": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/escodegen/-/escodegen-2.0.0.tgz", - "integrity": "sha512-mmHKys/C8BFUGI+MAWNcSYoORYLMdPzjrknd2Vc+bUsjN5bXcr8EhrNB+UTqfL1y3I9c4fw2ihgtMPQLBRiQxw==", - "dev": true, - "dependencies": { - "esprima": "^4.0.1", - "estraverse": "^5.2.0", - "esutils": "^2.0.2", - "optionator": "^0.8.1" - }, - "bin": { - "escodegen": "bin/escodegen.js", - "esgenerate": "bin/esgenerate.js" - }, - "engines": { - "node": ">=6.0" - }, - "optionalDependencies": { - "source-map": "~0.6.1" - } - }, "node_modules/eslint": { "version": "9.33.0", "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.33.0.tgz", @@ -3613,9 +3740,9 @@ } }, "node_modules/graceful-fs": { - "version": "4.2.10", - "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.10.tgz", - "integrity": "sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA==", + "version": "4.2.11", + "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", + "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==", "dev": true }, "node_modules/has": { @@ -3685,15 +3812,15 @@ } }, "node_modules/html-encoding-sniffer": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/html-encoding-sniffer/-/html-encoding-sniffer-3.0.0.tgz", - "integrity": "sha512-oWv4T4yJ52iKrufjnyZPkrN0CH3QnrUqdB6In1g5Fe1mia8GmF36gnfNySxoZtxD5+NmYw1EElVXiBk93UeskA==", + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/html-encoding-sniffer/-/html-encoding-sniffer-4.0.0.tgz", + "integrity": "sha512-Y22oTqIU4uuPgEemfz7NDJz6OeKf12Lsu+QC+s3BVpda64lTiMYCyGwg5ki4vFxkMwQdeZDl2adZoqUgdFuTgQ==", "dev": true, "dependencies": { - "whatwg-encoding": "^2.0.0" + "whatwg-encoding": "^3.1.1" }, "engines": { - "node": ">=12" + "node": ">=18" } }, "node_modules/html-escaper": { @@ -3703,30 +3830,29 @@ "dev": true }, "node_modules/http-proxy-agent": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-5.0.0.tgz", - "integrity": "sha512-n2hY8YdoRE1i7r6M0w9DIw5GgZN0G25P8zLCRQ8rjXtTU3vsNFBI/vWK/UIeE6g5MUUz6avwAPXmL6Fy9D/90w==", + "version": "7.0.2", + "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-7.0.2.tgz", + "integrity": "sha512-T1gkAiYYDWYx3V5Bmyu7HcfcvL7mUrTWiM6yOfa3PIphViJ/gFPbvidQ+veqSOHci/PxBcDabeUNCzpOODJZig==", "dev": true, "dependencies": { - "@tootallnate/once": "2", - "agent-base": "6", - "debug": "4" + "agent-base": "^7.1.0", + "debug": "^4.3.4" }, "engines": { - "node": ">= 6" + "node": ">= 14" } }, "node_modules/https-proxy-agent": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.1.tgz", - "integrity": "sha512-dFcAjpTQFgoLMzC2VwU+C/CbS7uRL0lWmxDITmqm7C+7F0Odmj6s9l6alZc6AELXhrnggM2CeWSXHGOdX2YtwA==", + "version": "7.0.6", + "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-7.0.6.tgz", + "integrity": "sha512-vK9P5/iUfdl95AI+JVyUuIcVtd4ofvtrOr3HNtM2yxC9bnMbEdp3x01OhQNnjb8IJYi38VlTE3mBXwcfvywuSw==", "dev": true, "dependencies": { - "agent-base": "6", + "agent-base": "^7.1.2", "debug": "4" }, "engines": { - "node": ">= 6" + "node": ">= 14" } }, "node_modules/human-signals": { @@ -4331,17 +4457,150 @@ "integrity": "sha512-gns+Er14+ZrEoC5fhOfYCY1LOHHr0TI+rQUHZS8Ttw2l7gl+80eHc/gFf2Ktkw0+SIACDTeWvpFcv3B04VembQ==", "dev": true, "dependencies": { - "@jest/types": "^29.6.3", - "chalk": "^4.0.0", - "jest-get-type": "^29.6.3", - "jest-util": "^29.7.0", - "pretty-format": "^29.7.0" + "@jest/types": "^29.6.3", + "chalk": "^4.0.0", + "jest-get-type": "^29.6.3", + "jest-util": "^29.7.0", + "pretty-format": "^29.7.0" + }, + "engines": { + "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + } + }, + "node_modules/jest-each/node_modules/ansi-styles": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz", + "integrity": "sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==", + "dev": true, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, + "node_modules/jest-each/node_modules/pretty-format": { + "version": "29.7.0", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-29.7.0.tgz", + "integrity": "sha512-Pdlw/oPxN+aXdmM9R00JVC9WVFoCLTKJvDVLgmJ+qAffBMxsV85l/Lu7sNx4zSzPyoL2euImuEwHhOXdEgNFZQ==", + "dev": true, + "dependencies": { + "@jest/schemas": "^29.6.3", + "ansi-styles": "^5.0.0", + "react-is": "^18.0.0" + }, + "engines": { + "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + } + }, + "node_modules/jest-each/node_modules/react-is": { + "version": "18.2.0", + "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz", + "integrity": "sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w==", + "dev": true + }, + "node_modules/jest-environment-jsdom": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/jest-environment-jsdom/-/jest-environment-jsdom-30.0.5.tgz", + "integrity": "sha512-BmnDEoAH+jEjkPrvE9DTKS2r3jYSJWlN/r46h0/DBUxKrkgt2jAZ5Nj4wXLAcV1KWkRpcFqA5zri9SWzJZ1cCg==", + "dev": true, + "dependencies": { + "@jest/environment": "30.0.5", + "@jest/environment-jsdom-abstract": "30.0.5", + "@types/jsdom": "^21.1.7", + "@types/node": "*", + "jsdom": "^26.1.0" + }, + "engines": { + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" + }, + "peerDependencies": { + "canvas": "^3.0.0" + }, + "peerDependenciesMeta": { + "canvas": { + "optional": true + } + } + }, + "node_modules/jest-environment-jsdom/node_modules/@jest/environment": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-30.0.5.tgz", + "integrity": "sha512-aRX7WoaWx1oaOkDQvCWImVQ8XNtdv5sEWgk4gxR6NXb7WBUnL5sRak4WRzIQRZ1VTWPvV4VI4mgGjNL9TeKMYA==", + "dev": true, + "dependencies": { + "@jest/fake-timers": "30.0.5", + "@jest/types": "30.0.5", + "@types/node": "*", + "jest-mock": "30.0.5" + }, + "engines": { + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" + } + }, + "node_modules/jest-environment-jsdom/node_modules/@jest/fake-timers": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-30.0.5.tgz", + "integrity": "sha512-ZO5DHfNV+kgEAeP3gK3XlpJLL4U3Sz6ebl/n68Uwt64qFFs5bv4bfEEjyRGK5uM0C90ewooNgFuKMdkbEoMEXw==", + "dev": true, + "dependencies": { + "@jest/types": "30.0.5", + "@sinonjs/fake-timers": "^13.0.0", + "@types/node": "*", + "jest-message-util": "30.0.5", + "jest-mock": "30.0.5", + "jest-util": "30.0.5" + }, + "engines": { + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" + } + }, + "node_modules/jest-environment-jsdom/node_modules/@jest/schemas": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/@jest/schemas/-/schemas-30.0.5.tgz", + "integrity": "sha512-DmdYgtezMkh3cpU8/1uyXakv3tJRcmcXxBOcO0tbaozPwpmh4YMsnWrQm9ZmZMfa5ocbxzbFk6O4bDPEc/iAnA==", + "dev": true, + "dependencies": { + "@sinclair/typebox": "^0.34.0" + }, + "engines": { + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" + } + }, + "node_modules/jest-environment-jsdom/node_modules/@jest/types": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/@jest/types/-/types-30.0.5.tgz", + "integrity": "sha512-aREYa3aku9SSnea4aX6bhKn4bgv3AXkgijoQgbYV3yvbiGt6z+MQ85+6mIhx9DsKW2BuB/cLR/A+tcMThx+KLQ==", + "dev": true, + "dependencies": { + "@jest/pattern": "30.0.1", + "@jest/schemas": "30.0.5", + "@types/istanbul-lib-coverage": "^2.0.6", + "@types/istanbul-reports": "^3.0.4", + "@types/node": "*", + "@types/yargs": "^17.0.33", + "chalk": "^4.1.2" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, - "node_modules/jest-each/node_modules/ansi-styles": { + "node_modules/jest-environment-jsdom/node_modules/@sinclair/typebox": { + "version": "0.34.38", + "resolved": "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.34.38.tgz", + "integrity": "sha512-HpkxMmc2XmZKhvaKIZZThlHmx1L0I/V1hWK1NubtlFnr6ZqdiOpV72TKudZUNQjZNsyDBay72qFEhEvb+bcwcA==", + "dev": true + }, + "node_modules/jest-environment-jsdom/node_modules/@sinonjs/fake-timers": { + "version": "13.0.5", + "resolved": "https://registry.npmjs.org/@sinonjs/fake-timers/-/fake-timers-13.0.5.tgz", + "integrity": "sha512-36/hTbH2uaWuGVERyC6da9YwGWnzUZXuPro/F2LfsdOsLnCojz/iSH8MxUt/FD2S5XBSVPhmArFUXcpCQ2Hkiw==", + "dev": true, + "dependencies": { + "@sinonjs/commons": "^3.0.1" + } + }, + "node_modules/jest-environment-jsdom/node_modules/ansi-styles": { "version": "5.2.0", "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz", "integrity": "sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==", @@ -4353,53 +4612,104 @@ "url": "https://github.com/chalk/ansi-styles?sponsor=1" } }, - "node_modules/jest-each/node_modules/pretty-format": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-29.7.0.tgz", - "integrity": "sha512-Pdlw/oPxN+aXdmM9R00JVC9WVFoCLTKJvDVLgmJ+qAffBMxsV85l/Lu7sNx4zSzPyoL2euImuEwHhOXdEgNFZQ==", + "node_modules/jest-environment-jsdom/node_modules/ci-info": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-4.3.0.tgz", + "integrity": "sha512-l+2bNRMiQgcfILUi33labAZYIWlH1kWDp+ecNo5iisRKrbm0xcRyCww71/YU0Fkw0mAFpz9bJayXPjey6vkmaQ==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/sibiraj-s" + } + ], + "engines": { + "node": ">=8" + } + }, + "node_modules/jest-environment-jsdom/node_modules/jest-message-util": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-30.0.5.tgz", + "integrity": "sha512-NAiDOhsK3V7RU0Aa/HnrQo+E4JlbarbmI3q6Pi4KcxicdtjV82gcIUrejOtczChtVQR4kddu1E1EJlW6EN9IyA==", "dev": true, "dependencies": { - "@jest/schemas": "^29.6.3", - "ansi-styles": "^5.0.0", - "react-is": "^18.0.0" + "@babel/code-frame": "^7.27.1", + "@jest/types": "30.0.5", + "@types/stack-utils": "^2.0.3", + "chalk": "^4.1.2", + "graceful-fs": "^4.2.11", + "micromatch": "^4.0.8", + "pretty-format": "30.0.5", + "slash": "^3.0.0", + "stack-utils": "^2.0.6" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, - "node_modules/jest-each/node_modules/react-is": { - "version": "18.2.0", - "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz", - "integrity": "sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w==", - "dev": true + "node_modules/jest-environment-jsdom/node_modules/jest-mock": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-30.0.5.tgz", + "integrity": "sha512-Od7TyasAAQX/6S+QCbN6vZoWOMwlTtzzGuxJku1GhGanAjz9y+QsQkpScDmETvdc9aSXyJ/Op4rhpMYBWW91wQ==", + "dev": true, + "dependencies": { + "@jest/types": "30.0.5", + "@types/node": "*", + "jest-util": "30.0.5" + }, + "engines": { + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" + } }, - "node_modules/jest-environment-jsdom": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-environment-jsdom/-/jest-environment-jsdom-29.7.0.tgz", - "integrity": "sha512-k9iQbsf9OyOfdzWH8HDmrRT0gSIcX+FLNW7IQq94tFX0gynPwqDTW0Ho6iMVNjGz/nb+l/vW3dWM2bbLLpkbXA==", + "node_modules/jest-environment-jsdom/node_modules/jest-util": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-30.0.5.tgz", + "integrity": "sha512-pvyPWssDZR0FlfMxCBoc0tvM8iUEskaRFALUtGQYzVEAqisAztmy+R8LnU14KT4XA0H/a5HMVTXat1jLne010g==", "dev": true, "dependencies": { - "@jest/environment": "^29.7.0", - "@jest/fake-timers": "^29.7.0", - "@jest/types": "^29.6.3", - "@types/jsdom": "^20.0.0", + "@jest/types": "30.0.5", "@types/node": "*", - "jest-mock": "^29.7.0", - "jest-util": "^29.7.0", - "jsdom": "^20.0.0" + "chalk": "^4.1.2", + "ci-info": "^4.2.0", + "graceful-fs": "^4.2.11", + "picomatch": "^4.0.2" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" + } + }, + "node_modules/jest-environment-jsdom/node_modules/picomatch": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-4.0.3.tgz", + "integrity": "sha512-5gTmgEY/sqK6gFXLIsQNH19lWb4ebPDLA4SdLP7dsWkIXHWlG66oPuVvXSGFPppYZz8ZDZq0dYYrbHfBCVUb1Q==", + "dev": true, + "engines": { + "node": ">=12" }, - "peerDependencies": { - "canvas": "^2.5.0" + "funding": { + "url": "https://github.com/sponsors/jonschlinkert" + } + }, + "node_modules/jest-environment-jsdom/node_modules/pretty-format": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.0.5.tgz", + "integrity": "sha512-D1tKtYvByrBkFLe2wHJl2bwMJIiT8rW+XA+TiataH79/FszLQMrpGEvzUVkzPau7OCO0Qnrhpe87PqtOAIB8Yw==", + "dev": true, + "dependencies": { + "@jest/schemas": "30.0.5", + "ansi-styles": "^5.2.0", + "react-is": "^18.3.1" }, - "peerDependenciesMeta": { - "canvas": { - "optional": true - } + "engines": { + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, + "node_modules/jest-environment-jsdom/node_modules/react-is": { + "version": "18.3.1", + "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.3.1.tgz", + "integrity": "sha512-/LLMVyas0ljjAtoYiPqYiL8VWXzUUdThrmU5+n20DZv+a+ClRoevUzw5JxU+Ieh5/c87ytoTBV9G1FiKfNJdmg==", + "dev": true + }, "node_modules/jest-environment-node": { "version": "29.7.0", "resolved": "https://registry.npmjs.org/jest-environment-node/-/jest-environment-node-29.7.0.tgz", @@ -4985,43 +5295,37 @@ } }, "node_modules/jsdom": { - "version": "20.0.1", - "resolved": "https://registry.npmjs.org/jsdom/-/jsdom-20.0.1.tgz", - "integrity": "sha512-pksjj7Rqoa+wdpkKcLzQRHhJCEE42qQhl/xLMUKHgoSejaKOdaXEAnqs6uDNwMl/fciHTzKeR8Wm8cw7N+g98A==", - "dev": true, - "dependencies": { - "abab": "^2.0.6", - "acorn": "^8.8.0", - "acorn-globals": "^7.0.0", - "cssom": "^0.5.0", - "cssstyle": "^2.3.0", - "data-urls": "^3.0.2", - "decimal.js": "^10.4.1", - "domexception": "^4.0.0", - "escodegen": "^2.0.0", - "form-data": "^4.0.0", - "html-encoding-sniffer": "^3.0.0", - "http-proxy-agent": "^5.0.0", - "https-proxy-agent": "^5.0.1", + "version": "26.1.0", + "resolved": "https://registry.npmjs.org/jsdom/-/jsdom-26.1.0.tgz", + "integrity": "sha512-Cvc9WUhxSMEo4McES3P7oK3QaXldCfNWp7pl2NNeiIFlCoLr3kfq9kb1fxftiwk1FLV7CvpvDfonxtzUDeSOPg==", + "dev": true, + "dependencies": { + "cssstyle": "^4.2.1", + "data-urls": "^5.0.0", + "decimal.js": "^10.5.0", + "html-encoding-sniffer": "^4.0.0", + "http-proxy-agent": "^7.0.2", + "https-proxy-agent": "^7.0.6", "is-potential-custom-element-name": "^1.0.1", - "nwsapi": "^2.2.2", - "parse5": "^7.1.1", + "nwsapi": "^2.2.16", + "parse5": "^7.2.1", + "rrweb-cssom": "^0.8.0", "saxes": "^6.0.0", "symbol-tree": "^3.2.4", - "tough-cookie": "^4.1.2", - "w3c-xmlserializer": "^3.0.0", + "tough-cookie": "^5.1.1", + "w3c-xmlserializer": "^5.0.0", "webidl-conversions": "^7.0.0", - "whatwg-encoding": "^2.0.0", - "whatwg-mimetype": "^3.0.0", - "whatwg-url": "^11.0.0", - "ws": "^8.9.0", - "xml-name-validator": "^4.0.0" + "whatwg-encoding": "^3.1.1", + "whatwg-mimetype": "^4.0.0", + "whatwg-url": "^14.1.1", + "ws": "^8.18.0", + "xml-name-validator": "^5.0.0" }, "engines": { - "node": ">=14" + "node": ">=18" }, "peerDependencies": { - "canvas": "^2.5.0" + "canvas": "^3.0.0" }, "peerDependenciesMeta": { "canvas": { @@ -5110,19 +5414,6 @@ "node": ">=6" } }, - "node_modules/levn": { - "version": "0.3.0", - "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", - "integrity": "sha512-0OO4y2iOHix2W6ujICbKIaEQXvFQHue65vUG3pb5EUomzPI90z9hsA1VsO/dbIIpC53J8gxM9Q4Oho0jrCM/yA==", - "dev": true, - "dependencies": { - "prelude-ls": "~1.1.2", - "type-check": "~0.3.2" - }, - "engines": { - "node": ">= 0.8.0" - } - }, "node_modules/lilconfig": { "version": "3.1.3", "resolved": "https://registry.npmjs.org/lilconfig/-/lilconfig-3.1.3.tgz", @@ -5830,9 +6121,9 @@ } }, "node_modules/nwsapi": { - "version": "2.2.2", - "resolved": "https://registry.npmjs.org/nwsapi/-/nwsapi-2.2.2.tgz", - "integrity": "sha512-90yv+6538zuvUMnN+zCr8LuV6bPFdq50304114vJYJ8RDyK8D5O9Phpbd6SZWgI7PwzmmfN1upeOJlvybDSgCw==", + "version": "2.2.21", + "resolved": "https://registry.npmjs.org/nwsapi/-/nwsapi-2.2.21.tgz", + "integrity": "sha512-o6nIY3qwiSXl7/LuOU0Dmuctd34Yay0yeuZRLFmDPrrdHpXKFndPj3hM+YEPVHYC5fx2otBx4Ilc/gyYSAUaIA==", "dev": true }, "node_modules/once": { @@ -5859,23 +6150,6 @@ "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/optionator": { - "version": "0.8.3", - "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.3.tgz", - "integrity": "sha512-+IW9pACdk3XWmmTXG8m3upGUJst5XRGzxMRjXzAuJ1XnIFNvfhjjIuYkDvysnPQ7qzqVzLt78BCruntqRhWQbA==", - "dev": true, - "dependencies": { - "deep-is": "~0.1.3", - "fast-levenshtein": "~2.0.6", - "levn": "~0.3.0", - "prelude-ls": "~1.1.2", - "type-check": "~0.3.2", - "word-wrap": "~1.2.3" - }, - "engines": { - "node": ">= 0.8.0" - } - }, "node_modules/p-limit": { "version": "3.1.0", "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", @@ -5981,12 +6255,12 @@ "license": "MIT" }, "node_modules/parse5": { - "version": "7.1.1", - "resolved": "https://registry.npmjs.org/parse5/-/parse5-7.1.1.tgz", - "integrity": "sha512-kwpuwzB+px5WUg9pyK0IcK/shltJN5/OVhQagxhCQNtT9Y9QRZqNY2e1cmbu/paRh5LMnz/oVTVLBpjFmMZhSg==", + "version": "7.3.0", + "resolved": "https://registry.npmjs.org/parse5/-/parse5-7.3.0.tgz", + "integrity": "sha512-IInvU7fabl34qmi9gY8XOVxhYyMyuH2xUNpb2q8/Y+7552KlejkRvqvD19nMoUW/uQGGbqNpA6Tufu5FL5BZgw==", "dev": true, "dependencies": { - "entities": "^4.4.0" + "entities": "^6.0.0" }, "funding": { "url": "https://github.com/inikulin/parse5?sponsor=1" @@ -6082,15 +6356,6 @@ "integrity": "sha512-fnWVljUchTro6RiCFvCXBbNhJc2NijN7oIQxbwsyL0buWJPG85v81ehlHI9fXrJsMNgTofEoWIQeClKpgxFLrg==", "dev": true }, - "node_modules/prelude-ls": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", - "integrity": "sha512-ESF23V4SKG6lVSGZgYNpbsiaAkdab6ZgOxe52p7+Kid3W3u3bxR4Vfd/o21dmN7jSt0IwgZ4v5MUd26FEtXE9w==", - "dev": true, - "engines": { - "node": ">= 0.8.0" - } - }, "node_modules/prettier": { "version": "3.6.2", "resolved": "https://registry.npmjs.org/prettier/-/prettier-3.6.2.tgz", @@ -6150,16 +6415,10 @@ "resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz", "integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==" }, - "node_modules/psl": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/psl/-/psl-1.9.0.tgz", - "integrity": "sha512-E/ZsdU4HLs/68gYzgGTkMicWTLPdAftJLfJFlLUAAKZGkStNU72sZjT66SnMDVOfOWY/YAoiD7Jxa9iHvngcag==", - "dev": true - }, "node_modules/punycode": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", - "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", + "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==", "dev": true, "engines": { "node": ">=6" @@ -6181,12 +6440,6 @@ } ] }, - "node_modules/querystringify": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/querystringify/-/querystringify-2.2.0.tgz", - "integrity": "sha512-FIqgj2EUvTa7R50u0rGsyTftzjYmv/a3hO345bZNrqabNqjtgiDMgmo4mkUjd+nzU5oF3dClKqFIPUKybUyqoQ==", - "dev": true - }, "node_modules/react-is": { "version": "17.0.2", "resolved": "https://registry.npmjs.org/react-is/-/react-is-17.0.2.tgz", @@ -6235,12 +6488,6 @@ "node": ">=0.10.0" } }, - "node_modules/requires-port": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/requires-port/-/requires-port-1.0.0.tgz", - "integrity": "sha512-KigOCHcocU3XODJxsu8i/j8T9tzT4adHiecwORRQ0ZZFcp7ahwXuRU1m+yuO90C5ZUyGeGfocHDI14M3L3yDAQ==", - "dev": true - }, "node_modules/resolve": { "version": "1.22.6", "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.6.tgz", @@ -6337,6 +6584,12 @@ "integrity": "sha512-q1b3N5QkRUWUl7iyylaaj3kOpIT0N2i9MqIEQXP73GVsN9cw3fdx8X63cEmWhJGi2PPCF23Ijp7ktmd39rawIA==", "dev": true }, + "node_modules/rrweb-cssom": { + "version": "0.8.0", + "resolved": "https://registry.npmjs.org/rrweb-cssom/-/rrweb-cssom-0.8.0.tgz", + "integrity": "sha512-guoltQEx+9aMf2gDZ0s62EcV8lsXR+0w8915TC3ITdn2YueuNjdAYh/levpU9nFaoChh9RUS5ZdQMrKfVEN9tw==", + "dev": true + }, "node_modules/safe-buffer": { "version": "5.2.1", "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", @@ -6523,9 +6776,9 @@ "dev": true }, "node_modules/stack-utils": { - "version": "2.0.5", - "resolved": "https://registry.npmjs.org/stack-utils/-/stack-utils-2.0.5.tgz", - "integrity": "sha512-xrQcmYhOsn/1kX+Vraq+7j4oE2j/6BFscZ0etmYg81xuM8Gq0022Pxb8+IqgOFUIaxHs0KaSb7T1+OegiNrNFA==", + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/stack-utils/-/stack-utils-2.0.6.tgz", + "integrity": "sha512-XlkWvfIm6RmsWtNJx+uqtKLS8eqFbxUg0ZzLXqY0caEy9l7hruX8IpiDnjsLavoBgqCCR71TqWO8MaXYheJ3RQ==", "dev": true, "dependencies": { "escape-string-regexp": "^2.0.0" @@ -6686,6 +6939,24 @@ "readable-stream": "3" } }, + "node_modules/tldts": { + "version": "6.1.86", + "resolved": "https://registry.npmjs.org/tldts/-/tldts-6.1.86.tgz", + "integrity": "sha512-WMi/OQ2axVTf/ykqCQgXiIct+mSQDFdH2fkwhPwgEwvJ1kSzZRiinb0zF2Xb8u4+OqPChmyI6MEu4EezNJz+FQ==", + "dev": true, + "dependencies": { + "tldts-core": "^6.1.86" + }, + "bin": { + "tldts": "bin/cli.js" + } + }, + "node_modules/tldts-core": { + "version": "6.1.86", + "resolved": "https://registry.npmjs.org/tldts-core/-/tldts-core-6.1.86.tgz", + "integrity": "sha512-Je6p7pkk+KMzMv2XXKmAE3McmolOQFdxkKw0R8EYNr7sELW46JqnNeTX8ybPiQgvg1ymCoF8LXs5fzFaZvJPTA==", + "dev": true + }, "node_modules/tmpl": { "version": "1.0.5", "resolved": "https://registry.npmjs.org/tmpl/-/tmpl-1.0.5.tgz", @@ -6714,30 +6985,27 @@ } }, "node_modules/tough-cookie": { - "version": "4.1.3", - "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-4.1.3.tgz", - "integrity": "sha512-aX/y5pVRkfRnfmuX+OdbSdXvPe6ieKX/G2s7e98f4poJHnqH3281gDPm/metm6E/WRamfx7WC4HUqkWHfQHprw==", + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-5.1.2.tgz", + "integrity": "sha512-FVDYdxtnj0G6Qm/DhNPSb8Ju59ULcup3tuJxkFb5K8Bv2pUXILbf0xZWU8PX8Ov19OXljbUyveOFwRMwkXzO+A==", "dev": true, "dependencies": { - "psl": "^1.1.33", - "punycode": "^2.1.1", - "universalify": "^0.2.0", - "url-parse": "^1.5.3" + "tldts": "^6.1.32" }, "engines": { - "node": ">=6" + "node": ">=16" } }, "node_modules/tr46": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/tr46/-/tr46-3.0.0.tgz", - "integrity": "sha512-l7FvfAHlcmulp8kr+flpQZmVwtu7nfRV7NZujtN0OqES8EL4O4e0qqzL0DC5gAvx/ZC/9lk6rhcUwYvkBnBnYA==", + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/tr46/-/tr46-5.1.1.tgz", + "integrity": "sha512-hdF5ZgjTqgAntKkklYw0R03MG2x/bSzTtkxmIRw/sTNV8YXsCJ1tfLAX23lhxhHJlEf3CRCOCGGWw3vI3GaSPw==", "dev": true, "dependencies": { - "punycode": "^2.1.1" + "punycode": "^2.3.1" }, "engines": { - "node": ">=12" + "node": ">=18" } }, "node_modules/tunnel": { @@ -6749,18 +7017,6 @@ "node": ">=0.6.11 <=0.7.0 || >=0.7.3" } }, - "node_modules/type-check": { - "version": "0.3.2", - "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", - "integrity": "sha512-ZCmOJdvOWDBYJlzAoFkC+Q0+bUyEOS1ltgp1MGU03fqHG+dbi9tBFU2Rd9QKiDZFAYrhPh2JUf7rZRIuHRKtOg==", - "dev": true, - "dependencies": { - "prelude-ls": "~1.1.2" - }, - "engines": { - "node": ">= 0.8.0" - } - }, "node_modules/type-detect": { "version": "4.0.8", "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", @@ -6802,15 +7058,6 @@ "dev": true, "license": "ISC" }, - "node_modules/universalify": { - "version": "0.2.0", - "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.2.0.tgz", - "integrity": "sha512-CJ1QgKmNg3CwvAv/kOFmtnEN05f0D/cn9QntgNOQlQF9dgvVTHj3t+8JPdjqawCHk7V/KA+fbUqzZ9XWhcqPUg==", - "dev": true, - "engines": { - "node": ">= 4.0.0" - } - }, "node_modules/update-browserslist-db": { "version": "1.0.11", "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.11.tgz", @@ -6855,16 +7102,6 @@ "punycode": "^2.1.0" } }, - "node_modules/url-parse": { - "version": "1.5.10", - "resolved": "https://registry.npmjs.org/url-parse/-/url-parse-1.5.10.tgz", - "integrity": "sha512-WypcfiRhfeUP9vvF0j6rw0J3hrWrw6iZv3+22h6iRMJ/8z1Tj6XfLP4DsUix5MhMPnXpiHDoKyoZ/bdCkwBCiQ==", - "dev": true, - "dependencies": { - "querystringify": "^2.1.1", - "requires-port": "^1.0.0" - } - }, "node_modules/util-deprecate": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", @@ -6892,15 +7129,15 @@ "dev": true }, "node_modules/w3c-xmlserializer": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/w3c-xmlserializer/-/w3c-xmlserializer-3.0.0.tgz", - "integrity": "sha512-3WFqGEgSXIyGhOmAFtlicJNMjEps8b1MG31NCA0/vOF9+nKMUW1ckhi9cnNHmf88Rzw5V+dwIwsm2C7X8k9aQg==", + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/w3c-xmlserializer/-/w3c-xmlserializer-5.0.0.tgz", + "integrity": "sha512-o8qghlI8NZHU1lLPrpi2+Uq7abh4GGPpYANlalzWxyWteJOCsr/P+oPBA49TOLu5FTZO4d3F9MnWJfiMo4BkmA==", "dev": true, "dependencies": { - "xml-name-validator": "^4.0.0" + "xml-name-validator": "^5.0.0" }, "engines": { - "node": ">=12" + "node": ">=18" } }, "node_modules/walker": { @@ -6922,37 +7159,37 @@ } }, "node_modules/whatwg-encoding": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/whatwg-encoding/-/whatwg-encoding-2.0.0.tgz", - "integrity": "sha512-p41ogyeMUrw3jWclHWTQg1k05DSVXPLcVxRTYsXUk+ZooOCZLcoYgPZ/HL/D/N+uQPOtcp1me1WhBEaX02mhWg==", + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/whatwg-encoding/-/whatwg-encoding-3.1.1.tgz", + "integrity": "sha512-6qN4hJdMwfYBtE3YBTTHhoeuUrDBPZmbQaxWAqSALV/MeEnR5z1xd8UKud2RAkFoPkmB+hli1TZSnyi84xz1vQ==", "dev": true, "dependencies": { "iconv-lite": "0.6.3" }, "engines": { - "node": ">=12" + "node": ">=18" } }, "node_modules/whatwg-mimetype": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/whatwg-mimetype/-/whatwg-mimetype-3.0.0.tgz", - "integrity": "sha512-nt+N2dzIutVRxARx1nghPKGv1xHikU7HKdfafKkLNLindmPU/ch3U31NOCGGA/dmPcmb1VlofO0vnKAcsm0o/Q==", + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/whatwg-mimetype/-/whatwg-mimetype-4.0.0.tgz", + "integrity": "sha512-QaKxh0eNIi2mE9p2vEdzfagOKHCcj1pJ56EEHGQOVxp8r9/iszLUUV7v89x9O1p/T+NlTM5W7jW6+cz4Fq1YVg==", "dev": true, "engines": { - "node": ">=12" + "node": ">=18" } }, "node_modules/whatwg-url": { - "version": "11.0.0", - "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-11.0.0.tgz", - "integrity": "sha512-RKT8HExMpoYx4igMiVMY83lN6UeITKJlBQ+vR/8ZJ8OCdSiN3RwCq+9gH0+Xzj0+5IrM6i4j/6LuvzbZIQgEcQ==", + "version": "14.2.0", + "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-14.2.0.tgz", + "integrity": "sha512-De72GdQZzNTUBBChsXueQUnPKDkg/5A5zp7pFDuQAj5UFoENpiACU0wlCvzpAGnTkj++ihpKwKyYewn/XNUbKw==", "dev": true, "dependencies": { - "tr46": "^3.0.0", + "tr46": "^5.1.0", "webidl-conversions": "^7.0.0" }, "engines": { - "node": ">=12" + "node": ">=18" } }, "node_modules/which": { @@ -7015,9 +7252,9 @@ } }, "node_modules/ws": { - "version": "8.17.1", - "resolved": "https://registry.npmjs.org/ws/-/ws-8.17.1.tgz", - "integrity": "sha512-6XQFvXTkbfUOZOKKILFG1PDK2NDQs4azKQl26T0YS5CxqWLgXajbPZ+h4gZekJyRqFU8pvnbAbbs/3TgRPy+GQ==", + "version": "8.18.3", + "resolved": "https://registry.npmjs.org/ws/-/ws-8.18.3.tgz", + "integrity": "sha512-PEIGCY5tSlUt50cqyMXfCzX+oOPqN0vuGqWzbcJ2xvnkzkq46oOpz7dQaTDBdfICb4N14+GARUDw2XV2N4tvzg==", "dev": true, "engines": { "node": ">=10.0.0" @@ -7036,12 +7273,12 @@ } }, "node_modules/xml-name-validator": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/xml-name-validator/-/xml-name-validator-4.0.0.tgz", - "integrity": "sha512-ICP2e+jsHvAj2E2lIHxa5tjXRlKDJo4IdvPvCXbXQGdzSfmSpNVyIKMvoZHjDY9DP0zV17iI85o90vRFXNccRw==", + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/xml-name-validator/-/xml-name-validator-5.0.0.tgz", + "integrity": "sha512-EvGK8EJ3DhaHfbRlETOWAS5pO9MZITeauHKJyb8wyajUfQUenkIg2MvLDTZ4T/TgIcm3HU0TFBgWWboAZ30UHg==", "dev": true, "engines": { - "node": ">=12" + "node": ">=18" } }, "node_modules/xmlchars": { @@ -7191,74 +7428,38 @@ "@jridgewell/trace-mapping": "^0.3.9" } }, - "@babel/code-frame": { - "version": "7.22.13", - "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.22.13.tgz", - "integrity": "sha512-XktuhWlJ5g+3TJXc5upd9Ks1HutSArik6jf2eAjYFyIOf4ej3RN+184cZbzDvbPnuTJIUhPKKJE3cIsYTiAT3w==", + "@asamuzakjp/css-color": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/@asamuzakjp/css-color/-/css-color-3.2.0.tgz", + "integrity": "sha512-K1A6z8tS3XsmCMM86xoWdn7Fkdn9m6RSVtocUrJYIwZnFVkng/PvkEoWtOWmP+Scc6saYWHWZYbndEEXxl24jw==", "dev": true, "requires": { - "@babel/highlight": "^7.22.13", - "chalk": "^2.4.2" + "@csstools/css-calc": "^2.1.3", + "@csstools/css-color-parser": "^3.0.9", + "@csstools/css-parser-algorithms": "^3.0.4", + "@csstools/css-tokenizer": "^3.0.3", + "lru-cache": "^10.4.3" }, "dependencies": { - "ansi-styles": { - "version": "3.2.1", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", - "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", - "dev": true, - "requires": { - "color-convert": "^1.9.0" - } - }, - "chalk": { - "version": "2.4.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", - "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", - "dev": true, - "requires": { - "ansi-styles": "^3.2.1", - "escape-string-regexp": "^1.0.5", - "supports-color": "^5.3.0" - } - }, - "color-convert": { - "version": "1.9.3", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", - "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", - "dev": true, - "requires": { - "color-name": "1.1.3" - } - }, - "color-name": { - "version": "1.1.3", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", - "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", - "dev": true - }, - "escape-string-regexp": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", - "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", - "dev": true - }, - "has-flag": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", - "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", + "lru-cache": { + "version": "10.4.3", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-10.4.3.tgz", + "integrity": "sha512-JNAzZcXrCt42VGLuYz0zfAzDfAvJWW6AfYlDBQyDV5DClI2m5sAmK+OIO7s59XfsRsWHp02jAJrRadPRGTt6SQ==", "dev": true - }, - "supports-color": { - "version": "5.5.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", - "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", - "dev": true, - "requires": { - "has-flag": "^3.0.0" - } } } }, + "@babel/code-frame": { + "version": "7.27.1", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.27.1.tgz", + "integrity": "sha512-cjQ7ZlQ0Mv3b47hABuTevyTuYN4i+loJKGeV9flcCgIK37cCXRh+L1bd3iBHlynerhQ7BhCkn2BPbQUL+rGqFg==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.27.1", + "js-tokens": "^4.0.0", + "picocolors": "^1.1.1" + } + }, "@babel/compat-data": { "version": "7.22.9", "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.22.9.tgz", @@ -7399,9 +7600,9 @@ "dev": true }, "@babel/helper-validator-identifier": { - "version": "7.22.20", - "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.22.20.tgz", - "integrity": "sha512-Y4OZ+ytlatR8AI+8KZfKuL5urKp7qey08ha31L8b3BwewJAoJamTzyvxPR/5D+KkdJCGPq/+8TukHBlY10FX9A==", + "version": "7.27.1", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.27.1.tgz", + "integrity": "sha512-D2hP9eA+Sqx1kBZgzxZh0y1trbuU+JoDkiEwqhQ36nodYqJwyEIhPSdMNd7lOm/4io72luTPWH20Yda0xOuUow==", "dev": true }, "@babel/helper-validator-option": { @@ -7421,75 +7622,6 @@ "@babel/types": "^7.22.5" } }, - "@babel/highlight": { - "version": "7.22.20", - "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.22.20.tgz", - "integrity": "sha512-dkdMCN3py0+ksCgYmGG8jKeGA/8Tk+gJwSYYlFGxG5lmhfKNoAy004YpLxpS1W2J8m/EK2Ew+yOs9pVRwO89mg==", - "dev": true, - "requires": { - "@babel/helper-validator-identifier": "^7.22.20", - "chalk": "^2.4.2", - "js-tokens": "^4.0.0" - }, - "dependencies": { - "ansi-styles": { - "version": "3.2.1", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", - "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", - "dev": true, - "requires": { - "color-convert": "^1.9.0" - } - }, - "chalk": { - "version": "2.4.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", - "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", - "dev": true, - "requires": { - "ansi-styles": "^3.2.1", - "escape-string-regexp": "^1.0.5", - "supports-color": "^5.3.0" - } - }, - "color-convert": { - "version": "1.9.3", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", - "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", - "dev": true, - "requires": { - "color-name": "1.1.3" - } - }, - "color-name": { - "version": "1.1.3", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", - "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", - "dev": true - }, - "escape-string-regexp": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", - "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", - "dev": true - }, - "has-flag": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", - "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", - "dev": true - }, - "supports-color": { - "version": "5.5.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", - "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", - "dev": true, - "requires": { - "has-flag": "^3.0.0" - } - } - } - }, "@babel/parser": { "version": "7.23.0", "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.23.0.tgz", @@ -7668,21 +7800,57 @@ } } }, - "@babel/types": { - "version": "7.23.0", - "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.23.0.tgz", - "integrity": "sha512-0oIyUfKoI3mSqMvsxBdclDwxXKXAUA8v/apZbc+iSyARYou1o8ZGDxbUYyLFoW2arqS2jDGqJuZvv1d/io1axg==", + "@babel/types": { + "version": "7.23.0", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.23.0.tgz", + "integrity": "sha512-0oIyUfKoI3mSqMvsxBdclDwxXKXAUA8v/apZbc+iSyARYou1o8ZGDxbUYyLFoW2arqS2jDGqJuZvv1d/io1axg==", + "dev": true, + "requires": { + "@babel/helper-string-parser": "^7.22.5", + "@babel/helper-validator-identifier": "^7.22.20", + "to-fast-properties": "^2.0.0" + } + }, + "@bcoe/v8-coverage": { + "version": "0.2.3", + "resolved": "https://registry.npmjs.org/@bcoe/v8-coverage/-/v8-coverage-0.2.3.tgz", + "integrity": "sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw==", + "dev": true + }, + "@csstools/color-helpers": { + "version": "5.0.2", + "resolved": "https://registry.npmjs.org/@csstools/color-helpers/-/color-helpers-5.0.2.tgz", + "integrity": "sha512-JqWH1vsgdGcw2RR6VliXXdA0/59LttzlU8UlRT/iUUsEeWfYq8I+K0yhihEUTTHLRm1EXvpsCx3083EU15ecsA==", + "dev": true + }, + "@csstools/css-calc": { + "version": "2.1.4", + "resolved": "https://registry.npmjs.org/@csstools/css-calc/-/css-calc-2.1.4.tgz", + "integrity": "sha512-3N8oaj+0juUw/1H3YwmDDJXCgTB1gKU6Hc/bB502u9zR0q2vd786XJH9QfrKIEgFlZmhZiq6epXl4rHqhzsIgQ==", + "dev": true, + "requires": {} + }, + "@csstools/css-color-parser": { + "version": "3.0.10", + "resolved": "https://registry.npmjs.org/@csstools/css-color-parser/-/css-color-parser-3.0.10.tgz", + "integrity": "sha512-TiJ5Ajr6WRd1r8HSiwJvZBiJOqtH86aHpUjq5aEKWHiII2Qfjqd/HCWKPOW8EP4vcspXbHnXrwIDlu5savQipg==", "dev": true, "requires": { - "@babel/helper-string-parser": "^7.22.5", - "@babel/helper-validator-identifier": "^7.22.20", - "to-fast-properties": "^2.0.0" + "@csstools/color-helpers": "^5.0.2", + "@csstools/css-calc": "^2.1.4" } }, - "@bcoe/v8-coverage": { - "version": "0.2.3", - "resolved": "https://registry.npmjs.org/@bcoe/v8-coverage/-/v8-coverage-0.2.3.tgz", - "integrity": "sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw==", + "@csstools/css-parser-algorithms": { + "version": "3.0.5", + "resolved": "https://registry.npmjs.org/@csstools/css-parser-algorithms/-/css-parser-algorithms-3.0.5.tgz", + "integrity": "sha512-DaDeUkXZKjdGhgYaHNJTV9pV7Y9B3b644jCLs9Upc3VeNGg6LWARAT6O+Q+/COo+2gg/bM5rhpMAtf70WqfBdQ==", + "dev": true, + "requires": {} + }, + "@csstools/css-tokenizer": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/@csstools/css-tokenizer/-/css-tokenizer-3.0.4.tgz", + "integrity": "sha512-Vd/9EVDiu6PPJt9yAh6roZP6El1xHrdvIVGjyBsHR0RYwNHgL7FJPyIIW4fANJNG6FtyZfvlRPpFI4ZM/lubvw==", "dev": true }, "@es-joy/jsdoccomment": { @@ -7982,6 +8150,165 @@ "jest-mock": "^29.7.0" } }, + "@jest/environment-jsdom-abstract": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/@jest/environment-jsdom-abstract/-/environment-jsdom-abstract-30.0.5.tgz", + "integrity": "sha512-gpWwiVxZunkoglP8DCnT3As9x5O8H6gveAOpvaJd2ATAoSh7ZSSCWbr9LQtUMvr8WD3VjG9YnDhsmkCK5WN1rQ==", + "dev": true, + "requires": { + "@jest/environment": "30.0.5", + "@jest/fake-timers": "30.0.5", + "@jest/types": "30.0.5", + "@types/jsdom": "^21.1.7", + "@types/node": "*", + "jest-mock": "30.0.5", + "jest-util": "30.0.5" + }, + "dependencies": { + "@jest/environment": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-30.0.5.tgz", + "integrity": "sha512-aRX7WoaWx1oaOkDQvCWImVQ8XNtdv5sEWgk4gxR6NXb7WBUnL5sRak4WRzIQRZ1VTWPvV4VI4mgGjNL9TeKMYA==", + "dev": true, + "requires": { + "@jest/fake-timers": "30.0.5", + "@jest/types": "30.0.5", + "@types/node": "*", + "jest-mock": "30.0.5" + } + }, + "@jest/fake-timers": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-30.0.5.tgz", + "integrity": "sha512-ZO5DHfNV+kgEAeP3gK3XlpJLL4U3Sz6ebl/n68Uwt64qFFs5bv4bfEEjyRGK5uM0C90ewooNgFuKMdkbEoMEXw==", + "dev": true, + "requires": { + "@jest/types": "30.0.5", + "@sinonjs/fake-timers": "^13.0.0", + "@types/node": "*", + "jest-message-util": "30.0.5", + "jest-mock": "30.0.5", + "jest-util": "30.0.5" + } + }, + "@jest/schemas": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/@jest/schemas/-/schemas-30.0.5.tgz", + "integrity": "sha512-DmdYgtezMkh3cpU8/1uyXakv3tJRcmcXxBOcO0tbaozPwpmh4YMsnWrQm9ZmZMfa5ocbxzbFk6O4bDPEc/iAnA==", + "dev": true, + "requires": { + "@sinclair/typebox": "^0.34.0" + } + }, + "@jest/types": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/@jest/types/-/types-30.0.5.tgz", + "integrity": "sha512-aREYa3aku9SSnea4aX6bhKn4bgv3AXkgijoQgbYV3yvbiGt6z+MQ85+6mIhx9DsKW2BuB/cLR/A+tcMThx+KLQ==", + "dev": true, + "requires": { + "@jest/pattern": "30.0.1", + "@jest/schemas": "30.0.5", + "@types/istanbul-lib-coverage": "^2.0.6", + "@types/istanbul-reports": "^3.0.4", + "@types/node": "*", + "@types/yargs": "^17.0.33", + "chalk": "^4.1.2" + } + }, + "@sinclair/typebox": { + "version": "0.34.38", + "resolved": "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.34.38.tgz", + "integrity": "sha512-HpkxMmc2XmZKhvaKIZZThlHmx1L0I/V1hWK1NubtlFnr6ZqdiOpV72TKudZUNQjZNsyDBay72qFEhEvb+bcwcA==", + "dev": true + }, + "@sinonjs/fake-timers": { + "version": "13.0.5", + "resolved": "https://registry.npmjs.org/@sinonjs/fake-timers/-/fake-timers-13.0.5.tgz", + "integrity": "sha512-36/hTbH2uaWuGVERyC6da9YwGWnzUZXuPro/F2LfsdOsLnCojz/iSH8MxUt/FD2S5XBSVPhmArFUXcpCQ2Hkiw==", + "dev": true, + "requires": { + "@sinonjs/commons": "^3.0.1" + } + }, + "ansi-styles": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz", + "integrity": "sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==", + "dev": true + }, + "ci-info": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-4.3.0.tgz", + "integrity": "sha512-l+2bNRMiQgcfILUi33labAZYIWlH1kWDp+ecNo5iisRKrbm0xcRyCww71/YU0Fkw0mAFpz9bJayXPjey6vkmaQ==", + "dev": true + }, + "jest-message-util": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-30.0.5.tgz", + "integrity": "sha512-NAiDOhsK3V7RU0Aa/HnrQo+E4JlbarbmI3q6Pi4KcxicdtjV82gcIUrejOtczChtVQR4kddu1E1EJlW6EN9IyA==", + "dev": true, + "requires": { + "@babel/code-frame": "^7.27.1", + "@jest/types": "30.0.5", + "@types/stack-utils": "^2.0.3", + "chalk": "^4.1.2", + "graceful-fs": "^4.2.11", + "micromatch": "^4.0.8", + "pretty-format": "30.0.5", + "slash": "^3.0.0", + "stack-utils": "^2.0.6" + } + }, + "jest-mock": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-30.0.5.tgz", + "integrity": "sha512-Od7TyasAAQX/6S+QCbN6vZoWOMwlTtzzGuxJku1GhGanAjz9y+QsQkpScDmETvdc9aSXyJ/Op4rhpMYBWW91wQ==", + "dev": true, + "requires": { + "@jest/types": "30.0.5", + "@types/node": "*", + "jest-util": "30.0.5" + } + }, + "jest-util": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-30.0.5.tgz", + "integrity": "sha512-pvyPWssDZR0FlfMxCBoc0tvM8iUEskaRFALUtGQYzVEAqisAztmy+R8LnU14KT4XA0H/a5HMVTXat1jLne010g==", + "dev": true, + "requires": { + "@jest/types": "30.0.5", + "@types/node": "*", + "chalk": "^4.1.2", + "ci-info": "^4.2.0", + "graceful-fs": "^4.2.11", + "picomatch": "^4.0.2" + } + }, + "picomatch": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-4.0.3.tgz", + "integrity": "sha512-5gTmgEY/sqK6gFXLIsQNH19lWb4ebPDLA4SdLP7dsWkIXHWlG66oPuVvXSGFPppYZz8ZDZq0dYYrbHfBCVUb1Q==", + "dev": true + }, + "pretty-format": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.0.5.tgz", + "integrity": "sha512-D1tKtYvByrBkFLe2wHJl2bwMJIiT8rW+XA+TiataH79/FszLQMrpGEvzUVkzPau7OCO0Qnrhpe87PqtOAIB8Yw==", + "dev": true, + "requires": { + "@jest/schemas": "30.0.5", + "ansi-styles": "^5.2.0", + "react-is": "^18.3.1" + } + }, + "react-is": { + "version": "18.3.1", + "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.3.1.tgz", + "integrity": "sha512-/LLMVyas0ljjAtoYiPqYiL8VWXzUUdThrmU5+n20DZv+a+ClRoevUzw5JxU+Ieh5/c87ytoTBV9G1FiKfNJdmg==", + "dev": true + } + } + }, "@jest/expect": { "version": "29.7.0", "resolved": "https://registry.npmjs.org/@jest/expect/-/expect-29.7.0.tgz", @@ -8027,6 +8354,24 @@ "jest-mock": "^29.7.0" } }, + "@jest/pattern": { + "version": "30.0.1", + "resolved": "https://registry.npmjs.org/@jest/pattern/-/pattern-30.0.1.tgz", + "integrity": "sha512-gWp7NfQW27LaBQz3TITS8L7ZCQ0TLvtmI//4OwlQRx4rnWxcPNIYjxZpDcN4+UlGxgm3jS5QPz8IPTCkb59wZA==", + "dev": true, + "requires": { + "@types/node": "*", + "jest-regex-util": "30.0.1" + }, + "dependencies": { + "jest-regex-util": { + "version": "30.0.1", + "resolved": "https://registry.npmjs.org/jest-regex-util/-/jest-regex-util-30.0.1.tgz", + "integrity": "sha512-jHEQgBXAgc+Gh4g0p3bCevgRCVRkB4VB70zhoAE48gxeSr1hfUOsM/C2WoJgVL7Eyg//hudYENbm3Ne+/dRVVA==", + "dev": true + } + } + }, "@jest/reporters": { "version": "29.7.0", "resolved": "https://registry.npmjs.org/@jest/reporters/-/reporters-29.7.0.tgz", @@ -8365,9 +8710,9 @@ "dev": true }, "@sinonjs/commons": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/@sinonjs/commons/-/commons-3.0.0.tgz", - "integrity": "sha512-jXBtWAF4vmdNmZgD5FoKsVLv3rPgDnLgPbU84LIJ3otV44vJlDRokVng5v8NFJdCf/da9legHcKaRuZs4L7faA==", + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/@sinonjs/commons/-/commons-3.0.1.tgz", + "integrity": "sha512-K3mCHKQ9sVh8o1C9cxkwxaOmXoAMlDxC1mYyHrjqOWEcBjYr76t96zL2zlj5dUGZ3HSw240X1qgH3Mjf1yJWpQ==", "dev": true, "requires": { "type-detect": "4.0.8" @@ -8420,12 +8765,6 @@ } } }, - "@tootallnate/once": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/@tootallnate/once/-/once-2.0.0.tgz", - "integrity": "sha512-XCuKFP5PS55gnMVu3dty8KPatLqUoy/ZYzDzAGCQ8JNFCkLXzmI7vNHCR+XpbZaMWQK/vQubr7PkYq8g470J/A==", - "dev": true - }, "@types/aria-query": { "version": "5.0.1", "resolved": "https://registry.npmjs.org/@types/aria-query/-/aria-query-5.0.1.tgz", @@ -8489,9 +8828,9 @@ } }, "@types/istanbul-lib-coverage": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.4.tgz", - "integrity": "sha512-z/QT1XN4K4KYuslS23k62yDIDLwLFkzxOuMplDtObz0+y7VqJCaO2o+SPwHCvLFZh7xazvvoor2tA/hPz9ee7g==", + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.6.tgz", + "integrity": "sha512-2QF/t/auWm0lsy8XtKVPG19v3sSOQlJe/YHZgfjb/KBBHOGSV+J2q/S671rcq9uTBrLAXmZpqJiaQbMT+zNU1w==", "dev": true }, "@types/istanbul-lib-report": { @@ -8504,18 +8843,18 @@ } }, "@types/istanbul-reports": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/@types/istanbul-reports/-/istanbul-reports-3.0.1.tgz", - "integrity": "sha512-c3mAZEuK0lvBp8tmuL74XRKn1+y2dcwOUpH7x4WrF6gk1GIgiluDRgMYQtw2OFcBvAJWlt6ASU3tSqxp0Uu0Aw==", + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/@types/istanbul-reports/-/istanbul-reports-3.0.4.tgz", + "integrity": "sha512-pk2B1NWalF9toCRu6gjBzR69syFjP4Od8WRAX+0mmf9lAjCRicLOWc+ZrxZHx/0XRjotgkF9t6iaMJ+aXcOdZQ==", "dev": true, "requires": { "@types/istanbul-lib-report": "*" } }, "@types/jsdom": { - "version": "20.0.0", - "resolved": "https://registry.npmjs.org/@types/jsdom/-/jsdom-20.0.0.tgz", - "integrity": "sha512-YfAchFs0yM1QPDrLm2VHe+WHGtqms3NXnXAMolrgrVP6fgBHHXy1ozAbo/dFtPNtZC/m66bPiCTWYmqp1F14gA==", + "version": "21.1.7", + "resolved": "https://registry.npmjs.org/@types/jsdom/-/jsdom-21.1.7.tgz", + "integrity": "sha512-yOriVnggzrnQ3a9OKOCxaVuSug3w3/SbOj5i7VwXWZEyUNl3bLF9V3MfxGbZKuwqJOQyRfqXyROBB1CoZLFWzA==", "dev": true, "requires": { "@types/node": "*", @@ -8536,21 +8875,21 @@ "dev": true }, "@types/stack-utils": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/@types/stack-utils/-/stack-utils-2.0.1.tgz", - "integrity": "sha512-Hl219/BT5fLAaz6NDkSuhzasy49dwQS/DSdu4MdggFB8zcXv7vflBI3xp7FEmkmdDkBUI2bPUNeMttp2knYdxw==", + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/@types/stack-utils/-/stack-utils-2.0.3.tgz", + "integrity": "sha512-9aEbYZ3TbYMznPdcdr3SmIrLXwC/AKZXQeCf9Pgao5CKb8CyHuEX5jzWPTkvregvhRJHcpRO6BFoGW9ycaOkYw==", "dev": true }, "@types/tough-cookie": { - "version": "4.0.2", - "resolved": "https://registry.npmjs.org/@types/tough-cookie/-/tough-cookie-4.0.2.tgz", - "integrity": "sha512-Q5vtl1W5ue16D+nIaW8JWebSSraJVlK+EthKn7e7UcD4KWsaSJ8BqGPXNaPghgtcn/fhvrN17Tv8ksUsQpiplw==", + "version": "4.0.5", + "resolved": "https://registry.npmjs.org/@types/tough-cookie/-/tough-cookie-4.0.5.tgz", + "integrity": "sha512-/Ad8+nIOV7Rl++6f1BdKxFSMgmoqEoYbHRpPcx3JEfv8VRsQe9Z4mCXeJBzxs7mbHY/XOZZuXlRNfhpVPbs6ZA==", "dev": true }, "@types/yargs": { - "version": "17.0.13", - "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-17.0.13.tgz", - "integrity": "sha512-9sWaruZk2JGxIQU+IhI1fhPYRcQ0UuTNuKuCW9bR5fp7qi2Llf7WDzNa17Cy7TKnh3cdxDOiyTu6gaLS0eDatg==", + "version": "17.0.33", + "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-17.0.33.tgz", + "integrity": "sha512-WpxBCKWPLr4xSsHgz511rFJAM+wS28w2zEO1QDNY5zM/S8ok70NNfztH0xwhqKyaK0OHCbN98LDAZuy1ctxDkA==", "dev": true, "requires": { "@types/yargs-parser": "*" @@ -8574,28 +8913,12 @@ "integrity": "sha512-dCTxxolI6fu28lzNRVwd7CzJV8EbARITFyCbP/JqLHYLfWHY7GJqXHDdk0GbtfXvsZosPCvjOE4dOIMT4XDFZQ==", "dev": true }, - "abab": { - "version": "2.0.6", - "resolved": "https://registry.npmjs.org/abab/-/abab-2.0.6.tgz", - "integrity": "sha512-j2afSsaIENvHZN2B8GOpF566vZ5WVk5opAiMTvWgaQT8DkbOqsTfvNAvHoRGU2zzP8cPoqys+xHTRDWW8L+/BA==", - "dev": true - }, "acorn": { "version": "8.15.0", "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.15.0.tgz", "integrity": "sha512-NZyJarBfL7nWwIq+FDL6Zp/yHEhePMNnnJ0y3qfieCrmNvYct8uvtiV41UvlSe6apAfk0fY1FbWx+NwfmpvtTg==", "dev": true }, - "acorn-globals": { - "version": "7.0.1", - "resolved": "https://registry.npmjs.org/acorn-globals/-/acorn-globals-7.0.1.tgz", - "integrity": "sha512-umOSDSDrfHbTNPuNpC2NSnnA3LUrqpevPb4T9jRx4MagXNS0rs+gwiTcAvqCRmsD6utzsrzNt+ebm00SNWiC3Q==", - "dev": true, - "requires": { - "acorn": "^8.1.0", - "acorn-walk": "^8.0.2" - } - }, "acorn-jsx": { "version": "5.3.2", "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", @@ -8603,20 +8926,11 @@ "dev": true, "requires": {} }, - "acorn-walk": { - "version": "8.2.0", - "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.2.0.tgz", - "integrity": "sha512-k+iyHEuPgSw6SbuDpGQM+06HQUa04DZ3o+F6CSzXMvvI5KMvnaEqXe+YVe555R9nn6GPt404fos4wcgpw12SDA==", - "dev": true - }, "agent-base": { - "version": "6.0.2", - "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz", - "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==", - "dev": true, - "requires": { - "debug": "4" - } + "version": "7.1.4", + "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-7.1.4.tgz", + "integrity": "sha512-MnA+YT8fwfJPgBx3m60MNqakm30XOkyIoH1y6huTQvC0PwZG7ki8NacLBcrPbNoo8vEZy7Jpuk7+jMO+CUovTQ==", + "dev": true }, "ajv": { "version": "6.12.6", @@ -9070,38 +9384,24 @@ "integrity": "sha512-YUifsXXuknHlUsmlgyY0PKzgPOr7/FjCePfHNt0jxm83wHZi44VDMQ7/fGNkjY3/jV1MC+1CmZbaHzugyeRtpg==", "dev": true }, - "cssom": { - "version": "0.5.0", - "resolved": "https://registry.npmjs.org/cssom/-/cssom-0.5.0.tgz", - "integrity": "sha512-iKuQcq+NdHqlAcwUY0o/HL69XQrUaQdMjmStJ8JFmUaiiQErlhrmuigkg/CU4E2J0IyUKUrMAgl36TvN67MqTw==", - "dev": true - }, "cssstyle": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/cssstyle/-/cssstyle-2.3.0.tgz", - "integrity": "sha512-AZL67abkUzIuvcHqk7c09cezpGNcxUxU4Ioi/05xHk4DQeTkWmGYftIE6ctU6AEt+Gn4n1lDStOtj7FKycP71A==", + "version": "4.6.0", + "resolved": "https://registry.npmjs.org/cssstyle/-/cssstyle-4.6.0.tgz", + "integrity": "sha512-2z+rWdzbbSZv6/rhtvzvqeZQHrBaqgogqt85sqFNbabZOuFbCVFb8kPeEtZjiKkbrm395irpNKiYeFeLiQnFPg==", "dev": true, "requires": { - "cssom": "~0.3.6" - }, - "dependencies": { - "cssom": { - "version": "0.3.8", - "resolved": "https://registry.npmjs.org/cssom/-/cssom-0.3.8.tgz", - "integrity": "sha512-b0tGHbfegbhPJpxpiBPU2sCkigAqtM9O121le6bbOlgyV+NyGyCmVfJ6QW9eRjz8CpNfWEOYBIMIGRYkLwsIYg==", - "dev": true - } + "@asamuzakjp/css-color": "^3.2.0", + "rrweb-cssom": "^0.8.0" } }, "data-urls": { - "version": "3.0.2", - "resolved": "https://registry.npmjs.org/data-urls/-/data-urls-3.0.2.tgz", - "integrity": "sha512-Jy/tj3ldjZJo63sVAvg6LHt2mHvl4V6AgRAmNDtLdm7faqtsx+aJG42rsyCo9JCoRVKwPFzKlIPx3DIibwSIaQ==", + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/data-urls/-/data-urls-5.0.0.tgz", + "integrity": "sha512-ZYP5VBHshaDAiVZxjbRVcFJpc+4xGgT0bK3vzy1HLN8jTO975HEbuYzZJcHoQEY5K1a0z8YayJkyVETa08eNTg==", "dev": true, "requires": { - "abab": "^2.0.6", - "whatwg-mimetype": "^3.0.0", - "whatwg-url": "^11.0.0" + "whatwg-mimetype": "^4.0.0", + "whatwg-url": "^14.0.0" } }, "debug": { @@ -9114,9 +9414,9 @@ } }, "decimal.js": { - "version": "10.4.1", - "resolved": "https://registry.npmjs.org/decimal.js/-/decimal.js-10.4.1.tgz", - "integrity": "sha512-F29o+vci4DodHYT9UrR5IEbfBw9pE5eSapIJdTqXK5+6hq+t8VRxwQyKlW2i+KDKFkkJQRvFyI/QXD83h8LyQw==", + "version": "10.6.0", + "resolved": "https://registry.npmjs.org/decimal.js/-/decimal.js-10.6.0.tgz", + "integrity": "sha512-YpgQiITW3JXGntzdUmyUR1V812Hn8T1YVXhCu+wO3OpS4eU9l4YdD3qjyiKdV6mvV29zapkMeD390UVEf2lkUg==", "dev": true }, "dedent": { @@ -9173,15 +9473,6 @@ "integrity": "sha512-NMt+m9zFMPZe0JcY9gN224Qvk6qLIdqex29clBvc/y75ZBX9YA9wNK3frsYvu2DI1xcCIwxwnX+TlsJ2DSOADg==", "dev": true }, - "domexception": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/domexception/-/domexception-4.0.0.tgz", - "integrity": "sha512-A2is4PLG+eeSfoTMA95/s4pvAoSo2mKtiM5jlHkAVewmiO8ISFTFKZjH7UAM1Atli/OT/7JHOrJRJiMKUZKYBw==", - "dev": true, - "requires": { - "webidl-conversions": "^7.0.0" - } - }, "dotenv": { "version": "17.2.1", "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-17.2.1.tgz", @@ -9231,9 +9522,9 @@ "integrity": "sha512-5U0rVMU5Y2n2+ykNLQqMoqklN9ICBT/KsvC1Gz6vqHbz2AXXGkG+Pm5rMWk/8Vjrr/mY9985Hi8DYzn1F09Nyw==" }, "entities": { - "version": "4.4.0", - "resolved": "https://registry.npmjs.org/entities/-/entities-4.4.0.tgz", - "integrity": "sha512-oYp7156SP8LkeGD0GF85ad1X9Ai79WtRsZ2gxJqtBuzH+98YUV6jkHEKlZkMbcrjJjIVJNIDP/3WL9wQkoPbWA==", + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/entities/-/entities-6.0.1.tgz", + "integrity": "sha512-aN97NXWF6AWBTahfVOIrB/NShkzi5H7F9r1s9mD3cDj4Ko5f2qhhVoYMibXF7GlLveb/D2ioWay8lxI97Ven3g==", "dev": true }, "environment": { @@ -9292,19 +9583,6 @@ "integrity": "sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w==", "dev": true }, - "escodegen": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/escodegen/-/escodegen-2.0.0.tgz", - "integrity": "sha512-mmHKys/C8BFUGI+MAWNcSYoORYLMdPzjrknd2Vc+bUsjN5bXcr8EhrNB+UTqfL1y3I9c4fw2ihgtMPQLBRiQxw==", - "dev": true, - "requires": { - "esprima": "^4.0.1", - "estraverse": "^5.2.0", - "esutils": "^2.0.2", - "optionator": "^0.8.1", - "source-map": "~0.6.1" - } - }, "eslint": { "version": "9.33.0", "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.33.0.tgz", @@ -9783,9 +10061,9 @@ "integrity": "sha512-ZUKRh6/kUFoAiTAtTYPZJ3hw9wNxx+BIBOijnlG9PnrJsCcSjs1wyyD6vJpaYtgnzDrKYRSqf3OO6Rfa93xsRg==" }, "graceful-fs": { - "version": "4.2.10", - "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.10.tgz", - "integrity": "sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA==", + "version": "4.2.11", + "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", + "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==", "dev": true }, "has": { @@ -9831,12 +10109,12 @@ "dev": true }, "html-encoding-sniffer": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/html-encoding-sniffer/-/html-encoding-sniffer-3.0.0.tgz", - "integrity": "sha512-oWv4T4yJ52iKrufjnyZPkrN0CH3QnrUqdB6In1g5Fe1mia8GmF36gnfNySxoZtxD5+NmYw1EElVXiBk93UeskA==", + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/html-encoding-sniffer/-/html-encoding-sniffer-4.0.0.tgz", + "integrity": "sha512-Y22oTqIU4uuPgEemfz7NDJz6OeKf12Lsu+QC+s3BVpda64lTiMYCyGwg5ki4vFxkMwQdeZDl2adZoqUgdFuTgQ==", "dev": true, "requires": { - "whatwg-encoding": "^2.0.0" + "whatwg-encoding": "^3.1.1" } }, "html-escaper": { @@ -9846,23 +10124,22 @@ "dev": true }, "http-proxy-agent": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-5.0.0.tgz", - "integrity": "sha512-n2hY8YdoRE1i7r6M0w9DIw5GgZN0G25P8zLCRQ8rjXtTU3vsNFBI/vWK/UIeE6g5MUUz6avwAPXmL6Fy9D/90w==", + "version": "7.0.2", + "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-7.0.2.tgz", + "integrity": "sha512-T1gkAiYYDWYx3V5Bmyu7HcfcvL7mUrTWiM6yOfa3PIphViJ/gFPbvidQ+veqSOHci/PxBcDabeUNCzpOODJZig==", "dev": true, "requires": { - "@tootallnate/once": "2", - "agent-base": "6", - "debug": "4" + "agent-base": "^7.1.0", + "debug": "^4.3.4" } }, "https-proxy-agent": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.1.tgz", - "integrity": "sha512-dFcAjpTQFgoLMzC2VwU+C/CbS7uRL0lWmxDITmqm7C+7F0Odmj6s9l6alZc6AELXhrnggM2CeWSXHGOdX2YtwA==", + "version": "7.0.6", + "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-7.0.6.tgz", + "integrity": "sha512-vK9P5/iUfdl95AI+JVyUuIcVtd4ofvtrOr3HNtM2yxC9bnMbEdp3x01OhQNnjb8IJYi38VlTE3mBXwcfvywuSw==", "dev": true, "requires": { - "agent-base": "6", + "agent-base": "^7.1.2", "debug": "4" } }, @@ -10326,19 +10603,160 @@ } }, "jest-environment-jsdom": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-environment-jsdom/-/jest-environment-jsdom-29.7.0.tgz", - "integrity": "sha512-k9iQbsf9OyOfdzWH8HDmrRT0gSIcX+FLNW7IQq94tFX0gynPwqDTW0Ho6iMVNjGz/nb+l/vW3dWM2bbLLpkbXA==", + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/jest-environment-jsdom/-/jest-environment-jsdom-30.0.5.tgz", + "integrity": "sha512-BmnDEoAH+jEjkPrvE9DTKS2r3jYSJWlN/r46h0/DBUxKrkgt2jAZ5Nj4wXLAcV1KWkRpcFqA5zri9SWzJZ1cCg==", "dev": true, "requires": { - "@jest/environment": "^29.7.0", - "@jest/fake-timers": "^29.7.0", - "@jest/types": "^29.6.3", - "@types/jsdom": "^20.0.0", + "@jest/environment": "30.0.5", + "@jest/environment-jsdom-abstract": "30.0.5", + "@types/jsdom": "^21.1.7", "@types/node": "*", - "jest-mock": "^29.7.0", - "jest-util": "^29.7.0", - "jsdom": "^20.0.0" + "jsdom": "^26.1.0" + }, + "dependencies": { + "@jest/environment": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-30.0.5.tgz", + "integrity": "sha512-aRX7WoaWx1oaOkDQvCWImVQ8XNtdv5sEWgk4gxR6NXb7WBUnL5sRak4WRzIQRZ1VTWPvV4VI4mgGjNL9TeKMYA==", + "dev": true, + "requires": { + "@jest/fake-timers": "30.0.5", + "@jest/types": "30.0.5", + "@types/node": "*", + "jest-mock": "30.0.5" + } + }, + "@jest/fake-timers": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-30.0.5.tgz", + "integrity": "sha512-ZO5DHfNV+kgEAeP3gK3XlpJLL4U3Sz6ebl/n68Uwt64qFFs5bv4bfEEjyRGK5uM0C90ewooNgFuKMdkbEoMEXw==", + "dev": true, + "requires": { + "@jest/types": "30.0.5", + "@sinonjs/fake-timers": "^13.0.0", + "@types/node": "*", + "jest-message-util": "30.0.5", + "jest-mock": "30.0.5", + "jest-util": "30.0.5" + } + }, + "@jest/schemas": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/@jest/schemas/-/schemas-30.0.5.tgz", + "integrity": "sha512-DmdYgtezMkh3cpU8/1uyXakv3tJRcmcXxBOcO0tbaozPwpmh4YMsnWrQm9ZmZMfa5ocbxzbFk6O4bDPEc/iAnA==", + "dev": true, + "requires": { + "@sinclair/typebox": "^0.34.0" + } + }, + "@jest/types": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/@jest/types/-/types-30.0.5.tgz", + "integrity": "sha512-aREYa3aku9SSnea4aX6bhKn4bgv3AXkgijoQgbYV3yvbiGt6z+MQ85+6mIhx9DsKW2BuB/cLR/A+tcMThx+KLQ==", + "dev": true, + "requires": { + "@jest/pattern": "30.0.1", + "@jest/schemas": "30.0.5", + "@types/istanbul-lib-coverage": "^2.0.6", + "@types/istanbul-reports": "^3.0.4", + "@types/node": "*", + "@types/yargs": "^17.0.33", + "chalk": "^4.1.2" + } + }, + "@sinclair/typebox": { + "version": "0.34.38", + "resolved": "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.34.38.tgz", + "integrity": "sha512-HpkxMmc2XmZKhvaKIZZThlHmx1L0I/V1hWK1NubtlFnr6ZqdiOpV72TKudZUNQjZNsyDBay72qFEhEvb+bcwcA==", + "dev": true + }, + "@sinonjs/fake-timers": { + "version": "13.0.5", + "resolved": "https://registry.npmjs.org/@sinonjs/fake-timers/-/fake-timers-13.0.5.tgz", + "integrity": "sha512-36/hTbH2uaWuGVERyC6da9YwGWnzUZXuPro/F2LfsdOsLnCojz/iSH8MxUt/FD2S5XBSVPhmArFUXcpCQ2Hkiw==", + "dev": true, + "requires": { + "@sinonjs/commons": "^3.0.1" + } + }, + "ansi-styles": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz", + "integrity": "sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==", + "dev": true + }, + "ci-info": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-4.3.0.tgz", + "integrity": "sha512-l+2bNRMiQgcfILUi33labAZYIWlH1kWDp+ecNo5iisRKrbm0xcRyCww71/YU0Fkw0mAFpz9bJayXPjey6vkmaQ==", + "dev": true + }, + "jest-message-util": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-30.0.5.tgz", + "integrity": "sha512-NAiDOhsK3V7RU0Aa/HnrQo+E4JlbarbmI3q6Pi4KcxicdtjV82gcIUrejOtczChtVQR4kddu1E1EJlW6EN9IyA==", + "dev": true, + "requires": { + "@babel/code-frame": "^7.27.1", + "@jest/types": "30.0.5", + "@types/stack-utils": "^2.0.3", + "chalk": "^4.1.2", + "graceful-fs": "^4.2.11", + "micromatch": "^4.0.8", + "pretty-format": "30.0.5", + "slash": "^3.0.0", + "stack-utils": "^2.0.6" + } + }, + "jest-mock": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-30.0.5.tgz", + "integrity": "sha512-Od7TyasAAQX/6S+QCbN6vZoWOMwlTtzzGuxJku1GhGanAjz9y+QsQkpScDmETvdc9aSXyJ/Op4rhpMYBWW91wQ==", + "dev": true, + "requires": { + "@jest/types": "30.0.5", + "@types/node": "*", + "jest-util": "30.0.5" + } + }, + "jest-util": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-30.0.5.tgz", + "integrity": "sha512-pvyPWssDZR0FlfMxCBoc0tvM8iUEskaRFALUtGQYzVEAqisAztmy+R8LnU14KT4XA0H/a5HMVTXat1jLne010g==", + "dev": true, + "requires": { + "@jest/types": "30.0.5", + "@types/node": "*", + "chalk": "^4.1.2", + "ci-info": "^4.2.0", + "graceful-fs": "^4.2.11", + "picomatch": "^4.0.2" + } + }, + "picomatch": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-4.0.3.tgz", + "integrity": "sha512-5gTmgEY/sqK6gFXLIsQNH19lWb4ebPDLA4SdLP7dsWkIXHWlG66oPuVvXSGFPppYZz8ZDZq0dYYrbHfBCVUb1Q==", + "dev": true + }, + "pretty-format": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.0.5.tgz", + "integrity": "sha512-D1tKtYvByrBkFLe2wHJl2bwMJIiT8rW+XA+TiataH79/FszLQMrpGEvzUVkzPau7OCO0Qnrhpe87PqtOAIB8Yw==", + "dev": true, + "requires": { + "@jest/schemas": "30.0.5", + "ansi-styles": "^5.2.0", + "react-is": "^18.3.1" + } + }, + "react-is": { + "version": "18.3.1", + "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.3.1.tgz", + "integrity": "sha512-/LLMVyas0ljjAtoYiPqYiL8VWXzUUdThrmU5+n20DZv+a+ClRoevUzw5JxU+Ieh5/c87ytoTBV9G1FiKfNJdmg==", + "dev": true + } } }, "jest-environment-node": { @@ -10802,37 +11220,31 @@ "dev": true }, "jsdom": { - "version": "20.0.1", - "resolved": "https://registry.npmjs.org/jsdom/-/jsdom-20.0.1.tgz", - "integrity": "sha512-pksjj7Rqoa+wdpkKcLzQRHhJCEE42qQhl/xLMUKHgoSejaKOdaXEAnqs6uDNwMl/fciHTzKeR8Wm8cw7N+g98A==", - "dev": true, - "requires": { - "abab": "^2.0.6", - "acorn": "^8.8.0", - "acorn-globals": "^7.0.0", - "cssom": "^0.5.0", - "cssstyle": "^2.3.0", - "data-urls": "^3.0.2", - "decimal.js": "^10.4.1", - "domexception": "^4.0.0", - "escodegen": "^2.0.0", - "form-data": "^4.0.0", - "html-encoding-sniffer": "^3.0.0", - "http-proxy-agent": "^5.0.0", - "https-proxy-agent": "^5.0.1", + "version": "26.1.0", + "resolved": "https://registry.npmjs.org/jsdom/-/jsdom-26.1.0.tgz", + "integrity": "sha512-Cvc9WUhxSMEo4McES3P7oK3QaXldCfNWp7pl2NNeiIFlCoLr3kfq9kb1fxftiwk1FLV7CvpvDfonxtzUDeSOPg==", + "dev": true, + "requires": { + "cssstyle": "^4.2.1", + "data-urls": "^5.0.0", + "decimal.js": "^10.5.0", + "html-encoding-sniffer": "^4.0.0", + "http-proxy-agent": "^7.0.2", + "https-proxy-agent": "^7.0.6", "is-potential-custom-element-name": "^1.0.1", - "nwsapi": "^2.2.2", - "parse5": "^7.1.1", + "nwsapi": "^2.2.16", + "parse5": "^7.2.1", + "rrweb-cssom": "^0.8.0", "saxes": "^6.0.0", "symbol-tree": "^3.2.4", - "tough-cookie": "^4.1.2", - "w3c-xmlserializer": "^3.0.0", + "tough-cookie": "^5.1.1", + "w3c-xmlserializer": "^5.0.0", "webidl-conversions": "^7.0.0", - "whatwg-encoding": "^2.0.0", - "whatwg-mimetype": "^3.0.0", - "whatwg-url": "^11.0.0", - "ws": "^8.9.0", - "xml-name-validator": "^4.0.0" + "whatwg-encoding": "^3.1.1", + "whatwg-mimetype": "^4.0.0", + "whatwg-url": "^14.1.1", + "ws": "^8.18.0", + "xml-name-validator": "^5.0.0" } }, "jsesc": { @@ -10898,16 +11310,6 @@ "integrity": "sha512-qsda+H8jTaUaN/x5vzW2rzc+8Rw4TAQ/4KjB46IwK5VH+IlVeeeje/EoZRpiXvIqjFgK84QffqPztGI3VBLG1A==", "dev": true }, - "levn": { - "version": "0.3.0", - "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", - "integrity": "sha512-0OO4y2iOHix2W6ujICbKIaEQXvFQHue65vUG3pb5EUomzPI90z9hsA1VsO/dbIIpC53J8gxM9Q4Oho0jrCM/yA==", - "dev": true, - "requires": { - "prelude-ls": "~1.1.2", - "type-check": "~0.3.2" - } - }, "lilconfig": { "version": "3.1.3", "resolved": "https://registry.npmjs.org/lilconfig/-/lilconfig-3.1.3.tgz", @@ -11394,9 +11796,9 @@ } }, "nwsapi": { - "version": "2.2.2", - "resolved": "https://registry.npmjs.org/nwsapi/-/nwsapi-2.2.2.tgz", - "integrity": "sha512-90yv+6538zuvUMnN+zCr8LuV6bPFdq50304114vJYJ8RDyK8D5O9Phpbd6SZWgI7PwzmmfN1upeOJlvybDSgCw==", + "version": "2.2.21", + "resolved": "https://registry.npmjs.org/nwsapi/-/nwsapi-2.2.21.tgz", + "integrity": "sha512-o6nIY3qwiSXl7/LuOU0Dmuctd34Yay0yeuZRLFmDPrrdHpXKFndPj3hM+YEPVHYC5fx2otBx4Ilc/gyYSAUaIA==", "dev": true }, "once": { @@ -11417,20 +11819,6 @@ "mimic-fn": "^2.1.0" } }, - "optionator": { - "version": "0.8.3", - "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.3.tgz", - "integrity": "sha512-+IW9pACdk3XWmmTXG8m3upGUJst5XRGzxMRjXzAuJ1XnIFNvfhjjIuYkDvysnPQ7qzqVzLt78BCruntqRhWQbA==", - "dev": true, - "requires": { - "deep-is": "~0.1.3", - "fast-levenshtein": "~2.0.6", - "levn": "~0.3.0", - "prelude-ls": "~1.1.2", - "type-check": "~0.3.2", - "word-wrap": "~1.2.3" - } - }, "p-limit": { "version": "3.1.0", "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", @@ -11509,12 +11897,12 @@ "dev": true }, "parse5": { - "version": "7.1.1", - "resolved": "https://registry.npmjs.org/parse5/-/parse5-7.1.1.tgz", - "integrity": "sha512-kwpuwzB+px5WUg9pyK0IcK/shltJN5/OVhQagxhCQNtT9Y9QRZqNY2e1cmbu/paRh5LMnz/oVTVLBpjFmMZhSg==", + "version": "7.3.0", + "resolved": "https://registry.npmjs.org/parse5/-/parse5-7.3.0.tgz", + "integrity": "sha512-IInvU7fabl34qmi9gY8XOVxhYyMyuH2xUNpb2q8/Y+7552KlejkRvqvD19nMoUW/uQGGbqNpA6Tufu5FL5BZgw==", "dev": true, "requires": { - "entities": "^4.4.0" + "entities": "^6.0.0" } }, "path-exists": { @@ -11580,12 +11968,6 @@ "integrity": "sha512-fnWVljUchTro6RiCFvCXBbNhJc2NijN7oIQxbwsyL0buWJPG85v81ehlHI9fXrJsMNgTofEoWIQeClKpgxFLrg==", "dev": true }, - "prelude-ls": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", - "integrity": "sha512-ESF23V4SKG6lVSGZgYNpbsiaAkdab6ZgOxe52p7+Kid3W3u3bxR4Vfd/o21dmN7jSt0IwgZ4v5MUd26FEtXE9w==", - "dev": true - }, "prettier": { "version": "3.6.2", "resolved": "https://registry.npmjs.org/prettier/-/prettier-3.6.2.tgz", @@ -11626,16 +12008,10 @@ "resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz", "integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==" }, - "psl": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/psl/-/psl-1.9.0.tgz", - "integrity": "sha512-E/ZsdU4HLs/68gYzgGTkMicWTLPdAftJLfJFlLUAAKZGkStNU72sZjT66SnMDVOfOWY/YAoiD7Jxa9iHvngcag==", - "dev": true - }, "punycode": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", - "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", + "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==", "dev": true }, "pure-rand": { @@ -11644,12 +12020,6 @@ "integrity": "sha512-KddyFewCsO0j3+np81IQ+SweXLDnDQTs5s67BOnrYmYe/yNmUhttQyGsYzy8yUnoljGAQ9sl38YB4vH8ur7Y+w==", "dev": true }, - "querystringify": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/querystringify/-/querystringify-2.2.0.tgz", - "integrity": "sha512-FIqgj2EUvTa7R50u0rGsyTftzjYmv/a3hO345bZNrqabNqjtgiDMgmo4mkUjd+nzU5oF3dClKqFIPUKybUyqoQ==", - "dev": true - }, "react-is": { "version": "17.0.2", "resolved": "https://registry.npmjs.org/react-is/-/react-is-17.0.2.tgz", @@ -11689,12 +12059,6 @@ "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", "dev": true }, - "requires-port": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/requires-port/-/requires-port-1.0.0.tgz", - "integrity": "sha512-KigOCHcocU3XODJxsu8i/j8T9tzT4adHiecwORRQ0ZZFcp7ahwXuRU1m+yuO90C5ZUyGeGfocHDI14M3L3yDAQ==", - "dev": true - }, "resolve": { "version": "1.22.6", "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.6.tgz", @@ -11760,6 +12124,12 @@ "integrity": "sha512-q1b3N5QkRUWUl7iyylaaj3kOpIT0N2i9MqIEQXP73GVsN9cw3fdx8X63cEmWhJGi2PPCF23Ijp7ktmd39rawIA==", "dev": true }, + "rrweb-cssom": { + "version": "0.8.0", + "resolved": "https://registry.npmjs.org/rrweb-cssom/-/rrweb-cssom-0.8.0.tgz", + "integrity": "sha512-guoltQEx+9aMf2gDZ0s62EcV8lsXR+0w8915TC3ITdn2YueuNjdAYh/levpU9nFaoChh9RUS5ZdQMrKfVEN9tw==", + "dev": true + }, "safe-buffer": { "version": "5.2.1", "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", @@ -11898,9 +12268,9 @@ "dev": true }, "stack-utils": { - "version": "2.0.5", - "resolved": "https://registry.npmjs.org/stack-utils/-/stack-utils-2.0.5.tgz", - "integrity": "sha512-xrQcmYhOsn/1kX+Vraq+7j4oE2j/6BFscZ0etmYg81xuM8Gq0022Pxb8+IqgOFUIaxHs0KaSb7T1+OegiNrNFA==", + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/stack-utils/-/stack-utils-2.0.6.tgz", + "integrity": "sha512-XlkWvfIm6RmsWtNJx+uqtKLS8eqFbxUg0ZzLXqY0caEy9l7hruX8IpiDnjsLavoBgqCCR71TqWO8MaXYheJ3RQ==", "dev": true, "requires": { "escape-string-regexp": "^2.0.0" @@ -12019,6 +12389,21 @@ "readable-stream": "3" } }, + "tldts": { + "version": "6.1.86", + "resolved": "https://registry.npmjs.org/tldts/-/tldts-6.1.86.tgz", + "integrity": "sha512-WMi/OQ2axVTf/ykqCQgXiIct+mSQDFdH2fkwhPwgEwvJ1kSzZRiinb0zF2Xb8u4+OqPChmyI6MEu4EezNJz+FQ==", + "dev": true, + "requires": { + "tldts-core": "^6.1.86" + } + }, + "tldts-core": { + "version": "6.1.86", + "resolved": "https://registry.npmjs.org/tldts-core/-/tldts-core-6.1.86.tgz", + "integrity": "sha512-Je6p7pkk+KMzMv2XXKmAE3McmolOQFdxkKw0R8EYNr7sELW46JqnNeTX8ybPiQgvg1ymCoF8LXs5fzFaZvJPTA==", + "dev": true + }, "tmpl": { "version": "1.0.5", "resolved": "https://registry.npmjs.org/tmpl/-/tmpl-1.0.5.tgz", @@ -12041,24 +12426,21 @@ } }, "tough-cookie": { - "version": "4.1.3", - "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-4.1.3.tgz", - "integrity": "sha512-aX/y5pVRkfRnfmuX+OdbSdXvPe6ieKX/G2s7e98f4poJHnqH3281gDPm/metm6E/WRamfx7WC4HUqkWHfQHprw==", + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-5.1.2.tgz", + "integrity": "sha512-FVDYdxtnj0G6Qm/DhNPSb8Ju59ULcup3tuJxkFb5K8Bv2pUXILbf0xZWU8PX8Ov19OXljbUyveOFwRMwkXzO+A==", "dev": true, "requires": { - "psl": "^1.1.33", - "punycode": "^2.1.1", - "universalify": "^0.2.0", - "url-parse": "^1.5.3" + "tldts": "^6.1.32" } }, "tr46": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/tr46/-/tr46-3.0.0.tgz", - "integrity": "sha512-l7FvfAHlcmulp8kr+flpQZmVwtu7nfRV7NZujtN0OqES8EL4O4e0qqzL0DC5gAvx/ZC/9lk6rhcUwYvkBnBnYA==", + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/tr46/-/tr46-5.1.1.tgz", + "integrity": "sha512-hdF5ZgjTqgAntKkklYw0R03MG2x/bSzTtkxmIRw/sTNV8YXsCJ1tfLAX23lhxhHJlEf3CRCOCGGWw3vI3GaSPw==", "dev": true, "requires": { - "punycode": "^2.1.1" + "punycode": "^2.3.1" } }, "tunnel": { @@ -12067,15 +12449,6 @@ "integrity": "sha512-1h/Lnq9yajKY2PEbBadPXj3VxsDDu844OnaAo52UVmIzIvwwtBPIuNvkjuzBlTWpfJyUbG3ez0KSBibQkj4ojg==", "dev": true }, - "type-check": { - "version": "0.3.2", - "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", - "integrity": "sha512-ZCmOJdvOWDBYJlzAoFkC+Q0+bUyEOS1ltgp1MGU03fqHG+dbi9tBFU2Rd9QKiDZFAYrhPh2JUf7rZRIuHRKtOg==", - "dev": true, - "requires": { - "prelude-ls": "~1.1.2" - } - }, "type-detect": { "version": "4.0.8", "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", @@ -12103,12 +12476,6 @@ "integrity": "sha512-yCzhz6FN2wU1NiiQRogkTQszlQSlpWaw8SvVegAc+bDxbzHgh1vX8uIe8OYyMH6DwH+sdTJsgMl36+mSMdRJIQ==", "dev": true }, - "universalify": { - "version": "0.2.0", - "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.2.0.tgz", - "integrity": "sha512-CJ1QgKmNg3CwvAv/kOFmtnEN05f0D/cn9QntgNOQlQF9dgvVTHj3t+8JPdjqawCHk7V/KA+fbUqzZ9XWhcqPUg==", - "dev": true - }, "update-browserslist-db": { "version": "1.0.11", "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.11.tgz", @@ -12133,16 +12500,6 @@ "punycode": "^2.1.0" } }, - "url-parse": { - "version": "1.5.10", - "resolved": "https://registry.npmjs.org/url-parse/-/url-parse-1.5.10.tgz", - "integrity": "sha512-WypcfiRhfeUP9vvF0j6rw0J3hrWrw6iZv3+22h6iRMJ/8z1Tj6XfLP4DsUix5MhMPnXpiHDoKyoZ/bdCkwBCiQ==", - "dev": true, - "requires": { - "querystringify": "^2.1.1", - "requires-port": "^1.0.0" - } - }, "util-deprecate": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", @@ -12169,12 +12526,12 @@ } }, "w3c-xmlserializer": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/w3c-xmlserializer/-/w3c-xmlserializer-3.0.0.tgz", - "integrity": "sha512-3WFqGEgSXIyGhOmAFtlicJNMjEps8b1MG31NCA0/vOF9+nKMUW1ckhi9cnNHmf88Rzw5V+dwIwsm2C7X8k9aQg==", + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/w3c-xmlserializer/-/w3c-xmlserializer-5.0.0.tgz", + "integrity": "sha512-o8qghlI8NZHU1lLPrpi2+Uq7abh4GGPpYANlalzWxyWteJOCsr/P+oPBA49TOLu5FTZO4d3F9MnWJfiMo4BkmA==", "dev": true, "requires": { - "xml-name-validator": "^4.0.0" + "xml-name-validator": "^5.0.0" } }, "walker": { @@ -12193,27 +12550,27 @@ "dev": true }, "whatwg-encoding": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/whatwg-encoding/-/whatwg-encoding-2.0.0.tgz", - "integrity": "sha512-p41ogyeMUrw3jWclHWTQg1k05DSVXPLcVxRTYsXUk+ZooOCZLcoYgPZ/HL/D/N+uQPOtcp1me1WhBEaX02mhWg==", + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/whatwg-encoding/-/whatwg-encoding-3.1.1.tgz", + "integrity": "sha512-6qN4hJdMwfYBtE3YBTTHhoeuUrDBPZmbQaxWAqSALV/MeEnR5z1xd8UKud2RAkFoPkmB+hli1TZSnyi84xz1vQ==", "dev": true, "requires": { "iconv-lite": "0.6.3" } }, "whatwg-mimetype": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/whatwg-mimetype/-/whatwg-mimetype-3.0.0.tgz", - "integrity": "sha512-nt+N2dzIutVRxARx1nghPKGv1xHikU7HKdfafKkLNLindmPU/ch3U31NOCGGA/dmPcmb1VlofO0vnKAcsm0o/Q==", + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/whatwg-mimetype/-/whatwg-mimetype-4.0.0.tgz", + "integrity": "sha512-QaKxh0eNIi2mE9p2vEdzfagOKHCcj1pJ56EEHGQOVxp8r9/iszLUUV7v89x9O1p/T+NlTM5W7jW6+cz4Fq1YVg==", "dev": true }, "whatwg-url": { - "version": "11.0.0", - "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-11.0.0.tgz", - "integrity": "sha512-RKT8HExMpoYx4igMiVMY83lN6UeITKJlBQ+vR/8ZJ8OCdSiN3RwCq+9gH0+Xzj0+5IrM6i4j/6LuvzbZIQgEcQ==", + "version": "14.2.0", + "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-14.2.0.tgz", + "integrity": "sha512-De72GdQZzNTUBBChsXueQUnPKDkg/5A5zp7pFDuQAj5UFoENpiACU0wlCvzpAGnTkj++ihpKwKyYewn/XNUbKw==", "dev": true, "requires": { - "tr46": "^3.0.0", + "tr46": "^5.1.0", "webidl-conversions": "^7.0.0" } }, @@ -12259,16 +12616,16 @@ } }, "ws": { - "version": "8.17.1", - "resolved": "https://registry.npmjs.org/ws/-/ws-8.17.1.tgz", - "integrity": "sha512-6XQFvXTkbfUOZOKKILFG1PDK2NDQs4azKQl26T0YS5CxqWLgXajbPZ+h4gZekJyRqFU8pvnbAbbs/3TgRPy+GQ==", + "version": "8.18.3", + "resolved": "https://registry.npmjs.org/ws/-/ws-8.18.3.tgz", + "integrity": "sha512-PEIGCY5tSlUt50cqyMXfCzX+oOPqN0vuGqWzbcJ2xvnkzkq46oOpz7dQaTDBdfICb4N14+GARUDw2XV2N4tvzg==", "dev": true, "requires": {} }, "xml-name-validator": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/xml-name-validator/-/xml-name-validator-4.0.0.tgz", - "integrity": "sha512-ICP2e+jsHvAj2E2lIHxa5tjXRlKDJo4IdvPvCXbXQGdzSfmSpNVyIKMvoZHjDY9DP0zV17iI85o90vRFXNccRw==", + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/xml-name-validator/-/xml-name-validator-5.0.0.tgz", + "integrity": "sha512-EvGK8EJ3DhaHfbRlETOWAS5pO9MZITeauHKJyb8wyajUfQUenkIg2MvLDTZ4T/TgIcm3HU0TFBgWWboAZ30UHg==", "dev": true }, "xmlchars": { diff --git a/package.json b/package.json index 76c920c135c8d..b3579977793f7 100644 --- a/package.json +++ b/package.json @@ -53,7 +53,7 @@ "husky": "^9.1.7", "jest": "^29.7.0", "jest-bench": "^29.7.1", - "jest-environment-jsdom": "^29.7.0", + "jest-environment-jsdom": "^30.0.5", "js-yaml": "^4.1.0", "lint-staged": "^15.5.1", "lodash.snakecase": "^4.1.1", From 32964d1b253e0c50b5cac7f5fa2bc10a4e5ba3df Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Sun, 24 Aug 2025 20:40:21 +0300 Subject: [PATCH 014/265] build(deps-dev): bump lint-staged from 15.5.1 to 16.1.5 (#4362) Bumps [lint-staged](https://github.com/lint-staged/lint-staged) from 15.5.1 to 16.1.5. - [Release notes](https://github.com/lint-staged/lint-staged/releases) - [Changelog](https://github.com/lint-staged/lint-staged/blob/main/CHANGELOG.md) - [Commits](https://github.com/lint-staged/lint-staged/compare/v15.5.1...v16.1.5) --- updated-dependencies: - dependency-name: lint-staged dependency-version: 16.1.5 dependency-type: direct:development update-type: version-update:semver-major ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- package-lock.json | 362 +++++++++++----------------------------------- package.json | 2 +- 2 files changed, 84 insertions(+), 280 deletions(-) diff --git a/package-lock.json b/package-lock.json index 5699e7969d81e..5401ed3321293 100644 --- a/package-lock.json +++ b/package-lock.json @@ -36,7 +36,7 @@ "jest-bench": "^29.7.1", "jest-environment-jsdom": "^30.0.5", "js-yaml": "^4.1.0", - "lint-staged": "^15.5.1", + "lint-staged": "^16.1.5", "lodash.snakecase": "^4.1.1", "parse-diff": "^0.11.1", "prettier": "^3.6.2" @@ -2555,9 +2555,9 @@ } }, "node_modules/cli-truncate/node_modules/ansi-regex": { - "version": "6.1.0", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.1.0.tgz", - "integrity": "sha512-7HSX4QQb4CspciLpVFwyRe79O3xsIZDDLER21kERQ71oaPodF8jL725AgJMFAYbooIqolJoRLuM81SpeUkpkvA==", + "version": "6.2.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.2.0.tgz", + "integrity": "sha512-TKY5pyBkHyADOPYlRT9Lx6F544mPl0vS5Ew7BJ45hA08Q+t3GjbueLliBWN3sMICk6+y7HdyxSzC4bWS8baBdg==", "dev": true, "engines": { "node": ">=12" @@ -2676,13 +2676,12 @@ } }, "node_modules/commander": { - "version": "13.1.0", - "resolved": "https://registry.npmjs.org/commander/-/commander-13.1.0.tgz", - "integrity": "sha512-/rFeCpNJQbhSZjGVwO9RFV3xPqbnERS8MmIQzCtD/zl6gpJuV/bMLuN92oG3F7d8oDEHHRrujSXNUr8fpjntKw==", + "version": "14.0.0", + "resolved": "https://registry.npmjs.org/commander/-/commander-14.0.0.tgz", + "integrity": "sha512-2uM9rYjPvyq39NwLRqaiLtWHyDC1FvryJDa2ATTVims5YAS4PupsEQsDvP14FqhFr0P49CYDugi59xaxJlTXRA==", "dev": true, - "license": "MIT", "engines": { - "node": ">=18" + "node": ">=20" } }, "node_modules/comment-parser": { @@ -5433,37 +5432,36 @@ "dev": true }, "node_modules/lint-staged": { - "version": "15.5.1", - "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-15.5.1.tgz", - "integrity": "sha512-6m7u8mue4Xn6wK6gZvSCQwBvMBR36xfY24nF5bMTf2MHDYG6S3yhJuOgdYVw99hsjyDt2d4z168b3naI8+NWtQ==", + "version": "16.1.5", + "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-16.1.5.tgz", + "integrity": "sha512-uAeQQwByI6dfV7wpt/gVqg+jAPaSp8WwOA8kKC/dv1qw14oGpnpAisY65ibGHUGDUv0rYaZ8CAJZ/1U8hUvC2A==", "dev": true, - "license": "MIT", "dependencies": { - "chalk": "^5.4.1", - "commander": "^13.1.0", - "debug": "^4.4.0", - "execa": "^8.0.1", + "chalk": "^5.5.0", + "commander": "^14.0.0", + "debug": "^4.4.1", "lilconfig": "^3.1.3", - "listr2": "^8.2.5", + "listr2": "^9.0.1", "micromatch": "^4.0.8", + "nano-spawn": "^1.0.2", "pidtree": "^0.6.0", "string-argv": "^0.3.2", - "yaml": "^2.7.0" + "yaml": "^2.8.1" }, "bin": { "lint-staged": "bin/lint-staged.js" }, "engines": { - "node": ">=18.12.0" + "node": ">=20.17" }, "funding": { "url": "https://opencollective.com/lint-staged" } }, "node_modules/lint-staged/node_modules/chalk": { - "version": "5.4.1", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-5.4.1.tgz", - "integrity": "sha512-zgVZuo2WcZgfUEmsn6eO3kINexW8RAE4maiQ8QNs8CtpPCSyMiYsULR3HQYkm3w8FIA3SberyMJMSldGsW+U3w==", + "version": "5.6.0", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-5.6.0.tgz", + "integrity": "sha512-46QrSQFyVSEyYAgQ22hQ+zDa60YHA4fBstHmtSApj1Y5vKtG27fWowW03jCk5KcbXEWPZUIR894aARCA/G1kfQ==", "dev": true, "engines": { "node": "^12.17.0 || ^14.13 || >=16.0.0" @@ -5472,144 +5470,10 @@ "url": "https://github.com/chalk/chalk?sponsor=1" } }, - "node_modules/lint-staged/node_modules/execa": { - "version": "8.0.1", - "resolved": "https://registry.npmjs.org/execa/-/execa-8.0.1.tgz", - "integrity": "sha512-VyhnebXciFV2DESc+p6B+y0LjSm0krU4OgJN44qFAhBY0TJ+1V61tYD2+wHusZ6F9n5K+vl8k0sTy7PEfV4qpg==", - "dev": true, - "dependencies": { - "cross-spawn": "^7.0.3", - "get-stream": "^8.0.1", - "human-signals": "^5.0.0", - "is-stream": "^3.0.0", - "merge-stream": "^2.0.0", - "npm-run-path": "^5.1.0", - "onetime": "^6.0.0", - "signal-exit": "^4.1.0", - "strip-final-newline": "^3.0.0" - }, - "engines": { - "node": ">=16.17" - }, - "funding": { - "url": "https://github.com/sindresorhus/execa?sponsor=1" - } - }, - "node_modules/lint-staged/node_modules/get-stream": { - "version": "8.0.1", - "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-8.0.1.tgz", - "integrity": "sha512-VaUJspBffn/LMCJVoMvSAdmscJyS1auj5Zulnn5UoYcY531UWmdwhRWkcGKnGU93m5HSXP9LP2usOryrBtQowA==", - "dev": true, - "engines": { - "node": ">=16" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/lint-staged/node_modules/human-signals": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-5.0.0.tgz", - "integrity": "sha512-AXcZb6vzzrFAUE61HnN4mpLqd/cSIwNQjtNWR0euPm6y0iqx3G4gOXaIDdtdDwZmhwe82LA6+zinmW4UBWVePQ==", - "dev": true, - "engines": { - "node": ">=16.17.0" - } - }, - "node_modules/lint-staged/node_modules/is-stream": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-3.0.0.tgz", - "integrity": "sha512-LnQR4bZ9IADDRSkvpqMGvt/tEJWclzklNgSw48V5EAaAeDd6qGvN8ei6k5p0tvxSR171VmGyHuTiAOfxAbr8kA==", - "dev": true, - "engines": { - "node": "^12.20.0 || ^14.13.1 || >=16.0.0" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/lint-staged/node_modules/mimic-fn": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-4.0.0.tgz", - "integrity": "sha512-vqiC06CuhBTUdZH+RYl8sFrL096vA45Ok5ISO6sE/Mr1jRbGH4Csnhi8f3wKVl7x8mO4Au7Ir9D3Oyv1VYMFJw==", - "dev": true, - "engines": { - "node": ">=12" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/lint-staged/node_modules/npm-run-path": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-5.1.0.tgz", - "integrity": "sha512-sJOdmRGrY2sjNTRMbSvluQqg+8X7ZK61yvzBEIDhz4f8z1TZFYABsqjjCBd/0PUNE9M6QDgHJXQkGUEm7Q+l9Q==", - "dev": true, - "dependencies": { - "path-key": "^4.0.0" - }, - "engines": { - "node": "^12.20.0 || ^14.13.1 || >=16.0.0" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/lint-staged/node_modules/onetime": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/onetime/-/onetime-6.0.0.tgz", - "integrity": "sha512-1FlR+gjXK7X+AsAHso35MnyN5KqGwJRi/31ft6x0M194ht7S+rWAvd7PHss9xSKMzE0asv1pyIHaJYq+BbacAQ==", - "dev": true, - "dependencies": { - "mimic-fn": "^4.0.0" - }, - "engines": { - "node": ">=12" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/lint-staged/node_modules/path-key": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/path-key/-/path-key-4.0.0.tgz", - "integrity": "sha512-haREypq7xkM7ErfgIyA0z+Bj4AGKlMSdlQE2jvJo6huWD1EdkKYV+G/T4nq0YEF2vgTT8kqMFKo1uHn950r4SQ==", - "dev": true, - "engines": { - "node": ">=12" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/lint-staged/node_modules/signal-exit": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-4.1.0.tgz", - "integrity": "sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw==", - "dev": true, - "engines": { - "node": ">=14" - }, - "funding": { - "url": "https://github.com/sponsors/isaacs" - } - }, - "node_modules/lint-staged/node_modules/strip-final-newline": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-3.0.0.tgz", - "integrity": "sha512-dOESqjYr96iWYylGObzd39EuNTa5VJxyvVAEm5Jnh7KGo75V43Hk1odPQkNDyXNmUR6k+gEiDVXnjB8HJ3crXw==", - "dev": true, - "engines": { - "node": ">=12" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, "node_modules/listr2": { - "version": "8.2.5", - "resolved": "https://registry.npmjs.org/listr2/-/listr2-8.2.5.tgz", - "integrity": "sha512-iyAZCeyD+c1gPyE9qpFu8af0Y+MRtmKOncdGoA2S5EY8iFq99dmmvkNnHiWo+pj0s7yH7l3KPIgee77tKpXPWQ==", + "version": "9.0.2", + "resolved": "https://registry.npmjs.org/listr2/-/listr2-9.0.2.tgz", + "integrity": "sha512-VVd7cS6W+vLJu2wmq4QmfVj14Iep7cz4r/OWNk36Aq5ZOY7G8/BfCrQFexcwB1OIxB3yERiePfE/REBjEFulag==", "dev": true, "dependencies": { "cli-truncate": "^4.0.0", @@ -5620,13 +5484,13 @@ "wrap-ansi": "^9.0.0" }, "engines": { - "node": ">=18.0.0" + "node": ">=20.0.0" } }, "node_modules/listr2/node_modules/ansi-regex": { - "version": "6.1.0", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.1.0.tgz", - "integrity": "sha512-7HSX4QQb4CspciLpVFwyRe79O3xsIZDDLER21kERQ71oaPodF8jL725AgJMFAYbooIqolJoRLuM81SpeUkpkvA==", + "version": "6.2.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.2.0.tgz", + "integrity": "sha512-TKY5pyBkHyADOPYlRT9Lx6F544mPl0vS5Ew7BJ45hA08Q+t3GjbueLliBWN3sMICk6+y7HdyxSzC4bWS8baBdg==", "dev": true, "engines": { "node": ">=12" @@ -5767,9 +5631,9 @@ } }, "node_modules/log-update/node_modules/ansi-regex": { - "version": "6.1.0", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.1.0.tgz", - "integrity": "sha512-7HSX4QQb4CspciLpVFwyRe79O3xsIZDDLER21kERQ71oaPodF8jL725AgJMFAYbooIqolJoRLuM81SpeUkpkvA==", + "version": "6.2.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.2.0.tgz", + "integrity": "sha512-TKY5pyBkHyADOPYlRT9Lx6F544mPl0vS5Ew7BJ45hA08Q+t3GjbueLliBWN3sMICk6+y7HdyxSzC4bWS8baBdg==", "dev": true, "engines": { "node": ">=12" @@ -6062,6 +5926,18 @@ "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", "dev": true }, + "node_modules/nano-spawn": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/nano-spawn/-/nano-spawn-1.0.2.tgz", + "integrity": "sha512-21t+ozMQDAL/UGgQVBbZ/xXvNO10++ZPuTmKRO8k9V3AClVRht49ahtDjfY8l1q6nSHOrE5ASfthzH3ol6R/hg==", + "dev": true, + "engines": { + "node": ">=20.17" + }, + "funding": { + "url": "https://github.com/sindresorhus/nano-spawn?sponsor=1" + } + }, "node_modules/natural-compare": { "version": "1.4.0", "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", @@ -7303,16 +7179,15 @@ "dev": true }, "node_modules/yaml": { - "version": "2.7.0", - "resolved": "https://registry.npmjs.org/yaml/-/yaml-2.7.0.tgz", - "integrity": "sha512-+hSoy/QHluxmC9kCIJyL/uyFmLmc+e5CFR5Wa+bpIhIj85LVb9ZH2nVnqrHoSvKogwODv0ClqZkmiSSaIH5LTA==", + "version": "2.8.1", + "resolved": "https://registry.npmjs.org/yaml/-/yaml-2.8.1.tgz", + "integrity": "sha512-lcYcMxX2PO9XMGvAJkJ3OsNMw+/7FKes7/hgerGUYWIoWu5j/+YQqcZr5JnPZWzOsEBgMbSbiSTn/dv/69Mkpw==", "dev": true, - "license": "ISC", "bin": { "yaml": "bin.mjs" }, "engines": { - "node": ">= 14" + "node": ">= 14.6" } }, "node_modules/yargs": { @@ -9237,9 +9112,9 @@ }, "dependencies": { "ansi-regex": { - "version": "6.1.0", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.1.0.tgz", - "integrity": "sha512-7HSX4QQb4CspciLpVFwyRe79O3xsIZDDLER21kERQ71oaPodF8jL725AgJMFAYbooIqolJoRLuM81SpeUkpkvA==", + "version": "6.2.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.2.0.tgz", + "integrity": "sha512-TKY5pyBkHyADOPYlRT9Lx6F544mPl0vS5Ew7BJ45hA08Q+t3GjbueLliBWN3sMICk6+y7HdyxSzC4bWS8baBdg==", "dev": true }, "emoji-regex": { @@ -9329,9 +9204,9 @@ } }, "commander": { - "version": "13.1.0", - "resolved": "https://registry.npmjs.org/commander/-/commander-13.1.0.tgz", - "integrity": "sha512-/rFeCpNJQbhSZjGVwO9RFV3xPqbnERS8MmIQzCtD/zl6gpJuV/bMLuN92oG3F7d8oDEHHRrujSXNUr8fpjntKw==", + "version": "14.0.0", + "resolved": "https://registry.npmjs.org/commander/-/commander-14.0.0.tgz", + "integrity": "sha512-2uM9rYjPvyq39NwLRqaiLtWHyDC1FvryJDa2ATTVims5YAS4PupsEQsDvP14FqhFr0P49CYDugi59xaxJlTXRA==", "dev": true }, "comment-parser": { @@ -11323,112 +11198,35 @@ "dev": true }, "lint-staged": { - "version": "15.5.1", - "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-15.5.1.tgz", - "integrity": "sha512-6m7u8mue4Xn6wK6gZvSCQwBvMBR36xfY24nF5bMTf2MHDYG6S3yhJuOgdYVw99hsjyDt2d4z168b3naI8+NWtQ==", + "version": "16.1.5", + "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-16.1.5.tgz", + "integrity": "sha512-uAeQQwByI6dfV7wpt/gVqg+jAPaSp8WwOA8kKC/dv1qw14oGpnpAisY65ibGHUGDUv0rYaZ8CAJZ/1U8hUvC2A==", "dev": true, "requires": { - "chalk": "^5.4.1", - "commander": "^13.1.0", - "debug": "^4.4.0", - "execa": "^8.0.1", + "chalk": "^5.5.0", + "commander": "^14.0.0", + "debug": "^4.4.1", "lilconfig": "^3.1.3", - "listr2": "^8.2.5", + "listr2": "^9.0.1", "micromatch": "^4.0.8", + "nano-spawn": "^1.0.2", "pidtree": "^0.6.0", "string-argv": "^0.3.2", - "yaml": "^2.7.0" + "yaml": "^2.8.1" }, "dependencies": { "chalk": { - "version": "5.4.1", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-5.4.1.tgz", - "integrity": "sha512-zgVZuo2WcZgfUEmsn6eO3kINexW8RAE4maiQ8QNs8CtpPCSyMiYsULR3HQYkm3w8FIA3SberyMJMSldGsW+U3w==", - "dev": true - }, - "execa": { - "version": "8.0.1", - "resolved": "https://registry.npmjs.org/execa/-/execa-8.0.1.tgz", - "integrity": "sha512-VyhnebXciFV2DESc+p6B+y0LjSm0krU4OgJN44qFAhBY0TJ+1V61tYD2+wHusZ6F9n5K+vl8k0sTy7PEfV4qpg==", - "dev": true, - "requires": { - "cross-spawn": "^7.0.3", - "get-stream": "^8.0.1", - "human-signals": "^5.0.0", - "is-stream": "^3.0.0", - "merge-stream": "^2.0.0", - "npm-run-path": "^5.1.0", - "onetime": "^6.0.0", - "signal-exit": "^4.1.0", - "strip-final-newline": "^3.0.0" - } - }, - "get-stream": { - "version": "8.0.1", - "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-8.0.1.tgz", - "integrity": "sha512-VaUJspBffn/LMCJVoMvSAdmscJyS1auj5Zulnn5UoYcY531UWmdwhRWkcGKnGU93m5HSXP9LP2usOryrBtQowA==", - "dev": true - }, - "human-signals": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-5.0.0.tgz", - "integrity": "sha512-AXcZb6vzzrFAUE61HnN4mpLqd/cSIwNQjtNWR0euPm6y0iqx3G4gOXaIDdtdDwZmhwe82LA6+zinmW4UBWVePQ==", - "dev": true - }, - "is-stream": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-3.0.0.tgz", - "integrity": "sha512-LnQR4bZ9IADDRSkvpqMGvt/tEJWclzklNgSw48V5EAaAeDd6qGvN8ei6k5p0tvxSR171VmGyHuTiAOfxAbr8kA==", - "dev": true - }, - "mimic-fn": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-4.0.0.tgz", - "integrity": "sha512-vqiC06CuhBTUdZH+RYl8sFrL096vA45Ok5ISO6sE/Mr1jRbGH4Csnhi8f3wKVl7x8mO4Au7Ir9D3Oyv1VYMFJw==", - "dev": true - }, - "npm-run-path": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-5.1.0.tgz", - "integrity": "sha512-sJOdmRGrY2sjNTRMbSvluQqg+8X7ZK61yvzBEIDhz4f8z1TZFYABsqjjCBd/0PUNE9M6QDgHJXQkGUEm7Q+l9Q==", - "dev": true, - "requires": { - "path-key": "^4.0.0" - } - }, - "onetime": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/onetime/-/onetime-6.0.0.tgz", - "integrity": "sha512-1FlR+gjXK7X+AsAHso35MnyN5KqGwJRi/31ft6x0M194ht7S+rWAvd7PHss9xSKMzE0asv1pyIHaJYq+BbacAQ==", - "dev": true, - "requires": { - "mimic-fn": "^4.0.0" - } - }, - "path-key": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/path-key/-/path-key-4.0.0.tgz", - "integrity": "sha512-haREypq7xkM7ErfgIyA0z+Bj4AGKlMSdlQE2jvJo6huWD1EdkKYV+G/T4nq0YEF2vgTT8kqMFKo1uHn950r4SQ==", - "dev": true - }, - "signal-exit": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-4.1.0.tgz", - "integrity": "sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw==", - "dev": true - }, - "strip-final-newline": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-3.0.0.tgz", - "integrity": "sha512-dOESqjYr96iWYylGObzd39EuNTa5VJxyvVAEm5Jnh7KGo75V43Hk1odPQkNDyXNmUR6k+gEiDVXnjB8HJ3crXw==", + "version": "5.6.0", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-5.6.0.tgz", + "integrity": "sha512-46QrSQFyVSEyYAgQ22hQ+zDa60YHA4fBstHmtSApj1Y5vKtG27fWowW03jCk5KcbXEWPZUIR894aARCA/G1kfQ==", "dev": true } } }, "listr2": { - "version": "8.2.5", - "resolved": "https://registry.npmjs.org/listr2/-/listr2-8.2.5.tgz", - "integrity": "sha512-iyAZCeyD+c1gPyE9qpFu8af0Y+MRtmKOncdGoA2S5EY8iFq99dmmvkNnHiWo+pj0s7yH7l3KPIgee77tKpXPWQ==", + "version": "9.0.2", + "resolved": "https://registry.npmjs.org/listr2/-/listr2-9.0.2.tgz", + "integrity": "sha512-VVd7cS6W+vLJu2wmq4QmfVj14Iep7cz4r/OWNk36Aq5ZOY7G8/BfCrQFexcwB1OIxB3yERiePfE/REBjEFulag==", "dev": true, "requires": { "cli-truncate": "^4.0.0", @@ -11440,9 +11238,9 @@ }, "dependencies": { "ansi-regex": { - "version": "6.1.0", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.1.0.tgz", - "integrity": "sha512-7HSX4QQb4CspciLpVFwyRe79O3xsIZDDLER21kERQ71oaPodF8jL725AgJMFAYbooIqolJoRLuM81SpeUkpkvA==", + "version": "6.2.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.2.0.tgz", + "integrity": "sha512-TKY5pyBkHyADOPYlRT9Lx6F544mPl0vS5Ew7BJ45hA08Q+t3GjbueLliBWN3sMICk6+y7HdyxSzC4bWS8baBdg==", "dev": true }, "ansi-styles": { @@ -11540,9 +11338,9 @@ } }, "ansi-regex": { - "version": "6.1.0", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.1.0.tgz", - "integrity": "sha512-7HSX4QQb4CspciLpVFwyRe79O3xsIZDDLER21kERQ71oaPodF8jL725AgJMFAYbooIqolJoRLuM81SpeUkpkvA==", + "version": "6.2.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.2.0.tgz", + "integrity": "sha512-TKY5pyBkHyADOPYlRT9Lx6F544mPl0vS5Ew7BJ45hA08Q+t3GjbueLliBWN3sMICk6+y7HdyxSzC4bWS8baBdg==", "dev": true }, "ansi-styles": { @@ -11749,6 +11547,12 @@ "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", "dev": true }, + "nano-spawn": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/nano-spawn/-/nano-spawn-1.0.2.tgz", + "integrity": "sha512-21t+ozMQDAL/UGgQVBbZ/xXvNO10++ZPuTmKRO8k9V3AClVRht49ahtDjfY8l1q6nSHOrE5ASfthzH3ol6R/hg==", + "dev": true + }, "natural-compare": { "version": "1.4.0", "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", @@ -12647,9 +12451,9 @@ "dev": true }, "yaml": { - "version": "2.7.0", - "resolved": "https://registry.npmjs.org/yaml/-/yaml-2.7.0.tgz", - "integrity": "sha512-+hSoy/QHluxmC9kCIJyL/uyFmLmc+e5CFR5Wa+bpIhIj85LVb9ZH2nVnqrHoSvKogwODv0ClqZkmiSSaIH5LTA==", + "version": "2.8.1", + "resolved": "https://registry.npmjs.org/yaml/-/yaml-2.8.1.tgz", + "integrity": "sha512-lcYcMxX2PO9XMGvAJkJ3OsNMw+/7FKes7/hgerGUYWIoWu5j/+YQqcZr5JnPZWzOsEBgMbSbiSTn/dv/69Mkpw==", "dev": true }, "yargs": { diff --git a/package.json b/package.json index b3579977793f7..dfc2df20a08eb 100644 --- a/package.json +++ b/package.json @@ -55,7 +55,7 @@ "jest-bench": "^29.7.1", "jest-environment-jsdom": "^30.0.5", "js-yaml": "^4.1.0", - "lint-staged": "^15.5.1", + "lint-staged": "^16.1.5", "lodash.snakecase": "^4.1.1", "parse-diff": "^0.11.1", "prettier": "^3.6.2" From 87c8cbaa5865b6be96628b324ac781db24e5a7ba Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Sun, 24 Aug 2025 20:43:47 +0300 Subject: [PATCH 015/265] build(deps-dev): bump eslint-plugin-jsdoc from 50.7.1 to 54.1.0 (#4365) Bumps [eslint-plugin-jsdoc](https://github.com/gajus/eslint-plugin-jsdoc) from 50.7.1 to 54.1.0. - [Release notes](https://github.com/gajus/eslint-plugin-jsdoc/releases) - [Changelog](https://github.com/gajus/eslint-plugin-jsdoc/blob/main/.releaserc) - [Commits](https://github.com/gajus/eslint-plugin-jsdoc/compare/v50.7.1...v54.1.0) --- updated-dependencies: - dependency-name: eslint-plugin-jsdoc dependency-version: 54.1.0 dependency-type: direct:development update-type: version-update:semver-major ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- package-lock.json | 91 ++++++++++++++++++++++------------------------- package.json | 2 +- 2 files changed, 44 insertions(+), 49 deletions(-) diff --git a/package-lock.json b/package-lock.json index 5401ed3321293..375190c4312dc 100644 --- a/package-lock.json +++ b/package-lock.json @@ -28,7 +28,7 @@ "color-contrast-checker": "^2.1.0", "eslint": "^9.33.0", "eslint-config-prettier": "^10.1.8", - "eslint-plugin-jsdoc": "^50.7.1", + "eslint-plugin-jsdoc": "^54.1.0", "globals": "^16.3.0", "hjson": "^3.2.2", "husky": "^9.1.7", @@ -751,20 +751,19 @@ } }, "node_modules/@es-joy/jsdoccomment": { - "version": "0.50.2", - "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.50.2.tgz", - "integrity": "sha512-YAdE/IJSpwbOTiaURNCKECdAwqrJuFiZhylmesBcIRawtYKnBR2wxPhoIewMg+Yu+QuYvHfJNReWpoxGBKOChA==", + "version": "0.53.0", + "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.53.0.tgz", + "integrity": "sha512-Wyed8Wfn3vMNVwrZrgLMxmqwmlcCE1/RfUAOHFzMJb3QLH03mi9Yv1iOCZjif0yx5EZUeJ+17VD1MHPka9IQjQ==", "dev": true, - "license": "MIT", "dependencies": { - "@types/estree": "^1.0.6", - "@typescript-eslint/types": "^8.11.0", + "@types/estree": "^1.0.8", + "@typescript-eslint/types": "^8.39.1", "comment-parser": "1.4.1", "esquery": "^1.6.0", - "jsdoc-type-pratt-parser": "~4.1.0" + "jsdoc-type-pratt-parser": "~4.8.0" }, "engines": { - "node": ">=18" + "node": ">=20.11.0" } }, "node_modules/@eslint-community/eslint-utils": { @@ -1985,9 +1984,9 @@ } }, "node_modules/@types/estree": { - "version": "1.0.6", - "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.6.tgz", - "integrity": "sha512-AYnb1nQyY49te+VRAVgmzfcgjYS91mY5P0TKUDCLEM+gNnA+3T6rWITXRLYCpahpqSQbN5cE+gHpnPyXjHWxcw==", + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.8.tgz", + "integrity": "sha512-dWHzHa2WqEXI/O1E9OjrocMTKJl2mSrEolh1Iomrv6U+JuNwaHXsXx9bLu5gG7BUWFIN0skIQJQ/L1rIex4X6w==", "dev": true }, "node_modules/@types/graceful-fs": { @@ -2074,11 +2073,10 @@ "dev": true }, "node_modules/@typescript-eslint/types": { - "version": "8.33.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.33.1.tgz", - "integrity": "sha512-xid1WfizGhy/TKMTwhtVOgalHwPtV8T32MS9MaH50Cwvz6x6YqRIPdD2WvW0XaqOzTV9p5xdLY0h/ZusU5Lokg==", + "version": "8.40.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.40.0.tgz", + "integrity": "sha512-ETdbFlgbAmXHyFPwqUIYrfc12ArvpBhEVgGAxVYSwli26dn8Ko+lIo4Su9vI9ykTZdJn+vJprs/0eZU0YMAEQg==", "dev": true, - "license": "MIT", "engines": { "node": "^18.18.0 || ^20.9.0 || >=21.1.0" }, @@ -2689,7 +2687,6 @@ "resolved": "https://registry.npmjs.org/comment-parser/-/comment-parser-1.4.1.tgz", "integrity": "sha512-buhp5kePrmda3vhc5B9t7pUQXAb2Tnd0qgpkIhPhkHXxJpiPJ11H0ZEU0oBpJ2QztSbzG/ZxMj/CHsYJqRHmyg==", "dev": true, - "license": "MIT", "engines": { "node": ">= 12.0.0" } @@ -3105,25 +3102,24 @@ } }, "node_modules/eslint-plugin-jsdoc": { - "version": "50.7.1", - "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-50.7.1.tgz", - "integrity": "sha512-XBnVA5g2kUVokTNUiE1McEPse5n9/mNUmuJcx52psT6zBs2eVcXSmQBvjfa7NZdfLVSy3u1pEDDUxoxpwy89WA==", + "version": "54.1.0", + "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-54.1.0.tgz", + "integrity": "sha512-tZJuW6s3gtveVsg08IbJgmfgAA1SpSkEz7KjxPEVmyAO4fPlz7zsMHdxjyn+Zku1l+wejr2JUdTFTNirRgHOrQ==", "dev": true, - "license": "BSD-3-Clause", "dependencies": { - "@es-joy/jsdoccomment": "~0.50.2", + "@es-joy/jsdoccomment": "~0.53.0", "are-docs-informative": "^0.0.2", "comment-parser": "1.4.1", "debug": "^4.4.1", "escape-string-regexp": "^4.0.0", - "espree": "^10.3.0", + "espree": "^10.4.0", "esquery": "^1.6.0", "parse-imports-exports": "^0.2.4", "semver": "^7.7.2", "spdx-expression-parse": "^4.0.0" }, "engines": { - "node": ">=18" + "node": ">=20.11.0" }, "peerDependencies": { "eslint": "^7.0.0 || ^8.0.0 || ^9.0.0" @@ -5284,11 +5280,10 @@ } }, "node_modules/jsdoc-type-pratt-parser": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-4.1.0.tgz", - "integrity": "sha512-Hicd6JK5Njt2QB6XYFS7ok9e37O8AYk3jTcppG4YVQnYjOemymvTcmc7OWsmq/Qqj5TdRFO5/x/tIPmBeRtGHg==", + "version": "4.8.0", + "resolved": "https://registry.npmjs.org/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-4.8.0.tgz", + "integrity": "sha512-iZ8Bdb84lWRuGHamRXFyML07r21pcwBrLkHEuHgEY5UbCouBwv7ECknDRKzsQIXMiqpPymqtIf8TC/shYKB5rw==", "dev": true, - "license": "MIT", "engines": { "node": ">=12.0.0" } @@ -7729,16 +7724,16 @@ "dev": true }, "@es-joy/jsdoccomment": { - "version": "0.50.2", - "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.50.2.tgz", - "integrity": "sha512-YAdE/IJSpwbOTiaURNCKECdAwqrJuFiZhylmesBcIRawtYKnBR2wxPhoIewMg+Yu+QuYvHfJNReWpoxGBKOChA==", + "version": "0.53.0", + "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.53.0.tgz", + "integrity": "sha512-Wyed8Wfn3vMNVwrZrgLMxmqwmlcCE1/RfUAOHFzMJb3QLH03mi9Yv1iOCZjif0yx5EZUeJ+17VD1MHPka9IQjQ==", "dev": true, "requires": { - "@types/estree": "^1.0.6", - "@typescript-eslint/types": "^8.11.0", + "@types/estree": "^1.0.8", + "@typescript-eslint/types": "^8.39.1", "comment-parser": "1.4.1", "esquery": "^1.6.0", - "jsdoc-type-pratt-parser": "~4.1.0" + "jsdoc-type-pratt-parser": "~4.8.0" } }, "@eslint-community/eslint-utils": { @@ -8688,9 +8683,9 @@ } }, "@types/estree": { - "version": "1.0.6", - "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.6.tgz", - "integrity": "sha512-AYnb1nQyY49te+VRAVgmzfcgjYS91mY5P0TKUDCLEM+gNnA+3T6rWITXRLYCpahpqSQbN5cE+gHpnPyXjHWxcw==", + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.8.tgz", + "integrity": "sha512-dWHzHa2WqEXI/O1E9OjrocMTKJl2mSrEolh1Iomrv6U+JuNwaHXsXx9bLu5gG7BUWFIN0skIQJQ/L1rIex4X6w==", "dev": true }, "@types/graceful-fs": { @@ -8777,9 +8772,9 @@ "dev": true }, "@typescript-eslint/types": { - "version": "8.33.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.33.1.tgz", - "integrity": "sha512-xid1WfizGhy/TKMTwhtVOgalHwPtV8T32MS9MaH50Cwvz6x6YqRIPdD2WvW0XaqOzTV9p5xdLY0h/ZusU5Lokg==", + "version": "8.40.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.40.0.tgz", + "integrity": "sha512-ETdbFlgbAmXHyFPwqUIYrfc12ArvpBhEVgGAxVYSwli26dn8Ko+lIo4Su9vI9ykTZdJn+vJprs/0eZU0YMAEQg==", "dev": true }, "@uppercod/css-to-object": { @@ -9590,17 +9585,17 @@ "requires": {} }, "eslint-plugin-jsdoc": { - "version": "50.7.1", - "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-50.7.1.tgz", - "integrity": "sha512-XBnVA5g2kUVokTNUiE1McEPse5n9/mNUmuJcx52psT6zBs2eVcXSmQBvjfa7NZdfLVSy3u1pEDDUxoxpwy89WA==", + "version": "54.1.0", + "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-54.1.0.tgz", + "integrity": "sha512-tZJuW6s3gtveVsg08IbJgmfgAA1SpSkEz7KjxPEVmyAO4fPlz7zsMHdxjyn+Zku1l+wejr2JUdTFTNirRgHOrQ==", "dev": true, "requires": { - "@es-joy/jsdoccomment": "~0.50.2", + "@es-joy/jsdoccomment": "~0.53.0", "are-docs-informative": "^0.0.2", "comment-parser": "1.4.1", "debug": "^4.4.1", "escape-string-regexp": "^4.0.0", - "espree": "^10.3.0", + "espree": "^10.4.0", "esquery": "^1.6.0", "parse-imports-exports": "^0.2.4", "semver": "^7.7.2", @@ -11089,9 +11084,9 @@ } }, "jsdoc-type-pratt-parser": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-4.1.0.tgz", - "integrity": "sha512-Hicd6JK5Njt2QB6XYFS7ok9e37O8AYk3jTcppG4YVQnYjOemymvTcmc7OWsmq/Qqj5TdRFO5/x/tIPmBeRtGHg==", + "version": "4.8.0", + "resolved": "https://registry.npmjs.org/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-4.8.0.tgz", + "integrity": "sha512-iZ8Bdb84lWRuGHamRXFyML07r21pcwBrLkHEuHgEY5UbCouBwv7ECknDRKzsQIXMiqpPymqtIf8TC/shYKB5rw==", "dev": true }, "jsdom": { diff --git a/package.json b/package.json index dfc2df20a08eb..264762c796ffb 100644 --- a/package.json +++ b/package.json @@ -47,7 +47,7 @@ "color-contrast-checker": "^2.1.0", "eslint": "^9.33.0", "eslint-config-prettier": "^10.1.8", - "eslint-plugin-jsdoc": "^50.7.1", + "eslint-plugin-jsdoc": "^54.1.0", "globals": "^16.3.0", "hjson": "^3.2.2", "husky": "^9.1.7", From 0425bc7b05e46c09901073214129603a1cfb90a5 Mon Sep 17 00:00:00 2001 From: "github-actions[bot]" <41898282+github-actions[bot]@users.noreply.github.com> Date: Mon, 1 Sep 2025 18:38:51 +0300 Subject: [PATCH 016/265] refactor: update languages JSON (#4395) Co-authored-by: Alexandr Garbuzov --- src/common/languageColors.json | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/src/common/languageColors.json b/src/common/languageColors.json index 6c23a4bb20b24..9d25c8909904d 100644 --- a/src/common/languageColors.json +++ b/src/common/languageColors.json @@ -68,6 +68,7 @@ "C": "#555555", "C#": "#178600", "C++": "#f34b7d", + "C3": "#2563eb", "CAP CDS": "#0092d1", "CLIPS": "#00A300", "CMake": "#DA3434", @@ -106,6 +107,7 @@ "Common Lisp": "#3fb68b", "Common Workflow Language": "#B5314C", "Component Pascal": "#B0CE4E", + "Cooklang": "#E15A29", "Crystal": "#000100", "Csound": "#1a1a1a", "Csound Document": "#1a1a1a", @@ -445,6 +447,7 @@ "QML": "#44a51c", "Qt Script": "#00b841", "Quake": "#882233", + "QuakeC": "#975777", "QuickBASIC": "#008080", "R": "#198CE7", "RAML": "#77d9fb", @@ -453,6 +456,7 @@ "REXX": "#d90e09", "RMarkdown": "#198ce7", "RON": "#a62c00", + "ROS Interface": "#22314e", "RPGLE": "#2BDE21", "RUNOFF": "#665a4e", "Racket": "#3c5caa", From 0a5fe6f7a62be59c9d786844049ce53f06decfa2 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Mon, 1 Sep 2025 18:39:58 +0300 Subject: [PATCH 017/265] ci(deps): bump actions/checkout from 4.1.1 to 5.0.0 (#4380) Bumps [actions/checkout](https://github.com/actions/checkout) from 4.1.1 to 5.0.0. - [Release notes](https://github.com/actions/checkout/releases) - [Changelog](https://github.com/actions/checkout/blob/main/CHANGELOG.md) - [Commits](https://github.com/actions/checkout/compare/v4.1.1...08c6903cd8c0fde910a37f88322edcfb5dd907a8) --- updated-dependencies: - dependency-name: actions/checkout dependency-version: 5.0.0 dependency-type: direct:production update-type: version-update:semver-major ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- .github/workflows/theme-prs-closer.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/theme-prs-closer.yml b/.github/workflows/theme-prs-closer.yml index 13ca8488adc69..d0bd3154e7ca4 100644 --- a/.github/workflows/theme-prs-closer.yml +++ b/.github/workflows/theme-prs-closer.yml @@ -25,7 +25,7 @@ jobs: steps: - name: Check out the code - uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 + uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 - name: Set up Git run: | From a8db2001ee659037246a6b608c8b70f910af3199 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Mon, 1 Sep 2025 18:41:09 +0300 Subject: [PATCH 018/265] build(deps-dev): bump @eslint/js from 9.33.0 to 9.34.0 (#4384) Bumps [@eslint/js](https://github.com/eslint/eslint/tree/HEAD/packages/js) from 9.33.0 to 9.34.0. - [Release notes](https://github.com/eslint/eslint/releases) - [Changelog](https://github.com/eslint/eslint/blob/main/CHANGELOG.md) - [Commits](https://github.com/eslint/eslint/commits/v9.34.0/packages/js) --- updated-dependencies: - dependency-name: "@eslint/js" dependency-version: 9.34.0 dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- package-lock.json | 32 +++++++++++++++++++++++++------- package.json | 2 +- 2 files changed, 26 insertions(+), 8 deletions(-) diff --git a/package-lock.json b/package-lock.json index 375190c4312dc..71cf85e8ab9c3 100644 --- a/package-lock.json +++ b/package-lock.json @@ -20,7 +20,7 @@ "@actions/core": "^1.11.1", "@actions/github": "^6.0.1", "@eslint/eslintrc": "^3.3.1", - "@eslint/js": "^9.33.0", + "@eslint/js": "^9.34.0", "@testing-library/dom": "^10.4.1", "@testing-library/jest-dom": "^6.6.4", "@uppercod/css-to-object": "^1.1.1", @@ -862,9 +862,9 @@ } }, "node_modules/@eslint/js": { - "version": "9.33.0", - "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.33.0.tgz", - "integrity": "sha512-5K1/mKhWaMfreBGJTwval43JJmkip0RmM+3+IuqupeSKNC/Th2Kc7ucaq5ovTSra/OOKB9c58CGSz3QMVbWt0A==", + "version": "9.34.0", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.34.0.tgz", + "integrity": "sha512-EoyvqQnBNsV1CWaEJ559rxXL4c8V92gxirbawSmVUOWXlsRxxQXl6LmCpdUblgxgSkDIqKnhzba2SjRTI/A5Rw==", "dev": true, "engines": { "node": "^18.18.0 || ^20.9.0 || >=21.1.0" @@ -3179,6 +3179,18 @@ "url": "https://opencollective.com/eslint" } }, + "node_modules/eslint/node_modules/@eslint/js": { + "version": "9.33.0", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.33.0.tgz", + "integrity": "sha512-5K1/mKhWaMfreBGJTwval43JJmkip0RmM+3+IuqupeSKNC/Th2Kc7ucaq5ovTSra/OOKB9c58CGSz3QMVbWt0A==", + "dev": true, + "engines": { + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" + }, + "funding": { + "url": "https://eslint.org/donate" + } + }, "node_modules/eslint/node_modules/escape-string-regexp": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", @@ -7803,9 +7815,9 @@ } }, "@eslint/js": { - "version": "9.33.0", - "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.33.0.tgz", - "integrity": "sha512-5K1/mKhWaMfreBGJTwval43JJmkip0RmM+3+IuqupeSKNC/Th2Kc7ucaq5ovTSra/OOKB9c58CGSz3QMVbWt0A==", + "version": "9.34.0", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.34.0.tgz", + "integrity": "sha512-EoyvqQnBNsV1CWaEJ559rxXL4c8V92gxirbawSmVUOWXlsRxxQXl6LmCpdUblgxgSkDIqKnhzba2SjRTI/A5Rw==", "dev": true }, "@eslint/object-schema": { @@ -9496,6 +9508,12 @@ "optionator": "^0.9.3" }, "dependencies": { + "@eslint/js": { + "version": "9.33.0", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.33.0.tgz", + "integrity": "sha512-5K1/mKhWaMfreBGJTwval43JJmkip0RmM+3+IuqupeSKNC/Th2Kc7ucaq5ovTSra/OOKB9c58CGSz3QMVbWt0A==", + "dev": true + }, "escape-string-regexp": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", diff --git a/package.json b/package.json index 264762c796ffb..77451983577e7 100644 --- a/package.json +++ b/package.json @@ -39,7 +39,7 @@ "@actions/core": "^1.11.1", "@actions/github": "^6.0.1", "@eslint/eslintrc": "^3.3.1", - "@eslint/js": "^9.33.0", + "@eslint/js": "^9.34.0", "@testing-library/dom": "^10.4.1", "@testing-library/jest-dom": "^6.6.4", "@uppercod/css-to-object": "^1.1.1", From d2b8d47a9f4361c76aae44ccd2fd1e78c481b883 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Mon, 1 Sep 2025 18:44:45 +0300 Subject: [PATCH 019/265] build(deps-dev): bump eslint from 9.33.0 to 9.34.0 (#4381) Bumps [eslint](https://github.com/eslint/eslint) from 9.33.0 to 9.34.0. - [Release notes](https://github.com/eslint/eslint/releases) - [Changelog](https://github.com/eslint/eslint/blob/main/CHANGELOG.md) - [Commits](https://github.com/eslint/eslint/compare/v9.33.0...v9.34.0) --- updated-dependencies: - dependency-name: eslint dependency-version: 9.34.0 dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- package-lock.json | 36 +++++++++--------------------------- package.json | 2 +- 2 files changed, 10 insertions(+), 28 deletions(-) diff --git a/package-lock.json b/package-lock.json index 71cf85e8ab9c3..3ffd87870666c 100644 --- a/package-lock.json +++ b/package-lock.json @@ -26,7 +26,7 @@ "@uppercod/css-to-object": "^1.1.1", "axios-mock-adapter": "^2.1.0", "color-contrast-checker": "^2.1.0", - "eslint": "^9.33.0", + "eslint": "^9.34.0", "eslint-config-prettier": "^10.1.8", "eslint-plugin-jsdoc": "^54.1.0", "globals": "^16.3.0", @@ -3027,9 +3027,9 @@ } }, "node_modules/eslint": { - "version": "9.33.0", - "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.33.0.tgz", - "integrity": "sha512-TS9bTNIryDzStCpJN93aC5VRSW3uTx9sClUn4B87pwiCaJh220otoI0X8mJKr+VcPtniMdN8GKjlwgWGUv5ZKA==", + "version": "9.34.0", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.34.0.tgz", + "integrity": "sha512-RNCHRX5EwdrESy3Jc9o8ie8Bog+PeYvvSR8sDGoZxNFTvZ4dlxUB3WzQ3bQMztFrSRODGrLLj8g6OFuGY/aiQg==", "dev": true, "dependencies": { "@eslint-community/eslint-utils": "^4.2.0", @@ -3038,7 +3038,7 @@ "@eslint/config-helpers": "^0.3.1", "@eslint/core": "^0.15.2", "@eslint/eslintrc": "^3.3.1", - "@eslint/js": "9.33.0", + "@eslint/js": "9.34.0", "@eslint/plugin-kit": "^0.3.5", "@humanfs/node": "^0.16.6", "@humanwhocodes/module-importer": "^1.0.1", @@ -3179,18 +3179,6 @@ "url": "https://opencollective.com/eslint" } }, - "node_modules/eslint/node_modules/@eslint/js": { - "version": "9.33.0", - "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.33.0.tgz", - "integrity": "sha512-5K1/mKhWaMfreBGJTwval43JJmkip0RmM+3+IuqupeSKNC/Th2Kc7ucaq5ovTSra/OOKB9c58CGSz3QMVbWt0A==", - "dev": true, - "engines": { - "node": "^18.18.0 || ^20.9.0 || >=21.1.0" - }, - "funding": { - "url": "https://eslint.org/donate" - } - }, "node_modules/eslint/node_modules/escape-string-regexp": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", @@ -9466,9 +9454,9 @@ "dev": true }, "eslint": { - "version": "9.33.0", - "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.33.0.tgz", - "integrity": "sha512-TS9bTNIryDzStCpJN93aC5VRSW3uTx9sClUn4B87pwiCaJh220otoI0X8mJKr+VcPtniMdN8GKjlwgWGUv5ZKA==", + "version": "9.34.0", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.34.0.tgz", + "integrity": "sha512-RNCHRX5EwdrESy3Jc9o8ie8Bog+PeYvvSR8sDGoZxNFTvZ4dlxUB3WzQ3bQMztFrSRODGrLLj8g6OFuGY/aiQg==", "dev": true, "requires": { "@eslint-community/eslint-utils": "^4.2.0", @@ -9477,7 +9465,7 @@ "@eslint/config-helpers": "^0.3.1", "@eslint/core": "^0.15.2", "@eslint/eslintrc": "^3.3.1", - "@eslint/js": "9.33.0", + "@eslint/js": "9.34.0", "@eslint/plugin-kit": "^0.3.5", "@humanfs/node": "^0.16.6", "@humanwhocodes/module-importer": "^1.0.1", @@ -9508,12 +9496,6 @@ "optionator": "^0.9.3" }, "dependencies": { - "@eslint/js": { - "version": "9.33.0", - "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.33.0.tgz", - "integrity": "sha512-5K1/mKhWaMfreBGJTwval43JJmkip0RmM+3+IuqupeSKNC/Th2Kc7ucaq5ovTSra/OOKB9c58CGSz3QMVbWt0A==", - "dev": true - }, "escape-string-regexp": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", diff --git a/package.json b/package.json index 77451983577e7..090ff0a05c802 100644 --- a/package.json +++ b/package.json @@ -45,7 +45,7 @@ "@uppercod/css-to-object": "^1.1.1", "axios-mock-adapter": "^2.1.0", "color-contrast-checker": "^2.1.0", - "eslint": "^9.33.0", + "eslint": "^9.34.0", "eslint-config-prettier": "^10.1.8", "eslint-plugin-jsdoc": "^54.1.0", "globals": "^16.3.0", From b8b89d82df7a4737e9d59ebb6994c339ba098156 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Mon, 1 Sep 2025 18:46:34 +0300 Subject: [PATCH 020/265] build(deps-dev): bump eslint-plugin-jsdoc from 54.1.0 to 54.1.1 (#4382) Bumps [eslint-plugin-jsdoc](https://github.com/gajus/eslint-plugin-jsdoc) from 54.1.0 to 54.1.1. - [Release notes](https://github.com/gajus/eslint-plugin-jsdoc/releases) - [Changelog](https://github.com/gajus/eslint-plugin-jsdoc/blob/main/.releaserc) - [Commits](https://github.com/gajus/eslint-plugin-jsdoc/compare/v54.1.0...v54.1.1) --- updated-dependencies: - dependency-name: eslint-plugin-jsdoc dependency-version: 54.1.1 dependency-type: direct:development update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- package-lock.json | 14 +++++++------- package.json | 2 +- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/package-lock.json b/package-lock.json index 3ffd87870666c..ac2a924459a0d 100644 --- a/package-lock.json +++ b/package-lock.json @@ -28,7 +28,7 @@ "color-contrast-checker": "^2.1.0", "eslint": "^9.34.0", "eslint-config-prettier": "^10.1.8", - "eslint-plugin-jsdoc": "^54.1.0", + "eslint-plugin-jsdoc": "^54.1.1", "globals": "^16.3.0", "hjson": "^3.2.2", "husky": "^9.1.7", @@ -3102,9 +3102,9 @@ } }, "node_modules/eslint-plugin-jsdoc": { - "version": "54.1.0", - "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-54.1.0.tgz", - "integrity": "sha512-tZJuW6s3gtveVsg08IbJgmfgAA1SpSkEz7KjxPEVmyAO4fPlz7zsMHdxjyn+Zku1l+wejr2JUdTFTNirRgHOrQ==", + "version": "54.1.1", + "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-54.1.1.tgz", + "integrity": "sha512-qoY2Gl0OkvATXIxRaG2irS2ue78+RTaOyYrADvg1ue+9FHE+2Mp7RcpO0epkuhhQgOkH/REv1oJFe58dYv8SGg==", "dev": true, "dependencies": { "@es-joy/jsdoccomment": "~0.53.0", @@ -9585,9 +9585,9 @@ "requires": {} }, "eslint-plugin-jsdoc": { - "version": "54.1.0", - "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-54.1.0.tgz", - "integrity": "sha512-tZJuW6s3gtveVsg08IbJgmfgAA1SpSkEz7KjxPEVmyAO4fPlz7zsMHdxjyn+Zku1l+wejr2JUdTFTNirRgHOrQ==", + "version": "54.1.1", + "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-54.1.1.tgz", + "integrity": "sha512-qoY2Gl0OkvATXIxRaG2irS2ue78+RTaOyYrADvg1ue+9FHE+2Mp7RcpO0epkuhhQgOkH/REv1oJFe58dYv8SGg==", "dev": true, "requires": { "@es-joy/jsdoccomment": "~0.53.0", diff --git a/package.json b/package.json index 090ff0a05c802..86f985ca74855 100644 --- a/package.json +++ b/package.json @@ -47,7 +47,7 @@ "color-contrast-checker": "^2.1.0", "eslint": "^9.34.0", "eslint-config-prettier": "^10.1.8", - "eslint-plugin-jsdoc": "^54.1.0", + "eslint-plugin-jsdoc": "^54.1.1", "globals": "^16.3.0", "hjson": "^3.2.2", "husky": "^9.1.7", From b0da0850cce0ba229c6b9f0b278c8076cb0dd22e Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Mon, 1 Sep 2025 18:48:50 +0300 Subject: [PATCH 021/265] build(deps-dev): bump @testing-library/jest-dom from 6.7.0 to 6.8.0 (#4383) Bumps [@testing-library/jest-dom](https://github.com/testing-library/jest-dom) from 6.7.0 to 6.8.0. - [Release notes](https://github.com/testing-library/jest-dom/releases) - [Changelog](https://github.com/testing-library/jest-dom/blob/main/CHANGELOG.md) - [Commits](https://github.com/testing-library/jest-dom/compare/v6.7.0...v6.8.0) --- updated-dependencies: - dependency-name: "@testing-library/jest-dom" dependency-version: 6.8.0 dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- package-lock.json | 14 +++++++------- package.json | 2 +- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/package-lock.json b/package-lock.json index ac2a924459a0d..04dd8361c1ce4 100644 --- a/package-lock.json +++ b/package-lock.json @@ -22,7 +22,7 @@ "@eslint/eslintrc": "^3.3.1", "@eslint/js": "^9.34.0", "@testing-library/dom": "^10.4.1", - "@testing-library/jest-dom": "^6.6.4", + "@testing-library/jest-dom": "^6.8.0", "@uppercod/css-to-object": "^1.1.1", "axios-mock-adapter": "^2.1.0", "color-contrast-checker": "^2.1.0", @@ -1912,9 +1912,9 @@ } }, "node_modules/@testing-library/jest-dom": { - "version": "6.7.0", - "resolved": "https://registry.npmjs.org/@testing-library/jest-dom/-/jest-dom-6.7.0.tgz", - "integrity": "sha512-RI2e97YZ7MRa+vxP4UUnMuMFL2buSsf0ollxUbTgrbPLKhMn8KVTx7raS6DYjC7v1NDVrioOvaShxsguLNISCA==", + "version": "6.8.0", + "resolved": "https://registry.npmjs.org/@testing-library/jest-dom/-/jest-dom-6.8.0.tgz", + "integrity": "sha512-WgXcWzVM6idy5JaftTVC8Vs83NKRmGJz4Hqs4oyOuO2J4r/y79vvKZsb+CaGyCSEbUPI6OsewfPd0G1A0/TUZQ==", "dev": true, "dependencies": { "@adobe/css-tools": "^4.4.0", @@ -8614,9 +8614,9 @@ } }, "@testing-library/jest-dom": { - "version": "6.7.0", - "resolved": "https://registry.npmjs.org/@testing-library/jest-dom/-/jest-dom-6.7.0.tgz", - "integrity": "sha512-RI2e97YZ7MRa+vxP4UUnMuMFL2buSsf0ollxUbTgrbPLKhMn8KVTx7raS6DYjC7v1NDVrioOvaShxsguLNISCA==", + "version": "6.8.0", + "resolved": "https://registry.npmjs.org/@testing-library/jest-dom/-/jest-dom-6.8.0.tgz", + "integrity": "sha512-WgXcWzVM6idy5JaftTVC8Vs83NKRmGJz4Hqs4oyOuO2J4r/y79vvKZsb+CaGyCSEbUPI6OsewfPd0G1A0/TUZQ==", "dev": true, "requires": { "@adobe/css-tools": "^4.4.0", diff --git a/package.json b/package.json index 86f985ca74855..094671c0d8881 100644 --- a/package.json +++ b/package.json @@ -41,7 +41,7 @@ "@eslint/eslintrc": "^3.3.1", "@eslint/js": "^9.34.0", "@testing-library/dom": "^10.4.1", - "@testing-library/jest-dom": "^6.6.4", + "@testing-library/jest-dom": "^6.8.0", "@uppercod/css-to-object": "^1.1.1", "axios-mock-adapter": "^2.1.0", "color-contrast-checker": "^2.1.0", From a5cdd3f5314f708c75b0f91367355fa207e98137 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov Date: Sun, 7 Sep 2025 20:37:25 +0300 Subject: [PATCH 022/265] ci: temporary disable preview theme workflow (#3514) * ci: temporary disable preview theme workflow * dev --- .github/workflows/preview-theme.yml | 13 +++++++------ 1 file changed, 7 insertions(+), 6 deletions(-) diff --git a/.github/workflows/preview-theme.yml b/.github/workflows/preview-theme.yml index f24ccd9a5ec00..6b7e46cede398 100644 --- a/.github/workflows/preview-theme.yml +++ b/.github/workflows/preview-theme.yml @@ -1,11 +1,12 @@ name: Theme preview on: - pull_request_target: - types: [opened, edited, reopened, synchronize] - branches: - - master - paths: - - "themes/index.js" + # pull_request_target: + # types: [opened, edited, reopened, synchronize] + # branches: + # - master + # paths: + # - "themes/index.js" + workflow_dispatch: permissions: actions: read From e27f7ed6d05bdfe58e843e487cd0db03991734bf Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov Date: Sun, 7 Sep 2025 20:40:46 +0300 Subject: [PATCH 023/265] ci: temporary disable stale theme pr closer workflow (#3520) --- .github/workflows/stale-theme-pr-closer.yml | 23 +++++++++++---------- 1 file changed, 12 insertions(+), 11 deletions(-) diff --git a/.github/workflows/stale-theme-pr-closer.yml b/.github/workflows/stale-theme-pr-closer.yml index 17c5e3a92e455..6a48cce2fcf62 100644 --- a/.github/workflows/stale-theme-pr-closer.yml +++ b/.github/workflows/stale-theme-pr-closer.yml @@ -1,16 +1,17 @@ name: Close stale theme pull requests that have the 'invalid' label. on: - schedule: - # ┌───────────── minute (0 - 59) - # │ ┌───────────── hour (0 - 23) - # │ │ ┌───────────── day of the month (1 - 31) - # │ │ │ ┌───────────── month (1 - 12 or JAN-DEC) - # │ │ │ │ ┌───────────── day of the week (0 - 6 or SUN-SAT) - # │ │ │ │ │ - # │ │ │ │ │ - # │ │ │ │ │ - # * * * * * - - cron: "0 0 */7 * *" + # schedule: + # # ┌───────────── minute (0 - 59) + # # │ ┌───────────── hour (0 - 23) + # # │ │ ┌───────────── day of the month (1 - 31) + # # │ │ │ ┌───────────── month (1 - 12 or JAN-DEC) + # # │ │ │ │ ┌───────────── day of the week (0 - 6 or SUN-SAT) + # # │ │ │ │ │ + # # │ │ │ │ │ + # # │ │ │ │ │ + # # * * * * * + # - cron: "0 0 */7 * *" + workflow_dispatch: permissions: actions: read From 68084d9f675869daf0029fd42ddc79c57d8a722c Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov Date: Sun, 7 Sep 2025 20:43:59 +0300 Subject: [PATCH 024/265] fix: return cache seconds value clamping which was accidentally removed in cdc6ad1 (#4379) --- api/top-langs.js | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/api/top-langs.js b/api/top-langs.js index fe5fb4afc3cfb..1c7ed68157456 100644 --- a/api/top-langs.js +++ b/api/top-langs.js @@ -1,6 +1,7 @@ import { renderTopLanguages } from "../src/cards/top-languages.js"; import { blacklist } from "../src/common/blacklist.js"; import { + clampValue, CONSTANTS, parseArray, parseBoolean, @@ -69,9 +70,10 @@ export default async (req, res) => { count_weight, ); - let cacheSeconds = parseInt( - cache_seconds || CONSTANTS.TOP_LANGS_CACHE_SECONDS, - 10, + let cacheSeconds = clampValue( + parseInt(cache_seconds || CONSTANTS.TOP_LANGS_CACHE_SECONDS, 10), + CONSTANTS.TWO_DAY, + CONSTANTS.TEN_DAY, ); cacheSeconds = process.env.CACHE_SECONDS ? parseInt(process.env.CACHE_SECONDS, 10) || cacheSeconds From 794dc6bd234aac4784b949fbdd4855d4312dd1fc Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov Date: Sun, 7 Sep 2025 20:47:14 +0300 Subject: [PATCH 025/265] docs: make table of contents opt-in (#4385) --- readme.md | 33 ++++++++++++++++++--------------- 1 file changed, 18 insertions(+), 15 deletions(-) diff --git a/readme.md b/readme.md index b6c3e36f004f9..eafbf9b248333 100644 --- a/readme.md +++ b/readme.md @@ -44,21 +44,8 @@

Love the project? Please consider donating to help it improve!

- - Give india logo - - -Are you considering supporting the project by donating to me? Please DO NOT!!! - -Picture of Coromandel Express train tragedy - -India has recently suffered one of the most devastating train accidents, and your help will be immensely valuable for the people who were affected by this tragedy. - -Please visit [this link](https://give.do/fundraisers/stand-beside-the-victims-of-the-coromandel-express-train-tragedy-in-odisha-donate-now) and make a small donation to help the people in need. A small donation goes a long way. :heart: - -

- -# Features +
+Table of contents (Click to show) - [GitHub Stats Card](#github-stats-card) - [Hiding individual stats](#hiding-individual-stats) @@ -95,6 +82,22 @@ Please visit [this link](https://give.do/fundraisers/stand-beside-the-victims-of - [Disable rate limit protections](#disable-rate-limit-protections) - [Keep your fork up to date](#keep-your-fork-up-to-date) - [:sparkling\_heart: Support the project](#sparkling_heart-support-the-project) +
+ + + + Give india logo + + +Are you considering supporting the project by donating to me? Please DO NOT!!! + +Picture of Coromandel Express train tragedy + +India has recently suffered one of the most devastating train accidents, and your help will be immensely valuable for the people who were affected by this tragedy. + +Please visit [this link](https://give.do/fundraisers/stand-beside-the-victims-of-the-coromandel-express-train-tragedy-in-odisha-donate-now) and make a small donation to help the people in need. A small donation goes a long way. :heart: + +

# Important Notices From 3878de9783b2110f5316b33cb599f1395da5bdec Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov Date: Sun, 7 Sep 2025 20:50:05 +0300 Subject: [PATCH 026/265] chore: add ms-azuretools.vscode-containers extension to the workspace recommended (#4386) --- .vscode/extensions.json | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.vscode/extensions.json b/.vscode/extensions.json index 48d1f95eda4be..540848a504fdf 100644 --- a/.vscode/extensions.json +++ b/.vscode/extensions.json @@ -2,6 +2,7 @@ "recommendations": [ "yzhang.markdown-all-in-one", "esbenp.prettier-vscode", - "dbaeumer.vscode-eslint" + "dbaeumer.vscode-eslint", + "ms-azuretools.vscode-containers" ] } From 647f2e1c88c5b933e9796769a44fe6e26b4102af Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov Date: Sun, 7 Sep 2025 20:53:13 +0300 Subject: [PATCH 027/265] ci: add missing github token env to the theme prs closer workflow (#4388) --- .github/workflows/theme-prs-closer.yml | 2 ++ 1 file changed, 2 insertions(+) diff --git a/.github/workflows/theme-prs-closer.yml b/.github/workflows/theme-prs-closer.yml index d0bd3154e7ca4..ce75833eb2908 100644 --- a/.github/workflows/theme-prs-closer.yml +++ b/.github/workflows/theme-prs-closer.yml @@ -39,3 +39,5 @@ jobs: for pr_number in $(gh pr list -l "themes" -q is:open --json number -q ".[].number"); do gh pr close $pr_number -c "$comment_message" done + env: + GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} From 8d620f6085eb3a541489602df90bd58f55786fe7 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov Date: Sun, 7 Sep 2025 20:56:19 +0300 Subject: [PATCH 028/265] refactor: simplify cache timings constants (#4390) --- src/common/utils.js | 56 +++++++++++++++++++-------------------------- 1 file changed, 24 insertions(+), 32 deletions(-) diff --git a/src/common/utils.js b/src/common/utils.js index b780657c1c244..68adafdf4a28c 100644 --- a/src/common/utils.js +++ b/src/common/utils.js @@ -440,40 +440,32 @@ const noop = () => {}; const logger = process.env.NODE_ENV === "test" ? { log: noop, error: noop } : console; -const ONE_MINUTE = 60; -const FIVE_MINUTES = 300; -const TEN_MINUTES = 600; -const FIFTEEN_MINUTES = 900; -const THIRTY_MINUTES = 1800; -const TWO_HOURS = 7200; -const FOUR_HOURS = 14400; -const SIX_HOURS = 21600; -const EIGHT_HOURS = 28800; -const TWELVE_HOURS = 43200; -const ONE_DAY = 86400; -const TWO_DAY = ONE_DAY * 2; -const SIX_DAY = ONE_DAY * 6; -const TEN_DAY = ONE_DAY * 10; +const MIN = 60; +const HOUR = 60 * MIN; +const DAY = 24 * HOUR; const CONSTANTS = { - ONE_MINUTE, - FIVE_MINUTES, - TEN_MINUTES, - FIFTEEN_MINUTES, - THIRTY_MINUTES, - TWO_HOURS, - FOUR_HOURS, - SIX_HOURS, - EIGHT_HOURS, - TWELVE_HOURS, - ONE_DAY, - TWO_DAY, - SIX_DAY, - TEN_DAY, - CARD_CACHE_SECONDS: ONE_DAY, - TOP_LANGS_CACHE_SECONDS: SIX_DAY, - PIN_CARD_CACHE_SECONDS: TEN_DAY, - ERROR_CACHE_SECONDS: TEN_MINUTES, + ONE_MINUTE: MIN, + FIVE_MINUTES: 5 * MIN, + TEN_MINUTES: 10 * MIN, + FIFTEEN_MINUTES: 15 * MIN, + THIRTY_MINUTES: 30 * MIN, + + TWO_HOURS: 2 * HOUR, + FOUR_HOURS: 4 * HOUR, + SIX_HOURS: 6 * HOUR, + EIGHT_HOURS: 8 * HOUR, + TWELVE_HOURS: 12 * HOUR, + + ONE_DAY: DAY, + TWO_DAY: 2 * DAY, + SIX_DAY: 6 * DAY, + TEN_DAY: 10 * DAY, + + CARD_CACHE_SECONDS: DAY, + TOP_LANGS_CACHE_SECONDS: 6 * DAY, + PIN_CARD_CACHE_SECONDS: 10 * DAY, + ERROR_CACHE_SECONDS: 10 * MIN, }; /** From 57ababf1c21510e6f2f906a346720112e969aa0b Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov Date: Sun, 7 Sep 2025 20:59:28 +0300 Subject: [PATCH 029/265] docs: reorder cards options sections inside readme for better readability (#4391) --- readme.md | 114 ++++++++++++++++++++++++++++++------------------------ 1 file changed, 63 insertions(+), 51 deletions(-) diff --git a/readme.md b/readme.md index eafbf9b248333..c78a8b9b0056a 100644 --- a/readme.md +++ b/readme.md @@ -55,12 +55,15 @@ - [Customization](#customization) - [GitHub Extra Pins](#github-extra-pins) - [Usage](#usage) + - [Options](#options) - [Demo](#demo) - [GitHub Gist Pins](#github-gist-pins) - [Usage](#usage-1) + - [Options](#options-1) - [Demo](#demo-1) - [Top Languages Card](#top-languages-card) - [Usage](#usage-2) + - [Options](#options-2) - [Language stats algorithm](#language-stats-algorithm) - [Exclude individual repositories](#exclude-individual-repositories) - [Hide individual languages](#hide-individual-languages) @@ -72,6 +75,7 @@ - [Hide Progress Bars](#hide-progress-bars) - [Demo](#demo-2) - [WakaTime Stats Card](#wakatime-stats-card) + - [Options](#options-3) - [Demo](#demo-3) - [All Demos](#all-demos) - [Quick Tip (Align The Cards)](#quick-tip-align-the-cards) @@ -365,55 +369,6 @@ If we don't support your language, please consider contributing! You can find mo > [!NOTE]\ > When hide\_rank=`true`, the minimum card width is 270 px + the title length and padding. -#### Repo Card Exclusive Options - -| Name | Description | Type | Default value | -| --- | --- | --- | --- | -| `show_owner` | Shows the repo's owner name. | boolean | `false` | -| `description_lines_count` | Manually set the number of lines for the description. Specified value will be clamped between 1 and 3. If this parameter is not specified, the number of lines will be automatically adjusted according to the actual length of the description. | number | `null` | - -#### Gist Card Exclusive Options - -| Name | Description | Type | Default value | -| --- | --- | --- | --- | -| `show_owner` | Shows the gist's owner name. | boolean | `false` | - -#### Language Card Exclusive Options - -| Name | Description | Type | Default value | -| --- | --- | --- | --- | -| `hide` | Hides the [specified languages](#hide-individual-languages) from card. | string (comma-separated values) | `null` | -| `hide_title` | Hides the title of your card. | boolean | `false` | -| `layout` | Switches between five available layouts `normal` & `compact` & `donut` & `donut-vertical` & `pie`. | enum | `normal` | -| `card_width` | Sets the card's width manually. | number | `300` | -| `langs_count` | Shows more languages on the card, between 1-20. | integer | `5` for `normal` and `donut`, `6` for other layouts | -| `exclude_repo` | Excludes specified repositories. | string (comma-separated values) | `null` | -| `custom_title` | Sets a custom title for the card. | string | `Most Used Languages` | -| `disable_animations` | Disables all animations in the card. | boolean | `false` | -| `hide_progress` | Uses the compact layout option, hides percentages, and removes the bars. | boolean | `false` | -| `size_weight` | Configures language stats algorithm (see [Language stats algorithm](#language-stats-algorithm)). | integer | `1` | -| `count_weight` | Configures language stats algorithm (see [Language stats algorithm](#language-stats-algorithm)). | integer | `0` | - -> [!WARNING]\ -> Language names should be URI-escaped, as specified in [Percent Encoding](https://en.wikipedia.org/wiki/Percent-encoding) -> (i.e: `c++` should become `c%2B%2B`, `jupyter notebook` should become `jupyter%20notebook`, etc.) You can use -> [urlencoder.org](https://www.urlencoder.org/) to help you do this automatically. - -#### WakaTime Card Exclusive Options - -| Name | Description | Type | Default value | -| --- | --- | --- | --- | -| `hide` | Hides the languages specified from the card. | string (comma-separated values) | `null` | -| `hide_title` | Hides the title of your card. | boolean | `false` | -| `line_height` | Sets the line height between text. | integer | `25` | -| `hide_progress` | Hides the progress bar and percentage. | boolean | `false` | -| `custom_title` | Sets a custom title for the card. | string | `WakaTime Stats` | -| `layout` | Switches between two available layouts `default` & `compact`. | enum | `default` | -| `langs_count` | Limits the number of languages on the card, defaults to all reported languages. | integer | `null` | -| `api_domain` | Sets a custom API domain for the card, e.g. to use services like [Hakatime](https://github.com/mujx/hakatime) or [Wakapi](https://github.com/muety/wakapi) | string | `wakatime.com` | -| `display_format` | Sets the WakaTime stats display format. Choose `time` to display time-based stats or `percent` to show percentages. | enum | `time` | -| `disable_animations` | Disables all animations in the card. | boolean | `false` | - *** # GitHub Extra Pins @@ -432,11 +387,20 @@ Endpoint: `api/pin?username=anuraghazra&repo=github-readme-stats` [![Readme Card](https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra&repo=github-readme-stats)](https://github.com/anuraghazra/github-readme-stats) ``` +### Options + +You can customize the appearance and behavior of the pinned repository card using the [common options](#common-options) and exclusive options listed in the table below. + +| Name | Description | Type | Default value | +| --- | --- | --- | --- | +| `show_owner` | Shows the repo's owner name. | boolean | `false` | +| `description_lines_count` | Manually set the number of lines for the description. Specified value will be clamped between 1 and 3. If this parameter is not specified, the number of lines will be automatically adjusted according to the actual length of the description. | number | `null` | + ### Demo ![Readme Card](https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra\&repo=github-readme-stats) -Use [show\_owner](#repo-card-exclusive-options) query option to include the repo's owner username +Use `show_owner` query option to include the repo's owner username ![Readme Card](https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra\&repo=github-readme-stats\&show_owner=true) @@ -454,11 +418,19 @@ Endpoint: `api/gist?id=bbfce31e0217a3689c8d961a356cb10d` [![Gist Card](https://github-readme-stats.vercel.app/api/gist?id=bbfce31e0217a3689c8d961a356cb10d)](https://gist.github.com/Yizack/bbfce31e0217a3689c8d961a356cb10d/) ``` +### Options + +You can customize the appearance and behavior of the gist card using the [common options](#common-options) and exclusive options listed in the table below. + +| Name | Description | Type | Default value | +| --- | --- | --- | --- | +| `show_owner` | Shows the gist's owner name. | boolean | `false` | + ### Demo ![Gist Card](https://github-readme-stats.vercel.app/api/gist?id=bbfce31e0217a3689c8d961a356cb10d) -Use [show\_owner](#gist-card-exclusive-options) query option to include the gist's owner username +Use `show_owner` query option to include the gist's owner username ![Gist Card](https://github-readme-stats.vercel.app/api/gist?id=bbfce31e0217a3689c8d961a356cb10d\&show_owner=true) @@ -488,6 +460,29 @@ Endpoint: `api/top-langs?username=anuraghazra` [![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) ``` +### Options + +You can customize the appearance and behavior of the top languages card using the [common options](#common-options) and exclusive options listed in the table below. + +| Name | Description | Type | Default value | +| --- | --- | --- | --- | +| `hide` | Hides the [specified languages](#hide-individual-languages) from card. | string (comma-separated values) | `null` | +| `hide_title` | Hides the title of your card. | boolean | `false` | +| `layout` | Switches between five available layouts `normal` & `compact` & `donut` & `donut-vertical` & `pie`. | enum | `normal` | +| `card_width` | Sets the card's width manually. | number | `300` | +| `langs_count` | Shows more languages on the card, between 1-20. | integer | `5` for `normal` and `donut`, `6` for other layouts | +| `exclude_repo` | Excludes specified repositories. | string (comma-separated values) | `null` | +| `custom_title` | Sets a custom title for the card. | string | `Most Used Languages` | +| `disable_animations` | Disables all animations in the card. | boolean | `false` | +| `hide_progress` | Uses the compact layout option, hides percentages, and removes the bars. | boolean | `false` | +| `size_weight` | Configures language stats algorithm (see [Language stats algorithm](#language-stats-algorithm)). | integer | `1` | +| `count_weight` | Configures language stats algorithm (see [Language stats algorithm](#language-stats-algorithm)). | integer | `0` | + +> [!WARNING]\ +> Language names should be URI-escaped, as specified in [Percent Encoding](https://en.wikipedia.org/wiki/Percent-encoding) +> (i.e: `c++` should become `c%2B%2B`, `jupyter notebook` should become `jupyter%20notebook`, etc.) You can use +> [urlencoder.org](https://www.urlencoder.org/) to help you do this automatically. + ### Language stats algorithm We use the following algorithm to calculate the languages percentages on the language card: @@ -605,6 +600,23 @@ Change the `?username=` value to your [WakaTime](https://wakatime.com) username. [![Harlok's WakaTime stats](https://github-readme-stats.vercel.app/api/wakatime?username=ffflabs)](https://github.com/anuraghazra/github-readme-stats) ``` +### Options + +You can customize the appearance and behavior of the WakaTime stats card using the [common options](#common-options) and exclusive options listed in the table below. + +| Name | Description | Type | Default value | +| --- | --- | --- | --- | +| `hide` | Hides the languages specified from the card. | string (comma-separated values) | `null` | +| `hide_title` | Hides the title of your card. | boolean | `false` | +| `line_height` | Sets the line height between text. | integer | `25` | +| `hide_progress` | Hides the progress bar and percentage. | boolean | `false` | +| `custom_title` | Sets a custom title for the card. | string | `WakaTime Stats` | +| `layout` | Switches between two available layouts `default` & `compact`. | enum | `default` | +| `langs_count` | Limits the number of languages on the card, defaults to all reported languages. | integer | `null` | +| `api_domain` | Sets a custom API domain for the card, e.g. to use services like [Hakatime](https://github.com/mujx/hakatime) or [Wakapi](https://github.com/muety/wakapi) | string | `wakatime.com` | +| `display_format` | Sets the WakaTime stats display format. Choose `time` to display time-based stats or `percent` to show percentages. | enum | `time` | +| `disable_animations` | Disables all animations in the card. | boolean | `false` | + ### Demo ![Harlok's WakaTime stats](https://github-readme-stats.vercel.app/api/wakatime?username=ffflabs) From 309f4a274901b2d98295ab4354c73c37310d6401 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov Date: Sun, 7 Sep 2025 21:05:48 +0300 Subject: [PATCH 030/265] docs: remove outdated give.india banner & fix broken HTML tags structure (#4392) --- readme.md | 90 +++++++++++++++++++++++-------------------------------- 1 file changed, 38 insertions(+), 52 deletions(-) diff --git a/readme.md b/readme.md index c78a8b9b0056a..93dde5da13586 100644 --- a/readme.md +++ b/readme.md @@ -3,45 +3,46 @@

GitHub Readme Stats

Get dynamically generated GitHub stats on your READMEs!

-

- - Tests Passing - - - GitHub Contributors - - - Tests Coverage - - - Issues - - - GitHub pull requests - - - OpenSSF Scorecard - -
-
- - - -

- -

- View Demo - · - Report Bug - · - Request Feature - · - FAQ - · - Ask Question -

+ +

+ + Tests Passing + + + GitHub Contributors + + + Tests Coverage + + + Issues + + + GitHub pull requests + + + OpenSSF Scorecard + +
+
+ + + +

+ +

+ View Demo + · + Report Bug + · + Request Feature + · + FAQ + · + Ask Question

+

Love the project? Please consider donating to help it improve!

@@ -88,21 +89,6 @@ - [:sparkling\_heart: Support the project](#sparkling_heart-support-the-project)
- - - Give india logo - - -Are you considering supporting the project by donating to me? Please DO NOT!!! - -Picture of Coromandel Express train tragedy - -India has recently suffered one of the most devastating train accidents, and your help will be immensely valuable for the people who were affected by this tragedy. - -Please visit [this link](https://give.do/fundraisers/stand-beside-the-victims-of-the-coromandel-express-train-tragedy-in-odisha-donate-now) and make a small donation to help the people in need. A small donation goes a long way. :heart: - -

- # Important Notices > [!IMPORTANT]\ From 3adf254fb8c996bef000307c7125c15fde25559b Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov Date: Sun, 7 Sep 2025 21:08:57 +0300 Subject: [PATCH 031/265] chore: remove outdated reviewer fields from dependabot config (#4393) --- .github/dependabot.yml | 4 ---- 1 file changed, 4 deletions(-) diff --git a/.github/dependabot.yml b/.github/dependabot.yml index d762530895ca6..931c461ca4ebb 100644 --- a/.github/dependabot.yml +++ b/.github/dependabot.yml @@ -9,8 +9,6 @@ updates: commit-message: prefix: "build(deps)" prefix-development: "build(deps-dev)" - reviewers: - - "qwerty541" # Maintain dependencies for GitHub Actions - package-ecosystem: github-actions @@ -21,5 +19,3 @@ updates: commit-message: prefix: "ci(deps)" prefix-development: "ci(deps-dev)" - reviewers: - - "qwerty541" From 891e31952b668bf4144b79b756d3dbf216f1c7b5 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov Date: Sun, 7 Sep 2025 21:11:55 +0300 Subject: [PATCH 032/265] chore: replace dependabot reviewer with codeowners file (#4394) --- .github/CODEOWNERS | 6 ++++++ 1 file changed, 6 insertions(+) create mode 100644 .github/CODEOWNERS diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS new file mode 100644 index 0000000000000..c3d3ae4d78452 --- /dev/null +++ b/.github/CODEOWNERS @@ -0,0 +1,6 @@ +# This file is used to define code owners for the repository. +# Code owners are automatically requested for review when someone opens a pull request that modifies code they own. + +# Assign @qwerty541 as the owner for package.json and package-lock.json +package.json @qwerty541 +package-lock.json @qwerty541 From 9f0b9c784663fc13e7b0cb29cc2052697cd8e820 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov Date: Sun, 7 Sep 2025 21:15:27 +0300 Subject: [PATCH 033/265] ci: fix prs cache clean workflow name to match naming style of other workflows (#4398) --- .github/workflows/prs-cache-clean.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/prs-cache-clean.yml b/.github/workflows/prs-cache-clean.yml index 9f45918992d01..89393b4bcd0cf 100644 --- a/.github/workflows/prs-cache-clean.yml +++ b/.github/workflows/prs-cache-clean.yml @@ -1,4 +1,4 @@ -name: prs cache clean +name: Cleanup closed pull requests cache on: pull_request: types: From 71dd0da906a228fc6fc88afa770c47f2b3364374 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov Date: Sun, 7 Sep 2025 21:18:13 +0300 Subject: [PATCH 034/265] docs: refactor quick align tip section in readme for better readability (#4399) --- readme.md | 29 +++++++++++++++++++---------- 1 file changed, 19 insertions(+), 10 deletions(-) diff --git a/readme.md b/readme.md index 93dde5da13586..891e710a32531 100644 --- a/readme.md +++ b/readme.md @@ -80,6 +80,8 @@ - [Demo](#demo-3) - [All Demos](#all-demos) - [Quick Tip (Align The Cards)](#quick-tip-align-the-cards) + - [Stats and top languages cards](#stats-and-top-languages-cards) + - [Pinning repositories](#pinning-repositories) - [Deploy on your own](#deploy-on-your-own) - [On Vercel](#on-vercel) - [:film\_projector: Check Out Step By Step Video Tutorial By @codeSTACKr](#film_projector-check-out-step-by-step-video-tutorial-by-codestackr) @@ -691,7 +693,9 @@ Choose from any of the [default themes](#themes) ## Quick Tip (Align The Cards) -By default, GitHub does not lay out the cards side by side. To do that, you can use this approach: +By default, GitHub does not lay out the cards side by side. To do that, you can use such approaches: + +### Stats and top languages cards ```html @@ -702,26 +706,31 @@ By default, GitHub does not lay out the cards side by side. To do that, you can ``` -```html +
+:eyes: Show example + - + - + -``` -
-:eyes: Show example +
+ +### Pinning repositories +```html - + - + +``` -*** +
+:eyes: Show example From 7a2d13430da64dcd3bb8fc3e1a3064c6dc0b01d5 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov Date: Sun, 7 Sep 2025 21:21:03 +0300 Subject: [PATCH 035/265] refactor: remove suggestion to add theme from generate theme doc script (#4400) --- scripts/generate-theme-doc.js | 13 ------------- 1 file changed, 13 deletions(-) diff --git a/scripts/generate-theme-doc.js b/scripts/generate-theme-doc.js index 1716ea6e95122..b83003d66f330 100644 --- a/scripts/generate-theme-doc.js +++ b/scripts/generate-theme-doc.js @@ -39,11 +39,6 @@ ${REPO_CARD_TABLE_FLAG} ${STAT_CARD_LINKS_FLAG} ${REPO_CARD_LINKS_FLAG} - - -[add-theme]: https://github.com/anuraghazra/github-readme-stats/edit/master/themes/index.js - -Want to add a new theme? Consider reading the [contribution guidelines](../CONTRIBUTING.md#themes-contribution) :D `; const createRepoMdLink = (theme) => { @@ -81,15 +76,7 @@ const generateTable = ({ isRepoCard }) => { let tableItem2 = createTableItem({ link: two, label: two, isRepoCard }); let tableItem3 = createTableItem({ link: three, label: three, isRepoCard }); - if (three === undefined) { - tableItem3 = `[Add your theme][add-theme]`; - } rows.push(`| ${tableItem1} | ${tableItem2} | ${tableItem3} |`); - - // if it's the last row & the row has no empty space push a new row - if (three && i + 3 === themesFiltered.length) { - rows.push(`| [Add your theme][add-theme] | | |`); - } } return rows.join("\n"); From 62069d08dd30627bb9c34137609d5b767d36dbb6 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov Date: Sun, 7 Sep 2025 21:24:53 +0300 Subject: [PATCH 036/265] ci: add ability to manually run the generate theme doc workflow (#4401) --- .github/workflows/generate-theme-doc.yml | 1 + 1 file changed, 1 insertion(+) diff --git a/.github/workflows/generate-theme-doc.yml b/.github/workflows/generate-theme-doc.yml index 31e724e675840..a9922e485b999 100644 --- a/.github/workflows/generate-theme-doc.yml +++ b/.github/workflows/generate-theme-doc.yml @@ -5,6 +5,7 @@ on: - master paths: - "themes/index.js" + workflow_dispatch: permissions: actions: read From fe5ba3d641259a4f01ab4362032c00e41a25a0e7 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov Date: Sun, 7 Sep 2025 21:31:36 +0300 Subject: [PATCH 037/265] chore: fix some grammar errors in theme doc generation script (#4402) --- scripts/generate-theme-doc.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/scripts/generate-theme-doc.js b/scripts/generate-theme-doc.js index b83003d66f330..e7500eeb13113 100644 --- a/scripts/generate-theme-doc.js +++ b/scripts/generate-theme-doc.js @@ -22,7 +22,7 @@ Use \`?theme=THEME_NAME\` parameter like so: ## Stats -> These themes works with all five our cards: Stats Card, Repo Card, Gist Card, Top languages Card and WakaTime Card. +> These themes work with all five of our cards: Stats Card, Repo Card, Gist Card, Top Languages Card, and WakaTime Card. | | | | | :--: | :--: | :--: | @@ -30,7 +30,7 @@ ${STAT_CARD_TABLE_FLAG} ## Repo Card -> These themes works with all five our cards: Stats Card, Repo Card, Gist Card, Top languages Card and WakaTime Card. +> These themes work with all five of our cards: Stats Card, Repo Card, Gist Card, Top Languages Card, and WakaTime Card. | | | | | :--: | :--: | :--: | From 6db838534624e168768ec72993a1e31278128fa9 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Sun, 7 Sep 2025 21:46:21 +0300 Subject: [PATCH 038/265] build(deps): bump emoji-name-map from 1.2.9 to 2.0.3 (#4221) Bumps [emoji-name-map](https://github.com/IonicaBizau/emoji-name-map) from 1.2.9 to 2.0.3. - [Release notes](https://github.com/IonicaBizau/emoji-name-map/releases) - [Commits](https://github.com/IonicaBizau/emoji-name-map/compare/1.2.9...2.0.3) --- updated-dependencies: - dependency-name: emoji-name-map dependency-version: 2.0.3 dependency-type: direct:production update-type: version-update:semver-major ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- package-lock.json | 60 ++++++----------------------------------------- package.json | 2 +- 2 files changed, 8 insertions(+), 54 deletions(-) diff --git a/package-lock.json b/package-lock.json index 04dd8361c1ce4..f9a5d0b75915f 100644 --- a/package-lock.json +++ b/package-lock.json @@ -11,7 +11,7 @@ "dependencies": { "axios": "^1.11.0", "dotenv": "^17.2.1", - "emoji-name-map": "^1.2.8", + "emoji-name-map": "^2.0.3", "github-username-regex": "^1.0.0", "upgrade": "^1.1.0", "word-wrap": "^1.2.5" @@ -2914,14 +2914,9 @@ } }, "node_modules/emoji-name-map": { - "version": "1.2.9", - "resolved": "https://registry.npmjs.org/emoji-name-map/-/emoji-name-map-1.2.9.tgz", - "integrity": "sha512-MSM8y6koSqh/2uEMI2VoKA+Ac0qL5RkgFGP/pzL6n5FOrOJ7FOZFxgs7+uNpqA+AT+WmdbMPXkd3HnFXXdz4AA==", - "dependencies": { - "emojilib": "^2.0.2", - "iterate-object": "^1.3.1", - "map-o": "^2.0.1" - } + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/emoji-name-map/-/emoji-name-map-2.0.3.tgz", + "integrity": "sha512-3KBuQuhYkRtLd9utBKfTtclbWP3IytC1FNcXg+NKARltPSYpkg/MLiklGv4vLwl8A8jMQjdneXNBYx8k0rrg+g==" }, "node_modules/emoji-regex": { "version": "8.0.0", @@ -2929,11 +2924,6 @@ "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", "dev": true }, - "node_modules/emojilib": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/emojilib/-/emojilib-2.4.0.tgz", - "integrity": "sha512-5U0rVMU5Y2n2+ykNLQqMoqklN9ICBT/KsvC1Gz6vqHbz2AXXGkG+Pm5rMWk/8Vjrr/mY9985Hi8DYzn1F09Nyw==" - }, "node_modules/entities": { "version": "6.0.1", "resolved": "https://registry.npmjs.org/entities/-/entities-6.0.1.tgz", @@ -4152,11 +4142,6 @@ "node": ">=8" } }, - "node_modules/iterate-object": { - "version": "1.3.4", - "resolved": "https://registry.npmjs.org/iterate-object/-/iterate-object-1.3.4.tgz", - "integrity": "sha512-4dG1D1x/7g8PwHS9aK6QV5V94+ZvyP4+d19qDv43EzImmrndysIl4prmJ1hWWIGCqrZHyaHBm6BSEWHOLnpoNw==" - }, "node_modules/jest": { "version": "29.7.0", "resolved": "https://registry.npmjs.org/jest/-/jest-29.7.0.tgz", @@ -5810,14 +5795,6 @@ "tmpl": "1.0.5" } }, - "node_modules/map-o": { - "version": "2.0.10", - "resolved": "https://registry.npmjs.org/map-o/-/map-o-2.0.10.tgz", - "integrity": "sha512-BxazE81fVByHWasyXhqKeo2m7bFKYu+ZbEfiuexMOnklXW+tzDvnlTi/JaklEeuuwqcqJzPaf9q+TWptSGXeLg==", - "dependencies": { - "iterate-object": "^1.3.0" - } - }, "node_modules/math-intrinsics": { "version": "1.1.0", "resolved": "https://registry.npmjs.org/math-intrinsics/-/math-intrinsics-1.1.0.tgz", @@ -9371,14 +9348,9 @@ "dev": true }, "emoji-name-map": { - "version": "1.2.9", - "resolved": "https://registry.npmjs.org/emoji-name-map/-/emoji-name-map-1.2.9.tgz", - "integrity": "sha512-MSM8y6koSqh/2uEMI2VoKA+Ac0qL5RkgFGP/pzL6n5FOrOJ7FOZFxgs7+uNpqA+AT+WmdbMPXkd3HnFXXdz4AA==", - "requires": { - "emojilib": "^2.0.2", - "iterate-object": "^1.3.1", - "map-o": "^2.0.1" - } + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/emoji-name-map/-/emoji-name-map-2.0.3.tgz", + "integrity": "sha512-3KBuQuhYkRtLd9utBKfTtclbWP3IytC1FNcXg+NKARltPSYpkg/MLiklGv4vLwl8A8jMQjdneXNBYx8k0rrg+g==" }, "emoji-regex": { "version": "8.0.0", @@ -9386,11 +9358,6 @@ "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", "dev": true }, - "emojilib": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/emojilib/-/emojilib-2.4.0.tgz", - "integrity": "sha512-5U0rVMU5Y2n2+ykNLQqMoqklN9ICBT/KsvC1Gz6vqHbz2AXXGkG+Pm5rMWk/8Vjrr/mY9985Hi8DYzn1F09Nyw==" - }, "entities": { "version": "6.0.1", "resolved": "https://registry.npmjs.org/entities/-/entities-6.0.1.tgz", @@ -10219,11 +10186,6 @@ "istanbul-lib-report": "^3.0.0" } }, - "iterate-object": { - "version": "1.3.4", - "resolved": "https://registry.npmjs.org/iterate-object/-/iterate-object-1.3.4.tgz", - "integrity": "sha512-4dG1D1x/7g8PwHS9aK6QV5V94+ZvyP4+d19qDv43EzImmrndysIl4prmJ1hWWIGCqrZHyaHBm6BSEWHOLnpoNw==" - }, "jest": { "version": "29.7.0", "resolved": "https://registry.npmjs.org/jest/-/jest-29.7.0.tgz", @@ -11461,14 +11423,6 @@ "tmpl": "1.0.5" } }, - "map-o": { - "version": "2.0.10", - "resolved": "https://registry.npmjs.org/map-o/-/map-o-2.0.10.tgz", - "integrity": "sha512-BxazE81fVByHWasyXhqKeo2m7bFKYu+ZbEfiuexMOnklXW+tzDvnlTi/JaklEeuuwqcqJzPaf9q+TWptSGXeLg==", - "requires": { - "iterate-object": "^1.3.0" - } - }, "math-intrinsics": { "version": "1.1.0", "resolved": "https://registry.npmjs.org/math-intrinsics/-/math-intrinsics-1.1.0.tgz", diff --git a/package.json b/package.json index 094671c0d8881..24fcad601bf42 100644 --- a/package.json +++ b/package.json @@ -63,7 +63,7 @@ "dependencies": { "axios": "^1.11.0", "dotenv": "^17.2.1", - "emoji-name-map": "^1.2.8", + "emoji-name-map": "^2.0.3", "github-username-regex": "^1.0.0", "upgrade": "^1.1.0", "word-wrap": "^1.2.5" From 62658da1e28edae3ce8cf1c0616ad5f0b3980c0a Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Sun, 7 Sep 2025 21:49:35 +0300 Subject: [PATCH 039/265] build(deps-dev): bump lint-staged from 16.1.5 to 16.1.6 (#4396) Bumps [lint-staged](https://github.com/lint-staged/lint-staged) from 16.1.5 to 16.1.6. - [Release notes](https://github.com/lint-staged/lint-staged/releases) - [Changelog](https://github.com/lint-staged/lint-staged/blob/main/CHANGELOG.md) - [Commits](https://github.com/lint-staged/lint-staged/compare/v16.1.5...v16.1.6) --- updated-dependencies: - dependency-name: lint-staged dependency-version: 16.1.6 dependency-type: direct:development update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- package-lock.json | 98 +++++++++++++++++++++++------------------------ package.json | 2 +- 2 files changed, 50 insertions(+), 50 deletions(-) diff --git a/package-lock.json b/package-lock.json index f9a5d0b75915f..7c49847d54248 100644 --- a/package-lock.json +++ b/package-lock.json @@ -36,7 +36,7 @@ "jest-bench": "^29.7.1", "jest-environment-jsdom": "^30.0.5", "js-yaml": "^4.1.0", - "lint-staged": "^16.1.5", + "lint-staged": "^16.1.6", "lodash.snakecase": "^4.1.1", "parse-diff": "^0.11.1", "prettier": "^3.6.2" @@ -2565,9 +2565,9 @@ } }, "node_modules/cli-truncate/node_modules/emoji-regex": { - "version": "10.4.0", - "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.4.0.tgz", - "integrity": "sha512-EC+0oUMY1Rqm4O6LLrgjtYDvcVYTy7chDnM4Q7030tP4Kwj3u/pR6gP9ygnp2CJMK5Gq+9Q2oqmrFJAz01DXjw==", + "version": "10.5.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.5.0.tgz", + "integrity": "sha512-lb49vf1Xzfx080OKA0o6l8DQQpV+6Vg95zyCJX9VB/BqKYlhG7N4wgROUUHRA+ZPUefLnteQOad7z1kT2bV7bg==", "dev": true }, "node_modules/cli-truncate/node_modules/string-width": { @@ -3597,9 +3597,9 @@ } }, "node_modules/get-east-asian-width": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/get-east-asian-width/-/get-east-asian-width-1.3.0.tgz", - "integrity": "sha512-vpeMIQKxczTD/0s2CdEWHcb0eeJe6TFjxb+J5xgX7hScxqrGuyjmv4c1D4A/gelKfyox0gJJwIHF+fLjeaM8kQ==", + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/get-east-asian-width/-/get-east-asian-width-1.3.1.tgz", + "integrity": "sha512-R1QfovbPsKmosqTnPoRFiJ7CF9MLRgb53ChvMZm+r4p76/+8yKDy17qLL2PKInORy2RkZZekuK0efYgmzTkXyQ==", "dev": true, "engines": { "node": ">=18" @@ -5412,16 +5412,16 @@ "dev": true }, "node_modules/lint-staged": { - "version": "16.1.5", - "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-16.1.5.tgz", - "integrity": "sha512-uAeQQwByI6dfV7wpt/gVqg+jAPaSp8WwOA8kKC/dv1qw14oGpnpAisY65ibGHUGDUv0rYaZ8CAJZ/1U8hUvC2A==", + "version": "16.1.6", + "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-16.1.6.tgz", + "integrity": "sha512-U4kuulU3CKIytlkLlaHcGgKscNfJPNTiDF2avIUGFCv7K95/DCYQ7Ra62ydeRWmgQGg9zJYw2dzdbztwJlqrow==", "dev": true, "dependencies": { - "chalk": "^5.5.0", + "chalk": "^5.6.0", "commander": "^14.0.0", "debug": "^4.4.1", "lilconfig": "^3.1.3", - "listr2": "^9.0.1", + "listr2": "^9.0.3", "micromatch": "^4.0.8", "nano-spawn": "^1.0.2", "pidtree": "^0.6.0", @@ -5451,9 +5451,9 @@ } }, "node_modules/listr2": { - "version": "9.0.2", - "resolved": "https://registry.npmjs.org/listr2/-/listr2-9.0.2.tgz", - "integrity": "sha512-VVd7cS6W+vLJu2wmq4QmfVj14Iep7cz4r/OWNk36Aq5ZOY7G8/BfCrQFexcwB1OIxB3yERiePfE/REBjEFulag==", + "version": "9.0.3", + "resolved": "https://registry.npmjs.org/listr2/-/listr2-9.0.3.tgz", + "integrity": "sha512-0aeh5HHHgmq1KRdMMDHfhMWQmIT/m7nRDTlxlFqni2Sp0had9baqsjJRvDGdlvgd6NmPE0nPloOipiQJGFtTHQ==", "dev": true, "dependencies": { "cli-truncate": "^4.0.0", @@ -5492,9 +5492,9 @@ } }, "node_modules/listr2/node_modules/emoji-regex": { - "version": "10.4.0", - "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.4.0.tgz", - "integrity": "sha512-EC+0oUMY1Rqm4O6LLrgjtYDvcVYTy7chDnM4Q7030tP4Kwj3u/pR6gP9ygnp2CJMK5Gq+9Q2oqmrFJAz01DXjw==", + "version": "10.5.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.5.0.tgz", + "integrity": "sha512-lb49vf1Xzfx080OKA0o6l8DQQpV+6Vg95zyCJX9VB/BqKYlhG7N4wgROUUHRA+ZPUefLnteQOad7z1kT2bV7bg==", "dev": true }, "node_modules/listr2/node_modules/string-width": { @@ -5635,18 +5635,18 @@ } }, "node_modules/log-update/node_modules/emoji-regex": { - "version": "10.4.0", - "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.4.0.tgz", - "integrity": "sha512-EC+0oUMY1Rqm4O6LLrgjtYDvcVYTy7chDnM4Q7030tP4Kwj3u/pR6gP9ygnp2CJMK5Gq+9Q2oqmrFJAz01DXjw==", + "version": "10.5.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.5.0.tgz", + "integrity": "sha512-lb49vf1Xzfx080OKA0o6l8DQQpV+6Vg95zyCJX9VB/BqKYlhG7N4wgROUUHRA+ZPUefLnteQOad7z1kT2bV7bg==", "dev": true }, "node_modules/log-update/node_modules/is-fullwidth-code-point": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-5.0.0.tgz", - "integrity": "sha512-OVa3u9kkBbw7b8Xw5F9P+D/T9X+Z4+JruYVNapTjPYZYUznQ5YfWeFkOj606XYYW8yugTfC8Pj0hYqvi4ryAhA==", + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-5.1.0.tgz", + "integrity": "sha512-5XHYaSyiqADb4RnZ1Bdad6cPp8Toise4TzEjcOYDHZkTCbKgiUl7WTUCpNWHuxmDt91wnsZBc9xinNzopv3JMQ==", "dev": true, "dependencies": { - "get-east-asian-width": "^1.0.0" + "get-east-asian-width": "^1.3.1" }, "engines": { "node": ">=18" @@ -9090,9 +9090,9 @@ "dev": true }, "emoji-regex": { - "version": "10.4.0", - "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.4.0.tgz", - "integrity": "sha512-EC+0oUMY1Rqm4O6LLrgjtYDvcVYTy7chDnM4Q7030tP4Kwj3u/pR6gP9ygnp2CJMK5Gq+9Q2oqmrFJAz01DXjw==", + "version": "10.5.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.5.0.tgz", + "integrity": "sha512-lb49vf1Xzfx080OKA0o6l8DQQpV+6Vg95zyCJX9VB/BqKYlhG7N4wgROUUHRA+ZPUefLnteQOad7z1kT2bV7bg==", "dev": true }, "string-width": { @@ -9815,9 +9815,9 @@ "dev": true }, "get-east-asian-width": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/get-east-asian-width/-/get-east-asian-width-1.3.0.tgz", - "integrity": "sha512-vpeMIQKxczTD/0s2CdEWHcb0eeJe6TFjxb+J5xgX7hScxqrGuyjmv4c1D4A/gelKfyox0gJJwIHF+fLjeaM8kQ==", + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/get-east-asian-width/-/get-east-asian-width-1.3.1.tgz", + "integrity": "sha512-R1QfovbPsKmosqTnPoRFiJ7CF9MLRgb53ChvMZm+r4p76/+8yKDy17qLL2PKInORy2RkZZekuK0efYgmzTkXyQ==", "dev": true }, "get-intrinsic": { @@ -11155,16 +11155,16 @@ "dev": true }, "lint-staged": { - "version": "16.1.5", - "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-16.1.5.tgz", - "integrity": "sha512-uAeQQwByI6dfV7wpt/gVqg+jAPaSp8WwOA8kKC/dv1qw14oGpnpAisY65ibGHUGDUv0rYaZ8CAJZ/1U8hUvC2A==", + "version": "16.1.6", + "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-16.1.6.tgz", + "integrity": "sha512-U4kuulU3CKIytlkLlaHcGgKscNfJPNTiDF2avIUGFCv7K95/DCYQ7Ra62ydeRWmgQGg9zJYw2dzdbztwJlqrow==", "dev": true, "requires": { - "chalk": "^5.5.0", + "chalk": "^5.6.0", "commander": "^14.0.0", "debug": "^4.4.1", "lilconfig": "^3.1.3", - "listr2": "^9.0.1", + "listr2": "^9.0.3", "micromatch": "^4.0.8", "nano-spawn": "^1.0.2", "pidtree": "^0.6.0", @@ -11181,9 +11181,9 @@ } }, "listr2": { - "version": "9.0.2", - "resolved": "https://registry.npmjs.org/listr2/-/listr2-9.0.2.tgz", - "integrity": "sha512-VVd7cS6W+vLJu2wmq4QmfVj14Iep7cz4r/OWNk36Aq5ZOY7G8/BfCrQFexcwB1OIxB3yERiePfE/REBjEFulag==", + "version": "9.0.3", + "resolved": "https://registry.npmjs.org/listr2/-/listr2-9.0.3.tgz", + "integrity": "sha512-0aeh5HHHgmq1KRdMMDHfhMWQmIT/m7nRDTlxlFqni2Sp0had9baqsjJRvDGdlvgd6NmPE0nPloOipiQJGFtTHQ==", "dev": true, "requires": { "cli-truncate": "^4.0.0", @@ -11207,9 +11207,9 @@ "dev": true }, "emoji-regex": { - "version": "10.4.0", - "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.4.0.tgz", - "integrity": "sha512-EC+0oUMY1Rqm4O6LLrgjtYDvcVYTy7chDnM4Q7030tP4Kwj3u/pR6gP9ygnp2CJMK5Gq+9Q2oqmrFJAz01DXjw==", + "version": "10.5.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.5.0.tgz", + "integrity": "sha512-lb49vf1Xzfx080OKA0o6l8DQQpV+6Vg95zyCJX9VB/BqKYlhG7N4wgROUUHRA+ZPUefLnteQOad7z1kT2bV7bg==", "dev": true }, "string-width": { @@ -11307,18 +11307,18 @@ "dev": true }, "emoji-regex": { - "version": "10.4.0", - "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.4.0.tgz", - "integrity": "sha512-EC+0oUMY1Rqm4O6LLrgjtYDvcVYTy7chDnM4Q7030tP4Kwj3u/pR6gP9ygnp2CJMK5Gq+9Q2oqmrFJAz01DXjw==", + "version": "10.5.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.5.0.tgz", + "integrity": "sha512-lb49vf1Xzfx080OKA0o6l8DQQpV+6Vg95zyCJX9VB/BqKYlhG7N4wgROUUHRA+ZPUefLnteQOad7z1kT2bV7bg==", "dev": true }, "is-fullwidth-code-point": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-5.0.0.tgz", - "integrity": "sha512-OVa3u9kkBbw7b8Xw5F9P+D/T9X+Z4+JruYVNapTjPYZYUznQ5YfWeFkOj606XYYW8yugTfC8Pj0hYqvi4ryAhA==", + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-5.1.0.tgz", + "integrity": "sha512-5XHYaSyiqADb4RnZ1Bdad6cPp8Toise4TzEjcOYDHZkTCbKgiUl7WTUCpNWHuxmDt91wnsZBc9xinNzopv3JMQ==", "dev": true, "requires": { - "get-east-asian-width": "^1.0.0" + "get-east-asian-width": "^1.3.1" } }, "slice-ansi": { diff --git a/package.json b/package.json index 24fcad601bf42..3cea21ba4e3a5 100644 --- a/package.json +++ b/package.json @@ -55,7 +55,7 @@ "jest-bench": "^29.7.1", "jest-environment-jsdom": "^30.0.5", "js-yaml": "^4.1.0", - "lint-staged": "^16.1.5", + "lint-staged": "^16.1.6", "lodash.snakecase": "^4.1.1", "parse-diff": "^0.11.1", "prettier": "^3.6.2" From 3fd11653f1a9f0d5133dbdb49aef769a7181744c Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Sun, 7 Sep 2025 21:53:09 +0300 Subject: [PATCH 040/265] build(deps-dev): bump jest-environment-jsdom from 30.0.5 to 30.1.2 (#4397) Bumps [jest-environment-jsdom](https://github.com/jestjs/jest/tree/HEAD/packages/jest-environment-jsdom) from 30.0.5 to 30.1.2. - [Release notes](https://github.com/jestjs/jest/releases) - [Changelog](https://github.com/jestjs/jest/blob/main/CHANGELOG.md) - [Commits](https://github.com/jestjs/jest/commits/HEAD/packages/jest-environment-jsdom) --- updated-dependencies: - dependency-name: jest-environment-jsdom dependency-version: 30.1.2 dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- package-lock.json | 182 +++++++++++++++++++++++----------------------- package.json | 2 +- 2 files changed, 92 insertions(+), 92 deletions(-) diff --git a/package-lock.json b/package-lock.json index 7c49847d54248..4cfd3f3642192 100644 --- a/package-lock.json +++ b/package-lock.json @@ -34,7 +34,7 @@ "husky": "^9.1.7", "jest": "^29.7.0", "jest-bench": "^29.7.1", - "jest-environment-jsdom": "^30.0.5", + "jest-environment-jsdom": "^30.1.2", "js-yaml": "^4.1.0", "lint-staged": "^16.1.6", "lodash.snakecase": "^4.1.1", @@ -641,9 +641,9 @@ "dev": true }, "node_modules/@csstools/color-helpers": { - "version": "5.0.2", - "resolved": "https://registry.npmjs.org/@csstools/color-helpers/-/color-helpers-5.0.2.tgz", - "integrity": "sha512-JqWH1vsgdGcw2RR6VliXXdA0/59LttzlU8UlRT/iUUsEeWfYq8I+K0yhihEUTTHLRm1EXvpsCx3083EU15ecsA==", + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/@csstools/color-helpers/-/color-helpers-5.1.0.tgz", + "integrity": "sha512-S11EXWJyy0Mz5SYvRmY8nJYTFFd1LCNV+7cXyAgQtOOuzb4EsgfqDufL+9esx72/eLhsRdGZwaldu/h+E4t4BA==", "dev": true, "funding": [ { @@ -683,9 +683,9 @@ } }, "node_modules/@csstools/css-color-parser": { - "version": "3.0.10", - "resolved": "https://registry.npmjs.org/@csstools/css-color-parser/-/css-color-parser-3.0.10.tgz", - "integrity": "sha512-TiJ5Ajr6WRd1r8HSiwJvZBiJOqtH86aHpUjq5aEKWHiII2Qfjqd/HCWKPOW8EP4vcspXbHnXrwIDlu5savQipg==", + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/@csstools/css-color-parser/-/css-color-parser-3.1.0.tgz", + "integrity": "sha512-nbtKwh3a6xNVIp/VRuXV64yTKnb1IjTAEEh3irzS+HkKjAOYLTGNb9pmVNntZ8iVBHcWDA2Dof0QtPgFI1BaTA==", "dev": true, "funding": [ { @@ -698,7 +698,7 @@ } ], "dependencies": { - "@csstools/color-helpers": "^5.0.2", + "@csstools/color-helpers": "^5.1.0", "@csstools/css-calc": "^2.1.4" }, "engines": { @@ -1159,13 +1159,13 @@ } }, "node_modules/@jest/environment-jsdom-abstract": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/@jest/environment-jsdom-abstract/-/environment-jsdom-abstract-30.0.5.tgz", - "integrity": "sha512-gpWwiVxZunkoglP8DCnT3As9x5O8H6gveAOpvaJd2ATAoSh7ZSSCWbr9LQtUMvr8WD3VjG9YnDhsmkCK5WN1rQ==", + "version": "30.1.2", + "resolved": "https://registry.npmjs.org/@jest/environment-jsdom-abstract/-/environment-jsdom-abstract-30.1.2.tgz", + "integrity": "sha512-u8kTh/ZBl97GOmnGJLYK/1GuwAruMC4hoP6xuk/kwltmVWsA9u/6fH1/CsPVGt2O+Wn2yEjs8n1B1zZJ62Cx0w==", "dev": true, "dependencies": { - "@jest/environment": "30.0.5", - "@jest/fake-timers": "30.0.5", + "@jest/environment": "30.1.2", + "@jest/fake-timers": "30.1.2", "@jest/types": "30.0.5", "@types/jsdom": "^21.1.7", "@types/node": "*", @@ -1186,12 +1186,12 @@ } }, "node_modules/@jest/environment-jsdom-abstract/node_modules/@jest/environment": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-30.0.5.tgz", - "integrity": "sha512-aRX7WoaWx1oaOkDQvCWImVQ8XNtdv5sEWgk4gxR6NXb7WBUnL5sRak4WRzIQRZ1VTWPvV4VI4mgGjNL9TeKMYA==", + "version": "30.1.2", + "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-30.1.2.tgz", + "integrity": "sha512-N8t1Ytw4/mr9uN28OnVf0SYE2dGhaIxOVYcwsf9IInBKjvofAjbFRvedvBBlyTYk2knbJTiEjEJ2PyyDIBnd9w==", "dev": true, "dependencies": { - "@jest/fake-timers": "30.0.5", + "@jest/fake-timers": "30.1.2", "@jest/types": "30.0.5", "@types/node": "*", "jest-mock": "30.0.5" @@ -1201,15 +1201,15 @@ } }, "node_modules/@jest/environment-jsdom-abstract/node_modules/@jest/fake-timers": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-30.0.5.tgz", - "integrity": "sha512-ZO5DHfNV+kgEAeP3gK3XlpJLL4U3Sz6ebl/n68Uwt64qFFs5bv4bfEEjyRGK5uM0C90ewooNgFuKMdkbEoMEXw==", + "version": "30.1.2", + "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-30.1.2.tgz", + "integrity": "sha512-Beljfv9AYkr9K+ETX9tvV61rJTY706BhBUtiaepQHeEGfe0DbpvUA5Z3fomwc5Xkhns6NWrcFDZn+72fLieUnA==", "dev": true, "dependencies": { "@jest/types": "30.0.5", "@sinonjs/fake-timers": "^13.0.0", "@types/node": "*", - "jest-message-util": "30.0.5", + "jest-message-util": "30.1.0", "jest-mock": "30.0.5", "jest-util": "30.0.5" }, @@ -1248,9 +1248,9 @@ } }, "node_modules/@jest/environment-jsdom-abstract/node_modules/@sinclair/typebox": { - "version": "0.34.38", - "resolved": "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.34.38.tgz", - "integrity": "sha512-HpkxMmc2XmZKhvaKIZZThlHmx1L0I/V1hWK1NubtlFnr6ZqdiOpV72TKudZUNQjZNsyDBay72qFEhEvb+bcwcA==", + "version": "0.34.41", + "resolved": "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.34.41.tgz", + "integrity": "sha512-6gS8pZzSXdyRHTIqoqSVknxolr1kzfy4/CeDnrzsVz8TTIWUbOBr6gnzOmTYJ3eXQNh4IYHIGi5aIL7sOZ2G/g==", "dev": true }, "node_modules/@jest/environment-jsdom-abstract/node_modules/@sinonjs/fake-timers": { @@ -1290,9 +1290,9 @@ } }, "node_modules/@jest/environment-jsdom-abstract/node_modules/jest-message-util": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-30.0.5.tgz", - "integrity": "sha512-NAiDOhsK3V7RU0Aa/HnrQo+E4JlbarbmI3q6Pi4KcxicdtjV82gcIUrejOtczChtVQR4kddu1E1EJlW6EN9IyA==", + "version": "30.1.0", + "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-30.1.0.tgz", + "integrity": "sha512-HizKDGG98cYkWmaLUHChq4iN+oCENohQLb7Z5guBPumYs+/etonmNFlg1Ps6yN9LTPyZn+M+b/9BbnHx3WTMDg==", "dev": true, "dependencies": { "@babel/code-frame": "^7.27.1", @@ -4480,13 +4480,13 @@ "dev": true }, "node_modules/jest-environment-jsdom": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/jest-environment-jsdom/-/jest-environment-jsdom-30.0.5.tgz", - "integrity": "sha512-BmnDEoAH+jEjkPrvE9DTKS2r3jYSJWlN/r46h0/DBUxKrkgt2jAZ5Nj4wXLAcV1KWkRpcFqA5zri9SWzJZ1cCg==", + "version": "30.1.2", + "resolved": "https://registry.npmjs.org/jest-environment-jsdom/-/jest-environment-jsdom-30.1.2.tgz", + "integrity": "sha512-LXsfAh5+mDTuXDONGl1ZLYxtJEaS06GOoxJb2arcJTjIfh1adYg8zLD8f6P0df8VmjvCaMrLmc1PgHUI/YUTbg==", "dev": true, "dependencies": { - "@jest/environment": "30.0.5", - "@jest/environment-jsdom-abstract": "30.0.5", + "@jest/environment": "30.1.2", + "@jest/environment-jsdom-abstract": "30.1.2", "@types/jsdom": "^21.1.7", "@types/node": "*", "jsdom": "^26.1.0" @@ -4504,12 +4504,12 @@ } }, "node_modules/jest-environment-jsdom/node_modules/@jest/environment": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-30.0.5.tgz", - "integrity": "sha512-aRX7WoaWx1oaOkDQvCWImVQ8XNtdv5sEWgk4gxR6NXb7WBUnL5sRak4WRzIQRZ1VTWPvV4VI4mgGjNL9TeKMYA==", + "version": "30.1.2", + "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-30.1.2.tgz", + "integrity": "sha512-N8t1Ytw4/mr9uN28OnVf0SYE2dGhaIxOVYcwsf9IInBKjvofAjbFRvedvBBlyTYk2knbJTiEjEJ2PyyDIBnd9w==", "dev": true, "dependencies": { - "@jest/fake-timers": "30.0.5", + "@jest/fake-timers": "30.1.2", "@jest/types": "30.0.5", "@types/node": "*", "jest-mock": "30.0.5" @@ -4519,15 +4519,15 @@ } }, "node_modules/jest-environment-jsdom/node_modules/@jest/fake-timers": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-30.0.5.tgz", - "integrity": "sha512-ZO5DHfNV+kgEAeP3gK3XlpJLL4U3Sz6ebl/n68Uwt64qFFs5bv4bfEEjyRGK5uM0C90ewooNgFuKMdkbEoMEXw==", + "version": "30.1.2", + "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-30.1.2.tgz", + "integrity": "sha512-Beljfv9AYkr9K+ETX9tvV61rJTY706BhBUtiaepQHeEGfe0DbpvUA5Z3fomwc5Xkhns6NWrcFDZn+72fLieUnA==", "dev": true, "dependencies": { "@jest/types": "30.0.5", "@sinonjs/fake-timers": "^13.0.0", "@types/node": "*", - "jest-message-util": "30.0.5", + "jest-message-util": "30.1.0", "jest-mock": "30.0.5", "jest-util": "30.0.5" }, @@ -4566,9 +4566,9 @@ } }, "node_modules/jest-environment-jsdom/node_modules/@sinclair/typebox": { - "version": "0.34.38", - "resolved": "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.34.38.tgz", - "integrity": "sha512-HpkxMmc2XmZKhvaKIZZThlHmx1L0I/V1hWK1NubtlFnr6ZqdiOpV72TKudZUNQjZNsyDBay72qFEhEvb+bcwcA==", + "version": "0.34.41", + "resolved": "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.34.41.tgz", + "integrity": "sha512-6gS8pZzSXdyRHTIqoqSVknxolr1kzfy4/CeDnrzsVz8TTIWUbOBr6gnzOmTYJ3eXQNh4IYHIGi5aIL7sOZ2G/g==", "dev": true }, "node_modules/jest-environment-jsdom/node_modules/@sinonjs/fake-timers": { @@ -4608,9 +4608,9 @@ } }, "node_modules/jest-environment-jsdom/node_modules/jest-message-util": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-30.0.5.tgz", - "integrity": "sha512-NAiDOhsK3V7RU0Aa/HnrQo+E4JlbarbmI3q6Pi4KcxicdtjV82gcIUrejOtczChtVQR4kddu1E1EJlW6EN9IyA==", + "version": "30.1.0", + "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-30.1.0.tgz", + "integrity": "sha512-HizKDGG98cYkWmaLUHChq4iN+oCENohQLb7Z5guBPumYs+/etonmNFlg1Ps6yN9LTPyZn+M+b/9BbnHx3WTMDg==", "dev": true, "dependencies": { "@babel/code-frame": "^7.27.1", @@ -7665,9 +7665,9 @@ "dev": true }, "@csstools/color-helpers": { - "version": "5.0.2", - "resolved": "https://registry.npmjs.org/@csstools/color-helpers/-/color-helpers-5.0.2.tgz", - "integrity": "sha512-JqWH1vsgdGcw2RR6VliXXdA0/59LttzlU8UlRT/iUUsEeWfYq8I+K0yhihEUTTHLRm1EXvpsCx3083EU15ecsA==", + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/@csstools/color-helpers/-/color-helpers-5.1.0.tgz", + "integrity": "sha512-S11EXWJyy0Mz5SYvRmY8nJYTFFd1LCNV+7cXyAgQtOOuzb4EsgfqDufL+9esx72/eLhsRdGZwaldu/h+E4t4BA==", "dev": true }, "@csstools/css-calc": { @@ -7678,12 +7678,12 @@ "requires": {} }, "@csstools/css-color-parser": { - "version": "3.0.10", - "resolved": "https://registry.npmjs.org/@csstools/css-color-parser/-/css-color-parser-3.0.10.tgz", - "integrity": "sha512-TiJ5Ajr6WRd1r8HSiwJvZBiJOqtH86aHpUjq5aEKWHiII2Qfjqd/HCWKPOW8EP4vcspXbHnXrwIDlu5savQipg==", + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/@csstools/css-color-parser/-/css-color-parser-3.1.0.tgz", + "integrity": "sha512-nbtKwh3a6xNVIp/VRuXV64yTKnb1IjTAEEh3irzS+HkKjAOYLTGNb9pmVNntZ8iVBHcWDA2Dof0QtPgFI1BaTA==", "dev": true, "requires": { - "@csstools/color-helpers": "^5.0.2", + "@csstools/color-helpers": "^5.1.0", "@csstools/css-calc": "^2.1.4" } }, @@ -7998,13 +7998,13 @@ } }, "@jest/environment-jsdom-abstract": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/@jest/environment-jsdom-abstract/-/environment-jsdom-abstract-30.0.5.tgz", - "integrity": "sha512-gpWwiVxZunkoglP8DCnT3As9x5O8H6gveAOpvaJd2ATAoSh7ZSSCWbr9LQtUMvr8WD3VjG9YnDhsmkCK5WN1rQ==", + "version": "30.1.2", + "resolved": "https://registry.npmjs.org/@jest/environment-jsdom-abstract/-/environment-jsdom-abstract-30.1.2.tgz", + "integrity": "sha512-u8kTh/ZBl97GOmnGJLYK/1GuwAruMC4hoP6xuk/kwltmVWsA9u/6fH1/CsPVGt2O+Wn2yEjs8n1B1zZJ62Cx0w==", "dev": true, "requires": { - "@jest/environment": "30.0.5", - "@jest/fake-timers": "30.0.5", + "@jest/environment": "30.1.2", + "@jest/fake-timers": "30.1.2", "@jest/types": "30.0.5", "@types/jsdom": "^21.1.7", "@types/node": "*", @@ -8013,27 +8013,27 @@ }, "dependencies": { "@jest/environment": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-30.0.5.tgz", - "integrity": "sha512-aRX7WoaWx1oaOkDQvCWImVQ8XNtdv5sEWgk4gxR6NXb7WBUnL5sRak4WRzIQRZ1VTWPvV4VI4mgGjNL9TeKMYA==", + "version": "30.1.2", + "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-30.1.2.tgz", + "integrity": "sha512-N8t1Ytw4/mr9uN28OnVf0SYE2dGhaIxOVYcwsf9IInBKjvofAjbFRvedvBBlyTYk2knbJTiEjEJ2PyyDIBnd9w==", "dev": true, "requires": { - "@jest/fake-timers": "30.0.5", + "@jest/fake-timers": "30.1.2", "@jest/types": "30.0.5", "@types/node": "*", "jest-mock": "30.0.5" } }, "@jest/fake-timers": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-30.0.5.tgz", - "integrity": "sha512-ZO5DHfNV+kgEAeP3gK3XlpJLL4U3Sz6ebl/n68Uwt64qFFs5bv4bfEEjyRGK5uM0C90ewooNgFuKMdkbEoMEXw==", + "version": "30.1.2", + "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-30.1.2.tgz", + "integrity": "sha512-Beljfv9AYkr9K+ETX9tvV61rJTY706BhBUtiaepQHeEGfe0DbpvUA5Z3fomwc5Xkhns6NWrcFDZn+72fLieUnA==", "dev": true, "requires": { "@jest/types": "30.0.5", "@sinonjs/fake-timers": "^13.0.0", "@types/node": "*", - "jest-message-util": "30.0.5", + "jest-message-util": "30.1.0", "jest-mock": "30.0.5", "jest-util": "30.0.5" } @@ -8063,9 +8063,9 @@ } }, "@sinclair/typebox": { - "version": "0.34.38", - "resolved": "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.34.38.tgz", - "integrity": "sha512-HpkxMmc2XmZKhvaKIZZThlHmx1L0I/V1hWK1NubtlFnr6ZqdiOpV72TKudZUNQjZNsyDBay72qFEhEvb+bcwcA==", + "version": "0.34.41", + "resolved": "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.34.41.tgz", + "integrity": "sha512-6gS8pZzSXdyRHTIqoqSVknxolr1kzfy4/CeDnrzsVz8TTIWUbOBr6gnzOmTYJ3eXQNh4IYHIGi5aIL7sOZ2G/g==", "dev": true }, "@sinonjs/fake-timers": { @@ -8090,9 +8090,9 @@ "dev": true }, "jest-message-util": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-30.0.5.tgz", - "integrity": "sha512-NAiDOhsK3V7RU0Aa/HnrQo+E4JlbarbmI3q6Pi4KcxicdtjV82gcIUrejOtczChtVQR4kddu1E1EJlW6EN9IyA==", + "version": "30.1.0", + "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-30.1.0.tgz", + "integrity": "sha512-HizKDGG98cYkWmaLUHChq4iN+oCENohQLb7Z5guBPumYs+/etonmNFlg1Ps6yN9LTPyZn+M+b/9BbnHx3WTMDg==", "dev": true, "requires": { "@babel/code-frame": "^7.27.1", @@ -10435,40 +10435,40 @@ } }, "jest-environment-jsdom": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/jest-environment-jsdom/-/jest-environment-jsdom-30.0.5.tgz", - "integrity": "sha512-BmnDEoAH+jEjkPrvE9DTKS2r3jYSJWlN/r46h0/DBUxKrkgt2jAZ5Nj4wXLAcV1KWkRpcFqA5zri9SWzJZ1cCg==", + "version": "30.1.2", + "resolved": "https://registry.npmjs.org/jest-environment-jsdom/-/jest-environment-jsdom-30.1.2.tgz", + "integrity": "sha512-LXsfAh5+mDTuXDONGl1ZLYxtJEaS06GOoxJb2arcJTjIfh1adYg8zLD8f6P0df8VmjvCaMrLmc1PgHUI/YUTbg==", "dev": true, "requires": { - "@jest/environment": "30.0.5", - "@jest/environment-jsdom-abstract": "30.0.5", + "@jest/environment": "30.1.2", + "@jest/environment-jsdom-abstract": "30.1.2", "@types/jsdom": "^21.1.7", "@types/node": "*", "jsdom": "^26.1.0" }, "dependencies": { "@jest/environment": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-30.0.5.tgz", - "integrity": "sha512-aRX7WoaWx1oaOkDQvCWImVQ8XNtdv5sEWgk4gxR6NXb7WBUnL5sRak4WRzIQRZ1VTWPvV4VI4mgGjNL9TeKMYA==", + "version": "30.1.2", + "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-30.1.2.tgz", + "integrity": "sha512-N8t1Ytw4/mr9uN28OnVf0SYE2dGhaIxOVYcwsf9IInBKjvofAjbFRvedvBBlyTYk2knbJTiEjEJ2PyyDIBnd9w==", "dev": true, "requires": { - "@jest/fake-timers": "30.0.5", + "@jest/fake-timers": "30.1.2", "@jest/types": "30.0.5", "@types/node": "*", "jest-mock": "30.0.5" } }, "@jest/fake-timers": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-30.0.5.tgz", - "integrity": "sha512-ZO5DHfNV+kgEAeP3gK3XlpJLL4U3Sz6ebl/n68Uwt64qFFs5bv4bfEEjyRGK5uM0C90ewooNgFuKMdkbEoMEXw==", + "version": "30.1.2", + "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-30.1.2.tgz", + "integrity": "sha512-Beljfv9AYkr9K+ETX9tvV61rJTY706BhBUtiaepQHeEGfe0DbpvUA5Z3fomwc5Xkhns6NWrcFDZn+72fLieUnA==", "dev": true, "requires": { "@jest/types": "30.0.5", "@sinonjs/fake-timers": "^13.0.0", "@types/node": "*", - "jest-message-util": "30.0.5", + "jest-message-util": "30.1.0", "jest-mock": "30.0.5", "jest-util": "30.0.5" } @@ -10498,9 +10498,9 @@ } }, "@sinclair/typebox": { - "version": "0.34.38", - "resolved": "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.34.38.tgz", - "integrity": "sha512-HpkxMmc2XmZKhvaKIZZThlHmx1L0I/V1hWK1NubtlFnr6ZqdiOpV72TKudZUNQjZNsyDBay72qFEhEvb+bcwcA==", + "version": "0.34.41", + "resolved": "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.34.41.tgz", + "integrity": "sha512-6gS8pZzSXdyRHTIqoqSVknxolr1kzfy4/CeDnrzsVz8TTIWUbOBr6gnzOmTYJ3eXQNh4IYHIGi5aIL7sOZ2G/g==", "dev": true }, "@sinonjs/fake-timers": { @@ -10525,9 +10525,9 @@ "dev": true }, "jest-message-util": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-30.0.5.tgz", - "integrity": "sha512-NAiDOhsK3V7RU0Aa/HnrQo+E4JlbarbmI3q6Pi4KcxicdtjV82gcIUrejOtczChtVQR4kddu1E1EJlW6EN9IyA==", + "version": "30.1.0", + "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-30.1.0.tgz", + "integrity": "sha512-HizKDGG98cYkWmaLUHChq4iN+oCENohQLb7Z5guBPumYs+/etonmNFlg1Ps6yN9LTPyZn+M+b/9BbnHx3WTMDg==", "dev": true, "requires": { "@babel/code-frame": "^7.27.1", diff --git a/package.json b/package.json index 3cea21ba4e3a5..263b43b8a4492 100644 --- a/package.json +++ b/package.json @@ -53,7 +53,7 @@ "husky": "^9.1.7", "jest": "^29.7.0", "jest-bench": "^29.7.1", - "jest-environment-jsdom": "^30.0.5", + "jest-environment-jsdom": "^30.1.2", "js-yaml": "^4.1.0", "lint-staged": "^16.1.6", "lodash.snakecase": "^4.1.1", From ac3924e10b4747c3b77ee9eb7483cba52f349793 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov Date: Mon, 8 Sep 2025 14:01:59 +0300 Subject: [PATCH 041/265] docs(theme): auto update theme readme (#4411) Co-authored-by: GitHub Readme Stats Bot --- themes/README.md | 13 ++++--------- 1 file changed, 4 insertions(+), 9 deletions(-) diff --git a/themes/README.md b/themes/README.md index 5e50b5bbc8e6d..c8dffda25d420 100644 --- a/themes/README.md +++ b/themes/README.md @@ -12,7 +12,7 @@ Use `?theme=THEME_NAME` parameter like so: ## Stats -> These themes works with all five our cards: Stats Card, Repo Card, Gist Card, Top languages Card and WakaTime Card. +> These themes work with all five of our cards: Stats Card, Repo Card, Gist Card, Top Languages Card, and WakaTime Card. | | | | | :--: | :--: | :--: | @@ -40,11 +40,11 @@ Use `?theme=THEME_NAME` parameter like so: | `rose_pine` ![rose_pine][rose_pine] | `catppuccin_latte` ![catppuccin_latte][catppuccin_latte] | `catppuccin_mocha` ![catppuccin_mocha][catppuccin_mocha] | | `date_night` ![date_night][date_night] | `one_dark_pro` ![one_dark_pro][one_dark_pro] | `rose` ![rose][rose] | | `holi` ![holi][holi] | `neon` ![neon][neon] | `blue_navy` ![blue_navy][blue_navy] | -| `calm_pink` ![calm_pink][calm_pink] | `ambient_gradient` ![ambient_gradient][ambient_gradient] | [Add your theme][add-theme] | +| `calm_pink` ![calm_pink][calm_pink] | `ambient_gradient` ![ambient_gradient][ambient_gradient] | | ## Repo Card -> These themes works with all five our cards: Stats Card, Repo Card, Gist Card, Top languages Card and WakaTime Card. +> These themes work with all five of our cards: Stats Card, Repo Card, Gist Card, Top Languages Card, and WakaTime Card. | | | | | :--: | :--: | :--: | @@ -72,7 +72,7 @@ Use `?theme=THEME_NAME` parameter like so: | `rose_pine` ![rose_pine][rose_pine_repo] | `catppuccin_latte` ![catppuccin_latte][catppuccin_latte_repo] | `catppuccin_mocha` ![catppuccin_mocha][catppuccin_mocha_repo] | | `date_night` ![date_night][date_night_repo] | `one_dark_pro` ![one_dark_pro][one_dark_pro_repo] | `rose` ![rose][rose_repo] | | `holi` ![holi][holi_repo] | `neon` ![neon][neon_repo] | `blue_navy` ![blue_navy][blue_navy_repo] | -| `calm_pink` ![calm_pink][calm_pink_repo] | `ambient_gradient` ![ambient_gradient][ambient_gradient_repo] | [Add your theme][add-theme] | +| `calm_pink` ![calm_pink][calm_pink_repo] | `ambient_gradient` ![ambient_gradient][ambient_gradient_repo] | | [default]: https://github-readme-stats.vercel.app/api?username=anuraghazra&show_icons=true&hide=contribs,prs&cache_seconds=86400&theme=default @@ -227,8 +227,3 @@ Use `?theme=THEME_NAME` parameter like so: [blue_navy_repo]: https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra&repo=github-readme-stats&cache_seconds=86400&theme=blue_navy [calm_pink_repo]: https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra&repo=github-readme-stats&cache_seconds=86400&theme=calm_pink [ambient_gradient_repo]: https://github-readme-stats.vercel.app/api/pin/?username=anuraghazra&repo=github-readme-stats&cache_seconds=86400&theme=ambient_gradient - - -[add-theme]: https://github.com/anuraghazra/github-readme-stats/edit/master/themes/index.js - -Want to add a new theme? Consider reading the [contribution guidelines](../CONTRIBUTING.md#themes-contribution) :D From c8e6976f351e429e8b0e7eb0cd998166d1158a5b Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Mon, 8 Sep 2025 14:06:38 +0300 Subject: [PATCH 042/265] ci(deps): bump actions/setup-node from 4.4.0 to 5.0.0 (#4405) Bumps [actions/setup-node](https://github.com/actions/setup-node) from 4.4.0 to 5.0.0. - [Release notes](https://github.com/actions/setup-node/releases) - [Commits](https://github.com/actions/setup-node/compare/49933ea5288caeca8642d1e84afbd3f7d6820020...a0853c24544627f65ddf259abe73b1d18a591444) --- updated-dependencies: - dependency-name: actions/setup-node dependency-version: 5.0.0 dependency-type: direct:production update-type: version-update:semver-major ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- .github/workflows/e2e-test.yml | 2 +- .github/workflows/generate-theme-doc.yml | 2 +- .github/workflows/preview-theme.yml | 2 +- .github/workflows/stale-theme-pr-closer.yml | 2 +- .github/workflows/test.yml | 2 +- .github/workflows/update-langs.yml | 2 +- 6 files changed, 6 insertions(+), 6 deletions(-) diff --git a/.github/workflows/e2e-test.yml b/.github/workflows/e2e-test.yml index 5dc71faf93422..e4d53ad947f47 100644 --- a/.github/workflows/e2e-test.yml +++ b/.github/workflows/e2e-test.yml @@ -20,7 +20,7 @@ jobs: - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 - name: Setup Node - uses: actions/setup-node@49933ea5288caeca8642d1e84afbd3f7d6820020 # v4.4.0 + uses: actions/setup-node@a0853c24544627f65ddf259abe73b1d18a591444 # v5.0.0 with: node-version: ${{ matrix.node-version }} cache: npm diff --git a/.github/workflows/generate-theme-doc.yml b/.github/workflows/generate-theme-doc.yml index a9922e485b999..123aaaab668c0 100644 --- a/.github/workflows/generate-theme-doc.yml +++ b/.github/workflows/generate-theme-doc.yml @@ -33,7 +33,7 @@ jobs: - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 - name: Setup Node - uses: actions/setup-node@49933ea5288caeca8642d1e84afbd3f7d6820020 # v4.4.0 + uses: actions/setup-node@a0853c24544627f65ddf259abe73b1d18a591444 # v5.0.0 with: node-version: ${{ matrix.node-version }} cache: npm diff --git a/.github/workflows/preview-theme.yml b/.github/workflows/preview-theme.yml index 6b7e46cede398..6cea283c3947d 100644 --- a/.github/workflows/preview-theme.yml +++ b/.github/workflows/preview-theme.yml @@ -34,7 +34,7 @@ jobs: - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 - name: Setup Node - uses: actions/setup-node@49933ea5288caeca8642d1e84afbd3f7d6820020 # v4.4.0 + uses: actions/setup-node@a0853c24544627f65ddf259abe73b1d18a591444 # v5.0.0 with: node-version: ${{ matrix.node-version }} cache: npm diff --git a/.github/workflows/stale-theme-pr-closer.yml b/.github/workflows/stale-theme-pr-closer.yml index 6a48cce2fcf62..f9e550796873a 100644 --- a/.github/workflows/stale-theme-pr-closer.yml +++ b/.github/workflows/stale-theme-pr-closer.yml @@ -40,7 +40,7 @@ jobs: - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 - name: Setup Node - uses: actions/setup-node@49933ea5288caeca8642d1e84afbd3f7d6820020 # v4.4.0 + uses: actions/setup-node@a0853c24544627f65ddf259abe73b1d18a591444 # v5.0.0 with: node-version: ${{ matrix.node-version }} cache: npm diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index c13310da12498..113716d9ff7ea 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -21,7 +21,7 @@ jobs: - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 - name: Setup Node - uses: actions/setup-node@49933ea5288caeca8642d1e84afbd3f7d6820020 # v4.4.0 + uses: actions/setup-node@a0853c24544627f65ddf259abe73b1d18a591444 # v5.0.0 with: node-version: ${{ matrix.node-version }} cache: npm diff --git a/.github/workflows/update-langs.yml b/.github/workflows/update-langs.yml index 521bdb2eb8953..708fe63d80825 100644 --- a/.github/workflows/update-langs.yml +++ b/.github/workflows/update-langs.yml @@ -39,7 +39,7 @@ jobs: - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 - name: Setup Node - uses: actions/setup-node@49933ea5288caeca8642d1e84afbd3f7d6820020 # v4.4.0 + uses: actions/setup-node@a0853c24544627f65ddf259abe73b1d18a591444 # v5.0.0 with: node-version: ${{ matrix.node-version }} cache: npm From 104dfbf3408541c4b1a9d76e9a2a4454066466eb Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Mon, 8 Sep 2025 14:10:33 +0300 Subject: [PATCH 043/265] ci(deps): bump actions/labeler from 5.0.0 to 6.0.1 (#4406) Bumps [actions/labeler](https://github.com/actions/labeler) from 5.0.0 to 6.0.1. - [Release notes](https://github.com/actions/labeler/releases) - [Commits](https://github.com/actions/labeler/compare/8558fd74291d67161a8a78ce36a881fa63b766a9...634933edcd8ababfe52f92936142cc22ac488b1b) --- updated-dependencies: - dependency-name: actions/labeler dependency-version: 6.0.1 dependency-type: direct:production update-type: version-update:semver-major ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- .github/workflows/label-pr.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/label-pr.yml b/.github/workflows/label-pr.yml index 5318b304d3a36..b774b145b0064 100644 --- a/.github/workflows/label-pr.yml +++ b/.github/workflows/label-pr.yml @@ -21,7 +21,7 @@ jobs: if: github.repository == 'anuraghazra/github-readme-stats' runs-on: ubuntu-latest steps: - - uses: actions/labeler@8558fd74291d67161a8a78ce36a881fa63b766a9 # v5.0.0 + - uses: actions/labeler@634933edcd8ababfe52f92936142cc22ac488b1b # v6.0.1 with: repo-token: "${{ secrets.GITHUB_TOKEN }}" sync-labels: true From 3fa9c1df766242038315ecf0aedc645cd6bc44ea Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Mon, 8 Sep 2025 14:13:30 +0300 Subject: [PATCH 044/265] build(deps): bump dotenv from 17.2.1 to 17.2.2 (#4408) Bumps [dotenv](https://github.com/motdotla/dotenv) from 17.2.1 to 17.2.2. - [Changelog](https://github.com/motdotla/dotenv/blob/master/CHANGELOG.md) - [Commits](https://github.com/motdotla/dotenv/compare/v17.2.1...v17.2.2) --- updated-dependencies: - dependency-name: dotenv dependency-version: 17.2.2 dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- package-lock.json | 14 +++++++------- package.json | 2 +- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/package-lock.json b/package-lock.json index 4cfd3f3642192..8d8f0957abff0 100644 --- a/package-lock.json +++ b/package-lock.json @@ -10,7 +10,7 @@ "license": "MIT", "dependencies": { "axios": "^1.11.0", - "dotenv": "^17.2.1", + "dotenv": "^17.2.2", "emoji-name-map": "^2.0.3", "github-username-regex": "^1.0.0", "upgrade": "^1.1.0", @@ -2872,9 +2872,9 @@ "dev": true }, "node_modules/dotenv": { - "version": "17.2.1", - "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-17.2.1.tgz", - "integrity": "sha512-kQhDYKZecqnM0fCnzI5eIv5L4cAe/iRI+HqMbO/hbRdTAeXDG+M9FjipUxNfbARuEg4iHIbhnhs78BCHNbSxEQ==", + "version": "17.2.2", + "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-17.2.2.tgz", + "integrity": "sha512-Sf2LSQP+bOlhKWWyhFsn0UsfdK/kCWRv1iuA2gXAwt3dyNabr6QSj00I2V10pidqz69soatm9ZwZvpQMTIOd5Q==", "engines": { "node": ">=12" }, @@ -9321,9 +9321,9 @@ "dev": true }, "dotenv": { - "version": "17.2.1", - "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-17.2.1.tgz", - "integrity": "sha512-kQhDYKZecqnM0fCnzI5eIv5L4cAe/iRI+HqMbO/hbRdTAeXDG+M9FjipUxNfbARuEg4iHIbhnhs78BCHNbSxEQ==" + "version": "17.2.2", + "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-17.2.2.tgz", + "integrity": "sha512-Sf2LSQP+bOlhKWWyhFsn0UsfdK/kCWRv1iuA2gXAwt3dyNabr6QSj00I2V10pidqz69soatm9ZwZvpQMTIOd5Q==" }, "dunder-proto": { "version": "1.0.1", diff --git a/package.json b/package.json index 263b43b8a4492..6f400ab8accc4 100644 --- a/package.json +++ b/package.json @@ -62,7 +62,7 @@ }, "dependencies": { "axios": "^1.11.0", - "dotenv": "^17.2.1", + "dotenv": "^17.2.2", "emoji-name-map": "^2.0.3", "github-username-regex": "^1.0.0", "upgrade": "^1.1.0", From edc5d7762cfd17fe4762d9f3cb54d004a4c5b544 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Mon, 8 Sep 2025 14:16:38 +0300 Subject: [PATCH 045/265] build(deps-dev): bump @eslint/js from 9.34.0 to 9.35.0 (#4409) Bumps [@eslint/js](https://github.com/eslint/eslint/tree/HEAD/packages/js) from 9.34.0 to 9.35.0. - [Release notes](https://github.com/eslint/eslint/releases) - [Changelog](https://github.com/eslint/eslint/blob/main/CHANGELOG.md) - [Commits](https://github.com/eslint/eslint/commits/v9.35.0/packages/js) --- updated-dependencies: - dependency-name: "@eslint/js" dependency-version: 9.35.0 dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- package-lock.json | 32 +++++++++++++++++++++++++------- package.json | 2 +- 2 files changed, 26 insertions(+), 8 deletions(-) diff --git a/package-lock.json b/package-lock.json index 8d8f0957abff0..692842df9aeea 100644 --- a/package-lock.json +++ b/package-lock.json @@ -20,7 +20,7 @@ "@actions/core": "^1.11.1", "@actions/github": "^6.0.1", "@eslint/eslintrc": "^3.3.1", - "@eslint/js": "^9.34.0", + "@eslint/js": "^9.35.0", "@testing-library/dom": "^10.4.1", "@testing-library/jest-dom": "^6.8.0", "@uppercod/css-to-object": "^1.1.1", @@ -862,9 +862,9 @@ } }, "node_modules/@eslint/js": { - "version": "9.34.0", - "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.34.0.tgz", - "integrity": "sha512-EoyvqQnBNsV1CWaEJ559rxXL4c8V92gxirbawSmVUOWXlsRxxQXl6LmCpdUblgxgSkDIqKnhzba2SjRTI/A5Rw==", + "version": "9.35.0", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.35.0.tgz", + "integrity": "sha512-30iXE9whjlILfWobBkNerJo+TXYsgVM5ERQwMcMKCHckHflCmf7wXDAHlARoWnh0s1U72WqlbeyE7iAcCzuCPw==", "dev": true, "engines": { "node": "^18.18.0 || ^20.9.0 || >=21.1.0" @@ -3169,6 +3169,18 @@ "url": "https://opencollective.com/eslint" } }, + "node_modules/eslint/node_modules/@eslint/js": { + "version": "9.34.0", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.34.0.tgz", + "integrity": "sha512-EoyvqQnBNsV1CWaEJ559rxXL4c8V92gxirbawSmVUOWXlsRxxQXl6LmCpdUblgxgSkDIqKnhzba2SjRTI/A5Rw==", + "dev": true, + "engines": { + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" + }, + "funding": { + "url": "https://eslint.org/donate" + } + }, "node_modules/eslint/node_modules/escape-string-regexp": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", @@ -7780,9 +7792,9 @@ } }, "@eslint/js": { - "version": "9.34.0", - "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.34.0.tgz", - "integrity": "sha512-EoyvqQnBNsV1CWaEJ559rxXL4c8V92gxirbawSmVUOWXlsRxxQXl6LmCpdUblgxgSkDIqKnhzba2SjRTI/A5Rw==", + "version": "9.35.0", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.35.0.tgz", + "integrity": "sha512-30iXE9whjlILfWobBkNerJo+TXYsgVM5ERQwMcMKCHckHflCmf7wXDAHlARoWnh0s1U72WqlbeyE7iAcCzuCPw==", "dev": true }, "@eslint/object-schema": { @@ -9463,6 +9475,12 @@ "optionator": "^0.9.3" }, "dependencies": { + "@eslint/js": { + "version": "9.34.0", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.34.0.tgz", + "integrity": "sha512-EoyvqQnBNsV1CWaEJ559rxXL4c8V92gxirbawSmVUOWXlsRxxQXl6LmCpdUblgxgSkDIqKnhzba2SjRTI/A5Rw==", + "dev": true + }, "escape-string-regexp": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", diff --git a/package.json b/package.json index 6f400ab8accc4..d9872af155a1b 100644 --- a/package.json +++ b/package.json @@ -39,7 +39,7 @@ "@actions/core": "^1.11.1", "@actions/github": "^6.0.1", "@eslint/eslintrc": "^3.3.1", - "@eslint/js": "^9.34.0", + "@eslint/js": "^9.35.0", "@testing-library/dom": "^10.4.1", "@testing-library/jest-dom": "^6.8.0", "@uppercod/css-to-object": "^1.1.1", From 20721f7fa859edbb935d3d96ab8c500a4c97212b Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Mon, 8 Sep 2025 14:19:46 +0300 Subject: [PATCH 046/265] build(deps-dev): bump eslint from 9.34.0 to 9.35.0 (#4410) Bumps [eslint](https://github.com/eslint/eslint) from 9.34.0 to 9.35.0. - [Release notes](https://github.com/eslint/eslint/releases) - [Changelog](https://github.com/eslint/eslint/blob/main/CHANGELOG.md) - [Commits](https://github.com/eslint/eslint/compare/v9.34.0...v9.35.0) --- updated-dependencies: - dependency-name: eslint dependency-version: 9.35.0 dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- package-lock.json | 41 ++++++++++++++++++++++------------------- package.json | 2 +- 2 files changed, 23 insertions(+), 20 deletions(-) diff --git a/package-lock.json b/package-lock.json index 692842df9aeea..d03b332345327 100644 --- a/package-lock.json +++ b/package-lock.json @@ -26,7 +26,7 @@ "@uppercod/css-to-object": "^1.1.1", "axios-mock-adapter": "^2.1.0", "color-contrast-checker": "^2.1.0", - "eslint": "^9.34.0", + "eslint": "^9.35.0", "eslint-config-prettier": "^10.1.8", "eslint-plugin-jsdoc": "^54.1.1", "globals": "^16.3.0", @@ -767,16 +767,19 @@ } }, "node_modules/@eslint-community/eslint-utils": { - "version": "4.4.0", - "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz", - "integrity": "sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==", + "version": "4.8.0", + "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.8.0.tgz", + "integrity": "sha512-MJQFqrZgcW0UNYLGOuQpey/oTN59vyWwplvCGZztn1cKz9agZPPYpJB7h2OMmuu7VLqkvEjN8feFZJmxNF9D+Q==", "dev": true, "dependencies": { - "eslint-visitor-keys": "^3.3.0" + "eslint-visitor-keys": "^3.4.3" }, "engines": { "node": "^12.22.0 || ^14.17.0 || >=16.0.0" }, + "funding": { + "url": "https://opencollective.com/eslint" + }, "peerDependencies": { "eslint": "^6.0.0 || ^7.0.0 || >=8.0.0" } @@ -3017,18 +3020,18 @@ } }, "node_modules/eslint": { - "version": "9.34.0", - "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.34.0.tgz", - "integrity": "sha512-RNCHRX5EwdrESy3Jc9o8ie8Bog+PeYvvSR8sDGoZxNFTvZ4dlxUB3WzQ3bQMztFrSRODGrLLj8g6OFuGY/aiQg==", + "version": "9.35.0", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.35.0.tgz", + "integrity": "sha512-QePbBFMJFjgmlE+cXAlbHZbHpdFVS2E/6vzCy7aKlebddvl1vadiC4JFV5u/wqTkNUwEV8WrQi257jf5f06hrg==", "dev": true, "dependencies": { - "@eslint-community/eslint-utils": "^4.2.0", + "@eslint-community/eslint-utils": "^4.8.0", "@eslint-community/regexpp": "^4.12.1", "@eslint/config-array": "^0.21.0", "@eslint/config-helpers": "^0.3.1", "@eslint/core": "^0.15.2", "@eslint/eslintrc": "^3.3.1", - "@eslint/js": "9.34.0", + "@eslint/js": "9.35.0", "@eslint/plugin-kit": "^0.3.5", "@humanfs/node": "^0.16.6", "@humanwhocodes/module-importer": "^1.0.1", @@ -7726,12 +7729,12 @@ } }, "@eslint-community/eslint-utils": { - "version": "4.4.0", - "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz", - "integrity": "sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==", + "version": "4.8.0", + "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.8.0.tgz", + "integrity": "sha512-MJQFqrZgcW0UNYLGOuQpey/oTN59vyWwplvCGZztn1cKz9agZPPYpJB7h2OMmuu7VLqkvEjN8feFZJmxNF9D+Q==", "dev": true, "requires": { - "eslint-visitor-keys": "^3.3.0" + "eslint-visitor-keys": "^3.4.3" } }, "@eslint-community/regexpp": { @@ -9433,18 +9436,18 @@ "dev": true }, "eslint": { - "version": "9.34.0", - "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.34.0.tgz", - "integrity": "sha512-RNCHRX5EwdrESy3Jc9o8ie8Bog+PeYvvSR8sDGoZxNFTvZ4dlxUB3WzQ3bQMztFrSRODGrLLj8g6OFuGY/aiQg==", + "version": "9.35.0", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.35.0.tgz", + "integrity": "sha512-QePbBFMJFjgmlE+cXAlbHZbHpdFVS2E/6vzCy7aKlebddvl1vadiC4JFV5u/wqTkNUwEV8WrQi257jf5f06hrg==", "dev": true, "requires": { - "@eslint-community/eslint-utils": "^4.2.0", + "@eslint-community/eslint-utils": "^4.8.0", "@eslint-community/regexpp": "^4.12.1", "@eslint/config-array": "^0.21.0", "@eslint/config-helpers": "^0.3.1", "@eslint/core": "^0.15.2", "@eslint/eslintrc": "^3.3.1", - "@eslint/js": "9.34.0", + "@eslint/js": "9.35.0", "@eslint/plugin-kit": "^0.3.5", "@humanfs/node": "^0.16.6", "@humanwhocodes/module-importer": "^1.0.1", diff --git a/package.json b/package.json index d9872af155a1b..abc22b6ec7239 100644 --- a/package.json +++ b/package.json @@ -45,7 +45,7 @@ "@uppercod/css-to-object": "^1.1.1", "axios-mock-adapter": "^2.1.0", "color-contrast-checker": "^2.1.0", - "eslint": "^9.34.0", + "eslint": "^9.35.0", "eslint-config-prettier": "^10.1.8", "eslint-plugin-jsdoc": "^54.1.1", "globals": "^16.3.0", From d3ee38f154320af8a505a5d0c2f5e6fdaa527405 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Mon, 8 Sep 2025 14:22:34 +0300 Subject: [PATCH 047/265] build(deps-dev): bump eslint-plugin-jsdoc from 54.1.1 to 54.5.0 (#4407) Bumps [eslint-plugin-jsdoc](https://github.com/gajus/eslint-plugin-jsdoc) from 54.1.1 to 54.5.0. - [Release notes](https://github.com/gajus/eslint-plugin-jsdoc/releases) - [Changelog](https://github.com/gajus/eslint-plugin-jsdoc/blob/main/.releaserc) - [Commits](https://github.com/gajus/eslint-plugin-jsdoc/compare/v54.1.1...v54.5.0) --- updated-dependencies: - dependency-name: eslint-plugin-jsdoc dependency-version: 54.5.0 dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- package-lock.json | 62 +++++++++++++++++++++++------------------------ package.json | 2 +- 2 files changed, 32 insertions(+), 32 deletions(-) diff --git a/package-lock.json b/package-lock.json index d03b332345327..5a13f55c93c24 100644 --- a/package-lock.json +++ b/package-lock.json @@ -28,7 +28,7 @@ "color-contrast-checker": "^2.1.0", "eslint": "^9.35.0", "eslint-config-prettier": "^10.1.8", - "eslint-plugin-jsdoc": "^54.1.1", + "eslint-plugin-jsdoc": "^54.5.0", "globals": "^16.3.0", "hjson": "^3.2.2", "husky": "^9.1.7", @@ -751,16 +751,16 @@ } }, "node_modules/@es-joy/jsdoccomment": { - "version": "0.53.0", - "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.53.0.tgz", - "integrity": "sha512-Wyed8Wfn3vMNVwrZrgLMxmqwmlcCE1/RfUAOHFzMJb3QLH03mi9Yv1iOCZjif0yx5EZUeJ+17VD1MHPka9IQjQ==", + "version": "0.56.0", + "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.56.0.tgz", + "integrity": "sha512-c6EW+aA1w2rjqOMjbL93nZlwxp6c1Ln06vTYs5FjRRhmJXK8V/OrSXdT+pUr4aRYgjCgu8/OkiZr0tzeVrRSbw==", "dev": true, "dependencies": { "@types/estree": "^1.0.8", - "@typescript-eslint/types": "^8.39.1", + "@typescript-eslint/types": "^8.42.0", "comment-parser": "1.4.1", "esquery": "^1.6.0", - "jsdoc-type-pratt-parser": "~4.8.0" + "jsdoc-type-pratt-parser": "~5.1.0" }, "engines": { "node": ">=20.11.0" @@ -2076,9 +2076,9 @@ "dev": true }, "node_modules/@typescript-eslint/types": { - "version": "8.40.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.40.0.tgz", - "integrity": "sha512-ETdbFlgbAmXHyFPwqUIYrfc12ArvpBhEVgGAxVYSwli26dn8Ko+lIo4Su9vI9ykTZdJn+vJprs/0eZU0YMAEQg==", + "version": "8.42.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.42.0.tgz", + "integrity": "sha512-LdtAWMiFmbRLNP7JNeY0SqEtJvGMYSzfiWBSmx+VSZ1CH+1zyl8Mmw1TT39OrtsRvIYShjJWzTDMPWZJCpwBlw==", "dev": true, "engines": { "node": "^18.18.0 || ^20.9.0 || >=21.1.0" @@ -3095,12 +3095,12 @@ } }, "node_modules/eslint-plugin-jsdoc": { - "version": "54.1.1", - "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-54.1.1.tgz", - "integrity": "sha512-qoY2Gl0OkvATXIxRaG2irS2ue78+RTaOyYrADvg1ue+9FHE+2Mp7RcpO0epkuhhQgOkH/REv1oJFe58dYv8SGg==", + "version": "54.5.0", + "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-54.5.0.tgz", + "integrity": "sha512-f+AOXbKa9QtOrJr1lfEZ6ScSnS4Lun8czm+U9VNB39jq5mTUc1WQTXDOaESm0C5veSyuo3WBz2ge0Ah79Jzo7g==", "dev": true, "dependencies": { - "@es-joy/jsdoccomment": "~0.53.0", + "@es-joy/jsdoccomment": "~0.56.0", "are-docs-informative": "^0.0.2", "comment-parser": "1.4.1", "debug": "^4.4.1", @@ -5280,9 +5280,9 @@ } }, "node_modules/jsdoc-type-pratt-parser": { - "version": "4.8.0", - "resolved": "https://registry.npmjs.org/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-4.8.0.tgz", - "integrity": "sha512-iZ8Bdb84lWRuGHamRXFyML07r21pcwBrLkHEuHgEY5UbCouBwv7ECknDRKzsQIXMiqpPymqtIf8TC/shYKB5rw==", + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-5.1.1.tgz", + "integrity": "sha512-DYYlVP1fe4QBMh2xTIs20/YeTz2GYVbWAEZweHSZD+qQ/Cx2d5RShuhhsdk64eTjNq0FeVnteP/qVOgaywSRbg==", "dev": true, "engines": { "node": ">=12.0.0" @@ -7716,16 +7716,16 @@ "dev": true }, "@es-joy/jsdoccomment": { - "version": "0.53.0", - "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.53.0.tgz", - "integrity": "sha512-Wyed8Wfn3vMNVwrZrgLMxmqwmlcCE1/RfUAOHFzMJb3QLH03mi9Yv1iOCZjif0yx5EZUeJ+17VD1MHPka9IQjQ==", + "version": "0.56.0", + "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.56.0.tgz", + "integrity": "sha512-c6EW+aA1w2rjqOMjbL93nZlwxp6c1Ln06vTYs5FjRRhmJXK8V/OrSXdT+pUr4aRYgjCgu8/OkiZr0tzeVrRSbw==", "dev": true, "requires": { "@types/estree": "^1.0.8", - "@typescript-eslint/types": "^8.39.1", + "@typescript-eslint/types": "^8.42.0", "comment-parser": "1.4.1", "esquery": "^1.6.0", - "jsdoc-type-pratt-parser": "~4.8.0" + "jsdoc-type-pratt-parser": "~5.1.0" } }, "@eslint-community/eslint-utils": { @@ -8764,9 +8764,9 @@ "dev": true }, "@typescript-eslint/types": { - "version": "8.40.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.40.0.tgz", - "integrity": "sha512-ETdbFlgbAmXHyFPwqUIYrfc12ArvpBhEVgGAxVYSwli26dn8Ko+lIo4Su9vI9ykTZdJn+vJprs/0eZU0YMAEQg==", + "version": "8.42.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.42.0.tgz", + "integrity": "sha512-LdtAWMiFmbRLNP7JNeY0SqEtJvGMYSzfiWBSmx+VSZ1CH+1zyl8Mmw1TT39OrtsRvIYShjJWzTDMPWZJCpwBlw==", "dev": true }, "@uppercod/css-to-object": { @@ -9573,12 +9573,12 @@ "requires": {} }, "eslint-plugin-jsdoc": { - "version": "54.1.1", - "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-54.1.1.tgz", - "integrity": "sha512-qoY2Gl0OkvATXIxRaG2irS2ue78+RTaOyYrADvg1ue+9FHE+2Mp7RcpO0epkuhhQgOkH/REv1oJFe58dYv8SGg==", + "version": "54.5.0", + "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-54.5.0.tgz", + "integrity": "sha512-f+AOXbKa9QtOrJr1lfEZ6ScSnS4Lun8czm+U9VNB39jq5mTUc1WQTXDOaESm0C5veSyuo3WBz2ge0Ah79Jzo7g==", "dev": true, "requires": { - "@es-joy/jsdoccomment": "~0.53.0", + "@es-joy/jsdoccomment": "~0.56.0", "are-docs-informative": "^0.0.2", "comment-parser": "1.4.1", "debug": "^4.4.1", @@ -11067,9 +11067,9 @@ } }, "jsdoc-type-pratt-parser": { - "version": "4.8.0", - "resolved": "https://registry.npmjs.org/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-4.8.0.tgz", - "integrity": "sha512-iZ8Bdb84lWRuGHamRXFyML07r21pcwBrLkHEuHgEY5UbCouBwv7ECknDRKzsQIXMiqpPymqtIf8TC/shYKB5rw==", + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-5.1.1.tgz", + "integrity": "sha512-DYYlVP1fe4QBMh2xTIs20/YeTz2GYVbWAEZweHSZD+qQ/Cx2d5RShuhhsdk64eTjNq0FeVnteP/qVOgaywSRbg==", "dev": true }, "jsdom": { diff --git a/package.json b/package.json index abc22b6ec7239..5eef0cdf58d5c 100644 --- a/package.json +++ b/package.json @@ -47,7 +47,7 @@ "color-contrast-checker": "^2.1.0", "eslint": "^9.35.0", "eslint-config-prettier": "^10.1.8", - "eslint-plugin-jsdoc": "^54.1.1", + "eslint-plugin-jsdoc": "^54.5.0", "globals": "^16.3.0", "hjson": "^3.2.2", "husky": "^9.1.7", From e4d4e9e28478b14cb1430c98c481fb85375e317e Mon Sep 17 00:00:00 2001 From: Vusal Huseynov <87518350+huseynovvusal@users.noreply.github.com> Date: Tue, 9 Sep 2025 21:30:50 +0400 Subject: [PATCH 048/265] feat: add Azerbaijani translations (#4214) * feat(translations): add Azerbaijani translations * feat(translations): add Azerbaijani to available locales * Update src/translations.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --------- Co-authored-by: Alexandr Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --- readme.md | 1 + src/translations.js | 22 ++++++++++++++++++++++ 2 files changed, 23 insertions(+) diff --git a/readme.md b/readme.md index 891e710a32531..2fa05a2ff7064 100644 --- a/readme.md +++ b/readme.md @@ -328,6 +328,7 @@ Here is a list of all available locales: | `uz` | Uzbek | | `vi` | Vietnamese | | `se` | Swedish | +| `az` | Azerbaijani | diff --git a/src/translations.js b/src/translations.js index aa8744d7e1391..2c30431e3ea77 100644 --- a/src/translations.js +++ b/src/translations.js @@ -17,6 +17,7 @@ const statCardLocales = ({ name, apostrophe }) => { return { "statcard.title": { ar: `${encodedName} إحصائيات غيت هاب`, + az: `${encodedName}'${apostrophe} Hesabının GitHub Statistikası`, cn: `${encodedName} 的 GitHub 统计数据`, "zh-tw": `${encodedName} 的 GitHub 統計數據`, cs: `GitHub statistiky uživatele ${encodedName}`, @@ -48,6 +49,7 @@ const statCardLocales = ({ name, apostrophe }) => { }, "statcard.ranktitle": { ar: `${encodedName} إحصائيات غيت هاب`, + az: `${encodedName}'${apostrophe} Hesabının GitHub Statistikası`, cn: `${encodedName} 的 GitHub 统计数据`, "zh-tw": `${encodedName} 的 GitHub 統計數據`, cs: `GitHub statistiky uživatele ${encodedName}`, @@ -79,6 +81,7 @@ const statCardLocales = ({ name, apostrophe }) => { }, "statcard.totalstars": { ar: "مجموع النجوم", + az: "Ümumi Ulduz", cn: "获标星数(star)", "zh-tw": "獲標星數(star)", cs: "Celkem hvězd", @@ -110,6 +113,7 @@ const statCardLocales = ({ name, apostrophe }) => { }, "statcard.commits": { ar: "مجموع الحفظ", + az: "Ümumi Commit", cn: "累计提交数(commit)", "zh-tw": "累計提交數(commit)", cs: "Celkem commitů", @@ -141,6 +145,7 @@ const statCardLocales = ({ name, apostrophe }) => { }, "statcard.prs": { ar: "مجموع طلبات السحب", + az: "Ümumi PR", cn: "拉取请求数(PR)", "zh-tw": "拉取請求數(PR)", cs: "Celkem PRs", @@ -172,6 +177,7 @@ const statCardLocales = ({ name, apostrophe }) => { }, "statcard.issues": { ar: "مجموع التحسينات", + az: "Ümumi Problem", cn: "指出问题数(issue)", "zh-tw": "指出問題數(issue)", cs: "Celkem problémů", @@ -203,6 +209,7 @@ const statCardLocales = ({ name, apostrophe }) => { }, "statcard.contribs": { ar: "ساهم في (العام الماضي)", + az: "Töhfə verdi (ötən il)", cn: "贡献于(去年)", "zh-tw": "參與項目數 (去年)", cs: "Přispěl k (minulý rok)", @@ -234,6 +241,7 @@ const statCardLocales = ({ name, apostrophe }) => { }, "statcard.reviews": { ar: "تمت مراجعة إجمالي العلاقات العامة", + az: "Nəzərdən Keçirilən Ümumi PR", cn: "審查的 PR 總數", "zh-tw": "审查的 PR 总数", cs: "Celkový počet PR", @@ -265,6 +273,7 @@ const statCardLocales = ({ name, apostrophe }) => { }, "statcard.discussions-started": { ar: "مجموع بدء المناقشات", + az: "Başladılan Ümumi Müzakirə", cn: "发起的讨论总数", "zh-tw": "發起的討論總數", cs: "Celkem zahájených diskusí", @@ -296,6 +305,7 @@ const statCardLocales = ({ name, apostrophe }) => { }, "statcard.discussions-answered": { ar: "مجموع الردود على المناقشات", + az: "Cavablandırılan Ümumi Müzakirə", cn: "回复的讨论总数", "zh-tw": "回覆的討論總數", cs: "Celkem zodpovězených diskusí", @@ -327,6 +337,7 @@ const statCardLocales = ({ name, apostrophe }) => { }, "statcard.prs-merged": { ar: "مجموع الطلبات المدمجة", + az: "Birləşdirilmiş Ümumi PR", cn: "合并的 PR 总数", "zh-tw": "合併的 PR 總數", cs: "Celkem sloučených PR", @@ -357,6 +368,7 @@ const statCardLocales = ({ name, apostrophe }) => { }, "statcard.prs-merged-percentage": { ar: "نسبة الطلبات المدمجة", + az: "Birləşdirilmiş PR-ların Faizi", cn: "合并的 PR 百分比", "zh-tw": "合併的 PR 百分比", cs: "Sloučené PRs v procentech", @@ -391,6 +403,7 @@ const statCardLocales = ({ name, apostrophe }) => { const repoCardLocales = { "repocard.template": { ar: "قالب", + az: "Şablon", bn: "টেমপ্লেট", cn: "模板", "zh-tw": "模板", @@ -422,6 +435,7 @@ const repoCardLocales = { }, "repocard.archived": { ar: "محفوظ", + az: "Arxiv", bn: "আর্কাইভড", cn: "已归档", "zh-tw": "已歸檔", @@ -456,6 +470,7 @@ const repoCardLocales = { const langCardLocales = { "langcard.title": { ar: "أكثر اللغات إستخداماً", + az: "Ən Çox İstifadə Olunan Dillər", cn: "最常用的语言", "zh-tw": "最常用的語言", cs: "Nejpoužívanější jazyky", @@ -487,6 +502,7 @@ const langCardLocales = { }, "langcard.nodata": { ar: "لا توجد بيانات لغات.", + az: "Dil məlumatı yoxdur.", cn: "沒有語言數據。", "zh-tw": "沒有語言數據。", cs: "Žádné jazykové údaje.", @@ -521,6 +537,7 @@ const langCardLocales = { const wakatimeCardLocales = { "wakatimecard.title": { ar: "إحصائيات واكا تايم", + az: "WakaTime Statistikası", cn: "WakaTime 周统计", "zh-tw": "WakaTime 周統計", cs: "Statistiky WakaTime", @@ -552,6 +569,7 @@ const wakatimeCardLocales = { }, "wakatimecard.lastyear": { ar: "العام الماضي", + az: "Ötən il", cn: "去年", "zh-tw": "去年", cs: "Minulý rok", @@ -583,6 +601,7 @@ const wakatimeCardLocales = { }, "wakatimecard.last7days": { ar: "آخر 7 أيام", + az: "Son 7 gün", cn: "最近 7 天", "zh-tw": "最近 7 天", cs: "Posledních 7 dní", @@ -614,6 +633,7 @@ const wakatimeCardLocales = { }, "wakatimecard.notpublic": { ar: "ملف المستخدم غير عام", + az: "WakaTime istifadəçi profili ictimai deyil", cn: "WakaTime 用户个人资料未公开", "zh-tw": "WakaTime 使用者個人資料未公開", cs: "Profil uživatele WakaTime není veřejný", @@ -645,6 +665,7 @@ const wakatimeCardLocales = { }, "wakatimecard.nocodedetails": { ar: "المستخدم لا يشارك معلومات تفصيلية عن البرمجة", + az: "İstifadəçi kod statistikalarını ictimai şəkildə paylaşmır", cn: "用户不公开分享详细的代码统计信息", "zh-tw": "使用者不公開分享詳細的程式碼統計資訊", cs: "Uživatel nesdílí podrobné statistiky kódu", @@ -678,6 +699,7 @@ const wakatimeCardLocales = { }, "wakatimecard.nocodingactivity": { ar: "لا يوجد نشاط برمجي لهذا الأسبوع", + az: "Bu həftə heç bir kodlaşdırma fəaliyyəti olmayıb", cn: "本周没有编程活动", "zh-tw": "本周沒有編程活動", cs: "Tento týden žádná aktivita v kódování", From 44cc74d6c601cff612e5e9971b0cfadab364121f Mon Sep 17 00:00:00 2001 From: Malware <85979829+Sploder-Saptarshi@users.noreply.github.com> Date: Tue, 9 Sep 2025 23:06:33 +0530 Subject: [PATCH 049/265] docs: fix grammar error inside readme file (#4180) * Fix grammatical error :) * Update readme.md Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --------- Co-authored-by: Alexandr Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --- readme.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/readme.md b/readme.md index 2fa05a2ff7064..793c57c192841 100644 --- a/readme.md +++ b/readme.md @@ -818,7 +818,7 @@ However, if you are using this project and are happy with it or just want to enc * Giving proper credit when you use github-readme-stats on your readme, linking back to it. :D * Starring and sharing the project. :rocket: -* [![paypal.me/anuraghazra](https://ionicabizau.github.io/badges/paypal.svg)](https://www.paypal.me/anuraghazra) - You can make a one-time donations via PayPal. I'll probably buy a ~~coffee~~ tea. :tea: +* [![paypal.me/anuraghazra](https://ionicabizau.github.io/badges/paypal.svg)](https://www.paypal.me/anuraghazra) - You can make a one-time donation via PayPal. I'll probably buy a ~~coffee~~ tea. :tea: Thanks! :heart: From 25dced4363fe852148e95d71ff17a3e5ea6a3f43 Mon Sep 17 00:00:00 2001 From: Blackspirits Date: Tue, 9 Sep 2025 20:00:29 +0200 Subject: [PATCH 050/265] fix: update Portuguese translations (#4213) Co-authored-by: Alexandr --- src/translations.js | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/translations.js b/src/translations.js index 2c30431e3ea77..9ae397bbe4d92 100644 --- a/src/translations.js +++ b/src/translations.js @@ -484,7 +484,7 @@ const langCardLocales = { ja: "最もよく使っている言語", kr: "가장 많이 사용된 언어", nl: "Meest gebruikte talen", - "pt-pt": "Idiomas mais usados", + "pt-pt": "Linguagens mais usadas", "pt-br": "Linguagens mais usadas", np: "अधिक प्रयोग गरिएको भाषाहरू", el: "Οι περισσότερο χρησιμοποιούμενες γλώσσες", @@ -516,8 +516,8 @@ const langCardLocales = { ja: "言語データがありません。", kr: "언어 데이터가 없습니다.", nl: "Ingen sprogdata.", - "pt-pt": "Sem dados de idiomas.", - "pt-br": "Sem dados de idiomas.", + "pt-pt": "Sem dados de linguagens.", + "pt-br": "Sem dados de linguagens.", np: "कुनै भाषा डाटा छैन।", el: "Δεν υπάρχουν δεδομένα γλωσσών.", ru: "Нет данных о языках.", @@ -647,7 +647,7 @@ const wakatimeCardLocales = { ja: "WakaTime ユーザープロファイルは公開されていません", kr: "WakaTime 사용자 프로필이 공개되지 않았습니다", nl: "WakaTime gebruikersprofiel niet openbaar", - "pt-pt": "Perfil de usuário WakaTime não público", + "pt-pt": "Perfil de utilizador WakaTime não público", "pt-br": "Perfil de usuário WakaTime não público", np: "WakaTime प्रयोगकर्ता प्रोफाइल सार्वजनिक छैन", el: "Το προφίλ χρήστη WakaTime δεν είναι δημόσιο", From 71ff19860917fbca732a00cb6eb036753064650a Mon Sep 17 00:00:00 2001 From: "Mohamed A. Abdallah" Date: Tue, 9 Sep 2025 21:12:50 +0300 Subject: [PATCH 051/265] fix: improve Arabic translations for accuracy (#4327) * fix(translations): improve Arabic translations for accuracy * Update src/translations.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --------- Co-authored-by: Alexandr Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --- src/translations.js | 26 +++++++++++++------------- 1 file changed, 13 insertions(+), 13 deletions(-) diff --git a/src/translations.js b/src/translations.js index 9ae397bbe4d92..1a9a77facceb1 100644 --- a/src/translations.js +++ b/src/translations.js @@ -16,7 +16,7 @@ const statCardLocales = ({ name, apostrophe }) => { const encodedName = encodeHTML(name); return { "statcard.title": { - ar: `${encodedName} إحصائيات غيت هاب`, + ar: `${encodedName} إحصائيات جيت هاب`, az: `${encodedName}'${apostrophe} Hesabının GitHub Statistikası`, cn: `${encodedName} 的 GitHub 统计数据`, "zh-tw": `${encodedName} 的 GitHub 統計數據`, @@ -48,7 +48,7 @@ const statCardLocales = ({ name, apostrophe }) => { se: `GitHubstatistik för ${encodedName}`, }, "statcard.ranktitle": { - ar: `${encodedName} إحصائيات غيت هاب`, + ar: `${encodedName} إحصائيات جيت هاب`, az: `${encodedName}'${apostrophe} Hesabının GitHub Statistikası`, cn: `${encodedName} 的 GitHub 统计数据`, "zh-tw": `${encodedName} 的 GitHub 統計數據`, @@ -112,7 +112,7 @@ const statCardLocales = ({ name, apostrophe }) => { se: "Antal intjänade stjärnor", }, "statcard.commits": { - ar: "مجموع الحفظ", + ar: "مجموع المساهمات", az: "Ümumi Commit", cn: "累计提交数(commit)", "zh-tw": "累計提交數(commit)", @@ -240,7 +240,7 @@ const statCardLocales = ({ name, apostrophe }) => { se: "Bidragit till (förra året)", }, "statcard.reviews": { - ar: "تمت مراجعة إجمالي العلاقات العامة", + ar: "طلبات السحب التي تم مراجعتها", az: "Nəzərdən Keçirilən Ümumi PR", cn: "審查的 PR 總數", "zh-tw": "审查的 PR 总数", @@ -272,7 +272,7 @@ const statCardLocales = ({ name, apostrophe }) => { se: "Totalt antal granskade PR", }, "statcard.discussions-started": { - ar: "مجموع بدء المناقشات", + ar: "مجموع المناقشات التي بدأها", az: "Başladılan Ümumi Müzakirə", cn: "发起的讨论总数", "zh-tw": "發起的討論總數", @@ -304,7 +304,7 @@ const statCardLocales = ({ name, apostrophe }) => { se: "Totalt antal diskussioner startade", }, "statcard.discussions-answered": { - ar: "مجموع الردود على المناقشات", + ar: "مجموع المناقشات المُجابة", az: "Cavablandırılan Ümumi Müzakirə", cn: "回复的讨论总数", "zh-tw": "回覆的討論總數", @@ -336,7 +336,7 @@ const statCardLocales = ({ name, apostrophe }) => { se: "Totalt antal diskussioner besvarade", }, "statcard.prs-merged": { - ar: "مجموع الطلبات المدمجة", + ar: "مجموع طلبات السحب المُدمجة", az: "Birləşdirilmiş Ümumi PR", cn: "合并的 PR 总数", "zh-tw": "合併的 PR 總數", @@ -367,7 +367,7 @@ const statCardLocales = ({ name, apostrophe }) => { se: "Totalt antal sammanfogade PR", }, "statcard.prs-merged-percentage": { - ar: "نسبة الطلبات المدمجة", + ar: "نسبة طلبات السحب المُدمجة", az: "Birləşdirilmiş PR-ların Faizi", cn: "合并的 PR 百分比", "zh-tw": "合併的 PR 百分比", @@ -434,7 +434,7 @@ const repoCardLocales = { se: "Mall", }, "repocard.archived": { - ar: "محفوظ", + ar: "مُؤرشف", az: "Arxiv", bn: "আর্কাইভড", cn: "已归档", @@ -469,7 +469,7 @@ const repoCardLocales = { const langCardLocales = { "langcard.title": { - ar: "أكثر اللغات إستخداماً", + ar: "أكثر اللغات استخدامًا", az: "Ən Çox İstifadə Olunan Dillər", cn: "最常用的语言", "zh-tw": "最常用的語言", @@ -501,7 +501,7 @@ const langCardLocales = { se: "Mest använda språken", }, "langcard.nodata": { - ar: "لا توجد بيانات لغات.", + ar: "لا توجد بيانات للغات.", az: "Dil məlumatı yoxdur.", cn: "沒有語言數據。", "zh-tw": "沒有語言數據。", @@ -632,7 +632,7 @@ const wakatimeCardLocales = { se: "Senaste 7 dagarna", }, "wakatimecard.notpublic": { - ar: "ملف المستخدم غير عام", + ar: "ملف مستخدم واكا تايم شخصي", az: "WakaTime istifadəçi profili ictimai deyil", cn: "WakaTime 用户个人资料未公开", "zh-tw": "WakaTime 使用者個人資料未公開", @@ -664,7 +664,7 @@ const wakatimeCardLocales = { se: "WakaTime användarprofil inte offentlig", }, "wakatimecard.nocodedetails": { - ar: "المستخدم لا يشارك معلومات تفصيلية عن البرمجة", + ar: "المستخدم لا يشارك المعلومات التفصيلية", az: "İstifadəçi kod statistikalarını ictimai şəkildə paylaşmır", cn: "用户不公开分享详细的代码统计信息", "zh-tw": "使用者不公開分享詳細的程式碼統計資訊", From b907fba9b0c2cea1c090d4f94072481903c137ea Mon Sep 17 00:00:00 2001 From: Yavuz Selim OKTAR Date: Tue, 9 Sep 2025 23:03:33 +0300 Subject: [PATCH 052/265] fix: improve Turkish translations (#4279) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit https://dictionary.cambridge.org/dictionary/english-turkish/statistics?q=Statistics#:~:text=information%20about%20something-,istatistik,-There%20were%20900 Change "Yıldızları" to the better translation of "İstatistikleri". Co-authored-by: Alexandr --- src/translations.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/translations.js b/src/translations.js index 1a9a77facceb1..848971d3eca7a 100644 --- a/src/translations.js +++ b/src/translations.js @@ -41,7 +41,7 @@ const statCardLocales = ({ name, apostrophe }) => { ml: `${encodedName}'${apostrophe} ഗിറ്റ്ഹബ് സ്ഥിതിവിവരക്കണക്കുകൾ`, my: `Statistik GitHub ${encodedName}`, sk: `GitHub štatistiky používateľa ${encodedName}`, - tr: `${encodedName} Hesabının GitHub Yıldızları`, + tr: `${encodedName} Hesabının GitHub İstatistikleri`, pl: `Statystyki GitHub użytkownika ${encodedName}`, uz: `${encodedName}ning GitHub'dagi statistikasi`, vi: `Thống Kê GitHub ${encodedName}`, From b0b14091e785e8b70f24def73b41ecb2b99c0082 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Tue, 9 Sep 2025 23:43:25 +0300 Subject: [PATCH 053/265] build(deps-dev): bump eslint-plugin-jsdoc from 54.5.0 to 55.0.0 (#4414) Bumps [eslint-plugin-jsdoc](https://github.com/gajus/eslint-plugin-jsdoc) from 54.5.0 to 55.0.0. - [Release notes](https://github.com/gajus/eslint-plugin-jsdoc/releases) - [Changelog](https://github.com/gajus/eslint-plugin-jsdoc/blob/main/.releaserc) - [Commits](https://github.com/gajus/eslint-plugin-jsdoc/compare/v54.5.0...v55.0.0) --- updated-dependencies: - dependency-name: eslint-plugin-jsdoc dependency-version: 55.0.0 dependency-type: direct:development update-type: version-update:semver-major ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- package-lock.json | 72 +++++++++++++++++++++++++++++++---------------- package.json | 2 +- 2 files changed, 48 insertions(+), 26 deletions(-) diff --git a/package-lock.json b/package-lock.json index 5a13f55c93c24..4a6501ffd5bb9 100644 --- a/package-lock.json +++ b/package-lock.json @@ -28,7 +28,7 @@ "color-contrast-checker": "^2.1.0", "eslint": "^9.35.0", "eslint-config-prettier": "^10.1.8", - "eslint-plugin-jsdoc": "^54.5.0", + "eslint-plugin-jsdoc": "^55.0.0", "globals": "^16.3.0", "hjson": "^3.2.2", "husky": "^9.1.7", @@ -3095,9 +3095,9 @@ } }, "node_modules/eslint-plugin-jsdoc": { - "version": "54.5.0", - "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-54.5.0.tgz", - "integrity": "sha512-f+AOXbKa9QtOrJr1lfEZ6ScSnS4Lun8czm+U9VNB39jq5mTUc1WQTXDOaESm0C5veSyuo3WBz2ge0Ah79Jzo7g==", + "version": "55.0.0", + "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-55.0.0.tgz", + "integrity": "sha512-45ljWx7dw0kA+zT/gYxhUUeMXUFZdn3yTxkOKvekYmhfYQF2kUx+2THnK1oeHFqdnJWkyi3ZSeLt4FKWMLKXTA==", "dev": true, "dependencies": { "@es-joy/jsdoccomment": "~0.56.0", @@ -3107,6 +3107,7 @@ "escape-string-regexp": "^4.0.0", "espree": "^10.4.0", "esquery": "^1.6.0", + "object-deep-merge": "^1.0.5", "parse-imports-exports": "^0.2.4", "semver": "^7.7.2", "spdx-expression-parse": "^4.0.0" @@ -3172,18 +3173,6 @@ "url": "https://opencollective.com/eslint" } }, - "node_modules/eslint/node_modules/@eslint/js": { - "version": "9.34.0", - "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.34.0.tgz", - "integrity": "sha512-EoyvqQnBNsV1CWaEJ559rxXL4c8V92gxirbawSmVUOWXlsRxxQXl6LmCpdUblgxgSkDIqKnhzba2SjRTI/A5Rw==", - "dev": true, - "engines": { - "node": "^18.18.0 || ^20.9.0 || >=21.1.0" - }, - "funding": { - "url": "https://eslint.org/donate" - } - }, "node_modules/eslint/node_modules/escape-string-regexp": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", @@ -5989,6 +5978,27 @@ "integrity": "sha512-o6nIY3qwiSXl7/LuOU0Dmuctd34Yay0yeuZRLFmDPrrdHpXKFndPj3hM+YEPVHYC5fx2otBx4Ilc/gyYSAUaIA==", "dev": true }, + "node_modules/object-deep-merge": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/object-deep-merge/-/object-deep-merge-1.0.5.tgz", + "integrity": "sha512-3DioFgOzetbxbeUq8pB2NunXo8V0n4EvqsWM/cJoI6IA9zghd7cl/2pBOuWRf4dlvA+fcg5ugFMZaN2/RuoaGg==", + "dev": true, + "dependencies": { + "type-fest": "4.2.0" + } + }, + "node_modules/object-deep-merge/node_modules/type-fest": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-4.2.0.tgz", + "integrity": "sha512-5zknd7Dss75pMSED270A1RQS3KloqRJA9XbXLe0eCxyw7xXFb3rd+9B0UQ/0E+LQT6lnrLviEolYORlRWamn4w==", + "dev": true, + "engines": { + "node": ">=16" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, "node_modules/once": { "version": "1.4.0", "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", @@ -9478,12 +9488,6 @@ "optionator": "^0.9.3" }, "dependencies": { - "@eslint/js": { - "version": "9.34.0", - "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.34.0.tgz", - "integrity": "sha512-EoyvqQnBNsV1CWaEJ559rxXL4c8V92gxirbawSmVUOWXlsRxxQXl6LmCpdUblgxgSkDIqKnhzba2SjRTI/A5Rw==", - "dev": true - }, "escape-string-regexp": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", @@ -9573,9 +9577,9 @@ "requires": {} }, "eslint-plugin-jsdoc": { - "version": "54.5.0", - "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-54.5.0.tgz", - "integrity": "sha512-f+AOXbKa9QtOrJr1lfEZ6ScSnS4Lun8czm+U9VNB39jq5mTUc1WQTXDOaESm0C5veSyuo3WBz2ge0Ah79Jzo7g==", + "version": "55.0.0", + "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-55.0.0.tgz", + "integrity": "sha512-45ljWx7dw0kA+zT/gYxhUUeMXUFZdn3yTxkOKvekYmhfYQF2kUx+2THnK1oeHFqdnJWkyi3ZSeLt4FKWMLKXTA==", "dev": true, "requires": { "@es-joy/jsdoccomment": "~0.56.0", @@ -9585,6 +9589,7 @@ "escape-string-regexp": "^4.0.0", "espree": "^10.4.0", "esquery": "^1.6.0", + "object-deep-merge": "^1.0.5", "parse-imports-exports": "^0.2.4", "semver": "^7.7.2", "spdx-expression-parse": "^4.0.0" @@ -11575,6 +11580,23 @@ "integrity": "sha512-o6nIY3qwiSXl7/LuOU0Dmuctd34Yay0yeuZRLFmDPrrdHpXKFndPj3hM+YEPVHYC5fx2otBx4Ilc/gyYSAUaIA==", "dev": true }, + "object-deep-merge": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/object-deep-merge/-/object-deep-merge-1.0.5.tgz", + "integrity": "sha512-3DioFgOzetbxbeUq8pB2NunXo8V0n4EvqsWM/cJoI6IA9zghd7cl/2pBOuWRf4dlvA+fcg5ugFMZaN2/RuoaGg==", + "dev": true, + "requires": { + "type-fest": "4.2.0" + }, + "dependencies": { + "type-fest": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-4.2.0.tgz", + "integrity": "sha512-5zknd7Dss75pMSED270A1RQS3KloqRJA9XbXLe0eCxyw7xXFb3rd+9B0UQ/0E+LQT6lnrLviEolYORlRWamn4w==", + "dev": true + } + } + }, "once": { "version": "1.4.0", "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", diff --git a/package.json b/package.json index 5eef0cdf58d5c..11684546702a4 100644 --- a/package.json +++ b/package.json @@ -47,7 +47,7 @@ "color-contrast-checker": "^2.1.0", "eslint": "^9.35.0", "eslint-config-prettier": "^10.1.8", - "eslint-plugin-jsdoc": "^54.5.0", + "eslint-plugin-jsdoc": "^55.0.0", "globals": "^16.3.0", "hjson": "^3.2.2", "husky": "^9.1.7", From ea6ef1124d957172da30528edb763cacd70782c8 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ma=C5=82gorzata=20=28Gosia=29?= <143265463+malgokiel@users.noreply.github.com> Date: Wed, 10 Sep 2025 17:32:30 +0200 Subject: [PATCH 054/265] fix: handle apostrophes for names ending in x (#4343) * fix: handle apostrophes for names ending in x * review --------- Co-authored-by: Alexandr --- src/cards/stats.js | 4 +--- tests/renderStatsCard.test.js | 2 +- 2 files changed, 2 insertions(+), 4 deletions(-) diff --git a/src/cards/stats.js b/src/cards/stats.js index 5b7f0d268f9bd..402e86fb4aa42 100644 --- a/src/cards/stats.js +++ b/src/cards/stats.js @@ -254,9 +254,7 @@ const renderStatsCard = (stats, options = {}) => { theme, }); - const apostrophe = ["x", "s"].includes(name.slice(-1).toLocaleLowerCase()) - ? "" - : "s"; + const apostrophe = /s$/i.test(name.trim()) ? "" : "s"; const i18n = new I18n({ locale, translations: statCardLocales({ name, apostrophe }), diff --git a/tests/renderStatsCard.test.js b/tests/renderStatsCard.test.js index dab0f86178978..12640fdbd8912 100644 --- a/tests/renderStatsCard.test.js +++ b/tests/renderStatsCard.test.js @@ -71,7 +71,7 @@ describe("Test renderStatsCard", () => { document.body.innerHTML = renderStatsCard({ ...stats, name: "Felix" }); expect(document.getElementsByClassName("header")[0].textContent).toBe( - "Felix' GitHub Stats", + "Felix's GitHub Stats", ); }); From 5320bc8c835e87143495595ea4473ea438e09991 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E5=AD=9F=E6=AD=A6=2E=E5=B0=BC=E5=BE=B7=E9=9C=8D=E6=A0=BC?= =?UTF-8?q?=2E=E9=BE=8D?= <9822340+tony8077616@users.noreply.github.com> Date: Wed, 10 Sep 2025 23:43:52 +0800 Subject: [PATCH 055/265] fix: update Traditional Chinese translations (#4089) Co-authored-by: Alexandr --- src/translations.js | 24 ++++++++++++------------ 1 file changed, 12 insertions(+), 12 deletions(-) diff --git a/src/translations.js b/src/translations.js index 848971d3eca7a..495d0d1bf6c9b 100644 --- a/src/translations.js +++ b/src/translations.js @@ -19,7 +19,7 @@ const statCardLocales = ({ name, apostrophe }) => { ar: `${encodedName} إحصائيات جيت هاب`, az: `${encodedName}'${apostrophe} Hesabının GitHub Statistikası`, cn: `${encodedName} 的 GitHub 统计数据`, - "zh-tw": `${encodedName} 的 GitHub 統計數據`, + "zh-tw": `${encodedName} 的 GitHub 統計資料`, cs: `GitHub statistiky uživatele ${encodedName}`, de: `${encodedName + apostrophe} GitHub-Statistiken`, en: `${encodedName}'${apostrophe} GitHub Stats`, @@ -51,7 +51,7 @@ const statCardLocales = ({ name, apostrophe }) => { ar: `${encodedName} إحصائيات جيت هاب`, az: `${encodedName}'${apostrophe} Hesabının GitHub Statistikası`, cn: `${encodedName} 的 GitHub 统计数据`, - "zh-tw": `${encodedName} 的 GitHub 統計數據`, + "zh-tw": `${encodedName} 的 GitHub 統計資料`, cs: `GitHub statistiky uživatele ${encodedName}`, de: `${encodedName + apostrophe} GitHub-Statistiken`, en: `${encodedName}'${apostrophe} GitHub Rank`, @@ -83,7 +83,7 @@ const statCardLocales = ({ name, apostrophe }) => { ar: "مجموع النجوم", az: "Ümumi Ulduz", cn: "获标星数(star)", - "zh-tw": "獲標星數(star)", + "zh-tw": "得標星星數量(Star)", cs: "Celkem hvězd", de: "Insgesamt erhaltene Sterne", en: "Total Stars Earned", @@ -115,7 +115,7 @@ const statCardLocales = ({ name, apostrophe }) => { ar: "مجموع المساهمات", az: "Ümumi Commit", cn: "累计提交数(commit)", - "zh-tw": "累計提交數(commit)", + "zh-tw": "累計提交數量(Commit)", cs: "Celkem commitů", de: "Anzahl Commits", en: "Total Commits", @@ -147,7 +147,7 @@ const statCardLocales = ({ name, apostrophe }) => { ar: "مجموع طلبات السحب", az: "Ümumi PR", cn: "拉取请求数(PR)", - "zh-tw": "拉取請求數(PR)", + "zh-tw": "拉取請求數量(PR)", cs: "Celkem PRs", de: "PRs Insgesamt", en: "Total PRs", @@ -179,7 +179,7 @@ const statCardLocales = ({ name, apostrophe }) => { ar: "مجموع التحسينات", az: "Ümumi Problem", cn: "指出问题数(issue)", - "zh-tw": "指出問題數(issue)", + "zh-tw": "提出問題數量(Issue)", cs: "Celkem problémů", de: "Anzahl Issues", en: "Total Issues", @@ -211,7 +211,7 @@ const statCardLocales = ({ name, apostrophe }) => { ar: "ساهم في (العام الماضي)", az: "Töhfə verdi (ötən il)", cn: "贡献于(去年)", - "zh-tw": "參與項目數 (去年)", + "zh-tw": "參與項目數量(去年)", cs: "Přispěl k (minulý rok)", de: "Beigetragen zu (letztes Jahr)", en: "Contributed to (last year)", @@ -243,7 +243,7 @@ const statCardLocales = ({ name, apostrophe }) => { ar: "طلبات السحب التي تم مراجعتها", az: "Nəzərdən Keçirilən Ümumi PR", cn: "審查的 PR 總數", - "zh-tw": "审查的 PR 总数", + "zh-tw": "審核的 PR 總計", cs: "Celkový počet PR", de: "Insgesamt überprüfte PRs", en: "Total PRs Reviewed", @@ -307,7 +307,7 @@ const statCardLocales = ({ name, apostrophe }) => { ar: "مجموع المناقشات المُجابة", az: "Cavablandırılan Ümumi Müzakirə", cn: "回复的讨论总数", - "zh-tw": "回覆的討論總數", + "zh-tw": "回覆討論總計", cs: "Celkem zodpovězených diskusí", de: "Gesamt beantwortete Diskussionen", en: "Total Discussions Answered", @@ -339,7 +339,7 @@ const statCardLocales = ({ name, apostrophe }) => { ar: "مجموع طلبات السحب المُدمجة", az: "Birləşdirilmiş Ümumi PR", cn: "合并的 PR 总数", - "zh-tw": "合併的 PR 總數", + "zh-tw": "合併的 PR 總計", cs: "Celkem sloučených PR", de: "Insgesamt zusammengeführte PRs", en: "Total PRs Merged", @@ -438,7 +438,7 @@ const repoCardLocales = { az: "Arxiv", bn: "আর্কাইভড", cn: "已归档", - "zh-tw": "已歸檔", + "zh-tw": "已封存", cs: "Archivováno", de: "Archiviert", en: "Archived", @@ -504,7 +504,7 @@ const langCardLocales = { ar: "لا توجد بيانات للغات.", az: "Dil məlumatı yoxdur.", cn: "沒有語言數據。", - "zh-tw": "沒有語言數據。", + "zh-tw": "沒有語言資料。", cs: "Žádné jazykové údaje.", de: "Keine Sprachdaten.", bn: "কোন ভাষার ডেটা নেই।", From 3cdfa8826e8beaea6e7e508566ceed220141433e Mon Sep 17 00:00:00 2001 From: Blueberryy <36592509+Blueberryy@users.noreply.github.com> Date: Wed, 10 Sep 2025 21:25:13 +0500 Subject: [PATCH 056/265] fix: update Russian translations (#4119) * Update Russian translation * fix {apostrophe} * missed {apostrophe} * review --------- Co-authored-by: Alexandr --- src/translations.js | 24 ++++++++++++------------ 1 file changed, 12 insertions(+), 12 deletions(-) diff --git a/src/translations.js b/src/translations.js index 495d0d1bf6c9b..1f2f2808debdd 100644 --- a/src/translations.js +++ b/src/translations.js @@ -67,7 +67,7 @@ const statCardLocales = ({ name, apostrophe }) => { "pt-br": `Estatísticas do GitHub de ${encodedName}`, np: `${encodedName}'${apostrophe} गिटहब तथ्याङ्क`, el: `Στατιστικά GitHub του ${encodedName}`, - ru: `Статистика GitHub пользователя ${encodedName}`, + ru: `Рейтинг GitHub пользователя ${encodedName}`, "uk-ua": `Статистика GitHub користувача ${encodedName}`, id: `Statistik GitHub ${encodedName}`, ml: `${encodedName}'${apostrophe} ഗിറ്റ്ഹബ് സ്ഥിതിവിവരക്കണക്കുകൾ`, @@ -99,7 +99,7 @@ const statCardLocales = ({ name, apostrophe }) => { "pt-br": "Total de estrelas", np: "कुल ताराहरू", el: "Σύνολο Αστεριών", - ru: "Всего звезд", + ru: "Всего звёзд", "uk-ua": "Всього зірок", id: "Total Bintang", ml: "ആകെ നക്ഷത്രങ്ങൾ", @@ -163,7 +163,7 @@ const statCardLocales = ({ name, apostrophe }) => { "pt-br": "Total de PRs", np: "कुल PRs", el: "Σύνολο PRs", - ru: "Всего pull request`ов", + ru: "Всего запросов изменений", "uk-ua": "Всього pull request`iв", id: "Total Permintaan Tarik", ml: "ആകെ പുൾ അഭ്യർത്ഥനകൾ", @@ -195,7 +195,7 @@ const statCardLocales = ({ name, apostrophe }) => { "pt-br": "Total de Issues", np: "कुल मुद्दाहरू", el: "Σύνολο Ζητημάτων", - ru: "Всего issue", + ru: "Всего вопросов", "uk-ua": "Всього issue", id: "Total Masalah Dilaporkan", ml: "ആകെ ലക്കങ്ങൾ", @@ -227,7 +227,7 @@ const statCardLocales = ({ name, apostrophe }) => { "pt-br": "Contribuiu para (ano passado)", np: "कुल योगदानहरू (गत वर्ष)", el: "Συνεισφέρθηκε σε (πέρυσι)", - ru: "Внёс вклад в (за прошлый год)", + ru: "Внесено вклада (за прошлый год)", "uk-ua": "Зробив внесок у (за минулий рік)", id: "Berkontribusi ke (tahun lalu)", ml: "സമർപ്പിച്ചിരിക്കുന്നത് (കഴിഞ്ഞ വർഷം)", @@ -259,7 +259,7 @@ const statCardLocales = ({ name, apostrophe }) => { "pt-br": "Total de PRs revisados", np: "कुल पीआर समीक्षित", el: "Σύνολο Αναθεωρημένων PR", - ru: "Всего pull request`ов проверено", + ru: "Всего запросов проверено", "uk-ua": "Всього pull request`iв перевірено", id: "Total PR yang Direview", ml: "ആകെ പുൾ അഭിപ്രായങ്ങൾ", @@ -291,7 +291,7 @@ const statCardLocales = ({ name, apostrophe }) => { "pt-br": "Total de Discussões Iniciadas", np: "कुल चर्चा सुरु", el: "Σύνολο Συζητήσεων που Ξεκίνησαν", - ru: "Всего начатых дискуссий", + ru: "Всего начатых обсуждений", "uk-ua": "Всього розпочатих дискусій", id: "Total Diskusi Dimulai", ml: "ആരംഭിച്ച ആലോചനകൾ", @@ -323,7 +323,7 @@ const statCardLocales = ({ name, apostrophe }) => { "pt-br": "Total de Discussões Respondidas", np: "कुल चर्चा उत्तर", el: "Σύνολο Συζητήσεων που Απαντήθηκαν", - ru: "Всего отвеченных дискуссий", + ru: "Всего отвеченных обсуждений", "uk-ua": "Всього відповідей на дискусії", id: "Total Diskusi Dibalas", ml: "ഉത്തരം നൽകിയ ആലോചനകൾ", @@ -355,7 +355,7 @@ const statCardLocales = ({ name, apostrophe }) => { "pt-br": "Total de PRs Fundidos", np: "कुल PRs मर्ज गरिएको", el: "Σύνολο Συγχωνευμένων PR", - ru: "Всего объединённых pull request`ов", + ru: "Всего объединённых запросов", "uk-ua": "Всього об'єднаних pull request`iв", id: "Total PR Digabungkan", my: "Jumlah PR Digabungkan", @@ -386,7 +386,7 @@ const statCardLocales = ({ name, apostrophe }) => { "pt-br": "Porcentagem de PRs Fundidos", np: "PR मर्ज गरिएको प्रतिशत", el: "Ποσοστό Συγχωνευμένων PR", - ru: "Процент объединённых pull request`ов", + ru: "Процент объединённых запросов", "uk-ua": "Відсоток об'єднаних pull request`iв", id: "Persentase PR Digabungkan", my: "Peratus PR Digabungkan", @@ -488,7 +488,7 @@ const langCardLocales = { "pt-br": "Linguagens mais usadas", np: "अधिक प्रयोग गरिएको भाषाहरू", el: "Οι περισσότερο χρησιμοποιούμενες γλώσσες", - ru: "Наиболее часто используемые языки", + ru: "Наиболее используемые языки", "uk-ua": "Найчастіше використовувані мови", id: "Bahasa Yang Paling Banyak Digunakan", ml: "കൂടുതൽ ഉപയോഗിച്ച ഭാഷകൾ", @@ -651,7 +651,7 @@ const wakatimeCardLocales = { "pt-br": "Perfil de usuário WakaTime não público", np: "WakaTime प्रयोगकर्ता प्रोफाइल सार्वजनिक छैन", el: "Το προφίλ χρήστη WakaTime δεν είναι δημόσιο", - ru: "Профиль пользователя WakaTime не является общедоступным", + ru: "Профиль пользователя WakaTime не общедоступный", "uk-ua": "Профіль користувача WakaTime не є публічним", id: "Profil pengguna WakaTime tidak publik", ml: "WakaTime ഉപയോക്തൃ പ്രൊഫൈൽ പൊതുവായി പ്രസിദ്ധീകരിക്കപ്പെടാത്തതാണ്", From c966becb9ab35bf95031e2b6a04ccedfedcc47de Mon Sep 17 00:00:00 2001 From: Frieder Bluemle Date: Wed, 10 Sep 2025 09:31:35 -0700 Subject: [PATCH 057/265] chore: standardize the GitHub and npm branding through the codebase (#4014) Co-authored-by: Alexandr --- .github/dependabot.yml | 2 +- readme.md | 4 ++-- src/fetchers/gist.js | 2 +- src/fetchers/stats.js | 2 +- 4 files changed, 5 insertions(+), 5 deletions(-) diff --git a/.github/dependabot.yml b/.github/dependabot.yml index 931c461ca4ebb..13eb4b3c6ca40 100644 --- a/.github/dependabot.yml +++ b/.github/dependabot.yml @@ -1,6 +1,6 @@ version: 2 updates: - # Maintain dependencies for NPM + # Maintain dependencies for npm - package-ecosystem: npm directory: "/" schedule: diff --git a/readme.md b/readme.md index 793c57c192841..f8704486ebd71 100644 --- a/readme.md +++ b/readme.md @@ -636,7 +636,7 @@ You can customize the appearance and behavior of the WakaTime stats card using t ![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra\&hide=issues\&show_icons=true) -* Shows Github logo instead rank level +* Shows GitHub logo instead rank level ![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra\&rank_icon=github) @@ -799,7 +799,7 @@ Since the GitHub API only allows 5k requests per hour, my `https://github-readme ## Disable rate limit protections -Github Readme Stats contains several Vercel environment variables that can be used to remove the rate limit protections: +GitHub Readme Stats contains several Vercel environment variables that can be used to remove the rate limit protections: * `CACHE_SECONDS`: This environment variable takes precedence over our cache minimum and maximum values and can circumvent these values for self-hosted Vercel instances. diff --git a/src/fetchers/gist.js b/src/fetchers/gist.js index 4e0e0f5e7e4f2..cd4006b2224c5 100644 --- a/src/fetchers/gist.js +++ b/src/fetchers/gist.js @@ -83,7 +83,7 @@ const calculatePrimaryLanguage = (files) => { /** * Fetch GitHub gist information by given username and ID. * - * @param {string} id Github gist ID. + * @param {string} id GitHub gist ID. * @returns {Promise} Gist data. */ const fetchGist = async (id) => { diff --git a/src/fetchers/stats.js b/src/fetchers/stats.js index 115cd50a51564..88fd72fcb9760 100644 --- a/src/fetchers/stats.js +++ b/src/fetchers/stats.js @@ -105,7 +105,7 @@ const fetcher = (variables, token) => { * Fetch stats information for a given username. * * @param {object} variables Fetcher variables. - * @param {string} variables.username Github username. + * @param {string} variables.username GitHub username. * @param {boolean} variables.includeMergedPullRequests Include merged pull requests. * @param {boolean} variables.includeDiscussions Include discussions. * @param {boolean} variables.includeDiscussionsAnswers Include discussions answers. From affd6f458fdb599db478defc8d4d6ef3de08e49d Mon Sep 17 00:00:00 2001 From: George Gastaldi Date: Wed, 10 Sep 2025 15:32:04 -0300 Subject: [PATCH 058/265] fix: improve Portuguese translations (#3889) A more accurate ptBR translation for `Merged` is `Integrados` Co-authored-by: Alexandr --- src/translations.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/translations.js b/src/translations.js index 1f2f2808debdd..28403441febba 100644 --- a/src/translations.js +++ b/src/translations.js @@ -352,7 +352,7 @@ const statCardLocales = ({ name, apostrophe }) => { kr: "병합된 총 PR", nl: "Totaal samengevoegde PR's", "pt-pt": "Total de PRs Fundidos", - "pt-br": "Total de PRs Fundidos", + "pt-br": "Total de PRs Integrados", np: "कुल PRs मर्ज गरिएको", el: "Σύνολο Συγχωνευμένων PR", ru: "Всего объединённых запросов", @@ -383,7 +383,7 @@ const statCardLocales = ({ name, apostrophe }) => { kr: "병합된 PR의 비율", nl: "Percentage samengevoegde PR's", "pt-pt": "Percentagem de PRs Fundidos", - "pt-br": "Porcentagem de PRs Fundidos", + "pt-br": "Porcentagem de PRs Integrados", np: "PR मर्ज गरिएको प्रतिशत", el: "Ποσοστό Συγχωνευμένων PR", ru: "Процент объединённых запросов", From 116d255bf11ecf44bf5455cc452134623c1290e6 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Wed, 10 Sep 2025 21:35:23 +0300 Subject: [PATCH 059/265] build(deps-dev): bump globals from 16.3.0 to 16.4.0 (#4418) Bumps [globals](https://github.com/sindresorhus/globals) from 16.3.0 to 16.4.0. - [Release notes](https://github.com/sindresorhus/globals/releases) - [Commits](https://github.com/sindresorhus/globals/compare/v16.3.0...v16.4.0) --- updated-dependencies: - dependency-name: globals dependency-version: 16.4.0 dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- package-lock.json | 14 +++++++------- package.json | 2 +- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/package-lock.json b/package-lock.json index 4a6501ffd5bb9..ac7875f351e73 100644 --- a/package-lock.json +++ b/package-lock.json @@ -29,7 +29,7 @@ "eslint": "^9.35.0", "eslint-config-prettier": "^10.1.8", "eslint-plugin-jsdoc": "^55.0.0", - "globals": "^16.3.0", + "globals": "^16.4.0", "hjson": "^3.2.2", "husky": "^9.1.7", "jest": "^29.7.0", @@ -3706,9 +3706,9 @@ } }, "node_modules/globals": { - "version": "16.3.0", - "resolved": "https://registry.npmjs.org/globals/-/globals-16.3.0.tgz", - "integrity": "sha512-bqWEnJ1Nt3neqx2q5SFfGS8r/ahumIakg3HcwtNlrVlwXIeNumWn/c7Pn/wKzGhf6SaW6H6uWXLqC30STCMchQ==", + "version": "16.4.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-16.4.0.tgz", + "integrity": "sha512-ob/2LcVVaVGCYN+r14cnwnoDPUufjiYgSqRhiFD0Q1iI4Odora5RE8Iv1D24hAz5oMophRGkGz+yuvQmmUMnMw==", "dev": true, "engines": { "node": ">=18" @@ -9913,9 +9913,9 @@ } }, "globals": { - "version": "16.3.0", - "resolved": "https://registry.npmjs.org/globals/-/globals-16.3.0.tgz", - "integrity": "sha512-bqWEnJ1Nt3neqx2q5SFfGS8r/ahumIakg3HcwtNlrVlwXIeNumWn/c7Pn/wKzGhf6SaW6H6uWXLqC30STCMchQ==", + "version": "16.4.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-16.4.0.tgz", + "integrity": "sha512-ob/2LcVVaVGCYN+r14cnwnoDPUufjiYgSqRhiFD0Q1iI4Odora5RE8Iv1D24hAz5oMophRGkGz+yuvQmmUMnMw==", "dev": true }, "gopd": { diff --git a/package.json b/package.json index 11684546702a4..f594a1f86319a 100644 --- a/package.json +++ b/package.json @@ -48,7 +48,7 @@ "eslint": "^9.35.0", "eslint-config-prettier": "^10.1.8", "eslint-plugin-jsdoc": "^55.0.0", - "globals": "^16.3.0", + "globals": "^16.4.0", "hjson": "^3.2.2", "husky": "^9.1.7", "jest": "^29.7.0", From b13d6a9ca2a819c31853b537b2e904ab1cf81848 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Wed, 10 Sep 2025 21:41:50 +0300 Subject: [PATCH 060/265] build(deps-dev): bump eslint-plugin-jsdoc from 55.0.0 to 55.2.0 (#4419) * build(deps-dev): bump eslint-plugin-jsdoc from 55.0.0 to 55.2.0 Bumps [eslint-plugin-jsdoc](https://github.com/gajus/eslint-plugin-jsdoc) from 55.0.0 to 55.2.0. - [Release notes](https://github.com/gajus/eslint-plugin-jsdoc/releases) - [Changelog](https://github.com/gajus/eslint-plugin-jsdoc/blob/main/.releaserc) - [Commits](https://github.com/gajus/eslint-plugin-jsdoc/compare/v55.0.0...v55.2.0) --- updated-dependencies: - dependency-name: eslint-plugin-jsdoc dependency-version: 55.2.0 dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] * dev --------- Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- package-lock.json | 58 +++++++++++++++++++++++------------------------ package.json | 2 +- 2 files changed, 30 insertions(+), 30 deletions(-) diff --git a/package-lock.json b/package-lock.json index ac7875f351e73..98e2114abe02a 100644 --- a/package-lock.json +++ b/package-lock.json @@ -28,7 +28,7 @@ "color-contrast-checker": "^2.1.0", "eslint": "^9.35.0", "eslint-config-prettier": "^10.1.8", - "eslint-plugin-jsdoc": "^55.0.0", + "eslint-plugin-jsdoc": "^55.2.0", "globals": "^16.4.0", "hjson": "^3.2.2", "husky": "^9.1.7", @@ -751,16 +751,16 @@ } }, "node_modules/@es-joy/jsdoccomment": { - "version": "0.56.0", - "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.56.0.tgz", - "integrity": "sha512-c6EW+aA1w2rjqOMjbL93nZlwxp6c1Ln06vTYs5FjRRhmJXK8V/OrSXdT+pUr4aRYgjCgu8/OkiZr0tzeVrRSbw==", + "version": "0.57.0", + "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.57.0.tgz", + "integrity": "sha512-M4isJXgy+ZLXvt9EFLHuG5+6Q8hl1iSn3ZnO5R+DiPLUBvsTOh93fZ9X/X1z3l6/pmq3STZtqrEAi6SaPzB4AQ==", "dev": true, "dependencies": { "@types/estree": "^1.0.8", "@typescript-eslint/types": "^8.42.0", "comment-parser": "1.4.1", "esquery": "^1.6.0", - "jsdoc-type-pratt-parser": "~5.1.0" + "jsdoc-type-pratt-parser": "~5.2.0" }, "engines": { "node": ">=20.11.0" @@ -2076,9 +2076,9 @@ "dev": true }, "node_modules/@typescript-eslint/types": { - "version": "8.42.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.42.0.tgz", - "integrity": "sha512-LdtAWMiFmbRLNP7JNeY0SqEtJvGMYSzfiWBSmx+VSZ1CH+1zyl8Mmw1TT39OrtsRvIYShjJWzTDMPWZJCpwBlw==", + "version": "8.43.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.43.0.tgz", + "integrity": "sha512-vQ2FZaxJpydjSZJKiSW/LJsabFFvV7KgLC5DiLhkBcykhQj8iK9BOaDmQt74nnKdLvceM5xmhaTF+pLekrxEkw==", "dev": true, "engines": { "node": "^18.18.0 || ^20.9.0 || >=21.1.0" @@ -3095,12 +3095,12 @@ } }, "node_modules/eslint-plugin-jsdoc": { - "version": "55.0.0", - "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-55.0.0.tgz", - "integrity": "sha512-45ljWx7dw0kA+zT/gYxhUUeMXUFZdn3yTxkOKvekYmhfYQF2kUx+2THnK1oeHFqdnJWkyi3ZSeLt4FKWMLKXTA==", + "version": "55.3.0", + "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-55.3.0.tgz", + "integrity": "sha512-oo8ByBStn+VO/mPRTkNOCORoJxCegmevFV6v70xf+7+KgCFCyP9ay67l/2420OU0zZUMWfq61BTIaXi+DjVVWQ==", "dev": true, "dependencies": { - "@es-joy/jsdoccomment": "~0.56.0", + "@es-joy/jsdoccomment": "~0.57.0", "are-docs-informative": "^0.0.2", "comment-parser": "1.4.1", "debug": "^4.4.1", @@ -5269,9 +5269,9 @@ } }, "node_modules/jsdoc-type-pratt-parser": { - "version": "5.1.1", - "resolved": "https://registry.npmjs.org/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-5.1.1.tgz", - "integrity": "sha512-DYYlVP1fe4QBMh2xTIs20/YeTz2GYVbWAEZweHSZD+qQ/Cx2d5RShuhhsdk64eTjNq0FeVnteP/qVOgaywSRbg==", + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-5.2.0.tgz", + "integrity": "sha512-qJmErzgL4DLj4lyRkDWnEXZRNu3X3CJxVKKhuUPwqPFMiJV6K7/6O//D2Uf+rRi6+qTPgHWxDAgfGllEXoGkMA==", "dev": true, "engines": { "node": ">=12.0.0" @@ -7726,16 +7726,16 @@ "dev": true }, "@es-joy/jsdoccomment": { - "version": "0.56.0", - "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.56.0.tgz", - "integrity": "sha512-c6EW+aA1w2rjqOMjbL93nZlwxp6c1Ln06vTYs5FjRRhmJXK8V/OrSXdT+pUr4aRYgjCgu8/OkiZr0tzeVrRSbw==", + "version": "0.57.0", + "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.57.0.tgz", + "integrity": "sha512-M4isJXgy+ZLXvt9EFLHuG5+6Q8hl1iSn3ZnO5R+DiPLUBvsTOh93fZ9X/X1z3l6/pmq3STZtqrEAi6SaPzB4AQ==", "dev": true, "requires": { "@types/estree": "^1.0.8", "@typescript-eslint/types": "^8.42.0", "comment-parser": "1.4.1", "esquery": "^1.6.0", - "jsdoc-type-pratt-parser": "~5.1.0" + "jsdoc-type-pratt-parser": "~5.2.0" } }, "@eslint-community/eslint-utils": { @@ -8774,9 +8774,9 @@ "dev": true }, "@typescript-eslint/types": { - "version": "8.42.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.42.0.tgz", - "integrity": "sha512-LdtAWMiFmbRLNP7JNeY0SqEtJvGMYSzfiWBSmx+VSZ1CH+1zyl8Mmw1TT39OrtsRvIYShjJWzTDMPWZJCpwBlw==", + "version": "8.43.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.43.0.tgz", + "integrity": "sha512-vQ2FZaxJpydjSZJKiSW/LJsabFFvV7KgLC5DiLhkBcykhQj8iK9BOaDmQt74nnKdLvceM5xmhaTF+pLekrxEkw==", "dev": true }, "@uppercod/css-to-object": { @@ -9577,12 +9577,12 @@ "requires": {} }, "eslint-plugin-jsdoc": { - "version": "55.0.0", - "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-55.0.0.tgz", - "integrity": "sha512-45ljWx7dw0kA+zT/gYxhUUeMXUFZdn3yTxkOKvekYmhfYQF2kUx+2THnK1oeHFqdnJWkyi3ZSeLt4FKWMLKXTA==", + "version": "55.3.0", + "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-55.3.0.tgz", + "integrity": "sha512-oo8ByBStn+VO/mPRTkNOCORoJxCegmevFV6v70xf+7+KgCFCyP9ay67l/2420OU0zZUMWfq61BTIaXi+DjVVWQ==", "dev": true, "requires": { - "@es-joy/jsdoccomment": "~0.56.0", + "@es-joy/jsdoccomment": "~0.57.0", "are-docs-informative": "^0.0.2", "comment-parser": "1.4.1", "debug": "^4.4.1", @@ -11072,9 +11072,9 @@ } }, "jsdoc-type-pratt-parser": { - "version": "5.1.1", - "resolved": "https://registry.npmjs.org/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-5.1.1.tgz", - "integrity": "sha512-DYYlVP1fe4QBMh2xTIs20/YeTz2GYVbWAEZweHSZD+qQ/Cx2d5RShuhhsdk64eTjNq0FeVnteP/qVOgaywSRbg==", + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-5.2.0.tgz", + "integrity": "sha512-qJmErzgL4DLj4lyRkDWnEXZRNu3X3CJxVKKhuUPwqPFMiJV6K7/6O//D2Uf+rRi6+qTPgHWxDAgfGllEXoGkMA==", "dev": true }, "jsdom": { diff --git a/package.json b/package.json index f594a1f86319a..8340acb785401 100644 --- a/package.json +++ b/package.json @@ -47,7 +47,7 @@ "color-contrast-checker": "^2.1.0", "eslint": "^9.35.0", "eslint-config-prettier": "^10.1.8", - "eslint-plugin-jsdoc": "^55.0.0", + "eslint-plugin-jsdoc": "^55.2.0", "globals": "^16.4.0", "hjson": "^3.2.2", "husky": "^9.1.7", From 70add4cfcfe5ea87572105835adba23e5d4ad59a Mon Sep 17 00:00:00 2001 From: Yunxiao Crrashh <1542@crrashh.com> Date: Tue, 16 Sep 2025 01:12:33 +0800 Subject: [PATCH 061/265] fix: update Simplified Chinese translations (#3766) * chore(translations): Update translation for cn Signed-off-by: crrashh1542 * update tests * prettier --------- Signed-off-by: crrashh1542 Co-authored-by: Alexandr --- src/translations.js | 16 ++++++++-------- tests/renderStatsCard.test.js | 12 +++++------- 2 files changed, 13 insertions(+), 15 deletions(-) diff --git a/src/translations.js b/src/translations.js index 28403441febba..e0946c6024250 100644 --- a/src/translations.js +++ b/src/translations.js @@ -82,7 +82,7 @@ const statCardLocales = ({ name, apostrophe }) => { "statcard.totalstars": { ar: "مجموع النجوم", az: "Ümumi Ulduz", - cn: "获标星数(star)", + cn: "获标星数", "zh-tw": "得標星星數量(Star)", cs: "Celkem hvězd", de: "Insgesamt erhaltene Sterne", @@ -114,7 +114,7 @@ const statCardLocales = ({ name, apostrophe }) => { "statcard.commits": { ar: "مجموع المساهمات", az: "Ümumi Commit", - cn: "累计提交数(commit)", + cn: "累计提交总数", "zh-tw": "累計提交數量(Commit)", cs: "Celkem commitů", de: "Anzahl Commits", @@ -146,7 +146,7 @@ const statCardLocales = ({ name, apostrophe }) => { "statcard.prs": { ar: "مجموع طلبات السحب", az: "Ümumi PR", - cn: "拉取请求数(PR)", + cn: "发起的 PR 总数", "zh-tw": "拉取請求數量(PR)", cs: "Celkem PRs", de: "PRs Insgesamt", @@ -178,7 +178,7 @@ const statCardLocales = ({ name, apostrophe }) => { "statcard.issues": { ar: "مجموع التحسينات", az: "Ümumi Problem", - cn: "指出问题数(issue)", + cn: "提出的 issue 总数", "zh-tw": "提出問題數量(Issue)", cs: "Celkem problémů", de: "Anzahl Issues", @@ -210,7 +210,7 @@ const statCardLocales = ({ name, apostrophe }) => { "statcard.contribs": { ar: "ساهم في (العام الماضي)", az: "Töhfə verdi (ötən il)", - cn: "贡献于(去年)", + cn: "贡献的项目数(去年)", "zh-tw": "參與項目數量(去年)", cs: "Přispěl k (minulý rok)", de: "Beigetragen zu (letztes Jahr)", @@ -242,7 +242,7 @@ const statCardLocales = ({ name, apostrophe }) => { "statcard.reviews": { ar: "طلبات السحب التي تم مراجعتها", az: "Nəzərdən Keçirilən Ümumi PR", - cn: "審查的 PR 總數", + cn: "审查的 PR 总数", "zh-tw": "審核的 PR 總計", cs: "Celkový počet PR", de: "Insgesamt überprüfte PRs", @@ -369,7 +369,7 @@ const statCardLocales = ({ name, apostrophe }) => { "statcard.prs-merged-percentage": { ar: "نسبة طلبات السحب المُدمجة", az: "Birləşdirilmiş PR-ların Faizi", - cn: "合并的 PR 百分比", + cn: "被合并的 PR 占比", "zh-tw": "合併的 PR 百分比", cs: "Sloučené PRs v procentech", de: "Zusammengeführte PRs in Prozent", @@ -503,7 +503,7 @@ const langCardLocales = { "langcard.nodata": { ar: "لا توجد بيانات للغات.", az: "Dil məlumatı yoxdur.", - cn: "沒有語言數據。", + cn: "没有语言数据。", "zh-tw": "沒有語言資料。", cs: "Žádné jazykové údaje.", de: "Keine Sprachdaten.", diff --git a/tests/renderStatsCard.test.js b/tests/renderStatsCard.test.js index 12640fdbd8912..ebf0d251f55af 100644 --- a/tests/renderStatsCard.test.js +++ b/tests/renderStatsCard.test.js @@ -382,29 +382,27 @@ describe("Test renderStatsCard", () => { document.querySelector( 'g[transform="translate(0, 0)"]>.stagger>.stat.bold', ).textContent, - ).toMatchInlineSnapshot(`"获标星数(star):"`); + ).toMatchInlineSnapshot(`"获标星数:"`); expect( document.querySelector( 'g[transform="translate(0, 25)"]>.stagger>.stat.bold', ).textContent, - ).toMatchInlineSnapshot( - `"累计提交数(commit) (${new Date().getFullYear()}):"`, - ); + ).toMatchInlineSnapshot(`"累计提交总数 (${new Date().getFullYear()}):"`); expect( document.querySelector( 'g[transform="translate(0, 50)"]>.stagger>.stat.bold', ).textContent, - ).toMatchInlineSnapshot(`"拉取请求数(PR):"`); + ).toMatchInlineSnapshot(`"发起的 PR 总数:"`); expect( document.querySelector( 'g[transform="translate(0, 75)"]>.stagger>.stat.bold', ).textContent, - ).toMatchInlineSnapshot(`"指出问题数(issue):"`); + ).toMatchInlineSnapshot(`"提出的 issue 总数:"`); expect( document.querySelector( 'g[transform="translate(0, 100)"]>.stagger>.stat.bold', ).textContent, - ).toMatchInlineSnapshot(`"贡献于(去年):"`); + ).toMatchInlineSnapshot(`"贡献的项目数(去年):"`); }); it("should render without rounding", () => { From 3987991058b0988e548b7b32f4dfb00a3320a892 Mon Sep 17 00:00:00 2001 From: Kyle Upton <44348980+kyleaupton@users.noreply.github.com> Date: Mon, 15 Sep 2025 16:13:42 -0400 Subject: [PATCH 062/265] feat: implement whitelist for self-hosted instances (#3939) * whitelist for username based endpoints * added gist whitelist * review * fix --------- Co-authored-by: Alexandr --- api/gist.js | 18 ++++++++++++++++++ api/index.js | 39 +++++++++++++++++++++++++++++++-------- api/pin.js | 39 +++++++++++++++++++++++++++++++-------- api/top-langs.js | 39 +++++++++++++++++++++++++++++++-------- api/wakatime.js | 18 ++++++++++++++++++ readme.md | 10 ++++++---- src/common/utils.js | 9 ++++++++- src/common/whitelist.js | 10 ++++++++++ tests/api.test.js | 6 +++++- tests/pin.test.js | 6 +++++- tests/top-langs.test.js | 6 +++++- 11 files changed, 168 insertions(+), 32 deletions(-) create mode 100644 src/common/whitelist.js diff --git a/api/gist.js b/api/gist.js index 006977613a2b4..c309c8cfde14b 100644 --- a/api/gist.js +++ b/api/gist.js @@ -4,6 +4,7 @@ import { renderError, parseBoolean, } from "../src/common/utils.js"; +import { gistWhitelist } from "../src/common/whitelist.js"; import { isLocaleAvailable } from "../src/translations.js"; import { renderGistCard } from "../src/cards/gist.js"; import { fetchGist } from "../src/fetchers/gist.js"; @@ -26,6 +27,23 @@ export default async (req, res) => { res.setHeader("Content-Type", "image/svg+xml"); + if (gistWhitelist && !gistWhitelist.includes(id)) { + return res.send( + renderError( + "This gist ID is not whitelisted", + "Please deploy your own instance", + { + title_color, + text_color, + bg_color, + border_color, + theme, + show_repo_link: false, + }, + ), + ); + } + if (locale && !isLocaleAvailable(locale)) { return res.send( renderError("Something went wrong", "Language not found", { diff --git a/api/index.js b/api/index.js index ef41fa139755f..b5705fbc62b8c 100644 --- a/api/index.js +++ b/api/index.js @@ -1,5 +1,6 @@ import { renderStatsCard } from "../src/cards/stats.js"; import { blacklist } from "../src/common/blacklist.js"; +import { whitelist } from "../src/common/whitelist.js"; import { clampValue, CONSTANTS, @@ -41,15 +42,37 @@ export default async (req, res) => { } = req.query; res.setHeader("Content-Type", "image/svg+xml"); - if (blacklist.includes(username)) { + if (whitelist && !whitelist.includes(username)) { return res.send( - renderError("Something went wrong", "This username is blacklisted", { - title_color, - text_color, - bg_color, - border_color, - theme, - }), + renderError( + "This username is not whitelisted", + "Please deploy your own instance", + { + title_color, + text_color, + bg_color, + border_color, + theme, + show_repo_link: false, + }, + ), + ); + } + + if (whitelist === undefined && blacklist.includes(username)) { + return res.send( + renderError( + "This username is blacklisted", + "Please deploy your own instance", + { + title_color, + text_color, + bg_color, + border_color, + theme, + show_repo_link: false, + }, + ), ); } diff --git a/api/pin.js b/api/pin.js index b8fa617ba7860..eec584d9433e9 100644 --- a/api/pin.js +++ b/api/pin.js @@ -1,5 +1,6 @@ import { renderRepoCard } from "../src/cards/repo.js"; import { blacklist } from "../src/common/blacklist.js"; +import { whitelist } from "../src/common/whitelist.js"; import { clampValue, CONSTANTS, @@ -29,15 +30,37 @@ export default async (req, res) => { res.setHeader("Content-Type", "image/svg+xml"); - if (blacklist.includes(username)) { + if (whitelist && !whitelist.includes(username)) { return res.send( - renderError("Something went wrong", "This username is blacklisted", { - title_color, - text_color, - bg_color, - border_color, - theme, - }), + renderError( + "This username is not whitelisted", + "Please deploy your own instance", + { + title_color, + text_color, + bg_color, + border_color, + theme, + show_repo_link: false, + }, + ), + ); + } + + if (whitelist === undefined && blacklist.includes(username)) { + return res.send( + renderError( + "This username is blacklisted", + "Please deploy your own instance", + { + title_color, + text_color, + bg_color, + border_color, + theme, + show_repo_link: false, + }, + ), ); } diff --git a/api/top-langs.js b/api/top-langs.js index 1c7ed68157456..d63463de0a548 100644 --- a/api/top-langs.js +++ b/api/top-langs.js @@ -1,5 +1,6 @@ import { renderTopLanguages } from "../src/cards/top-languages.js"; import { blacklist } from "../src/common/blacklist.js"; +import { whitelist } from "../src/common/whitelist.js"; import { clampValue, CONSTANTS, @@ -36,15 +37,37 @@ export default async (req, res) => { } = req.query; res.setHeader("Content-Type", "image/svg+xml"); - if (blacklist.includes(username)) { + if (whitelist && !whitelist.includes(username)) { return res.send( - renderError("Something went wrong", "This username is blacklisted", { - title_color, - text_color, - bg_color, - border_color, - theme, - }), + renderError( + "This username is not whitelisted", + "Please deploy your own instance", + { + title_color, + text_color, + bg_color, + border_color, + theme, + show_repo_link: false, + }, + ), + ); + } + + if (whitelist === undefined && blacklist.includes(username)) { + return res.send( + renderError( + "This username is blacklisted", + "Please deploy your own instance", + { + title_color, + text_color, + bg_color, + border_color, + theme, + show_repo_link: false, + }, + ), ); } diff --git a/api/wakatime.js b/api/wakatime.js index 1517cc496011f..69f0ce7d10e8c 100644 --- a/api/wakatime.js +++ b/api/wakatime.js @@ -6,6 +6,7 @@ import { parseBoolean, renderError, } from "../src/common/utils.js"; +import { whitelist } from "../src/common/whitelist.js"; import { fetchWakatimeStats } from "../src/fetchers/wakatime.js"; import { isLocaleAvailable } from "../src/translations.js"; @@ -36,6 +37,23 @@ export default async (req, res) => { res.setHeader("Content-Type", "image/svg+xml"); + if (whitelist && !whitelist.includes(username)) { + return res.send( + renderError( + "This username is not whitelisted", + "Please deploy your own instance", + { + title_color, + text_color, + bg_color, + border_color, + theme, + show_repo_link: false, + }, + ), + ); + } + if (locale && !isLocaleAvailable(locale)) { return res.send( renderError("Something went wrong", "Language not found", { diff --git a/readme.md b/readme.md index f8704486ebd71..00752dbbc39e7 100644 --- a/readme.md +++ b/readme.md @@ -86,7 +86,7 @@ - [On Vercel](#on-vercel) - [:film\_projector: Check Out Step By Step Video Tutorial By @codeSTACKr](#film_projector-check-out-step-by-step-video-tutorial-by-codestackr) - [On other platforms](#on-other-platforms) - - [Disable rate limit protections](#disable-rate-limit-protections) + - [Available environment variables](#available-environment-variables) - [Keep your fork up to date](#keep-your-fork-up-to-date) - [:sparkling\_heart: Support the project](#sparkling_heart-support-the-project)
@@ -797,11 +797,13 @@ Since the GitHub API only allows 5k requests per hour, my `https://github-readme 5. You're done 🎉
-## Disable rate limit protections +## Available environment variables -GitHub Readme Stats contains several Vercel environment variables that can be used to remove the rate limit protections: +GitHub Readme Stats provides several environment variables that can be used to customize the behavior of your self-hosted instance. These include: -* `CACHE_SECONDS`: This environment variable takes precedence over our cache minimum and maximum values and can circumvent these values for self-hosted Vercel instances. +* `CACHE_SECONDS`: This takes precedence over our cache minimum and maximum values and can circumvent these values for self-hosted instances. +* `WHITELIST`: A comma-separated list of GitHub usernames that are allowed to access your instance. If this variable is not set, all usernames are allowed. +* `GIST_WHITELIST`: A comma-separated list of GitHub gist IDs that are allowed to be accessed on your instance. If this variable is not set, all gist IDs are allowed. See [the Vercel documentation](https://vercel.com/docs/concepts/projects/environment-variables) on adding these environment variables to your Vercel instance. diff --git a/src/common/utils.js b/src/common/utils.js index 68adafdf4a28c..b12a9147a7fbd 100644 --- a/src/common/utils.js +++ b/src/common/utils.js @@ -355,6 +355,12 @@ const UPSTREAM_API_ERRORS = [ * @param {string} message Main error message. * @param {string} secondaryMessage The secondary error message. * @param {object} options Function options. + * @param {string=} options.title_color Card title color. + * @param {string=} options.text_color Card text color. + * @param {string=} options.bg_color Card background color. + * @param {string=} options.border_color Card border color. + * @param {string=} options.theme Card theme. + * @param {boolean=} options.show_repo_link Whether to show repo link or not. * @returns {string} The SVG markup. */ const renderError = (message, secondaryMessage = "", options = {}) => { @@ -364,6 +370,7 @@ const renderError = (message, secondaryMessage = "", options = {}) => { bg_color, border_color, theme = "default", + show_repo_link = true, } = options; // returns theme based colors with proper overrides and defaults @@ -388,7 +395,7 @@ const renderError = (message, secondaryMessage = "", options = {}) => { ERROR_CARD_LENGTH - 1 }" height="99%" rx="4.5" fill="${bgColor}" stroke="${borderColor}"/> Something went wrong!${ - UPSTREAM_API_ERRORS.includes(secondaryMessage) + UPSTREAM_API_ERRORS.includes(secondaryMessage) || !show_repo_link ? "" : " file an issue at https://tiny.one/readme-stats" } diff --git a/src/common/whitelist.js b/src/common/whitelist.js new file mode 100644 index 0000000000000..b5df7c70cacc8 --- /dev/null +++ b/src/common/whitelist.js @@ -0,0 +1,10 @@ +const whitelist = process.env.WHITELIST + ? process.env.WHITELIST.split(",") + : undefined; + +const gistWhitelist = process.env.GIST_WHITELIST + ? process.env.GIST_WHITELIST.split(",") + : undefined; + +export { whitelist, gistWhitelist }; +export default whitelist; diff --git a/tests/api.test.js b/tests/api.test.js index 1b576b19b24d4..697c690ec39fe 100644 --- a/tests/api.test.js +++ b/tests/api.test.js @@ -307,7 +307,11 @@ describe("Test /api/", () => { expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); expect(res.send).toBeCalledWith( - renderError("Something went wrong", "This username is blacklisted"), + renderError( + "This username is blacklisted", + "Please deploy your own instance", + { show_repo_link: false }, + ), ); }); diff --git a/tests/pin.test.js b/tests/pin.test.js index e9adcaa8d384b..15a93b21944dc 100644 --- a/tests/pin.test.js +++ b/tests/pin.test.js @@ -156,7 +156,11 @@ describe("Test /api/pin", () => { expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); expect(res.send).toBeCalledWith( - renderError("Something went wrong", "This username is blacklisted"), + renderError( + "This username is blacklisted", + "Please deploy your own instance", + { show_repo_link: false }, + ), ); }); diff --git a/tests/top-langs.test.js b/tests/top-langs.test.js index 62d4f7a0a71ef..c4b0fa9755623 100644 --- a/tests/top-langs.test.js +++ b/tests/top-langs.test.js @@ -184,7 +184,11 @@ describe("Test /api/top-langs", () => { expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); expect(res.send).toBeCalledWith( - renderError("Something went wrong", "This username is blacklisted"), + renderError( + "This username is blacklisted", + "Please deploy your own instance", + { show_repo_link: false }, + ), ); }); From 1b06e7117e3c42954e2699d85757f1796fb2cd6c Mon Sep 17 00:00:00 2001 From: Joni <146933644+Eyesore123@users.noreply.github.com> Date: Mon, 15 Sep 2025 23:25:10 +0300 Subject: [PATCH 063/265] feat: add Finnish translations (#4144) * Update translations.js Finnish added to 'src/translations.js' as a new translated language. * docs --------- Co-authored-by: Alexandr --- readme.md | 1 + src/translations.js | 22 ++++++++++++++++++++++ 2 files changed, 23 insertions(+) diff --git a/readme.md b/readme.md index 00752dbbc39e7..8176a05b6500a 100644 --- a/readme.md +++ b/readme.md @@ -299,6 +299,7 @@ Here is a list of all available locales: | `es` | Spanish | | `fr` | French | | `hu` | Hungarian | +| `fi` | Finnish | diff --git a/src/translations.js b/src/translations.js index e0946c6024250..8a869cb5a5c26 100644 --- a/src/translations.js +++ b/src/translations.js @@ -25,6 +25,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: `${encodedName}'${apostrophe} GitHub Stats`, bn: `${encodedName} এর GitHub পরিসংখ্যান`, es: `Estadísticas de GitHub de ${encodedName}`, + fi: `${encodedName}:n GitHub-tilastot`, fr: `Statistiques GitHub de ${encodedName}`, hu: `${encodedName} GitHub statisztika`, it: `Statistiche GitHub di ${encodedName}`, @@ -57,6 +58,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: `${encodedName}'${apostrophe} GitHub Rank`, bn: `${encodedName} এর GitHub পরিসংখ্যান`, es: `Estadísticas de GitHub de ${encodedName}`, + fi: `${encodedName}:n GitHub-sijoitus`, fr: `Statistiques GitHub de ${encodedName}`, hu: `${encodedName} GitHub statisztika`, it: `Statistiche GitHub di ${encodedName}`, @@ -89,6 +91,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: "Total Stars Earned", bn: "সর্বমোট Star", es: "Estrellas totales", + fi: "Ansaitut tähdet yhteensä", fr: "Total d'étoiles", hu: "Csillagok", it: "Stelle totali", @@ -121,6 +124,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: "Total Commits", bn: "সর্বমোট Commit", es: "Commits totales", + fi: "Yhteensä committeja", fr: "Total des Commits", hu: "Összes commit", it: "Commit totali", @@ -153,6 +157,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: "Total PRs", bn: "সর্বমোট PR", es: "PRs totales", + fi: "Yhteensä PR:t", fr: "Total des PRs", hu: "Összes PR", it: "PR totali", @@ -185,6 +190,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: "Total Issues", bn: "সর্বমোট Issue", es: "Issues totales", + fi: "Yhteensä ongelmat", fr: "Nombre total d'incidents", hu: "Összes hibajegy", it: "Segnalazioni totali", @@ -217,6 +223,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: "Contributed to (last year)", bn: "অবদান (গত বছর)", es: "Contribuciones en (el año pasado)", + fi: "Osallistunut (viime vuonna)", fr: "Contribué à (l'année dernière)", hu: "Hozzájárulások (tavaly)", it: "Ha contribuito a (l'anno scorso)", @@ -249,6 +256,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: "Total PRs Reviewed", bn: "সর্বমোট পুনরালোচনা করা PR", es: "PR totales revisados", + fi: "Yhteensä tarkastettuja PR:itä", fr: "Nombre total de PR examinés", hu: "Összes ellenőrzött PR", it: "PR totali esaminati", @@ -281,6 +289,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: "Total Discussions Started", bn: "সর্বমোট আলোচনা শুরু", es: "Discusiones totales iniciadas", + fi: "Aloitetut keskustelut yhteensä", fr: "Nombre total de discussions lancées", hu: "Összes megkezdett megbeszélés", it: "Discussioni totali avviate", @@ -313,6 +322,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: "Total Discussions Answered", bn: "সর্বমোট আলোচনা উত্তর", es: "Discusiones totales respondidas", + fi: "Vastatut keskustelut yhteensä", fr: "Nombre total de discussions répondues", hu: "Összes megválaszolt megbeszélés", it: "Discussioni totali risposte", @@ -345,6 +355,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: "Total PRs Merged", bn: "সর্বমোট PR একত্রীকৃত", es: "PR totales fusionados", + fi: "Yhteensä yhdistetyt PR:t", fr: "Nombre total de PR fusionnés", hu: "Összes egyesített PR", it: "PR totali uniti", @@ -376,6 +387,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: "Merged PRs Percentage", bn: "PR একত্রীকরণের শতাংশ", es: "Porcentaje de PR fusionados", + fi: "Yhdistettyjen PR:ien prosentti", fr: "Pourcentage de PR fusionnés", hu: "Egyesített PR-k százaléka", it: "Percentuale di PR uniti", @@ -411,6 +423,7 @@ const repoCardLocales = { de: "Vorlage", en: "Template", es: "Plantilla", + fi: "Malli", fr: "Modèle", hu: "Sablon", it: "Template", @@ -443,6 +456,7 @@ const repoCardLocales = { de: "Archiviert", en: "Archived", es: "Archivados", + fi: "Arkistoitu", fr: "Archivé", hu: "Archivált", it: "Archiviata", @@ -478,6 +492,7 @@ const langCardLocales = { bn: "সর্বাধিক ব্যবহৃত ভাষা সমূহ", en: "Most Used Languages", es: "Lenguajes más usados", + fi: "Käytetyimmät kielet", fr: "Langages les plus utilisés", hu: "Leggyakrabban használt nyelvek", it: "Linguaggi più utilizzati", @@ -510,6 +525,7 @@ const langCardLocales = { bn: "কোন ভাষার ডেটা নেই।", en: "No languages data.", es: "Sin datos de idiomas.", + fi: "Ei kielitietoja.", fr: "Aucune donnée sur les langues.", hu: "Nincsenek nyelvi adatok.", it: "Nessun dato sulle lingue.", @@ -545,6 +561,7 @@ const wakatimeCardLocales = { en: "WakaTime Stats", bn: "WakaTime স্ট্যাটাস", es: "Estadísticas de WakaTime", + fi: "WakaTime-tilastot", fr: "Statistiques de WakaTime", hu: "WakaTime statisztika", it: "Statistiche WakaTime", @@ -577,6 +594,7 @@ const wakatimeCardLocales = { en: "last year", bn: "গত বছর", es: "El año pasado", + fi: "Viime vuosi", fr: "L'année dernière", hu: "Tavaly", it: "L'anno scorso", @@ -609,6 +627,7 @@ const wakatimeCardLocales = { en: "last 7 days", bn: "গত ৭ দিন", es: "Últimos 7 días", + fi: "Viimeiset 7 päivää", fr: "7 derniers jours", hu: "Elmúlt 7 nap", it: "Ultimi 7 giorni", @@ -641,6 +660,7 @@ const wakatimeCardLocales = { en: "WakaTime user profile not public", bn: "WakaTime ব্যবহারকারীর প্রোফাইল প্রকাশ্য নয়", es: "Perfil de usuario de WakaTime no público", + fi: "WakaTime-käyttäjäprofiili ei ole julkinen", fr: "Profil utilisateur WakaTime non public", hu: "A WakaTime felhasználói profilja nem nyilvános", it: "Profilo utente WakaTime non pubblico", @@ -673,6 +693,7 @@ const wakatimeCardLocales = { en: "User doesn't publicly share detailed code statistics", bn: "ব্যবহারকারী বিস্তারিত কোড পরিসংখ্যান প্রকাশ করেন না", es: "El usuario no comparte públicamente estadísticas detalladas de código", + fi: "Käyttäjä ei jaa julkisesti tarkkoja kooditilastoja", fr: "L'utilisateur ne partage pas publiquement de statistiques de code détaillées", hu: "A felhasználó nem osztja meg nyilvánosan a részletes kódstatisztikákat", it: "L'utente non condivide pubblicamente statistiche dettagliate sul codice", @@ -707,6 +728,7 @@ const wakatimeCardLocales = { en: "No coding activity this week", bn: "এই সপ্তাহে কোন কোডিং অ্যাক্টিভিটি নেই", es: "No hay actividad de codificación esta semana", + fi: "Ei koodaustoimintaa tällä viikolla", fr: "Aucune activité de codage cette semaine", hu: "Nem volt aktivitás ezen a héten", it: "Nessuna attività in questa settimana", From aa1caba1d4a0fb9d31e585123aacc42db5b85647 Mon Sep 17 00:00:00 2001 From: Algren Pauna Date: Mon, 15 Sep 2025 21:51:10 +0100 Subject: [PATCH 064/265] feat: add Romanian translations (#3970) * feat: add Romanian translation * Update src/translations.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update src/translations.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update src/translations.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update src/translations.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --------- Co-authored-by: Alexandr Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --- readme.md | 1 + src/translations.js | 22 ++++++++++++++++++++++ 2 files changed, 23 insertions(+) diff --git a/readme.md b/readme.md index 8176a05b6500a..cb137590af390 100644 --- a/readme.md +++ b/readme.md @@ -315,6 +315,7 @@ Here is a list of all available locales: | `el` | Greek | | `ru` | Russian | | `uk-ua` | Ukrainian | +| `ro` | Romanian | diff --git a/src/translations.js b/src/translations.js index 8a869cb5a5c26..a4761254b196b 100644 --- a/src/translations.js +++ b/src/translations.js @@ -36,6 +36,7 @@ const statCardLocales = ({ name, apostrophe }) => { "pt-br": `Estatísticas do GitHub de ${encodedName}`, np: `${encodedName}'${apostrophe} गिटहब तथ्याङ्क`, el: `Στατιστικά GitHub του ${encodedName}`, + ro: `Statisticile GitHub ale lui ${encodedName}`, ru: `Статистика GitHub пользователя ${encodedName}`, "uk-ua": `Статистика GitHub користувача ${encodedName}`, id: `Statistik GitHub ${encodedName}`, @@ -69,6 +70,7 @@ const statCardLocales = ({ name, apostrophe }) => { "pt-br": `Estatísticas do GitHub de ${encodedName}`, np: `${encodedName}'${apostrophe} गिटहब तथ्याङ्क`, el: `Στατιστικά GitHub του ${encodedName}`, + ro: `Rankul GitHub al lui ${encodedName}`, ru: `Рейтинг GitHub пользователя ${encodedName}`, "uk-ua": `Статистика GitHub користувача ${encodedName}`, id: `Statistik GitHub ${encodedName}`, @@ -102,6 +104,7 @@ const statCardLocales = ({ name, apostrophe }) => { "pt-br": "Total de estrelas", np: "कुल ताराहरू", el: "Σύνολο Αστεριών", + ro: "Total de stele câștigate", ru: "Всего звёзд", "uk-ua": "Всього зірок", id: "Total Bintang", @@ -135,6 +138,7 @@ const statCardLocales = ({ name, apostrophe }) => { "pt-br": "Total de Commits", np: "कुल Commits", el: "Σύνολο Commits", + ro: "Total Commit-uri", ru: "Всего коммитов", "uk-ua": "Всього комітів", id: "Total Komitmen", @@ -168,6 +172,7 @@ const statCardLocales = ({ name, apostrophe }) => { "pt-br": "Total de PRs", np: "कुल PRs", el: "Σύνολο PRs", + ro: "Total PR-uri", ru: "Всего запросов изменений", "uk-ua": "Всього pull request`iв", id: "Total Permintaan Tarik", @@ -201,6 +206,7 @@ const statCardLocales = ({ name, apostrophe }) => { "pt-br": "Total de Issues", np: "कुल मुद्दाहरू", el: "Σύνολο Ζητημάτων", + ro: "Total Issue-uri", ru: "Всего вопросов", "uk-ua": "Всього issue", id: "Total Masalah Dilaporkan", @@ -234,6 +240,7 @@ const statCardLocales = ({ name, apostrophe }) => { "pt-br": "Contribuiu para (ano passado)", np: "कुल योगदानहरू (गत वर्ष)", el: "Συνεισφέρθηκε σε (πέρυσι)", + ro: "Total Contribuiri", ru: "Внесено вклада (за прошлый год)", "uk-ua": "Зробив внесок у (за минулий рік)", id: "Berkontribusi ke (tahun lalu)", @@ -267,6 +274,7 @@ const statCardLocales = ({ name, apostrophe }) => { "pt-br": "Total de PRs revisados", np: "कुल पीआर समीक्षित", el: "Σύνολο Αναθεωρημένων PR", + ro: "Total PR-uri Revizuite", ru: "Всего запросов проверено", "uk-ua": "Всього pull request`iв перевірено", id: "Total PR yang Direview", @@ -300,6 +308,7 @@ const statCardLocales = ({ name, apostrophe }) => { "pt-br": "Total de Discussões Iniciadas", np: "कुल चर्चा सुरु", el: "Σύνολο Συζητήσεων που Ξεκίνησαν", + ro: "Total Discuții Începute", ru: "Всего начатых обсуждений", "uk-ua": "Всього розпочатих дискусій", id: "Total Diskusi Dimulai", @@ -333,6 +342,7 @@ const statCardLocales = ({ name, apostrophe }) => { "pt-br": "Total de Discussões Respondidas", np: "कुल चर्चा उत्तर", el: "Σύνολο Συζητήσεων που Απαντήθηκαν", + ro: "Total Răspunsuri La Discuții", ru: "Всего отвеченных обсуждений", "uk-ua": "Всього відповідей на дискусії", id: "Total Diskusi Dibalas", @@ -366,6 +376,7 @@ const statCardLocales = ({ name, apostrophe }) => { "pt-br": "Total de PRs Integrados", np: "कुल PRs मर्ज गरिएको", el: "Σύνολο Συγχωνευμένων PR", + ro: "Total PR-uri Fuzionate", ru: "Всего объединённых запросов", "uk-ua": "Всього об'єднаних pull request`iв", id: "Total PR Digabungkan", @@ -398,6 +409,7 @@ const statCardLocales = ({ name, apostrophe }) => { "pt-br": "Porcentagem de PRs Integrados", np: "PR मर्ज गरिएको प्रतिशत", el: "Ποσοστό Συγχωνευμένων PR", + ro: "Procentaj PR-uri Fuzionate", ru: "Процент объединённых запросов", "uk-ua": "Відсоток об'єднаних pull request`iв", id: "Persentase PR Digabungkan", @@ -434,6 +446,7 @@ const repoCardLocales = { "pt-br": "Modelo", np: "टेम्पलेट", el: "Πρότυπο", + ro: "Șablon", ru: "Шаблон", "uk-ua": "Шаблон", id: "Pola", @@ -467,6 +480,7 @@ const repoCardLocales = { "pt-br": "Arquivados", np: "अभिलेख राखियो", el: "Αρχειοθετημένα", + ro: "Arhivat", ru: "Архивирован", "uk-ua": "Архивований", id: "Arsip", @@ -503,6 +517,7 @@ const langCardLocales = { "pt-br": "Linguagens mais usadas", np: "अधिक प्रयोग गरिएको भाषाहरू", el: "Οι περισσότερο χρησιμοποιούμενες γλώσσες", + ro: "Cele Mai Folosite Limbaje", ru: "Наиболее используемые языки", "uk-ua": "Найчастіше використовувані мови", id: "Bahasa Yang Paling Banyak Digunakan", @@ -536,6 +551,7 @@ const langCardLocales = { "pt-br": "Sem dados de linguagens.", np: "कुनै भाषा डाटा छैन।", el: "Δεν υπάρχουν δεδομένα γλωσσών.", + ro: "Lipsesc date despre limbă.", ru: "Нет данных о языках.", "uk-ua": "Немає даних про мови.", id: "Tidak ada data bahasa.", @@ -572,6 +588,7 @@ const wakatimeCardLocales = { "pt-br": "Estatísticas WakaTime", np: "WakaTime तथ्या .्क", el: "Στατιστικά WakaTime", + ro: "Statistici WakaTime", ru: "Статистика WakaTime", "uk-ua": "Статистика WakaTime", id: "Status WakaTime", @@ -605,6 +622,7 @@ const wakatimeCardLocales = { "pt-br": "Ano passado", np: "गत वर्ष", el: "Πέρυσι", + ro: "Anul trecut", ru: "За прошлый год", "uk-ua": "За минулий рік", id: "Tahun lalu", @@ -638,6 +656,7 @@ const wakatimeCardLocales = { "pt-br": "Últimos 7 dias", np: "गत ७ दिन", el: "Τελευταίες 7 ημέρες", + ro: "Ultimele 7 zile", ru: "Последние 7 дней", "uk-ua": "Останні 7 днів", id: "7 hari terakhir", @@ -671,6 +690,7 @@ const wakatimeCardLocales = { "pt-br": "Perfil de usuário WakaTime não público", np: "WakaTime प्रयोगकर्ता प्रोफाइल सार्वजनिक छैन", el: "Το προφίλ χρήστη WakaTime δεν είναι δημόσιο", + ro: "Profilul utilizatorului de Wakatime nu este public", ru: "Профиль пользователя WakaTime не общедоступный", "uk-ua": "Профіль користувача WakaTime не є публічним", id: "Profil pengguna WakaTime tidak publik", @@ -706,6 +726,7 @@ const wakatimeCardLocales = { "O usuário não compartilha publicamente estatísticas detalhadas de código", np: "प्रयोगकर्ता सार्वजनिक रूपमा विस्तृत कोड तथ्याङ्क साझा गर्दैन", el: "Ο χρήστης δεν δημοσιεύει δημόσια λεπτομερείς στατιστικές κώδικα", + ro: "Utilizatorul nu își publică statisticile detaliate ale codului", ru: "Пользователь не делится подробной статистикой кода", "uk-ua": "Користувач не публікує детальну статистику коду", id: "Pengguna tidak membagikan statistik kode terperinci secara publik", @@ -739,6 +760,7 @@ const wakatimeCardLocales = { "pt-br": "Nenhuma atividade de codificação esta semana", np: "यस हप्ता कुनै कोडिंग गतिविधि छैन", el: "Δεν υπάρχει δραστηριότητα κώδικα γι' αυτή την εβδομάδα", + ro: "Nicio activitate de programare săptămâna aceasta", ru: "На этой неделе не было активности", "uk-ua": "На цьому тижні не було активності", id: "Tidak ada aktivitas perkodingan minggu ini", From 485c2247f85a6c6c463dcb198037a5a065fe1d76 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Mon, 15 Sep 2025 23:54:04 +0300 Subject: [PATCH 065/265] build(deps): bump axios from 1.11.0 to 1.12.1 (#4421) Bumps [axios](https://github.com/axios/axios) from 1.11.0 to 1.12.1. - [Release notes](https://github.com/axios/axios/releases) - [Changelog](https://github.com/axios/axios/blob/v1.x/CHANGELOG.md) - [Commits](https://github.com/axios/axios/compare/v1.11.0...v1.12.1) --- updated-dependencies: - dependency-name: axios dependency-version: 1.12.1 dependency-type: direct:production ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- package-lock.json | 14 +++++++------- package.json | 2 +- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/package-lock.json b/package-lock.json index 98e2114abe02a..81e07ee2b3e07 100644 --- a/package-lock.json +++ b/package-lock.json @@ -9,7 +9,7 @@ "version": "1.0.0", "license": "MIT", "dependencies": { - "axios": "^1.11.0", + "axios": "^1.12.1", "dotenv": "^17.2.2", "emoji-name-map": "^2.0.3", "github-username-regex": "^1.0.0", @@ -2223,9 +2223,9 @@ "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==" }, "node_modules/axios": { - "version": "1.11.0", - "resolved": "https://registry.npmjs.org/axios/-/axios-1.11.0.tgz", - "integrity": "sha512-1Lx3WLFQWm3ooKDYZD1eXmoGO9fxYQjrycfHFC8P0sCfQVXyROp0p9PFWBehewBOdCwHc+f/b8I0fMto5eSfwA==", + "version": "1.12.1", + "resolved": "https://registry.npmjs.org/axios/-/axios-1.12.1.tgz", + "integrity": "sha512-Kn4kbSXpkFHCGE6rBFNwIv0GQs4AvDT80jlveJDKFxjbTYMUeB4QtsdPCv6H8Cm19Je7IU6VFtRl2zWZI0rudQ==", "dependencies": { "follow-redirects": "^1.15.6", "form-data": "^4.0.4", @@ -8877,9 +8877,9 @@ "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==" }, "axios": { - "version": "1.11.0", - "resolved": "https://registry.npmjs.org/axios/-/axios-1.11.0.tgz", - "integrity": "sha512-1Lx3WLFQWm3ooKDYZD1eXmoGO9fxYQjrycfHFC8P0sCfQVXyROp0p9PFWBehewBOdCwHc+f/b8I0fMto5eSfwA==", + "version": "1.12.1", + "resolved": "https://registry.npmjs.org/axios/-/axios-1.12.1.tgz", + "integrity": "sha512-Kn4kbSXpkFHCGE6rBFNwIv0GQs4AvDT80jlveJDKFxjbTYMUeB4QtsdPCv6H8Cm19Je7IU6VFtRl2zWZI0rudQ==", "requires": { "follow-redirects": "^1.15.6", "form-data": "^4.0.4", diff --git a/package.json b/package.json index 8340acb785401..de16fdc2b6b7f 100644 --- a/package.json +++ b/package.json @@ -61,7 +61,7 @@ "prettier": "^3.6.2" }, "dependencies": { - "axios": "^1.11.0", + "axios": "^1.12.1", "dotenv": "^17.2.2", "emoji-name-map": "^2.0.3", "github-username-regex": "^1.0.0", From 078040d26e6cd79be3f09bf45f6983b63c1bb8e9 Mon Sep 17 00:00:00 2001 From: abap34 Date: Wed, 17 Sep 2025 03:41:46 +0900 Subject: [PATCH 066/265] feat: add bytes stats format option for top-languages card (#3708) * feat: add `display_bytes` option to top-languages. * docs: add description about display bytes in top-languages * feat: add `stats_format` option instead of `display_bytes` * docs: add description about stats format in top-languages * refactor: rewrite with function to determine display value * docs: add `stats_format`to table of parameter * fix: remove unnecessary decimal part from format of bytes * tests: add tests of stats_format in top-langs card * Update tests/renderTopLanguagesCard.test.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update readme.md Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * prettier * jsdoc --------- Co-authored-by: Alexandr Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --- api/top-langs.js | 12 +++ readme.md | 16 ++++ src/cards/top-languages.js | 116 ++++++++++++++++++++++----- src/cards/types.d.ts | 1 + src/common/utils.js | 28 +++++++ tests/renderTopLanguagesCard.test.js | 36 +++++++++ tests/utils.test.js | 15 ++++ 7 files changed, 203 insertions(+), 21 deletions(-) diff --git a/api/top-langs.js b/api/top-langs.js index d63463de0a548..10ecc5d9f997c 100644 --- a/api/top-langs.js +++ b/api/top-langs.js @@ -34,6 +34,7 @@ export default async (req, res) => { border_color, disable_animations, hide_progress, + stats_format, } = req.query; res.setHeader("Content-Type", "image/svg+xml"); @@ -85,6 +86,16 @@ export default async (req, res) => { ); } + if ( + stats_format !== undefined && + (typeof stats_format !== "string" || + !["bytes", "percentages"].includes(stats_format)) + ) { + return res.send( + renderError("Something went wrong", "Incorrect stats_format input"), + ); + } + try { const topLangs = await fetchTopLanguages( username, @@ -125,6 +136,7 @@ export default async (req, res) => { locale: locale ? locale.toLowerCase() : null, disable_animations: parseBoolean(disable_animations), hide_progress: parseBoolean(hide_progress), + stats_format, }), ); } catch (err) { diff --git a/readme.md b/readme.md index cb137590af390..a6df0d080ef84 100644 --- a/readme.md +++ b/readme.md @@ -74,6 +74,7 @@ - [Donut Vertical Chart Language Card Layout](#donut-vertical-chart-language-card-layout) - [Pie Chart Language Card Layout](#pie-chart-language-card-layout) - [Hide Progress Bars](#hide-progress-bars) + - [Change format of language's stats](#change-format-of-languages-stats) - [Demo](#demo-2) - [WakaTime Stats Card](#wakatime-stats-card) - [Options](#options-3) @@ -468,6 +469,7 @@ You can customize the appearance and behavior of the top languages card using th | `hide_progress` | Uses the compact layout option, hides percentages, and removes the bars. | boolean | `false` | | `size_weight` | Configures language stats algorithm (see [Language stats algorithm](#language-stats-algorithm)). | integer | `1` | | `count_weight` | Configures language stats algorithm (see [Language stats algorithm](#language-stats-algorithm)). | integer | `0` | +| `stats_format` | Switches between two available formats for language's stats `percentages` and `bytes`. | enum | `percentages` | > [!WARNING]\ > Language names should be URI-escaped, as specified in [Percent Encoding](https://en.wikipedia.org/wiki/Percent-encoding) @@ -556,6 +558,15 @@ You can use the `&hide_progress=true` option to hide the percentages and the pro ![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&hide_progress=true) ``` +### Change format of language's stats + +You can use the `&stats_format=bytes` option to display the stats in bytes instead of percentage. + +```md +![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra&stats_format=bytes) +``` + + ### Demo ![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra) @@ -580,6 +591,11 @@ You can use the `&hide_progress=true` option to hide the percentages and the pro ![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra\&hide_progress=true) + +* Display bytes instead of percentage + +![Top Langs](https://github-readme-stats.vercel.app/api/top-langs/?username=anuraghazra\&stats_format=bytes) + # WakaTime Stats Card > [!WARNING]\ diff --git a/src/cards/top-languages.js b/src/cards/top-languages.js index 9385f4a7ebed3..fec72c7c391c8 100644 --- a/src/cards/top-languages.js +++ b/src/cards/top-languages.js @@ -9,6 +9,7 @@ import { getCardColors, lowercaseTrim, measureText, + formatBytes, } from "../common/utils.js"; import { langCardLocales } from "../translations.js"; @@ -196,6 +197,18 @@ const trimTopLanguages = (topLangs, langs_count, hide) => { return { langs, totalLanguageSize }; }; +/** + * Get display value corresponding to the format. + * + * @param {number} size Bytes size. + * @param {number} percentages Percentage value. + * @param {string} format Format of the stats. + * @returns {string} Display value. + */ +const getDisplayValue = (size, percentages, format) => { + return format === "bytes" ? formatBytes(size) : `${percentages.toFixed(2)}%`; +}; + /** * Create progress bar text item for a programming language. * @@ -203,20 +216,33 @@ const trimTopLanguages = (topLangs, langs_count, hide) => { * @param {number} props.width The card width * @param {string} props.color Color of the programming language. * @param {string} props.name Name of the programming language. - * @param {number} props.progress Usage of the programming language in percentage. + * @param {number} props.size Size of the programming language. + * @param {number} props.totalSize Total size of all languages. + * @param {string} props.statsFormat Stats format. * @param {number} props.index Index of the programming language. * @returns {string} Programming language SVG node. */ -const createProgressTextNode = ({ width, color, name, progress, index }) => { +const createProgressTextNode = ({ + width, + color, + name, + size, + totalSize, + statsFormat, + index, +}) => { const staggerDelay = (index + 3) * 150; const paddingRight = 95; const progressTextX = width - paddingRight + 10; const progressWidth = width - paddingRight; + const progress = (size / totalSize) * 100; + const displayValue = getDisplayValue(size, progress, statsFormat); + return ` ${name} - ${progress}% + ${displayValue} ${createProgressNode({ x: 0, y: 25, @@ -237,11 +263,20 @@ const createProgressTextNode = ({ width, color, name, progress, index }) => { * @param {Lang} props.lang Programming language object. * @param {number} props.totalSize Total size of all languages. * @param {boolean=} props.hideProgress Whether to hide percentage. + * @param {string=} props.statsFormat Stats format * @param {number} props.index Index of the programming language. * @returns {string} Compact layout programming language SVG node. */ -const createCompactLangNode = ({ lang, totalSize, hideProgress, index }) => { - const percentage = ((lang.size / totalSize) * 100).toFixed(2); +const createCompactLangNode = ({ + lang, + totalSize, + hideProgress, + statsFormat = "percentages", + index, +}) => { + const percentages = (lang.size / totalSize) * 100; + const displayValue = getDisplayValue(lang.size, percentages, statsFormat); + const staggerDelay = (index + 3) * 150; const color = lang.color || "#858585"; @@ -249,7 +284,7 @@ const createCompactLangNode = ({ lang, totalSize, hideProgress, index }) => { - ${lang.name} ${hideProgress ? "" : percentage + "%"} + ${lang.name} ${hideProgress ? "" : displayValue} `; @@ -262,9 +297,15 @@ const createCompactLangNode = ({ lang, totalSize, hideProgress, index }) => { * @param {Lang[]} props.langs Array of programming languages. * @param {number} props.totalSize Total size of all languages. * @param {boolean=} props.hideProgress Whether to hide percentage. + * @param {string=} props.statsFormat Stats format * @returns {string} Programming languages SVG node. */ -const createLanguageTextNode = ({ langs, totalSize, hideProgress }) => { +const createLanguageTextNode = ({ + langs, + totalSize, + hideProgress, + statsFormat, +}) => { const longestLang = getLongestLang(langs); const chunked = chunkArray(langs, langs.length / 2); const layouts = chunked.map((array) => { @@ -274,6 +315,7 @@ const createLanguageTextNode = ({ langs, totalSize, hideProgress }) => { lang, totalSize, hideProgress, + statsFormat, index, }), ); @@ -299,15 +341,17 @@ const createLanguageTextNode = ({ langs, totalSize, hideProgress }) => { * @param {object} props Function properties. * @param {Lang[]} props.langs Array of programming languages. * @param {number} props.totalSize Total size of all languages. + * @param {string} props.statsFormat Stats format * @returns {string} Donut layout programming language SVG node. */ -const createDonutLanguagesNode = ({ langs, totalSize }) => { +const createDonutLanguagesNode = ({ langs, totalSize, statsFormat }) => { return flexLayout({ items: langs.map((lang, index) => { return createCompactLangNode({ lang, totalSize, hideProgress: false, + statsFormat, index, }); }), @@ -322,18 +366,19 @@ const createDonutLanguagesNode = ({ langs, totalSize }) => { * @param {Lang[]} langs Array of programming languages. * @param {number} width Card width. * @param {number} totalLanguageSize Total size of all languages. + * @param {string} statsFormat Stats format. * @returns {string} Normal layout card SVG object. */ -const renderNormalLayout = (langs, width, totalLanguageSize) => { +const renderNormalLayout = (langs, width, totalLanguageSize, statsFormat) => { return flexLayout({ items: langs.map((lang, index) => { return createProgressTextNode({ width, name: lang.name, color: lang.color || DEFAULT_LANG_COLOR, - progress: parseFloat( - ((lang.size / totalLanguageSize) * 100).toFixed(2), - ), + size: lang.size, + totalSize: totalLanguageSize, + statsFormat, index, }); }), @@ -349,9 +394,16 @@ const renderNormalLayout = (langs, width, totalLanguageSize) => { * @param {number} width Card width. * @param {number} totalLanguageSize Total size of all languages. * @param {boolean=} hideProgress Whether to hide progress bar. + * @param {string} statsFormat Stats format. * @returns {string} Compact layout card SVG object. */ -const renderCompactLayout = (langs, width, totalLanguageSize, hideProgress) => { +const renderCompactLayout = ( + langs, + width, + totalLanguageSize, + hideProgress, + statsFormat = "percentages", +) => { const paddingRight = 50; const offsetWidth = width - paddingRight; // progressOffset holds the previous language's width and used to offset the next language @@ -397,6 +449,7 @@ const renderCompactLayout = (langs, width, totalLanguageSize, hideProgress) => { langs, totalSize: totalLanguageSize, hideProgress, + statsFormat, })} `; @@ -407,9 +460,10 @@ const renderCompactLayout = (langs, width, totalLanguageSize, hideProgress) => { * * @param {Lang[]} langs Array of programming languages. * @param {number} totalLanguageSize Total size of all languages. + * @param {string} statsFormat Stats format. * @returns {string} Compact layout card SVG object. */ -const renderDonutVerticalLayout = (langs, totalLanguageSize) => { +const renderDonutVerticalLayout = (langs, totalLanguageSize, statsFormat) => { // Donut vertical chart radius and total length const radius = 80; const totalCircleLength = getCircleLength(radius); @@ -465,6 +519,7 @@ const renderDonutVerticalLayout = (langs, totalLanguageSize) => { langs, totalSize: totalLanguageSize, hideProgress: false, + statsFormat, })} @@ -477,9 +532,10 @@ const renderDonutVerticalLayout = (langs, totalLanguageSize) => { * * @param {Lang[]} langs Array of programming languages. * @param {number} totalLanguageSize Total size of all languages. + * @param {string} statsFormat Stats format. * @returns {string} Compact layout card SVG object. */ -const renderPieLayout = (langs, totalLanguageSize) => { +const renderPieLayout = (langs, totalLanguageSize, statsFormat) => { // Pie chart radius and center coordinates const radius = 90; const centerX = 150; @@ -560,6 +616,7 @@ const renderPieLayout = (langs, totalLanguageSize) => { langs, totalSize: totalLanguageSize, hideProgress: false, + statsFormat, })} @@ -610,9 +667,10 @@ const createDonutPaths = (cx, cy, radius, percentages) => { * @param {Lang[]} langs Array of programming languages. * @param {number} width Card width. * @param {number} totalLanguageSize Total size of all languages. + * @param {string} statsFormat Stats format. * @returns {string} Donut layout card SVG object. */ -const renderDonutLayout = (langs, width, totalLanguageSize) => { +const renderDonutLayout = (langs, width, totalLanguageSize, statsFormat) => { const centerX = width / 3; const centerY = width / 3; const radius = centerX - 60; @@ -655,7 +713,7 @@ const renderDonutLayout = (langs, width, totalLanguageSize) => { return ` - ${createDonutLanguagesNode({ langs, totalSize: totalLanguageSize })} + ${createDonutLanguagesNode({ langs, totalSize: totalLanguageSize, statsFormat })} @@ -738,6 +796,7 @@ const renderTopLanguages = (topLangs, options = {}) => { border_radius, border_color, disable_animations, + stats_format = "percentages", } = options; const i18n = new I18n({ @@ -779,10 +838,14 @@ const renderTopLanguages = (topLangs, options = {}) => { }); } else if (layout === "pie") { height = calculatePieLayoutHeight(langs.length); - finalLayout = renderPieLayout(langs, totalLanguageSize); + finalLayout = renderPieLayout(langs, totalLanguageSize, stats_format); } else if (layout === "donut-vertical") { height = calculateDonutVerticalLayoutHeight(langs.length); - finalLayout = renderDonutVerticalLayout(langs, totalLanguageSize); + finalLayout = renderDonutVerticalLayout( + langs, + totalLanguageSize, + stats_format, + ); } else if (layout === "compact" || hide_progress == true) { height = calculateCompactLayoutHeight(langs.length) + (hide_progress ? -25 : 0); @@ -792,13 +855,24 @@ const renderTopLanguages = (topLangs, options = {}) => { width, totalLanguageSize, hide_progress, + stats_format, ); } else if (layout === "donut") { height = calculateDonutLayoutHeight(langs.length); width = width + 50; // padding - finalLayout = renderDonutLayout(langs, width, totalLanguageSize); + finalLayout = renderDonutLayout( + langs, + width, + totalLanguageSize, + stats_format, + ); } else { - finalLayout = renderNormalLayout(langs, width, totalLanguageSize); + finalLayout = renderNormalLayout( + langs, + width, + totalLanguageSize, + stats_format, + ); } const card = new Card({ diff --git a/src/cards/types.d.ts b/src/cards/types.d.ts index 9a21be4a0160a..08f80ef2c3a68 100644 --- a/src/cards/types.d.ts +++ b/src/cards/types.d.ts @@ -44,6 +44,7 @@ export type TopLangOptions = CommonOptions & { langs_count: number; disable_animations: boolean; hide_progress: boolean; + stats_format: "percentages" | "bytes"; }; export type WakaTimeOptions = CommonOptions & { diff --git a/src/common/utils.js b/src/common/utils.js index b12a9147a7fbd..04b02e2c8215f 100644 --- a/src/common/utils.js +++ b/src/common/utils.js @@ -598,6 +598,33 @@ const dateDiff = (d1, d2) => { return Math.round(diff / (1000 * 60)); }; +/** + * Convert bytes to a human-readable string representation. + * + * @param {number} bytes The number of bytes to convert. + * @returns {string} The human-readable representation of bytes. + * @throws {Error} If bytes is negative or too large. + */ +const formatBytes = (bytes) => { + if (bytes < 0) { + throw new Error("Bytes must be a non-negative number"); + } + + if (bytes === 0) { + return "0 B"; + } + + const sizes = ["B", "KB", "MB", "GB", "TB", "PB", "EB"]; + const base = 1024; + const i = Math.floor(Math.log(bytes) / Math.log(base)); + + if (i >= sizes.length) { + throw new Error("Bytes is too large to convert to a human-readable string"); + } + + return `${(bytes / Math.pow(base, i)).toFixed(1)} ${sizes[i]}`; +}; + export { ERROR_CARD_LENGTH, renderError, @@ -624,4 +651,5 @@ export { chunkArray, parseEmojis, dateDiff, + formatBytes, }; diff --git a/tests/renderTopLanguagesCard.test.js b/tests/renderTopLanguagesCard.test.js index 55965da066517..0a7aba617c9fb 100644 --- a/tests/renderTopLanguagesCard.test.js +++ b/tests/renderTopLanguagesCard.test.js @@ -849,4 +849,40 @@ describe("Test renderTopLanguages", () => { "No languages data.", ); }); + + it("should show proper stats format", () => { + document.body.innerHTML = renderTopLanguages(langs, { + layout: "compact", + stats_format: "percentages", + }); + + expect(queryAllByTestId(document.body, "lang-name")[0]).toHaveTextContent( + "HTML 40.00%", + ); + + expect(queryAllByTestId(document.body, "lang-name")[1]).toHaveTextContent( + "javascript 40.00%", + ); + + expect(queryAllByTestId(document.body, "lang-name")[2]).toHaveTextContent( + "css 20.00%", + ); + + document.body.innerHTML = renderTopLanguages(langs, { + layout: "compact", + stats_format: "bytes", + }); + + expect(queryAllByTestId(document.body, "lang-name")[0]).toHaveTextContent( + "HTML 200.0 B", + ); + + expect(queryAllByTestId(document.body, "lang-name")[1]).toHaveTextContent( + "javascript 200.0 B", + ); + + expect(queryAllByTestId(document.body, "lang-name")[2]).toHaveTextContent( + "css 100.0 B", + ); + }); }); diff --git a/tests/utils.test.js b/tests/utils.test.js index 5bd43955485c3..7277b95d4d2cb 100644 --- a/tests/utils.test.js +++ b/tests/utils.test.js @@ -7,6 +7,7 @@ import { parseBoolean, renderError, wrapTextMultiline, + formatBytes, } from "../src/common/utils.js"; import { expect, it, describe } from "@jest/globals"; @@ -134,6 +135,20 @@ describe("Test utils.js", () => { borderColor: "#fff", }); }); + + it("formatBytes: should return expected values", () => { + expect(formatBytes(0)).toBe("0 B"); + expect(formatBytes(100)).toBe("100.0 B"); + expect(formatBytes(1024)).toBe("1.0 KB"); + expect(formatBytes(1024 * 1024)).toBe("1.0 MB"); + expect(formatBytes(1024 * 1024 * 1024)).toBe("1.0 GB"); + expect(formatBytes(1024 * 1024 * 1024 * 1024)).toBe("1.0 TB"); + expect(formatBytes(1024 * 1024 * 1024 * 1024 * 1024)).toBe("1.0 PB"); + expect(formatBytes(1024 * 1024 * 1024 * 1024 * 1024 * 1024)).toBe("1.0 EB"); + + expect(formatBytes(1234 * 1024)).toBe("1.2 MB"); + expect(formatBytes(123.4 * 1024)).toBe("123.4 KB"); + }); }); describe("wrapTextMultiline", () => { From d210391e7d50977be6f322d56b79a5b2b94b6471 Mon Sep 17 00:00:00 2001 From: Marcus Otterstad Date: Tue, 16 Sep 2025 21:14:38 +0200 Subject: [PATCH 067/265] feat: add Norwegian translations (#3653) * Update readme.md * Update translations.js --------- Co-authored-by: Alexandr --- readme.md | 1 + src/translations.js | 22 ++++++++++++++++++++++ 2 files changed, 23 insertions(+) diff --git a/readme.md b/readme.md index a6df0d080ef84..c3f8a3c2b97a2 100644 --- a/readme.md +++ b/readme.md @@ -332,6 +332,7 @@ Here is a list of all available locales: | `vi` | Vietnamese | | `se` | Swedish | | `az` | Azerbaijani | +| `no` | Norwegian | diff --git a/src/translations.js b/src/translations.js index a4761254b196b..82bfeb8b079c2 100644 --- a/src/translations.js +++ b/src/translations.js @@ -48,6 +48,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: `${encodedName}ning GitHub'dagi statistikasi`, vi: `Thống Kê GitHub ${encodedName}`, se: `GitHubstatistik för ${encodedName}`, + no: `GitHub-statistikk for ${encodedName}`, }, "statcard.ranktitle": { ar: `${encodedName} إحصائيات جيت هاب`, @@ -82,6 +83,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: `${encodedName}ning GitHub'dagi statistikasi`, vi: `Thống Kê GitHub ${encodedName}`, se: `GitHubstatistik för ${encodedName}`, + no: `GitHub-statistikk for ${encodedName}`, }, "statcard.totalstars": { ar: "مجموع النجوم", @@ -116,6 +118,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "Yulduzchalar", vi: "Tổng Số Sao", se: "Antal intjänade stjärnor", + no: "Totalt antall stjerner", }, "statcard.commits": { ar: "مجموع المساهمات", @@ -150,6 +153,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "'Commit'lar", vi: "Tổng Số Cam Kết", se: "Totalt antal commits", + no: "Totalt antall commits", }, "statcard.prs": { ar: "مجموع طلبات السحب", @@ -184,6 +188,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "'Pull Request'lar", vi: "Tổng Số PR", se: "Totalt antal PR", + no: "Totalt antall PR", }, "statcard.issues": { ar: "مجموع التحسينات", @@ -218,6 +223,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "'Issue'lar", vi: "Tổng Số Vấn Đề", se: "Total antal issues", + no: "Totalt antall issues", }, "statcard.contribs": { ar: "ساهم في (العام الماضي)", @@ -252,6 +258,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "Hissa qoʻshgan (o'tgan yili)", vi: "Đã Đóng Góp (năm ngoái)", se: "Bidragit till (förra året)", + no: "Bidro til (i fjor)", }, "statcard.reviews": { ar: "طلبات السحب التي تم مراجعتها", @@ -286,6 +293,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "Koʻrib chiqilgan PR-lar soni", vi: "Tổng Số PR Đã Xem Xét", se: "Totalt antal granskade PR", + no: "Totalt antall vurderte PR", }, "statcard.discussions-started": { ar: "مجموع المناقشات التي بدأها", @@ -320,6 +328,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "Boshlangan muzokaralar soni", vi: "Tổng Số Thảo Luận Bắt Đầu", se: "Totalt antal diskussioner startade", + no: "Totalt antall startede diskusjoner", }, "statcard.discussions-answered": { ar: "مجموع المناقشات المُجابة", @@ -354,6 +363,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "Javob berilgan muzokaralar soni", vi: "Tổng Số Thảo Luận Đã Trả Lời", se: "Totalt antal diskussioner besvarade", + no: "Totalt antall besvarte diskusjoner", }, "statcard.prs-merged": { ar: "مجموع طلبات السحب المُدمجة", @@ -387,6 +397,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "Birlangan PR-lar soni", vi: "Tổng Số PR Đã Hợp Nhất", se: "Totalt antal sammanfogade PR", + no: "Totalt antall sammenslåtte PR", }, "statcard.prs-merged-percentage": { ar: "نسبة طلبات السحب المُدمجة", @@ -420,6 +431,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "Birlangan PR-lar foizi", vi: "Tỷ Lệ PR Đã Hợp Nhất", se: "Procent av sammanfogade PR", + no: "Prosentandel sammenslåtte PR", }, }; }; @@ -458,6 +470,7 @@ const repoCardLocales = { uz: "Shablon", vi: "Mẫu", se: "Mall", + no: "Mal", }, "repocard.archived": { ar: "مُؤرشف", @@ -492,6 +505,7 @@ const repoCardLocales = { uz: "Arxivlangan", vi: "Đã Lưu Trữ", se: "Arkiverade", + no: "Arkivert", }, }; @@ -529,6 +543,7 @@ const langCardLocales = { uz: "Eng koʻp ishlatiladigan tillar", vi: "Ngôn Ngữ Thường Sử Dụng", se: "Mest använda språken", + no: "Mest brukte språk", }, "langcard.nodata": { ar: "لا توجد بيانات للغات.", @@ -563,6 +578,7 @@ const langCardLocales = { uz: "Til haqida ma'lumot yo'q.", vi: "Không có dữ liệu ngôn ngữ.", se: "Inga språkdata.", + no: "Ingen språkdata.", }, }; @@ -600,6 +616,7 @@ const wakatimeCardLocales = { uz: "WakaTime statistikasi", vi: "Thống Kê WakaTime", se: "WakaTime statistik", + no: "WakaTime-statistikk", }, "wakatimecard.lastyear": { ar: "العام الماضي", @@ -634,6 +651,7 @@ const wakatimeCardLocales = { uz: "O'tgan yil", vi: "Năm ngoái", se: "Förra året", + no: "I fjor", }, "wakatimecard.last7days": { ar: "آخر 7 أيام", @@ -668,6 +686,7 @@ const wakatimeCardLocales = { uz: "O'tgan 7 kun", vi: "7 ngày qua", se: "Senaste 7 dagarna", + no: "Siste 7 dager", }, "wakatimecard.notpublic": { ar: "ملف مستخدم واكا تايم شخصي", @@ -702,6 +721,7 @@ const wakatimeCardLocales = { uz: "WakaTime foydalanuvchi profili ochiq emas", vi: "Hồ sơ người dùng WakaTime không công khai", se: "WakaTime användarprofil inte offentlig", + no: "WakaTime brukerprofil ikke offentlig", }, "wakatimecard.nocodedetails": { ar: "المستخدم لا يشارك المعلومات التفصيلية", @@ -738,6 +758,7 @@ const wakatimeCardLocales = { uz: "Foydalanuvchi umumiy ko`d statistikasini ochiq ravishda almashmaydi", vi: "Người dùng không chia sẻ thống kê mã chi tiết công khai", se: "Användaren delar inte offentligt detaljerad kodstatistik", + no: "Brukeren deler ikke detaljert kodestatistikk offentlig", }, "wakatimecard.nocodingactivity": { ar: "لا يوجد نشاط برمجي لهذا الأسبوع", @@ -772,6 +793,7 @@ const wakatimeCardLocales = { uz: "Bu hafta faol bo'lmadi", vi: "Không Có Hoạt Động Trong Tuần Này", se: "Ingen aktivitet denna vecka", + no: "Ingen kodeaktivitet denne uken", }, }; From 1655c957ce3a3da2a61fb0b53200df19add0634a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Trifun=20=C4=90or=C4=91evi=C4=87?= Date: Tue, 16 Sep 2025 21:38:45 +0200 Subject: [PATCH 068/265] feat: add Serbian translations (#3542) * Update readme.md * Update translations.js * Update src/translations.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update src/translations.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * mark as long lang --------- Co-authored-by: Alexandr Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --- readme.md | 1 + src/cards/stats.js | 1 + src/translations.js | 22 ++++++++++++++++++++++ 3 files changed, 24 insertions(+) diff --git a/readme.md b/readme.md index c3f8a3c2b97a2..7d6e15867f74c 100644 --- a/readme.md +++ b/readme.md @@ -301,6 +301,7 @@ Here is a list of all available locales: | `fr` | French | | `hu` | Hungarian | | `fi` | Finnish | +| `sr` | Serbian | diff --git a/src/cards/stats.js b/src/cards/stats.js index 402e86fb4aa42..38ce915be16a2 100644 --- a/src/cards/stats.js +++ b/src/cards/stats.js @@ -358,6 +358,7 @@ const renderStatsCard = (stats, options = {}) => { "nl", "zh-tw", "uz", + "sr", ]; const isLongLocale = locale ? longLocales.includes(locale) : false; diff --git a/src/translations.js b/src/translations.js index 82bfeb8b079c2..c81eef117365b 100644 --- a/src/translations.js +++ b/src/translations.js @@ -48,6 +48,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: `${encodedName}ning GitHub'dagi statistikasi`, vi: `Thống Kê GitHub ${encodedName}`, se: `GitHubstatistik för ${encodedName}`, + sr: `GitHub статистика корисника ${encodedName}`, no: `GitHub-statistikk for ${encodedName}`, }, "statcard.ranktitle": { @@ -83,6 +84,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: `${encodedName}ning GitHub'dagi statistikasi`, vi: `Thống Kê GitHub ${encodedName}`, se: `GitHubstatistik för ${encodedName}`, + sr: `Ранк корисника ${encodedName}`, no: `GitHub-statistikk for ${encodedName}`, }, "statcard.totalstars": { @@ -118,6 +120,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "Yulduzchalar", vi: "Tổng Số Sao", se: "Antal intjänade stjärnor", + sr: "Број освојених звездица", no: "Totalt antall stjerner", }, "statcard.commits": { @@ -153,6 +156,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "'Commit'lar", vi: "Tổng Số Cam Kết", se: "Totalt antal commits", + sr: "Укупан број коммитова", no: "Totalt antall commits", }, "statcard.prs": { @@ -188,6 +192,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "'Pull Request'lar", vi: "Tổng Số PR", se: "Totalt antal PR", + sr: "Укупно PRова", no: "Totalt antall PR", }, "statcard.issues": { @@ -223,6 +228,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "'Issue'lar", vi: "Tổng Số Vấn Đề", se: "Total antal issues", + sr: "Укупно пријављених проблема", no: "Totalt antall issues", }, "statcard.contribs": { @@ -258,6 +264,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "Hissa qoʻshgan (o'tgan yili)", vi: "Đã Đóng Góp (năm ngoái)", se: "Bidragit till (förra året)", + sr: "Контрибуирано (прошле године)", no: "Bidro til (i fjor)", }, "statcard.reviews": { @@ -293,6 +300,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "Koʻrib chiqilgan PR-lar soni", vi: "Tổng Số PR Đã Xem Xét", se: "Totalt antal granskade PR", + sr: "Укупно прегледаних PRова", no: "Totalt antall vurderte PR", }, "statcard.discussions-started": { @@ -328,6 +336,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "Boshlangan muzokaralar soni", vi: "Tổng Số Thảo Luận Bắt Đầu", se: "Totalt antal diskussioner startade", + sr: "Укупно покренутих дискусија", no: "Totalt antall startede diskusjoner", }, "statcard.discussions-answered": { @@ -363,6 +372,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "Javob berilgan muzokaralar soni", vi: "Tổng Số Thảo Luận Đã Trả Lời", se: "Totalt antal diskussioner besvarade", + sr: "Укупно одговорених дискусија", no: "Totalt antall besvarte diskusjoner", }, "statcard.prs-merged": { @@ -397,6 +407,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "Birlangan PR-lar soni", vi: "Tổng Số PR Đã Hợp Nhất", se: "Totalt antal sammanfogade PR", + sr: "Укупно обједињених PRова", no: "Totalt antall sammenslåtte PR", }, "statcard.prs-merged-percentage": { @@ -431,6 +442,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "Birlangan PR-lar foizi", vi: "Tỷ Lệ PR Đã Hợp Nhất", se: "Procent av sammanfogade PR", + sr: "Проценат обједињених PRова", no: "Prosentandel sammenslåtte PR", }, }; @@ -470,6 +482,7 @@ const repoCardLocales = { uz: "Shablon", vi: "Mẫu", se: "Mall", + sr: "Шаблон", no: "Mal", }, "repocard.archived": { @@ -505,6 +518,7 @@ const repoCardLocales = { uz: "Arxivlangan", vi: "Đã Lưu Trữ", se: "Arkiverade", + sr: "Архивирано", no: "Arkivert", }, }; @@ -543,6 +557,7 @@ const langCardLocales = { uz: "Eng koʻp ishlatiladigan tillar", vi: "Ngôn Ngữ Thường Sử Dụng", se: "Mest använda språken", + sr: "Најкоришћенији језици", no: "Mest brukte språk", }, "langcard.nodata": { @@ -578,6 +593,7 @@ const langCardLocales = { uz: "Til haqida ma'lumot yo'q.", vi: "Không có dữ liệu ngôn ngữ.", se: "Inga språkdata.", + sr: "Нема података о језицима.", no: "Ingen språkdata.", }, }; @@ -616,6 +632,7 @@ const wakatimeCardLocales = { uz: "WakaTime statistikasi", vi: "Thống Kê WakaTime", se: "WakaTime statistik", + sr: "WakaTime статистика", no: "WakaTime-statistikk", }, "wakatimecard.lastyear": { @@ -651,6 +668,7 @@ const wakatimeCardLocales = { uz: "O'tgan yil", vi: "Năm ngoái", se: "Förra året", + sr: "Претходна година", no: "I fjor", }, "wakatimecard.last7days": { @@ -686,6 +704,7 @@ const wakatimeCardLocales = { uz: "O'tgan 7 kun", vi: "7 ngày qua", se: "Senaste 7 dagarna", + sr: "Претходних 7 дана", no: "Siste 7 dager", }, "wakatimecard.notpublic": { @@ -721,6 +740,7 @@ const wakatimeCardLocales = { uz: "WakaTime foydalanuvchi profili ochiq emas", vi: "Hồ sơ người dùng WakaTime không công khai", se: "WakaTime användarprofil inte offentlig", + sr: "WakaTime профил корисника није јаван", no: "WakaTime brukerprofil ikke offentlig", }, "wakatimecard.nocodedetails": { @@ -758,6 +778,7 @@ const wakatimeCardLocales = { uz: "Foydalanuvchi umumiy ko`d statistikasini ochiq ravishda almashmaydi", vi: "Người dùng không chia sẻ thống kê mã chi tiết công khai", se: "Användaren delar inte offentligt detaljerad kodstatistik", + sr: "Корисник не дели јавно детаљну статистику кода", no: "Brukeren deler ikke detaljert kodestatistikk offentlig", }, "wakatimecard.nocodingactivity": { @@ -793,6 +814,7 @@ const wakatimeCardLocales = { uz: "Bu hafta faol bo'lmadi", vi: "Không Có Hoạt Động Trong Tuần Này", se: "Ingen aktivitet denna vecka", + sr: "Током ове недеље није било никаквих активности", no: "Ingen kodeaktivitet denne uken", }, }; From ef7f1394406d0bd8cc1d035d63142c2182e72823 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Tue, 16 Sep 2025 22:47:50 +0300 Subject: [PATCH 069/265] build(deps): bump axios from 1.11.0 to 1.12.2 (#4423) Bumps [axios](https://github.com/axios/axios) from 1.11.0 to 1.12.2. - [Release notes](https://github.com/axios/axios/releases) - [Changelog](https://github.com/axios/axios/blob/v1.x/CHANGELOG.md) - [Commits](https://github.com/axios/axios/compare/v1.11.0...v1.12.2) --- updated-dependencies: - dependency-name: axios dependency-version: 1.12.2 dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- package-lock.json | 14 +++++++------- package.json | 2 +- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/package-lock.json b/package-lock.json index 81e07ee2b3e07..66d191f5a4da4 100644 --- a/package-lock.json +++ b/package-lock.json @@ -9,7 +9,7 @@ "version": "1.0.0", "license": "MIT", "dependencies": { - "axios": "^1.12.1", + "axios": "^1.12.2", "dotenv": "^17.2.2", "emoji-name-map": "^2.0.3", "github-username-regex": "^1.0.0", @@ -2223,9 +2223,9 @@ "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==" }, "node_modules/axios": { - "version": "1.12.1", - "resolved": "https://registry.npmjs.org/axios/-/axios-1.12.1.tgz", - "integrity": "sha512-Kn4kbSXpkFHCGE6rBFNwIv0GQs4AvDT80jlveJDKFxjbTYMUeB4QtsdPCv6H8Cm19Je7IU6VFtRl2zWZI0rudQ==", + "version": "1.12.2", + "resolved": "https://registry.npmjs.org/axios/-/axios-1.12.2.tgz", + "integrity": "sha512-vMJzPewAlRyOgxV2dU0Cuz2O8zzzx9VYtbJOaBgXFeLc4IV/Eg50n4LowmehOOR61S8ZMpc2K5Sa7g6A4jfkUw==", "dependencies": { "follow-redirects": "^1.15.6", "form-data": "^4.0.4", @@ -8877,9 +8877,9 @@ "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==" }, "axios": { - "version": "1.12.1", - "resolved": "https://registry.npmjs.org/axios/-/axios-1.12.1.tgz", - "integrity": "sha512-Kn4kbSXpkFHCGE6rBFNwIv0GQs4AvDT80jlveJDKFxjbTYMUeB4QtsdPCv6H8Cm19Je7IU6VFtRl2zWZI0rudQ==", + "version": "1.12.2", + "resolved": "https://registry.npmjs.org/axios/-/axios-1.12.2.tgz", + "integrity": "sha512-vMJzPewAlRyOgxV2dU0Cuz2O8zzzx9VYtbJOaBgXFeLc4IV/Eg50n4LowmehOOR61S8ZMpc2K5Sa7g6A4jfkUw==", "requires": { "follow-redirects": "^1.15.6", "form-data": "^4.0.4", diff --git a/package.json b/package.json index de16fdc2b6b7f..f5b327eee5b9a 100644 --- a/package.json +++ b/package.json @@ -61,7 +61,7 @@ "prettier": "^3.6.2" }, "dependencies": { - "axios": "^1.12.1", + "axios": "^1.12.2", "dotenv": "^17.2.2", "emoji-name-map": "^2.0.3", "github-username-regex": "^1.0.0", From f179fbe840184c8eef8814d69b4d9bd10b596ff2 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Tue, 16 Sep 2025 22:50:12 +0300 Subject: [PATCH 070/265] build(deps-dev): bump eslint-plugin-jsdoc from 55.3.0 to 57.0.8 (#4424) Bumps [eslint-plugin-jsdoc](https://github.com/gajus/eslint-plugin-jsdoc) from 55.3.0 to 57.0.8. - [Release notes](https://github.com/gajus/eslint-plugin-jsdoc/releases) - [Changelog](https://github.com/gajus/eslint-plugin-jsdoc/blob/main/.releaserc) - [Commits](https://github.com/gajus/eslint-plugin-jsdoc/compare/v55.3.0...v57.0.8) --- updated-dependencies: - dependency-name: eslint-plugin-jsdoc dependency-version: 57.0.8 dependency-type: direct:development update-type: version-update:semver-major ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- package-lock.json | 79 +++++++++++++++++++++++------------------------ package.json | 2 +- 2 files changed, 40 insertions(+), 41 deletions(-) diff --git a/package-lock.json b/package-lock.json index 66d191f5a4da4..10740e7f78c43 100644 --- a/package-lock.json +++ b/package-lock.json @@ -28,7 +28,7 @@ "color-contrast-checker": "^2.1.0", "eslint": "^9.35.0", "eslint-config-prettier": "^10.1.8", - "eslint-plugin-jsdoc": "^55.2.0", + "eslint-plugin-jsdoc": "^57.0.8", "globals": "^16.4.0", "hjson": "^3.2.2", "husky": "^9.1.7", @@ -751,16 +751,16 @@ } }, "node_modules/@es-joy/jsdoccomment": { - "version": "0.57.0", - "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.57.0.tgz", - "integrity": "sha512-M4isJXgy+ZLXvt9EFLHuG5+6Q8hl1iSn3ZnO5R+DiPLUBvsTOh93fZ9X/X1z3l6/pmq3STZtqrEAi6SaPzB4AQ==", + "version": "0.58.0", + "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.58.0.tgz", + "integrity": "sha512-smMc5pDht/UVsCD3hhw/a/e/p8m0RdRYiluXToVfd+d4yaQQh7nn9bACjkk6nXJvat7EWPAxuFkMEFfrxeGa3Q==", "dev": true, "dependencies": { "@types/estree": "^1.0.8", - "@typescript-eslint/types": "^8.42.0", + "@typescript-eslint/types": "^8.43.0", "comment-parser": "1.4.1", "esquery": "^1.6.0", - "jsdoc-type-pratt-parser": "~5.2.0" + "jsdoc-type-pratt-parser": "~5.4.0" }, "engines": { "node": ">=20.11.0" @@ -2076,9 +2076,9 @@ "dev": true }, "node_modules/@typescript-eslint/types": { - "version": "8.43.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.43.0.tgz", - "integrity": "sha512-vQ2FZaxJpydjSZJKiSW/LJsabFFvV7KgLC5DiLhkBcykhQj8iK9BOaDmQt74nnKdLvceM5xmhaTF+pLekrxEkw==", + "version": "8.44.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.44.0.tgz", + "integrity": "sha512-ZSl2efn44VsYM0MfDQe68RKzBz75NPgLQXuGypmym6QVOWL5kegTZuZ02xRAT9T+onqvM6T8CdQk0OwYMB6ZvA==", "dev": true, "engines": { "node": "^18.18.0 || ^20.9.0 || >=21.1.0" @@ -2774,11 +2774,10 @@ } }, "node_modules/debug": { - "version": "4.4.1", - "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.1.tgz", - "integrity": "sha512-KcKCqiftBJcZr++7ykoDIEwSa3XWowTfNPo92BYxjXiyYEVrUQh2aLyhxBCwww+heortUFxEJYcRzosstTEBYQ==", + "version": "4.4.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz", + "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", "dev": true, - "license": "MIT", "dependencies": { "ms": "^2.1.3" }, @@ -3095,15 +3094,15 @@ } }, "node_modules/eslint-plugin-jsdoc": { - "version": "55.3.0", - "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-55.3.0.tgz", - "integrity": "sha512-oo8ByBStn+VO/mPRTkNOCORoJxCegmevFV6v70xf+7+KgCFCyP9ay67l/2420OU0zZUMWfq61BTIaXi+DjVVWQ==", + "version": "57.0.8", + "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-57.0.8.tgz", + "integrity": "sha512-L3kb1fz1VsWMDxcNOPqomC8gWROxCJomynYZkhQJInZu4m3Ugjod75pWAICRrKW1WedHkX8BotknBtGCLUFpAg==", "dev": true, "dependencies": { - "@es-joy/jsdoccomment": "~0.57.0", + "@es-joy/jsdoccomment": "~0.58.0", "are-docs-informative": "^0.0.2", "comment-parser": "1.4.1", - "debug": "^4.4.1", + "debug": "^4.4.3", "escape-string-regexp": "^4.0.0", "espree": "^10.4.0", "esquery": "^1.6.0", @@ -5269,9 +5268,9 @@ } }, "node_modules/jsdoc-type-pratt-parser": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-5.2.0.tgz", - "integrity": "sha512-qJmErzgL4DLj4lyRkDWnEXZRNu3X3CJxVKKhuUPwqPFMiJV6K7/6O//D2Uf+rRi6+qTPgHWxDAgfGllEXoGkMA==", + "version": "5.4.0", + "resolved": "https://registry.npmjs.org/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-5.4.0.tgz", + "integrity": "sha512-F9GQ+F1ZU6qvSrZV8fNFpjDNf614YzR2eF6S0+XbDjAcUI28FSoXnYZFjQmb1kFx3rrJb5PnxUH3/Yti6fcM+g==", "dev": true, "engines": { "node": ">=12.0.0" @@ -7726,16 +7725,16 @@ "dev": true }, "@es-joy/jsdoccomment": { - "version": "0.57.0", - "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.57.0.tgz", - "integrity": "sha512-M4isJXgy+ZLXvt9EFLHuG5+6Q8hl1iSn3ZnO5R+DiPLUBvsTOh93fZ9X/X1z3l6/pmq3STZtqrEAi6SaPzB4AQ==", + "version": "0.58.0", + "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.58.0.tgz", + "integrity": "sha512-smMc5pDht/UVsCD3hhw/a/e/p8m0RdRYiluXToVfd+d4yaQQh7nn9bACjkk6nXJvat7EWPAxuFkMEFfrxeGa3Q==", "dev": true, "requires": { "@types/estree": "^1.0.8", - "@typescript-eslint/types": "^8.42.0", + "@typescript-eslint/types": "^8.43.0", "comment-parser": "1.4.1", "esquery": "^1.6.0", - "jsdoc-type-pratt-parser": "~5.2.0" + "jsdoc-type-pratt-parser": "~5.4.0" } }, "@eslint-community/eslint-utils": { @@ -8774,9 +8773,9 @@ "dev": true }, "@typescript-eslint/types": { - "version": "8.43.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.43.0.tgz", - "integrity": "sha512-vQ2FZaxJpydjSZJKiSW/LJsabFFvV7KgLC5DiLhkBcykhQj8iK9BOaDmQt74nnKdLvceM5xmhaTF+pLekrxEkw==", + "version": "8.44.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.44.0.tgz", + "integrity": "sha512-ZSl2efn44VsYM0MfDQe68RKzBz75NPgLQXuGypmym6QVOWL5kegTZuZ02xRAT9T+onqvM6T8CdQk0OwYMB6ZvA==", "dev": true }, "@uppercod/css-to-object": { @@ -9277,9 +9276,9 @@ } }, "debug": { - "version": "4.4.1", - "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.1.tgz", - "integrity": "sha512-KcKCqiftBJcZr++7ykoDIEwSa3XWowTfNPo92BYxjXiyYEVrUQh2aLyhxBCwww+heortUFxEJYcRzosstTEBYQ==", + "version": "4.4.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz", + "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", "dev": true, "requires": { "ms": "^2.1.3" @@ -9577,15 +9576,15 @@ "requires": {} }, "eslint-plugin-jsdoc": { - "version": "55.3.0", - "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-55.3.0.tgz", - "integrity": "sha512-oo8ByBStn+VO/mPRTkNOCORoJxCegmevFV6v70xf+7+KgCFCyP9ay67l/2420OU0zZUMWfq61BTIaXi+DjVVWQ==", + "version": "57.0.8", + "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-57.0.8.tgz", + "integrity": "sha512-L3kb1fz1VsWMDxcNOPqomC8gWROxCJomynYZkhQJInZu4m3Ugjod75pWAICRrKW1WedHkX8BotknBtGCLUFpAg==", "dev": true, "requires": { - "@es-joy/jsdoccomment": "~0.57.0", + "@es-joy/jsdoccomment": "~0.58.0", "are-docs-informative": "^0.0.2", "comment-parser": "1.4.1", - "debug": "^4.4.1", + "debug": "^4.4.3", "escape-string-regexp": "^4.0.0", "espree": "^10.4.0", "esquery": "^1.6.0", @@ -11072,9 +11071,9 @@ } }, "jsdoc-type-pratt-parser": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-5.2.0.tgz", - "integrity": "sha512-qJmErzgL4DLj4lyRkDWnEXZRNu3X3CJxVKKhuUPwqPFMiJV6K7/6O//D2Uf+rRi6+qTPgHWxDAgfGllEXoGkMA==", + "version": "5.4.0", + "resolved": "https://registry.npmjs.org/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-5.4.0.tgz", + "integrity": "sha512-F9GQ+F1ZU6qvSrZV8fNFpjDNf614YzR2eF6S0+XbDjAcUI28FSoXnYZFjQmb1kFx3rrJb5PnxUH3/Yti6fcM+g==", "dev": true }, "jsdom": { diff --git a/package.json b/package.json index f5b327eee5b9a..de63b19c4b2f5 100644 --- a/package.json +++ b/package.json @@ -47,7 +47,7 @@ "color-contrast-checker": "^2.1.0", "eslint": "^9.35.0", "eslint-config-prettier": "^10.1.8", - "eslint-plugin-jsdoc": "^55.2.0", + "eslint-plugin-jsdoc": "^57.0.8", "globals": "^16.4.0", "hjson": "^3.2.2", "husky": "^9.1.7", From 63b402177d6d9a567b330039e0cb830f6a601bd5 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Wed, 17 Sep 2025 20:48:39 +0300 Subject: [PATCH 071/265] docs: add information about fine-grained personal access tokens (PATs) scopes (#4426) * :wrench: Add .env example * :memo: Update README for add the PAT settings * :memo: Add fine-grained PAT documentation * remove .env.example * docs review * toc * more review * Update readme.md Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --------- Co-authored-by: Colin-de-Seroux <77831261+Colin-de-Seroux@users.noreply.github.com> Co-authored-by: Alexandr Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --- readme.md | 37 ++++++++++++++++++++++++++++++++++++- 1 file changed, 36 insertions(+), 1 deletion(-) diff --git a/readme.md b/readme.md index 7d6e15867f74c..1f9da22d3519f 100644 --- a/readme.md +++ b/readme.md @@ -84,6 +84,9 @@ - [Stats and top languages cards](#stats-and-top-languages-cards) - [Pinning repositories](#pinning-repositories) - [Deploy on your own](#deploy-on-your-own) + - [First step: get your Personal Access Token (PAT)](#first-step-get-your-personal-access-token-pat) + - [Classic token](#classic-token) + - [Fine-grained token](#fine-grained-token) - [On Vercel](#on-vercel) - [:film\_projector: Check Out Step By Step Video Tutorial By @codeSTACKr](#film_projector-check-out-step-by-step-video-tutorial-by-codestackr) - [On other platforms](#on-other-platforms) @@ -764,6 +767,38 @@ By default, GitHub does not lay out the cards side by side. To do that, you can # Deploy on your own +## First step: get your Personal Access Token (PAT) + +Selecting the right scopes for your token is important in case you want to display private contributions on your stats card. + +### Classic token + +Steps: + - Go to [Account -> Settings -> Developer Settings -> Personal access tokens -> Tokens (classic)](https://github.com/settings/tokens). + - Click on `Generate new token -> Generate new token (classic)`. + - Scopes to select: + - repo + - read:user + - Click on `Generate token` and copy it. + +### Fine-grained token + +> [!WARNING]\ +> This limits the number of issues to the number of issues on your repositories only and only takes public commits into account. + +Steps: + - Go to [Account -> Settings -> Developer Settings -> Personal access tokens -> Fine-grained tokens](https://github.com/settings/tokens). + - Click on `Generate new token -> Generate new token`. + - Select an expiration date + - Select `All repositories` + - Scopes to select in `Repository permission`: + - Commit statuses: read-only + - Contents: read-only + - Issues: read-only + - Metadata: read-only + - Pull requests: read-only + - Click on `Generate token` and copy it. + ## On Vercel ### :film\_projector: [Check Out Step By Step Video Tutorial By @codeSTACKr](https://youtu.be/n6d4KHSKqGk?t=107) @@ -793,7 +828,7 @@ Since the GitHub API only allows 5k requests per hour, my `https://github-readme ![](https://files.catbox.moe/3n76fh.png) 8. Click the `Continue with GitHub` button, search for the required Git Repository and import it by clicking the `Import` button. Alternatively, you can import a Third-Party Git Repository using the `Import Third-Party Git Repository ->` link at the bottom of the page. ![](https://files.catbox.moe/mg5p04.png) -9. Create a personal access token (PAT) [here](https://github.com/settings/tokens/new) and enable the `repo` and `user` permissions (this allows access to see private repo and user stats). +9. Create a Personal Access Token (PAT) as described in the [previous section](#first-step-get-your-personal-access-token-pat). 10. Add the PAT as an environment variable named `PAT_1` (as shown). ![](https://files.catbox.moe/0yclio.png) 11. Click deploy, and you're good to go. See your domains to use the API! From b594b57b56968cb401cf12af311436c954aed245 Mon Sep 17 00:00:00 2001 From: my99N Date: Thu, 18 Sep 2025 02:01:37 +0700 Subject: [PATCH 072/265] feat: implement commits year option and display appropriate year label (#2107) * add custom year * edit fetcher * add tests * add documentation * Update vercel.json * Update fetchStats.test.js * Update readme.md * Update readme.md Co-authored-by: Rick Staa * test: fix tests * style: format code * fix: fix commit stats time frame description #1053 This commit makes sure the last year label is shown when `include_all_commits` or `year` is not provided. See #1053 for more information. * resolved merge conflict * Update stats-fetcher.js * resolve comments * Update src/cards/types.d.ts Co-authored-by: Alexandr Garbuzov * Update src/fetchers/stats-fetcher.js Co-authored-by: Alexandr Garbuzov * graphQL year only to commit * change argument name to commits_year * Update readme.md Co-authored-by: Alexandr Garbuzov * Update readme.md Co-authored-by: Alexandr Garbuzov * Update readme.md Co-authored-by: Alexandr Garbuzov * wrap label into function * review * more review * fix test * Update readme.md Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * docs --------- Co-authored-by: Touch Sungkawichai Co-authored-by: Rick Staa Co-authored-by: Alexandr Garbuzov Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --- api/index.js | 3 ++ readme.md | 10 +++++++ src/cards/stats.js | 39 +++++++++++++++++++----- src/cards/types.d.ts | 1 + src/fetchers/stats.js | 17 +++++++---- tests/api.test.js | 4 ++- tests/bench/api.bench.js | 4 ++- tests/fetchStats.test.js | 56 +++++++++++++++++++++++++++++++++-- tests/renderStatsCard.test.js | 2 +- 9 files changed, 118 insertions(+), 18 deletions(-) diff --git a/api/index.js b/api/index.js index b5705fbc62b8c..66c119a5e0563 100644 --- a/api/index.js +++ b/api/index.js @@ -21,6 +21,7 @@ export default async (req, res) => { hide_rank, show_icons, include_all_commits, + commits_year, line_height, title_color, ring_color, @@ -98,6 +99,7 @@ export default async (req, res) => { showStats.includes("prs_merged_percentage"), showStats.includes("discussions_started"), showStats.includes("discussions_answered"), + parseInt(commits_year, 10), ); let cacheSeconds = clampValue( @@ -123,6 +125,7 @@ export default async (req, res) => { card_width: parseInt(card_width, 10), hide_rank: parseBoolean(hide_rank), include_all_commits: parseBoolean(include_all_commits), + commits_year: parseInt(commits_year, 10), line_height, title_color, ring_color, diff --git a/readme.md b/readme.md index 1f9da22d3519f..5b4151f311a83 100644 --- a/readme.md +++ b/readme.md @@ -52,6 +52,7 @@ - [Hiding individual stats](#hiding-individual-stats) - [Showing additional individual stats](#showing-additional-individual-stats) - [Showing icons](#showing-icons) + - [Showing commits count for specified year](#showing-commits-count-for-specified-year) - [Themes](#themes) - [Customization](#customization) - [GitHub Extra Pins](#github-extra-pins) @@ -149,6 +150,14 @@ To enable icons, you can pass `&show_icons=true` in the query param, like so: ![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&show_icons=true) ``` +### Showing commits count for specified year + +You can specify a year and fetch only the commits that were made in that year by passing `&commits_year=YYYY` to the parameter. + +```md +![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra&commits_year=2020) +``` + ### Themes With inbuilt themes, you can customize the look of the card without doing any [manual customization](#customization). @@ -362,6 +371,7 @@ If we don't support your language, please consider contributing! You can find mo | `ring_color` | Color of the rank circle. | string (hex color) | `2f80ed` | | `number_format` | Switches between two available formats for displaying the card values `short` (i.e. `6.6k`) and `long` (i.e. `6626`). | enum | `short` | | `show` | Shows [additional items](#showing-additional-individual-stats) on stats card (i.e. `reviews`, `discussions_started`, `discussions_answered`, `prs_merged` or `prs_merged_percentage`). | string (comma-separated values) | `null` | +| `commits_year` | Filters and counts only commits made in the specified year | integer _(YYYY)_ | ` (one year to date)`. > [!NOTE]\ > When hide\_rank=`true`, the minimum card width is 270 px + the title length and padding. diff --git a/src/cards/stats.js b/src/cards/stats.js index 38ce915be16a2..3a4d53ca7df0f 100644 --- a/src/cards/stats.js +++ b/src/cards/stats.js @@ -10,7 +10,7 @@ import { kFormatter, measureText, } from "../common/utils.js"; -import { statCardLocales } from "../translations.js"; +import { statCardLocales, wakatimeCardLocales } from "../translations.js"; const CARD_MIN_WIDTH = 287; const CARD_DEFAULT_WIDTH = 287; @@ -187,6 +187,21 @@ const getStyles = ({ `; }; +/** + * Return the label for commits according to the selected options + * + * @param {boolean} include_all_commits Option to include all years + * @param {number|undefined} commits_year Option to include only selected year + * @param {I18n} i18n The I18n instance. + * @returns {string} The label corresponding to the options. + */ +const getTotalCommitsYearLabel = (include_all_commits, commits_year, i18n) => + include_all_commits + ? "" + : commits_year + ? ` (${commits_year})` + : ` (${i18n.t("wakatimecard.lastyear")})`; + /** * @typedef {import('../fetchers/types').StatsData} StatsData * @typedef {import('./types').StatCardOptions} StatCardOptions @@ -222,6 +237,7 @@ const renderStatsCard = (stats, options = {}) => { card_width, hide_rank = false, include_all_commits = false, + commits_year, line_height = 25, title_color, ring_color, @@ -257,7 +273,10 @@ const renderStatsCard = (stats, options = {}) => { const apostrophe = /s$/i.test(name.trim()) ? "" : "s"; const i18n = new I18n({ locale, - translations: statCardLocales({ name, apostrophe }), + translations: { + ...statCardLocales({ name, apostrophe }), + ...wakatimeCardLocales, + }, }); // Meta data for creating text nodes with createTextNode function @@ -271,9 +290,11 @@ const renderStatsCard = (stats, options = {}) => { }; STATS.commits = { icon: icons.commits, - label: `${i18n.t("statcard.commits")}${ - include_all_commits ? "" : ` (${new Date().getFullYear()})` - }`, + label: `${i18n.t("statcard.commits")}${getTotalCommitsYearLabel( + include_all_commits, + commits_year, + i18n, + )}`, value: totalCommits, id: "commits", }; @@ -515,9 +536,11 @@ const renderStatsCard = (stats, options = {}) => { .filter((key) => !hide.includes(key)) .map((key) => { if (key === "commits") { - return `${i18n.t("statcard.commits")} ${ - include_all_commits ? "" : `in ${new Date().getFullYear()}` - } : ${STATS[key].value}`; + return `${i18n.t("statcard.commits")} ${getTotalCommitsYearLabel( + include_all_commits, + commits_year, + i18n, + )} : ${STATS[key].value}`; } return `${STATS[key].label}: ${STATS[key].value}`; }) diff --git a/src/cards/types.d.ts b/src/cards/types.d.ts index 08f80ef2c3a68..94f36adc624b7 100644 --- a/src/cards/types.d.ts +++ b/src/cards/types.d.ts @@ -20,6 +20,7 @@ export type StatCardOptions = CommonOptions & { card_width: number; hide_rank: boolean; include_all_commits: boolean; + commits_year: number; line_height: number | string; custom_title: string; disable_animations: boolean; diff --git a/src/fetchers/stats.js b/src/fetchers/stats.js index 88fd72fcb9760..56af97d89a041 100644 --- a/src/fetchers/stats.js +++ b/src/fetchers/stats.js @@ -40,12 +40,14 @@ const GRAPHQL_REPOS_QUERY = ` `; const GRAPHQL_STATS_QUERY = ` - query userInfo($login: String!, $after: String, $includeMergedPullRequests: Boolean!, $includeDiscussions: Boolean!, $includeDiscussionsAnswers: Boolean!) { + query userInfo($login: String!, $after: String, $includeMergedPullRequests: Boolean!, $includeDiscussions: Boolean!, $includeDiscussionsAnswers: Boolean!, $startTime: DateTime = null) { user(login: $login) { name login - contributionsCollection { + commits: contributionsCollection (from: $startTime) { totalCommitContributions, + } + reviews: contributionsCollection { totalPullRequestReviewContributions } repositoriesContributedTo(first: 1, contributionTypes: [COMMIT, ISSUE, PULL_REQUEST, REPOSITORY]) { @@ -109,6 +111,7 @@ const fetcher = (variables, token) => { * @param {boolean} variables.includeMergedPullRequests Include merged pull requests. * @param {boolean} variables.includeDiscussions Include discussions. * @param {boolean} variables.includeDiscussionsAnswers Include discussions answers. + * @param {string|undefined} variables.startTime Time to start the count of total commits. * @returns {Promise} Axios response. * * @description This function supports multi-page fetching if the 'FETCH_MULTI_PAGE_STARS' environment variable is set to true. @@ -118,6 +121,7 @@ const statsFetcher = async ({ includeMergedPullRequests, includeDiscussions, includeDiscussionsAnswers, + startTime, }) => { let stats; let hasNextPage = true; @@ -130,6 +134,7 @@ const statsFetcher = async ({ includeMergedPullRequests, includeDiscussions, includeDiscussionsAnswers, + startTime, }; let res = await retryer(fetcher, variables); if (res.data.errors) { @@ -217,6 +222,7 @@ const totalCommitsFetcher = async (username) => { * @param {boolean} include_merged_pull_requests Include merged pull requests. * @param {boolean} include_discussions Include discussions. * @param {boolean} include_discussions_answers Include discussions answers. + * @param {number|undefined} commits_year Year to count total commits * @returns {Promise} Stats data. */ const fetchStats = async ( @@ -226,6 +232,7 @@ const fetchStats = async ( include_merged_pull_requests = false, include_discussions = false, include_discussions_answers = false, + commits_year, ) => { if (!username) { throw new MissingParamError(["username"]); @@ -251,6 +258,7 @@ const fetchStats = async ( includeMergedPullRequests: include_merged_pull_requests, includeDiscussions: include_discussions, includeDiscussionsAnswers: include_discussions_answers, + startTime: commits_year ? `${commits_year}-01-01T00:00:00Z` : undefined, }); // Catch GraphQL errors. @@ -282,7 +290,7 @@ const fetchStats = async ( if (include_all_commits) { stats.totalCommits = await totalCommitsFetcher(username); } else { - stats.totalCommits = user.contributionsCollection.totalCommitContributions; + stats.totalCommits = user.commits.totalCommitContributions; } stats.totalPRs = user.pullRequests.totalCount; @@ -291,8 +299,7 @@ const fetchStats = async ( stats.mergedPRsPercentage = (user.mergedPullRequests.totalCount / user.pullRequests.totalCount) * 100; } - stats.totalReviews = - user.contributionsCollection.totalPullRequestReviewContributions; + stats.totalReviews = user.reviews.totalPullRequestReviewContributions; stats.totalIssues = user.openIssues.totalCount + user.closedIssues.totalCount; if (include_discussions) { stats.totalDiscussionsStarted = user.repositoryDiscussions.totalCount; diff --git a/tests/api.test.js b/tests/api.test.js index 697c690ec39fe..44928887d953a 100644 --- a/tests/api.test.js +++ b/tests/api.test.js @@ -38,8 +38,10 @@ const data_stats = { user: { name: stats.name, repositoriesContributedTo: { totalCount: stats.contributedTo }, - contributionsCollection: { + commits: { totalCommitContributions: stats.totalCommits, + }, + reviews: { totalPullRequestReviewContributions: stats.totalReviews, }, pullRequests: { totalCount: stats.totalPRs }, diff --git a/tests/bench/api.bench.js b/tests/bench/api.bench.js index 4796b64306e24..f5f192d97e131 100644 --- a/tests/bench/api.bench.js +++ b/tests/bench/api.bench.js @@ -24,8 +24,10 @@ const data_stats = { user: { name: stats.name, repositoriesContributedTo: { totalCount: stats.contributedTo }, - contributionsCollection: { + commits: { totalCommitContributions: stats.totalCommits, + }, + reviews: { totalPullRequestReviewContributions: stats.totalReviews, }, pullRequests: { totalCount: stats.totalPRs }, diff --git a/tests/fetchStats.test.js b/tests/fetchStats.test.js index 06aefeddee1c9..73a4f28257d4e 100644 --- a/tests/fetchStats.test.js +++ b/tests/fetchStats.test.js @@ -11,8 +11,10 @@ const data_stats = { user: { name: "Anurag Hazra", repositoriesContributedTo: { totalCount: 61 }, - contributionsCollection: { + commits: { totalCommitContributions: 100, + }, + reviews: { totalPullRequestReviewContributions: 50, }, pullRequests: { totalCount: 300 }, @@ -38,6 +40,9 @@ const data_stats = { }, }; +const data_year2003 = JSON.parse(JSON.stringify(data_stats)); +data_year2003.data.user.commits.totalCommitContributions = 428; + const data_repo = { data: { user: { @@ -91,9 +96,18 @@ const mock = new MockAdapter(axios); beforeEach(() => { process.env.FETCH_MULTI_PAGE_STARS = "false"; // Set to `false` to fetch only one page of stars. mock.onPost("https://api.github.com/graphql").reply((cfg) => { + let req = JSON.parse(cfg.data); + + if ( + req.variables && + req.variables.startTime && + req.variables.startTime.startsWith("2003") + ) { + return [200, data_year2003]; + } return [ 200, - cfg.data.includes("contributionsCollection") ? data_stats : data_repo, + req.query.includes("totalCommitContributions") ? data_stats : data_repo, ]; }); }); @@ -409,4 +423,42 @@ describe("Test fetchStats", () => { rank, }); }); + + it("should get commits of provided year", async () => { + let stats = await fetchStats( + "anuraghazra", + false, + [], + false, + false, + false, + 2003, + ); + + const rank = calculateRank({ + all_commits: false, + commits: 428, + prs: 300, + reviews: 50, + issues: 200, + repos: 5, + stars: 300, + followers: 100, + }); + + expect(stats).toStrictEqual({ + contributedTo: 61, + name: "Anurag Hazra", + totalCommits: 428, + totalIssues: 200, + totalPRs: 300, + totalPRsMerged: 0, + mergedPRsPercentage: 0, + totalReviews: 50, + totalStars: 300, + totalDiscussionsStarted: 0, + totalDiscussionsAnswered: 0, + rank, + }); + }); }); diff --git a/tests/renderStatsCard.test.js b/tests/renderStatsCard.test.js index ebf0d251f55af..a460454052506 100644 --- a/tests/renderStatsCard.test.js +++ b/tests/renderStatsCard.test.js @@ -387,7 +387,7 @@ describe("Test renderStatsCard", () => { document.querySelector( 'g[transform="translate(0, 25)"]>.stagger>.stat.bold', ).textContent, - ).toMatchInlineSnapshot(`"累计提交总数 (${new Date().getFullYear()}):"`); + ).toMatchInlineSnapshot(`"累计提交总数 (去年):"`); expect( document.querySelector( 'g[transform="translate(0, 50)"]>.stagger>.stat.bold', From f441d1696cec229db262ecedf11aaed5ba709079 Mon Sep 17 00:00:00 2001 From: Amin <36745993+4Min4m@users.noreply.github.com> Date: Wed, 17 Sep 2025 21:36:12 +0200 Subject: [PATCH 073/265] feat: add Persian (Farsi) translations (#4263) * Add Persian/Farsi (fa) language support This PR adds support for Persian (Farsi) language with ISO 639-1 code `fa`. Translations have been added for all keys in `statCardLocales`, `repoCardLocales`, `langCardLocales`, and `wakatimeCardLocales`. The translations follow the existing style and are compatible with the project's structure. Please test the display of Persian text in the UI to ensure proper rendering. * review * Update src/translations.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update src/translations.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update src/translations.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --------- Co-authored-by: Alexandr Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --- readme.md | 1 + src/translations.js | 22 ++++++++++++++++++++++ 2 files changed, 23 insertions(+) diff --git a/readme.md b/readme.md index 5b4151f311a83..da7a524f8aa8b 100644 --- a/readme.md +++ b/readme.md @@ -330,6 +330,7 @@ Here is a list of all available locales: | `ru` | Russian | | `uk-ua` | Ukrainian | | `ro` | Romanian | +| `fa` | Persian (Farsi) | diff --git a/src/translations.js b/src/translations.js index c81eef117365b..4a294404c7d73 100644 --- a/src/translations.js +++ b/src/translations.js @@ -25,6 +25,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: `${encodedName}'${apostrophe} GitHub Stats`, bn: `${encodedName} এর GitHub পরিসংখ্যান`, es: `Estadísticas de GitHub de ${encodedName}`, + fa: `آمار گیت‌هاب ${encodedName}`, fi: `${encodedName}:n GitHub-tilastot`, fr: `Statistiques GitHub de ${encodedName}`, hu: `${encodedName} GitHub statisztika`, @@ -61,6 +62,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: `${encodedName}'${apostrophe} GitHub Rank`, bn: `${encodedName} এর GitHub পরিসংখ্যান`, es: `Estadísticas de GitHub de ${encodedName}`, + fa: `رتبه گیت‌هاب ${encodedName}`, fi: `${encodedName}:n GitHub-sijoitus`, fr: `Statistiques GitHub de ${encodedName}`, hu: `${encodedName} GitHub statisztika`, @@ -97,6 +99,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: "Total Stars Earned", bn: "সর্বমোট Star", es: "Estrellas totales", + fa: "مجموع ستاره‌های دریافت‌شده", fi: "Ansaitut tähdet yhteensä", fr: "Total d'étoiles", hu: "Csillagok", @@ -133,6 +136,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: "Total Commits", bn: "সর্বমোট Commit", es: "Commits totales", + fa: "مجموع کامیت‌ها", fi: "Yhteensä committeja", fr: "Total des Commits", hu: "Összes commit", @@ -169,6 +173,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: "Total PRs", bn: "সর্বমোট PR", es: "PRs totales", + fa: "مجموع Pull Request", fi: "Yhteensä PR:t", fr: "Total des PRs", hu: "Összes PR", @@ -205,6 +210,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: "Total Issues", bn: "সর্বমোট Issue", es: "Issues totales", + fa: "مجموع مسائل", fi: "Yhteensä ongelmat", fr: "Nombre total d'incidents", hu: "Összes hibajegy", @@ -241,6 +247,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: "Contributed to (last year)", bn: "অবদান (গত বছর)", es: "Contribuciones en (el año pasado)", + fa: "مشارکت در (سال گذشته)", fi: "Osallistunut (viime vuonna)", fr: "Contribué à (l'année dernière)", hu: "Hozzájárulások (tavaly)", @@ -277,6 +284,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: "Total PRs Reviewed", bn: "সর্বমোট পুনরালোচনা করা PR", es: "PR totales revisados", + fa: "مجموع درخواست‌های ادغام بررسی‌شده", fi: "Yhteensä tarkastettuja PR:itä", fr: "Nombre total de PR examinés", hu: "Összes ellenőrzött PR", @@ -313,6 +321,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: "Total Discussions Started", bn: "সর্বমোট আলোচনা শুরু", es: "Discusiones totales iniciadas", + fa: "مجموع بحث‌های آغازشده", fi: "Aloitetut keskustelut yhteensä", fr: "Nombre total de discussions lancées", hu: "Összes megkezdett megbeszélés", @@ -349,6 +358,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: "Total Discussions Answered", bn: "সর্বমোট আলোচনা উত্তর", es: "Discusiones totales respondidas", + fa: "مجموع بحث‌های پاسخ‌داده‌شده", fi: "Vastatut keskustelut yhteensä", fr: "Nombre total de discussions répondues", hu: "Összes megválaszolt megbeszélés", @@ -385,6 +395,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: "Total PRs Merged", bn: "সর্বমোট PR একত্রীকৃত", es: "PR totales fusionados", + fa: "مجموع درخواست‌های ادغام شده", fi: "Yhteensä yhdistetyt PR:t", fr: "Nombre total de PR fusionnés", hu: "Összes egyesített PR", @@ -420,6 +431,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: "Merged PRs Percentage", bn: "PR একত্রীকরণের শতাংশ", es: "Porcentaje de PR fusionados", + fa: "درصد درخواست‌های ادغام‌شده", fi: "Yhdistettyjen PR:ien prosentti", fr: "Pourcentage de PR fusionnés", hu: "Egyesített PR-k százaléka", @@ -459,6 +471,7 @@ const repoCardLocales = { de: "Vorlage", en: "Template", es: "Plantilla", + fa: "الگو", fi: "Malli", fr: "Modèle", hu: "Sablon", @@ -495,6 +508,7 @@ const repoCardLocales = { de: "Archiviert", en: "Archived", es: "Archivados", + fa: "بایگانی‌شده", fi: "Arkistoitu", fr: "Archivé", hu: "Archivált", @@ -534,6 +548,7 @@ const langCardLocales = { bn: "সর্বাধিক ব্যবহৃত ভাষা সমূহ", en: "Most Used Languages", es: "Lenguajes más usados", + fa: "زبان‌های پرکاربرد", fi: "Käytetyimmät kielet", fr: "Langages les plus utilisés", hu: "Leggyakrabban használt nyelvek", @@ -570,6 +585,7 @@ const langCardLocales = { bn: "কোন ভাষার ডেটা নেই।", en: "No languages data.", es: "Sin datos de idiomas.", + fa: "داده‌ای برای زبان‌ها وجود ندارد.", fi: "Ei kielitietoja.", fr: "Aucune donnée sur les langues.", hu: "Nincsenek nyelvi adatok.", @@ -609,6 +625,7 @@ const wakatimeCardLocales = { en: "WakaTime Stats", bn: "WakaTime স্ট্যাটাস", es: "Estadísticas de WakaTime", + fa: "آمار WakaTime", fi: "WakaTime-tilastot", fr: "Statistiques de WakaTime", hu: "WakaTime statisztika", @@ -645,6 +662,7 @@ const wakatimeCardLocales = { en: "last year", bn: "গত বছর", es: "El año pasado", + fa: "سال گذشته", fi: "Viime vuosi", fr: "L'année dernière", hu: "Tavaly", @@ -681,6 +699,7 @@ const wakatimeCardLocales = { en: "last 7 days", bn: "গত ৭ দিন", es: "Últimos 7 días", + fa: "هفت روز گذشته", fi: "Viimeiset 7 päivää", fr: "7 derniers jours", hu: "Elmúlt 7 nap", @@ -717,6 +736,7 @@ const wakatimeCardLocales = { en: "WakaTime user profile not public", bn: "WakaTime ব্যবহারকারীর প্রোফাইল প্রকাশ্য নয়", es: "Perfil de usuario de WakaTime no público", + fa: "پروفایل کاربری WakaTime عمومی نیست", fi: "WakaTime-käyttäjäprofiili ei ole julkinen", fr: "Profil utilisateur WakaTime non public", hu: "A WakaTime felhasználói profilja nem nyilvános", @@ -753,6 +773,7 @@ const wakatimeCardLocales = { en: "User doesn't publicly share detailed code statistics", bn: "ব্যবহারকারী বিস্তারিত কোড পরিসংখ্যান প্রকাশ করেন না", es: "El usuario no comparte públicamente estadísticas detalladas de código", + fa: "کاربر آمار کد تفصیلی را به‌صورت عمومی به اشتراک نمی‌گذارد", fi: "Käyttäjä ei jaa julkisesti tarkkoja kooditilastoja", fr: "L'utilisateur ne partage pas publiquement de statistiques de code détaillées", hu: "A felhasználó nem osztja meg nyilvánosan a részletes kódstatisztikákat", @@ -791,6 +812,7 @@ const wakatimeCardLocales = { en: "No coding activity this week", bn: "এই সপ্তাহে কোন কোডিং অ্যাক্টিভিটি নেই", es: "No hay actividad de codificación esta semana", + fa: "فعالیت کدنویسی در این هفته وجود ندارد", fi: "Ei koodaustoimintaa tällä viikolla", fr: "Aucune activité de codage cette semaine", hu: "Nem volt aktivitás ezen a héten", From 53061185874b9a434a2bc9bca0fbed5ad4317973 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Wed, 17 Sep 2025 22:52:18 +0300 Subject: [PATCH 074/265] chore: fix jsdoc for rank calculation function (#4427) Co-authored-by: Alexandr --- src/calculateRank.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/calculateRank.js b/src/calculateRank.js index 4724d0388c846..a7741985e489e 100644 --- a/src/calculateRank.js +++ b/src/calculateRank.js @@ -31,7 +31,7 @@ function log_normal_cdf(x) { * @param {number} params.repos Total number of repos. * @param {number} params.stars The number of stars. * @param {number} params.followers The number of followers. - * @returns {{level: string, percentile: number}}} The users rank. + * @returns {{ level: string, percentile: number }} The users rank. */ function calculateRank({ all_commits, From 10526a0b7ebba80e13b7debf59911c637d5b23f9 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Wed, 17 Sep 2025 22:53:48 +0300 Subject: [PATCH 075/265] chore: make stats card create text node function jsdoc shorter (#4429) Co-authored-by: Alexandr --- src/cards/stats.js | 22 +++++++++++----------- 1 file changed, 11 insertions(+), 11 deletions(-) diff --git a/src/cards/stats.js b/src/cards/stats.js index 3a4d53ca7df0f..5c34360d67716 100644 --- a/src/cards/stats.js +++ b/src/cards/stats.js @@ -22,17 +22,17 @@ const RANK_ONLY_CARD_DEFAULT_WIDTH = 290; /** * Create a stats card text item. * - * @param {object} createTextNodeParams Object that contains the createTextNode parameters. - * @param {string} createTextNodeParams.icon The icon to display. - * @param {string} createTextNodeParams.label The label to display. - * @param {number} createTextNodeParams.value The value to display. - * @param {string} createTextNodeParams.id The id of the stat. - * @param {string=} createTextNodeParams.unitSymbol The unit symbol of the stat. - * @param {number} createTextNodeParams.index The index of the stat. - * @param {boolean} createTextNodeParams.showIcons Whether to show icons. - * @param {number} createTextNodeParams.shiftValuePos Number of pixels the value has to be shifted to the right. - * @param {boolean} createTextNodeParams.bold Whether to bold the label. - * @param {string} createTextNodeParams.number_format The format of numbers on card. + * @param {object} params Object that contains the createTextNode parameters. + * @param {string} params.icon The icon to display. + * @param {string} params.label The label to display. + * @param {number} params.value The value to display. + * @param {string} params.id The id of the stat. + * @param {string=} params.unitSymbol The unit symbol of the stat. + * @param {number} params.index The index of the stat. + * @param {boolean} params.showIcons Whether to show icons. + * @param {number} params.shiftValuePos Number of pixels the value has to be shifted to the right. + * @param {boolean} params.bold Whether to bold the label. + * @param {string} params.number_format The format of numbers on card. * @returns {string} The stats card text item SVG object. */ const createTextNode = ({ From a8c56ff4c9e8684fc77b916ffc5991aefbc1d0c1 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Thu, 18 Sep 2025 19:52:10 +0300 Subject: [PATCH 076/265] fix: react on both type and message-based rate-limit signals (#4440) Co-authored-by: Alexandr --- src/common/retryer.js | 12 +++++++++--- tests/retryer.test.js | 28 ++++++++++++++++++++++++++++ 2 files changed, 37 insertions(+), 3 deletions(-) diff --git a/src/common/retryer.js b/src/common/retryer.js index 3f294d3751327..1c3adc9587117 100644 --- a/src/common/retryer.js +++ b/src/common/retryer.js @@ -25,12 +25,14 @@ const retryer = async (fetcher, variables, retries = 0) => { if (!RETRIES) { throw new CustomError("No GitHub API tokens found", CustomError.NO_TOKENS); } + if (retries > RETRIES) { throw new CustomError( "Downtime due to GitHub API rate limiting", CustomError.MAX_RETRY, ); } + try { // try to fetch with the first token since RETRIES is 0 index i'm adding +1 let response = await fetcher( @@ -39,12 +41,16 @@ const retryer = async (fetcher, variables, retries = 0) => { retries, ); - // prettier-ignore - const isRateExceeded = response.data.errors && response.data.errors[0].type === "RATE_LIMITED"; + // react on both type and message-based rate-limit signals. + const errors = response?.data?.errors; + const errorType = errors?.[0]?.type; + const errorMsg = errors?.[0]?.message || ""; + const isRateLimited = + (errors && errorType === "RATE_LIMITED") || /rate limit/i.test(errorMsg); // if rate limit is hit increase the RETRIES and recursively call the retryer // with username, and current RETRIES - if (isRateExceeded) { + if (isRateLimited) { logger.log(`PAT_${retries + 1} Failed`); retries++; // directly return from the function diff --git a/tests/retryer.test.js b/tests/retryer.test.js index b0b4bd79df857..76630039d5017 100644 --- a/tests/retryer.test.js +++ b/tests/retryer.test.js @@ -25,6 +25,27 @@ const fetcherFailOnSecondTry = jest.fn((_vars, _token, retries) => { }); }); +const fetcherFailWithMessageBasedRateLimitErr = jest.fn( + (_vars, _token, retries) => { + return new Promise((res) => { + // faking rate limit + if (retries < 1) { + return res({ + data: { + errors: [ + { + type: "ASDF", + message: "API rate limit already exceeded for user ID 11111111", + }, + ], + }, + }); + } + return res({ data: "ok" }); + }); + }, +); + describe("Test Retryer", () => { it("retryer should return value and have zero retries on first try", async () => { let res = await retryer(fetcher, {}); @@ -40,6 +61,13 @@ describe("Test Retryer", () => { expect(res).toStrictEqual({ data: "ok" }); }); + it("retryer should return value and have 2 retries with message based rate limit error", async () => { + let res = await retryer(fetcherFailWithMessageBasedRateLimitErr, {}); + + expect(fetcherFailWithMessageBasedRateLimitErr).toBeCalledTimes(2); + expect(res).toStrictEqual({ data: "ok" }); + }); + it("retryer should throw specific error if maximum retries reached", async () => { try { await retryer(fetcherFail, {}); From 6bda67effca03564eb413a6785f8828bf2a3b1ad Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Thu, 18 Sep 2025 20:57:18 +0300 Subject: [PATCH 077/265] chore: make create progress node function jsdoc shorter (#4441) Co-authored-by: Alexandr --- src/common/createProgressNode.js | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/src/common/createProgressNode.js b/src/common/createProgressNode.js index 2d7303a5a78ef..22a7ad65006e2 100644 --- a/src/common/createProgressNode.js +++ b/src/common/createProgressNode.js @@ -5,14 +5,14 @@ import { clampValue } from "./utils.js"; /** * Create a node to indicate progress in percentage along a horizontal line. * - * @param {Object} createProgressNodeParams Object that contains the createProgressNode parameters. - * @param {number} createProgressNodeParams.x X-axis position. - * @param {number} createProgressNodeParams.y Y-axis position. - * @param {number} createProgressNodeParams.width Width of progress bar. - * @param {string} createProgressNodeParams.color Progress color. - * @param {number} createProgressNodeParams.progress Progress value. - * @param {string} createProgressNodeParams.progressBarBackgroundColor Progress bar bg color. - * @param {number} createProgressNodeParams.delay Delay before animation starts. + * @param {Object} params Object that contains the createProgressNode parameters. + * @param {number} params.x X-axis position. + * @param {number} params.y Y-axis position. + * @param {number} params.width Width of progress bar. + * @param {string} params.color Progress color. + * @param {number} params.progress Progress value. + * @param {string} params.progressBarBackgroundColor Progress bar bg color. + * @param {number} params.delay Delay before animation starts. * @returns {string} Progress node. */ const createProgressNode = ({ From 4f33921e9e435814655d919f5e15708224f9331e Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Thu, 18 Sep 2025 21:12:31 +0300 Subject: [PATCH 078/265] fix: remove Chinese from long locales (#4442) Co-authored-by: Alexandr --- src/cards/stats.js | 1 - 1 file changed, 1 deletion(-) diff --git a/src/cards/stats.js b/src/cards/stats.js index 5c34360d67716..e5536601ae2ca 100644 --- a/src/cards/stats.js +++ b/src/cards/stats.js @@ -365,7 +365,6 @@ const renderStatsCard = (stats, options = {}) => { }; const longLocales = [ - "cn", "es", "fr", "pt-br", From f48a59b9bfd224a1bd939b9cd793147433a61bd2 Mon Sep 17 00:00:00 2001 From: Kornchanok Iednusorn <165641936+HKornchanok@users.noreply.github.com> Date: Fri, 19 Sep 2025 01:39:06 +0700 Subject: [PATCH 079/265] feat: add Thai translations (#4247) * Add locale th to translations.js * add Locale th to readme.md --------- Co-authored-by: Alexandr --- readme.md | 1 + src/translations.js | 22 ++++++++++++++++++++++ 2 files changed, 23 insertions(+) diff --git a/readme.md b/readme.md index da7a524f8aa8b..7b661b95589dc 100644 --- a/readme.md +++ b/readme.md @@ -341,6 +341,7 @@ Here is a list of all available locales: | `my` | Burmese | | `sk` | Slovak | | `tr` | Turkish | +| `th` | Thai | | `pl` | Polish | | `uz` | Uzbek | | `vi` | Vietnamese | diff --git a/src/translations.js b/src/translations.js index 4a294404c7d73..cd38bb424ba6b 100644 --- a/src/translations.js +++ b/src/translations.js @@ -49,6 +49,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: `${encodedName}ning GitHub'dagi statistikasi`, vi: `Thống Kê GitHub ${encodedName}`, se: `GitHubstatistik för ${encodedName}`, + th: `สถิติ GitHub ของ ${encodedName}`, sr: `GitHub статистика корисника ${encodedName}`, no: `GitHub-statistikk for ${encodedName}`, }, @@ -86,6 +87,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: `${encodedName}ning GitHub'dagi statistikasi`, vi: `Thống Kê GitHub ${encodedName}`, se: `GitHubstatistik för ${encodedName}`, + th: `อันดับ GitHub ของ ${encodedName}`, sr: `Ранк корисника ${encodedName}`, no: `GitHub-statistikk for ${encodedName}`, }, @@ -123,6 +125,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "Yulduzchalar", vi: "Tổng Số Sao", se: "Antal intjänade stjärnor", + th: "ดาวทั้งหมดที่ได้รับ", sr: "Број освојених звездица", no: "Totalt antall stjerner", }, @@ -160,6 +163,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "'Commit'lar", vi: "Tổng Số Cam Kết", se: "Totalt antal commits", + th: "Commit ทั้งหมด", sr: "Укупан број коммитова", no: "Totalt antall commits", }, @@ -197,6 +201,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "'Pull Request'lar", vi: "Tổng Số PR", se: "Totalt antal PR", + th: "PR ทั้งหมด", sr: "Укупно PRова", no: "Totalt antall PR", }, @@ -234,6 +239,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "'Issue'lar", vi: "Tổng Số Vấn Đề", se: "Total antal issues", + th: "Issue ทั้งหมด", sr: "Укупно пријављених проблема", no: "Totalt antall issues", }, @@ -271,6 +277,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "Hissa qoʻshgan (o'tgan yili)", vi: "Đã Đóng Góp (năm ngoái)", se: "Bidragit till (förra året)", + th: "มีส่วนร่วมใน (ปีที่แล้ว)", sr: "Контрибуирано (прошле године)", no: "Bidro til (i fjor)", }, @@ -308,6 +315,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "Koʻrib chiqilgan PR-lar soni", vi: "Tổng Số PR Đã Xem Xét", se: "Totalt antal granskade PR", + th: "รีวิว PR แล้วทั้งหมด", sr: "Укупно прегледаних PRова", no: "Totalt antall vurderte PR", }, @@ -345,6 +353,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "Boshlangan muzokaralar soni", vi: "Tổng Số Thảo Luận Bắt Đầu", se: "Totalt antal diskussioner startade", + th: "เริ่มหัวข้อสนทนาทั้งหมด", sr: "Укупно покренутих дискусија", no: "Totalt antall startede diskusjoner", }, @@ -382,6 +391,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "Javob berilgan muzokaralar soni", vi: "Tổng Số Thảo Luận Đã Trả Lời", se: "Totalt antal diskussioner besvarade", + th: "ตอบกลับหัวข้อสนทนาทั้งหมด", sr: "Укупно одговорених дискусија", no: "Totalt antall besvarte diskusjoner", }, @@ -418,6 +428,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "Birlangan PR-lar soni", vi: "Tổng Số PR Đã Hợp Nhất", se: "Totalt antal sammanfogade PR", + th: "PR ที่ถูก Merged แล้วทั้งหมด", sr: "Укупно обједињених PRова", no: "Totalt antall sammenslåtte PR", }, @@ -454,6 +465,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "Birlangan PR-lar foizi", vi: "Tỷ Lệ PR Đã Hợp Nhất", se: "Procent av sammanfogade PR", + th: "เปอร์เซ็นต์ PR ที่ถูก Merged แล้วทั้งหมด", sr: "Проценат обједињених PRова", no: "Prosentandel sammenslåtte PR", }, @@ -495,6 +507,7 @@ const repoCardLocales = { uz: "Shablon", vi: "Mẫu", se: "Mall", + th: "เทมเพลต", sr: "Шаблон", no: "Mal", }, @@ -532,6 +545,7 @@ const repoCardLocales = { uz: "Arxivlangan", vi: "Đã Lưu Trữ", se: "Arkiverade", + th: "เก็บถาวร", sr: "Архивирано", no: "Arkivert", }, @@ -572,6 +586,7 @@ const langCardLocales = { uz: "Eng koʻp ishlatiladigan tillar", vi: "Ngôn Ngữ Thường Sử Dụng", se: "Mest använda språken", + th: "ภาษาที่ใช้บ่อยที่สุด", sr: "Најкоришћенији језици", no: "Mest brukte språk", }, @@ -609,6 +624,7 @@ const langCardLocales = { uz: "Til haqida ma'lumot yo'q.", vi: "Không có dữ liệu ngôn ngữ.", se: "Inga språkdata.", + th: "ไม่มีข้อมูลภาษา", sr: "Нема података о језицима.", no: "Ingen språkdata.", }, @@ -649,6 +665,7 @@ const wakatimeCardLocales = { uz: "WakaTime statistikasi", vi: "Thống Kê WakaTime", se: "WakaTime statistik", + th: "สถิติ WakaTime", sr: "WakaTime статистика", no: "WakaTime-statistikk", }, @@ -686,6 +703,7 @@ const wakatimeCardLocales = { uz: "O'tgan yil", vi: "Năm ngoái", se: "Förra året", + th: "ปีที่แล้ว", sr: "Претходна година", no: "I fjor", }, @@ -723,6 +741,7 @@ const wakatimeCardLocales = { uz: "O'tgan 7 kun", vi: "7 ngày qua", se: "Senaste 7 dagarna", + th: "7 วันที่ผ่านมา", sr: "Претходних 7 дана", no: "Siste 7 dager", }, @@ -760,6 +779,7 @@ const wakatimeCardLocales = { uz: "WakaTime foydalanuvchi profili ochiq emas", vi: "Hồ sơ người dùng WakaTime không công khai", se: "WakaTime användarprofil inte offentlig", + th: "โปรไฟล์ผู้ใช้ WakaTime ไม่ได้เป็นสาธารณะ", sr: "WakaTime профил корисника није јаван", no: "WakaTime brukerprofil ikke offentlig", }, @@ -799,6 +819,7 @@ const wakatimeCardLocales = { uz: "Foydalanuvchi umumiy ko`d statistikasini ochiq ravishda almashmaydi", vi: "Người dùng không chia sẻ thống kê mã chi tiết công khai", se: "Användaren delar inte offentligt detaljerad kodstatistik", + th: "ผู้ใช้ไม่ได้แชร์สถิติโค้ดแบบสาธารณะ", sr: "Корисник не дели јавно детаљну статистику кода", no: "Brukeren deler ikke detaljert kodestatistikk offentlig", }, @@ -836,6 +857,7 @@ const wakatimeCardLocales = { uz: "Bu hafta faol bo'lmadi", vi: "Không Có Hoạt Động Trong Tuần Này", se: "Ingen aktivitet denna vecka", + th: "ไม่มีกิจกรรมการเขียนโค้ดในสัปดาห์นี้", sr: "Током ове недеље није било никаквих активности", no: "Ingen kodeaktivitet denne uken", }, From 3e6ce83a42c01c5cf3d552105493095a91827657 Mon Sep 17 00:00:00 2001 From: Vaibhav Verma <143488352+VaibhavVermaa16@users.noreply.github.com> Date: Fri, 19 Sep 2025 00:39:18 +0530 Subject: [PATCH 080/265] feat: add Hindi translations (#3985) * Update readme.md Added hindi language in available locales. * Update translations.js Added hindi language * prettier * Update src/translations.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update src/translations.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update src/translations.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update src/translations.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update src/translations.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update src/translations.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update src/translations.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update src/translations.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update src/translations.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update src/translations.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --------- Co-authored-by: Alexandr Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --- readme.md | 1 + src/translations.js | 22 ++++++++++++++++++++++ 2 files changed, 23 insertions(+) diff --git a/readme.md b/readme.md index 7b661b95589dc..670bdd6d5a70e 100644 --- a/readme.md +++ b/readme.md @@ -314,6 +314,7 @@ Here is a list of all available locales: | `hu` | Hungarian | | `fi` | Finnish | | `sr` | Serbian | +| `hi` | Hindi | diff --git a/src/translations.js b/src/translations.js index cd38bb424ba6b..ef9833cc13e75 100644 --- a/src/translations.js +++ b/src/translations.js @@ -28,6 +28,7 @@ const statCardLocales = ({ name, apostrophe }) => { fa: `آمار گیت‌هاب ${encodedName}`, fi: `${encodedName}:n GitHub-tilastot`, fr: `Statistiques GitHub de ${encodedName}`, + hi: `${encodedName} के GitHub आँकड़े`, hu: `${encodedName} GitHub statisztika`, it: `Statistiche GitHub di ${encodedName}`, ja: `${encodedName}の GitHub 統計`, @@ -66,6 +67,7 @@ const statCardLocales = ({ name, apostrophe }) => { fa: `رتبه گیت‌هاب ${encodedName}`, fi: `${encodedName}:n GitHub-sijoitus`, fr: `Statistiques GitHub de ${encodedName}`, + hi: `${encodedName} का GitHub स्थान`, hu: `${encodedName} GitHub statisztika`, it: `Statistiche GitHub di ${encodedName}`, ja: `${encodedName} の GitHub ランク`, @@ -104,6 +106,7 @@ const statCardLocales = ({ name, apostrophe }) => { fa: "مجموع ستاره‌های دریافت‌شده", fi: "Ansaitut tähdet yhteensä", fr: "Total d'étoiles", + hi: "कुल अर्जित सितारे", hu: "Csillagok", it: "Stelle totali", ja: "スターされた数", @@ -142,6 +145,7 @@ const statCardLocales = ({ name, apostrophe }) => { fa: "مجموع کامیت‌ها", fi: "Yhteensä committeja", fr: "Total des Commits", + hi: "कुल commits", hu: "Összes commit", it: "Commit totali", ja: "合計コミット数", @@ -180,6 +184,7 @@ const statCardLocales = ({ name, apostrophe }) => { fa: "مجموع Pull Request", fi: "Yhteensä PR:t", fr: "Total des PRs", + hi: "कुल PR", hu: "Összes PR", it: "PR totali", ja: "合計 PR", @@ -218,6 +223,7 @@ const statCardLocales = ({ name, apostrophe }) => { fa: "مجموع مسائل", fi: "Yhteensä ongelmat", fr: "Nombre total d'incidents", + hi: "कुल मुद्दे", hu: "Összes hibajegy", it: "Segnalazioni totali", ja: "合計 issue", @@ -256,6 +262,7 @@ const statCardLocales = ({ name, apostrophe }) => { fa: "مشارکت در (سال گذشته)", fi: "Osallistunut (viime vuonna)", fr: "Contribué à (l'année dernière)", + hi: "(पिछले वर्ष) में योगदान दिया", hu: "Hozzájárulások (tavaly)", it: "Ha contribuito a (l'anno scorso)", ja: "貢献したリポジトリ (昨年)", @@ -294,6 +301,7 @@ const statCardLocales = ({ name, apostrophe }) => { fa: "مجموع درخواست‌های ادغام بررسی‌شده", fi: "Yhteensä tarkastettuja PR:itä", fr: "Nombre total de PR examinés", + hi: "कुल PRs की समीक्षा की गई", hu: "Összes ellenőrzött PR", it: "PR totali esaminati", ja: "レビューされた PR の総数", @@ -332,6 +340,7 @@ const statCardLocales = ({ name, apostrophe }) => { fa: "مجموع بحث‌های آغازشده", fi: "Aloitetut keskustelut yhteensä", fr: "Nombre total de discussions lancées", + hi: "कुल चर्चा शुरू हुई", hu: "Összes megkezdett megbeszélés", it: "Discussioni totali avviate", ja: "開始されたディスカッションの総数", @@ -370,6 +379,7 @@ const statCardLocales = ({ name, apostrophe }) => { fa: "مجموع بحث‌های پاسخ‌داده‌شده", fi: "Vastatut keskustelut yhteensä", fr: "Nombre total de discussions répondues", + hi: "कुल चर्चाओं का उत्तर दिया गया", hu: "Összes megválaszolt megbeszélés", it: "Discussioni totali risposte", ja: "回答されたディスカッションの総数", @@ -408,6 +418,7 @@ const statCardLocales = ({ name, apostrophe }) => { fa: "مجموع درخواست‌های ادغام شده", fi: "Yhteensä yhdistetyt PR:t", fr: "Nombre total de PR fusionnés", + hi: "कुल PR का विलय", hu: "Összes egyesített PR", it: "PR totali uniti", ja: "マージされた PR の総数", @@ -445,6 +456,7 @@ const statCardLocales = ({ name, apostrophe }) => { fa: "درصد درخواست‌های ادغام‌شده", fi: "Yhdistettyjen PR:ien prosentti", fr: "Pourcentage de PR fusionnés", + hi: "मर्ज किए गए PR प्रतिशत", hu: "Egyesített PR-k százaléka", it: "Percentuale di PR uniti", ja: "マージされた PR の割合", @@ -486,6 +498,7 @@ const repoCardLocales = { fa: "الگو", fi: "Malli", fr: "Modèle", + hi: "खाका", hu: "Sablon", it: "Template", ja: "テンプレート", @@ -524,6 +537,7 @@ const repoCardLocales = { fa: "بایگانی‌شده", fi: "Arkistoitu", fr: "Archivé", + hi: "संग्रहीत", hu: "Archivált", it: "Archiviata", ja: "アーカイブ済み", @@ -565,6 +579,7 @@ const langCardLocales = { fa: "زبان‌های پرکاربرد", fi: "Käytetyimmät kielet", fr: "Langages les plus utilisés", + hi: "सर्वाधिक प्रयुक्त भाषा", hu: "Leggyakrabban használt nyelvek", it: "Linguaggi più utilizzati", ja: "最もよく使っている言語", @@ -603,6 +618,7 @@ const langCardLocales = { fa: "داده‌ای برای زبان‌ها وجود ندارد.", fi: "Ei kielitietoja.", fr: "Aucune donnée sur les langues.", + hi: "कोई भाषा डेटा नहीं", hu: "Nincsenek nyelvi adatok.", it: "Nessun dato sulle lingue.", ja: "言語データがありません。", @@ -644,6 +660,7 @@ const wakatimeCardLocales = { fa: "آمار WakaTime", fi: "WakaTime-tilastot", fr: "Statistiques de WakaTime", + hi: "वाकाटाइम आँकड़े", hu: "WakaTime statisztika", it: "Statistiche WakaTime", ja: "WakaTime ワカタイム統計", @@ -682,6 +699,7 @@ const wakatimeCardLocales = { fa: "سال گذشته", fi: "Viime vuosi", fr: "L'année dernière", + hi: "पिछले साल", hu: "Tavaly", it: "L'anno scorso", ja: "昨年", @@ -720,6 +738,7 @@ const wakatimeCardLocales = { fa: "هفت روز گذشته", fi: "Viimeiset 7 päivää", fr: "7 derniers jours", + hi: "पिछले 7 दिन", hu: "Elmúlt 7 nap", it: "Ultimi 7 giorni", ja: "過去 7 日間", @@ -758,6 +777,7 @@ const wakatimeCardLocales = { fa: "پروفایل کاربری WakaTime عمومی نیست", fi: "WakaTime-käyttäjäprofiili ei ole julkinen", fr: "Profil utilisateur WakaTime non public", + hi: "WakaTime उपयोगकर्ता प्रोफ़ाइल सार्वजनिक नहीं है", hu: "A WakaTime felhasználói profilja nem nyilvános", it: "Profilo utente WakaTime non pubblico", ja: "WakaTime ユーザープロファイルは公開されていません", @@ -796,6 +816,7 @@ const wakatimeCardLocales = { fa: "کاربر آمار کد تفصیلی را به‌صورت عمومی به اشتراک نمی‌گذارد", fi: "Käyttäjä ei jaa julkisesti tarkkoja kooditilastoja", fr: "L'utilisateur ne partage pas publiquement de statistiques de code détaillées", + hi: "उपयोगकर्ता विस्तृत कोड आँकड़े सार्वजनिक रूप से साझा नहीं करता है", hu: "A felhasználó nem osztja meg nyilvánosan a részletes kódstatisztikákat", it: "L'utente non condivide pubblicamente statistiche dettagliate sul codice", ja: "ユーザーは詳細なコード統計を公開しません", @@ -836,6 +857,7 @@ const wakatimeCardLocales = { fa: "فعالیت کدنویسی در این هفته وجود ندارد", fi: "Ei koodaustoimintaa tällä viikolla", fr: "Aucune activité de codage cette semaine", + hi: "इस सप्ताह कोई कोडिंग गतिविधि नहीं", hu: "Nem volt aktivitás ezen a héten", it: "Nessuna attività in questa settimana", ja: "今週のコーディング活動はありません", From 68e5862b0b2e9cdb688209050c2da23f5726dc8f Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Fri, 19 Sep 2025 18:38:29 +0300 Subject: [PATCH 081/265] docs: sort list of available languages alphabetically inside readme (#4445) * docs: sort list of available languages alphabetically inside readme * dev --------- Co-authored-by: Alexandr --- readme.md | 46 +++++++++++++++++++++++----------------------- 1 file changed, 23 insertions(+), 23 deletions(-) diff --git a/readme.md b/readme.md index 670bdd6d5a70e..8d53b8f94fad6 100644 --- a/readme.md +++ b/readme.md @@ -302,53 +302,53 @@ Here is a list of all available locales: | Code | Locale | | --- | --- | +| `ar` | Arabic | +| `az` | Azerbaijani | +| `bn` | Bengali | +| `my` | Burmese | | `cn` | Chinese | | `zh-tw` | Chinese (Taiwan) | -| `ar` | Arabic | | `cs` | Czech | -| `de` | German | +| `nl` | Dutch | | `en` | English | -| `bn` | Bengali | -| `es` | Spanish | -| `fr` | French | -| `hu` | Hungarian | | `fi` | Finnish | -| `sr` | Serbian | -| `hi` | Hindi | +| `fr` | French | +| `de` | German | +| `el` | Greek | | Code | Locale | | --- | --- | +| `hi` | Hindi | +| `hu` | Hungarian | +| `id` | Indonesian | | `it` | Italian | | `ja` | Japanese | | `kr` | Korean | -| `nl` | Dutch | -| `pt-pt` | Portuguese (Portugal) | -| `pt-br` | Portuguese (Brazil) | +| `ml` | Malayalam | | `np` | Nepali | -| `el` | Greek | -| `ru` | Russian | -| `uk-ua` | Ukrainian | -| `ro` | Romanian | +| `no` | Norwegian | | `fa` | Persian (Farsi) | +| `pl` | Polish | +| `pt-br` | Portuguese (Brazil) | | Code | Locale | | --- | --- | -| `id` | Indonesian | -| `ml` | Malayalam | -| `my` | Burmese | +| `pt-pt` | Portuguese (Portugal) | +| `ro` | Romanian | +| `ru` | Russian | +| `sr` | Serbian | | `sk` | Slovak | -| `tr` | Turkish | +| `es` | Spanish | +| `se` | Swedish | | `th` | Thai | -| `pl` | Polish | +| `tr` | Turkish | +| `uk-ua` | Ukrainian | | `uz` | Uzbek | | `vi` | Vietnamese | -| `se` | Swedish | -| `az` | Azerbaijani | -| `no` | Norwegian | From c3585cc1d07404a1e00cd571c2b380000da7d4e3 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Fri, 19 Sep 2025 18:39:29 +0300 Subject: [PATCH 082/265] chore: sort stats card long locales alphabetically (#4446) Co-authored-by: Alexandr --- src/cards/stats.js | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/src/cards/stats.js b/src/cards/stats.js index e5536601ae2ca..c54f81ca5b8eb 100644 --- a/src/cards/stats.js +++ b/src/cards/stats.js @@ -365,20 +365,20 @@ const renderStatsCard = (stats, options = {}) => { }; const longLocales = [ + "de", "es", "fr", - "pt-br", - "ru", - "uk-ua", "id", "ml", "my", - "pl", - "de", "nl", - "zh-tw", - "uz", + "pl", + "pt-br", + "ru", "sr", + "uk-ua", + "uz", + "zh-tw", ]; const isLongLocale = locale ? longLocales.includes(locale) : false; From e91880231de9683c421b80cfc9132a38e97109df Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Fri, 19 Sep 2025 18:41:22 +0300 Subject: [PATCH 083/265] chore: move original english translations to the top for convenience during development (#4447) Co-authored-by: Alexandr --- src/translations.js | 44 ++++++++++++++++++++++---------------------- 1 file changed, 22 insertions(+), 22 deletions(-) diff --git a/src/translations.js b/src/translations.js index ef9833cc13e75..6f5b0c8247b16 100644 --- a/src/translations.js +++ b/src/translations.js @@ -16,13 +16,13 @@ const statCardLocales = ({ name, apostrophe }) => { const encodedName = encodeHTML(name); return { "statcard.title": { + en: `${encodedName}'${apostrophe} GitHub Stats`, ar: `${encodedName} إحصائيات جيت هاب`, az: `${encodedName}'${apostrophe} Hesabının GitHub Statistikası`, cn: `${encodedName} 的 GitHub 统计数据`, "zh-tw": `${encodedName} 的 GitHub 統計資料`, cs: `GitHub statistiky uživatele ${encodedName}`, de: `${encodedName + apostrophe} GitHub-Statistiken`, - en: `${encodedName}'${apostrophe} GitHub Stats`, bn: `${encodedName} এর GitHub পরিসংখ্যান`, es: `Estadísticas de GitHub de ${encodedName}`, fa: `آمار گیت‌هاب ${encodedName}`, @@ -55,13 +55,13 @@ const statCardLocales = ({ name, apostrophe }) => { no: `GitHub-statistikk for ${encodedName}`, }, "statcard.ranktitle": { + en: `${encodedName}'${apostrophe} GitHub Rank`, ar: `${encodedName} إحصائيات جيت هاب`, az: `${encodedName}'${apostrophe} Hesabının GitHub Statistikası`, cn: `${encodedName} 的 GitHub 统计数据`, "zh-tw": `${encodedName} 的 GitHub 統計資料`, cs: `GitHub statistiky uživatele ${encodedName}`, de: `${encodedName + apostrophe} GitHub-Statistiken`, - en: `${encodedName}'${apostrophe} GitHub Rank`, bn: `${encodedName} এর GitHub পরিসংখ্যান`, es: `Estadísticas de GitHub de ${encodedName}`, fa: `رتبه گیت‌هاب ${encodedName}`, @@ -94,13 +94,13 @@ const statCardLocales = ({ name, apostrophe }) => { no: `GitHub-statistikk for ${encodedName}`, }, "statcard.totalstars": { + en: "Total Stars Earned", ar: "مجموع النجوم", az: "Ümumi Ulduz", cn: "获标星数", "zh-tw": "得標星星數量(Star)", cs: "Celkem hvězd", de: "Insgesamt erhaltene Sterne", - en: "Total Stars Earned", bn: "সর্বমোট Star", es: "Estrellas totales", fa: "مجموع ستاره‌های دریافت‌شده", @@ -133,13 +133,13 @@ const statCardLocales = ({ name, apostrophe }) => { no: "Totalt antall stjerner", }, "statcard.commits": { + en: "Total Commits", ar: "مجموع المساهمات", az: "Ümumi Commit", cn: "累计提交总数", "zh-tw": "累計提交數量(Commit)", cs: "Celkem commitů", de: "Anzahl Commits", - en: "Total Commits", bn: "সর্বমোট Commit", es: "Commits totales", fa: "مجموع کامیت‌ها", @@ -172,13 +172,13 @@ const statCardLocales = ({ name, apostrophe }) => { no: "Totalt antall commits", }, "statcard.prs": { + en: "Total PRs", ar: "مجموع طلبات السحب", az: "Ümumi PR", cn: "发起的 PR 总数", "zh-tw": "拉取請求數量(PR)", cs: "Celkem PRs", de: "PRs Insgesamt", - en: "Total PRs", bn: "সর্বমোট PR", es: "PRs totales", fa: "مجموع Pull Request", @@ -211,13 +211,13 @@ const statCardLocales = ({ name, apostrophe }) => { no: "Totalt antall PR", }, "statcard.issues": { + en: "Total Issues", ar: "مجموع التحسينات", az: "Ümumi Problem", cn: "提出的 issue 总数", "zh-tw": "提出問題數量(Issue)", cs: "Celkem problémů", de: "Anzahl Issues", - en: "Total Issues", bn: "সর্বমোট Issue", es: "Issues totales", fa: "مجموع مسائل", @@ -250,13 +250,13 @@ const statCardLocales = ({ name, apostrophe }) => { no: "Totalt antall issues", }, "statcard.contribs": { + en: "Contributed to (last year)", ar: "ساهم في (العام الماضي)", az: "Töhfə verdi (ötən il)", cn: "贡献的项目数(去年)", "zh-tw": "參與項目數量(去年)", cs: "Přispěl k (minulý rok)", de: "Beigetragen zu (letztes Jahr)", - en: "Contributed to (last year)", bn: "অবদান (গত বছর)", es: "Contribuciones en (el año pasado)", fa: "مشارکت در (سال گذشته)", @@ -289,13 +289,13 @@ const statCardLocales = ({ name, apostrophe }) => { no: "Bidro til (i fjor)", }, "statcard.reviews": { + en: "Total PRs Reviewed", ar: "طلبات السحب التي تم مراجعتها", az: "Nəzərdən Keçirilən Ümumi PR", cn: "审查的 PR 总数", "zh-tw": "審核的 PR 總計", cs: "Celkový počet PR", de: "Insgesamt überprüfte PRs", - en: "Total PRs Reviewed", bn: "সর্বমোট পুনরালোচনা করা PR", es: "PR totales revisados", fa: "مجموع درخواست‌های ادغام بررسی‌شده", @@ -328,13 +328,13 @@ const statCardLocales = ({ name, apostrophe }) => { no: "Totalt antall vurderte PR", }, "statcard.discussions-started": { + en: "Total Discussions Started", ar: "مجموع المناقشات التي بدأها", az: "Başladılan Ümumi Müzakirə", cn: "发起的讨论总数", "zh-tw": "發起的討論總數", cs: "Celkem zahájených diskusí", de: "Gesamt gestartete Diskussionen", - en: "Total Discussions Started", bn: "সর্বমোট আলোচনা শুরু", es: "Discusiones totales iniciadas", fa: "مجموع بحث‌های آغازشده", @@ -367,13 +367,13 @@ const statCardLocales = ({ name, apostrophe }) => { no: "Totalt antall startede diskusjoner", }, "statcard.discussions-answered": { + en: "Total Discussions Answered", ar: "مجموع المناقشات المُجابة", az: "Cavablandırılan Ümumi Müzakirə", cn: "回复的讨论总数", "zh-tw": "回覆討論總計", cs: "Celkem zodpovězených diskusí", de: "Gesamt beantwortete Diskussionen", - en: "Total Discussions Answered", bn: "সর্বমোট আলোচনা উত্তর", es: "Discusiones totales respondidas", fa: "مجموع بحث‌های پاسخ‌داده‌شده", @@ -406,13 +406,13 @@ const statCardLocales = ({ name, apostrophe }) => { no: "Totalt antall besvarte diskusjoner", }, "statcard.prs-merged": { + en: "Total PRs Merged", ar: "مجموع طلبات السحب المُدمجة", az: "Birləşdirilmiş Ümumi PR", cn: "合并的 PR 总数", "zh-tw": "合併的 PR 總計", cs: "Celkem sloučených PR", de: "Insgesamt zusammengeführte PRs", - en: "Total PRs Merged", bn: "সর্বমোট PR একত্রীকৃত", es: "PR totales fusionados", fa: "مجموع درخواست‌های ادغام شده", @@ -444,13 +444,13 @@ const statCardLocales = ({ name, apostrophe }) => { no: "Totalt antall sammenslåtte PR", }, "statcard.prs-merged-percentage": { + en: "Merged PRs Percentage", ar: "نسبة طلبات السحب المُدمجة", az: "Birləşdirilmiş PR-ların Faizi", cn: "被合并的 PR 占比", "zh-tw": "合併的 PR 百分比", cs: "Sloučené PRs v procentech", de: "Zusammengeführte PRs in Prozent", - en: "Merged PRs Percentage", bn: "PR একত্রীকরণের শতাংশ", es: "Porcentaje de PR fusionados", fa: "درصد درخواست‌های ادغام‌شده", @@ -486,6 +486,7 @@ const statCardLocales = ({ name, apostrophe }) => { const repoCardLocales = { "repocard.template": { + en: "Template", ar: "قالب", az: "Şablon", bn: "টেমপ্লেট", @@ -493,7 +494,6 @@ const repoCardLocales = { "zh-tw": "模板", cs: "Šablona", de: "Vorlage", - en: "Template", es: "Plantilla", fa: "الگو", fi: "Malli", @@ -525,6 +525,7 @@ const repoCardLocales = { no: "Mal", }, "repocard.archived": { + en: "Archived", ar: "مُؤرشف", az: "Arxiv", bn: "আর্কাইভড", @@ -532,7 +533,6 @@ const repoCardLocales = { "zh-tw": "已封存", cs: "Archivováno", de: "Archiviert", - en: "Archived", es: "Archivados", fa: "بایگانی‌شده", fi: "Arkistoitu", @@ -567,6 +567,7 @@ const repoCardLocales = { const langCardLocales = { "langcard.title": { + en: "Most Used Languages", ar: "أكثر اللغات استخدامًا", az: "Ən Çox İstifadə Olunan Dillər", cn: "最常用的语言", @@ -574,7 +575,6 @@ const langCardLocales = { cs: "Nejpoužívanější jazyky", de: "Meist verwendete Sprachen", bn: "সর্বাধিক ব্যবহৃত ভাষা সমূহ", - en: "Most Used Languages", es: "Lenguajes más usados", fa: "زبان‌های پرکاربرد", fi: "Käytetyimmät kielet", @@ -606,6 +606,7 @@ const langCardLocales = { no: "Mest brukte språk", }, "langcard.nodata": { + en: "No languages data.", ar: "لا توجد بيانات للغات.", az: "Dil məlumatı yoxdur.", cn: "没有语言数据。", @@ -613,7 +614,6 @@ const langCardLocales = { cs: "Žádné jazykové údaje.", de: "Keine Sprachdaten.", bn: "কোন ভাষার ডেটা নেই।", - en: "No languages data.", es: "Sin datos de idiomas.", fa: "داده‌ای برای زبان‌ها وجود ندارد.", fi: "Ei kielitietoja.", @@ -648,13 +648,13 @@ const langCardLocales = { const wakatimeCardLocales = { "wakatimecard.title": { + en: "WakaTime Stats", ar: "إحصائيات واكا تايم", az: "WakaTime Statistikası", cn: "WakaTime 周统计", "zh-tw": "WakaTime 周統計", cs: "Statistiky WakaTime", de: "WakaTime Status", - en: "WakaTime Stats", bn: "WakaTime স্ট্যাটাস", es: "Estadísticas de WakaTime", fa: "آمار WakaTime", @@ -687,13 +687,13 @@ const wakatimeCardLocales = { no: "WakaTime-statistikk", }, "wakatimecard.lastyear": { + en: "last year", ar: "العام الماضي", az: "Ötən il", cn: "去年", "zh-tw": "去年", cs: "Minulý rok", de: "Letztes Jahr", - en: "last year", bn: "গত বছর", es: "El año pasado", fa: "سال گذشته", @@ -726,13 +726,13 @@ const wakatimeCardLocales = { no: "I fjor", }, "wakatimecard.last7days": { + en: "last 7 days", ar: "آخر 7 أيام", az: "Son 7 gün", cn: "最近 7 天", "zh-tw": "最近 7 天", cs: "Posledních 7 dní", de: "Letzte 7 Tage", - en: "last 7 days", bn: "গত ৭ দিন", es: "Últimos 7 días", fa: "هفت روز گذشته", @@ -765,13 +765,13 @@ const wakatimeCardLocales = { no: "Siste 7 dager", }, "wakatimecard.notpublic": { + en: "WakaTime user profile not public", ar: "ملف مستخدم واكا تايم شخصي", az: "WakaTime istifadəçi profili ictimai deyil", cn: "WakaTime 用户个人资料未公开", "zh-tw": "WakaTime 使用者個人資料未公開", cs: "Profil uživatele WakaTime není veřejný", de: "WakaTime-Benutzerprofil nicht öffentlich", - en: "WakaTime user profile not public", bn: "WakaTime ব্যবহারকারীর প্রোফাইল প্রকাশ্য নয়", es: "Perfil de usuario de WakaTime no público", fa: "پروفایل کاربری WakaTime عمومی نیست", @@ -804,13 +804,13 @@ const wakatimeCardLocales = { no: "WakaTime brukerprofil ikke offentlig", }, "wakatimecard.nocodedetails": { + en: "User doesn't publicly share detailed code statistics", ar: "المستخدم لا يشارك المعلومات التفصيلية", az: "İstifadəçi kod statistikalarını ictimai şəkildə paylaşmır", cn: "用户不公开分享详细的代码统计信息", "zh-tw": "使用者不公開分享詳細的程式碼統計資訊", cs: "Uživatel nesdílí podrobné statistiky kódu", de: "Benutzer teilt keine detaillierten Code-Statistiken", - en: "User doesn't publicly share detailed code statistics", bn: "ব্যবহারকারী বিস্তারিত কোড পরিসংখ্যান প্রকাশ করেন না", es: "El usuario no comparte públicamente estadísticas detalladas de código", fa: "کاربر آمار کد تفصیلی را به‌صورت عمومی به اشتراک نمی‌گذارد", @@ -845,13 +845,13 @@ const wakatimeCardLocales = { no: "Brukeren deler ikke detaljert kodestatistikk offentlig", }, "wakatimecard.nocodingactivity": { + en: "No coding activity this week", ar: "لا يوجد نشاط برمجي لهذا الأسبوع", az: "Bu həftə heç bir kodlaşdırma fəaliyyəti olmayıb", cn: "本周没有编程活动", "zh-tw": "本周沒有編程活動", cs: "Tento týden žádná aktivita v kódování", de: "Keine Aktivitäten in dieser Woche", - en: "No coding activity this week", bn: "এই সপ্তাহে কোন কোডিং অ্যাক্টিভিটি নেই", es: "No hay actividad de codificación esta semana", fa: "فعالیت کدنویسی در این هفته وجود ندارد", From 51664ce7fa401505c389ca6998749841f9f402af Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Fri, 19 Sep 2025 22:37:29 +0300 Subject: [PATCH 084/265] tests(e2e): fix gist description (#4450) Co-authored-by: Alexandr --- tests/e2e/e2e.test.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tests/e2e/e2e.test.js b/tests/e2e/e2e.test.js index e3970aae285fd..10517759b8f21 100644 --- a/tests/e2e/e2e.test.js +++ b/tests/e2e/e2e.test.js @@ -96,7 +96,7 @@ const GIST_DATA = { name: "link.txt", nameWithOwner: "qwerty541/link.txt", description: - "Trying to access this path on Windown 10 ver. 1803+ will breaks NTFS", + "Trying to access this path on Windows 10 ver. 1803+ will breaks NTFS", language: "Text", starsCount: 1, forksCount: 0, From 42130f1f96b29b9cf95d6c9f44c53a245b2b2f29 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Fri, 19 Sep 2025 22:40:40 +0300 Subject: [PATCH 085/265] fix: mark Portuguese locale as long for stats card (#4451) Co-authored-by: Alexandr --- src/cards/stats.js | 1 + 1 file changed, 1 insertion(+) diff --git a/src/cards/stats.js b/src/cards/stats.js index c54f81ca5b8eb..67e71aef52114 100644 --- a/src/cards/stats.js +++ b/src/cards/stats.js @@ -374,6 +374,7 @@ const renderStatsCard = (stats, options = {}) => { "nl", "pl", "pt-br", + "pt-pt", "ru", "sr", "uk-ua", From 4859cc76890c1b417aed57bd13a80e3bbd5c0d17 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Wed, 24 Sep 2025 21:28:44 +0300 Subject: [PATCH 086/265] ci: restrict repositories for theme pull requests closer workflow (#4463) Co-authored-by: Alexandr --- .github/workflows/theme-prs-closer.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/theme-prs-closer.yml b/.github/workflows/theme-prs-closer.yml index ce75833eb2908..568bd10a1403c 100644 --- a/.github/workflows/theme-prs-closer.yml +++ b/.github/workflows/theme-prs-closer.yml @@ -21,8 +21,8 @@ permissions: jobs: close-prs: + if: github.repository == 'anuraghazra/github-readme-stats' runs-on: ubuntu-latest - steps: - name: Check out the code uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 From 3dd8095d5c6a3093e708fa094bf2882638436bf4 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Wed, 24 Sep 2025 21:30:02 +0300 Subject: [PATCH 087/265] ci: set proper trigger event for theme pull requests closer workflow (#4464) Co-authored-by: Alexandr --- .github/workflows/theme-prs-closer.yml | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/.github/workflows/theme-prs-closer.yml b/.github/workflows/theme-prs-closer.yml index 568bd10a1403c..10e9097abd612 100644 --- a/.github/workflows/theme-prs-closer.yml +++ b/.github/workflows/theme-prs-closer.yml @@ -1,9 +1,7 @@ name: Theme Pull Requests Closer on: - pull_request: - types: - - labeled + - pull_request_target permissions: actions: read From be0dba89869547663dca88e00e6ce3cebc757e62 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Wed, 24 Sep 2025 21:31:53 +0300 Subject: [PATCH 088/265] ci: update message in theme pull requests closer workflow (#4465) Co-authored-by: Alexandr --- .github/workflows/theme-prs-closer.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/theme-prs-closer.yml b/.github/workflows/theme-prs-closer.yml index 10e9097abd612..cab367ea30d0c 100644 --- a/.github/workflows/theme-prs-closer.yml +++ b/.github/workflows/theme-prs-closer.yml @@ -32,7 +32,7 @@ jobs: - name: Close Pull Requests run: | - comment_message="We are currently pausing addition of new themes. If this theme is exclusively for your personal use, then instead of adding it to our theme collection, you can use card customization options." + comment_message="We are currently pausing addition of new themes. If this theme is exclusively for your personal use, then instead of adding it to our theme collection, you can use card [customization options](https://github.com/anuraghazra/github-readme-stats?tab=readme-ov-file#customization)." for pr_number in $(gh pr list -l "themes" -q is:open --json number -q ".[].number"); do gh pr close $pr_number -c "$comment_message" From 4f17194684c99a287e3d02ed4eacf5484534d8ac Mon Sep 17 00:00:00 2001 From: Mohd Amir <152868927+webdev-mohdamir@users.noreply.github.com> Date: Thu, 25 Sep 2025 01:25:49 +0530 Subject: [PATCH 089/265] fix: display correct data when user don't have any pull requests (#4452) * Fix: When user doesn't have any PR, it's Merged PRs Percentage is NAN (fixes #4449) * review --------- Co-authored-by: Alexandr --- src/fetchers/stats.js | 3 ++- tests/fetchStats.test.js | 43 ++++++++++++++++++++++++++++++++++++++++ 2 files changed, 45 insertions(+), 1 deletion(-) diff --git a/src/fetchers/stats.js b/src/fetchers/stats.js index 56af97d89a041..c54cdd93ea81c 100644 --- a/src/fetchers/stats.js +++ b/src/fetchers/stats.js @@ -297,7 +297,8 @@ const fetchStats = async ( if (include_merged_pull_requests) { stats.totalPRsMerged = user.mergedPullRequests.totalCount; stats.mergedPRsPercentage = - (user.mergedPullRequests.totalCount / user.pullRequests.totalCount) * 100; + (user.mergedPullRequests.totalCount / user.pullRequests.totalCount) * + 100 || 0; } stats.totalReviews = user.reviews.totalPullRequestReviewContributions; stats.totalIssues = user.openIssues.totalCount + user.closedIssues.totalCount; diff --git a/tests/fetchStats.test.js b/tests/fetchStats.test.js index 73a4f28257d4e..e0b0a146bfc6c 100644 --- a/tests/fetchStats.test.js +++ b/tests/fetchStats.test.js @@ -43,6 +43,16 @@ const data_stats = { const data_year2003 = JSON.parse(JSON.stringify(data_stats)); data_year2003.data.user.commits.totalCommitContributions = 428; +const data_without_pull_requests = { + data: { + user: { + ...data_stats.data.user, + pullRequests: { totalCount: 0 }, + mergedPullRequests: { totalCount: 0 }, + }, + }, +}; + const data_repo = { data: { user: { @@ -461,4 +471,37 @@ describe("Test fetchStats", () => { rank, }); }); + + it("should return correct data when user don't have any pull requests", async () => { + mock.reset(); + mock + .onPost("https://api.github.com/graphql") + .reply(200, data_without_pull_requests); + const stats = await fetchStats("anuraghazra", false, [], true); + const rank = calculateRank({ + all_commits: false, + commits: 100, + prs: 0, + reviews: 50, + issues: 200, + repos: 5, + stars: 300, + followers: 100, + }); + + expect(stats).toStrictEqual({ + contributedTo: 61, + name: "Anurag Hazra", + totalCommits: 100, + totalIssues: 200, + totalPRs: 0, + totalPRsMerged: 0, + mergedPRsPercentage: 0, + totalReviews: 50, + totalStars: 300, + totalDiscussionsStarted: 0, + totalDiscussionsAnswered: 0, + rank, + }); + }); }); From c81f3eb92d5823a1836ec3f3f3f540ea26d8b90b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Rado=C5=A1=20Mili=C4=87ev?= <40705899+rammba@users.noreply.github.com> Date: Wed, 24 Sep 2025 22:21:26 +0200 Subject: [PATCH 090/265] feat: add Serbian (Latin) translations (#4448) * Improve existing Serbian * Distinguish Cyrillic & Latin Serbian * Use sr for cyrillic Serbian to support backwards compatibility * review --------- Co-authored-by: Alexandr --- readme.md | 5 +++-- src/cards/stats.js | 1 + src/translations.js | 36 +++++++++++++++++++++++++++++------- 3 files changed, 33 insertions(+), 9 deletions(-) diff --git a/readme.md b/readme.md index 8d53b8f94fad6..d2ddfc82f1c31 100644 --- a/readme.md +++ b/readme.md @@ -332,15 +332,16 @@ Here is a list of all available locales: | `fa` | Persian (Farsi) | | `pl` | Polish | | `pt-br` | Portuguese (Brazil) | +| `pt-pt` | Portuguese (Portugal) | | Code | Locale | | --- | --- | -| `pt-pt` | Portuguese (Portugal) | | `ro` | Romanian | | `ru` | Russian | -| `sr` | Serbian | +| `sr` | Serbian (Cyrillic) | +| `sr-latn` | Serbian (Latin) | | `sk` | Slovak | | `es` | Spanish | | `se` | Swedish | diff --git a/src/cards/stats.js b/src/cards/stats.js index 67e71aef52114..09b7a2ce16648 100644 --- a/src/cards/stats.js +++ b/src/cards/stats.js @@ -377,6 +377,7 @@ const renderStatsCard = (stats, options = {}) => { "pt-pt", "ru", "sr", + "sr-latn", "uk-ua", "uz", "zh-tw", diff --git a/src/translations.js b/src/translations.js index 6f5b0c8247b16..044e0657cc00d 100644 --- a/src/translations.js +++ b/src/translations.js @@ -52,6 +52,7 @@ const statCardLocales = ({ name, apostrophe }) => { se: `GitHubstatistik för ${encodedName}`, th: `สถิติ GitHub ของ ${encodedName}`, sr: `GitHub статистика корисника ${encodedName}`, + "sr-latn": `GitHub statistika korisnika ${encodedName}`, no: `GitHub-statistikk for ${encodedName}`, }, "statcard.ranktitle": { @@ -91,6 +92,7 @@ const statCardLocales = ({ name, apostrophe }) => { se: `GitHubstatistik för ${encodedName}`, th: `อันดับ GitHub ของ ${encodedName}`, sr: `Ранк корисника ${encodedName}`, + "sr-latn": `Rank korisnika ${encodedName}`, no: `GitHub-statistikk for ${encodedName}`, }, "statcard.totalstars": { @@ -130,6 +132,7 @@ const statCardLocales = ({ name, apostrophe }) => { se: "Antal intjänade stjärnor", th: "ดาวทั้งหมดที่ได้รับ", sr: "Број освојених звездица", + "sr-latn": "Broj osvojenih zvezdica", no: "Totalt antall stjerner", }, "statcard.commits": { @@ -168,7 +171,8 @@ const statCardLocales = ({ name, apostrophe }) => { vi: "Tổng Số Cam Kết", se: "Totalt antal commits", th: "Commit ทั้งหมด", - sr: "Укупан број коммитова", + sr: "Укупно commit-ова", + "sr-latn": "Ukupno commit-ova", no: "Totalt antall commits", }, "statcard.prs": { @@ -207,7 +211,8 @@ const statCardLocales = ({ name, apostrophe }) => { vi: "Tổng Số PR", se: "Totalt antal PR", th: "PR ทั้งหมด", - sr: "Укупно PRова", + sr: "Укупно PR-ова", + "sr-latn": "Ukupno PR-ova", no: "Totalt antall PR", }, "statcard.issues": { @@ -247,6 +252,7 @@ const statCardLocales = ({ name, apostrophe }) => { se: "Total antal issues", th: "Issue ทั้งหมด", sr: "Укупно пријављених проблема", + "sr-latn": "Ukupno prijavljenih problema", no: "Totalt antall issues", }, "statcard.contribs": { @@ -285,7 +291,8 @@ const statCardLocales = ({ name, apostrophe }) => { vi: "Đã Đóng Góp (năm ngoái)", se: "Bidragit till (förra året)", th: "มีส่วนร่วมใน (ปีที่แล้ว)", - sr: "Контрибуирано (прошле године)", + sr: "Доприноси (прошла година)", + "sr-latn": "Doprinosi (prošla godina)", no: "Bidro til (i fjor)", }, "statcard.reviews": { @@ -324,7 +331,8 @@ const statCardLocales = ({ name, apostrophe }) => { vi: "Tổng Số PR Đã Xem Xét", se: "Totalt antal granskade PR", th: "รีวิว PR แล้วทั้งหมด", - sr: "Укупно прегледаних PRова", + sr: "Укупно прегледаних PR-ова", + "sr-latn": "Ukupno pregledanih PR-ova", no: "Totalt antall vurderte PR", }, "statcard.discussions-started": { @@ -364,6 +372,7 @@ const statCardLocales = ({ name, apostrophe }) => { se: "Totalt antal diskussioner startade", th: "เริ่มหัวข้อสนทนาทั้งหมด", sr: "Укупно покренутих дискусија", + "sr-latn": "Ukupno pokrenutih diskusija", no: "Totalt antall startede diskusjoner", }, "statcard.discussions-answered": { @@ -403,6 +412,7 @@ const statCardLocales = ({ name, apostrophe }) => { se: "Totalt antal diskussioner besvarade", th: "ตอบกลับหัวข้อสนทนาทั้งหมด", sr: "Укупно одговорених дискусија", + "sr-latn": "Ukupno odgovorenih diskusija", no: "Totalt antall besvarte diskusjoner", }, "statcard.prs-merged": { @@ -440,7 +450,8 @@ const statCardLocales = ({ name, apostrophe }) => { vi: "Tổng Số PR Đã Hợp Nhất", se: "Totalt antal sammanfogade PR", th: "PR ที่ถูก Merged แล้วทั้งหมด", - sr: "Укупно обједињених PRова", + sr: "Укупно спојених PR-ова", + "sr-latn": "Ukupno spojenih PR-ova", no: "Totalt antall sammenslåtte PR", }, "statcard.prs-merged-percentage": { @@ -478,7 +489,8 @@ const statCardLocales = ({ name, apostrophe }) => { vi: "Tỷ Lệ PR Đã Hợp Nhất", se: "Procent av sammanfogade PR", th: "เปอร์เซ็นต์ PR ที่ถูก Merged แล้วทั้งหมด", - sr: "Проценат обједињених PRова", + sr: "Проценат спојених PR-ова", + "sr-latn": "Procenat spojenih PR-ova", no: "Prosentandel sammenslåtte PR", }, }; @@ -522,6 +534,7 @@ const repoCardLocales = { se: "Mall", th: "เทมเพลต", sr: "Шаблон", + "sr-latn": "Šablon", no: "Mal", }, "repocard.archived": { @@ -561,6 +574,7 @@ const repoCardLocales = { se: "Arkiverade", th: "เก็บถาวร", sr: "Архивирано", + "sr-latn": "Arhivirano", no: "Arkivert", }, }; @@ -603,6 +617,7 @@ const langCardLocales = { se: "Mest använda språken", th: "ภาษาที่ใช้บ่อยที่สุด", sr: "Најкоришћенији језици", + "sr-latn": "Najkorišćeniji jezici", no: "Mest brukte språk", }, "langcard.nodata": { @@ -642,6 +657,7 @@ const langCardLocales = { se: "Inga språkdata.", th: "ไม่มีข้อมูลภาษา", sr: "Нема података о језицима.", + "sr-latn": "Nema podataka o jezicima.", no: "Ingen språkdata.", }, }; @@ -684,6 +700,7 @@ const wakatimeCardLocales = { se: "WakaTime statistik", th: "สถิติ WakaTime", sr: "WakaTime статистика", + "sr-latn": "WakaTime statistika", no: "WakaTime-statistikk", }, "wakatimecard.lastyear": { @@ -722,7 +739,8 @@ const wakatimeCardLocales = { vi: "Năm ngoái", se: "Förra året", th: "ปีที่แล้ว", - sr: "Претходна година", + sr: "Прошла год.", + "sr-latn": "Prošla god.", no: "I fjor", }, "wakatimecard.last7days": { @@ -762,6 +780,7 @@ const wakatimeCardLocales = { se: "Senaste 7 dagarna", th: "7 วันที่ผ่านมา", sr: "Претходних 7 дана", + "sr-latn": "Prethodnih 7 dana", no: "Siste 7 dager", }, "wakatimecard.notpublic": { @@ -801,6 +820,7 @@ const wakatimeCardLocales = { se: "WakaTime användarprofil inte offentlig", th: "โปรไฟล์ผู้ใช้ WakaTime ไม่ได้เป็นสาธารณะ", sr: "WakaTime профил корисника није јаван", + "sr-latn": "WakaTime profil korisnika nije javan", no: "WakaTime brukerprofil ikke offentlig", }, "wakatimecard.nocodedetails": { @@ -842,6 +862,7 @@ const wakatimeCardLocales = { se: "Användaren delar inte offentligt detaljerad kodstatistik", th: "ผู้ใช้ไม่ได้แชร์สถิติโค้ดแบบสาธารณะ", sr: "Корисник не дели јавно детаљну статистику кода", + "sr-latn": "Korisnik ne deli javno detaljnu statistiku koda", no: "Brukeren deler ikke detaljert kodestatistikk offentlig", }, "wakatimecard.nocodingactivity": { @@ -881,6 +902,7 @@ const wakatimeCardLocales = { se: "Ingen aktivitet denna vecka", th: "ไม่มีกิจกรรมการเขียนโค้ดในสัปดาห์นี้", sr: "Током ове недеље није било никаквих активности", + "sr-latn": "Tokom ove nedelje nije bilo nikakvih aktivnosti", no: "Ingen kodeaktivitet denne uken", }, }; From a298e1cd4145b0053a8f6bd19657ac2cb607bc4e Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 26 Sep 2025 18:39:23 +0300 Subject: [PATCH 091/265] build(deps-dev): bump @eslint/js from 9.35.0 to 9.36.0 (#4454) Bumps [@eslint/js](https://github.com/eslint/eslint/tree/HEAD/packages/js) from 9.35.0 to 9.36.0. - [Release notes](https://github.com/eslint/eslint/releases) - [Changelog](https://github.com/eslint/eslint/blob/main/CHANGELOG.md) - [Commits](https://github.com/eslint/eslint/commits/v9.36.0/packages/js) --- updated-dependencies: - dependency-name: "@eslint/js" dependency-version: 9.36.0 dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- package-lock.json | 32 +++++++++++++++++++++++++------- package.json | 2 +- 2 files changed, 26 insertions(+), 8 deletions(-) diff --git a/package-lock.json b/package-lock.json index 10740e7f78c43..61f6ee013afbb 100644 --- a/package-lock.json +++ b/package-lock.json @@ -20,7 +20,7 @@ "@actions/core": "^1.11.1", "@actions/github": "^6.0.1", "@eslint/eslintrc": "^3.3.1", - "@eslint/js": "^9.35.0", + "@eslint/js": "^9.36.0", "@testing-library/dom": "^10.4.1", "@testing-library/jest-dom": "^6.8.0", "@uppercod/css-to-object": "^1.1.1", @@ -865,9 +865,9 @@ } }, "node_modules/@eslint/js": { - "version": "9.35.0", - "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.35.0.tgz", - "integrity": "sha512-30iXE9whjlILfWobBkNerJo+TXYsgVM5ERQwMcMKCHckHflCmf7wXDAHlARoWnh0s1U72WqlbeyE7iAcCzuCPw==", + "version": "9.36.0", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.36.0.tgz", + "integrity": "sha512-uhCbYtYynH30iZErszX78U+nR3pJU3RHGQ57NXy5QupD4SBVwDeU8TNBy+MjMngc1UyIW9noKqsRqfjQTBU2dw==", "dev": true, "engines": { "node": "^18.18.0 || ^20.9.0 || >=21.1.0" @@ -3172,6 +3172,18 @@ "url": "https://opencollective.com/eslint" } }, + "node_modules/eslint/node_modules/@eslint/js": { + "version": "9.35.0", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.35.0.tgz", + "integrity": "sha512-30iXE9whjlILfWobBkNerJo+TXYsgVM5ERQwMcMKCHckHflCmf7wXDAHlARoWnh0s1U72WqlbeyE7iAcCzuCPw==", + "dev": true, + "engines": { + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" + }, + "funding": { + "url": "https://eslint.org/donate" + } + }, "node_modules/eslint/node_modules/escape-string-regexp": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", @@ -7804,9 +7816,9 @@ } }, "@eslint/js": { - "version": "9.35.0", - "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.35.0.tgz", - "integrity": "sha512-30iXE9whjlILfWobBkNerJo+TXYsgVM5ERQwMcMKCHckHflCmf7wXDAHlARoWnh0s1U72WqlbeyE7iAcCzuCPw==", + "version": "9.36.0", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.36.0.tgz", + "integrity": "sha512-uhCbYtYynH30iZErszX78U+nR3pJU3RHGQ57NXy5QupD4SBVwDeU8TNBy+MjMngc1UyIW9noKqsRqfjQTBU2dw==", "dev": true }, "@eslint/object-schema": { @@ -9487,6 +9499,12 @@ "optionator": "^0.9.3" }, "dependencies": { + "@eslint/js": { + "version": "9.35.0", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.35.0.tgz", + "integrity": "sha512-30iXE9whjlILfWobBkNerJo+TXYsgVM5ERQwMcMKCHckHflCmf7wXDAHlARoWnh0s1U72WqlbeyE7iAcCzuCPw==", + "dev": true + }, "escape-string-regexp": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", diff --git a/package.json b/package.json index de63b19c4b2f5..ff1eddcd3819b 100644 --- a/package.json +++ b/package.json @@ -39,7 +39,7 @@ "@actions/core": "^1.11.1", "@actions/github": "^6.0.1", "@eslint/eslintrc": "^3.3.1", - "@eslint/js": "^9.35.0", + "@eslint/js": "^9.36.0", "@testing-library/dom": "^10.4.1", "@testing-library/jest-dom": "^6.8.0", "@uppercod/css-to-object": "^1.1.1", From d34a7068e7cf9df905487773c1b1978e8cf396ab Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 26 Sep 2025 18:42:23 +0300 Subject: [PATCH 092/265] build(deps-dev): bump eslint from 9.35.0 to 9.36.0 (#4455) Bumps [eslint](https://github.com/eslint/eslint) from 9.35.0 to 9.36.0. - [Release notes](https://github.com/eslint/eslint/releases) - [Changelog](https://github.com/eslint/eslint/blob/main/CHANGELOG.md) - [Commits](https://github.com/eslint/eslint/compare/v9.35.0...v9.36.0) --- updated-dependencies: - dependency-name: eslint dependency-version: 9.36.0 dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- package-lock.json | 18 +++++++++--------- package.json | 2 +- 2 files changed, 10 insertions(+), 10 deletions(-) diff --git a/package-lock.json b/package-lock.json index 61f6ee013afbb..1d177eafd7876 100644 --- a/package-lock.json +++ b/package-lock.json @@ -26,7 +26,7 @@ "@uppercod/css-to-object": "^1.1.1", "axios-mock-adapter": "^2.1.0", "color-contrast-checker": "^2.1.0", - "eslint": "^9.35.0", + "eslint": "^9.36.0", "eslint-config-prettier": "^10.1.8", "eslint-plugin-jsdoc": "^57.0.8", "globals": "^16.4.0", @@ -3019,9 +3019,9 @@ } }, "node_modules/eslint": { - "version": "9.35.0", - "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.35.0.tgz", - "integrity": "sha512-QePbBFMJFjgmlE+cXAlbHZbHpdFVS2E/6vzCy7aKlebddvl1vadiC4JFV5u/wqTkNUwEV8WrQi257jf5f06hrg==", + "version": "9.36.0", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.36.0.tgz", + "integrity": "sha512-hB4FIzXovouYzwzECDcUkJ4OcfOEkXTv2zRY6B9bkwjx/cprAq0uvm1nl7zvQ0/TsUk0zQiN4uPfJpB9m+rPMQ==", "dev": true, "dependencies": { "@eslint-community/eslint-utils": "^4.8.0", @@ -3030,7 +3030,7 @@ "@eslint/config-helpers": "^0.3.1", "@eslint/core": "^0.15.2", "@eslint/eslintrc": "^3.3.1", - "@eslint/js": "9.35.0", + "@eslint/js": "9.36.0", "@eslint/plugin-kit": "^0.3.5", "@humanfs/node": "^0.16.6", "@humanwhocodes/module-importer": "^1.0.1", @@ -9457,9 +9457,9 @@ "dev": true }, "eslint": { - "version": "9.35.0", - "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.35.0.tgz", - "integrity": "sha512-QePbBFMJFjgmlE+cXAlbHZbHpdFVS2E/6vzCy7aKlebddvl1vadiC4JFV5u/wqTkNUwEV8WrQi257jf5f06hrg==", + "version": "9.36.0", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.36.0.tgz", + "integrity": "sha512-hB4FIzXovouYzwzECDcUkJ4OcfOEkXTv2zRY6B9bkwjx/cprAq0uvm1nl7zvQ0/TsUk0zQiN4uPfJpB9m+rPMQ==", "dev": true, "requires": { "@eslint-community/eslint-utils": "^4.8.0", @@ -9468,7 +9468,7 @@ "@eslint/config-helpers": "^0.3.1", "@eslint/core": "^0.15.2", "@eslint/eslintrc": "^3.3.1", - "@eslint/js": "9.35.0", + "@eslint/js": "9.36.0", "@eslint/plugin-kit": "^0.3.5", "@humanfs/node": "^0.16.6", "@humanwhocodes/module-importer": "^1.0.1", diff --git a/package.json b/package.json index ff1eddcd3819b..b9c5bc9ef4fe3 100644 --- a/package.json +++ b/package.json @@ -45,7 +45,7 @@ "@uppercod/css-to-object": "^1.1.1", "axios-mock-adapter": "^2.1.0", "color-contrast-checker": "^2.1.0", - "eslint": "^9.35.0", + "eslint": "^9.36.0", "eslint-config-prettier": "^10.1.8", "eslint-plugin-jsdoc": "^57.0.8", "globals": "^16.4.0", From 8d0d044517d49d3d44ba26b0646b4eceb7405a0f Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 26 Sep 2025 18:45:15 +0300 Subject: [PATCH 093/265] build(deps-dev): bump eslint-plugin-jsdoc from 57.0.8 to 60.1.1 (#4453) Bumps [eslint-plugin-jsdoc](https://github.com/gajus/eslint-plugin-jsdoc) from 57.0.8 to 60.1.1. - [Release notes](https://github.com/gajus/eslint-plugin-jsdoc/releases) - [Changelog](https://github.com/gajus/eslint-plugin-jsdoc/blob/main/.releaserc) - [Commits](https://github.com/gajus/eslint-plugin-jsdoc/compare/v57.0.8...v60.1.1) --- updated-dependencies: - dependency-name: eslint-plugin-jsdoc dependency-version: 60.1.1 dependency-type: direct:development update-type: version-update:semver-major ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- package-lock.json | 14 +++++++------- package.json | 2 +- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/package-lock.json b/package-lock.json index 1d177eafd7876..adee8576efba4 100644 --- a/package-lock.json +++ b/package-lock.json @@ -28,7 +28,7 @@ "color-contrast-checker": "^2.1.0", "eslint": "^9.36.0", "eslint-config-prettier": "^10.1.8", - "eslint-plugin-jsdoc": "^57.0.8", + "eslint-plugin-jsdoc": "^60.1.1", "globals": "^16.4.0", "hjson": "^3.2.2", "husky": "^9.1.7", @@ -3094,9 +3094,9 @@ } }, "node_modules/eslint-plugin-jsdoc": { - "version": "57.0.8", - "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-57.0.8.tgz", - "integrity": "sha512-L3kb1fz1VsWMDxcNOPqomC8gWROxCJomynYZkhQJInZu4m3Ugjod75pWAICRrKW1WedHkX8BotknBtGCLUFpAg==", + "version": "60.1.1", + "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-60.1.1.tgz", + "integrity": "sha512-eEyINuG4pZtVFplyCPTeUif/+C14zh4fmm5IrDE5YY2Zc3IYKpdGjeaWahJcxWDDwjTVjWCw1zL9XbX3Fb0Wjg==", "dev": true, "dependencies": { "@es-joy/jsdoccomment": "~0.58.0", @@ -9594,9 +9594,9 @@ "requires": {} }, "eslint-plugin-jsdoc": { - "version": "57.0.8", - "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-57.0.8.tgz", - "integrity": "sha512-L3kb1fz1VsWMDxcNOPqomC8gWROxCJomynYZkhQJInZu4m3Ugjod75pWAICRrKW1WedHkX8BotknBtGCLUFpAg==", + "version": "60.1.1", + "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-60.1.1.tgz", + "integrity": "sha512-eEyINuG4pZtVFplyCPTeUif/+C14zh4fmm5IrDE5YY2Zc3IYKpdGjeaWahJcxWDDwjTVjWCw1zL9XbX3Fb0Wjg==", "dev": true, "requires": { "@es-joy/jsdoccomment": "~0.58.0", diff --git a/package.json b/package.json index b9c5bc9ef4fe3..bb0a874f7a6ad 100644 --- a/package.json +++ b/package.json @@ -47,7 +47,7 @@ "color-contrast-checker": "^2.1.0", "eslint": "^9.36.0", "eslint-config-prettier": "^10.1.8", - "eslint-plugin-jsdoc": "^57.0.8", + "eslint-plugin-jsdoc": "^60.1.1", "globals": "^16.4.0", "hjson": "^3.2.2", "husky": "^9.1.7", From 31f34d9f52a411f86b3cf75a6c320acfa3dd46c5 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 26 Sep 2025 18:48:50 +0300 Subject: [PATCH 094/265] build(deps-dev): bump lint-staged from 16.1.6 to 16.2.0 (#4456) Bumps [lint-staged](https://github.com/lint-staged/lint-staged) from 16.1.6 to 16.2.0. - [Release notes](https://github.com/lint-staged/lint-staged/releases) - [Changelog](https://github.com/lint-staged/lint-staged/blob/main/CHANGELOG.md) - [Commits](https://github.com/lint-staged/lint-staged/compare/v16.1.6...v16.2.0) --- updated-dependencies: - dependency-name: lint-staged dependency-version: 16.2.0 dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- package-lock.json | 430 ++++++++++++++++++---------------------------- package.json | 2 +- 2 files changed, 165 insertions(+), 267 deletions(-) diff --git a/package-lock.json b/package-lock.json index adee8576efba4..01cdd0e322dcf 100644 --- a/package-lock.json +++ b/package-lock.json @@ -36,7 +36,7 @@ "jest-bench": "^29.7.1", "jest-environment-jsdom": "^30.1.2", "js-yaml": "^4.1.0", - "lint-staged": "^16.1.6", + "lint-staged": "^16.2.0", "lodash.snakecase": "^4.1.1", "parse-diff": "^0.11.1", "prettier": "^3.6.2" @@ -2540,25 +2540,25 @@ } }, "node_modules/cli-truncate": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/cli-truncate/-/cli-truncate-4.0.0.tgz", - "integrity": "sha512-nPdaFdQ0h/GEigbPClz11D0v/ZJEwxmeVZGeMo3Z5StPtUTkA9o1lD6QwoirYiSDzbcwn2XcjwmCp68W1IS4TA==", + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/cli-truncate/-/cli-truncate-5.1.0.tgz", + "integrity": "sha512-7JDGG+4Zp0CsknDCedl0DYdaeOhc46QNpXi3NLQblkZpXXgA6LncLDUUyvrjSvZeF3VRQa+KiMGomazQrC1V8g==", "dev": true, "dependencies": { - "slice-ansi": "^5.0.0", - "string-width": "^7.0.0" + "slice-ansi": "^7.1.0", + "string-width": "^8.0.0" }, "engines": { - "node": ">=18" + "node": ">=20" }, "funding": { "url": "https://github.com/sponsors/sindresorhus" } }, "node_modules/cli-truncate/node_modules/ansi-regex": { - "version": "6.2.0", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.2.0.tgz", - "integrity": "sha512-TKY5pyBkHyADOPYlRT9Lx6F544mPl0vS5Ew7BJ45hA08Q+t3GjbueLliBWN3sMICk6+y7HdyxSzC4bWS8baBdg==", + "version": "6.2.2", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.2.2.tgz", + "integrity": "sha512-Bq3SmSpyFHaWjPk8If9yc6svM8c56dB5BAtW4Qbw5jHTwwXXcTLoRMkpDJp6VL0XzlWaCHTXrkFURMYmD0sLqg==", "dev": true, "engines": { "node": ">=12" @@ -2567,33 +2567,26 @@ "url": "https://github.com/chalk/ansi-regex?sponsor=1" } }, - "node_modules/cli-truncate/node_modules/emoji-regex": { - "version": "10.5.0", - "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.5.0.tgz", - "integrity": "sha512-lb49vf1Xzfx080OKA0o6l8DQQpV+6Vg95zyCJX9VB/BqKYlhG7N4wgROUUHRA+ZPUefLnteQOad7z1kT2bV7bg==", - "dev": true - }, "node_modules/cli-truncate/node_modules/string-width": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/string-width/-/string-width-7.2.0.tgz", - "integrity": "sha512-tsaTIkKW9b4N+AEj+SVA+WhJzV7/zMhcSu78mLKWSk7cXMOSHsBKFWUs0fWwq8QyK3MgJBQRX6Gbi4kYbdvGkQ==", + "version": "8.1.0", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-8.1.0.tgz", + "integrity": "sha512-Kxl3KJGb/gxkaUMOjRsQ8IrXiGW75O4E3RPjFIINOVH8AMl2SQ/yWdTzWwF3FevIX9LcMAjJW+GRwAlAbTSXdg==", "dev": true, "dependencies": { - "emoji-regex": "^10.3.0", - "get-east-asian-width": "^1.0.0", + "get-east-asian-width": "^1.3.0", "strip-ansi": "^7.1.0" }, "engines": { - "node": ">=18" + "node": ">=20" }, "funding": { "url": "https://github.com/sponsors/sindresorhus" } }, "node_modules/cli-truncate/node_modules/strip-ansi": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz", - "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==", + "version": "7.1.2", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.2.tgz", + "integrity": "sha512-gmBGslpoQJtgnMAvOVqGZpEz9dyoKTCzy2nfz/n8aIFhN/jCE/rCmcxabB6jOOHV+0WNnylOxaxBQPSvcWklhA==", "dev": true, "dependencies": { "ansi-regex": "^6.0.1" @@ -2677,9 +2670,9 @@ } }, "node_modules/commander": { - "version": "14.0.0", - "resolved": "https://registry.npmjs.org/commander/-/commander-14.0.0.tgz", - "integrity": "sha512-2uM9rYjPvyq39NwLRqaiLtWHyDC1FvryJDa2ATTVims5YAS4PupsEQsDvP14FqhFr0P49CYDugi59xaxJlTXRA==", + "version": "14.0.1", + "resolved": "https://registry.npmjs.org/commander/-/commander-14.0.1.tgz", + "integrity": "sha512-2JkV3gUZUVrbNA+1sjBOYLsMZ5cEEl8GTFP2a4AVz5hvasAMCQ1D2l2le/cX+pV4N6ZU17zjUahLpIXRrnWL8A==", "dev": true, "engines": { "node": ">=20" @@ -3612,9 +3605,9 @@ } }, "node_modules/get-east-asian-width": { - "version": "1.3.1", - "resolved": "https://registry.npmjs.org/get-east-asian-width/-/get-east-asian-width-1.3.1.tgz", - "integrity": "sha512-R1QfovbPsKmosqTnPoRFiJ7CF9MLRgb53ChvMZm+r4p76/+8yKDy17qLL2PKInORy2RkZZekuK0efYgmzTkXyQ==", + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/get-east-asian-width/-/get-east-asian-width-1.4.0.tgz", + "integrity": "sha512-QZjmEOC+IT1uk6Rx0sX22V6uHWVwbdbxf1faPqJ1QhLdGgsRGCZoyaQBm/piRdJy/D2um6hM1UP7ZEeQ4EkP+Q==", "dev": true, "engines": { "node": ">=18" @@ -5408,18 +5401,6 @@ "node": ">=6" } }, - "node_modules/lilconfig": { - "version": "3.1.3", - "resolved": "https://registry.npmjs.org/lilconfig/-/lilconfig-3.1.3.tgz", - "integrity": "sha512-/vlFKAoH5Cgt3Ie+JLhRbwOsCQePABiU3tJ1egGvyQ+33R/vcwM2Zl2QR/LzjsBeItPt3oSVXapn+m4nQDvpzw==", - "dev": true, - "engines": { - "node": ">=14" - }, - "funding": { - "url": "https://github.com/sponsors/antonk52" - } - }, "node_modules/lines-and-columns": { "version": "1.2.4", "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz", @@ -5427,21 +5408,18 @@ "dev": true }, "node_modules/lint-staged": { - "version": "16.1.6", - "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-16.1.6.tgz", - "integrity": "sha512-U4kuulU3CKIytlkLlaHcGgKscNfJPNTiDF2avIUGFCv7K95/DCYQ7Ra62ydeRWmgQGg9zJYw2dzdbztwJlqrow==", + "version": "16.2.0", + "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-16.2.0.tgz", + "integrity": "sha512-spdYSOCQ2MdZ9CM1/bu/kDmaYGsrpNOeu1InFFV8uhv14x6YIubGxbCpSmGILFoxkiheNQPDXSg5Sbb5ZuVnug==", "dev": true, "dependencies": { - "chalk": "^5.6.0", - "commander": "^14.0.0", - "debug": "^4.4.1", - "lilconfig": "^3.1.3", - "listr2": "^9.0.3", - "micromatch": "^4.0.8", - "nano-spawn": "^1.0.2", - "pidtree": "^0.6.0", - "string-argv": "^0.3.2", - "yaml": "^2.8.1" + "commander": "14.0.1", + "listr2": "9.0.4", + "micromatch": "4.0.8", + "nano-spawn": "1.0.3", + "pidtree": "0.6.0", + "string-argv": "0.3.2", + "yaml": "2.8.1" }, "bin": { "lint-staged": "bin/lint-staged.js" @@ -5453,25 +5431,13 @@ "url": "https://opencollective.com/lint-staged" } }, - "node_modules/lint-staged/node_modules/chalk": { - "version": "5.6.0", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-5.6.0.tgz", - "integrity": "sha512-46QrSQFyVSEyYAgQ22hQ+zDa60YHA4fBstHmtSApj1Y5vKtG27fWowW03jCk5KcbXEWPZUIR894aARCA/G1kfQ==", - "dev": true, - "engines": { - "node": "^12.17.0 || ^14.13 || >=16.0.0" - }, - "funding": { - "url": "https://github.com/chalk/chalk?sponsor=1" - } - }, "node_modules/listr2": { - "version": "9.0.3", - "resolved": "https://registry.npmjs.org/listr2/-/listr2-9.0.3.tgz", - "integrity": "sha512-0aeh5HHHgmq1KRdMMDHfhMWQmIT/m7nRDTlxlFqni2Sp0had9baqsjJRvDGdlvgd6NmPE0nPloOipiQJGFtTHQ==", + "version": "9.0.4", + "resolved": "https://registry.npmjs.org/listr2/-/listr2-9.0.4.tgz", + "integrity": "sha512-1wd/kpAdKRLwv7/3OKC8zZ5U8e/fajCfWMxacUvB79S5nLrYGPtUI/8chMQhn3LQjsRVErTb9i1ECAwW0ZIHnQ==", "dev": true, "dependencies": { - "cli-truncate": "^4.0.0", + "cli-truncate": "^5.0.0", "colorette": "^2.0.20", "eventemitter3": "^5.0.1", "log-update": "^6.1.0", @@ -5483,9 +5449,9 @@ } }, "node_modules/listr2/node_modules/ansi-regex": { - "version": "6.2.0", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.2.0.tgz", - "integrity": "sha512-TKY5pyBkHyADOPYlRT9Lx6F544mPl0vS5Ew7BJ45hA08Q+t3GjbueLliBWN3sMICk6+y7HdyxSzC4bWS8baBdg==", + "version": "6.2.2", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.2.2.tgz", + "integrity": "sha512-Bq3SmSpyFHaWjPk8If9yc6svM8c56dB5BAtW4Qbw5jHTwwXXcTLoRMkpDJp6VL0XzlWaCHTXrkFURMYmD0sLqg==", "dev": true, "engines": { "node": ">=12" @@ -5495,9 +5461,9 @@ } }, "node_modules/listr2/node_modules/ansi-styles": { - "version": "6.2.1", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz", - "integrity": "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==", + "version": "6.2.3", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.3.tgz", + "integrity": "sha512-4Dj6M28JB+oAH8kFkTLUo+a2jwOFkuqb3yucU0CANcRRUbxS0cP0nZYCGjcc3BNXwRIsUVmDGgzawme7zvJHvg==", "dev": true, "engines": { "node": ">=12" @@ -5530,9 +5496,9 @@ } }, "node_modules/listr2/node_modules/strip-ansi": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz", - "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==", + "version": "7.1.2", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.2.tgz", + "integrity": "sha512-gmBGslpoQJtgnMAvOVqGZpEz9dyoKTCzy2nfz/n8aIFhN/jCE/rCmcxabB6jOOHV+0WNnylOxaxBQPSvcWklhA==", "dev": true, "dependencies": { "ansi-regex": "^6.0.1" @@ -5545,9 +5511,9 @@ } }, "node_modules/listr2/node_modules/wrap-ansi": { - "version": "9.0.0", - "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-9.0.0.tgz", - "integrity": "sha512-G8ura3S+3Z2G+mkgNRq8dqaFZAuxfsxpBB8OCTGRTCtp+l/v9nbFNmCUP1BZMts3G1142MsZfn6eeUKrr4PD1Q==", + "version": "9.0.2", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-9.0.2.tgz", + "integrity": "sha512-42AtmgqjV+X1VpdOfyTGOYRi0/zsoLqtXQckTmqTeybT+BDIbM/Guxo7x3pE2vtpr1ok6xRqM9OpBe+Jyoqyww==", "dev": true, "dependencies": { "ansi-styles": "^6.2.1", @@ -5611,9 +5577,9 @@ } }, "node_modules/log-update/node_modules/ansi-escapes": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-7.0.0.tgz", - "integrity": "sha512-GdYO7a61mR0fOlAsvC9/rIHf7L96sBc6dEWzeOu+KAea5bZyQRPIpojrVoI4AXGJS/ycu/fBTdLrUkA4ODrvjw==", + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-7.1.0.tgz", + "integrity": "sha512-YdhtCd19sKRKfAAUsrcC1wzm4JuzJoiX4pOJqIoW2qmKj5WzG/dL8uUJ0361zaXtHqK7gEhOwtAtz7t3Yq3X5g==", "dev": true, "dependencies": { "environment": "^1.0.0" @@ -5626,9 +5592,9 @@ } }, "node_modules/log-update/node_modules/ansi-regex": { - "version": "6.2.0", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.2.0.tgz", - "integrity": "sha512-TKY5pyBkHyADOPYlRT9Lx6F544mPl0vS5Ew7BJ45hA08Q+t3GjbueLliBWN3sMICk6+y7HdyxSzC4bWS8baBdg==", + "version": "6.2.2", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.2.2.tgz", + "integrity": "sha512-Bq3SmSpyFHaWjPk8If9yc6svM8c56dB5BAtW4Qbw5jHTwwXXcTLoRMkpDJp6VL0XzlWaCHTXrkFURMYmD0sLqg==", "dev": true, "engines": { "node": ">=12" @@ -5638,9 +5604,9 @@ } }, "node_modules/log-update/node_modules/ansi-styles": { - "version": "6.2.1", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz", - "integrity": "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==", + "version": "6.2.3", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.3.tgz", + "integrity": "sha512-4Dj6M28JB+oAH8kFkTLUo+a2jwOFkuqb3yucU0CANcRRUbxS0cP0nZYCGjcc3BNXwRIsUVmDGgzawme7zvJHvg==", "dev": true, "engines": { "node": ">=12" @@ -5655,37 +5621,6 @@ "integrity": "sha512-lb49vf1Xzfx080OKA0o6l8DQQpV+6Vg95zyCJX9VB/BqKYlhG7N4wgROUUHRA+ZPUefLnteQOad7z1kT2bV7bg==", "dev": true }, - "node_modules/log-update/node_modules/is-fullwidth-code-point": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-5.1.0.tgz", - "integrity": "sha512-5XHYaSyiqADb4RnZ1Bdad6cPp8Toise4TzEjcOYDHZkTCbKgiUl7WTUCpNWHuxmDt91wnsZBc9xinNzopv3JMQ==", - "dev": true, - "dependencies": { - "get-east-asian-width": "^1.3.1" - }, - "engines": { - "node": ">=18" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/log-update/node_modules/slice-ansi": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-7.1.0.tgz", - "integrity": "sha512-bSiSngZ/jWeX93BqeIAbImyTbEihizcwNjFoRUIY/T1wWQsfsm2Vw1agPKylXvQTU7iASGdHhyqRlqQzfz+Htg==", - "dev": true, - "dependencies": { - "ansi-styles": "^6.2.1", - "is-fullwidth-code-point": "^5.0.0" - }, - "engines": { - "node": ">=18" - }, - "funding": { - "url": "https://github.com/chalk/slice-ansi?sponsor=1" - } - }, "node_modules/log-update/node_modules/string-width": { "version": "7.2.0", "resolved": "https://registry.npmjs.org/string-width/-/string-width-7.2.0.tgz", @@ -5704,9 +5639,9 @@ } }, "node_modules/log-update/node_modules/strip-ansi": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz", - "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==", + "version": "7.1.2", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.2.tgz", + "integrity": "sha512-gmBGslpoQJtgnMAvOVqGZpEz9dyoKTCzy2nfz/n8aIFhN/jCE/rCmcxabB6jOOHV+0WNnylOxaxBQPSvcWklhA==", "dev": true, "dependencies": { "ansi-regex": "^6.0.1" @@ -5719,9 +5654,9 @@ } }, "node_modules/log-update/node_modules/wrap-ansi": { - "version": "9.0.0", - "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-9.0.0.tgz", - "integrity": "sha512-G8ura3S+3Z2G+mkgNRq8dqaFZAuxfsxpBB8OCTGRTCtp+l/v9nbFNmCUP1BZMts3G1142MsZfn6eeUKrr4PD1Q==", + "version": "9.0.2", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-9.0.2.tgz", + "integrity": "sha512-42AtmgqjV+X1VpdOfyTGOYRi0/zsoLqtXQckTmqTeybT+BDIbM/Guxo7x3pE2vtpr1ok6xRqM9OpBe+Jyoqyww==", "dev": true, "dependencies": { "ansi-styles": "^6.2.1", @@ -5914,9 +5849,9 @@ "dev": true }, "node_modules/nano-spawn": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/nano-spawn/-/nano-spawn-1.0.2.tgz", - "integrity": "sha512-21t+ozMQDAL/UGgQVBbZ/xXvNO10++ZPuTmKRO8k9V3AClVRht49ahtDjfY8l1q6nSHOrE5ASfthzH3ol6R/hg==", + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/nano-spawn/-/nano-spawn-1.0.3.tgz", + "integrity": "sha512-jtpsQDetTnvS2Ts1fiRdci5rx0VYws5jGyC+4IYOTnIQ/wwdf6JdomlHBwqC3bJYOvaKu0C2GSZ1A60anrYpaA==", "dev": true, "engines": { "node": ">=20.17" @@ -6564,25 +6499,25 @@ } }, "node_modules/slice-ansi": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-5.0.0.tgz", - "integrity": "sha512-FC+lgizVPfie0kkhqUScwRu1O/lF6NOgJmlCgK+/LYxDCTk8sGelYaHDhFcDN+Sn3Cv+3VSa4Byeo+IMCzpMgQ==", + "version": "7.1.2", + "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-7.1.2.tgz", + "integrity": "sha512-iOBWFgUX7caIZiuutICxVgX1SdxwAVFFKwt1EvMYYec/NWO5meOJ6K5uQxhrYBdQJne4KxiqZc+KptFOWFSI9w==", "dev": true, "dependencies": { - "ansi-styles": "^6.0.0", - "is-fullwidth-code-point": "^4.0.0" + "ansi-styles": "^6.2.1", + "is-fullwidth-code-point": "^5.0.0" }, "engines": { - "node": ">=12" + "node": ">=18" }, "funding": { "url": "https://github.com/chalk/slice-ansi?sponsor=1" } }, "node_modules/slice-ansi/node_modules/ansi-styles": { - "version": "6.2.1", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz", - "integrity": "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==", + "version": "6.2.3", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.3.tgz", + "integrity": "sha512-4Dj6M28JB+oAH8kFkTLUo+a2jwOFkuqb3yucU0CANcRRUbxS0cP0nZYCGjcc3BNXwRIsUVmDGgzawme7zvJHvg==", "dev": true, "engines": { "node": ">=12" @@ -6592,12 +6527,15 @@ } }, "node_modules/slice-ansi/node_modules/is-fullwidth-code-point": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-4.0.0.tgz", - "integrity": "sha512-O4L094N2/dZ7xqVdrXhh9r1KODPJpFms8B5sGdJLPy664AgvXsreZUyCQQNItZRDlYug4xStLjNp/sz3HvBowQ==", + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-5.1.0.tgz", + "integrity": "sha512-5XHYaSyiqADb4RnZ1Bdad6cPp8Toise4TzEjcOYDHZkTCbKgiUl7WTUCpNWHuxmDt91wnsZBc9xinNzopv3JMQ==", "dev": true, + "dependencies": { + "get-east-asian-width": "^1.3.1" + }, "engines": { - "node": ">=12" + "node": ">=18" }, "funding": { "url": "https://github.com/sponsors/sindresorhus" @@ -9110,42 +9048,35 @@ } }, "cli-truncate": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/cli-truncate/-/cli-truncate-4.0.0.tgz", - "integrity": "sha512-nPdaFdQ0h/GEigbPClz11D0v/ZJEwxmeVZGeMo3Z5StPtUTkA9o1lD6QwoirYiSDzbcwn2XcjwmCp68W1IS4TA==", + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/cli-truncate/-/cli-truncate-5.1.0.tgz", + "integrity": "sha512-7JDGG+4Zp0CsknDCedl0DYdaeOhc46QNpXi3NLQblkZpXXgA6LncLDUUyvrjSvZeF3VRQa+KiMGomazQrC1V8g==", "dev": true, "requires": { - "slice-ansi": "^5.0.0", - "string-width": "^7.0.0" + "slice-ansi": "^7.1.0", + "string-width": "^8.0.0" }, "dependencies": { "ansi-regex": { - "version": "6.2.0", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.2.0.tgz", - "integrity": "sha512-TKY5pyBkHyADOPYlRT9Lx6F544mPl0vS5Ew7BJ45hA08Q+t3GjbueLliBWN3sMICk6+y7HdyxSzC4bWS8baBdg==", - "dev": true - }, - "emoji-regex": { - "version": "10.5.0", - "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.5.0.tgz", - "integrity": "sha512-lb49vf1Xzfx080OKA0o6l8DQQpV+6Vg95zyCJX9VB/BqKYlhG7N4wgROUUHRA+ZPUefLnteQOad7z1kT2bV7bg==", + "version": "6.2.2", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.2.2.tgz", + "integrity": "sha512-Bq3SmSpyFHaWjPk8If9yc6svM8c56dB5BAtW4Qbw5jHTwwXXcTLoRMkpDJp6VL0XzlWaCHTXrkFURMYmD0sLqg==", "dev": true }, "string-width": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/string-width/-/string-width-7.2.0.tgz", - "integrity": "sha512-tsaTIkKW9b4N+AEj+SVA+WhJzV7/zMhcSu78mLKWSk7cXMOSHsBKFWUs0fWwq8QyK3MgJBQRX6Gbi4kYbdvGkQ==", + "version": "8.1.0", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-8.1.0.tgz", + "integrity": "sha512-Kxl3KJGb/gxkaUMOjRsQ8IrXiGW75O4E3RPjFIINOVH8AMl2SQ/yWdTzWwF3FevIX9LcMAjJW+GRwAlAbTSXdg==", "dev": true, "requires": { - "emoji-regex": "^10.3.0", - "get-east-asian-width": "^1.0.0", + "get-east-asian-width": "^1.3.0", "strip-ansi": "^7.1.0" } }, "strip-ansi": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz", - "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==", + "version": "7.1.2", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.2.tgz", + "integrity": "sha512-gmBGslpoQJtgnMAvOVqGZpEz9dyoKTCzy2nfz/n8aIFhN/jCE/rCmcxabB6jOOHV+0WNnylOxaxBQPSvcWklhA==", "dev": true, "requires": { "ansi-regex": "^6.0.1" @@ -9212,9 +9143,9 @@ } }, "commander": { - "version": "14.0.0", - "resolved": "https://registry.npmjs.org/commander/-/commander-14.0.0.tgz", - "integrity": "sha512-2uM9rYjPvyq39NwLRqaiLtWHyDC1FvryJDa2ATTVims5YAS4PupsEQsDvP14FqhFr0P49CYDugi59xaxJlTXRA==", + "version": "14.0.1", + "resolved": "https://registry.npmjs.org/commander/-/commander-14.0.1.tgz", + "integrity": "sha512-2JkV3gUZUVrbNA+1sjBOYLsMZ5cEEl8GTFP2a4AVz5hvasAMCQ1D2l2le/cX+pV4N6ZU17zjUahLpIXRrnWL8A==", "dev": true }, "comment-parser": { @@ -9858,9 +9789,9 @@ "dev": true }, "get-east-asian-width": { - "version": "1.3.1", - "resolved": "https://registry.npmjs.org/get-east-asian-width/-/get-east-asian-width-1.3.1.tgz", - "integrity": "sha512-R1QfovbPsKmosqTnPoRFiJ7CF9MLRgb53ChvMZm+r4p76/+8yKDy17qLL2PKInORy2RkZZekuK0efYgmzTkXyQ==", + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/get-east-asian-width/-/get-east-asian-width-1.4.0.tgz", + "integrity": "sha512-QZjmEOC+IT1uk6Rx0sX22V6uHWVwbdbxf1faPqJ1QhLdGgsRGCZoyaQBm/piRdJy/D2um6hM1UP7ZEeQ4EkP+Q==", "dev": true }, "get-intrinsic": { @@ -11185,12 +11116,6 @@ "integrity": "sha512-qsda+H8jTaUaN/x5vzW2rzc+8Rw4TAQ/4KjB46IwK5VH+IlVeeeje/EoZRpiXvIqjFgK84QffqPztGI3VBLG1A==", "dev": true }, - "lilconfig": { - "version": "3.1.3", - "resolved": "https://registry.npmjs.org/lilconfig/-/lilconfig-3.1.3.tgz", - "integrity": "sha512-/vlFKAoH5Cgt3Ie+JLhRbwOsCQePABiU3tJ1egGvyQ+33R/vcwM2Zl2QR/LzjsBeItPt3oSVXapn+m4nQDvpzw==", - "dev": true - }, "lines-and-columns": { "version": "1.2.4", "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz", @@ -11198,38 +11123,27 @@ "dev": true }, "lint-staged": { - "version": "16.1.6", - "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-16.1.6.tgz", - "integrity": "sha512-U4kuulU3CKIytlkLlaHcGgKscNfJPNTiDF2avIUGFCv7K95/DCYQ7Ra62ydeRWmgQGg9zJYw2dzdbztwJlqrow==", + "version": "16.2.0", + "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-16.2.0.tgz", + "integrity": "sha512-spdYSOCQ2MdZ9CM1/bu/kDmaYGsrpNOeu1InFFV8uhv14x6YIubGxbCpSmGILFoxkiheNQPDXSg5Sbb5ZuVnug==", "dev": true, "requires": { - "chalk": "^5.6.0", - "commander": "^14.0.0", - "debug": "^4.4.1", - "lilconfig": "^3.1.3", - "listr2": "^9.0.3", - "micromatch": "^4.0.8", - "nano-spawn": "^1.0.2", - "pidtree": "^0.6.0", - "string-argv": "^0.3.2", - "yaml": "^2.8.1" - }, - "dependencies": { - "chalk": { - "version": "5.6.0", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-5.6.0.tgz", - "integrity": "sha512-46QrSQFyVSEyYAgQ22hQ+zDa60YHA4fBstHmtSApj1Y5vKtG27fWowW03jCk5KcbXEWPZUIR894aARCA/G1kfQ==", - "dev": true - } + "commander": "14.0.1", + "listr2": "9.0.4", + "micromatch": "4.0.8", + "nano-spawn": "1.0.3", + "pidtree": "0.6.0", + "string-argv": "0.3.2", + "yaml": "2.8.1" } }, "listr2": { - "version": "9.0.3", - "resolved": "https://registry.npmjs.org/listr2/-/listr2-9.0.3.tgz", - "integrity": "sha512-0aeh5HHHgmq1KRdMMDHfhMWQmIT/m7nRDTlxlFqni2Sp0had9baqsjJRvDGdlvgd6NmPE0nPloOipiQJGFtTHQ==", + "version": "9.0.4", + "resolved": "https://registry.npmjs.org/listr2/-/listr2-9.0.4.tgz", + "integrity": "sha512-1wd/kpAdKRLwv7/3OKC8zZ5U8e/fajCfWMxacUvB79S5nLrYGPtUI/8chMQhn3LQjsRVErTb9i1ECAwW0ZIHnQ==", "dev": true, "requires": { - "cli-truncate": "^4.0.0", + "cli-truncate": "^5.0.0", "colorette": "^2.0.20", "eventemitter3": "^5.0.1", "log-update": "^6.1.0", @@ -11238,15 +11152,15 @@ }, "dependencies": { "ansi-regex": { - "version": "6.2.0", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.2.0.tgz", - "integrity": "sha512-TKY5pyBkHyADOPYlRT9Lx6F544mPl0vS5Ew7BJ45hA08Q+t3GjbueLliBWN3sMICk6+y7HdyxSzC4bWS8baBdg==", + "version": "6.2.2", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.2.2.tgz", + "integrity": "sha512-Bq3SmSpyFHaWjPk8If9yc6svM8c56dB5BAtW4Qbw5jHTwwXXcTLoRMkpDJp6VL0XzlWaCHTXrkFURMYmD0sLqg==", "dev": true }, "ansi-styles": { - "version": "6.2.1", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz", - "integrity": "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==", + "version": "6.2.3", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.3.tgz", + "integrity": "sha512-4Dj6M28JB+oAH8kFkTLUo+a2jwOFkuqb3yucU0CANcRRUbxS0cP0nZYCGjcc3BNXwRIsUVmDGgzawme7zvJHvg==", "dev": true }, "emoji-regex": { @@ -11267,18 +11181,18 @@ } }, "strip-ansi": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz", - "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==", + "version": "7.1.2", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.2.tgz", + "integrity": "sha512-gmBGslpoQJtgnMAvOVqGZpEz9dyoKTCzy2nfz/n8aIFhN/jCE/rCmcxabB6jOOHV+0WNnylOxaxBQPSvcWklhA==", "dev": true, "requires": { "ansi-regex": "^6.0.1" } }, "wrap-ansi": { - "version": "9.0.0", - "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-9.0.0.tgz", - "integrity": "sha512-G8ura3S+3Z2G+mkgNRq8dqaFZAuxfsxpBB8OCTGRTCtp+l/v9nbFNmCUP1BZMts3G1142MsZfn6eeUKrr4PD1Q==", + "version": "9.0.2", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-9.0.2.tgz", + "integrity": "sha512-42AtmgqjV+X1VpdOfyTGOYRi0/zsoLqtXQckTmqTeybT+BDIbM/Guxo7x3pE2vtpr1ok6xRqM9OpBe+Jyoqyww==", "dev": true, "requires": { "ansi-styles": "^6.2.1", @@ -11329,24 +11243,24 @@ }, "dependencies": { "ansi-escapes": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-7.0.0.tgz", - "integrity": "sha512-GdYO7a61mR0fOlAsvC9/rIHf7L96sBc6dEWzeOu+KAea5bZyQRPIpojrVoI4AXGJS/ycu/fBTdLrUkA4ODrvjw==", + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-7.1.0.tgz", + "integrity": "sha512-YdhtCd19sKRKfAAUsrcC1wzm4JuzJoiX4pOJqIoW2qmKj5WzG/dL8uUJ0361zaXtHqK7gEhOwtAtz7t3Yq3X5g==", "dev": true, "requires": { "environment": "^1.0.0" } }, "ansi-regex": { - "version": "6.2.0", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.2.0.tgz", - "integrity": "sha512-TKY5pyBkHyADOPYlRT9Lx6F544mPl0vS5Ew7BJ45hA08Q+t3GjbueLliBWN3sMICk6+y7HdyxSzC4bWS8baBdg==", + "version": "6.2.2", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.2.2.tgz", + "integrity": "sha512-Bq3SmSpyFHaWjPk8If9yc6svM8c56dB5BAtW4Qbw5jHTwwXXcTLoRMkpDJp6VL0XzlWaCHTXrkFURMYmD0sLqg==", "dev": true }, "ansi-styles": { - "version": "6.2.1", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz", - "integrity": "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==", + "version": "6.2.3", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.3.tgz", + "integrity": "sha512-4Dj6M28JB+oAH8kFkTLUo+a2jwOFkuqb3yucU0CANcRRUbxS0cP0nZYCGjcc3BNXwRIsUVmDGgzawme7zvJHvg==", "dev": true }, "emoji-regex": { @@ -11355,25 +11269,6 @@ "integrity": "sha512-lb49vf1Xzfx080OKA0o6l8DQQpV+6Vg95zyCJX9VB/BqKYlhG7N4wgROUUHRA+ZPUefLnteQOad7z1kT2bV7bg==", "dev": true }, - "is-fullwidth-code-point": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-5.1.0.tgz", - "integrity": "sha512-5XHYaSyiqADb4RnZ1Bdad6cPp8Toise4TzEjcOYDHZkTCbKgiUl7WTUCpNWHuxmDt91wnsZBc9xinNzopv3JMQ==", - "dev": true, - "requires": { - "get-east-asian-width": "^1.3.1" - } - }, - "slice-ansi": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-7.1.0.tgz", - "integrity": "sha512-bSiSngZ/jWeX93BqeIAbImyTbEihizcwNjFoRUIY/T1wWQsfsm2Vw1agPKylXvQTU7iASGdHhyqRlqQzfz+Htg==", - "dev": true, - "requires": { - "ansi-styles": "^6.2.1", - "is-fullwidth-code-point": "^5.0.0" - } - }, "string-width": { "version": "7.2.0", "resolved": "https://registry.npmjs.org/string-width/-/string-width-7.2.0.tgz", @@ -11386,18 +11281,18 @@ } }, "strip-ansi": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz", - "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==", + "version": "7.1.2", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.2.tgz", + "integrity": "sha512-gmBGslpoQJtgnMAvOVqGZpEz9dyoKTCzy2nfz/n8aIFhN/jCE/rCmcxabB6jOOHV+0WNnylOxaxBQPSvcWklhA==", "dev": true, "requires": { "ansi-regex": "^6.0.1" } }, "wrap-ansi": { - "version": "9.0.0", - "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-9.0.0.tgz", - "integrity": "sha512-G8ura3S+3Z2G+mkgNRq8dqaFZAuxfsxpBB8OCTGRTCtp+l/v9nbFNmCUP1BZMts3G1142MsZfn6eeUKrr4PD1Q==", + "version": "9.0.2", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-9.0.2.tgz", + "integrity": "sha512-42AtmgqjV+X1VpdOfyTGOYRi0/zsoLqtXQckTmqTeybT+BDIbM/Guxo7x3pE2vtpr1ok6xRqM9OpBe+Jyoqyww==", "dev": true, "requires": { "ansi-styles": "^6.2.1", @@ -11540,9 +11435,9 @@ "dev": true }, "nano-spawn": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/nano-spawn/-/nano-spawn-1.0.2.tgz", - "integrity": "sha512-21t+ozMQDAL/UGgQVBbZ/xXvNO10++ZPuTmKRO8k9V3AClVRht49ahtDjfY8l1q6nSHOrE5ASfthzH3ol6R/hg==", + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/nano-spawn/-/nano-spawn-1.0.3.tgz", + "integrity": "sha512-jtpsQDetTnvS2Ts1fiRdci5rx0VYws5jGyC+4IYOTnIQ/wwdf6JdomlHBwqC3bJYOvaKu0C2GSZ1A60anrYpaA==", "dev": true }, "natural-compare": { @@ -12004,26 +11899,29 @@ "dev": true }, "slice-ansi": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-5.0.0.tgz", - "integrity": "sha512-FC+lgizVPfie0kkhqUScwRu1O/lF6NOgJmlCgK+/LYxDCTk8sGelYaHDhFcDN+Sn3Cv+3VSa4Byeo+IMCzpMgQ==", + "version": "7.1.2", + "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-7.1.2.tgz", + "integrity": "sha512-iOBWFgUX7caIZiuutICxVgX1SdxwAVFFKwt1EvMYYec/NWO5meOJ6K5uQxhrYBdQJne4KxiqZc+KptFOWFSI9w==", "dev": true, "requires": { - "ansi-styles": "^6.0.0", - "is-fullwidth-code-point": "^4.0.0" + "ansi-styles": "^6.2.1", + "is-fullwidth-code-point": "^5.0.0" }, "dependencies": { "ansi-styles": { - "version": "6.2.1", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz", - "integrity": "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==", + "version": "6.2.3", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.3.tgz", + "integrity": "sha512-4Dj6M28JB+oAH8kFkTLUo+a2jwOFkuqb3yucU0CANcRRUbxS0cP0nZYCGjcc3BNXwRIsUVmDGgzawme7zvJHvg==", "dev": true }, "is-fullwidth-code-point": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-4.0.0.tgz", - "integrity": "sha512-O4L094N2/dZ7xqVdrXhh9r1KODPJpFms8B5sGdJLPy664AgvXsreZUyCQQNItZRDlYug4xStLjNp/sz3HvBowQ==", - "dev": true + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-5.1.0.tgz", + "integrity": "sha512-5XHYaSyiqADb4RnZ1Bdad6cPp8Toise4TzEjcOYDHZkTCbKgiUl7WTUCpNWHuxmDt91wnsZBc9xinNzopv3JMQ==", + "dev": true, + "requires": { + "get-east-asian-width": "^1.3.1" + } } } }, diff --git a/package.json b/package.json index bb0a874f7a6ad..cdbdebd356b01 100644 --- a/package.json +++ b/package.json @@ -55,7 +55,7 @@ "jest-bench": "^29.7.1", "jest-environment-jsdom": "^30.1.2", "js-yaml": "^4.1.0", - "lint-staged": "^16.1.6", + "lint-staged": "^16.2.0", "lodash.snakecase": "^4.1.1", "parse-diff": "^0.11.1", "prettier": "^3.6.2" From 3131cf7fc561ba1db92708e5360b87b0944e7b0d Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 26 Sep 2025 18:51:55 +0300 Subject: [PATCH 095/265] ci(deps): bump bahmutov/npm-install from 1.10.10 to 1.11.0 (#4457) Bumps [bahmutov/npm-install](https://github.com/bahmutov/npm-install) from 1.10.10 to 1.11.0. - [Release notes](https://github.com/bahmutov/npm-install/releases) - [Commits](https://github.com/bahmutov/npm-install/compare/3714964fb879ebbbc108e167f0f3a0c81ec075c9...e5fe105da2400070b5345aeb71fcb1ef5d4b2d1f) --- updated-dependencies: - dependency-name: bahmutov/npm-install dependency-version: 1.11.0 dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- .github/workflows/preview-theme.yml | 2 +- .github/workflows/stale-theme-pr-closer.yml | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/preview-theme.yml b/.github/workflows/preview-theme.yml index 6cea283c3947d..10e91c9c4120d 100644 --- a/.github/workflows/preview-theme.yml +++ b/.github/workflows/preview-theme.yml @@ -39,7 +39,7 @@ jobs: node-version: ${{ matrix.node-version }} cache: npm - - uses: bahmutov/npm-install@3714964fb879ebbbc108e167f0f3a0c81ec075c9 # v1.10.10 + - uses: bahmutov/npm-install@e5fe105da2400070b5345aeb71fcb1ef5d4b2d1f # v1.11.0 with: useLockFile: false diff --git a/.github/workflows/stale-theme-pr-closer.yml b/.github/workflows/stale-theme-pr-closer.yml index f9e550796873a..c416cd63792bf 100644 --- a/.github/workflows/stale-theme-pr-closer.yml +++ b/.github/workflows/stale-theme-pr-closer.yml @@ -45,7 +45,7 @@ jobs: node-version: ${{ matrix.node-version }} cache: npm - - uses: bahmutov/npm-install@3714964fb879ebbbc108e167f0f3a0c81ec075c9 # v1.10.10 + - uses: bahmutov/npm-install@e5fe105da2400070b5345aeb71fcb1ef5d4b2d1f # v1.11.0 with: useLockFile: false From fd15fcebf76d4ff858384388f18ba9841b994c42 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Mon, 29 Sep 2025 21:59:32 +0300 Subject: [PATCH 096/265] chore: remove redundant gitattributes file (#4471) Co-authored-by: Alexandr --- .gitattributes | 1 - 1 file changed, 1 deletion(-) delete mode 100644 .gitattributes diff --git a/.gitattributes b/.gitattributes deleted file mode 100644 index 747a6258768f2..0000000000000 --- a/.gitattributes +++ /dev/null @@ -1 +0,0 @@ -dist/* linguist-vendored=false From 1b579cda01f18fd5842dd5af7351291c62af80e8 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Mon, 29 Sep 2025 23:16:09 +0300 Subject: [PATCH 097/265] chore: add more folders into vercelignore (#4473) Co-authored-by: Alexandr --- .vercelignore | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/.vercelignore b/.vercelignore index 3a9f5413b9808..48dfdfb8696fe 100644 --- a/.vercelignore +++ b/.vercelignore @@ -1,3 +1,10 @@ +.devcontainer +.github +.husky +.vscode +benchmarks +coverage +scripts +tests .env package-lock.json -coverage \ No newline at end of file From 4c30073ed909614121468da8f87a95ef73fbdaff Mon Sep 17 00:00:00 2001 From: Alejandro Cabrera Carrasco <91148883+Alexasto12@users.noreply.github.com> Date: Mon, 29 Sep 2025 22:46:10 +0200 Subject: [PATCH 098/265] feat: add Catalan translations (#4134) * Update translations.js Catalan translation added * Update src/translations.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --------- Co-authored-by: Alexandr Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --- readme.md | 5 +++-- src/translations.js | 22 ++++++++++++++++++++++ 2 files changed, 25 insertions(+), 2 deletions(-) diff --git a/readme.md b/readme.md index d2ddfc82f1c31..83613a83d76f1 100644 --- a/readme.md +++ b/readme.md @@ -306,6 +306,7 @@ Here is a list of all available locales: | `az` | Azerbaijani | | `bn` | Bengali | | `my` | Burmese | +| `ca` | Catalan | | `cn` | Chinese | | `zh-tw` | Chinese (Taiwan) | | `cs` | Czech | @@ -314,12 +315,12 @@ Here is a list of all available locales: | `fi` | Finnish | | `fr` | French | | `de` | German | -| `el` | Greek | | Code | Locale | | --- | --- | +| `el` | Greek | | `hi` | Hindi | | `hu` | Hungarian | | `id` | Indonesian | @@ -332,12 +333,12 @@ Here is a list of all available locales: | `fa` | Persian (Farsi) | | `pl` | Polish | | `pt-br` | Portuguese (Brazil) | -| `pt-pt` | Portuguese (Portugal) | | Code | Locale | | --- | --- | +| `pt-pt` | Portuguese (Portugal) | | `ro` | Romanian | | `ru` | Russian | | `sr` | Serbian (Cyrillic) | diff --git a/src/translations.js b/src/translations.js index 044e0657cc00d..d9f5dee35d9ff 100644 --- a/src/translations.js +++ b/src/translations.js @@ -19,6 +19,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: `${encodedName}'${apostrophe} GitHub Stats`, ar: `${encodedName} إحصائيات جيت هاب`, az: `${encodedName}'${apostrophe} Hesabının GitHub Statistikası`, + ca: `Estadístiques de GitHub de ${encodedName}`, cn: `${encodedName} 的 GitHub 统计数据`, "zh-tw": `${encodedName} 的 GitHub 統計資料`, cs: `GitHub statistiky uživatele ${encodedName}`, @@ -59,6 +60,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: `${encodedName}'${apostrophe} GitHub Rank`, ar: `${encodedName} إحصائيات جيت هاب`, az: `${encodedName}'${apostrophe} Hesabının GitHub Statistikası`, + ca: `Estadístiques de GitHub de ${encodedName}`, cn: `${encodedName} 的 GitHub 统计数据`, "zh-tw": `${encodedName} 的 GitHub 統計資料`, cs: `GitHub statistiky uživatele ${encodedName}`, @@ -99,6 +101,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: "Total Stars Earned", ar: "مجموع النجوم", az: "Ümumi Ulduz", + ca: "Total d'estrelles", cn: "获标星数", "zh-tw": "得標星星數量(Star)", cs: "Celkem hvězd", @@ -139,6 +142,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: "Total Commits", ar: "مجموع المساهمات", az: "Ümumi Commit", + ca: "Commits totals", cn: "累计提交总数", "zh-tw": "累計提交數量(Commit)", cs: "Celkem commitů", @@ -179,6 +183,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: "Total PRs", ar: "مجموع طلبات السحب", az: "Ümumi PR", + ca: "PRs totals", cn: "发起的 PR 总数", "zh-tw": "拉取請求數量(PR)", cs: "Celkem PRs", @@ -219,6 +224,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: "Total Issues", ar: "مجموع التحسينات", az: "Ümumi Problem", + ca: "Issues totals", cn: "提出的 issue 总数", "zh-tw": "提出問題數量(Issue)", cs: "Celkem problémů", @@ -259,6 +265,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: "Contributed to (last year)", ar: "ساهم في (العام الماضي)", az: "Töhfə verdi (ötən il)", + ca: "Contribucions (l'any passat)", cn: "贡献的项目数(去年)", "zh-tw": "參與項目數量(去年)", cs: "Přispěl k (minulý rok)", @@ -299,6 +306,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: "Total PRs Reviewed", ar: "طلبات السحب التي تم مراجعتها", az: "Nəzərdən Keçirilən Ümumi PR", + ca: "Total de PRs revisats", cn: "审查的 PR 总数", "zh-tw": "審核的 PR 總計", cs: "Celkový počet PR", @@ -339,6 +347,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: "Total Discussions Started", ar: "مجموع المناقشات التي بدأها", az: "Başladılan Ümumi Müzakirə", + ca: "Discussions totals iniciades", cn: "发起的讨论总数", "zh-tw": "發起的討論總數", cs: "Celkem zahájených diskusí", @@ -379,6 +388,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: "Total Discussions Answered", ar: "مجموع المناقشات المُجابة", az: "Cavablandırılan Ümumi Müzakirə", + ca: "Discussions totals respostes", cn: "回复的讨论总数", "zh-tw": "回覆討論總計", cs: "Celkem zodpovězených diskusí", @@ -419,6 +429,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: "Total PRs Merged", ar: "مجموع طلبات السحب المُدمجة", az: "Birləşdirilmiş Ümumi PR", + ca: "PRs totals fusionats", cn: "合并的 PR 总数", "zh-tw": "合併的 PR 總計", cs: "Celkem sloučených PR", @@ -458,6 +469,7 @@ const statCardLocales = ({ name, apostrophe }) => { en: "Merged PRs Percentage", ar: "نسبة طلبات السحب المُدمجة", az: "Birləşdirilmiş PR-ların Faizi", + ca: "Percentatge de PRs fusionats", cn: "被合并的 PR 占比", "zh-tw": "合併的 PR 百分比", cs: "Sloučené PRs v procentech", @@ -502,6 +514,7 @@ const repoCardLocales = { ar: "قالب", az: "Şablon", bn: "টেমপ্লেট", + ca: "Plantilla", cn: "模板", "zh-tw": "模板", cs: "Šablona", @@ -542,6 +555,7 @@ const repoCardLocales = { ar: "مُؤرشف", az: "Arxiv", bn: "আর্কাইভড", + ca: "Arxivats", cn: "已归档", "zh-tw": "已封存", cs: "Archivováno", @@ -584,6 +598,7 @@ const langCardLocales = { en: "Most Used Languages", ar: "أكثر اللغات استخدامًا", az: "Ən Çox İstifadə Olunan Dillər", + ca: "Llenguatges més utilitzats", cn: "最常用的语言", "zh-tw": "最常用的語言", cs: "Nejpoužívanější jazyky", @@ -624,6 +639,7 @@ const langCardLocales = { en: "No languages data.", ar: "لا توجد بيانات للغات.", az: "Dil məlumatı yoxdur.", + ca: "Sense dades d'idiomes", cn: "没有语言数据。", "zh-tw": "沒有語言資料。", cs: "Žádné jazykové údaje.", @@ -667,6 +683,7 @@ const wakatimeCardLocales = { en: "WakaTime Stats", ar: "إحصائيات واكا تايم", az: "WakaTime Statistikası", + ca: "Estadístiques de WakaTime", cn: "WakaTime 周统计", "zh-tw": "WakaTime 周統計", cs: "Statistiky WakaTime", @@ -707,6 +724,7 @@ const wakatimeCardLocales = { en: "last year", ar: "العام الماضي", az: "Ötən il", + ca: "L'any passat", cn: "去年", "zh-tw": "去年", cs: "Minulý rok", @@ -747,6 +765,7 @@ const wakatimeCardLocales = { en: "last 7 days", ar: "آخر 7 أيام", az: "Son 7 gün", + ca: "Ultims 7 dies", cn: "最近 7 天", "zh-tw": "最近 7 天", cs: "Posledních 7 dní", @@ -787,6 +806,7 @@ const wakatimeCardLocales = { en: "WakaTime user profile not public", ar: "ملف مستخدم واكا تايم شخصي", az: "WakaTime istifadəçi profili ictimai deyil", + ca: "Perfil d'usuari de WakaTime no públic", cn: "WakaTime 用户个人资料未公开", "zh-tw": "WakaTime 使用者個人資料未公開", cs: "Profil uživatele WakaTime není veřejný", @@ -827,6 +847,7 @@ const wakatimeCardLocales = { en: "User doesn't publicly share detailed code statistics", ar: "المستخدم لا يشارك المعلومات التفصيلية", az: "İstifadəçi kod statistikalarını ictimai şəkildə paylaşmır", + ca: "L'usuari no comparteix dades públiques del seu codi", cn: "用户不公开分享详细的代码统计信息", "zh-tw": "使用者不公開分享詳細的程式碼統計資訊", cs: "Uživatel nesdílí podrobné statistiky kódu", @@ -869,6 +890,7 @@ const wakatimeCardLocales = { en: "No coding activity this week", ar: "لا يوجد نشاط برمجي لهذا الأسبوع", az: "Bu həftə heç bir kodlaşdırma fəaliyyəti olmayıb", + ca: "No hi ha activitat de codificació aquesta setmana", cn: "本周没有编程活动", "zh-tw": "本周沒有編程活動", cs: "Tento týden žádná aktivita v kódování", From b2465143792a4ade4c41f7c85fdefb185da9ebff Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Mon, 29 Sep 2025 23:54:33 +0300 Subject: [PATCH 099/265] docs(readme): fix stats card options table markdown syntax (#4475) * docs(readme): fix stats card options table markdown syntax * Update readme.md Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --------- Co-authored-by: Alexandr Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --- readme.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/readme.md b/readme.md index 83613a83d76f1..d716d6b264821 100644 --- a/readme.md +++ b/readme.md @@ -376,7 +376,7 @@ If we don't support your language, please consider contributing! You can find mo | `ring_color` | Color of the rank circle. | string (hex color) | `2f80ed` | | `number_format` | Switches between two available formats for displaying the card values `short` (i.e. `6.6k`) and `long` (i.e. `6626`). | enum | `short` | | `show` | Shows [additional items](#showing-additional-individual-stats) on stats card (i.e. `reviews`, `discussions_started`, `discussions_answered`, `prs_merged` or `prs_merged_percentage`). | string (comma-separated values) | `null` | -| `commits_year` | Filters and counts only commits made in the specified year | integer _(YYYY)_ | ` (one year to date)`. +| `commits_year` | Filters and counts only commits made in the specified year. | integer _(YYYY)_ | ` (one year to date)` | > [!NOTE]\ > When hide\_rank=`true`, the minimum card width is 270 px + the title length and padding. From bce273dcad568787dee55072a8d2008e2d583d25 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Mon, 29 Sep 2025 23:59:16 +0300 Subject: [PATCH 100/265] docs(readme): remove redundant steps words from tokens retrieval guides (#4476) Co-authored-by: Alexandr --- readme.md | 2 -- 1 file changed, 2 deletions(-) diff --git a/readme.md b/readme.md index d716d6b264821..903d22b235537 100644 --- a/readme.md +++ b/readme.md @@ -788,7 +788,6 @@ Selecting the right scopes for your token is important in case you want to displ ### Classic token -Steps: - Go to [Account -> Settings -> Developer Settings -> Personal access tokens -> Tokens (classic)](https://github.com/settings/tokens). - Click on `Generate new token -> Generate new token (classic)`. - Scopes to select: @@ -801,7 +800,6 @@ Steps: > [!WARNING]\ > This limits the number of issues to the number of issues on your repositories only and only takes public commits into account. -Steps: - Go to [Account -> Settings -> Developer Settings -> Personal access tokens -> Fine-grained tokens](https://github.com/settings/tokens). - Click on `Generate new token -> Generate new token`. - Select an expiration date From b118aee08cc06a0b1159b7707772da8e30eb7991 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Tue, 30 Sep 2025 21:59:33 +0300 Subject: [PATCH 101/265] docs(readme): enhance the description of deploy first steps section (#4483) Co-authored-by: Alexandr --- readme.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/readme.md b/readme.md index 903d22b235537..c8339452525c0 100644 --- a/readme.md +++ b/readme.md @@ -784,6 +784,8 @@ By default, GitHub does not lay out the cards side by side. To do that, you can ## First step: get your Personal Access Token (PAT) +For deploying your own instance of GitHub Readme Stats, you will need to create a GitHub Personal Access Token (PAT). Below are the steps to create one and the scopes you need to select for both classic and fine-grained tokens. + Selecting the right scopes for your token is important in case you want to display private contributions on your stats card. ### Classic token From e9bf75e9155e7ea03dce44bea63a13a4ea1fcbd8 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Tue, 30 Sep 2025 22:44:57 +0300 Subject: [PATCH 102/265] docs(readme): update wording since token scopes is not about stats card only (#4484) Co-authored-by: Alexandr --- readme.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/readme.md b/readme.md index c8339452525c0..93be329199637 100644 --- a/readme.md +++ b/readme.md @@ -786,7 +786,7 @@ By default, GitHub does not lay out the cards side by side. To do that, you can For deploying your own instance of GitHub Readme Stats, you will need to create a GitHub Personal Access Token (PAT). Below are the steps to create one and the scopes you need to select for both classic and fine-grained tokens. -Selecting the right scopes for your token is important in case you want to display private contributions on your stats card. +Selecting the right scopes for your token is important in case you want to display private contributions on your cards. ### Classic token From c6380b7f881a3c3c1cdb95a183842a16e34facca Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Tue, 30 Sep 2025 22:45:46 +0300 Subject: [PATCH 103/265] docs(readme): add warning about new wakatime accounts (#4485) Co-authored-by: Alexandr --- readme.md | 3 +++ 1 file changed, 3 insertions(+) diff --git a/readme.md b/readme.md index 93be329199637..f98cd4cac9338 100644 --- a/readme.md +++ b/readme.md @@ -621,6 +621,9 @@ You can use the `&stats_format=bytes` option to display the stats in bytes inste > [!WARNING]\ > Please be aware that we currently only show data from WakaTime profiles that are public. You therefore have to make sure that **BOTH** `Display code time publicly` and `Display languages, editors, os, categories publicly` are enabled. +> [!WARNING]\ +> In case you just created a new WakaTime account, then it might take up to 24 hours until your stats will become visible on the WakaTime stats card. + Change the `?username=` value to your [WakaTime](https://wakatime.com) username. ```md From 18c808afcfcb574ec3006ee1d9f063805844a17c Mon Sep 17 00:00:00 2001 From: Mark Anthony Tomas Date: Wed, 1 Oct 2025 04:01:52 +0800 Subject: [PATCH 104/265] feat: add Filipino translations (#3800) * Update translations.js Added translations. Filipino Languages which is main language that Philippines used. * Update translations.js Added translations. Filipino language which is the main language of Philippines. Added translations in translations.js * Update translations.js * docs * Update src/translations.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update src/translations.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --------- Co-authored-by: Alexandr Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --- readme.md | 1 + src/translations.js | 22 ++++++++++++++++++++++ 2 files changed, 23 insertions(+) diff --git a/readme.md b/readme.md index f98cd4cac9338..a782128433e4e 100644 --- a/readme.md +++ b/readme.md @@ -312,6 +312,7 @@ Here is a list of all available locales: | `cs` | Czech | | `nl` | Dutch | | `en` | English | +| `fil` | Filipino | | `fi` | Finnish | | `fr` | French | | `de` | German | diff --git a/src/translations.js b/src/translations.js index d9f5dee35d9ff..3fbb02d8a18c1 100644 --- a/src/translations.js +++ b/src/translations.js @@ -51,6 +51,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: `${encodedName}ning GitHub'dagi statistikasi`, vi: `Thống Kê GitHub ${encodedName}`, se: `GitHubstatistik för ${encodedName}`, + fil: `Mga Stats ng GitHub ni ${encodedName}`, th: `สถิติ GitHub ของ ${encodedName}`, sr: `GitHub статистика корисника ${encodedName}`, "sr-latn": `GitHub statistika korisnika ${encodedName}`, @@ -92,6 +93,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: `${encodedName}ning GitHub'dagi statistikasi`, vi: `Thống Kê GitHub ${encodedName}`, se: `GitHubstatistik för ${encodedName}`, + fil: `Ranggo ng GitHub ni ${encodedName}`, th: `อันดับ GitHub ของ ${encodedName}`, sr: `Ранк корисника ${encodedName}`, "sr-latn": `Rank korisnika ${encodedName}`, @@ -133,6 +135,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "Yulduzchalar", vi: "Tổng Số Sao", se: "Antal intjänade stjärnor", + fil: "Kabuuang Nakuhang Bituin", th: "ดาวทั้งหมดที่ได้รับ", sr: "Број освојених звездица", "sr-latn": "Broj osvojenih zvezdica", @@ -174,6 +177,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "'Commit'lar", vi: "Tổng Số Cam Kết", se: "Totalt antal commits", + fil: "Kabuuang Commits", th: "Commit ทั้งหมด", sr: "Укупно commit-ова", "sr-latn": "Ukupno commit-ova", @@ -215,6 +219,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "'Pull Request'lar", vi: "Tổng Số PR", se: "Totalt antal PR", + fil: "Kabuuang PRs", th: "PR ทั้งหมด", sr: "Укупно PR-ова", "sr-latn": "Ukupno PR-ova", @@ -256,6 +261,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "'Issue'lar", vi: "Tổng Số Vấn Đề", se: "Total antal issues", + fil: "Kabuuang mga Isyu", th: "Issue ทั้งหมด", sr: "Укупно пријављених проблема", "sr-latn": "Ukupno prijavljenih problema", @@ -297,6 +303,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "Hissa qoʻshgan (o'tgan yili)", vi: "Đã Đóng Góp (năm ngoái)", se: "Bidragit till (förra året)", + fil: "Nag-ambag sa (nakaraang taon)", th: "มีส่วนร่วมใน (ปีที่แล้ว)", sr: "Доприноси (прошла година)", "sr-latn": "Doprinosi (prošla godina)", @@ -338,6 +345,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "Koʻrib chiqilgan PR-lar soni", vi: "Tổng Số PR Đã Xem Xét", se: "Totalt antal granskade PR", + fil: "Kabuuang PR na Na-review", th: "รีวิว PR แล้วทั้งหมด", sr: "Укупно прегледаних PR-ова", "sr-latn": "Ukupno pregledanih PR-ova", @@ -379,6 +387,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "Boshlangan muzokaralar soni", vi: "Tổng Số Thảo Luận Bắt Đầu", se: "Totalt antal diskussioner startade", + fil: "Kabuuang mga Diskusyon na Sinimulan", th: "เริ่มหัวข้อสนทนาทั้งหมด", sr: "Укупно покренутих дискусија", "sr-latn": "Ukupno pokrenutih diskusija", @@ -420,6 +429,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "Javob berilgan muzokaralar soni", vi: "Tổng Số Thảo Luận Đã Trả Lời", se: "Totalt antal diskussioner besvarade", + fil: "Kabuuang mga Diskusyon na Sinagot", th: "ตอบกลับหัวข้อสนทนาทั้งหมด", sr: "Укупно одговорених дискусија", "sr-latn": "Ukupno odgovorenih diskusija", @@ -460,6 +470,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "Birlangan PR-lar soni", vi: "Tổng Số PR Đã Hợp Nhất", se: "Totalt antal sammanfogade PR", + fil: "Kabuuang mga PR na Pinagsama", th: "PR ที่ถูก Merged แล้วทั้งหมด", sr: "Укупно спојених PR-ова", "sr-latn": "Ukupno spojenih PR-ova", @@ -500,6 +511,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "Birlangan PR-lar foizi", vi: "Tỷ Lệ PR Đã Hợp Nhất", se: "Procent av sammanfogade PR", + fil: "Porsyento ng mga PR na Pinagsama", th: "เปอร์เซ็นต์ PR ที่ถูก Merged แล้วทั้งหมด", sr: "Проценат спојених PR-ова", "sr-latn": "Procenat spojenih PR-ova", @@ -545,6 +557,7 @@ const repoCardLocales = { uz: "Shablon", vi: "Mẫu", se: "Mall", + fil: "Suleras", th: "เทมเพลต", sr: "Шаблон", "sr-latn": "Šablon", @@ -586,6 +599,7 @@ const repoCardLocales = { uz: "Arxivlangan", vi: "Đã Lưu Trữ", se: "Arkiverade", + fil: "Naka-arkibo", th: "เก็บถาวร", sr: "Архивирано", "sr-latn": "Arhivirano", @@ -630,6 +644,7 @@ const langCardLocales = { uz: "Eng koʻp ishlatiladigan tillar", vi: "Ngôn Ngữ Thường Sử Dụng", se: "Mest använda språken", + fil: "Mga Pinakamadalas na Ginagamit na Wika", th: "ภาษาที่ใช้บ่อยที่สุด", sr: "Најкоришћенији језици", "sr-latn": "Najkorišćeniji jezici", @@ -671,6 +686,7 @@ const langCardLocales = { uz: "Til haqida ma'lumot yo'q.", vi: "Không có dữ liệu ngôn ngữ.", se: "Inga språkdata.", + fil: "Walang datos ng lenggwahe.", th: "ไม่มีข้อมูลภาษา", sr: "Нема података о језицима.", "sr-latn": "Nema podataka o jezicima.", @@ -715,6 +731,7 @@ const wakatimeCardLocales = { uz: "WakaTime statistikasi", vi: "Thống Kê WakaTime", se: "WakaTime statistik", + fil: "Mga Estadistika ng WakaTime", th: "สถิติ WakaTime", sr: "WakaTime статистика", "sr-latn": "WakaTime statistika", @@ -756,6 +773,7 @@ const wakatimeCardLocales = { uz: "O'tgan yil", vi: "Năm ngoái", se: "Förra året", + fil: "Nakaraang Taon", th: "ปีที่แล้ว", sr: "Прошла год.", "sr-latn": "Prošla god.", @@ -797,6 +815,7 @@ const wakatimeCardLocales = { uz: "O'tgan 7 kun", vi: "7 ngày qua", se: "Senaste 7 dagarna", + fil: "Huling 7 Araw", th: "7 วันที่ผ่านมา", sr: "Претходних 7 дана", "sr-latn": "Prethodnih 7 dana", @@ -838,6 +857,7 @@ const wakatimeCardLocales = { uz: "WakaTime foydalanuvchi profili ochiq emas", vi: "Hồ sơ người dùng WakaTime không công khai", se: "WakaTime användarprofil inte offentlig", + fil: "Hindi pampubliko ang profile ng gumagamit ng WakaTime", th: "โปรไฟล์ผู้ใช้ WakaTime ไม่ได้เป็นสาธารณะ", sr: "WakaTime профил корисника није јаван", "sr-latn": "WakaTime profil korisnika nije javan", @@ -881,6 +901,7 @@ const wakatimeCardLocales = { uz: "Foydalanuvchi umumiy ko`d statistikasini ochiq ravishda almashmaydi", vi: "Người dùng không chia sẻ thống kê mã chi tiết công khai", se: "Användaren delar inte offentligt detaljerad kodstatistik", + fil: "Hindi ibinabahagi ng gumagamit ang detalyadong estadistika ng code nang pampubliko", th: "ผู้ใช้ไม่ได้แชร์สถิติโค้ดแบบสาธารณะ", sr: "Корисник не дели јавно детаљну статистику кода", "sr-latn": "Korisnik ne deli javno detaljnu statistiku koda", @@ -922,6 +943,7 @@ const wakatimeCardLocales = { uz: "Bu hafta faol bo'lmadi", vi: "Không Có Hoạt Động Trong Tuần Này", se: "Ingen aktivitet denna vecka", + fil: "Walang aktibidad sa pag-code ngayong linggo", th: "ไม่มีกิจกรรมการเขียนโค้ดในสัปดาห์นี้", sr: "Током ове недеље није било никаквих активности", "sr-latn": "Tokom ove nedelje nije bilo nikakvih aktivnosti", From d286fa39be91280bc8f3d67556022ec8f904274d Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Tue, 30 Sep 2025 23:10:14 +0300 Subject: [PATCH 105/265] fix: mark Filipino langiage as long for stats card (#4486) Co-authored-by: Alexandr --- src/cards/stats.js | 1 + 1 file changed, 1 insertion(+) diff --git a/src/cards/stats.js b/src/cards/stats.js index 09b7a2ce16648..3b2579cbb7d79 100644 --- a/src/cards/stats.js +++ b/src/cards/stats.js @@ -367,6 +367,7 @@ const renderStatsCard = (stats, options = {}) => { const longLocales = [ "de", "es", + "fil", "fr", "id", "ml", From e466ada34ec42dd81dd612ca2ddd7941bc713e38 Mon Sep 17 00:00:00 2001 From: Ethan Date: Tue, 30 Sep 2025 23:43:58 +0300 Subject: [PATCH 106/265] feat: add Hebrew translations (#3957) * Added Hebrew * docs * Update src/translations.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --------- Co-authored-by: Alexandr Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --- readme.md | 1 + src/translations.js | 22 ++++++++++++++++++++++ 2 files changed, 23 insertions(+) diff --git a/readme.md b/readme.md index a782128433e4e..5e520dd9e7b9e 100644 --- a/readme.md +++ b/readme.md @@ -322,6 +322,7 @@ Here is a list of all available locales: | Code | Locale | | --- | --- | | `el` | Greek | +| `he` | Hebrew | | `hi` | Hindi | | `hu` | Hungarian | | `id` | Indonesian | diff --git a/src/translations.js b/src/translations.js index 3fbb02d8a18c1..f0218d0ad1369 100644 --- a/src/translations.js +++ b/src/translations.js @@ -51,6 +51,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: `${encodedName}ning GitHub'dagi statistikasi`, vi: `Thống Kê GitHub ${encodedName}`, se: `GitHubstatistik för ${encodedName}`, + he: `סטטיסטיקות הגיטהאב של ${encodedName}`, fil: `Mga Stats ng GitHub ni ${encodedName}`, th: `สถิติ GitHub ของ ${encodedName}`, sr: `GitHub статистика корисника ${encodedName}`, @@ -93,6 +94,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: `${encodedName}ning GitHub'dagi statistikasi`, vi: `Thống Kê GitHub ${encodedName}`, se: `GitHubstatistik för ${encodedName}`, + he: `דרגת הגיטהאב של ${encodedName}`, fil: `Ranggo ng GitHub ni ${encodedName}`, th: `อันดับ GitHub ของ ${encodedName}`, sr: `Ранк корисника ${encodedName}`, @@ -135,6 +137,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "Yulduzchalar", vi: "Tổng Số Sao", se: "Antal intjänade stjärnor", + he: "סך כל הכוכבים שהושגו", fil: "Kabuuang Nakuhang Bituin", th: "ดาวทั้งหมดที่ได้รับ", sr: "Број освојених звездица", @@ -177,6 +180,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "'Commit'lar", vi: "Tổng Số Cam Kết", se: "Totalt antal commits", + he: "סך כל ה־commits", fil: "Kabuuang Commits", th: "Commit ทั้งหมด", sr: "Укупно commit-ова", @@ -219,6 +223,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "'Pull Request'lar", vi: "Tổng Số PR", se: "Totalt antal PR", + he: "סך כל ה־PRs", fil: "Kabuuang PRs", th: "PR ทั้งหมด", sr: "Укупно PR-ова", @@ -261,6 +266,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "'Issue'lar", vi: "Tổng Số Vấn Đề", se: "Total antal issues", + he: "סך כל ה־issues", fil: "Kabuuang mga Isyu", th: "Issue ทั้งหมด", sr: "Укупно пријављених проблема", @@ -303,6 +309,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "Hissa qoʻshgan (o'tgan yili)", vi: "Đã Đóng Góp (năm ngoái)", se: "Bidragit till (förra året)", + he: "תרם ל... (שנה שעברה)", fil: "Nag-ambag sa (nakaraang taon)", th: "มีส่วนร่วมใน (ปีที่แล้ว)", sr: "Доприноси (прошла година)", @@ -345,6 +352,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "Koʻrib chiqilgan PR-lar soni", vi: "Tổng Số PR Đã Xem Xét", se: "Totalt antal granskade PR", + he: "סך כל ה־PRs שנסרקו", fil: "Kabuuang PR na Na-review", th: "รีวิว PR แล้วทั้งหมด", sr: "Укупно прегледаних PR-ова", @@ -387,6 +395,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "Boshlangan muzokaralar soni", vi: "Tổng Số Thảo Luận Bắt Đầu", se: "Totalt antal diskussioner startade", + he: "סך כל הדיונים שהותחלו", fil: "Kabuuang mga Diskusyon na Sinimulan", th: "เริ่มหัวข้อสนทนาทั้งหมด", sr: "Укупно покренутих дискусија", @@ -429,6 +438,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "Javob berilgan muzokaralar soni", vi: "Tổng Số Thảo Luận Đã Trả Lời", se: "Totalt antal diskussioner besvarade", + he: "סך כל הדיונים שנענו", fil: "Kabuuang mga Diskusyon na Sinagot", th: "ตอบกลับหัวข้อสนทนาทั้งหมด", sr: "Укупно одговорених дискусија", @@ -470,6 +480,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "Birlangan PR-lar soni", vi: "Tổng Số PR Đã Hợp Nhất", se: "Totalt antal sammanfogade PR", + he: "סך כל ה־PRs ששולבו", fil: "Kabuuang mga PR na Pinagsama", th: "PR ที่ถูก Merged แล้วทั้งหมด", sr: "Укупно спојених PR-ова", @@ -511,6 +522,7 @@ const statCardLocales = ({ name, apostrophe }) => { uz: "Birlangan PR-lar foizi", vi: "Tỷ Lệ PR Đã Hợp Nhất", se: "Procent av sammanfogade PR", + he: "אחוז ה־PRs ששולבו", fil: "Porsyento ng mga PR na Pinagsama", th: "เปอร์เซ็นต์ PR ที่ถูก Merged แล้วทั้งหมด", sr: "Проценат спојених PR-ова", @@ -557,6 +569,7 @@ const repoCardLocales = { uz: "Shablon", vi: "Mẫu", se: "Mall", + he: "תבנית", fil: "Suleras", th: "เทมเพลต", sr: "Шаблон", @@ -599,6 +612,7 @@ const repoCardLocales = { uz: "Arxivlangan", vi: "Đã Lưu Trữ", se: "Arkiverade", + he: "גנוז", fil: "Naka-arkibo", th: "เก็บถาวร", sr: "Архивирано", @@ -644,6 +658,7 @@ const langCardLocales = { uz: "Eng koʻp ishlatiladigan tillar", vi: "Ngôn Ngữ Thường Sử Dụng", se: "Mest använda språken", + he: "השפות הכי משומשות", fil: "Mga Pinakamadalas na Ginagamit na Wika", th: "ภาษาที่ใช้บ่อยที่สุด", sr: "Најкоришћенији језици", @@ -686,6 +701,7 @@ const langCardLocales = { uz: "Til haqida ma'lumot yo'q.", vi: "Không có dữ liệu ngôn ngữ.", se: "Inga språkdata.", + he: "אין נתוני שפות", fil: "Walang datos ng lenggwahe.", th: "ไม่มีข้อมูลภาษา", sr: "Нема података о језицима.", @@ -731,6 +747,7 @@ const wakatimeCardLocales = { uz: "WakaTime statistikasi", vi: "Thống Kê WakaTime", se: "WakaTime statistik", + he: "סטטיסטיקות WakaTime", fil: "Mga Estadistika ng WakaTime", th: "สถิติ WakaTime", sr: "WakaTime статистика", @@ -773,6 +790,7 @@ const wakatimeCardLocales = { uz: "O'tgan yil", vi: "Năm ngoái", se: "Förra året", + he: "שנה שעברה", fil: "Nakaraang Taon", th: "ปีที่แล้ว", sr: "Прошла год.", @@ -815,6 +833,7 @@ const wakatimeCardLocales = { uz: "O'tgan 7 kun", vi: "7 ngày qua", se: "Senaste 7 dagarna", + he: "ב־7 הימים האחרונים", fil: "Huling 7 Araw", th: "7 วันที่ผ่านมา", sr: "Претходних 7 дана", @@ -857,6 +876,7 @@ const wakatimeCardLocales = { uz: "WakaTime foydalanuvchi profili ochiq emas", vi: "Hồ sơ người dùng WakaTime không công khai", se: "WakaTime användarprofil inte offentlig", + he: "פרופיל משתמש WakaTime לא פומבי", fil: "Hindi pampubliko ang profile ng gumagamit ng WakaTime", th: "โปรไฟล์ผู้ใช้ WakaTime ไม่ได้เป็นสาธารณะ", sr: "WakaTime профил корисника није јаван", @@ -901,6 +921,7 @@ const wakatimeCardLocales = { uz: "Foydalanuvchi umumiy ko`d statistikasini ochiq ravishda almashmaydi", vi: "Người dùng không chia sẻ thống kê mã chi tiết công khai", se: "Användaren delar inte offentligt detaljerad kodstatistik", + he: "משתמש לא מפרסם פומבית סטטיסטיקות קוד מפורטות", fil: "Hindi ibinabahagi ng gumagamit ang detalyadong estadistika ng code nang pampubliko", th: "ผู้ใช้ไม่ได้แชร์สถิติโค้ดแบบสาธารณะ", sr: "Корисник не дели јавно детаљну статистику кода", @@ -943,6 +964,7 @@ const wakatimeCardLocales = { uz: "Bu hafta faol bo'lmadi", vi: "Không Có Hoạt Động Trong Tuần Này", se: "Ingen aktivitet denna vecka", + he: "אין פעילות תכנותית השבוע", fil: "Walang aktibidad sa pag-code ngayong linggo", th: "ไม่มีกิจกรรมการเขียนโค้ดในสัปดาห์นี้", sr: "Током ове недеље није било никаквих активности", From 651de3afe4e6414ec4ba5a2c6fd87e8536b42e8e Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Wed, 1 Oct 2025 20:19:27 +0300 Subject: [PATCH 107/265] docs(readme): add notice about hacktoberfest (#4491) * docs(readme): add notice about hacktoberfest * dev --------- Co-authored-by: Alexandr --- readme.md | 3 +++ 1 file changed, 3 insertions(+) diff --git a/readme.md b/readme.md index 5e520dd9e7b9e..74191f4e1e392 100644 --- a/readme.md +++ b/readme.md @@ -98,6 +98,9 @@ # Important Notices +> [!IMPORTANT]\ +> Please note that we are NOT participating in Hacktoberfest this year. Unfortunately, the only person with sufficient access rights to remove the repository label is currently unreachable, so we are notifying you here. As a small team, we cannot handle the increased volume of PRs and issues that the event brings. We appreciate your understanding. + > [!IMPORTANT]\ > Since the GitHub API only [allows 5k requests per hour per user account](https://docs.github.com/en/graphql/overview/resource-limitations), the public Vercel instance hosted on `https://github-readme-stats.vercel.app/api` could possibly hit the rate limiter (see [#1471](https://github.com/anuraghazra/github-readme-stats/issues/1471)). We use caching to prevent this from happening (see https://github.com/anuraghazra/github-readme-stats#common-options). You can turn off these rate limit protections by deploying [your own Vercel instance](#disable-rate-limit-protections). From 0d60641b7c4002ae8ac9731bf9a89de34151985d Mon Sep 17 00:00:00 2001 From: Chongyi Zheng Date: Wed, 1 Oct 2025 14:20:32 -0500 Subject: [PATCH 108/265] tests: use custom benchmarking solution instead of outdated `jest-bench` package (#4468) * Remove jest-bench dependency and use custom solutions * review * Update tests/bench/calculateRank.bench.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --------- Co-authored-by: Alexandr Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --- jest.bench.config.js | 23 ++- package-lock.json | 270 ----------------------------- package.json | 1 - tests/bench/api.bench.js | 10 +- tests/bench/calculateRank.bench.js | 9 +- tests/bench/gist.bench.js | 10 +- tests/bench/pin.bench.js | 10 +- tests/bench/utils.js | 127 ++++++++++++++ 8 files changed, 157 insertions(+), 303 deletions(-) create mode 100644 tests/bench/utils.js diff --git a/jest.bench.config.js b/jest.bench.config.js index 8a39b14d30743..880f918d76f2a 100644 --- a/jest.bench.config.js +++ b/jest.bench.config.js @@ -1,16 +1,13 @@ export default { - // Jest-bench need its own test environment to function - testEnvironment: "jest-bench/environment", - testEnvironmentOptions: { - // still Jest-bench environment will run your environment if you specify it here - testEnvironment: "jest-environment-node", - testEnvironmentOptions: { - // specify any option for your environment - }, - }, - // always include "default" reporter along with Jest-bench reporter - // for error reporting - reporters: ["default", "jest-bench/reporter"], - // will pick up "*.bench.js" file. + clearMocks: true, + transform: {}, + testEnvironment: "jsdom", + coverageProvider: "v8", + testPathIgnorePatterns: ["/node_modules/", "/tests/e2e/"], + modulePathIgnorePatterns: ["/node_modules/", "/tests/e2e/"], + coveragePathIgnorePatterns: [ + "/node_modules/", + "/tests/e2e/", + ], testRegex: "(\\.bench)\\.(ts|tsx|js)$", }; diff --git a/package-lock.json b/package-lock.json index 01cdd0e322dcf..7306b2b5845b9 100644 --- a/package-lock.json +++ b/package-lock.json @@ -33,7 +33,6 @@ "hjson": "^3.2.2", "husky": "^9.1.7", "jest": "^29.7.0", - "jest-bench": "^29.7.1", "jest-environment-jsdom": "^30.1.2", "js-yaml": "^4.1.0", "lint-staged": "^16.2.0", @@ -2349,16 +2348,6 @@ "dev": true, "license": "Apache-2.0" }, - "node_modules/benchmark": { - "version": "2.1.4", - "resolved": "https://registry.npmjs.org/benchmark/-/benchmark-2.1.4.tgz", - "integrity": "sha512-l9MlfN4M1K/H2fbhfMy3B7vJd6AGKJVQn2h6Sg/Yx+KckoUA7ewS5Vv6TjSq18ooE1kS9hhAlQRH3AkXIh/aOQ==", - "dev": true, - "dependencies": { - "lodash": "^4.17.4", - "platform": "^1.3.3" - } - }, "node_modules/brace-expansion": { "version": "1.1.11", "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", @@ -3165,18 +3154,6 @@ "url": "https://opencollective.com/eslint" } }, - "node_modules/eslint/node_modules/@eslint/js": { - "version": "9.35.0", - "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.35.0.tgz", - "integrity": "sha512-30iXE9whjlILfWobBkNerJo+TXYsgVM5ERQwMcMKCHckHflCmf7wXDAHlARoWnh0s1U72WqlbeyE7iAcCzuCPw==", - "dev": true, - "engines": { - "node": "^18.18.0 || ^20.9.0 || >=21.1.0" - }, - "funding": { - "url": "https://eslint.org/donate" - } - }, "node_modules/eslint/node_modules/escape-string-regexp": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", @@ -4176,23 +4153,6 @@ } } }, - "node_modules/jest-bench": { - "version": "29.7.1", - "resolved": "https://registry.npmjs.org/jest-bench/-/jest-bench-29.7.1.tgz", - "integrity": "sha512-eFjQa+KVThwqY+Ecs9jeD+CdTUlDrJUAAFLy+DlWW5H1crnG1F4ad5Dk8K+kV6nB2aGCdFcusKBdgtx1SXYiHQ==", - "dev": true, - "dependencies": { - "@jest/globals": "^29.7.0", - "@jest/reporters": "^29.7.0", - "benchmark": "^2.1.4", - "chalk": "^4.1.0", - "lodash": "^4.17.20", - "ndjson": "^2.0.0" - }, - "peerDependencies": { - "jest": "^29.7.0" - } - }, "node_modules/jest-changed-files": { "version": "29.7.0", "resolved": "https://registry.npmjs.org/jest-changed-files/-/jest-changed-files-29.7.0.tgz", @@ -5356,12 +5316,6 @@ "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==", "dev": true }, - "node_modules/json-stringify-safe": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", - "integrity": "sha512-ZClg6AaYvamvYEE82d3Iyd3vSSIjQ+odgjaTzRuO3s7toCdFKczob2i0zCh7JE8kWn17yvAWhUVxvqGwUalsRA==", - "dev": true - }, "node_modules/json5": { "version": "2.2.3", "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz", @@ -5539,12 +5493,6 @@ "node": ">=8" } }, - "node_modules/lodash": { - "version": "4.17.21", - "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", - "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", - "dev": true - }, "node_modules/lodash.merge": { "version": "4.6.2", "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", @@ -5833,15 +5781,6 @@ "node": "*" } }, - "node_modules/minimist": { - "version": "1.2.8", - "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.8.tgz", - "integrity": "sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA==", - "dev": true, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, "node_modules/ms": { "version": "2.1.3", "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", @@ -5866,25 +5805,6 @@ "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", "dev": true }, - "node_modules/ndjson": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/ndjson/-/ndjson-2.0.0.tgz", - "integrity": "sha512-nGl7LRGrzugTtaFcJMhLbpzJM6XdivmbkdlaGcrk/LXg2KL/YBC6z1g70xh0/al+oFuVFP8N8kiWRucmeEH/qQ==", - "dev": true, - "dependencies": { - "json-stringify-safe": "^5.0.1", - "minimist": "^1.2.5", - "readable-stream": "^3.6.0", - "split2": "^3.0.0", - "through2": "^4.0.0" - }, - "bin": { - "ndjson": "cli.js" - }, - "engines": { - "node": ">=10" - } - }, "node_modules/node-int64": { "version": "0.4.0", "resolved": "https://registry.npmjs.org/node-int64/-/node-int64-0.4.0.tgz", @@ -6169,12 +6089,6 @@ "node": ">=8" } }, - "node_modules/platform": { - "version": "1.3.6", - "resolved": "https://registry.npmjs.org/platform/-/platform-1.3.6.tgz", - "integrity": "sha512-fnWVljUchTro6RiCFvCXBbNhJc2NijN7oIQxbwsyL0buWJPG85v81ehlHI9fXrJsMNgTofEoWIQeClKpgxFLrg==", - "dev": true - }, "node_modules/prettier": { "version": "3.6.2", "resolved": "https://registry.npmjs.org/prettier/-/prettier-3.6.2.tgz", @@ -6265,20 +6179,6 @@ "integrity": "sha512-w2GsyukL62IJnlaff/nRegPQR94C/XXamvMWmSHRJ4y7Ts/4ocGRmTHvOs8PSE6pB3dWOrD/nueuU5sduBsQ4w==", "dev": true }, - "node_modules/readable-stream": { - "version": "3.6.2", - "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.2.tgz", - "integrity": "sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA==", - "dev": true, - "dependencies": { - "inherits": "^2.0.3", - "string_decoder": "^1.1.1", - "util-deprecate": "^1.0.1" - }, - "engines": { - "node": ">= 6" - } - }, "node_modules/redent": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/redent/-/redent-3.0.0.tgz", @@ -6409,26 +6309,6 @@ "integrity": "sha512-guoltQEx+9aMf2gDZ0s62EcV8lsXR+0w8915TC3ITdn2YueuNjdAYh/levpU9nFaoChh9RUS5ZdQMrKfVEN9tw==", "dev": true }, - "node_modules/safe-buffer": { - "version": "5.2.1", - "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", - "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", - "dev": true, - "funding": [ - { - "type": "github", - "url": "https://github.com/sponsors/feross" - }, - { - "type": "patreon", - "url": "https://www.patreon.com/feross" - }, - { - "type": "consulting", - "url": "https://feross.org/support" - } - ] - }, "node_modules/safer-buffer": { "version": "2.1.2", "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", @@ -6582,15 +6462,6 @@ "integrity": "sha512-xxRs31BqRYHwiMzudOrpSiHtZ8i/GeionCBDSilhYRj+9gIcI8wCZTlXZKu9vZIVqViP3dcp9qE5G6AlIaD+TQ==", "dev": true }, - "node_modules/split2": { - "version": "3.2.2", - "resolved": "https://registry.npmjs.org/split2/-/split2-3.2.2.tgz", - "integrity": "sha512-9NThjpgZnifTkJpzTZ7Eue85S49QwpNhZTq6GRJwObb6jnLFNGB7Qm73V5HewTROPyxD0C29xqmaI68bQtV+hg==", - "dev": true, - "dependencies": { - "readable-stream": "^3.0.0" - } - }, "node_modules/sprintf-js": { "version": "1.0.3", "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", @@ -6609,15 +6480,6 @@ "node": ">=10" } }, - "node_modules/string_decoder": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", - "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", - "dev": true, - "dependencies": { - "safe-buffer": "~5.2.0" - } - }, "node_modules/string-argv": { "version": "0.3.2", "resolved": "https://registry.npmjs.org/string-argv/-/string-argv-0.3.2.tgz", @@ -6752,15 +6614,6 @@ "node": ">=8" } }, - "node_modules/through2": { - "version": "4.0.2", - "resolved": "https://registry.npmjs.org/through2/-/through2-4.0.2.tgz", - "integrity": "sha512-iOqSav00cVxEEICeD7TjLB1sueEL+81Wpzp2bY17uZjZN0pWZPuo4suZ/61VujxmqSGFfgOcNuTZ85QJwNZQpw==", - "dev": true, - "dependencies": { - "readable-stream": "3" - } - }, "node_modules/tldts": { "version": "6.1.86", "resolved": "https://registry.npmjs.org/tldts/-/tldts-6.1.86.tgz", @@ -6924,12 +6777,6 @@ "punycode": "^2.1.0" } }, - "node_modules/util-deprecate": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", - "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==", - "dev": true - }, "node_modules/v8-to-istanbul": { "version": "9.1.0", "resolved": "https://registry.npmjs.org/v8-to-istanbul/-/v8-to-istanbul-9.1.0.tgz", @@ -8927,16 +8774,6 @@ "integrity": "sha512-NzUnlZexiaH/46WDhANlyR2bXRopNg4F/zuSA3OpZnllCUgRaOF2znDioDWrmbNVsuZk6l9pMquQB38cfBZwkQ==", "dev": true }, - "benchmark": { - "version": "2.1.4", - "resolved": "https://registry.npmjs.org/benchmark/-/benchmark-2.1.4.tgz", - "integrity": "sha512-l9MlfN4M1K/H2fbhfMy3B7vJd6AGKJVQn2h6Sg/Yx+KckoUA7ewS5Vv6TjSq18ooE1kS9hhAlQRH3AkXIh/aOQ==", - "dev": true, - "requires": { - "lodash": "^4.17.4", - "platform": "^1.3.3" - } - }, "brace-expansion": { "version": "1.1.11", "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", @@ -9430,12 +9267,6 @@ "optionator": "^0.9.3" }, "dependencies": { - "@eslint/js": { - "version": "9.35.0", - "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.35.0.tgz", - "integrity": "sha512-30iXE9whjlILfWobBkNerJo+TXYsgVM5ERQwMcMKCHckHflCmf7wXDAHlARoWnh0s1U72WqlbeyE7iAcCzuCPw==", - "dev": true - }, "escape-string-regexp": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", @@ -10172,20 +10003,6 @@ "jest-cli": "^29.7.0" } }, - "jest-bench": { - "version": "29.7.1", - "resolved": "https://registry.npmjs.org/jest-bench/-/jest-bench-29.7.1.tgz", - "integrity": "sha512-eFjQa+KVThwqY+Ecs9jeD+CdTUlDrJUAAFLy+DlWW5H1crnG1F4ad5Dk8K+kV6nB2aGCdFcusKBdgtx1SXYiHQ==", - "dev": true, - "requires": { - "@jest/globals": "^29.7.0", - "@jest/reporters": "^29.7.0", - "benchmark": "^2.1.4", - "chalk": "^4.1.0", - "lodash": "^4.17.20", - "ndjson": "^2.0.0" - } - }, "jest-changed-files": { "version": "29.7.0", "resolved": "https://registry.npmjs.org/jest-changed-files/-/jest-changed-files-29.7.0.tgz", @@ -11083,12 +10900,6 @@ "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==", "dev": true }, - "json-stringify-safe": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", - "integrity": "sha512-ZClg6AaYvamvYEE82d3Iyd3vSSIjQ+odgjaTzRuO3s7toCdFKczob2i0zCh7JE8kWn17yvAWhUVxvqGwUalsRA==", - "dev": true - }, "json5": { "version": "2.2.3", "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz", @@ -11211,12 +11022,6 @@ "p-locate": "^4.1.0" } }, - "lodash": { - "version": "4.17.21", - "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", - "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", - "dev": true - }, "lodash.merge": { "version": "4.6.2", "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", @@ -11422,12 +11227,6 @@ "brace-expansion": "^1.1.7" } }, - "minimist": { - "version": "1.2.8", - "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.8.tgz", - "integrity": "sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA==", - "dev": true - }, "ms": { "version": "2.1.3", "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", @@ -11446,19 +11245,6 @@ "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", "dev": true }, - "ndjson": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/ndjson/-/ndjson-2.0.0.tgz", - "integrity": "sha512-nGl7LRGrzugTtaFcJMhLbpzJM6XdivmbkdlaGcrk/LXg2KL/YBC6z1g70xh0/al+oFuVFP8N8kiWRucmeEH/qQ==", - "dev": true, - "requires": { - "json-stringify-safe": "^5.0.1", - "minimist": "^1.2.5", - "readable-stream": "^3.6.0", - "split2": "^3.0.0", - "through2": "^4.0.0" - } - }, "node-int64": { "version": "0.4.0", "resolved": "https://registry.npmjs.org/node-int64/-/node-int64-0.4.0.tgz", @@ -11670,12 +11456,6 @@ "find-up": "^4.0.0" } }, - "platform": { - "version": "1.3.6", - "resolved": "https://registry.npmjs.org/platform/-/platform-1.3.6.tgz", - "integrity": "sha512-fnWVljUchTro6RiCFvCXBbNhJc2NijN7oIQxbwsyL0buWJPG85v81ehlHI9fXrJsMNgTofEoWIQeClKpgxFLrg==", - "dev": true - }, "prettier": { "version": "3.6.2", "resolved": "https://registry.npmjs.org/prettier/-/prettier-3.6.2.tgz", @@ -11734,17 +11514,6 @@ "integrity": "sha512-w2GsyukL62IJnlaff/nRegPQR94C/XXamvMWmSHRJ4y7Ts/4ocGRmTHvOs8PSE6pB3dWOrD/nueuU5sduBsQ4w==", "dev": true }, - "readable-stream": { - "version": "3.6.2", - "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.2.tgz", - "integrity": "sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA==", - "dev": true, - "requires": { - "inherits": "^2.0.3", - "string_decoder": "^1.1.1", - "util-deprecate": "^1.0.1" - } - }, "redent": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/redent/-/redent-3.0.0.tgz", @@ -11838,12 +11607,6 @@ "integrity": "sha512-guoltQEx+9aMf2gDZ0s62EcV8lsXR+0w8915TC3ITdn2YueuNjdAYh/levpU9nFaoChh9RUS5ZdQMrKfVEN9tw==", "dev": true }, - "safe-buffer": { - "version": "5.2.1", - "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", - "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", - "dev": true - }, "safer-buffer": { "version": "2.1.2", "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", @@ -11963,15 +11726,6 @@ "integrity": "sha512-xxRs31BqRYHwiMzudOrpSiHtZ8i/GeionCBDSilhYRj+9gIcI8wCZTlXZKu9vZIVqViP3dcp9qE5G6AlIaD+TQ==", "dev": true }, - "split2": { - "version": "3.2.2", - "resolved": "https://registry.npmjs.org/split2/-/split2-3.2.2.tgz", - "integrity": "sha512-9NThjpgZnifTkJpzTZ7Eue85S49QwpNhZTq6GRJwObb6jnLFNGB7Qm73V5HewTROPyxD0C29xqmaI68bQtV+hg==", - "dev": true, - "requires": { - "readable-stream": "^3.0.0" - } - }, "sprintf-js": { "version": "1.0.3", "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", @@ -11987,15 +11741,6 @@ "escape-string-regexp": "^2.0.0" } }, - "string_decoder": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", - "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", - "dev": true, - "requires": { - "safe-buffer": "~5.2.0" - } - }, "string-argv": { "version": "0.3.2", "resolved": "https://registry.npmjs.org/string-argv/-/string-argv-0.3.2.tgz", @@ -12091,15 +11836,6 @@ "minimatch": "^3.0.4" } }, - "through2": { - "version": "4.0.2", - "resolved": "https://registry.npmjs.org/through2/-/through2-4.0.2.tgz", - "integrity": "sha512-iOqSav00cVxEEICeD7TjLB1sueEL+81Wpzp2bY17uZjZN0pWZPuo4suZ/61VujxmqSGFfgOcNuTZ85QJwNZQpw==", - "dev": true, - "requires": { - "readable-stream": "3" - } - }, "tldts": { "version": "6.1.86", "resolved": "https://registry.npmjs.org/tldts/-/tldts-6.1.86.tgz", @@ -12211,12 +11947,6 @@ "punycode": "^2.1.0" } }, - "util-deprecate": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", - "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==", - "dev": true - }, "v8-to-istanbul": { "version": "9.1.0", "resolved": "https://registry.npmjs.org/v8-to-istanbul/-/v8-to-istanbul-9.1.0.tgz", diff --git a/package.json b/package.json index cdbdebd356b01..003759510d450 100644 --- a/package.json +++ b/package.json @@ -52,7 +52,6 @@ "hjson": "^3.2.2", "husky": "^9.1.7", "jest": "^29.7.0", - "jest-bench": "^29.7.1", "jest-environment-jsdom": "^30.1.2", "js-yaml": "^4.1.0", "lint-staged": "^16.2.0", diff --git a/tests/bench/api.bench.js b/tests/bench/api.bench.js index f5f192d97e131..d6581da3f9752 100644 --- a/tests/bench/api.bench.js +++ b/tests/bench/api.bench.js @@ -1,8 +1,8 @@ -import { benchmarkSuite } from "jest-bench"; import api from "../../api/index.js"; import axios from "axios"; import MockAdapter from "axios-mock-adapter"; -import { jest } from "@jest/globals"; +import { it, jest } from "@jest/globals"; +import { runAndLogStats } from "./utils.js"; const stats = { name: "Anurag Hazra", @@ -69,10 +69,10 @@ const faker = (query, data) => { return { req, res }; }; -benchmarkSuite("test /api", { - ["simple request"]: async () => { +it("test /api", async () => { + await runAndLogStats("test /api", async () => { const { req, res } = faker({}, data_stats); await api(req, res); - }, + }); }); diff --git a/tests/bench/calculateRank.bench.js b/tests/bench/calculateRank.bench.js index 1ce6b05b28291..6907dd21af290 100644 --- a/tests/bench/calculateRank.bench.js +++ b/tests/bench/calculateRank.bench.js @@ -1,8 +1,9 @@ -import { benchmarkSuite } from "jest-bench"; import { calculateRank } from "../../src/calculateRank.js"; +import { it } from "@jest/globals"; +import { runAndLogStats } from "./utils.js"; -benchmarkSuite("calculateRank", { - ["calculateRank"]: () => { +it("calculateRank", async () => { + await runAndLogStats("calculateRank", () => { calculateRank({ all_commits: false, commits: 1300, @@ -13,5 +14,5 @@ benchmarkSuite("calculateRank", { stars: 600000, followers: 50000, }); - }, + }); }); diff --git a/tests/bench/gist.bench.js b/tests/bench/gist.bench.js index 69f381379c20b..66e618ec810ec 100644 --- a/tests/bench/gist.bench.js +++ b/tests/bench/gist.bench.js @@ -1,8 +1,8 @@ -import { benchmarkSuite } from "jest-bench"; import gist from "../../api/gist.js"; import axios from "axios"; import MockAdapter from "axios-mock-adapter"; -import { jest } from "@jest/globals"; +import { it, jest } from "@jest/globals"; +import { runAndLogStats } from "./utils.js"; const gist_data = { data: { @@ -34,8 +34,8 @@ const gist_data = { const mock = new MockAdapter(axios); mock.onPost("https://api.github.com/graphql").reply(200, gist_data); -benchmarkSuite("test /api/gist", { - ["simple request"]: async () => { +it("test /api/gist", async () => { + await runAndLogStats("test /api/gist", async () => { const req = { query: { id: "bbfce31e0217a3689c8d961a356cb10d", @@ -47,5 +47,5 @@ benchmarkSuite("test /api/gist", { }; await gist(req, res); - }, + }); }); diff --git a/tests/bench/pin.bench.js b/tests/bench/pin.bench.js index 636e0d58bdd79..9a2498460dfa2 100644 --- a/tests/bench/pin.bench.js +++ b/tests/bench/pin.bench.js @@ -1,8 +1,8 @@ -import { benchmarkSuite } from "jest-bench"; import pin from "../../api/pin.js"; import axios from "axios"; import MockAdapter from "axios-mock-adapter"; -import { jest } from "@jest/globals"; +import { it, jest } from "@jest/globals"; +import { runAndLogStats } from "./utils.js"; const data_repo = { repository: { @@ -32,8 +32,8 @@ const data_user = { const mock = new MockAdapter(axios); mock.onPost("https://api.github.com/graphql").reply(200, data_user); -benchmarkSuite("test /api/pin", { - ["simple request"]: async () => { +it("test /api/pin", async () => { + await runAndLogStats("test /api/pin", async () => { const req = { query: { username: "anuraghazra", @@ -46,5 +46,5 @@ benchmarkSuite("test /api/pin", { }; await pin(req, res); - }, + }); }); diff --git a/tests/bench/utils.js b/tests/bench/utils.js new file mode 100644 index 0000000000000..a94b258b9e1b2 --- /dev/null +++ b/tests/bench/utils.js @@ -0,0 +1,127 @@ +const DEFAULT_RUNS = 1000; +const DEFAULT_WARMUPS = 50; + +/** + * Formats a duration in nanoseconds to a compact human-readable string. + * @param {bigint} ns Duration in nanoseconds. + * @returns {string} Formatted time string. + */ +const formatTime = (ns) => { + if (ns < 1_000n) { + return `${ns}ns`; + } + if (ns < 1_000_000n) { + return `${Number(ns) / 1_000}µs`; + } + if (ns < 1_000_000_000n) { + return `${(Number(ns) / 1_000_000).toFixed(3)}ms`; + } + return `${(Number(ns) / 1_000_000_000).toFixed(3)}s`; +}; + +/** + * Measures synchronous or async function execution time. + * @param {Function} fn Function to measure. + * @returns {Promise} elapsed nanoseconds + */ +const measurePerformance = async (fn) => { + const start = process.hrtime.bigint(); + const ret = fn(); + if (ret instanceof Promise) { + await ret; + } + const end = process.hrtime.bigint(); + return end - start; +}; + +/** + * Computes basic & extended statistics. + * @param {bigint[]} samples Array of samples in nanoseconds. + * @returns {object} Stats + */ +const computeStats = (samples) => { + const sorted = [...samples].sort((a, b) => (a < b ? -1 : 1)); + const toNumber = (b) => Number(b); // safe for typical short benches + const n = sorted.length; + const sum = sorted.reduce((a, b) => a + b, 0n); + const avg = Number(sum) / n; + const median = + n % 2 + ? toNumber(sorted[(n - 1) / 2]) + : (toNumber(sorted[n / 2 - 1]) + toNumber(sorted[n / 2])) / 2; + const p = (q) => { + const idx = Math.min(n - 1, Math.floor((q / 100) * n)); + return toNumber(sorted[idx]); + }; + const min = toNumber(sorted[0]); + const max = toNumber(sorted[n - 1]); + const variance = + sorted.reduce((acc, v) => acc + (toNumber(v) - avg) ** 2, 0) / n; + const stdev = Math.sqrt(variance); + + return { + runs: n, + min, + max, + average: avg, + median, + p75: p(75), + p95: p(95), + p99: p(99), + stdev, + totalTime: toNumber(sum), + }; +}; + +/** + * Benchmark a function. + * @param {string} fnName Name of the function (for logging). + * @param {Function} fn Function to benchmark. + * @param {object} [opts] Options. + * @param {number} [opts.runs] Number of measured runs. + * @param {number} [opts.warmup] Warm-up iterations (not measured). + * @param {boolean} [opts.trimOutliers] Drop top & bottom 1% before stats. + * @returns {Promise} Stats (nanoseconds for core metrics). + */ +export const runAndLogStats = async ( + fnName, + fn, + { runs = DEFAULT_RUNS, warmup = DEFAULT_WARMUPS, trimOutliers = false } = {}, +) => { + if (runs <= 0) { + throw new Error("Number of runs must be positive."); + } + + // Warm-up + for (let i = 0; i < warmup; i++) { + const ret = fn(); + if (ret instanceof Promise) { + await ret; + } + } + + const samples = []; + for (let i = 0; i < runs; i++) { + samples.push(await measurePerformance(fn)); + } + + let processed = samples; + if (trimOutliers && samples.length > 10) { + const sorted = [...samples].sort((a, b) => (a < b ? -1 : 1)); + const cut = Math.max(1, Math.floor(sorted.length * 0.01)); + processed = sorted.slice(cut, sorted.length - cut); + } + + const stats = computeStats(processed); + + const fmt = (ns) => formatTime(BigInt(Math.round(ns))); + console.log( + `${fnName} | runs=${stats.runs} avg=${fmt(stats.average)} median=${fmt( + stats.median, + )} p95=${fmt(stats.p95)} min=${fmt(stats.min)} max=${fmt( + stats.max, + )} stdev=${fmt(stats.stdev)}`, + ); + + return stats; +}; From ed942e846c42930ac5facbe03a052e79603e11fd Mon Sep 17 00:00:00 2001 From: EstoesMoises <118999648+EstoesMoises@users.noreply.github.com> Date: Wed, 1 Oct 2025 20:41:08 +0100 Subject: [PATCH 109/265] feat: update express.js to support containerized deployments + replicate the behaviour of the vercel app (#4345) * Update express.js This will help with containerized deployments and it replicates the behaviour of the vercel app * Update express.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --------- Co-authored-by: Alexandr Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --- express.js | 19 +++++++++++++------ 1 file changed, 13 insertions(+), 6 deletions(-) diff --git a/express.js b/express.js index ddc69ba7cba8e..92a7fb1673908 100644 --- a/express.js +++ b/express.js @@ -7,10 +7,17 @@ import gistCard from "./api/gist.js"; import express from "express"; const app = express(); -app.listen(process.env.port || 9000); +const router = express.Router(); -app.get("/", statsCard); -app.get("/pin", repoCard); -app.get("/top-langs", langCard); -app.get("/wakatime", wakatimeCard); -app.get("/gist", gistCard); +router.get("/", statsCard); +router.get("/pin", repoCard); +router.get("/top-langs", langCard); +router.get("/wakatime", wakatimeCard); +router.get("/gist", gistCard); + +app.use("/api", router); + +const port = process.env.PORT || process.env.port || 9000; +app.listen(port, "0.0.0.0", () => { + console.log(`Server running on port ${port}`); +}); From c689c516f027387cb89b8671799c7c35bef27415 Mon Sep 17 00:00:00 2001 From: MD SARFARAZ <159709636+TechCoursesCreator@users.noreply.github.com> Date: Thu, 2 Oct 2025 01:26:59 +0530 Subject: [PATCH 110/265] feat: add Urdu translations (#3958) * Update translations.js for Urdu language I've added the translations for Urdu language for stats cards. * docs --------- Co-authored-by: MD SARFARAZ <159709636+LearnWithNewton@users.noreply.github.com> Co-authored-by: Alexandr --- readme.md | 1 + src/translations.js | 22 ++++++++++++++++++++++ 2 files changed, 23 insertions(+) diff --git a/readme.md b/readme.md index 74191f4e1e392..6d9bfe7af8887 100644 --- a/readme.md +++ b/readme.md @@ -354,6 +354,7 @@ Here is a list of all available locales: | `th` | Thai | | `tr` | Turkish | | `uk-ua` | Ukrainian | +| `ur` | Urdu | | `uz` | Uzbek | | `vi` | Vietnamese | diff --git a/src/translations.js b/src/translations.js index f0218d0ad1369..c016aa78b47a2 100644 --- a/src/translations.js +++ b/src/translations.js @@ -24,6 +24,7 @@ const statCardLocales = ({ name, apostrophe }) => { "zh-tw": `${encodedName} 的 GitHub 統計資料`, cs: `GitHub statistiky uživatele ${encodedName}`, de: `${encodedName + apostrophe} GitHub-Statistiken`, + ur: `${encodedName} کے گٹ ہب کے اعداد و شمار`, bn: `${encodedName} এর GitHub পরিসংখ্যান`, es: `Estadísticas de GitHub de ${encodedName}`, fa: `آمار گیت‌هاب ${encodedName}`, @@ -67,6 +68,7 @@ const statCardLocales = ({ name, apostrophe }) => { "zh-tw": `${encodedName} 的 GitHub 統計資料`, cs: `GitHub statistiky uživatele ${encodedName}`, de: `${encodedName + apostrophe} GitHub-Statistiken`, + ur: `${encodedName} کی گٹ ہب رینک`, bn: `${encodedName} এর GitHub পরিসংখ্যান`, es: `Estadísticas de GitHub de ${encodedName}`, fa: `رتبه گیت‌هاب ${encodedName}`, @@ -110,6 +112,7 @@ const statCardLocales = ({ name, apostrophe }) => { "zh-tw": "得標星星數量(Star)", cs: "Celkem hvězd", de: "Insgesamt erhaltene Sterne", + ur: "کل ستارے حاصل کیے", bn: "সর্বমোট Star", es: "Estrellas totales", fa: "مجموع ستاره‌های دریافت‌شده", @@ -153,6 +156,7 @@ const statCardLocales = ({ name, apostrophe }) => { "zh-tw": "累計提交數量(Commit)", cs: "Celkem commitů", de: "Anzahl Commits", + ur: "کل کمٹ", bn: "সর্বমোট Commit", es: "Commits totales", fa: "مجموع کامیت‌ها", @@ -196,6 +200,7 @@ const statCardLocales = ({ name, apostrophe }) => { "zh-tw": "拉取請求數量(PR)", cs: "Celkem PRs", de: "PRs Insgesamt", + ur: "کل پی آرز", bn: "সর্বমোট PR", es: "PRs totales", fa: "مجموع Pull Request", @@ -239,6 +244,7 @@ const statCardLocales = ({ name, apostrophe }) => { "zh-tw": "提出問題數量(Issue)", cs: "Celkem problémů", de: "Anzahl Issues", + ur: "کل مسائل", bn: "সর্বমোট Issue", es: "Issues totales", fa: "مجموع مسائل", @@ -282,6 +288,7 @@ const statCardLocales = ({ name, apostrophe }) => { "zh-tw": "參與項目數量(去年)", cs: "Přispěl k (minulý rok)", de: "Beigetragen zu (letztes Jahr)", + ur: "پچھلے سال میں تعاون کیا", bn: "অবদান (গত বছর)", es: "Contribuciones en (el año pasado)", fa: "مشارکت در (سال گذشته)", @@ -325,6 +332,7 @@ const statCardLocales = ({ name, apostrophe }) => { "zh-tw": "審核的 PR 總計", cs: "Celkový počet PR", de: "Insgesamt überprüfte PRs", + ur: "کل پی آرز کا جائزہ لیا", bn: "সর্বমোট পুনরালোচনা করা PR", es: "PR totales revisados", fa: "مجموع درخواست‌های ادغام بررسی‌شده", @@ -368,6 +376,7 @@ const statCardLocales = ({ name, apostrophe }) => { "zh-tw": "發起的討論總數", cs: "Celkem zahájených diskusí", de: "Gesamt gestartete Diskussionen", + ur: "کل مباحثے شروع کیے", bn: "সর্বমোট আলোচনা শুরু", es: "Discusiones totales iniciadas", fa: "مجموع بحث‌های آغازشده", @@ -411,6 +420,7 @@ const statCardLocales = ({ name, apostrophe }) => { "zh-tw": "回覆討論總計", cs: "Celkem zodpovězených diskusí", de: "Gesamt beantwortete Diskussionen", + ur: "کل مباحثے جواب دیے", bn: "সর্বমোট আলোচনা উত্তর", es: "Discusiones totales respondidas", fa: "مجموع بحث‌های پاسخ‌داده‌شده", @@ -454,6 +464,7 @@ const statCardLocales = ({ name, apostrophe }) => { "zh-tw": "合併的 PR 總計", cs: "Celkem sloučených PR", de: "Insgesamt zusammengeführte PRs", + ur: "کل پی آرز ضم کیے", bn: "সর্বমোট PR একত্রীকৃত", es: "PR totales fusionados", fa: "مجموع درخواست‌های ادغام شده", @@ -496,6 +507,7 @@ const statCardLocales = ({ name, apostrophe }) => { "zh-tw": "合併的 PR 百分比", cs: "Sloučené PRs v procentech", de: "Zusammengeführte PRs in Prozent", + ur: "ضم کیے گئے پی آرز کی شرح", bn: "PR একত্রীকরণের শতাংশ", es: "Porcentaje de PR fusionados", fa: "درصد درخواست‌های ادغام‌شده", @@ -543,6 +555,7 @@ const repoCardLocales = { "zh-tw": "模板", cs: "Šablona", de: "Vorlage", + ur: "سانچہ", es: "Plantilla", fa: "الگو", fi: "Malli", @@ -586,6 +599,7 @@ const repoCardLocales = { "zh-tw": "已封存", cs: "Archivováno", de: "Archiviert", + ur: "محفوظ شدہ", es: "Archivados", fa: "بایگانی‌شده", fi: "Arkistoitu", @@ -632,6 +646,7 @@ const langCardLocales = { cs: "Nejpoužívanější jazyky", de: "Meist verwendete Sprachen", bn: "সর্বাধিক ব্যবহৃত ভাষা সমূহ", + ur: "سب سے زیادہ استعمال شدہ زبانیں", es: "Lenguajes más usados", fa: "زبان‌های پرکاربرد", fi: "Käytetyimmät kielet", @@ -675,6 +690,7 @@ const langCardLocales = { cs: "Žádné jazykové údaje.", de: "Keine Sprachdaten.", bn: "কোন ভাষার ডেটা নেই।", + ur: "کوئی زبان کا ڈیٹا نہیں۔", es: "Sin datos de idiomas.", fa: "داده‌ای برای زبان‌ها وجود ندارد.", fi: "Ei kielitietoja.", @@ -720,6 +736,7 @@ const wakatimeCardLocales = { "zh-tw": "WakaTime 周統計", cs: "Statistiky WakaTime", de: "WakaTime Status", + ur: "وکاٹائم کے اعداد و شمار", bn: "WakaTime স্ট্যাটাস", es: "Estadísticas de WakaTime", fa: "آمار WakaTime", @@ -763,6 +780,7 @@ const wakatimeCardLocales = { "zh-tw": "去年", cs: "Minulý rok", de: "Letztes Jahr", + ur: "پچھلا سال", bn: "গত বছর", es: "El año pasado", fa: "سال گذشته", @@ -806,6 +824,7 @@ const wakatimeCardLocales = { "zh-tw": "最近 7 天", cs: "Posledních 7 dní", de: "Letzte 7 Tage", + ur: "پچھلے 7 دن", bn: "গত ৭ দিন", es: "Últimos 7 días", fa: "هفت روز گذشته", @@ -849,6 +868,7 @@ const wakatimeCardLocales = { "zh-tw": "WakaTime 使用者個人資料未公開", cs: "Profil uživatele WakaTime není veřejný", de: "WakaTime-Benutzerprofil nicht öffentlich", + ur: "وکاٹائم صارف کا پروفائل عوامی نہیں", bn: "WakaTime ব্যবহারকারীর প্রোফাইল প্রকাশ্য নয়", es: "Perfil de usuario de WakaTime no público", fa: "پروفایل کاربری WakaTime عمومی نیست", @@ -892,6 +912,7 @@ const wakatimeCardLocales = { "zh-tw": "使用者不公開分享詳細的程式碼統計資訊", cs: "Uživatel nesdílí podrobné statistiky kódu", de: "Benutzer teilt keine detaillierten Code-Statistiken", + ur: "صارف عوامی طور پر تفصیلی کوڈ کے اعداد و شمار شیئر نہیں کرتا", bn: "ব্যবহারকারী বিস্তারিত কোড পরিসংখ্যান প্রকাশ করেন না", es: "El usuario no comparte públicamente estadísticas detalladas de código", fa: "کاربر آمار کد تفصیلی را به‌صورت عمومی به اشتراک نمی‌گذارد", @@ -937,6 +958,7 @@ const wakatimeCardLocales = { "zh-tw": "本周沒有編程活動", cs: "Tento týden žádná aktivita v kódování", de: "Keine Aktivitäten in dieser Woche", + ur: "اس ہفتے کوئی کوڈنگ سرگرمی نہیں", bn: "এই সপ্তাহে কোন কোডিং অ্যাক্টিভিটি নেই", es: "No hay actividad de codificación esta semana", fa: "فعالیت کدنویسی در این هفته وجود ندارد", From ca3c5d5641182a0082eac0ccf0efa69dbf6f9a0d Mon Sep 17 00:00:00 2001 From: Mihail Kondov <116218303+mihailkondov@users.noreply.github.com> Date: Wed, 1 Oct 2025 23:17:57 +0300 Subject: [PATCH 111/265] feat: add Bulgarian translations (#3987) * Update translations.js Added Bulgarian language translation * Sorted languages alphabetically in translations.js * docs --------- Co-authored-by: mastersho <116218303+mastersho@users.noreply.github.com> Co-authored-by: Alexandr --- readme.md | 1 + src/translations.js | 22 ++++++++++++++++++++++ 2 files changed, 23 insertions(+) diff --git a/readme.md b/readme.md index 6d9bfe7af8887..e32d24adadb14 100644 --- a/readme.md +++ b/readme.md @@ -308,6 +308,7 @@ Here is a list of all available locales: | `ar` | Arabic | | `az` | Azerbaijani | | `bn` | Bengali | +| `bg` | Bulgarian | | `my` | Burmese | | `ca` | Catalan | | `cn` | Chinese | diff --git a/src/translations.js b/src/translations.js index c016aa78b47a2..f3d10c8feae2d 100644 --- a/src/translations.js +++ b/src/translations.js @@ -25,6 +25,7 @@ const statCardLocales = ({ name, apostrophe }) => { cs: `GitHub statistiky uživatele ${encodedName}`, de: `${encodedName + apostrophe} GitHub-Statistiken`, ur: `${encodedName} کے گٹ ہب کے اعداد و شمار`, + bg: `GitHub статистика на потребител ${encodedName}`, bn: `${encodedName} এর GitHub পরিসংখ্যান`, es: `Estadísticas de GitHub de ${encodedName}`, fa: `آمار گیت‌هاب ${encodedName}`, @@ -69,6 +70,7 @@ const statCardLocales = ({ name, apostrophe }) => { cs: `GitHub statistiky uživatele ${encodedName}`, de: `${encodedName + apostrophe} GitHub-Statistiken`, ur: `${encodedName} کی گٹ ہب رینک`, + bg: `GitHub ранг на ${encodedName}`, bn: `${encodedName} এর GitHub পরিসংখ্যান`, es: `Estadísticas de GitHub de ${encodedName}`, fa: `رتبه گیت‌هاب ${encodedName}`, @@ -113,6 +115,7 @@ const statCardLocales = ({ name, apostrophe }) => { cs: "Celkem hvězd", de: "Insgesamt erhaltene Sterne", ur: "کل ستارے حاصل کیے", + bg: "Получени звезди", bn: "সর্বমোট Star", es: "Estrellas totales", fa: "مجموع ستاره‌های دریافت‌شده", @@ -157,6 +160,7 @@ const statCardLocales = ({ name, apostrophe }) => { cs: "Celkem commitů", de: "Anzahl Commits", ur: "کل کمٹ", + bg: "Общо ангажименти (commits)", bn: "সর্বমোট Commit", es: "Commits totales", fa: "مجموع کامیت‌ها", @@ -201,6 +205,7 @@ const statCardLocales = ({ name, apostrophe }) => { cs: "Celkem PRs", de: "PRs Insgesamt", ur: "کل پی آرز", + bg: "Заявки за изтегляния", bn: "সর্বমোট PR", es: "PRs totales", fa: "مجموع Pull Request", @@ -245,6 +250,7 @@ const statCardLocales = ({ name, apostrophe }) => { cs: "Celkem problémů", de: "Anzahl Issues", ur: "کل مسائل", + bg: "Брой въпроси", bn: "সর্বমোট Issue", es: "Issues totales", fa: "مجموع مسائل", @@ -289,6 +295,7 @@ const statCardLocales = ({ name, apostrophe }) => { cs: "Přispěl k (minulý rok)", de: "Beigetragen zu (letztes Jahr)", ur: "پچھلے سال میں تعاون کیا", + bg: "Приноси (за изминалата година)", bn: "অবদান (গত বছর)", es: "Contribuciones en (el año pasado)", fa: "مشارکت در (سال گذشته)", @@ -333,6 +340,7 @@ const statCardLocales = ({ name, apostrophe }) => { cs: "Celkový počet PR", de: "Insgesamt überprüfte PRs", ur: "کل پی آرز کا جائزہ لیا", + bg: "Разгледани заявки за изтегляне", bn: "সর্বমোট পুনরালোচনা করা PR", es: "PR totales revisados", fa: "مجموع درخواست‌های ادغام بررسی‌شده", @@ -377,6 +385,7 @@ const statCardLocales = ({ name, apostrophe }) => { cs: "Celkem zahájených diskusí", de: "Gesamt gestartete Diskussionen", ur: "کل مباحثے شروع کیے", + bg: "Започнати дискусии", bn: "সর্বমোট আলোচনা শুরু", es: "Discusiones totales iniciadas", fa: "مجموع بحث‌های آغازشده", @@ -421,6 +430,7 @@ const statCardLocales = ({ name, apostrophe }) => { cs: "Celkem zodpovězených diskusí", de: "Gesamt beantwortete Diskussionen", ur: "کل مباحثے جواب دیے", + bg: "Отговорени дискусии", bn: "সর্বমোট আলোচনা উত্তর", es: "Discusiones totales respondidas", fa: "مجموع بحث‌های پاسخ‌داده‌شده", @@ -465,6 +475,7 @@ const statCardLocales = ({ name, apostrophe }) => { cs: "Celkem sloučených PR", de: "Insgesamt zusammengeführte PRs", ur: "کل پی آرز ضم کیے", + bg: "Сляти заявки за изтегляния", bn: "সর্বমোট PR একত্রীকৃত", es: "PR totales fusionados", fa: "مجموع درخواست‌های ادغام شده", @@ -508,6 +519,7 @@ const statCardLocales = ({ name, apostrophe }) => { cs: "Sloučené PRs v procentech", de: "Zusammengeführte PRs in Prozent", ur: "ضم کیے گئے پی آرز کی شرح", + bg: "Процент сляти заявки за изтегляния", bn: "PR একত্রীকরণের শতাংশ", es: "Porcentaje de PR fusionados", fa: "درصد درخواست‌های ادغام‌شده", @@ -549,6 +561,7 @@ const repoCardLocales = { en: "Template", ar: "قالب", az: "Şablon", + bg: "Шаблон", bn: "টেমপ্লেট", ca: "Plantilla", cn: "模板", @@ -593,6 +606,7 @@ const repoCardLocales = { en: "Archived", ar: "مُؤرشف", az: "Arxiv", + bg: "Архивирани", bn: "আর্কাইভড", ca: "Arxivats", cn: "已归档", @@ -645,6 +659,7 @@ const langCardLocales = { "zh-tw": "最常用的語言", cs: "Nejpoužívanější jazyky", de: "Meist verwendete Sprachen", + bg: "Най-използвани езици", bn: "সর্বাধিক ব্যবহৃত ভাষা সমূহ", ur: "سب سے زیادہ استعمال شدہ زبانیں", es: "Lenguajes más usados", @@ -689,6 +704,7 @@ const langCardLocales = { "zh-tw": "沒有語言資料。", cs: "Žádné jazykové údaje.", de: "Keine Sprachdaten.", + bg: "Няма данни за езици", bn: "কোন ভাষার ডেটা নেই।", ur: "کوئی زبان کا ڈیٹا نہیں۔", es: "Sin datos de idiomas.", @@ -737,6 +753,7 @@ const wakatimeCardLocales = { cs: "Statistiky WakaTime", de: "WakaTime Status", ur: "وکاٹائم کے اعداد و شمار", + bg: "WakaTime статистика", bn: "WakaTime স্ট্যাটাস", es: "Estadísticas de WakaTime", fa: "آمار WakaTime", @@ -781,6 +798,7 @@ const wakatimeCardLocales = { cs: "Minulý rok", de: "Letztes Jahr", ur: "پچھلا سال", + bg: "миналата година", bn: "গত বছর", es: "El año pasado", fa: "سال گذشته", @@ -825,6 +843,7 @@ const wakatimeCardLocales = { cs: "Posledních 7 dní", de: "Letzte 7 Tage", ur: "پچھلے 7 دن", + bg: "последните 7 дни", bn: "গত ৭ দিন", es: "Últimos 7 días", fa: "هفت روز گذشته", @@ -869,6 +888,7 @@ const wakatimeCardLocales = { cs: "Profil uživatele WakaTime není veřejný", de: "WakaTime-Benutzerprofil nicht öffentlich", ur: "وکاٹائم صارف کا پروفائل عوامی نہیں", + bg: "Потребителски профил в WakaTime не е общодостъпен", bn: "WakaTime ব্যবহারকারীর প্রোফাইল প্রকাশ্য নয়", es: "Perfil de usuario de WakaTime no público", fa: "پروفایل کاربری WakaTime عمومی نیست", @@ -913,6 +933,7 @@ const wakatimeCardLocales = { cs: "Uživatel nesdílí podrobné statistiky kódu", de: "Benutzer teilt keine detaillierten Code-Statistiken", ur: "صارف عوامی طور پر تفصیلی کوڈ کے اعداد و شمار شیئر نہیں کرتا", + bg: "Потребителят не споделя подробна статистика за код", bn: "ব্যবহারকারী বিস্তারিত কোড পরিসংখ্যান প্রকাশ করেন না", es: "El usuario no comparte públicamente estadísticas detalladas de código", fa: "کاربر آمار کد تفصیلی را به‌صورت عمومی به اشتراک نمی‌گذارد", @@ -959,6 +980,7 @@ const wakatimeCardLocales = { cs: "Tento týden žádná aktivita v kódování", de: "Keine Aktivitäten in dieser Woche", ur: "اس ہفتے کوئی کوڈنگ سرگرمی نہیں", + bg: "Няма активност при кодирането тази седмица", bn: "এই সপ্তাহে কোন কোডিং অ্যাক্টিভিটি নেই", es: "No hay actividad de codificación esta semana", fa: "فعالیت کدنویسی در این هفته وجود ندارد", From df8f7a6cefb2d5fd4abe0ae80fd0faae4d4ef80d Mon Sep 17 00:00:00 2001 From: ranker-Aayush Date: Thu, 2 Oct 2025 02:05:45 +0530 Subject: [PATCH 112/265] fix: update Hindi translations (#4488) * Fixed the trans in Hindi * Update src/translations.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update src/translations.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * review --------- Co-authored-by: Alexandr Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --- src/translations.js | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/src/translations.js b/src/translations.js index f3d10c8feae2d..2f9fe9f576fc1 100644 --- a/src/translations.js +++ b/src/translations.js @@ -256,7 +256,7 @@ const statCardLocales = ({ name, apostrophe }) => { fa: "مجموع مسائل", fi: "Yhteensä ongelmat", fr: "Nombre total d'incidents", - hi: "कुल मुद्दे", + hi: "कुल मुद्दे(Issues)", hu: "Összes hibajegy", it: "Segnalazioni totali", ja: "合計 issue", @@ -391,7 +391,7 @@ const statCardLocales = ({ name, apostrophe }) => { fa: "مجموع بحث‌های آغازشده", fi: "Aloitetut keskustelut yhteensä", fr: "Nombre total de discussions lancées", - hi: "कुल चर्चा शुरू हुई", + hi: "कुल चर्चाएँ शुरू हुईं", hu: "Összes megkezdett megbeszélés", it: "Discussioni totali avviate", ja: "開始されたディスカッションの総数", @@ -436,7 +436,7 @@ const statCardLocales = ({ name, apostrophe }) => { fa: "مجموع بحث‌های پاسخ‌داده‌شده", fi: "Vastatut keskustelut yhteensä", fr: "Nombre total de discussions répondues", - hi: "कुल चर्चाओं का उत्तर दिया गया", + hi: "कुल चर्चाओं के उत्तर", hu: "Összes megválaszolt megbeszélés", it: "Discussioni totali risposte", ja: "回答されたディスカッションの総数", @@ -489,7 +489,7 @@ const statCardLocales = ({ name, apostrophe }) => { nl: "Totaal samengevoegde PR's", "pt-pt": "Total de PRs Fundidos", "pt-br": "Total de PRs Integrados", - np: "कुल PRs मर्ज गरिएको", + np: "कुल विलयित PRs", el: "Σύνολο Συγχωνευμένων PR", ro: "Total PR-uri Fuzionate", ru: "Всего объединённых запросов", @@ -525,7 +525,7 @@ const statCardLocales = ({ name, apostrophe }) => { fa: "درصد درخواست‌های ادغام‌شده", fi: "Yhdistettyjen PR:ien prosentti", fr: "Pourcentage de PR fusionnés", - hi: "मर्ज किए गए PR प्रतिशत", + hi: "मर्ज किए गए PRs प्रतिशत", hu: "Egyesített PR-k százaléka", it: "Percentuale di PR uniti", ja: "マージされた PR の割合", @@ -986,7 +986,7 @@ const wakatimeCardLocales = { fa: "فعالیت کدنویسی در این هفته وجود ندارد", fi: "Ei koodaustoimintaa tällä viikolla", fr: "Aucune activité de codage cette semaine", - hi: "इस सप्ताह कोई कोडिंग गतिविधि नहीं", + hi: "इस सप्ताह कोई कोडिंग गतिविधि नहीं ", hu: "Nem volt aktivitás ezen a héten", it: "Nessuna attività in questa settimana", ja: "今週のコーディング活動はありません", From 8e8a15ba63ced8b520e9bebff2dc9993c61a0647 Mon Sep 17 00:00:00 2001 From: Dhia Shams Date: Thu, 2 Oct 2025 02:10:26 +0530 Subject: [PATCH 113/265] fix: update Malayalam translations (#4490) Co-authored-by: Alexandr --- src/translations.js | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/src/translations.js b/src/translations.js index 2f9fe9f576fc1..5faa3821a8d63 100644 --- a/src/translations.js +++ b/src/translations.js @@ -270,7 +270,7 @@ const statCardLocales = ({ name, apostrophe }) => { ru: "Всего вопросов", "uk-ua": "Всього issue", id: "Total Masalah Dilaporkan", - ml: "ആകെ ലക്കങ്ങൾ", + ml: "ആകെ പ്രശ്നങ്ങൾ", my: "Jumlah Isu Dilaporkan", sk: "Všetky problémy", tr: "Toplam Hata", @@ -315,7 +315,7 @@ const statCardLocales = ({ name, apostrophe }) => { ru: "Внесено вклада (за прошлый год)", "uk-ua": "Зробив внесок у (за минулий рік)", id: "Berkontribusi ke (tahun lalu)", - ml: "സമർപ്പിച്ചിരിക്കുന്നത് (കഴിഞ്ഞ വർഷം)", + ml: "(കഴിഞ്ഞ വർഷത്തെ)ആകെ സംഭാവനകൾ ", my: "Menyumbang kepada (tahun lepas)", sk: "Účasti (minulý rok)", tr: "Katkı Verildi (geçen yıl)", @@ -360,7 +360,7 @@ const statCardLocales = ({ name, apostrophe }) => { ru: "Всего запросов проверено", "uk-ua": "Всього pull request`iв перевірено", id: "Total PR yang Direview", - ml: "ആകെ പുൾ അഭിപ്രായങ്ങൾ", + ml: "ആകെ പുൾ അവലോകനങ്ങൾ", my: "Jumlah PR Dikaji Semula", sk: "Celkový počet PR", tr: "İncelenen toplam PR", @@ -773,7 +773,7 @@ const wakatimeCardLocales = { ru: "Статистика WakaTime", "uk-ua": "Статистика WakaTime", id: "Status WakaTime", - ml: "വേക്ക് ടൈം സ്ഥിതിവിവരക്കണക്കുകൾ", + ml: "വാകടൈം സ്ഥിതിവിവരക്കണക്കുകൾ", my: "Statistik WakaTime", sk: "WakaTime štatistika", tr: "WakaTime İstatistikler", @@ -955,7 +955,7 @@ const wakatimeCardLocales = { ru: "Пользователь не делится подробной статистикой кода", "uk-ua": "Користувач не публікує детальну статистику коду", id: "Pengguna tidak membagikan statistik kode terperinci secara publik", - ml: "ഉപയോക്താവ് പൊതുവെ വിശദീകരിച്ച കോഡ് സ്റ്റാറ്റിസ്റ്റിക്സ് പങ്കിടുന്നില്ല", + ml: "ഉപയോക്താവ് പൊതുവായി വിശദീകരിച്ച കോഡ് സ്റ്റാറ്റിസ്റ്റിക്സ് പങ്കിടുന്നില്ല", my: "Pengguna tidak berkongsi statistik kod terperinci secara awam", sk: "Používateľ neposkytuje verejne podrobné štatistiky kódu", tr: "Kullanıcı ayrıntılı kod istatistiklerini herkese açık olarak paylaşmıyor", From aac573569fe1b7a2a07fe84a77f76d1dd6993bbd Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Wed, 1 Oct 2025 23:48:41 +0300 Subject: [PATCH 114/265] docs(readme): fix deploy vercel instance link inside important notice (#4492) Co-authored-by: Alexandr --- readme.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/readme.md b/readme.md index e32d24adadb14..28e596390d885 100644 --- a/readme.md +++ b/readme.md @@ -102,7 +102,7 @@ > Please note that we are NOT participating in Hacktoberfest this year. Unfortunately, the only person with sufficient access rights to remove the repository label is currently unreachable, so we are notifying you here. As a small team, we cannot handle the increased volume of PRs and issues that the event brings. We appreciate your understanding. > [!IMPORTANT]\ -> Since the GitHub API only [allows 5k requests per hour per user account](https://docs.github.com/en/graphql/overview/resource-limitations), the public Vercel instance hosted on `https://github-readme-stats.vercel.app/api` could possibly hit the rate limiter (see [#1471](https://github.com/anuraghazra/github-readme-stats/issues/1471)). We use caching to prevent this from happening (see https://github.com/anuraghazra/github-readme-stats#common-options). You can turn off these rate limit protections by deploying [your own Vercel instance](#disable-rate-limit-protections). +> Since the GitHub API only [allows 5k requests per hour per user account](https://docs.github.com/en/graphql/overview/resource-limitations), the public Vercel instance hosted on `https://github-readme-stats.vercel.app/api` could possibly hit the rate limiter (see [#1471](https://github.com/anuraghazra/github-readme-stats/issues/1471)). We use caching to prevent this from happening (see https://github.com/anuraghazra/github-readme-stats#common-options). You can turn off these rate limit protections by [deploying your own Vercel instance](#deploy-on-your-own). Uptime Badge From a38ff1003ed44d68f83ab3ae6c41bcdd9e75283f Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Wed, 1 Oct 2025 23:52:56 +0300 Subject: [PATCH 115/265] fix: mark Bulgarian language as long for stats card (#4493) Co-authored-by: Alexandr --- src/cards/stats.js | 1 + 1 file changed, 1 insertion(+) diff --git a/src/cards/stats.js b/src/cards/stats.js index 3b2579cbb7d79..3e853b0a41274 100644 --- a/src/cards/stats.js +++ b/src/cards/stats.js @@ -365,6 +365,7 @@ const renderStatsCard = (stats, options = {}) => { }; const longLocales = [ + "bg", "de", "es", "fil", From 02cf32ce22167479ced38d32b81f908fc914c1cf Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Wed, 1 Oct 2025 23:57:29 +0300 Subject: [PATCH 116/265] docs(readme): fix environment variables link inside common options section (#4494) Co-authored-by: Alexandr --- readme.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/readme.md b/readme.md index 28e596390d885..12256703b0a3d 100644 --- a/readme.md +++ b/readme.md @@ -288,7 +288,7 @@ You can customize the appearance of all your cards however you wish with URL par | `border_radius` | Corner rounding on the card. | number | `4.5` | > [!WARNING]\ -> We use caching to decrease the load on our servers (see ). Our cards have the following default cache hours: stats card - 24 hours, top languages card - 144 hours (6 days), pin card - 240 hours (10 days), gist card - 48 hours (2 days). If you want the data on your statistics card to be updated more often you can [deploy your own instance](#deploy-on-your-own) and set [environment variable](#disable-rate-limit-protections) `CACHE_SECONDS` to a value of your choosing. +> We use caching to decrease the load on our servers (see ). Our cards have the following default cache hours: stats card - 24 hours, top languages card - 144 hours (6 days), pin card - 240 hours (10 days), gist card - 48 hours (2 days). If you want the data on your statistics card to be updated more often you can [deploy your own instance](#deploy-on-your-own) and set [environment variable](#available-environment-variables) `CACHE_SECONDS` to a value of your choosing. ##### Gradient in bg\_color From e0d573e91b8922ff4f00038f53dcb6c0758e3e3a Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Thu, 2 Oct 2025 20:39:31 +0300 Subject: [PATCH 117/265] chore: add more entries into vercelignore (#4499) Co-authored-by: Alexandr --- .vercelignore | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/.vercelignore b/.vercelignore index 48dfdfb8696fe..064c0ab23a89a 100644 --- a/.vercelignore +++ b/.vercelignore @@ -8,3 +8,9 @@ scripts tests .env package-lock.json +**/*.md +**/*.svg +.eslintrc.json +.prettierignore +.pretterrc.json +codecov.yml From 5031e32781dcdac362e62aba8f2ceae7eb28170d Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Thu, 2 Oct 2025 20:54:44 +0300 Subject: [PATCH 118/265] fix: make Bulgarian total commits translation shorter to prevent items overlapping (#4500) Co-authored-by: Alexandr --- src/translations.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/translations.js b/src/translations.js index 5faa3821a8d63..92bb5b0ad4196 100644 --- a/src/translations.js +++ b/src/translations.js @@ -160,7 +160,7 @@ const statCardLocales = ({ name, apostrophe }) => { cs: "Celkem commitů", de: "Anzahl Commits", ur: "کل کمٹ", - bg: "Общо ангажименти (commits)", + bg: "Общо ангажименти", bn: "সর্বমোট Commit", es: "Commits totales", fa: "مجموع کامیت‌ها", @@ -798,7 +798,7 @@ const wakatimeCardLocales = { cs: "Minulý rok", de: "Letztes Jahr", ur: "پچھلا سال", - bg: "миналата година", + bg: "миналата год.", bn: "গত বছর", es: "El año pasado", fa: "سال گذشته", From b25904c123b72b868901317fd1d7dc6e739aaba1 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Thu, 2 Oct 2025 21:35:18 +0300 Subject: [PATCH 119/265] chore: improve bench tests utils jsdoc readability (#4501) Co-authored-by: Alexandr --- tests/bench/utils.js | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/tests/bench/utils.js b/tests/bench/utils.js index a94b258b9e1b2..f4c8afb45a632 100644 --- a/tests/bench/utils.js +++ b/tests/bench/utils.js @@ -3,6 +3,7 @@ const DEFAULT_WARMUPS = 50; /** * Formats a duration in nanoseconds to a compact human-readable string. + * * @param {bigint} ns Duration in nanoseconds. * @returns {string} Formatted time string. */ @@ -21,6 +22,7 @@ const formatTime = (ns) => { /** * Measures synchronous or async function execution time. + * * @param {Function} fn Function to measure. * @returns {Promise} elapsed nanoseconds */ @@ -36,6 +38,7 @@ const measurePerformance = async (fn) => { /** * Computes basic & extended statistics. + * * @param {bigint[]} samples Array of samples in nanoseconds. * @returns {object} Stats */ @@ -75,6 +78,7 @@ const computeStats = (samples) => { /** * Benchmark a function. + * * @param {string} fnName Name of the function (for logging). * @param {Function} fn Function to benchmark. * @param {object} [opts] Options. From 98412a1c7308e48af1a3ac96cc0b5f0317eb4396 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Thu, 2 Oct 2025 21:56:48 +0300 Subject: [PATCH 120/265] build(deps-dev): add express for testing custom deployment issues (#4502) Co-authored-by: Alexandr --- package-lock.json | 1231 ++++++++++++++++++++++++++++++++++++++++++++- package.json | 1 + 2 files changed, 1231 insertions(+), 1 deletion(-) diff --git a/package-lock.json b/package-lock.json index 7306b2b5845b9..cc5e555fea186 100644 --- a/package-lock.json +++ b/package-lock.json @@ -29,6 +29,7 @@ "eslint": "^9.36.0", "eslint-config-prettier": "^10.1.8", "eslint-plugin-jsdoc": "^60.1.1", + "express": "^5.1.0", "globals": "^16.4.0", "hjson": "^3.2.2", "husky": "^9.1.7", @@ -2093,6 +2094,43 @@ "integrity": "sha512-dCTxxolI6fu28lzNRVwd7CzJV8EbARITFyCbP/JqLHYLfWHY7GJqXHDdk0GbtfXvsZosPCvjOE4dOIMT4XDFZQ==", "dev": true }, + "node_modules/accepts": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/accepts/-/accepts-2.0.0.tgz", + "integrity": "sha512-5cvg6CtKwfgdmVqY1WIiXKc3Q1bkRqGLi+2W/6ao+6Y7gu/RCwRuAhGEzh5B4KlszSuTLgZYuqFqo5bImjNKng==", + "dev": true, + "license": "MIT", + "dependencies": { + "mime-types": "^3.0.0", + "negotiator": "^1.0.0" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/accepts/node_modules/mime-db": { + "version": "1.54.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.54.0.tgz", + "integrity": "sha512-aU5EJuIN2WDemCcAp2vFBfp/m4EAhWJnUNSSw0ixs7/kXbd6Pg64EmwJkNdFhB8aWt1sH2CTXrLxo/iAGV3oPQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/accepts/node_modules/mime-types": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-3.0.1.tgz", + "integrity": "sha512-xRc4oEhT6eaBpU1XF7AjpOFD+xQmXNB5OVKwp4tqCuBpHLS/ZbBDrc07mYTDqVMg6PfxUjjNp85O6Cd2Z/5HWA==", + "dev": true, + "license": "MIT", + "dependencies": { + "mime-db": "^1.54.0" + }, + "engines": { + "node": ">= 0.6" + } + }, "node_modules/acorn": { "version": "8.15.0", "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.15.0.tgz", @@ -2348,6 +2386,27 @@ "dev": true, "license": "Apache-2.0" }, + "node_modules/body-parser": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-2.2.0.tgz", + "integrity": "sha512-02qvAaxv8tp7fBa/mw1ga98OGm+eCbqzJOKoRt70sLmfEEi+jyBYVTDGfCL/k06/4EMk/z01gCe7HoCH/f2LTg==", + "dev": true, + "license": "MIT", + "dependencies": { + "bytes": "^3.1.2", + "content-type": "^1.0.5", + "debug": "^4.4.0", + "http-errors": "^2.0.0", + "iconv-lite": "^0.6.3", + "on-finished": "^2.4.1", + "qs": "^6.14.0", + "raw-body": "^3.0.0", + "type-is": "^2.0.0" + }, + "engines": { + "node": ">=18" + } + }, "node_modules/brace-expansion": { "version": "1.1.11", "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", @@ -2417,6 +2476,16 @@ "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", "dev": true }, + "node_modules/bytes": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", + "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + }, "node_modules/call-bind-apply-helpers": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/call-bind-apply-helpers/-/call-bind-apply-helpers-1.0.2.tgz", @@ -2429,6 +2498,23 @@ "node": ">= 0.4" } }, + "node_modules/call-bound": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/call-bound/-/call-bound-1.0.4.tgz", + "integrity": "sha512-+ys997U96po4Kx/ABpBCqhA9EuxJaQWDQg7295H4hBphv3IZg0boBKuwYpt4YXp6MZ5AmZQnU/tyMTlRpaSejg==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind-apply-helpers": "^1.0.2", + "get-intrinsic": "^1.3.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, "node_modules/callsites": { "version": "3.1.0", "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", @@ -2682,12 +2768,55 @@ "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", "dev": true }, + "node_modules/content-disposition": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-1.0.0.tgz", + "integrity": "sha512-Au9nRL8VNUut/XSzbQA38+M78dzP4D+eqg3gfJHMIHHYa3bg067xj1KxMUWj+VULbiZMowKngFFbKczUrNJ1mg==", + "dev": true, + "license": "MIT", + "dependencies": { + "safe-buffer": "5.2.1" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/content-type": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.5.tgz", + "integrity": "sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, "node_modules/convert-source-map": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-2.0.0.tgz", "integrity": "sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==", "dev": true }, + "node_modules/cookie": { + "version": "0.7.2", + "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.7.2.tgz", + "integrity": "sha512-yki5XnKuf750l50uGTllt6kKILY4nQ1eNIQatoXEByZ5dWgnKqbnqmTrBE5B4N7lrMJKQ2ytWMiTO2o0v6Ew/w==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/cookie-signature": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.2.2.tgz", + "integrity": "sha512-D76uU73ulSXrD1UXF4KE2TMxVVwhsnCgfAyTg9k8P6KGZjlXKrOLe4dJQKI3Bxi5wjesZoFXJWElNWBjPZMbhg==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=6.6.0" + } + }, "node_modules/create-jest": { "version": "29.7.0", "resolved": "https://registry.npmjs.org/create-jest/-/create-jest-29.7.0.tgz", @@ -2815,6 +2944,16 @@ "node": ">=0.4.0" } }, + "node_modules/depd": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", + "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + }, "node_modules/deprecation": { "version": "2.3.1", "resolved": "https://registry.npmjs.org/deprecation/-/deprecation-2.3.1.tgz", @@ -2879,6 +3018,13 @@ "node": ">= 0.4" } }, + "node_modules/ee-first": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", + "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==", + "dev": true, + "license": "MIT" + }, "node_modules/electron-to-chromium": { "version": "1.4.478", "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.478.tgz", @@ -2908,6 +3054,16 @@ "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", "dev": true }, + "node_modules/encodeurl": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-2.0.0.tgz", + "integrity": "sha512-Q0n9HRi4m6JuGIV1eFlmvJB7ZEVxu93IrMyiMsGC0lrMJMWzRgx6WGquyfQgZVb31vhGgXnfmPNNXmxnOkRBrg==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + }, "node_modules/entities": { "version": "6.0.1", "resolved": "https://registry.npmjs.org/entities/-/entities-6.0.1.tgz", @@ -2991,6 +3147,13 @@ "node": ">=6" } }, + "node_modules/escape-html": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", + "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==", + "dev": true, + "license": "MIT" + }, "node_modules/escape-string-regexp": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz", @@ -3363,6 +3526,16 @@ "node": ">=0.10.0" } }, + "node_modules/etag": { + "version": "1.8.1", + "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", + "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, "node_modules/eventemitter3": { "version": "5.0.1", "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-5.0.1.tgz", @@ -3417,6 +3590,72 @@ "node": "^14.15.0 || ^16.10.0 || >=18.0.0" } }, + "node_modules/express": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/express/-/express-5.1.0.tgz", + "integrity": "sha512-DT9ck5YIRU+8GYzzU5kT3eHGA5iL+1Zd0EutOmTE9Dtk+Tvuzd23VBU+ec7HPNSTxXYO55gPV/hq4pSBJDjFpA==", + "dev": true, + "license": "MIT", + "dependencies": { + "accepts": "^2.0.0", + "body-parser": "^2.2.0", + "content-disposition": "^1.0.0", + "content-type": "^1.0.5", + "cookie": "^0.7.1", + "cookie-signature": "^1.2.1", + "debug": "^4.4.0", + "encodeurl": "^2.0.0", + "escape-html": "^1.0.3", + "etag": "^1.8.1", + "finalhandler": "^2.1.0", + "fresh": "^2.0.0", + "http-errors": "^2.0.0", + "merge-descriptors": "^2.0.0", + "mime-types": "^3.0.0", + "on-finished": "^2.4.1", + "once": "^1.4.0", + "parseurl": "^1.3.3", + "proxy-addr": "^2.0.7", + "qs": "^6.14.0", + "range-parser": "^1.2.1", + "router": "^2.2.0", + "send": "^1.1.0", + "serve-static": "^2.2.0", + "statuses": "^2.0.1", + "type-is": "^2.0.1", + "vary": "^1.1.2" + }, + "engines": { + "node": ">= 18" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/express" + } + }, + "node_modules/express/node_modules/mime-db": { + "version": "1.54.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.54.0.tgz", + "integrity": "sha512-aU5EJuIN2WDemCcAp2vFBfp/m4EAhWJnUNSSw0ixs7/kXbd6Pg64EmwJkNdFhB8aWt1sH2CTXrLxo/iAGV3oPQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/express/node_modules/mime-types": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-3.0.1.tgz", + "integrity": "sha512-xRc4oEhT6eaBpU1XF7AjpOFD+xQmXNB5OVKwp4tqCuBpHLS/ZbBDrc07mYTDqVMg6PfxUjjNp85O6Cd2Z/5HWA==", + "dev": true, + "license": "MIT", + "dependencies": { + "mime-db": "^1.54.0" + }, + "engines": { + "node": ">= 0.6" + } + }, "node_modules/fast-deep-equal": { "version": "3.1.3", "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", @@ -3468,6 +3707,24 @@ "node": ">=8" } }, + "node_modules/finalhandler": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-2.1.0.tgz", + "integrity": "sha512-/t88Ty3d5JWQbWYgaOGCCYfXRwV1+be02WqYYlL6h0lEiUAMPM8o8qKGO01YIkOHzka2up08wvgYD0mDiI+q3Q==", + "dev": true, + "license": "MIT", + "dependencies": { + "debug": "^4.4.0", + "encodeurl": "^2.0.0", + "escape-html": "^1.0.3", + "on-finished": "^2.4.1", + "parseurl": "^1.3.3", + "statuses": "^2.0.1" + }, + "engines": { + "node": ">= 0.8" + } + }, "node_modules/find-up": { "version": "4.1.0", "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", @@ -3534,6 +3791,26 @@ "node": ">= 6" } }, + "node_modules/forwarded": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", + "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/fresh": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/fresh/-/fresh-2.0.0.tgz", + "integrity": "sha512-Rx/WycZ60HOaqLKAi6cHRKKI7zxWbJ31MhntmtwMoaTeF7XFH9hhBp8vITaMidfljRQ6eYWCKkaTK+ykVJHP2A==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + }, "node_modules/fs.realpath": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", @@ -3799,6 +4076,33 @@ "integrity": "sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==", "dev": true }, + "node_modules/http-errors": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", + "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "depd": "2.0.0", + "inherits": "2.0.4", + "setprototypeof": "1.2.0", + "statuses": "2.0.1", + "toidentifier": "1.0.1" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/http-errors/node_modules/statuses": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", + "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + }, "node_modules/http-proxy-agent": { "version": "7.0.2", "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-7.0.2.tgz", @@ -3948,6 +4252,16 @@ "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", "dev": true }, + "node_modules/ipaddr.js": { + "version": "1.9.1", + "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", + "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.10" + } + }, "node_modules/is-arrayish": { "version": "0.2.1", "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", @@ -4043,6 +4357,13 @@ "integrity": "sha512-bCYeRA2rVibKZd+s2625gGnGF/t7DSqDs4dP7CrLA1m7jKWz6pps0LpYLJN8Q64HtmPKJ1hrN3nzPNKFEKOUiQ==", "dev": true }, + "node_modules/is-promise": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-4.0.0.tgz", + "integrity": "sha512-hvpoI6korhJMnej285dSg6nu1+e6uxs7zG3BYAm5byqDsgJNWwxzM6z6iZiAgQR4TJ30JmBTOwqZUw3WlyH3AQ==", + "dev": true, + "license": "MIT" + }, "node_modules/is-stream": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.1.tgz", @@ -5701,6 +6022,29 @@ "node": ">= 0.4" } }, + "node_modules/media-typer": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-1.1.0.tgz", + "integrity": "sha512-aisnrDP4GNe06UcKFnV5bfMNPBUw4jsLGaWwWfnH3v02GnBuXX2MCVn5RbrWo0j3pczUilYblq7fQ7Nw2t5XKw==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/merge-descriptors": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-2.0.0.tgz", + "integrity": "sha512-Snk314V5ayFLhp3fkUREub6WtjBfPdCPY1Ln8/8munuLuiYhsABgBVWsozAG+MWMbVEvcdcpbi9R7ww22l9Q3g==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, "node_modules/merge-stream": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", @@ -5805,6 +6149,16 @@ "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", "dev": true }, + "node_modules/negotiator": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-1.0.0.tgz", + "integrity": "sha512-8Ofs/AUQh8MaEcrlq5xOX0CQ9ypTF5dl78mjlMNfOK08fzpgTHQRQPBxcPlEtIw0yRpws+Zo/3r+5WRby7u3Gg==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, "node_modules/node-int64": { "version": "0.4.0", "resolved": "https://registry.npmjs.org/node-int64/-/node-int64-0.4.0.tgz", @@ -5865,6 +6219,32 @@ "url": "https://github.com/sponsors/sindresorhus" } }, + "node_modules/object-inspect": { + "version": "1.13.4", + "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.13.4.tgz", + "integrity": "sha512-W67iLl4J2EXEGTbfeHCffrjDfitvLANg0UlX3wFUUSTx92KXRFegMHUVgSqE+wvhAbi4WqjGg9czysTV2Epbew==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/on-finished": { + "version": "2.4.1", + "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz", + "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==", + "dev": true, + "license": "MIT", + "dependencies": { + "ee-first": "1.1.1" + }, + "engines": { + "node": ">= 0.8" + } + }, "node_modules/once": { "version": "1.4.0", "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", @@ -6005,6 +6385,16 @@ "url": "https://github.com/inikulin/parse5?sponsor=1" } }, + "node_modules/parseurl": { + "version": "1.3.3", + "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", + "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + }, "node_modules/path-exists": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", @@ -6038,6 +6428,17 @@ "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", "dev": true }, + "node_modules/path-to-regexp": { + "version": "8.3.0", + "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-8.3.0.tgz", + "integrity": "sha512-7jdwVIRtsP8MYpdXSwOS0YdD0Du+qOoF/AEPIt88PcCFrZCzx41oxku1jD88hZBwbNUIEfpqvuhjFaMAqMTWnA==", + "dev": true, + "license": "MIT", + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/express" + } + }, "node_modules/picocolors": { "version": "1.1.1", "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.1.1.tgz", @@ -6143,6 +6544,20 @@ "node": ">= 6" } }, + "node_modules/proxy-addr": { + "version": "2.0.7", + "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", + "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", + "dev": true, + "license": "MIT", + "dependencies": { + "forwarded": "0.2.0", + "ipaddr.js": "1.9.1" + }, + "engines": { + "node": ">= 0.10" + } + }, "node_modules/proxy-from-env": { "version": "1.1.0", "resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz", @@ -6173,6 +6588,65 @@ } ] }, + "node_modules/qs": { + "version": "6.14.0", + "resolved": "https://registry.npmjs.org/qs/-/qs-6.14.0.tgz", + "integrity": "sha512-YWWTjgABSKcvs/nWBi9PycY/JiPJqOD4JA6o9Sej2AtvSGarXxKC3OQSk4pAarbdQlKAh5D4FCQkJNkW+GAn3w==", + "dev": true, + "license": "BSD-3-Clause", + "dependencies": { + "side-channel": "^1.1.0" + }, + "engines": { + "node": ">=0.6" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/range-parser": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", + "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/raw-body": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-3.0.1.tgz", + "integrity": "sha512-9G8cA+tuMS75+6G/TzW8OtLzmBDMo8p1JRxN5AZ+LAp8uxGA8V8GZm4GQ4/N5QNQEnLmg6SS7wyuSmbKepiKqA==", + "dev": true, + "license": "MIT", + "dependencies": { + "bytes": "3.1.2", + "http-errors": "2.0.0", + "iconv-lite": "0.7.0", + "unpipe": "1.0.0" + }, + "engines": { + "node": ">= 0.10" + } + }, + "node_modules/raw-body/node_modules/iconv-lite": { + "version": "0.7.0", + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.7.0.tgz", + "integrity": "sha512-cf6L2Ds3h57VVmkZe+Pn+5APsT7FpqJtEhhieDCvrE2MK5Qk9MyffgQyuxQTm6BChfeZNtcOLHp9IcWRVcIcBQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "safer-buffer": ">= 2.1.2 < 3.0.0" + }, + "engines": { + "node": ">=0.10.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/express" + } + }, "node_modules/react-is": { "version": "17.0.2", "resolved": "https://registry.npmjs.org/react-is/-/react-is-17.0.2.tgz", @@ -6303,12 +6777,50 @@ "integrity": "sha512-q1b3N5QkRUWUl7iyylaaj3kOpIT0N2i9MqIEQXP73GVsN9cw3fdx8X63cEmWhJGi2PPCF23Ijp7ktmd39rawIA==", "dev": true }, + "node_modules/router": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/router/-/router-2.2.0.tgz", + "integrity": "sha512-nLTrUKm2UyiL7rlhapu/Zl45FwNgkZGaCpZbIHajDYgwlJCOzLSk+cIPAnsEqV955GjILJnKbdQC1nVPz+gAYQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "debug": "^4.4.0", + "depd": "^2.0.0", + "is-promise": "^4.0.0", + "parseurl": "^1.3.3", + "path-to-regexp": "^8.0.0" + }, + "engines": { + "node": ">= 18" + } + }, "node_modules/rrweb-cssom": { "version": "0.8.0", "resolved": "https://registry.npmjs.org/rrweb-cssom/-/rrweb-cssom-0.8.0.tgz", "integrity": "sha512-guoltQEx+9aMf2gDZ0s62EcV8lsXR+0w8915TC3ITdn2YueuNjdAYh/levpU9nFaoChh9RUS5ZdQMrKfVEN9tw==", "dev": true }, + "node_modules/safe-buffer": { + "version": "5.2.1", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", + "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ], + "license": "MIT" + }, "node_modules/safer-buffer": { "version": "2.1.2", "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", @@ -6336,6 +6848,75 @@ "semver": "bin/semver.js" } }, + "node_modules/send": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/send/-/send-1.2.0.tgz", + "integrity": "sha512-uaW0WwXKpL9blXE2o0bRhoL2EGXIrZxQ2ZQ4mgcfoBxdFmQold+qWsD2jLrfZ0trjKL6vOw0j//eAwcALFjKSw==", + "dev": true, + "license": "MIT", + "dependencies": { + "debug": "^4.3.5", + "encodeurl": "^2.0.0", + "escape-html": "^1.0.3", + "etag": "^1.8.1", + "fresh": "^2.0.0", + "http-errors": "^2.0.0", + "mime-types": "^3.0.1", + "ms": "^2.1.3", + "on-finished": "^2.4.1", + "range-parser": "^1.2.1", + "statuses": "^2.0.1" + }, + "engines": { + "node": ">= 18" + } + }, + "node_modules/send/node_modules/mime-db": { + "version": "1.54.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.54.0.tgz", + "integrity": "sha512-aU5EJuIN2WDemCcAp2vFBfp/m4EAhWJnUNSSw0ixs7/kXbd6Pg64EmwJkNdFhB8aWt1sH2CTXrLxo/iAGV3oPQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/send/node_modules/mime-types": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-3.0.1.tgz", + "integrity": "sha512-xRc4oEhT6eaBpU1XF7AjpOFD+xQmXNB5OVKwp4tqCuBpHLS/ZbBDrc07mYTDqVMg6PfxUjjNp85O6Cd2Z/5HWA==", + "dev": true, + "license": "MIT", + "dependencies": { + "mime-db": "^1.54.0" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/serve-static": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-2.2.0.tgz", + "integrity": "sha512-61g9pCh0Vnh7IutZjtLGGpTA355+OPn2TyDv/6ivP2h/AdAVX9azsoxmg2/M6nZeQZNYBEwIcsne1mJd9oQItQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "encodeurl": "^2.0.0", + "escape-html": "^1.0.3", + "parseurl": "^1.3.3", + "send": "^1.2.0" + }, + "engines": { + "node": ">= 18" + } + }, + "node_modules/setprototypeof": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", + "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==", + "dev": true, + "license": "ISC" + }, "node_modules/shebang-command": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", @@ -6354,7 +6935,83 @@ "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", "dev": true, "engines": { - "node": ">=8" + "node": ">=8" + } + }, + "node_modules/side-channel": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.1.0.tgz", + "integrity": "sha512-ZX99e6tRweoUXqR+VBrslhda51Nh5MTQwou5tnUDgbtyM0dBgmhEDtWGP/xbKn6hqfPRHujUNwz5fy/wbbhnpw==", + "dev": true, + "license": "MIT", + "dependencies": { + "es-errors": "^1.3.0", + "object-inspect": "^1.13.3", + "side-channel-list": "^1.0.0", + "side-channel-map": "^1.0.1", + "side-channel-weakmap": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/side-channel-list": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/side-channel-list/-/side-channel-list-1.0.0.tgz", + "integrity": "sha512-FCLHtRD/gnpCiCHEiJLOwdmFP+wzCmDEkc9y7NsYxeF4u7Btsn1ZuwgwJGxImImHicJArLP4R0yX4c2KCrMrTA==", + "dev": true, + "license": "MIT", + "dependencies": { + "es-errors": "^1.3.0", + "object-inspect": "^1.13.3" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/side-channel-map": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/side-channel-map/-/side-channel-map-1.0.1.tgz", + "integrity": "sha512-VCjCNfgMsby3tTdo02nbjtM/ewra6jPHmpThenkTYh8pG9ucZ/1P8So4u4FGBek/BjpOVsDCMoLA/iuBKIFXRA==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bound": "^1.0.2", + "es-errors": "^1.3.0", + "get-intrinsic": "^1.2.5", + "object-inspect": "^1.13.3" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/side-channel-weakmap": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/side-channel-weakmap/-/side-channel-weakmap-1.0.2.tgz", + "integrity": "sha512-WPS/HvHQTYnHisLo9McqBHOJk2FkHO/tlpvldyrnem4aeQp4hai3gythswg6p01oSoTl58rcpiFAjF2br2Ak2A==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bound": "^1.0.2", + "es-errors": "^1.3.0", + "get-intrinsic": "^1.2.5", + "object-inspect": "^1.13.3", + "side-channel-map": "^1.0.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" } }, "node_modules/signal-exit": { @@ -6480,6 +7137,16 @@ "node": ">=10" } }, + "node_modules/statuses": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.2.tgz", + "integrity": "sha512-DvEy55V3DB7uknRo+4iOGT5fP1slR8wQohVdknigZPMpMstaKJQWhwiYBACJE3Ul2pTnATihhBYnRhZQHGBiRw==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + }, "node_modules/string-argv": { "version": "0.3.2", "resolved": "https://registry.npmjs.org/string-argv/-/string-argv-0.3.2.tgz", @@ -6659,6 +7326,16 @@ "node": ">=8.0" } }, + "node_modules/toidentifier": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", + "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.6" + } + }, "node_modules/tough-cookie": { "version": "5.1.2", "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-5.1.2.tgz", @@ -6713,6 +7390,44 @@ "url": "https://github.com/sponsors/sindresorhus" } }, + "node_modules/type-is": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/type-is/-/type-is-2.0.1.tgz", + "integrity": "sha512-OZs6gsjF4vMp32qrCbiVSkrFmXtG/AZhY3t0iAMrMBiAZyV9oALtXO8hsrHbMXF9x6L3grlFuwW2oAz7cav+Gw==", + "dev": true, + "license": "MIT", + "dependencies": { + "content-type": "^1.0.5", + "media-typer": "^1.1.0", + "mime-types": "^3.0.0" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/type-is/node_modules/mime-db": { + "version": "1.54.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.54.0.tgz", + "integrity": "sha512-aU5EJuIN2WDemCcAp2vFBfp/m4EAhWJnUNSSw0ixs7/kXbd6Pg64EmwJkNdFhB8aWt1sH2CTXrLxo/iAGV3oPQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/type-is/node_modules/mime-types": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-3.0.1.tgz", + "integrity": "sha512-xRc4oEhT6eaBpU1XF7AjpOFD+xQmXNB5OVKwp4tqCuBpHLS/ZbBDrc07mYTDqVMg6PfxUjjNp85O6Cd2Z/5HWA==", + "dev": true, + "license": "MIT", + "dependencies": { + "mime-db": "^1.54.0" + }, + "engines": { + "node": ">= 0.6" + } + }, "node_modules/undici": { "version": "5.29.0", "resolved": "https://registry.npmjs.org/undici/-/undici-5.29.0.tgz", @@ -6733,6 +7448,16 @@ "dev": true, "license": "ISC" }, + "node_modules/unpipe": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", + "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + }, "node_modules/update-browserslist-db": { "version": "1.0.11", "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.11.tgz", @@ -6797,6 +7522,16 @@ "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==", "dev": true }, + "node_modules/vary": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", + "integrity": "sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + }, "node_modules/w3c-xmlserializer": { "version": "5.0.0", "resolved": "https://registry.npmjs.org/w3c-xmlserializer/-/w3c-xmlserializer-5.0.0.tgz", @@ -8581,6 +9316,33 @@ "integrity": "sha512-dCTxxolI6fu28lzNRVwd7CzJV8EbARITFyCbP/JqLHYLfWHY7GJqXHDdk0GbtfXvsZosPCvjOE4dOIMT4XDFZQ==", "dev": true }, + "accepts": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/accepts/-/accepts-2.0.0.tgz", + "integrity": "sha512-5cvg6CtKwfgdmVqY1WIiXKc3Q1bkRqGLi+2W/6ao+6Y7gu/RCwRuAhGEzh5B4KlszSuTLgZYuqFqo5bImjNKng==", + "dev": true, + "requires": { + "mime-types": "^3.0.0", + "negotiator": "^1.0.0" + }, + "dependencies": { + "mime-db": { + "version": "1.54.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.54.0.tgz", + "integrity": "sha512-aU5EJuIN2WDemCcAp2vFBfp/m4EAhWJnUNSSw0ixs7/kXbd6Pg64EmwJkNdFhB8aWt1sH2CTXrLxo/iAGV3oPQ==", + "dev": true + }, + "mime-types": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-3.0.1.tgz", + "integrity": "sha512-xRc4oEhT6eaBpU1XF7AjpOFD+xQmXNB5OVKwp4tqCuBpHLS/ZbBDrc07mYTDqVMg6PfxUjjNp85O6Cd2Z/5HWA==", + "dev": true, + "requires": { + "mime-db": "^1.54.0" + } + } + } + }, "acorn": { "version": "8.15.0", "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.15.0.tgz", @@ -8774,6 +9536,23 @@ "integrity": "sha512-NzUnlZexiaH/46WDhANlyR2bXRopNg4F/zuSA3OpZnllCUgRaOF2znDioDWrmbNVsuZk6l9pMquQB38cfBZwkQ==", "dev": true }, + "body-parser": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-2.2.0.tgz", + "integrity": "sha512-02qvAaxv8tp7fBa/mw1ga98OGm+eCbqzJOKoRt70sLmfEEi+jyBYVTDGfCL/k06/4EMk/z01gCe7HoCH/f2LTg==", + "dev": true, + "requires": { + "bytes": "^3.1.2", + "content-type": "^1.0.5", + "debug": "^4.4.0", + "http-errors": "^2.0.0", + "iconv-lite": "^0.6.3", + "on-finished": "^2.4.1", + "qs": "^6.14.0", + "raw-body": "^3.0.0", + "type-is": "^2.0.0" + } + }, "brace-expansion": { "version": "1.1.11", "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", @@ -8820,6 +9599,12 @@ "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", "dev": true }, + "bytes": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", + "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==", + "dev": true + }, "call-bind-apply-helpers": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/call-bind-apply-helpers/-/call-bind-apply-helpers-1.0.2.tgz", @@ -8829,6 +9614,16 @@ "function-bind": "^1.1.2" } }, + "call-bound": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/call-bound/-/call-bound-1.0.4.tgz", + "integrity": "sha512-+ys997U96po4Kx/ABpBCqhA9EuxJaQWDQg7295H4hBphv3IZg0boBKuwYpt4YXp6MZ5AmZQnU/tyMTlRpaSejg==", + "dev": true, + "requires": { + "call-bind-apply-helpers": "^1.0.2", + "get-intrinsic": "^1.3.0" + } + }, "callsites": { "version": "3.1.0", "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", @@ -8997,12 +9792,39 @@ "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", "dev": true }, + "content-disposition": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-1.0.0.tgz", + "integrity": "sha512-Au9nRL8VNUut/XSzbQA38+M78dzP4D+eqg3gfJHMIHHYa3bg067xj1KxMUWj+VULbiZMowKngFFbKczUrNJ1mg==", + "dev": true, + "requires": { + "safe-buffer": "5.2.1" + } + }, + "content-type": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.5.tgz", + "integrity": "sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==", + "dev": true + }, "convert-source-map": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-2.0.0.tgz", "integrity": "sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==", "dev": true }, + "cookie": { + "version": "0.7.2", + "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.7.2.tgz", + "integrity": "sha512-yki5XnKuf750l50uGTllt6kKILY4nQ1eNIQatoXEByZ5dWgnKqbnqmTrBE5B4N7lrMJKQ2ytWMiTO2o0v6Ew/w==", + "dev": true + }, + "cookie-signature": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.2.2.tgz", + "integrity": "sha512-D76uU73ulSXrD1UXF4KE2TMxVVwhsnCgfAyTg9k8P6KGZjlXKrOLe4dJQKI3Bxi5wjesZoFXJWElNWBjPZMbhg==", + "dev": true + }, "create-jest": { "version": "29.7.0", "resolved": "https://registry.npmjs.org/create-jest/-/create-jest-29.7.0.tgz", @@ -9094,6 +9916,12 @@ "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==" }, + "depd": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", + "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==", + "dev": true + }, "deprecation": { "version": "2.3.1", "resolved": "https://registry.npmjs.org/deprecation/-/deprecation-2.3.1.tgz", @@ -9139,6 +9967,12 @@ "gopd": "^1.2.0" } }, + "ee-first": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", + "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==", + "dev": true + }, "electron-to-chromium": { "version": "1.4.478", "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.478.tgz", @@ -9162,6 +9996,12 @@ "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", "dev": true }, + "encodeurl": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-2.0.0.tgz", + "integrity": "sha512-Q0n9HRi4m6JuGIV1eFlmvJB7ZEVxu93IrMyiMsGC0lrMJMWzRgx6WGquyfQgZVb31vhGgXnfmPNNXmxnOkRBrg==", + "dev": true + }, "entities": { "version": "6.0.1", "resolved": "https://registry.npmjs.org/entities/-/entities-6.0.1.tgz", @@ -9218,6 +10058,12 @@ "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", "dev": true }, + "escape-html": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", + "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==", + "dev": true + }, "escape-string-regexp": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz", @@ -9459,6 +10305,12 @@ "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", "dev": true }, + "etag": { + "version": "1.8.1", + "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", + "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==", + "dev": true + }, "eventemitter3": { "version": "5.0.1", "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-5.0.1.tgz", @@ -9501,6 +10353,58 @@ "jest-util": "^29.7.0" } }, + "express": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/express/-/express-5.1.0.tgz", + "integrity": "sha512-DT9ck5YIRU+8GYzzU5kT3eHGA5iL+1Zd0EutOmTE9Dtk+Tvuzd23VBU+ec7HPNSTxXYO55gPV/hq4pSBJDjFpA==", + "dev": true, + "requires": { + "accepts": "^2.0.0", + "body-parser": "^2.2.0", + "content-disposition": "^1.0.0", + "content-type": "^1.0.5", + "cookie": "^0.7.1", + "cookie-signature": "^1.2.1", + "debug": "^4.4.0", + "encodeurl": "^2.0.0", + "escape-html": "^1.0.3", + "etag": "^1.8.1", + "finalhandler": "^2.1.0", + "fresh": "^2.0.0", + "http-errors": "^2.0.0", + "merge-descriptors": "^2.0.0", + "mime-types": "^3.0.0", + "on-finished": "^2.4.1", + "once": "^1.4.0", + "parseurl": "^1.3.3", + "proxy-addr": "^2.0.7", + "qs": "^6.14.0", + "range-parser": "^1.2.1", + "router": "^2.2.0", + "send": "^1.1.0", + "serve-static": "^2.2.0", + "statuses": "^2.0.1", + "type-is": "^2.0.1", + "vary": "^1.1.2" + }, + "dependencies": { + "mime-db": { + "version": "1.54.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.54.0.tgz", + "integrity": "sha512-aU5EJuIN2WDemCcAp2vFBfp/m4EAhWJnUNSSw0ixs7/kXbd6Pg64EmwJkNdFhB8aWt1sH2CTXrLxo/iAGV3oPQ==", + "dev": true + }, + "mime-types": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-3.0.1.tgz", + "integrity": "sha512-xRc4oEhT6eaBpU1XF7AjpOFD+xQmXNB5OVKwp4tqCuBpHLS/ZbBDrc07mYTDqVMg6PfxUjjNp85O6Cd2Z/5HWA==", + "dev": true, + "requires": { + "mime-db": "^1.54.0" + } + } + } + }, "fast-deep-equal": { "version": "3.1.3", "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", @@ -9546,6 +10450,20 @@ "to-regex-range": "^5.0.1" } }, + "finalhandler": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-2.1.0.tgz", + "integrity": "sha512-/t88Ty3d5JWQbWYgaOGCCYfXRwV1+be02WqYYlL6h0lEiUAMPM8o8qKGO01YIkOHzka2up08wvgYD0mDiI+q3Q==", + "dev": true, + "requires": { + "debug": "^4.4.0", + "encodeurl": "^2.0.0", + "escape-html": "^1.0.3", + "on-finished": "^2.4.1", + "parseurl": "^1.3.3", + "statuses": "^2.0.1" + } + }, "find-up": { "version": "4.1.0", "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", @@ -9589,6 +10507,18 @@ "mime-types": "^2.1.12" } }, + "forwarded": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", + "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==", + "dev": true + }, + "fresh": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/fresh/-/fresh-2.0.0.tgz", + "integrity": "sha512-Rx/WycZ60HOaqLKAi6cHRKKI7zxWbJ31MhntmtwMoaTeF7XFH9hhBp8vITaMidfljRQ6eYWCKkaTK+ykVJHP2A==", + "dev": true + }, "fs.realpath": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", @@ -9765,6 +10695,27 @@ "integrity": "sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==", "dev": true }, + "http-errors": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", + "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", + "dev": true, + "requires": { + "depd": "2.0.0", + "inherits": "2.0.4", + "setprototypeof": "1.2.0", + "statuses": "2.0.1", + "toidentifier": "1.0.1" + }, + "dependencies": { + "statuses": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", + "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==", + "dev": true + } + } + }, "http-proxy-agent": { "version": "7.0.2", "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-7.0.2.tgz", @@ -9868,6 +10819,12 @@ "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", "dev": true }, + "ipaddr.js": { + "version": "1.9.1", + "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", + "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==", + "dev": true + }, "is-arrayish": { "version": "0.2.1", "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", @@ -9928,6 +10885,12 @@ "integrity": "sha512-bCYeRA2rVibKZd+s2625gGnGF/t7DSqDs4dP7CrLA1m7jKWz6pps0LpYLJN8Q64HtmPKJ1hrN3nzPNKFEKOUiQ==", "dev": true }, + "is-promise": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-4.0.0.tgz", + "integrity": "sha512-hvpoI6korhJMnej285dSg6nu1+e6uxs7zG3BYAm5byqDsgJNWwxzM6z6iZiAgQR4TJ30JmBTOwqZUw3WlyH3AQ==", + "dev": true + }, "is-stream": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.1.tgz", @@ -11171,6 +12134,18 @@ "resolved": "https://registry.npmjs.org/math-intrinsics/-/math-intrinsics-1.1.0.tgz", "integrity": "sha512-/IXtbwEk5HTPyEwyKX6hGkYXxM9nbj64B+ilVJnC/R6B0pH5G4V3b0pVbL7DBj4tkhBAppbQUlf6F6Xl9LHu1g==" }, + "media-typer": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-1.1.0.tgz", + "integrity": "sha512-aisnrDP4GNe06UcKFnV5bfMNPBUw4jsLGaWwWfnH3v02GnBuXX2MCVn5RbrWo0j3pczUilYblq7fQ7Nw2t5XKw==", + "dev": true + }, + "merge-descriptors": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-2.0.0.tgz", + "integrity": "sha512-Snk314V5ayFLhp3fkUREub6WtjBfPdCPY1Ln8/8munuLuiYhsABgBVWsozAG+MWMbVEvcdcpbi9R7ww22l9Q3g==", + "dev": true + }, "merge-stream": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", @@ -11245,6 +12220,12 @@ "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", "dev": true }, + "negotiator": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-1.0.0.tgz", + "integrity": "sha512-8Ofs/AUQh8MaEcrlq5xOX0CQ9ypTF5dl78mjlMNfOK08fzpgTHQRQPBxcPlEtIw0yRpws+Zo/3r+5WRby7u3Gg==", + "dev": true + }, "node-int64": { "version": "0.4.0", "resolved": "https://registry.npmjs.org/node-int64/-/node-int64-0.4.0.tgz", @@ -11295,6 +12276,21 @@ } } }, + "object-inspect": { + "version": "1.13.4", + "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.13.4.tgz", + "integrity": "sha512-W67iLl4J2EXEGTbfeHCffrjDfitvLANg0UlX3wFUUSTx92KXRFegMHUVgSqE+wvhAbi4WqjGg9czysTV2Epbew==", + "dev": true + }, + "on-finished": { + "version": "2.4.1", + "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz", + "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==", + "dev": true, + "requires": { + "ee-first": "1.1.1" + } + }, "once": { "version": "1.4.0", "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", @@ -11399,6 +12395,12 @@ "entities": "^6.0.0" } }, + "parseurl": { + "version": "1.3.3", + "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", + "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==", + "dev": true + }, "path-exists": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", @@ -11423,6 +12425,12 @@ "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", "dev": true }, + "path-to-regexp": { + "version": "8.3.0", + "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-8.3.0.tgz", + "integrity": "sha512-7jdwVIRtsP8MYpdXSwOS0YdD0Du+qOoF/AEPIt88PcCFrZCzx41oxku1jD88hZBwbNUIEfpqvuhjFaMAqMTWnA==", + "dev": true + }, "picocolors": { "version": "1.1.1", "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.1.1.tgz", @@ -11491,6 +12499,16 @@ "sisteransi": "^1.0.5" } }, + "proxy-addr": { + "version": "2.0.7", + "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", + "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", + "dev": true, + "requires": { + "forwarded": "0.2.0", + "ipaddr.js": "1.9.1" + } + }, "proxy-from-env": { "version": "1.1.0", "resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz", @@ -11508,6 +12526,44 @@ "integrity": "sha512-KddyFewCsO0j3+np81IQ+SweXLDnDQTs5s67BOnrYmYe/yNmUhttQyGsYzy8yUnoljGAQ9sl38YB4vH8ur7Y+w==", "dev": true }, + "qs": { + "version": "6.14.0", + "resolved": "https://registry.npmjs.org/qs/-/qs-6.14.0.tgz", + "integrity": "sha512-YWWTjgABSKcvs/nWBi9PycY/JiPJqOD4JA6o9Sej2AtvSGarXxKC3OQSk4pAarbdQlKAh5D4FCQkJNkW+GAn3w==", + "dev": true, + "requires": { + "side-channel": "^1.1.0" + } + }, + "range-parser": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", + "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==", + "dev": true + }, + "raw-body": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-3.0.1.tgz", + "integrity": "sha512-9G8cA+tuMS75+6G/TzW8OtLzmBDMo8p1JRxN5AZ+LAp8uxGA8V8GZm4GQ4/N5QNQEnLmg6SS7wyuSmbKepiKqA==", + "dev": true, + "requires": { + "bytes": "3.1.2", + "http-errors": "2.0.0", + "iconv-lite": "0.7.0", + "unpipe": "1.0.0" + }, + "dependencies": { + "iconv-lite": { + "version": "0.7.0", + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.7.0.tgz", + "integrity": "sha512-cf6L2Ds3h57VVmkZe+Pn+5APsT7FpqJtEhhieDCvrE2MK5Qk9MyffgQyuxQTm6BChfeZNtcOLHp9IcWRVcIcBQ==", + "dev": true, + "requires": { + "safer-buffer": ">= 2.1.2 < 3.0.0" + } + } + } + }, "react-is": { "version": "17.0.2", "resolved": "https://registry.npmjs.org/react-is/-/react-is-17.0.2.tgz", @@ -11601,12 +12657,31 @@ "integrity": "sha512-q1b3N5QkRUWUl7iyylaaj3kOpIT0N2i9MqIEQXP73GVsN9cw3fdx8X63cEmWhJGi2PPCF23Ijp7ktmd39rawIA==", "dev": true }, + "router": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/router/-/router-2.2.0.tgz", + "integrity": "sha512-nLTrUKm2UyiL7rlhapu/Zl45FwNgkZGaCpZbIHajDYgwlJCOzLSk+cIPAnsEqV955GjILJnKbdQC1nVPz+gAYQ==", + "dev": true, + "requires": { + "debug": "^4.4.0", + "depd": "^2.0.0", + "is-promise": "^4.0.0", + "parseurl": "^1.3.3", + "path-to-regexp": "^8.0.0" + } + }, "rrweb-cssom": { "version": "0.8.0", "resolved": "https://registry.npmjs.org/rrweb-cssom/-/rrweb-cssom-0.8.0.tgz", "integrity": "sha512-guoltQEx+9aMf2gDZ0s62EcV8lsXR+0w8915TC3ITdn2YueuNjdAYh/levpU9nFaoChh9RUS5ZdQMrKfVEN9tw==", "dev": true }, + "safe-buffer": { + "version": "5.2.1", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", + "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", + "dev": true + }, "safer-buffer": { "version": "2.1.2", "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", @@ -11628,6 +12703,60 @@ "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", "dev": true }, + "send": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/send/-/send-1.2.0.tgz", + "integrity": "sha512-uaW0WwXKpL9blXE2o0bRhoL2EGXIrZxQ2ZQ4mgcfoBxdFmQold+qWsD2jLrfZ0trjKL6vOw0j//eAwcALFjKSw==", + "dev": true, + "requires": { + "debug": "^4.3.5", + "encodeurl": "^2.0.0", + "escape-html": "^1.0.3", + "etag": "^1.8.1", + "fresh": "^2.0.0", + "http-errors": "^2.0.0", + "mime-types": "^3.0.1", + "ms": "^2.1.3", + "on-finished": "^2.4.1", + "range-parser": "^1.2.1", + "statuses": "^2.0.1" + }, + "dependencies": { + "mime-db": { + "version": "1.54.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.54.0.tgz", + "integrity": "sha512-aU5EJuIN2WDemCcAp2vFBfp/m4EAhWJnUNSSw0ixs7/kXbd6Pg64EmwJkNdFhB8aWt1sH2CTXrLxo/iAGV3oPQ==", + "dev": true + }, + "mime-types": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-3.0.1.tgz", + "integrity": "sha512-xRc4oEhT6eaBpU1XF7AjpOFD+xQmXNB5OVKwp4tqCuBpHLS/ZbBDrc07mYTDqVMg6PfxUjjNp85O6Cd2Z/5HWA==", + "dev": true, + "requires": { + "mime-db": "^1.54.0" + } + } + } + }, + "serve-static": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-2.2.0.tgz", + "integrity": "sha512-61g9pCh0Vnh7IutZjtLGGpTA355+OPn2TyDv/6ivP2h/AdAVX9azsoxmg2/M6nZeQZNYBEwIcsne1mJd9oQItQ==", + "dev": true, + "requires": { + "encodeurl": "^2.0.0", + "escape-html": "^1.0.3", + "parseurl": "^1.3.3", + "send": "^1.2.0" + } + }, + "setprototypeof": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", + "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==", + "dev": true + }, "shebang-command": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", @@ -11643,6 +12772,54 @@ "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", "dev": true }, + "side-channel": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.1.0.tgz", + "integrity": "sha512-ZX99e6tRweoUXqR+VBrslhda51Nh5MTQwou5tnUDgbtyM0dBgmhEDtWGP/xbKn6hqfPRHujUNwz5fy/wbbhnpw==", + "dev": true, + "requires": { + "es-errors": "^1.3.0", + "object-inspect": "^1.13.3", + "side-channel-list": "^1.0.0", + "side-channel-map": "^1.0.1", + "side-channel-weakmap": "^1.0.2" + } + }, + "side-channel-list": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/side-channel-list/-/side-channel-list-1.0.0.tgz", + "integrity": "sha512-FCLHtRD/gnpCiCHEiJLOwdmFP+wzCmDEkc9y7NsYxeF4u7Btsn1ZuwgwJGxImImHicJArLP4R0yX4c2KCrMrTA==", + "dev": true, + "requires": { + "es-errors": "^1.3.0", + "object-inspect": "^1.13.3" + } + }, + "side-channel-map": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/side-channel-map/-/side-channel-map-1.0.1.tgz", + "integrity": "sha512-VCjCNfgMsby3tTdo02nbjtM/ewra6jPHmpThenkTYh8pG9ucZ/1P8So4u4FGBek/BjpOVsDCMoLA/iuBKIFXRA==", + "dev": true, + "requires": { + "call-bound": "^1.0.2", + "es-errors": "^1.3.0", + "get-intrinsic": "^1.2.5", + "object-inspect": "^1.13.3" + } + }, + "side-channel-weakmap": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/side-channel-weakmap/-/side-channel-weakmap-1.0.2.tgz", + "integrity": "sha512-WPS/HvHQTYnHisLo9McqBHOJk2FkHO/tlpvldyrnem4aeQp4hai3gythswg6p01oSoTl58rcpiFAjF2br2Ak2A==", + "dev": true, + "requires": { + "call-bound": "^1.0.2", + "es-errors": "^1.3.0", + "get-intrinsic": "^1.2.5", + "object-inspect": "^1.13.3", + "side-channel-map": "^1.0.1" + } + }, "signal-exit": { "version": "3.0.7", "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", @@ -11741,6 +12918,12 @@ "escape-string-regexp": "^2.0.0" } }, + "statuses": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.2.tgz", + "integrity": "sha512-DvEy55V3DB7uknRo+4iOGT5fP1slR8wQohVdknigZPMpMstaKJQWhwiYBACJE3Ul2pTnATihhBYnRhZQHGBiRw==", + "dev": true + }, "string-argv": { "version": "0.3.2", "resolved": "https://registry.npmjs.org/string-argv/-/string-argv-0.3.2.tgz", @@ -11872,6 +13055,12 @@ "is-number": "^7.0.0" } }, + "toidentifier": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", + "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==", + "dev": true + }, "tough-cookie": { "version": "5.1.2", "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-5.1.2.tgz", @@ -11908,6 +13097,34 @@ "integrity": "sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w==", "dev": true }, + "type-is": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/type-is/-/type-is-2.0.1.tgz", + "integrity": "sha512-OZs6gsjF4vMp32qrCbiVSkrFmXtG/AZhY3t0iAMrMBiAZyV9oALtXO8hsrHbMXF9x6L3grlFuwW2oAz7cav+Gw==", + "dev": true, + "requires": { + "content-type": "^1.0.5", + "media-typer": "^1.1.0", + "mime-types": "^3.0.0" + }, + "dependencies": { + "mime-db": { + "version": "1.54.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.54.0.tgz", + "integrity": "sha512-aU5EJuIN2WDemCcAp2vFBfp/m4EAhWJnUNSSw0ixs7/kXbd6Pg64EmwJkNdFhB8aWt1sH2CTXrLxo/iAGV3oPQ==", + "dev": true + }, + "mime-types": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-3.0.1.tgz", + "integrity": "sha512-xRc4oEhT6eaBpU1XF7AjpOFD+xQmXNB5OVKwp4tqCuBpHLS/ZbBDrc07mYTDqVMg6PfxUjjNp85O6Cd2Z/5HWA==", + "dev": true, + "requires": { + "mime-db": "^1.54.0" + } + } + } + }, "undici": { "version": "5.29.0", "resolved": "https://registry.npmjs.org/undici/-/undici-5.29.0.tgz", @@ -11923,6 +13140,12 @@ "integrity": "sha512-yCzhz6FN2wU1NiiQRogkTQszlQSlpWaw8SvVegAc+bDxbzHgh1vX8uIe8OYyMH6DwH+sdTJsgMl36+mSMdRJIQ==", "dev": true }, + "unpipe": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", + "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==", + "dev": true + }, "update-browserslist-db": { "version": "1.0.11", "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.11.tgz", @@ -11966,6 +13189,12 @@ } } }, + "vary": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", + "integrity": "sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==", + "dev": true + }, "w3c-xmlserializer": { "version": "5.0.0", "resolved": "https://registry.npmjs.org/w3c-xmlserializer/-/w3c-xmlserializer-5.0.0.tgz", diff --git a/package.json b/package.json index 003759510d450..638d8e9992205 100644 --- a/package.json +++ b/package.json @@ -48,6 +48,7 @@ "eslint": "^9.36.0", "eslint-config-prettier": "^10.1.8", "eslint-plugin-jsdoc": "^60.1.1", + "express": "^5.1.0", "globals": "^16.4.0", "hjson": "^3.2.2", "husky": "^9.1.7", From 0e3056243ebe867e9ffaf0c62a0a4c9e243e560a Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 3 Oct 2025 18:40:36 +0300 Subject: [PATCH 121/265] ci(deps): bump bahmutov/npm-install from 1.11.0 to 1.11.1 (#4474) Bumps [bahmutov/npm-install](https://github.com/bahmutov/npm-install) from 1.11.0 to 1.11.1. - [Release notes](https://github.com/bahmutov/npm-install/releases) - [Commits](https://github.com/bahmutov/npm-install/compare/e5fe105da2400070b5345aeb71fcb1ef5d4b2d1f...4488656f8e90d3c85e3a964db0018dd624f340e7) --- updated-dependencies: - dependency-name: bahmutov/npm-install dependency-version: 1.11.1 dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- .github/workflows/preview-theme.yml | 2 +- .github/workflows/stale-theme-pr-closer.yml | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/preview-theme.yml b/.github/workflows/preview-theme.yml index 10e91c9c4120d..6db3aeea938ed 100644 --- a/.github/workflows/preview-theme.yml +++ b/.github/workflows/preview-theme.yml @@ -39,7 +39,7 @@ jobs: node-version: ${{ matrix.node-version }} cache: npm - - uses: bahmutov/npm-install@e5fe105da2400070b5345aeb71fcb1ef5d4b2d1f # v1.11.0 + - uses: bahmutov/npm-install@4488656f8e90d3c85e3a964db0018dd624f340e7 # v1.11.1 with: useLockFile: false diff --git a/.github/workflows/stale-theme-pr-closer.yml b/.github/workflows/stale-theme-pr-closer.yml index c416cd63792bf..81c8ee22f0901 100644 --- a/.github/workflows/stale-theme-pr-closer.yml +++ b/.github/workflows/stale-theme-pr-closer.yml @@ -45,7 +45,7 @@ jobs: node-version: ${{ matrix.node-version }} cache: npm - - uses: bahmutov/npm-install@e5fe105da2400070b5345aeb71fcb1ef5d4b2d1f # v1.11.0 + - uses: bahmutov/npm-install@4488656f8e90d3c85e3a964db0018dd624f340e7 # v1.11.1 with: useLockFile: false From cacc32a2cb040a8bcf14906ded24d3fa9f1cde47 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 3 Oct 2025 18:43:40 +0300 Subject: [PATCH 122/265] build(deps-dev): bump lint-staged from 16.2.0 to 16.2.3 (#4472) Bumps [lint-staged](https://github.com/lint-staged/lint-staged) from 16.2.0 to 16.2.3. - [Release notes](https://github.com/lint-staged/lint-staged/releases) - [Changelog](https://github.com/lint-staged/lint-staged/blob/main/CHANGELOG.md) - [Commits](https://github.com/lint-staged/lint-staged/compare/v16.2.0...v16.2.3) --- updated-dependencies: - dependency-name: lint-staged dependency-version: 16.2.3 dependency-type: direct:development update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- package-lock.json | 46 +++++++++++++++++++++++----------------------- package.json | 2 +- 2 files changed, 24 insertions(+), 24 deletions(-) diff --git a/package-lock.json b/package-lock.json index cc5e555fea186..77f2d7d52b829 100644 --- a/package-lock.json +++ b/package-lock.json @@ -36,7 +36,7 @@ "jest": "^29.7.0", "jest-environment-jsdom": "^30.1.2", "js-yaml": "^4.1.0", - "lint-staged": "^16.2.0", + "lint-staged": "^16.2.3", "lodash.snakecase": "^4.1.1", "parse-diff": "^0.11.1", "prettier": "^3.6.2" @@ -5683,18 +5683,18 @@ "dev": true }, "node_modules/lint-staged": { - "version": "16.2.0", - "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-16.2.0.tgz", - "integrity": "sha512-spdYSOCQ2MdZ9CM1/bu/kDmaYGsrpNOeu1InFFV8uhv14x6YIubGxbCpSmGILFoxkiheNQPDXSg5Sbb5ZuVnug==", + "version": "16.2.3", + "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-16.2.3.tgz", + "integrity": "sha512-1OnJEESB9zZqsp61XHH2fvpS1es3hRCxMplF/AJUDa8Ho8VrscYDIuxGrj3m8KPXbcWZ8fT9XTMUhEQmOVKpKw==", "dev": true, "dependencies": { - "commander": "14.0.1", - "listr2": "9.0.4", - "micromatch": "4.0.8", - "nano-spawn": "1.0.3", - "pidtree": "0.6.0", - "string-argv": "0.3.2", - "yaml": "2.8.1" + "commander": "^14.0.1", + "listr2": "^9.0.4", + "micromatch": "^4.0.8", + "nano-spawn": "^1.0.3", + "pidtree": "^0.6.0", + "string-argv": "^0.3.2", + "yaml": "^2.8.1" }, "bin": { "lint-staged": "bin/lint-staged.js" @@ -11897,18 +11897,18 @@ "dev": true }, "lint-staged": { - "version": "16.2.0", - "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-16.2.0.tgz", - "integrity": "sha512-spdYSOCQ2MdZ9CM1/bu/kDmaYGsrpNOeu1InFFV8uhv14x6YIubGxbCpSmGILFoxkiheNQPDXSg5Sbb5ZuVnug==", - "dev": true, - "requires": { - "commander": "14.0.1", - "listr2": "9.0.4", - "micromatch": "4.0.8", - "nano-spawn": "1.0.3", - "pidtree": "0.6.0", - "string-argv": "0.3.2", - "yaml": "2.8.1" + "version": "16.2.3", + "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-16.2.3.tgz", + "integrity": "sha512-1OnJEESB9zZqsp61XHH2fvpS1es3hRCxMplF/AJUDa8Ho8VrscYDIuxGrj3m8KPXbcWZ8fT9XTMUhEQmOVKpKw==", + "dev": true, + "requires": { + "commander": "^14.0.1", + "listr2": "^9.0.4", + "micromatch": "^4.0.8", + "nano-spawn": "^1.0.3", + "pidtree": "^0.6.0", + "string-argv": "^0.3.2", + "yaml": "^2.8.1" } }, "listr2": { diff --git a/package.json b/package.json index 638d8e9992205..71eeea50ed675 100644 --- a/package.json +++ b/package.json @@ -55,7 +55,7 @@ "jest": "^29.7.0", "jest-environment-jsdom": "^30.1.2", "js-yaml": "^4.1.0", - "lint-staged": "^16.2.0", + "lint-staged": "^16.2.3", "lodash.snakecase": "^4.1.1", "parse-diff": "^0.11.1", "prettier": "^3.6.2" From 811f4582eeee1798f75110a90c2f42ba41719af0 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 3 Oct 2025 18:46:36 +0300 Subject: [PATCH 123/265] build(deps-dev): bump jest-environment-jsdom from 30.1.2 to 30.2.0 (#4479) Bumps [jest-environment-jsdom](https://github.com/jestjs/jest/tree/HEAD/packages/jest-environment-jsdom) from 30.1.2 to 30.2.0. - [Release notes](https://github.com/jestjs/jest/releases) - [Changelog](https://github.com/jestjs/jest/blob/main/CHANGELOG.md) - [Commits](https://github.com/jestjs/jest/commits/v30.2.0/packages/jest-environment-jsdom) --- updated-dependencies: - dependency-name: jest-environment-jsdom dependency-version: 30.2.0 dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- package-lock.json | 330 +++++++++++++++++++++++----------------------- package.json | 2 +- 2 files changed, 166 insertions(+), 166 deletions(-) diff --git a/package-lock.json b/package-lock.json index 77f2d7d52b829..adb8adb39b397 100644 --- a/package-lock.json +++ b/package-lock.json @@ -34,7 +34,7 @@ "hjson": "^3.2.2", "husky": "^9.1.7", "jest": "^29.7.0", - "jest-environment-jsdom": "^30.1.2", + "jest-environment-jsdom": "^30.2.0", "js-yaml": "^4.1.0", "lint-staged": "^16.2.3", "lodash.snakecase": "^4.1.1", @@ -1162,18 +1162,18 @@ } }, "node_modules/@jest/environment-jsdom-abstract": { - "version": "30.1.2", - "resolved": "https://registry.npmjs.org/@jest/environment-jsdom-abstract/-/environment-jsdom-abstract-30.1.2.tgz", - "integrity": "sha512-u8kTh/ZBl97GOmnGJLYK/1GuwAruMC4hoP6xuk/kwltmVWsA9u/6fH1/CsPVGt2O+Wn2yEjs8n1B1zZJ62Cx0w==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/environment-jsdom-abstract/-/environment-jsdom-abstract-30.2.0.tgz", + "integrity": "sha512-kazxw2L9IPuZpQ0mEt9lu9Z98SqR74xcagANmMBU16X0lS23yPc0+S6hGLUz8kVRlomZEs/5S/Zlpqwf5yu6OQ==", "dev": true, "dependencies": { - "@jest/environment": "30.1.2", - "@jest/fake-timers": "30.1.2", - "@jest/types": "30.0.5", + "@jest/environment": "30.2.0", + "@jest/fake-timers": "30.2.0", + "@jest/types": "30.2.0", "@types/jsdom": "^21.1.7", "@types/node": "*", - "jest-mock": "30.0.5", - "jest-util": "30.0.5" + "jest-mock": "30.2.0", + "jest-util": "30.2.0" }, "engines": { "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" @@ -1189,32 +1189,32 @@ } }, "node_modules/@jest/environment-jsdom-abstract/node_modules/@jest/environment": { - "version": "30.1.2", - "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-30.1.2.tgz", - "integrity": "sha512-N8t1Ytw4/mr9uN28OnVf0SYE2dGhaIxOVYcwsf9IInBKjvofAjbFRvedvBBlyTYk2knbJTiEjEJ2PyyDIBnd9w==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-30.2.0.tgz", + "integrity": "sha512-/QPTL7OBJQ5ac09UDRa3EQes4gt1FTEG/8jZ/4v5IVzx+Cv7dLxlVIvfvSVRiiX2drWyXeBjkMSR8hvOWSog5g==", "dev": true, "dependencies": { - "@jest/fake-timers": "30.1.2", - "@jest/types": "30.0.5", + "@jest/fake-timers": "30.2.0", + "@jest/types": "30.2.0", "@types/node": "*", - "jest-mock": "30.0.5" + "jest-mock": "30.2.0" }, "engines": { "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/@jest/environment-jsdom-abstract/node_modules/@jest/fake-timers": { - "version": "30.1.2", - "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-30.1.2.tgz", - "integrity": "sha512-Beljfv9AYkr9K+ETX9tvV61rJTY706BhBUtiaepQHeEGfe0DbpvUA5Z3fomwc5Xkhns6NWrcFDZn+72fLieUnA==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-30.2.0.tgz", + "integrity": "sha512-HI3tRLjRxAbBy0VO8dqqm7Hb2mIa8d5bg/NJkyQcOk7V118ObQML8RC5luTF/Zsg4474a+gDvhce7eTnP4GhYw==", "dev": true, "dependencies": { - "@jest/types": "30.0.5", + "@jest/types": "30.2.0", "@sinonjs/fake-timers": "^13.0.0", "@types/node": "*", - "jest-message-util": "30.1.0", - "jest-mock": "30.0.5", - "jest-util": "30.0.5" + "jest-message-util": "30.2.0", + "jest-mock": "30.2.0", + "jest-util": "30.2.0" }, "engines": { "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" @@ -1233,9 +1233,9 @@ } }, "node_modules/@jest/environment-jsdom-abstract/node_modules/@jest/types": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/@jest/types/-/types-30.0.5.tgz", - "integrity": "sha512-aREYa3aku9SSnea4aX6bhKn4bgv3AXkgijoQgbYV3yvbiGt6z+MQ85+6mIhx9DsKW2BuB/cLR/A+tcMThx+KLQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/types/-/types-30.2.0.tgz", + "integrity": "sha512-H9xg1/sfVvyfU7o3zMfBEjQ1gcsdeTMgqHoYdN79tuLqfTtuu7WckRA1R5whDwOzxaZAeMKTYWqP+WCAi0CHsg==", "dev": true, "dependencies": { "@jest/pattern": "30.0.1", @@ -1293,18 +1293,18 @@ } }, "node_modules/@jest/environment-jsdom-abstract/node_modules/jest-message-util": { - "version": "30.1.0", - "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-30.1.0.tgz", - "integrity": "sha512-HizKDGG98cYkWmaLUHChq4iN+oCENohQLb7Z5guBPumYs+/etonmNFlg1Ps6yN9LTPyZn+M+b/9BbnHx3WTMDg==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-30.2.0.tgz", + "integrity": "sha512-y4DKFLZ2y6DxTWD4cDe07RglV88ZiNEdlRfGtqahfbIjfsw1nMCPx49Uev4IA/hWn3sDKyAnSPwoYSsAEdcimw==", "dev": true, "dependencies": { "@babel/code-frame": "^7.27.1", - "@jest/types": "30.0.5", + "@jest/types": "30.2.0", "@types/stack-utils": "^2.0.3", "chalk": "^4.1.2", "graceful-fs": "^4.2.11", "micromatch": "^4.0.8", - "pretty-format": "30.0.5", + "pretty-format": "30.2.0", "slash": "^3.0.0", "stack-utils": "^2.0.6" }, @@ -1313,26 +1313,26 @@ } }, "node_modules/@jest/environment-jsdom-abstract/node_modules/jest-mock": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-30.0.5.tgz", - "integrity": "sha512-Od7TyasAAQX/6S+QCbN6vZoWOMwlTtzzGuxJku1GhGanAjz9y+QsQkpScDmETvdc9aSXyJ/Op4rhpMYBWW91wQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-30.2.0.tgz", + "integrity": "sha512-JNNNl2rj4b5ICpmAcq+WbLH83XswjPbjH4T7yvGzfAGCPh1rw+xVNbtk+FnRslvt9lkCcdn9i1oAoKUuFsOxRw==", "dev": true, "dependencies": { - "@jest/types": "30.0.5", + "@jest/types": "30.2.0", "@types/node": "*", - "jest-util": "30.0.5" + "jest-util": "30.2.0" }, "engines": { "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/@jest/environment-jsdom-abstract/node_modules/jest-util": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-30.0.5.tgz", - "integrity": "sha512-pvyPWssDZR0FlfMxCBoc0tvM8iUEskaRFALUtGQYzVEAqisAztmy+R8LnU14KT4XA0H/a5HMVTXat1jLne010g==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-30.2.0.tgz", + "integrity": "sha512-QKNsM0o3Xe6ISQU869e+DhG+4CK/48aHYdJZGlFQVTjnbvgpcKyxpzk29fGiO7i/J8VENZ+d2iGnSsvmuHywlA==", "dev": true, "dependencies": { - "@jest/types": "30.0.5", + "@jest/types": "30.2.0", "@types/node": "*", "chalk": "^4.1.2", "ci-info": "^4.2.0", @@ -1356,9 +1356,9 @@ } }, "node_modules/@jest/environment-jsdom-abstract/node_modules/pretty-format": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.0.5.tgz", - "integrity": "sha512-D1tKtYvByrBkFLe2wHJl2bwMJIiT8rW+XA+TiataH79/FszLQMrpGEvzUVkzPau7OCO0Qnrhpe87PqtOAIB8Yw==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.2.0.tgz", + "integrity": "sha512-9uBdv/B4EefsuAL+pWqueZyZS2Ba+LxfFeQ9DN14HU4bN8bhaxKdkpjpB6fs9+pSjIBu+FXQHImEg8j/Lw0+vA==", "dev": true, "dependencies": { "@jest/schemas": "30.0.5", @@ -4769,13 +4769,13 @@ "dev": true }, "node_modules/jest-environment-jsdom": { - "version": "30.1.2", - "resolved": "https://registry.npmjs.org/jest-environment-jsdom/-/jest-environment-jsdom-30.1.2.tgz", - "integrity": "sha512-LXsfAh5+mDTuXDONGl1ZLYxtJEaS06GOoxJb2arcJTjIfh1adYg8zLD8f6P0df8VmjvCaMrLmc1PgHUI/YUTbg==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-environment-jsdom/-/jest-environment-jsdom-30.2.0.tgz", + "integrity": "sha512-zbBTiqr2Vl78pKp/laGBREYzbZx9ZtqPjOK4++lL4BNDhxRnahg51HtoDrk9/VjIy9IthNEWdKVd7H5bqBhiWQ==", "dev": true, "dependencies": { - "@jest/environment": "30.1.2", - "@jest/environment-jsdom-abstract": "30.1.2", + "@jest/environment": "30.2.0", + "@jest/environment-jsdom-abstract": "30.2.0", "@types/jsdom": "^21.1.7", "@types/node": "*", "jsdom": "^26.1.0" @@ -4793,32 +4793,32 @@ } }, "node_modules/jest-environment-jsdom/node_modules/@jest/environment": { - "version": "30.1.2", - "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-30.1.2.tgz", - "integrity": "sha512-N8t1Ytw4/mr9uN28OnVf0SYE2dGhaIxOVYcwsf9IInBKjvofAjbFRvedvBBlyTYk2knbJTiEjEJ2PyyDIBnd9w==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-30.2.0.tgz", + "integrity": "sha512-/QPTL7OBJQ5ac09UDRa3EQes4gt1FTEG/8jZ/4v5IVzx+Cv7dLxlVIvfvSVRiiX2drWyXeBjkMSR8hvOWSog5g==", "dev": true, "dependencies": { - "@jest/fake-timers": "30.1.2", - "@jest/types": "30.0.5", + "@jest/fake-timers": "30.2.0", + "@jest/types": "30.2.0", "@types/node": "*", - "jest-mock": "30.0.5" + "jest-mock": "30.2.0" }, "engines": { "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/jest-environment-jsdom/node_modules/@jest/fake-timers": { - "version": "30.1.2", - "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-30.1.2.tgz", - "integrity": "sha512-Beljfv9AYkr9K+ETX9tvV61rJTY706BhBUtiaepQHeEGfe0DbpvUA5Z3fomwc5Xkhns6NWrcFDZn+72fLieUnA==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-30.2.0.tgz", + "integrity": "sha512-HI3tRLjRxAbBy0VO8dqqm7Hb2mIa8d5bg/NJkyQcOk7V118ObQML8RC5luTF/Zsg4474a+gDvhce7eTnP4GhYw==", "dev": true, "dependencies": { - "@jest/types": "30.0.5", + "@jest/types": "30.2.0", "@sinonjs/fake-timers": "^13.0.0", "@types/node": "*", - "jest-message-util": "30.1.0", - "jest-mock": "30.0.5", - "jest-util": "30.0.5" + "jest-message-util": "30.2.0", + "jest-mock": "30.2.0", + "jest-util": "30.2.0" }, "engines": { "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" @@ -4837,9 +4837,9 @@ } }, "node_modules/jest-environment-jsdom/node_modules/@jest/types": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/@jest/types/-/types-30.0.5.tgz", - "integrity": "sha512-aREYa3aku9SSnea4aX6bhKn4bgv3AXkgijoQgbYV3yvbiGt6z+MQ85+6mIhx9DsKW2BuB/cLR/A+tcMThx+KLQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/types/-/types-30.2.0.tgz", + "integrity": "sha512-H9xg1/sfVvyfU7o3zMfBEjQ1gcsdeTMgqHoYdN79tuLqfTtuu7WckRA1R5whDwOzxaZAeMKTYWqP+WCAi0CHsg==", "dev": true, "dependencies": { "@jest/pattern": "30.0.1", @@ -4897,18 +4897,18 @@ } }, "node_modules/jest-environment-jsdom/node_modules/jest-message-util": { - "version": "30.1.0", - "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-30.1.0.tgz", - "integrity": "sha512-HizKDGG98cYkWmaLUHChq4iN+oCENohQLb7Z5guBPumYs+/etonmNFlg1Ps6yN9LTPyZn+M+b/9BbnHx3WTMDg==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-30.2.0.tgz", + "integrity": "sha512-y4DKFLZ2y6DxTWD4cDe07RglV88ZiNEdlRfGtqahfbIjfsw1nMCPx49Uev4IA/hWn3sDKyAnSPwoYSsAEdcimw==", "dev": true, "dependencies": { "@babel/code-frame": "^7.27.1", - "@jest/types": "30.0.5", + "@jest/types": "30.2.0", "@types/stack-utils": "^2.0.3", "chalk": "^4.1.2", "graceful-fs": "^4.2.11", "micromatch": "^4.0.8", - "pretty-format": "30.0.5", + "pretty-format": "30.2.0", "slash": "^3.0.0", "stack-utils": "^2.0.6" }, @@ -4917,26 +4917,26 @@ } }, "node_modules/jest-environment-jsdom/node_modules/jest-mock": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-30.0.5.tgz", - "integrity": "sha512-Od7TyasAAQX/6S+QCbN6vZoWOMwlTtzzGuxJku1GhGanAjz9y+QsQkpScDmETvdc9aSXyJ/Op4rhpMYBWW91wQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-30.2.0.tgz", + "integrity": "sha512-JNNNl2rj4b5ICpmAcq+WbLH83XswjPbjH4T7yvGzfAGCPh1rw+xVNbtk+FnRslvt9lkCcdn9i1oAoKUuFsOxRw==", "dev": true, "dependencies": { - "@jest/types": "30.0.5", + "@jest/types": "30.2.0", "@types/node": "*", - "jest-util": "30.0.5" + "jest-util": "30.2.0" }, "engines": { "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/jest-environment-jsdom/node_modules/jest-util": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-30.0.5.tgz", - "integrity": "sha512-pvyPWssDZR0FlfMxCBoc0tvM8iUEskaRFALUtGQYzVEAqisAztmy+R8LnU14KT4XA0H/a5HMVTXat1jLne010g==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-30.2.0.tgz", + "integrity": "sha512-QKNsM0o3Xe6ISQU869e+DhG+4CK/48aHYdJZGlFQVTjnbvgpcKyxpzk29fGiO7i/J8VENZ+d2iGnSsvmuHywlA==", "dev": true, "dependencies": { - "@jest/types": "30.0.5", + "@jest/types": "30.2.0", "@types/node": "*", "chalk": "^4.1.2", "ci-info": "^4.2.0", @@ -4960,9 +4960,9 @@ } }, "node_modules/jest-environment-jsdom/node_modules/pretty-format": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.0.5.tgz", - "integrity": "sha512-D1tKtYvByrBkFLe2wHJl2bwMJIiT8rW+XA+TiataH79/FszLQMrpGEvzUVkzPau7OCO0Qnrhpe87PqtOAIB8Yw==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.2.0.tgz", + "integrity": "sha512-9uBdv/B4EefsuAL+pWqueZyZS2Ba+LxfFeQ9DN14HU4bN8bhaxKdkpjpB6fs9+pSjIBu+FXQHImEg8j/Lw0+vA==", "dev": true, "dependencies": { "@jest/schemas": "30.0.5", @@ -6193,9 +6193,9 @@ } }, "node_modules/nwsapi": { - "version": "2.2.21", - "resolved": "https://registry.npmjs.org/nwsapi/-/nwsapi-2.2.21.tgz", - "integrity": "sha512-o6nIY3qwiSXl7/LuOU0Dmuctd34Yay0yeuZRLFmDPrrdHpXKFndPj3hM+YEPVHYC5fx2otBx4Ilc/gyYSAUaIA==", + "version": "2.2.22", + "resolved": "https://registry.npmjs.org/nwsapi/-/nwsapi-2.2.22.tgz", + "integrity": "sha512-ujSMe1OWVn55euT1ihwCI1ZcAaAU3nxUiDwfDQldc51ZXaB9m2AyOn6/jh1BLe2t/G8xd6uKG1UBF2aZJeg2SQ==", "dev": true }, "node_modules/object-deep-merge": { @@ -8554,44 +8554,44 @@ } }, "@jest/environment-jsdom-abstract": { - "version": "30.1.2", - "resolved": "https://registry.npmjs.org/@jest/environment-jsdom-abstract/-/environment-jsdom-abstract-30.1.2.tgz", - "integrity": "sha512-u8kTh/ZBl97GOmnGJLYK/1GuwAruMC4hoP6xuk/kwltmVWsA9u/6fH1/CsPVGt2O+Wn2yEjs8n1B1zZJ62Cx0w==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/environment-jsdom-abstract/-/environment-jsdom-abstract-30.2.0.tgz", + "integrity": "sha512-kazxw2L9IPuZpQ0mEt9lu9Z98SqR74xcagANmMBU16X0lS23yPc0+S6hGLUz8kVRlomZEs/5S/Zlpqwf5yu6OQ==", "dev": true, "requires": { - "@jest/environment": "30.1.2", - "@jest/fake-timers": "30.1.2", - "@jest/types": "30.0.5", + "@jest/environment": "30.2.0", + "@jest/fake-timers": "30.2.0", + "@jest/types": "30.2.0", "@types/jsdom": "^21.1.7", "@types/node": "*", - "jest-mock": "30.0.5", - "jest-util": "30.0.5" + "jest-mock": "30.2.0", + "jest-util": "30.2.0" }, "dependencies": { "@jest/environment": { - "version": "30.1.2", - "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-30.1.2.tgz", - "integrity": "sha512-N8t1Ytw4/mr9uN28OnVf0SYE2dGhaIxOVYcwsf9IInBKjvofAjbFRvedvBBlyTYk2knbJTiEjEJ2PyyDIBnd9w==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-30.2.0.tgz", + "integrity": "sha512-/QPTL7OBJQ5ac09UDRa3EQes4gt1FTEG/8jZ/4v5IVzx+Cv7dLxlVIvfvSVRiiX2drWyXeBjkMSR8hvOWSog5g==", "dev": true, "requires": { - "@jest/fake-timers": "30.1.2", - "@jest/types": "30.0.5", + "@jest/fake-timers": "30.2.0", + "@jest/types": "30.2.0", "@types/node": "*", - "jest-mock": "30.0.5" + "jest-mock": "30.2.0" } }, "@jest/fake-timers": { - "version": "30.1.2", - "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-30.1.2.tgz", - "integrity": "sha512-Beljfv9AYkr9K+ETX9tvV61rJTY706BhBUtiaepQHeEGfe0DbpvUA5Z3fomwc5Xkhns6NWrcFDZn+72fLieUnA==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-30.2.0.tgz", + "integrity": "sha512-HI3tRLjRxAbBy0VO8dqqm7Hb2mIa8d5bg/NJkyQcOk7V118ObQML8RC5luTF/Zsg4474a+gDvhce7eTnP4GhYw==", "dev": true, "requires": { - "@jest/types": "30.0.5", + "@jest/types": "30.2.0", "@sinonjs/fake-timers": "^13.0.0", "@types/node": "*", - "jest-message-util": "30.1.0", - "jest-mock": "30.0.5", - "jest-util": "30.0.5" + "jest-message-util": "30.2.0", + "jest-mock": "30.2.0", + "jest-util": "30.2.0" } }, "@jest/schemas": { @@ -8604,9 +8604,9 @@ } }, "@jest/types": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/@jest/types/-/types-30.0.5.tgz", - "integrity": "sha512-aREYa3aku9SSnea4aX6bhKn4bgv3AXkgijoQgbYV3yvbiGt6z+MQ85+6mIhx9DsKW2BuB/cLR/A+tcMThx+KLQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/types/-/types-30.2.0.tgz", + "integrity": "sha512-H9xg1/sfVvyfU7o3zMfBEjQ1gcsdeTMgqHoYdN79tuLqfTtuu7WckRA1R5whDwOzxaZAeMKTYWqP+WCAi0CHsg==", "dev": true, "requires": { "@jest/pattern": "30.0.1", @@ -8646,40 +8646,40 @@ "dev": true }, "jest-message-util": { - "version": "30.1.0", - "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-30.1.0.tgz", - "integrity": "sha512-HizKDGG98cYkWmaLUHChq4iN+oCENohQLb7Z5guBPumYs+/etonmNFlg1Ps6yN9LTPyZn+M+b/9BbnHx3WTMDg==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-30.2.0.tgz", + "integrity": "sha512-y4DKFLZ2y6DxTWD4cDe07RglV88ZiNEdlRfGtqahfbIjfsw1nMCPx49Uev4IA/hWn3sDKyAnSPwoYSsAEdcimw==", "dev": true, "requires": { "@babel/code-frame": "^7.27.1", - "@jest/types": "30.0.5", + "@jest/types": "30.2.0", "@types/stack-utils": "^2.0.3", "chalk": "^4.1.2", "graceful-fs": "^4.2.11", "micromatch": "^4.0.8", - "pretty-format": "30.0.5", + "pretty-format": "30.2.0", "slash": "^3.0.0", "stack-utils": "^2.0.6" } }, "jest-mock": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-30.0.5.tgz", - "integrity": "sha512-Od7TyasAAQX/6S+QCbN6vZoWOMwlTtzzGuxJku1GhGanAjz9y+QsQkpScDmETvdc9aSXyJ/Op4rhpMYBWW91wQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-30.2.0.tgz", + "integrity": "sha512-JNNNl2rj4b5ICpmAcq+WbLH83XswjPbjH4T7yvGzfAGCPh1rw+xVNbtk+FnRslvt9lkCcdn9i1oAoKUuFsOxRw==", "dev": true, "requires": { - "@jest/types": "30.0.5", + "@jest/types": "30.2.0", "@types/node": "*", - "jest-util": "30.0.5" + "jest-util": "30.2.0" } }, "jest-util": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-30.0.5.tgz", - "integrity": "sha512-pvyPWssDZR0FlfMxCBoc0tvM8iUEskaRFALUtGQYzVEAqisAztmy+R8LnU14KT4XA0H/a5HMVTXat1jLne010g==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-30.2.0.tgz", + "integrity": "sha512-QKNsM0o3Xe6ISQU869e+DhG+4CK/48aHYdJZGlFQVTjnbvgpcKyxpzk29fGiO7i/J8VENZ+d2iGnSsvmuHywlA==", "dev": true, "requires": { - "@jest/types": "30.0.5", + "@jest/types": "30.2.0", "@types/node": "*", "chalk": "^4.1.2", "ci-info": "^4.2.0", @@ -8694,9 +8694,9 @@ "dev": true }, "pretty-format": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.0.5.tgz", - "integrity": "sha512-D1tKtYvByrBkFLe2wHJl2bwMJIiT8rW+XA+TiataH79/FszLQMrpGEvzUVkzPau7OCO0Qnrhpe87PqtOAIB8Yw==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.2.0.tgz", + "integrity": "sha512-9uBdv/B4EefsuAL+pWqueZyZS2Ba+LxfFeQ9DN14HU4bN8bhaxKdkpjpB6fs9+pSjIBu+FXQHImEg8j/Lw0+vA==", "dev": true, "requires": { "@jest/schemas": "30.0.5", @@ -11189,42 +11189,42 @@ } }, "jest-environment-jsdom": { - "version": "30.1.2", - "resolved": "https://registry.npmjs.org/jest-environment-jsdom/-/jest-environment-jsdom-30.1.2.tgz", - "integrity": "sha512-LXsfAh5+mDTuXDONGl1ZLYxtJEaS06GOoxJb2arcJTjIfh1adYg8zLD8f6P0df8VmjvCaMrLmc1PgHUI/YUTbg==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-environment-jsdom/-/jest-environment-jsdom-30.2.0.tgz", + "integrity": "sha512-zbBTiqr2Vl78pKp/laGBREYzbZx9ZtqPjOK4++lL4BNDhxRnahg51HtoDrk9/VjIy9IthNEWdKVd7H5bqBhiWQ==", "dev": true, "requires": { - "@jest/environment": "30.1.2", - "@jest/environment-jsdom-abstract": "30.1.2", + "@jest/environment": "30.2.0", + "@jest/environment-jsdom-abstract": "30.2.0", "@types/jsdom": "^21.1.7", "@types/node": "*", "jsdom": "^26.1.0" }, "dependencies": { "@jest/environment": { - "version": "30.1.2", - "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-30.1.2.tgz", - "integrity": "sha512-N8t1Ytw4/mr9uN28OnVf0SYE2dGhaIxOVYcwsf9IInBKjvofAjbFRvedvBBlyTYk2knbJTiEjEJ2PyyDIBnd9w==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-30.2.0.tgz", + "integrity": "sha512-/QPTL7OBJQ5ac09UDRa3EQes4gt1FTEG/8jZ/4v5IVzx+Cv7dLxlVIvfvSVRiiX2drWyXeBjkMSR8hvOWSog5g==", "dev": true, "requires": { - "@jest/fake-timers": "30.1.2", - "@jest/types": "30.0.5", + "@jest/fake-timers": "30.2.0", + "@jest/types": "30.2.0", "@types/node": "*", - "jest-mock": "30.0.5" + "jest-mock": "30.2.0" } }, "@jest/fake-timers": { - "version": "30.1.2", - "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-30.1.2.tgz", - "integrity": "sha512-Beljfv9AYkr9K+ETX9tvV61rJTY706BhBUtiaepQHeEGfe0DbpvUA5Z3fomwc5Xkhns6NWrcFDZn+72fLieUnA==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-30.2.0.tgz", + "integrity": "sha512-HI3tRLjRxAbBy0VO8dqqm7Hb2mIa8d5bg/NJkyQcOk7V118ObQML8RC5luTF/Zsg4474a+gDvhce7eTnP4GhYw==", "dev": true, "requires": { - "@jest/types": "30.0.5", + "@jest/types": "30.2.0", "@sinonjs/fake-timers": "^13.0.0", "@types/node": "*", - "jest-message-util": "30.1.0", - "jest-mock": "30.0.5", - "jest-util": "30.0.5" + "jest-message-util": "30.2.0", + "jest-mock": "30.2.0", + "jest-util": "30.2.0" } }, "@jest/schemas": { @@ -11237,9 +11237,9 @@ } }, "@jest/types": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/@jest/types/-/types-30.0.5.tgz", - "integrity": "sha512-aREYa3aku9SSnea4aX6bhKn4bgv3AXkgijoQgbYV3yvbiGt6z+MQ85+6mIhx9DsKW2BuB/cLR/A+tcMThx+KLQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/types/-/types-30.2.0.tgz", + "integrity": "sha512-H9xg1/sfVvyfU7o3zMfBEjQ1gcsdeTMgqHoYdN79tuLqfTtuu7WckRA1R5whDwOzxaZAeMKTYWqP+WCAi0CHsg==", "dev": true, "requires": { "@jest/pattern": "30.0.1", @@ -11279,40 +11279,40 @@ "dev": true }, "jest-message-util": { - "version": "30.1.0", - "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-30.1.0.tgz", - "integrity": "sha512-HizKDGG98cYkWmaLUHChq4iN+oCENohQLb7Z5guBPumYs+/etonmNFlg1Ps6yN9LTPyZn+M+b/9BbnHx3WTMDg==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-30.2.0.tgz", + "integrity": "sha512-y4DKFLZ2y6DxTWD4cDe07RglV88ZiNEdlRfGtqahfbIjfsw1nMCPx49Uev4IA/hWn3sDKyAnSPwoYSsAEdcimw==", "dev": true, "requires": { "@babel/code-frame": "^7.27.1", - "@jest/types": "30.0.5", + "@jest/types": "30.2.0", "@types/stack-utils": "^2.0.3", "chalk": "^4.1.2", "graceful-fs": "^4.2.11", "micromatch": "^4.0.8", - "pretty-format": "30.0.5", + "pretty-format": "30.2.0", "slash": "^3.0.0", "stack-utils": "^2.0.6" } }, "jest-mock": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-30.0.5.tgz", - "integrity": "sha512-Od7TyasAAQX/6S+QCbN6vZoWOMwlTtzzGuxJku1GhGanAjz9y+QsQkpScDmETvdc9aSXyJ/Op4rhpMYBWW91wQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-30.2.0.tgz", + "integrity": "sha512-JNNNl2rj4b5ICpmAcq+WbLH83XswjPbjH4T7yvGzfAGCPh1rw+xVNbtk+FnRslvt9lkCcdn9i1oAoKUuFsOxRw==", "dev": true, "requires": { - "@jest/types": "30.0.5", + "@jest/types": "30.2.0", "@types/node": "*", - "jest-util": "30.0.5" + "jest-util": "30.2.0" } }, "jest-util": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-30.0.5.tgz", - "integrity": "sha512-pvyPWssDZR0FlfMxCBoc0tvM8iUEskaRFALUtGQYzVEAqisAztmy+R8LnU14KT4XA0H/a5HMVTXat1jLne010g==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-30.2.0.tgz", + "integrity": "sha512-QKNsM0o3Xe6ISQU869e+DhG+4CK/48aHYdJZGlFQVTjnbvgpcKyxpzk29fGiO7i/J8VENZ+d2iGnSsvmuHywlA==", "dev": true, "requires": { - "@jest/types": "30.0.5", + "@jest/types": "30.2.0", "@types/node": "*", "chalk": "^4.1.2", "ci-info": "^4.2.0", @@ -11327,9 +11327,9 @@ "dev": true }, "pretty-format": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.0.5.tgz", - "integrity": "sha512-D1tKtYvByrBkFLe2wHJl2bwMJIiT8rW+XA+TiataH79/FszLQMrpGEvzUVkzPau7OCO0Qnrhpe87PqtOAIB8Yw==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.2.0.tgz", + "integrity": "sha512-9uBdv/B4EefsuAL+pWqueZyZS2Ba+LxfFeQ9DN14HU4bN8bhaxKdkpjpB6fs9+pSjIBu+FXQHImEg8j/Lw0+vA==", "dev": true, "requires": { "@jest/schemas": "30.0.5", @@ -12254,9 +12254,9 @@ } }, "nwsapi": { - "version": "2.2.21", - "resolved": "https://registry.npmjs.org/nwsapi/-/nwsapi-2.2.21.tgz", - "integrity": "sha512-o6nIY3qwiSXl7/LuOU0Dmuctd34Yay0yeuZRLFmDPrrdHpXKFndPj3hM+YEPVHYC5fx2otBx4Ilc/gyYSAUaIA==", + "version": "2.2.22", + "resolved": "https://registry.npmjs.org/nwsapi/-/nwsapi-2.2.22.tgz", + "integrity": "sha512-ujSMe1OWVn55euT1ihwCI1ZcAaAU3nxUiDwfDQldc51ZXaB9m2AyOn6/jh1BLe2t/G8xd6uKG1UBF2aZJeg2SQ==", "dev": true }, "object-deep-merge": { diff --git a/package.json b/package.json index 71eeea50ed675..9c062a8aa073d 100644 --- a/package.json +++ b/package.json @@ -53,7 +53,7 @@ "hjson": "^3.2.2", "husky": "^9.1.7", "jest": "^29.7.0", - "jest-environment-jsdom": "^30.1.2", + "jest-environment-jsdom": "^30.2.0", "js-yaml": "^4.1.0", "lint-staged": "^16.2.3", "lodash.snakecase": "^4.1.1", From 29560fe856c809a6f25f3cf5df9363fd46461944 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 3 Oct 2025 18:50:31 +0300 Subject: [PATCH 124/265] build(deps-dev): bump eslint-plugin-jsdoc from 60.1.1 to 60.5.0 (#4478) * build(deps-dev): bump eslint-plugin-jsdoc from 60.1.1 to 60.5.0 Bumps [eslint-plugin-jsdoc](https://github.com/gajus/eslint-plugin-jsdoc) from 60.1.1 to 60.5.0. - [Release notes](https://github.com/gajus/eslint-plugin-jsdoc/releases) - [Changelog](https://github.com/gajus/eslint-plugin-jsdoc/blob/main/.releaserc) - [Commits](https://github.com/gajus/eslint-plugin-jsdoc/compare/v60.1.1...v60.5.0) --- updated-dependencies: - dependency-name: eslint-plugin-jsdoc dependency-version: 60.5.0 dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] * dev --------- Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- package-lock.json | 88 ++++++++++++++++++++++++++++++----------------- package.json | 2 +- 2 files changed, 57 insertions(+), 33 deletions(-) diff --git a/package-lock.json b/package-lock.json index adb8adb39b397..2ce90430e8fc0 100644 --- a/package-lock.json +++ b/package-lock.json @@ -28,7 +28,7 @@ "color-contrast-checker": "^2.1.0", "eslint": "^9.36.0", "eslint-config-prettier": "^10.1.8", - "eslint-plugin-jsdoc": "^60.1.1", + "eslint-plugin-jsdoc": "^60.7.1", "express": "^5.1.0", "globals": "^16.4.0", "hjson": "^3.2.2", @@ -751,16 +751,16 @@ } }, "node_modules/@es-joy/jsdoccomment": { - "version": "0.58.0", - "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.58.0.tgz", - "integrity": "sha512-smMc5pDht/UVsCD3hhw/a/e/p8m0RdRYiluXToVfd+d4yaQQh7nn9bACjkk6nXJvat7EWPAxuFkMEFfrxeGa3Q==", + "version": "0.65.2", + "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.65.2.tgz", + "integrity": "sha512-/rrj5oayCc7xdoQZ24Tz/+V41IDm+9ILYpTFJOZgav9vfncMNApKR0t/4d1oRXYTcyLZEcGHGOg4xBsD0Doing==", "dev": true, "dependencies": { "@types/estree": "^1.0.8", - "@typescript-eslint/types": "^8.43.0", + "@typescript-eslint/types": "^8.45.0", "comment-parser": "1.4.1", "esquery": "^1.6.0", - "jsdoc-type-pratt-parser": "~5.4.0" + "jsdoc-type-pratt-parser": "~6.1.2" }, "engines": { "node": ">=20.11.0" @@ -2076,9 +2076,9 @@ "dev": true }, "node_modules/@typescript-eslint/types": { - "version": "8.44.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.44.0.tgz", - "integrity": "sha512-ZSl2efn44VsYM0MfDQe68RKzBz75NPgLQXuGypmym6QVOWL5kegTZuZ02xRAT9T+onqvM6T8CdQk0OwYMB6ZvA==", + "version": "8.45.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.45.0.tgz", + "integrity": "sha512-WugXLuOIq67BMgQInIxxnsSyRLFxdkJEJu8r4ngLR56q/4Q5LrbfkFRH27vMTjxEK8Pyz7QfzuZe/G15qQnVRA==", "dev": true, "engines": { "node": "^18.18.0 || ^20.9.0 || >=21.1.0" @@ -3239,18 +3239,19 @@ } }, "node_modules/eslint-plugin-jsdoc": { - "version": "60.1.1", - "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-60.1.1.tgz", - "integrity": "sha512-eEyINuG4pZtVFplyCPTeUif/+C14zh4fmm5IrDE5YY2Zc3IYKpdGjeaWahJcxWDDwjTVjWCw1zL9XbX3Fb0Wjg==", + "version": "60.7.1", + "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-60.7.1.tgz", + "integrity": "sha512-JCLls7B3Tlb2YS5M6+aZqxb0gnEkr+H9/qMm5HSzynlvq3wqbxS7+4RS954EGuLrITfbaB6nmf3FyZAhOeCUEg==", "dev": true, "dependencies": { - "@es-joy/jsdoccomment": "~0.58.0", + "@es-joy/jsdoccomment": "~0.65.2", "are-docs-informative": "^0.0.2", "comment-parser": "1.4.1", "debug": "^4.4.3", "escape-string-regexp": "^4.0.0", "espree": "^10.4.0", "esquery": "^1.6.0", + "html-entities": "^2.6.0", "object-deep-merge": "^1.0.5", "parse-imports-exports": "^0.2.4", "semver": "^7.7.2", @@ -4070,6 +4071,22 @@ "node": ">=18" } }, + "node_modules/html-entities": { + "version": "2.6.0", + "resolved": "https://registry.npmjs.org/html-entities/-/html-entities-2.6.0.tgz", + "integrity": "sha512-kig+rMn/QOVRvr7c86gQ8lWXq+Hkv6CbAH1hLu+RG338StTpE8Z0b44SDVaqVu7HGKf27frdmUYEs9hTUX/cLQ==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/mdevils" + }, + { + "type": "patreon", + "url": "https://patreon.com/mdevils" + } + ] + }, "node_modules/html-escaper": { "version": "2.0.2", "resolved": "https://registry.npmjs.org/html-escaper/-/html-escaper-2.0.2.tgz", @@ -5554,12 +5571,12 @@ } }, "node_modules/jsdoc-type-pratt-parser": { - "version": "5.4.0", - "resolved": "https://registry.npmjs.org/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-5.4.0.tgz", - "integrity": "sha512-F9GQ+F1ZU6qvSrZV8fNFpjDNf614YzR2eF6S0+XbDjAcUI28FSoXnYZFjQmb1kFx3rrJb5PnxUH3/Yti6fcM+g==", + "version": "6.1.2", + "resolved": "https://registry.npmjs.org/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-6.1.2.tgz", + "integrity": "sha512-ruy+JcplsWkqnYq1m/qokaErhEURwf/vhdTzlPNpei7RJabVWxPxGWoCPSCP0sbsz03d590hTkjLdXjyMxH0iA==", "dev": true, "engines": { - "node": ">=12.0.0" + "node": ">=20.0.0" } }, "node_modules/jsdom": { @@ -8257,16 +8274,16 @@ "dev": true }, "@es-joy/jsdoccomment": { - "version": "0.58.0", - "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.58.0.tgz", - "integrity": "sha512-smMc5pDht/UVsCD3hhw/a/e/p8m0RdRYiluXToVfd+d4yaQQh7nn9bACjkk6nXJvat7EWPAxuFkMEFfrxeGa3Q==", + "version": "0.65.2", + "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.65.2.tgz", + "integrity": "sha512-/rrj5oayCc7xdoQZ24Tz/+V41IDm+9ILYpTFJOZgav9vfncMNApKR0t/4d1oRXYTcyLZEcGHGOg4xBsD0Doing==", "dev": true, "requires": { "@types/estree": "^1.0.8", - "@typescript-eslint/types": "^8.43.0", + "@typescript-eslint/types": "^8.45.0", "comment-parser": "1.4.1", "esquery": "^1.6.0", - "jsdoc-type-pratt-parser": "~5.4.0" + "jsdoc-type-pratt-parser": "~6.1.2" } }, "@eslint-community/eslint-utils": { @@ -9305,9 +9322,9 @@ "dev": true }, "@typescript-eslint/types": { - "version": "8.44.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.44.0.tgz", - "integrity": "sha512-ZSl2efn44VsYM0MfDQe68RKzBz75NPgLQXuGypmym6QVOWL5kegTZuZ02xRAT9T+onqvM6T8CdQk0OwYMB6ZvA==", + "version": "8.45.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.45.0.tgz", + "integrity": "sha512-WugXLuOIq67BMgQInIxxnsSyRLFxdkJEJu8r4ngLR56q/4Q5LrbfkFRH27vMTjxEK8Pyz7QfzuZe/G15qQnVRA==", "dev": true }, "@uppercod/css-to-object": { @@ -10202,18 +10219,19 @@ "requires": {} }, "eslint-plugin-jsdoc": { - "version": "60.1.1", - "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-60.1.1.tgz", - "integrity": "sha512-eEyINuG4pZtVFplyCPTeUif/+C14zh4fmm5IrDE5YY2Zc3IYKpdGjeaWahJcxWDDwjTVjWCw1zL9XbX3Fb0Wjg==", + "version": "60.7.1", + "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-60.7.1.tgz", + "integrity": "sha512-JCLls7B3Tlb2YS5M6+aZqxb0gnEkr+H9/qMm5HSzynlvq3wqbxS7+4RS954EGuLrITfbaB6nmf3FyZAhOeCUEg==", "dev": true, "requires": { - "@es-joy/jsdoccomment": "~0.58.0", + "@es-joy/jsdoccomment": "~0.65.2", "are-docs-informative": "^0.0.2", "comment-parser": "1.4.1", "debug": "^4.4.3", "escape-string-regexp": "^4.0.0", "espree": "^10.4.0", "esquery": "^1.6.0", + "html-entities": "^2.6.0", "object-deep-merge": "^1.0.5", "parse-imports-exports": "^0.2.4", "semver": "^7.7.2", @@ -10689,6 +10707,12 @@ "whatwg-encoding": "^3.1.1" } }, + "html-entities": { + "version": "2.6.0", + "resolved": "https://registry.npmjs.org/html-entities/-/html-entities-2.6.0.tgz", + "integrity": "sha512-kig+rMn/QOVRvr7c86gQ8lWXq+Hkv6CbAH1hLu+RG338StTpE8Z0b44SDVaqVu7HGKf27frdmUYEs9hTUX/cLQ==", + "dev": true + }, "html-escaper": { "version": "2.0.2", "resolved": "https://registry.npmjs.org/html-escaper/-/html-escaper-2.0.2.tgz", @@ -11800,9 +11824,9 @@ } }, "jsdoc-type-pratt-parser": { - "version": "5.4.0", - "resolved": "https://registry.npmjs.org/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-5.4.0.tgz", - "integrity": "sha512-F9GQ+F1ZU6qvSrZV8fNFpjDNf614YzR2eF6S0+XbDjAcUI28FSoXnYZFjQmb1kFx3rrJb5PnxUH3/Yti6fcM+g==", + "version": "6.1.2", + "resolved": "https://registry.npmjs.org/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-6.1.2.tgz", + "integrity": "sha512-ruy+JcplsWkqnYq1m/qokaErhEURwf/vhdTzlPNpei7RJabVWxPxGWoCPSCP0sbsz03d590hTkjLdXjyMxH0iA==", "dev": true }, "jsdom": { diff --git a/package.json b/package.json index 9c062a8aa073d..19d7b9b2824ad 100644 --- a/package.json +++ b/package.json @@ -47,7 +47,7 @@ "color-contrast-checker": "^2.1.0", "eslint": "^9.36.0", "eslint-config-prettier": "^10.1.8", - "eslint-plugin-jsdoc": "^60.1.1", + "eslint-plugin-jsdoc": "^60.5.0", "express": "^5.1.0", "globals": "^16.4.0", "hjson": "^3.2.2", From a8dd06537f5ed77c39a41b5be5427a65940b0ce5 Mon Sep 17 00:00:00 2001 From: "github-actions[bot]" <41898282+github-actions[bot]@users.noreply.github.com> Date: Fri, 3 Oct 2025 18:55:41 +0300 Subject: [PATCH 125/265] refactor: update languages JSON (#4487) Co-authored-by: qwerty541 <53787217+qwerty541@users.noreply.github.com> Co-authored-by: Alexandr --- src/common/languageColors.json | 3 +++ 1 file changed, 3 insertions(+) diff --git a/src/common/languageColors.json b/src/common/languageColors.json index 9d25c8909904d..28d778ff591f1 100644 --- a/src/common/languageColors.json +++ b/src/common/languageColors.json @@ -64,6 +64,7 @@ "BrighterScript": "#66AABB", "Brightscript": "#662D91", "Browserslist": "#ffd539", + "Bru": "#F4AA41", "BuildStream": "#006bff", "C": "#555555", "C#": "#178600", @@ -166,6 +167,7 @@ "Faust": "#c37240", "Fennel": "#fff3d7", "Filebench WML": "#F6B900", + "Flix": "#d44a45", "Fluent": "#ffcc33", "Forth": "#341708", "Fortran": "#4d41b1", @@ -292,6 +294,7 @@ "KiCad Layout": "#2f4aab", "KiCad Legacy Layout": "#2f4aab", "KiCad Schematic": "#2f4aab", + "KoLMafia ASH": "#B9D9B9", "Koka": "#215166", "Kotlin": "#A97BFF", "LFE": "#4C3023", From bfa895d2e76f9e36911b97326c7e792e71edc0fd Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov Date: Sat, 4 Oct 2025 18:29:04 +0300 Subject: [PATCH 126/265] docs(contributing): add notice about hacktoberfest (#4506) Co-authored-by: Alexandr --- CONTRIBUTING.md | 3 +++ 1 file changed, 3 insertions(+) diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index f607da7b512c8..a593078c58d47 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -1,5 +1,8 @@ # Contributing to [github-readme-stats](https://github.com/anuraghazra/github-readme-stats) +> [!IMPORTANT]\ +> Please note that we are NOT participating in Hacktoberfest this year. Unfortunately, the only person with sufficient access rights to remove the repository label is currently unreachable, so we are notifying you here. As a small team, we cannot handle the increased volume of PRs and issues that the event brings. We appreciate your understanding. + We love your input! We want to make contributing to this project as easy and transparent as possible, whether it's: - Reporting [an issue](https://github.com/anuraghazra/github-readme-stats/issues/new?assignees=&labels=bug&template=bug_report.yml). From 3ce1fd74ae40f33b26bea5739edab7066400f902 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov Date: Sat, 4 Oct 2025 18:30:17 +0300 Subject: [PATCH 127/265] docs(readme): update string about express inside the section about deploy on other platforms (#4507) Co-authored-by: Alexandr --- readme.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/readme.md b/readme.md index 12256703b0a3d..7bc3e629c12c4 100644 --- a/readme.md +++ b/readme.md @@ -869,7 +869,7 @@ Since the GitHub API only allows 5k requests per hour, my `https://github-readme :hammer_and_wrench: Step-by-step guide for deploying on other platforms 1. Fork or clone this repo as per your needs -2. Add `express` to the dependencies section of `package.json` +2. Move `express` from the devDependencies to the dependencies section of `package.json` 3. Run `npm i` if needed (initial setup) 4. Run `node express.js` to start the server, or set the entry point to `express.js` in `package.json` if you're deploying on a managed service From ba9406e84c4c0a1c9d7aafddfbf5f408cebb170e Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov Date: Sat, 4 Oct 2025 19:01:58 +0300 Subject: [PATCH 128/265] chore: add comment with issue link to the retryer rate limit detection logic (#4508) Co-authored-by: Alexandr --- src/common/retryer.js | 1 + 1 file changed, 1 insertion(+) diff --git a/src/common/retryer.js b/src/common/retryer.js index 1c3adc9587117..090865ed00c6d 100644 --- a/src/common/retryer.js +++ b/src/common/retryer.js @@ -42,6 +42,7 @@ const retryer = async (fetcher, variables, retries = 0) => { ); // react on both type and message-based rate-limit signals. + // https://github.com/anuraghazra/github-readme-stats/issues/4425 const errors = response?.data?.errors; const errorType = errors?.[0]?.type; const errorMsg = errors?.[0]?.message || ""; From 35485384e04f414ef559b4c376233137ca4fa6e5 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov Date: Sat, 4 Oct 2025 19:02:39 +0300 Subject: [PATCH 129/265] build(deps): remove unused upgrade dependency (#4509) Co-authored-by: Alexandr --- package-lock.json | 13 +------------ package.json | 1 - 2 files changed, 1 insertion(+), 13 deletions(-) diff --git a/package-lock.json b/package-lock.json index 2ce90430e8fc0..df42504c40b74 100644 --- a/package-lock.json +++ b/package-lock.json @@ -13,7 +13,6 @@ "dotenv": "^17.2.2", "emoji-name-map": "^2.0.3", "github-username-regex": "^1.0.0", - "upgrade": "^1.1.0", "word-wrap": "^1.2.5" }, "devDependencies": { @@ -28,7 +27,7 @@ "color-contrast-checker": "^2.1.0", "eslint": "^9.36.0", "eslint-config-prettier": "^10.1.8", - "eslint-plugin-jsdoc": "^60.7.1", + "eslint-plugin-jsdoc": "^60.5.0", "express": "^5.1.0", "globals": "^16.4.0", "hjson": "^3.2.2", @@ -7505,11 +7504,6 @@ "browserslist": ">= 4.21.0" } }, - "node_modules/upgrade": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/upgrade/-/upgrade-1.1.0.tgz", - "integrity": "sha512-NtkVvqVCqsJo5U3mYRum2Tw6uCltOxfIJ/AfTZeTmw6U39IB5X23xF+kRZ9aiPaORqeiQQ7Q209/ibhOvxzwHA==" - }, "node_modules/uri-js": { "version": "4.4.1", "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", @@ -13180,11 +13174,6 @@ "picocolors": "^1.0.0" } }, - "upgrade": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/upgrade/-/upgrade-1.1.0.tgz", - "integrity": "sha512-NtkVvqVCqsJo5U3mYRum2Tw6uCltOxfIJ/AfTZeTmw6U39IB5X23xF+kRZ9aiPaORqeiQQ7Q209/ibhOvxzwHA==" - }, "uri-js": { "version": "4.4.1", "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", diff --git a/package.json b/package.json index 19d7b9b2824ad..c8d3982b82a32 100644 --- a/package.json +++ b/package.json @@ -65,7 +65,6 @@ "dotenv": "^17.2.2", "emoji-name-map": "^2.0.3", "github-username-regex": "^1.0.0", - "upgrade": "^1.1.0", "word-wrap": "^1.2.5" }, "lint-staged": { From 9f3223fb35aaec55c142749cbcd6e071cd281402 Mon Sep 17 00:00:00 2001 From: Ericode254 Date: Sat, 4 Oct 2025 21:19:19 +0300 Subject: [PATCH 130/265] feat: add Swahili translations (#3911) * Update translations.js added the swahili translation * dev * docs * Update src/translations.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update src/translations.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --------- Co-authored-by: Alexandr Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --- readme.md | 3 ++- src/translations.js | 22 ++++++++++++++++++++++ 2 files changed, 24 insertions(+), 1 deletion(-) diff --git a/readme.md b/readme.md index 7bc3e629c12c4..11d8702593c27 100644 --- a/readme.md +++ b/readme.md @@ -339,18 +339,19 @@ Here is a list of all available locales: | `fa` | Persian (Farsi) | | `pl` | Polish | | `pt-br` | Portuguese (Brazil) | +| `pt-pt` | Portuguese (Portugal) | | Code | Locale | | --- | --- | -| `pt-pt` | Portuguese (Portugal) | | `ro` | Romanian | | `ru` | Russian | | `sr` | Serbian (Cyrillic) | | `sr-latn` | Serbian (Latin) | | `sk` | Slovak | | `es` | Spanish | +| `sw` | Swahili | | `se` | Swedish | | `th` | Thai | | `tr` | Turkish | diff --git a/src/translations.js b/src/translations.js index 92bb5b0ad4196..cb479bf5eb2e7 100644 --- a/src/translations.js +++ b/src/translations.js @@ -24,6 +24,7 @@ const statCardLocales = ({ name, apostrophe }) => { "zh-tw": `${encodedName} 的 GitHub 統計資料`, cs: `GitHub statistiky uživatele ${encodedName}`, de: `${encodedName + apostrophe} GitHub-Statistiken`, + sw: `GitHub Stats za ${encodedName}`, ur: `${encodedName} کے گٹ ہب کے اعداد و شمار`, bg: `GitHub статистика на потребител ${encodedName}`, bn: `${encodedName} এর GitHub পরিসংখ্যান`, @@ -69,6 +70,7 @@ const statCardLocales = ({ name, apostrophe }) => { "zh-tw": `${encodedName} 的 GitHub 統計資料`, cs: `GitHub statistiky uživatele ${encodedName}`, de: `${encodedName + apostrophe} GitHub-Statistiken`, + sw: `GitHub Rank ya ${encodedName}`, ur: `${encodedName} کی گٹ ہب رینک`, bg: `GitHub ранг на ${encodedName}`, bn: `${encodedName} এর GitHub পরিসংখ্যান`, @@ -114,6 +116,7 @@ const statCardLocales = ({ name, apostrophe }) => { "zh-tw": "得標星星數量(Star)", cs: "Celkem hvězd", de: "Insgesamt erhaltene Sterne", + sw: "Medali(stars) ulizojishindia", ur: "کل ستارے حاصل کیے", bg: "Получени звезди", bn: "সর্বমোট Star", @@ -159,6 +162,7 @@ const statCardLocales = ({ name, apostrophe }) => { "zh-tw": "累計提交數量(Commit)", cs: "Celkem commitů", de: "Anzahl Commits", + sw: "Matendo(Commits) yako yote", ur: "کل کمٹ", bg: "Общо ангажименти", bn: "সর্বমোট Commit", @@ -204,6 +208,7 @@ const statCardLocales = ({ name, apostrophe }) => { "zh-tw": "拉取請求數量(PR)", cs: "Celkem PRs", de: "PRs Insgesamt", + sw: "PRs Zote", ur: "کل پی آرز", bg: "Заявки за изтегляния", bn: "সর্বমোট PR", @@ -249,6 +254,7 @@ const statCardLocales = ({ name, apostrophe }) => { "zh-tw": "提出問題數量(Issue)", cs: "Celkem problémů", de: "Anzahl Issues", + sw: "Masuala Ibuka", ur: "کل مسائل", bg: "Брой въпроси", bn: "সর্বমোট Issue", @@ -294,6 +300,7 @@ const statCardLocales = ({ name, apostrophe }) => { "zh-tw": "參與項目數量(去年)", cs: "Přispěl k (minulý rok)", de: "Beigetragen zu (letztes Jahr)", + sw: "Idadi ya michango (mwaka mzima)", ur: "پچھلے سال میں تعاون کیا", bg: "Приноси (за изминалата година)", bn: "অবদান (গত বছর)", @@ -339,6 +346,7 @@ const statCardLocales = ({ name, apostrophe }) => { "zh-tw": "審核的 PR 總計", cs: "Celkový počet PR", de: "Insgesamt überprüfte PRs", + sw: "Idadi ya PRs zilizopitiliwa upya", ur: "کل پی آرز کا جائزہ لیا", bg: "Разгледани заявки за изтегляне", bn: "সর্বমোট পুনরালোচনা করা PR", @@ -384,6 +392,7 @@ const statCardLocales = ({ name, apostrophe }) => { "zh-tw": "發起的討論總數", cs: "Celkem zahájených diskusí", de: "Gesamt gestartete Diskussionen", + sw: "Idadi ya majadiliano yaliyoanzishwa", ur: "کل مباحثے شروع کیے", bg: "Започнати дискусии", bn: "সর্বমোট আলোচনা শুরু", @@ -429,6 +438,7 @@ const statCardLocales = ({ name, apostrophe }) => { "zh-tw": "回覆討論總計", cs: "Celkem zodpovězených diskusí", de: "Gesamt beantwortete Diskussionen", + sw: "Idadi ya majadiliano yaliyojibiwa", ur: "کل مباحثے جواب دیے", bg: "Отговорени дискусии", bn: "সর্বমোট আলোচনা উত্তর", @@ -474,6 +484,7 @@ const statCardLocales = ({ name, apostrophe }) => { "zh-tw": "合併的 PR 總計", cs: "Celkem sloučených PR", de: "Insgesamt zusammengeführte PRs", + sw: "Idadi ya PRs zilizounganishwa", ur: "کل پی آرز ضم کیے", bg: "Сляти заявки за изтегляния", bn: "সর্বমোট PR একত্রীকৃত", @@ -518,6 +529,7 @@ const statCardLocales = ({ name, apostrophe }) => { "zh-tw": "合併的 PR 百分比", cs: "Sloučené PRs v procentech", de: "Zusammengeführte PRs in Prozent", + sw: "Asilimia ya PRs zilizounganishwa", ur: "ضم کیے گئے پی آرز کی شرح", bg: "Процент сляти заявки за изтегляния", bn: "PR একত্রীকরণের শতাংশ", @@ -568,6 +580,7 @@ const repoCardLocales = { "zh-tw": "模板", cs: "Šablona", de: "Vorlage", + sw: "Kigezo", ur: "سانچہ", es: "Plantilla", fa: "الگو", @@ -613,6 +626,7 @@ const repoCardLocales = { "zh-tw": "已封存", cs: "Archivováno", de: "Archiviert", + sw: "Hifadhiwa kwenye kumbukumbu", ur: "محفوظ شدہ", es: "Archivados", fa: "بایگانی‌شده", @@ -661,6 +675,7 @@ const langCardLocales = { de: "Meist verwendete Sprachen", bg: "Най-използвани езици", bn: "সর্বাধিক ব্যবহৃত ভাষা সমূহ", + sw: "Lugha zilizotumika zaidi", ur: "سب سے زیادہ استعمال شدہ زبانیں", es: "Lenguajes más usados", fa: "زبان‌های پرکاربرد", @@ -706,6 +721,7 @@ const langCardLocales = { de: "Keine Sprachdaten.", bg: "Няма данни за езици", bn: "কোন ভাষার ডেটা নেই।", + sw: "Hakuna kumbukumbu ya lugha zozote", ur: "کوئی زبان کا ڈیٹا نہیں۔", es: "Sin datos de idiomas.", fa: "داده‌ای برای زبان‌ها وجود ندارد.", @@ -752,6 +768,7 @@ const wakatimeCardLocales = { "zh-tw": "WakaTime 周統計", cs: "Statistiky WakaTime", de: "WakaTime Status", + sw: "Takwimu ya WakaTime", ur: "وکاٹائم کے اعداد و شمار", bg: "WakaTime статистика", bn: "WakaTime স্ট্যাটাস", @@ -797,6 +814,7 @@ const wakatimeCardLocales = { "zh-tw": "去年", cs: "Minulý rok", de: "Letztes Jahr", + sw: "Mwaka uliopita", ur: "پچھلا سال", bg: "миналата год.", bn: "গত বছর", @@ -842,6 +860,7 @@ const wakatimeCardLocales = { "zh-tw": "最近 7 天", cs: "Posledních 7 dní", de: "Letzte 7 Tage", + sw: "Siku 7 zilizopita", ur: "پچھلے 7 دن", bg: "последните 7 дни", bn: "গত ৭ দিন", @@ -887,6 +906,7 @@ const wakatimeCardLocales = { "zh-tw": "WakaTime 使用者個人資料未公開", cs: "Profil uživatele WakaTime není veřejný", de: "WakaTime-Benutzerprofil nicht öffentlich", + sw: "Maelezo ya mtumizi wa WakaTime si ya watu wote(umma)", ur: "وکاٹائم صارف کا پروفائل عوامی نہیں", bg: "Потребителски профил в WakaTime не е общодостъпен", bn: "WakaTime ব্যবহারকারীর প্রোফাইল প্রকাশ্য নয়", @@ -932,6 +952,7 @@ const wakatimeCardLocales = { "zh-tw": "使用者不公開分享詳細的程式碼統計資訊", cs: "Uživatel nesdílí podrobné statistiky kódu", de: "Benutzer teilt keine detaillierten Code-Statistiken", + sw: "Mtumizi hagawi kila kitu au takwimu na umma", ur: "صارف عوامی طور پر تفصیلی کوڈ کے اعداد و شمار شیئر نہیں کرتا", bg: "Потребителят не споделя подробна статистика за код", bn: "ব্যবহারকারী বিস্তারিত কোড পরিসংখ্যান প্রকাশ করেন না", @@ -979,6 +1000,7 @@ const wakatimeCardLocales = { "zh-tw": "本周沒有編程活動", cs: "Tento týden žádná aktivita v kódování", de: "Keine Aktivitäten in dieser Woche", + sw: "Hakuna matukio yoyote ya kusimba wiki hii", ur: "اس ہفتے کوئی کوڈنگ سرگرمی نہیں", bg: "Няма активност при кодирането тази седмица", bn: "এই সপ্তাহে কোন কোডিং অ্যাক্টিভিটি নেই", From 7b7f78127fd0e4c83542f3acdd815fed3ba16a60 Mon Sep 17 00:00:00 2001 From: Dhia Shams Date: Sun, 5 Oct 2025 00:02:50 +0530 Subject: [PATCH 131/265] feat: add Tamil translations (#4504) * Corrections in malayalam translation * Added tamil translations * Added tamil to readme file * review --------- Co-authored-by: Alexandr --- readme.md | 1 + src/translations.js | 22 ++++++++++++++++++++++ 2 files changed, 23 insertions(+) diff --git a/readme.md b/readme.md index 11d8702593c27..565d7f230c7f5 100644 --- a/readme.md +++ b/readme.md @@ -353,6 +353,7 @@ Here is a list of all available locales: | `es` | Spanish | | `sw` | Swahili | | `se` | Swedish | +| `ta` | Tamil | | `th` | Thai | | `tr` | Turkish | | `uk-ua` | Ukrainian | diff --git a/src/translations.js b/src/translations.js index cb479bf5eb2e7..da101b0cfc7ed 100644 --- a/src/translations.js +++ b/src/translations.js @@ -48,6 +48,7 @@ const statCardLocales = ({ name, apostrophe }) => { id: `Statistik GitHub ${encodedName}`, ml: `${encodedName}'${apostrophe} ഗിറ്റ്ഹബ് സ്ഥിതിവിവരക്കണക്കുകൾ`, my: `Statistik GitHub ${encodedName}`, + ta: `${encodedName} கிட்ஹப் புள்ளிவிவரங்கள்`, sk: `GitHub štatistiky používateľa ${encodedName}`, tr: `${encodedName} Hesabının GitHub İstatistikleri`, pl: `Statystyki GitHub użytkownika ${encodedName}`, @@ -94,6 +95,7 @@ const statCardLocales = ({ name, apostrophe }) => { id: `Statistik GitHub ${encodedName}`, ml: `${encodedName}'${apostrophe} ഗിറ്റ്ഹബ് സ്ഥിതിവിവരക്കണക്കുകൾ`, my: `Statistik GitHub ${encodedName}`, + ta: `${encodedName} கிட்ஹப் தரவரிசை`, sk: `GitHub štatistiky používateľa ${encodedName}`, tr: `${encodedName} Hesabının GitHub Yıldızları`, pl: `Statystyki GitHub użytkownika ${encodedName}`, @@ -140,6 +142,7 @@ const statCardLocales = ({ name, apostrophe }) => { id: "Total Bintang", ml: "ആകെ നക്ഷത്രങ്ങൾ", my: "Jumlah Bintang", + ta: "சம்பாதித்த மொத்த நட்சத்திரங்கள்", sk: "Hviezdy", tr: "Toplam Yıldız", pl: "Liczba otrzymanych gwiazdek", @@ -186,6 +189,7 @@ const statCardLocales = ({ name, apostrophe }) => { id: "Total Komitmen", ml: "ആകെ കമ്മിറ്റുകൾ", my: "Jumlah Komitmen", + ta: `மொத்த கமிட்கள்`, sk: "Všetky commity", tr: "Toplam Commit", pl: "Wszystkie commity", @@ -232,6 +236,7 @@ const statCardLocales = ({ name, apostrophe }) => { id: "Total Permintaan Tarik", ml: "ആകെ പുൾ അഭ്യർത്ഥനകൾ", my: "Jumlah PR", + ta: `மொத்த இழுக்கும் கோரிக்கைகள்`, sk: "Všetky PR", tr: "Toplam PR", pl: "Wszystkie PR-y", @@ -278,6 +283,7 @@ const statCardLocales = ({ name, apostrophe }) => { id: "Total Masalah Dilaporkan", ml: "ആകെ പ്രശ്നങ്ങൾ", my: "Jumlah Isu Dilaporkan", + ta: `மொத்த சிக்கல்கள்`, sk: "Všetky problémy", tr: "Toplam Hata", pl: "Wszystkie problemy", @@ -324,6 +330,7 @@ const statCardLocales = ({ name, apostrophe }) => { id: "Berkontribusi ke (tahun lalu)", ml: "(കഴിഞ്ഞ വർഷത്തെ)ആകെ സംഭാവനകൾ ", my: "Menyumbang kepada (tahun lepas)", + ta: "(கடந்த ஆண்டு) பங்களித்தது", sk: "Účasti (minulý rok)", tr: "Katkı Verildi (geçen yıl)", pl: "Kontrybucje (w zeszłym roku)", @@ -370,6 +377,7 @@ const statCardLocales = ({ name, apostrophe }) => { id: "Total PR yang Direview", ml: "ആകെ പുൾ അവലോകനങ്ങൾ", my: "Jumlah PR Dikaji Semula", + ta: "மதிப்பாய்வு செய்யப்பட்ட மொத்த இழுத்தல் கோரிக்கைகள்", sk: "Celkový počet PR", tr: "İncelenen toplam PR", pl: "Łącznie sprawdzonych PR", @@ -416,6 +424,7 @@ const statCardLocales = ({ name, apostrophe }) => { id: "Total Diskusi Dimulai", ml: "ആരംഭിച്ച ആലോചനകൾ", my: "Jumlah Perbincangan Bermula", + ta: "மொத்த விவாதங்கள் தொடங்கின", sk: "Celkový počet začatých diskusií", tr: "Başlatılan Toplam Tartışma", pl: "Łącznie rozpoczętych dyskusji", @@ -462,6 +471,7 @@ const statCardLocales = ({ name, apostrophe }) => { id: "Total Diskusi Dibalas", ml: "ഉത്തരം നൽകിയ ആലോചനകൾ", my: "Jumlah Perbincangan Dijawab", + ta: "பதிலளிக்கப்பட்ட மொத்த விவாதங்கள்", sk: "Celkový počet zodpovedaných diskusií", tr: "Toplam Cevaplanan Tartışma", pl: "Łącznie odpowiedzianych dyskusji", @@ -507,6 +517,7 @@ const statCardLocales = ({ name, apostrophe }) => { "uk-ua": "Всього об'єднаних pull request`iв", id: "Total PR Digabungkan", my: "Jumlah PR Digabungkan", + ta: "இணைக்கப்பட்ட மொத்த PRகள்", sk: "Celkový počet zlúčených PR", tr: "Toplam Birleştirilmiş PR", pl: "Łącznie połączonych PR", @@ -552,6 +563,7 @@ const statCardLocales = ({ name, apostrophe }) => { "uk-ua": "Відсоток об'єднаних pull request`iв", id: "Persentase PR Digabungkan", my: "Peratus PR Digabungkan", + ta: "இணைக்கப்பட்ட PRகள் சதவீதம்", sk: "Percento zlúčených PR", tr: "Birleştirilmiş PR Yüzdesi", pl: "Procent połączonych PR", @@ -602,6 +614,7 @@ const repoCardLocales = { id: "Pola", ml: "ടെംപ്ലേറ്റ്", my: "Templat", + ta: `டெம்ப்ளேட்`, sk: "Šablóna", tr: "Şablon", pl: "Szablony", @@ -648,6 +661,7 @@ const repoCardLocales = { id: "Arsip", ml: "ശേഖരിച്ചത്", my: "Arkib", + ta: `காப்பகப்படுத்தப்பட்டது`, sk: "Archivované", tr: "Arşiv", pl: "Zarchiwizowano", @@ -697,6 +711,7 @@ const langCardLocales = { id: "Bahasa Yang Paling Banyak Digunakan", ml: "കൂടുതൽ ഉപയോഗിച്ച ഭാഷകൾ", my: "Bahasa Paling Digunakan", + ta: `அதிகம் பயன்படுத்தப்படும் மொழிகள்`, sk: "Najviac používané jazyky", tr: "En Çok Kullanılan Diller", pl: "Najczęściej używane języki", @@ -743,6 +758,7 @@ const langCardLocales = { id: "Tidak ada data bahasa.", ml: "ഭാഷാ ഡാറ്റയില്ല.", my: "Tiada data bahasa.", + ta: `மொழி தரவு இல்லை.`, sk: "Žiadne údaje o jazykoch.", tr: "Dil verisi yok.", pl: "Brak danych dotyczących języków.", @@ -792,6 +808,7 @@ const wakatimeCardLocales = { id: "Status WakaTime", ml: "വാകടൈം സ്ഥിതിവിവരക്കണക്കുകൾ", my: "Statistik WakaTime", + ta: `WakaTime புள்ளிவிவரங்கள்`, sk: "WakaTime štatistika", tr: "WakaTime İstatistikler", pl: "Statystyki WakaTime", @@ -838,6 +855,7 @@ const wakatimeCardLocales = { id: "Tahun lalu", ml: "കഴിഞ്ഞ വർഷം", my: "Tahun lepas", + ta: `கடந்த ஆண்டு`, sk: "Minulý rok", tr: "Geçen yıl", pl: "W zeszłym roku", @@ -884,6 +902,7 @@ const wakatimeCardLocales = { id: "7 hari terakhir", ml: "കഴിഞ്ഞ 7 ദിവസം", my: "7 hari lepas", + ta: `கடந்த 7 நாட்கள்`, sk: "Posledných 7 dní", tr: "Son 7 gün", pl: "Ostatnie 7 dni", @@ -930,6 +949,7 @@ const wakatimeCardLocales = { id: "Profil pengguna WakaTime tidak publik", ml: "WakaTime ഉപയോക്തൃ പ്രൊഫൈൽ പൊതുവായി പ്രസിദ്ധീകരിക്കപ്പെടാത്തതാണ്", my: "Profil pengguna WakaTime tidak awam", + ta: `WakaTime பயனர் சுயவிவரம் பொதுவில் இல்லை.`, sk: "Profil používateľa WakaTime nie je verejný", tr: "WakaTime kullanıcı profili herkese açık değil", pl: "Profil użytkownika WakaTime nie jest publiczny", @@ -978,6 +998,7 @@ const wakatimeCardLocales = { id: "Pengguna tidak membagikan statistik kode terperinci secara publik", ml: "ഉപയോക്താവ് പൊതുവായി വിശദീകരിച്ച കോഡ് സ്റ്റാറ്റിസ്റ്റിക്സ് പങ്കിടുന്നില്ല", my: "Pengguna tidak berkongsi statistik kod terperinci secara awam", + ta: `பயனர் விரிவான குறியீட்டு புள்ளிவிவரங்களைப் பொதுவில் பகிர்வதில்லை.`, sk: "Používateľ neposkytuje verejne podrobné štatistiky kódu", tr: "Kullanıcı ayrıntılı kod istatistiklerini herkese açık olarak paylaşmıyor", pl: "Użytkownik nie udostępnia publicznie szczegółowych statystyk kodu", @@ -1024,6 +1045,7 @@ const wakatimeCardLocales = { id: "Tidak ada aktivitas perkodingan minggu ini", ml: "ഈ ആഴ്ച കോഡിംഗ് പ്രവർത്തനങ്ങളൊന്നുമില്ല", my: "Tiada aktiviti pengekodan minggu ini", + ta: `இந்த வாரம் குறியீட்டு செயல்பாடு இல்லை.`, sk: "Žiadna kódovacia aktivita tento týždeň", tr: "Bu hafta herhangi bir kod yazma aktivitesi olmadı", pl: "Brak aktywności w tym tygodniu", From 2641d6933167863aa4f07993b77e0143700dc593 Mon Sep 17 00:00:00 2001 From: arjav007 <111127105+arjav007@users.noreply.github.com> Date: Sun, 5 Oct 2025 00:19:18 +0530 Subject: [PATCH 132/265] feat: add Sanskrit translations (#4503) * feat: add Sanskrit translations * revert * revert * docs --------- Co-authored-by: Alexandr --- readme.md | 5 +++-- src/translations.js | 22 ++++++++++++++++++++++ 2 files changed, 25 insertions(+), 2 deletions(-) diff --git a/readme.md b/readme.md index 565d7f230c7f5..bd7a90ad034c5 100644 --- a/readme.md +++ b/readme.md @@ -320,12 +320,12 @@ Here is a list of all available locales: | `fi` | Finnish | | `fr` | French | | `de` | German | +| `el` | Greek | | Code | Locale | | --- | --- | -| `el` | Greek | | `he` | Hebrew | | `hi` | Hindi | | `hu` | Hungarian | @@ -340,13 +340,14 @@ Here is a list of all available locales: | `pl` | Polish | | `pt-br` | Portuguese (Brazil) | | `pt-pt` | Portuguese (Portugal) | +| `ro` | Romanian | | Code | Locale | | --- | --- | -| `ro` | Romanian | | `ru` | Russian | +| `sa` | Sanskrit | | `sr` | Serbian (Cyrillic) | | `sr-latn` | Serbian (Latin) | | `sk` | Slovak | diff --git a/src/translations.js b/src/translations.js index da101b0cfc7ed..83c0d5beb65d5 100644 --- a/src/translations.js +++ b/src/translations.js @@ -33,6 +33,7 @@ const statCardLocales = ({ name, apostrophe }) => { fi: `${encodedName}:n GitHub-tilastot`, fr: `Statistiques GitHub de ${encodedName}`, hi: `${encodedName} के GitHub आँकड़े`, + sa: `${encodedName} इत्यस्य GitHub सांख्यिकी`, hu: `${encodedName} GitHub statisztika`, it: `Statistiche GitHub di ${encodedName}`, ja: `${encodedName}の GitHub 統計`, @@ -80,6 +81,7 @@ const statCardLocales = ({ name, apostrophe }) => { fi: `${encodedName}:n GitHub-sijoitus`, fr: `Statistiques GitHub de ${encodedName}`, hi: `${encodedName} का GitHub स्थान`, + sa: `${encodedName} इत्यस्य GitHub स्थानम्`, hu: `${encodedName} GitHub statisztika`, it: `Statistiche GitHub di ${encodedName}`, ja: `${encodedName} の GitHub ランク`, @@ -127,6 +129,7 @@ const statCardLocales = ({ name, apostrophe }) => { fi: "Ansaitut tähdet yhteensä", fr: "Total d'étoiles", hi: "कुल अर्जित सितारे", + sa: "अर्जिताः कुल-तारकाः", hu: "Csillagok", it: "Stelle totali", ja: "スターされた数", @@ -174,6 +177,7 @@ const statCardLocales = ({ name, apostrophe }) => { fi: "Yhteensä committeja", fr: "Total des Commits", hi: "कुल commits", + sa: "कुल-समिन्चयः", hu: "Összes commit", it: "Commit totali", ja: "合計コミット数", @@ -221,6 +225,7 @@ const statCardLocales = ({ name, apostrophe }) => { fi: "Yhteensä PR:t", fr: "Total des PRs", hi: "कुल PR", + sa: "कुल-पीआर", hu: "Összes PR", it: "PR totali", ja: "合計 PR", @@ -268,6 +273,7 @@ const statCardLocales = ({ name, apostrophe }) => { fi: "Yhteensä ongelmat", fr: "Nombre total d'incidents", hi: "कुल मुद्दे(Issues)", + sa: "कुल-समस्याः", hu: "Összes hibajegy", it: "Segnalazioni totali", ja: "合計 issue", @@ -315,6 +321,7 @@ const statCardLocales = ({ name, apostrophe }) => { fi: "Osallistunut (viime vuonna)", fr: "Contribué à (l'année dernière)", hi: "(पिछले वर्ष) में योगदान दिया", + sa: "(गते वर्षे) योगदानम् कृतम्", hu: "Hozzájárulások (tavaly)", it: "Ha contribuito a (l'anno scorso)", ja: "貢献したリポジトリ (昨年)", @@ -362,6 +369,7 @@ const statCardLocales = ({ name, apostrophe }) => { fi: "Yhteensä tarkastettuja PR:itä", fr: "Nombre total de PR examinés", hi: "कुल PRs की समीक्षा की गई", + sa: "समीक्षिताः कुल-पीआर", hu: "Összes ellenőrzött PR", it: "PR totali esaminati", ja: "レビューされた PR の総数", @@ -409,6 +417,7 @@ const statCardLocales = ({ name, apostrophe }) => { fi: "Aloitetut keskustelut yhteensä", fr: "Nombre total de discussions lancées", hi: "कुल चर्चाएँ शुरू हुईं", + sa: "प्रारब्धाः कुल-चर्चाः", hu: "Összes megkezdett megbeszélés", it: "Discussioni totali avviate", ja: "開始されたディスカッションの総数", @@ -456,6 +465,7 @@ const statCardLocales = ({ name, apostrophe }) => { fi: "Vastatut keskustelut yhteensä", fr: "Nombre total de discussions répondues", hi: "कुल चर्चाओं के उत्तर", + sa: "उत्तरिताः कुल-चर्चाः", hu: "Összes megválaszolt megbeszélés", it: "Discussioni totali risposte", ja: "回答されたディスカッションの総数", @@ -503,6 +513,7 @@ const statCardLocales = ({ name, apostrophe }) => { fi: "Yhteensä yhdistetyt PR:t", fr: "Nombre total de PR fusionnés", hi: "कुल PR का विलय", + sa: "विलीनाः कुल-पीआर", hu: "Összes egyesített PR", it: "PR totali uniti", ja: "マージされた PR の総数", @@ -549,6 +560,7 @@ const statCardLocales = ({ name, apostrophe }) => { fi: "Yhdistettyjen PR:ien prosentti", fr: "Pourcentage de PR fusionnés", hi: "मर्ज किए गए PRs प्रतिशत", + sa: "विलीन-पीआर प्रतिशतम्", hu: "Egyesített PR-k százaléka", it: "Percentuale di PR uniti", ja: "マージされた PR の割合", @@ -599,6 +611,7 @@ const repoCardLocales = { fi: "Malli", fr: "Modèle", hi: "खाका", + sa: "प्रारूपम्", hu: "Sablon", it: "Template", ja: "テンプレート", @@ -646,6 +659,7 @@ const repoCardLocales = { fi: "Arkistoitu", fr: "Archivé", hi: "संग्रहीत", + sa: "संगृहीतम्", hu: "Archivált", it: "Archiviata", ja: "アーカイブ済み", @@ -696,6 +710,7 @@ const langCardLocales = { fi: "Käytetyimmät kielet", fr: "Langages les plus utilisés", hi: "सर्वाधिक प्रयुक्त भाषा", + sa: "सर्वाधिक-प्रयुक्ताः भाषाः", hu: "Leggyakrabban használt nyelvek", it: "Linguaggi più utilizzati", ja: "最もよく使っている言語", @@ -743,6 +758,7 @@ const langCardLocales = { fi: "Ei kielitietoja.", fr: "Aucune donnée sur les langues.", hi: "कोई भाषा डेटा नहीं", + sa: "भाषा-विवरणं नास्ति।", hu: "Nincsenek nyelvi adatok.", it: "Nessun dato sulle lingue.", ja: "言語データがありません。", @@ -793,6 +809,7 @@ const wakatimeCardLocales = { fi: "WakaTime-tilastot", fr: "Statistiques de WakaTime", hi: "वाकाटाइम आँकड़े", + sa: "WakaTime सांख्यिकी", hu: "WakaTime statisztika", it: "Statistiche WakaTime", ja: "WakaTime ワカタイム統計", @@ -840,6 +857,7 @@ const wakatimeCardLocales = { fi: "Viime vuosi", fr: "L'année dernière", hi: "पिछले साल", + sa: "गतवर्षे", hu: "Tavaly", it: "L'anno scorso", ja: "昨年", @@ -887,6 +905,7 @@ const wakatimeCardLocales = { fi: "Viimeiset 7 päivää", fr: "7 derniers jours", hi: "पिछले 7 दिन", + sa: "विगतसप्तदिनेषु", hu: "Elmúlt 7 nap", it: "Ultimi 7 giorni", ja: "過去 7 日間", @@ -934,6 +953,7 @@ const wakatimeCardLocales = { fi: "WakaTime-käyttäjäprofiili ei ole julkinen", fr: "Profil utilisateur WakaTime non public", hi: "WakaTime उपयोगकर्ता प्रोफ़ाइल सार्वजनिक नहीं है", + sa: "WakaTime उपयोगकर्ता-प्रोफ़ाइल सार्वजनिकं नास्ति", hu: "A WakaTime felhasználói profilja nem nyilvános", it: "Profilo utente WakaTime non pubblico", ja: "WakaTime ユーザープロファイルは公開されていません", @@ -981,6 +1001,7 @@ const wakatimeCardLocales = { fi: "Käyttäjä ei jaa julkisesti tarkkoja kooditilastoja", fr: "L'utilisateur ne partage pas publiquement de statistiques de code détaillées", hi: "उपयोगकर्ता विस्तृत कोड आँकड़े सार्वजनिक रूप से साझा नहीं करता है", + sa: "उपयोगकर्ता विस्तृत-कोड-सांख्यिकीं सार्वजनिकरूपेण न दर्शयति", hu: "A felhasználó nem osztja meg nyilvánosan a részletes kódstatisztikákat", it: "L'utente non condivide pubblicamente statistiche dettagliate sul codice", ja: "ユーザーは詳細なコード統計を公開しません", @@ -1030,6 +1051,7 @@ const wakatimeCardLocales = { fi: "Ei koodaustoimintaa tällä viikolla", fr: "Aucune activité de codage cette semaine", hi: "इस सप्ताह कोई कोडिंग गतिविधि नहीं ", + sa: "अस्मिन् सप्ताहे कोडिङ्-कार्यं नास्ति", hu: "Nem volt aktivitás ezen a héten", it: "Nessuna attività in questa settimana", ja: "今週のコーディング活動はありません", From e09f69c82b0209b95ade2907d944cfd27539cc6d Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov Date: Sat, 4 Oct 2025 21:59:30 +0300 Subject: [PATCH 133/265] chore: enable ts-check for bench tests utils (#4512) Co-authored-by: Alexandr --- tests/bench/utils.js | 2 ++ 1 file changed, 2 insertions(+) diff --git a/tests/bench/utils.js b/tests/bench/utils.js index f4c8afb45a632..e135302599ac0 100644 --- a/tests/bench/utils.js +++ b/tests/bench/utils.js @@ -1,3 +1,5 @@ +// @ts-check + const DEFAULT_RUNS = 1000; const DEFAULT_WARMUPS = 50; From 9abfce8ca0f42d3282bac909cae27f0c98c2ab63 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov Date: Sat, 4 Oct 2025 22:00:08 +0300 Subject: [PATCH 134/265] chore: remove package lock from vercelignore to prevent discrepancies between dev and prod envs (#4513) Co-authored-by: Alexandr --- .vercelignore | 1 - 1 file changed, 1 deletion(-) diff --git a/.vercelignore b/.vercelignore index 064c0ab23a89a..7dc1e9516fc6d 100644 --- a/.vercelignore +++ b/.vercelignore @@ -7,7 +7,6 @@ coverage scripts tests .env -package-lock.json **/*.md **/*.svg .eslintrc.json From 3456ceb4b48939cd798b29232abae5ad9f1e90f3 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Sun, 5 Oct 2025 21:20:52 +0300 Subject: [PATCH 135/265] docs(readme): update notice about hacktoberfest (#4516) Co-authored-by: Alexandr --- readme.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/readme.md b/readme.md index bd7a90ad034c5..d1348777a7697 100644 --- a/readme.md +++ b/readme.md @@ -99,7 +99,7 @@ # Important Notices > [!IMPORTANT]\ -> Please note that we are NOT participating in Hacktoberfest this year. Unfortunately, the only person with sufficient access rights to remove the repository label is currently unreachable, so we are notifying you here. As a small team, we cannot handle the increased volume of PRs and issues that the event brings. We appreciate your understanding. +> Please note that we are NOT participating in Hacktoberfest this year. As a small team, we cannot handle the increased volume of PRs and issues that the event brings. We appreciate your understanding. > [!IMPORTANT]\ > Since the GitHub API only [allows 5k requests per hour per user account](https://docs.github.com/en/graphql/overview/resource-limitations), the public Vercel instance hosted on `https://github-readme-stats.vercel.app/api` could possibly hit the rate limiter (see [#1471](https://github.com/anuraghazra/github-readme-stats/issues/1471)). We use caching to prevent this from happening (see https://github.com/anuraghazra/github-readme-stats#common-options). You can turn off these rate limit protections by [deploying your own Vercel instance](#deploy-on-your-own). From f5de3eb91889df1c3d9e2754375156705f0eeb62 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Sun, 5 Oct 2025 21:21:26 +0300 Subject: [PATCH 136/265] docs(contributing): update notice about hacktoberfest (#4517) Co-authored-by: Alexandr --- CONTRIBUTING.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index a593078c58d47..29edbd34e68e2 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -1,7 +1,7 @@ # Contributing to [github-readme-stats](https://github.com/anuraghazra/github-readme-stats) > [!IMPORTANT]\ -> Please note that we are NOT participating in Hacktoberfest this year. Unfortunately, the only person with sufficient access rights to remove the repository label is currently unreachable, so we are notifying you here. As a small team, we cannot handle the increased volume of PRs and issues that the event brings. We appreciate your understanding. +> Please note that we are NOT participating in Hacktoberfest this year. As a small team, we cannot handle the increased volume of PRs and issues that the event brings. We appreciate your understanding. We love your input! We want to make contributing to this project as easy and transparent as possible, whether it's: From 41317e848e997b90095fcb5b8fa12e9057df023b Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Sun, 5 Oct 2025 21:22:05 +0300 Subject: [PATCH 137/265] fix: mark Tamil as long language for stats card (#4518) Co-authored-by: Alexandr --- src/cards/stats.js | 1 + 1 file changed, 1 insertion(+) diff --git a/src/cards/stats.js b/src/cards/stats.js index 3e853b0a41274..9d42005dc76bc 100644 --- a/src/cards/stats.js +++ b/src/cards/stats.js @@ -380,6 +380,7 @@ const renderStatsCard = (stats, options = {}) => { "ru", "sr", "sr-latn", + "ta", "uk-ua", "uz", "zh-tw", From 361e8279cc888c3932eb5af9ec8a1ee033363773 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Sun, 5 Oct 2025 21:22:46 +0300 Subject: [PATCH 138/265] chore: enable dependabot updates for devcontainer (#4519) Co-authored-by: Alexandr --- .github/dependabot.yml | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/.github/dependabot.yml b/.github/dependabot.yml index 13eb4b3c6ca40..3534f3bdfe705 100644 --- a/.github/dependabot.yml +++ b/.github/dependabot.yml @@ -19,3 +19,13 @@ updates: commit-message: prefix: "ci(deps)" prefix-development: "ci(deps-dev)" + + # Maintain dependencies for Devcontainers + - package-ecosystem: devcontainers + directory: "/" + schedule: + interval: weekly + open-pull-requests-limit: 10 + commit-message: + prefix: "build(deps)" + prefix-development: "build(deps-dev)" From 39b93b57c8c8170df7b2ba028fa4c159dea81a72 Mon Sep 17 00:00:00 2001 From: martin-mfg <2026226+martin-mfg@users.noreply.github.com> Date: Sun, 5 Oct 2025 22:03:25 +0200 Subject: [PATCH 139/265] feat: wakatime card width customization (#4458) * add card_width to wakatime card * better handling of card_width in wakatime card * move default card_width for wakatime card, add to readme * review * review --------- Co-authored-by: Alexandr --- api/wakatime.js | 2 ++ readme.md | 1 + src/cards/types.d.ts | 1 + src/cards/wakatime.js | 61 +++++++++++++++++++++++++++++++------------ 4 files changed, 48 insertions(+), 17 deletions(-) diff --git a/api/wakatime.js b/api/wakatime.js index 69f0ce7d10e8c..4b9ce1f8404fe 100644 --- a/api/wakatime.js +++ b/api/wakatime.js @@ -16,6 +16,7 @@ export default async (req, res) => { title_color, icon_color, hide_border, + card_width, line_height, text_color, bg_color, @@ -90,6 +91,7 @@ export default async (req, res) => { custom_title, hide_title: parseBoolean(hide_title), hide_border: parseBoolean(hide_border), + card_width: parseInt(card_width, 10), hide: parseArray(hide), line_height, title_color, diff --git a/readme.md b/readme.md index d1348777a7697..dab957dd7d4f6 100644 --- a/readme.md +++ b/readme.md @@ -648,6 +648,7 @@ You can customize the appearance and behavior of the WakaTime stats card using t | --- | --- | --- | --- | | `hide` | Hides the languages specified from the card. | string (comma-separated values) | `null` | | `hide_title` | Hides the title of your card. | boolean | `false` | +| `card_width` | Sets the card's width manually. | number | `495` | | `line_height` | Sets the line height between text. | integer | `25` | | `hide_progress` | Hides the progress bar and percentage. | boolean | `false` | | `custom_title` | Sets a custom title for the card. | string | `WakaTime Stats` | diff --git a/src/cards/types.d.ts b/src/cards/types.d.ts index 94f36adc624b7..c7d8c60fb2b28 100644 --- a/src/cards/types.d.ts +++ b/src/cards/types.d.ts @@ -51,6 +51,7 @@ export type TopLangOptions = CommonOptions & { export type WakaTimeOptions = CommonOptions & { hide_title: boolean; hide: string[]; + card_width: number; line_height: string; hide_progress: boolean; custom_title: string; diff --git a/src/cards/wakatime.js b/src/cards/wakatime.js index 65e1d54d779ea..64ded83d41692 100644 --- a/src/cards/wakatime.js +++ b/src/cards/wakatime.js @@ -1,4 +1,5 @@ // @ts-check + import { Card } from "../common/Card.js"; import { createProgressNode } from "../common/createProgressNode.js"; import { I18n } from "../common/I18n.js"; @@ -21,6 +22,10 @@ import { createRequire } from "module"; const require = createRequire(import.meta.url); const languageColors = require("../common/languageColors.json"); // now works +const DEFAULT_CARD_WIDTH = 495; +const MIN_CARD_WIDTH = 250; +const COMPACT_LAYOUT_MIN_WIDTH = 400; + /** * Creates the no coding activity SVG node. * @@ -84,22 +89,21 @@ const createCompactLangNode = ({ lang, x, y, display_format }) => { * @param {WakaTimeLang[]} args.langs The language objects. * @param {number} args.y The y position of the language node. * @param {"time" | "percent"} args.display_format The display format of the language node. + * @param {number} args.card_width Width in px of the card. * @returns {string[]} The language text node items. */ -const createLanguageTextNode = ({ langs, y, display_format }) => { +const createLanguageTextNode = ({ langs, y, display_format, card_width }) => { + const LEFT_X = 25; + const RIGHT_X_BASE = 230; + const rightOffset = (card_width - DEFAULT_CARD_WIDTH) / 2; + const RIGHT_X = RIGHT_X_BASE + rightOffset; + return langs.map((lang, index) => { - if (index % 2 === 0) { - return createCompactLangNode({ - lang, - x: 25, - y: 12.5 * index + y, - display_format, - }); - } + const isLeft = index % 2 === 0; return createCompactLangNode({ lang, - x: 230, - y: 12.5 + 12.5 * index, + x: isLeft ? LEFT_X : RIGHT_X, + y: isLeft ? 12.5 * index + y : 12.5 + 12.5 * index, display_format, }); }); @@ -117,6 +121,7 @@ const createLanguageTextNode = ({ langs, y, display_format }) => { * @param {boolean=} args.hideProgress Whether to hide the progress bar. * @param {string} args.progressBarColor The color of the progress bar. * @param {string} args.progressBarBackgroundColor The color of the progress bar background. + * @param {number} args.progressBarWidth The width of the progress bar. * @returns {string} The text SVG node. */ const createTextNode = ({ @@ -128,6 +133,7 @@ const createTextNode = ({ hideProgress, progressBarColor, progressBarBackgroundColor, + progressBarWidth, }) => { const staggerDelay = (index + 3) * 150; @@ -138,7 +144,7 @@ const createTextNode = ({ y: 4, progress: percent, color: progressBarColor, - width: 220, + width: progressBarWidth, // @ts-ignore name: label, progressBarBackgroundColor, @@ -150,7 +156,7 @@ const createTextNode = ({ ${label}: ${value} ${cardProgress} @@ -206,6 +212,24 @@ const getStyles = ({ `; }; +/** + * Normalize incoming width (string or number) and clamp to minimum. + * + * @param {Object} args The function arguments. + * @param {WakaTimeOptions["layout"] | undefined} args.layout The incoming layout value. + * @param {number|undefined} args.value The incoming width value. + * @returns {number} The normalized width value. + */ +const normalizeCardWidth = ({ value, layout }) => { + if (value === undefined || value === null || isNaN(value)) { + return DEFAULT_CARD_WIDTH; + } + return Math.max( + layout === "compact" ? COMPACT_LAYOUT_MIN_WIDTH : MIN_CARD_WIDTH, + value, + ); +}; + /** * @typedef {import('../fetchers/types').WakaTimeData} WakaTimeData * @typedef {import('./types').WakaTimeOptions} WakaTimeOptions @@ -223,6 +247,7 @@ const renderWakatimeCard = (stats = {}, options = { hide: [] }) => { const { hide_title = false, hide_border = false, + card_width, hide, line_height = 25, title_color, @@ -241,6 +266,8 @@ const renderWakatimeCard = (stats = {}, options = { hide: [] }) => { disable_animations, } = options; + const normalizedWidth = normalizeCardWidth({ value: card_width, layout }); + const shouldHideLangs = Array.isArray(hide) && hide.length > 0; if (shouldHideLangs) { const languagesToHide = new Set(hide.map((lang) => lowercaseTrim(lang))); @@ -289,11 +316,9 @@ const renderWakatimeCard = (stats = {}, options = { hide: [] }) => { let finalLayout = ""; - let width = 440; - // RENDER COMPACT LAYOUT if (layout === "compact") { - width = width + 50; + let width = normalizedWidth - 5; height = 90 + Math.round(filteredLanguages.length / 2) * 25; // progressOffset holds the previous language's width and used to offset the next language @@ -333,6 +358,7 @@ const renderWakatimeCard = (stats = {}, options = { hide: [] }) => { y: 25, langs: filteredLanguages, display_format, + card_width: normalizedWidth, }).join("") : noCodingActivityNode({ // @ts-ignore @@ -360,6 +386,7 @@ const renderWakatimeCard = (stats = {}, options = { hide: [] }) => { // @ts-ignore progressBarBackgroundColor: textColor, hideProgress: hide_progress, + progressBarWidth: normalizedWidth - 275, }); }) : [ @@ -392,7 +419,7 @@ const renderWakatimeCard = (stats = {}, options = { hide: [] }) => { const card = new Card({ customTitle: custom_title, defaultTitle: titleText, - width: 495, + width: normalizedWidth, height, border_radius, colors: { From a697215f8e7ca8902cc107ed0b854cd6cca7cf8e Mon Sep 17 00:00:00 2001 From: Bear_03 <64696287+Bear-03@users.noreply.github.com> Date: Sun, 5 Oct 2025 22:49:17 +0200 Subject: [PATCH 140/265] feat: add support for EXCLUDE_REPO env variable (#1299) * Add support for EXCLUDE_REPO env variable * review * docs * refactor --------- Co-authored-by: Alexandr --- readme.md | 1 + src/common/excludeRepo.js | 6 ++++++ src/fetchers/stats.js | 5 ++++- src/fetchers/top-languages.js | 7 +++++-- 4 files changed, 16 insertions(+), 3 deletions(-) create mode 100644 src/common/excludeRepo.js diff --git a/readme.md b/readme.md index dab957dd7d4f6..00eb0a135d9c9 100644 --- a/readme.md +++ b/readme.md @@ -888,6 +888,7 @@ GitHub Readme Stats provides several environment variables that can be used to c * `CACHE_SECONDS`: This takes precedence over our cache minimum and maximum values and can circumvent these values for self-hosted instances. * `WHITELIST`: A comma-separated list of GitHub usernames that are allowed to access your instance. If this variable is not set, all usernames are allowed. * `GIST_WHITELIST`: A comma-separated list of GitHub gist IDs that are allowed to be accessed on your instance. If this variable is not set, all gist IDs are allowed. +* `EXCLUDE_REPO`: A comma-separated list of repositories that will be excluded from stats and top languages cards on your instance. This allows repository exclusion without exposing repository names in public URLs. This enhances privacy for self-hosted instances that include private repositories in stats cards. See [the Vercel documentation](https://vercel.com/docs/concepts/projects/environment-variables) on adding these environment variables to your Vercel instance. diff --git a/src/common/excludeRepo.js b/src/common/excludeRepo.js new file mode 100644 index 0000000000000..4e42ff8a73f94 --- /dev/null +++ b/src/common/excludeRepo.js @@ -0,0 +1,6 @@ +const excludeRepositories = process.env.EXCLUDE_REPO + ? process.env.EXCLUDE_REPO.split(",") + : []; + +export { excludeRepositories }; +export default excludeRepositories; diff --git a/src/fetchers/stats.js b/src/fetchers/stats.js index c54cdd93ea81c..5f56a7c4e79ad 100644 --- a/src/fetchers/stats.js +++ b/src/fetchers/stats.js @@ -1,4 +1,5 @@ // @ts-check + import axios from "axios"; import * as dotenv from "dotenv"; import githubUsernameRegex from "github-username-regex"; @@ -11,6 +12,7 @@ import { request, wrapTextMultiline, } from "../common/utils.js"; +import excludeRepositories from "../common/excludeRepo.js"; dotenv.config(); @@ -312,7 +314,8 @@ const fetchStats = async ( stats.contributedTo = user.repositoriesContributedTo.totalCount; // Retrieve stars while filtering out repositories to be hidden. - let repoToHide = new Set(exclude_repo); + const allExcludedRepos = [...exclude_repo, ...excludeRepositories]; + let repoToHide = new Set(allExcludedRepos); stats.totalStars = user.repositories.nodes .filter((data) => { diff --git a/src/fetchers/top-languages.js b/src/fetchers/top-languages.js index 485cc8b75de8a..4490ef40b43a4 100644 --- a/src/fetchers/top-languages.js +++ b/src/fetchers/top-languages.js @@ -1,4 +1,5 @@ // @ts-check + import { retryer } from "../common/retryer.js"; import { CustomError, @@ -7,6 +8,7 @@ import { request, wrapTextMultiline, } from "../common/utils.js"; +import excludeRepositories from "../common/excludeRepo.js"; /** * @typedef {import("axios").AxiosRequestHeaders} AxiosRequestHeaders Axios request headers. @@ -99,11 +101,12 @@ const fetchTopLanguages = async ( let repoNodes = res.data.data.user.repositories.nodes; let repoToHide = {}; + const allExcludedRepos = [...exclude_repo, ...excludeRepositories]; // populate repoToHide map for quick lookup // while filtering out - if (exclude_repo) { - exclude_repo.forEach((repoName) => { + if (allExcludedRepos) { + allExcludedRepos.forEach((repoName) => { repoToHide[repoName] = true; }); } From 24b1df0d28db272b67303b04330215031281f15a Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Mon, 6 Oct 2025 21:31:10 +0300 Subject: [PATCH 141/265] fix: mark Swahili language as long for stats card (#4528) Co-authored-by: Alexandr --- src/cards/stats.js | 1 + 1 file changed, 1 insertion(+) diff --git a/src/cards/stats.js b/src/cards/stats.js index 9d42005dc76bc..8920c52b11b24 100644 --- a/src/cards/stats.js +++ b/src/cards/stats.js @@ -380,6 +380,7 @@ const renderStatsCard = (stats, options = {}) => { "ru", "sr", "sr-latn", + "sw", "ta", "uk-ua", "uz", From f5b1ffa5e39c84fc70e904eeb26fe2ed78ecaebd Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Mon, 6 Oct 2025 21:32:23 +0300 Subject: [PATCH 142/265] refactor: move all envs related code into separate file (#4529) Co-authored-by: Alexandr --- api/gist.js | 4 +++- api/index.js | 4 +++- api/pin.js | 4 +++- api/top-langs.js | 4 +++- api/wakatime.js | 4 +++- src/common/{whitelist.js => envs.js} | 7 +++++-- src/common/excludeRepo.js | 6 ------ src/fetchers/stats.js | 2 +- src/fetchers/top-languages.js | 2 +- 9 files changed, 22 insertions(+), 15 deletions(-) rename src/common/{whitelist.js => envs.js} (55%) delete mode 100644 src/common/excludeRepo.js diff --git a/api/gist.js b/api/gist.js index c309c8cfde14b..f0bc08adbe4d8 100644 --- a/api/gist.js +++ b/api/gist.js @@ -1,10 +1,12 @@ +// @ts-check + import { clampValue, CONSTANTS, renderError, parseBoolean, } from "../src/common/utils.js"; -import { gistWhitelist } from "../src/common/whitelist.js"; +import { gistWhitelist } from "../src/common/envs.js"; import { isLocaleAvailable } from "../src/translations.js"; import { renderGistCard } from "../src/cards/gist.js"; import { fetchGist } from "../src/fetchers/gist.js"; diff --git a/api/index.js b/api/index.js index 66c119a5e0563..5e0939ab6e018 100644 --- a/api/index.js +++ b/api/index.js @@ -1,6 +1,8 @@ +// @ts-check + import { renderStatsCard } from "../src/cards/stats.js"; import { blacklist } from "../src/common/blacklist.js"; -import { whitelist } from "../src/common/whitelist.js"; +import { whitelist } from "../src/common/envs.js"; import { clampValue, CONSTANTS, diff --git a/api/pin.js b/api/pin.js index eec584d9433e9..67802a03e4ac8 100644 --- a/api/pin.js +++ b/api/pin.js @@ -1,6 +1,8 @@ +// @ts-check + import { renderRepoCard } from "../src/cards/repo.js"; import { blacklist } from "../src/common/blacklist.js"; -import { whitelist } from "../src/common/whitelist.js"; +import { whitelist } from "../src/common/envs.js"; import { clampValue, CONSTANTS, diff --git a/api/top-langs.js b/api/top-langs.js index 10ecc5d9f997c..e701cb16e624f 100644 --- a/api/top-langs.js +++ b/api/top-langs.js @@ -1,6 +1,8 @@ +// @ts-check + import { renderTopLanguages } from "../src/cards/top-languages.js"; import { blacklist } from "../src/common/blacklist.js"; -import { whitelist } from "../src/common/whitelist.js"; +import { whitelist } from "../src/common/envs.js"; import { clampValue, CONSTANTS, diff --git a/api/wakatime.js b/api/wakatime.js index 4b9ce1f8404fe..0c5494b446146 100644 --- a/api/wakatime.js +++ b/api/wakatime.js @@ -1,3 +1,5 @@ +// @ts-check + import { renderWakatimeCard } from "../src/cards/wakatime.js"; import { clampValue, @@ -6,7 +8,7 @@ import { parseBoolean, renderError, } from "../src/common/utils.js"; -import { whitelist } from "../src/common/whitelist.js"; +import { whitelist } from "../src/common/envs.js"; import { fetchWakatimeStats } from "../src/fetchers/wakatime.js"; import { isLocaleAvailable } from "../src/translations.js"; diff --git a/src/common/whitelist.js b/src/common/envs.js similarity index 55% rename from src/common/whitelist.js rename to src/common/envs.js index b5df7c70cacc8..f1ae30de4b2e5 100644 --- a/src/common/whitelist.js +++ b/src/common/envs.js @@ -6,5 +6,8 @@ const gistWhitelist = process.env.GIST_WHITELIST ? process.env.GIST_WHITELIST.split(",") : undefined; -export { whitelist, gistWhitelist }; -export default whitelist; +const excludeRepositories = process.env.EXCLUDE_REPO + ? process.env.EXCLUDE_REPO.split(",") + : []; + +export { whitelist, gistWhitelist, excludeRepositories }; diff --git a/src/common/excludeRepo.js b/src/common/excludeRepo.js deleted file mode 100644 index 4e42ff8a73f94..0000000000000 --- a/src/common/excludeRepo.js +++ /dev/null @@ -1,6 +0,0 @@ -const excludeRepositories = process.env.EXCLUDE_REPO - ? process.env.EXCLUDE_REPO.split(",") - : []; - -export { excludeRepositories }; -export default excludeRepositories; diff --git a/src/fetchers/stats.js b/src/fetchers/stats.js index 5f56a7c4e79ad..d4ead2944f4c6 100644 --- a/src/fetchers/stats.js +++ b/src/fetchers/stats.js @@ -12,7 +12,7 @@ import { request, wrapTextMultiline, } from "../common/utils.js"; -import excludeRepositories from "../common/excludeRepo.js"; +import { excludeRepositories } from "../common/envs.js"; dotenv.config(); diff --git a/src/fetchers/top-languages.js b/src/fetchers/top-languages.js index 4490ef40b43a4..2e0c1e2110a1c 100644 --- a/src/fetchers/top-languages.js +++ b/src/fetchers/top-languages.js @@ -8,7 +8,7 @@ import { request, wrapTextMultiline, } from "../common/utils.js"; -import excludeRepositories from "../common/excludeRepo.js"; +import { excludeRepositories } from "../common/envs.js"; /** * @typedef {import("axios").AxiosRequestHeaders} AxiosRequestHeaders Axios request headers. From e5f40eb09cf665b0d9b3a8384086f53d6961fc6b Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Mon, 6 Oct 2025 22:02:00 +0300 Subject: [PATCH 143/265] fix: prevent items overlap by making swahili translation shorter for stats card commits (#4530) Co-authored-by: Alexandr --- src/translations.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/translations.js b/src/translations.js index 83c0d5beb65d5..6798032907e47 100644 --- a/src/translations.js +++ b/src/translations.js @@ -168,7 +168,7 @@ const statCardLocales = ({ name, apostrophe }) => { "zh-tw": "累計提交數量(Commit)", cs: "Celkem commitů", de: "Anzahl Commits", - sw: "Matendo(Commits) yako yote", + sw: "Matendo yako yote", ur: "کل کمٹ", bg: "Общо ангажименти", bn: "সর্বমোট Commit", From fde13639aa3eff7e455d0c64065f886b64ed10bd Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Mon, 6 Oct 2025 22:04:06 +0300 Subject: [PATCH 144/265] docs(readme): add description of FETCH_MULTI_PAGE_STARS environment variable (#4531) * docs(readme): add description of FETCH_MULTI_PAGE_STARS environment variable * Update readme.md Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --------- Co-authored-by: Alexandr Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --- readme.md | 1 + 1 file changed, 1 insertion(+) diff --git a/readme.md b/readme.md index 00eb0a135d9c9..6562c676a2369 100644 --- a/readme.md +++ b/readme.md @@ -889,6 +889,7 @@ GitHub Readme Stats provides several environment variables that can be used to c * `WHITELIST`: A comma-separated list of GitHub usernames that are allowed to access your instance. If this variable is not set, all usernames are allowed. * `GIST_WHITELIST`: A comma-separated list of GitHub gist IDs that are allowed to be accessed on your instance. If this variable is not set, all gist IDs are allowed. * `EXCLUDE_REPO`: A comma-separated list of repositories that will be excluded from stats and top languages cards on your instance. This allows repository exclusion without exposing repository names in public URLs. This enhances privacy for self-hosted instances that include private repositories in stats cards. +* `FETCH_MULTI_PAGE_STARS`: When set to `true`, this enables fetching all starred repositories for accurate star counts, especially for users with more than 100 repositories. This may increase response times and API points usage, so it is disabled on the public instance. See [the Vercel documentation](https://vercel.com/docs/concepts/projects/environment-variables) on adding these environment variables to your Vercel instance. From ade7d5365307e38135de9b96350a732b146deb2e Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Mon, 6 Oct 2025 23:32:47 +0300 Subject: [PATCH 145/265] refactor: move cache seconds calculation logic into reusable function (#4532) * refactor: move cache seconds calculation logic into reusable function * dev --------- Co-authored-by: Alexandr --- api/gist.js | 23 ++++++++--------------- api/index.js | 17 +++++++---------- api/pin.js | 23 ++++++++--------------- api/top-langs.js | 17 +++++++---------- api/wakatime.js | 17 +++++++---------- src/common/cache.js | 23 +++++++++++++++++++++++ 6 files changed, 60 insertions(+), 60 deletions(-) create mode 100644 src/common/cache.js diff --git a/api/gist.js b/api/gist.js index f0bc08adbe4d8..d592895063cb7 100644 --- a/api/gist.js +++ b/api/gist.js @@ -1,15 +1,11 @@ // @ts-check -import { - clampValue, - CONSTANTS, - renderError, - parseBoolean, -} from "../src/common/utils.js"; +import { CONSTANTS, renderError, parseBoolean } from "../src/common/utils.js"; import { gistWhitelist } from "../src/common/envs.js"; import { isLocaleAvailable } from "../src/translations.js"; import { renderGistCard } from "../src/cards/gist.js"; import { fetchGist } from "../src/fetchers/gist.js"; +import { resolveCacheSeconds } from "../src/common/cache.js"; export default async (req, res) => { const { @@ -60,15 +56,12 @@ export default async (req, res) => { try { const gistData = await fetchGist(id); - - let cacheSeconds = clampValue( - parseInt(cache_seconds || CONSTANTS.TWO_DAY, 10), - CONSTANTS.TWO_DAY, - CONSTANTS.SIX_DAY, - ); - cacheSeconds = process.env.CACHE_SECONDS - ? parseInt(process.env.CACHE_SECONDS, 10) || cacheSeconds - : cacheSeconds; + const cacheSeconds = resolveCacheSeconds({ + requested: cache_seconds, + def: CONSTANTS.TWO_DAY, + min: CONSTANTS.TWO_DAY, + max: CONSTANTS.SIX_DAY, + }); res.setHeader( "Cache-Control", diff --git a/api/index.js b/api/index.js index 5e0939ab6e018..989e39a6256a5 100644 --- a/api/index.js +++ b/api/index.js @@ -2,9 +2,9 @@ import { renderStatsCard } from "../src/cards/stats.js"; import { blacklist } from "../src/common/blacklist.js"; +import { resolveCacheSeconds } from "../src/common/cache.js"; import { whitelist } from "../src/common/envs.js"; import { - clampValue, CONSTANTS, parseArray, parseBoolean, @@ -103,15 +103,12 @@ export default async (req, res) => { showStats.includes("discussions_answered"), parseInt(commits_year, 10), ); - - let cacheSeconds = clampValue( - parseInt(cache_seconds || CONSTANTS.CARD_CACHE_SECONDS, 10), - CONSTANTS.TWELVE_HOURS, - CONSTANTS.TWO_DAY, - ); - cacheSeconds = process.env.CACHE_SECONDS - ? parseInt(process.env.CACHE_SECONDS, 10) || cacheSeconds - : cacheSeconds; + const cacheSeconds = resolveCacheSeconds({ + requested: cache_seconds, + def: CONSTANTS.CARD_CACHE_SECONDS, + min: CONSTANTS.TWELVE_HOURS, + max: CONSTANTS.TWO_DAY, + }); res.setHeader( "Cache-Control", diff --git a/api/pin.js b/api/pin.js index 67802a03e4ac8..10c52f1f3485c 100644 --- a/api/pin.js +++ b/api/pin.js @@ -2,13 +2,9 @@ import { renderRepoCard } from "../src/cards/repo.js"; import { blacklist } from "../src/common/blacklist.js"; +import { resolveCacheSeconds } from "../src/common/cache.js"; import { whitelist } from "../src/common/envs.js"; -import { - clampValue, - CONSTANTS, - parseBoolean, - renderError, -} from "../src/common/utils.js"; +import { CONSTANTS, parseBoolean, renderError } from "../src/common/utils.js"; import { fetchRepo } from "../src/fetchers/repo.js"; import { isLocaleAvailable } from "../src/translations.js"; @@ -80,15 +76,12 @@ export default async (req, res) => { try { const repoData = await fetchRepo(username, repo); - - let cacheSeconds = clampValue( - parseInt(cache_seconds || CONSTANTS.PIN_CARD_CACHE_SECONDS, 10), - CONSTANTS.ONE_DAY, - CONSTANTS.TEN_DAY, - ); - cacheSeconds = process.env.CACHE_SECONDS - ? parseInt(process.env.CACHE_SECONDS, 10) || cacheSeconds - : cacheSeconds; + const cacheSeconds = resolveCacheSeconds({ + requested: cache_seconds, + def: CONSTANTS.PIN_CARD_CACHE_SECONDS, + min: CONSTANTS.ONE_DAY, + max: CONSTANTS.TEN_DAY, + }); res.setHeader( "Cache-Control", diff --git a/api/top-langs.js b/api/top-langs.js index e701cb16e624f..ce3443ba26c1c 100644 --- a/api/top-langs.js +++ b/api/top-langs.js @@ -2,9 +2,9 @@ import { renderTopLanguages } from "../src/cards/top-languages.js"; import { blacklist } from "../src/common/blacklist.js"; +import { resolveCacheSeconds } from "../src/common/cache.js"; import { whitelist } from "../src/common/envs.js"; import { - clampValue, CONSTANTS, parseArray, parseBoolean, @@ -105,15 +105,12 @@ export default async (req, res) => { size_weight, count_weight, ); - - let cacheSeconds = clampValue( - parseInt(cache_seconds || CONSTANTS.TOP_LANGS_CACHE_SECONDS, 10), - CONSTANTS.TWO_DAY, - CONSTANTS.TEN_DAY, - ); - cacheSeconds = process.env.CACHE_SECONDS - ? parseInt(process.env.CACHE_SECONDS, 10) || cacheSeconds - : cacheSeconds; + const cacheSeconds = resolveCacheSeconds({ + requested: cache_seconds, + def: CONSTANTS.TOP_LANGS_CACHE_SECONDS, + min: CONSTANTS.TWO_DAY, + max: CONSTANTS.TEN_DAY, + }); res.setHeader( "Cache-Control", diff --git a/api/wakatime.js b/api/wakatime.js index 0c5494b446146..5aba93ab7e899 100644 --- a/api/wakatime.js +++ b/api/wakatime.js @@ -2,7 +2,6 @@ import { renderWakatimeCard } from "../src/cards/wakatime.js"; import { - clampValue, CONSTANTS, parseArray, parseBoolean, @@ -11,6 +10,7 @@ import { import { whitelist } from "../src/common/envs.js"; import { fetchWakatimeStats } from "../src/fetchers/wakatime.js"; import { isLocaleAvailable } from "../src/translations.js"; +import { resolveCacheSeconds } from "../src/common/cache.js"; export default async (req, res) => { const { @@ -71,15 +71,12 @@ export default async (req, res) => { try { const stats = await fetchWakatimeStats({ username, api_domain }); - - let cacheSeconds = clampValue( - parseInt(cache_seconds || CONSTANTS.CARD_CACHE_SECONDS, 10), - CONSTANTS.SIX_HOURS, - CONSTANTS.TWO_DAY, - ); - cacheSeconds = process.env.CACHE_SECONDS - ? parseInt(process.env.CACHE_SECONDS, 10) || cacheSeconds - : cacheSeconds; + const cacheSeconds = resolveCacheSeconds({ + requested: cache_seconds, + def: CONSTANTS.CARD_CACHE_SECONDS, + min: CONSTANTS.SIX_HOURS, + max: CONSTANTS.TWO_DAY, + }); res.setHeader( "Cache-Control", diff --git a/src/common/cache.js b/src/common/cache.js new file mode 100644 index 0000000000000..b5fd8ce72a573 --- /dev/null +++ b/src/common/cache.js @@ -0,0 +1,23 @@ +import { clampValue } from "./utils"; + +/** + * Resolves the cache seconds based on the requested, default, min, and max values. + * + * @param {Object} args The parameters object. + * @param {number} args.requested The requested cache seconds. + * @param {number} args.def The default cache seconds. + * @param {number} args.min The minimum cache seconds. + * @param {number} args.max The maximum cache seconds. + * @returns {number} The resolved cache seconds. + */ +const resolveCacheSeconds = ({ requested, def, min, max }) => { + let cacheSeconds = clampValue(parseInt(requested || def, 10), min, max); + + cacheSeconds = process.env.CACHE_SECONDS + ? parseInt(process.env.CACHE_SECONDS, 10) || cacheSeconds + : cacheSeconds; + + return cacheSeconds; +}; + +export { resolveCacheSeconds }; From 09627ce715905965b3cd099f76166c13b1ad0e2b Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Tue, 7 Oct 2025 00:13:21 +0300 Subject: [PATCH 146/265] refactor: move cache headers logic into reusable functions (#4533) * refactor: move cache headers logic into reusable functions * dev --------- Co-authored-by: Alexandr --- api/gist.js | 20 ++++++++------------ api/index.js | 20 ++++++++------------ api/pin.js | 20 ++++++++------------ api/top-langs.js | 20 ++++++++------------ api/wakatime.js | 22 ++++++++------------- src/common/cache.js | 36 ++++++++++++++++++++++++++++++++--- tests/api.test.js | 42 ++++++++++++++++++++--------------------- tests/gist.test.js | 2 +- tests/pin.test.js | 6 +++--- tests/top-langs.test.js | 6 +++--- 10 files changed, 100 insertions(+), 94 deletions(-) diff --git a/api/gist.js b/api/gist.js index d592895063cb7..435c6b7289cb6 100644 --- a/api/gist.js +++ b/api/gist.js @@ -5,7 +5,11 @@ import { gistWhitelist } from "../src/common/envs.js"; import { isLocaleAvailable } from "../src/translations.js"; import { renderGistCard } from "../src/cards/gist.js"; import { fetchGist } from "../src/fetchers/gist.js"; -import { resolveCacheSeconds } from "../src/common/cache.js"; +import { + resolveCacheSeconds, + setCacheHeaders, + setErrorCacheHeaders, +} from "../src/common/cache.js"; export default async (req, res) => { const { @@ -57,16 +61,13 @@ export default async (req, res) => { try { const gistData = await fetchGist(id); const cacheSeconds = resolveCacheSeconds({ - requested: cache_seconds, + requested: parseInt(cache_seconds, 10), def: CONSTANTS.TWO_DAY, min: CONSTANTS.TWO_DAY, max: CONSTANTS.SIX_DAY, }); - res.setHeader( - "Cache-Control", - `max-age=${cacheSeconds}, s-maxage=${cacheSeconds}`, - ); + setCacheHeaders(res, cacheSeconds); return res.send( renderGistCard(gistData, { @@ -83,12 +84,7 @@ export default async (req, res) => { }), ); } catch (err) { - res.setHeader( - "Cache-Control", - `max-age=${CONSTANTS.ERROR_CACHE_SECONDS / 2}, s-maxage=${ - CONSTANTS.ERROR_CACHE_SECONDS - }, stale-while-revalidate=${CONSTANTS.ONE_DAY}`, - ); // Use lower cache period for errors. + setErrorCacheHeaders(res); return res.send( renderError(err.message, err.secondaryMessage, { title_color, diff --git a/api/index.js b/api/index.js index 989e39a6256a5..88ffd2db67204 100644 --- a/api/index.js +++ b/api/index.js @@ -2,7 +2,11 @@ import { renderStatsCard } from "../src/cards/stats.js"; import { blacklist } from "../src/common/blacklist.js"; -import { resolveCacheSeconds } from "../src/common/cache.js"; +import { + resolveCacheSeconds, + setCacheHeaders, + setErrorCacheHeaders, +} from "../src/common/cache.js"; import { whitelist } from "../src/common/envs.js"; import { CONSTANTS, @@ -104,16 +108,13 @@ export default async (req, res) => { parseInt(commits_year, 10), ); const cacheSeconds = resolveCacheSeconds({ - requested: cache_seconds, + requested: parseInt(cache_seconds, 10), def: CONSTANTS.CARD_CACHE_SECONDS, min: CONSTANTS.TWELVE_HOURS, max: CONSTANTS.TWO_DAY, }); - res.setHeader( - "Cache-Control", - `max-age=${cacheSeconds}, s-maxage=${cacheSeconds}, stale-while-revalidate=${CONSTANTS.ONE_DAY}`, - ); + setCacheHeaders(res, cacheSeconds); return res.send( renderStatsCard(stats, { @@ -144,12 +145,7 @@ export default async (req, res) => { }), ); } catch (err) { - res.setHeader( - "Cache-Control", - `max-age=${CONSTANTS.ERROR_CACHE_SECONDS / 2}, s-maxage=${ - CONSTANTS.ERROR_CACHE_SECONDS - }, stale-while-revalidate=${CONSTANTS.ONE_DAY}`, - ); // Use lower cache period for errors. + setErrorCacheHeaders(res); return res.send( renderError(err.message, err.secondaryMessage, { title_color, diff --git a/api/pin.js b/api/pin.js index 10c52f1f3485c..2907774c543a7 100644 --- a/api/pin.js +++ b/api/pin.js @@ -2,7 +2,11 @@ import { renderRepoCard } from "../src/cards/repo.js"; import { blacklist } from "../src/common/blacklist.js"; -import { resolveCacheSeconds } from "../src/common/cache.js"; +import { + resolveCacheSeconds, + setCacheHeaders, + setErrorCacheHeaders, +} from "../src/common/cache.js"; import { whitelist } from "../src/common/envs.js"; import { CONSTANTS, parseBoolean, renderError } from "../src/common/utils.js"; import { fetchRepo } from "../src/fetchers/repo.js"; @@ -77,16 +81,13 @@ export default async (req, res) => { try { const repoData = await fetchRepo(username, repo); const cacheSeconds = resolveCacheSeconds({ - requested: cache_seconds, + requested: parseInt(cache_seconds, 10), def: CONSTANTS.PIN_CARD_CACHE_SECONDS, min: CONSTANTS.ONE_DAY, max: CONSTANTS.TEN_DAY, }); - res.setHeader( - "Cache-Control", - `max-age=${cacheSeconds}, s-maxage=${cacheSeconds}`, - ); + setCacheHeaders(res, cacheSeconds); return res.send( renderRepoCard(repoData, { @@ -104,12 +105,7 @@ export default async (req, res) => { }), ); } catch (err) { - res.setHeader( - "Cache-Control", - `max-age=${CONSTANTS.ERROR_CACHE_SECONDS / 2}, s-maxage=${ - CONSTANTS.ERROR_CACHE_SECONDS - }, stale-while-revalidate=${CONSTANTS.ONE_DAY}`, - ); // Use lower cache period for errors. + setErrorCacheHeaders(res); return res.send( renderError(err.message, err.secondaryMessage, { title_color, diff --git a/api/top-langs.js b/api/top-langs.js index ce3443ba26c1c..9e7df07fab721 100644 --- a/api/top-langs.js +++ b/api/top-langs.js @@ -2,7 +2,11 @@ import { renderTopLanguages } from "../src/cards/top-languages.js"; import { blacklist } from "../src/common/blacklist.js"; -import { resolveCacheSeconds } from "../src/common/cache.js"; +import { + resolveCacheSeconds, + setCacheHeaders, + setErrorCacheHeaders, +} from "../src/common/cache.js"; import { whitelist } from "../src/common/envs.js"; import { CONSTANTS, @@ -106,16 +110,13 @@ export default async (req, res) => { count_weight, ); const cacheSeconds = resolveCacheSeconds({ - requested: cache_seconds, + requested: parseInt(cache_seconds, 10), def: CONSTANTS.TOP_LANGS_CACHE_SECONDS, min: CONSTANTS.TWO_DAY, max: CONSTANTS.TEN_DAY, }); - res.setHeader( - "Cache-Control", - `max-age=${cacheSeconds / 2}, s-maxage=${cacheSeconds}`, - ); + setCacheHeaders(res, cacheSeconds); return res.send( renderTopLanguages(topLangs, { @@ -139,12 +140,7 @@ export default async (req, res) => { }), ); } catch (err) { - res.setHeader( - "Cache-Control", - `max-age=${CONSTANTS.ERROR_CACHE_SECONDS / 2}, s-maxage=${ - CONSTANTS.ERROR_CACHE_SECONDS - }, stale-while-revalidate=${CONSTANTS.ONE_DAY}`, - ); // Use lower cache period for errors. + setErrorCacheHeaders(res); return res.send( renderError(err.message, err.secondaryMessage, { title_color, diff --git a/api/wakatime.js b/api/wakatime.js index 5aba93ab7e899..e3fedd5df1888 100644 --- a/api/wakatime.js +++ b/api/wakatime.js @@ -10,7 +10,11 @@ import { import { whitelist } from "../src/common/envs.js"; import { fetchWakatimeStats } from "../src/fetchers/wakatime.js"; import { isLocaleAvailable } from "../src/translations.js"; -import { resolveCacheSeconds } from "../src/common/cache.js"; +import { + resolveCacheSeconds, + setCacheHeaders, + setErrorCacheHeaders, +} from "../src/common/cache.js"; export default async (req, res) => { const { @@ -72,18 +76,13 @@ export default async (req, res) => { try { const stats = await fetchWakatimeStats({ username, api_domain }); const cacheSeconds = resolveCacheSeconds({ - requested: cache_seconds, + requested: parseInt(cache_seconds, 10), def: CONSTANTS.CARD_CACHE_SECONDS, min: CONSTANTS.SIX_HOURS, max: CONSTANTS.TWO_DAY, }); - res.setHeader( - "Cache-Control", - `max-age=${ - cacheSeconds / 2 - }, s-maxage=${cacheSeconds}, stale-while-revalidate=${CONSTANTS.ONE_DAY}`, - ); + setCacheHeaders(res, cacheSeconds); return res.send( renderWakatimeCard(stats, { @@ -109,12 +108,7 @@ export default async (req, res) => { }), ); } catch (err) { - res.setHeader( - "Cache-Control", - `max-age=${CONSTANTS.ERROR_CACHE_SECONDS / 2}, s-maxage=${ - CONSTANTS.ERROR_CACHE_SECONDS - }, stale-while-revalidate=${CONSTANTS.ONE_DAY}`, - ); // Use lower cache period for errors. + setErrorCacheHeaders(res); return res.send( renderError(err.message, err.secondaryMessage, { title_color, diff --git a/src/common/cache.js b/src/common/cache.js index b5fd8ce72a573..013c16bc06abd 100644 --- a/src/common/cache.js +++ b/src/common/cache.js @@ -1,4 +1,6 @@ -import { clampValue } from "./utils"; +// @ts-check + +import { clampValue, CONSTANTS } from "./utils.js"; /** * Resolves the cache seconds based on the requested, default, min, and max values. @@ -11,7 +13,7 @@ import { clampValue } from "./utils"; * @returns {number} The resolved cache seconds. */ const resolveCacheSeconds = ({ requested, def, min, max }) => { - let cacheSeconds = clampValue(parseInt(requested || def, 10), min, max); + let cacheSeconds = clampValue(isNaN(requested) ? def : requested, min, max); cacheSeconds = process.env.CACHE_SECONDS ? parseInt(process.env.CACHE_SECONDS, 10) || cacheSeconds @@ -20,4 +22,32 @@ const resolveCacheSeconds = ({ requested, def, min, max }) => { return cacheSeconds; }; -export { resolveCacheSeconds }; +/** + * Sets the Cache-Control headers on the response object. + * + * @param {Object} res The response object. + * @param {number} cacheSeconds The cache seconds to set in the headers. + */ +const setCacheHeaders = (res, cacheSeconds) => { + res.setHeader( + "Cache-Control", + `max-age=${cacheSeconds}, s-maxage=${cacheSeconds}, stale-while-revalidate=${CONSTANTS.ONE_DAY}`, + ); +}; + +/** + * Sets the Cache-Control headers for error responses on the response object. + * + * @param {Object} res The response object. + */ +const setErrorCacheHeaders = (res) => { + // Use lower cache period for errors. + res.setHeader( + "Cache-Control", + `max-age=${CONSTANTS.ERROR_CACHE_SECONDS}, ` + + `s-maxage=${CONSTANTS.ERROR_CACHE_SECONDS}, ` + + `stale-while-revalidate=${CONSTANTS.ONE_DAY}`, + ); +}; + +export { resolveCacheSeconds, setCacheHeaders, setErrorCacheHeaders }; diff --git a/tests/api.test.js b/tests/api.test.js index 44928887d953a..e77775e93006d 100644 --- a/tests/api.test.js +++ b/tests/api.test.js @@ -179,9 +179,9 @@ describe("Test /api/", () => { ["Content-Type", "image/svg+xml"], [ "Cache-Control", - `max-age=${CONSTANTS.CARD_CACHE_SECONDS}, s-maxage=${ - CONSTANTS.CARD_CACHE_SECONDS - }, stale-while-revalidate=${CONSTANTS.ONE_DAY}`, + `max-age=${CONSTANTS.CARD_CACHE_SECONDS}, ` + + `s-maxage=${CONSTANTS.CARD_CACHE_SECONDS}, ` + + `stale-while-revalidate=${CONSTANTS.ONE_DAY}`, ], ]); }); @@ -195,11 +195,9 @@ describe("Test /api/", () => { ["Content-Type", "image/svg+xml"], [ "Cache-Control", - `max-age=${ - cache_seconds - }, s-maxage=${cache_seconds}, stale-while-revalidate=${ - CONSTANTS.ONE_DAY - }`, + `max-age=${cache_seconds}, ` + + `s-maxage=${cache_seconds}, ` + + `stale-while-revalidate=${CONSTANTS.ONE_DAY}`, ], ]); }); @@ -212,25 +210,25 @@ describe("Test /api/", () => { ["Content-Type", "image/svg+xml"], [ "Cache-Control", - `max-age=${CONSTANTS.ERROR_CACHE_SECONDS / 2}, s-maxage=${ - CONSTANTS.ERROR_CACHE_SECONDS - }, stale-while-revalidate=${CONSTANTS.ONE_DAY}`, + `max-age=${CONSTANTS.ERROR_CACHE_SECONDS}, ` + + `s-maxage=${CONSTANTS.ERROR_CACHE_SECONDS}, ` + + `stale-while-revalidate=${CONSTANTS.ONE_DAY}`, ], ]); }); it("should set proper cache with clamped values", async () => { { - let { req, res } = faker({ cache_seconds: 200000 }, data_stats); + let { req, res } = faker({ cache_seconds: 200_000 }, data_stats); await api(req, res); expect(res.setHeader.mock.calls).toEqual([ ["Content-Type", "image/svg+xml"], [ "Cache-Control", - `max-age=${CONSTANTS.TWO_DAY}, s-maxage=${ - CONSTANTS.TWO_DAY - }, stale-while-revalidate=${CONSTANTS.ONE_DAY}`, + `max-age=${CONSTANTS.TWO_DAY}, ` + + `s-maxage=${CONSTANTS.TWO_DAY}, ` + + `stale-while-revalidate=${CONSTANTS.ONE_DAY}`, ], ]); } @@ -244,24 +242,24 @@ describe("Test /api/", () => { ["Content-Type", "image/svg+xml"], [ "Cache-Control", - `max-age=${CONSTANTS.ONE_DAY}, s-maxage=${ - CONSTANTS.ONE_DAY - }, stale-while-revalidate=${CONSTANTS.ONE_DAY}`, + `max-age=${CONSTANTS.TWELVE_HOURS}, ` + + `s-maxage=${CONSTANTS.TWELVE_HOURS}, ` + + `stale-while-revalidate=${CONSTANTS.ONE_DAY}`, ], ]); } { - let { req, res } = faker({ cache_seconds: -10000 }, data_stats); + let { req, res } = faker({ cache_seconds: -10_000 }, data_stats); await api(req, res); expect(res.setHeader.mock.calls).toEqual([ ["Content-Type", "image/svg+xml"], [ "Cache-Control", - `max-age=${CONSTANTS.TWELVE_HOURS}, s-maxage=${ - CONSTANTS.TWELVE_HOURS - }, stale-while-revalidate=${CONSTANTS.ONE_DAY}`, + `max-age=${CONSTANTS.TWELVE_HOURS}, ` + + `s-maxage=${CONSTANTS.TWELVE_HOURS}, ` + + `stale-while-revalidate=${CONSTANTS.ONE_DAY}`, ], ]); } diff --git a/tests/gist.test.js b/tests/gist.test.js index fdbf9cf5fc642..ff336f1fa1407 100644 --- a/tests/gist.test.js +++ b/tests/gist.test.js @@ -188,7 +188,7 @@ describe("Test /api/gist", () => { expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); expect(res.setHeader).toBeCalledWith( "Cache-Control", - `max-age=${CONSTANTS.TWO_DAY}, s-maxage=${CONSTANTS.TWO_DAY}`, + `max-age=${CONSTANTS.TWO_DAY}, s-maxage=${CONSTANTS.TWO_DAY}, stale-while-revalidate=${CONSTANTS.ONE_DAY}`, ); }); }); diff --git a/tests/pin.test.js b/tests/pin.test.js index 15a93b21944dc..10324d44fd191 100644 --- a/tests/pin.test.js +++ b/tests/pin.test.js @@ -224,9 +224,9 @@ describe("Test /api/pin", () => { expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); expect(res.setHeader).toBeCalledWith( "Cache-Control", - `max-age=${CONSTANTS.PIN_CARD_CACHE_SECONDS}, s-maxage=${ - CONSTANTS.PIN_CARD_CACHE_SECONDS - }`, + `max-age=${CONSTANTS.PIN_CARD_CACHE_SECONDS}, ` + + `s-maxage=${CONSTANTS.PIN_CARD_CACHE_SECONDS}, ` + + `stale-while-revalidate=${CONSTANTS.ONE_DAY}`, ); }); }); diff --git a/tests/top-langs.test.js b/tests/top-langs.test.js index c4b0fa9755623..0a51d4e3580c2 100644 --- a/tests/top-langs.test.js +++ b/tests/top-langs.test.js @@ -230,9 +230,9 @@ describe("Test /api/top-langs", () => { expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); expect(res.setHeader).toBeCalledWith( "Cache-Control", - `max-age=${CONSTANTS.TOP_LANGS_CACHE_SECONDS / 2}, s-maxage=${ - CONSTANTS.TOP_LANGS_CACHE_SECONDS - }`, + `max-age=${CONSTANTS.TOP_LANGS_CACHE_SECONDS}, ` + + `s-maxage=${CONSTANTS.TOP_LANGS_CACHE_SECONDS}, ` + + `stale-while-revalidate=${CONSTANTS.ONE_DAY}`, ); }); }); From 195e2fc72d5b59c05c8717514d9be90509080014 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Tue, 7 Oct 2025 21:13:13 +0300 Subject: [PATCH 147/265] refactor: move access guards logic into reusable functions (#4535) * refactor: move access guards logic into reusable functions * Update src/common/access.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --------- Co-authored-by: Alexandr Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --- api/gist.js | 31 +++++++++++----------- api/index.js | 49 +++++++++++------------------------ api/pin.js | 49 +++++++++++------------------------ api/top-langs.js | 49 +++++++++++------------------------ api/wakatime.js | 31 +++++++++++----------- src/common/access.js | 61 ++++++++++++++++++++++++++++++++++++++++++++ 6 files changed, 136 insertions(+), 134 deletions(-) create mode 100644 src/common/access.js diff --git a/api/gist.js b/api/gist.js index 435c6b7289cb6..aab85ba96ab15 100644 --- a/api/gist.js +++ b/api/gist.js @@ -1,7 +1,6 @@ // @ts-check import { CONSTANTS, renderError, parseBoolean } from "../src/common/utils.js"; -import { gistWhitelist } from "../src/common/envs.js"; import { isLocaleAvailable } from "../src/translations.js"; import { renderGistCard } from "../src/cards/gist.js"; import { fetchGist } from "../src/fetchers/gist.js"; @@ -10,6 +9,7 @@ import { setCacheHeaders, setErrorCacheHeaders, } from "../src/common/cache.js"; +import { guardAccess } from "../src/common/access.js"; export default async (req, res) => { const { @@ -29,21 +29,20 @@ export default async (req, res) => { res.setHeader("Content-Type", "image/svg+xml"); - if (gistWhitelist && !gistWhitelist.includes(id)) { - return res.send( - renderError( - "This gist ID is not whitelisted", - "Please deploy your own instance", - { - title_color, - text_color, - bg_color, - border_color, - theme, - show_repo_link: false, - }, - ), - ); + const access = guardAccess({ + res, + id, + type: "gist", + colors: { + title_color, + text_color, + bg_color, + border_color, + theme, + }, + }); + if (!access.isPassed) { + return access.result; } if (locale && !isLocaleAvailable(locale)) { diff --git a/api/index.js b/api/index.js index 88ffd2db67204..a5887fb001060 100644 --- a/api/index.js +++ b/api/index.js @@ -1,13 +1,12 @@ // @ts-check import { renderStatsCard } from "../src/cards/stats.js"; -import { blacklist } from "../src/common/blacklist.js"; +import { guardAccess } from "../src/common/access.js"; import { resolveCacheSeconds, setCacheHeaders, setErrorCacheHeaders, } from "../src/common/cache.js"; -import { whitelist } from "../src/common/envs.js"; import { CONSTANTS, parseArray, @@ -49,38 +48,20 @@ export default async (req, res) => { } = req.query; res.setHeader("Content-Type", "image/svg+xml"); - if (whitelist && !whitelist.includes(username)) { - return res.send( - renderError( - "This username is not whitelisted", - "Please deploy your own instance", - { - title_color, - text_color, - bg_color, - border_color, - theme, - show_repo_link: false, - }, - ), - ); - } - - if (whitelist === undefined && blacklist.includes(username)) { - return res.send( - renderError( - "This username is blacklisted", - "Please deploy your own instance", - { - title_color, - text_color, - bg_color, - border_color, - theme, - show_repo_link: false, - }, - ), - ); + const access = guardAccess({ + res, + id: username, + type: "username", + colors: { + title_color, + text_color, + bg_color, + border_color, + theme, + }, + }); + if (!access.isPassed) { + return access.result; } if (locale && !isLocaleAvailable(locale)) { diff --git a/api/pin.js b/api/pin.js index 2907774c543a7..ebb0d8af4b38b 100644 --- a/api/pin.js +++ b/api/pin.js @@ -1,13 +1,12 @@ // @ts-check import { renderRepoCard } from "../src/cards/repo.js"; -import { blacklist } from "../src/common/blacklist.js"; +import { guardAccess } from "../src/common/access.js"; import { resolveCacheSeconds, setCacheHeaders, setErrorCacheHeaders, } from "../src/common/cache.js"; -import { whitelist } from "../src/common/envs.js"; import { CONSTANTS, parseBoolean, renderError } from "../src/common/utils.js"; import { fetchRepo } from "../src/fetchers/repo.js"; import { isLocaleAvailable } from "../src/translations.js"; @@ -32,38 +31,20 @@ export default async (req, res) => { res.setHeader("Content-Type", "image/svg+xml"); - if (whitelist && !whitelist.includes(username)) { - return res.send( - renderError( - "This username is not whitelisted", - "Please deploy your own instance", - { - title_color, - text_color, - bg_color, - border_color, - theme, - show_repo_link: false, - }, - ), - ); - } - - if (whitelist === undefined && blacklist.includes(username)) { - return res.send( - renderError( - "This username is blacklisted", - "Please deploy your own instance", - { - title_color, - text_color, - bg_color, - border_color, - theme, - show_repo_link: false, - }, - ), - ); + const access = guardAccess({ + res, + id: username, + type: "username", + colors: { + title_color, + text_color, + bg_color, + border_color, + theme, + }, + }); + if (!access.isPassed) { + return access.result; } if (locale && !isLocaleAvailable(locale)) { diff --git a/api/top-langs.js b/api/top-langs.js index 9e7df07fab721..f80528ae2490a 100644 --- a/api/top-langs.js +++ b/api/top-langs.js @@ -1,13 +1,12 @@ // @ts-check import { renderTopLanguages } from "../src/cards/top-languages.js"; -import { blacklist } from "../src/common/blacklist.js"; +import { guardAccess } from "../src/common/access.js"; import { resolveCacheSeconds, setCacheHeaders, setErrorCacheHeaders, } from "../src/common/cache.js"; -import { whitelist } from "../src/common/envs.js"; import { CONSTANTS, parseArray, @@ -44,38 +43,20 @@ export default async (req, res) => { } = req.query; res.setHeader("Content-Type", "image/svg+xml"); - if (whitelist && !whitelist.includes(username)) { - return res.send( - renderError( - "This username is not whitelisted", - "Please deploy your own instance", - { - title_color, - text_color, - bg_color, - border_color, - theme, - show_repo_link: false, - }, - ), - ); - } - - if (whitelist === undefined && blacklist.includes(username)) { - return res.send( - renderError( - "This username is blacklisted", - "Please deploy your own instance", - { - title_color, - text_color, - bg_color, - border_color, - theme, - show_repo_link: false, - }, - ), - ); + const access = guardAccess({ + res, + id: username, + type: "username", + colors: { + title_color, + text_color, + bg_color, + border_color, + theme, + }, + }); + if (!access.isPassed) { + return access.result; } if (locale && !isLocaleAvailable(locale)) { diff --git a/api/wakatime.js b/api/wakatime.js index e3fedd5df1888..9cbf779f88e37 100644 --- a/api/wakatime.js +++ b/api/wakatime.js @@ -7,7 +7,6 @@ import { parseBoolean, renderError, } from "../src/common/utils.js"; -import { whitelist } from "../src/common/envs.js"; import { fetchWakatimeStats } from "../src/fetchers/wakatime.js"; import { isLocaleAvailable } from "../src/translations.js"; import { @@ -15,6 +14,7 @@ import { setCacheHeaders, setErrorCacheHeaders, } from "../src/common/cache.js"; +import { guardAccess } from "../src/common/access.js"; export default async (req, res) => { const { @@ -44,21 +44,20 @@ export default async (req, res) => { res.setHeader("Content-Type", "image/svg+xml"); - if (whitelist && !whitelist.includes(username)) { - return res.send( - renderError( - "This username is not whitelisted", - "Please deploy your own instance", - { - title_color, - text_color, - bg_color, - border_color, - theme, - show_repo_link: false, - }, - ), - ); + const access = guardAccess({ + res, + id: username, + type: "wakatime", + colors: { + title_color, + text_color, + bg_color, + border_color, + theme, + }, + }); + if (!access.isPassed) { + return access.result; } if (locale && !isLocaleAvailable(locale)) { diff --git a/src/common/access.js b/src/common/access.js new file mode 100644 index 0000000000000..959e17afcaea5 --- /dev/null +++ b/src/common/access.js @@ -0,0 +1,61 @@ +// @ts-check + +import { renderError } from "./utils.js"; +import { blacklist } from "./blacklist.js"; +import { whitelist, gistWhitelist } from "./envs.js"; + +const NOT_WHITELISTED_USERNAME_MESSAGE = "This username is not whitelisted"; +const NOT_WHITELISTED_GIST_MESSAGE = "This gist ID is not whitelisted"; +const BLACKLISTED_MESSAGE = "This username is blacklisted"; + +/** + * Guards access using whitelist/blacklist. + * + * @param {Object} args The parameters object. + * @param {Object} args.res The response object. + * @param {string} args.id Resource identifier (username or gist id). + * @param {"username"|"gist"|"wakatime"} args.type The type of identifier. + * @param {{ title_color?: string, text_color?: string, bg_color?: string, border_color?: string, theme?: string }} args.colors Color options for the error card. + * @returns {{ isPassed: boolean, result?: any }} The result object indicating success or failure. + */ +const guardAccess = ({ res, id, type, colors }) => { + if (!["username", "gist", "wakatime"].includes(type)) { + throw new Error( + 'Invalid type. Expected "username", "gist", or "wakatime".', + ); + } + + const currentWhitelist = type === "gist" ? gistWhitelist : whitelist; + const notWhitelistedMsg = + type === "gist" + ? NOT_WHITELISTED_GIST_MESSAGE + : NOT_WHITELISTED_USERNAME_MESSAGE; + + if (Array.isArray(currentWhitelist) && !currentWhitelist.includes(id)) { + const result = res.send( + renderError(notWhitelistedMsg, "Please deploy your own instance", { + ...colors, + show_repo_link: false, + }), + ); + return { isPassed: false, result }; + } + + if ( + type === "username" && + currentWhitelist === undefined && + blacklist.includes(id) + ) { + const result = res.send( + renderError(BLACKLISTED_MESSAGE, "Please deploy your own instance", { + ...colors, + show_repo_link: false, + }), + ); + return { isPassed: false, result }; + } + + return { isPassed: true }; +}; + +export { guardAccess }; From f7920901b67021abedb7c3195e086b0a328fe488 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Tue, 7 Oct 2025 22:44:33 +0300 Subject: [PATCH 148/265] refactor: improve cache control headers formatting (#4536) Co-authored-by: Alexandr --- src/common/cache.js | 4 +++- tests/gist.test.js | 4 +++- 2 files changed, 6 insertions(+), 2 deletions(-) diff --git a/src/common/cache.js b/src/common/cache.js index 013c16bc06abd..c39a4b5d0e3ac 100644 --- a/src/common/cache.js +++ b/src/common/cache.js @@ -31,7 +31,9 @@ const resolveCacheSeconds = ({ requested, def, min, max }) => { const setCacheHeaders = (res, cacheSeconds) => { res.setHeader( "Cache-Control", - `max-age=${cacheSeconds}, s-maxage=${cacheSeconds}, stale-while-revalidate=${CONSTANTS.ONE_DAY}`, + `max-age=${cacheSeconds}, ` + + `s-maxage=${cacheSeconds}, ` + + `stale-while-revalidate=${CONSTANTS.ONE_DAY}`, ); }; diff --git a/tests/gist.test.js b/tests/gist.test.js index ff336f1fa1407..d6cd5621a34ad 100644 --- a/tests/gist.test.js +++ b/tests/gist.test.js @@ -188,7 +188,9 @@ describe("Test /api/gist", () => { expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); expect(res.setHeader).toBeCalledWith( "Cache-Control", - `max-age=${CONSTANTS.TWO_DAY}, s-maxage=${CONSTANTS.TWO_DAY}, stale-while-revalidate=${CONSTANTS.ONE_DAY}`, + `max-age=${CONSTANTS.TWO_DAY}, ` + + `s-maxage=${CONSTANTS.TWO_DAY}, ` + + `stale-while-revalidate=${CONSTANTS.ONE_DAY}`, ); }); }); From e9d0e8fd174f84fcac17be610f6d46dea0020f59 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Tue, 7 Oct 2025 23:21:18 +0300 Subject: [PATCH 149/265] refactor: named arguments for render error function (#4537) * refactor: named arguments for render error function * Update tests/api.test.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --------- Co-authored-by: Alexandr Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --- api/gist.js | 32 +++++++++++++++++----------- api/index.js | 32 +++++++++++++++++----------- api/pin.js | 32 +++++++++++++++++----------- api/top-langs.js | 33 +++++++++++++++++++++-------- api/wakatime.js | 32 +++++++++++++++++----------- src/common/access.js | 20 ++++++++++++------ src/common/utils.js | 27 +++++++++++++---------- tests/api.test.js | 47 ++++++++++++++++++++++++++--------------- tests/gist.test.js | 17 +++++++++------ tests/pin.test.js | 34 ++++++++++++++++++----------- tests/top-langs.test.js | 31 +++++++++++++++++---------- tests/utils.test.js | 10 ++++----- 12 files changed, 222 insertions(+), 125 deletions(-) diff --git a/api/gist.js b/api/gist.js index aab85ba96ab15..7c5f9e6844838 100644 --- a/api/gist.js +++ b/api/gist.js @@ -47,12 +47,16 @@ export default async (req, res) => { if (locale && !isLocaleAvailable(locale)) { return res.send( - renderError("Something went wrong", "Language not found", { - title_color, - text_color, - bg_color, - border_color, - theme, + renderError({ + message: "Something went wrong", + secondaryMessage: "Language not found", + renderOptions: { + title_color, + text_color, + bg_color, + border_color, + theme, + }, }), ); } @@ -85,12 +89,16 @@ export default async (req, res) => { } catch (err) { setErrorCacheHeaders(res); return res.send( - renderError(err.message, err.secondaryMessage, { - title_color, - text_color, - bg_color, - border_color, - theme, + renderError({ + message: err.message, + secondaryMessage: err.secondaryMessage, + renderOptions: { + title_color, + text_color, + bg_color, + border_color, + theme, + }, }), ); } diff --git a/api/index.js b/api/index.js index a5887fb001060..37a298412a7bd 100644 --- a/api/index.js +++ b/api/index.js @@ -66,12 +66,16 @@ export default async (req, res) => { if (locale && !isLocaleAvailable(locale)) { return res.send( - renderError("Something went wrong", "Language not found", { - title_color, - text_color, - bg_color, - border_color, - theme, + renderError({ + message: "Something went wrong", + secondaryMessage: "Language not found", + renderOptions: { + title_color, + text_color, + bg_color, + border_color, + theme, + }, }), ); } @@ -128,12 +132,16 @@ export default async (req, res) => { } catch (err) { setErrorCacheHeaders(res); return res.send( - renderError(err.message, err.secondaryMessage, { - title_color, - text_color, - bg_color, - border_color, - theme, + renderError({ + message: err.message, + secondaryMessage: err.secondaryMessage, + renderOptions: { + title_color, + text_color, + bg_color, + border_color, + theme, + }, }), ); } diff --git a/api/pin.js b/api/pin.js index ebb0d8af4b38b..2183c8f199e08 100644 --- a/api/pin.js +++ b/api/pin.js @@ -49,12 +49,16 @@ export default async (req, res) => { if (locale && !isLocaleAvailable(locale)) { return res.send( - renderError("Something went wrong", "Language not found", { - title_color, - text_color, - bg_color, - border_color, - theme, + renderError({ + message: "Something went wrong", + secondaryMessage: "Language not found", + renderOptions: { + title_color, + text_color, + bg_color, + border_color, + theme, + }, }), ); } @@ -88,12 +92,16 @@ export default async (req, res) => { } catch (err) { setErrorCacheHeaders(res); return res.send( - renderError(err.message, err.secondaryMessage, { - title_color, - text_color, - bg_color, - border_color, - theme, + renderError({ + message: err.message, + secondaryMessage: err.secondaryMessage, + renderOptions: { + title_color, + text_color, + bg_color, + border_color, + theme, + }, }), ); } diff --git a/api/top-langs.js b/api/top-langs.js index f80528ae2490a..d4b51c6bef8ea 100644 --- a/api/top-langs.js +++ b/api/top-langs.js @@ -60,7 +60,12 @@ export default async (req, res) => { } if (locale && !isLocaleAvailable(locale)) { - return res.send(renderError("Something went wrong", "Locale not found")); + return res.send( + renderError({ + message: "Something went wrong", + secondaryMessage: "Locale not found", + }), + ); } if ( @@ -69,7 +74,10 @@ export default async (req, res) => { !["compact", "normal", "donut", "donut-vertical", "pie"].includes(layout)) ) { return res.send( - renderError("Something went wrong", "Incorrect layout input"), + renderError({ + message: "Something went wrong", + secondaryMessage: "Incorrect layout input", + }), ); } @@ -79,7 +87,10 @@ export default async (req, res) => { !["bytes", "percentages"].includes(stats_format)) ) { return res.send( - renderError("Something went wrong", "Incorrect stats_format input"), + renderError({ + message: "Something went wrong", + secondaryMessage: "Incorrect stats_format input", + }), ); } @@ -123,12 +134,16 @@ export default async (req, res) => { } catch (err) { setErrorCacheHeaders(res); return res.send( - renderError(err.message, err.secondaryMessage, { - title_color, - text_color, - bg_color, - border_color, - theme, + renderError({ + message: err.message, + secondaryMessage: err.secondaryMessage, + renderOptions: { + title_color, + text_color, + bg_color, + border_color, + theme, + }, }), ); } diff --git a/api/wakatime.js b/api/wakatime.js index 9cbf779f88e37..7b5571ebdd04d 100644 --- a/api/wakatime.js +++ b/api/wakatime.js @@ -62,12 +62,16 @@ export default async (req, res) => { if (locale && !isLocaleAvailable(locale)) { return res.send( - renderError("Something went wrong", "Language not found", { - title_color, - text_color, - bg_color, - border_color, - theme, + renderError({ + message: "Something went wrong", + secondaryMessage: "Language not found", + renderOptions: { + title_color, + text_color, + bg_color, + border_color, + theme, + }, }), ); } @@ -109,12 +113,16 @@ export default async (req, res) => { } catch (err) { setErrorCacheHeaders(res); return res.send( - renderError(err.message, err.secondaryMessage, { - title_color, - text_color, - bg_color, - border_color, - theme, + renderError({ + message: err.message, + secondaryMessage: err.secondaryMessage, + renderOptions: { + title_color, + text_color, + bg_color, + border_color, + theme, + }, }), ); } diff --git a/src/common/access.js b/src/common/access.js index 959e17afcaea5..5b15dc5db652b 100644 --- a/src/common/access.js +++ b/src/common/access.js @@ -33,9 +33,13 @@ const guardAccess = ({ res, id, type, colors }) => { if (Array.isArray(currentWhitelist) && !currentWhitelist.includes(id)) { const result = res.send( - renderError(notWhitelistedMsg, "Please deploy your own instance", { - ...colors, - show_repo_link: false, + renderError({ + message: notWhitelistedMsg, + secondaryMessage: "Please deploy your own instance", + renderOptions: { + ...colors, + show_repo_link: false, + }, }), ); return { isPassed: false, result }; @@ -47,9 +51,13 @@ const guardAccess = ({ res, id, type, colors }) => { blacklist.includes(id) ) { const result = res.send( - renderError(BLACKLISTED_MESSAGE, "Please deploy your own instance", { - ...colors, - show_repo_link: false, + renderError({ + message: BLACKLISTED_MESSAGE, + secondaryMessage: "Please deploy your own instance", + renderOptions: { + ...colors, + show_repo_link: false, + }, }), ); return { isPassed: false, result }; diff --git a/src/common/utils.js b/src/common/utils.js index 04b02e2c8215f..3dac650bc65e2 100644 --- a/src/common/utils.js +++ b/src/common/utils.js @@ -352,18 +352,23 @@ const UPSTREAM_API_ERRORS = [ /** * Renders error message on the card. * - * @param {string} message Main error message. - * @param {string} secondaryMessage The secondary error message. - * @param {object} options Function options. - * @param {string=} options.title_color Card title color. - * @param {string=} options.text_color Card text color. - * @param {string=} options.bg_color Card background color. - * @param {string=} options.border_color Card border color. - * @param {string=} options.theme Card theme. - * @param {boolean=} options.show_repo_link Whether to show repo link or not. + * @param {object} args Function arguments. + * @param {string} args.message Main error message. + * @param {string} [args.secondaryMessage=""] The secondary error message. + * @param {object} [args.renderOptions={}] Render options. + * @param {string=} args.renderOptions.title_color Card title color. + * @param {string=} args.renderOptions.text_color Card text color. + * @param {string=} args.renderOptions.bg_color Card background color. + * @param {string=} args.renderOptions.border_color Card border color. + * @param {string=} args.renderOptions.theme Card theme. + * @param {boolean=} args.renderOptions.show_repo_link Whether to show repo link or not. * @returns {string} The SVG markup. */ -const renderError = (message, secondaryMessage = "", options = {}) => { +const renderError = ({ + message, + secondaryMessage = "", + renderOptions = {}, +}) => { const { title_color, text_color, @@ -371,7 +376,7 @@ const renderError = (message, secondaryMessage = "", options = {}) => { border_color, theme = "default", show_repo_link = true, - } = options; + } = renderOptions; // returns theme based colors with proper overrides and defaults const { titleColor, textColor, bgColor, borderColor } = getCardColors({ diff --git a/tests/api.test.js b/tests/api.test.js index e77775e93006d..2b4f83c999773 100644 --- a/tests/api.test.js +++ b/tests/api.test.js @@ -1,3 +1,5 @@ +// @ts-check + import { jest } from "@jest/globals"; import axios from "axios"; import MockAdapter from "axios-mock-adapter"; @@ -7,6 +9,9 @@ import { renderStatsCard } from "../src/cards/stats.js"; import { CONSTANTS, renderError } from "../src/common/utils.js"; import { expect, it, describe, afterEach } from "@jest/globals"; +/** + * @type {import("../src/fetchers/stats").StatsData} + */ const stats = { name: "Anurag Hazra", totalStars: 100, @@ -19,7 +24,7 @@ const stats = { totalDiscussionsStarted: 10, totalDiscussionsAnswered: 40, contributedTo: 50, - rank: null, + rank: { level: "DEV", percentile: 0 }, }; stats.rank = calculateRank({ @@ -115,10 +120,11 @@ describe("Test /api/", () => { expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); expect(res.send).toBeCalledWith( - renderError( - error.errors[0].message, - "Make sure the provided username is not an organization", - ), + renderError({ + message: error.errors[0].message, + secondaryMessage: + "Make sure the provided username is not an organization", + }), ); }); @@ -129,11 +135,12 @@ describe("Test /api/", () => { expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); expect(res.send).toBeCalledWith( - renderError( - error.errors[0].message, - "Make sure the provided username is not an organization", - { theme: "merko" }, - ), + renderError({ + message: error.errors[0].message, + secondaryMessage: + "Make sure the provided username is not an organization", + renderOptions: { theme: "merko" }, + }), ); }); @@ -307,11 +314,11 @@ describe("Test /api/", () => { expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); expect(res.send).toBeCalledWith( - renderError( - "This username is blacklisted", - "Please deploy your own instance", - { show_repo_link: false }, - ), + renderError({ + message: "This username is blacklisted", + secondaryMessage: "Please deploy your own instance", + renderOptions: { show_repo_link: false }, + }), ); }); @@ -322,7 +329,10 @@ describe("Test /api/", () => { expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); expect(res.send).toBeCalledWith( - renderError("Something went wrong", "Language not found"), + renderError({ + message: "Something went wrong", + secondaryMessage: "Language not found", + }), ); }); @@ -340,7 +350,10 @@ describe("Test /api/", () => { expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); expect(res.send).toBeCalledWith( - renderError("Could not fetch total commits.", "Please try again later"), + renderError({ + message: "Could not fetch total commits.", + secondaryMessage: "Please try again later", + }), ); // Received SVG output should not contain string "https://tiny.one/readme-stats" expect(res.send.mock.calls[0][0]).not.toContain( diff --git a/tests/gist.test.js b/tests/gist.test.js index d6cd5621a34ad..bfe5d77494eff 100644 --- a/tests/gist.test.js +++ b/tests/gist.test.js @@ -1,3 +1,5 @@ +// @ts-check + import { jest } from "@jest/globals"; import "@testing-library/jest-dom"; import axios from "axios"; @@ -124,10 +126,10 @@ describe("Test /api/gist", () => { expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); expect(res.send).toBeCalledWith( - renderError( - 'Missing params "id" make sure you pass the parameters in URL', - "/api/gist?id=GIST_ID", - ), + renderError({ + message: 'Missing params "id" make sure you pass the parameters in URL', + secondaryMessage: "/api/gist?id=GIST_ID", + }), ); }); @@ -148,7 +150,7 @@ describe("Test /api/gist", () => { await gist(req, res); expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); - expect(res.send).toBeCalledWith(renderError("Gist not found")); + expect(res.send).toBeCalledWith(renderError({ message: "Gist not found" })); }); it("should render error if wrong locale is provided", async () => { @@ -167,7 +169,10 @@ describe("Test /api/gist", () => { expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); expect(res.send).toBeCalledWith( - renderError("Something went wrong", "Language not found"), + renderError({ + message: "Something went wrong", + secondaryMessage: "Language not found", + }), ); }); diff --git a/tests/pin.test.js b/tests/pin.test.js index 10324d44fd191..88e431654f449 100644 --- a/tests/pin.test.js +++ b/tests/pin.test.js @@ -1,3 +1,5 @@ +// @ts-check + import { jest } from "@jest/globals"; import "@testing-library/jest-dom"; import axios from "axios"; @@ -56,6 +58,7 @@ describe("Test /api/pin", () => { expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); expect(res.send).toBeCalledWith( + // @ts-ignore renderRepoCard({ ...data_repo.repository, starCount: data_repo.repository.stargazers.totalCount, @@ -86,6 +89,7 @@ describe("Test /api/pin", () => { expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); expect(res.send).toBeCalledWith( renderRepoCard( + // @ts-ignore { ...data_repo.repository, starCount: data_repo.repository.stargazers.totalCount, @@ -113,7 +117,9 @@ describe("Test /api/pin", () => { await pin(req, res); expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); - expect(res.send).toBeCalledWith(renderError("User Repository Not found")); + expect(res.send).toBeCalledWith( + renderError({ message: "User Repository Not found" }), + ); }); it("should render error card if org repo not found", async () => { @@ -135,7 +141,7 @@ describe("Test /api/pin", () => { expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); expect(res.send).toBeCalledWith( - renderError("Organization Repository Not found"), + renderError({ message: "Organization Repository Not found" }), ); }); @@ -156,11 +162,11 @@ describe("Test /api/pin", () => { expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); expect(res.send).toBeCalledWith( - renderError( - "This username is blacklisted", - "Please deploy your own instance", - { show_repo_link: false }, - ), + renderError({ + message: "This username is blacklisted", + secondaryMessage: "Please deploy your own instance", + renderOptions: { show_repo_link: false }, + }), ); }); @@ -182,7 +188,10 @@ describe("Test /api/pin", () => { expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); expect(res.send).toBeCalledWith( - renderError("Something went wrong", "Language not found"), + renderError({ + message: "Something went wrong", + secondaryMessage: "Language not found", + }), ); }); @@ -199,10 +208,11 @@ describe("Test /api/pin", () => { expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); expect(res.send).toBeCalledWith( - renderError( - 'Missing params "username", "repo" make sure you pass the parameters in URL', - "/api/pin?username=USERNAME&repo=REPO_NAME", - ), + renderError({ + message: + 'Missing params "username", "repo" make sure you pass the parameters in URL', + secondaryMessage: "/api/pin?username=USERNAME&repo=REPO_NAME", + }), ); }); diff --git a/tests/top-langs.test.js b/tests/top-langs.test.js index 0a51d4e3580c2..cdd47d72c79af 100644 --- a/tests/top-langs.test.js +++ b/tests/top-langs.test.js @@ -1,3 +1,5 @@ +// @ts-check + import { jest } from "@jest/globals"; import "@testing-library/jest-dom"; import axios from "axios"; @@ -140,10 +142,11 @@ describe("Test /api/top-langs", () => { expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); expect(res.send).toBeCalledWith( - renderError( - error.errors[0].message, - "Make sure the provided username is not an organization", - ), + renderError({ + message: error.errors[0].message, + secondaryMessage: + "Make sure the provided username is not an organization", + }), ); }); @@ -164,7 +167,10 @@ describe("Test /api/top-langs", () => { expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); expect(res.send).toBeCalledWith( - renderError("Something went wrong", "Incorrect layout input"), + renderError({ + message: "Something went wrong", + secondaryMessage: "Incorrect layout input", + }), ); }); @@ -184,11 +190,11 @@ describe("Test /api/top-langs", () => { expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); expect(res.send).toBeCalledWith( - renderError( - "This username is blacklisted", - "Please deploy your own instance", - { show_repo_link: false }, - ), + renderError({ + message: "This username is blacklisted", + secondaryMessage: "Please deploy your own instance", + renderOptions: { show_repo_link: false }, + }), ); }); @@ -209,7 +215,10 @@ describe("Test /api/top-langs", () => { expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); expect(res.send).toBeCalledWith( - renderError("Something went wrong", "Locale not found"), + renderError({ + message: "Something went wrong", + secondaryMessage: "Locale not found", + }), ); }); diff --git a/tests/utils.test.js b/tests/utils.test.js index 7277b95d4d2cb..ad72b8c5b7655 100644 --- a/tests/utils.test.js +++ b/tests/utils.test.js @@ -46,7 +46,7 @@ describe("Test utils.js", () => { }); it("should test renderError", () => { - document.body.innerHTML = renderError("Something went wrong"); + document.body.innerHTML = renderError({ message: "Something went wrong" }); expect( queryByTestId(document.body, "message").children[0], ).toHaveTextContent(/Something went wrong/gim); @@ -55,10 +55,10 @@ describe("Test utils.js", () => { ).toBeEmptyDOMElement(2); // Secondary message - document.body.innerHTML = renderError( - "Something went wrong", - "Secondary Message", - ); + document.body.innerHTML = renderError({ + message: "Something went wrong", + secondaryMessage: "Secondary Message", + }); expect( queryByTestId(document.body, "message").children[1], ).toHaveTextContent(/Secondary Message/gim); From 66764616faffae43efca9a0c2c1001ba33fb6d20 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Tue, 7 Oct 2025 23:32:56 +0300 Subject: [PATCH 150/265] fix: ensure top langs error card dont ignore customization options (#4538) Co-authored-by: Alexandr --- api/top-langs.js | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) diff --git a/api/top-langs.js b/api/top-langs.js index d4b51c6bef8ea..3e90342831b39 100644 --- a/api/top-langs.js +++ b/api/top-langs.js @@ -64,6 +64,13 @@ export default async (req, res) => { renderError({ message: "Something went wrong", secondaryMessage: "Locale not found", + renderOptions: { + title_color, + text_color, + bg_color, + border_color, + theme, + }, }), ); } @@ -77,6 +84,13 @@ export default async (req, res) => { renderError({ message: "Something went wrong", secondaryMessage: "Incorrect layout input", + renderOptions: { + title_color, + text_color, + bg_color, + border_color, + theme, + }, }), ); } @@ -90,6 +104,13 @@ export default async (req, res) => { renderError({ message: "Something went wrong", secondaryMessage: "Incorrect stats_format input", + renderOptions: { + title_color, + text_color, + bg_color, + border_color, + theme, + }, }), ); } From e8e5cf86fba90f36735372006fad12f8ea4c9b69 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Wed, 8 Oct 2025 01:19:54 +0300 Subject: [PATCH 151/265] feat: disable cache with proper headers when CACHE_SECONDS env is zero (#4539) * feat: disable cache with proper headers when CACHE_SECONDS env is zero * Update src/common/cache.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --------- Co-authored-by: Alexandr Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --- src/common/cache.js | 37 ++++++++++++++++++++++++++++++++++--- tests/api.test.js | 38 +++++++++++++++++++++++++++++++++++++- 2 files changed, 71 insertions(+), 4 deletions(-) diff --git a/src/common/cache.js b/src/common/cache.js index c39a4b5d0e3ac..a4e6811304e70 100644 --- a/src/common/cache.js +++ b/src/common/cache.js @@ -15,13 +15,31 @@ import { clampValue, CONSTANTS } from "./utils.js"; const resolveCacheSeconds = ({ requested, def, min, max }) => { let cacheSeconds = clampValue(isNaN(requested) ? def : requested, min, max); - cacheSeconds = process.env.CACHE_SECONDS - ? parseInt(process.env.CACHE_SECONDS, 10) || cacheSeconds - : cacheSeconds; + if (process.env.CACHE_SECONDS) { + const envCacheSeconds = parseInt(process.env.CACHE_SECONDS, 10); + if (!isNaN(envCacheSeconds)) { + cacheSeconds = envCacheSeconds; + } + } return cacheSeconds; }; +/** + * Disables caching by setting appropriate headers on the response object. + * + * @param {Object} res The response object. + */ +const disableCaching = (res) => { + // Disable caching for browsers, shared caches/CDNs, and GitHub Camo. + res.setHeader( + "Cache-Control", + "no-cache, no-store, must-revalidate, max-age=0, s-maxage=0", + ); + res.setHeader("Pragma", "no-cache"); + res.setHeader("Expires", "0"); +}; + /** * Sets the Cache-Control headers on the response object. * @@ -29,6 +47,11 @@ const resolveCacheSeconds = ({ requested, def, min, max }) => { * @param {number} cacheSeconds The cache seconds to set in the headers. */ const setCacheHeaders = (res, cacheSeconds) => { + if (cacheSeconds < 1) { + disableCaching(res); + return; + } + res.setHeader( "Cache-Control", `max-age=${cacheSeconds}, ` + @@ -43,6 +66,14 @@ const setCacheHeaders = (res, cacheSeconds) => { * @param {Object} res The response object. */ const setErrorCacheHeaders = (res) => { + const envCacheSeconds = process.env.CACHE_SECONDS + ? parseInt(process.env.CACHE_SECONDS, 10) + : NaN; + if (!isNaN(envCacheSeconds) && envCacheSeconds < 1) { + disableCaching(res); + return; + } + // Use lower cache period for errors. res.setHeader( "Cache-Control", diff --git a/tests/api.test.js b/tests/api.test.js index 2b4f83c999773..bd2554550d7c1 100644 --- a/tests/api.test.js +++ b/tests/api.test.js @@ -1,6 +1,6 @@ // @ts-check -import { jest } from "@jest/globals"; +import { beforeEach, jest } from "@jest/globals"; import axios from "axios"; import MockAdapter from "axios-mock-adapter"; import api from "../api/index.js"; @@ -99,6 +99,10 @@ const faker = (query, data) => { return { req, res }; }; +beforeEach(() => { + process.env.CACHE_SECONDS = undefined; +}); + afterEach(() => { mock.reset(); }); @@ -224,6 +228,38 @@ describe("Test /api/", () => { ]); }); + it("should properly set cache using CACHE_SECONDS env variable", async () => { + process.env.CACHE_SECONDS = "10000"; + + const { req, res } = faker({}, data_stats); + await api(req, res); + + expect(res.setHeader.mock.calls).toEqual([ + ["Content-Type", "image/svg+xml"], + [ + "Cache-Control", + `max-age=10000, s-maxage=10000, stale-while-revalidate=${CONSTANTS.ONE_DAY}`, + ], + ]); + }); + + it("should disable cache when CACHE_SECONDS is set to 0", async () => { + process.env.CACHE_SECONDS = "0"; + + const { req, res } = faker({}, data_stats); + await api(req, res); + + expect(res.setHeader.mock.calls).toEqual([ + ["Content-Type", "image/svg+xml"], + [ + "Cache-Control", + "no-cache, no-store, must-revalidate, max-age=0, s-maxage=0", + ], + ["Pragma", "no-cache"], + ["Expires", "0"], + ]); + }); + it("should set proper cache with clamped values", async () => { { let { req, res } = faker({ cache_seconds: 200_000 }, data_stats); From e9cc6c0556088a84ce4233ef258cefd93e03f85a Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Wed, 8 Oct 2025 01:27:15 +0300 Subject: [PATCH 152/265] chore: configure tab size for javascript in vscode settings (#4540) Co-authored-by: Alexandr --- .vscode/settings.json | 3 +++ 1 file changed, 3 insertions(+) diff --git a/.vscode/settings.json b/.vscode/settings.json index 761ce7a6b370d..9e14194621dad 100644 --- a/.vscode/settings.json +++ b/.vscode/settings.json @@ -2,4 +2,7 @@ "markdown.extension.toc.levels": "1..3", "editor.formatOnSave": true, "editor.defaultFormatter": "esbenp.prettier-vscode", + "[javascript]": { + "editor.tabSize": 2 + } } From 12caf46c6d43a04ce172033ef423f184b53cc3d3 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Wed, 8 Oct 2025 01:42:04 +0300 Subject: [PATCH 153/265] fix: remove duplicate jest globals imports inside tests files (#4541) Co-authored-by: Alexandr --- tests/api.test.js | 10 ++++++++-- tests/gist.test.js | 3 +-- tests/pat-info.test.js | 10 ++++++++-- tests/pin.test.js | 3 +-- tests/retryer.test.js | 3 +-- tests/status.up.test.js | 4 ++-- tests/top-langs.test.js | 3 +-- tests/wakatime.test.js | 3 +-- 8 files changed, 23 insertions(+), 16 deletions(-) diff --git a/tests/api.test.js b/tests/api.test.js index bd2554550d7c1..b20fa69831193 100644 --- a/tests/api.test.js +++ b/tests/api.test.js @@ -1,13 +1,19 @@ // @ts-check -import { beforeEach, jest } from "@jest/globals"; import axios from "axios"; import MockAdapter from "axios-mock-adapter"; import api from "../api/index.js"; import { calculateRank } from "../src/calculateRank.js"; import { renderStatsCard } from "../src/cards/stats.js"; import { CONSTANTS, renderError } from "../src/common/utils.js"; -import { expect, it, describe, afterEach } from "@jest/globals"; +import { + expect, + it, + describe, + afterEach, + beforeEach, + jest, +} from "@jest/globals"; /** * @type {import("../src/fetchers/stats").StatsData} diff --git a/tests/gist.test.js b/tests/gist.test.js index bfe5d77494eff..98670adc1a926 100644 --- a/tests/gist.test.js +++ b/tests/gist.test.js @@ -1,10 +1,9 @@ // @ts-check -import { jest } from "@jest/globals"; import "@testing-library/jest-dom"; import axios from "axios"; import MockAdapter from "axios-mock-adapter"; -import { expect, it, describe, afterEach } from "@jest/globals"; +import { expect, it, describe, afterEach, jest } from "@jest/globals"; import { renderGistCard } from "../src/cards/gist.js"; import { CONSTANTS, renderError } from "../src/common/utils.js"; import gist from "../api/gist.js"; diff --git a/tests/pat-info.test.js b/tests/pat-info.test.js index 6c71d401c38f3..0f8783df7b13f 100644 --- a/tests/pat-info.test.js +++ b/tests/pat-info.test.js @@ -4,11 +4,17 @@ import dotenv from "dotenv"; dotenv.config(); -import { jest } from "@jest/globals"; import axios from "axios"; import MockAdapter from "axios-mock-adapter"; import patInfo, { RATE_LIMIT_SECONDS } from "../api/status/pat-info.js"; -import { expect, it, describe, afterEach, beforeAll } from "@jest/globals"; +import { + expect, + it, + describe, + afterEach, + beforeAll, + jest, +} from "@jest/globals"; const mock = new MockAdapter(axios); diff --git a/tests/pin.test.js b/tests/pin.test.js index 88e431654f449..34212649337bd 100644 --- a/tests/pin.test.js +++ b/tests/pin.test.js @@ -1,13 +1,12 @@ // @ts-check -import { jest } from "@jest/globals"; import "@testing-library/jest-dom"; import axios from "axios"; import MockAdapter from "axios-mock-adapter"; import pin from "../api/pin.js"; import { renderRepoCard } from "../src/cards/repo.js"; import { CONSTANTS, renderError } from "../src/common/utils.js"; -import { expect, it, describe, afterEach } from "@jest/globals"; +import { expect, it, describe, afterEach, jest } from "@jest/globals"; const data_repo = { repository: { diff --git a/tests/retryer.test.js b/tests/retryer.test.js index 76630039d5017..e231a366e1d90 100644 --- a/tests/retryer.test.js +++ b/tests/retryer.test.js @@ -1,8 +1,7 @@ -import { jest } from "@jest/globals"; import "@testing-library/jest-dom"; import { retryer, RETRIES } from "../src/common/retryer.js"; import { logger } from "../src/common/utils.js"; -import { expect, it, describe } from "@jest/globals"; +import { expect, it, describe, jest } from "@jest/globals"; const fetcher = jest.fn((variables, token) => { logger.log(variables, token); diff --git a/tests/status.up.test.js b/tests/status.up.test.js index f15b96fb1eb37..f7c0869239e35 100644 --- a/tests/status.up.test.js +++ b/tests/status.up.test.js @@ -1,11 +1,11 @@ /** * @file Tests for the status/up cloud function. */ -import { jest } from "@jest/globals"; + import axios from "axios"; import MockAdapter from "axios-mock-adapter"; import up, { RATE_LIMIT_SECONDS } from "../api/status/up.js"; -import { expect, it, describe, afterEach } from "@jest/globals"; +import { expect, it, describe, afterEach, jest } from "@jest/globals"; const mock = new MockAdapter(axios); diff --git a/tests/top-langs.test.js b/tests/top-langs.test.js index cdd47d72c79af..1e48ccfd0442e 100644 --- a/tests/top-langs.test.js +++ b/tests/top-langs.test.js @@ -1,13 +1,12 @@ // @ts-check -import { jest } from "@jest/globals"; import "@testing-library/jest-dom"; import axios from "axios"; import MockAdapter from "axios-mock-adapter"; import topLangs from "../api/top-langs.js"; import { renderTopLanguages } from "../src/cards/top-languages.js"; import { CONSTANTS, renderError } from "../src/common/utils.js"; -import { expect, it, describe, afterEach } from "@jest/globals"; +import { expect, it, describe, afterEach, jest } from "@jest/globals"; const data_langs = { data: { diff --git a/tests/wakatime.test.js b/tests/wakatime.test.js index ade0dc2b96e54..8afdecf1c3282 100644 --- a/tests/wakatime.test.js +++ b/tests/wakatime.test.js @@ -1,10 +1,9 @@ -import { jest } from "@jest/globals"; import "@testing-library/jest-dom"; import axios from "axios"; import MockAdapter from "axios-mock-adapter"; import wakatime from "../api/wakatime.js"; import { renderWakatimeCard } from "../src/cards/wakatime.js"; -import { expect, it, describe, afterEach } from "@jest/globals"; +import { expect, it, describe, afterEach, jest } from "@jest/globals"; const wakaTimeData = { data: { From 879463b14eb5e361dcca557d844f37287c52654b Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Wed, 8 Oct 2025 01:58:06 +0300 Subject: [PATCH 154/265] refactor: organize imports inside tests files (#4542) Co-authored-by: Alexandr --- tests/api.test.js | 16 ++++++++-------- tests/calculateRank.test.js | 2 +- tests/card.test.js | 2 +- tests/e2e/e2e.test.js | 4 ++-- tests/fetchGist.test.js | 2 +- tests/fetchRepo.test.js | 2 +- tests/fetchStats.test.js | 2 +- tests/fetchTopLanguages.test.js | 2 +- tests/fetchWakatime.test.js | 2 +- tests/flexLayout.test.js | 2 +- tests/gist.test.js | 4 ++-- tests/i18n.test.js | 2 +- tests/pat-info.test.js | 13 +++++++------ tests/pin.test.js | 2 +- tests/renderGistCard.test.js | 4 ++-- tests/renderRepoCard.test.js | 3 +-- tests/renderStatsCard.test.js | 6 ++---- tests/renderTopLanguagesCard.test.js | 26 ++++++++++++-------------- tests/renderWakatimeCard.test.js | 2 +- tests/retryer.test.js | 4 ++-- tests/status.up.test.js | 2 +- tests/top-langs.test.js | 2 +- tests/utils.test.js | 4 ++-- tests/wakatime.test.js | 2 +- 24 files changed, 54 insertions(+), 58 deletions(-) diff --git a/tests/api.test.js b/tests/api.test.js index b20fa69831193..caaa1c5a26668 100644 --- a/tests/api.test.js +++ b/tests/api.test.js @@ -1,19 +1,19 @@ // @ts-check +import { + afterEach, + beforeEach, + describe, + expect, + it, + jest, +} from "@jest/globals"; import axios from "axios"; import MockAdapter from "axios-mock-adapter"; import api from "../api/index.js"; import { calculateRank } from "../src/calculateRank.js"; import { renderStatsCard } from "../src/cards/stats.js"; import { CONSTANTS, renderError } from "../src/common/utils.js"; -import { - expect, - it, - describe, - afterEach, - beforeEach, - jest, -} from "@jest/globals"; /** * @type {import("../src/fetchers/stats").StatsData} diff --git a/tests/calculateRank.test.js b/tests/calculateRank.test.js index 65f60df3cad97..662dd2677f9ee 100644 --- a/tests/calculateRank.test.js +++ b/tests/calculateRank.test.js @@ -1,6 +1,6 @@ +import { describe, expect, it } from "@jest/globals"; import "@testing-library/jest-dom"; import { calculateRank } from "../src/calculateRank.js"; -import { expect, it, describe } from "@jest/globals"; describe("Test calculateRank", () => { it("new user gets C rank", () => { diff --git a/tests/card.test.js b/tests/card.test.js index 61e7ec0e00c14..02e476c3721db 100644 --- a/tests/card.test.js +++ b/tests/card.test.js @@ -1,10 +1,10 @@ +import { describe, expect, it } from "@jest/globals"; import { queryByTestId } from "@testing-library/dom"; import "@testing-library/jest-dom"; import { cssToObject } from "@uppercod/css-to-object"; import { Card } from "../src/common/Card.js"; import { icons } from "../src/common/icons.js"; import { getCardColors } from "../src/common/utils.js"; -import { expect, it, describe } from "@jest/globals"; describe("Card", () => { it("should hide border", () => { diff --git a/tests/e2e/e2e.test.js b/tests/e2e/e2e.test.js index 10517759b8f21..63e5e4fd7f792 100644 --- a/tests/e2e/e2e.test.js +++ b/tests/e2e/e2e.test.js @@ -4,13 +4,13 @@ import dotenv from "dotenv"; dotenv.config(); +import { beforeAll, describe, expect, test } from "@jest/globals"; import axios from "axios"; +import { renderGistCard } from "../../src/cards/gist.js"; import { renderRepoCard } from "../../src/cards/repo.js"; import { renderStatsCard } from "../../src/cards/stats.js"; import { renderTopLanguages } from "../../src/cards/top-languages.js"; import { renderWakatimeCard } from "../../src/cards/wakatime.js"; -import { renderGistCard } from "../../src/cards/gist.js"; -import { expect, describe, beforeAll, test } from "@jest/globals"; const REPO = "curly-fiesta"; const USER = "catelinemnemosyne"; diff --git a/tests/fetchGist.test.js b/tests/fetchGist.test.js index ee9be987137bf..ba5f3e520f9da 100644 --- a/tests/fetchGist.test.js +++ b/tests/fetchGist.test.js @@ -1,7 +1,7 @@ +import { afterEach, describe, expect, it } from "@jest/globals"; import "@testing-library/jest-dom"; import axios from "axios"; import MockAdapter from "axios-mock-adapter"; -import { expect, it, describe, afterEach } from "@jest/globals"; import { fetchGist } from "../src/fetchers/gist.js"; const gist_data = { diff --git a/tests/fetchRepo.test.js b/tests/fetchRepo.test.js index 604b34b4f06ea..e976dd72a47ce 100644 --- a/tests/fetchRepo.test.js +++ b/tests/fetchRepo.test.js @@ -1,8 +1,8 @@ +import { afterEach, describe, expect, it } from "@jest/globals"; import "@testing-library/jest-dom"; import axios from "axios"; import MockAdapter from "axios-mock-adapter"; import { fetchRepo } from "../src/fetchers/repo.js"; -import { expect, it, describe, afterEach } from "@jest/globals"; const data_repo = { repository: { diff --git a/tests/fetchStats.test.js b/tests/fetchStats.test.js index e0b0a146bfc6c..6c7edb46a34b4 100644 --- a/tests/fetchStats.test.js +++ b/tests/fetchStats.test.js @@ -1,9 +1,9 @@ +import { afterEach, beforeEach, describe, expect, it } from "@jest/globals"; import "@testing-library/jest-dom"; import axios from "axios"; import MockAdapter from "axios-mock-adapter"; import { calculateRank } from "../src/calculateRank.js"; import { fetchStats } from "../src/fetchers/stats.js"; -import { expect, it, describe, beforeEach, afterEach } from "@jest/globals"; // Test parameters. const data_stats = { diff --git a/tests/fetchTopLanguages.test.js b/tests/fetchTopLanguages.test.js index 287c8ede23ce6..e9764a25269c1 100644 --- a/tests/fetchTopLanguages.test.js +++ b/tests/fetchTopLanguages.test.js @@ -1,8 +1,8 @@ +import { afterEach, describe, expect, it } from "@jest/globals"; import "@testing-library/jest-dom"; import axios from "axios"; import MockAdapter from "axios-mock-adapter"; import { fetchTopLanguages } from "../src/fetchers/top-languages.js"; -import { expect, it, describe, afterEach } from "@jest/globals"; const mock = new MockAdapter(axios); diff --git a/tests/fetchWakatime.test.js b/tests/fetchWakatime.test.js index 0cfbe4dfde577..a0f8b12a12423 100644 --- a/tests/fetchWakatime.test.js +++ b/tests/fetchWakatime.test.js @@ -1,8 +1,8 @@ +import { afterEach, describe, expect, it } from "@jest/globals"; import "@testing-library/jest-dom"; import axios from "axios"; import MockAdapter from "axios-mock-adapter"; import { fetchWakatimeStats } from "../src/fetchers/wakatime.js"; -import { expect, it, describe, afterEach } from "@jest/globals"; const mock = new MockAdapter(axios); diff --git a/tests/flexLayout.test.js b/tests/flexLayout.test.js index e07aae2944290..a2bb580d8a440 100644 --- a/tests/flexLayout.test.js +++ b/tests/flexLayout.test.js @@ -1,5 +1,5 @@ +import { describe, expect, it } from "@jest/globals"; import { flexLayout } from "../src/common/utils.js"; -import { expect, it, describe } from "@jest/globals"; describe("flexLayout", () => { it("should work with row & col layouts", () => { diff --git a/tests/gist.test.js b/tests/gist.test.js index 98670adc1a926..e136c2b2e58e6 100644 --- a/tests/gist.test.js +++ b/tests/gist.test.js @@ -1,12 +1,12 @@ // @ts-check +import { afterEach, describe, expect, it, jest } from "@jest/globals"; import "@testing-library/jest-dom"; import axios from "axios"; import MockAdapter from "axios-mock-adapter"; -import { expect, it, describe, afterEach, jest } from "@jest/globals"; +import gist from "../api/gist.js"; import { renderGistCard } from "../src/cards/gist.js"; import { CONSTANTS, renderError } from "../src/common/utils.js"; -import gist from "../api/gist.js"; const gist_data = { data: { diff --git a/tests/i18n.test.js b/tests/i18n.test.js index 0466682538fb0..225800290499a 100644 --- a/tests/i18n.test.js +++ b/tests/i18n.test.js @@ -1,4 +1,4 @@ -import { expect, it, describe } from "@jest/globals"; +import { describe, expect, it } from "@jest/globals"; import { I18n } from "../src/common/I18n.js"; import { statCardLocales } from "../src/translations.js"; diff --git a/tests/pat-info.test.js b/tests/pat-info.test.js index 0f8783df7b13f..a46eee15547f7 100644 --- a/tests/pat-info.test.js +++ b/tests/pat-info.test.js @@ -1,20 +1,21 @@ /** * @file Tests for the status/pat-info cloud function. */ + import dotenv from "dotenv"; dotenv.config(); -import axios from "axios"; -import MockAdapter from "axios-mock-adapter"; -import patInfo, { RATE_LIMIT_SECONDS } from "../api/status/pat-info.js"; import { - expect, - it, - describe, afterEach, beforeAll, + describe, + expect, + it, jest, } from "@jest/globals"; +import axios from "axios"; +import MockAdapter from "axios-mock-adapter"; +import patInfo, { RATE_LIMIT_SECONDS } from "../api/status/pat-info.js"; const mock = new MockAdapter(axios); diff --git a/tests/pin.test.js b/tests/pin.test.js index 34212649337bd..035f4fb525f33 100644 --- a/tests/pin.test.js +++ b/tests/pin.test.js @@ -1,12 +1,12 @@ // @ts-check +import { afterEach, describe, expect, it, jest } from "@jest/globals"; import "@testing-library/jest-dom"; import axios from "axios"; import MockAdapter from "axios-mock-adapter"; import pin from "../api/pin.js"; import { renderRepoCard } from "../src/cards/repo.js"; import { CONSTANTS, renderError } from "../src/common/utils.js"; -import { expect, it, describe, afterEach, jest } from "@jest/globals"; const data_repo = { repository: { diff --git a/tests/renderGistCard.test.js b/tests/renderGistCard.test.js index 9d3600522d42f..c397281a561bc 100644 --- a/tests/renderGistCard.test.js +++ b/tests/renderGistCard.test.js @@ -1,9 +1,9 @@ -import { renderGistCard } from "../src/cards/gist.js"; import { describe, expect, it } from "@jest/globals"; import { queryByTestId } from "@testing-library/dom"; +import "@testing-library/jest-dom"; import { cssToObject } from "@uppercod/css-to-object"; +import { renderGistCard } from "../src/cards/gist.js"; import { themes } from "../themes/index.js"; -import "@testing-library/jest-dom"; /** * @type {import("../src/fetchers/gist").GistData} diff --git a/tests/renderRepoCard.test.js b/tests/renderRepoCard.test.js index 04c1090db758a..9fb5ab36c90de 100644 --- a/tests/renderRepoCard.test.js +++ b/tests/renderRepoCard.test.js @@ -1,9 +1,8 @@ +import { describe, expect, it } from "@jest/globals"; import { queryByTestId } from "@testing-library/dom"; import "@testing-library/jest-dom"; import { cssToObject } from "@uppercod/css-to-object"; import { renderRepoCard } from "../src/cards/repo.js"; -import { expect, it, describe } from "@jest/globals"; - import { themes } from "../themes/index.js"; const data_repo = { diff --git a/tests/renderStatsCard.test.js b/tests/renderStatsCard.test.js index a460454052506..40010944d4069 100644 --- a/tests/renderStatsCard.test.js +++ b/tests/renderStatsCard.test.js @@ -1,16 +1,14 @@ +import { describe, expect, it } from "@jest/globals"; import { getByTestId, queryAllByTestId, queryByTestId, } from "@testing-library/dom"; +import "@testing-library/jest-dom"; import { cssToObject } from "@uppercod/css-to-object"; import { renderStatsCard } from "../src/cards/stats.js"; -import { expect, it, describe } from "@jest/globals"; import { CustomError } from "../src/common/utils.js"; -// adds special assertions like toHaveTextContent -import "@testing-library/jest-dom"; - import { themes } from "../themes/index.js"; const stats = { diff --git a/tests/renderTopLanguagesCard.test.js b/tests/renderTopLanguagesCard.test.js index 0a7aba617c9fb..58532fa52e0aa 100644 --- a/tests/renderTopLanguagesCard.test.js +++ b/tests/renderTopLanguagesCard.test.js @@ -1,27 +1,25 @@ +import { describe, expect, it } from "@jest/globals"; import { queryAllByTestId, queryByTestId } from "@testing-library/dom"; +import "@testing-library/jest-dom"; import { cssToObject } from "@uppercod/css-to-object"; import { - getLongestLang, - degreesToRadians, - radiansToDegrees, - polarToCartesian, - cartesianToPolar, - getCircleLength, + MIN_CARD_WIDTH, calculateCompactLayoutHeight, - calculateNormalLayoutHeight, calculateDonutLayoutHeight, calculateDonutVerticalLayoutHeight, + calculateNormalLayoutHeight, calculatePieLayoutHeight, + cartesianToPolar, + degreesToRadians, donutCenterTranslation, - trimTopLanguages, - renderTopLanguages, - MIN_CARD_WIDTH, + getCircleLength, getDefaultLanguagesCountByLayout, + getLongestLang, + polarToCartesian, + radiansToDegrees, + renderTopLanguages, + trimTopLanguages, } from "../src/cards/top-languages.js"; -import { expect, it, describe } from "@jest/globals"; - -// adds special assertions like toHaveTextContent -import "@testing-library/jest-dom"; import { themes } from "../themes/index.js"; diff --git a/tests/renderWakatimeCard.test.js b/tests/renderWakatimeCard.test.js index ca2381485b480..24743f8d0a5ac 100644 --- a/tests/renderWakatimeCard.test.js +++ b/tests/renderWakatimeCard.test.js @@ -1,8 +1,8 @@ +import { describe, expect, it } from "@jest/globals"; import { queryByTestId } from "@testing-library/dom"; import "@testing-library/jest-dom"; import { renderWakatimeCard } from "../src/cards/wakatime.js"; import { wakaTimeData } from "./fetchWakatime.test.js"; -import { expect, it, describe } from "@jest/globals"; describe("Test Render WakaTime Card", () => { it("should render correctly", () => { diff --git a/tests/retryer.test.js b/tests/retryer.test.js index e231a366e1d90..967441e3b6456 100644 --- a/tests/retryer.test.js +++ b/tests/retryer.test.js @@ -1,7 +1,7 @@ +import { describe, expect, it, jest } from "@jest/globals"; import "@testing-library/jest-dom"; -import { retryer, RETRIES } from "../src/common/retryer.js"; +import { RETRIES, retryer } from "../src/common/retryer.js"; import { logger } from "../src/common/utils.js"; -import { expect, it, describe, jest } from "@jest/globals"; const fetcher = jest.fn((variables, token) => { logger.log(variables, token); diff --git a/tests/status.up.test.js b/tests/status.up.test.js index f7c0869239e35..a4cf00b7e4057 100644 --- a/tests/status.up.test.js +++ b/tests/status.up.test.js @@ -2,10 +2,10 @@ * @file Tests for the status/up cloud function. */ +import { afterEach, describe, expect, it, jest } from "@jest/globals"; import axios from "axios"; import MockAdapter from "axios-mock-adapter"; import up, { RATE_LIMIT_SECONDS } from "../api/status/up.js"; -import { expect, it, describe, afterEach, jest } from "@jest/globals"; const mock = new MockAdapter(axios); diff --git a/tests/top-langs.test.js b/tests/top-langs.test.js index 1e48ccfd0442e..62ad3494d2eac 100644 --- a/tests/top-langs.test.js +++ b/tests/top-langs.test.js @@ -1,12 +1,12 @@ // @ts-check +import { afterEach, describe, expect, it, jest } from "@jest/globals"; import "@testing-library/jest-dom"; import axios from "axios"; import MockAdapter from "axios-mock-adapter"; import topLangs from "../api/top-langs.js"; import { renderTopLanguages } from "../src/cards/top-languages.js"; import { CONSTANTS, renderError } from "../src/common/utils.js"; -import { expect, it, describe, afterEach, jest } from "@jest/globals"; const data_langs = { data: { diff --git a/tests/utils.test.js b/tests/utils.test.js index ad72b8c5b7655..21a78e4730b32 100644 --- a/tests/utils.test.js +++ b/tests/utils.test.js @@ -1,15 +1,15 @@ +import { describe, expect, it } from "@jest/globals"; import { queryByTestId } from "@testing-library/dom"; import "@testing-library/jest-dom"; import { encodeHTML, + formatBytes, getCardColors, kFormatter, parseBoolean, renderError, wrapTextMultiline, - formatBytes, } from "../src/common/utils.js"; -import { expect, it, describe } from "@jest/globals"; describe("Test utils.js", () => { it("should test kFormatter", () => { diff --git a/tests/wakatime.test.js b/tests/wakatime.test.js index 8afdecf1c3282..ce9843df157e3 100644 --- a/tests/wakatime.test.js +++ b/tests/wakatime.test.js @@ -1,9 +1,9 @@ +import { afterEach, describe, expect, it, jest } from "@jest/globals"; import "@testing-library/jest-dom"; import axios from "axios"; import MockAdapter from "axios-mock-adapter"; import wakatime from "../api/wakatime.js"; import { renderWakatimeCard } from "../src/cards/wakatime.js"; -import { expect, it, describe, afterEach, jest } from "@jest/globals"; const wakaTimeData = { data: { From 956d6deded37c0539e73b9cdb4802fcbef6170a9 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Wed, 8 Oct 2025 02:12:28 +0300 Subject: [PATCH 155/265] feat: disable caching when NODE_ENV is development (#4543) Co-authored-by: Alexandr --- src/common/cache.js | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/src/common/cache.js b/src/common/cache.js index a4e6811304e70..32aa48ce5d8ba 100644 --- a/src/common/cache.js +++ b/src/common/cache.js @@ -47,7 +47,7 @@ const disableCaching = (res) => { * @param {number} cacheSeconds The cache seconds to set in the headers. */ const setCacheHeaders = (res, cacheSeconds) => { - if (cacheSeconds < 1) { + if (cacheSeconds < 1 || process.env.NODE_ENV === "development") { disableCaching(res); return; } @@ -69,7 +69,10 @@ const setErrorCacheHeaders = (res) => { const envCacheSeconds = process.env.CACHE_SECONDS ? parseInt(process.env.CACHE_SECONDS, 10) : NaN; - if (!isNaN(envCacheSeconds) && envCacheSeconds < 1) { + if ( + (!isNaN(envCacheSeconds) && envCacheSeconds < 1) || + process.env.NODE_ENV === "development" + ) { disableCaching(res); return; } From 4f0aadcbcf4def40b5ec597a032a1ebdfdeda314 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Wed, 8 Oct 2025 02:27:20 +0300 Subject: [PATCH 156/265] docs(readme): update information about CACHE_SECONDS environment variable (#4544) Co-authored-by: Alexandr --- readme.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/readme.md b/readme.md index 6562c676a2369..db112661d47f8 100644 --- a/readme.md +++ b/readme.md @@ -885,7 +885,7 @@ Since the GitHub API only allows 5k requests per hour, my `https://github-readme GitHub Readme Stats provides several environment variables that can be used to customize the behavior of your self-hosted instance. These include: -* `CACHE_SECONDS`: This takes precedence over our cache minimum and maximum values and can circumvent these values for self-hosted instances. +* `CACHE_SECONDS`: Sets the cache duration in seconds for the generated cards. This variable takes precedence over the default cache timings for the public instance. You can also set it to `0` to disable caching completely. If this variable is not set, the default cache duration is 24 hours (86,400 seconds). * `WHITELIST`: A comma-separated list of GitHub usernames that are allowed to access your instance. If this variable is not set, all usernames are allowed. * `GIST_WHITELIST`: A comma-separated list of GitHub gist IDs that are allowed to be accessed on your instance. If this variable is not set, all gist IDs are allowed. * `EXCLUDE_REPO`: A comma-separated list of repositories that will be excluded from stats and top languages cards on your instance. This allows repository exclusion without exposing repository names in public URLs. This enhances privacy for self-hosted instances that include private repositories in stats cards. From 4ce7b8bb66dc14b3a6c9f52f73aec62a51310f75 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Wed, 8 Oct 2025 20:46:08 +0300 Subject: [PATCH 157/265] docs(contributing): add note about NODE_ENV variable to disable caching for local development (#4545) * docs(contributing): add note about NOTE_ENV variable to disable caching for local development * Update CONTRIBUTING.md Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --------- Co-authored-by: Alexandr Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --- CONTRIBUTING.md | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index 29edbd34e68e2..6c6dac1c7d3c3 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -38,7 +38,8 @@ _(make sure you already have a [Vercel](https://vercel.com/) account)_ 3. Run `npm install` in the repository root. 4. Run the command `vercel` in the root and follow the steps there. 5. Run the command `vercel dev` to start a development server at . -6. The cards will then be available from this local endpoint (i.e. `http://localhost:3000/api?username=anuraghazra`). +6. Create a `.env` file in the root and add the following line `NODE_ENV=development`, this will disable caching for local development. +7. The cards will then be available from this local endpoint (i.e. `http://localhost:3000/api?username=anuraghazra`). > [!NOTE]\ > You can debug the package code in [Vscode](https://code.visualstudio.com/) by using the [Node.js: Attach to process](https://code.visualstudio.com/docs/nodejs/nodejs-debugging#_setting-up-an-attach-configuration) debug option. You can also debug any tests using the [VSCode Jest extension](https://marketplace.visualstudio.com/items?itemName=Orta.vscode-jest). For more information, see https://github.com/jest-community/vscode-jest/issues/912. From 756a601079550c7d6bf86f50692f81ee95cebe4a Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Wed, 8 Oct 2025 20:47:30 +0300 Subject: [PATCH 158/265] docs(readme): add warning about required redeploy after changing environment variables to apply updates (#4546) Co-authored-by: Alexandr --- readme.md | 3 +++ 1 file changed, 3 insertions(+) diff --git a/readme.md b/readme.md index db112661d47f8..73440a67de7b0 100644 --- a/readme.md +++ b/readme.md @@ -893,6 +893,9 @@ GitHub Readme Stats provides several environment variables that can be used to c See [the Vercel documentation](https://vercel.com/docs/concepts/projects/environment-variables) on adding these environment variables to your Vercel instance. +> [!WARNING]\ +> Please remember to redeploy your instance after making any changes to the environment variables so that the updates take effect. The changes will not be applied to the previous deployments. + ## Keep your fork up to date You can keep your fork, and thus your private Vercel instance up to date with the upstream using GitHub's [Sync Fork button](https://docs.github.com/en/pull-requests/collaborating-with-pull-requests/working-with-forks/syncing-a-fork). You can also use the [pull](https://github.com/wei/pull) package created by [@wei](https://github.com/wei) to automate this process. From abda6d3663dd33192bd97788bd773e774a1c6701 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Wed, 8 Oct 2025 23:29:39 +0300 Subject: [PATCH 159/265] docs(readme): add warning that custom title value should be URL encoded (#4547) Co-authored-by: Alexandr --- readme.md | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/readme.md b/readme.md index 73440a67de7b0..4be544d9ab64b 100644 --- a/readme.md +++ b/readme.md @@ -388,6 +388,9 @@ If we don't support your language, please consider contributing! You can find mo | `show` | Shows [additional items](#showing-additional-individual-stats) on stats card (i.e. `reviews`, `discussions_started`, `discussions_answered`, `prs_merged` or `prs_merged_percentage`). | string (comma-separated values) | `null` | | `commits_year` | Filters and counts only commits made in the specified year. | integer _(YYYY)_ | ` (one year to date)` | +> [!WARNING]\ +> Custom title should be URI-escaped, as specified in [Percent Encoding](https://en.wikipedia.org/wiki/Percent-encoding) (i.e: `Anurag's GitHub Stats` should become `Anurag%27s%20GitHub%20Stats`). You can use [urlencoder.org](https://www.urlencoder.org/) to help you do this automatically. + > [!NOTE]\ > When hide\_rank=`true`, the minimum card width is 270 px + the title length and padding. @@ -502,9 +505,7 @@ You can customize the appearance and behavior of the top languages card using th | `stats_format` | Switches between two available formats for language's stats `percentages` and `bytes`. | enum | `percentages` | > [!WARNING]\ -> Language names should be URI-escaped, as specified in [Percent Encoding](https://en.wikipedia.org/wiki/Percent-encoding) -> (i.e: `c++` should become `c%2B%2B`, `jupyter notebook` should become `jupyter%20notebook`, etc.) You can use -> [urlencoder.org](https://www.urlencoder.org/) to help you do this automatically. +> Language names and custom title should be URI-escaped, as specified in [Percent Encoding](https://en.wikipedia.org/wiki/Percent-encoding) (i.e: `c++` should become `c%2B%2B`, `jupyter notebook` should become `jupyter%20notebook`, `Most Used Languages` should become `Most%20Used%20Languages`, etc.) You can use [urlencoder.org](https://www.urlencoder.org/) to help you do this automatically. ### Language stats algorithm @@ -658,6 +659,9 @@ You can customize the appearance and behavior of the WakaTime stats card using t | `display_format` | Sets the WakaTime stats display format. Choose `time` to display time-based stats or `percent` to show percentages. | enum | `time` | | `disable_animations` | Disables all animations in the card. | boolean | `false` | +> [!WARNING]\ +> Custom title should be URI-escaped, as specified in [Percent Encoding](https://en.wikipedia.org/wiki/Percent-encoding) (i.e: `WakaTime Stats` should become `WakaTime%20Stats`). You can use [urlencoder.org](https://www.urlencoder.org/) to help you do this automatically. + ### Demo ![Harlok's WakaTime stats](https://github-readme-stats.vercel.app/api/wakatime?username=ffflabs) From b3995211fec9c624406fd2e3611967df1122c694 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Thu, 9 Oct 2025 00:33:40 +0300 Subject: [PATCH 160/265] docs(readme): remove redundant backslashes (#4548) Co-authored-by: Alexandr --- readme.md | 40 ++++++++++++++++++++-------------------- 1 file changed, 20 insertions(+), 20 deletions(-) diff --git a/readme.md b/readme.md index 4be544d9ab64b..f40df627b77a0 100644 --- a/readme.md +++ b/readme.md @@ -98,15 +98,15 @@ # Important Notices -> [!IMPORTANT]\ +> [!IMPORTANT] > Please note that we are NOT participating in Hacktoberfest this year. As a small team, we cannot handle the increased volume of PRs and issues that the event brings. We appreciate your understanding. -> [!IMPORTANT]\ +> [!IMPORTANT] > Since the GitHub API only [allows 5k requests per hour per user account](https://docs.github.com/en/graphql/overview/resource-limitations), the public Vercel instance hosted on `https://github-readme-stats.vercel.app/api` could possibly hit the rate limiter (see [#1471](https://github.com/anuraghazra/github-readme-stats/issues/1471)). We use caching to prevent this from happening (see https://github.com/anuraghazra/github-readme-stats#common-options). You can turn off these rate limit protections by [deploying your own Vercel instance](#deploy-on-your-own). Uptime Badge -> [!IMPORTANT]\ +> [!IMPORTANT] > We're a small team, and to prioritize, we rely on upvotes :+1:. We use the Top Issues dashboard for tracking community demand (see [#1935](https://github.com/anuraghazra/github-readme-stats/issues/1935)). Do not hesitate to upvote the issues and pull requests you are interested in. We will work on the most upvoted first. # GitHub Stats Card @@ -119,10 +119,10 @@ Change the `?username=` value to your GitHub username. [![Anurag's GitHub stats](https://github-readme-stats.vercel.app/api?username=anuraghazra)](https://github.com/anuraghazra/github-readme-stats) ``` -> [!WARNING]\ +> [!WARNING] > By default, the stats card only shows statistics like stars, commits, and pull requests from public repositories. To show private statistics on the stats card, you should [deploy your own instance](#deploy-on-your-own) using your own GitHub API token. -> [!NOTE]\ +> [!NOTE] > Available ranks are S (top 1%), A+ (12.5%), A (25%), A- (37.5%), B+ (50%), B (62.5%), B- (75%), C+ (87.5%) and C (everyone). This ranking scheme is based on the [Japanese academic grading](https://wikipedia.org/wiki/Academic_grading_in_Japan) system. The global percentile is calculated as a weighted sum of percentiles for each statistic (number of commits, pull requests, reviews, issues, stars, and followers), based on the cumulative distribution function of the [exponential](https://wikipedia.org/wiki/exponential_distribution) and the [log-normal](https://wikipedia.org/wiki/Log-normal_distribution) distributions. The implementation can be investigated at [src/calculateRank.js](https://github.com/anuraghazra/github-readme-stats/blob/master/src/calculateRank.js). The circle around the rank shows 100 minus the global percentile. ### Hiding individual stats @@ -287,7 +287,7 @@ You can customize the appearance of all your cards however you wish with URL par | `locale` | Sets the language in the card, you can check full list of available locales [here](#available-locales). | enum | `en` | | `border_radius` | Corner rounding on the card. | number | `4.5` | -> [!WARNING]\ +> [!WARNING] > We use caching to decrease the load on our servers (see ). Our cards have the following default cache hours: stats card - 24 hours, top languages card - 144 hours (6 days), pin card - 240 hours (10 days), gist card - 48 hours (2 days). If you want the data on your statistics card to be updated more often you can [deploy your own instance](#deploy-on-your-own) and set [environment variable](#available-environment-variables) `CACHE_SECONDS` to a value of your choosing. ##### Gradient in bg\_color @@ -388,10 +388,10 @@ If we don't support your language, please consider contributing! You can find mo | `show` | Shows [additional items](#showing-additional-individual-stats) on stats card (i.e. `reviews`, `discussions_started`, `discussions_answered`, `prs_merged` or `prs_merged_percentage`). | string (comma-separated values) | `null` | | `commits_year` | Filters and counts only commits made in the specified year. | integer _(YYYY)_ | ` (one year to date)` | -> [!WARNING]\ +> [!WARNING] > Custom title should be URI-escaped, as specified in [Percent Encoding](https://en.wikipedia.org/wiki/Percent-encoding) (i.e: `Anurag's GitHub Stats` should become `Anurag%27s%20GitHub%20Stats`). You can use [urlencoder.org](https://www.urlencoder.org/) to help you do this automatically. -> [!NOTE]\ +> [!NOTE] > When hide\_rank=`true`, the minimum card width is 270 px + the title length and padding. *** @@ -463,16 +463,16 @@ Use `show_owner` query option to include the gist's owner username The top languages card shows a GitHub user's most frequently used languages. -> [!WARNING]\ +> [!WARNING] > By default, the language card shows language results only from public repositories. To include languages used in private repositories, you should [deploy your own instance](#deploy-on-your-own) using your own GitHub API token. -> [!NOTE]\ +> [!NOTE] > Top Languages does not indicate the user's skill level or anything like that; it's a GitHub metric to determine which languages have the most code on GitHub. It is a new feature of github-readme-stats. -> [!WARNING]\ +> [!WARNING] > This card shows language usage only inside your own non-forked repositories, not depending on who the author of the commits is. It does not include your contributions into another users/organizations repositories. Currently there are no way to get this data from GitHub API. If you want this behavior to be improved you can support [this feature request](https://github.com/orgs/community/discussions/18230) created by [@rickstaa](https://github.com/rickstaa) inside GitHub Community. -> [!WARNING]\ +> [!WARNING] > Currently this card shows data only about first 100 repositories. This is because GitHub API limitations which cause downtimes of public instances (see [#1471](https://github.com/anuraghazra/github-readme-stats/issues/1471)). In future this behavior will be improved by releasing GitHub action or providing environment variables for user's own instances. ### Usage @@ -504,7 +504,7 @@ You can customize the appearance and behavior of the top languages card using th | `count_weight` | Configures language stats algorithm (see [Language stats algorithm](#language-stats-algorithm)). | integer | `0` | | `stats_format` | Switches between two available formats for language's stats `percentages` and `bytes`. | enum | `percentages` | -> [!WARNING]\ +> [!WARNING] > Language names and custom title should be URI-escaped, as specified in [Percent Encoding](https://en.wikipedia.org/wiki/Percent-encoding) (i.e: `c++` should become `c%2B%2B`, `jupyter notebook` should become `jupyter%20notebook`, `Most Used Languages` should become `Most%20Used%20Languages`, etc.) You can use [urlencoder.org](https://www.urlencoder.org/) to help you do this automatically. ### Language stats algorithm @@ -629,10 +629,10 @@ You can use the `&stats_format=bytes` option to display the stats in bytes inste # WakaTime Stats Card -> [!WARNING]\ +> [!WARNING] > Please be aware that we currently only show data from WakaTime profiles that are public. You therefore have to make sure that **BOTH** `Display code time publicly` and `Display languages, editors, os, categories publicly` are enabled. -> [!WARNING]\ +> [!WARNING] > In case you just created a new WakaTime account, then it might take up to 24 hours until your stats will become visible on the WakaTime stats card. Change the `?username=` value to your [WakaTime](https://wakatime.com) username. @@ -659,7 +659,7 @@ You can customize the appearance and behavior of the WakaTime stats card using t | `display_format` | Sets the WakaTime stats display format. Choose `time` to display time-based stats or `percent` to show percentages. | enum | `time` | | `disable_animations` | Disables all animations in the card. | boolean | `false` | -> [!WARNING]\ +> [!WARNING] > Custom title should be URI-escaped, as specified in [Percent Encoding](https://en.wikipedia.org/wiki/Percent-encoding) (i.e: `WakaTime Stats` should become `WakaTime%20Stats`). You can use [urlencoder.org](https://www.urlencoder.org/) to help you do this automatically. ### Demo @@ -838,10 +838,10 @@ Selecting the right scopes for your token is important in case you want to displ Since the GitHub API only allows 5k requests per hour, my `https://github-readme-stats.vercel.app/api` could possibly hit the rate limiter. If you host it on your own Vercel server, then you do not have to worry about anything. Click on the deploy button to get started! -> [!NOTE]\ +> [!NOTE] > Since [#58](https://github.com/anuraghazra/github-readme-stats/pull/58), we should be able to handle more than 5k requests and have fewer issues with downtime :grin:. -> [!NOTE]\ +> [!NOTE] > If you are on the [Pro (i.e. paid)](https://vercel.com/pricing) Vercel plan, the [maxDuration](https://vercel.com/docs/concepts/projects/project-configuration#value-definition) value found in the [vercel.json](https://github.com/anuraghazra/github-readme-stats/blob/master/vercel.json) can be increased when your Vercel instance frequently times out during the card request. You are advised to keep this value lower than `30` seconds to prevent high memory usage. [![Deploy to Vercel](https://vercel.com/button)](https://vercel.com/import/project?template=https://github.com/anuraghazra/github-readme-stats) @@ -870,7 +870,7 @@ Since the GitHub API only allows 5k requests per hour, my `https://github-readme ## On other platforms -> [!WARNING]\ +> [!WARNING] > This way of using GRS is not officially supported and was added to cater to some particular use cases where Vercel could not be used (e.g. [#2341](https://github.com/anuraghazra/github-readme-stats/discussions/2341)). The support for this method, therefore, is limited.
@@ -897,7 +897,7 @@ GitHub Readme Stats provides several environment variables that can be used to c See [the Vercel documentation](https://vercel.com/docs/concepts/projects/environment-variables) on adding these environment variables to your Vercel instance. -> [!WARNING]\ +> [!WARNING] > Please remember to redeploy your instance after making any changes to the environment variables so that the updates take effect. The changes will not be applied to the previous deployments. ## Keep your fork up to date From 3c22841a82dcdc332bac133ef5bbdacc2106508a Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Thu, 9 Oct 2025 00:34:24 +0300 Subject: [PATCH 161/265] docs(contributing): remove redundant backslashes (#4549) Co-authored-by: Alexandr --- CONTRIBUTING.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index 6c6dac1c7d3c3..e72d7b9f8013c 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -1,6 +1,6 @@ # Contributing to [github-readme-stats](https://github.com/anuraghazra/github-readme-stats) -> [!IMPORTANT]\ +> [!IMPORTANT] > Please note that we are NOT participating in Hacktoberfest this year. As a small team, we cannot handle the increased volume of PRs and issues that the event brings. We appreciate your understanding. We love your input! We want to make contributing to this project as easy and transparent as possible, whether it's: @@ -41,14 +41,14 @@ _(make sure you already have a [Vercel](https://vercel.com/) account)_ 6. Create a `.env` file in the root and add the following line `NODE_ENV=development`, this will disable caching for local development. 7. The cards will then be available from this local endpoint (i.e. `http://localhost:3000/api?username=anuraghazra`). -> [!NOTE]\ +> [!NOTE] > You can debug the package code in [Vscode](https://code.visualstudio.com/) by using the [Node.js: Attach to process](https://code.visualstudio.com/docs/nodejs/nodejs-debugging#_setting-up-an-attach-configuration) debug option. You can also debug any tests using the [VSCode Jest extension](https://marketplace.visualstudio.com/items?itemName=Orta.vscode-jest). For more information, see https://github.com/jest-community/vscode-jest/issues/912. ## Themes Contribution We're currently paused addition of new themes to decrease maintenance efforts. All pull requests related to new themes will be closed. -> [!NOTE]\ +> [!NOTE] > If you are considering contributing your theme just because you are using it personally, then instead of adding it to our theme collection, you can use card [customization options](./readme.md#customization). ## Translations Contribution From 0afa6c4e785d9f5145e65f8e5217c2f5a85645fd Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Thu, 9 Oct 2025 03:41:02 +0300 Subject: [PATCH 162/265] refactor: reorganize cache TTL constants (#4550) * refactor: reorganize cache TTL constants * Update tests/wakatime.test.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --------- Co-authored-by: Alexandr Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --- api/gist.js | 9 ++--- api/index.js | 14 +++----- api/pin.js | 9 ++--- api/top-langs.js | 14 +++----- api/wakatime.js | 14 +++----- src/common/cache.js | 76 +++++++++++++++++++++++++++++++++++++---- src/common/index.js | 3 +- src/common/utils.js | 29 ---------------- tests/api.test.js | 44 +++++++++++++----------- tests/gist.test.js | 9 ++--- tests/pin.test.js | 9 ++--- tests/top-langs.test.js | 9 ++--- tests/wakatime.test.js | 22 ++++++++++++ 13 files changed, 158 insertions(+), 103 deletions(-) diff --git a/api/gist.js b/api/gist.js index 7c5f9e6844838..d6713eafcef43 100644 --- a/api/gist.js +++ b/api/gist.js @@ -1,10 +1,11 @@ // @ts-check -import { CONSTANTS, renderError, parseBoolean } from "../src/common/utils.js"; +import { renderError, parseBoolean } from "../src/common/utils.js"; import { isLocaleAvailable } from "../src/translations.js"; import { renderGistCard } from "../src/cards/gist.js"; import { fetchGist } from "../src/fetchers/gist.js"; import { + CACHE_TTL, resolveCacheSeconds, setCacheHeaders, setErrorCacheHeaders, @@ -65,9 +66,9 @@ export default async (req, res) => { const gistData = await fetchGist(id); const cacheSeconds = resolveCacheSeconds({ requested: parseInt(cache_seconds, 10), - def: CONSTANTS.TWO_DAY, - min: CONSTANTS.TWO_DAY, - max: CONSTANTS.SIX_DAY, + def: CACHE_TTL.GIST_CARD.DEFAULT, + min: CACHE_TTL.GIST_CARD.MIN, + max: CACHE_TTL.GIST_CARD.MAX, }); setCacheHeaders(res, cacheSeconds); diff --git a/api/index.js b/api/index.js index 37a298412a7bd..d5e55fbbfcd60 100644 --- a/api/index.js +++ b/api/index.js @@ -3,16 +3,12 @@ import { renderStatsCard } from "../src/cards/stats.js"; import { guardAccess } from "../src/common/access.js"; import { + CACHE_TTL, resolveCacheSeconds, setCacheHeaders, setErrorCacheHeaders, } from "../src/common/cache.js"; -import { - CONSTANTS, - parseArray, - parseBoolean, - renderError, -} from "../src/common/utils.js"; +import { parseArray, parseBoolean, renderError } from "../src/common/utils.js"; import { fetchStats } from "../src/fetchers/stats.js"; import { isLocaleAvailable } from "../src/translations.js"; @@ -94,9 +90,9 @@ export default async (req, res) => { ); const cacheSeconds = resolveCacheSeconds({ requested: parseInt(cache_seconds, 10), - def: CONSTANTS.CARD_CACHE_SECONDS, - min: CONSTANTS.TWELVE_HOURS, - max: CONSTANTS.TWO_DAY, + def: CACHE_TTL.STATS_CARD.DEFAULT, + min: CACHE_TTL.STATS_CARD.MIN, + max: CACHE_TTL.STATS_CARD.MAX, }); setCacheHeaders(res, cacheSeconds); diff --git a/api/pin.js b/api/pin.js index 2183c8f199e08..e1f46b32c34b9 100644 --- a/api/pin.js +++ b/api/pin.js @@ -3,11 +3,12 @@ import { renderRepoCard } from "../src/cards/repo.js"; import { guardAccess } from "../src/common/access.js"; import { + CACHE_TTL, resolveCacheSeconds, setCacheHeaders, setErrorCacheHeaders, } from "../src/common/cache.js"; -import { CONSTANTS, parseBoolean, renderError } from "../src/common/utils.js"; +import { parseBoolean, renderError } from "../src/common/utils.js"; import { fetchRepo } from "../src/fetchers/repo.js"; import { isLocaleAvailable } from "../src/translations.js"; @@ -67,9 +68,9 @@ export default async (req, res) => { const repoData = await fetchRepo(username, repo); const cacheSeconds = resolveCacheSeconds({ requested: parseInt(cache_seconds, 10), - def: CONSTANTS.PIN_CARD_CACHE_SECONDS, - min: CONSTANTS.ONE_DAY, - max: CONSTANTS.TEN_DAY, + def: CACHE_TTL.PIN_CARD.DEFAULT, + min: CACHE_TTL.PIN_CARD.MIN, + max: CACHE_TTL.PIN_CARD.MAX, }); setCacheHeaders(res, cacheSeconds); diff --git a/api/top-langs.js b/api/top-langs.js index 3e90342831b39..df286b483d929 100644 --- a/api/top-langs.js +++ b/api/top-langs.js @@ -3,16 +3,12 @@ import { renderTopLanguages } from "../src/cards/top-languages.js"; import { guardAccess } from "../src/common/access.js"; import { + CACHE_TTL, resolveCacheSeconds, setCacheHeaders, setErrorCacheHeaders, } from "../src/common/cache.js"; -import { - CONSTANTS, - parseArray, - parseBoolean, - renderError, -} from "../src/common/utils.js"; +import { parseArray, parseBoolean, renderError } from "../src/common/utils.js"; import { fetchTopLanguages } from "../src/fetchers/top-languages.js"; import { isLocaleAvailable } from "../src/translations.js"; @@ -124,9 +120,9 @@ export default async (req, res) => { ); const cacheSeconds = resolveCacheSeconds({ requested: parseInt(cache_seconds, 10), - def: CONSTANTS.TOP_LANGS_CACHE_SECONDS, - min: CONSTANTS.TWO_DAY, - max: CONSTANTS.TEN_DAY, + def: CACHE_TTL.TOP_LANGS_CARD.DEFAULT, + min: CACHE_TTL.TOP_LANGS_CARD.MIN, + max: CACHE_TTL.TOP_LANGS_CARD.MAX, }); setCacheHeaders(res, cacheSeconds); diff --git a/api/wakatime.js b/api/wakatime.js index 7b5571ebdd04d..b8642649be219 100644 --- a/api/wakatime.js +++ b/api/wakatime.js @@ -1,15 +1,11 @@ // @ts-check import { renderWakatimeCard } from "../src/cards/wakatime.js"; -import { - CONSTANTS, - parseArray, - parseBoolean, - renderError, -} from "../src/common/utils.js"; +import { parseArray, parseBoolean, renderError } from "../src/common/utils.js"; import { fetchWakatimeStats } from "../src/fetchers/wakatime.js"; import { isLocaleAvailable } from "../src/translations.js"; import { + CACHE_TTL, resolveCacheSeconds, setCacheHeaders, setErrorCacheHeaders, @@ -80,9 +76,9 @@ export default async (req, res) => { const stats = await fetchWakatimeStats({ username, api_domain }); const cacheSeconds = resolveCacheSeconds({ requested: parseInt(cache_seconds, 10), - def: CONSTANTS.CARD_CACHE_SECONDS, - min: CONSTANTS.SIX_HOURS, - max: CONSTANTS.TWO_DAY, + def: CACHE_TTL.WAKATIME_CARD.DEFAULT, + min: CACHE_TTL.WAKATIME_CARD.MIN, + max: CACHE_TTL.WAKATIME_CARD.MAX, }); setCacheHeaders(res, cacheSeconds); diff --git a/src/common/cache.js b/src/common/cache.js index 32aa48ce5d8ba..3e88e3c9c4fae 100644 --- a/src/common/cache.js +++ b/src/common/cache.js @@ -1,6 +1,64 @@ // @ts-check -import { clampValue, CONSTANTS } from "./utils.js"; +import { clampValue } from "./utils.js"; + +const MIN = 60; +const HOUR = 60 * MIN; +const DAY = 24 * HOUR; + +/** + * Common durations in seconds. + */ +const DURATIONS = { + ONE_MINUTE: MIN, + FIVE_MINUTES: 5 * MIN, + TEN_MINUTES: 10 * MIN, + FIFTEEN_MINUTES: 15 * MIN, + THIRTY_MINUTES: 30 * MIN, + + TWO_HOURS: 2 * HOUR, + FOUR_HOURS: 4 * HOUR, + SIX_HOURS: 6 * HOUR, + EIGHT_HOURS: 8 * HOUR, + TWELVE_HOURS: 12 * HOUR, + + ONE_DAY: DAY, + TWO_DAY: 2 * DAY, + SIX_DAY: 6 * DAY, + TEN_DAY: 10 * DAY, +}; + +/** + * Common cache TTL values in seconds. + */ +const CACHE_TTL = { + STATS_CARD: { + DEFAULT: DURATIONS.ONE_DAY, + MIN: DURATIONS.TWELVE_HOURS, + MAX: DURATIONS.TWO_DAY, + }, + TOP_LANGS_CARD: { + DEFAULT: DURATIONS.SIX_DAY, + MIN: DURATIONS.TWO_DAY, + MAX: DURATIONS.TEN_DAY, + }, + PIN_CARD: { + DEFAULT: DURATIONS.TEN_DAY, + MIN: DURATIONS.ONE_DAY, + MAX: DURATIONS.TEN_DAY, + }, + GIST_CARD: { + DEFAULT: DURATIONS.TWO_DAY, + MIN: DURATIONS.ONE_DAY, + MAX: DURATIONS.TEN_DAY, + }, + WAKATIME_CARD: { + DEFAULT: DURATIONS.ONE_DAY, + MIN: DURATIONS.TWELVE_HOURS, + MAX: DURATIONS.TWO_DAY, + }, + ERROR: DURATIONS.TEN_MINUTES, +}; /** * Resolves the cache seconds based on the requested, default, min, and max values. @@ -56,7 +114,7 @@ const setCacheHeaders = (res, cacheSeconds) => { "Cache-Control", `max-age=${cacheSeconds}, ` + `s-maxage=${cacheSeconds}, ` + - `stale-while-revalidate=${CONSTANTS.ONE_DAY}`, + `stale-while-revalidate=${DURATIONS.ONE_DAY}`, ); }; @@ -80,10 +138,16 @@ const setErrorCacheHeaders = (res) => { // Use lower cache period for errors. res.setHeader( "Cache-Control", - `max-age=${CONSTANTS.ERROR_CACHE_SECONDS}, ` + - `s-maxage=${CONSTANTS.ERROR_CACHE_SECONDS}, ` + - `stale-while-revalidate=${CONSTANTS.ONE_DAY}`, + `max-age=${CACHE_TTL.ERROR}, ` + + `s-maxage=${CACHE_TTL.ERROR}, ` + + `stale-while-revalidate=${DURATIONS.ONE_DAY}`, ); }; -export { resolveCacheSeconds, setCacheHeaders, setErrorCacheHeaders }; +export { + resolveCacheSeconds, + setCacheHeaders, + setErrorCacheHeaders, + DURATIONS, + CACHE_TTL, +}; diff --git a/src/common/index.js b/src/common/index.js index 2e7e9cb20fe0b..39bbd6d6ddb01 100644 --- a/src/common/index.js +++ b/src/common/index.js @@ -1,3 +1,5 @@ +// @ts-check + export { blacklist } from "./blacklist.js"; export { Card } from "./Card.js"; export { createProgressNode } from "./createProgressNode.js"; @@ -20,7 +22,6 @@ export { getCardColors, wrapTextMultiline, logger, - CONSTANTS, CustomError, MissingParamError, measureText, diff --git a/src/common/utils.js b/src/common/utils.js index 3dac650bc65e2..8b2fe01dcd1d0 100644 --- a/src/common/utils.js +++ b/src/common/utils.js @@ -452,34 +452,6 @@ const noop = () => {}; const logger = process.env.NODE_ENV === "test" ? { log: noop, error: noop } : console; -const MIN = 60; -const HOUR = 60 * MIN; -const DAY = 24 * HOUR; - -const CONSTANTS = { - ONE_MINUTE: MIN, - FIVE_MINUTES: 5 * MIN, - TEN_MINUTES: 10 * MIN, - FIFTEEN_MINUTES: 15 * MIN, - THIRTY_MINUTES: 30 * MIN, - - TWO_HOURS: 2 * HOUR, - FOUR_HOURS: 4 * HOUR, - SIX_HOURS: 6 * HOUR, - EIGHT_HOURS: 8 * HOUR, - TWELVE_HOURS: 12 * HOUR, - - ONE_DAY: DAY, - TWO_DAY: 2 * DAY, - SIX_DAY: 6 * DAY, - TEN_DAY: 10 * DAY, - - CARD_CACHE_SECONDS: DAY, - TOP_LANGS_CACHE_SECONDS: 6 * DAY, - PIN_CARD_CACHE_SECONDS: 10 * DAY, - ERROR_CACHE_SECONDS: 10 * MIN, -}; - /** * Missing query parameter class. */ @@ -648,7 +620,6 @@ export { getCardColors, wrapTextMultiline, logger, - CONSTANTS, CustomError, MissingParamError, measureText, diff --git a/tests/api.test.js b/tests/api.test.js index caaa1c5a26668..e54764a31aaf4 100644 --- a/tests/api.test.js +++ b/tests/api.test.js @@ -13,7 +13,8 @@ import MockAdapter from "axios-mock-adapter"; import api from "../api/index.js"; import { calculateRank } from "../src/calculateRank.js"; import { renderStatsCard } from "../src/cards/stats.js"; -import { CONSTANTS, renderError } from "../src/common/utils.js"; +import { renderError } from "../src/common/utils.js"; +import { CACHE_TTL, DURATIONS } from "../src/common/cache.js"; /** * @type {import("../src/fetchers/stats").StatsData} @@ -196,15 +197,15 @@ describe("Test /api/", () => { ["Content-Type", "image/svg+xml"], [ "Cache-Control", - `max-age=${CONSTANTS.CARD_CACHE_SECONDS}, ` + - `s-maxage=${CONSTANTS.CARD_CACHE_SECONDS}, ` + - `stale-while-revalidate=${CONSTANTS.ONE_DAY}`, + `max-age=${CACHE_TTL.STATS_CARD.DEFAULT}, ` + + `s-maxage=${CACHE_TTL.STATS_CARD.DEFAULT}, ` + + `stale-while-revalidate=${DURATIONS.ONE_DAY}`, ], ]); }); it("should set proper cache", async () => { - const cache_seconds = CONSTANTS.TWELVE_HOURS; + const cache_seconds = DURATIONS.TWELVE_HOURS; const { req, res } = faker({ cache_seconds }, data_stats); await api(req, res); @@ -214,7 +215,7 @@ describe("Test /api/", () => { "Cache-Control", `max-age=${cache_seconds}, ` + `s-maxage=${cache_seconds}, ` + - `stale-while-revalidate=${CONSTANTS.ONE_DAY}`, + `stale-while-revalidate=${DURATIONS.ONE_DAY}`, ], ]); }); @@ -227,15 +228,16 @@ describe("Test /api/", () => { ["Content-Type", "image/svg+xml"], [ "Cache-Control", - `max-age=${CONSTANTS.ERROR_CACHE_SECONDS}, ` + - `s-maxage=${CONSTANTS.ERROR_CACHE_SECONDS}, ` + - `stale-while-revalidate=${CONSTANTS.ONE_DAY}`, + `max-age=${CACHE_TTL.ERROR}, ` + + `s-maxage=${CACHE_TTL.ERROR}, ` + + `stale-while-revalidate=${DURATIONS.ONE_DAY}`, ], ]); }); it("should properly set cache using CACHE_SECONDS env variable", async () => { - process.env.CACHE_SECONDS = "10000"; + const cacheSeconds = "10000"; + process.env.CACHE_SECONDS = cacheSeconds; const { req, res } = faker({}, data_stats); await api(req, res); @@ -244,7 +246,9 @@ describe("Test /api/", () => { ["Content-Type", "image/svg+xml"], [ "Cache-Control", - `max-age=10000, s-maxage=10000, stale-while-revalidate=${CONSTANTS.ONE_DAY}`, + `max-age=${cacheSeconds}, ` + + `s-maxage=${cacheSeconds}, ` + + `stale-while-revalidate=${DURATIONS.ONE_DAY}`, ], ]); }); @@ -275,9 +279,9 @@ describe("Test /api/", () => { ["Content-Type", "image/svg+xml"], [ "Cache-Control", - `max-age=${CONSTANTS.TWO_DAY}, ` + - `s-maxage=${CONSTANTS.TWO_DAY}, ` + - `stale-while-revalidate=${CONSTANTS.ONE_DAY}`, + `max-age=${CACHE_TTL.STATS_CARD.MAX}, ` + + `s-maxage=${CACHE_TTL.STATS_CARD.MAX}, ` + + `stale-while-revalidate=${DURATIONS.ONE_DAY}`, ], ]); } @@ -291,9 +295,9 @@ describe("Test /api/", () => { ["Content-Type", "image/svg+xml"], [ "Cache-Control", - `max-age=${CONSTANTS.TWELVE_HOURS}, ` + - `s-maxage=${CONSTANTS.TWELVE_HOURS}, ` + - `stale-while-revalidate=${CONSTANTS.ONE_DAY}`, + `max-age=${CACHE_TTL.STATS_CARD.MIN}, ` + + `s-maxage=${CACHE_TTL.STATS_CARD.MIN}, ` + + `stale-while-revalidate=${DURATIONS.ONE_DAY}`, ], ]); } @@ -306,9 +310,9 @@ describe("Test /api/", () => { ["Content-Type", "image/svg+xml"], [ "Cache-Control", - `max-age=${CONSTANTS.TWELVE_HOURS}, ` + - `s-maxage=${CONSTANTS.TWELVE_HOURS}, ` + - `stale-while-revalidate=${CONSTANTS.ONE_DAY}`, + `max-age=${CACHE_TTL.STATS_CARD.MIN}, ` + + `s-maxage=${CACHE_TTL.STATS_CARD.MIN}, ` + + `stale-while-revalidate=${DURATIONS.ONE_DAY}`, ], ]); } diff --git a/tests/gist.test.js b/tests/gist.test.js index e136c2b2e58e6..1f3b6000c658f 100644 --- a/tests/gist.test.js +++ b/tests/gist.test.js @@ -6,7 +6,8 @@ import axios from "axios"; import MockAdapter from "axios-mock-adapter"; import gist from "../api/gist.js"; import { renderGistCard } from "../src/cards/gist.js"; -import { CONSTANTS, renderError } from "../src/common/utils.js"; +import { renderError } from "../src/common/utils.js"; +import { CACHE_TTL, DURATIONS } from "../src/common/cache.js"; const gist_data = { data: { @@ -192,9 +193,9 @@ describe("Test /api/gist", () => { expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); expect(res.setHeader).toBeCalledWith( "Cache-Control", - `max-age=${CONSTANTS.TWO_DAY}, ` + - `s-maxage=${CONSTANTS.TWO_DAY}, ` + - `stale-while-revalidate=${CONSTANTS.ONE_DAY}`, + `max-age=${CACHE_TTL.GIST_CARD.DEFAULT}, ` + + `s-maxage=${CACHE_TTL.GIST_CARD.DEFAULT}, ` + + `stale-while-revalidate=${DURATIONS.ONE_DAY}`, ); }); }); diff --git a/tests/pin.test.js b/tests/pin.test.js index 035f4fb525f33..91c756dda0282 100644 --- a/tests/pin.test.js +++ b/tests/pin.test.js @@ -6,7 +6,8 @@ import axios from "axios"; import MockAdapter from "axios-mock-adapter"; import pin from "../api/pin.js"; import { renderRepoCard } from "../src/cards/repo.js"; -import { CONSTANTS, renderError } from "../src/common/utils.js"; +import { renderError } from "../src/common/utils.js"; +import { CACHE_TTL, DURATIONS } from "../src/common/cache.js"; const data_repo = { repository: { @@ -233,9 +234,9 @@ describe("Test /api/pin", () => { expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); expect(res.setHeader).toBeCalledWith( "Cache-Control", - `max-age=${CONSTANTS.PIN_CARD_CACHE_SECONDS}, ` + - `s-maxage=${CONSTANTS.PIN_CARD_CACHE_SECONDS}, ` + - `stale-while-revalidate=${CONSTANTS.ONE_DAY}`, + `max-age=${CACHE_TTL.PIN_CARD.DEFAULT}, ` + + `s-maxage=${CACHE_TTL.PIN_CARD.DEFAULT}, ` + + `stale-while-revalidate=${DURATIONS.ONE_DAY}`, ); }); }); diff --git a/tests/top-langs.test.js b/tests/top-langs.test.js index 62ad3494d2eac..41ee95e142f1a 100644 --- a/tests/top-langs.test.js +++ b/tests/top-langs.test.js @@ -6,7 +6,8 @@ import axios from "axios"; import MockAdapter from "axios-mock-adapter"; import topLangs from "../api/top-langs.js"; import { renderTopLanguages } from "../src/cards/top-languages.js"; -import { CONSTANTS, renderError } from "../src/common/utils.js"; +import { renderError } from "../src/common/utils.js"; +import { CACHE_TTL, DURATIONS } from "../src/common/cache.js"; const data_langs = { data: { @@ -238,9 +239,9 @@ describe("Test /api/top-langs", () => { expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); expect(res.setHeader).toBeCalledWith( "Cache-Control", - `max-age=${CONSTANTS.TOP_LANGS_CACHE_SECONDS}, ` + - `s-maxage=${CONSTANTS.TOP_LANGS_CACHE_SECONDS}, ` + - `stale-while-revalidate=${CONSTANTS.ONE_DAY}`, + `max-age=${CACHE_TTL.TOP_LANGS_CARD.DEFAULT}, ` + + `s-maxage=${CACHE_TTL.TOP_LANGS_CARD.DEFAULT}, ` + + `stale-while-revalidate=${DURATIONS.ONE_DAY}`, ); }); }); diff --git a/tests/wakatime.test.js b/tests/wakatime.test.js index ce9843df157e3..2b269c2724879 100644 --- a/tests/wakatime.test.js +++ b/tests/wakatime.test.js @@ -4,6 +4,7 @@ import axios from "axios"; import MockAdapter from "axios-mock-adapter"; import wakatime from "../api/wakatime.js"; import { renderWakatimeCard } from "../src/cards/wakatime.js"; +import { CACHE_TTL, DURATIONS } from "../src/common/cache.js"; const wakaTimeData = { data: { @@ -119,4 +120,25 @@ describe("Test /api/wakatime", () => { expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); expect(res.send).toBeCalledWith(renderWakatimeCard(wakaTimeData.data, {})); }); + + it("should have proper cache", async () => { + const username = "anuraghazra"; + const req = { query: { username } }; + const res = { setHeader: jest.fn(), send: jest.fn() }; + mock + .onGet( + `https://wakatime.com/api/v1/users/${username}/stats?is_including_today=true`, + ) + .reply(200, wakaTimeData); + + await wakatime(req, res); + + expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); + expect(res.setHeader).toBeCalledWith( + "Cache-Control", + `max-age=${CACHE_TTL.WAKATIME_CARD.DEFAULT}, ` + + `s-maxage=${CACHE_TTL.WAKATIME_CARD.DEFAULT}, ` + + `stale-while-revalidate=${DURATIONS.ONE_DAY}`, + ); + }); }); From 7b0b366781f35c5ea4a5e77248448b1ad2af64a3 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Thu, 9 Oct 2025 21:12:25 +0300 Subject: [PATCH 163/265] docs(readme): add missing info about wakatime card default cache timing (#4552) Co-authored-by: Alexandr --- readme.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/readme.md b/readme.md index f40df627b77a0..b734630d81e70 100644 --- a/readme.md +++ b/readme.md @@ -288,7 +288,7 @@ You can customize the appearance of all your cards however you wish with URL par | `border_radius` | Corner rounding on the card. | number | `4.5` | > [!WARNING] -> We use caching to decrease the load on our servers (see ). Our cards have the following default cache hours: stats card - 24 hours, top languages card - 144 hours (6 days), pin card - 240 hours (10 days), gist card - 48 hours (2 days). If you want the data on your statistics card to be updated more often you can [deploy your own instance](#deploy-on-your-own) and set [environment variable](#available-environment-variables) `CACHE_SECONDS` to a value of your choosing. +> We use caching to decrease the load on our servers (see ). Our cards have the following default cache hours: stats card - 24 hours, top languages card - 144 hours (6 days), pin card - 240 hours (10 days), gist card - 48 hours (2 days), and wakatime card - 24 hours. If you want the data on your cards to be updated more often you can [deploy your own instance](#deploy-on-your-own) and set [environment variable](#available-environment-variables) `CACHE_SECONDS` to a value of your choosing. ##### Gradient in bg\_color From f6e5d507ad02c53e328f00dcd1520fa283ac50b1 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Thu, 9 Oct 2025 21:13:20 +0300 Subject: [PATCH 164/265] docs(readme): use same markdown syntax for lists across all file and remove redundant indentations (#4553) Co-authored-by: Alexandr --- readme.md | 34 +++++++++++++++++----------------- 1 file changed, 17 insertions(+), 17 deletions(-) diff --git a/readme.md b/readme.md index b734630d81e70..95bcf43f58b2f 100644 --- a/readme.md +++ b/readme.md @@ -808,29 +808,29 @@ Selecting the right scopes for your token is important in case you want to displ ### Classic token - - Go to [Account -> Settings -> Developer Settings -> Personal access tokens -> Tokens (classic)](https://github.com/settings/tokens). - - Click on `Generate new token -> Generate new token (classic)`. - - Scopes to select: - - repo - - read:user - - Click on `Generate token` and copy it. +* Go to [Account -> Settings -> Developer Settings -> Personal access tokens -> Tokens (classic)](https://github.com/settings/tokens). +* Click on `Generate new token -> Generate new token (classic)`. +* Scopes to select: + * repo + * read:user +* Click on `Generate token` and copy it. ### Fine-grained token > [!WARNING]\ > This limits the number of issues to the number of issues on your repositories only and only takes public commits into account. - - Go to [Account -> Settings -> Developer Settings -> Personal access tokens -> Fine-grained tokens](https://github.com/settings/tokens). - - Click on `Generate new token -> Generate new token`. - - Select an expiration date - - Select `All repositories` - - Scopes to select in `Repository permission`: - - Commit statuses: read-only - - Contents: read-only - - Issues: read-only - - Metadata: read-only - - Pull requests: read-only - - Click on `Generate token` and copy it. +* Go to [Account -> Settings -> Developer Settings -> Personal access tokens -> Fine-grained tokens](https://github.com/settings/tokens). +* Click on `Generate new token -> Generate new token`. +* Select an expiration date +* Select `All repositories` +* Scopes to select in `Repository permission`: + * Commit statuses: read-only + * Contents: read-only + * Issues: read-only + * Metadata: read-only + * Pull requests: read-only +* Click on `Generate token` and copy it. ## On Vercel From b164ecebda4bf6ddba04b2b1d42940416c3a81ec Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Thu, 9 Oct 2025 22:31:46 +0300 Subject: [PATCH 165/265] refactor: move errors related code into separate file (#4554) * refactor: move errors related code into separate file * jsdoc --------- Co-authored-by: Alexandr --- src/cards/stats.js | 3 +- src/common/error.js | 69 +++++++++++++++++++++++++++++++++++ src/common/index.js | 2 - src/common/retryer.js | 11 ++++-- src/common/utils.js | 59 +----------------------------- src/fetchers/gist.js | 3 +- src/fetchers/repo.js | 4 +- src/fetchers/stats.js | 9 +---- src/fetchers/top-languages.js | 9 +---- src/fetchers/wakatime.js | 6 ++- tests/renderStatsCard.test.js | 3 +- 11 files changed, 95 insertions(+), 83 deletions(-) create mode 100644 src/common/error.js diff --git a/src/cards/stats.js b/src/cards/stats.js index 8920c52b11b24..6e5bdd5186a74 100644 --- a/src/cards/stats.js +++ b/src/cards/stats.js @@ -1,9 +1,10 @@ // @ts-check + import { Card } from "../common/Card.js"; +import { CustomError } from "../common/error.js"; import { I18n } from "../common/I18n.js"; import { icons, rankIcon } from "../common/icons.js"; import { - CustomError, clampValue, flexLayout, getCardColors, diff --git a/src/common/error.js b/src/common/error.js new file mode 100644 index 0000000000000..c76a198d75d6a --- /dev/null +++ b/src/common/error.js @@ -0,0 +1,69 @@ +/** + * @type {string} A general message to ask user to try again later. + */ +const TRY_AGAIN_LATER = "Please try again later"; + +/** + * @type {Object} A map of error types to secondary error messages. + */ +const SECONDARY_ERROR_MESSAGES = { + MAX_RETRY: + "You can deploy own instance or wait until public will be no longer limited", + NO_TOKENS: + "Please add an env variable called PAT_1 with your GitHub API token in vercel", + USER_NOT_FOUND: "Make sure the provided username is not an organization", + GRAPHQL_ERROR: TRY_AGAIN_LATER, + GITHUB_REST_API_ERROR: TRY_AGAIN_LATER, + WAKATIME_USER_NOT_FOUND: "Make sure you have a public WakaTime profile", +}; + +/** + * Custom error class to handle custom GRS errors. + */ +class CustomError extends Error { + /** + * Custom error constructor. + * + * @param {string} message Error message. + * @param {string} type Error type. + */ + constructor(message, type) { + super(message); + this.type = type; + this.secondaryMessage = SECONDARY_ERROR_MESSAGES[type] || type; + } + + static MAX_RETRY = "MAX_RETRY"; + static NO_TOKENS = "NO_TOKENS"; + static USER_NOT_FOUND = "USER_NOT_FOUND"; + static GRAPHQL_ERROR = "GRAPHQL_ERROR"; + static GITHUB_REST_API_ERROR = "GITHUB_REST_API_ERROR"; + static WAKATIME_ERROR = "WAKATIME_ERROR"; +} + +/** + * Missing query parameter class. + */ +class MissingParamError extends Error { + /** + * Missing query parameter error constructor. + * + * @param {string[]} missedParams An array of missing parameters names. + * @param {string=} secondaryMessage Optional secondary message to display. + */ + constructor(missedParams, secondaryMessage) { + const msg = `Missing params ${missedParams + .map((p) => `"${p}"`) + .join(", ")} make sure you pass the parameters in URL`; + super(msg); + this.missedParams = missedParams; + this.secondaryMessage = secondaryMessage; + } +} + +export { + CustomError, + MissingParamError, + SECONDARY_ERROR_MESSAGES, + TRY_AGAIN_LATER, +}; diff --git a/src/common/index.js b/src/common/index.js index 39bbd6d6ddb01..aa5ec0828b41a 100644 --- a/src/common/index.js +++ b/src/common/index.js @@ -22,8 +22,6 @@ export { getCardColors, wrapTextMultiline, logger, - CustomError, - MissingParamError, measureText, lowercaseTrim, chunkArray, diff --git a/src/common/retryer.js b/src/common/retryer.js index 090865ed00c6d..c65d6ededdfdf 100644 --- a/src/common/retryer.js +++ b/src/common/retryer.js @@ -1,4 +1,7 @@ -import { CustomError, logger } from "./utils.js"; +// @ts-check + +import { CustomError } from "./error.js"; +import { logger } from "./utils.js"; // Script variables. @@ -10,7 +13,7 @@ const RETRIES = process.env.NODE_ENV === "test" ? 7 : PATs; /** * @typedef {import("axios").AxiosResponse} AxiosResponse Axios response. - * @typedef {(variables: object, token: string) => Promise} FetcherFunction Fetcher function. + * @typedef {(variables: object, token: string, retriesForTests?: number) => Promise} FetcherFunction Fetcher function. */ /** @@ -19,7 +22,7 @@ const RETRIES = process.env.NODE_ENV === "test" ? 7 : PATs; * @param {FetcherFunction} fetcher The fetcher function. * @param {object} variables Object with arguments to pass to the fetcher function. * @param {number} retries How many times to retry. - * @returns {Promise} The response from the fetcher function. + * @returns {Promise} The response from the fetcher function. */ const retryer = async (fetcher, variables, retries = 0) => { if (!RETRIES) { @@ -37,7 +40,9 @@ const retryer = async (fetcher, variables, retries = 0) => { // try to fetch with the first token since RETRIES is 0 index i'm adding +1 let response = await fetcher( variables, + // @ts-ignore process.env[`PAT_${retries + 1}`], + // used in tests for faking rate limit retries, ); diff --git a/src/common/utils.js b/src/common/utils.js index 8b2fe01dcd1d0..c9ceb24a568d6 100644 --- a/src/common/utils.js +++ b/src/common/utils.js @@ -1,43 +1,10 @@ // @ts-check + import axios from "axios"; import toEmoji from "emoji-name-map"; import wrap from "word-wrap"; import { themes } from "../../themes/index.js"; - -const TRY_AGAIN_LATER = "Please try again later"; - -const SECONDARY_ERROR_MESSAGES = { - MAX_RETRY: - "You can deploy own instance or wait until public will be no longer limited", - NO_TOKENS: - "Please add an env variable called PAT_1 with your GitHub API token in vercel", - USER_NOT_FOUND: "Make sure the provided username is not an organization", - GRAPHQL_ERROR: TRY_AGAIN_LATER, - GITHUB_REST_API_ERROR: TRY_AGAIN_LATER, - WAKATIME_USER_NOT_FOUND: "Make sure you have a public WakaTime profile", -}; - -/** - * Custom error class to handle custom GRS errors. - */ -class CustomError extends Error { - /** - * @param {string} message Error message. - * @param {string} type Error type. - */ - constructor(message, type) { - super(message); - this.type = type; - this.secondaryMessage = SECONDARY_ERROR_MESSAGES[type] || type; - } - - static MAX_RETRY = "MAX_RETRY"; - static NO_TOKENS = "NO_TOKENS"; - static USER_NOT_FOUND = "USER_NOT_FOUND"; - static GRAPHQL_ERROR = "GRAPHQL_ERROR"; - static GITHUB_REST_API_ERROR = "GITHUB_REST_API_ERROR"; - static WAKATIME_ERROR = "WAKATIME_ERROR"; -} +import { SECONDARY_ERROR_MESSAGES, TRY_AGAIN_LATER } from "./error.js"; /** * Auto layout utility, allows us to layout things vertically or horizontally with @@ -452,26 +419,6 @@ const noop = () => {}; const logger = process.env.NODE_ENV === "test" ? { log: noop, error: noop } : console; -/** - * Missing query parameter class. - */ -class MissingParamError extends Error { - /** - * Missing query parameter error constructor. - * - * @param {string[]} missedParams An array of missing parameters names. - * @param {string=} secondaryMessage Optional secondary message to display. - */ - constructor(missedParams, secondaryMessage) { - const msg = `Missing params ${missedParams - .map((p) => `"${p}"`) - .join(", ")} make sure you pass the parameters in URL`; - super(msg); - this.missedParams = missedParams; - this.secondaryMessage = secondaryMessage; - } -} - /** * Retrieve text length. * @@ -620,8 +567,6 @@ export { getCardColors, wrapTextMultiline, logger, - CustomError, - MissingParamError, measureText, lowercaseTrim, chunkArray, diff --git a/src/fetchers/gist.js b/src/fetchers/gist.js index cd4006b2224c5..ce96c2b111111 100644 --- a/src/fetchers/gist.js +++ b/src/fetchers/gist.js @@ -1,7 +1,8 @@ // @ts-check -import { request, MissingParamError } from "../common/utils.js"; +import { request } from "../common/utils.js"; import { retryer } from "../common/retryer.js"; +import { MissingParamError } from "../common/error.js"; /** * @typedef {import('axios').AxiosRequestHeaders} AxiosRequestHeaders Axios request headers. diff --git a/src/fetchers/repo.js b/src/fetchers/repo.js index 6438f8895cfb6..3cad9c00fd588 100644 --- a/src/fetchers/repo.js +++ b/src/fetchers/repo.js @@ -1,6 +1,8 @@ // @ts-check + +import { MissingParamError } from "../common/error.js"; import { retryer } from "../common/retryer.js"; -import { MissingParamError, request } from "../common/utils.js"; +import { request } from "../common/utils.js"; /** * @typedef {import('axios').AxiosRequestHeaders} AxiosRequestHeaders Axios request headers. diff --git a/src/fetchers/stats.js b/src/fetchers/stats.js index d4ead2944f4c6..f22dfaf65f7c0 100644 --- a/src/fetchers/stats.js +++ b/src/fetchers/stats.js @@ -5,14 +5,9 @@ import * as dotenv from "dotenv"; import githubUsernameRegex from "github-username-regex"; import { calculateRank } from "../calculateRank.js"; import { retryer } from "../common/retryer.js"; -import { - CustomError, - logger, - MissingParamError, - request, - wrapTextMultiline, -} from "../common/utils.js"; +import { logger, request, wrapTextMultiline } from "../common/utils.js"; import { excludeRepositories } from "../common/envs.js"; +import { CustomError, MissingParamError } from "../common/error.js"; dotenv.config(); diff --git a/src/fetchers/top-languages.js b/src/fetchers/top-languages.js index 2e0c1e2110a1c..9542678e581b0 100644 --- a/src/fetchers/top-languages.js +++ b/src/fetchers/top-languages.js @@ -1,14 +1,9 @@ // @ts-check import { retryer } from "../common/retryer.js"; -import { - CustomError, - logger, - MissingParamError, - request, - wrapTextMultiline, -} from "../common/utils.js"; +import { logger, request, wrapTextMultiline } from "../common/utils.js"; import { excludeRepositories } from "../common/envs.js"; +import { CustomError, MissingParamError } from "../common/error.js"; /** * @typedef {import("axios").AxiosRequestHeaders} AxiosRequestHeaders Axios request headers. diff --git a/src/fetchers/wakatime.js b/src/fetchers/wakatime.js index f69d6ae498eef..a081dbd2dc07d 100644 --- a/src/fetchers/wakatime.js +++ b/src/fetchers/wakatime.js @@ -1,11 +1,13 @@ +// @ts-check + import axios from "axios"; -import { CustomError, MissingParamError } from "../common/utils.js"; +import { CustomError, MissingParamError } from "../common/error.js"; /** * WakaTime data fetcher. * * @param {{username: string, api_domain: string }} props Fetcher props. - * @returns {Promise} WakaTime data response. + * @returns {Promise} WakaTime data response. */ const fetchWakatimeStats = async ({ username, api_domain }) => { if (!username) { diff --git a/tests/renderStatsCard.test.js b/tests/renderStatsCard.test.js index 40010944d4069..de123ffe88df2 100644 --- a/tests/renderStatsCard.test.js +++ b/tests/renderStatsCard.test.js @@ -7,8 +7,7 @@ import { import "@testing-library/jest-dom"; import { cssToObject } from "@uppercod/css-to-object"; import { renderStatsCard } from "../src/cards/stats.js"; -import { CustomError } from "../src/common/utils.js"; - +import { CustomError } from "../src/common/error.js"; import { themes } from "../themes/index.js"; const stats = { From 99b95fbc95c45386407ffdf12a1aa4e458bcb235 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 10 Oct 2025 18:48:59 +0300 Subject: [PATCH 166/265] ci(deps): bump ossf/scorecard-action from 2.4.2 to 2.4.3 (#4520) Bumps [ossf/scorecard-action](https://github.com/ossf/scorecard-action) from 2.4.2 to 2.4.3. - [Release notes](https://github.com/ossf/scorecard-action/releases) - [Changelog](https://github.com/ossf/scorecard-action/blob/main/RELEASE.md) - [Commits](https://github.com/ossf/scorecard-action/compare/05b42c624433fc40578a4040d5cf5e36ddca8cde...4eaacf0543bb3f2c246792bd56e8cdeffafb205a) --- updated-dependencies: - dependency-name: ossf/scorecard-action dependency-version: 2.4.3 dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- .github/workflows/ossf-analysis.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/ossf-analysis.yml b/.github/workflows/ossf-analysis.yml index 3261c5bccdb72..832a9d6f1234c 100644 --- a/.github/workflows/ossf-analysis.yml +++ b/.github/workflows/ossf-analysis.yml @@ -27,7 +27,7 @@ jobs: persist-credentials: false - name: "Run analysis" - uses: ossf/scorecard-action@05b42c624433fc40578a4040d5cf5e36ddca8cde # v2.4.2 + uses: ossf/scorecard-action@4eaacf0543bb3f2c246792bd56e8cdeffafb205a # v2.4.3 with: results_file: results.sarif results_format: sarif From 3fd9ce0778d57045c78d48b9eed6b43d896db8f8 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 10 Oct 2025 18:52:01 +0300 Subject: [PATCH 167/265] build(deps-dev): bump @eslint/js from 9.36.0 to 9.37.0 (#4521) Bumps [@eslint/js](https://github.com/eslint/eslint/tree/HEAD/packages/js) from 9.36.0 to 9.37.0. - [Release notes](https://github.com/eslint/eslint/releases) - [Commits](https://github.com/eslint/eslint/commits/v9.37.0/packages/js) --- updated-dependencies: - dependency-name: "@eslint/js" dependency-version: 9.37.0 dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- package-lock.json | 32 +++++++++++++++++++++++++------- package.json | 2 +- 2 files changed, 26 insertions(+), 8 deletions(-) diff --git a/package-lock.json b/package-lock.json index df42504c40b74..28f48cea8bb28 100644 --- a/package-lock.json +++ b/package-lock.json @@ -19,7 +19,7 @@ "@actions/core": "^1.11.1", "@actions/github": "^6.0.1", "@eslint/eslintrc": "^3.3.1", - "@eslint/js": "^9.36.0", + "@eslint/js": "^9.37.0", "@testing-library/dom": "^10.4.1", "@testing-library/jest-dom": "^6.8.0", "@uppercod/css-to-object": "^1.1.1", @@ -864,9 +864,9 @@ } }, "node_modules/@eslint/js": { - "version": "9.36.0", - "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.36.0.tgz", - "integrity": "sha512-uhCbYtYynH30iZErszX78U+nR3pJU3RHGQ57NXy5QupD4SBVwDeU8TNBy+MjMngc1UyIW9noKqsRqfjQTBU2dw==", + "version": "9.37.0", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.37.0.tgz", + "integrity": "sha512-jaS+NJ+hximswBG6pjNX0uEJZkrT0zwpVi3BA3vX22aFGjJjmgSTSmPpZCRKmoBL5VY/M6p0xsSJx7rk7sy5gg==", "dev": true, "engines": { "node": "^18.18.0 || ^20.9.0 || >=21.1.0" @@ -3317,6 +3317,18 @@ "url": "https://opencollective.com/eslint" } }, + "node_modules/eslint/node_modules/@eslint/js": { + "version": "9.36.0", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.36.0.tgz", + "integrity": "sha512-uhCbYtYynH30iZErszX78U+nR3pJU3RHGQ57NXy5QupD4SBVwDeU8TNBy+MjMngc1UyIW9noKqsRqfjQTBU2dw==", + "dev": true, + "engines": { + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" + }, + "funding": { + "url": "https://eslint.org/donate" + } + }, "node_modules/eslint/node_modules/escape-string-regexp": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", @@ -8347,9 +8359,9 @@ } }, "@eslint/js": { - "version": "9.36.0", - "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.36.0.tgz", - "integrity": "sha512-uhCbYtYynH30iZErszX78U+nR3pJU3RHGQ57NXy5QupD4SBVwDeU8TNBy+MjMngc1UyIW9noKqsRqfjQTBU2dw==", + "version": "9.37.0", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.37.0.tgz", + "integrity": "sha512-jaS+NJ+hximswBG6pjNX0uEJZkrT0zwpVi3BA3vX22aFGjJjmgSTSmPpZCRKmoBL5VY/M6p0xsSJx7rk7sy5gg==", "dev": true }, "@eslint/object-schema": { @@ -10124,6 +10136,12 @@ "optionator": "^0.9.3" }, "dependencies": { + "@eslint/js": { + "version": "9.36.0", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.36.0.tgz", + "integrity": "sha512-uhCbYtYynH30iZErszX78U+nR3pJU3RHGQ57NXy5QupD4SBVwDeU8TNBy+MjMngc1UyIW9noKqsRqfjQTBU2dw==", + "dev": true + }, "escape-string-regexp": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", diff --git a/package.json b/package.json index c8d3982b82a32..4e1566e6b5b20 100644 --- a/package.json +++ b/package.json @@ -39,7 +39,7 @@ "@actions/core": "^1.11.1", "@actions/github": "^6.0.1", "@eslint/eslintrc": "^3.3.1", - "@eslint/js": "^9.36.0", + "@eslint/js": "^9.37.0", "@testing-library/dom": "^10.4.1", "@testing-library/jest-dom": "^6.8.0", "@uppercod/css-to-object": "^1.1.1", From 9648e8c67b6c3ba316d4b263723b70e2eb397d01 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 10 Oct 2025 18:54:45 +0300 Subject: [PATCH 168/265] build(deps-dev): bump eslint from 9.36.0 to 9.37.0 (#4523) Bumps [eslint](https://github.com/eslint/eslint) from 9.36.0 to 9.37.0. - [Release notes](https://github.com/eslint/eslint/releases) - [Commits](https://github.com/eslint/eslint/compare/v9.36.0...v9.37.0) --- updated-dependencies: - dependency-name: eslint dependency-version: 9.37.0 dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- package-lock.json | 257 ++++++++++++++++++---------------------------- package.json | 2 +- 2 files changed, 102 insertions(+), 157 deletions(-) diff --git a/package-lock.json b/package-lock.json index 28f48cea8bb28..d0e68583a293c 100644 --- a/package-lock.json +++ b/package-lock.json @@ -25,7 +25,7 @@ "@uppercod/css-to-object": "^1.1.1", "axios-mock-adapter": "^2.1.0", "color-contrast-checker": "^2.1.0", - "eslint": "^9.36.0", + "eslint": "^9.37.0", "eslint-config-prettier": "^10.1.8", "eslint-plugin-jsdoc": "^60.5.0", "express": "^5.1.0", @@ -807,18 +807,21 @@ } }, "node_modules/@eslint/config-helpers": { - "version": "0.3.1", - "resolved": "https://registry.npmjs.org/@eslint/config-helpers/-/config-helpers-0.3.1.tgz", - "integrity": "sha512-xR93k9WhrDYpXHORXpxVL5oHj3Era7wo6k/Wd8/IsQNnZUTzkGS29lyn3nAT05v6ltUuTFVCCYDEGfy2Or/sPA==", + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/@eslint/config-helpers/-/config-helpers-0.4.0.tgz", + "integrity": "sha512-WUFvV4WoIwW8Bv0KeKCIIEgdSiFOsulyN0xrMu+7z43q/hkOLXjvb5u7UC9jDxvRzcrbEmuZBX5yJZz1741jog==", "dev": true, + "dependencies": { + "@eslint/core": "^0.16.0" + }, "engines": { "node": "^18.18.0 || ^20.9.0 || >=21.1.0" } }, "node_modules/@eslint/core": { - "version": "0.15.2", - "resolved": "https://registry.npmjs.org/@eslint/core/-/core-0.15.2.tgz", - "integrity": "sha512-78Md3/Rrxh83gCxoUc0EiciuOHsIITzLy53m3d9UyiW8y9Dj2D29FeETqyKA+BRK76tnTp6RXWb3pCay8Oyomg==", + "version": "0.16.0", + "resolved": "https://registry.npmjs.org/@eslint/core/-/core-0.16.0.tgz", + "integrity": "sha512-nmC8/totwobIiFcGkDza3GIKfAw1+hLiYVrh3I1nIomQ8PEr5cxg34jnkmGawul/ep52wGRAcyeDCNtWKSOj4Q==", "dev": true, "dependencies": { "@types/json-schema": "^7.0.15" @@ -885,52 +888,18 @@ } }, "node_modules/@eslint/plugin-kit": { - "version": "0.3.5", - "resolved": "https://registry.npmjs.org/@eslint/plugin-kit/-/plugin-kit-0.3.5.tgz", - "integrity": "sha512-Z5kJ+wU3oA7MMIqVR9tyZRtjYPr4OC004Q4Rw7pgOKUOKkJfZ3O24nz3WYfGRpMDNmcOi3TwQOmgm7B7Tpii0w==", + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/@eslint/plugin-kit/-/plugin-kit-0.4.0.tgz", + "integrity": "sha512-sB5uyeq+dwCWyPi31B2gQlVlo+j5brPlWx4yZBrEaRo/nhdDE8Xke1gsGgtiBdaBTxuTkceLVuVt/pclrasb0A==", "dev": true, "dependencies": { - "@eslint/core": "^0.15.2", + "@eslint/core": "^0.16.0", "levn": "^0.4.1" }, "engines": { "node": "^18.18.0 || ^20.9.0 || >=21.1.0" } }, - "node_modules/@eslint/plugin-kit/node_modules/levn": { - "version": "0.4.1", - "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", - "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", - "dev": true, - "dependencies": { - "prelude-ls": "^1.2.1", - "type-check": "~0.4.0" - }, - "engines": { - "node": ">= 0.8.0" - } - }, - "node_modules/@eslint/plugin-kit/node_modules/prelude-ls": { - "version": "1.2.1", - "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", - "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", - "dev": true, - "engines": { - "node": ">= 0.8.0" - } - }, - "node_modules/@eslint/plugin-kit/node_modules/type-check": { - "version": "0.4.0", - "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", - "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", - "dev": true, - "dependencies": { - "prelude-ls": "^1.2.1" - }, - "engines": { - "node": ">= 0.8.0" - } - }, "node_modules/@fastify/busboy": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/@fastify/busboy/-/busboy-2.0.0.tgz", @@ -3163,19 +3132,19 @@ } }, "node_modules/eslint": { - "version": "9.36.0", - "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.36.0.tgz", - "integrity": "sha512-hB4FIzXovouYzwzECDcUkJ4OcfOEkXTv2zRY6B9bkwjx/cprAq0uvm1nl7zvQ0/TsUk0zQiN4uPfJpB9m+rPMQ==", + "version": "9.37.0", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.37.0.tgz", + "integrity": "sha512-XyLmROnACWqSxiGYArdef1fItQd47weqB7iwtfr9JHwRrqIXZdcFMvvEcL9xHCmL0SNsOvF0c42lWyM1U5dgig==", "dev": true, "dependencies": { "@eslint-community/eslint-utils": "^4.8.0", "@eslint-community/regexpp": "^4.12.1", "@eslint/config-array": "^0.21.0", - "@eslint/config-helpers": "^0.3.1", - "@eslint/core": "^0.15.2", + "@eslint/config-helpers": "^0.4.0", + "@eslint/core": "^0.16.0", "@eslint/eslintrc": "^3.3.1", - "@eslint/js": "9.36.0", - "@eslint/plugin-kit": "^0.3.5", + "@eslint/js": "9.37.0", + "@eslint/plugin-kit": "^0.4.0", "@humanfs/node": "^0.16.6", "@humanwhocodes/module-importer": "^1.0.1", "@humanwhocodes/retry": "^0.4.2", @@ -3370,19 +3339,6 @@ "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/eslint/node_modules/levn": { - "version": "0.4.1", - "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", - "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", - "dev": true, - "dependencies": { - "prelude-ls": "^1.2.1", - "type-check": "~0.4.0" - }, - "engines": { - "node": ">= 0.8.0" - } - }, "node_modules/eslint/node_modules/locate-path": { "version": "6.0.0", "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", @@ -3430,27 +3386,6 @@ "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/eslint/node_modules/prelude-ls": { - "version": "1.2.1", - "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", - "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", - "dev": true, - "engines": { - "node": ">= 0.8.0" - } - }, - "node_modules/eslint/node_modules/type-check": { - "version": "0.4.0", - "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", - "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", - "dev": true, - "dependencies": { - "prelude-ls": "^1.2.1" - }, - "engines": { - "node": ">= 0.8.0" - } - }, "node_modules/espree": { "version": "10.4.0", "resolved": "https://registry.npmjs.org/espree/-/espree-10.4.0.tgz", @@ -5704,6 +5639,19 @@ "node": ">=6" } }, + "node_modules/levn": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", + "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", + "dev": true, + "dependencies": { + "prelude-ls": "^1.2.1", + "type-check": "~0.4.0" + }, + "engines": { + "node": ">= 0.8.0" + } + }, "node_modules/lines-and-columns": { "version": "1.2.4", "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz", @@ -6518,6 +6466,15 @@ "node": ">=8" } }, + "node_modules/prelude-ls": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", + "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", + "dev": true, + "engines": { + "node": ">= 0.8.0" + } + }, "node_modules/prettier": { "version": "3.6.2", "resolved": "https://registry.npmjs.org/prettier/-/prettier-3.6.2.tgz", @@ -7397,6 +7354,18 @@ "node": ">=0.6.11 <=0.7.0 || >=0.7.3" } }, + "node_modules/type-check": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", + "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", + "dev": true, + "dependencies": { + "prelude-ls": "^1.2.1" + }, + "engines": { + "node": ">= 0.8.0" + } + }, "node_modules/type-detect": { "version": "4.0.8", "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", @@ -8319,15 +8288,18 @@ } }, "@eslint/config-helpers": { - "version": "0.3.1", - "resolved": "https://registry.npmjs.org/@eslint/config-helpers/-/config-helpers-0.3.1.tgz", - "integrity": "sha512-xR93k9WhrDYpXHORXpxVL5oHj3Era7wo6k/Wd8/IsQNnZUTzkGS29lyn3nAT05v6ltUuTFVCCYDEGfy2Or/sPA==", - "dev": true + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/@eslint/config-helpers/-/config-helpers-0.4.0.tgz", + "integrity": "sha512-WUFvV4WoIwW8Bv0KeKCIIEgdSiFOsulyN0xrMu+7z43q/hkOLXjvb5u7UC9jDxvRzcrbEmuZBX5yJZz1741jog==", + "dev": true, + "requires": { + "@eslint/core": "^0.16.0" + } }, "@eslint/core": { - "version": "0.15.2", - "resolved": "https://registry.npmjs.org/@eslint/core/-/core-0.15.2.tgz", - "integrity": "sha512-78Md3/Rrxh83gCxoUc0EiciuOHsIITzLy53m3d9UyiW8y9Dj2D29FeETqyKA+BRK76tnTp6RXWb3pCay8Oyomg==", + "version": "0.16.0", + "resolved": "https://registry.npmjs.org/@eslint/core/-/core-0.16.0.tgz", + "integrity": "sha512-nmC8/totwobIiFcGkDza3GIKfAw1+hLiYVrh3I1nIomQ8PEr5cxg34jnkmGawul/ep52wGRAcyeDCNtWKSOj4Q==", "dev": true, "requires": { "@types/json-schema": "^7.0.15" @@ -8371,40 +8343,13 @@ "dev": true }, "@eslint/plugin-kit": { - "version": "0.3.5", - "resolved": "https://registry.npmjs.org/@eslint/plugin-kit/-/plugin-kit-0.3.5.tgz", - "integrity": "sha512-Z5kJ+wU3oA7MMIqVR9tyZRtjYPr4OC004Q4Rw7pgOKUOKkJfZ3O24nz3WYfGRpMDNmcOi3TwQOmgm7B7Tpii0w==", + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/@eslint/plugin-kit/-/plugin-kit-0.4.0.tgz", + "integrity": "sha512-sB5uyeq+dwCWyPi31B2gQlVlo+j5brPlWx4yZBrEaRo/nhdDE8Xke1gsGgtiBdaBTxuTkceLVuVt/pclrasb0A==", "dev": true, "requires": { - "@eslint/core": "^0.15.2", + "@eslint/core": "^0.16.0", "levn": "^0.4.1" - }, - "dependencies": { - "levn": { - "version": "0.4.1", - "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", - "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", - "dev": true, - "requires": { - "prelude-ls": "^1.2.1", - "type-check": "~0.4.0" - } - }, - "prelude-ls": { - "version": "1.2.1", - "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", - "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", - "dev": true - }, - "type-check": { - "version": "0.4.0", - "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", - "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", - "dev": true, - "requires": { - "prelude-ls": "^1.2.1" - } - } } }, "@fastify/busboy": { @@ -10094,19 +10039,19 @@ "dev": true }, "eslint": { - "version": "9.36.0", - "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.36.0.tgz", - "integrity": "sha512-hB4FIzXovouYzwzECDcUkJ4OcfOEkXTv2zRY6B9bkwjx/cprAq0uvm1nl7zvQ0/TsUk0zQiN4uPfJpB9m+rPMQ==", + "version": "9.37.0", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.37.0.tgz", + "integrity": "sha512-XyLmROnACWqSxiGYArdef1fItQd47weqB7iwtfr9JHwRrqIXZdcFMvvEcL9xHCmL0SNsOvF0c42lWyM1U5dgig==", "dev": true, "requires": { "@eslint-community/eslint-utils": "^4.8.0", "@eslint-community/regexpp": "^4.12.1", "@eslint/config-array": "^0.21.0", - "@eslint/config-helpers": "^0.3.1", - "@eslint/core": "^0.15.2", + "@eslint/config-helpers": "^0.4.0", + "@eslint/core": "^0.16.0", "@eslint/eslintrc": "^3.3.1", - "@eslint/js": "9.36.0", - "@eslint/plugin-kit": "^0.3.5", + "@eslint/js": "9.37.0", + "@eslint/plugin-kit": "^0.4.0", "@humanfs/node": "^0.16.6", "@humanwhocodes/module-importer": "^1.0.1", "@humanwhocodes/retry": "^0.4.2", @@ -10164,16 +10109,6 @@ "path-exists": "^4.0.0" } }, - "levn": { - "version": "0.4.1", - "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", - "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", - "dev": true, - "requires": { - "prelude-ls": "^1.2.1", - "type-check": "~0.4.0" - } - }, "locate-path": { "version": "6.0.0", "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", @@ -10205,21 +10140,6 @@ "requires": { "p-limit": "^3.0.2" } - }, - "prelude-ls": { - "version": "1.2.1", - "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", - "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", - "dev": true - }, - "type-check": { - "version": "0.4.0", - "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", - "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", - "dev": true, - "requires": { - "prelude-ls": "^1.2.1" - } } } }, @@ -11926,6 +11846,16 @@ "integrity": "sha512-qsda+H8jTaUaN/x5vzW2rzc+8Rw4TAQ/4KjB46IwK5VH+IlVeeeje/EoZRpiXvIqjFgK84QffqPztGI3VBLG1A==", "dev": true }, + "levn": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", + "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", + "dev": true, + "requires": { + "prelude-ls": "^1.2.1", + "type-check": "~0.4.0" + } + }, "lines-and-columns": { "version": "1.2.4", "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz", @@ -12500,6 +12430,12 @@ "find-up": "^4.0.0" } }, + "prelude-ls": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", + "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", + "dev": true + }, "prettier": { "version": "3.6.2", "resolved": "https://registry.npmjs.org/prettier/-/prettier-3.6.2.tgz", @@ -13121,6 +13057,15 @@ "integrity": "sha512-1h/Lnq9yajKY2PEbBadPXj3VxsDDu844OnaAo52UVmIzIvwwtBPIuNvkjuzBlTWpfJyUbG3ez0KSBibQkj4ojg==", "dev": true }, + "type-check": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", + "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", + "dev": true, + "requires": { + "prelude-ls": "^1.2.1" + } + }, "type-detect": { "version": "4.0.8", "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", diff --git a/package.json b/package.json index 4e1566e6b5b20..44e4fa065de00 100644 --- a/package.json +++ b/package.json @@ -45,7 +45,7 @@ "@uppercod/css-to-object": "^1.1.1", "axios-mock-adapter": "^2.1.0", "color-contrast-checker": "^2.1.0", - "eslint": "^9.36.0", + "eslint": "^9.37.0", "eslint-config-prettier": "^10.1.8", "eslint-plugin-jsdoc": "^60.5.0", "express": "^5.1.0", From 16e5bb5b190a0cd499a9a7f94d5e6964a324a6e4 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 10 Oct 2025 18:57:32 +0300 Subject: [PATCH 169/265] build(deps-dev): bump eslint-plugin-jsdoc from 60.7.1 to 60.8.2 (#4527) Bumps [eslint-plugin-jsdoc](https://github.com/gajus/eslint-plugin-jsdoc) from 60.7.1 to 60.8.2. - [Release notes](https://github.com/gajus/eslint-plugin-jsdoc/releases) - [Changelog](https://github.com/gajus/eslint-plugin-jsdoc/blob/main/.releaserc) - [Commits](https://github.com/gajus/eslint-plugin-jsdoc/compare/v60.7.1...v60.8.2) --- updated-dependencies: - dependency-name: eslint-plugin-jsdoc dependency-version: 60.8.2 dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- package-lock.json | 58 +++++++++++++++++++++++------------------------ package.json | 2 +- 2 files changed, 30 insertions(+), 30 deletions(-) diff --git a/package-lock.json b/package-lock.json index d0e68583a293c..74e4b4b910aa9 100644 --- a/package-lock.json +++ b/package-lock.json @@ -27,7 +27,7 @@ "color-contrast-checker": "^2.1.0", "eslint": "^9.37.0", "eslint-config-prettier": "^10.1.8", - "eslint-plugin-jsdoc": "^60.5.0", + "eslint-plugin-jsdoc": "^60.8.2", "express": "^5.1.0", "globals": "^16.4.0", "hjson": "^3.2.2", @@ -750,16 +750,16 @@ } }, "node_modules/@es-joy/jsdoccomment": { - "version": "0.65.2", - "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.65.2.tgz", - "integrity": "sha512-/rrj5oayCc7xdoQZ24Tz/+V41IDm+9ILYpTFJOZgav9vfncMNApKR0t/4d1oRXYTcyLZEcGHGOg4xBsD0Doing==", + "version": "0.69.0", + "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.69.0.tgz", + "integrity": "sha512-7UgbKSStPxf2RF2fqKqJq3u1QN4kFzhE/lofHtEuptRjQPdYZOLGsqGcKzQGYWoPG5p8PyxUOoc3/Ca+UcFkdA==", "dev": true, "dependencies": { "@types/estree": "^1.0.8", "@typescript-eslint/types": "^8.45.0", "comment-parser": "1.4.1", "esquery": "^1.6.0", - "jsdoc-type-pratt-parser": "~6.1.2" + "jsdoc-type-pratt-parser": "6.4.0" }, "engines": { "node": ">=20.11.0" @@ -2044,9 +2044,9 @@ "dev": true }, "node_modules/@typescript-eslint/types": { - "version": "8.45.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.45.0.tgz", - "integrity": "sha512-WugXLuOIq67BMgQInIxxnsSyRLFxdkJEJu8r4ngLR56q/4Q5LrbfkFRH27vMTjxEK8Pyz7QfzuZe/G15qQnVRA==", + "version": "8.46.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.46.0.tgz", + "integrity": "sha512-bHGGJyVjSE4dJJIO5yyEWt/cHyNwga/zXGJbJJ8TiO01aVREK6gCTu3L+5wrkb1FbDkQ+TKjMNe9R/QQQP9+rA==", "dev": true, "engines": { "node": "^18.18.0 || ^20.9.0 || >=21.1.0" @@ -3207,12 +3207,12 @@ } }, "node_modules/eslint-plugin-jsdoc": { - "version": "60.7.1", - "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-60.7.1.tgz", - "integrity": "sha512-JCLls7B3Tlb2YS5M6+aZqxb0gnEkr+H9/qMm5HSzynlvq3wqbxS7+4RS954EGuLrITfbaB6nmf3FyZAhOeCUEg==", + "version": "60.8.2", + "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-60.8.2.tgz", + "integrity": "sha512-ebEYZiAVL/ejjNQKO7Q1+FumDjGfs0T3+arQ3U54xomFiySUjKnZOzVZQAWhu+mlZXB4oeoizI4wRH+3i+knDg==", "dev": true, "dependencies": { - "@es-joy/jsdoccomment": "~0.65.2", + "@es-joy/jsdoccomment": "~0.69.0", "are-docs-informative": "^0.0.2", "comment-parser": "1.4.1", "debug": "^4.4.3", @@ -5517,9 +5517,9 @@ } }, "node_modules/jsdoc-type-pratt-parser": { - "version": "6.1.2", - "resolved": "https://registry.npmjs.org/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-6.1.2.tgz", - "integrity": "sha512-ruy+JcplsWkqnYq1m/qokaErhEURwf/vhdTzlPNpei7RJabVWxPxGWoCPSCP0sbsz03d590hTkjLdXjyMxH0iA==", + "version": "6.4.0", + "resolved": "https://registry.npmjs.org/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-6.4.0.tgz", + "integrity": "sha512-tVwTg612vD9h2w5hoRFRNOni7xITDYZigHwBDieLUf4IYPQtk6IFXe/NqJc/hGYteFAeIM+Ld6ZvmLuizKAZ7A==", "dev": true, "engines": { "node": ">=20.0.0" @@ -8249,16 +8249,16 @@ "dev": true }, "@es-joy/jsdoccomment": { - "version": "0.65.2", - "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.65.2.tgz", - "integrity": "sha512-/rrj5oayCc7xdoQZ24Tz/+V41IDm+9ILYpTFJOZgav9vfncMNApKR0t/4d1oRXYTcyLZEcGHGOg4xBsD0Doing==", + "version": "0.69.0", + "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.69.0.tgz", + "integrity": "sha512-7UgbKSStPxf2RF2fqKqJq3u1QN4kFzhE/lofHtEuptRjQPdYZOLGsqGcKzQGYWoPG5p8PyxUOoc3/Ca+UcFkdA==", "dev": true, "requires": { "@types/estree": "^1.0.8", "@typescript-eslint/types": "^8.45.0", "comment-parser": "1.4.1", "esquery": "^1.6.0", - "jsdoc-type-pratt-parser": "~6.1.2" + "jsdoc-type-pratt-parser": "6.4.0" } }, "@eslint-community/eslint-utils": { @@ -9273,9 +9273,9 @@ "dev": true }, "@typescript-eslint/types": { - "version": "8.45.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.45.0.tgz", - "integrity": "sha512-WugXLuOIq67BMgQInIxxnsSyRLFxdkJEJu8r4ngLR56q/4Q5LrbfkFRH27vMTjxEK8Pyz7QfzuZe/G15qQnVRA==", + "version": "8.46.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.46.0.tgz", + "integrity": "sha512-bHGGJyVjSE4dJJIO5yyEWt/cHyNwga/zXGJbJJ8TiO01aVREK6gCTu3L+5wrkb1FbDkQ+TKjMNe9R/QQQP9+rA==", "dev": true }, "@uppercod/css-to-object": { @@ -10151,12 +10151,12 @@ "requires": {} }, "eslint-plugin-jsdoc": { - "version": "60.7.1", - "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-60.7.1.tgz", - "integrity": "sha512-JCLls7B3Tlb2YS5M6+aZqxb0gnEkr+H9/qMm5HSzynlvq3wqbxS7+4RS954EGuLrITfbaB6nmf3FyZAhOeCUEg==", + "version": "60.8.2", + "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-60.8.2.tgz", + "integrity": "sha512-ebEYZiAVL/ejjNQKO7Q1+FumDjGfs0T3+arQ3U54xomFiySUjKnZOzVZQAWhu+mlZXB4oeoizI4wRH+3i+knDg==", "dev": true, "requires": { - "@es-joy/jsdoccomment": "~0.65.2", + "@es-joy/jsdoccomment": "~0.69.0", "are-docs-informative": "^0.0.2", "comment-parser": "1.4.1", "debug": "^4.4.3", @@ -11756,9 +11756,9 @@ } }, "jsdoc-type-pratt-parser": { - "version": "6.1.2", - "resolved": "https://registry.npmjs.org/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-6.1.2.tgz", - "integrity": "sha512-ruy+JcplsWkqnYq1m/qokaErhEURwf/vhdTzlPNpei7RJabVWxPxGWoCPSCP0sbsz03d590hTkjLdXjyMxH0iA==", + "version": "6.4.0", + "resolved": "https://registry.npmjs.org/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-6.4.0.tgz", + "integrity": "sha512-tVwTg612vD9h2w5hoRFRNOni7xITDYZigHwBDieLUf4IYPQtk6IFXe/NqJc/hGYteFAeIM+Ld6ZvmLuizKAZ7A==", "dev": true }, "jsdom": { diff --git a/package.json b/package.json index 44e4fa065de00..1fe23235a995f 100644 --- a/package.json +++ b/package.json @@ -47,7 +47,7 @@ "color-contrast-checker": "^2.1.0", "eslint": "^9.37.0", "eslint-config-prettier": "^10.1.8", - "eslint-plugin-jsdoc": "^60.5.0", + "eslint-plugin-jsdoc": "^60.8.2", "express": "^5.1.0", "globals": "^16.4.0", "hjson": "^3.2.2", From b507f55ecd4af5758ca994b0ff25ac323cf9855b Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 10 Oct 2025 19:00:15 +0300 Subject: [PATCH 170/265] build(deps): bump dotenv from 17.2.2 to 17.2.3 (#4526) Bumps [dotenv](https://github.com/motdotla/dotenv) from 17.2.2 to 17.2.3. - [Changelog](https://github.com/motdotla/dotenv/blob/master/CHANGELOG.md) - [Commits](https://github.com/motdotla/dotenv/compare/v17.2.2...v17.2.3) --- updated-dependencies: - dependency-name: dotenv dependency-version: 17.2.3 dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- package-lock.json | 14 +++++++------- package.json | 2 +- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/package-lock.json b/package-lock.json index 74e4b4b910aa9..31cd0ea6754f7 100644 --- a/package-lock.json +++ b/package-lock.json @@ -10,7 +10,7 @@ "license": "MIT", "dependencies": { "axios": "^1.12.2", - "dotenv": "^17.2.2", + "dotenv": "^17.2.3", "emoji-name-map": "^2.0.3", "github-username-regex": "^1.0.0", "word-wrap": "^1.2.5" @@ -2963,9 +2963,9 @@ "dev": true }, "node_modules/dotenv": { - "version": "17.2.2", - "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-17.2.2.tgz", - "integrity": "sha512-Sf2LSQP+bOlhKWWyhFsn0UsfdK/kCWRv1iuA2gXAwt3dyNabr6QSj00I2V10pidqz69soatm9ZwZvpQMTIOd5Q==", + "version": "17.2.3", + "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-17.2.3.tgz", + "integrity": "sha512-JVUnt+DUIzu87TABbhPmNfVdBDt18BLOWjMUFJMSi/Qqg7NTYtabbvSNJGOJ7afbRuv9D/lngizHtP7QyLQ+9w==", "engines": { "node": ">=12" }, @@ -9921,9 +9921,9 @@ "dev": true }, "dotenv": { - "version": "17.2.2", - "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-17.2.2.tgz", - "integrity": "sha512-Sf2LSQP+bOlhKWWyhFsn0UsfdK/kCWRv1iuA2gXAwt3dyNabr6QSj00I2V10pidqz69soatm9ZwZvpQMTIOd5Q==" + "version": "17.2.3", + "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-17.2.3.tgz", + "integrity": "sha512-JVUnt+DUIzu87TABbhPmNfVdBDt18BLOWjMUFJMSi/Qqg7NTYtabbvSNJGOJ7afbRuv9D/lngizHtP7QyLQ+9w==" }, "dunder-proto": { "version": "1.0.1", diff --git a/package.json b/package.json index 1fe23235a995f..006c8b98514e5 100644 --- a/package.json +++ b/package.json @@ -62,7 +62,7 @@ }, "dependencies": { "axios": "^1.12.2", - "dotenv": "^17.2.2", + "dotenv": "^17.2.3", "emoji-name-map": "^2.0.3", "github-username-regex": "^1.0.0", "word-wrap": "^1.2.5" From 3d3786dad9d826e8b884e5e3a464e2d254c08ee2 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 10 Oct 2025 19:02:59 +0300 Subject: [PATCH 171/265] build(deps-dev): bump @testing-library/jest-dom from 6.8.0 to 6.9.1 (#4525) Bumps [@testing-library/jest-dom](https://github.com/testing-library/jest-dom) from 6.8.0 to 6.9.1. - [Release notes](https://github.com/testing-library/jest-dom/releases) - [Changelog](https://github.com/testing-library/jest-dom/blob/main/CHANGELOG.md) - [Commits](https://github.com/testing-library/jest-dom/compare/v6.8.0...v6.9.1) --- updated-dependencies: - dependency-name: "@testing-library/jest-dom" dependency-version: 6.9.1 dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- package-lock.json | 14 +++++++------- package.json | 2 +- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/package-lock.json b/package-lock.json index 31cd0ea6754f7..7b790408d8a01 100644 --- a/package-lock.json +++ b/package-lock.json @@ -21,7 +21,7 @@ "@eslint/eslintrc": "^3.3.1", "@eslint/js": "^9.37.0", "@testing-library/dom": "^10.4.1", - "@testing-library/jest-dom": "^6.8.0", + "@testing-library/jest-dom": "^6.9.1", "@uppercod/css-to-object": "^1.1.1", "axios-mock-adapter": "^2.1.0", "color-contrast-checker": "^2.1.0", @@ -1883,9 +1883,9 @@ } }, "node_modules/@testing-library/jest-dom": { - "version": "6.8.0", - "resolved": "https://registry.npmjs.org/@testing-library/jest-dom/-/jest-dom-6.8.0.tgz", - "integrity": "sha512-WgXcWzVM6idy5JaftTVC8Vs83NKRmGJz4Hqs4oyOuO2J4r/y79vvKZsb+CaGyCSEbUPI6OsewfPd0G1A0/TUZQ==", + "version": "6.9.1", + "resolved": "https://registry.npmjs.org/@testing-library/jest-dom/-/jest-dom-6.9.1.tgz", + "integrity": "sha512-zIcONa+hVtVSSep9UT3jZ5rizo2BsxgyDYU7WFD5eICBE7no3881HGeb/QkGfsJs6JTkY1aQhT7rIPC7e+0nnA==", "dev": true, "dependencies": { "@adobe/css-tools": "^4.4.0", @@ -9115,9 +9115,9 @@ } }, "@testing-library/jest-dom": { - "version": "6.8.0", - "resolved": "https://registry.npmjs.org/@testing-library/jest-dom/-/jest-dom-6.8.0.tgz", - "integrity": "sha512-WgXcWzVM6idy5JaftTVC8Vs83NKRmGJz4Hqs4oyOuO2J4r/y79vvKZsb+CaGyCSEbUPI6OsewfPd0G1A0/TUZQ==", + "version": "6.9.1", + "resolved": "https://registry.npmjs.org/@testing-library/jest-dom/-/jest-dom-6.9.1.tgz", + "integrity": "sha512-zIcONa+hVtVSSep9UT3jZ5rizo2BsxgyDYU7WFD5eICBE7no3881HGeb/QkGfsJs6JTkY1aQhT7rIPC7e+0nnA==", "dev": true, "requires": { "@adobe/css-tools": "^4.4.0", diff --git a/package.json b/package.json index 006c8b98514e5..00d10bf64d06f 100644 --- a/package.json +++ b/package.json @@ -41,7 +41,7 @@ "@eslint/eslintrc": "^3.3.1", "@eslint/js": "^9.37.0", "@testing-library/dom": "^10.4.1", - "@testing-library/jest-dom": "^6.8.0", + "@testing-library/jest-dom": "^6.9.1", "@uppercod/css-to-object": "^1.1.1", "axios-mock-adapter": "^2.1.0", "color-contrast-checker": "^2.1.0", From 6d6b87c359cd7f7c642b1a701dadeeae78ac7be1 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 10 Oct 2025 19:20:14 +0300 Subject: [PATCH 172/265] build(deps-dev): bump jest from 29.7.0 to 30.2.0 (#4524) * build(deps-dev): bump jest from 29.7.0 to 30.2.0 Bumps [jest](https://github.com/jestjs/jest/tree/HEAD/packages/jest) from 29.7.0 to 30.2.0. - [Release notes](https://github.com/jestjs/jest/releases) - [Changelog](https://github.com/jestjs/jest/blob/main/CHANGELOG.md) - [Commits](https://github.com/jestjs/jest/commits/v30.2.0/packages/jest) --- updated-dependencies: - dependency-name: jest dependency-version: 30.2.0 dependency-type: direct:development update-type: version-update:semver-major ... Signed-off-by: dependabot[bot] * migration --------- Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- package-lock.json | 6156 +++++++++-------- package.json | 2 +- .../renderWakatimeCard.test.js.snap | 2 +- tests/api.test.js | 35 +- tests/gist.test.js | 26 +- tests/pat-info.test.js | 30 +- tests/pin.test.js | 32 +- tests/retryer.test.js | 8 +- tests/status.up.test.js | 70 +- tests/top-langs.test.js | 28 +- tests/wakatime.test.js | 10 +- 11 files changed, 3257 insertions(+), 3142 deletions(-) diff --git a/package-lock.json b/package-lock.json index 7b790408d8a01..8d78c098988a5 100644 --- a/package-lock.json +++ b/package-lock.json @@ -32,7 +32,7 @@ "globals": "^16.4.0", "hjson": "^3.2.2", "husky": "^9.1.7", - "jest": "^29.7.0", + "jest": "^30.2.0", "jest-environment-jsdom": "^30.2.0", "js-yaml": "^4.1.0", "lint-staged": "^16.2.3", @@ -110,19 +110,6 @@ "integrity": "sha512-Ff9+ksdQQB3rMncgqDK78uLznstjyfIf2Arnh22pW8kBpLs6rpKDwgnZT46hin5Hl1WzazzK64DOrhSwYpS7bQ==", "dev": true }, - "node_modules/@ampproject/remapping": { - "version": "2.2.1", - "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.2.1.tgz", - "integrity": "sha512-lFMjJTrFL3j7L9yBxwYfCq2k6qqwHyzuUl/XBnif78PWTJYyL/dfowQHWE3sp6U6ZzqWiiIZnpTMO96zhkjwtg==", - "dev": true, - "dependencies": { - "@jridgewell/gen-mapping": "^0.3.0", - "@jridgewell/trace-mapping": "^0.3.9" - }, - "engines": { - "node": ">=6.0.0" - } - }, "node_modules/@asamuzakjp/css-color": { "version": "3.2.0", "resolved": "https://registry.npmjs.org/@asamuzakjp/css-color/-/css-color-3.2.0.tgz", @@ -157,34 +144,34 @@ } }, "node_modules/@babel/compat-data": { - "version": "7.22.9", - "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.22.9.tgz", - "integrity": "sha512-5UamI7xkUcJ3i9qVDS+KFDEK8/7oJ55/sJMB1Ge7IEapr7KfdfV/HErR+koZwOfd+SgtFKOKRhRakdg++DcJpQ==", + "version": "7.28.4", + "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.28.4.tgz", + "integrity": "sha512-YsmSKC29MJwf0gF8Rjjrg5LQCmyh+j/nD8/eP7f+BeoQTKYqs9RoWbjGOdy0+1Ekr68RJZMUOPVQaQisnIo4Rw==", "dev": true, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/core": { - "version": "7.22.9", - "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.22.9.tgz", - "integrity": "sha512-G2EgeufBcYw27U4hhoIwFcgc1XU7TlXJ3mv04oOv1WCuo900U/anZSPzEqNjwdjgffkk2Gs0AN0dW1CKVLcG7w==", - "dev": true, - "dependencies": { - "@ampproject/remapping": "^2.2.0", - "@babel/code-frame": "^7.22.5", - "@babel/generator": "^7.22.9", - "@babel/helper-compilation-targets": "^7.22.9", - "@babel/helper-module-transforms": "^7.22.9", - "@babel/helpers": "^7.22.6", - "@babel/parser": "^7.22.7", - "@babel/template": "^7.22.5", - "@babel/traverse": "^7.22.8", - "@babel/types": "^7.22.5", - "convert-source-map": "^1.7.0", + "version": "7.28.4", + "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.28.4.tgz", + "integrity": "sha512-2BCOP7TN8M+gVDj7/ht3hsaO/B/n5oDbiAyyvnRlNOs+u1o+JWNYTQrmpuNp1/Wq2gcFrI01JAW+paEKDMx/CA==", + "dev": true, + "dependencies": { + "@babel/code-frame": "^7.27.1", + "@babel/generator": "^7.28.3", + "@babel/helper-compilation-targets": "^7.27.2", + "@babel/helper-module-transforms": "^7.28.3", + "@babel/helpers": "^7.28.4", + "@babel/parser": "^7.28.4", + "@babel/template": "^7.27.2", + "@babel/traverse": "^7.28.4", + "@babel/types": "^7.28.4", + "@jridgewell/remapping": "^2.3.5", + "convert-source-map": "^2.0.0", "debug": "^4.1.0", "gensync": "^1.0.0-beta.2", - "json5": "^2.2.2", + "json5": "^2.2.3", "semver": "^6.3.1" }, "engines": { @@ -195,103 +182,69 @@ "url": "https://opencollective.com/babel" } }, - "node_modules/@babel/core/node_modules/convert-source-map": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.9.0.tgz", - "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==", - "dev": true - }, "node_modules/@babel/generator": { - "version": "7.23.0", - "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.23.0.tgz", - "integrity": "sha512-lN85QRR+5IbYrMWM6Y4pE/noaQtg4pNiqeNGX60eqOfo6gtEj6uw/JagelB8vVztSd7R6M5n1+PQkDbHbBRU4g==", + "version": "7.28.3", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.28.3.tgz", + "integrity": "sha512-3lSpxGgvnmZznmBkCRnVREPUFJv2wrv9iAoFDvADJc0ypmdOxdUtcLeBgBJ6zE0PMeTKnxeQzyk0xTBq4Ep7zw==", "dev": true, "dependencies": { - "@babel/types": "^7.23.0", - "@jridgewell/gen-mapping": "^0.3.2", - "@jridgewell/trace-mapping": "^0.3.17", - "jsesc": "^2.5.1" + "@babel/parser": "^7.28.3", + "@babel/types": "^7.28.2", + "@jridgewell/gen-mapping": "^0.3.12", + "@jridgewell/trace-mapping": "^0.3.28", + "jsesc": "^3.0.2" }, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/helper-compilation-targets": { - "version": "7.22.9", - "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.22.9.tgz", - "integrity": "sha512-7qYrNM6HjpnPHJbopxmb8hSPoZ0gsX8IvUS32JGVoy+pU9e5N0nLr1VjJoR6kA4d9dmGLxNYOjeB8sUDal2WMw==", + "version": "7.27.2", + "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.27.2.tgz", + "integrity": "sha512-2+1thGUUWWjLTYTHZWK1n8Yga0ijBz1XAhUXcKy81rd5g6yh7hGqMp45v7cadSbEHc9G3OTv45SyneRN3ps4DQ==", "dev": true, "dependencies": { - "@babel/compat-data": "^7.22.9", - "@babel/helper-validator-option": "^7.22.5", - "browserslist": "^4.21.9", + "@babel/compat-data": "^7.27.2", + "@babel/helper-validator-option": "^7.27.1", + "browserslist": "^4.24.0", "lru-cache": "^5.1.1", "semver": "^6.3.1" }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0" - } - }, - "node_modules/@babel/helper-environment-visitor": { - "version": "7.22.20", - "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.22.20.tgz", - "integrity": "sha512-zfedSIzFhat/gFhWfHtgWvlec0nqB9YEIVrpuwjruLlXfUSnA8cJB0miHKwqDnQ7d32aKo2xt88/xZptwxbfhA==", - "dev": true, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-function-name": { - "version": "7.23.0", - "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.23.0.tgz", - "integrity": "sha512-OErEqsrxjZTJciZ4Oo+eoZqeW9UIiOcuYKRJA4ZAgV9myA+pOXhhmpfNCKjEH/auVfEYVFJ6y1Tc4r0eIApqiw==", - "dev": true, - "dependencies": { - "@babel/template": "^7.22.15", - "@babel/types": "^7.23.0" - }, "engines": { "node": ">=6.9.0" } }, - "node_modules/@babel/helper-hoist-variables": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.22.5.tgz", - "integrity": "sha512-wGjk9QZVzvknA6yKIUURb8zY3grXCcOZt+/7Wcy8O2uctxhplmUPkOdlgoNhmdVee2c92JXbf1xpMtVNbfoxRw==", + "node_modules/@babel/helper-globals": { + "version": "7.28.0", + "resolved": "https://registry.npmjs.org/@babel/helper-globals/-/helper-globals-7.28.0.tgz", + "integrity": "sha512-+W6cISkXFa1jXsDEdYA8HeevQT/FULhxzR99pxphltZcVaugps53THCeiWA8SguxxpSp3gKPiuYfSWopkLQ4hw==", "dev": true, - "dependencies": { - "@babel/types": "^7.22.5" - }, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/helper-module-imports": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.22.5.tgz", - "integrity": "sha512-8Dl6+HD/cKifutF5qGd/8ZJi84QeAKh+CEe1sBzz8UayBBGg1dAIJrdHOcOM5b2MpzWL2yuotJTtGjETq0qjXg==", + "version": "7.27.1", + "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.27.1.tgz", + "integrity": "sha512-0gSFWUPNXNopqtIPQvlD5WgXYI5GY2kP2cCvoT8kczjbfcfuIljTbcWrulD1CIPIX2gt1wghbDy08yE1p+/r3w==", "dev": true, "dependencies": { - "@babel/types": "^7.22.5" + "@babel/traverse": "^7.27.1", + "@babel/types": "^7.27.1" }, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/helper-module-transforms": { - "version": "7.22.9", - "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.22.9.tgz", - "integrity": "sha512-t+WA2Xn5K+rTeGtC8jCsdAH52bjggG5TKRuRrAGNM/mjIbO4GxvlLMFOEz9wXY5I2XQ60PMFsAG2WIcG82dQMQ==", + "version": "7.28.3", + "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.28.3.tgz", + "integrity": "sha512-gytXUbs8k2sXS9PnQptz5o0QnpLL51SwASIORY6XaBKF88nsOT0Zw9szLqlSGQDP/4TljBAD5y98p2U1fqkdsw==", "dev": true, "dependencies": { - "@babel/helper-environment-visitor": "^7.22.5", - "@babel/helper-module-imports": "^7.22.5", - "@babel/helper-simple-access": "^7.22.5", - "@babel/helper-split-export-declaration": "^7.22.6", - "@babel/helper-validator-identifier": "^7.22.5" + "@babel/helper-module-imports": "^7.27.1", + "@babel/helper-validator-identifier": "^7.27.1", + "@babel/traverse": "^7.28.3" }, "engines": { "node": ">=6.9.0" @@ -301,42 +254,18 @@ } }, "node_modules/@babel/helper-plugin-utils": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.22.5.tgz", - "integrity": "sha512-uLls06UVKgFG9QD4OeFYLEGteMIAa5kpTPcFL28yuCIIzsf6ZyKZMllKVOCZFhiZ5ptnwX4mtKdWCBE/uT4amg==", - "dev": true, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-simple-access": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.22.5.tgz", - "integrity": "sha512-n0H99E/K+Bika3++WNL17POvo4rKWZ7lZEp1Q+fStVbUi8nxPQEBOlTmCOxW/0JsS56SKKQ+ojAe2pHKJHN35w==", - "dev": true, - "dependencies": { - "@babel/types": "^7.22.5" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-split-export-declaration": { - "version": "7.22.6", - "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.22.6.tgz", - "integrity": "sha512-AsUnxuLhRYsisFiaJwvp1QF+I3KjD5FOxut14q/GzovUe6orHLesW2C7d754kRm53h5gqrz6sFl6sxc4BVtE/g==", + "version": "7.27.1", + "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.27.1.tgz", + "integrity": "sha512-1gn1Up5YXka3YYAHGKpbideQ5Yjf1tDa9qYcgysz+cNCXukyLl6DjPXhD3VRwSb8c0J9tA4b2+rHEZtc6R0tlw==", "dev": true, - "dependencies": { - "@babel/types": "^7.22.5" - }, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/helper-string-parser": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.22.5.tgz", - "integrity": "sha512-mM4COjgZox8U+JcXQwPijIZLElkgEpO5rsERVDJTc2qfCDfERyob6k5WegS14SX18IIjv+XD+GrqNumY5JRCDw==", + "version": "7.27.1", + "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.27.1.tgz", + "integrity": "sha512-qMlSxKbpRlAridDExk92nSobyDdpPijUq2DW6oDnUqd0iOGxmQjyqhMIihI9+zv4LPyZdRje2cavWPbCbWm3eA==", "dev": true, "engines": { "node": ">=6.9.0" @@ -352,33 +281,35 @@ } }, "node_modules/@babel/helper-validator-option": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.22.5.tgz", - "integrity": "sha512-R3oB6xlIVKUnxNUxbmgq7pKjxpru24zlimpE8WK47fACIlM0II/Hm1RS8IaOI7NgCr6LNS+jl5l75m20npAziw==", + "version": "7.27.1", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.27.1.tgz", + "integrity": "sha512-YvjJow9FxbhFFKDSuFnVCe2WxXk1zWc22fFePVNEaWJEu8IrZVlda6N0uHwzZrUM1il7NC9Mlp4MaJYbYd9JSg==", "dev": true, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/helpers": { - "version": "7.22.6", - "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.22.6.tgz", - "integrity": "sha512-YjDs6y/fVOYFV8hAf1rxd1QvR9wJe1pDBZ2AREKq/SDayfPzgk0PBnVuTCE5X1acEpMMNOVUqoe+OwiZGJ+OaA==", + "version": "7.28.4", + "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.28.4.tgz", + "integrity": "sha512-HFN59MmQXGHVyYadKLVumYsA9dBFun/ldYxipEjzA4196jpLZd8UjEEBLkbEkvfYreDqJhZxYAWFPtrfhNpj4w==", "dev": true, "dependencies": { - "@babel/template": "^7.22.5", - "@babel/traverse": "^7.22.6", - "@babel/types": "^7.22.5" + "@babel/template": "^7.27.2", + "@babel/types": "^7.28.4" }, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/parser": { - "version": "7.23.0", - "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.23.0.tgz", - "integrity": "sha512-vvPKKdMemU85V9WE/l5wZEmImpCtLqbnTvqDS2U1fJ96KrxoW7KrXhNsNCblQlg8Ck4b85yxdTyelsMUgFUXiw==", + "version": "7.28.4", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.28.4.tgz", + "integrity": "sha512-yZbBqeM6TkpP9du/I2pUZnJsRMGGvOuIrhjzC1AwHwW+6he4mni6Bp/m8ijn0iOuZuPI2BfkCoSRunpyjnrQKg==", "dev": true, + "dependencies": { + "@babel/types": "^7.28.4" + }, "bin": { "parser": "bin/babel-parser.js" }, @@ -422,6 +353,36 @@ "@babel/core": "^7.0.0-0" } }, + "node_modules/@babel/plugin-syntax-class-static-block": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-static-block/-/plugin-syntax-class-static-block-7.14.5.tgz", + "integrity": "sha512-b+YyPmr6ldyNnM6sqYeMWE+bgJcJpO6yS4QD7ymxgH34GBPNDM/THBh8iunyvKIZztiwLH4CJZ0RxTk9emgpjw==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.14.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-import-attributes": { + "version": "7.27.1", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-attributes/-/plugin-syntax-import-attributes-7.27.1.tgz", + "integrity": "sha512-oFT0FrKHgF53f4vOsZGi2Hh3I35PfSmVs4IBFLFj4dnafP+hIWDLg3VyKmUHfLoLHlyxY4C7DGtmHuJgn+IGww==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.27.1" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, "node_modules/@babel/plugin-syntax-import-meta": { "version": "7.10.4", "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-meta/-/plugin-syntax-import-meta-7.10.4.tgz", @@ -447,12 +408,12 @@ } }, "node_modules/@babel/plugin-syntax-jsx": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.22.5.tgz", - "integrity": "sha512-gvyP4hZrgrs/wWMaocvxZ44Hw0b3W8Pe+cMxc8V1ULQ07oh8VNbIRaoD1LRZVTvD+0nieDKjfgKg89sD7rrKrg==", + "version": "7.27.1", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.27.1.tgz", + "integrity": "sha512-y8YTNIeKoyhGd9O0Jiyzyyqk8gdjnumGTQPsz0xOZOQ2RmkVJeZ1vmmfIvFEKqucBG6axJGBZDE/7iI5suUI/w==", "dev": true, "dependencies": { - "@babel/helper-plugin-utils": "^7.22.5" + "@babel/helper-plugin-utils": "^7.27.1" }, "engines": { "node": ">=6.9.0" @@ -533,6 +494,21 @@ "@babel/core": "^7.0.0-0" } }, + "node_modules/@babel/plugin-syntax-private-property-in-object": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-private-property-in-object/-/plugin-syntax-private-property-in-object-7.14.5.tgz", + "integrity": "sha512-0wVnp9dxJ72ZUJDV27ZfbSj6iHLoytYZmh3rFcxNnvsJF3ktkzLDZPy/mA17HGsaQT3/DQsWYX1f1QGWkCoVUg==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.14.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, "node_modules/@babel/plugin-syntax-top-level-await": { "version": "7.14.5", "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.14.5.tgz", @@ -549,12 +525,12 @@ } }, "node_modules/@babel/plugin-syntax-typescript": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.22.5.tgz", - "integrity": "sha512-1mS2o03i7t1c6VzH6fdQ3OA8tcEIxwG18zIPRp+UY1Ihv6W+XZzBCVxExF9upussPXJ0xE9XRHwMoNs1ep/nRQ==", + "version": "7.27.1", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.27.1.tgz", + "integrity": "sha512-xfYCBMxveHrRMnAWl1ZlPXOZjzkN82THFvLhQhFXFt81Z5HnN+EtUkZhv/zcKpmT3fzmWZB0ywiBrbC3vogbwQ==", "dev": true, "dependencies": { - "@babel/helper-plugin-utils": "^7.22.5" + "@babel/helper-plugin-utils": "^7.27.1" }, "engines": { "node": ">=6.9.0" @@ -576,58 +552,45 @@ } }, "node_modules/@babel/template": { - "version": "7.22.15", - "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.22.15.tgz", - "integrity": "sha512-QPErUVm4uyJa60rkI73qneDacvdvzxshT3kksGqlGWYdOTIUOwJ7RDUL8sGqslY1uXWSL6xMFKEXDS3ox2uF0w==", + "version": "7.27.2", + "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.27.2.tgz", + "integrity": "sha512-LPDZ85aEJyYSd18/DkjNh4/y1ntkE5KwUHWTiqgRxruuZL2F1yuHligVHLvcHY2vMHXttKFpJn6LwfI7cw7ODw==", "dev": true, "dependencies": { - "@babel/code-frame": "^7.22.13", - "@babel/parser": "^7.22.15", - "@babel/types": "^7.22.15" + "@babel/code-frame": "^7.27.1", + "@babel/parser": "^7.27.2", + "@babel/types": "^7.27.1" }, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/traverse": { - "version": "7.23.2", - "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.23.2.tgz", - "integrity": "sha512-azpe59SQ48qG6nu2CzcMLbxUudtN+dOM9kDbUqGq3HXUJRlo7i8fvPoxQUzYgLZ4cMVmuZgm8vvBpNeRhd6XSw==", - "dev": true, - "dependencies": { - "@babel/code-frame": "^7.22.13", - "@babel/generator": "^7.23.0", - "@babel/helper-environment-visitor": "^7.22.20", - "@babel/helper-function-name": "^7.23.0", - "@babel/helper-hoist-variables": "^7.22.5", - "@babel/helper-split-export-declaration": "^7.22.6", - "@babel/parser": "^7.23.0", - "@babel/types": "^7.23.0", - "debug": "^4.1.0", - "globals": "^11.1.0" + "version": "7.28.4", + "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.28.4.tgz", + "integrity": "sha512-YEzuboP2qvQavAcjgQNVgsvHIDv6ZpwXvcvjmyySP2DIMuByS/6ioU5G9pYrWHM6T2YDfc7xga9iNzYOs12CFQ==", + "dev": true, + "dependencies": { + "@babel/code-frame": "^7.27.1", + "@babel/generator": "^7.28.3", + "@babel/helper-globals": "^7.28.0", + "@babel/parser": "^7.28.4", + "@babel/template": "^7.27.2", + "@babel/types": "^7.28.4", + "debug": "^4.3.1" }, "engines": { "node": ">=6.9.0" } }, - "node_modules/@babel/traverse/node_modules/globals": { - "version": "11.12.0", - "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", - "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", - "dev": true, - "engines": { - "node": ">=4" - } - }, "node_modules/@babel/types": { - "version": "7.23.0", - "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.23.0.tgz", - "integrity": "sha512-0oIyUfKoI3mSqMvsxBdclDwxXKXAUA8v/apZbc+iSyARYou1o8ZGDxbUYyLFoW2arqS2jDGqJuZvv1d/io1axg==", + "version": "7.28.4", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.28.4.tgz", + "integrity": "sha512-bkFqkLhh3pMBUQQkpVgWDWq/lqzc2678eUyDlTBhRqhCHFguYYGM0Efga7tYk4TogG/3x0EEl66/OQ+WGbWB/Q==", "dev": true, "dependencies": { - "@babel/helper-string-parser": "^7.22.5", - "@babel/helper-validator-identifier": "^7.22.20", - "to-fast-properties": "^2.0.0" + "@babel/helper-string-parser": "^7.27.1", + "@babel/helper-validator-identifier": "^7.27.1" }, "engines": { "node": ">=6.9.0" @@ -749,6 +712,37 @@ "node": ">=18" } }, + "node_modules/@emnapi/core": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/@emnapi/core/-/core-1.5.0.tgz", + "integrity": "sha512-sbP8GzB1WDzacS8fgNPpHlp6C9VZe+SJP3F90W9rLemaQj2PzIuTEl1qDOYQf58YIpyjViI24y9aPWCjEzY2cg==", + "dev": true, + "optional": true, + "dependencies": { + "@emnapi/wasi-threads": "1.1.0", + "tslib": "^2.4.0" + } + }, + "node_modules/@emnapi/runtime": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/@emnapi/runtime/-/runtime-1.5.0.tgz", + "integrity": "sha512-97/BJ3iXHww3djw6hYIfErCZFee7qCtrneuLa20UXFCOTCfBM2cvQHjWJ2EG0s0MtdNwInarqCTz35i4wWXHsQ==", + "dev": true, + "optional": true, + "dependencies": { + "tslib": "^2.4.0" + } + }, + "node_modules/@emnapi/wasi-threads": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@emnapi/wasi-threads/-/wasi-threads-1.1.0.tgz", + "integrity": "sha512-WI0DdZ8xFSbgMjR1sFsKABJ/C5OnRrjT06JXbZKexJGrDuPTzZdDYfFlsgcCXCyf+suG5QU2e/y1Wo2V/OapLQ==", + "dev": true, + "optional": true, + "dependencies": { + "tslib": "^2.4.0" + } + }, "node_modules/@es-joy/jsdoccomment": { "version": "0.69.0", "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.69.0.tgz", @@ -971,6 +965,23 @@ "url": "https://github.com/sponsors/nzakas" } }, + "node_modules/@isaacs/cliui": { + "version": "8.0.2", + "resolved": "https://registry.npmjs.org/@isaacs/cliui/-/cliui-8.0.2.tgz", + "integrity": "sha512-O8jcjabXaleOG9DQ0+ARXWZBTfnP4WNAqzuiJK7ll44AmxGKv/J2M4TPjxjY3znBCfvBXFzucm1twdyFybFqEA==", + "dev": true, + "dependencies": { + "string-width": "^5.1.2", + "string-width-cjs": "npm:string-width@^4.2.0", + "strip-ansi": "^7.0.1", + "strip-ansi-cjs": "npm:strip-ansi@^6.0.1", + "wrap-ansi": "^8.1.0", + "wrap-ansi-cjs": "npm:wrap-ansi@^7.0.0" + }, + "engines": { + "node": ">=12" + } + }, "node_modules/@istanbuljs/load-nyc-config": { "version": "1.1.0", "resolved": "https://registry.npmjs.org/@istanbuljs/load-nyc-config/-/load-nyc-config-1.1.0.tgz", @@ -1019,59 +1030,59 @@ } }, "node_modules/@jest/console": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/@jest/console/-/console-29.7.0.tgz", - "integrity": "sha512-5Ni4CU7XHQi32IJ398EEP4RrB8eV09sXP2ROqD4bksHrnTree52PsxvX8tpL8LvTZ3pFzXyPbNQReSN41CAhOg==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/console/-/console-30.2.0.tgz", + "integrity": "sha512-+O1ifRjkvYIkBqASKWgLxrpEhQAAE7hY77ALLUufSk5717KfOShg6IbqLmdsLMPdUiFvA2kTs0R7YZy+l0IzZQ==", "dev": true, "dependencies": { - "@jest/types": "^29.6.3", + "@jest/types": "30.2.0", "@types/node": "*", - "chalk": "^4.0.0", - "jest-message-util": "^29.7.0", - "jest-util": "^29.7.0", + "chalk": "^4.1.2", + "jest-message-util": "30.2.0", + "jest-util": "30.2.0", "slash": "^3.0.0" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/@jest/core": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/@jest/core/-/core-29.7.0.tgz", - "integrity": "sha512-n7aeXWKMnGtDA48y8TLWJPJmLmmZ642Ceo78cYWEpiD7FzDgmNDV/GCVRorPABdXLJZ/9wzzgZAlHjXjxDHGsg==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/core/-/core-30.2.0.tgz", + "integrity": "sha512-03W6IhuhjqTlpzh/ojut/pDB2LPRygyWX8ExpgHtQA8H/3K7+1vKmcINx5UzeOX1se6YEsBsOHQ1CRzf3fOwTQ==", "dev": true, "dependencies": { - "@jest/console": "^29.7.0", - "@jest/reporters": "^29.7.0", - "@jest/test-result": "^29.7.0", - "@jest/transform": "^29.7.0", - "@jest/types": "^29.6.3", + "@jest/console": "30.2.0", + "@jest/pattern": "30.0.1", + "@jest/reporters": "30.2.0", + "@jest/test-result": "30.2.0", + "@jest/transform": "30.2.0", + "@jest/types": "30.2.0", "@types/node": "*", - "ansi-escapes": "^4.2.1", - "chalk": "^4.0.0", - "ci-info": "^3.2.0", - "exit": "^0.1.2", - "graceful-fs": "^4.2.9", - "jest-changed-files": "^29.7.0", - "jest-config": "^29.7.0", - "jest-haste-map": "^29.7.0", - "jest-message-util": "^29.7.0", - "jest-regex-util": "^29.6.3", - "jest-resolve": "^29.7.0", - "jest-resolve-dependencies": "^29.7.0", - "jest-runner": "^29.7.0", - "jest-runtime": "^29.7.0", - "jest-snapshot": "^29.7.0", - "jest-util": "^29.7.0", - "jest-validate": "^29.7.0", - "jest-watcher": "^29.7.0", - "micromatch": "^4.0.4", - "pretty-format": "^29.7.0", - "slash": "^3.0.0", - "strip-ansi": "^6.0.0" + "ansi-escapes": "^4.3.2", + "chalk": "^4.1.2", + "ci-info": "^4.2.0", + "exit-x": "^0.2.2", + "graceful-fs": "^4.2.11", + "jest-changed-files": "30.2.0", + "jest-config": "30.2.0", + "jest-haste-map": "30.2.0", + "jest-message-util": "30.2.0", + "jest-regex-util": "30.0.1", + "jest-resolve": "30.2.0", + "jest-resolve-dependencies": "30.2.0", + "jest-runner": "30.2.0", + "jest-runtime": "30.2.0", + "jest-snapshot": "30.2.0", + "jest-util": "30.2.0", + "jest-validate": "30.2.0", + "jest-watcher": "30.2.0", + "micromatch": "^4.0.8", + "pretty-format": "30.2.0", + "slash": "^3.0.0" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" }, "peerDependencies": { "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" @@ -1095,38 +1106,47 @@ } }, "node_modules/@jest/core/node_modules/pretty-format": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-29.7.0.tgz", - "integrity": "sha512-Pdlw/oPxN+aXdmM9R00JVC9WVFoCLTKJvDVLgmJ+qAffBMxsV85l/Lu7sNx4zSzPyoL2euImuEwHhOXdEgNFZQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.2.0.tgz", + "integrity": "sha512-9uBdv/B4EefsuAL+pWqueZyZS2Ba+LxfFeQ9DN14HU4bN8bhaxKdkpjpB6fs9+pSjIBu+FXQHImEg8j/Lw0+vA==", "dev": true, "dependencies": { - "@jest/schemas": "^29.6.3", - "ansi-styles": "^5.0.0", - "react-is": "^18.0.0" + "@jest/schemas": "30.0.5", + "ansi-styles": "^5.2.0", + "react-is": "^18.3.1" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/@jest/core/node_modules/react-is": { - "version": "18.2.0", - "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz", - "integrity": "sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w==", + "version": "18.3.1", + "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.3.1.tgz", + "integrity": "sha512-/LLMVyas0ljjAtoYiPqYiL8VWXzUUdThrmU5+n20DZv+a+ClRoevUzw5JxU+Ieh5/c87ytoTBV9G1FiKfNJdmg==", "dev": true }, + "node_modules/@jest/diff-sequences": { + "version": "30.0.1", + "resolved": "https://registry.npmjs.org/@jest/diff-sequences/-/diff-sequences-30.0.1.tgz", + "integrity": "sha512-n5H8QLDJ47QqbCNn5SuFjCRDrOLEZ0h8vAHCK5RL9Ls7Xa8AQLa/YxAc9UjFqoEDM48muwtBGjtMY5cr0PLDCw==", + "dev": true, + "engines": { + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" + } + }, "node_modules/@jest/environment": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-29.7.0.tgz", - "integrity": "sha512-aQIfHDq33ExsN4jP1NWGXhxgQ/wixs60gDiKO+XVMd8Mn0NWPWgc34ZQDTb2jKaUWQ7MuwoitXAsN2XVXNMpAw==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-30.2.0.tgz", + "integrity": "sha512-/QPTL7OBJQ5ac09UDRa3EQes4gt1FTEG/8jZ/4v5IVzx+Cv7dLxlVIvfvSVRiiX2drWyXeBjkMSR8hvOWSog5g==", "dev": true, "dependencies": { - "@jest/fake-timers": "^29.7.0", - "@jest/types": "^29.6.3", + "@jest/fake-timers": "30.2.0", + "@jest/types": "30.2.0", "@types/node": "*", - "jest-mock": "^29.7.0" + "jest-mock": "30.2.0" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/@jest/environment-jsdom-abstract": { @@ -1156,22 +1176,32 @@ } } }, - "node_modules/@jest/environment-jsdom-abstract/node_modules/@jest/environment": { + "node_modules/@jest/expect": { "version": "30.2.0", - "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-30.2.0.tgz", - "integrity": "sha512-/QPTL7OBJQ5ac09UDRa3EQes4gt1FTEG/8jZ/4v5IVzx+Cv7dLxlVIvfvSVRiiX2drWyXeBjkMSR8hvOWSog5g==", + "resolved": "https://registry.npmjs.org/@jest/expect/-/expect-30.2.0.tgz", + "integrity": "sha512-V9yxQK5erfzx99Sf+7LbhBwNWEZ9eZay8qQ9+JSC0TrMR1pMDHLMY+BnVPacWU6Jamrh252/IKo4F1Xn/zfiqA==", "dev": true, "dependencies": { - "@jest/fake-timers": "30.2.0", - "@jest/types": "30.2.0", - "@types/node": "*", - "jest-mock": "30.2.0" + "expect": "30.2.0", + "jest-snapshot": "30.2.0" + }, + "engines": { + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" + } + }, + "node_modules/@jest/expect-utils": { + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/expect-utils/-/expect-utils-30.2.0.tgz", + "integrity": "sha512-1JnRfhqpD8HGpOmQp180Fo9Zt69zNtC+9lR+kT7NVL05tNXIi+QC8Csz7lfidMoVLPD3FnOtcmp0CEFnxExGEA==", + "dev": true, + "dependencies": { + "@jest/get-type": "30.1.0" }, "engines": { "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, - "node_modules/@jest/environment-jsdom-abstract/node_modules/@jest/fake-timers": { + "node_modules/@jest/fake-timers": { "version": "30.2.0", "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-30.2.0.tgz", "integrity": "sha512-HI3tRLjRxAbBy0VO8dqqm7Hb2mIa8d5bg/NJkyQcOk7V118ObQML8RC5luTF/Zsg4474a+gDvhce7eTnP4GhYw==", @@ -1188,273 +1218,75 @@ "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, - "node_modules/@jest/environment-jsdom-abstract/node_modules/@jest/schemas": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/@jest/schemas/-/schemas-30.0.5.tgz", - "integrity": "sha512-DmdYgtezMkh3cpU8/1uyXakv3tJRcmcXxBOcO0tbaozPwpmh4YMsnWrQm9ZmZMfa5ocbxzbFk6O4bDPEc/iAnA==", + "node_modules/@jest/get-type": { + "version": "30.1.0", + "resolved": "https://registry.npmjs.org/@jest/get-type/-/get-type-30.1.0.tgz", + "integrity": "sha512-eMbZE2hUnx1WV0pmURZY9XoXPkUYjpc55mb0CrhtdWLtzMQPFvu/rZkTLZFTsdaVQa+Tr4eWAteqcUzoawq/uA==", "dev": true, - "dependencies": { - "@sinclair/typebox": "^0.34.0" - }, "engines": { "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, - "node_modules/@jest/environment-jsdom-abstract/node_modules/@jest/types": { + "node_modules/@jest/globals": { "version": "30.2.0", - "resolved": "https://registry.npmjs.org/@jest/types/-/types-30.2.0.tgz", - "integrity": "sha512-H9xg1/sfVvyfU7o3zMfBEjQ1gcsdeTMgqHoYdN79tuLqfTtuu7WckRA1R5whDwOzxaZAeMKTYWqP+WCAi0CHsg==", + "resolved": "https://registry.npmjs.org/@jest/globals/-/globals-30.2.0.tgz", + "integrity": "sha512-b63wmnKPaK+6ZZfpYhz9K61oybvbI1aMcIs80++JI1O1rR1vaxHUCNqo3ITu6NU0d4V34yZFoHMn/uoKr/Rwfw==", "dev": true, "dependencies": { - "@jest/pattern": "30.0.1", - "@jest/schemas": "30.0.5", - "@types/istanbul-lib-coverage": "^2.0.6", - "@types/istanbul-reports": "^3.0.4", - "@types/node": "*", - "@types/yargs": "^17.0.33", - "chalk": "^4.1.2" + "@jest/environment": "30.2.0", + "@jest/expect": "30.2.0", + "@jest/types": "30.2.0", + "jest-mock": "30.2.0" }, "engines": { "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, - "node_modules/@jest/environment-jsdom-abstract/node_modules/@sinclair/typebox": { - "version": "0.34.41", - "resolved": "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.34.41.tgz", - "integrity": "sha512-6gS8pZzSXdyRHTIqoqSVknxolr1kzfy4/CeDnrzsVz8TTIWUbOBr6gnzOmTYJ3eXQNh4IYHIGi5aIL7sOZ2G/g==", - "dev": true - }, - "node_modules/@jest/environment-jsdom-abstract/node_modules/@sinonjs/fake-timers": { - "version": "13.0.5", - "resolved": "https://registry.npmjs.org/@sinonjs/fake-timers/-/fake-timers-13.0.5.tgz", - "integrity": "sha512-36/hTbH2uaWuGVERyC6da9YwGWnzUZXuPro/F2LfsdOsLnCojz/iSH8MxUt/FD2S5XBSVPhmArFUXcpCQ2Hkiw==", + "node_modules/@jest/pattern": { + "version": "30.0.1", + "resolved": "https://registry.npmjs.org/@jest/pattern/-/pattern-30.0.1.tgz", + "integrity": "sha512-gWp7NfQW27LaBQz3TITS8L7ZCQ0TLvtmI//4OwlQRx4rnWxcPNIYjxZpDcN4+UlGxgm3jS5QPz8IPTCkb59wZA==", "dev": true, "dependencies": { - "@sinonjs/commons": "^3.0.1" - } - }, - "node_modules/@jest/environment-jsdom-abstract/node_modules/ansi-styles": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz", - "integrity": "sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==", - "dev": true, - "engines": { - "node": ">=10" + "@types/node": "*", + "jest-regex-util": "30.0.1" }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/@jest/environment-jsdom-abstract/node_modules/ci-info": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-4.3.0.tgz", - "integrity": "sha512-l+2bNRMiQgcfILUi33labAZYIWlH1kWDp+ecNo5iisRKrbm0xcRyCww71/YU0Fkw0mAFpz9bJayXPjey6vkmaQ==", - "dev": true, - "funding": [ - { - "type": "github", - "url": "https://github.com/sponsors/sibiraj-s" - } - ], "engines": { - "node": ">=8" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, - "node_modules/@jest/environment-jsdom-abstract/node_modules/jest-message-util": { + "node_modules/@jest/reporters": { "version": "30.2.0", - "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-30.2.0.tgz", - "integrity": "sha512-y4DKFLZ2y6DxTWD4cDe07RglV88ZiNEdlRfGtqahfbIjfsw1nMCPx49Uev4IA/hWn3sDKyAnSPwoYSsAEdcimw==", + "resolved": "https://registry.npmjs.org/@jest/reporters/-/reporters-30.2.0.tgz", + "integrity": "sha512-DRyW6baWPqKMa9CzeiBjHwjd8XeAyco2Vt8XbcLFjiwCOEKOvy82GJ8QQnJE9ofsxCMPjH4MfH8fCWIHHDKpAQ==", "dev": true, "dependencies": { - "@babel/code-frame": "^7.27.1", + "@bcoe/v8-coverage": "^0.2.3", + "@jest/console": "30.2.0", + "@jest/test-result": "30.2.0", + "@jest/transform": "30.2.0", "@jest/types": "30.2.0", - "@types/stack-utils": "^2.0.3", + "@jridgewell/trace-mapping": "^0.3.25", + "@types/node": "*", "chalk": "^4.1.2", + "collect-v8-coverage": "^1.0.2", + "exit-x": "^0.2.2", + "glob": "^10.3.10", "graceful-fs": "^4.2.11", - "micromatch": "^4.0.8", - "pretty-format": "30.2.0", + "istanbul-lib-coverage": "^3.0.0", + "istanbul-lib-instrument": "^6.0.0", + "istanbul-lib-report": "^3.0.0", + "istanbul-lib-source-maps": "^5.0.0", + "istanbul-reports": "^3.1.3", + "jest-message-util": "30.2.0", + "jest-util": "30.2.0", + "jest-worker": "30.2.0", "slash": "^3.0.0", - "stack-utils": "^2.0.6" + "string-length": "^4.0.2", + "v8-to-istanbul": "^9.0.1" }, "engines": { "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" - } - }, - "node_modules/@jest/environment-jsdom-abstract/node_modules/jest-mock": { - "version": "30.2.0", - "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-30.2.0.tgz", - "integrity": "sha512-JNNNl2rj4b5ICpmAcq+WbLH83XswjPbjH4T7yvGzfAGCPh1rw+xVNbtk+FnRslvt9lkCcdn9i1oAoKUuFsOxRw==", - "dev": true, - "dependencies": { - "@jest/types": "30.2.0", - "@types/node": "*", - "jest-util": "30.2.0" - }, - "engines": { - "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" - } - }, - "node_modules/@jest/environment-jsdom-abstract/node_modules/jest-util": { - "version": "30.2.0", - "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-30.2.0.tgz", - "integrity": "sha512-QKNsM0o3Xe6ISQU869e+DhG+4CK/48aHYdJZGlFQVTjnbvgpcKyxpzk29fGiO7i/J8VENZ+d2iGnSsvmuHywlA==", - "dev": true, - "dependencies": { - "@jest/types": "30.2.0", - "@types/node": "*", - "chalk": "^4.1.2", - "ci-info": "^4.2.0", - "graceful-fs": "^4.2.11", - "picomatch": "^4.0.2" - }, - "engines": { - "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" - } - }, - "node_modules/@jest/environment-jsdom-abstract/node_modules/picomatch": { - "version": "4.0.3", - "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-4.0.3.tgz", - "integrity": "sha512-5gTmgEY/sqK6gFXLIsQNH19lWb4ebPDLA4SdLP7dsWkIXHWlG66oPuVvXSGFPppYZz8ZDZq0dYYrbHfBCVUb1Q==", - "dev": true, - "engines": { - "node": ">=12" - }, - "funding": { - "url": "https://github.com/sponsors/jonschlinkert" - } - }, - "node_modules/@jest/environment-jsdom-abstract/node_modules/pretty-format": { - "version": "30.2.0", - "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.2.0.tgz", - "integrity": "sha512-9uBdv/B4EefsuAL+pWqueZyZS2Ba+LxfFeQ9DN14HU4bN8bhaxKdkpjpB6fs9+pSjIBu+FXQHImEg8j/Lw0+vA==", - "dev": true, - "dependencies": { - "@jest/schemas": "30.0.5", - "ansi-styles": "^5.2.0", - "react-is": "^18.3.1" - }, - "engines": { - "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" - } - }, - "node_modules/@jest/environment-jsdom-abstract/node_modules/react-is": { - "version": "18.3.1", - "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.3.1.tgz", - "integrity": "sha512-/LLMVyas0ljjAtoYiPqYiL8VWXzUUdThrmU5+n20DZv+a+ClRoevUzw5JxU+Ieh5/c87ytoTBV9G1FiKfNJdmg==", - "dev": true - }, - "node_modules/@jest/expect": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/@jest/expect/-/expect-29.7.0.tgz", - "integrity": "sha512-8uMeAMycttpva3P1lBHB8VciS9V0XAr3GymPpipdyQXbBcuhkLQOSe8E/p92RyAdToS6ZD1tFkX+CkhoECE0dQ==", - "dev": true, - "dependencies": { - "expect": "^29.7.0", - "jest-snapshot": "^29.7.0" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/@jest/expect-utils": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/@jest/expect-utils/-/expect-utils-29.7.0.tgz", - "integrity": "sha512-GlsNBWiFQFCVi9QVSx7f5AgMeLxe9YCCs5PuP2O2LdjDAA8Jh9eX7lA1Jq/xdXw3Wb3hyvlFNfZIfcRetSzYcA==", - "dev": true, - "dependencies": { - "jest-get-type": "^29.6.3" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/@jest/fake-timers": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-29.7.0.tgz", - "integrity": "sha512-q4DH1Ha4TTFPdxLsqDXK1d3+ioSL7yL5oCMJZgDYm6i+6CygW5E5xVr/D1HdsGxjt1ZWSfUAs9OxSB/BNelWrQ==", - "dev": true, - "dependencies": { - "@jest/types": "^29.6.3", - "@sinonjs/fake-timers": "^10.0.2", - "@types/node": "*", - "jest-message-util": "^29.7.0", - "jest-mock": "^29.7.0", - "jest-util": "^29.7.0" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/@jest/globals": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/@jest/globals/-/globals-29.7.0.tgz", - "integrity": "sha512-mpiz3dutLbkW2MNFubUGUEVLkTGiqW6yLVTA+JbP6fI6J5iL9Y0Nlg8k95pcF8ctKwCS7WVxteBs29hhfAotzQ==", - "dev": true, - "dependencies": { - "@jest/environment": "^29.7.0", - "@jest/expect": "^29.7.0", - "@jest/types": "^29.6.3", - "jest-mock": "^29.7.0" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/@jest/pattern": { - "version": "30.0.1", - "resolved": "https://registry.npmjs.org/@jest/pattern/-/pattern-30.0.1.tgz", - "integrity": "sha512-gWp7NfQW27LaBQz3TITS8L7ZCQ0TLvtmI//4OwlQRx4rnWxcPNIYjxZpDcN4+UlGxgm3jS5QPz8IPTCkb59wZA==", - "dev": true, - "dependencies": { - "@types/node": "*", - "jest-regex-util": "30.0.1" - }, - "engines": { - "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" - } - }, - "node_modules/@jest/pattern/node_modules/jest-regex-util": { - "version": "30.0.1", - "resolved": "https://registry.npmjs.org/jest-regex-util/-/jest-regex-util-30.0.1.tgz", - "integrity": "sha512-jHEQgBXAgc+Gh4g0p3bCevgRCVRkB4VB70zhoAE48gxeSr1hfUOsM/C2WoJgVL7Eyg//hudYENbm3Ne+/dRVVA==", - "dev": true, - "engines": { - "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" - } - }, - "node_modules/@jest/reporters": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/@jest/reporters/-/reporters-29.7.0.tgz", - "integrity": "sha512-DApq0KJbJOEzAFYjHADNNxAE3KbhxQB1y5Kplb5Waqw6zVbuWatSnMjE5gs8FUgEPmNsnZA3NCWl9NG0ia04Pg==", - "dev": true, - "dependencies": { - "@bcoe/v8-coverage": "^0.2.3", - "@jest/console": "^29.7.0", - "@jest/test-result": "^29.7.0", - "@jest/transform": "^29.7.0", - "@jest/types": "^29.6.3", - "@jridgewell/trace-mapping": "^0.3.18", - "@types/node": "*", - "chalk": "^4.0.0", - "collect-v8-coverage": "^1.0.0", - "exit": "^0.1.2", - "glob": "^7.1.3", - "graceful-fs": "^4.2.9", - "istanbul-lib-coverage": "^3.0.0", - "istanbul-lib-instrument": "^6.0.0", - "istanbul-lib-report": "^3.0.0", - "istanbul-lib-source-maps": "^4.0.0", - "istanbul-reports": "^3.1.3", - "jest-message-util": "^29.7.0", - "jest-util": "^29.7.0", - "jest-worker": "^29.7.0", - "slash": "^3.0.0", - "string-length": "^4.0.1", - "strip-ansi": "^6.0.0", - "v8-to-istanbul": "^9.0.1" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" }, "peerDependencies": { "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" @@ -1465,207 +1297,177 @@ } } }, - "node_modules/@jest/reporters/node_modules/istanbul-lib-instrument": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-6.0.0.tgz", - "integrity": "sha512-x58orMzEVfzPUKqlbLd1hXCnySCxKdDKa6Rjg97CwuLLRI4g3FHTdnExu1OqffVFay6zeMW+T6/DowFLndWnIw==", - "dev": true, - "dependencies": { - "@babel/core": "^7.12.3", - "@babel/parser": "^7.14.7", - "@istanbuljs/schema": "^0.1.2", - "istanbul-lib-coverage": "^3.2.0", - "semver": "^7.5.4" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/@jest/reporters/node_modules/lru-cache": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", - "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", - "dev": true, - "dependencies": { - "yallist": "^4.0.0" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/@jest/reporters/node_modules/semver": { - "version": "7.5.4", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz", - "integrity": "sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA==", + "node_modules/@jest/schemas": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/@jest/schemas/-/schemas-30.0.5.tgz", + "integrity": "sha512-DmdYgtezMkh3cpU8/1uyXakv3tJRcmcXxBOcO0tbaozPwpmh4YMsnWrQm9ZmZMfa5ocbxzbFk6O4bDPEc/iAnA==", "dev": true, "dependencies": { - "lru-cache": "^6.0.0" - }, - "bin": { - "semver": "bin/semver.js" + "@sinclair/typebox": "^0.34.0" }, "engines": { - "node": ">=10" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, - "node_modules/@jest/reporters/node_modules/yallist": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", - "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", - "dev": true - }, - "node_modules/@jest/schemas": { - "version": "29.6.3", - "resolved": "https://registry.npmjs.org/@jest/schemas/-/schemas-29.6.3.tgz", - "integrity": "sha512-mo5j5X+jIZmJQveBKeS/clAueipV7KgiX1vMgCxam1RNYiqE1w62n0/tJJnHtjW8ZHcQco5gY85jA3mi0L+nSA==", + "node_modules/@jest/snapshot-utils": { + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/snapshot-utils/-/snapshot-utils-30.2.0.tgz", + "integrity": "sha512-0aVxM3RH6DaiLcjj/b0KrIBZhSX1373Xci4l3cW5xiUWPctZ59zQ7jj4rqcJQ/Z8JuN/4wX3FpJSa3RssVvCug==", "dev": true, "dependencies": { - "@sinclair/typebox": "^0.27.8" + "@jest/types": "30.2.0", + "chalk": "^4.1.2", + "graceful-fs": "^4.2.11", + "natural-compare": "^1.4.0" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/@jest/source-map": { - "version": "29.6.3", - "resolved": "https://registry.npmjs.org/@jest/source-map/-/source-map-29.6.3.tgz", - "integrity": "sha512-MHjT95QuipcPrpLM+8JMSzFx6eHp5Bm+4XeFDJlwsvVBjmKNiIAvasGK2fxz2WbGRlnvqehFbh07MMa7n3YJnw==", + "version": "30.0.1", + "resolved": "https://registry.npmjs.org/@jest/source-map/-/source-map-30.0.1.tgz", + "integrity": "sha512-MIRWMUUR3sdbP36oyNyhbThLHyJ2eEDClPCiHVbrYAe5g3CHRArIVpBw7cdSB5fr+ofSfIb2Tnsw8iEHL0PYQg==", "dev": true, "dependencies": { - "@jridgewell/trace-mapping": "^0.3.18", - "callsites": "^3.0.0", - "graceful-fs": "^4.2.9" + "@jridgewell/trace-mapping": "^0.3.25", + "callsites": "^3.1.0", + "graceful-fs": "^4.2.11" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/@jest/test-result": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/@jest/test-result/-/test-result-29.7.0.tgz", - "integrity": "sha512-Fdx+tv6x1zlkJPcWXmMDAG2HBnaR9XPSd5aDWQVsfrZmLVT3lU1cwyxLgRmXR9yrq4NBoEm9BMsfgFzTQAbJYA==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/test-result/-/test-result-30.2.0.tgz", + "integrity": "sha512-RF+Z+0CCHkARz5HT9mcQCBulb1wgCP3FBvl9VFokMX27acKphwyQsNuWH3c+ojd1LeWBLoTYoxF0zm6S/66mjg==", "dev": true, "dependencies": { - "@jest/console": "^29.7.0", - "@jest/types": "^29.6.3", - "@types/istanbul-lib-coverage": "^2.0.0", - "collect-v8-coverage": "^1.0.0" + "@jest/console": "30.2.0", + "@jest/types": "30.2.0", + "@types/istanbul-lib-coverage": "^2.0.6", + "collect-v8-coverage": "^1.0.2" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/@jest/test-sequencer": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/@jest/test-sequencer/-/test-sequencer-29.7.0.tgz", - "integrity": "sha512-GQwJ5WZVrKnOJuiYiAF52UNUJXgTZx1NHjFSEB0qEMmSZKAkdMoIzw/Cj6x6NF4AvV23AUqDpFzQkN/eYCYTxw==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/test-sequencer/-/test-sequencer-30.2.0.tgz", + "integrity": "sha512-wXKgU/lk8fKXMu/l5Hog1R61bL4q5GCdT6OJvdAFz1P+QrpoFuLU68eoKuVc4RbrTtNnTL5FByhWdLgOPSph+Q==", "dev": true, "dependencies": { - "@jest/test-result": "^29.7.0", - "graceful-fs": "^4.2.9", - "jest-haste-map": "^29.7.0", + "@jest/test-result": "30.2.0", + "graceful-fs": "^4.2.11", + "jest-haste-map": "30.2.0", "slash": "^3.0.0" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/@jest/transform": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/@jest/transform/-/transform-29.7.0.tgz", - "integrity": "sha512-ok/BTPFzFKVMwO5eOHRrvnBVHdRy9IrsrW1GpMaQ9MCnilNLXQKmAX8s1YXDFaai9xJpac2ySzV0YeRRECr2Vw==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/transform/-/transform-30.2.0.tgz", + "integrity": "sha512-XsauDV82o5qXbhalKxD7p4TZYYdwcaEXC77PPD2HixEFF+6YGppjrAAQurTl2ECWcEomHBMMNS9AH3kcCFx8jA==", "dev": true, "dependencies": { - "@babel/core": "^7.11.6", - "@jest/types": "^29.6.3", - "@jridgewell/trace-mapping": "^0.3.18", - "babel-plugin-istanbul": "^6.1.1", - "chalk": "^4.0.0", + "@babel/core": "^7.27.4", + "@jest/types": "30.2.0", + "@jridgewell/trace-mapping": "^0.3.25", + "babel-plugin-istanbul": "^7.0.1", + "chalk": "^4.1.2", "convert-source-map": "^2.0.0", "fast-json-stable-stringify": "^2.1.0", - "graceful-fs": "^4.2.9", - "jest-haste-map": "^29.7.0", - "jest-regex-util": "^29.6.3", - "jest-util": "^29.7.0", - "micromatch": "^4.0.4", - "pirates": "^4.0.4", + "graceful-fs": "^4.2.11", + "jest-haste-map": "30.2.0", + "jest-regex-util": "30.0.1", + "jest-util": "30.2.0", + "micromatch": "^4.0.8", + "pirates": "^4.0.7", "slash": "^3.0.0", - "write-file-atomic": "^4.0.2" + "write-file-atomic": "^5.0.1" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/@jest/types": { - "version": "29.6.3", - "resolved": "https://registry.npmjs.org/@jest/types/-/types-29.6.3.tgz", - "integrity": "sha512-u3UPsIilWKOM3F9CXtrG8LEJmNxwoCQC/XVj4IKYXvvpx7QIi/Kg1LI5uDmDpKlac62NUtX7eLjRh+jVZcLOzw==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/types/-/types-30.2.0.tgz", + "integrity": "sha512-H9xg1/sfVvyfU7o3zMfBEjQ1gcsdeTMgqHoYdN79tuLqfTtuu7WckRA1R5whDwOzxaZAeMKTYWqP+WCAi0CHsg==", "dev": true, "dependencies": { - "@jest/schemas": "^29.6.3", - "@types/istanbul-lib-coverage": "^2.0.0", - "@types/istanbul-reports": "^3.0.0", + "@jest/pattern": "30.0.1", + "@jest/schemas": "30.0.5", + "@types/istanbul-lib-coverage": "^2.0.6", + "@types/istanbul-reports": "^3.0.4", "@types/node": "*", - "@types/yargs": "^17.0.8", - "chalk": "^4.0.0" + "@types/yargs": "^17.0.33", + "chalk": "^4.1.2" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/@jridgewell/gen-mapping": { - "version": "0.3.3", - "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.3.tgz", - "integrity": "sha512-HLhSWOLRi875zjjMG/r+Nv0oCW8umGb0BgEhyX3dDX3egwZtB8PqLnjz3yedt8R5StBrzcg4aBpnh8UA9D1BoQ==", + "version": "0.3.13", + "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.13.tgz", + "integrity": "sha512-2kkt/7niJ6MgEPxF0bYdQ6etZaA+fQvDcLKckhy1yIQOzaoKjBBjSj63/aLVjYE3qhRt5dvM+uUyfCg6UKCBbA==", "dev": true, "dependencies": { - "@jridgewell/set-array": "^1.0.1", - "@jridgewell/sourcemap-codec": "^1.4.10", - "@jridgewell/trace-mapping": "^0.3.9" - }, - "engines": { - "node": ">=6.0.0" + "@jridgewell/sourcemap-codec": "^1.5.0", + "@jridgewell/trace-mapping": "^0.3.24" } }, - "node_modules/@jridgewell/resolve-uri": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz", - "integrity": "sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w==", + "node_modules/@jridgewell/remapping": { + "version": "2.3.5", + "resolved": "https://registry.npmjs.org/@jridgewell/remapping/-/remapping-2.3.5.tgz", + "integrity": "sha512-LI9u/+laYG4Ds1TDKSJW2YPrIlcVYOwi2fUC6xB43lueCjgxV4lffOCZCtYFiH6TNOX+tQKXx97T4IKHbhyHEQ==", "dev": true, - "engines": { - "node": ">=6.0.0" + "dependencies": { + "@jridgewell/gen-mapping": "^0.3.5", + "@jridgewell/trace-mapping": "^0.3.24" } }, - "node_modules/@jridgewell/set-array": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz", - "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==", + "node_modules/@jridgewell/resolve-uri": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz", + "integrity": "sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==", "dev": true, "engines": { "node": ">=6.0.0" } }, "node_modules/@jridgewell/sourcemap-codec": { - "version": "1.4.15", - "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz", - "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==", + "version": "1.5.5", + "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.5.5.tgz", + "integrity": "sha512-cYQ9310grqxueWbl+WuIUIaiUaDcj7WOq5fVhEljNVgRfOUhY9fy2zTvfoqWsnebh8Sl70VScFbICvJnLKB0Og==", "dev": true }, "node_modules/@jridgewell/trace-mapping": { - "version": "0.3.18", - "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.18.tgz", - "integrity": "sha512-w+niJYzMHdd7USdiH2U6869nqhD2nbfZXND5Yp93qIbEmnDNk7PD48o+YchRVpzMU7M6jVCbenTR7PA1FLQ9pA==", + "version": "0.3.31", + "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.31.tgz", + "integrity": "sha512-zzNR+SdQSDJzc8joaeP8QQoCQr8NuYx2dIIytl1QeBEZHJ9uW6hebsrYgbz8hJwUQao3TWCMtmfV8Nu1twOLAw==", "dev": true, "dependencies": { - "@jridgewell/resolve-uri": "3.1.0", - "@jridgewell/sourcemap-codec": "1.4.14" + "@jridgewell/resolve-uri": "^3.1.0", + "@jridgewell/sourcemap-codec": "^1.4.14" } }, - "node_modules/@jridgewell/trace-mapping/node_modules/@jridgewell/sourcemap-codec": { - "version": "1.4.14", - "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz", - "integrity": "sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw==", - "dev": true + "node_modules/@napi-rs/wasm-runtime": { + "version": "0.2.12", + "resolved": "https://registry.npmjs.org/@napi-rs/wasm-runtime/-/wasm-runtime-0.2.12.tgz", + "integrity": "sha512-ZVWUcfwY4E/yPitQJl481FjFo3K22D6qF0DuFH6Y/nbnE11GY5uguDxZMGXPQ8WQ0128MXQD7TnfHyK4oWoIJQ==", + "dev": true, + "optional": true, + "dependencies": { + "@emnapi/core": "^1.4.3", + "@emnapi/runtime": "^1.4.3", + "@tybys/wasm-util": "^0.10.0" + } }, "node_modules/@octokit/auth-token": { "version": "4.0.0", @@ -1839,10 +1641,32 @@ "@octokit/openapi-types": "^24.2.0" } }, + "node_modules/@pkgjs/parseargs": { + "version": "0.11.0", + "resolved": "https://registry.npmjs.org/@pkgjs/parseargs/-/parseargs-0.11.0.tgz", + "integrity": "sha512-+1VkjdD0QBLPodGrJUeqarH8VAIvQODIbwh9XpP5Syisf7YoQgsJKPNFoqqLQlu+VQ/tVSshMR6loPMn8U+dPg==", + "dev": true, + "optional": true, + "engines": { + "node": ">=14" + } + }, + "node_modules/@pkgr/core": { + "version": "0.2.9", + "resolved": "https://registry.npmjs.org/@pkgr/core/-/core-0.2.9.tgz", + "integrity": "sha512-QNqXyfVS2wm9hweSYD2O7F0G06uurj9kZ96TRQE5Y9hU7+tgdZwIkbAKc5Ocy1HxEY2kuDQa6cQ1WRs/O5LFKA==", + "dev": true, + "engines": { + "node": "^12.20.0 || ^14.18.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/pkgr" + } + }, "node_modules/@sinclair/typebox": { - "version": "0.27.8", - "resolved": "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.27.8.tgz", - "integrity": "sha512-+Fj43pSMwJs4KRrH/938Uf+uAELIgVBmQzg/q1YG10djyfA3TnrU8N8XzqCh/okZdszqBQTZf96idMfE5lnwTA==", + "version": "0.34.41", + "resolved": "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.34.41.tgz", + "integrity": "sha512-6gS8pZzSXdyRHTIqoqSVknxolr1kzfy4/CeDnrzsVz8TTIWUbOBr6gnzOmTYJ3eXQNh4IYHIGi5aIL7sOZ2G/g==", "dev": true }, "node_modules/@sinonjs/commons": { @@ -1855,12 +1679,12 @@ } }, "node_modules/@sinonjs/fake-timers": { - "version": "10.2.0", - "resolved": "https://registry.npmjs.org/@sinonjs/fake-timers/-/fake-timers-10.2.0.tgz", - "integrity": "sha512-OPwQlEdg40HAj5KNF8WW6q2KG4Z+cBCZb3m4ninfTZKaBmbIJodviQsDBoYMPHkOyJJMHnOJo5j2+LKDOhOACg==", + "version": "13.0.5", + "resolved": "https://registry.npmjs.org/@sinonjs/fake-timers/-/fake-timers-13.0.5.tgz", + "integrity": "sha512-36/hTbH2uaWuGVERyC6da9YwGWnzUZXuPro/F2LfsdOsLnCojz/iSH8MxUt/FD2S5XBSVPhmArFUXcpCQ2Hkiw==", "dev": true, "dependencies": { - "@sinonjs/commons": "^3.0.0" + "@sinonjs/commons": "^3.0.1" } }, "node_modules/@testing-library/dom": { @@ -1907,6 +1731,16 @@ "integrity": "sha512-7ZgogeTnjuHbo+ct10G9Ffp0mif17idi0IyWNVA/wcwcm7NPOD/WEHVP3n7n3MhXqxoIYm8d6MuZohYWIZ4T3w==", "dev": true }, + "node_modules/@tybys/wasm-util": { + "version": "0.10.1", + "resolved": "https://registry.npmjs.org/@tybys/wasm-util/-/wasm-util-0.10.1.tgz", + "integrity": "sha512-9tTaPJLSiejZKx+Bmog4uSubteqTvFrVrURwkmHixBo0G4seD0zUxp98E1DzUBJxLQ3NPwXrGKDiVjwx/DpPsg==", + "dev": true, + "optional": true, + "dependencies": { + "tslib": "^2.4.0" + } + }, "node_modules/@types/aria-query": { "version": "5.0.1", "resolved": "https://registry.npmjs.org/@types/aria-query/-/aria-query-5.0.1.tgz", @@ -1914,9 +1748,9 @@ "dev": true }, "node_modules/@types/babel__core": { - "version": "7.20.2", - "resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.20.2.tgz", - "integrity": "sha512-pNpr1T1xLUc2l3xJKuPtsEky3ybxN3m4fJkknfIpTCTfIZCDW57oAg+EfCgIIp2rvCe0Wn++/FfodDS4YXxBwA==", + "version": "7.20.5", + "resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.20.5.tgz", + "integrity": "sha512-qoQprZvz5wQFJwMDqeseRXWv3rqMvhgpbXFfVyWhbx9X47POIA6i/+dXefEmZKoAgOaTdaIgNSMqMIU61yRyzA==", "dev": true, "dependencies": { "@babel/parser": "^7.20.7", @@ -1927,18 +1761,18 @@ } }, "node_modules/@types/babel__generator": { - "version": "7.6.5", - "resolved": "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.6.5.tgz", - "integrity": "sha512-h9yIuWbJKdOPLJTbmSpPzkF67e659PbQDba7ifWm5BJ8xTv+sDmS7rFmywkWOvXedGTivCdeGSIIX8WLcRTz8w==", + "version": "7.27.0", + "resolved": "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.27.0.tgz", + "integrity": "sha512-ufFd2Xi92OAVPYsy+P4n7/U7e68fex0+Ee8gSG9KX7eo084CWiQ4sdxktvdl0bOPupXtVJPY19zk6EwWqUQ8lg==", "dev": true, "dependencies": { "@babel/types": "^7.0.0" } }, "node_modules/@types/babel__template": { - "version": "7.4.2", - "resolved": "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.4.2.tgz", - "integrity": "sha512-/AVzPICMhMOMYoSx9MoKpGDKdBRsIXMNByh1PXSZoa+v6ZoLa8xxtsT/uLQ/NJm0XVAWl/BvId4MlDeXJaeIZQ==", + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.4.4.tgz", + "integrity": "sha512-h/NUaSyG5EyxBIp8YRxo4RMe2/qQgvyowRwVMzhYhBCONbW8PUsg4lkFMrhgZhUe5z3L3MiLDuvyJ/CaPa2A8A==", "dev": true, "dependencies": { "@babel/parser": "^7.1.0", @@ -1946,12 +1780,12 @@ } }, "node_modules/@types/babel__traverse": { - "version": "7.20.2", - "resolved": "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.20.2.tgz", - "integrity": "sha512-ojlGK1Hsfce93J0+kn3H5R73elidKUaZonirN33GSmgTUMpzI/MIFfSpF3haANe3G1bEBS9/9/QEqwTzwqFsKw==", + "version": "7.28.0", + "resolved": "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.28.0.tgz", + "integrity": "sha512-8PvcXf70gTDZBgt9ptxJ8elBeBjcLOAcOtoO/mPJjtji1+CdGbHgm77om1GrsPxsiE+uXIpNSK64UYaIwQXd4Q==", "dev": true, "dependencies": { - "@babel/types": "^7.20.7" + "@babel/types": "^7.28.2" } }, "node_modules/@types/estree": { @@ -1960,15 +1794,6 @@ "integrity": "sha512-dWHzHa2WqEXI/O1E9OjrocMTKJl2mSrEolh1Iomrv6U+JuNwaHXsXx9bLu5gG7BUWFIN0skIQJQ/L1rIex4X6w==", "dev": true }, - "node_modules/@types/graceful-fs": { - "version": "4.1.6", - "resolved": "https://registry.npmjs.org/@types/graceful-fs/-/graceful-fs-4.1.6.tgz", - "integrity": "sha512-Sig0SNORX9fdW+bQuTEovKj3uHcUL6LQKbCrrqb1X7J6/ReAbhCXRAhc+SMejhLELFj2QcyuxmUooZ4bt5ReSw==", - "dev": true, - "dependencies": { - "@types/node": "*" - } - }, "node_modules/@types/istanbul-lib-coverage": { "version": "2.0.6", "resolved": "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.6.tgz", @@ -2056,28 +1881,284 @@ "url": "https://opencollective.com/typescript-eslint" } }, - "node_modules/@uppercod/css-to-object": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/@uppercod/css-to-object/-/css-to-object-1.1.1.tgz", - "integrity": "sha512-dCTxxolI6fu28lzNRVwd7CzJV8EbARITFyCbP/JqLHYLfWHY7GJqXHDdk0GbtfXvsZosPCvjOE4dOIMT4XDFZQ==", + "node_modules/@ungap/structured-clone": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/@ungap/structured-clone/-/structured-clone-1.3.0.tgz", + "integrity": "sha512-WmoN8qaIAo7WTYWbAZuG8PYEhn5fkz7dZrqTBZ7dtt//lL2Gwms1IcnQ5yHqjDfX8Ft5j4YzDM23f87zBfDe9g==", "dev": true }, - "node_modules/accepts": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/accepts/-/accepts-2.0.0.tgz", - "integrity": "sha512-5cvg6CtKwfgdmVqY1WIiXKc3Q1bkRqGLi+2W/6ao+6Y7gu/RCwRuAhGEzh5B4KlszSuTLgZYuqFqo5bImjNKng==", + "node_modules/@unrs/resolver-binding-android-arm-eabi": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-android-arm-eabi/-/resolver-binding-android-arm-eabi-1.11.1.tgz", + "integrity": "sha512-ppLRUgHVaGRWUx0R0Ut06Mjo9gBaBkg3v/8AxusGLhsIotbBLuRk51rAzqLC8gq6NyyAojEXglNjzf6R948DNw==", + "cpu": [ + "arm" + ], "dev": true, - "license": "MIT", - "dependencies": { - "mime-types": "^3.0.0", - "negotiator": "^1.0.0" - }, - "engines": { - "node": ">= 0.6" - } + "optional": true, + "os": [ + "android" + ] }, - "node_modules/accepts/node_modules/mime-db": { - "version": "1.54.0", + "node_modules/@unrs/resolver-binding-android-arm64": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-android-arm64/-/resolver-binding-android-arm64-1.11.1.tgz", + "integrity": "sha512-lCxkVtb4wp1v+EoN+HjIG9cIIzPkX5OtM03pQYkG+U5O/wL53LC4QbIeazgiKqluGeVEeBlZahHalCaBvU1a2g==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "android" + ] + }, + "node_modules/@unrs/resolver-binding-darwin-arm64": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-darwin-arm64/-/resolver-binding-darwin-arm64-1.11.1.tgz", + "integrity": "sha512-gPVA1UjRu1Y/IsB/dQEsp2V1pm44Of6+LWvbLc9SDk1c2KhhDRDBUkQCYVWe6f26uJb3fOK8saWMgtX8IrMk3g==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "darwin" + ] + }, + "node_modules/@unrs/resolver-binding-darwin-x64": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-darwin-x64/-/resolver-binding-darwin-x64-1.11.1.tgz", + "integrity": "sha512-cFzP7rWKd3lZaCsDze07QX1SC24lO8mPty9vdP+YVa3MGdVgPmFc59317b2ioXtgCMKGiCLxJ4HQs62oz6GfRQ==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "darwin" + ] + }, + "node_modules/@unrs/resolver-binding-freebsd-x64": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-freebsd-x64/-/resolver-binding-freebsd-x64-1.11.1.tgz", + "integrity": "sha512-fqtGgak3zX4DCB6PFpsH5+Kmt/8CIi4Bry4rb1ho6Av2QHTREM+47y282Uqiu3ZRF5IQioJQ5qWRV6jduA+iGw==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "freebsd" + ] + }, + "node_modules/@unrs/resolver-binding-linux-arm-gnueabihf": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-linux-arm-gnueabihf/-/resolver-binding-linux-arm-gnueabihf-1.11.1.tgz", + "integrity": "sha512-u92mvlcYtp9MRKmP+ZvMmtPN34+/3lMHlyMj7wXJDeXxuM0Vgzz0+PPJNsro1m3IZPYChIkn944wW8TYgGKFHw==", + "cpu": [ + "arm" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@unrs/resolver-binding-linux-arm-musleabihf": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-linux-arm-musleabihf/-/resolver-binding-linux-arm-musleabihf-1.11.1.tgz", + "integrity": "sha512-cINaoY2z7LVCrfHkIcmvj7osTOtm6VVT16b5oQdS4beibX2SYBwgYLmqhBjA1t51CarSaBuX5YNsWLjsqfW5Cw==", + "cpu": [ + "arm" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@unrs/resolver-binding-linux-arm64-gnu": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-linux-arm64-gnu/-/resolver-binding-linux-arm64-gnu-1.11.1.tgz", + "integrity": "sha512-34gw7PjDGB9JgePJEmhEqBhWvCiiWCuXsL9hYphDF7crW7UgI05gyBAi6MF58uGcMOiOqSJ2ybEeCvHcq0BCmQ==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@unrs/resolver-binding-linux-arm64-musl": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-linux-arm64-musl/-/resolver-binding-linux-arm64-musl-1.11.1.tgz", + "integrity": "sha512-RyMIx6Uf53hhOtJDIamSbTskA99sPHS96wxVE/bJtePJJtpdKGXO1wY90oRdXuYOGOTuqjT8ACccMc4K6QmT3w==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@unrs/resolver-binding-linux-ppc64-gnu": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-linux-ppc64-gnu/-/resolver-binding-linux-ppc64-gnu-1.11.1.tgz", + "integrity": "sha512-D8Vae74A4/a+mZH0FbOkFJL9DSK2R6TFPC9M+jCWYia/q2einCubX10pecpDiTmkJVUH+y8K3BZClycD8nCShA==", + "cpu": [ + "ppc64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@unrs/resolver-binding-linux-riscv64-gnu": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-linux-riscv64-gnu/-/resolver-binding-linux-riscv64-gnu-1.11.1.tgz", + "integrity": "sha512-frxL4OrzOWVVsOc96+V3aqTIQl1O2TjgExV4EKgRY09AJ9leZpEg8Ak9phadbuX0BA4k8U5qtvMSQQGGmaJqcQ==", + "cpu": [ + "riscv64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@unrs/resolver-binding-linux-riscv64-musl": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-linux-riscv64-musl/-/resolver-binding-linux-riscv64-musl-1.11.1.tgz", + "integrity": "sha512-mJ5vuDaIZ+l/acv01sHoXfpnyrNKOk/3aDoEdLO/Xtn9HuZlDD6jKxHlkN8ZhWyLJsRBxfv9GYM2utQ1SChKew==", + "cpu": [ + "riscv64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@unrs/resolver-binding-linux-s390x-gnu": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-linux-s390x-gnu/-/resolver-binding-linux-s390x-gnu-1.11.1.tgz", + "integrity": "sha512-kELo8ebBVtb9sA7rMe1Cph4QHreByhaZ2QEADd9NzIQsYNQpt9UkM9iqr2lhGr5afh885d/cB5QeTXSbZHTYPg==", + "cpu": [ + "s390x" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@unrs/resolver-binding-linux-x64-gnu": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-linux-x64-gnu/-/resolver-binding-linux-x64-gnu-1.11.1.tgz", + "integrity": "sha512-C3ZAHugKgovV5YvAMsxhq0gtXuwESUKc5MhEtjBpLoHPLYM+iuwSj3lflFwK3DPm68660rZ7G8BMcwSro7hD5w==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@unrs/resolver-binding-linux-x64-musl": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-linux-x64-musl/-/resolver-binding-linux-x64-musl-1.11.1.tgz", + "integrity": "sha512-rV0YSoyhK2nZ4vEswT/QwqzqQXw5I6CjoaYMOX0TqBlWhojUf8P94mvI7nuJTeaCkkds3QE4+zS8Ko+GdXuZtA==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@unrs/resolver-binding-wasm32-wasi": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-wasm32-wasi/-/resolver-binding-wasm32-wasi-1.11.1.tgz", + "integrity": "sha512-5u4RkfxJm+Ng7IWgkzi3qrFOvLvQYnPBmjmZQ8+szTK/b31fQCnleNl1GgEt7nIsZRIf5PLhPwT0WM+q45x/UQ==", + "cpu": [ + "wasm32" + ], + "dev": true, + "optional": true, + "dependencies": { + "@napi-rs/wasm-runtime": "^0.2.11" + }, + "engines": { + "node": ">=14.0.0" + } + }, + "node_modules/@unrs/resolver-binding-win32-arm64-msvc": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-win32-arm64-msvc/-/resolver-binding-win32-arm64-msvc-1.11.1.tgz", + "integrity": "sha512-nRcz5Il4ln0kMhfL8S3hLkxI85BXs3o8EYoattsJNdsX4YUU89iOkVn7g0VHSRxFuVMdM4Q1jEpIId1Ihim/Uw==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "win32" + ] + }, + "node_modules/@unrs/resolver-binding-win32-ia32-msvc": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-win32-ia32-msvc/-/resolver-binding-win32-ia32-msvc-1.11.1.tgz", + "integrity": "sha512-DCEI6t5i1NmAZp6pFonpD5m7i6aFrpofcp4LA2i8IIq60Jyo28hamKBxNrZcyOwVOZkgsRp9O2sXWBWP8MnvIQ==", + "cpu": [ + "ia32" + ], + "dev": true, + "optional": true, + "os": [ + "win32" + ] + }, + "node_modules/@unrs/resolver-binding-win32-x64-msvc": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-win32-x64-msvc/-/resolver-binding-win32-x64-msvc-1.11.1.tgz", + "integrity": "sha512-lrW200hZdbfRtztbygyaq/6jP6AKE8qQN2KvPcJ+x7wiD038YtnYtZ82IMNJ69GJibV7bwL3y9FgK+5w/pYt6g==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "win32" + ] + }, + "node_modules/@uppercod/css-to-object": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/@uppercod/css-to-object/-/css-to-object-1.1.1.tgz", + "integrity": "sha512-dCTxxolI6fu28lzNRVwd7CzJV8EbARITFyCbP/JqLHYLfWHY7GJqXHDdk0GbtfXvsZosPCvjOE4dOIMT4XDFZQ==", + "dev": true + }, + "node_modules/accepts": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/accepts/-/accepts-2.0.0.tgz", + "integrity": "sha512-5cvg6CtKwfgdmVqY1WIiXKc3Q1bkRqGLi+2W/6ao+6Y7gu/RCwRuAhGEzh5B4KlszSuTLgZYuqFqo5bImjNKng==", + "dev": true, + "license": "MIT", + "dependencies": { + "mime-types": "^3.0.0", + "negotiator": "^1.0.0" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/accepts/node_modules/mime-db": { + "version": "1.54.0", "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.54.0.tgz", "integrity": "sha512-aU5EJuIN2WDemCcAp2vFBfp/m4EAhWJnUNSSw0ixs7/kXbd6Pg64EmwJkNdFhB8aWt1sH2CTXrLxo/iAGV3oPQ==", "dev": true, @@ -2251,94 +2332,94 @@ } }, "node_modules/babel-jest": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/babel-jest/-/babel-jest-29.7.0.tgz", - "integrity": "sha512-BrvGY3xZSwEcCzKvKsCi2GgHqDqsYkOP4/by5xCgIwGXQxIEh+8ew3gmrE1y7XRR6LHZIj6yLYnUi/mm2KXKBg==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/babel-jest/-/babel-jest-30.2.0.tgz", + "integrity": "sha512-0YiBEOxWqKkSQWL9nNGGEgndoeL0ZpWrbLMNL5u/Kaxrli3Eaxlt3ZtIDktEvXt4L/R9r3ODr2zKwGM/2BjxVw==", "dev": true, "dependencies": { - "@jest/transform": "^29.7.0", - "@types/babel__core": "^7.1.14", - "babel-plugin-istanbul": "^6.1.1", - "babel-preset-jest": "^29.6.3", - "chalk": "^4.0.0", - "graceful-fs": "^4.2.9", + "@jest/transform": "30.2.0", + "@types/babel__core": "^7.20.5", + "babel-plugin-istanbul": "^7.0.1", + "babel-preset-jest": "30.2.0", + "chalk": "^4.1.2", + "graceful-fs": "^4.2.11", "slash": "^3.0.0" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" }, "peerDependencies": { - "@babel/core": "^7.8.0" + "@babel/core": "^7.11.0 || ^8.0.0-0" } }, "node_modules/babel-plugin-istanbul": { - "version": "6.1.1", - "resolved": "https://registry.npmjs.org/babel-plugin-istanbul/-/babel-plugin-istanbul-6.1.1.tgz", - "integrity": "sha512-Y1IQok9821cC9onCx5otgFfRm7Lm+I+wwxOx738M/WLPZ9Q42m4IG5W0FNX8WLL2gYMZo3JkuXIH2DOpWM+qwA==", + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/babel-plugin-istanbul/-/babel-plugin-istanbul-7.0.1.tgz", + "integrity": "sha512-D8Z6Qm8jCvVXtIRkBnqNHX0zJ37rQcFJ9u8WOS6tkYOsRdHBzypCstaxWiu5ZIlqQtviRYbgnRLSoCEvjqcqbA==", "dev": true, "dependencies": { "@babel/helper-plugin-utils": "^7.0.0", "@istanbuljs/load-nyc-config": "^1.0.0", - "@istanbuljs/schema": "^0.1.2", - "istanbul-lib-instrument": "^5.0.4", + "@istanbuljs/schema": "^0.1.3", + "istanbul-lib-instrument": "^6.0.2", "test-exclude": "^6.0.0" }, "engines": { - "node": ">=8" + "node": ">=12" } }, "node_modules/babel-plugin-jest-hoist": { - "version": "29.6.3", - "resolved": "https://registry.npmjs.org/babel-plugin-jest-hoist/-/babel-plugin-jest-hoist-29.6.3.tgz", - "integrity": "sha512-ESAc/RJvGTFEzRwOTT4+lNDk/GNHMkKbNzsvT0qKRfDyyYTskxB5rnU2njIDYVxXCBHHEI1c0YwHob3WaYujOg==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/babel-plugin-jest-hoist/-/babel-plugin-jest-hoist-30.2.0.tgz", + "integrity": "sha512-ftzhzSGMUnOzcCXd6WHdBGMyuwy15Wnn0iyyWGKgBDLxf9/s5ABuraCSpBX2uG0jUg4rqJnxsLc5+oYBqoxVaA==", "dev": true, "dependencies": { - "@babel/template": "^7.3.3", - "@babel/types": "^7.3.3", - "@types/babel__core": "^7.1.14", - "@types/babel__traverse": "^7.0.6" + "@types/babel__core": "^7.20.5" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/babel-preset-current-node-syntax": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/babel-preset-current-node-syntax/-/babel-preset-current-node-syntax-1.0.1.tgz", - "integrity": "sha512-M7LQ0bxarkxQoN+vz5aJPsLBn77n8QgTFmo8WK0/44auK2xlCXrYcUxHFxgU7qW5Yzw/CjmLRK2uJzaCd7LvqQ==", + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/babel-preset-current-node-syntax/-/babel-preset-current-node-syntax-1.2.0.tgz", + "integrity": "sha512-E/VlAEzRrsLEb2+dv8yp3bo4scof3l9nR4lrld+Iy5NyVqgVYUJnDAmunkhPMisRI32Qc4iRiz425d8vM++2fg==", "dev": true, "dependencies": { "@babel/plugin-syntax-async-generators": "^7.8.4", "@babel/plugin-syntax-bigint": "^7.8.3", - "@babel/plugin-syntax-class-properties": "^7.8.3", - "@babel/plugin-syntax-import-meta": "^7.8.3", + "@babel/plugin-syntax-class-properties": "^7.12.13", + "@babel/plugin-syntax-class-static-block": "^7.14.5", + "@babel/plugin-syntax-import-attributes": "^7.24.7", + "@babel/plugin-syntax-import-meta": "^7.10.4", "@babel/plugin-syntax-json-strings": "^7.8.3", - "@babel/plugin-syntax-logical-assignment-operators": "^7.8.3", + "@babel/plugin-syntax-logical-assignment-operators": "^7.10.4", "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3", - "@babel/plugin-syntax-numeric-separator": "^7.8.3", + "@babel/plugin-syntax-numeric-separator": "^7.10.4", "@babel/plugin-syntax-object-rest-spread": "^7.8.3", "@babel/plugin-syntax-optional-catch-binding": "^7.8.3", "@babel/plugin-syntax-optional-chaining": "^7.8.3", - "@babel/plugin-syntax-top-level-await": "^7.8.3" + "@babel/plugin-syntax-private-property-in-object": "^7.14.5", + "@babel/plugin-syntax-top-level-await": "^7.14.5" }, "peerDependencies": { - "@babel/core": "^7.0.0" + "@babel/core": "^7.0.0 || ^8.0.0-0" } }, "node_modules/babel-preset-jest": { - "version": "29.6.3", - "resolved": "https://registry.npmjs.org/babel-preset-jest/-/babel-preset-jest-29.6.3.tgz", - "integrity": "sha512-0B3bhxR6snWXJZtR/RliHTDPRgn1sNHOR0yVtq/IiQFyuOVjFS+wuio/R4gSNkyYmKmJB4wGZv2NZanmKmTnNA==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/babel-preset-jest/-/babel-preset-jest-30.2.0.tgz", + "integrity": "sha512-US4Z3NOieAQumwFnYdUWKvUKh8+YSnS/gB3t6YBiz0bskpu7Pine8pPCheNxlPEW4wnUkma2a94YuW2q3guvCQ==", "dev": true, "dependencies": { - "babel-plugin-jest-hoist": "^29.6.3", - "babel-preset-current-node-syntax": "^1.0.0" + "babel-plugin-jest-hoist": "30.2.0", + "babel-preset-current-node-syntax": "^1.2.0" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" }, "peerDependencies": { - "@babel/core": "^7.0.0" + "@babel/core": "^7.11.0 || ^8.0.0-beta.1" } }, "node_modules/balanced-match": { @@ -2347,6 +2428,15 @@ "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", "dev": true }, + "node_modules/baseline-browser-mapping": { + "version": "2.8.16", + "resolved": "https://registry.npmjs.org/baseline-browser-mapping/-/baseline-browser-mapping-2.8.16.tgz", + "integrity": "sha512-OMu3BGQ4E7P1ErFsIPpbJh0qvDudM/UuJeHgkAvfWe+0HFJCXh+t/l8L6fVLR55RI/UbKrVLnAXZSVwd9ysWYw==", + "dev": true, + "bin": { + "baseline-browser-mapping": "dist/cli.js" + } + }, "node_modules/before-after-hook": { "version": "2.2.3", "resolved": "https://registry.npmjs.org/before-after-hook/-/before-after-hook-2.2.3.tgz", @@ -2398,9 +2488,9 @@ } }, "node_modules/browserslist": { - "version": "4.21.10", - "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.21.10.tgz", - "integrity": "sha512-bipEBdZfVH5/pwrvqc+Ub0kUPVfGUhlKxbvfD+z1BDnPEO/X98ruXGA1WP5ASpAFKan7Qr6j736IacbZQuAlKQ==", + "version": "4.26.3", + "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.26.3.tgz", + "integrity": "sha512-lAUU+02RFBuCKQPj/P6NgjlbCnLBMp4UtgTx7vNHd3XSIJF87s9a5rA3aH2yw3GS9DqZAUbOtZdCCiZeVRqt0w==", "dev": true, "funding": [ { @@ -2417,10 +2507,11 @@ } ], "dependencies": { - "caniuse-lite": "^1.0.30001517", - "electron-to-chromium": "^1.4.477", - "node-releases": "^2.0.13", - "update-browserslist-db": "^1.0.11" + "baseline-browser-mapping": "^2.8.9", + "caniuse-lite": "^1.0.30001746", + "electron-to-chromium": "^1.5.227", + "node-releases": "^2.0.21", + "update-browserslist-db": "^1.1.3" }, "bin": { "browserslist": "cli.js" @@ -2502,9 +2593,9 @@ } }, "node_modules/caniuse-lite": { - "version": "1.0.30001518", - "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001518.tgz", - "integrity": "sha512-rup09/e3I0BKjncL+FesTayKtPrdwKhUufQFd3riFw1hHg8JmIFoInYfB102cFcY/pPgGmdyl/iy+jgiDi2vdA==", + "version": "1.0.30001749", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001749.tgz", + "integrity": "sha512-0rw2fJOmLfnzCRbkm8EyHL8SvI2Apu5UbnQuTsJ0ClgrH8hcwFooJ1s5R0EP8o8aVrFu8++ae29Kt9/gZAZp/Q==", "dev": true, "funding": [ { @@ -2547,9 +2638,9 @@ } }, "node_modules/ci-info": { - "version": "3.8.0", - "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-3.8.0.tgz", - "integrity": "sha512-eXTggHWSooYhq49F2opQhuHWgzucfF2YgODK4e1566GQs5BIfP30B0oenwBJHfWxAs2fyPB1s7Mg949zLf61Yw==", + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-4.3.1.tgz", + "integrity": "sha512-Wdy2Igu8OcBpI2pZePZ5oWjPC38tmDVx5WKUXKwlLYkA0ozo85sLsLvkBbBn/sZaSCMFOGZJ14fvW9t5/d7kdA==", "dev": true, "funding": [ { @@ -2562,9 +2653,9 @@ } }, "node_modules/cjs-module-lexer": { - "version": "1.2.3", - "resolved": "https://registry.npmjs.org/cjs-module-lexer/-/cjs-module-lexer-1.2.3.tgz", - "integrity": "sha512-0TNiGstbQmCFwt4akjjBg5pLRTSyj/PkWQ1ZoO2zntmg9yLqSRxwEa4iCfQLGjqhiqBfOJa7W/E8wfGrTDmlZQ==", + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/cjs-module-lexer/-/cjs-module-lexer-2.1.0.tgz", + "integrity": "sha512-UX0OwmYRYQQetfrLEZeewIFFI+wSTofC+pMBLNuH3RUuu/xzG1oz84UCEDOSoQlN3fZ4+AzmV50ZYvGqkMh9yA==", "dev": true }, "node_modules/cli-cursor": { @@ -2598,18 +2689,6 @@ "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/cli-truncate/node_modules/ansi-regex": { - "version": "6.2.2", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.2.2.tgz", - "integrity": "sha512-Bq3SmSpyFHaWjPk8If9yc6svM8c56dB5BAtW4Qbw5jHTwwXXcTLoRMkpDJp6VL0XzlWaCHTXrkFURMYmD0sLqg==", - "dev": true, - "engines": { - "node": ">=12" - }, - "funding": { - "url": "https://github.com/chalk/ansi-regex?sponsor=1" - } - }, "node_modules/cli-truncate/node_modules/string-width": { "version": "8.1.0", "resolved": "https://registry.npmjs.org/string-width/-/string-width-8.1.0.tgz", @@ -2626,21 +2705,6 @@ "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/cli-truncate/node_modules/strip-ansi": { - "version": "7.1.2", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.2.tgz", - "integrity": "sha512-gmBGslpoQJtgnMAvOVqGZpEz9dyoKTCzy2nfz/n8aIFhN/jCE/rCmcxabB6jOOHV+0WNnylOxaxBQPSvcWklhA==", - "dev": true, - "dependencies": { - "ansi-regex": "^6.0.1" - }, - "engines": { - "node": ">=12" - }, - "funding": { - "url": "https://github.com/chalk/strip-ansi?sponsor=1" - } - }, "node_modules/cliui": { "version": "8.0.1", "resolved": "https://registry.npmjs.org/cliui/-/cliui-8.0.1.tgz", @@ -2655,6 +2719,55 @@ "node": ">=12" } }, + "node_modules/cliui/node_modules/emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "dev": true + }, + "node_modules/cliui/node_modules/string-width": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", + "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", + "dev": true, + "dependencies": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/cliui/node_modules/strip-ansi": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", + "dev": true, + "dependencies": { + "ansi-regex": "^5.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/cliui/node_modules/wrap-ansi": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", + "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", + "dev": true, + "dependencies": { + "ansi-styles": "^4.0.0", + "string-width": "^4.1.0", + "strip-ansi": "^6.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/wrap-ansi?sponsor=1" + } + }, "node_modules/co": { "version": "4.6.0", "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz", @@ -2785,27 +2898,6 @@ "node": ">=6.6.0" } }, - "node_modules/create-jest": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/create-jest/-/create-jest-29.7.0.tgz", - "integrity": "sha512-Adz2bdH0Vq3F53KEMJOoftQFutWCukm6J24wbPWRO4k1kMY7gS7ds/uoJkNuV8wDCtWWnuwGcJwpWcih+zEW1Q==", - "dev": true, - "dependencies": { - "@jest/types": "^29.6.3", - "chalk": "^4.0.0", - "exit": "^0.1.2", - "graceful-fs": "^4.2.9", - "jest-config": "^29.7.0", - "jest-util": "^29.7.0", - "prompts": "^2.0.1" - }, - "bin": { - "create-jest": "bin/create-jest.js" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, "node_modules/cross-spawn": { "version": "7.0.6", "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.6.tgz", @@ -2876,9 +2968,9 @@ "dev": true }, "node_modules/dedent": { - "version": "1.5.1", - "resolved": "https://registry.npmjs.org/dedent/-/dedent-1.5.1.tgz", - "integrity": "sha512-+LxW+KLWxu3HW3M2w2ympwtqPrqYRzU8fqi6Fhd18fBALe15blJPI/I4+UHveMVG6lJqB4JNd4UG0S5cnVHwIg==", + "version": "1.7.0", + "resolved": "https://registry.npmjs.org/dedent/-/dedent-1.7.0.tgz", + "integrity": "sha512-HGFtf8yhuhGhqO07SV79tRp+br4MnbdjeVxotpn1QBl30pcLLCQjX5b2295ll0fv8RKDKsmWYrl05usHM9CewQ==", "dev": true, "peerDependencies": { "babel-plugin-macros": "^3.1.0" @@ -2947,15 +3039,6 @@ "node": ">=8" } }, - "node_modules/diff-sequences": { - "version": "29.6.3", - "resolved": "https://registry.npmjs.org/diff-sequences/-/diff-sequences-29.6.3.tgz", - "integrity": "sha512-EjePK1srD3P08o2j4f0ExnylqRs5B9tJjcp9t1krH2qRi8CCdsYfwe9JgSLurFBWwq4uOlipzfk5fHNvwFKr8Q==", - "dev": true, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, "node_modules/dom-accessibility-api": { "version": "0.5.14", "resolved": "https://registry.npmjs.org/dom-accessibility-api/-/dom-accessibility-api-0.5.14.tgz", @@ -2986,6 +3069,12 @@ "node": ">= 0.4" } }, + "node_modules/eastasianwidth": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/eastasianwidth/-/eastasianwidth-0.2.0.tgz", + "integrity": "sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA==", + "dev": true + }, "node_modules/ee-first": { "version": "1.1.1", "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", @@ -2994,9 +3083,9 @@ "license": "MIT" }, "node_modules/electron-to-chromium": { - "version": "1.4.478", - "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.478.tgz", - "integrity": "sha512-qjTA8djMXd+ruoODDFGnRCRBpID+AAfYWCyGtYTNhsuwxI19s8q19gbjKTwRS5z/LyVf5wICaIiPQGLekmbJbA==", + "version": "1.5.234", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.5.234.tgz", + "integrity": "sha512-RXfEp2x+VRYn8jbKfQlRImzoJU01kyDvVPBmG39eU2iuRVhuS6vQNocB8J0/8GrIMLnPzgz4eW6WiRnJkTuNWg==", "dev": true }, "node_modules/emittery": { @@ -3017,9 +3106,9 @@ "integrity": "sha512-3KBuQuhYkRtLd9utBKfTtclbWP3IytC1FNcXg+NKARltPSYpkg/MLiklGv4vLwl8A8jMQjdneXNBYx8k0rrg+g==" }, "node_modules/emoji-regex": { - "version": "8.0.0", - "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", - "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "version": "9.2.2", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-9.2.2.tgz", + "integrity": "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==", "dev": true }, "node_modules/encodeurl": { @@ -3057,9 +3146,9 @@ } }, "node_modules/error-ex": { - "version": "1.3.2", - "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", - "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", + "version": "1.3.4", + "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.4.tgz", + "integrity": "sha512-sqQamAnR14VgCr1A618A3sGrygcpK+HEbenA/HiEAkkUwcZIIB/tgWqHFxWgOyDh4nB4JCRimh79dR5Ywc9MDQ==", "dev": true, "dependencies": { "is-arrayish": "^0.2.1" @@ -3107,9 +3196,9 @@ } }, "node_modules/escalade": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", - "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.2.0.tgz", + "integrity": "sha512-WUj2qlxaQtO4g6Pq5c29GTcWGDyd8itL8zTlipgECz3JesAiiOKotd8JU6otB3PACgG6xkJUyVhboMS+bje/jA==", "dev": true, "engines": { "node": ">=6" @@ -3286,18 +3375,6 @@ "url": "https://opencollective.com/eslint" } }, - "node_modules/eslint/node_modules/@eslint/js": { - "version": "9.36.0", - "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.36.0.tgz", - "integrity": "sha512-uhCbYtYynH30iZErszX78U+nR3pJU3RHGQ57NXy5QupD4SBVwDeU8TNBy+MjMngc1UyIW9noKqsRqfjQTBU2dw==", - "dev": true, - "engines": { - "node": "^18.18.0 || ^20.9.0 || >=21.1.0" - }, - "funding": { - "url": "https://eslint.org/donate" - } - }, "node_modules/eslint/node_modules/escape-string-regexp": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", @@ -3512,29 +3589,36 @@ "url": "https://github.com/sindresorhus/execa?sponsor=1" } }, - "node_modules/exit": { - "version": "0.1.2", - "resolved": "https://registry.npmjs.org/exit/-/exit-0.1.2.tgz", - "integrity": "sha512-Zk/eNKV2zbjpKzrsQ+n1G6poVbErQxJ0LBOJXaKZ1EViLzH+hrLu9cdXI4zw9dBQJslwBEpbQ2P1oS7nDxs6jQ==", + "node_modules/execa/node_modules/signal-exit": { + "version": "3.0.7", + "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", + "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", + "dev": true + }, + "node_modules/exit-x": { + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/exit-x/-/exit-x-0.2.2.tgz", + "integrity": "sha512-+I6B/IkJc1o/2tiURyz/ivu/O0nKNEArIUB5O7zBrlDVJr22SCLH3xTeEry428LvFhRzIA1g8izguxJ/gbNcVQ==", "dev": true, "engines": { "node": ">= 0.8.0" } }, "node_modules/expect": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/expect/-/expect-29.7.0.tgz", - "integrity": "sha512-2Zks0hf1VLFYI1kbh0I5jP3KHHyCHpkfyHBzsSXRFgl/Bg9mWYfMW8oD+PdMPlEwy5HNsR9JutYy6pMeOh61nw==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/expect/-/expect-30.2.0.tgz", + "integrity": "sha512-u/feCi0GPsI+988gU2FLcsHyAHTU0MX1Wg68NhAnN7z/+C5wqG+CY8J53N9ioe8RXgaoz0nBR/TYMf3AycUuPw==", "dev": true, "dependencies": { - "@jest/expect-utils": "^29.7.0", - "jest-get-type": "^29.6.3", - "jest-matcher-utils": "^29.7.0", - "jest-message-util": "^29.7.0", - "jest-util": "^29.7.0" + "@jest/expect-utils": "30.2.0", + "@jest/get-type": "30.1.0", + "jest-matcher-utils": "30.2.0", + "jest-message-util": "30.2.0", + "jest-mock": "30.2.0", + "jest-util": "30.2.0" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/express": { @@ -3723,6 +3807,22 @@ } } }, + "node_modules/foreground-child": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/foreground-child/-/foreground-child-3.3.1.tgz", + "integrity": "sha512-gIXjKqtFuWEgzFRJA9WCQeSJLZDjgJUOMCMzxtvFq/37KojM1BFGufqsCy0r4qSQmYLsZYMeyRqzIWOMup03sw==", + "dev": true, + "dependencies": { + "cross-spawn": "^7.0.6", + "signal-exit": "^4.0.1" + }, + "engines": { + "node": ">=14" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, "node_modules/form-data": { "version": "4.0.4", "resolved": "https://registry.npmjs.org/form-data/-/form-data-4.0.4.tgz", @@ -3879,20 +3979,20 @@ "integrity": "sha512-EqDVkN0/5MQyDPOSDLInVRRXdeISRfcN1UW/1FUqD2knV1HHw8DndMB3UPNn5lO51DvRnjzbLXwWqNNV86PLOw==" }, "node_modules/glob": { - "version": "7.2.3", - "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", - "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", + "version": "10.4.5", + "resolved": "https://registry.npmjs.org/glob/-/glob-10.4.5.tgz", + "integrity": "sha512-7Bv8RF0k6xjo7d4A/PxYLbUCfb6c+Vpd2/mB2yRDlew7Jb5hEXiCD9ibfO7wpk8i4sevK6DFny9h7EYbM3/sHg==", "dev": true, "dependencies": { - "fs.realpath": "^1.0.0", - "inflight": "^1.0.4", - "inherits": "2", - "minimatch": "^3.1.1", - "once": "^1.3.0", - "path-is-absolute": "^1.0.0" + "foreground-child": "^3.1.0", + "jackspeak": "^3.1.2", + "minimatch": "^9.0.4", + "minipass": "^7.1.2", + "package-json-from-dist": "^1.0.0", + "path-scurry": "^1.11.1" }, - "engines": { - "node": "*" + "bin": { + "glob": "dist/esm/bin.mjs" }, "funding": { "url": "https://github.com/sponsors/isaacs" @@ -3910,6 +4010,30 @@ "node": ">=10.13.0" } }, + "node_modules/glob/node_modules/brace-expansion": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.2.tgz", + "integrity": "sha512-Jt0vHyM+jmUBqojB7E1NIYadt0vI0Qxjxd2TErW94wDz+E2LAm5vKMXXwg6ZZBTHPuUlDgQHKXvjGBdfcF1ZDQ==", + "dev": true, + "dependencies": { + "balanced-match": "^1.0.0" + } + }, + "node_modules/glob/node_modules/minimatch": { + "version": "9.0.5", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.5.tgz", + "integrity": "sha512-G6T0ZX48xgozx7587koeX9Ys2NYy6Gmv//P89sEte9V9whIapMNF4idKxnW2QtCcLiTWlb/wfCabAtAFWhhBow==", + "dev": true, + "dependencies": { + "brace-expansion": "^2.0.1" + }, + "engines": { + "node": ">=16 || 14 >=14.17" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, "node_modules/globals": { "version": "16.4.0", "resolved": "https://registry.npmjs.org/globals/-/globals-16.4.0.tgz", @@ -3939,18 +4063,6 @@ "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==", "dev": true }, - "node_modules/has": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", - "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", - "dev": true, - "dependencies": { - "function-bind": "^1.1.1" - }, - "engines": { - "node": ">= 0.4.0" - } - }, "node_modules/has-flag": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", @@ -4163,9 +4275,9 @@ } }, "node_modules/import-local": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/import-local/-/import-local-3.1.0.tgz", - "integrity": "sha512-ASB07uLtnDs1o6EHjKpX34BKYDSqnFerfTOJL2HvMqF70LnxpjkzDB8J44oT9pu4AMPkQwf8jl6szgvNd2tRIg==", + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/import-local/-/import-local-3.2.0.tgz", + "integrity": "sha512-2SPlun1JUPWoM6t3F0dw0FkCF/jWY8kttcY4f599GLTSjh2OCuuhdTkJQsEcZzBqbXZGKMK2OqW1oZsjtf/gQA==", "dev": true, "dependencies": { "pkg-dir": "^4.2.0", @@ -4203,6 +4315,7 @@ "version": "1.0.6", "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", + "deprecated": "This module is not supported, and leaks memory. Do not use it. Check out lru-cache if you want a good and tested way to coalesce async requests by a key value, which is much more comprehensive and powerful.", "dev": true, "dependencies": { "once": "^1.3.0", @@ -4254,18 +4367,6 @@ "node": ">=4" } }, - "node_modules/is-core-module": { - "version": "2.13.0", - "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.13.0.tgz", - "integrity": "sha512-Z7dk6Qo8pOCp3l4tsX2C5ZVas4V+UxwQodwZhLopL91TX8UyyHEXafPcyoeeWuLrwzHcr3igO78wNLwHJHsMCQ==", - "dev": true, - "dependencies": { - "has": "^1.0.3" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, "node_modules/is-extglob": { "version": "2.1.1", "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", @@ -4346,28 +4447,40 @@ "dev": true }, "node_modules/istanbul-lib-coverage": { - "version": "3.2.0", - "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.0.tgz", - "integrity": "sha512-eOeJ5BHCmHYvQK7xt9GkdHuzuCGS1Y6g9Gvnx3Ym33fz/HpLRYxiS0wHNr+m/MBC8B647Xt608vCDEvhl9c6Mw==", + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.2.tgz", + "integrity": "sha512-O8dpsF+r0WV/8MNRKfnmrtCWhuKjxrq2w+jpzBL5UZKTi2LeVWnWOmWRxFlesJONmc+wLAGvKQZEOanko0LFTg==", "dev": true, "engines": { "node": ">=8" } }, "node_modules/istanbul-lib-instrument": { - "version": "5.2.1", - "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-5.2.1.tgz", - "integrity": "sha512-pzqtp31nLv/XFOzXGuvhCb8qhjmTVo5vjVk19XE4CRlSWz0KoeJ3bw9XsA7nOp9YBf4qHjwBxkDzKcME/J29Yg==", + "version": "6.0.3", + "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-6.0.3.tgz", + "integrity": "sha512-Vtgk7L/R2JHyyGW07spoFlB8/lpjiOLTjMdms6AFMraYt3BaJauod/NGrfnVG/y4Ix1JEuMRPDPEj2ua+zz1/Q==", "dev": true, "dependencies": { - "@babel/core": "^7.12.3", - "@babel/parser": "^7.14.7", - "@istanbuljs/schema": "^0.1.2", + "@babel/core": "^7.23.9", + "@babel/parser": "^7.23.9", + "@istanbuljs/schema": "^0.1.3", "istanbul-lib-coverage": "^3.2.0", - "semver": "^6.3.0" + "semver": "^7.5.4" }, "engines": { - "node": ">=8" + "node": ">=10" + } + }, + "node_modules/istanbul-lib-instrument/node_modules/semver": { + "version": "7.7.3", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.7.3.tgz", + "integrity": "sha512-SdsKMrI9TdgjdweUSR9MweHA4EJ8YxHn8DFaDisvhVlUOe4BF1tLD7GAj0lIqWVl+dPb/rExr0Btby5loQm20Q==", + "dev": true, + "bin": { + "semver": "bin/semver.js" + }, + "engines": { + "node": ">=10" } }, "node_modules/istanbul-lib-report": { @@ -4385,23 +4498,23 @@ } }, "node_modules/istanbul-lib-source-maps": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/istanbul-lib-source-maps/-/istanbul-lib-source-maps-4.0.1.tgz", - "integrity": "sha512-n3s8EwkdFIJCG3BPKBYvskgXGoy88ARzvegkitk60NxRdwltLOTaH7CUiMRXvwYorl0Q712iEjcWB+fK/MrWVw==", + "version": "5.0.6", + "resolved": "https://registry.npmjs.org/istanbul-lib-source-maps/-/istanbul-lib-source-maps-5.0.6.tgz", + "integrity": "sha512-yg2d+Em4KizZC5niWhQaIomgf5WlL4vOOjZ5xGCmF8SnPE/mDWWXgvRExdcpCgh9lLRRa1/fSYp2ymmbJ1pI+A==", "dev": true, "dependencies": { + "@jridgewell/trace-mapping": "^0.3.23", "debug": "^4.1.1", - "istanbul-lib-coverage": "^3.0.0", - "source-map": "^0.6.1" + "istanbul-lib-coverage": "^3.0.0" }, "engines": { "node": ">=10" } }, "node_modules/istanbul-reports": { - "version": "3.1.6", - "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.1.6.tgz", - "integrity": "sha512-TLgnMkKg3iTDsQ9PbPTdpfAK2DzjF9mqUG7RMgcQl8oFjad8ob4laGxv5XV5U9MAfx8D6tSJiUyuAwzLicaxlg==", + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.2.0.tgz", + "integrity": "sha512-HGYWWS/ehqTV3xN10i23tkPkpH46MLCIMFNCaaKNavAXTF1RkqxawEPtnjnGZ6XKSInBKkiOA5BKS+aZiY3AvA==", "dev": true, "dependencies": { "html-escaper": "^2.0.0", @@ -4411,22 +4524,37 @@ "node": ">=8" } }, + "node_modules/jackspeak": { + "version": "3.4.3", + "resolved": "https://registry.npmjs.org/jackspeak/-/jackspeak-3.4.3.tgz", + "integrity": "sha512-OGlZQpz2yfahA/Rd1Y8Cd9SIEsqvXkLVoSw/cgwhnhFMDbsQFeZYoJJ7bIZBS9BcamUW96asq/npPWugM+RQBw==", + "dev": true, + "dependencies": { + "@isaacs/cliui": "^8.0.2" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + }, + "optionalDependencies": { + "@pkgjs/parseargs": "^0.11.0" + } + }, "node_modules/jest": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest/-/jest-29.7.0.tgz", - "integrity": "sha512-NIy3oAFp9shda19hy4HK0HRTWKtPJmGdnvywu01nOqNC2vZg+Z+fvJDxpMQA88eb2I9EcafcdjYgsDthnYTvGw==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest/-/jest-30.2.0.tgz", + "integrity": "sha512-F26gjC0yWN8uAA5m5Ss8ZQf5nDHWGlN/xWZIh8S5SRbsEKBovwZhxGd6LJlbZYxBgCYOtreSUyb8hpXyGC5O4A==", "dev": true, "dependencies": { - "@jest/core": "^29.7.0", - "@jest/types": "^29.6.3", - "import-local": "^3.0.2", - "jest-cli": "^29.7.0" + "@jest/core": "30.2.0", + "@jest/types": "30.2.0", + "import-local": "^3.2.0", + "jest-cli": "30.2.0" }, "bin": { "jest": "bin/jest.js" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" }, "peerDependencies": { "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" @@ -4438,48 +4566,48 @@ } }, "node_modules/jest-changed-files": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-changed-files/-/jest-changed-files-29.7.0.tgz", - "integrity": "sha512-fEArFiwf1BpQ+4bXSprcDc3/x4HSzL4al2tozwVpDFpsxALjLYdyiIK4e5Vz66GQJIbXJ82+35PtysofptNX2w==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-changed-files/-/jest-changed-files-30.2.0.tgz", + "integrity": "sha512-L8lR1ChrRnSdfeOvTrwZMlnWV8G/LLjQ0nG9MBclwWZidA2N5FviRki0Bvh20WRMOX31/JYvzdqTJrk5oBdydQ==", "dev": true, "dependencies": { - "execa": "^5.0.0", - "jest-util": "^29.7.0", + "execa": "^5.1.1", + "jest-util": "30.2.0", "p-limit": "^3.1.0" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/jest-circus": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-circus/-/jest-circus-29.7.0.tgz", - "integrity": "sha512-3E1nCMgipcTkCocFwM90XXQab9bS+GMsjdpmPrlelaxwD93Ad8iVEjX/vvHPdLPnFf+L40u+5+iutRdA1N9myw==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-circus/-/jest-circus-30.2.0.tgz", + "integrity": "sha512-Fh0096NC3ZkFx05EP2OXCxJAREVxj1BcW/i6EWqqymcgYKWjyyDpral3fMxVcHXg6oZM7iULer9wGRFvfpl+Tg==", "dev": true, "dependencies": { - "@jest/environment": "^29.7.0", - "@jest/expect": "^29.7.0", - "@jest/test-result": "^29.7.0", - "@jest/types": "^29.6.3", + "@jest/environment": "30.2.0", + "@jest/expect": "30.2.0", + "@jest/test-result": "30.2.0", + "@jest/types": "30.2.0", "@types/node": "*", - "chalk": "^4.0.0", + "chalk": "^4.1.2", "co": "^4.6.0", - "dedent": "^1.0.0", - "is-generator-fn": "^2.0.0", - "jest-each": "^29.7.0", - "jest-matcher-utils": "^29.7.0", - "jest-message-util": "^29.7.0", - "jest-runtime": "^29.7.0", - "jest-snapshot": "^29.7.0", - "jest-util": "^29.7.0", + "dedent": "^1.6.0", + "is-generator-fn": "^2.1.0", + "jest-each": "30.2.0", + "jest-matcher-utils": "30.2.0", + "jest-message-util": "30.2.0", + "jest-runtime": "30.2.0", + "jest-snapshot": "30.2.0", + "jest-util": "30.2.0", "p-limit": "^3.1.0", - "pretty-format": "^29.7.0", - "pure-rand": "^6.0.0", + "pretty-format": "30.2.0", + "pure-rand": "^7.0.0", "slash": "^3.0.0", - "stack-utils": "^2.0.3" + "stack-utils": "^2.0.6" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/jest-circus/node_modules/ansi-styles": { @@ -4495,48 +4623,47 @@ } }, "node_modules/jest-circus/node_modules/pretty-format": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-29.7.0.tgz", - "integrity": "sha512-Pdlw/oPxN+aXdmM9R00JVC9WVFoCLTKJvDVLgmJ+qAffBMxsV85l/Lu7sNx4zSzPyoL2euImuEwHhOXdEgNFZQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.2.0.tgz", + "integrity": "sha512-9uBdv/B4EefsuAL+pWqueZyZS2Ba+LxfFeQ9DN14HU4bN8bhaxKdkpjpB6fs9+pSjIBu+FXQHImEg8j/Lw0+vA==", "dev": true, "dependencies": { - "@jest/schemas": "^29.6.3", - "ansi-styles": "^5.0.0", - "react-is": "^18.0.0" + "@jest/schemas": "30.0.5", + "ansi-styles": "^5.2.0", + "react-is": "^18.3.1" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/jest-circus/node_modules/react-is": { - "version": "18.2.0", - "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz", - "integrity": "sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w==", + "version": "18.3.1", + "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.3.1.tgz", + "integrity": "sha512-/LLMVyas0ljjAtoYiPqYiL8VWXzUUdThrmU5+n20DZv+a+ClRoevUzw5JxU+Ieh5/c87ytoTBV9G1FiKfNJdmg==", "dev": true }, "node_modules/jest-cli": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-cli/-/jest-cli-29.7.0.tgz", - "integrity": "sha512-OVVobw2IubN/GSYsxETi+gOe7Ka59EFMR/twOU3Jb2GnKKeMGJB5SGUUrEz3SFVmJASUdZUzy83sLNNQ2gZslg==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-cli/-/jest-cli-30.2.0.tgz", + "integrity": "sha512-Os9ukIvADX/A9sLt6Zse3+nmHtHaE6hqOsjQtNiugFTbKRHYIYtZXNGNK9NChseXy7djFPjndX1tL0sCTlfpAA==", "dev": true, "dependencies": { - "@jest/core": "^29.7.0", - "@jest/test-result": "^29.7.0", - "@jest/types": "^29.6.3", - "chalk": "^4.0.0", - "create-jest": "^29.7.0", - "exit": "^0.1.2", - "import-local": "^3.0.2", - "jest-config": "^29.7.0", - "jest-util": "^29.7.0", - "jest-validate": "^29.7.0", - "yargs": "^17.3.1" + "@jest/core": "30.2.0", + "@jest/test-result": "30.2.0", + "@jest/types": "30.2.0", + "chalk": "^4.1.2", + "exit-x": "^0.2.2", + "import-local": "^3.2.0", + "jest-config": "30.2.0", + "jest-util": "30.2.0", + "jest-validate": "30.2.0", + "yargs": "^17.7.2" }, "bin": { "jest": "bin/jest.js" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" }, "peerDependencies": { "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" @@ -4548,45 +4675,51 @@ } }, "node_modules/jest-config": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-config/-/jest-config-29.7.0.tgz", - "integrity": "sha512-uXbpfeQ7R6TZBqI3/TxCU4q4ttk3u0PJeC+E0zbfSoSjq6bJ7buBPxzQPL0ifrkY4DNu4JUdk0ImlBUYi840eQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-config/-/jest-config-30.2.0.tgz", + "integrity": "sha512-g4WkyzFQVWHtu6uqGmQR4CQxz/CH3yDSlhzXMWzNjDx843gYjReZnMRanjRCq5XZFuQrGDxgUaiYWE8BRfVckA==", "dev": true, "dependencies": { - "@babel/core": "^7.11.6", - "@jest/test-sequencer": "^29.7.0", - "@jest/types": "^29.6.3", - "babel-jest": "^29.7.0", - "chalk": "^4.0.0", - "ci-info": "^3.2.0", - "deepmerge": "^4.2.2", - "glob": "^7.1.3", - "graceful-fs": "^4.2.9", - "jest-circus": "^29.7.0", - "jest-environment-node": "^29.7.0", - "jest-get-type": "^29.6.3", - "jest-regex-util": "^29.6.3", - "jest-resolve": "^29.7.0", - "jest-runner": "^29.7.0", - "jest-util": "^29.7.0", - "jest-validate": "^29.7.0", - "micromatch": "^4.0.4", + "@babel/core": "^7.27.4", + "@jest/get-type": "30.1.0", + "@jest/pattern": "30.0.1", + "@jest/test-sequencer": "30.2.0", + "@jest/types": "30.2.0", + "babel-jest": "30.2.0", + "chalk": "^4.1.2", + "ci-info": "^4.2.0", + "deepmerge": "^4.3.1", + "glob": "^10.3.10", + "graceful-fs": "^4.2.11", + "jest-circus": "30.2.0", + "jest-docblock": "30.2.0", + "jest-environment-node": "30.2.0", + "jest-regex-util": "30.0.1", + "jest-resolve": "30.2.0", + "jest-runner": "30.2.0", + "jest-util": "30.2.0", + "jest-validate": "30.2.0", + "micromatch": "^4.0.8", "parse-json": "^5.2.0", - "pretty-format": "^29.7.0", + "pretty-format": "30.2.0", "slash": "^3.0.0", "strip-json-comments": "^3.1.1" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" }, "peerDependencies": { "@types/node": "*", + "esbuild-register": ">=3.4.0", "ts-node": ">=9.0.0" }, "peerDependenciesMeta": { "@types/node": { "optional": true }, + "esbuild-register": { + "optional": true + }, "ts-node": { "optional": true } @@ -4605,38 +4738,38 @@ } }, "node_modules/jest-config/node_modules/pretty-format": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-29.7.0.tgz", - "integrity": "sha512-Pdlw/oPxN+aXdmM9R00JVC9WVFoCLTKJvDVLgmJ+qAffBMxsV85l/Lu7sNx4zSzPyoL2euImuEwHhOXdEgNFZQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.2.0.tgz", + "integrity": "sha512-9uBdv/B4EefsuAL+pWqueZyZS2Ba+LxfFeQ9DN14HU4bN8bhaxKdkpjpB6fs9+pSjIBu+FXQHImEg8j/Lw0+vA==", "dev": true, "dependencies": { - "@jest/schemas": "^29.6.3", - "ansi-styles": "^5.0.0", - "react-is": "^18.0.0" + "@jest/schemas": "30.0.5", + "ansi-styles": "^5.2.0", + "react-is": "^18.3.1" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/jest-config/node_modules/react-is": { - "version": "18.2.0", - "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz", - "integrity": "sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w==", + "version": "18.3.1", + "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.3.1.tgz", + "integrity": "sha512-/LLMVyas0ljjAtoYiPqYiL8VWXzUUdThrmU5+n20DZv+a+ClRoevUzw5JxU+Ieh5/c87ytoTBV9G1FiKfNJdmg==", "dev": true }, "node_modules/jest-diff": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-diff/-/jest-diff-29.7.0.tgz", - "integrity": "sha512-LMIgiIrhigmPrs03JHpxUh2yISK3vLFPkAodPeo0+BuF7wA2FoQbkEg1u8gBYBThncu7e1oEDUfIXVuTqLRUjw==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-diff/-/jest-diff-30.2.0.tgz", + "integrity": "sha512-dQHFo3Pt4/NLlG5z4PxZ/3yZTZ1C7s9hveiOj+GCN+uT109NC2QgsoVZsVOAvbJ3RgKkvyLGXZV9+piDpWbm6A==", "dev": true, "dependencies": { - "chalk": "^4.0.0", - "diff-sequences": "^29.6.3", - "jest-get-type": "^29.6.3", - "pretty-format": "^29.7.0" + "@jest/diff-sequences": "30.0.1", + "@jest/get-type": "30.1.0", + "chalk": "^4.1.2", + "pretty-format": "30.2.0" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/jest-diff/node_modules/ansi-styles": { @@ -4652,51 +4785,51 @@ } }, "node_modules/jest-diff/node_modules/pretty-format": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-29.7.0.tgz", - "integrity": "sha512-Pdlw/oPxN+aXdmM9R00JVC9WVFoCLTKJvDVLgmJ+qAffBMxsV85l/Lu7sNx4zSzPyoL2euImuEwHhOXdEgNFZQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.2.0.tgz", + "integrity": "sha512-9uBdv/B4EefsuAL+pWqueZyZS2Ba+LxfFeQ9DN14HU4bN8bhaxKdkpjpB6fs9+pSjIBu+FXQHImEg8j/Lw0+vA==", "dev": true, "dependencies": { - "@jest/schemas": "^29.6.3", - "ansi-styles": "^5.0.0", - "react-is": "^18.0.0" + "@jest/schemas": "30.0.5", + "ansi-styles": "^5.2.0", + "react-is": "^18.3.1" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/jest-diff/node_modules/react-is": { - "version": "18.2.0", - "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz", - "integrity": "sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w==", + "version": "18.3.1", + "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.3.1.tgz", + "integrity": "sha512-/LLMVyas0ljjAtoYiPqYiL8VWXzUUdThrmU5+n20DZv+a+ClRoevUzw5JxU+Ieh5/c87ytoTBV9G1FiKfNJdmg==", "dev": true }, "node_modules/jest-docblock": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-docblock/-/jest-docblock-29.7.0.tgz", - "integrity": "sha512-q617Auw3A612guyaFgsbFeYpNP5t2aoUNLwBUbc/0kD1R4t9ixDbyFTHd1nok4epoVFpr7PmeWHrhvuV3XaJ4g==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-docblock/-/jest-docblock-30.2.0.tgz", + "integrity": "sha512-tR/FFgZKS1CXluOQzZvNH3+0z9jXr3ldGSD8bhyuxvlVUwbeLOGynkunvlTMxchC5urrKndYiwCFC0DLVjpOCA==", "dev": true, "dependencies": { - "detect-newline": "^3.0.0" + "detect-newline": "^3.1.0" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/jest-each": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-each/-/jest-each-29.7.0.tgz", - "integrity": "sha512-gns+Er14+ZrEoC5fhOfYCY1LOHHr0TI+rQUHZS8Ttw2l7gl+80eHc/gFf2Ktkw0+SIACDTeWvpFcv3B04VembQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-each/-/jest-each-30.2.0.tgz", + "integrity": "sha512-lpWlJlM7bCUf1mfmuqTA8+j2lNURW9eNafOy99knBM01i5CQeY5UH1vZjgT9071nDJac1M4XsbyI44oNOdhlDQ==", "dev": true, "dependencies": { - "@jest/types": "^29.6.3", - "chalk": "^4.0.0", - "jest-get-type": "^29.6.3", - "jest-util": "^29.7.0", - "pretty-format": "^29.7.0" + "@jest/get-type": "30.1.0", + "@jest/types": "30.2.0", + "chalk": "^4.1.2", + "jest-util": "30.2.0", + "pretty-format": "30.2.0" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/jest-each/node_modules/ansi-styles": { @@ -4712,23 +4845,23 @@ } }, "node_modules/jest-each/node_modules/pretty-format": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-29.7.0.tgz", - "integrity": "sha512-Pdlw/oPxN+aXdmM9R00JVC9WVFoCLTKJvDVLgmJ+qAffBMxsV85l/Lu7sNx4zSzPyoL2euImuEwHhOXdEgNFZQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.2.0.tgz", + "integrity": "sha512-9uBdv/B4EefsuAL+pWqueZyZS2Ba+LxfFeQ9DN14HU4bN8bhaxKdkpjpB6fs9+pSjIBu+FXQHImEg8j/Lw0+vA==", "dev": true, "dependencies": { - "@jest/schemas": "^29.6.3", - "ansi-styles": "^5.0.0", - "react-is": "^18.0.0" + "@jest/schemas": "30.0.5", + "ansi-styles": "^5.2.0", + "react-is": "^18.3.1" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/jest-each/node_modules/react-is": { - "version": "18.2.0", - "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz", - "integrity": "sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w==", + "version": "18.3.1", + "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.3.1.tgz", + "integrity": "sha512-/LLMVyas0ljjAtoYiPqYiL8VWXzUUdThrmU5+n20DZv+a+ClRoevUzw5JxU+Ieh5/c87ytoTBV9G1FiKfNJdmg==", "dev": true }, "node_modules/jest-environment-jsdom": { @@ -4755,84 +4888,62 @@ } } }, - "node_modules/jest-environment-jsdom/node_modules/@jest/environment": { + "node_modules/jest-environment-node": { "version": "30.2.0", - "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-30.2.0.tgz", - "integrity": "sha512-/QPTL7OBJQ5ac09UDRa3EQes4gt1FTEG/8jZ/4v5IVzx+Cv7dLxlVIvfvSVRiiX2drWyXeBjkMSR8hvOWSog5g==", + "resolved": "https://registry.npmjs.org/jest-environment-node/-/jest-environment-node-30.2.0.tgz", + "integrity": "sha512-ElU8v92QJ9UrYsKrxDIKCxu6PfNj4Hdcktcn0JX12zqNdqWHB0N+hwOnnBBXvjLd2vApZtuLUGs1QSY+MsXoNA==", "dev": true, "dependencies": { + "@jest/environment": "30.2.0", "@jest/fake-timers": "30.2.0", "@jest/types": "30.2.0", "@types/node": "*", - "jest-mock": "30.2.0" + "jest-mock": "30.2.0", + "jest-util": "30.2.0", + "jest-validate": "30.2.0" }, "engines": { "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, - "node_modules/jest-environment-jsdom/node_modules/@jest/fake-timers": { + "node_modules/jest-haste-map": { "version": "30.2.0", - "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-30.2.0.tgz", - "integrity": "sha512-HI3tRLjRxAbBy0VO8dqqm7Hb2mIa8d5bg/NJkyQcOk7V118ObQML8RC5luTF/Zsg4474a+gDvhce7eTnP4GhYw==", + "resolved": "https://registry.npmjs.org/jest-haste-map/-/jest-haste-map-30.2.0.tgz", + "integrity": "sha512-sQA/jCb9kNt+neM0anSj6eZhLZUIhQgwDt7cPGjumgLM4rXsfb9kpnlacmvZz3Q5tb80nS+oG/if+NBKrHC+Xw==", "dev": true, "dependencies": { "@jest/types": "30.2.0", - "@sinonjs/fake-timers": "^13.0.0", "@types/node": "*", - "jest-message-util": "30.2.0", - "jest-mock": "30.2.0", - "jest-util": "30.2.0" + "anymatch": "^3.1.3", + "fb-watchman": "^2.0.2", + "graceful-fs": "^4.2.11", + "jest-regex-util": "30.0.1", + "jest-util": "30.2.0", + "jest-worker": "30.2.0", + "micromatch": "^4.0.8", + "walker": "^1.0.8" }, "engines": { "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" - } - }, - "node_modules/jest-environment-jsdom/node_modules/@jest/schemas": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/@jest/schemas/-/schemas-30.0.5.tgz", - "integrity": "sha512-DmdYgtezMkh3cpU8/1uyXakv3tJRcmcXxBOcO0tbaozPwpmh4YMsnWrQm9ZmZMfa5ocbxzbFk6O4bDPEc/iAnA==", - "dev": true, - "dependencies": { - "@sinclair/typebox": "^0.34.0" }, - "engines": { - "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" + "optionalDependencies": { + "fsevents": "^2.3.3" } }, - "node_modules/jest-environment-jsdom/node_modules/@jest/types": { + "node_modules/jest-leak-detector": { "version": "30.2.0", - "resolved": "https://registry.npmjs.org/@jest/types/-/types-30.2.0.tgz", - "integrity": "sha512-H9xg1/sfVvyfU7o3zMfBEjQ1gcsdeTMgqHoYdN79tuLqfTtuu7WckRA1R5whDwOzxaZAeMKTYWqP+WCAi0CHsg==", + "resolved": "https://registry.npmjs.org/jest-leak-detector/-/jest-leak-detector-30.2.0.tgz", + "integrity": "sha512-M6jKAjyzjHG0SrQgwhgZGy9hFazcudwCNovY/9HPIicmNSBuockPSedAP9vlPK6ONFJ1zfyH/M2/YYJxOz5cdQ==", "dev": true, "dependencies": { - "@jest/pattern": "30.0.1", - "@jest/schemas": "30.0.5", - "@types/istanbul-lib-coverage": "^2.0.6", - "@types/istanbul-reports": "^3.0.4", - "@types/node": "*", - "@types/yargs": "^17.0.33", - "chalk": "^4.1.2" + "@jest/get-type": "30.1.0", + "pretty-format": "30.2.0" }, "engines": { "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, - "node_modules/jest-environment-jsdom/node_modules/@sinclair/typebox": { - "version": "0.34.41", - "resolved": "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.34.41.tgz", - "integrity": "sha512-6gS8pZzSXdyRHTIqoqSVknxolr1kzfy4/CeDnrzsVz8TTIWUbOBr6gnzOmTYJ3eXQNh4IYHIGi5aIL7sOZ2G/g==", - "dev": true - }, - "node_modules/jest-environment-jsdom/node_modules/@sinonjs/fake-timers": { - "version": "13.0.5", - "resolved": "https://registry.npmjs.org/@sinonjs/fake-timers/-/fake-timers-13.0.5.tgz", - "integrity": "sha512-36/hTbH2uaWuGVERyC6da9YwGWnzUZXuPro/F2LfsdOsLnCojz/iSH8MxUt/FD2S5XBSVPhmArFUXcpCQ2Hkiw==", - "dev": true, - "dependencies": { - "@sinonjs/commons": "^3.0.1" - } - }, - "node_modules/jest-environment-jsdom/node_modules/ansi-styles": { + "node_modules/jest-leak-detector/node_modules/ansi-styles": { "version": "5.2.0", "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz", "integrity": "sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==", @@ -4844,88 +4955,10 @@ "url": "https://github.com/chalk/ansi-styles?sponsor=1" } }, - "node_modules/jest-environment-jsdom/node_modules/ci-info": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-4.3.0.tgz", - "integrity": "sha512-l+2bNRMiQgcfILUi33labAZYIWlH1kWDp+ecNo5iisRKrbm0xcRyCww71/YU0Fkw0mAFpz9bJayXPjey6vkmaQ==", - "dev": true, - "funding": [ - { - "type": "github", - "url": "https://github.com/sponsors/sibiraj-s" - } - ], - "engines": { - "node": ">=8" - } - }, - "node_modules/jest-environment-jsdom/node_modules/jest-message-util": { - "version": "30.2.0", - "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-30.2.0.tgz", - "integrity": "sha512-y4DKFLZ2y6DxTWD4cDe07RglV88ZiNEdlRfGtqahfbIjfsw1nMCPx49Uev4IA/hWn3sDKyAnSPwoYSsAEdcimw==", - "dev": true, - "dependencies": { - "@babel/code-frame": "^7.27.1", - "@jest/types": "30.2.0", - "@types/stack-utils": "^2.0.3", - "chalk": "^4.1.2", - "graceful-fs": "^4.2.11", - "micromatch": "^4.0.8", - "pretty-format": "30.2.0", - "slash": "^3.0.0", - "stack-utils": "^2.0.6" - }, - "engines": { - "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" - } - }, - "node_modules/jest-environment-jsdom/node_modules/jest-mock": { - "version": "30.2.0", - "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-30.2.0.tgz", - "integrity": "sha512-JNNNl2rj4b5ICpmAcq+WbLH83XswjPbjH4T7yvGzfAGCPh1rw+xVNbtk+FnRslvt9lkCcdn9i1oAoKUuFsOxRw==", - "dev": true, - "dependencies": { - "@jest/types": "30.2.0", - "@types/node": "*", - "jest-util": "30.2.0" - }, - "engines": { - "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" - } - }, - "node_modules/jest-environment-jsdom/node_modules/jest-util": { - "version": "30.2.0", - "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-30.2.0.tgz", - "integrity": "sha512-QKNsM0o3Xe6ISQU869e+DhG+4CK/48aHYdJZGlFQVTjnbvgpcKyxpzk29fGiO7i/J8VENZ+d2iGnSsvmuHywlA==", - "dev": true, - "dependencies": { - "@jest/types": "30.2.0", - "@types/node": "*", - "chalk": "^4.1.2", - "ci-info": "^4.2.0", - "graceful-fs": "^4.2.11", - "picomatch": "^4.0.2" - }, - "engines": { - "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" - } - }, - "node_modules/jest-environment-jsdom/node_modules/picomatch": { - "version": "4.0.3", - "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-4.0.3.tgz", - "integrity": "sha512-5gTmgEY/sqK6gFXLIsQNH19lWb4ebPDLA4SdLP7dsWkIXHWlG66oPuVvXSGFPppYZz8ZDZq0dYYrbHfBCVUb1Q==", - "dev": true, - "engines": { - "node": ">=12" - }, - "funding": { - "url": "https://github.com/sponsors/jonschlinkert" - } - }, - "node_modules/jest-environment-jsdom/node_modules/pretty-format": { - "version": "30.2.0", - "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.2.0.tgz", - "integrity": "sha512-9uBdv/B4EefsuAL+pWqueZyZS2Ba+LxfFeQ9DN14HU4bN8bhaxKdkpjpB6fs9+pSjIBu+FXQHImEg8j/Lw0+vA==", + "node_modules/jest-leak-detector/node_modules/pretty-format": { + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.2.0.tgz", + "integrity": "sha512-9uBdv/B4EefsuAL+pWqueZyZS2Ba+LxfFeQ9DN14HU4bN8bhaxKdkpjpB6fs9+pSjIBu+FXQHImEg8j/Lw0+vA==", "dev": true, "dependencies": { "@jest/schemas": "30.0.5", @@ -4936,121 +4969,25 @@ "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, - "node_modules/jest-environment-jsdom/node_modules/react-is": { + "node_modules/jest-leak-detector/node_modules/react-is": { "version": "18.3.1", "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.3.1.tgz", "integrity": "sha512-/LLMVyas0ljjAtoYiPqYiL8VWXzUUdThrmU5+n20DZv+a+ClRoevUzw5JxU+Ieh5/c87ytoTBV9G1FiKfNJdmg==", "dev": true }, - "node_modules/jest-environment-node": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-environment-node/-/jest-environment-node-29.7.0.tgz", - "integrity": "sha512-DOSwCRqXirTOyheM+4d5YZOrWcdu0LNZ87ewUoywbcb2XR4wKgqiG8vNeYwhjFMbEkfju7wx2GYH0P2gevGvFw==", - "dev": true, - "dependencies": { - "@jest/environment": "^29.7.0", - "@jest/fake-timers": "^29.7.0", - "@jest/types": "^29.6.3", - "@types/node": "*", - "jest-mock": "^29.7.0", - "jest-util": "^29.7.0" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/jest-get-type": { - "version": "29.6.3", - "resolved": "https://registry.npmjs.org/jest-get-type/-/jest-get-type-29.6.3.tgz", - "integrity": "sha512-zrteXnqYxfQh7l5FHyL38jL39di8H8rHoecLH3JNxH3BwOrBsNeabdap5e0I23lD4HHI8W5VFBZqG4Eaq5LNcw==", - "dev": true, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/jest-haste-map": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-haste-map/-/jest-haste-map-29.7.0.tgz", - "integrity": "sha512-fP8u2pyfqx0K1rGn1R9pyE0/KTn+G7PxktWidOBTqFPLYX0b9ksaMFkhK5vrS3DVun09pckLdlx90QthlW7AmA==", - "dev": true, - "dependencies": { - "@jest/types": "^29.6.3", - "@types/graceful-fs": "^4.1.3", - "@types/node": "*", - "anymatch": "^3.0.3", - "fb-watchman": "^2.0.0", - "graceful-fs": "^4.2.9", - "jest-regex-util": "^29.6.3", - "jest-util": "^29.7.0", - "jest-worker": "^29.7.0", - "micromatch": "^4.0.4", - "walker": "^1.0.8" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - }, - "optionalDependencies": { - "fsevents": "^2.3.2" - } - }, - "node_modules/jest-leak-detector": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-leak-detector/-/jest-leak-detector-29.7.0.tgz", - "integrity": "sha512-kYA8IJcSYtST2BY9I+SMC32nDpBT3J2NvWJx8+JCuCdl/CR1I4EKUJROiP8XtCcxqgTTBGJNdbB1A8XRKbTetw==", - "dev": true, - "dependencies": { - "jest-get-type": "^29.6.3", - "pretty-format": "^29.7.0" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/jest-leak-detector/node_modules/ansi-styles": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz", - "integrity": "sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/jest-leak-detector/node_modules/pretty-format": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-29.7.0.tgz", - "integrity": "sha512-Pdlw/oPxN+aXdmM9R00JVC9WVFoCLTKJvDVLgmJ+qAffBMxsV85l/Lu7sNx4zSzPyoL2euImuEwHhOXdEgNFZQ==", - "dev": true, - "dependencies": { - "@jest/schemas": "^29.6.3", - "ansi-styles": "^5.0.0", - "react-is": "^18.0.0" - }, - "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - } - }, - "node_modules/jest-leak-detector/node_modules/react-is": { - "version": "18.2.0", - "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz", - "integrity": "sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w==", - "dev": true - }, "node_modules/jest-matcher-utils": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-matcher-utils/-/jest-matcher-utils-29.7.0.tgz", - "integrity": "sha512-sBkD+Xi9DtcChsI3L3u0+N0opgPYnCRPtGcQYrgXmR+hmt/fYfWAL0xRXYU8eWOdfuLgBe0YCW3AFtnRLagq/g==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-matcher-utils/-/jest-matcher-utils-30.2.0.tgz", + "integrity": "sha512-dQ94Nq4dbzmUWkQ0ANAWS9tBRfqCrn0bV9AMYdOi/MHW726xn7eQmMeRTpX2ViC00bpNaWXq+7o4lIQ3AX13Hg==", "dev": true, "dependencies": { - "chalk": "^4.0.0", - "jest-diff": "^29.7.0", - "jest-get-type": "^29.6.3", - "pretty-format": "^29.7.0" + "@jest/get-type": "30.1.0", + "chalk": "^4.1.2", + "jest-diff": "30.2.0", + "pretty-format": "30.2.0" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/jest-matcher-utils/node_modules/ansi-styles": { @@ -5066,43 +5003,43 @@ } }, "node_modules/jest-matcher-utils/node_modules/pretty-format": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-29.7.0.tgz", - "integrity": "sha512-Pdlw/oPxN+aXdmM9R00JVC9WVFoCLTKJvDVLgmJ+qAffBMxsV85l/Lu7sNx4zSzPyoL2euImuEwHhOXdEgNFZQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.2.0.tgz", + "integrity": "sha512-9uBdv/B4EefsuAL+pWqueZyZS2Ba+LxfFeQ9DN14HU4bN8bhaxKdkpjpB6fs9+pSjIBu+FXQHImEg8j/Lw0+vA==", "dev": true, "dependencies": { - "@jest/schemas": "^29.6.3", - "ansi-styles": "^5.0.0", - "react-is": "^18.0.0" + "@jest/schemas": "30.0.5", + "ansi-styles": "^5.2.0", + "react-is": "^18.3.1" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/jest-matcher-utils/node_modules/react-is": { - "version": "18.2.0", - "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz", - "integrity": "sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w==", + "version": "18.3.1", + "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.3.1.tgz", + "integrity": "sha512-/LLMVyas0ljjAtoYiPqYiL8VWXzUUdThrmU5+n20DZv+a+ClRoevUzw5JxU+Ieh5/c87ytoTBV9G1FiKfNJdmg==", "dev": true }, "node_modules/jest-message-util": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-29.7.0.tgz", - "integrity": "sha512-GBEV4GRADeP+qtB2+6u61stea8mGcOT4mCtrYISZwfu9/ISHFJ/5zOMXYbpBE9RsS5+Gb63DW4FgmnKJ79Kf6w==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-30.2.0.tgz", + "integrity": "sha512-y4DKFLZ2y6DxTWD4cDe07RglV88ZiNEdlRfGtqahfbIjfsw1nMCPx49Uev4IA/hWn3sDKyAnSPwoYSsAEdcimw==", "dev": true, "dependencies": { - "@babel/code-frame": "^7.12.13", - "@jest/types": "^29.6.3", - "@types/stack-utils": "^2.0.0", - "chalk": "^4.0.0", - "graceful-fs": "^4.2.9", - "micromatch": "^4.0.4", - "pretty-format": "^29.7.0", + "@babel/code-frame": "^7.27.1", + "@jest/types": "30.2.0", + "@types/stack-utils": "^2.0.3", + "chalk": "^4.1.2", + "graceful-fs": "^4.2.11", + "micromatch": "^4.0.8", + "pretty-format": "30.2.0", "slash": "^3.0.0", - "stack-utils": "^2.0.3" + "stack-utils": "^2.0.6" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/jest-message-util/node_modules/ansi-styles": { @@ -5118,37 +5055,37 @@ } }, "node_modules/jest-message-util/node_modules/pretty-format": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-29.7.0.tgz", - "integrity": "sha512-Pdlw/oPxN+aXdmM9R00JVC9WVFoCLTKJvDVLgmJ+qAffBMxsV85l/Lu7sNx4zSzPyoL2euImuEwHhOXdEgNFZQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.2.0.tgz", + "integrity": "sha512-9uBdv/B4EefsuAL+pWqueZyZS2Ba+LxfFeQ9DN14HU4bN8bhaxKdkpjpB6fs9+pSjIBu+FXQHImEg8j/Lw0+vA==", "dev": true, "dependencies": { - "@jest/schemas": "^29.6.3", - "ansi-styles": "^5.0.0", - "react-is": "^18.0.0" + "@jest/schemas": "30.0.5", + "ansi-styles": "^5.2.0", + "react-is": "^18.3.1" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/jest-message-util/node_modules/react-is": { - "version": "18.2.0", - "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz", - "integrity": "sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w==", + "version": "18.3.1", + "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.3.1.tgz", + "integrity": "sha512-/LLMVyas0ljjAtoYiPqYiL8VWXzUUdThrmU5+n20DZv+a+ClRoevUzw5JxU+Ieh5/c87ytoTBV9G1FiKfNJdmg==", "dev": true }, "node_modules/jest-mock": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-29.7.0.tgz", - "integrity": "sha512-ITOMZn+UkYS4ZFh83xYAOzWStloNzJFO2s8DWrE4lhtGD+AorgnbkiKERe4wQVBydIGPx059g6riW5Btp6Llnw==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-30.2.0.tgz", + "integrity": "sha512-JNNNl2rj4b5ICpmAcq+WbLH83XswjPbjH4T7yvGzfAGCPh1rw+xVNbtk+FnRslvt9lkCcdn9i1oAoKUuFsOxRw==", "dev": true, "dependencies": { - "@jest/types": "^29.6.3", + "@jest/types": "30.2.0", "@types/node": "*", - "jest-util": "^29.7.0" + "jest-util": "30.2.0" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/jest-pnp-resolver": { @@ -5169,141 +5106,142 @@ } }, "node_modules/jest-regex-util": { - "version": "29.6.3", - "resolved": "https://registry.npmjs.org/jest-regex-util/-/jest-regex-util-29.6.3.tgz", - "integrity": "sha512-KJJBsRCyyLNWCNBOvZyRDnAIfUiRJ8v+hOBQYGn8gDyF3UegwiP4gwRR3/SDa42g1YbVycTidUF3rKjyLFDWbg==", + "version": "30.0.1", + "resolved": "https://registry.npmjs.org/jest-regex-util/-/jest-regex-util-30.0.1.tgz", + "integrity": "sha512-jHEQgBXAgc+Gh4g0p3bCevgRCVRkB4VB70zhoAE48gxeSr1hfUOsM/C2WoJgVL7Eyg//hudYENbm3Ne+/dRVVA==", "dev": true, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/jest-resolve": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-resolve/-/jest-resolve-29.7.0.tgz", - "integrity": "sha512-IOVhZSrg+UvVAshDSDtHyFCCBUl/Q3AAJv8iZ6ZjnZ74xzvwuzLXid9IIIPgTnY62SJjfuupMKZsZQRsCvxEgA==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-resolve/-/jest-resolve-30.2.0.tgz", + "integrity": "sha512-TCrHSxPlx3tBY3hWNtRQKbtgLhsXa1WmbJEqBlTBrGafd5fiQFByy2GNCEoGR+Tns8d15GaL9cxEzKOO3GEb2A==", "dev": true, "dependencies": { - "chalk": "^4.0.0", - "graceful-fs": "^4.2.9", - "jest-haste-map": "^29.7.0", - "jest-pnp-resolver": "^1.2.2", - "jest-util": "^29.7.0", - "jest-validate": "^29.7.0", - "resolve": "^1.20.0", - "resolve.exports": "^2.0.0", - "slash": "^3.0.0" + "chalk": "^4.1.2", + "graceful-fs": "^4.2.11", + "jest-haste-map": "30.2.0", + "jest-pnp-resolver": "^1.2.3", + "jest-util": "30.2.0", + "jest-validate": "30.2.0", + "slash": "^3.0.0", + "unrs-resolver": "^1.7.11" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/jest-resolve-dependencies": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-resolve-dependencies/-/jest-resolve-dependencies-29.7.0.tgz", - "integrity": "sha512-un0zD/6qxJ+S0et7WxeI3H5XSe9lTBBR7bOHCHXkKR6luG5mwDDlIzVQ0V5cZCuoTgEdcdwzTghYkTWfubi+nA==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-resolve-dependencies/-/jest-resolve-dependencies-30.2.0.tgz", + "integrity": "sha512-xTOIGug/0RmIe3mmCqCT95yO0vj6JURrn1TKWlNbhiAefJRWINNPgwVkrVgt/YaerPzY3iItufd80v3lOrFJ2w==", "dev": true, "dependencies": { - "jest-regex-util": "^29.6.3", - "jest-snapshot": "^29.7.0" + "jest-regex-util": "30.0.1", + "jest-snapshot": "30.2.0" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/jest-runner": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-runner/-/jest-runner-29.7.0.tgz", - "integrity": "sha512-fsc4N6cPCAahybGBfTRcq5wFR6fpLznMg47sY5aDpsoejOcVYFb07AHuSnR0liMcPTgBsA3ZJL6kFOjPdoNipQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-runner/-/jest-runner-30.2.0.tgz", + "integrity": "sha512-PqvZ2B2XEyPEbclp+gV6KO/F1FIFSbIwewRgmROCMBo/aZ6J1w8Qypoj2pEOcg3G2HzLlaP6VUtvwCI8dM3oqQ==", "dev": true, "dependencies": { - "@jest/console": "^29.7.0", - "@jest/environment": "^29.7.0", - "@jest/test-result": "^29.7.0", - "@jest/transform": "^29.7.0", - "@jest/types": "^29.6.3", + "@jest/console": "30.2.0", + "@jest/environment": "30.2.0", + "@jest/test-result": "30.2.0", + "@jest/transform": "30.2.0", + "@jest/types": "30.2.0", "@types/node": "*", - "chalk": "^4.0.0", + "chalk": "^4.1.2", "emittery": "^0.13.1", - "graceful-fs": "^4.2.9", - "jest-docblock": "^29.7.0", - "jest-environment-node": "^29.7.0", - "jest-haste-map": "^29.7.0", - "jest-leak-detector": "^29.7.0", - "jest-message-util": "^29.7.0", - "jest-resolve": "^29.7.0", - "jest-runtime": "^29.7.0", - "jest-util": "^29.7.0", - "jest-watcher": "^29.7.0", - "jest-worker": "^29.7.0", + "exit-x": "^0.2.2", + "graceful-fs": "^4.2.11", + "jest-docblock": "30.2.0", + "jest-environment-node": "30.2.0", + "jest-haste-map": "30.2.0", + "jest-leak-detector": "30.2.0", + "jest-message-util": "30.2.0", + "jest-resolve": "30.2.0", + "jest-runtime": "30.2.0", + "jest-util": "30.2.0", + "jest-watcher": "30.2.0", + "jest-worker": "30.2.0", "p-limit": "^3.1.0", "source-map-support": "0.5.13" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/jest-runtime": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-runtime/-/jest-runtime-29.7.0.tgz", - "integrity": "sha512-gUnLjgwdGqW7B4LvOIkbKs9WGbn+QLqRQQ9juC6HndeDiezIwhDP+mhMwHWCEcfQ5RUXa6OPnFF8BJh5xegwwQ==", - "dev": true, - "dependencies": { - "@jest/environment": "^29.7.0", - "@jest/fake-timers": "^29.7.0", - "@jest/globals": "^29.7.0", - "@jest/source-map": "^29.6.3", - "@jest/test-result": "^29.7.0", - "@jest/transform": "^29.7.0", - "@jest/types": "^29.6.3", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-runtime/-/jest-runtime-30.2.0.tgz", + "integrity": "sha512-p1+GVX/PJqTucvsmERPMgCPvQJpFt4hFbM+VN3n8TMo47decMUcJbt+rgzwrEme0MQUA/R+1de2axftTHkKckg==", + "dev": true, + "dependencies": { + "@jest/environment": "30.2.0", + "@jest/fake-timers": "30.2.0", + "@jest/globals": "30.2.0", + "@jest/source-map": "30.0.1", + "@jest/test-result": "30.2.0", + "@jest/transform": "30.2.0", + "@jest/types": "30.2.0", "@types/node": "*", - "chalk": "^4.0.0", - "cjs-module-lexer": "^1.0.0", - "collect-v8-coverage": "^1.0.0", - "glob": "^7.1.3", - "graceful-fs": "^4.2.9", - "jest-haste-map": "^29.7.0", - "jest-message-util": "^29.7.0", - "jest-mock": "^29.7.0", - "jest-regex-util": "^29.6.3", - "jest-resolve": "^29.7.0", - "jest-snapshot": "^29.7.0", - "jest-util": "^29.7.0", + "chalk": "^4.1.2", + "cjs-module-lexer": "^2.1.0", + "collect-v8-coverage": "^1.0.2", + "glob": "^10.3.10", + "graceful-fs": "^4.2.11", + "jest-haste-map": "30.2.0", + "jest-message-util": "30.2.0", + "jest-mock": "30.2.0", + "jest-regex-util": "30.0.1", + "jest-resolve": "30.2.0", + "jest-snapshot": "30.2.0", + "jest-util": "30.2.0", "slash": "^3.0.0", "strip-bom": "^4.0.0" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/jest-snapshot": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-snapshot/-/jest-snapshot-29.7.0.tgz", - "integrity": "sha512-Rm0BMWtxBcioHr1/OX5YCP8Uov4riHvKPknOGs804Zg9JGZgmIBkbtlxJC/7Z4msKYVbIJtfU+tKb8xlYNfdkw==", - "dev": true, - "dependencies": { - "@babel/core": "^7.11.6", - "@babel/generator": "^7.7.2", - "@babel/plugin-syntax-jsx": "^7.7.2", - "@babel/plugin-syntax-typescript": "^7.7.2", - "@babel/types": "^7.3.3", - "@jest/expect-utils": "^29.7.0", - "@jest/transform": "^29.7.0", - "@jest/types": "^29.6.3", - "babel-preset-current-node-syntax": "^1.0.0", - "chalk": "^4.0.0", - "expect": "^29.7.0", - "graceful-fs": "^4.2.9", - "jest-diff": "^29.7.0", - "jest-get-type": "^29.6.3", - "jest-matcher-utils": "^29.7.0", - "jest-message-util": "^29.7.0", - "jest-util": "^29.7.0", - "natural-compare": "^1.4.0", - "pretty-format": "^29.7.0", - "semver": "^7.5.3" + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-snapshot/-/jest-snapshot-30.2.0.tgz", + "integrity": "sha512-5WEtTy2jXPFypadKNpbNkZ72puZCa6UjSr/7djeecHWOu7iYhSXSnHScT8wBz3Rn8Ena5d5RYRcsyKIeqG1IyA==", + "dev": true, + "dependencies": { + "@babel/core": "^7.27.4", + "@babel/generator": "^7.27.5", + "@babel/plugin-syntax-jsx": "^7.27.1", + "@babel/plugin-syntax-typescript": "^7.27.1", + "@babel/types": "^7.27.3", + "@jest/expect-utils": "30.2.0", + "@jest/get-type": "30.1.0", + "@jest/snapshot-utils": "30.2.0", + "@jest/transform": "30.2.0", + "@jest/types": "30.2.0", + "babel-preset-current-node-syntax": "^1.2.0", + "chalk": "^4.1.2", + "expect": "30.2.0", + "graceful-fs": "^4.2.11", + "jest-diff": "30.2.0", + "jest-matcher-utils": "30.2.0", + "jest-message-util": "30.2.0", + "jest-util": "30.2.0", + "pretty-format": "30.2.0", + "semver": "^7.7.2", + "synckit": "^0.11.8" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/jest-snapshot/node_modules/ansi-styles": { @@ -5318,46 +5256,31 @@ "url": "https://github.com/chalk/ansi-styles?sponsor=1" } }, - "node_modules/jest-snapshot/node_modules/lru-cache": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", - "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", - "dev": true, - "dependencies": { - "yallist": "^4.0.0" - }, - "engines": { - "node": ">=10" - } - }, "node_modules/jest-snapshot/node_modules/pretty-format": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-29.7.0.tgz", - "integrity": "sha512-Pdlw/oPxN+aXdmM9R00JVC9WVFoCLTKJvDVLgmJ+qAffBMxsV85l/Lu7sNx4zSzPyoL2euImuEwHhOXdEgNFZQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.2.0.tgz", + "integrity": "sha512-9uBdv/B4EefsuAL+pWqueZyZS2Ba+LxfFeQ9DN14HU4bN8bhaxKdkpjpB6fs9+pSjIBu+FXQHImEg8j/Lw0+vA==", "dev": true, "dependencies": { - "@jest/schemas": "^29.6.3", - "ansi-styles": "^5.0.0", - "react-is": "^18.0.0" + "@jest/schemas": "30.0.5", + "ansi-styles": "^5.2.0", + "react-is": "^18.3.1" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/jest-snapshot/node_modules/react-is": { - "version": "18.2.0", - "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz", - "integrity": "sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w==", + "version": "18.3.1", + "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.3.1.tgz", + "integrity": "sha512-/LLMVyas0ljjAtoYiPqYiL8VWXzUUdThrmU5+n20DZv+a+ClRoevUzw5JxU+Ieh5/c87ytoTBV9G1FiKfNJdmg==", "dev": true }, "node_modules/jest-snapshot/node_modules/semver": { - "version": "7.5.4", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz", - "integrity": "sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA==", + "version": "7.7.3", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.7.3.tgz", + "integrity": "sha512-SdsKMrI9TdgjdweUSR9MweHA4EJ8YxHn8DFaDisvhVlUOe4BF1tLD7GAj0lIqWVl+dPb/rExr0Btby5loQm20Q==", "dev": true, - "dependencies": { - "lru-cache": "^6.0.0" - }, "bin": { "semver": "bin/semver.js" }, @@ -5365,44 +5288,50 @@ "node": ">=10" } }, - "node_modules/jest-snapshot/node_modules/yallist": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", - "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", - "dev": true - }, "node_modules/jest-util": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-29.7.0.tgz", - "integrity": "sha512-z6EbKajIpqGKU56y5KBUgy1dt1ihhQJgWzUlZHArA/+X2ad7Cb5iF+AK1EWVL/Bo7Rz9uurpqw6SiBCefUbCGA==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-30.2.0.tgz", + "integrity": "sha512-QKNsM0o3Xe6ISQU869e+DhG+4CK/48aHYdJZGlFQVTjnbvgpcKyxpzk29fGiO7i/J8VENZ+d2iGnSsvmuHywlA==", "dev": true, "dependencies": { - "@jest/types": "^29.6.3", + "@jest/types": "30.2.0", "@types/node": "*", - "chalk": "^4.0.0", - "ci-info": "^3.2.0", - "graceful-fs": "^4.2.9", - "picomatch": "^2.2.3" + "chalk": "^4.1.2", + "ci-info": "^4.2.0", + "graceful-fs": "^4.2.11", + "picomatch": "^4.0.2" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" + } + }, + "node_modules/jest-util/node_modules/picomatch": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-4.0.3.tgz", + "integrity": "sha512-5gTmgEY/sqK6gFXLIsQNH19lWb4ebPDLA4SdLP7dsWkIXHWlG66oPuVvXSGFPppYZz8ZDZq0dYYrbHfBCVUb1Q==", + "dev": true, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/sponsors/jonschlinkert" } }, "node_modules/jest-validate": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-validate/-/jest-validate-29.7.0.tgz", - "integrity": "sha512-ZB7wHqaRGVw/9hST/OuFUReG7M8vKeq0/J2egIGLdvjHCmYqGARhzXmtgi+gVeZ5uXFF219aOc3Ls2yLg27tkw==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-validate/-/jest-validate-30.2.0.tgz", + "integrity": "sha512-FBGWi7dP2hpdi8nBoWxSsLvBFewKAg0+uSQwBaof4Y4DPgBabXgpSYC5/lR7VmnIlSpASmCi/ntRWPbv7089Pw==", "dev": true, "dependencies": { - "@jest/types": "^29.6.3", - "camelcase": "^6.2.0", - "chalk": "^4.0.0", - "jest-get-type": "^29.6.3", + "@jest/get-type": "30.1.0", + "@jest/types": "30.2.0", + "camelcase": "^6.3.0", + "chalk": "^4.1.2", "leven": "^3.1.0", - "pretty-format": "^29.7.0" + "pretty-format": "30.2.0" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/jest-validate/node_modules/ansi-styles": { @@ -5430,57 +5359,58 @@ } }, "node_modules/jest-validate/node_modules/pretty-format": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-29.7.0.tgz", - "integrity": "sha512-Pdlw/oPxN+aXdmM9R00JVC9WVFoCLTKJvDVLgmJ+qAffBMxsV85l/Lu7sNx4zSzPyoL2euImuEwHhOXdEgNFZQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.2.0.tgz", + "integrity": "sha512-9uBdv/B4EefsuAL+pWqueZyZS2Ba+LxfFeQ9DN14HU4bN8bhaxKdkpjpB6fs9+pSjIBu+FXQHImEg8j/Lw0+vA==", "dev": true, "dependencies": { - "@jest/schemas": "^29.6.3", - "ansi-styles": "^5.0.0", - "react-is": "^18.0.0" + "@jest/schemas": "30.0.5", + "ansi-styles": "^5.2.0", + "react-is": "^18.3.1" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/jest-validate/node_modules/react-is": { - "version": "18.2.0", - "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz", - "integrity": "sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w==", + "version": "18.3.1", + "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.3.1.tgz", + "integrity": "sha512-/LLMVyas0ljjAtoYiPqYiL8VWXzUUdThrmU5+n20DZv+a+ClRoevUzw5JxU+Ieh5/c87ytoTBV9G1FiKfNJdmg==", "dev": true }, "node_modules/jest-watcher": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-watcher/-/jest-watcher-29.7.0.tgz", - "integrity": "sha512-49Fg7WXkU3Vl2h6LbLtMQ/HyB6rXSIX7SqvBLQmssRBGN9I0PNvPmAmCWSOY6SOvrjhI/F7/bGAv9RtnsPA03g==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-watcher/-/jest-watcher-30.2.0.tgz", + "integrity": "sha512-PYxa28dxJ9g777pGm/7PrbnMeA0Jr7osHP9bS7eJy9DuAjMgdGtxgf0uKMyoIsTWAkIbUW5hSDdJ3urmgXBqxg==", "dev": true, "dependencies": { - "@jest/test-result": "^29.7.0", - "@jest/types": "^29.6.3", + "@jest/test-result": "30.2.0", + "@jest/types": "30.2.0", "@types/node": "*", - "ansi-escapes": "^4.2.1", - "chalk": "^4.0.0", + "ansi-escapes": "^4.3.2", + "chalk": "^4.1.2", "emittery": "^0.13.1", - "jest-util": "^29.7.0", - "string-length": "^4.0.1" + "jest-util": "30.2.0", + "string-length": "^4.0.2" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/jest-worker": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-worker/-/jest-worker-29.7.0.tgz", - "integrity": "sha512-eIz2msL/EzL9UFTFFx7jBTkeZfku0yUAyZZZmJ93H2TYEiroIx2PQjEXcwYtYl8zXCxb+PAmA2hLIt/6ZEkPHw==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-worker/-/jest-worker-30.2.0.tgz", + "integrity": "sha512-0Q4Uk8WF7BUwqXHuAjc23vmopWJw5WH7w2tqBoUOZpOjW/ZnR44GXXd1r82RvnmI2GZge3ivrYXk/BE2+VtW2g==", "dev": true, "dependencies": { "@types/node": "*", - "jest-util": "^29.7.0", + "@ungap/structured-clone": "^1.3.0", + "jest-util": "30.2.0", "merge-stream": "^2.0.0", - "supports-color": "^8.0.0" + "supports-color": "^8.1.1" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" + "node": "^18.14.0 || ^20.0.0 || ^22.0.0 || >=24.0.0" } }, "node_modules/jest-worker/node_modules/supports-color": { @@ -5565,15 +5495,15 @@ } }, "node_modules/jsesc": { - "version": "2.5.2", - "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", - "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-3.1.0.tgz", + "integrity": "sha512-/sM3dO2FOzXjKQhJuo0Q173wf2KOo8t4I8vHy6lF9poUp7bKT0/NHE8fPX23PwfhnykfqnC2xRxOnVw5XuGIaA==", "dev": true, "bin": { "jsesc": "bin/jsesc" }, "engines": { - "node": ">=4" + "node": ">=6" } }, "node_modules/json-buffer": { @@ -5621,15 +5551,6 @@ "json-buffer": "3.0.1" } }, - "node_modules/kleur": { - "version": "3.0.3", - "resolved": "https://registry.npmjs.org/kleur/-/kleur-3.0.3.tgz", - "integrity": "sha512-eTIzlVOSUR+JxdDFepEYcBMtZ9Qqdef+rnzWdRZuMbOywu5tO2w2N7rqjoANZ5k9vywhL6Br1VRjUIgTQx4E8w==", - "dev": true, - "engines": { - "node": ">=6" - } - }, "node_modules/leven": { "version": "3.1.0", "resolved": "https://registry.npmjs.org/leven/-/leven-3.1.0.tgz", @@ -5699,18 +5620,6 @@ "node": ">=20.0.0" } }, - "node_modules/listr2/node_modules/ansi-regex": { - "version": "6.2.2", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.2.2.tgz", - "integrity": "sha512-Bq3SmSpyFHaWjPk8If9yc6svM8c56dB5BAtW4Qbw5jHTwwXXcTLoRMkpDJp6VL0XzlWaCHTXrkFURMYmD0sLqg==", - "dev": true, - "engines": { - "node": ">=12" - }, - "funding": { - "url": "https://github.com/chalk/ansi-regex?sponsor=1" - } - }, "node_modules/listr2/node_modules/ansi-styles": { "version": "6.2.3", "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.3.tgz", @@ -5746,21 +5655,6 @@ "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/listr2/node_modules/strip-ansi": { - "version": "7.1.2", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.2.tgz", - "integrity": "sha512-gmBGslpoQJtgnMAvOVqGZpEz9dyoKTCzy2nfz/n8aIFhN/jCE/rCmcxabB6jOOHV+0WNnylOxaxBQPSvcWklhA==", - "dev": true, - "dependencies": { - "ansi-regex": "^6.0.1" - }, - "engines": { - "node": ">=12" - }, - "funding": { - "url": "https://github.com/chalk/strip-ansi?sponsor=1" - } - }, "node_modules/listr2/node_modules/wrap-ansi": { "version": "9.0.2", "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-9.0.2.tgz", @@ -5836,18 +5730,6 @@ "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/log-update/node_modules/ansi-regex": { - "version": "6.2.2", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.2.2.tgz", - "integrity": "sha512-Bq3SmSpyFHaWjPk8If9yc6svM8c56dB5BAtW4Qbw5jHTwwXXcTLoRMkpDJp6VL0XzlWaCHTXrkFURMYmD0sLqg==", - "dev": true, - "engines": { - "node": ">=12" - }, - "funding": { - "url": "https://github.com/chalk/ansi-regex?sponsor=1" - } - }, "node_modules/log-update/node_modules/ansi-styles": { "version": "6.2.3", "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.3.tgz", @@ -5883,21 +5765,6 @@ "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/log-update/node_modules/strip-ansi": { - "version": "7.1.2", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.2.tgz", - "integrity": "sha512-gmBGslpoQJtgnMAvOVqGZpEz9dyoKTCzy2nfz/n8aIFhN/jCE/rCmcxabB6jOOHV+0WNnylOxaxBQPSvcWklhA==", - "dev": true, - "dependencies": { - "ansi-regex": "^6.0.1" - }, - "engines": { - "node": ">=12" - }, - "funding": { - "url": "https://github.com/chalk/strip-ansi?sponsor=1" - } - }, "node_modules/log-update/node_modules/wrap-ansi": { "version": "9.0.2", "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-9.0.2.tgz", @@ -5948,26 +5815,11 @@ "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/make-dir/node_modules/lru-cache": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", - "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", - "dev": true, - "dependencies": { - "yallist": "^4.0.0" - }, - "engines": { - "node": ">=10" - } - }, "node_modules/make-dir/node_modules/semver": { - "version": "7.5.4", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz", - "integrity": "sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA==", + "version": "7.7.3", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.7.3.tgz", + "integrity": "sha512-SdsKMrI9TdgjdweUSR9MweHA4EJ8YxHn8DFaDisvhVlUOe4BF1tLD7GAj0lIqWVl+dPb/rExr0Btby5loQm20Q==", "dev": true, - "dependencies": { - "lru-cache": "^6.0.0" - }, "bin": { "semver": "bin/semver.js" }, @@ -5975,12 +5827,6 @@ "node": ">=10" } }, - "node_modules/make-dir/node_modules/yallist": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", - "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", - "dev": true - }, "node_modules/makeerror": { "version": "1.0.12", "resolved": "https://registry.npmjs.org/makeerror/-/makeerror-1.0.12.tgz", @@ -6101,6 +5947,15 @@ "node": "*" } }, + "node_modules/minipass": { + "version": "7.1.2", + "resolved": "https://registry.npmjs.org/minipass/-/minipass-7.1.2.tgz", + "integrity": "sha512-qOOzS1cBTWYF4BH8fVePDBOO9iptMnGUEZwNc/cMWnTV2nVLZ7VoNWEPHkYczZA0pdoA7dl6e7FL659nX9S2aw==", + "dev": true, + "engines": { + "node": ">=16 || 14 >=14.17" + } + }, "node_modules/ms": { "version": "2.1.3", "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", @@ -6119,6 +5974,21 @@ "url": "https://github.com/sindresorhus/nano-spawn?sponsor=1" } }, + "node_modules/napi-postinstall": { + "version": "0.3.4", + "resolved": "https://registry.npmjs.org/napi-postinstall/-/napi-postinstall-0.3.4.tgz", + "integrity": "sha512-PHI5f1O0EP5xJ9gQmFGMS6IZcrVvTjpXjz7Na41gTE7eE2hK11lg04CECCYEEjdc17EV4DO+fkGEtt7TpTaTiQ==", + "dev": true, + "bin": { + "napi-postinstall": "lib/cli.js" + }, + "engines": { + "node": "^12.20.0 || ^14.18.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/napi-postinstall" + } + }, "node_modules/natural-compare": { "version": "1.4.0", "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", @@ -6142,9 +6012,9 @@ "dev": true }, "node_modules/node-releases": { - "version": "2.0.13", - "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.13.tgz", - "integrity": "sha512-uYr7J37ae/ORWdZeQ1xxMJe3NtdmqMC/JZK+geofDrkLUApKRHPd18/TxtBOJ4A0/+uUIliorNrfYV6s1b02eQ==", + "version": "2.0.23", + "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.23.tgz", + "integrity": "sha512-cCmFDMSm26S6tQSDpBCg/NR8NENrVPhAJSf+XbxBG4rPFaaonlEoE9wHQmun+cls499TQGSb7ZyPBRlzgKfpeg==", "dev": true }, "node_modules/normalize-path": { @@ -6296,6 +6166,12 @@ "node": ">=6" } }, + "node_modules/package-json-from-dist": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/package-json-from-dist/-/package-json-from-dist-1.0.1.tgz", + "integrity": "sha512-UEZIS3/by4OC8vL3P2dTXRETpebLI2NiI5vIrjaD/5UtrkFX/tNbwjTSRAGC/+7CAo2pIcBaRgWmcBBHcsaCIw==", + "dev": true + }, "node_modules/parent-module": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", @@ -6398,10 +6274,26 @@ "node": ">=8" } }, - "node_modules/path-parse": { - "version": "1.0.7", - "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", - "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", + "node_modules/path-scurry": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/path-scurry/-/path-scurry-1.11.1.tgz", + "integrity": "sha512-Xa4Nw17FS9ApQFJ9umLiJS4orGjm7ZzwUrwamcGQuHSzDyth9boKDaycYdDcZDuqYATXw4HFXgaqWTctW/v1HA==", + "dev": true, + "dependencies": { + "lru-cache": "^10.2.0", + "minipass": "^5.0.0 || ^6.0.2 || ^7.0.0" + }, + "engines": { + "node": ">=16 || 14 >=14.18" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/path-scurry/node_modules/lru-cache": { + "version": "10.4.3", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-10.4.3.tgz", + "integrity": "sha512-JNAzZcXrCt42VGLuYz0zfAzDfAvJWW6AfYlDBQyDV5DClI2m5sAmK+OIO7s59XfsRsWHp02jAJrRadPRGTt6SQ==", "dev": true }, "node_modules/path-to-regexp": { @@ -6446,9 +6338,9 @@ } }, "node_modules/pirates": { - "version": "4.0.6", - "resolved": "https://registry.npmjs.org/pirates/-/pirates-4.0.6.tgz", - "integrity": "sha512-saLsH7WeYYPiD25LDuLRRY/i+6HaPYr6G1OUlN39otzkSTxKnubR9RTxS3/Kk50s1g2JTgFwWQDQyplC5/SHZg==", + "version": "4.0.7", + "resolved": "https://registry.npmjs.org/pirates/-/pirates-4.0.7.tgz", + "integrity": "sha512-TfySrs/5nm8fQJDcBDuUng3VOUKsd7S+zqvbOTiGXHfxX4wK31ard+hoNuvkicM/2YFzlpDgABOevKSsB4G/FA==", "dev": true, "engines": { "node": ">= 6" @@ -6510,23 +6402,10 @@ "integrity": "sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==", "dev": true, "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/prompts": { - "version": "2.4.2", - "resolved": "https://registry.npmjs.org/prompts/-/prompts-2.4.2.tgz", - "integrity": "sha512-NxNv/kLguCA7p3jE8oL2aEBsrJWgAakBpgmgK6lpPWV+WuOmY6r2/zbAVnP+T8bQlA0nzHXSJSJW0Hq7ylaD2Q==", - "dev": true, - "dependencies": { - "kleur": "^3.0.3", - "sisteransi": "^1.0.5" - }, - "engines": { - "node": ">= 6" + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" } }, "node_modules/proxy-addr": { @@ -6558,9 +6437,9 @@ } }, "node_modules/pure-rand": { - "version": "6.0.3", - "resolved": "https://registry.npmjs.org/pure-rand/-/pure-rand-6.0.3.tgz", - "integrity": "sha512-KddyFewCsO0j3+np81IQ+SweXLDnDQTs5s67BOnrYmYe/yNmUhttQyGsYzy8yUnoljGAQ9sl38YB4vH8ur7Y+w==", + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/pure-rand/-/pure-rand-7.0.1.tgz", + "integrity": "sha512-oTUZM/NAZS8p7ANR3SHh30kXB+zK2r2BPcEn/awJIbOvq82WoMN4p62AWWp3Hhw50G0xMsw1mhIBLqHw64EcNQ==", "dev": true, "funding": [ { @@ -6666,23 +6545,6 @@ "node": ">=0.10.0" } }, - "node_modules/resolve": { - "version": "1.22.6", - "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.6.tgz", - "integrity": "sha512-njhxM7mV12JfufShqGy3Rz8j11RPdLy4xi15UurGJeoHLfJpVXKdh3ueuOqbYUcDZnffr6X739JBo5LzyahEsw==", - "dev": true, - "dependencies": { - "is-core-module": "^2.13.0", - "path-parse": "^1.0.7", - "supports-preserve-symlinks-flag": "^1.0.0" - }, - "bin": { - "resolve": "bin/resolve" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, "node_modules/resolve-cwd": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/resolve-cwd/-/resolve-cwd-3.0.0.tgz", @@ -6704,15 +6566,6 @@ "node": ">=8" } }, - "node_modules/resolve.exports": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/resolve.exports/-/resolve.exports-2.0.2.tgz", - "integrity": "sha512-X2UW6Nw3n/aMgDVy+0rSqgHlv39WZAlZrXCdnbyEiKm17DSqHX4MmQMaST3FbeWR5FTuRcUwYAziZajji0Y7mg==", - "dev": true, - "engines": { - "node": ">=10" - } - }, "node_modules/restore-cursor": { "version": "5.1.0", "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-5.1.0.tgz", @@ -6744,18 +6597,6 @@ "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/restore-cursor/node_modules/signal-exit": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-4.1.0.tgz", - "integrity": "sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw==", - "dev": true, - "engines": { - "node": ">=14" - }, - "funding": { - "url": "https://github.com/sponsors/isaacs" - } - }, "node_modules/rfdc": { "version": "1.4.1", "resolved": "https://registry.npmjs.org/rfdc/-/rfdc-1.4.1.tgz", @@ -7000,16 +6841,16 @@ } }, "node_modules/signal-exit": { - "version": "3.0.7", - "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", - "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", - "dev": true - }, - "node_modules/sisteransi": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/sisteransi/-/sisteransi-1.0.5.tgz", - "integrity": "sha512-bLGGlR1QxBcynn2d5YmDX4MGjlZvy2MRBDRNHLJ8VI6l6+9FUiyTFNJ0IveOSP0bcXgVDPRcfGqA0pjaqUpfVg==", - "dev": true + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-4.1.0.tgz", + "integrity": "sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw==", + "dev": true, + "engines": { + "node": ">=14" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } }, "node_modules/slash": { "version": "3.0.0", @@ -7154,7 +6995,37 @@ "node": ">=10" } }, + "node_modules/string-length/node_modules/strip-ansi": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", + "dev": true, + "dependencies": { + "ansi-regex": "^5.0.1" + }, + "engines": { + "node": ">=8" + } + }, "node_modules/string-width": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-5.1.2.tgz", + "integrity": "sha512-HnLOCR3vjcY8beoNLtcjZ5/nxn2afmME6lhrDrebokqMap+XbeW8n9TXpPDOqdGK5qcI3oT0GKTW6wC7EMiVqA==", + "dev": true, + "dependencies": { + "eastasianwidth": "^0.2.0", + "emoji-regex": "^9.2.2", + "strip-ansi": "^7.0.1" + }, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/string-width-cjs": { + "name": "string-width", "version": "4.2.3", "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", @@ -7168,7 +7039,41 @@ "node": ">=8" } }, + "node_modules/string-width-cjs/node_modules/emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "dev": true + }, + "node_modules/string-width-cjs/node_modules/strip-ansi": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", + "dev": true, + "dependencies": { + "ansi-regex": "^5.0.1" + }, + "engines": { + "node": ">=8" + } + }, "node_modules/strip-ansi": { + "version": "7.1.2", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.2.tgz", + "integrity": "sha512-gmBGslpoQJtgnMAvOVqGZpEz9dyoKTCzy2nfz/n8aIFhN/jCE/rCmcxabB6jOOHV+0WNnylOxaxBQPSvcWklhA==", + "dev": true, + "dependencies": { + "ansi-regex": "^6.0.1" + }, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/strip-ansi?sponsor=1" + } + }, + "node_modules/strip-ansi-cjs": { + "name": "strip-ansi", "version": "6.0.1", "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", @@ -7180,6 +7085,18 @@ "node": ">=8" } }, + "node_modules/strip-ansi/node_modules/ansi-regex": { + "version": "6.2.2", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.2.2.tgz", + "integrity": "sha512-Bq3SmSpyFHaWjPk8If9yc6svM8c56dB5BAtW4Qbw5jHTwwXXcTLoRMkpDJp6VL0XzlWaCHTXrkFURMYmD0sLqg==", + "dev": true, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/ansi-regex?sponsor=1" + } + }, "node_modules/strip-bom": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-4.0.0.tgz", @@ -7234,24 +7151,27 @@ "node": ">=8" } }, - "node_modules/supports-preserve-symlinks-flag": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", - "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", - "dev": true, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, "node_modules/symbol-tree": { "version": "3.2.4", "resolved": "https://registry.npmjs.org/symbol-tree/-/symbol-tree-3.2.4.tgz", "integrity": "sha512-9QNk5KwDF+Bvz+PyObkmSYjI5ksVUYtjW7AU22r2NKcfLJcXp96hkDWU3+XndOsUb+AQ9QhfzfCT2O+CNWT5Tw==", "dev": true }, + "node_modules/synckit": { + "version": "0.11.11", + "resolved": "https://registry.npmjs.org/synckit/-/synckit-0.11.11.tgz", + "integrity": "sha512-MeQTA1r0litLUf0Rp/iisCaL8761lKAZHaimlbGK4j0HysC4PLfqygQj9srcs0m2RdtDYnF8UuYyKpbjHYp7Jw==", + "dev": true, + "dependencies": { + "@pkgr/core": "^0.2.9" + }, + "engines": { + "node": "^14.18.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/synckit" + } + }, "node_modules/test-exclude": { "version": "6.0.0", "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz", @@ -7266,6 +7186,27 @@ "node": ">=8" } }, + "node_modules/test-exclude/node_modules/glob": { + "version": "7.2.3", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", + "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", + "deprecated": "Glob versions prior to v9 are no longer supported", + "dev": true, + "dependencies": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.1.1", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + }, + "engines": { + "node": "*" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, "node_modules/tldts": { "version": "6.1.86", "resolved": "https://registry.npmjs.org/tldts/-/tldts-6.1.86.tgz", @@ -7290,15 +7231,6 @@ "integrity": "sha512-3f0uOEAQwIqGuWW2MVzYg8fV/QNnc/IpuJNG837rLuczAaLVHslWHZQj4IGiEl5Hs3kkbhwL9Ab7Hrsmuj+Smw==", "dev": true }, - "node_modules/to-fast-properties": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", - "integrity": "sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==", - "dev": true, - "engines": { - "node": ">=4" - } - }, "node_modules/to-regex-range": { "version": "5.0.1", "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", @@ -7345,6 +7277,13 @@ "node": ">=18" } }, + "node_modules/tslib": { + "version": "2.8.1", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.8.1.tgz", + "integrity": "sha512-oJFu94HQb+KVduSUQL7wnpmqnfmLsOA/nAh6b6EH0wCEoK0/mPeXU6c3wKDV83MkOuHPRHtSXKKU99IBazS/2w==", + "dev": true, + "optional": true + }, "node_modules/tunnel": { "version": "0.0.6", "resolved": "https://registry.npmjs.org/tunnel/-/tunnel-0.0.6.tgz", @@ -7455,10 +7394,44 @@ "node": ">= 0.8" } }, + "node_modules/unrs-resolver": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/unrs-resolver/-/unrs-resolver-1.11.1.tgz", + "integrity": "sha512-bSjt9pjaEBnNiGgc9rUiHGKv5l4/TGzDmYw3RhnkJGtLhbnnA/5qJj7x3dNDCRx/PJxu774LlH8lCOlB4hEfKg==", + "dev": true, + "hasInstallScript": true, + "dependencies": { + "napi-postinstall": "^0.3.0" + }, + "funding": { + "url": "https://opencollective.com/unrs-resolver" + }, + "optionalDependencies": { + "@unrs/resolver-binding-android-arm-eabi": "1.11.1", + "@unrs/resolver-binding-android-arm64": "1.11.1", + "@unrs/resolver-binding-darwin-arm64": "1.11.1", + "@unrs/resolver-binding-darwin-x64": "1.11.1", + "@unrs/resolver-binding-freebsd-x64": "1.11.1", + "@unrs/resolver-binding-linux-arm-gnueabihf": "1.11.1", + "@unrs/resolver-binding-linux-arm-musleabihf": "1.11.1", + "@unrs/resolver-binding-linux-arm64-gnu": "1.11.1", + "@unrs/resolver-binding-linux-arm64-musl": "1.11.1", + "@unrs/resolver-binding-linux-ppc64-gnu": "1.11.1", + "@unrs/resolver-binding-linux-riscv64-gnu": "1.11.1", + "@unrs/resolver-binding-linux-riscv64-musl": "1.11.1", + "@unrs/resolver-binding-linux-s390x-gnu": "1.11.1", + "@unrs/resolver-binding-linux-x64-gnu": "1.11.1", + "@unrs/resolver-binding-linux-x64-musl": "1.11.1", + "@unrs/resolver-binding-wasm32-wasi": "1.11.1", + "@unrs/resolver-binding-win32-arm64-msvc": "1.11.1", + "@unrs/resolver-binding-win32-ia32-msvc": "1.11.1", + "@unrs/resolver-binding-win32-x64-msvc": "1.11.1" + } + }, "node_modules/update-browserslist-db": { - "version": "1.0.11", - "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.11.tgz", - "integrity": "sha512-dCwEFf0/oT85M1fHBg4F0jtLwJrutGoHSQXCh7u4o2t1drG+c0a9Flnqww6XUKSfQMPpJBRjU8d4RXB09qtvaA==", + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.1.3.tgz", + "integrity": "sha512-UxhIZQ+QInVdunkDAaiazvvT/+fXL5Osr0JZlJulepYu6Jd7qJtDZjlur0emRlT71EN3ScPoE7gvsuIKKNavKw==", "dev": true, "funding": [ { @@ -7475,8 +7448,8 @@ } ], "dependencies": { - "escalade": "^3.1.1", - "picocolors": "^1.0.0" + "escalade": "^3.2.0", + "picocolors": "^1.1.1" }, "bin": { "update-browserslist-db": "cli.js" @@ -7495,25 +7468,19 @@ } }, "node_modules/v8-to-istanbul": { - "version": "9.1.0", - "resolved": "https://registry.npmjs.org/v8-to-istanbul/-/v8-to-istanbul-9.1.0.tgz", - "integrity": "sha512-6z3GW9x8G1gd+JIIgQQQxXuiJtCXeAjp6RaPEPLv62mH3iPHPxV6W3robxtCzNErRo6ZwTmzWhsbNvjyEBKzKA==", + "version": "9.3.0", + "resolved": "https://registry.npmjs.org/v8-to-istanbul/-/v8-to-istanbul-9.3.0.tgz", + "integrity": "sha512-kiGUalWN+rgBJ/1OHZsBtU4rXZOfj/7rKQxULKlIzwzQSvMJUUNgPwJEEh7gU6xEVxC0ahoOBvN2YI8GH6FNgA==", "dev": true, "dependencies": { "@jridgewell/trace-mapping": "^0.3.12", "@types/istanbul-lib-coverage": "^2.0.1", - "convert-source-map": "^1.6.0" + "convert-source-map": "^2.0.0" }, "engines": { "node": ">=10.12.0" } }, - "node_modules/v8-to-istanbul/node_modules/convert-source-map": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.9.0.tgz", - "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==", - "dev": true - }, "node_modules/vary": { "version": "1.1.2", "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", @@ -7612,6 +7579,24 @@ } }, "node_modules/wrap-ansi": { + "version": "8.1.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-8.1.0.tgz", + "integrity": "sha512-si7QWI6zUMq56bESFvagtmzMdGOtoxfR+Sez11Mobfc7tm+VkUckk9bW2UeffTGVUbOksxmSw0AA2gs8g71NCQ==", + "dev": true, + "dependencies": { + "ansi-styles": "^6.1.0", + "string-width": "^5.0.1", + "strip-ansi": "^7.0.1" + }, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/wrap-ansi?sponsor=1" + } + }, + "node_modules/wrap-ansi-cjs": { + "name": "wrap-ansi", "version": "7.0.0", "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", @@ -7628,6 +7613,50 @@ "url": "https://github.com/chalk/wrap-ansi?sponsor=1" } }, + "node_modules/wrap-ansi-cjs/node_modules/emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "dev": true + }, + "node_modules/wrap-ansi-cjs/node_modules/string-width": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", + "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", + "dev": true, + "dependencies": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/wrap-ansi-cjs/node_modules/strip-ansi": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", + "dev": true, + "dependencies": { + "ansi-regex": "^5.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/wrap-ansi/node_modules/ansi-styles": { + "version": "6.2.3", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.3.tgz", + "integrity": "sha512-4Dj6M28JB+oAH8kFkTLUo+a2jwOFkuqb3yucU0CANcRRUbxS0cP0nZYCGjcc3BNXwRIsUVmDGgzawme7zvJHvg==", + "dev": true, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, "node_modules/wrappy": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", @@ -7635,16 +7664,16 @@ "dev": true }, "node_modules/write-file-atomic": { - "version": "4.0.2", - "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-4.0.2.tgz", - "integrity": "sha512-7KxauUdBmSdWnmpaGFg+ppNjKF8uNLry8LyzjauQDOVONfFLNKrKvQOxZ/VuTIcS/gge/YNahf5RIIQWTSarlg==", + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-5.0.1.tgz", + "integrity": "sha512-+QU2zd6OTD8XWIJCbffaiQeH9U73qIqafo1x6V1snCWYGJf6cVE0cDR4D8xRzcEnfI21IFrUPzPGtcPf8AC+Rw==", "dev": true, "dependencies": { "imurmurhash": "^0.1.4", - "signal-exit": "^3.0.7" + "signal-exit": "^4.0.1" }, "engines": { - "node": "^12.13.0 || ^14.15.0 || >=16.0.0" + "node": "^14.17.0 || ^16.13.0 || >=18.0.0" } }, "node_modules/ws": { @@ -7734,7 +7763,39 @@ "integrity": "sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw==", "dev": true, "engines": { - "node": ">=12" + "node": ">=12" + } + }, + "node_modules/yargs/node_modules/emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "dev": true + }, + "node_modules/yargs/node_modules/string-width": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", + "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", + "dev": true, + "dependencies": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/yargs/node_modules/strip-ansi": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", + "dev": true, + "dependencies": { + "ansi-regex": "^5.0.1" + }, + "engines": { + "node": ">=8" } }, "node_modules/yocto-queue": { @@ -7813,16 +7874,6 @@ "integrity": "sha512-Ff9+ksdQQB3rMncgqDK78uLznstjyfIf2Arnh22pW8kBpLs6rpKDwgnZT46hin5Hl1WzazzK64DOrhSwYpS7bQ==", "dev": true }, - "@ampproject/remapping": { - "version": "2.2.1", - "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.2.1.tgz", - "integrity": "sha512-lFMjJTrFL3j7L9yBxwYfCq2k6qqwHyzuUl/XBnif78PWTJYyL/dfowQHWE3sp6U6ZzqWiiIZnpTMO96zhkjwtg==", - "dev": true, - "requires": { - "@jridgewell/gen-mapping": "^0.3.0", - "@jridgewell/trace-mapping": "^0.3.9" - } - }, "@asamuzakjp/css-color": { "version": "3.2.0", "resolved": "https://registry.npmjs.org/@asamuzakjp/css-color/-/css-color-3.2.0.tgz", @@ -7856,142 +7907,97 @@ } }, "@babel/compat-data": { - "version": "7.22.9", - "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.22.9.tgz", - "integrity": "sha512-5UamI7xkUcJ3i9qVDS+KFDEK8/7oJ55/sJMB1Ge7IEapr7KfdfV/HErR+koZwOfd+SgtFKOKRhRakdg++DcJpQ==", + "version": "7.28.4", + "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.28.4.tgz", + "integrity": "sha512-YsmSKC29MJwf0gF8Rjjrg5LQCmyh+j/nD8/eP7f+BeoQTKYqs9RoWbjGOdy0+1Ekr68RJZMUOPVQaQisnIo4Rw==", "dev": true }, "@babel/core": { - "version": "7.22.9", - "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.22.9.tgz", - "integrity": "sha512-G2EgeufBcYw27U4hhoIwFcgc1XU7TlXJ3mv04oOv1WCuo900U/anZSPzEqNjwdjgffkk2Gs0AN0dW1CKVLcG7w==", - "dev": true, - "requires": { - "@ampproject/remapping": "^2.2.0", - "@babel/code-frame": "^7.22.5", - "@babel/generator": "^7.22.9", - "@babel/helper-compilation-targets": "^7.22.9", - "@babel/helper-module-transforms": "^7.22.9", - "@babel/helpers": "^7.22.6", - "@babel/parser": "^7.22.7", - "@babel/template": "^7.22.5", - "@babel/traverse": "^7.22.8", - "@babel/types": "^7.22.5", - "convert-source-map": "^1.7.0", + "version": "7.28.4", + "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.28.4.tgz", + "integrity": "sha512-2BCOP7TN8M+gVDj7/ht3hsaO/B/n5oDbiAyyvnRlNOs+u1o+JWNYTQrmpuNp1/Wq2gcFrI01JAW+paEKDMx/CA==", + "dev": true, + "requires": { + "@babel/code-frame": "^7.27.1", + "@babel/generator": "^7.28.3", + "@babel/helper-compilation-targets": "^7.27.2", + "@babel/helper-module-transforms": "^7.28.3", + "@babel/helpers": "^7.28.4", + "@babel/parser": "^7.28.4", + "@babel/template": "^7.27.2", + "@babel/traverse": "^7.28.4", + "@babel/types": "^7.28.4", + "@jridgewell/remapping": "^2.3.5", + "convert-source-map": "^2.0.0", "debug": "^4.1.0", "gensync": "^1.0.0-beta.2", - "json5": "^2.2.2", + "json5": "^2.2.3", "semver": "^6.3.1" - }, - "dependencies": { - "convert-source-map": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.9.0.tgz", - "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==", - "dev": true - } } }, "@babel/generator": { - "version": "7.23.0", - "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.23.0.tgz", - "integrity": "sha512-lN85QRR+5IbYrMWM6Y4pE/noaQtg4pNiqeNGX60eqOfo6gtEj6uw/JagelB8vVztSd7R6M5n1+PQkDbHbBRU4g==", + "version": "7.28.3", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.28.3.tgz", + "integrity": "sha512-3lSpxGgvnmZznmBkCRnVREPUFJv2wrv9iAoFDvADJc0ypmdOxdUtcLeBgBJ6zE0PMeTKnxeQzyk0xTBq4Ep7zw==", "dev": true, "requires": { - "@babel/types": "^7.23.0", - "@jridgewell/gen-mapping": "^0.3.2", - "@jridgewell/trace-mapping": "^0.3.17", - "jsesc": "^2.5.1" + "@babel/parser": "^7.28.3", + "@babel/types": "^7.28.2", + "@jridgewell/gen-mapping": "^0.3.12", + "@jridgewell/trace-mapping": "^0.3.28", + "jsesc": "^3.0.2" } }, "@babel/helper-compilation-targets": { - "version": "7.22.9", - "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.22.9.tgz", - "integrity": "sha512-7qYrNM6HjpnPHJbopxmb8hSPoZ0gsX8IvUS32JGVoy+pU9e5N0nLr1VjJoR6kA4d9dmGLxNYOjeB8sUDal2WMw==", + "version": "7.27.2", + "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.27.2.tgz", + "integrity": "sha512-2+1thGUUWWjLTYTHZWK1n8Yga0ijBz1XAhUXcKy81rd5g6yh7hGqMp45v7cadSbEHc9G3OTv45SyneRN3ps4DQ==", "dev": true, "requires": { - "@babel/compat-data": "^7.22.9", - "@babel/helper-validator-option": "^7.22.5", - "browserslist": "^4.21.9", + "@babel/compat-data": "^7.27.2", + "@babel/helper-validator-option": "^7.27.1", + "browserslist": "^4.24.0", "lru-cache": "^5.1.1", "semver": "^6.3.1" } }, - "@babel/helper-environment-visitor": { - "version": "7.22.20", - "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.22.20.tgz", - "integrity": "sha512-zfedSIzFhat/gFhWfHtgWvlec0nqB9YEIVrpuwjruLlXfUSnA8cJB0miHKwqDnQ7d32aKo2xt88/xZptwxbfhA==", + "@babel/helper-globals": { + "version": "7.28.0", + "resolved": "https://registry.npmjs.org/@babel/helper-globals/-/helper-globals-7.28.0.tgz", + "integrity": "sha512-+W6cISkXFa1jXsDEdYA8HeevQT/FULhxzR99pxphltZcVaugps53THCeiWA8SguxxpSp3gKPiuYfSWopkLQ4hw==", "dev": true }, - "@babel/helper-function-name": { - "version": "7.23.0", - "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.23.0.tgz", - "integrity": "sha512-OErEqsrxjZTJciZ4Oo+eoZqeW9UIiOcuYKRJA4ZAgV9myA+pOXhhmpfNCKjEH/auVfEYVFJ6y1Tc4r0eIApqiw==", - "dev": true, - "requires": { - "@babel/template": "^7.22.15", - "@babel/types": "^7.23.0" - } - }, - "@babel/helper-hoist-variables": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.22.5.tgz", - "integrity": "sha512-wGjk9QZVzvknA6yKIUURb8zY3grXCcOZt+/7Wcy8O2uctxhplmUPkOdlgoNhmdVee2c92JXbf1xpMtVNbfoxRw==", - "dev": true, - "requires": { - "@babel/types": "^7.22.5" - } - }, "@babel/helper-module-imports": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.22.5.tgz", - "integrity": "sha512-8Dl6+HD/cKifutF5qGd/8ZJi84QeAKh+CEe1sBzz8UayBBGg1dAIJrdHOcOM5b2MpzWL2yuotJTtGjETq0qjXg==", + "version": "7.27.1", + "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.27.1.tgz", + "integrity": "sha512-0gSFWUPNXNopqtIPQvlD5WgXYI5GY2kP2cCvoT8kczjbfcfuIljTbcWrulD1CIPIX2gt1wghbDy08yE1p+/r3w==", "dev": true, "requires": { - "@babel/types": "^7.22.5" + "@babel/traverse": "^7.27.1", + "@babel/types": "^7.27.1" } }, "@babel/helper-module-transforms": { - "version": "7.22.9", - "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.22.9.tgz", - "integrity": "sha512-t+WA2Xn5K+rTeGtC8jCsdAH52bjggG5TKRuRrAGNM/mjIbO4GxvlLMFOEz9wXY5I2XQ60PMFsAG2WIcG82dQMQ==", + "version": "7.28.3", + "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.28.3.tgz", + "integrity": "sha512-gytXUbs8k2sXS9PnQptz5o0QnpLL51SwASIORY6XaBKF88nsOT0Zw9szLqlSGQDP/4TljBAD5y98p2U1fqkdsw==", "dev": true, "requires": { - "@babel/helper-environment-visitor": "^7.22.5", - "@babel/helper-module-imports": "^7.22.5", - "@babel/helper-simple-access": "^7.22.5", - "@babel/helper-split-export-declaration": "^7.22.6", - "@babel/helper-validator-identifier": "^7.22.5" + "@babel/helper-module-imports": "^7.27.1", + "@babel/helper-validator-identifier": "^7.27.1", + "@babel/traverse": "^7.28.3" } }, "@babel/helper-plugin-utils": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.22.5.tgz", - "integrity": "sha512-uLls06UVKgFG9QD4OeFYLEGteMIAa5kpTPcFL28yuCIIzsf6ZyKZMllKVOCZFhiZ5ptnwX4mtKdWCBE/uT4amg==", + "version": "7.27.1", + "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.27.1.tgz", + "integrity": "sha512-1gn1Up5YXka3YYAHGKpbideQ5Yjf1tDa9qYcgysz+cNCXukyLl6DjPXhD3VRwSb8c0J9tA4b2+rHEZtc6R0tlw==", "dev": true }, - "@babel/helper-simple-access": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.22.5.tgz", - "integrity": "sha512-n0H99E/K+Bika3++WNL17POvo4rKWZ7lZEp1Q+fStVbUi8nxPQEBOlTmCOxW/0JsS56SKKQ+ojAe2pHKJHN35w==", - "dev": true, - "requires": { - "@babel/types": "^7.22.5" - } - }, - "@babel/helper-split-export-declaration": { - "version": "7.22.6", - "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.22.6.tgz", - "integrity": "sha512-AsUnxuLhRYsisFiaJwvp1QF+I3KjD5FOxut14q/GzovUe6orHLesW2C7d754kRm53h5gqrz6sFl6sxc4BVtE/g==", - "dev": true, - "requires": { - "@babel/types": "^7.22.5" - } - }, "@babel/helper-string-parser": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.22.5.tgz", - "integrity": "sha512-mM4COjgZox8U+JcXQwPijIZLElkgEpO5rsERVDJTc2qfCDfERyob6k5WegS14SX18IIjv+XD+GrqNumY5JRCDw==", + "version": "7.27.1", + "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.27.1.tgz", + "integrity": "sha512-qMlSxKbpRlAridDExk92nSobyDdpPijUq2DW6oDnUqd0iOGxmQjyqhMIihI9+zv4LPyZdRje2cavWPbCbWm3eA==", "dev": true }, "@babel/helper-validator-identifier": { @@ -8001,27 +8007,29 @@ "dev": true }, "@babel/helper-validator-option": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.22.5.tgz", - "integrity": "sha512-R3oB6xlIVKUnxNUxbmgq7pKjxpru24zlimpE8WK47fACIlM0II/Hm1RS8IaOI7NgCr6LNS+jl5l75m20npAziw==", + "version": "7.27.1", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.27.1.tgz", + "integrity": "sha512-YvjJow9FxbhFFKDSuFnVCe2WxXk1zWc22fFePVNEaWJEu8IrZVlda6N0uHwzZrUM1il7NC9Mlp4MaJYbYd9JSg==", "dev": true }, "@babel/helpers": { - "version": "7.22.6", - "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.22.6.tgz", - "integrity": "sha512-YjDs6y/fVOYFV8hAf1rxd1QvR9wJe1pDBZ2AREKq/SDayfPzgk0PBnVuTCE5X1acEpMMNOVUqoe+OwiZGJ+OaA==", + "version": "7.28.4", + "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.28.4.tgz", + "integrity": "sha512-HFN59MmQXGHVyYadKLVumYsA9dBFun/ldYxipEjzA4196jpLZd8UjEEBLkbEkvfYreDqJhZxYAWFPtrfhNpj4w==", "dev": true, "requires": { - "@babel/template": "^7.22.5", - "@babel/traverse": "^7.22.6", - "@babel/types": "^7.22.5" + "@babel/template": "^7.27.2", + "@babel/types": "^7.28.4" } }, "@babel/parser": { - "version": "7.23.0", - "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.23.0.tgz", - "integrity": "sha512-vvPKKdMemU85V9WE/l5wZEmImpCtLqbnTvqDS2U1fJ96KrxoW7KrXhNsNCblQlg8Ck4b85yxdTyelsMUgFUXiw==", - "dev": true + "version": "7.28.4", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.28.4.tgz", + "integrity": "sha512-yZbBqeM6TkpP9du/I2pUZnJsRMGGvOuIrhjzC1AwHwW+6he4mni6Bp/m8ijn0iOuZuPI2BfkCoSRunpyjnrQKg==", + "dev": true, + "requires": { + "@babel/types": "^7.28.4" + } }, "@babel/plugin-syntax-async-generators": { "version": "7.8.4", @@ -8050,6 +8058,24 @@ "@babel/helper-plugin-utils": "^7.12.13" } }, + "@babel/plugin-syntax-class-static-block": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-static-block/-/plugin-syntax-class-static-block-7.14.5.tgz", + "integrity": "sha512-b+YyPmr6ldyNnM6sqYeMWE+bgJcJpO6yS4QD7ymxgH34GBPNDM/THBh8iunyvKIZztiwLH4CJZ0RxTk9emgpjw==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-syntax-import-attributes": { + "version": "7.27.1", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-attributes/-/plugin-syntax-import-attributes-7.27.1.tgz", + "integrity": "sha512-oFT0FrKHgF53f4vOsZGi2Hh3I35PfSmVs4IBFLFj4dnafP+hIWDLg3VyKmUHfLoLHlyxY4C7DGtmHuJgn+IGww==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.27.1" + } + }, "@babel/plugin-syntax-import-meta": { "version": "7.10.4", "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-meta/-/plugin-syntax-import-meta-7.10.4.tgz", @@ -8069,12 +8095,12 @@ } }, "@babel/plugin-syntax-jsx": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.22.5.tgz", - "integrity": "sha512-gvyP4hZrgrs/wWMaocvxZ44Hw0b3W8Pe+cMxc8V1ULQ07oh8VNbIRaoD1LRZVTvD+0nieDKjfgKg89sD7rrKrg==", + "version": "7.27.1", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.27.1.tgz", + "integrity": "sha512-y8YTNIeKoyhGd9O0Jiyzyyqk8gdjnumGTQPsz0xOZOQ2RmkVJeZ1vmmfIvFEKqucBG6axJGBZDE/7iI5suUI/w==", "dev": true, "requires": { - "@babel/helper-plugin-utils": "^7.22.5" + "@babel/helper-plugin-utils": "^7.27.1" } }, "@babel/plugin-syntax-logical-assignment-operators": { @@ -8131,6 +8157,15 @@ "@babel/helper-plugin-utils": "^7.8.0" } }, + "@babel/plugin-syntax-private-property-in-object": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-private-property-in-object/-/plugin-syntax-private-property-in-object-7.14.5.tgz", + "integrity": "sha512-0wVnp9dxJ72ZUJDV27ZfbSj6iHLoytYZmh3rFcxNnvsJF3ktkzLDZPy/mA17HGsaQT3/DQsWYX1f1QGWkCoVUg==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, "@babel/plugin-syntax-top-level-await": { "version": "7.14.5", "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.14.5.tgz", @@ -8141,12 +8176,12 @@ } }, "@babel/plugin-syntax-typescript": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.22.5.tgz", - "integrity": "sha512-1mS2o03i7t1c6VzH6fdQ3OA8tcEIxwG18zIPRp+UY1Ihv6W+XZzBCVxExF9upussPXJ0xE9XRHwMoNs1ep/nRQ==", + "version": "7.27.1", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.27.1.tgz", + "integrity": "sha512-xfYCBMxveHrRMnAWl1ZlPXOZjzkN82THFvLhQhFXFt81Z5HnN+EtUkZhv/zcKpmT3fzmWZB0ywiBrbC3vogbwQ==", "dev": true, "requires": { - "@babel/helper-plugin-utils": "^7.22.5" + "@babel/helper-plugin-utils": "^7.27.1" } }, "@babel/runtime": { @@ -8159,51 +8194,39 @@ } }, "@babel/template": { - "version": "7.22.15", - "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.22.15.tgz", - "integrity": "sha512-QPErUVm4uyJa60rkI73qneDacvdvzxshT3kksGqlGWYdOTIUOwJ7RDUL8sGqslY1uXWSL6xMFKEXDS3ox2uF0w==", + "version": "7.27.2", + "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.27.2.tgz", + "integrity": "sha512-LPDZ85aEJyYSd18/DkjNh4/y1ntkE5KwUHWTiqgRxruuZL2F1yuHligVHLvcHY2vMHXttKFpJn6LwfI7cw7ODw==", "dev": true, "requires": { - "@babel/code-frame": "^7.22.13", - "@babel/parser": "^7.22.15", - "@babel/types": "^7.22.15" + "@babel/code-frame": "^7.27.1", + "@babel/parser": "^7.27.2", + "@babel/types": "^7.27.1" } }, "@babel/traverse": { - "version": "7.23.2", - "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.23.2.tgz", - "integrity": "sha512-azpe59SQ48qG6nu2CzcMLbxUudtN+dOM9kDbUqGq3HXUJRlo7i8fvPoxQUzYgLZ4cMVmuZgm8vvBpNeRhd6XSw==", - "dev": true, - "requires": { - "@babel/code-frame": "^7.22.13", - "@babel/generator": "^7.23.0", - "@babel/helper-environment-visitor": "^7.22.20", - "@babel/helper-function-name": "^7.23.0", - "@babel/helper-hoist-variables": "^7.22.5", - "@babel/helper-split-export-declaration": "^7.22.6", - "@babel/parser": "^7.23.0", - "@babel/types": "^7.23.0", - "debug": "^4.1.0", - "globals": "^11.1.0" - }, - "dependencies": { - "globals": { - "version": "11.12.0", - "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", - "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", - "dev": true - } + "version": "7.28.4", + "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.28.4.tgz", + "integrity": "sha512-YEzuboP2qvQavAcjgQNVgsvHIDv6ZpwXvcvjmyySP2DIMuByS/6ioU5G9pYrWHM6T2YDfc7xga9iNzYOs12CFQ==", + "dev": true, + "requires": { + "@babel/code-frame": "^7.27.1", + "@babel/generator": "^7.28.3", + "@babel/helper-globals": "^7.28.0", + "@babel/parser": "^7.28.4", + "@babel/template": "^7.27.2", + "@babel/types": "^7.28.4", + "debug": "^4.3.1" } }, "@babel/types": { - "version": "7.23.0", - "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.23.0.tgz", - "integrity": "sha512-0oIyUfKoI3mSqMvsxBdclDwxXKXAUA8v/apZbc+iSyARYou1o8ZGDxbUYyLFoW2arqS2jDGqJuZvv1d/io1axg==", + "version": "7.28.4", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.28.4.tgz", + "integrity": "sha512-bkFqkLhh3pMBUQQkpVgWDWq/lqzc2678eUyDlTBhRqhCHFguYYGM0Efga7tYk4TogG/3x0EEl66/OQ+WGbWB/Q==", "dev": true, "requires": { - "@babel/helper-string-parser": "^7.22.5", - "@babel/helper-validator-identifier": "^7.22.20", - "to-fast-properties": "^2.0.0" + "@babel/helper-string-parser": "^7.27.1", + "@babel/helper-validator-identifier": "^7.27.1" } }, "@bcoe/v8-coverage": { @@ -8248,6 +8271,37 @@ "integrity": "sha512-Vd/9EVDiu6PPJt9yAh6roZP6El1xHrdvIVGjyBsHR0RYwNHgL7FJPyIIW4fANJNG6FtyZfvlRPpFI4ZM/lubvw==", "dev": true }, + "@emnapi/core": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/@emnapi/core/-/core-1.5.0.tgz", + "integrity": "sha512-sbP8GzB1WDzacS8fgNPpHlp6C9VZe+SJP3F90W9rLemaQj2PzIuTEl1qDOYQf58YIpyjViI24y9aPWCjEzY2cg==", + "dev": true, + "optional": true, + "requires": { + "@emnapi/wasi-threads": "1.1.0", + "tslib": "^2.4.0" + } + }, + "@emnapi/runtime": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/@emnapi/runtime/-/runtime-1.5.0.tgz", + "integrity": "sha512-97/BJ3iXHww3djw6hYIfErCZFee7qCtrneuLa20UXFCOTCfBM2cvQHjWJ2EG0s0MtdNwInarqCTz35i4wWXHsQ==", + "dev": true, + "optional": true, + "requires": { + "tslib": "^2.4.0" + } + }, + "@emnapi/wasi-threads": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@emnapi/wasi-threads/-/wasi-threads-1.1.0.tgz", + "integrity": "sha512-WI0DdZ8xFSbgMjR1sFsKABJ/C5OnRrjT06JXbZKexJGrDuPTzZdDYfFlsgcCXCyf+suG5QU2e/y1Wo2V/OapLQ==", + "dev": true, + "optional": true, + "requires": { + "tslib": "^2.4.0" + } + }, "@es-joy/jsdoccomment": { "version": "0.69.0", "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.69.0.tgz", @@ -8394,6 +8448,20 @@ "integrity": "sha512-xeO57FpIu4p1Ri3Jq/EXq4ClRm86dVF2z/+kvFnyqVYRavTZmaFaUBbWCOuuTh0o/g7DSsk6kc2vrS4Vl5oPOQ==", "dev": true }, + "@isaacs/cliui": { + "version": "8.0.2", + "resolved": "https://registry.npmjs.org/@isaacs/cliui/-/cliui-8.0.2.tgz", + "integrity": "sha512-O8jcjabXaleOG9DQ0+ARXWZBTfnP4WNAqzuiJK7ll44AmxGKv/J2M4TPjxjY3znBCfvBXFzucm1twdyFybFqEA==", + "dev": true, + "requires": { + "string-width": "^5.1.2", + "string-width-cjs": "npm:string-width@^4.2.0", + "strip-ansi": "^7.0.1", + "strip-ansi-cjs": "npm:strip-ansi@^6.0.1", + "wrap-ansi": "^8.1.0", + "wrap-ansi-cjs": "npm:wrap-ansi@^7.0.0" + } + }, "@istanbuljs/load-nyc-config": { "version": "1.1.0", "resolved": "https://registry.npmjs.org/@istanbuljs/load-nyc-config/-/load-nyc-config-1.1.0.tgz", @@ -8435,53 +8503,53 @@ "dev": true }, "@jest/console": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/@jest/console/-/console-29.7.0.tgz", - "integrity": "sha512-5Ni4CU7XHQi32IJ398EEP4RrB8eV09sXP2ROqD4bksHrnTree52PsxvX8tpL8LvTZ3pFzXyPbNQReSN41CAhOg==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/console/-/console-30.2.0.tgz", + "integrity": "sha512-+O1ifRjkvYIkBqASKWgLxrpEhQAAE7hY77ALLUufSk5717KfOShg6IbqLmdsLMPdUiFvA2kTs0R7YZy+l0IzZQ==", "dev": true, "requires": { - "@jest/types": "^29.6.3", + "@jest/types": "30.2.0", "@types/node": "*", - "chalk": "^4.0.0", - "jest-message-util": "^29.7.0", - "jest-util": "^29.7.0", + "chalk": "^4.1.2", + "jest-message-util": "30.2.0", + "jest-util": "30.2.0", "slash": "^3.0.0" } }, "@jest/core": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/@jest/core/-/core-29.7.0.tgz", - "integrity": "sha512-n7aeXWKMnGtDA48y8TLWJPJmLmmZ642Ceo78cYWEpiD7FzDgmNDV/GCVRorPABdXLJZ/9wzzgZAlHjXjxDHGsg==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/core/-/core-30.2.0.tgz", + "integrity": "sha512-03W6IhuhjqTlpzh/ojut/pDB2LPRygyWX8ExpgHtQA8H/3K7+1vKmcINx5UzeOX1se6YEsBsOHQ1CRzf3fOwTQ==", "dev": true, "requires": { - "@jest/console": "^29.7.0", - "@jest/reporters": "^29.7.0", - "@jest/test-result": "^29.7.0", - "@jest/transform": "^29.7.0", - "@jest/types": "^29.6.3", + "@jest/console": "30.2.0", + "@jest/pattern": "30.0.1", + "@jest/reporters": "30.2.0", + "@jest/test-result": "30.2.0", + "@jest/transform": "30.2.0", + "@jest/types": "30.2.0", "@types/node": "*", - "ansi-escapes": "^4.2.1", - "chalk": "^4.0.0", - "ci-info": "^3.2.0", - "exit": "^0.1.2", - "graceful-fs": "^4.2.9", - "jest-changed-files": "^29.7.0", - "jest-config": "^29.7.0", - "jest-haste-map": "^29.7.0", - "jest-message-util": "^29.7.0", - "jest-regex-util": "^29.6.3", - "jest-resolve": "^29.7.0", - "jest-resolve-dependencies": "^29.7.0", - "jest-runner": "^29.7.0", - "jest-runtime": "^29.7.0", - "jest-snapshot": "^29.7.0", - "jest-util": "^29.7.0", - "jest-validate": "^29.7.0", - "jest-watcher": "^29.7.0", - "micromatch": "^4.0.4", - "pretty-format": "^29.7.0", - "slash": "^3.0.0", - "strip-ansi": "^6.0.0" + "ansi-escapes": "^4.3.2", + "chalk": "^4.1.2", + "ci-info": "^4.2.0", + "exit-x": "^0.2.2", + "graceful-fs": "^4.2.11", + "jest-changed-files": "30.2.0", + "jest-config": "30.2.0", + "jest-haste-map": "30.2.0", + "jest-message-util": "30.2.0", + "jest-regex-util": "30.0.1", + "jest-resolve": "30.2.0", + "jest-resolve-dependencies": "30.2.0", + "jest-runner": "30.2.0", + "jest-runtime": "30.2.0", + "jest-snapshot": "30.2.0", + "jest-util": "30.2.0", + "jest-validate": "30.2.0", + "jest-watcher": "30.2.0", + "micromatch": "^4.0.8", + "pretty-format": "30.2.0", + "slash": "^3.0.0" }, "dependencies": { "ansi-styles": { @@ -8491,34 +8559,40 @@ "dev": true }, "pretty-format": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-29.7.0.tgz", - "integrity": "sha512-Pdlw/oPxN+aXdmM9R00JVC9WVFoCLTKJvDVLgmJ+qAffBMxsV85l/Lu7sNx4zSzPyoL2euImuEwHhOXdEgNFZQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.2.0.tgz", + "integrity": "sha512-9uBdv/B4EefsuAL+pWqueZyZS2Ba+LxfFeQ9DN14HU4bN8bhaxKdkpjpB6fs9+pSjIBu+FXQHImEg8j/Lw0+vA==", "dev": true, "requires": { - "@jest/schemas": "^29.6.3", - "ansi-styles": "^5.0.0", - "react-is": "^18.0.0" + "@jest/schemas": "30.0.5", + "ansi-styles": "^5.2.0", + "react-is": "^18.3.1" } }, "react-is": { - "version": "18.2.0", - "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz", - "integrity": "sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w==", + "version": "18.3.1", + "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.3.1.tgz", + "integrity": "sha512-/LLMVyas0ljjAtoYiPqYiL8VWXzUUdThrmU5+n20DZv+a+ClRoevUzw5JxU+Ieh5/c87ytoTBV9G1FiKfNJdmg==", "dev": true } } }, + "@jest/diff-sequences": { + "version": "30.0.1", + "resolved": "https://registry.npmjs.org/@jest/diff-sequences/-/diff-sequences-30.0.1.tgz", + "integrity": "sha512-n5H8QLDJ47QqbCNn5SuFjCRDrOLEZ0h8vAHCK5RL9Ls7Xa8AQLa/YxAc9UjFqoEDM48muwtBGjtMY5cr0PLDCw==", + "dev": true + }, "@jest/environment": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-29.7.0.tgz", - "integrity": "sha512-aQIfHDq33ExsN4jP1NWGXhxgQ/wixs60gDiKO+XVMd8Mn0NWPWgc34ZQDTb2jKaUWQ7MuwoitXAsN2XVXNMpAw==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-30.2.0.tgz", + "integrity": "sha512-/QPTL7OBJQ5ac09UDRa3EQes4gt1FTEG/8jZ/4v5IVzx+Cv7dLxlVIvfvSVRiiX2drWyXeBjkMSR8hvOWSog5g==", "dev": true, "requires": { - "@jest/fake-timers": "^29.7.0", - "@jest/types": "^29.6.3", + "@jest/fake-timers": "30.2.0", + "@jest/types": "30.2.0", "@types/node": "*", - "jest-mock": "^29.7.0" + "jest-mock": "30.2.0" } }, "@jest/environment-jsdom-abstract": { @@ -8534,195 +8608,57 @@ "@types/node": "*", "jest-mock": "30.2.0", "jest-util": "30.2.0" - }, - "dependencies": { - "@jest/environment": { - "version": "30.2.0", - "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-30.2.0.tgz", - "integrity": "sha512-/QPTL7OBJQ5ac09UDRa3EQes4gt1FTEG/8jZ/4v5IVzx+Cv7dLxlVIvfvSVRiiX2drWyXeBjkMSR8hvOWSog5g==", - "dev": true, - "requires": { - "@jest/fake-timers": "30.2.0", - "@jest/types": "30.2.0", - "@types/node": "*", - "jest-mock": "30.2.0" - } - }, - "@jest/fake-timers": { - "version": "30.2.0", - "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-30.2.0.tgz", - "integrity": "sha512-HI3tRLjRxAbBy0VO8dqqm7Hb2mIa8d5bg/NJkyQcOk7V118ObQML8RC5luTF/Zsg4474a+gDvhce7eTnP4GhYw==", - "dev": true, - "requires": { - "@jest/types": "30.2.0", - "@sinonjs/fake-timers": "^13.0.0", - "@types/node": "*", - "jest-message-util": "30.2.0", - "jest-mock": "30.2.0", - "jest-util": "30.2.0" - } - }, - "@jest/schemas": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/@jest/schemas/-/schemas-30.0.5.tgz", - "integrity": "sha512-DmdYgtezMkh3cpU8/1uyXakv3tJRcmcXxBOcO0tbaozPwpmh4YMsnWrQm9ZmZMfa5ocbxzbFk6O4bDPEc/iAnA==", - "dev": true, - "requires": { - "@sinclair/typebox": "^0.34.0" - } - }, - "@jest/types": { - "version": "30.2.0", - "resolved": "https://registry.npmjs.org/@jest/types/-/types-30.2.0.tgz", - "integrity": "sha512-H9xg1/sfVvyfU7o3zMfBEjQ1gcsdeTMgqHoYdN79tuLqfTtuu7WckRA1R5whDwOzxaZAeMKTYWqP+WCAi0CHsg==", - "dev": true, - "requires": { - "@jest/pattern": "30.0.1", - "@jest/schemas": "30.0.5", - "@types/istanbul-lib-coverage": "^2.0.6", - "@types/istanbul-reports": "^3.0.4", - "@types/node": "*", - "@types/yargs": "^17.0.33", - "chalk": "^4.1.2" - } - }, - "@sinclair/typebox": { - "version": "0.34.41", - "resolved": "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.34.41.tgz", - "integrity": "sha512-6gS8pZzSXdyRHTIqoqSVknxolr1kzfy4/CeDnrzsVz8TTIWUbOBr6gnzOmTYJ3eXQNh4IYHIGi5aIL7sOZ2G/g==", - "dev": true - }, - "@sinonjs/fake-timers": { - "version": "13.0.5", - "resolved": "https://registry.npmjs.org/@sinonjs/fake-timers/-/fake-timers-13.0.5.tgz", - "integrity": "sha512-36/hTbH2uaWuGVERyC6da9YwGWnzUZXuPro/F2LfsdOsLnCojz/iSH8MxUt/FD2S5XBSVPhmArFUXcpCQ2Hkiw==", - "dev": true, - "requires": { - "@sinonjs/commons": "^3.0.1" - } - }, - "ansi-styles": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz", - "integrity": "sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==", - "dev": true - }, - "ci-info": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-4.3.0.tgz", - "integrity": "sha512-l+2bNRMiQgcfILUi33labAZYIWlH1kWDp+ecNo5iisRKrbm0xcRyCww71/YU0Fkw0mAFpz9bJayXPjey6vkmaQ==", - "dev": true - }, - "jest-message-util": { - "version": "30.2.0", - "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-30.2.0.tgz", - "integrity": "sha512-y4DKFLZ2y6DxTWD4cDe07RglV88ZiNEdlRfGtqahfbIjfsw1nMCPx49Uev4IA/hWn3sDKyAnSPwoYSsAEdcimw==", - "dev": true, - "requires": { - "@babel/code-frame": "^7.27.1", - "@jest/types": "30.2.0", - "@types/stack-utils": "^2.0.3", - "chalk": "^4.1.2", - "graceful-fs": "^4.2.11", - "micromatch": "^4.0.8", - "pretty-format": "30.2.0", - "slash": "^3.0.0", - "stack-utils": "^2.0.6" - } - }, - "jest-mock": { - "version": "30.2.0", - "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-30.2.0.tgz", - "integrity": "sha512-JNNNl2rj4b5ICpmAcq+WbLH83XswjPbjH4T7yvGzfAGCPh1rw+xVNbtk+FnRslvt9lkCcdn9i1oAoKUuFsOxRw==", - "dev": true, - "requires": { - "@jest/types": "30.2.0", - "@types/node": "*", - "jest-util": "30.2.0" - } - }, - "jest-util": { - "version": "30.2.0", - "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-30.2.0.tgz", - "integrity": "sha512-QKNsM0o3Xe6ISQU869e+DhG+4CK/48aHYdJZGlFQVTjnbvgpcKyxpzk29fGiO7i/J8VENZ+d2iGnSsvmuHywlA==", - "dev": true, - "requires": { - "@jest/types": "30.2.0", - "@types/node": "*", - "chalk": "^4.1.2", - "ci-info": "^4.2.0", - "graceful-fs": "^4.2.11", - "picomatch": "^4.0.2" - } - }, - "picomatch": { - "version": "4.0.3", - "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-4.0.3.tgz", - "integrity": "sha512-5gTmgEY/sqK6gFXLIsQNH19lWb4ebPDLA4SdLP7dsWkIXHWlG66oPuVvXSGFPppYZz8ZDZq0dYYrbHfBCVUb1Q==", - "dev": true - }, - "pretty-format": { - "version": "30.2.0", - "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.2.0.tgz", - "integrity": "sha512-9uBdv/B4EefsuAL+pWqueZyZS2Ba+LxfFeQ9DN14HU4bN8bhaxKdkpjpB6fs9+pSjIBu+FXQHImEg8j/Lw0+vA==", - "dev": true, - "requires": { - "@jest/schemas": "30.0.5", - "ansi-styles": "^5.2.0", - "react-is": "^18.3.1" - } - }, - "react-is": { - "version": "18.3.1", - "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.3.1.tgz", - "integrity": "sha512-/LLMVyas0ljjAtoYiPqYiL8VWXzUUdThrmU5+n20DZv+a+ClRoevUzw5JxU+Ieh5/c87ytoTBV9G1FiKfNJdmg==", - "dev": true - } } }, "@jest/expect": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/@jest/expect/-/expect-29.7.0.tgz", - "integrity": "sha512-8uMeAMycttpva3P1lBHB8VciS9V0XAr3GymPpipdyQXbBcuhkLQOSe8E/p92RyAdToS6ZD1tFkX+CkhoECE0dQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/expect/-/expect-30.2.0.tgz", + "integrity": "sha512-V9yxQK5erfzx99Sf+7LbhBwNWEZ9eZay8qQ9+JSC0TrMR1pMDHLMY+BnVPacWU6Jamrh252/IKo4F1Xn/zfiqA==", "dev": true, "requires": { - "expect": "^29.7.0", - "jest-snapshot": "^29.7.0" + "expect": "30.2.0", + "jest-snapshot": "30.2.0" } }, "@jest/expect-utils": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/@jest/expect-utils/-/expect-utils-29.7.0.tgz", - "integrity": "sha512-GlsNBWiFQFCVi9QVSx7f5AgMeLxe9YCCs5PuP2O2LdjDAA8Jh9eX7lA1Jq/xdXw3Wb3hyvlFNfZIfcRetSzYcA==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/expect-utils/-/expect-utils-30.2.0.tgz", + "integrity": "sha512-1JnRfhqpD8HGpOmQp180Fo9Zt69zNtC+9lR+kT7NVL05tNXIi+QC8Csz7lfidMoVLPD3FnOtcmp0CEFnxExGEA==", "dev": true, "requires": { - "jest-get-type": "^29.6.3" + "@jest/get-type": "30.1.0" } }, "@jest/fake-timers": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-29.7.0.tgz", - "integrity": "sha512-q4DH1Ha4TTFPdxLsqDXK1d3+ioSL7yL5oCMJZgDYm6i+6CygW5E5xVr/D1HdsGxjt1ZWSfUAs9OxSB/BNelWrQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-30.2.0.tgz", + "integrity": "sha512-HI3tRLjRxAbBy0VO8dqqm7Hb2mIa8d5bg/NJkyQcOk7V118ObQML8RC5luTF/Zsg4474a+gDvhce7eTnP4GhYw==", "dev": true, "requires": { - "@jest/types": "^29.6.3", - "@sinonjs/fake-timers": "^10.0.2", + "@jest/types": "30.2.0", + "@sinonjs/fake-timers": "^13.0.0", "@types/node": "*", - "jest-message-util": "^29.7.0", - "jest-mock": "^29.7.0", - "jest-util": "^29.7.0" + "jest-message-util": "30.2.0", + "jest-mock": "30.2.0", + "jest-util": "30.2.0" } }, + "@jest/get-type": { + "version": "30.1.0", + "resolved": "https://registry.npmjs.org/@jest/get-type/-/get-type-30.1.0.tgz", + "integrity": "sha512-eMbZE2hUnx1WV0pmURZY9XoXPkUYjpc55mb0CrhtdWLtzMQPFvu/rZkTLZFTsdaVQa+Tr4eWAteqcUzoawq/uA==", + "dev": true + }, "@jest/globals": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/@jest/globals/-/globals-29.7.0.tgz", - "integrity": "sha512-mpiz3dutLbkW2MNFubUGUEVLkTGiqW6yLVTA+JbP6fI6J5iL9Y0Nlg8k95pcF8ctKwCS7WVxteBs29hhfAotzQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/globals/-/globals-30.2.0.tgz", + "integrity": "sha512-b63wmnKPaK+6ZZfpYhz9K61oybvbI1aMcIs80++JI1O1rR1vaxHUCNqo3ITu6NU0d4V34yZFoHMn/uoKr/Rwfw==", "dev": true, "requires": { - "@jest/environment": "^29.7.0", - "@jest/expect": "^29.7.0", - "@jest/types": "^29.6.3", - "jest-mock": "^29.7.0" + "@jest/environment": "30.2.0", + "@jest/expect": "30.2.0", + "@jest/types": "30.2.0", + "jest-mock": "30.2.0" } }, "@jest/pattern": { @@ -8733,213 +8669,185 @@ "requires": { "@types/node": "*", "jest-regex-util": "30.0.1" - }, - "dependencies": { - "jest-regex-util": { - "version": "30.0.1", - "resolved": "https://registry.npmjs.org/jest-regex-util/-/jest-regex-util-30.0.1.tgz", - "integrity": "sha512-jHEQgBXAgc+Gh4g0p3bCevgRCVRkB4VB70zhoAE48gxeSr1hfUOsM/C2WoJgVL7Eyg//hudYENbm3Ne+/dRVVA==", - "dev": true - } } }, "@jest/reporters": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/@jest/reporters/-/reporters-29.7.0.tgz", - "integrity": "sha512-DApq0KJbJOEzAFYjHADNNxAE3KbhxQB1y5Kplb5Waqw6zVbuWatSnMjE5gs8FUgEPmNsnZA3NCWl9NG0ia04Pg==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/reporters/-/reporters-30.2.0.tgz", + "integrity": "sha512-DRyW6baWPqKMa9CzeiBjHwjd8XeAyco2Vt8XbcLFjiwCOEKOvy82GJ8QQnJE9ofsxCMPjH4MfH8fCWIHHDKpAQ==", "dev": true, "requires": { "@bcoe/v8-coverage": "^0.2.3", - "@jest/console": "^29.7.0", - "@jest/test-result": "^29.7.0", - "@jest/transform": "^29.7.0", - "@jest/types": "^29.6.3", - "@jridgewell/trace-mapping": "^0.3.18", + "@jest/console": "30.2.0", + "@jest/test-result": "30.2.0", + "@jest/transform": "30.2.0", + "@jest/types": "30.2.0", + "@jridgewell/trace-mapping": "^0.3.25", "@types/node": "*", - "chalk": "^4.0.0", - "collect-v8-coverage": "^1.0.0", - "exit": "^0.1.2", - "glob": "^7.1.3", - "graceful-fs": "^4.2.9", + "chalk": "^4.1.2", + "collect-v8-coverage": "^1.0.2", + "exit-x": "^0.2.2", + "glob": "^10.3.10", + "graceful-fs": "^4.2.11", "istanbul-lib-coverage": "^3.0.0", "istanbul-lib-instrument": "^6.0.0", "istanbul-lib-report": "^3.0.0", - "istanbul-lib-source-maps": "^4.0.0", + "istanbul-lib-source-maps": "^5.0.0", "istanbul-reports": "^3.1.3", - "jest-message-util": "^29.7.0", - "jest-util": "^29.7.0", - "jest-worker": "^29.7.0", + "jest-message-util": "30.2.0", + "jest-util": "30.2.0", + "jest-worker": "30.2.0", "slash": "^3.0.0", - "string-length": "^4.0.1", - "strip-ansi": "^6.0.0", + "string-length": "^4.0.2", "v8-to-istanbul": "^9.0.1" - }, - "dependencies": { - "istanbul-lib-instrument": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-6.0.0.tgz", - "integrity": "sha512-x58orMzEVfzPUKqlbLd1hXCnySCxKdDKa6Rjg97CwuLLRI4g3FHTdnExu1OqffVFay6zeMW+T6/DowFLndWnIw==", - "dev": true, - "requires": { - "@babel/core": "^7.12.3", - "@babel/parser": "^7.14.7", - "@istanbuljs/schema": "^0.1.2", - "istanbul-lib-coverage": "^3.2.0", - "semver": "^7.5.4" - } - }, - "lru-cache": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", - "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", - "dev": true, - "requires": { - "yallist": "^4.0.0" - } - }, - "semver": { - "version": "7.5.4", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz", - "integrity": "sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA==", - "dev": true, - "requires": { - "lru-cache": "^6.0.0" - } - }, - "yallist": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", - "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", - "dev": true - } } }, - "@jest/schemas": { - "version": "29.6.3", - "resolved": "https://registry.npmjs.org/@jest/schemas/-/schemas-29.6.3.tgz", - "integrity": "sha512-mo5j5X+jIZmJQveBKeS/clAueipV7KgiX1vMgCxam1RNYiqE1w62n0/tJJnHtjW8ZHcQco5gY85jA3mi0L+nSA==", + "@jest/schemas": { + "version": "30.0.5", + "resolved": "https://registry.npmjs.org/@jest/schemas/-/schemas-30.0.5.tgz", + "integrity": "sha512-DmdYgtezMkh3cpU8/1uyXakv3tJRcmcXxBOcO0tbaozPwpmh4YMsnWrQm9ZmZMfa5ocbxzbFk6O4bDPEc/iAnA==", + "dev": true, + "requires": { + "@sinclair/typebox": "^0.34.0" + } + }, + "@jest/snapshot-utils": { + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/snapshot-utils/-/snapshot-utils-30.2.0.tgz", + "integrity": "sha512-0aVxM3RH6DaiLcjj/b0KrIBZhSX1373Xci4l3cW5xiUWPctZ59zQ7jj4rqcJQ/Z8JuN/4wX3FpJSa3RssVvCug==", "dev": true, "requires": { - "@sinclair/typebox": "^0.27.8" + "@jest/types": "30.2.0", + "chalk": "^4.1.2", + "graceful-fs": "^4.2.11", + "natural-compare": "^1.4.0" } }, "@jest/source-map": { - "version": "29.6.3", - "resolved": "https://registry.npmjs.org/@jest/source-map/-/source-map-29.6.3.tgz", - "integrity": "sha512-MHjT95QuipcPrpLM+8JMSzFx6eHp5Bm+4XeFDJlwsvVBjmKNiIAvasGK2fxz2WbGRlnvqehFbh07MMa7n3YJnw==", + "version": "30.0.1", + "resolved": "https://registry.npmjs.org/@jest/source-map/-/source-map-30.0.1.tgz", + "integrity": "sha512-MIRWMUUR3sdbP36oyNyhbThLHyJ2eEDClPCiHVbrYAe5g3CHRArIVpBw7cdSB5fr+ofSfIb2Tnsw8iEHL0PYQg==", "dev": true, "requires": { - "@jridgewell/trace-mapping": "^0.3.18", - "callsites": "^3.0.0", - "graceful-fs": "^4.2.9" + "@jridgewell/trace-mapping": "^0.3.25", + "callsites": "^3.1.0", + "graceful-fs": "^4.2.11" } }, "@jest/test-result": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/@jest/test-result/-/test-result-29.7.0.tgz", - "integrity": "sha512-Fdx+tv6x1zlkJPcWXmMDAG2HBnaR9XPSd5aDWQVsfrZmLVT3lU1cwyxLgRmXR9yrq4NBoEm9BMsfgFzTQAbJYA==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/test-result/-/test-result-30.2.0.tgz", + "integrity": "sha512-RF+Z+0CCHkARz5HT9mcQCBulb1wgCP3FBvl9VFokMX27acKphwyQsNuWH3c+ojd1LeWBLoTYoxF0zm6S/66mjg==", "dev": true, "requires": { - "@jest/console": "^29.7.0", - "@jest/types": "^29.6.3", - "@types/istanbul-lib-coverage": "^2.0.0", - "collect-v8-coverage": "^1.0.0" + "@jest/console": "30.2.0", + "@jest/types": "30.2.0", + "@types/istanbul-lib-coverage": "^2.0.6", + "collect-v8-coverage": "^1.0.2" } }, "@jest/test-sequencer": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/@jest/test-sequencer/-/test-sequencer-29.7.0.tgz", - "integrity": "sha512-GQwJ5WZVrKnOJuiYiAF52UNUJXgTZx1NHjFSEB0qEMmSZKAkdMoIzw/Cj6x6NF4AvV23AUqDpFzQkN/eYCYTxw==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/test-sequencer/-/test-sequencer-30.2.0.tgz", + "integrity": "sha512-wXKgU/lk8fKXMu/l5Hog1R61bL4q5GCdT6OJvdAFz1P+QrpoFuLU68eoKuVc4RbrTtNnTL5FByhWdLgOPSph+Q==", "dev": true, "requires": { - "@jest/test-result": "^29.7.0", - "graceful-fs": "^4.2.9", - "jest-haste-map": "^29.7.0", + "@jest/test-result": "30.2.0", + "graceful-fs": "^4.2.11", + "jest-haste-map": "30.2.0", "slash": "^3.0.0" } }, "@jest/transform": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/@jest/transform/-/transform-29.7.0.tgz", - "integrity": "sha512-ok/BTPFzFKVMwO5eOHRrvnBVHdRy9IrsrW1GpMaQ9MCnilNLXQKmAX8s1YXDFaai9xJpac2ySzV0YeRRECr2Vw==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/transform/-/transform-30.2.0.tgz", + "integrity": "sha512-XsauDV82o5qXbhalKxD7p4TZYYdwcaEXC77PPD2HixEFF+6YGppjrAAQurTl2ECWcEomHBMMNS9AH3kcCFx8jA==", "dev": true, "requires": { - "@babel/core": "^7.11.6", - "@jest/types": "^29.6.3", - "@jridgewell/trace-mapping": "^0.3.18", - "babel-plugin-istanbul": "^6.1.1", - "chalk": "^4.0.0", + "@babel/core": "^7.27.4", + "@jest/types": "30.2.0", + "@jridgewell/trace-mapping": "^0.3.25", + "babel-plugin-istanbul": "^7.0.1", + "chalk": "^4.1.2", "convert-source-map": "^2.0.0", "fast-json-stable-stringify": "^2.1.0", - "graceful-fs": "^4.2.9", - "jest-haste-map": "^29.7.0", - "jest-regex-util": "^29.6.3", - "jest-util": "^29.7.0", - "micromatch": "^4.0.4", - "pirates": "^4.0.4", + "graceful-fs": "^4.2.11", + "jest-haste-map": "30.2.0", + "jest-regex-util": "30.0.1", + "jest-util": "30.2.0", + "micromatch": "^4.0.8", + "pirates": "^4.0.7", "slash": "^3.0.0", - "write-file-atomic": "^4.0.2" + "write-file-atomic": "^5.0.1" } }, "@jest/types": { - "version": "29.6.3", - "resolved": "https://registry.npmjs.org/@jest/types/-/types-29.6.3.tgz", - "integrity": "sha512-u3UPsIilWKOM3F9CXtrG8LEJmNxwoCQC/XVj4IKYXvvpx7QIi/Kg1LI5uDmDpKlac62NUtX7eLjRh+jVZcLOzw==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/@jest/types/-/types-30.2.0.tgz", + "integrity": "sha512-H9xg1/sfVvyfU7o3zMfBEjQ1gcsdeTMgqHoYdN79tuLqfTtuu7WckRA1R5whDwOzxaZAeMKTYWqP+WCAi0CHsg==", "dev": true, "requires": { - "@jest/schemas": "^29.6.3", - "@types/istanbul-lib-coverage": "^2.0.0", - "@types/istanbul-reports": "^3.0.0", + "@jest/pattern": "30.0.1", + "@jest/schemas": "30.0.5", + "@types/istanbul-lib-coverage": "^2.0.6", + "@types/istanbul-reports": "^3.0.4", "@types/node": "*", - "@types/yargs": "^17.0.8", - "chalk": "^4.0.0" + "@types/yargs": "^17.0.33", + "chalk": "^4.1.2" } }, "@jridgewell/gen-mapping": { - "version": "0.3.3", - "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.3.tgz", - "integrity": "sha512-HLhSWOLRi875zjjMG/r+Nv0oCW8umGb0BgEhyX3dDX3egwZtB8PqLnjz3yedt8R5StBrzcg4aBpnh8UA9D1BoQ==", + "version": "0.3.13", + "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.13.tgz", + "integrity": "sha512-2kkt/7niJ6MgEPxF0bYdQ6etZaA+fQvDcLKckhy1yIQOzaoKjBBjSj63/aLVjYE3qhRt5dvM+uUyfCg6UKCBbA==", "dev": true, "requires": { - "@jridgewell/set-array": "^1.0.1", - "@jridgewell/sourcemap-codec": "^1.4.10", - "@jridgewell/trace-mapping": "^0.3.9" + "@jridgewell/sourcemap-codec": "^1.5.0", + "@jridgewell/trace-mapping": "^0.3.24" } }, - "@jridgewell/resolve-uri": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz", - "integrity": "sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w==", - "dev": true + "@jridgewell/remapping": { + "version": "2.3.5", + "resolved": "https://registry.npmjs.org/@jridgewell/remapping/-/remapping-2.3.5.tgz", + "integrity": "sha512-LI9u/+laYG4Ds1TDKSJW2YPrIlcVYOwi2fUC6xB43lueCjgxV4lffOCZCtYFiH6TNOX+tQKXx97T4IKHbhyHEQ==", + "dev": true, + "requires": { + "@jridgewell/gen-mapping": "^0.3.5", + "@jridgewell/trace-mapping": "^0.3.24" + } }, - "@jridgewell/set-array": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz", - "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==", + "@jridgewell/resolve-uri": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz", + "integrity": "sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==", "dev": true }, "@jridgewell/sourcemap-codec": { - "version": "1.4.15", - "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz", - "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==", + "version": "1.5.5", + "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.5.5.tgz", + "integrity": "sha512-cYQ9310grqxueWbl+WuIUIaiUaDcj7WOq5fVhEljNVgRfOUhY9fy2zTvfoqWsnebh8Sl70VScFbICvJnLKB0Og==", "dev": true }, "@jridgewell/trace-mapping": { - "version": "0.3.18", - "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.18.tgz", - "integrity": "sha512-w+niJYzMHdd7USdiH2U6869nqhD2nbfZXND5Yp93qIbEmnDNk7PD48o+YchRVpzMU7M6jVCbenTR7PA1FLQ9pA==", + "version": "0.3.31", + "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.31.tgz", + "integrity": "sha512-zzNR+SdQSDJzc8joaeP8QQoCQr8NuYx2dIIytl1QeBEZHJ9uW6hebsrYgbz8hJwUQao3TWCMtmfV8Nu1twOLAw==", "dev": true, "requires": { - "@jridgewell/resolve-uri": "3.1.0", - "@jridgewell/sourcemap-codec": "1.4.14" - }, - "dependencies": { - "@jridgewell/sourcemap-codec": { - "version": "1.4.14", - "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz", - "integrity": "sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw==", - "dev": true - } + "@jridgewell/resolve-uri": "^3.1.0", + "@jridgewell/sourcemap-codec": "^1.4.14" + } + }, + "@napi-rs/wasm-runtime": { + "version": "0.2.12", + "resolved": "https://registry.npmjs.org/@napi-rs/wasm-runtime/-/wasm-runtime-0.2.12.tgz", + "integrity": "sha512-ZVWUcfwY4E/yPitQJl481FjFo3K22D6qF0DuFH6Y/nbnE11GY5uguDxZMGXPQ8WQ0128MXQD7TnfHyK4oWoIJQ==", + "dev": true, + "optional": true, + "requires": { + "@emnapi/core": "^1.4.3", + "@emnapi/runtime": "^1.4.3", + "@tybys/wasm-util": "^0.10.0" } }, "@octokit/auth-token": { @@ -9074,10 +8982,23 @@ "@octokit/openapi-types": "^24.2.0" } }, + "@pkgjs/parseargs": { + "version": "0.11.0", + "resolved": "https://registry.npmjs.org/@pkgjs/parseargs/-/parseargs-0.11.0.tgz", + "integrity": "sha512-+1VkjdD0QBLPodGrJUeqarH8VAIvQODIbwh9XpP5Syisf7YoQgsJKPNFoqqLQlu+VQ/tVSshMR6loPMn8U+dPg==", + "dev": true, + "optional": true + }, + "@pkgr/core": { + "version": "0.2.9", + "resolved": "https://registry.npmjs.org/@pkgr/core/-/core-0.2.9.tgz", + "integrity": "sha512-QNqXyfVS2wm9hweSYD2O7F0G06uurj9kZ96TRQE5Y9hU7+tgdZwIkbAKc5Ocy1HxEY2kuDQa6cQ1WRs/O5LFKA==", + "dev": true + }, "@sinclair/typebox": { - "version": "0.27.8", - "resolved": "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.27.8.tgz", - "integrity": "sha512-+Fj43pSMwJs4KRrH/938Uf+uAELIgVBmQzg/q1YG10djyfA3TnrU8N8XzqCh/okZdszqBQTZf96idMfE5lnwTA==", + "version": "0.34.41", + "resolved": "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.34.41.tgz", + "integrity": "sha512-6gS8pZzSXdyRHTIqoqSVknxolr1kzfy4/CeDnrzsVz8TTIWUbOBr6gnzOmTYJ3eXQNh4IYHIGi5aIL7sOZ2G/g==", "dev": true }, "@sinonjs/commons": { @@ -9090,12 +9011,12 @@ } }, "@sinonjs/fake-timers": { - "version": "10.2.0", - "resolved": "https://registry.npmjs.org/@sinonjs/fake-timers/-/fake-timers-10.2.0.tgz", - "integrity": "sha512-OPwQlEdg40HAj5KNF8WW6q2KG4Z+cBCZb3m4ninfTZKaBmbIJodviQsDBoYMPHkOyJJMHnOJo5j2+LKDOhOACg==", + "version": "13.0.5", + "resolved": "https://registry.npmjs.org/@sinonjs/fake-timers/-/fake-timers-13.0.5.tgz", + "integrity": "sha512-36/hTbH2uaWuGVERyC6da9YwGWnzUZXuPro/F2LfsdOsLnCojz/iSH8MxUt/FD2S5XBSVPhmArFUXcpCQ2Hkiw==", "dev": true, "requires": { - "@sinonjs/commons": "^3.0.0" + "@sinonjs/commons": "^3.0.1" } }, "@testing-library/dom": { @@ -9136,6 +9057,16 @@ } } }, + "@tybys/wasm-util": { + "version": "0.10.1", + "resolved": "https://registry.npmjs.org/@tybys/wasm-util/-/wasm-util-0.10.1.tgz", + "integrity": "sha512-9tTaPJLSiejZKx+Bmog4uSubteqTvFrVrURwkmHixBo0G4seD0zUxp98E1DzUBJxLQ3NPwXrGKDiVjwx/DpPsg==", + "dev": true, + "optional": true, + "requires": { + "tslib": "^2.4.0" + } + }, "@types/aria-query": { "version": "5.0.1", "resolved": "https://registry.npmjs.org/@types/aria-query/-/aria-query-5.0.1.tgz", @@ -9143,9 +9074,9 @@ "dev": true }, "@types/babel__core": { - "version": "7.20.2", - "resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.20.2.tgz", - "integrity": "sha512-pNpr1T1xLUc2l3xJKuPtsEky3ybxN3m4fJkknfIpTCTfIZCDW57oAg+EfCgIIp2rvCe0Wn++/FfodDS4YXxBwA==", + "version": "7.20.5", + "resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.20.5.tgz", + "integrity": "sha512-qoQprZvz5wQFJwMDqeseRXWv3rqMvhgpbXFfVyWhbx9X47POIA6i/+dXefEmZKoAgOaTdaIgNSMqMIU61yRyzA==", "dev": true, "requires": { "@babel/parser": "^7.20.7", @@ -9156,18 +9087,18 @@ } }, "@types/babel__generator": { - "version": "7.6.5", - "resolved": "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.6.5.tgz", - "integrity": "sha512-h9yIuWbJKdOPLJTbmSpPzkF67e659PbQDba7ifWm5BJ8xTv+sDmS7rFmywkWOvXedGTivCdeGSIIX8WLcRTz8w==", + "version": "7.27.0", + "resolved": "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.27.0.tgz", + "integrity": "sha512-ufFd2Xi92OAVPYsy+P4n7/U7e68fex0+Ee8gSG9KX7eo084CWiQ4sdxktvdl0bOPupXtVJPY19zk6EwWqUQ8lg==", "dev": true, "requires": { "@babel/types": "^7.0.0" } }, "@types/babel__template": { - "version": "7.4.2", - "resolved": "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.4.2.tgz", - "integrity": "sha512-/AVzPICMhMOMYoSx9MoKpGDKdBRsIXMNByh1PXSZoa+v6ZoLa8xxtsT/uLQ/NJm0XVAWl/BvId4MlDeXJaeIZQ==", + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.4.4.tgz", + "integrity": "sha512-h/NUaSyG5EyxBIp8YRxo4RMe2/qQgvyowRwVMzhYhBCONbW8PUsg4lkFMrhgZhUe5z3L3MiLDuvyJ/CaPa2A8A==", "dev": true, "requires": { "@babel/parser": "^7.1.0", @@ -9175,12 +9106,12 @@ } }, "@types/babel__traverse": { - "version": "7.20.2", - "resolved": "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.20.2.tgz", - "integrity": "sha512-ojlGK1Hsfce93J0+kn3H5R73elidKUaZonirN33GSmgTUMpzI/MIFfSpF3haANe3G1bEBS9/9/QEqwTzwqFsKw==", + "version": "7.28.0", + "resolved": "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.28.0.tgz", + "integrity": "sha512-8PvcXf70gTDZBgt9ptxJ8elBeBjcLOAcOtoO/mPJjtji1+CdGbHgm77om1GrsPxsiE+uXIpNSK64UYaIwQXd4Q==", "dev": true, "requires": { - "@babel/types": "^7.20.7" + "@babel/types": "^7.28.2" } }, "@types/estree": { @@ -9189,15 +9120,6 @@ "integrity": "sha512-dWHzHa2WqEXI/O1E9OjrocMTKJl2mSrEolh1Iomrv6U+JuNwaHXsXx9bLu5gG7BUWFIN0skIQJQ/L1rIex4X6w==", "dev": true }, - "@types/graceful-fs": { - "version": "4.1.6", - "resolved": "https://registry.npmjs.org/@types/graceful-fs/-/graceful-fs-4.1.6.tgz", - "integrity": "sha512-Sig0SNORX9fdW+bQuTEovKj3uHcUL6LQKbCrrqb1X7J6/ReAbhCXRAhc+SMejhLELFj2QcyuxmUooZ4bt5ReSw==", - "dev": true, - "requires": { - "@types/node": "*" - } - }, "@types/istanbul-lib-coverage": { "version": "2.0.6", "resolved": "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.6.tgz", @@ -9278,6 +9200,148 @@ "integrity": "sha512-bHGGJyVjSE4dJJIO5yyEWt/cHyNwga/zXGJbJJ8TiO01aVREK6gCTu3L+5wrkb1FbDkQ+TKjMNe9R/QQQP9+rA==", "dev": true }, + "@ungap/structured-clone": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/@ungap/structured-clone/-/structured-clone-1.3.0.tgz", + "integrity": "sha512-WmoN8qaIAo7WTYWbAZuG8PYEhn5fkz7dZrqTBZ7dtt//lL2Gwms1IcnQ5yHqjDfX8Ft5j4YzDM23f87zBfDe9g==", + "dev": true + }, + "@unrs/resolver-binding-android-arm-eabi": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-android-arm-eabi/-/resolver-binding-android-arm-eabi-1.11.1.tgz", + "integrity": "sha512-ppLRUgHVaGRWUx0R0Ut06Mjo9gBaBkg3v/8AxusGLhsIotbBLuRk51rAzqLC8gq6NyyAojEXglNjzf6R948DNw==", + "dev": true, + "optional": true + }, + "@unrs/resolver-binding-android-arm64": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-android-arm64/-/resolver-binding-android-arm64-1.11.1.tgz", + "integrity": "sha512-lCxkVtb4wp1v+EoN+HjIG9cIIzPkX5OtM03pQYkG+U5O/wL53LC4QbIeazgiKqluGeVEeBlZahHalCaBvU1a2g==", + "dev": true, + "optional": true + }, + "@unrs/resolver-binding-darwin-arm64": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-darwin-arm64/-/resolver-binding-darwin-arm64-1.11.1.tgz", + "integrity": "sha512-gPVA1UjRu1Y/IsB/dQEsp2V1pm44Of6+LWvbLc9SDk1c2KhhDRDBUkQCYVWe6f26uJb3fOK8saWMgtX8IrMk3g==", + "dev": true, + "optional": true + }, + "@unrs/resolver-binding-darwin-x64": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-darwin-x64/-/resolver-binding-darwin-x64-1.11.1.tgz", + "integrity": "sha512-cFzP7rWKd3lZaCsDze07QX1SC24lO8mPty9vdP+YVa3MGdVgPmFc59317b2ioXtgCMKGiCLxJ4HQs62oz6GfRQ==", + "dev": true, + "optional": true + }, + "@unrs/resolver-binding-freebsd-x64": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-freebsd-x64/-/resolver-binding-freebsd-x64-1.11.1.tgz", + "integrity": "sha512-fqtGgak3zX4DCB6PFpsH5+Kmt/8CIi4Bry4rb1ho6Av2QHTREM+47y282Uqiu3ZRF5IQioJQ5qWRV6jduA+iGw==", + "dev": true, + "optional": true + }, + "@unrs/resolver-binding-linux-arm-gnueabihf": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-linux-arm-gnueabihf/-/resolver-binding-linux-arm-gnueabihf-1.11.1.tgz", + "integrity": "sha512-u92mvlcYtp9MRKmP+ZvMmtPN34+/3lMHlyMj7wXJDeXxuM0Vgzz0+PPJNsro1m3IZPYChIkn944wW8TYgGKFHw==", + "dev": true, + "optional": true + }, + "@unrs/resolver-binding-linux-arm-musleabihf": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-linux-arm-musleabihf/-/resolver-binding-linux-arm-musleabihf-1.11.1.tgz", + "integrity": "sha512-cINaoY2z7LVCrfHkIcmvj7osTOtm6VVT16b5oQdS4beibX2SYBwgYLmqhBjA1t51CarSaBuX5YNsWLjsqfW5Cw==", + "dev": true, + "optional": true + }, + "@unrs/resolver-binding-linux-arm64-gnu": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-linux-arm64-gnu/-/resolver-binding-linux-arm64-gnu-1.11.1.tgz", + "integrity": "sha512-34gw7PjDGB9JgePJEmhEqBhWvCiiWCuXsL9hYphDF7crW7UgI05gyBAi6MF58uGcMOiOqSJ2ybEeCvHcq0BCmQ==", + "dev": true, + "optional": true + }, + "@unrs/resolver-binding-linux-arm64-musl": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-linux-arm64-musl/-/resolver-binding-linux-arm64-musl-1.11.1.tgz", + "integrity": "sha512-RyMIx6Uf53hhOtJDIamSbTskA99sPHS96wxVE/bJtePJJtpdKGXO1wY90oRdXuYOGOTuqjT8ACccMc4K6QmT3w==", + "dev": true, + "optional": true + }, + "@unrs/resolver-binding-linux-ppc64-gnu": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-linux-ppc64-gnu/-/resolver-binding-linux-ppc64-gnu-1.11.1.tgz", + "integrity": "sha512-D8Vae74A4/a+mZH0FbOkFJL9DSK2R6TFPC9M+jCWYia/q2einCubX10pecpDiTmkJVUH+y8K3BZClycD8nCShA==", + "dev": true, + "optional": true + }, + "@unrs/resolver-binding-linux-riscv64-gnu": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-linux-riscv64-gnu/-/resolver-binding-linux-riscv64-gnu-1.11.1.tgz", + "integrity": "sha512-frxL4OrzOWVVsOc96+V3aqTIQl1O2TjgExV4EKgRY09AJ9leZpEg8Ak9phadbuX0BA4k8U5qtvMSQQGGmaJqcQ==", + "dev": true, + "optional": true + }, + "@unrs/resolver-binding-linux-riscv64-musl": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-linux-riscv64-musl/-/resolver-binding-linux-riscv64-musl-1.11.1.tgz", + "integrity": "sha512-mJ5vuDaIZ+l/acv01sHoXfpnyrNKOk/3aDoEdLO/Xtn9HuZlDD6jKxHlkN8ZhWyLJsRBxfv9GYM2utQ1SChKew==", + "dev": true, + "optional": true + }, + "@unrs/resolver-binding-linux-s390x-gnu": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-linux-s390x-gnu/-/resolver-binding-linux-s390x-gnu-1.11.1.tgz", + "integrity": "sha512-kELo8ebBVtb9sA7rMe1Cph4QHreByhaZ2QEADd9NzIQsYNQpt9UkM9iqr2lhGr5afh885d/cB5QeTXSbZHTYPg==", + "dev": true, + "optional": true + }, + "@unrs/resolver-binding-linux-x64-gnu": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-linux-x64-gnu/-/resolver-binding-linux-x64-gnu-1.11.1.tgz", + "integrity": "sha512-C3ZAHugKgovV5YvAMsxhq0gtXuwESUKc5MhEtjBpLoHPLYM+iuwSj3lflFwK3DPm68660rZ7G8BMcwSro7hD5w==", + "dev": true, + "optional": true + }, + "@unrs/resolver-binding-linux-x64-musl": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-linux-x64-musl/-/resolver-binding-linux-x64-musl-1.11.1.tgz", + "integrity": "sha512-rV0YSoyhK2nZ4vEswT/QwqzqQXw5I6CjoaYMOX0TqBlWhojUf8P94mvI7nuJTeaCkkds3QE4+zS8Ko+GdXuZtA==", + "dev": true, + "optional": true + }, + "@unrs/resolver-binding-wasm32-wasi": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-wasm32-wasi/-/resolver-binding-wasm32-wasi-1.11.1.tgz", + "integrity": "sha512-5u4RkfxJm+Ng7IWgkzi3qrFOvLvQYnPBmjmZQ8+szTK/b31fQCnleNl1GgEt7nIsZRIf5PLhPwT0WM+q45x/UQ==", + "dev": true, + "optional": true, + "requires": { + "@napi-rs/wasm-runtime": "^0.2.11" + } + }, + "@unrs/resolver-binding-win32-arm64-msvc": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-win32-arm64-msvc/-/resolver-binding-win32-arm64-msvc-1.11.1.tgz", + "integrity": "sha512-nRcz5Il4ln0kMhfL8S3hLkxI85BXs3o8EYoattsJNdsX4YUU89iOkVn7g0VHSRxFuVMdM4Q1jEpIId1Ihim/Uw==", + "dev": true, + "optional": true + }, + "@unrs/resolver-binding-win32-ia32-msvc": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-win32-ia32-msvc/-/resolver-binding-win32-ia32-msvc-1.11.1.tgz", + "integrity": "sha512-DCEI6t5i1NmAZp6pFonpD5m7i6aFrpofcp4LA2i8IIq60Jyo28hamKBxNrZcyOwVOZkgsRp9O2sXWBWP8MnvIQ==", + "dev": true, + "optional": true + }, + "@unrs/resolver-binding-win32-x64-msvc": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/@unrs/resolver-binding-win32-x64-msvc/-/resolver-binding-win32-x64-msvc-1.11.1.tgz", + "integrity": "sha512-lrW200hZdbfRtztbygyaq/6jP6AKE8qQN2KvPcJ+x7wiD038YtnYtZ82IMNJ69GJibV7bwL3y9FgK+5w/pYt6g==", + "dev": true, + "optional": true + }, "@uppercod/css-to-object": { "version": "1.1.1", "resolved": "https://registry.npmjs.org/@uppercod/css-to-object/-/css-to-object-1.1.1.tgz", @@ -9423,73 +9487,73 @@ } }, "babel-jest": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/babel-jest/-/babel-jest-29.7.0.tgz", - "integrity": "sha512-BrvGY3xZSwEcCzKvKsCi2GgHqDqsYkOP4/by5xCgIwGXQxIEh+8ew3gmrE1y7XRR6LHZIj6yLYnUi/mm2KXKBg==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/babel-jest/-/babel-jest-30.2.0.tgz", + "integrity": "sha512-0YiBEOxWqKkSQWL9nNGGEgndoeL0ZpWrbLMNL5u/Kaxrli3Eaxlt3ZtIDktEvXt4L/R9r3ODr2zKwGM/2BjxVw==", "dev": true, "requires": { - "@jest/transform": "^29.7.0", - "@types/babel__core": "^7.1.14", - "babel-plugin-istanbul": "^6.1.1", - "babel-preset-jest": "^29.6.3", - "chalk": "^4.0.0", - "graceful-fs": "^4.2.9", + "@jest/transform": "30.2.0", + "@types/babel__core": "^7.20.5", + "babel-plugin-istanbul": "^7.0.1", + "babel-preset-jest": "30.2.0", + "chalk": "^4.1.2", + "graceful-fs": "^4.2.11", "slash": "^3.0.0" } }, "babel-plugin-istanbul": { - "version": "6.1.1", - "resolved": "https://registry.npmjs.org/babel-plugin-istanbul/-/babel-plugin-istanbul-6.1.1.tgz", - "integrity": "sha512-Y1IQok9821cC9onCx5otgFfRm7Lm+I+wwxOx738M/WLPZ9Q42m4IG5W0FNX8WLL2gYMZo3JkuXIH2DOpWM+qwA==", + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/babel-plugin-istanbul/-/babel-plugin-istanbul-7.0.1.tgz", + "integrity": "sha512-D8Z6Qm8jCvVXtIRkBnqNHX0zJ37rQcFJ9u8WOS6tkYOsRdHBzypCstaxWiu5ZIlqQtviRYbgnRLSoCEvjqcqbA==", "dev": true, "requires": { "@babel/helper-plugin-utils": "^7.0.0", "@istanbuljs/load-nyc-config": "^1.0.0", - "@istanbuljs/schema": "^0.1.2", - "istanbul-lib-instrument": "^5.0.4", + "@istanbuljs/schema": "^0.1.3", + "istanbul-lib-instrument": "^6.0.2", "test-exclude": "^6.0.0" } }, "babel-plugin-jest-hoist": { - "version": "29.6.3", - "resolved": "https://registry.npmjs.org/babel-plugin-jest-hoist/-/babel-plugin-jest-hoist-29.6.3.tgz", - "integrity": "sha512-ESAc/RJvGTFEzRwOTT4+lNDk/GNHMkKbNzsvT0qKRfDyyYTskxB5rnU2njIDYVxXCBHHEI1c0YwHob3WaYujOg==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/babel-plugin-jest-hoist/-/babel-plugin-jest-hoist-30.2.0.tgz", + "integrity": "sha512-ftzhzSGMUnOzcCXd6WHdBGMyuwy15Wnn0iyyWGKgBDLxf9/s5ABuraCSpBX2uG0jUg4rqJnxsLc5+oYBqoxVaA==", "dev": true, "requires": { - "@babel/template": "^7.3.3", - "@babel/types": "^7.3.3", - "@types/babel__core": "^7.1.14", - "@types/babel__traverse": "^7.0.6" + "@types/babel__core": "^7.20.5" } }, "babel-preset-current-node-syntax": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/babel-preset-current-node-syntax/-/babel-preset-current-node-syntax-1.0.1.tgz", - "integrity": "sha512-M7LQ0bxarkxQoN+vz5aJPsLBn77n8QgTFmo8WK0/44auK2xlCXrYcUxHFxgU7qW5Yzw/CjmLRK2uJzaCd7LvqQ==", + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/babel-preset-current-node-syntax/-/babel-preset-current-node-syntax-1.2.0.tgz", + "integrity": "sha512-E/VlAEzRrsLEb2+dv8yp3bo4scof3l9nR4lrld+Iy5NyVqgVYUJnDAmunkhPMisRI32Qc4iRiz425d8vM++2fg==", "dev": true, "requires": { "@babel/plugin-syntax-async-generators": "^7.8.4", "@babel/plugin-syntax-bigint": "^7.8.3", - "@babel/plugin-syntax-class-properties": "^7.8.3", - "@babel/plugin-syntax-import-meta": "^7.8.3", + "@babel/plugin-syntax-class-properties": "^7.12.13", + "@babel/plugin-syntax-class-static-block": "^7.14.5", + "@babel/plugin-syntax-import-attributes": "^7.24.7", + "@babel/plugin-syntax-import-meta": "^7.10.4", "@babel/plugin-syntax-json-strings": "^7.8.3", - "@babel/plugin-syntax-logical-assignment-operators": "^7.8.3", + "@babel/plugin-syntax-logical-assignment-operators": "^7.10.4", "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3", - "@babel/plugin-syntax-numeric-separator": "^7.8.3", + "@babel/plugin-syntax-numeric-separator": "^7.10.4", "@babel/plugin-syntax-object-rest-spread": "^7.8.3", "@babel/plugin-syntax-optional-catch-binding": "^7.8.3", "@babel/plugin-syntax-optional-chaining": "^7.8.3", - "@babel/plugin-syntax-top-level-await": "^7.8.3" + "@babel/plugin-syntax-private-property-in-object": "^7.14.5", + "@babel/plugin-syntax-top-level-await": "^7.14.5" } }, "babel-preset-jest": { - "version": "29.6.3", - "resolved": "https://registry.npmjs.org/babel-preset-jest/-/babel-preset-jest-29.6.3.tgz", - "integrity": "sha512-0B3bhxR6snWXJZtR/RliHTDPRgn1sNHOR0yVtq/IiQFyuOVjFS+wuio/R4gSNkyYmKmJB4wGZv2NZanmKmTnNA==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/babel-preset-jest/-/babel-preset-jest-30.2.0.tgz", + "integrity": "sha512-US4Z3NOieAQumwFnYdUWKvUKh8+YSnS/gB3t6YBiz0bskpu7Pine8pPCheNxlPEW4wnUkma2a94YuW2q3guvCQ==", "dev": true, "requires": { - "babel-plugin-jest-hoist": "^29.6.3", - "babel-preset-current-node-syntax": "^1.0.0" + "babel-plugin-jest-hoist": "30.2.0", + "babel-preset-current-node-syntax": "^1.2.0" } }, "balanced-match": { @@ -9498,6 +9562,12 @@ "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", "dev": true }, + "baseline-browser-mapping": { + "version": "2.8.16", + "resolved": "https://registry.npmjs.org/baseline-browser-mapping/-/baseline-browser-mapping-2.8.16.tgz", + "integrity": "sha512-OMu3BGQ4E7P1ErFsIPpbJh0qvDudM/UuJeHgkAvfWe+0HFJCXh+t/l8L6fVLR55RI/UbKrVLnAXZSVwd9ysWYw==", + "dev": true + }, "before-after-hook": { "version": "2.2.3", "resolved": "https://registry.npmjs.org/before-after-hook/-/before-after-hook-2.2.3.tgz", @@ -9541,15 +9611,16 @@ } }, "browserslist": { - "version": "4.21.10", - "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.21.10.tgz", - "integrity": "sha512-bipEBdZfVH5/pwrvqc+Ub0kUPVfGUhlKxbvfD+z1BDnPEO/X98ruXGA1WP5ASpAFKan7Qr6j736IacbZQuAlKQ==", + "version": "4.26.3", + "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.26.3.tgz", + "integrity": "sha512-lAUU+02RFBuCKQPj/P6NgjlbCnLBMp4UtgTx7vNHd3XSIJF87s9a5rA3aH2yw3GS9DqZAUbOtZdCCiZeVRqt0w==", "dev": true, "requires": { - "caniuse-lite": "^1.0.30001517", - "electron-to-chromium": "^1.4.477", - "node-releases": "^2.0.13", - "update-browserslist-db": "^1.0.11" + "baseline-browser-mapping": "^2.8.9", + "caniuse-lite": "^1.0.30001746", + "electron-to-chromium": "^1.5.227", + "node-releases": "^2.0.21", + "update-browserslist-db": "^1.1.3" } }, "bser": { @@ -9605,9 +9676,9 @@ "dev": true }, "caniuse-lite": { - "version": "1.0.30001518", - "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001518.tgz", - "integrity": "sha512-rup09/e3I0BKjncL+FesTayKtPrdwKhUufQFd3riFw1hHg8JmIFoInYfB102cFcY/pPgGmdyl/iy+jgiDi2vdA==", + "version": "1.0.30001749", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001749.tgz", + "integrity": "sha512-0rw2fJOmLfnzCRbkm8EyHL8SvI2Apu5UbnQuTsJ0ClgrH8hcwFooJ1s5R0EP8o8aVrFu8++ae29Kt9/gZAZp/Q==", "dev": true }, "chalk": { @@ -9627,15 +9698,15 @@ "dev": true }, "ci-info": { - "version": "3.8.0", - "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-3.8.0.tgz", - "integrity": "sha512-eXTggHWSooYhq49F2opQhuHWgzucfF2YgODK4e1566GQs5BIfP30B0oenwBJHfWxAs2fyPB1s7Mg949zLf61Yw==", + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-4.3.1.tgz", + "integrity": "sha512-Wdy2Igu8OcBpI2pZePZ5oWjPC38tmDVx5WKUXKwlLYkA0ozo85sLsLvkBbBn/sZaSCMFOGZJ14fvW9t5/d7kdA==", "dev": true }, "cjs-module-lexer": { - "version": "1.2.3", - "resolved": "https://registry.npmjs.org/cjs-module-lexer/-/cjs-module-lexer-1.2.3.tgz", - "integrity": "sha512-0TNiGstbQmCFwt4akjjBg5pLRTSyj/PkWQ1ZoO2zntmg9yLqSRxwEa4iCfQLGjqhiqBfOJa7W/E8wfGrTDmlZQ==", + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/cjs-module-lexer/-/cjs-module-lexer-2.1.0.tgz", + "integrity": "sha512-UX0OwmYRYQQetfrLEZeewIFFI+wSTofC+pMBLNuH3RUuu/xzG1oz84UCEDOSoQlN3fZ4+AzmV50ZYvGqkMh9yA==", "dev": true }, "cli-cursor": { @@ -9657,12 +9728,6 @@ "string-width": "^8.0.0" }, "dependencies": { - "ansi-regex": { - "version": "6.2.2", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.2.2.tgz", - "integrity": "sha512-Bq3SmSpyFHaWjPk8If9yc6svM8c56dB5BAtW4Qbw5jHTwwXXcTLoRMkpDJp6VL0XzlWaCHTXrkFURMYmD0sLqg==", - "dev": true - }, "string-width": { "version": "8.1.0", "resolved": "https://registry.npmjs.org/string-width/-/string-width-8.1.0.tgz", @@ -9672,15 +9737,6 @@ "get-east-asian-width": "^1.3.0", "strip-ansi": "^7.1.0" } - }, - "strip-ansi": { - "version": "7.1.2", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.2.tgz", - "integrity": "sha512-gmBGslpoQJtgnMAvOVqGZpEz9dyoKTCzy2nfz/n8aIFhN/jCE/rCmcxabB6jOOHV+0WNnylOxaxBQPSvcWklhA==", - "dev": true, - "requires": { - "ansi-regex": "^6.0.1" - } } } }, @@ -9693,6 +9749,45 @@ "string-width": "^4.2.0", "strip-ansi": "^6.0.1", "wrap-ansi": "^7.0.0" + }, + "dependencies": { + "emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "dev": true + }, + "string-width": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", + "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", + "dev": true, + "requires": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.1" + } + }, + "strip-ansi": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", + "dev": true, + "requires": { + "ansi-regex": "^5.0.1" + } + }, + "wrap-ansi": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", + "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", + "dev": true, + "requires": { + "ansi-styles": "^4.0.0", + "string-width": "^4.1.0", + "strip-ansi": "^6.0.0" + } + } } }, "co": { @@ -9793,21 +9888,6 @@ "integrity": "sha512-D76uU73ulSXrD1UXF4KE2TMxVVwhsnCgfAyTg9k8P6KGZjlXKrOLe4dJQKI3Bxi5wjesZoFXJWElNWBjPZMbhg==", "dev": true }, - "create-jest": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/create-jest/-/create-jest-29.7.0.tgz", - "integrity": "sha512-Adz2bdH0Vq3F53KEMJOoftQFutWCukm6J24wbPWRO4k1kMY7gS7ds/uoJkNuV8wDCtWWnuwGcJwpWcih+zEW1Q==", - "dev": true, - "requires": { - "@jest/types": "^29.6.3", - "chalk": "^4.0.0", - "exit": "^0.1.2", - "graceful-fs": "^4.2.9", - "jest-config": "^29.7.0", - "jest-util": "^29.7.0", - "prompts": "^2.0.1" - } - }, "cross-spawn": { "version": "7.0.6", "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.6.tgz", @@ -9861,9 +9941,9 @@ "dev": true }, "dedent": { - "version": "1.5.1", - "resolved": "https://registry.npmjs.org/dedent/-/dedent-1.5.1.tgz", - "integrity": "sha512-+LxW+KLWxu3HW3M2w2ympwtqPrqYRzU8fqi6Fhd18fBALe15blJPI/I4+UHveMVG6lJqB4JNd4UG0S5cnVHwIg==", + "version": "1.7.0", + "resolved": "https://registry.npmjs.org/dedent/-/dedent-1.7.0.tgz", + "integrity": "sha512-HGFtf8yhuhGhqO07SV79tRp+br4MnbdjeVxotpn1QBl30pcLLCQjX5b2295ll0fv8RKDKsmWYrl05usHM9CewQ==", "dev": true, "requires": {} }, @@ -9908,12 +9988,6 @@ "integrity": "sha512-TLz+x/vEXm/Y7P7wn1EJFNLxYpUD4TgMosxY6fAVJUnJMbupHBOncxyWUG9OpTaH9EBD7uFI5LfEgmMOc54DsA==", "dev": true }, - "diff-sequences": { - "version": "29.6.3", - "resolved": "https://registry.npmjs.org/diff-sequences/-/diff-sequences-29.6.3.tgz", - "integrity": "sha512-EjePK1srD3P08o2j4f0ExnylqRs5B9tJjcp9t1krH2qRi8CCdsYfwe9JgSLurFBWwq4uOlipzfk5fHNvwFKr8Q==", - "dev": true - }, "dom-accessibility-api": { "version": "0.5.14", "resolved": "https://registry.npmjs.org/dom-accessibility-api/-/dom-accessibility-api-0.5.14.tgz", @@ -9935,6 +10009,12 @@ "gopd": "^1.2.0" } }, + "eastasianwidth": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/eastasianwidth/-/eastasianwidth-0.2.0.tgz", + "integrity": "sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA==", + "dev": true + }, "ee-first": { "version": "1.1.1", "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", @@ -9942,9 +10022,9 @@ "dev": true }, "electron-to-chromium": { - "version": "1.4.478", - "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.478.tgz", - "integrity": "sha512-qjTA8djMXd+ruoODDFGnRCRBpID+AAfYWCyGtYTNhsuwxI19s8q19gbjKTwRS5z/LyVf5wICaIiPQGLekmbJbA==", + "version": "1.5.234", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.5.234.tgz", + "integrity": "sha512-RXfEp2x+VRYn8jbKfQlRImzoJU01kyDvVPBmG39eU2iuRVhuS6vQNocB8J0/8GrIMLnPzgz4eW6WiRnJkTuNWg==", "dev": true }, "emittery": { @@ -9959,9 +10039,9 @@ "integrity": "sha512-3KBuQuhYkRtLd9utBKfTtclbWP3IytC1FNcXg+NKARltPSYpkg/MLiklGv4vLwl8A8jMQjdneXNBYx8k0rrg+g==" }, "emoji-regex": { - "version": "8.0.0", - "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", - "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "version": "9.2.2", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-9.2.2.tgz", + "integrity": "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==", "dev": true }, "encodeurl": { @@ -9983,9 +10063,9 @@ "dev": true }, "error-ex": { - "version": "1.3.2", - "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", - "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", + "version": "1.3.4", + "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.4.tgz", + "integrity": "sha512-sqQamAnR14VgCr1A618A3sGrygcpK+HEbenA/HiEAkkUwcZIIB/tgWqHFxWgOyDh4nB4JCRimh79dR5Ywc9MDQ==", "dev": true, "requires": { "is-arrayish": "^0.2.1" @@ -10021,9 +10101,9 @@ } }, "escalade": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", - "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.2.0.tgz", + "integrity": "sha512-WUj2qlxaQtO4g6Pq5c29GTcWGDyd8itL8zTlipgECz3JesAiiOKotd8JU6otB3PACgG6xkJUyVhboMS+bje/jA==", "dev": true }, "escape-html": { @@ -10081,12 +10161,6 @@ "optionator": "^0.9.3" }, "dependencies": { - "@eslint/js": { - "version": "9.36.0", - "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.36.0.tgz", - "integrity": "sha512-uhCbYtYynH30iZErszX78U+nR3pJU3RHGQ57NXy5QupD4SBVwDeU8TNBy+MjMngc1UyIW9noKqsRqfjQTBU2dw==", - "dev": true - }, "escape-string-regexp": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", @@ -10282,25 +10356,34 @@ "onetime": "^5.1.2", "signal-exit": "^3.0.3", "strip-final-newline": "^2.0.0" + }, + "dependencies": { + "signal-exit": { + "version": "3.0.7", + "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", + "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", + "dev": true + } } }, - "exit": { - "version": "0.1.2", - "resolved": "https://registry.npmjs.org/exit/-/exit-0.1.2.tgz", - "integrity": "sha512-Zk/eNKV2zbjpKzrsQ+n1G6poVbErQxJ0LBOJXaKZ1EViLzH+hrLu9cdXI4zw9dBQJslwBEpbQ2P1oS7nDxs6jQ==", + "exit-x": { + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/exit-x/-/exit-x-0.2.2.tgz", + "integrity": "sha512-+I6B/IkJc1o/2tiURyz/ivu/O0nKNEArIUB5O7zBrlDVJr22SCLH3xTeEry428LvFhRzIA1g8izguxJ/gbNcVQ==", "dev": true }, "expect": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/expect/-/expect-29.7.0.tgz", - "integrity": "sha512-2Zks0hf1VLFYI1kbh0I5jP3KHHyCHpkfyHBzsSXRFgl/Bg9mWYfMW8oD+PdMPlEwy5HNsR9JutYy6pMeOh61nw==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/expect/-/expect-30.2.0.tgz", + "integrity": "sha512-u/feCi0GPsI+988gU2FLcsHyAHTU0MX1Wg68NhAnN7z/+C5wqG+CY8J53N9ioe8RXgaoz0nBR/TYMf3AycUuPw==", "dev": true, "requires": { - "@jest/expect-utils": "^29.7.0", - "jest-get-type": "^29.6.3", - "jest-matcher-utils": "^29.7.0", - "jest-message-util": "^29.7.0", - "jest-util": "^29.7.0" + "@jest/expect-utils": "30.2.0", + "@jest/get-type": "30.1.0", + "jest-matcher-utils": "30.2.0", + "jest-message-util": "30.2.0", + "jest-mock": "30.2.0", + "jest-util": "30.2.0" } }, "express": { @@ -10445,6 +10528,16 @@ "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.6.tgz", "integrity": "sha512-wWN62YITEaOpSK584EZXJafH1AGpO8RVgElfkuXbTOrPX4fIfOyEpW/CsiNd8JdYrAoOvafRTOEnvsO++qCqFA==" }, + "foreground-child": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/foreground-child/-/foreground-child-3.3.1.tgz", + "integrity": "sha512-gIXjKqtFuWEgzFRJA9WCQeSJLZDjgJUOMCMzxtvFq/37KojM1BFGufqsCy0r4qSQmYLsZYMeyRqzIWOMup03sw==", + "dev": true, + "requires": { + "cross-spawn": "^7.0.6", + "signal-exit": "^4.0.1" + } + }, "form-data": { "version": "4.0.4", "resolved": "https://registry.npmjs.org/form-data/-/form-data-4.0.4.tgz", @@ -10549,17 +10642,37 @@ "integrity": "sha512-EqDVkN0/5MQyDPOSDLInVRRXdeISRfcN1UW/1FUqD2knV1HHw8DndMB3UPNn5lO51DvRnjzbLXwWqNNV86PLOw==" }, "glob": { - "version": "7.2.3", - "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", - "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", + "version": "10.4.5", + "resolved": "https://registry.npmjs.org/glob/-/glob-10.4.5.tgz", + "integrity": "sha512-7Bv8RF0k6xjo7d4A/PxYLbUCfb6c+Vpd2/mB2yRDlew7Jb5hEXiCD9ibfO7wpk8i4sevK6DFny9h7EYbM3/sHg==", "dev": true, "requires": { - "fs.realpath": "^1.0.0", - "inflight": "^1.0.4", - "inherits": "2", - "minimatch": "^3.1.1", - "once": "^1.3.0", - "path-is-absolute": "^1.0.0" + "foreground-child": "^3.1.0", + "jackspeak": "^3.1.2", + "minimatch": "^9.0.4", + "minipass": "^7.1.2", + "package-json-from-dist": "^1.0.0", + "path-scurry": "^1.11.1" + }, + "dependencies": { + "brace-expansion": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.2.tgz", + "integrity": "sha512-Jt0vHyM+jmUBqojB7E1NIYadt0vI0Qxjxd2TErW94wDz+E2LAm5vKMXXwg6ZZBTHPuUlDgQHKXvjGBdfcF1ZDQ==", + "dev": true, + "requires": { + "balanced-match": "^1.0.0" + } + }, + "minimatch": { + "version": "9.0.5", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.5.tgz", + "integrity": "sha512-G6T0ZX48xgozx7587koeX9Ys2NYy6Gmv//P89sEte9V9whIapMNF4idKxnW2QtCcLiTWlb/wfCabAtAFWhhBow==", + "dev": true, + "requires": { + "brace-expansion": "^2.0.1" + } + } } }, "glob-parent": { @@ -10588,15 +10701,6 @@ "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==", "dev": true }, - "has": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", - "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", - "dev": true, - "requires": { - "function-bind": "^1.1.1" - } - }, "has-flag": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", @@ -10738,9 +10842,9 @@ } }, "import-local": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/import-local/-/import-local-3.1.0.tgz", - "integrity": "sha512-ASB07uLtnDs1o6EHjKpX34BKYDSqnFerfTOJL2HvMqF70LnxpjkzDB8J44oT9pu4AMPkQwf8jl6szgvNd2tRIg==", + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/import-local/-/import-local-3.2.0.tgz", + "integrity": "sha512-2SPlun1JUPWoM6t3F0dw0FkCF/jWY8kttcY4f599GLTSjh2OCuuhdTkJQsEcZzBqbXZGKMK2OqW1oZsjtf/gQA==", "dev": true, "requires": { "pkg-dir": "^4.2.0", @@ -10793,15 +10897,6 @@ "integrity": "sha512-i2R6zNFDwgEHJyQUtJEk0XFi1i0dPFn/oqjK3/vPCcDeJvW5NQ83V8QbicfF1SupOaB0h8ntgBC2YiE7dfyctQ==", "dev": true }, - "is-core-module": { - "version": "2.13.0", - "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.13.0.tgz", - "integrity": "sha512-Z7dk6Qo8pOCp3l4tsX2C5ZVas4V+UxwQodwZhLopL91TX8UyyHEXafPcyoeeWuLrwzHcr3igO78wNLwHJHsMCQ==", - "dev": true, - "requires": { - "has": "^1.0.3" - } - }, "is-extglob": { "version": "2.1.1", "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", @@ -10860,22 +10955,30 @@ "dev": true }, "istanbul-lib-coverage": { - "version": "3.2.0", - "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.0.tgz", - "integrity": "sha512-eOeJ5BHCmHYvQK7xt9GkdHuzuCGS1Y6g9Gvnx3Ym33fz/HpLRYxiS0wHNr+m/MBC8B647Xt608vCDEvhl9c6Mw==", + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.2.tgz", + "integrity": "sha512-O8dpsF+r0WV/8MNRKfnmrtCWhuKjxrq2w+jpzBL5UZKTi2LeVWnWOmWRxFlesJONmc+wLAGvKQZEOanko0LFTg==", "dev": true }, "istanbul-lib-instrument": { - "version": "5.2.1", - "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-5.2.1.tgz", - "integrity": "sha512-pzqtp31nLv/XFOzXGuvhCb8qhjmTVo5vjVk19XE4CRlSWz0KoeJ3bw9XsA7nOp9YBf4qHjwBxkDzKcME/J29Yg==", + "version": "6.0.3", + "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-6.0.3.tgz", + "integrity": "sha512-Vtgk7L/R2JHyyGW07spoFlB8/lpjiOLTjMdms6AFMraYt3BaJauod/NGrfnVG/y4Ix1JEuMRPDPEj2ua+zz1/Q==", "dev": true, "requires": { - "@babel/core": "^7.12.3", - "@babel/parser": "^7.14.7", - "@istanbuljs/schema": "^0.1.2", + "@babel/core": "^7.23.9", + "@babel/parser": "^7.23.9", + "@istanbuljs/schema": "^0.1.3", "istanbul-lib-coverage": "^3.2.0", - "semver": "^6.3.0" + "semver": "^7.5.4" + }, + "dependencies": { + "semver": { + "version": "7.7.3", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.7.3.tgz", + "integrity": "sha512-SdsKMrI9TdgjdweUSR9MweHA4EJ8YxHn8DFaDisvhVlUOe4BF1tLD7GAj0lIqWVl+dPb/rExr0Btby5loQm20Q==", + "dev": true + } } }, "istanbul-lib-report": { @@ -10890,75 +10993,85 @@ } }, "istanbul-lib-source-maps": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/istanbul-lib-source-maps/-/istanbul-lib-source-maps-4.0.1.tgz", - "integrity": "sha512-n3s8EwkdFIJCG3BPKBYvskgXGoy88ARzvegkitk60NxRdwltLOTaH7CUiMRXvwYorl0Q712iEjcWB+fK/MrWVw==", + "version": "5.0.6", + "resolved": "https://registry.npmjs.org/istanbul-lib-source-maps/-/istanbul-lib-source-maps-5.0.6.tgz", + "integrity": "sha512-yg2d+Em4KizZC5niWhQaIomgf5WlL4vOOjZ5xGCmF8SnPE/mDWWXgvRExdcpCgh9lLRRa1/fSYp2ymmbJ1pI+A==", "dev": true, "requires": { + "@jridgewell/trace-mapping": "^0.3.23", "debug": "^4.1.1", - "istanbul-lib-coverage": "^3.0.0", - "source-map": "^0.6.1" + "istanbul-lib-coverage": "^3.0.0" } }, "istanbul-reports": { - "version": "3.1.6", - "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.1.6.tgz", - "integrity": "sha512-TLgnMkKg3iTDsQ9PbPTdpfAK2DzjF9mqUG7RMgcQl8oFjad8ob4laGxv5XV5U9MAfx8D6tSJiUyuAwzLicaxlg==", + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.2.0.tgz", + "integrity": "sha512-HGYWWS/ehqTV3xN10i23tkPkpH46MLCIMFNCaaKNavAXTF1RkqxawEPtnjnGZ6XKSInBKkiOA5BKS+aZiY3AvA==", "dev": true, "requires": { "html-escaper": "^2.0.0", "istanbul-lib-report": "^3.0.0" } }, + "jackspeak": { + "version": "3.4.3", + "resolved": "https://registry.npmjs.org/jackspeak/-/jackspeak-3.4.3.tgz", + "integrity": "sha512-OGlZQpz2yfahA/Rd1Y8Cd9SIEsqvXkLVoSw/cgwhnhFMDbsQFeZYoJJ7bIZBS9BcamUW96asq/npPWugM+RQBw==", + "dev": true, + "requires": { + "@isaacs/cliui": "^8.0.2", + "@pkgjs/parseargs": "^0.11.0" + } + }, "jest": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest/-/jest-29.7.0.tgz", - "integrity": "sha512-NIy3oAFp9shda19hy4HK0HRTWKtPJmGdnvywu01nOqNC2vZg+Z+fvJDxpMQA88eb2I9EcafcdjYgsDthnYTvGw==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest/-/jest-30.2.0.tgz", + "integrity": "sha512-F26gjC0yWN8uAA5m5Ss8ZQf5nDHWGlN/xWZIh8S5SRbsEKBovwZhxGd6LJlbZYxBgCYOtreSUyb8hpXyGC5O4A==", "dev": true, "requires": { - "@jest/core": "^29.7.0", - "@jest/types": "^29.6.3", - "import-local": "^3.0.2", - "jest-cli": "^29.7.0" + "@jest/core": "30.2.0", + "@jest/types": "30.2.0", + "import-local": "^3.2.0", + "jest-cli": "30.2.0" } }, "jest-changed-files": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-changed-files/-/jest-changed-files-29.7.0.tgz", - "integrity": "sha512-fEArFiwf1BpQ+4bXSprcDc3/x4HSzL4al2tozwVpDFpsxALjLYdyiIK4e5Vz66GQJIbXJ82+35PtysofptNX2w==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-changed-files/-/jest-changed-files-30.2.0.tgz", + "integrity": "sha512-L8lR1ChrRnSdfeOvTrwZMlnWV8G/LLjQ0nG9MBclwWZidA2N5FviRki0Bvh20WRMOX31/JYvzdqTJrk5oBdydQ==", "dev": true, "requires": { - "execa": "^5.0.0", - "jest-util": "^29.7.0", + "execa": "^5.1.1", + "jest-util": "30.2.0", "p-limit": "^3.1.0" } }, "jest-circus": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-circus/-/jest-circus-29.7.0.tgz", - "integrity": "sha512-3E1nCMgipcTkCocFwM90XXQab9bS+GMsjdpmPrlelaxwD93Ad8iVEjX/vvHPdLPnFf+L40u+5+iutRdA1N9myw==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-circus/-/jest-circus-30.2.0.tgz", + "integrity": "sha512-Fh0096NC3ZkFx05EP2OXCxJAREVxj1BcW/i6EWqqymcgYKWjyyDpral3fMxVcHXg6oZM7iULer9wGRFvfpl+Tg==", "dev": true, "requires": { - "@jest/environment": "^29.7.0", - "@jest/expect": "^29.7.0", - "@jest/test-result": "^29.7.0", - "@jest/types": "^29.6.3", + "@jest/environment": "30.2.0", + "@jest/expect": "30.2.0", + "@jest/test-result": "30.2.0", + "@jest/types": "30.2.0", "@types/node": "*", - "chalk": "^4.0.0", + "chalk": "^4.1.2", "co": "^4.6.0", - "dedent": "^1.0.0", - "is-generator-fn": "^2.0.0", - "jest-each": "^29.7.0", - "jest-matcher-utils": "^29.7.0", - "jest-message-util": "^29.7.0", - "jest-runtime": "^29.7.0", - "jest-snapshot": "^29.7.0", - "jest-util": "^29.7.0", + "dedent": "^1.6.0", + "is-generator-fn": "^2.1.0", + "jest-each": "30.2.0", + "jest-matcher-utils": "30.2.0", + "jest-message-util": "30.2.0", + "jest-runtime": "30.2.0", + "jest-snapshot": "30.2.0", + "jest-util": "30.2.0", "p-limit": "^3.1.0", - "pretty-format": "^29.7.0", - "pure-rand": "^6.0.0", + "pretty-format": "30.2.0", + "pure-rand": "^7.0.0", "slash": "^3.0.0", - "stack-utils": "^2.0.3" + "stack-utils": "^2.0.6" }, "dependencies": { "ansi-styles": { @@ -10968,69 +11081,70 @@ "dev": true }, "pretty-format": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-29.7.0.tgz", - "integrity": "sha512-Pdlw/oPxN+aXdmM9R00JVC9WVFoCLTKJvDVLgmJ+qAffBMxsV85l/Lu7sNx4zSzPyoL2euImuEwHhOXdEgNFZQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.2.0.tgz", + "integrity": "sha512-9uBdv/B4EefsuAL+pWqueZyZS2Ba+LxfFeQ9DN14HU4bN8bhaxKdkpjpB6fs9+pSjIBu+FXQHImEg8j/Lw0+vA==", "dev": true, "requires": { - "@jest/schemas": "^29.6.3", - "ansi-styles": "^5.0.0", - "react-is": "^18.0.0" + "@jest/schemas": "30.0.5", + "ansi-styles": "^5.2.0", + "react-is": "^18.3.1" } }, "react-is": { - "version": "18.2.0", - "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz", - "integrity": "sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w==", + "version": "18.3.1", + "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.3.1.tgz", + "integrity": "sha512-/LLMVyas0ljjAtoYiPqYiL8VWXzUUdThrmU5+n20DZv+a+ClRoevUzw5JxU+Ieh5/c87ytoTBV9G1FiKfNJdmg==", "dev": true } } }, "jest-cli": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-cli/-/jest-cli-29.7.0.tgz", - "integrity": "sha512-OVVobw2IubN/GSYsxETi+gOe7Ka59EFMR/twOU3Jb2GnKKeMGJB5SGUUrEz3SFVmJASUdZUzy83sLNNQ2gZslg==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-cli/-/jest-cli-30.2.0.tgz", + "integrity": "sha512-Os9ukIvADX/A9sLt6Zse3+nmHtHaE6hqOsjQtNiugFTbKRHYIYtZXNGNK9NChseXy7djFPjndX1tL0sCTlfpAA==", "dev": true, "requires": { - "@jest/core": "^29.7.0", - "@jest/test-result": "^29.7.0", - "@jest/types": "^29.6.3", - "chalk": "^4.0.0", - "create-jest": "^29.7.0", - "exit": "^0.1.2", - "import-local": "^3.0.2", - "jest-config": "^29.7.0", - "jest-util": "^29.7.0", - "jest-validate": "^29.7.0", - "yargs": "^17.3.1" + "@jest/core": "30.2.0", + "@jest/test-result": "30.2.0", + "@jest/types": "30.2.0", + "chalk": "^4.1.2", + "exit-x": "^0.2.2", + "import-local": "^3.2.0", + "jest-config": "30.2.0", + "jest-util": "30.2.0", + "jest-validate": "30.2.0", + "yargs": "^17.7.2" } }, "jest-config": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-config/-/jest-config-29.7.0.tgz", - "integrity": "sha512-uXbpfeQ7R6TZBqI3/TxCU4q4ttk3u0PJeC+E0zbfSoSjq6bJ7buBPxzQPL0ifrkY4DNu4JUdk0ImlBUYi840eQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-config/-/jest-config-30.2.0.tgz", + "integrity": "sha512-g4WkyzFQVWHtu6uqGmQR4CQxz/CH3yDSlhzXMWzNjDx843gYjReZnMRanjRCq5XZFuQrGDxgUaiYWE8BRfVckA==", "dev": true, "requires": { - "@babel/core": "^7.11.6", - "@jest/test-sequencer": "^29.7.0", - "@jest/types": "^29.6.3", - "babel-jest": "^29.7.0", - "chalk": "^4.0.0", - "ci-info": "^3.2.0", - "deepmerge": "^4.2.2", - "glob": "^7.1.3", - "graceful-fs": "^4.2.9", - "jest-circus": "^29.7.0", - "jest-environment-node": "^29.7.0", - "jest-get-type": "^29.6.3", - "jest-regex-util": "^29.6.3", - "jest-resolve": "^29.7.0", - "jest-runner": "^29.7.0", - "jest-util": "^29.7.0", - "jest-validate": "^29.7.0", - "micromatch": "^4.0.4", + "@babel/core": "^7.27.4", + "@jest/get-type": "30.1.0", + "@jest/pattern": "30.0.1", + "@jest/test-sequencer": "30.2.0", + "@jest/types": "30.2.0", + "babel-jest": "30.2.0", + "chalk": "^4.1.2", + "ci-info": "^4.2.0", + "deepmerge": "^4.3.1", + "glob": "^10.3.10", + "graceful-fs": "^4.2.11", + "jest-circus": "30.2.0", + "jest-docblock": "30.2.0", + "jest-environment-node": "30.2.0", + "jest-regex-util": "30.0.1", + "jest-resolve": "30.2.0", + "jest-runner": "30.2.0", + "jest-util": "30.2.0", + "jest-validate": "30.2.0", + "micromatch": "^4.0.8", "parse-json": "^5.2.0", - "pretty-format": "^29.7.0", + "pretty-format": "30.2.0", "slash": "^3.0.0", "strip-json-comments": "^3.1.1" }, @@ -11042,34 +11156,34 @@ "dev": true }, "pretty-format": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-29.7.0.tgz", - "integrity": "sha512-Pdlw/oPxN+aXdmM9R00JVC9WVFoCLTKJvDVLgmJ+qAffBMxsV85l/Lu7sNx4zSzPyoL2euImuEwHhOXdEgNFZQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.2.0.tgz", + "integrity": "sha512-9uBdv/B4EefsuAL+pWqueZyZS2Ba+LxfFeQ9DN14HU4bN8bhaxKdkpjpB6fs9+pSjIBu+FXQHImEg8j/Lw0+vA==", "dev": true, "requires": { - "@jest/schemas": "^29.6.3", - "ansi-styles": "^5.0.0", - "react-is": "^18.0.0" + "@jest/schemas": "30.0.5", + "ansi-styles": "^5.2.0", + "react-is": "^18.3.1" } }, "react-is": { - "version": "18.2.0", - "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz", - "integrity": "sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w==", + "version": "18.3.1", + "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.3.1.tgz", + "integrity": "sha512-/LLMVyas0ljjAtoYiPqYiL8VWXzUUdThrmU5+n20DZv+a+ClRoevUzw5JxU+Ieh5/c87ytoTBV9G1FiKfNJdmg==", "dev": true } } }, "jest-diff": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-diff/-/jest-diff-29.7.0.tgz", - "integrity": "sha512-LMIgiIrhigmPrs03JHpxUh2yISK3vLFPkAodPeo0+BuF7wA2FoQbkEg1u8gBYBThncu7e1oEDUfIXVuTqLRUjw==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-diff/-/jest-diff-30.2.0.tgz", + "integrity": "sha512-dQHFo3Pt4/NLlG5z4PxZ/3yZTZ1C7s9hveiOj+GCN+uT109NC2QgsoVZsVOAvbJ3RgKkvyLGXZV9+piDpWbm6A==", "dev": true, "requires": { - "chalk": "^4.0.0", - "diff-sequences": "^29.6.3", - "jest-get-type": "^29.6.3", - "pretty-format": "^29.7.0" + "@jest/diff-sequences": "30.0.1", + "@jest/get-type": "30.1.0", + "chalk": "^4.1.2", + "pretty-format": "30.2.0" }, "dependencies": { "ansi-styles": { @@ -11079,44 +11193,44 @@ "dev": true }, "pretty-format": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-29.7.0.tgz", - "integrity": "sha512-Pdlw/oPxN+aXdmM9R00JVC9WVFoCLTKJvDVLgmJ+qAffBMxsV85l/Lu7sNx4zSzPyoL2euImuEwHhOXdEgNFZQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.2.0.tgz", + "integrity": "sha512-9uBdv/B4EefsuAL+pWqueZyZS2Ba+LxfFeQ9DN14HU4bN8bhaxKdkpjpB6fs9+pSjIBu+FXQHImEg8j/Lw0+vA==", "dev": true, "requires": { - "@jest/schemas": "^29.6.3", - "ansi-styles": "^5.0.0", - "react-is": "^18.0.0" + "@jest/schemas": "30.0.5", + "ansi-styles": "^5.2.0", + "react-is": "^18.3.1" } }, "react-is": { - "version": "18.2.0", - "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz", - "integrity": "sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w==", + "version": "18.3.1", + "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.3.1.tgz", + "integrity": "sha512-/LLMVyas0ljjAtoYiPqYiL8VWXzUUdThrmU5+n20DZv+a+ClRoevUzw5JxU+Ieh5/c87ytoTBV9G1FiKfNJdmg==", "dev": true } } }, "jest-docblock": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-docblock/-/jest-docblock-29.7.0.tgz", - "integrity": "sha512-q617Auw3A612guyaFgsbFeYpNP5t2aoUNLwBUbc/0kD1R4t9ixDbyFTHd1nok4epoVFpr7PmeWHrhvuV3XaJ4g==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-docblock/-/jest-docblock-30.2.0.tgz", + "integrity": "sha512-tR/FFgZKS1CXluOQzZvNH3+0z9jXr3ldGSD8bhyuxvlVUwbeLOGynkunvlTMxchC5urrKndYiwCFC0DLVjpOCA==", "dev": true, "requires": { - "detect-newline": "^3.0.0" + "detect-newline": "^3.1.0" } }, "jest-each": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-each/-/jest-each-29.7.0.tgz", - "integrity": "sha512-gns+Er14+ZrEoC5fhOfYCY1LOHHr0TI+rQUHZS8Ttw2l7gl+80eHc/gFf2Ktkw0+SIACDTeWvpFcv3B04VembQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-each/-/jest-each-30.2.0.tgz", + "integrity": "sha512-lpWlJlM7bCUf1mfmuqTA8+j2lNURW9eNafOy99knBM01i5CQeY5UH1vZjgT9071nDJac1M4XsbyI44oNOdhlDQ==", "dev": true, "requires": { - "@jest/types": "^29.6.3", - "chalk": "^4.0.0", - "jest-get-type": "^29.6.3", - "jest-util": "^29.7.0", - "pretty-format": "^29.7.0" + "@jest/get-type": "30.1.0", + "@jest/types": "30.2.0", + "chalk": "^4.1.2", + "jest-util": "30.2.0", + "pretty-format": "30.2.0" }, "dependencies": { "ansi-styles": { @@ -11126,20 +11240,20 @@ "dev": true }, "pretty-format": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-29.7.0.tgz", - "integrity": "sha512-Pdlw/oPxN+aXdmM9R00JVC9WVFoCLTKJvDVLgmJ+qAffBMxsV85l/Lu7sNx4zSzPyoL2euImuEwHhOXdEgNFZQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.2.0.tgz", + "integrity": "sha512-9uBdv/B4EefsuAL+pWqueZyZS2Ba+LxfFeQ9DN14HU4bN8bhaxKdkpjpB6fs9+pSjIBu+FXQHImEg8j/Lw0+vA==", "dev": true, "requires": { - "@jest/schemas": "^29.6.3", - "ansi-styles": "^5.0.0", - "react-is": "^18.0.0" + "@jest/schemas": "30.0.5", + "ansi-styles": "^5.2.0", + "react-is": "^18.3.1" } }, "react-is": { - "version": "18.2.0", - "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz", - "integrity": "sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w==", + "version": "18.3.1", + "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.3.1.tgz", + "integrity": "sha512-/LLMVyas0ljjAtoYiPqYiL8VWXzUUdThrmU5+n20DZv+a+ClRoevUzw5JxU+Ieh5/c87ytoTBV9G1FiKfNJdmg==", "dev": true } } @@ -11155,200 +11269,50 @@ "@types/jsdom": "^21.1.7", "@types/node": "*", "jsdom": "^26.1.0" - }, - "dependencies": { - "@jest/environment": { - "version": "30.2.0", - "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-30.2.0.tgz", - "integrity": "sha512-/QPTL7OBJQ5ac09UDRa3EQes4gt1FTEG/8jZ/4v5IVzx+Cv7dLxlVIvfvSVRiiX2drWyXeBjkMSR8hvOWSog5g==", - "dev": true, - "requires": { - "@jest/fake-timers": "30.2.0", - "@jest/types": "30.2.0", - "@types/node": "*", - "jest-mock": "30.2.0" - } - }, - "@jest/fake-timers": { - "version": "30.2.0", - "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-30.2.0.tgz", - "integrity": "sha512-HI3tRLjRxAbBy0VO8dqqm7Hb2mIa8d5bg/NJkyQcOk7V118ObQML8RC5luTF/Zsg4474a+gDvhce7eTnP4GhYw==", - "dev": true, - "requires": { - "@jest/types": "30.2.0", - "@sinonjs/fake-timers": "^13.0.0", - "@types/node": "*", - "jest-message-util": "30.2.0", - "jest-mock": "30.2.0", - "jest-util": "30.2.0" - } - }, - "@jest/schemas": { - "version": "30.0.5", - "resolved": "https://registry.npmjs.org/@jest/schemas/-/schemas-30.0.5.tgz", - "integrity": "sha512-DmdYgtezMkh3cpU8/1uyXakv3tJRcmcXxBOcO0tbaozPwpmh4YMsnWrQm9ZmZMfa5ocbxzbFk6O4bDPEc/iAnA==", - "dev": true, - "requires": { - "@sinclair/typebox": "^0.34.0" - } - }, - "@jest/types": { - "version": "30.2.0", - "resolved": "https://registry.npmjs.org/@jest/types/-/types-30.2.0.tgz", - "integrity": "sha512-H9xg1/sfVvyfU7o3zMfBEjQ1gcsdeTMgqHoYdN79tuLqfTtuu7WckRA1R5whDwOzxaZAeMKTYWqP+WCAi0CHsg==", - "dev": true, - "requires": { - "@jest/pattern": "30.0.1", - "@jest/schemas": "30.0.5", - "@types/istanbul-lib-coverage": "^2.0.6", - "@types/istanbul-reports": "^3.0.4", - "@types/node": "*", - "@types/yargs": "^17.0.33", - "chalk": "^4.1.2" - } - }, - "@sinclair/typebox": { - "version": "0.34.41", - "resolved": "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.34.41.tgz", - "integrity": "sha512-6gS8pZzSXdyRHTIqoqSVknxolr1kzfy4/CeDnrzsVz8TTIWUbOBr6gnzOmTYJ3eXQNh4IYHIGi5aIL7sOZ2G/g==", - "dev": true - }, - "@sinonjs/fake-timers": { - "version": "13.0.5", - "resolved": "https://registry.npmjs.org/@sinonjs/fake-timers/-/fake-timers-13.0.5.tgz", - "integrity": "sha512-36/hTbH2uaWuGVERyC6da9YwGWnzUZXuPro/F2LfsdOsLnCojz/iSH8MxUt/FD2S5XBSVPhmArFUXcpCQ2Hkiw==", - "dev": true, - "requires": { - "@sinonjs/commons": "^3.0.1" - } - }, - "ansi-styles": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz", - "integrity": "sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==", - "dev": true - }, - "ci-info": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-4.3.0.tgz", - "integrity": "sha512-l+2bNRMiQgcfILUi33labAZYIWlH1kWDp+ecNo5iisRKrbm0xcRyCww71/YU0Fkw0mAFpz9bJayXPjey6vkmaQ==", - "dev": true - }, - "jest-message-util": { - "version": "30.2.0", - "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-30.2.0.tgz", - "integrity": "sha512-y4DKFLZ2y6DxTWD4cDe07RglV88ZiNEdlRfGtqahfbIjfsw1nMCPx49Uev4IA/hWn3sDKyAnSPwoYSsAEdcimw==", - "dev": true, - "requires": { - "@babel/code-frame": "^7.27.1", - "@jest/types": "30.2.0", - "@types/stack-utils": "^2.0.3", - "chalk": "^4.1.2", - "graceful-fs": "^4.2.11", - "micromatch": "^4.0.8", - "pretty-format": "30.2.0", - "slash": "^3.0.0", - "stack-utils": "^2.0.6" - } - }, - "jest-mock": { - "version": "30.2.0", - "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-30.2.0.tgz", - "integrity": "sha512-JNNNl2rj4b5ICpmAcq+WbLH83XswjPbjH4T7yvGzfAGCPh1rw+xVNbtk+FnRslvt9lkCcdn9i1oAoKUuFsOxRw==", - "dev": true, - "requires": { - "@jest/types": "30.2.0", - "@types/node": "*", - "jest-util": "30.2.0" - } - }, - "jest-util": { - "version": "30.2.0", - "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-30.2.0.tgz", - "integrity": "sha512-QKNsM0o3Xe6ISQU869e+DhG+4CK/48aHYdJZGlFQVTjnbvgpcKyxpzk29fGiO7i/J8VENZ+d2iGnSsvmuHywlA==", - "dev": true, - "requires": { - "@jest/types": "30.2.0", - "@types/node": "*", - "chalk": "^4.1.2", - "ci-info": "^4.2.0", - "graceful-fs": "^4.2.11", - "picomatch": "^4.0.2" - } - }, - "picomatch": { - "version": "4.0.3", - "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-4.0.3.tgz", - "integrity": "sha512-5gTmgEY/sqK6gFXLIsQNH19lWb4ebPDLA4SdLP7dsWkIXHWlG66oPuVvXSGFPppYZz8ZDZq0dYYrbHfBCVUb1Q==", - "dev": true - }, - "pretty-format": { - "version": "30.2.0", - "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.2.0.tgz", - "integrity": "sha512-9uBdv/B4EefsuAL+pWqueZyZS2Ba+LxfFeQ9DN14HU4bN8bhaxKdkpjpB6fs9+pSjIBu+FXQHImEg8j/Lw0+vA==", - "dev": true, - "requires": { - "@jest/schemas": "30.0.5", - "ansi-styles": "^5.2.0", - "react-is": "^18.3.1" - } - }, - "react-is": { - "version": "18.3.1", - "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.3.1.tgz", - "integrity": "sha512-/LLMVyas0ljjAtoYiPqYiL8VWXzUUdThrmU5+n20DZv+a+ClRoevUzw5JxU+Ieh5/c87ytoTBV9G1FiKfNJdmg==", - "dev": true - } } }, "jest-environment-node": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-environment-node/-/jest-environment-node-29.7.0.tgz", - "integrity": "sha512-DOSwCRqXirTOyheM+4d5YZOrWcdu0LNZ87ewUoywbcb2XR4wKgqiG8vNeYwhjFMbEkfju7wx2GYH0P2gevGvFw==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-environment-node/-/jest-environment-node-30.2.0.tgz", + "integrity": "sha512-ElU8v92QJ9UrYsKrxDIKCxu6PfNj4Hdcktcn0JX12zqNdqWHB0N+hwOnnBBXvjLd2vApZtuLUGs1QSY+MsXoNA==", "dev": true, "requires": { - "@jest/environment": "^29.7.0", - "@jest/fake-timers": "^29.7.0", - "@jest/types": "^29.6.3", + "@jest/environment": "30.2.0", + "@jest/fake-timers": "30.2.0", + "@jest/types": "30.2.0", "@types/node": "*", - "jest-mock": "^29.7.0", - "jest-util": "^29.7.0" + "jest-mock": "30.2.0", + "jest-util": "30.2.0", + "jest-validate": "30.2.0" } }, - "jest-get-type": { - "version": "29.6.3", - "resolved": "https://registry.npmjs.org/jest-get-type/-/jest-get-type-29.6.3.tgz", - "integrity": "sha512-zrteXnqYxfQh7l5FHyL38jL39di8H8rHoecLH3JNxH3BwOrBsNeabdap5e0I23lD4HHI8W5VFBZqG4Eaq5LNcw==", - "dev": true - }, "jest-haste-map": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-haste-map/-/jest-haste-map-29.7.0.tgz", - "integrity": "sha512-fP8u2pyfqx0K1rGn1R9pyE0/KTn+G7PxktWidOBTqFPLYX0b9ksaMFkhK5vrS3DVun09pckLdlx90QthlW7AmA==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-haste-map/-/jest-haste-map-30.2.0.tgz", + "integrity": "sha512-sQA/jCb9kNt+neM0anSj6eZhLZUIhQgwDt7cPGjumgLM4rXsfb9kpnlacmvZz3Q5tb80nS+oG/if+NBKrHC+Xw==", "dev": true, "requires": { - "@jest/types": "^29.6.3", - "@types/graceful-fs": "^4.1.3", + "@jest/types": "30.2.0", "@types/node": "*", - "anymatch": "^3.0.3", - "fb-watchman": "^2.0.0", - "fsevents": "^2.3.2", - "graceful-fs": "^4.2.9", - "jest-regex-util": "^29.6.3", - "jest-util": "^29.7.0", - "jest-worker": "^29.7.0", - "micromatch": "^4.0.4", + "anymatch": "^3.1.3", + "fb-watchman": "^2.0.2", + "fsevents": "^2.3.3", + "graceful-fs": "^4.2.11", + "jest-regex-util": "30.0.1", + "jest-util": "30.2.0", + "jest-worker": "30.2.0", + "micromatch": "^4.0.8", "walker": "^1.0.8" } }, "jest-leak-detector": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-leak-detector/-/jest-leak-detector-29.7.0.tgz", - "integrity": "sha512-kYA8IJcSYtST2BY9I+SMC32nDpBT3J2NvWJx8+JCuCdl/CR1I4EKUJROiP8XtCcxqgTTBGJNdbB1A8XRKbTetw==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-leak-detector/-/jest-leak-detector-30.2.0.tgz", + "integrity": "sha512-M6jKAjyzjHG0SrQgwhgZGy9hFazcudwCNovY/9HPIicmNSBuockPSedAP9vlPK6ONFJ1zfyH/M2/YYJxOz5cdQ==", "dev": true, "requires": { - "jest-get-type": "^29.6.3", - "pretty-format": "^29.7.0" + "@jest/get-type": "30.1.0", + "pretty-format": "30.2.0" }, "dependencies": { "ansi-styles": { @@ -11358,34 +11322,34 @@ "dev": true }, "pretty-format": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-29.7.0.tgz", - "integrity": "sha512-Pdlw/oPxN+aXdmM9R00JVC9WVFoCLTKJvDVLgmJ+qAffBMxsV85l/Lu7sNx4zSzPyoL2euImuEwHhOXdEgNFZQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.2.0.tgz", + "integrity": "sha512-9uBdv/B4EefsuAL+pWqueZyZS2Ba+LxfFeQ9DN14HU4bN8bhaxKdkpjpB6fs9+pSjIBu+FXQHImEg8j/Lw0+vA==", "dev": true, "requires": { - "@jest/schemas": "^29.6.3", - "ansi-styles": "^5.0.0", - "react-is": "^18.0.0" + "@jest/schemas": "30.0.5", + "ansi-styles": "^5.2.0", + "react-is": "^18.3.1" } }, "react-is": { - "version": "18.2.0", - "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz", - "integrity": "sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w==", + "version": "18.3.1", + "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.3.1.tgz", + "integrity": "sha512-/LLMVyas0ljjAtoYiPqYiL8VWXzUUdThrmU5+n20DZv+a+ClRoevUzw5JxU+Ieh5/c87ytoTBV9G1FiKfNJdmg==", "dev": true } } }, "jest-matcher-utils": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-matcher-utils/-/jest-matcher-utils-29.7.0.tgz", - "integrity": "sha512-sBkD+Xi9DtcChsI3L3u0+N0opgPYnCRPtGcQYrgXmR+hmt/fYfWAL0xRXYU8eWOdfuLgBe0YCW3AFtnRLagq/g==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-matcher-utils/-/jest-matcher-utils-30.2.0.tgz", + "integrity": "sha512-dQ94Nq4dbzmUWkQ0ANAWS9tBRfqCrn0bV9AMYdOi/MHW726xn7eQmMeRTpX2ViC00bpNaWXq+7o4lIQ3AX13Hg==", "dev": true, "requires": { - "chalk": "^4.0.0", - "jest-diff": "^29.7.0", - "jest-get-type": "^29.6.3", - "pretty-format": "^29.7.0" + "@jest/get-type": "30.1.0", + "chalk": "^4.1.2", + "jest-diff": "30.2.0", + "pretty-format": "30.2.0" }, "dependencies": { "ansi-styles": { @@ -11395,39 +11359,39 @@ "dev": true }, "pretty-format": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-29.7.0.tgz", - "integrity": "sha512-Pdlw/oPxN+aXdmM9R00JVC9WVFoCLTKJvDVLgmJ+qAffBMxsV85l/Lu7sNx4zSzPyoL2euImuEwHhOXdEgNFZQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.2.0.tgz", + "integrity": "sha512-9uBdv/B4EefsuAL+pWqueZyZS2Ba+LxfFeQ9DN14HU4bN8bhaxKdkpjpB6fs9+pSjIBu+FXQHImEg8j/Lw0+vA==", "dev": true, "requires": { - "@jest/schemas": "^29.6.3", - "ansi-styles": "^5.0.0", - "react-is": "^18.0.0" + "@jest/schemas": "30.0.5", + "ansi-styles": "^5.2.0", + "react-is": "^18.3.1" } }, "react-is": { - "version": "18.2.0", - "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz", - "integrity": "sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w==", + "version": "18.3.1", + "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.3.1.tgz", + "integrity": "sha512-/LLMVyas0ljjAtoYiPqYiL8VWXzUUdThrmU5+n20DZv+a+ClRoevUzw5JxU+Ieh5/c87ytoTBV9G1FiKfNJdmg==", "dev": true } } }, "jest-message-util": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-29.7.0.tgz", - "integrity": "sha512-GBEV4GRADeP+qtB2+6u61stea8mGcOT4mCtrYISZwfu9/ISHFJ/5zOMXYbpBE9RsS5+Gb63DW4FgmnKJ79Kf6w==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-30.2.0.tgz", + "integrity": "sha512-y4DKFLZ2y6DxTWD4cDe07RglV88ZiNEdlRfGtqahfbIjfsw1nMCPx49Uev4IA/hWn3sDKyAnSPwoYSsAEdcimw==", "dev": true, "requires": { - "@babel/code-frame": "^7.12.13", - "@jest/types": "^29.6.3", - "@types/stack-utils": "^2.0.0", - "chalk": "^4.0.0", - "graceful-fs": "^4.2.9", - "micromatch": "^4.0.4", - "pretty-format": "^29.7.0", + "@babel/code-frame": "^7.27.1", + "@jest/types": "30.2.0", + "@types/stack-utils": "^2.0.3", + "chalk": "^4.1.2", + "graceful-fs": "^4.2.11", + "micromatch": "^4.0.8", + "pretty-format": "30.2.0", "slash": "^3.0.0", - "stack-utils": "^2.0.3" + "stack-utils": "^2.0.6" }, "dependencies": { "ansi-styles": { @@ -11437,33 +11401,33 @@ "dev": true }, "pretty-format": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-29.7.0.tgz", - "integrity": "sha512-Pdlw/oPxN+aXdmM9R00JVC9WVFoCLTKJvDVLgmJ+qAffBMxsV85l/Lu7sNx4zSzPyoL2euImuEwHhOXdEgNFZQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.2.0.tgz", + "integrity": "sha512-9uBdv/B4EefsuAL+pWqueZyZS2Ba+LxfFeQ9DN14HU4bN8bhaxKdkpjpB6fs9+pSjIBu+FXQHImEg8j/Lw0+vA==", "dev": true, "requires": { - "@jest/schemas": "^29.6.3", - "ansi-styles": "^5.0.0", - "react-is": "^18.0.0" + "@jest/schemas": "30.0.5", + "ansi-styles": "^5.2.0", + "react-is": "^18.3.1" } }, "react-is": { - "version": "18.2.0", - "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz", - "integrity": "sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w==", + "version": "18.3.1", + "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.3.1.tgz", + "integrity": "sha512-/LLMVyas0ljjAtoYiPqYiL8VWXzUUdThrmU5+n20DZv+a+ClRoevUzw5JxU+Ieh5/c87ytoTBV9G1FiKfNJdmg==", "dev": true } } }, "jest-mock": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-29.7.0.tgz", - "integrity": "sha512-ITOMZn+UkYS4ZFh83xYAOzWStloNzJFO2s8DWrE4lhtGD+AorgnbkiKERe4wQVBydIGPx059g6riW5Btp6Llnw==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-30.2.0.tgz", + "integrity": "sha512-JNNNl2rj4b5ICpmAcq+WbLH83XswjPbjH4T7yvGzfAGCPh1rw+xVNbtk+FnRslvt9lkCcdn9i1oAoKUuFsOxRw==", "dev": true, "requires": { - "@jest/types": "^29.6.3", + "@jest/types": "30.2.0", "@types/node": "*", - "jest-util": "^29.7.0" + "jest-util": "30.2.0" } }, "jest-pnp-resolver": { @@ -11474,123 +11438,124 @@ "requires": {} }, "jest-regex-util": { - "version": "29.6.3", - "resolved": "https://registry.npmjs.org/jest-regex-util/-/jest-regex-util-29.6.3.tgz", - "integrity": "sha512-KJJBsRCyyLNWCNBOvZyRDnAIfUiRJ8v+hOBQYGn8gDyF3UegwiP4gwRR3/SDa42g1YbVycTidUF3rKjyLFDWbg==", + "version": "30.0.1", + "resolved": "https://registry.npmjs.org/jest-regex-util/-/jest-regex-util-30.0.1.tgz", + "integrity": "sha512-jHEQgBXAgc+Gh4g0p3bCevgRCVRkB4VB70zhoAE48gxeSr1hfUOsM/C2WoJgVL7Eyg//hudYENbm3Ne+/dRVVA==", "dev": true }, "jest-resolve": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-resolve/-/jest-resolve-29.7.0.tgz", - "integrity": "sha512-IOVhZSrg+UvVAshDSDtHyFCCBUl/Q3AAJv8iZ6ZjnZ74xzvwuzLXid9IIIPgTnY62SJjfuupMKZsZQRsCvxEgA==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-resolve/-/jest-resolve-30.2.0.tgz", + "integrity": "sha512-TCrHSxPlx3tBY3hWNtRQKbtgLhsXa1WmbJEqBlTBrGafd5fiQFByy2GNCEoGR+Tns8d15GaL9cxEzKOO3GEb2A==", "dev": true, "requires": { - "chalk": "^4.0.0", - "graceful-fs": "^4.2.9", - "jest-haste-map": "^29.7.0", - "jest-pnp-resolver": "^1.2.2", - "jest-util": "^29.7.0", - "jest-validate": "^29.7.0", - "resolve": "^1.20.0", - "resolve.exports": "^2.0.0", - "slash": "^3.0.0" + "chalk": "^4.1.2", + "graceful-fs": "^4.2.11", + "jest-haste-map": "30.2.0", + "jest-pnp-resolver": "^1.2.3", + "jest-util": "30.2.0", + "jest-validate": "30.2.0", + "slash": "^3.0.0", + "unrs-resolver": "^1.7.11" } }, "jest-resolve-dependencies": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-resolve-dependencies/-/jest-resolve-dependencies-29.7.0.tgz", - "integrity": "sha512-un0zD/6qxJ+S0et7WxeI3H5XSe9lTBBR7bOHCHXkKR6luG5mwDDlIzVQ0V5cZCuoTgEdcdwzTghYkTWfubi+nA==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-resolve-dependencies/-/jest-resolve-dependencies-30.2.0.tgz", + "integrity": "sha512-xTOIGug/0RmIe3mmCqCT95yO0vj6JURrn1TKWlNbhiAefJRWINNPgwVkrVgt/YaerPzY3iItufd80v3lOrFJ2w==", "dev": true, "requires": { - "jest-regex-util": "^29.6.3", - "jest-snapshot": "^29.7.0" + "jest-regex-util": "30.0.1", + "jest-snapshot": "30.2.0" } }, "jest-runner": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-runner/-/jest-runner-29.7.0.tgz", - "integrity": "sha512-fsc4N6cPCAahybGBfTRcq5wFR6fpLznMg47sY5aDpsoejOcVYFb07AHuSnR0liMcPTgBsA3ZJL6kFOjPdoNipQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-runner/-/jest-runner-30.2.0.tgz", + "integrity": "sha512-PqvZ2B2XEyPEbclp+gV6KO/F1FIFSbIwewRgmROCMBo/aZ6J1w8Qypoj2pEOcg3G2HzLlaP6VUtvwCI8dM3oqQ==", "dev": true, "requires": { - "@jest/console": "^29.7.0", - "@jest/environment": "^29.7.0", - "@jest/test-result": "^29.7.0", - "@jest/transform": "^29.7.0", - "@jest/types": "^29.6.3", + "@jest/console": "30.2.0", + "@jest/environment": "30.2.0", + "@jest/test-result": "30.2.0", + "@jest/transform": "30.2.0", + "@jest/types": "30.2.0", "@types/node": "*", - "chalk": "^4.0.0", + "chalk": "^4.1.2", "emittery": "^0.13.1", - "graceful-fs": "^4.2.9", - "jest-docblock": "^29.7.0", - "jest-environment-node": "^29.7.0", - "jest-haste-map": "^29.7.0", - "jest-leak-detector": "^29.7.0", - "jest-message-util": "^29.7.0", - "jest-resolve": "^29.7.0", - "jest-runtime": "^29.7.0", - "jest-util": "^29.7.0", - "jest-watcher": "^29.7.0", - "jest-worker": "^29.7.0", + "exit-x": "^0.2.2", + "graceful-fs": "^4.2.11", + "jest-docblock": "30.2.0", + "jest-environment-node": "30.2.0", + "jest-haste-map": "30.2.0", + "jest-leak-detector": "30.2.0", + "jest-message-util": "30.2.0", + "jest-resolve": "30.2.0", + "jest-runtime": "30.2.0", + "jest-util": "30.2.0", + "jest-watcher": "30.2.0", + "jest-worker": "30.2.0", "p-limit": "^3.1.0", "source-map-support": "0.5.13" } }, "jest-runtime": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-runtime/-/jest-runtime-29.7.0.tgz", - "integrity": "sha512-gUnLjgwdGqW7B4LvOIkbKs9WGbn+QLqRQQ9juC6HndeDiezIwhDP+mhMwHWCEcfQ5RUXa6OPnFF8BJh5xegwwQ==", - "dev": true, - "requires": { - "@jest/environment": "^29.7.0", - "@jest/fake-timers": "^29.7.0", - "@jest/globals": "^29.7.0", - "@jest/source-map": "^29.6.3", - "@jest/test-result": "^29.7.0", - "@jest/transform": "^29.7.0", - "@jest/types": "^29.6.3", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-runtime/-/jest-runtime-30.2.0.tgz", + "integrity": "sha512-p1+GVX/PJqTucvsmERPMgCPvQJpFt4hFbM+VN3n8TMo47decMUcJbt+rgzwrEme0MQUA/R+1de2axftTHkKckg==", + "dev": true, + "requires": { + "@jest/environment": "30.2.0", + "@jest/fake-timers": "30.2.0", + "@jest/globals": "30.2.0", + "@jest/source-map": "30.0.1", + "@jest/test-result": "30.2.0", + "@jest/transform": "30.2.0", + "@jest/types": "30.2.0", "@types/node": "*", - "chalk": "^4.0.0", - "cjs-module-lexer": "^1.0.0", - "collect-v8-coverage": "^1.0.0", - "glob": "^7.1.3", - "graceful-fs": "^4.2.9", - "jest-haste-map": "^29.7.0", - "jest-message-util": "^29.7.0", - "jest-mock": "^29.7.0", - "jest-regex-util": "^29.6.3", - "jest-resolve": "^29.7.0", - "jest-snapshot": "^29.7.0", - "jest-util": "^29.7.0", + "chalk": "^4.1.2", + "cjs-module-lexer": "^2.1.0", + "collect-v8-coverage": "^1.0.2", + "glob": "^10.3.10", + "graceful-fs": "^4.2.11", + "jest-haste-map": "30.2.0", + "jest-message-util": "30.2.0", + "jest-mock": "30.2.0", + "jest-regex-util": "30.0.1", + "jest-resolve": "30.2.0", + "jest-snapshot": "30.2.0", + "jest-util": "30.2.0", "slash": "^3.0.0", "strip-bom": "^4.0.0" } }, "jest-snapshot": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-snapshot/-/jest-snapshot-29.7.0.tgz", - "integrity": "sha512-Rm0BMWtxBcioHr1/OX5YCP8Uov4riHvKPknOGs804Zg9JGZgmIBkbtlxJC/7Z4msKYVbIJtfU+tKb8xlYNfdkw==", - "dev": true, - "requires": { - "@babel/core": "^7.11.6", - "@babel/generator": "^7.7.2", - "@babel/plugin-syntax-jsx": "^7.7.2", - "@babel/plugin-syntax-typescript": "^7.7.2", - "@babel/types": "^7.3.3", - "@jest/expect-utils": "^29.7.0", - "@jest/transform": "^29.7.0", - "@jest/types": "^29.6.3", - "babel-preset-current-node-syntax": "^1.0.0", - "chalk": "^4.0.0", - "expect": "^29.7.0", - "graceful-fs": "^4.2.9", - "jest-diff": "^29.7.0", - "jest-get-type": "^29.6.3", - "jest-matcher-utils": "^29.7.0", - "jest-message-util": "^29.7.0", - "jest-util": "^29.7.0", - "natural-compare": "^1.4.0", - "pretty-format": "^29.7.0", - "semver": "^7.5.3" + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-snapshot/-/jest-snapshot-30.2.0.tgz", + "integrity": "sha512-5WEtTy2jXPFypadKNpbNkZ72puZCa6UjSr/7djeecHWOu7iYhSXSnHScT8wBz3Rn8Ena5d5RYRcsyKIeqG1IyA==", + "dev": true, + "requires": { + "@babel/core": "^7.27.4", + "@babel/generator": "^7.27.5", + "@babel/plugin-syntax-jsx": "^7.27.1", + "@babel/plugin-syntax-typescript": "^7.27.1", + "@babel/types": "^7.27.3", + "@jest/expect-utils": "30.2.0", + "@jest/get-type": "30.1.0", + "@jest/snapshot-utils": "30.2.0", + "@jest/transform": "30.2.0", + "@jest/types": "30.2.0", + "babel-preset-current-node-syntax": "^1.2.0", + "chalk": "^4.1.2", + "expect": "30.2.0", + "graceful-fs": "^4.2.11", + "jest-diff": "30.2.0", + "jest-matcher-utils": "30.2.0", + "jest-message-util": "30.2.0", + "jest-util": "30.2.0", + "pretty-format": "30.2.0", + "semver": "^7.7.2", + "synckit": "^0.11.8" }, "dependencies": { "ansi-styles": { @@ -11599,75 +11564,65 @@ "integrity": "sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==", "dev": true }, - "lru-cache": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", - "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", - "dev": true, - "requires": { - "yallist": "^4.0.0" - } - }, "pretty-format": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-29.7.0.tgz", - "integrity": "sha512-Pdlw/oPxN+aXdmM9R00JVC9WVFoCLTKJvDVLgmJ+qAffBMxsV85l/Lu7sNx4zSzPyoL2euImuEwHhOXdEgNFZQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.2.0.tgz", + "integrity": "sha512-9uBdv/B4EefsuAL+pWqueZyZS2Ba+LxfFeQ9DN14HU4bN8bhaxKdkpjpB6fs9+pSjIBu+FXQHImEg8j/Lw0+vA==", "dev": true, "requires": { - "@jest/schemas": "^29.6.3", - "ansi-styles": "^5.0.0", - "react-is": "^18.0.0" + "@jest/schemas": "30.0.5", + "ansi-styles": "^5.2.0", + "react-is": "^18.3.1" } }, "react-is": { - "version": "18.2.0", - "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz", - "integrity": "sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w==", + "version": "18.3.1", + "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.3.1.tgz", + "integrity": "sha512-/LLMVyas0ljjAtoYiPqYiL8VWXzUUdThrmU5+n20DZv+a+ClRoevUzw5JxU+Ieh5/c87ytoTBV9G1FiKfNJdmg==", "dev": true }, "semver": { - "version": "7.5.4", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz", - "integrity": "sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA==", - "dev": true, - "requires": { - "lru-cache": "^6.0.0" - } - }, - "yallist": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", - "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", + "version": "7.7.3", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.7.3.tgz", + "integrity": "sha512-SdsKMrI9TdgjdweUSR9MweHA4EJ8YxHn8DFaDisvhVlUOe4BF1tLD7GAj0lIqWVl+dPb/rExr0Btby5loQm20Q==", "dev": true } } }, "jest-util": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-29.7.0.tgz", - "integrity": "sha512-z6EbKajIpqGKU56y5KBUgy1dt1ihhQJgWzUlZHArA/+X2ad7Cb5iF+AK1EWVL/Bo7Rz9uurpqw6SiBCefUbCGA==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-30.2.0.tgz", + "integrity": "sha512-QKNsM0o3Xe6ISQU869e+DhG+4CK/48aHYdJZGlFQVTjnbvgpcKyxpzk29fGiO7i/J8VENZ+d2iGnSsvmuHywlA==", "dev": true, "requires": { - "@jest/types": "^29.6.3", + "@jest/types": "30.2.0", "@types/node": "*", - "chalk": "^4.0.0", - "ci-info": "^3.2.0", - "graceful-fs": "^4.2.9", - "picomatch": "^2.2.3" + "chalk": "^4.1.2", + "ci-info": "^4.2.0", + "graceful-fs": "^4.2.11", + "picomatch": "^4.0.2" + }, + "dependencies": { + "picomatch": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-4.0.3.tgz", + "integrity": "sha512-5gTmgEY/sqK6gFXLIsQNH19lWb4ebPDLA4SdLP7dsWkIXHWlG66oPuVvXSGFPppYZz8ZDZq0dYYrbHfBCVUb1Q==", + "dev": true + } } }, "jest-validate": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-validate/-/jest-validate-29.7.0.tgz", - "integrity": "sha512-ZB7wHqaRGVw/9hST/OuFUReG7M8vKeq0/J2egIGLdvjHCmYqGARhzXmtgi+gVeZ5uXFF219aOc3Ls2yLg27tkw==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-validate/-/jest-validate-30.2.0.tgz", + "integrity": "sha512-FBGWi7dP2hpdi8nBoWxSsLvBFewKAg0+uSQwBaof4Y4DPgBabXgpSYC5/lR7VmnIlSpASmCi/ntRWPbv7089Pw==", "dev": true, "requires": { - "@jest/types": "^29.6.3", - "camelcase": "^6.2.0", - "chalk": "^4.0.0", - "jest-get-type": "^29.6.3", + "@jest/get-type": "30.1.0", + "@jest/types": "30.2.0", + "camelcase": "^6.3.0", + "chalk": "^4.1.2", "leven": "^3.1.0", - "pretty-format": "^29.7.0" + "pretty-format": "30.2.0" }, "dependencies": { "ansi-styles": { @@ -11683,50 +11638,51 @@ "dev": true }, "pretty-format": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-29.7.0.tgz", - "integrity": "sha512-Pdlw/oPxN+aXdmM9R00JVC9WVFoCLTKJvDVLgmJ+qAffBMxsV85l/Lu7sNx4zSzPyoL2euImuEwHhOXdEgNFZQ==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-30.2.0.tgz", + "integrity": "sha512-9uBdv/B4EefsuAL+pWqueZyZS2Ba+LxfFeQ9DN14HU4bN8bhaxKdkpjpB6fs9+pSjIBu+FXQHImEg8j/Lw0+vA==", "dev": true, "requires": { - "@jest/schemas": "^29.6.3", - "ansi-styles": "^5.0.0", - "react-is": "^18.0.0" + "@jest/schemas": "30.0.5", + "ansi-styles": "^5.2.0", + "react-is": "^18.3.1" } }, "react-is": { - "version": "18.2.0", - "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz", - "integrity": "sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w==", + "version": "18.3.1", + "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.3.1.tgz", + "integrity": "sha512-/LLMVyas0ljjAtoYiPqYiL8VWXzUUdThrmU5+n20DZv+a+ClRoevUzw5JxU+Ieh5/c87ytoTBV9G1FiKfNJdmg==", "dev": true } } }, "jest-watcher": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-watcher/-/jest-watcher-29.7.0.tgz", - "integrity": "sha512-49Fg7WXkU3Vl2h6LbLtMQ/HyB6rXSIX7SqvBLQmssRBGN9I0PNvPmAmCWSOY6SOvrjhI/F7/bGAv9RtnsPA03g==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-watcher/-/jest-watcher-30.2.0.tgz", + "integrity": "sha512-PYxa28dxJ9g777pGm/7PrbnMeA0Jr7osHP9bS7eJy9DuAjMgdGtxgf0uKMyoIsTWAkIbUW5hSDdJ3urmgXBqxg==", "dev": true, "requires": { - "@jest/test-result": "^29.7.0", - "@jest/types": "^29.6.3", + "@jest/test-result": "30.2.0", + "@jest/types": "30.2.0", "@types/node": "*", - "ansi-escapes": "^4.2.1", - "chalk": "^4.0.0", + "ansi-escapes": "^4.3.2", + "chalk": "^4.1.2", "emittery": "^0.13.1", - "jest-util": "^29.7.0", - "string-length": "^4.0.1" + "jest-util": "30.2.0", + "string-length": "^4.0.2" } }, "jest-worker": { - "version": "29.7.0", - "resolved": "https://registry.npmjs.org/jest-worker/-/jest-worker-29.7.0.tgz", - "integrity": "sha512-eIz2msL/EzL9UFTFFx7jBTkeZfku0yUAyZZZmJ93H2TYEiroIx2PQjEXcwYtYl8zXCxb+PAmA2hLIt/6ZEkPHw==", + "version": "30.2.0", + "resolved": "https://registry.npmjs.org/jest-worker/-/jest-worker-30.2.0.tgz", + "integrity": "sha512-0Q4Uk8WF7BUwqXHuAjc23vmopWJw5WH7w2tqBoUOZpOjW/ZnR44GXXd1r82RvnmI2GZge3ivrYXk/BE2+VtW2g==", "dev": true, "requires": { "@types/node": "*", - "jest-util": "^29.7.0", + "@ungap/structured-clone": "^1.3.0", + "jest-util": "30.2.0", "merge-stream": "^2.0.0", - "supports-color": "^8.0.0" + "supports-color": "^8.1.1" }, "dependencies": { "supports-color": { @@ -11790,9 +11746,9 @@ } }, "jsesc": { - "version": "2.5.2", - "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", - "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-3.1.0.tgz", + "integrity": "sha512-/sM3dO2FOzXjKQhJuo0Q173wf2KOo8t4I8vHy6lF9poUp7bKT0/NHE8fPX23PwfhnykfqnC2xRxOnVw5XuGIaA==", "dev": true }, "json-buffer": { @@ -11834,12 +11790,6 @@ "json-buffer": "3.0.1" } }, - "kleur": { - "version": "3.0.3", - "resolved": "https://registry.npmjs.org/kleur/-/kleur-3.0.3.tgz", - "integrity": "sha512-eTIzlVOSUR+JxdDFepEYcBMtZ9Qqdef+rnzWdRZuMbOywu5tO2w2N7rqjoANZ5k9vywhL6Br1VRjUIgTQx4E8w==", - "dev": true - }, "leven": { "version": "3.1.0", "resolved": "https://registry.npmjs.org/leven/-/leven-3.1.0.tgz", @@ -11891,12 +11841,6 @@ "wrap-ansi": "^9.0.0" }, "dependencies": { - "ansi-regex": { - "version": "6.2.2", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.2.2.tgz", - "integrity": "sha512-Bq3SmSpyFHaWjPk8If9yc6svM8c56dB5BAtW4Qbw5jHTwwXXcTLoRMkpDJp6VL0XzlWaCHTXrkFURMYmD0sLqg==", - "dev": true - }, "ansi-styles": { "version": "6.2.3", "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.3.tgz", @@ -11920,15 +11864,6 @@ "strip-ansi": "^7.1.0" } }, - "strip-ansi": { - "version": "7.1.2", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.2.tgz", - "integrity": "sha512-gmBGslpoQJtgnMAvOVqGZpEz9dyoKTCzy2nfz/n8aIFhN/jCE/rCmcxabB6jOOHV+0WNnylOxaxBQPSvcWklhA==", - "dev": true, - "requires": { - "ansi-regex": "^6.0.1" - } - }, "wrap-ansi": { "version": "9.0.2", "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-9.0.2.tgz", @@ -11985,12 +11920,6 @@ "environment": "^1.0.0" } }, - "ansi-regex": { - "version": "6.2.2", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.2.2.tgz", - "integrity": "sha512-Bq3SmSpyFHaWjPk8If9yc6svM8c56dB5BAtW4Qbw5jHTwwXXcTLoRMkpDJp6VL0XzlWaCHTXrkFURMYmD0sLqg==", - "dev": true - }, "ansi-styles": { "version": "6.2.3", "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.3.tgz", @@ -12014,15 +11943,6 @@ "strip-ansi": "^7.1.0" } }, - "strip-ansi": { - "version": "7.1.2", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.2.tgz", - "integrity": "sha512-gmBGslpoQJtgnMAvOVqGZpEz9dyoKTCzy2nfz/n8aIFhN/jCE/rCmcxabB6jOOHV+0WNnylOxaxBQPSvcWklhA==", - "dev": true, - "requires": { - "ansi-regex": "^6.0.1" - } - }, "wrap-ansi": { "version": "9.0.2", "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-9.0.2.tgz", @@ -12060,28 +11980,10 @@ "semver": "^7.5.3" }, "dependencies": { - "lru-cache": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", - "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", - "dev": true, - "requires": { - "yallist": "^4.0.0" - } - }, "semver": { - "version": "7.5.4", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz", - "integrity": "sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA==", - "dev": true, - "requires": { - "lru-cache": "^6.0.0" - } - }, - "yallist": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", - "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", + "version": "7.7.3", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.7.3.tgz", + "integrity": "sha512-SdsKMrI9TdgjdweUSR9MweHA4EJ8YxHn8DFaDisvhVlUOe4BF1tLD7GAj0lIqWVl+dPb/rExr0Btby5loQm20Q==", "dev": true } } @@ -12168,6 +12070,12 @@ "brace-expansion": "^1.1.7" } }, + "minipass": { + "version": "7.1.2", + "resolved": "https://registry.npmjs.org/minipass/-/minipass-7.1.2.tgz", + "integrity": "sha512-qOOzS1cBTWYF4BH8fVePDBOO9iptMnGUEZwNc/cMWnTV2nVLZ7VoNWEPHkYczZA0pdoA7dl6e7FL659nX9S2aw==", + "dev": true + }, "ms": { "version": "2.1.3", "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", @@ -12180,6 +12088,12 @@ "integrity": "sha512-jtpsQDetTnvS2Ts1fiRdci5rx0VYws5jGyC+4IYOTnIQ/wwdf6JdomlHBwqC3bJYOvaKu0C2GSZ1A60anrYpaA==", "dev": true }, + "napi-postinstall": { + "version": "0.3.4", + "resolved": "https://registry.npmjs.org/napi-postinstall/-/napi-postinstall-0.3.4.tgz", + "integrity": "sha512-PHI5f1O0EP5xJ9gQmFGMS6IZcrVvTjpXjz7Na41gTE7eE2hK11lg04CECCYEEjdc17EV4DO+fkGEtt7TpTaTiQ==", + "dev": true + }, "natural-compare": { "version": "1.4.0", "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", @@ -12199,9 +12113,9 @@ "dev": true }, "node-releases": { - "version": "2.0.13", - "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.13.tgz", - "integrity": "sha512-uYr7J37ae/ORWdZeQ1xxMJe3NtdmqMC/JZK+geofDrkLUApKRHPd18/TxtBOJ4A0/+uUIliorNrfYV6s1b02eQ==", + "version": "2.0.23", + "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.23.tgz", + "integrity": "sha512-cCmFDMSm26S6tQSDpBCg/NR8NENrVPhAJSf+XbxBG4rPFaaonlEoE9wHQmun+cls499TQGSb7ZyPBRlzgKfpeg==", "dev": true }, "normalize-path": { @@ -12310,6 +12224,12 @@ "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", "dev": true }, + "package-json-from-dist": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/package-json-from-dist/-/package-json-from-dist-1.0.1.tgz", + "integrity": "sha512-UEZIS3/by4OC8vL3P2dTXRETpebLI2NiI5vIrjaD/5UtrkFX/tNbwjTSRAGC/+7CAo2pIcBaRgWmcBBHcsaCIw==", + "dev": true + }, "parent-module": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", @@ -12385,11 +12305,23 @@ "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", "dev": true }, - "path-parse": { - "version": "1.0.7", - "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", - "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", - "dev": true + "path-scurry": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/path-scurry/-/path-scurry-1.11.1.tgz", + "integrity": "sha512-Xa4Nw17FS9ApQFJ9umLiJS4orGjm7ZzwUrwamcGQuHSzDyth9boKDaycYdDcZDuqYATXw4HFXgaqWTctW/v1HA==", + "dev": true, + "requires": { + "lru-cache": "^10.2.0", + "minipass": "^5.0.0 || ^6.0.2 || ^7.0.0" + }, + "dependencies": { + "lru-cache": { + "version": "10.4.3", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-10.4.3.tgz", + "integrity": "sha512-JNAzZcXrCt42VGLuYz0zfAzDfAvJWW6AfYlDBQyDV5DClI2m5sAmK+OIO7s59XfsRsWHp02jAJrRadPRGTt6SQ==", + "dev": true + } + } }, "path-to-regexp": { "version": "8.3.0", @@ -12416,9 +12348,9 @@ "dev": true }, "pirates": { - "version": "4.0.6", - "resolved": "https://registry.npmjs.org/pirates/-/pirates-4.0.6.tgz", - "integrity": "sha512-saLsH7WeYYPiD25LDuLRRY/i+6HaPYr6G1OUlN39otzkSTxKnubR9RTxS3/Kk50s1g2JTgFwWQDQyplC5/SHZg==", + "version": "4.0.7", + "resolved": "https://registry.npmjs.org/pirates/-/pirates-4.0.7.tgz", + "integrity": "sha512-TfySrs/5nm8fQJDcBDuUng3VOUKsd7S+zqvbOTiGXHfxX4wK31ard+hoNuvkicM/2YFzlpDgABOevKSsB4G/FA==", "dev": true }, "pkg-dir": { @@ -12461,16 +12393,6 @@ } } }, - "prompts": { - "version": "2.4.2", - "resolved": "https://registry.npmjs.org/prompts/-/prompts-2.4.2.tgz", - "integrity": "sha512-NxNv/kLguCA7p3jE8oL2aEBsrJWgAakBpgmgK6lpPWV+WuOmY6r2/zbAVnP+T8bQlA0nzHXSJSJW0Hq7ylaD2Q==", - "dev": true, - "requires": { - "kleur": "^3.0.3", - "sisteransi": "^1.0.5" - } - }, "proxy-addr": { "version": "2.0.7", "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", @@ -12493,9 +12415,9 @@ "dev": true }, "pure-rand": { - "version": "6.0.3", - "resolved": "https://registry.npmjs.org/pure-rand/-/pure-rand-6.0.3.tgz", - "integrity": "sha512-KddyFewCsO0j3+np81IQ+SweXLDnDQTs5s67BOnrYmYe/yNmUhttQyGsYzy8yUnoljGAQ9sl38YB4vH8ur7Y+w==", + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/pure-rand/-/pure-rand-7.0.1.tgz", + "integrity": "sha512-oTUZM/NAZS8p7ANR3SHh30kXB+zK2r2BPcEn/awJIbOvq82WoMN4p62AWWp3Hhw50G0xMsw1mhIBLqHw64EcNQ==", "dev": true }, "qs": { @@ -12564,17 +12486,6 @@ "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", "dev": true }, - "resolve": { - "version": "1.22.6", - "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.6.tgz", - "integrity": "sha512-njhxM7mV12JfufShqGy3Rz8j11RPdLy4xi15UurGJeoHLfJpVXKdh3ueuOqbYUcDZnffr6X739JBo5LzyahEsw==", - "dev": true, - "requires": { - "is-core-module": "^2.13.0", - "path-parse": "^1.0.7", - "supports-preserve-symlinks-flag": "^1.0.0" - } - }, "resolve-cwd": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/resolve-cwd/-/resolve-cwd-3.0.0.tgz", @@ -12590,12 +12501,6 @@ "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==", "dev": true }, - "resolve.exports": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/resolve.exports/-/resolve.exports-2.0.2.tgz", - "integrity": "sha512-X2UW6Nw3n/aMgDVy+0rSqgHlv39WZAlZrXCdnbyEiKm17DSqHX4MmQMaST3FbeWR5FTuRcUwYAziZajji0Y7mg==", - "dev": true - }, "restore-cursor": { "version": "5.1.0", "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-5.1.0.tgz", @@ -12614,12 +12519,6 @@ "requires": { "mimic-function": "^5.0.0" } - }, - "signal-exit": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-4.1.0.tgz", - "integrity": "sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw==", - "dev": true } } }, @@ -12793,15 +12692,9 @@ } }, "signal-exit": { - "version": "3.0.7", - "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", - "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", - "dev": true - }, - "sisteransi": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/sisteransi/-/sisteransi-1.0.5.tgz", - "integrity": "sha512-bLGGlR1QxBcynn2d5YmDX4MGjlZvy2MRBDRNHLJ8VI6l6+9FUiyTFNJ0IveOSP0bcXgVDPRcfGqA0pjaqUpfVg==", + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-4.1.0.tgz", + "integrity": "sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw==", "dev": true }, "slash": { @@ -12910,10 +12803,32 @@ "requires": { "char-regex": "^1.0.2", "strip-ansi": "^6.0.0" + }, + "dependencies": { + "strip-ansi": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", + "dev": true, + "requires": { + "ansi-regex": "^5.0.1" + } + } } }, "string-width": { - "version": "4.2.3", + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-5.1.2.tgz", + "integrity": "sha512-HnLOCR3vjcY8beoNLtcjZ5/nxn2afmME6lhrDrebokqMap+XbeW8n9TXpPDOqdGK5qcI3oT0GKTW6wC7EMiVqA==", + "dev": true, + "requires": { + "eastasianwidth": "^0.2.0", + "emoji-regex": "^9.2.2", + "strip-ansi": "^7.0.1" + } + }, + "string-width-cjs": { + "version": "npm:string-width@4.2.3", "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", "dev": true, @@ -12921,10 +12836,44 @@ "emoji-regex": "^8.0.0", "is-fullwidth-code-point": "^3.0.0", "strip-ansi": "^6.0.1" + }, + "dependencies": { + "emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "dev": true + }, + "strip-ansi": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", + "dev": true, + "requires": { + "ansi-regex": "^5.0.1" + } + } } }, "strip-ansi": { - "version": "6.0.1", + "version": "7.1.2", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.2.tgz", + "integrity": "sha512-gmBGslpoQJtgnMAvOVqGZpEz9dyoKTCzy2nfz/n8aIFhN/jCE/rCmcxabB6jOOHV+0WNnylOxaxBQPSvcWklhA==", + "dev": true, + "requires": { + "ansi-regex": "^6.0.1" + }, + "dependencies": { + "ansi-regex": { + "version": "6.2.2", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.2.2.tgz", + "integrity": "sha512-Bq3SmSpyFHaWjPk8If9yc6svM8c56dB5BAtW4Qbw5jHTwwXXcTLoRMkpDJp6VL0XzlWaCHTXrkFURMYmD0sLqg==", + "dev": true + } + } + }, + "strip-ansi-cjs": { + "version": "npm:strip-ansi@6.0.1", "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", "dev": true, @@ -12968,18 +12917,21 @@ "has-flag": "^4.0.0" } }, - "supports-preserve-symlinks-flag": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", - "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", - "dev": true - }, "symbol-tree": { "version": "3.2.4", "resolved": "https://registry.npmjs.org/symbol-tree/-/symbol-tree-3.2.4.tgz", "integrity": "sha512-9QNk5KwDF+Bvz+PyObkmSYjI5ksVUYtjW7AU22r2NKcfLJcXp96hkDWU3+XndOsUb+AQ9QhfzfCT2O+CNWT5Tw==", "dev": true }, + "synckit": { + "version": "0.11.11", + "resolved": "https://registry.npmjs.org/synckit/-/synckit-0.11.11.tgz", + "integrity": "sha512-MeQTA1r0litLUf0Rp/iisCaL8761lKAZHaimlbGK4j0HysC4PLfqygQj9srcs0m2RdtDYnF8UuYyKpbjHYp7Jw==", + "dev": true, + "requires": { + "@pkgr/core": "^0.2.9" + } + }, "test-exclude": { "version": "6.0.0", "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz", @@ -12989,6 +12941,22 @@ "@istanbuljs/schema": "^0.1.2", "glob": "^7.1.4", "minimatch": "^3.0.4" + }, + "dependencies": { + "glob": { + "version": "7.2.3", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", + "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", + "dev": true, + "requires": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.1.1", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + } + } } }, "tldts": { @@ -13012,12 +12980,6 @@ "integrity": "sha512-3f0uOEAQwIqGuWW2MVzYg8fV/QNnc/IpuJNG837rLuczAaLVHslWHZQj4IGiEl5Hs3kkbhwL9Ab7Hrsmuj+Smw==", "dev": true }, - "to-fast-properties": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", - "integrity": "sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==", - "dev": true - }, "to-regex-range": { "version": "5.0.1", "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", @@ -13051,6 +13013,13 @@ "punycode": "^2.3.1" } }, + "tslib": { + "version": "2.8.1", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.8.1.tgz", + "integrity": "sha512-oJFu94HQb+KVduSUQL7wnpmqnfmLsOA/nAh6b6EH0wCEoK0/mPeXU6c3wKDV83MkOuHPRHtSXKKU99IBazS/2w==", + "dev": true, + "optional": true + }, "tunnel": { "version": "0.0.6", "resolved": "https://registry.npmjs.org/tunnel/-/tunnel-0.0.6.tgz", @@ -13127,14 +13096,42 @@ "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==", "dev": true }, + "unrs-resolver": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/unrs-resolver/-/unrs-resolver-1.11.1.tgz", + "integrity": "sha512-bSjt9pjaEBnNiGgc9rUiHGKv5l4/TGzDmYw3RhnkJGtLhbnnA/5qJj7x3dNDCRx/PJxu774LlH8lCOlB4hEfKg==", + "dev": true, + "requires": { + "@unrs/resolver-binding-android-arm-eabi": "1.11.1", + "@unrs/resolver-binding-android-arm64": "1.11.1", + "@unrs/resolver-binding-darwin-arm64": "1.11.1", + "@unrs/resolver-binding-darwin-x64": "1.11.1", + "@unrs/resolver-binding-freebsd-x64": "1.11.1", + "@unrs/resolver-binding-linux-arm-gnueabihf": "1.11.1", + "@unrs/resolver-binding-linux-arm-musleabihf": "1.11.1", + "@unrs/resolver-binding-linux-arm64-gnu": "1.11.1", + "@unrs/resolver-binding-linux-arm64-musl": "1.11.1", + "@unrs/resolver-binding-linux-ppc64-gnu": "1.11.1", + "@unrs/resolver-binding-linux-riscv64-gnu": "1.11.1", + "@unrs/resolver-binding-linux-riscv64-musl": "1.11.1", + "@unrs/resolver-binding-linux-s390x-gnu": "1.11.1", + "@unrs/resolver-binding-linux-x64-gnu": "1.11.1", + "@unrs/resolver-binding-linux-x64-musl": "1.11.1", + "@unrs/resolver-binding-wasm32-wasi": "1.11.1", + "@unrs/resolver-binding-win32-arm64-msvc": "1.11.1", + "@unrs/resolver-binding-win32-ia32-msvc": "1.11.1", + "@unrs/resolver-binding-win32-x64-msvc": "1.11.1", + "napi-postinstall": "^0.3.0" + } + }, "update-browserslist-db": { - "version": "1.0.11", - "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.11.tgz", - "integrity": "sha512-dCwEFf0/oT85M1fHBg4F0jtLwJrutGoHSQXCh7u4o2t1drG+c0a9Flnqww6XUKSfQMPpJBRjU8d4RXB09qtvaA==", + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.1.3.tgz", + "integrity": "sha512-UxhIZQ+QInVdunkDAaiazvvT/+fXL5Osr0JZlJulepYu6Jd7qJtDZjlur0emRlT71EN3ScPoE7gvsuIKKNavKw==", "dev": true, "requires": { - "escalade": "^3.1.1", - "picocolors": "^1.0.0" + "escalade": "^3.2.0", + "picocolors": "^1.1.1" } }, "uri-js": { @@ -13147,22 +13144,14 @@ } }, "v8-to-istanbul": { - "version": "9.1.0", - "resolved": "https://registry.npmjs.org/v8-to-istanbul/-/v8-to-istanbul-9.1.0.tgz", - "integrity": "sha512-6z3GW9x8G1gd+JIIgQQQxXuiJtCXeAjp6RaPEPLv62mH3iPHPxV6W3robxtCzNErRo6ZwTmzWhsbNvjyEBKzKA==", + "version": "9.3.0", + "resolved": "https://registry.npmjs.org/v8-to-istanbul/-/v8-to-istanbul-9.3.0.tgz", + "integrity": "sha512-kiGUalWN+rgBJ/1OHZsBtU4rXZOfj/7rKQxULKlIzwzQSvMJUUNgPwJEEh7gU6xEVxC0ahoOBvN2YI8GH6FNgA==", "dev": true, "requires": { "@jridgewell/trace-mapping": "^0.3.12", "@types/istanbul-lib-coverage": "^2.0.1", - "convert-source-map": "^1.6.0" - }, - "dependencies": { - "convert-source-map": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.9.0.tgz", - "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==", - "dev": true - } + "convert-source-map": "^2.0.0" } }, "vary": { @@ -13235,7 +13224,26 @@ "integrity": "sha512-BN22B5eaMMI9UMtjrGd5g5eCYPpCPDUy0FJXbYsaT5zYxjFOckS53SQDE3pWkVoWpHXVb3BrYcEN4Twa55B5cA==" }, "wrap-ansi": { - "version": "7.0.0", + "version": "8.1.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-8.1.0.tgz", + "integrity": "sha512-si7QWI6zUMq56bESFvagtmzMdGOtoxfR+Sez11Mobfc7tm+VkUckk9bW2UeffTGVUbOksxmSw0AA2gs8g71NCQ==", + "dev": true, + "requires": { + "ansi-styles": "^6.1.0", + "string-width": "^5.0.1", + "strip-ansi": "^7.0.1" + }, + "dependencies": { + "ansi-styles": { + "version": "6.2.3", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.3.tgz", + "integrity": "sha512-4Dj6M28JB+oAH8kFkTLUo+a2jwOFkuqb3yucU0CANcRRUbxS0cP0nZYCGjcc3BNXwRIsUVmDGgzawme7zvJHvg==", + "dev": true + } + } + }, + "wrap-ansi-cjs": { + "version": "npm:wrap-ansi@7.0.0", "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", "dev": true, @@ -13243,6 +13251,34 @@ "ansi-styles": "^4.0.0", "string-width": "^4.1.0", "strip-ansi": "^6.0.0" + }, + "dependencies": { + "emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "dev": true + }, + "string-width": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", + "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", + "dev": true, + "requires": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.1" + } + }, + "strip-ansi": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", + "dev": true, + "requires": { + "ansi-regex": "^5.0.1" + } + } } }, "wrappy": { @@ -13252,13 +13288,13 @@ "dev": true }, "write-file-atomic": { - "version": "4.0.2", - "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-4.0.2.tgz", - "integrity": "sha512-7KxauUdBmSdWnmpaGFg+ppNjKF8uNLry8LyzjauQDOVONfFLNKrKvQOxZ/VuTIcS/gge/YNahf5RIIQWTSarlg==", + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-5.0.1.tgz", + "integrity": "sha512-+QU2zd6OTD8XWIJCbffaiQeH9U73qIqafo1x6V1snCWYGJf6cVE0cDR4D8xRzcEnfI21IFrUPzPGtcPf8AC+Rw==", "dev": true, "requires": { "imurmurhash": "^0.1.4", - "signal-exit": "^3.0.7" + "signal-exit": "^4.0.1" } }, "ws": { @@ -13311,6 +13347,34 @@ "string-width": "^4.2.3", "y18n": "^5.0.5", "yargs-parser": "^21.1.1" + }, + "dependencies": { + "emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "dev": true + }, + "string-width": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", + "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", + "dev": true, + "requires": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.1" + } + }, + "strip-ansi": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", + "dev": true, + "requires": { + "ansi-regex": "^5.0.1" + } + } } }, "yargs-parser": { diff --git a/package.json b/package.json index 00d10bf64d06f..83d22f5b8d06a 100644 --- a/package.json +++ b/package.json @@ -52,7 +52,7 @@ "globals": "^16.4.0", "hjson": "^3.2.2", "husky": "^9.1.7", - "jest": "^29.7.0", + "jest": "^30.2.0", "jest-environment-jsdom": "^30.2.0", "js-yaml": "^4.1.0", "lint-staged": "^16.2.3", diff --git a/tests/__snapshots__/renderWakatimeCard.test.js.snap b/tests/__snapshots__/renderWakatimeCard.test.js.snap index 3727c36a39449..8b423afbb5951 100644 --- a/tests/__snapshots__/renderWakatimeCard.test.js.snap +++ b/tests/__snapshots__/renderWakatimeCard.test.js.snap @@ -1,4 +1,4 @@ -// Jest Snapshot v1, https://goo.gl/fbAQLP +// Jest Snapshot v1, https://jestjs.io/docs/snapshot-testing exports[`Test Render WakaTime Card should render correctly 1`] = ` " diff --git a/tests/api.test.js b/tests/api.test.js index e54764a31aaf4..967bfae64b500 100644 --- a/tests/api.test.js +++ b/tests/api.test.js @@ -90,6 +90,7 @@ const error = { const mock = new MockAdapter(axios); +// @ts-ignore const faker = (query, data) => { const req = { query: { @@ -120,8 +121,10 @@ describe("Test /api/", () => { await api(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); - expect(res.send).toBeCalledWith(renderStatsCard(stats, { ...req.query })); + expect(res.setHeader).toHaveBeenCalledWith("Content-Type", "image/svg+xml"); + expect(res.send).toHaveBeenCalledWith( + renderStatsCard(stats, { ...req.query }), + ); }); it("should render error card on error", async () => { @@ -129,8 +132,8 @@ describe("Test /api/", () => { await api(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); - expect(res.send).toBeCalledWith( + expect(res.setHeader).toHaveBeenCalledWith("Content-Type", "image/svg+xml"); + expect(res.send).toHaveBeenCalledWith( renderError({ message: error.errors[0].message, secondaryMessage: @@ -144,8 +147,8 @@ describe("Test /api/", () => { await api(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); - expect(res.send).toBeCalledWith( + expect(res.setHeader).toHaveBeenCalledWith("Content-Type", "image/svg+xml"); + expect(res.send).toHaveBeenCalledWith( renderError({ message: error.errors[0].message, secondaryMessage: @@ -173,8 +176,8 @@ describe("Test /api/", () => { await api(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); - expect(res.send).toBeCalledWith( + expect(res.setHeader).toHaveBeenCalledWith("Content-Type", "image/svg+xml"); + expect(res.send).toHaveBeenCalledWith( renderStatsCard(stats, { hide: ["issues", "prs", "contribs"], show_icons: true, @@ -337,8 +340,8 @@ describe("Test /api/", () => { await api(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); - expect(res.send).toBeCalledWith( + expect(res.setHeader).toHaveBeenCalledWith("Content-Type", "image/svg+xml"); + expect(res.send).toHaveBeenCalledWith( renderStatsCard(stats, { hide: ["issues", "prs", "contribs"], show_icons: true, @@ -358,8 +361,8 @@ describe("Test /api/", () => { await api(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); - expect(res.send).toBeCalledWith( + expect(res.setHeader).toHaveBeenCalledWith("Content-Type", "image/svg+xml"); + expect(res.send).toHaveBeenCalledWith( renderError({ message: "This username is blacklisted", secondaryMessage: "Please deploy your own instance", @@ -373,8 +376,8 @@ describe("Test /api/", () => { await api(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); - expect(res.send).toBeCalledWith( + expect(res.setHeader).toHaveBeenCalledWith("Content-Type", "image/svg+xml"); + expect(res.send).toHaveBeenCalledWith( renderError({ message: "Something went wrong", secondaryMessage: "Language not found", @@ -394,8 +397,8 @@ describe("Test /api/", () => { await api(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); - expect(res.send).toBeCalledWith( + expect(res.setHeader).toHaveBeenCalledWith("Content-Type", "image/svg+xml"); + expect(res.send).toHaveBeenCalledWith( renderError({ message: "Could not fetch total commits.", secondaryMessage: "Please try again later", diff --git a/tests/gist.test.js b/tests/gist.test.js index 1f3b6000c658f..cb69f9ed7e1ef 100644 --- a/tests/gist.test.js +++ b/tests/gist.test.js @@ -65,8 +65,8 @@ describe("Test /api/gist", () => { await gist(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); - expect(res.send).toBeCalledWith( + expect(res.setHeader).toHaveBeenCalledWith("Content-Type", "image/svg+xml"); + expect(res.send).toHaveBeenCalledWith( renderGistCard({ name: gist_data.data.viewer.gist.files[0].name, nameWithOwner: `${gist_data.data.viewer.gist.owner.login}/${gist_data.data.viewer.gist.files[0].name}`, @@ -97,8 +97,8 @@ describe("Test /api/gist", () => { await gist(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); - expect(res.send).toBeCalledWith( + expect(res.setHeader).toHaveBeenCalledWith("Content-Type", "image/svg+xml"); + expect(res.send).toHaveBeenCalledWith( renderGistCard( { name: gist_data.data.viewer.gist.files[0].name, @@ -124,8 +124,8 @@ describe("Test /api/gist", () => { await gist(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); - expect(res.send).toBeCalledWith( + expect(res.setHeader).toHaveBeenCalledWith("Content-Type", "image/svg+xml"); + expect(res.send).toHaveBeenCalledWith( renderError({ message: 'Missing params "id" make sure you pass the parameters in URL', secondaryMessage: "/api/gist?id=GIST_ID", @@ -149,8 +149,10 @@ describe("Test /api/gist", () => { await gist(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); - expect(res.send).toBeCalledWith(renderError({ message: "Gist not found" })); + expect(res.setHeader).toHaveBeenCalledWith("Content-Type", "image/svg+xml"); + expect(res.send).toHaveBeenCalledWith( + renderError({ message: "Gist not found" }), + ); }); it("should render error if wrong locale is provided", async () => { @@ -167,8 +169,8 @@ describe("Test /api/gist", () => { await gist(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); - expect(res.send).toBeCalledWith( + expect(res.setHeader).toHaveBeenCalledWith("Content-Type", "image/svg+xml"); + expect(res.send).toHaveBeenCalledWith( renderError({ message: "Something went wrong", secondaryMessage: "Language not found", @@ -190,8 +192,8 @@ describe("Test /api/gist", () => { await gist(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); - expect(res.setHeader).toBeCalledWith( + expect(res.setHeader).toHaveBeenCalledWith("Content-Type", "image/svg+xml"); + expect(res.setHeader).toHaveBeenCalledWith( "Cache-Control", `max-age=${CACHE_TTL.GIST_CARD.DEFAULT}, ` + `s-maxage=${CACHE_TTL.GIST_CARD.DEFAULT}, ` + diff --git a/tests/pat-info.test.js b/tests/pat-info.test.js index a46eee15547f7..a14e78ee971bb 100644 --- a/tests/pat-info.test.js +++ b/tests/pat-info.test.js @@ -90,8 +90,11 @@ describe("Test /api/status/pat-info", () => { const { req, res } = faker({}, {}); await patInfo(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "application/json"); - expect(res.send).toBeCalledWith( + expect(res.setHeader).toHaveBeenCalledWith( + "Content-Type", + "application/json", + ); + expect(res.send).toHaveBeenCalledWith( JSON.stringify( { validPATs: ["PAT_2", "PAT_3", "PAT_4"], @@ -135,8 +138,11 @@ describe("Test /api/status/pat-info", () => { const { req, res } = faker({}, {}); await patInfo(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "application/json"); - expect(res.send).toBeCalledWith( + expect(res.setHeader).toHaveBeenCalledWith( + "Content-Type", + "application/json", + ); + expect(res.send).toHaveBeenCalledWith( JSON.stringify( { validPATs: ["PAT_2", "PAT_3", "PAT_4"], @@ -182,8 +188,11 @@ describe("Test /api/status/pat-info", () => { const { req, res } = faker({}, {}); await patInfo(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "application/json"); - expect(res.send).toBeCalledWith( + expect(res.setHeader).toHaveBeenCalledWith( + "Content-Type", + "application/json", + ); + expect(res.send).toHaveBeenCalledWith( JSON.stringify( { validPATs: ["PAT_2", "PAT_3", "PAT_4"], @@ -221,8 +230,13 @@ describe("Test /api/status/pat-info", () => { const { req, res } = faker({}, {}); await patInfo(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "application/json"); - expect(res.send).toBeCalledWith("Something went wrong: Network Error"); + expect(res.setHeader).toHaveBeenCalledWith( + "Content-Type", + "application/json", + ); + expect(res.send).toHaveBeenCalledWith( + "Something went wrong: Network Error", + ); }); it("should have proper cache when no error is thrown", async () => { diff --git a/tests/pin.test.js b/tests/pin.test.js index 91c756dda0282..aabcfde0b6b53 100644 --- a/tests/pin.test.js +++ b/tests/pin.test.js @@ -56,8 +56,8 @@ describe("Test /api/pin", () => { await pin(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); - expect(res.send).toBeCalledWith( + expect(res.setHeader).toHaveBeenCalledWith("Content-Type", "image/svg+xml"); + expect(res.send).toHaveBeenCalledWith( // @ts-ignore renderRepoCard({ ...data_repo.repository, @@ -86,8 +86,8 @@ describe("Test /api/pin", () => { await pin(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); - expect(res.send).toBeCalledWith( + expect(res.setHeader).toHaveBeenCalledWith("Content-Type", "image/svg+xml"); + expect(res.send).toHaveBeenCalledWith( renderRepoCard( // @ts-ignore { @@ -116,8 +116,8 @@ describe("Test /api/pin", () => { await pin(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); - expect(res.send).toBeCalledWith( + expect(res.setHeader).toHaveBeenCalledWith("Content-Type", "image/svg+xml"); + expect(res.send).toHaveBeenCalledWith( renderError({ message: "User Repository Not found" }), ); }); @@ -139,8 +139,8 @@ describe("Test /api/pin", () => { await pin(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); - expect(res.send).toBeCalledWith( + expect(res.setHeader).toHaveBeenCalledWith("Content-Type", "image/svg+xml"); + expect(res.send).toHaveBeenCalledWith( renderError({ message: "Organization Repository Not found" }), ); }); @@ -160,8 +160,8 @@ describe("Test /api/pin", () => { await pin(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); - expect(res.send).toBeCalledWith( + expect(res.setHeader).toHaveBeenCalledWith("Content-Type", "image/svg+xml"); + expect(res.send).toHaveBeenCalledWith( renderError({ message: "This username is blacklisted", secondaryMessage: "Please deploy your own instance", @@ -186,8 +186,8 @@ describe("Test /api/pin", () => { await pin(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); - expect(res.send).toBeCalledWith( + expect(res.setHeader).toHaveBeenCalledWith("Content-Type", "image/svg+xml"); + expect(res.send).toHaveBeenCalledWith( renderError({ message: "Something went wrong", secondaryMessage: "Language not found", @@ -206,8 +206,8 @@ describe("Test /api/pin", () => { await pin(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); - expect(res.send).toBeCalledWith( + expect(res.setHeader).toHaveBeenCalledWith("Content-Type", "image/svg+xml"); + expect(res.send).toHaveBeenCalledWith( renderError({ message: 'Missing params "username", "repo" make sure you pass the parameters in URL', @@ -231,8 +231,8 @@ describe("Test /api/pin", () => { await pin(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); - expect(res.setHeader).toBeCalledWith( + expect(res.setHeader).toHaveBeenCalledWith("Content-Type", "image/svg+xml"); + expect(res.setHeader).toHaveBeenCalledWith( "Cache-Control", `max-age=${CACHE_TTL.PIN_CARD.DEFAULT}, ` + `s-maxage=${CACHE_TTL.PIN_CARD.DEFAULT}, ` + diff --git a/tests/retryer.test.js b/tests/retryer.test.js index 967441e3b6456..36ea8d353920a 100644 --- a/tests/retryer.test.js +++ b/tests/retryer.test.js @@ -49,21 +49,21 @@ describe("Test Retryer", () => { it("retryer should return value and have zero retries on first try", async () => { let res = await retryer(fetcher, {}); - expect(fetcher).toBeCalledTimes(1); + expect(fetcher).toHaveBeenCalledTimes(1); expect(res).toStrictEqual({ data: "ok" }); }); it("retryer should return value and have 2 retries", async () => { let res = await retryer(fetcherFailOnSecondTry, {}); - expect(fetcherFailOnSecondTry).toBeCalledTimes(2); + expect(fetcherFailOnSecondTry).toHaveBeenCalledTimes(2); expect(res).toStrictEqual({ data: "ok" }); }); it("retryer should return value and have 2 retries with message based rate limit error", async () => { let res = await retryer(fetcherFailWithMessageBasedRateLimitErr, {}); - expect(fetcherFailWithMessageBasedRateLimitErr).toBeCalledTimes(2); + expect(fetcherFailWithMessageBasedRateLimitErr).toHaveBeenCalledTimes(2); expect(res).toStrictEqual({ data: "ok" }); }); @@ -71,7 +71,7 @@ describe("Test Retryer", () => { try { await retryer(fetcherFail, {}); } catch (err) { - expect(fetcherFail).toBeCalledTimes(RETRIES + 1); + expect(fetcherFail).toHaveBeenCalledTimes(RETRIES + 1); expect(err.message).toBe("Downtime due to GitHub API rate limiting"); } }); diff --git a/tests/status.up.test.js b/tests/status.up.test.js index a4cf00b7e4057..16705cd283838 100644 --- a/tests/status.up.test.js +++ b/tests/status.up.test.js @@ -65,8 +65,11 @@ describe("Test /api/status/up", () => { const { req, res } = faker({}, {}); await up(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "application/json"); - expect(res.send).toBeCalledWith(true); + expect(res.setHeader).toHaveBeenCalledWith( + "Content-Type", + "application/json", + ); + expect(res.send).toHaveBeenCalledWith(true); }); it("should return `false` if all PATs are rate limited", async () => { @@ -75,8 +78,11 @@ describe("Test /api/status/up", () => { const { req, res } = faker({}, {}); await up(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "application/json"); - expect(res.send).toBeCalledWith(false); + expect(res.setHeader).toHaveBeenCalledWith( + "Content-Type", + "application/json", + ); + expect(res.send).toHaveBeenCalledWith(false); }); it("should return JSON `true` if request was successful and type='json'", async () => { @@ -85,8 +91,11 @@ describe("Test /api/status/up", () => { const { req, res } = faker({ type: "json" }, {}); await up(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "application/json"); - expect(res.send).toBeCalledWith({ up: true }); + expect(res.setHeader).toHaveBeenCalledWith( + "Content-Type", + "application/json", + ); + expect(res.send).toHaveBeenCalledWith({ up: true }); }); it("should return JSON `false` if all PATs are rate limited and type='json'", async () => { @@ -95,8 +104,11 @@ describe("Test /api/status/up", () => { const { req, res } = faker({ type: "json" }, {}); await up(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "application/json"); - expect(res.send).toBeCalledWith({ up: false }); + expect(res.setHeader).toHaveBeenCalledWith( + "Content-Type", + "application/json", + ); + expect(res.send).toHaveBeenCalledWith({ up: false }); }); it("should return UP shields.io config if request was successful and type='shields'", async () => { @@ -105,8 +117,11 @@ describe("Test /api/status/up", () => { const { req, res } = faker({ type: "shields" }, {}); await up(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "application/json"); - expect(res.send).toBeCalledWith(shields_up); + expect(res.setHeader).toHaveBeenCalledWith( + "Content-Type", + "application/json", + ); + expect(res.send).toHaveBeenCalledWith(shields_up); }); it("should return DOWN shields.io config if all PATs are rate limited and type='shields'", async () => { @@ -115,8 +130,11 @@ describe("Test /api/status/up", () => { const { req, res } = faker({ type: "shields" }, {}); await up(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "application/json"); - expect(res.send).toBeCalledWith(shields_down); + expect(res.setHeader).toHaveBeenCalledWith( + "Content-Type", + "application/json", + ); + expect(res.send).toHaveBeenCalledWith(shields_down); }); it("should return `true` if the first PAT is rate limited but the second PATs works", async () => { @@ -129,8 +147,11 @@ describe("Test /api/status/up", () => { const { req, res } = faker({}, {}); await up(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "application/json"); - expect(res.send).toBeCalledWith(true); + expect(res.setHeader).toHaveBeenCalledWith( + "Content-Type", + "application/json", + ); + expect(res.send).toHaveBeenCalledWith(true); }); it("should return `true` if the first PAT has 'Bad credentials' but the second PAT works", async () => { @@ -143,8 +164,11 @@ describe("Test /api/status/up", () => { const { req, res } = faker({}, {}); await up(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "application/json"); - expect(res.send).toBeCalledWith(true); + expect(res.setHeader).toHaveBeenCalledWith( + "Content-Type", + "application/json", + ); + expect(res.send).toHaveBeenCalledWith(true); }); it("should return `false` if all pats have 'Bad credentials'", async () => { @@ -155,8 +179,11 @@ describe("Test /api/status/up", () => { const { req, res } = faker({}, {}); await up(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "application/json"); - expect(res.send).toBeCalledWith(false); + expect(res.setHeader).toHaveBeenCalledWith( + "Content-Type", + "application/json", + ); + expect(res.send).toHaveBeenCalledWith(false); }); it("should throw an error if the request fails", async () => { @@ -165,8 +192,11 @@ describe("Test /api/status/up", () => { const { req, res } = faker({}, {}); await up(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "application/json"); - expect(res.send).toBeCalledWith(false); + expect(res.setHeader).toHaveBeenCalledWith( + "Content-Type", + "application/json", + ); + expect(res.send).toHaveBeenCalledWith(false); }); it("should have proper cache when no error is thrown", async () => { diff --git a/tests/top-langs.test.js b/tests/top-langs.test.js index 41ee95e142f1a..fb065fb7719a3 100644 --- a/tests/top-langs.test.js +++ b/tests/top-langs.test.js @@ -89,8 +89,8 @@ describe("Test /api/top-langs", () => { await topLangs(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); - expect(res.send).toBeCalledWith(renderTopLanguages(langs)); + expect(res.setHeader).toHaveBeenCalledWith("Content-Type", "image/svg+xml"); + expect(res.send).toHaveBeenCalledWith(renderTopLanguages(langs)); }); it("should work with the query options", async () => { @@ -113,8 +113,8 @@ describe("Test /api/top-langs", () => { await topLangs(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); - expect(res.send).toBeCalledWith( + expect(res.setHeader).toHaveBeenCalledWith("Content-Type", "image/svg+xml"); + expect(res.send).toHaveBeenCalledWith( renderTopLanguages(langs, { hide_title: true, card_width: 100, @@ -140,8 +140,8 @@ describe("Test /api/top-langs", () => { await topLangs(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); - expect(res.send).toBeCalledWith( + expect(res.setHeader).toHaveBeenCalledWith("Content-Type", "image/svg+xml"); + expect(res.send).toHaveBeenCalledWith( renderError({ message: error.errors[0].message, secondaryMessage: @@ -165,8 +165,8 @@ describe("Test /api/top-langs", () => { await topLangs(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); - expect(res.send).toBeCalledWith( + expect(res.setHeader).toHaveBeenCalledWith("Content-Type", "image/svg+xml"); + expect(res.send).toHaveBeenCalledWith( renderError({ message: "Something went wrong", secondaryMessage: "Incorrect layout input", @@ -188,8 +188,8 @@ describe("Test /api/top-langs", () => { await topLangs(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); - expect(res.send).toBeCalledWith( + expect(res.setHeader).toHaveBeenCalledWith("Content-Type", "image/svg+xml"); + expect(res.send).toHaveBeenCalledWith( renderError({ message: "This username is blacklisted", secondaryMessage: "Please deploy your own instance", @@ -213,8 +213,8 @@ describe("Test /api/top-langs", () => { await topLangs(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); - expect(res.send).toBeCalledWith( + expect(res.setHeader).toHaveBeenCalledWith("Content-Type", "image/svg+xml"); + expect(res.send).toHaveBeenCalledWith( renderError({ message: "Something went wrong", secondaryMessage: "Locale not found", @@ -236,8 +236,8 @@ describe("Test /api/top-langs", () => { await topLangs(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); - expect(res.setHeader).toBeCalledWith( + expect(res.setHeader).toHaveBeenCalledWith("Content-Type", "image/svg+xml"); + expect(res.setHeader).toHaveBeenCalledWith( "Cache-Control", `max-age=${CACHE_TTL.TOP_LANGS_CARD.DEFAULT}, ` + `s-maxage=${CACHE_TTL.TOP_LANGS_CARD.DEFAULT}, ` + diff --git a/tests/wakatime.test.js b/tests/wakatime.test.js index 2b269c2724879..bc1ed0d53b4d3 100644 --- a/tests/wakatime.test.js +++ b/tests/wakatime.test.js @@ -117,8 +117,10 @@ describe("Test /api/wakatime", () => { await wakatime(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); - expect(res.send).toBeCalledWith(renderWakatimeCard(wakaTimeData.data, {})); + expect(res.setHeader).toHaveBeenCalledWith("Content-Type", "image/svg+xml"); + expect(res.send).toHaveBeenCalledWith( + renderWakatimeCard(wakaTimeData.data, {}), + ); }); it("should have proper cache", async () => { @@ -133,8 +135,8 @@ describe("Test /api/wakatime", () => { await wakatime(req, res); - expect(res.setHeader).toBeCalledWith("Content-Type", "image/svg+xml"); - expect(res.setHeader).toBeCalledWith( + expect(res.setHeader).toHaveBeenCalledWith("Content-Type", "image/svg+xml"); + expect(res.setHeader).toHaveBeenCalledWith( "Cache-Control", `max-age=${CACHE_TTL.WAKATIME_CARD.DEFAULT}, ` + `s-maxage=${CACHE_TTL.WAKATIME_CARD.DEFAULT}, ` + From 0849165c6ed57ce211af3a2e6e8f115971f98df8 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Sat, 11 Oct 2025 20:57:00 +0300 Subject: [PATCH 173/265] fix: resolve vscode type errors in API endpoints files (#4555) Co-authored-by: Alexandr --- api/gist.js | 20 ++++++++++++++++++-- api/index.js | 20 ++++++++++++++++++-- api/pin.js | 20 ++++++++++++++++++-- api/top-langs.js | 20 ++++++++++++++++++-- api/wakatime.js | 20 ++++++++++++++++++-- src/common/error.js | 15 +++++++++++++++ 6 files changed, 105 insertions(+), 10 deletions(-) diff --git a/api/gist.js b/api/gist.js index d6713eafcef43..02d43d079d510 100644 --- a/api/gist.js +++ b/api/gist.js @@ -11,7 +11,9 @@ import { setErrorCacheHeaders, } from "../src/common/cache.js"; import { guardAccess } from "../src/common/access.js"; +import { retrieveSecondaryMessage } from "../src/common/error.js"; +// @ts-ignore export default async (req, res) => { const { id, @@ -89,10 +91,24 @@ export default async (req, res) => { ); } catch (err) { setErrorCacheHeaders(res); + if (err instanceof Error) { + return res.send( + renderError({ + message: err.message, + secondaryMessage: retrieveSecondaryMessage(err), + renderOptions: { + title_color, + text_color, + bg_color, + border_color, + theme, + }, + }), + ); + } return res.send( renderError({ - message: err.message, - secondaryMessage: err.secondaryMessage, + message: "An unknown error occurred", renderOptions: { title_color, text_color, diff --git a/api/index.js b/api/index.js index d5e55fbbfcd60..c8c5de63bc703 100644 --- a/api/index.js +++ b/api/index.js @@ -8,10 +8,12 @@ import { setCacheHeaders, setErrorCacheHeaders, } from "../src/common/cache.js"; +import { retrieveSecondaryMessage } from "../src/common/error.js"; import { parseArray, parseBoolean, renderError } from "../src/common/utils.js"; import { fetchStats } from "../src/fetchers/stats.js"; import { isLocaleAvailable } from "../src/translations.js"; +// @ts-ignore export default async (req, res) => { const { username, @@ -127,10 +129,24 @@ export default async (req, res) => { ); } catch (err) { setErrorCacheHeaders(res); + if (err instanceof Error) { + return res.send( + renderError({ + message: err.message, + secondaryMessage: retrieveSecondaryMessage(err), + renderOptions: { + title_color, + text_color, + bg_color, + border_color, + theme, + }, + }), + ); + } return res.send( renderError({ - message: err.message, - secondaryMessage: err.secondaryMessage, + message: "An unknown error occurred", renderOptions: { title_color, text_color, diff --git a/api/pin.js b/api/pin.js index e1f46b32c34b9..c8fa592468fcd 100644 --- a/api/pin.js +++ b/api/pin.js @@ -8,10 +8,12 @@ import { setCacheHeaders, setErrorCacheHeaders, } from "../src/common/cache.js"; +import { retrieveSecondaryMessage } from "../src/common/error.js"; import { parseBoolean, renderError } from "../src/common/utils.js"; import { fetchRepo } from "../src/fetchers/repo.js"; import { isLocaleAvailable } from "../src/translations.js"; +// @ts-ignore export default async (req, res) => { const { username, @@ -92,10 +94,24 @@ export default async (req, res) => { ); } catch (err) { setErrorCacheHeaders(res); + if (err instanceof Error) { + return res.send( + renderError({ + message: err.message, + secondaryMessage: retrieveSecondaryMessage(err), + renderOptions: { + title_color, + text_color, + bg_color, + border_color, + theme, + }, + }), + ); + } return res.send( renderError({ - message: err.message, - secondaryMessage: err.secondaryMessage, + message: "An unknown error occurred", renderOptions: { title_color, text_color, diff --git a/api/top-langs.js b/api/top-langs.js index df286b483d929..47c3c29d3713b 100644 --- a/api/top-langs.js +++ b/api/top-langs.js @@ -8,10 +8,12 @@ import { setCacheHeaders, setErrorCacheHeaders, } from "../src/common/cache.js"; +import { retrieveSecondaryMessage } from "../src/common/error.js"; import { parseArray, parseBoolean, renderError } from "../src/common/utils.js"; import { fetchTopLanguages } from "../src/fetchers/top-languages.js"; import { isLocaleAvailable } from "../src/translations.js"; +// @ts-ignore export default async (req, res) => { const { username, @@ -150,10 +152,24 @@ export default async (req, res) => { ); } catch (err) { setErrorCacheHeaders(res); + if (err instanceof Error) { + return res.send( + renderError({ + message: err.message, + secondaryMessage: retrieveSecondaryMessage(err), + renderOptions: { + title_color, + text_color, + bg_color, + border_color, + theme, + }, + }), + ); + } return res.send( renderError({ - message: err.message, - secondaryMessage: err.secondaryMessage, + message: "An unknown error occurred", renderOptions: { title_color, text_color, diff --git a/api/wakatime.js b/api/wakatime.js index b8642649be219..9cb995e2bbcbb 100644 --- a/api/wakatime.js +++ b/api/wakatime.js @@ -11,7 +11,9 @@ import { setErrorCacheHeaders, } from "../src/common/cache.js"; import { guardAccess } from "../src/common/access.js"; +import { retrieveSecondaryMessage } from "../src/common/error.js"; +// @ts-ignore export default async (req, res) => { const { username, @@ -108,10 +110,24 @@ export default async (req, res) => { ); } catch (err) { setErrorCacheHeaders(res); + if (err instanceof Error) { + return res.send( + renderError({ + message: err.message, + secondaryMessage: retrieveSecondaryMessage(err), + renderOptions: { + title_color, + text_color, + bg_color, + border_color, + theme, + }, + }), + ); + } return res.send( renderError({ - message: err.message, - secondaryMessage: err.secondaryMessage, + message: "An unknown error occurred", renderOptions: { title_color, text_color, diff --git a/src/common/error.js b/src/common/error.js index c76a198d75d6a..d3547bab4df45 100644 --- a/src/common/error.js +++ b/src/common/error.js @@ -1,3 +1,5 @@ +// @ts-check + /** * @type {string} A general message to ask user to try again later. */ @@ -61,9 +63,22 @@ class MissingParamError extends Error { } } +/** + * Retrieve secondary message from an error object. + * + * @param {Error} err The error object. + * @returns {string|undefined} The secondary message if available, otherwise undefined. + */ +const retrieveSecondaryMessage = (err) => { + return "secondaryMessage" in err && typeof err.secondaryMessage === "string" + ? err.secondaryMessage + : undefined; +}; + export { CustomError, MissingParamError, SECONDARY_ERROR_MESSAGES, TRY_AGAIN_LATER, + retrieveSecondaryMessage, }; From 6a542c870d56704c4849b4e208611c8ac2c5cdd7 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Sat, 11 Oct 2025 21:30:08 +0300 Subject: [PATCH 174/265] fix: resolve vscode errors inside colors related code (#4556) Co-authored-by: Alexandr --- src/common/utils.js | 15 ++++++++++----- 1 file changed, 10 insertions(+), 5 deletions(-) diff --git a/src/common/utils.js b/src/common/utils.js index c9ceb24a568d6..f451d8b9983ae 100644 --- a/src/common/utils.js +++ b/src/common/utils.js @@ -227,8 +227,8 @@ const request = (data, headers) => { * @param {string=} args.bg_color Card background color. * @param {string=} args.border_color Card border color. * @param {string=} args.ring_color Card ring color. - * @param {string=} args.theme Card theme. - * @param {string=} args.fallbackTheme Fallback theme. + * @param {keyof themes=} args.theme Card theme. + * @param {keyof themes=} args.fallbackTheme Fallback theme. * @returns {CardColors} Card colors. */ const getCardColors = ({ @@ -242,9 +242,13 @@ const getCardColors = ({ fallbackTheme = "default", }) => { const defaultTheme = themes[fallbackTheme]; - const selectedTheme = themes[theme] || defaultTheme; + const isThemeProvided = theme !== null && theme !== undefined; + const selectedTheme = isThemeProvided ? themes[theme] : defaultTheme; const defaultBorderColor = - selectedTheme.border_color || defaultTheme.border_color; + "border_color" in selectedTheme + ? selectedTheme.border_color + : // @ts-ignore + defaultTheme.border_color; // get the color provided by the user else the theme color // finally if both colors are invalid fallback to default theme @@ -256,6 +260,7 @@ const getCardColors = ({ // get the color provided by the user else the theme color // finally if both colors are invalid we use the titleColor const ringColor = fallbackColor( + // @ts-ignore ring_color || selectedTheme.ring_color, titleColor, ); @@ -327,7 +332,7 @@ const UPSTREAM_API_ERRORS = [ * @param {string=} args.renderOptions.text_color Card text color. * @param {string=} args.renderOptions.bg_color Card background color. * @param {string=} args.renderOptions.border_color Card border color. - * @param {string=} args.renderOptions.theme Card theme. + * @param {keyof themes=} args.renderOptions.theme Card theme. * @param {boolean=} args.renderOptions.show_repo_link Whether to show repo link or not. * @returns {string} The SVG markup. */ From 701068b8bcfe2a345ba802dafc0f1b4e7918d152 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Sat, 11 Oct 2025 22:07:03 +0300 Subject: [PATCH 175/265] refactor: move all color related code into separate file (#4557) Co-authored-by: Alexandr --- scripts/preview-theme.js | 2 +- src/cards/gist.js | 2 +- src/cards/repo.js | 2 +- src/cards/stats.js | 2 +- src/cards/top-languages.js | 2 +- src/cards/wakatime.js | 8 +- src/common/color.js | 141 +++++++++++++++++++++++++++++++++++ src/common/index.js | 4 - src/common/utils.js | 146 +------------------------------------ tests/card.test.js | 2 +- tests/utils.test.js | 2 +- 11 files changed, 152 insertions(+), 161 deletions(-) create mode 100644 src/common/color.js diff --git a/scripts/preview-theme.js b/scripts/preview-theme.js index 0f6de3729daf9..b9e53ffe97aad 100644 --- a/scripts/preview-theme.js +++ b/scripts/preview-theme.js @@ -12,7 +12,7 @@ import Hjson from "hjson"; import snakeCase from "lodash.snakecase"; import parse from "parse-diff"; import { inspect } from "util"; -import { isValidHexColor, isValidGradient } from "../src/common/utils.js"; +import { isValidHexColor, isValidGradient } from "../src/common/color.js"; import { themes } from "../themes/index.js"; import { getGithubToken, getRepoInfo } from "./helpers.js"; diff --git a/src/cards/gist.js b/src/cards/gist.js index 9e889e74424cd..9b6c128de2a5a 100644 --- a/src/cards/gist.js +++ b/src/cards/gist.js @@ -1,7 +1,6 @@ // @ts-check import { - getCardColors, parseEmojis, wrapTextMultiline, encodeHTML, @@ -12,6 +11,7 @@ import { createLanguageNode, } from "../common/utils.js"; import Card from "../common/Card.js"; +import { getCardColors } from "../common/color.js"; import { icons } from "../common/icons.js"; /** Import language colors. diff --git a/src/cards/repo.js b/src/cards/repo.js index bbfda52d47778..81d32066c1582 100644 --- a/src/cards/repo.js +++ b/src/cards/repo.js @@ -1,11 +1,11 @@ // @ts-check import { Card } from "../common/Card.js"; +import { getCardColors } from "../common/color.js"; import { I18n } from "../common/I18n.js"; import { icons } from "../common/icons.js"; import { encodeHTML, flexLayout, - getCardColors, kFormatter, measureText, parseEmojis, diff --git a/src/cards/stats.js b/src/cards/stats.js index 6e5bdd5186a74..301a6d78a9584 100644 --- a/src/cards/stats.js +++ b/src/cards/stats.js @@ -1,13 +1,13 @@ // @ts-check import { Card } from "../common/Card.js"; +import { getCardColors } from "../common/color.js"; import { CustomError } from "../common/error.js"; import { I18n } from "../common/I18n.js"; import { icons, rankIcon } from "../common/icons.js"; import { clampValue, flexLayout, - getCardColors, kFormatter, measureText, } from "../common/utils.js"; diff --git a/src/cards/top-languages.js b/src/cards/top-languages.js index fec72c7c391c8..569ccaaecd2d8 100644 --- a/src/cards/top-languages.js +++ b/src/cards/top-languages.js @@ -1,12 +1,12 @@ // @ts-check import { Card } from "../common/Card.js"; +import { getCardColors } from "../common/color.js"; import { createProgressNode } from "../common/createProgressNode.js"; import { I18n } from "../common/I18n.js"; import { chunkArray, clampValue, flexLayout, - getCardColors, lowercaseTrim, measureText, formatBytes, diff --git a/src/cards/wakatime.js b/src/cards/wakatime.js index 64ded83d41692..b2fec34096ec8 100644 --- a/src/cards/wakatime.js +++ b/src/cards/wakatime.js @@ -1,14 +1,10 @@ // @ts-check import { Card } from "../common/Card.js"; +import { getCardColors } from "../common/color.js"; import { createProgressNode } from "../common/createProgressNode.js"; import { I18n } from "../common/I18n.js"; -import { - clampValue, - flexLayout, - getCardColors, - lowercaseTrim, -} from "../common/utils.js"; +import { clampValue, flexLayout, lowercaseTrim } from "../common/utils.js"; import { wakatimeCardLocales } from "../translations.js"; /** Import language colors. diff --git a/src/common/color.js b/src/common/color.js new file mode 100644 index 0000000000000..8047ad06bbfa4 --- /dev/null +++ b/src/common/color.js @@ -0,0 +1,141 @@ +import { themes } from "../../themes/index.js"; + +/** + * Checks if a string is a valid hex color. + * + * @param {string} hexColor String to check. + * @returns {boolean} True if the given string is a valid hex color. + */ +const isValidHexColor = (hexColor) => { + return new RegExp( + /^([A-Fa-f0-9]{8}|[A-Fa-f0-9]{6}|[A-Fa-f0-9]{3}|[A-Fa-f0-9]{4})$/, + ).test(hexColor); +}; + +/** + * Check if the given string is a valid gradient. + * + * @param {string[]} colors Array of colors. + * @returns {boolean} True if the given string is a valid gradient. + */ +const isValidGradient = (colors) => { + return ( + colors.length > 2 && + colors.slice(1).every((color) => isValidHexColor(color)) + ); +}; + +/** + * Retrieves a gradient if color has more than one valid hex codes else a single color. + * + * @param {string} color The color to parse. + * @param {string | string[]} fallbackColor The fallback color. + * @returns {string | string[]} The gradient or color. + */ +const fallbackColor = (color, fallbackColor) => { + let gradient = null; + + let colors = color ? color.split(",") : []; + if (colors.length > 1 && isValidGradient(colors)) { + gradient = colors; + } + + return ( + (gradient ? gradient : isValidHexColor(color) && `#${color}`) || + fallbackColor + ); +}; + +/** + * Object containing card colors. + * @typedef {{ + * titleColor: string; + * iconColor: string; + * textColor: string; + * bgColor: string | string[]; + * borderColor: string; + * ringColor: string; + * }} CardColors + */ + +/** + * Returns theme based colors with proper overrides and defaults. + * + * @param {Object} args Function arguments. + * @param {string=} args.title_color Card title color. + * @param {string=} args.text_color Card text color. + * @param {string=} args.icon_color Card icon color. + * @param {string=} args.bg_color Card background color. + * @param {string=} args.border_color Card border color. + * @param {string=} args.ring_color Card ring color. + * @param {keyof themes=} args.theme Card theme. + * @param {keyof themes=} args.fallbackTheme Fallback theme. + * @returns {CardColors} Card colors. + */ +const getCardColors = ({ + title_color, + text_color, + icon_color, + bg_color, + border_color, + ring_color, + theme, + fallbackTheme = "default", +}) => { + const defaultTheme = themes[fallbackTheme]; + const isThemeProvided = theme !== null && theme !== undefined; + const selectedTheme = isThemeProvided ? themes[theme] : defaultTheme; + const defaultBorderColor = + "border_color" in selectedTheme + ? selectedTheme.border_color + : // @ts-ignore + defaultTheme.border_color; + + // get the color provided by the user else the theme color + // finally if both colors are invalid fallback to default theme + const titleColor = fallbackColor( + title_color || selectedTheme.title_color, + "#" + defaultTheme.title_color, + ); + + // get the color provided by the user else the theme color + // finally if both colors are invalid we use the titleColor + const ringColor = fallbackColor( + // @ts-ignore + ring_color || selectedTheme.ring_color, + titleColor, + ); + const iconColor = fallbackColor( + icon_color || selectedTheme.icon_color, + "#" + defaultTheme.icon_color, + ); + const textColor = fallbackColor( + text_color || selectedTheme.text_color, + "#" + defaultTheme.text_color, + ); + const bgColor = fallbackColor( + bg_color || selectedTheme.bg_color, + "#" + defaultTheme.bg_color, + ); + + const borderColor = fallbackColor( + border_color || defaultBorderColor, + "#" + defaultBorderColor, + ); + + if ( + typeof titleColor !== "string" || + typeof textColor !== "string" || + typeof ringColor !== "string" || + typeof iconColor !== "string" || + typeof borderColor !== "string" + ) { + throw new Error( + "Unexpected behavior, all colors except background should be string.", + ); + } + + return { titleColor, iconColor, textColor, bgColor, borderColor, ringColor }; +}; + +export { isValidHexColor, isValidGradient, getCardColors }; diff --git a/src/common/index.js b/src/common/index.js index aa5ec0828b41a..5dfb0e1209986 100644 --- a/src/common/index.js +++ b/src/common/index.js @@ -11,15 +11,11 @@ export { renderError, encodeHTML, kFormatter, - isValidHexColor, parseBoolean, parseArray, clampValue, - isValidGradient, - fallbackColor, request, flexLayout, - getCardColors, wrapTextMultiline, logger, measureText, diff --git a/src/common/utils.js b/src/common/utils.js index f451d8b9983ae..054788039b384 100644 --- a/src/common/utils.js +++ b/src/common/utils.js @@ -3,8 +3,8 @@ import axios from "axios"; import toEmoji from "emoji-name-map"; import wrap from "word-wrap"; -import { themes } from "../../themes/index.js"; import { SECONDARY_ERROR_MESSAGES, TRY_AGAIN_LATER } from "./error.js"; +import { getCardColors } from "./color.js"; /** * Auto layout utility, allows us to layout things vertically or horizontally with @@ -88,18 +88,6 @@ const kFormatter = (num) => { : Math.sign(num) * Math.abs(num); }; -/** - * Checks if a string is a valid hex color. - * - * @param {string} hexColor String to check. - * @returns {boolean} True if the given string is a valid hex color. - */ -const isValidHexColor = (hexColor) => { - return new RegExp( - /^([A-Fa-f0-9]{8}|[A-Fa-f0-9]{6}|[A-Fa-f0-9]{3}|[A-Fa-f0-9]{4})$/, - ).test(hexColor); -}; - /** * Returns boolean if value is either "true" or "false" else the value as it is. * @@ -150,40 +138,6 @@ const clampValue = (number, min, max) => { return Math.max(min, Math.min(number, max)); }; -/** - * Check if the given string is a valid gradient. - * - * @param {string[]} colors Array of colors. - * @returns {boolean} True if the given string is a valid gradient. - */ -const isValidGradient = (colors) => { - return ( - colors.length > 2 && - colors.slice(1).every((color) => isValidHexColor(color)) - ); -}; - -/** - * Retrieves a gradient if color has more than one valid hex codes else a single color. - * - * @param {string} color The color to parse. - * @param {string | string[]} fallbackColor The fallback color. - * @returns {string | string[]} The gradient or color. - */ -const fallbackColor = (color, fallbackColor) => { - let gradient = null; - - let colors = color ? color.split(",") : []; - if (colors.length > 1 && isValidGradient(colors)) { - gradient = colors; - } - - return ( - (gradient ? gradient : isValidHexColor(color) && `#${color}`) || - fallbackColor - ); -}; - /** * @typedef {import('axios').AxiosRequestConfig['data']} AxiosRequestConfigData Axios request data. * @typedef {import('axios').AxiosRequestConfig['headers']} AxiosRequestConfigHeaders Axios request headers. @@ -205,98 +159,6 @@ const request = (data, headers) => { }); }; -/** - * Object containing card colors. - * @typedef {{ - * titleColor: string; - * iconColor: string; - * textColor: string; - * bgColor: string | string[]; - * borderColor: string; - * ringColor: string; - * }} CardColors - */ - -/** - * Returns theme based colors with proper overrides and defaults. - * - * @param {Object} args Function arguments. - * @param {string=} args.title_color Card title color. - * @param {string=} args.text_color Card text color. - * @param {string=} args.icon_color Card icon color. - * @param {string=} args.bg_color Card background color. - * @param {string=} args.border_color Card border color. - * @param {string=} args.ring_color Card ring color. - * @param {keyof themes=} args.theme Card theme. - * @param {keyof themes=} args.fallbackTheme Fallback theme. - * @returns {CardColors} Card colors. - */ -const getCardColors = ({ - title_color, - text_color, - icon_color, - bg_color, - border_color, - ring_color, - theme, - fallbackTheme = "default", -}) => { - const defaultTheme = themes[fallbackTheme]; - const isThemeProvided = theme !== null && theme !== undefined; - const selectedTheme = isThemeProvided ? themes[theme] : defaultTheme; - const defaultBorderColor = - "border_color" in selectedTheme - ? selectedTheme.border_color - : // @ts-ignore - defaultTheme.border_color; - - // get the color provided by the user else the theme color - // finally if both colors are invalid fallback to default theme - const titleColor = fallbackColor( - title_color || selectedTheme.title_color, - "#" + defaultTheme.title_color, - ); - - // get the color provided by the user else the theme color - // finally if both colors are invalid we use the titleColor - const ringColor = fallbackColor( - // @ts-ignore - ring_color || selectedTheme.ring_color, - titleColor, - ); - const iconColor = fallbackColor( - icon_color || selectedTheme.icon_color, - "#" + defaultTheme.icon_color, - ); - const textColor = fallbackColor( - text_color || selectedTheme.text_color, - "#" + defaultTheme.text_color, - ); - const bgColor = fallbackColor( - bg_color || selectedTheme.bg_color, - "#" + defaultTheme.bg_color, - ); - - const borderColor = fallbackColor( - border_color || defaultBorderColor, - "#" + defaultBorderColor, - ); - - if ( - typeof titleColor !== "string" || - typeof textColor !== "string" || - typeof ringColor !== "string" || - typeof iconColor !== "string" || - typeof borderColor !== "string" - ) { - throw new Error( - "Unexpected behavior, all colors except background should be string.", - ); - } - - return { titleColor, iconColor, textColor, bgColor, borderColor, ringColor }; -}; - // Script parameters. const ERROR_CARD_LENGTH = 576.5; @@ -332,7 +194,7 @@ const UPSTREAM_API_ERRORS = [ * @param {string=} args.renderOptions.text_color Card text color. * @param {string=} args.renderOptions.bg_color Card background color. * @param {string=} args.renderOptions.border_color Card border color. - * @param {keyof themes=} args.renderOptions.theme Card theme. + * @param {Parameters[0]["theme"]=} args.renderOptions.theme Card theme. * @param {boolean=} args.renderOptions.show_repo_link Whether to show repo link or not. * @returns {string} The SVG markup. */ @@ -561,15 +423,11 @@ export { iconWithLabel, encodeHTML, kFormatter, - isValidHexColor, parseBoolean, parseArray, clampValue, - isValidGradient, - fallbackColor, request, flexLayout, - getCardColors, wrapTextMultiline, logger, measureText, diff --git a/tests/card.test.js b/tests/card.test.js index 02e476c3721db..21303603652c9 100644 --- a/tests/card.test.js +++ b/tests/card.test.js @@ -4,7 +4,7 @@ import "@testing-library/jest-dom"; import { cssToObject } from "@uppercod/css-to-object"; import { Card } from "../src/common/Card.js"; import { icons } from "../src/common/icons.js"; -import { getCardColors } from "../src/common/utils.js"; +import { getCardColors } from "../src/common/color.js"; describe("Card", () => { it("should hide border", () => { diff --git a/tests/utils.test.js b/tests/utils.test.js index 21a78e4730b32..f7ce665cc7624 100644 --- a/tests/utils.test.js +++ b/tests/utils.test.js @@ -4,12 +4,12 @@ import "@testing-library/jest-dom"; import { encodeHTML, formatBytes, - getCardColors, kFormatter, parseBoolean, renderError, wrapTextMultiline, } from "../src/common/utils.js"; +import { getCardColors } from "../src/common/color.js"; describe("Test utils.js", () => { it("should test kFormatter", () => { From 33f0c9153e3c2c6af3fad602ba4ae5bd307d36b7 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Sat, 11 Oct 2025 22:40:33 +0300 Subject: [PATCH 176/265] fix: resolve vscode errors inside cards svg generation code (#4558) Co-authored-by: Alexandr --- src/cards/gist.js | 1 + src/cards/repo.js | 1 + src/cards/stats.js | 27 ++++++++++++++++----------- src/cards/top-languages.js | 3 +++ src/cards/wakatime.js | 2 ++ src/common/color.js | 4 ++-- 6 files changed, 25 insertions(+), 13 deletions(-) diff --git a/src/cards/gist.js b/src/cards/gist.js index 9b6c128de2a5a..ecace8381495f 100644 --- a/src/cards/gist.js +++ b/src/cards/gist.js @@ -96,6 +96,7 @@ const renderGistCard = (gistData, options = {}) => { ); const languageName = language || "Unspecified"; + // @ts-ignore const languageColor = languageColors[languageName] || "#858585"; const svgLanguage = createLanguageNode(languageName, languageColor); diff --git a/src/cards/repo.js b/src/cards/repo.js index 81d32066c1582..9f28c7a5c2555 100644 --- a/src/cards/repo.js +++ b/src/cards/repo.js @@ -1,4 +1,5 @@ // @ts-check + import { Card } from "../common/Card.js"; import { getCardColors } from "../common/color.js"; import { I18n } from "../common/I18n.js"; diff --git a/src/cards/stats.js b/src/cards/stats.js index 301a6d78a9584..a0b12096e3aa5 100644 --- a/src/cards/stats.js +++ b/src/cards/stats.js @@ -392,21 +392,24 @@ const renderStatsCard = (stats, options = {}) => { // filter out hidden stats defined by user & create the text nodes const statItems = Object.keys(STATS) .filter((key) => !hide.includes(key)) - .map((key, index) => + .map((key, index) => { + // @ts-ignore + const stats = STATS[key]; + // create the text nodes, and pass index so that we can calculate the line spacing - createTextNode({ - icon: STATS[key].icon, - label: STATS[key].label, - value: STATS[key].value, - id: STATS[key].id, - unitSymbol: STATS[key].unitSymbol, + return createTextNode({ + icon: stats.icon, + label: stats.label, + value: stats.value, + id: stats.id, + unitSymbol: stats.unitSymbol, index, showIcons: show_icons, shiftValuePos: 79.01 + (isLongLocale ? 50 : 0), bold: text_bold, number_format, - }), - ); + }); + }); if (statItems.length === 0 && hide_rank) { throw new CustomError( @@ -541,14 +544,16 @@ const renderStatsCard = (stats, options = {}) => { const labels = Object.keys(STATS) .filter((key) => !hide.includes(key)) .map((key) => { + // @ts-ignore + const stats = STATS[key]; if (key === "commits") { return `${i18n.t("statcard.commits")} ${getTotalCommitsYearLabel( include_all_commits, commits_year, i18n, - )} : ${STATS[key].value}`; + )} : ${stats.value}`; } - return `${STATS[key].label}: ${STATS[key].value}`; + return `${stats.label}: ${stats.value}`; }) .join(", "); diff --git a/src/cards/top-languages.js b/src/cards/top-languages.js index 569ccaaecd2d8..76c02fad2156a 100644 --- a/src/cards/top-languages.js +++ b/src/cards/top-languages.js @@ -1,4 +1,5 @@ // @ts-check + import { Card } from "../common/Card.js"; import { getCardColors } from "../common/color.js"; import { createProgressNode } from "../common/createProgressNode.js"; @@ -180,6 +181,7 @@ const trimTopLanguages = (topLangs, langs_count, hide) => { // while filtering out if (hide) { hide.forEach((langName) => { + // @ts-ignore langsToHide[lowercaseTrim(langName)] = true; }); } @@ -188,6 +190,7 @@ const trimTopLanguages = (topLangs, langs_count, hide) => { langs = langs .sort((a, b) => b.size - a.size) .filter((lang) => { + // @ts-ignore return !langsToHide[lowercaseTrim(lang.name)]; }) .slice(0, langsCount); diff --git a/src/cards/wakatime.js b/src/cards/wakatime.js index b2fec34096ec8..5dadcdab905bf 100644 --- a/src/cards/wakatime.js +++ b/src/cards/wakatime.js @@ -65,6 +65,7 @@ const formatLanguageValue = ({ display_format, lang }) => { * @returns {string} The compact layout language SVG node. */ const createCompactLangNode = ({ lang, x, y, display_format }) => { + // @ts-ignore const color = languageColors[lang.name] || "#858585"; const value = formatLanguageValue({ display_format, lang }); @@ -325,6 +326,7 @@ const renderWakatimeCard = (stats = {}, options = { hide: [] }) => { // const progress = (width * lang.percent) / 100; const progress = ((width - 25) * language.percent) / 100; + // @ts-ignore const languageColor = languageColors[language.name] || "#858585"; const output = ` diff --git a/src/common/color.js b/src/common/color.js index 8047ad06bbfa4..759a07ca25c7b 100644 --- a/src/common/color.js +++ b/src/common/color.js @@ -68,8 +68,8 @@ const fallbackColor = (color, fallbackColor) => { * @param {string=} args.bg_color Card background color. * @param {string=} args.border_color Card border color. * @param {string=} args.ring_color Card ring color. - * @param {keyof themes=} args.theme Card theme. - * @param {keyof themes=} args.fallbackTheme Fallback theme. + * @param {string=} args.theme Card theme. + * @param {string=} args.fallbackTheme Fallback theme. * @returns {CardColors} Card colors. */ const getCardColors = ({ From 92d6dfa226f915039d8dc5721c5983ff75eb6999 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Sat, 11 Oct 2025 22:52:45 +0300 Subject: [PATCH 177/265] fix: resolve vscode type errors in cache utils (#4559) Co-authored-by: Alexandr --- src/common/cache.js | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/common/cache.js b/src/common/cache.js index 3e88e3c9c4fae..596aa5e3db87f 100644 --- a/src/common/cache.js +++ b/src/common/cache.js @@ -86,7 +86,7 @@ const resolveCacheSeconds = ({ requested, def, min, max }) => { /** * Disables caching by setting appropriate headers on the response object. * - * @param {Object} res The response object. + * @param {any} res The response object. */ const disableCaching = (res) => { // Disable caching for browsers, shared caches/CDNs, and GitHub Camo. @@ -101,7 +101,7 @@ const disableCaching = (res) => { /** * Sets the Cache-Control headers on the response object. * - * @param {Object} res The response object. + * @param {any} res The response object. * @param {number} cacheSeconds The cache seconds to set in the headers. */ const setCacheHeaders = (res, cacheSeconds) => { @@ -121,7 +121,7 @@ const setCacheHeaders = (res, cacheSeconds) => { /** * Sets the Cache-Control headers for error responses on the response object. * - * @param {Object} res The response object. + * @param {any} res The response object. */ const setErrorCacheHeaders = (res) => { const envCacheSeconds = process.env.CACHE_SECONDS From 90955dca00efc5c556783d18a740cabdc7de2df3 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Sun, 12 Oct 2025 23:14:27 +0300 Subject: [PATCH 178/265] fix: remove repository link display on missing param errors (#4560) * fix: remove repository link display on missing param errors * fix tests --------- Co-authored-by: Alexandr --- api/gist.js | 6 +++++- api/index.js | 6 +++++- api/pin.js | 6 +++++- api/top-langs.js | 6 +++++- api/wakatime.js | 6 +++++- tests/gist.test.js | 1 + tests/pin.test.js | 1 + 7 files changed, 27 insertions(+), 5 deletions(-) diff --git a/api/gist.js b/api/gist.js index 02d43d079d510..88f2f7b23a565 100644 --- a/api/gist.js +++ b/api/gist.js @@ -11,7 +11,10 @@ import { setErrorCacheHeaders, } from "../src/common/cache.js"; import { guardAccess } from "../src/common/access.js"; -import { retrieveSecondaryMessage } from "../src/common/error.js"; +import { + MissingParamError, + retrieveSecondaryMessage, +} from "../src/common/error.js"; // @ts-ignore export default async (req, res) => { @@ -102,6 +105,7 @@ export default async (req, res) => { bg_color, border_color, theme, + show_repo_link: !(err instanceof MissingParamError), }, }), ); diff --git a/api/index.js b/api/index.js index c8c5de63bc703..e821d13f797f0 100644 --- a/api/index.js +++ b/api/index.js @@ -8,7 +8,10 @@ import { setCacheHeaders, setErrorCacheHeaders, } from "../src/common/cache.js"; -import { retrieveSecondaryMessage } from "../src/common/error.js"; +import { + MissingParamError, + retrieveSecondaryMessage, +} from "../src/common/error.js"; import { parseArray, parseBoolean, renderError } from "../src/common/utils.js"; import { fetchStats } from "../src/fetchers/stats.js"; import { isLocaleAvailable } from "../src/translations.js"; @@ -140,6 +143,7 @@ export default async (req, res) => { bg_color, border_color, theme, + show_repo_link: !(err instanceof MissingParamError), }, }), ); diff --git a/api/pin.js b/api/pin.js index c8fa592468fcd..62b06a882da73 100644 --- a/api/pin.js +++ b/api/pin.js @@ -8,7 +8,10 @@ import { setCacheHeaders, setErrorCacheHeaders, } from "../src/common/cache.js"; -import { retrieveSecondaryMessage } from "../src/common/error.js"; +import { + MissingParamError, + retrieveSecondaryMessage, +} from "../src/common/error.js"; import { parseBoolean, renderError } from "../src/common/utils.js"; import { fetchRepo } from "../src/fetchers/repo.js"; import { isLocaleAvailable } from "../src/translations.js"; @@ -105,6 +108,7 @@ export default async (req, res) => { bg_color, border_color, theme, + show_repo_link: !(err instanceof MissingParamError), }, }), ); diff --git a/api/top-langs.js b/api/top-langs.js index 47c3c29d3713b..c00fde6b1bf35 100644 --- a/api/top-langs.js +++ b/api/top-langs.js @@ -8,7 +8,10 @@ import { setCacheHeaders, setErrorCacheHeaders, } from "../src/common/cache.js"; -import { retrieveSecondaryMessage } from "../src/common/error.js"; +import { + MissingParamError, + retrieveSecondaryMessage, +} from "../src/common/error.js"; import { parseArray, parseBoolean, renderError } from "../src/common/utils.js"; import { fetchTopLanguages } from "../src/fetchers/top-languages.js"; import { isLocaleAvailable } from "../src/translations.js"; @@ -163,6 +166,7 @@ export default async (req, res) => { bg_color, border_color, theme, + show_repo_link: !(err instanceof MissingParamError), }, }), ); diff --git a/api/wakatime.js b/api/wakatime.js index 9cb995e2bbcbb..af6c4af066d7f 100644 --- a/api/wakatime.js +++ b/api/wakatime.js @@ -11,7 +11,10 @@ import { setErrorCacheHeaders, } from "../src/common/cache.js"; import { guardAccess } from "../src/common/access.js"; -import { retrieveSecondaryMessage } from "../src/common/error.js"; +import { + MissingParamError, + retrieveSecondaryMessage, +} from "../src/common/error.js"; // @ts-ignore export default async (req, res) => { @@ -121,6 +124,7 @@ export default async (req, res) => { bg_color, border_color, theme, + show_repo_link: !(err instanceof MissingParamError), }, }), ); diff --git a/tests/gist.test.js b/tests/gist.test.js index cb69f9ed7e1ef..186edbdb305f7 100644 --- a/tests/gist.test.js +++ b/tests/gist.test.js @@ -129,6 +129,7 @@ describe("Test /api/gist", () => { renderError({ message: 'Missing params "id" make sure you pass the parameters in URL', secondaryMessage: "/api/gist?id=GIST_ID", + renderOptions: { show_repo_link: false }, }), ); }); diff --git a/tests/pin.test.js b/tests/pin.test.js index aabcfde0b6b53..126bb2aa7469f 100644 --- a/tests/pin.test.js +++ b/tests/pin.test.js @@ -212,6 +212,7 @@ describe("Test /api/pin", () => { message: 'Missing params "username", "repo" make sure you pass the parameters in URL', secondaryMessage: "/api/pin?username=USERNAME&repo=REPO_NAME", + renderOptions: { show_repo_link: false }, }), ); }); From d3a7a90bf9d282bd5653dd4f3fcedb03aa603871 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Sun, 12 Oct 2025 23:15:09 +0300 Subject: [PATCH 179/265] ci: prevent codeql analysis workflow from running in forks (#4561) Co-authored-by: Alexandr --- .github/workflows/codeql-analysis.yml | 2 ++ 1 file changed, 2 insertions(+) diff --git a/.github/workflows/codeql-analysis.yml b/.github/workflows/codeql-analysis.yml index 2dc34d118d3c2..b72a0e9b34409 100644 --- a/.github/workflows/codeql-analysis.yml +++ b/.github/workflows/codeql-analysis.yml @@ -24,6 +24,8 @@ permissions: jobs: CodeQL-Build: + if: github.repository == 'anuraghazra/github-readme-stats' + # CodeQL runs on ubuntu-latest, windows-latest, and macos-latest runs-on: ubuntu-latest From adbed1ee2f3caa85e15c78d69df657302dfadacc Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Sun, 12 Oct 2025 23:22:51 +0300 Subject: [PATCH 180/265] fix: mark Azerbaijani locale as long for stats card (#4562) Co-authored-by: Alexandr --- src/cards/stats.js | 1 + 1 file changed, 1 insertion(+) diff --git a/src/cards/stats.js b/src/cards/stats.js index a0b12096e3aa5..2e81385360a35 100644 --- a/src/cards/stats.js +++ b/src/cards/stats.js @@ -366,6 +366,7 @@ const renderStatsCard = (stats, options = {}) => { }; const longLocales = [ + "az", "bg", "de", "es", From 7caaa21e73f58c7805c998b50863078b7edddb71 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Sun, 12 Oct 2025 23:39:34 +0300 Subject: [PATCH 181/265] fix: improve Ukrainian translations (#4563) Co-authored-by: Alexandr --- src/translations.js | 20 ++++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) diff --git a/src/translations.js b/src/translations.js index 6798032907e47..f62294628bb77 100644 --- a/src/translations.js +++ b/src/translations.js @@ -93,7 +93,7 @@ const statCardLocales = ({ name, apostrophe }) => { el: `Στατιστικά GitHub του ${encodedName}`, ro: `Rankul GitHub al lui ${encodedName}`, ru: `Рейтинг GitHub пользователя ${encodedName}`, - "uk-ua": `Статистика GitHub користувача ${encodedName}`, + "uk-ua": `Рейтинг GitHub користувача ${encodedName}`, id: `Statistik GitHub ${encodedName}`, ml: `${encodedName}'${apostrophe} ഗിറ്റ്ഹബ് സ്ഥിതിവിവരക്കണക്കുകൾ`, my: `Statistik GitHub ${encodedName}`, @@ -237,7 +237,7 @@ const statCardLocales = ({ name, apostrophe }) => { el: "Σύνολο PRs", ro: "Total PR-uri", ru: "Всего запросов изменений", - "uk-ua": "Всього pull request`iв", + "uk-ua": "Всього запитів на злиття", id: "Total Permintaan Tarik", ml: "ആകെ പുൾ അഭ്യർത്ഥനകൾ", my: "Jumlah PR", @@ -285,7 +285,7 @@ const statCardLocales = ({ name, apostrophe }) => { el: "Σύνολο Ζητημάτων", ro: "Total Issue-uri", ru: "Всего вопросов", - "uk-ua": "Всього issue", + "uk-ua": "Всього питань", id: "Total Masalah Dilaporkan", ml: "ആകെ പ്രശ്നങ്ങൾ", my: "Jumlah Isu Dilaporkan", @@ -333,7 +333,7 @@ const statCardLocales = ({ name, apostrophe }) => { el: "Συνεισφέρθηκε σε (πέρυσι)", ro: "Total Contribuiri", ru: "Внесено вклада (за прошлый год)", - "uk-ua": "Зробив внесок у (за минулий рік)", + "uk-ua": "Зроблено внесок (за минулий рік)", id: "Berkontribusi ke (tahun lalu)", ml: "(കഴിഞ്ഞ വർഷത്തെ)ആകെ സംഭാവനകൾ ", my: "Menyumbang kepada (tahun lepas)", @@ -381,7 +381,7 @@ const statCardLocales = ({ name, apostrophe }) => { el: "Σύνολο Αναθεωρημένων PR", ro: "Total PR-uri Revizuite", ru: "Всего запросов проверено", - "uk-ua": "Всього pull request`iв перевірено", + "uk-ua": "Всього запитів перевірено", id: "Total PR yang Direview", ml: "ആകെ പുൾ അവലോകനങ്ങൾ", my: "Jumlah PR Dikaji Semula", @@ -525,7 +525,7 @@ const statCardLocales = ({ name, apostrophe }) => { el: "Σύνολο Συγχωνευμένων PR", ro: "Total PR-uri Fuzionate", ru: "Всего объединённых запросов", - "uk-ua": "Всього об'єднаних pull request`iв", + "uk-ua": "Всього об'єднаних запитів", id: "Total PR Digabungkan", my: "Jumlah PR Digabungkan", ta: "இணைக்கப்பட்ட மொத்த PRகள்", @@ -572,7 +572,7 @@ const statCardLocales = ({ name, apostrophe }) => { el: "Ποσοστό Συγχωνευμένων PR", ro: "Procentaj PR-uri Fuzionate", ru: "Процент объединённых запросов", - "uk-ua": "Відсоток об'єднаних pull request`iв", + "uk-ua": "Відсоток об'єднаних запитів", id: "Persentase PR Digabungkan", my: "Peratus PR Digabungkan", ta: "இணைக்கப்பட்ட PRகள் சதவீதம்", @@ -722,7 +722,7 @@ const langCardLocales = { el: "Οι περισσότερο χρησιμοποιούμενες γλώσσες", ro: "Cele Mai Folosite Limbaje", ru: "Наиболее используемые языки", - "uk-ua": "Найчастіше використовувані мови", + "uk-ua": "Найбільш використовувані мови", id: "Bahasa Yang Paling Banyak Digunakan", ml: "കൂടുതൽ ഉപയോഗിച്ച ഭാഷകൾ", my: "Bahasa Paling Digunakan", @@ -965,7 +965,7 @@ const wakatimeCardLocales = { el: "Το προφίλ χρήστη WakaTime δεν είναι δημόσιο", ro: "Profilul utilizatorului de Wakatime nu este public", ru: "Профиль пользователя WakaTime не общедоступный", - "uk-ua": "Профіль користувача WakaTime не є публічним", + "uk-ua": "Профіль користувача WakaTime не публічний", id: "Profil pengguna WakaTime tidak publik", ml: "WakaTime ഉപയോക്തൃ പ്രൊഫൈൽ പൊതുവായി പ്രസിദ്ധീകരിക്കപ്പെടാത്തതാണ്", my: "Profil pengguna WakaTime tidak awam", @@ -1063,7 +1063,7 @@ const wakatimeCardLocales = { el: "Δεν υπάρχει δραστηριότητα κώδικα γι' αυτή την εβδομάδα", ro: "Nicio activitate de programare săptămâna aceasta", ru: "На этой неделе не было активности", - "uk-ua": "На цьому тижні не було активності", + "uk-ua": "Цього тижня не було активності", id: "Tidak ada aktivitas perkodingan minggu ini", ml: "ഈ ആഴ്ച കോഡിംഗ് പ്രവർത്തനങ്ങളൊന്നുമില്ല", my: "Tiada aktiviti pengekodan minggu ini", From 4143c6dec35d821be7ec2507df0618e8450f443c Mon Sep 17 00:00:00 2001 From: Lucas <100660343+lulunac27a@users.noreply.github.com> Date: Mon, 13 Oct 2025 12:21:28 -0500 Subject: [PATCH 182/265] feat: implement number precision parameter for stats card (#4514) * Update short number format Update short number format by adding 2 decimal places instead of 1 for numbers between 1,000 and 9,999 * review * Update src/common/utils.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * dev * dev --------- Co-authored-by: Alexandr Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --- api/index.js | 2 ++ readme.md | 1 + src/cards/stats.js | 24 +++++++++++++++----- src/cards/types.d.ts | 1 + src/common/utils.js | 20 ++++++++++++----- tests/renderStatsCard.test.js | 7 ++++++ tests/utils.test.js | 41 ++++++++++++++++++++++++++++++++++- 7 files changed, 85 insertions(+), 11 deletions(-) diff --git a/api/index.js b/api/index.js index e821d13f797f0..f353d4c719f82 100644 --- a/api/index.js +++ b/api/index.js @@ -43,6 +43,7 @@ export default async (req, res) => { disable_animations, border_radius, number_format, + number_precision, border_color, rank_icon, show, @@ -124,6 +125,7 @@ export default async (req, res) => { border_radius, border_color, number_format, + number_precision: parseInt(number_precision, 10), locale: locale ? locale.toLowerCase() : null, disable_animations: parseBoolean(disable_animations), rank_icon, diff --git a/readme.md b/readme.md index 95bcf43f58b2f..e0f9597e3a9fe 100644 --- a/readme.md +++ b/readme.md @@ -385,6 +385,7 @@ If we don't support your language, please consider contributing! You can find mo | `disable_animations` | Disables all animations in the card. | boolean | `false` | | `ring_color` | Color of the rank circle. | string (hex color) | `2f80ed` | | `number_format` | Switches between two available formats for displaying the card values `short` (i.e. `6.6k`) and `long` (i.e. `6626`). | enum | `short` | +| `number_precision` | Enforce the number of digits after the decimal point for `short` number format. Must be an integer between 0 and 2. Will be ignored for `long` number format. | integer (0, 1 or 2) | `null` | | `show` | Shows [additional items](#showing-additional-individual-stats) on stats card (i.e. `reviews`, `discussions_started`, `discussions_answered`, `prs_merged` or `prs_merged_percentage`). | string (comma-separated values) | `null` | | `commits_year` | Filters and counts only commits made in the specified year. | integer _(YYYY)_ | ` (one year to date)` | diff --git a/src/cards/stats.js b/src/cards/stats.js index 2e81385360a35..67ef73d228608 100644 --- a/src/cards/stats.js +++ b/src/cards/stats.js @@ -33,7 +33,8 @@ const RANK_ONLY_CARD_DEFAULT_WIDTH = 290; * @param {boolean} params.showIcons Whether to show icons. * @param {number} params.shiftValuePos Number of pixels the value has to be shifted to the right. * @param {boolean} params.bold Whether to bold the label. - * @param {string} params.number_format The format of numbers on card. + * @param {string} params.numberFormat The format of numbers on card. + * @param {number=} params.numberPrecision The precision of numbers on card. * @returns {string} The stats card text item SVG object. */ const createTextNode = ({ @@ -46,10 +47,17 @@ const createTextNode = ({ showIcons, shiftValuePos, bold, - number_format, + numberFormat, + numberPrecision, }) => { + const precision = + typeof numberPrecision === "number" && !isNaN(numberPrecision) + ? clampValue(numberPrecision, 0, 2) + : undefined; const kValue = - number_format.toLowerCase() === "long" ? value : kFormatter(value); + numberFormat.toLowerCase() === "long" || id === "prs_merged_percentage" + ? value + : kFormatter(value, precision); const staggerDelay = (index + 3) * 150; const labelOffset = showIcons ? `x="25"` : ""; @@ -251,6 +259,7 @@ const renderStatsCard = (stats, options = {}) => { border_radius, border_color, number_format = "short", + number_precision, locale, disable_animations = false, rank_icon = "default", @@ -319,7 +328,11 @@ const renderStatsCard = (stats, options = {}) => { STATS.prs_merged_percentage = { icon: icons.prs_merged_percentage, label: i18n.t("statcard.prs-merged-percentage"), - value: mergedPRsPercentage.toFixed(2), + value: mergedPRsPercentage.toFixed( + typeof number_precision === "number" && !isNaN(number_precision) + ? clampValue(number_precision, 0, 2) + : 2, + ), id: "prs_merged_percentage", unitSymbol: "%", }; @@ -408,7 +421,8 @@ const renderStatsCard = (stats, options = {}) => { showIcons: show_icons, shiftValuePos: 79.01 + (isLongLocale ? 50 : 0), bold: text_bold, - number_format, + numberFormat: number_format, + numberPrecision: number_precision, }); }); diff --git a/src/cards/types.d.ts b/src/cards/types.d.ts index c7d8c60fb2b28..7535df35bbe6f 100644 --- a/src/cards/types.d.ts +++ b/src/cards/types.d.ts @@ -25,6 +25,7 @@ export type StatCardOptions = CommonOptions & { custom_title: string; disable_animations: boolean; number_format: string; + number_precision: number; ring_color: string; text_bold: boolean; rank_icon: RankIcon; diff --git a/src/common/utils.js b/src/common/utils.js index 054788039b384..a43df79b1b077 100644 --- a/src/common/utils.js +++ b/src/common/utils.js @@ -77,15 +77,25 @@ const iconWithLabel = (icon, label, testid, iconSize) => { }; /** - * Retrieves num with suffix k(thousands) precise to 1 decimal if greater than 999. + * Retrieves num with suffix k(thousands) precise to given decimal places. * * @param {number} num The number to format. + * @param {number=} precision The number of decimal places to include. * @returns {string|number} The formatted number. */ -const kFormatter = (num) => { - return Math.abs(num) > 999 - ? Math.sign(num) * parseFloat((Math.abs(num) / 1000).toFixed(1)) + "k" - : Math.sign(num) * Math.abs(num); +const kFormatter = (num, precision) => { + const abs = Math.abs(num); + const sign = Math.sign(num); + + if (typeof precision === "number" && !isNaN(precision)) { + return (sign * (abs / 1000)).toFixed(precision) + "k"; + } + + if (abs < 1000) { + return sign * abs; + } + + return sign * parseFloat((abs / 1000).toFixed(1)) + "k"; }; /** diff --git a/tests/renderStatsCard.test.js b/tests/renderStatsCard.test.js index de123ffe88df2..cd84a3f0f1e2a 100644 --- a/tests/renderStatsCard.test.js +++ b/tests/renderStatsCard.test.js @@ -416,6 +416,13 @@ describe("Test renderStatsCard", () => { expect(getByTestId(document.body, "commits").textContent).toBe("2k"); document.body.innerHTML = renderStatsCard(stats, { number_format: "long" }); expect(getByTestId(document.body, "commits").textContent).toBe("1999"); + document.body.innerHTML = renderStatsCard(stats, { number_precision: 2 }); + expect(getByTestId(document.body, "commits").textContent).toBe("2.00k"); + document.body.innerHTML = renderStatsCard(stats, { + number_format: "long", + number_precision: 2, + }); + expect(getByTestId(document.body, "commits").textContent).toBe("1999"); }); it("should render default rank icon with level A+", () => { diff --git a/tests/utils.test.js b/tests/utils.test.js index f7ce665cc7624..625786c5add6f 100644 --- a/tests/utils.test.js +++ b/tests/utils.test.js @@ -12,16 +12,55 @@ import { import { getCardColors } from "../src/common/color.js"; describe("Test utils.js", () => { - it("should test kFormatter", () => { + it("should test kFormatter default behavior", () => { expect(kFormatter(1)).toBe(1); expect(kFormatter(-1)).toBe(-1); expect(kFormatter(500)).toBe(500); expect(kFormatter(1000)).toBe("1k"); + expect(kFormatter(1200)).toBe("1.2k"); expect(kFormatter(10000)).toBe("10k"); expect(kFormatter(12345)).toBe("12.3k"); + expect(kFormatter(99900)).toBe("99.9k"); expect(kFormatter(9900000)).toBe("9900k"); }); + it("should test kFormatter with 0 decimal precision", () => { + expect(kFormatter(1, 0)).toBe("0k"); + expect(kFormatter(-1, 0)).toBe("-0k"); + expect(kFormatter(500, 0)).toBe("1k"); + expect(kFormatter(1000, 0)).toBe("1k"); + expect(kFormatter(1200, 0)).toBe("1k"); + expect(kFormatter(10000, 0)).toBe("10k"); + expect(kFormatter(12345, 0)).toBe("12k"); + expect(kFormatter(99000, 0)).toBe("99k"); + expect(kFormatter(99900, 0)).toBe("100k"); + expect(kFormatter(9900000, 0)).toBe("9900k"); + }); + + it("should test kFormatter with 1 decimal precision", () => { + expect(kFormatter(1, 1)).toBe("0.0k"); + expect(kFormatter(-1, 1)).toBe("-0.0k"); + expect(kFormatter(500, 1)).toBe("0.5k"); + expect(kFormatter(1000, 1)).toBe("1.0k"); + expect(kFormatter(1200, 1)).toBe("1.2k"); + expect(kFormatter(10000, 1)).toBe("10.0k"); + expect(kFormatter(12345, 1)).toBe("12.3k"); + expect(kFormatter(99900, 1)).toBe("99.9k"); + expect(kFormatter(9900000, 1)).toBe("9900.0k"); + }); + + it("should test kFormatter with 2 decimal precision", () => { + expect(kFormatter(1, 2)).toBe("0.00k"); + expect(kFormatter(-1, 2)).toBe("-0.00k"); + expect(kFormatter(500, 2)).toBe("0.50k"); + expect(kFormatter(1000, 2)).toBe("1.00k"); + expect(kFormatter(1200, 2)).toBe("1.20k"); + expect(kFormatter(10000, 2)).toBe("10.00k"); + expect(kFormatter(12345, 2)).toBe("12.35k"); + expect(kFormatter(99900, 2)).toBe("99.90k"); + expect(kFormatter(9900000, 2)).toBe("9900.00k"); + }); + it("should test parseBoolean", () => { expect(parseBoolean(true)).toBe(true); expect(parseBoolean(false)).toBe(false); From c1d13eac198ba3eeccb13f2e02dfefb6b56fbfe3 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Mon, 13 Oct 2025 20:39:16 +0300 Subject: [PATCH 183/265] refactor: move color related tests into separate file (#4564) Co-authored-by: Alexandr --- tests/color.test.js | 76 +++++++++++++++++++++++++++++++++++++++++++++ tests/utils.test.js | 73 ------------------------------------------- 2 files changed, 76 insertions(+), 73 deletions(-) create mode 100644 tests/color.test.js diff --git a/tests/color.test.js b/tests/color.test.js new file mode 100644 index 0000000000000..9fc6d067794ad --- /dev/null +++ b/tests/color.test.js @@ -0,0 +1,76 @@ +import { getCardColors } from "../src/common/color"; +import { describe, expect, it } from "@jest/globals"; + +describe("Test color.js", () => { + it("getCardColors: should return expected values", () => { + let colors = getCardColors({ + title_color: "f00", + text_color: "0f0", + ring_color: "0000ff", + icon_color: "00f", + bg_color: "fff", + border_color: "fff", + theme: "dark", + }); + expect(colors).toStrictEqual({ + titleColor: "#f00", + textColor: "#0f0", + iconColor: "#00f", + ringColor: "#0000ff", + bgColor: "#fff", + borderColor: "#fff", + }); + }); + + it("getCardColors: should fallback to default colors if color is invalid", () => { + let colors = getCardColors({ + title_color: "invalidcolor", + text_color: "0f0", + icon_color: "00f", + bg_color: "fff", + border_color: "invalidColor", + theme: "dark", + }); + expect(colors).toStrictEqual({ + titleColor: "#2f80ed", + textColor: "#0f0", + iconColor: "#00f", + ringColor: "#2f80ed", + bgColor: "#fff", + borderColor: "#e4e2e2", + }); + }); + + it("getCardColors: should fallback to specified theme colors if is not defined", () => { + let colors = getCardColors({ + theme: "dark", + }); + expect(colors).toStrictEqual({ + titleColor: "#fff", + textColor: "#9f9f9f", + ringColor: "#fff", + iconColor: "#79ff97", + bgColor: "#151515", + borderColor: "#e4e2e2", + }); + }); + + it("getCardColors: should return ring color equal to title color if not ring color is defined", () => { + let colors = getCardColors({ + title_color: "f00", + text_color: "0f0", + icon_color: "00f", + bg_color: "fff", + border_color: "fff", + theme: "dark", + }); + expect(colors).toStrictEqual({ + titleColor: "#f00", + textColor: "#0f0", + iconColor: "#00f", + ringColor: "#f00", + bgColor: "#fff", + borderColor: "#fff", + }); + }); +}); diff --git a/tests/utils.test.js b/tests/utils.test.js index 625786c5add6f..8cecfa7973cfc 100644 --- a/tests/utils.test.js +++ b/tests/utils.test.js @@ -9,7 +9,6 @@ import { renderError, wrapTextMultiline, } from "../src/common/utils.js"; -import { getCardColors } from "../src/common/color.js"; describe("Test utils.js", () => { it("should test kFormatter default behavior", () => { @@ -103,78 +102,6 @@ describe("Test utils.js", () => { ).toHaveTextContent(/Secondary Message/gim); }); - it("getCardColors: should return expected values", () => { - let colors = getCardColors({ - title_color: "f00", - text_color: "0f0", - ring_color: "0000ff", - icon_color: "00f", - bg_color: "fff", - border_color: "fff", - theme: "dark", - }); - expect(colors).toStrictEqual({ - titleColor: "#f00", - textColor: "#0f0", - iconColor: "#00f", - ringColor: "#0000ff", - bgColor: "#fff", - borderColor: "#fff", - }); - }); - - it("getCardColors: should fallback to default colors if color is invalid", () => { - let colors = getCardColors({ - title_color: "invalidcolor", - text_color: "0f0", - icon_color: "00f", - bg_color: "fff", - border_color: "invalidColor", - theme: "dark", - }); - expect(colors).toStrictEqual({ - titleColor: "#2f80ed", - textColor: "#0f0", - iconColor: "#00f", - ringColor: "#2f80ed", - bgColor: "#fff", - borderColor: "#e4e2e2", - }); - }); - - it("getCardColors: should fallback to specified theme colors if is not defined", () => { - let colors = getCardColors({ - theme: "dark", - }); - expect(colors).toStrictEqual({ - titleColor: "#fff", - textColor: "#9f9f9f", - ringColor: "#fff", - iconColor: "#79ff97", - bgColor: "#151515", - borderColor: "#e4e2e2", - }); - }); - - it("getCardColors: should return ring color equal to title color if not ring color is defined", () => { - let colors = getCardColors({ - title_color: "f00", - text_color: "0f0", - icon_color: "00f", - bg_color: "fff", - border_color: "fff", - theme: "dark", - }); - expect(colors).toStrictEqual({ - titleColor: "#f00", - textColor: "#0f0", - iconColor: "#00f", - ringColor: "#f00", - bgColor: "#fff", - borderColor: "#fff", - }); - }); - it("formatBytes: should return expected values", () => { expect(formatBytes(0)).toBe("0 B"); expect(formatBytes(100)).toBe("100.0 B"); From c4a59b5afaca04bd888b9c17badd2fe262cb815c Mon Sep 17 00:00:00 2001 From: martin-mfg <2026226+martin-mfg@users.noreply.github.com> Date: Mon, 13 Oct 2025 22:36:38 +0200 Subject: [PATCH 184/265] refactor: reduce magic numbers inside wakatime card generation code (#4534) * refactor magic numbers * dev --------- Co-authored-by: Alexandr --- src/cards/wakatime.js | 26 ++++++++++++++++---------- 1 file changed, 16 insertions(+), 10 deletions(-) diff --git a/src/cards/wakatime.js b/src/cards/wakatime.js index 5dadcdab905bf..b1accd4536887 100644 --- a/src/cards/wakatime.js +++ b/src/cards/wakatime.js @@ -21,6 +21,11 @@ const languageColors = require("../common/languageColors.json"); // now works const DEFAULT_CARD_WIDTH = 495; const MIN_CARD_WIDTH = 250; const COMPACT_LAYOUT_MIN_WIDTH = 400; +const DEFAULT_LINE_HEIGHT = 25; +const PROGRESSBAR_PADDING = 130; +const HIDDEN_PROGRESSBAR_PADDING = 170; +const COMPACT_LAYOUT_PROGRESSBAR_PADDING = 25; +const TOTAL_TEXT_WIDTH = 275; /** * Creates the no coding activity SVG node. @@ -100,7 +105,7 @@ const createLanguageTextNode = ({ langs, y, display_format, card_width }) => { return createCompactLangNode({ lang, x: isLeft ? LEFT_X : RIGHT_X, - y: isLeft ? 12.5 * index + y : 12.5 + 12.5 * index, + y: y + DEFAULT_LINE_HEIGHT * Math.floor(index / 2), display_format, }); }); @@ -133,7 +138,6 @@ const createTextNode = ({ progressBarWidth, }) => { const staggerDelay = (index + 3) * 150; - const cardProgress = hideProgress ? null : createProgressNode({ @@ -153,7 +157,7 @@ const createTextNode = ({ ${label}: ${value} ${cardProgress} @@ -246,7 +250,7 @@ const renderWakatimeCard = (stats = {}, options = { hide: [] }) => { hide_border = false, card_width, hide, - line_height = 25, + line_height = DEFAULT_LINE_HEIGHT, title_color, icon_color, text_color, @@ -315,16 +319,18 @@ const renderWakatimeCard = (stats = {}, options = { hide: [] }) => { // RENDER COMPACT LAYOUT if (layout === "compact") { - let width = normalizedWidth - 5; - height = 90 + Math.round(filteredLanguages.length / 2) * 25; + const width = normalizedWidth - 5; + height = + 90 + Math.round(filteredLanguages.length / 2) * DEFAULT_LINE_HEIGHT; // progressOffset holds the previous language's width and used to offset the next language // so that we can stack them one after another, like this: [--][----][---] let progressOffset = 0; const compactProgressBar = filteredLanguages .map((language) => { - // const progress = (width * lang.percent) / 100; - const progress = ((width - 25) * language.percent) / 100; + const progress = + ((width - COMPACT_LAYOUT_PROGRESSBAR_PADDING) * language.percent) / + 100; // @ts-ignore const languageColor = languageColors[language.name] || "#858585"; @@ -347,7 +353,7 @@ const renderWakatimeCard = (stats = {}, options = { hide: [] }) => { finalLayout = ` - + ${compactProgressBar} ${ @@ -384,7 +390,7 @@ const renderWakatimeCard = (stats = {}, options = { hide: [] }) => { // @ts-ignore progressBarBackgroundColor: textColor, hideProgress: hide_progress, - progressBarWidth: normalizedWidth - 275, + progressBarWidth: normalizedWidth - TOTAL_TEXT_WIDTH, }); }) : [ From 5df2e634e9c1223629fdb0ee64e8136ae44f5963 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Mon, 13 Oct 2025 23:50:06 +0300 Subject: [PATCH 185/265] refactor: move formatting related code into separate file (#4568) Co-authored-by: Alexandr --- src/cards/gist.js | 2 +- src/cards/repo.js | 2 +- src/cards/stats.js | 8 ++---- src/cards/top-languages.js | 2 +- src/common/fmt.js | 50 +++++++++++++++++++++++++++++++++++++ src/common/index.js | 1 - src/common/utils.js | 51 -------------------------------------- tests/utils.test.js | 5 ++-- 8 files changed, 58 insertions(+), 63 deletions(-) create mode 100644 src/common/fmt.js diff --git a/src/cards/gist.js b/src/cards/gist.js index ecace8381495f..3c3d059d07ae5 100644 --- a/src/cards/gist.js +++ b/src/cards/gist.js @@ -4,7 +4,6 @@ import { parseEmojis, wrapTextMultiline, encodeHTML, - kFormatter, measureText, flexLayout, iconWithLabel, @@ -12,6 +11,7 @@ import { } from "../common/utils.js"; import Card from "../common/Card.js"; import { getCardColors } from "../common/color.js"; +import { kFormatter } from "../common/fmt.js"; import { icons } from "../common/icons.js"; /** Import language colors. diff --git a/src/cards/repo.js b/src/cards/repo.js index 9f28c7a5c2555..6ebabeab07963 100644 --- a/src/cards/repo.js +++ b/src/cards/repo.js @@ -2,12 +2,12 @@ import { Card } from "../common/Card.js"; import { getCardColors } from "../common/color.js"; +import { kFormatter } from "../common/fmt.js"; import { I18n } from "../common/I18n.js"; import { icons } from "../common/icons.js"; import { encodeHTML, flexLayout, - kFormatter, measureText, parseEmojis, wrapTextMultiline, diff --git a/src/cards/stats.js b/src/cards/stats.js index 67ef73d228608..7737fe22b0afe 100644 --- a/src/cards/stats.js +++ b/src/cards/stats.js @@ -3,14 +3,10 @@ import { Card } from "../common/Card.js"; import { getCardColors } from "../common/color.js"; import { CustomError } from "../common/error.js"; +import { kFormatter } from "../common/fmt.js"; import { I18n } from "../common/I18n.js"; import { icons, rankIcon } from "../common/icons.js"; -import { - clampValue, - flexLayout, - kFormatter, - measureText, -} from "../common/utils.js"; +import { clampValue, flexLayout, measureText } from "../common/utils.js"; import { statCardLocales, wakatimeCardLocales } from "../translations.js"; const CARD_MIN_WIDTH = 287; diff --git a/src/cards/top-languages.js b/src/cards/top-languages.js index 76c02fad2156a..ec91fcc996390 100644 --- a/src/cards/top-languages.js +++ b/src/cards/top-languages.js @@ -3,6 +3,7 @@ import { Card } from "../common/Card.js"; import { getCardColors } from "../common/color.js"; import { createProgressNode } from "../common/createProgressNode.js"; +import { formatBytes } from "../common/fmt.js"; import { I18n } from "../common/I18n.js"; import { chunkArray, @@ -10,7 +11,6 @@ import { flexLayout, lowercaseTrim, measureText, - formatBytes, } from "../common/utils.js"; import { langCardLocales } from "../translations.js"; diff --git a/src/common/fmt.js b/src/common/fmt.js new file mode 100644 index 0000000000000..2d40378a88108 --- /dev/null +++ b/src/common/fmt.js @@ -0,0 +1,50 @@ +/** + * Retrieves num with suffix k(thousands) precise to given decimal places. + * + * @param {number} num The number to format. + * @param {number=} precision The number of decimal places to include. + * @returns {string|number} The formatted number. + */ +const kFormatter = (num, precision) => { + const abs = Math.abs(num); + const sign = Math.sign(num); + + if (typeof precision === "number" && !isNaN(precision)) { + return (sign * (abs / 1000)).toFixed(precision) + "k"; + } + + if (abs < 1000) { + return sign * abs; + } + + return sign * parseFloat((abs / 1000).toFixed(1)) + "k"; +}; + +/** + * Convert bytes to a human-readable string representation. + * + * @param {number} bytes The number of bytes to convert. + * @returns {string} The human-readable representation of bytes. + * @throws {Error} If bytes is negative or too large. + */ +const formatBytes = (bytes) => { + if (bytes < 0) { + throw new Error("Bytes must be a non-negative number"); + } + + if (bytes === 0) { + return "0 B"; + } + + const sizes = ["B", "KB", "MB", "GB", "TB", "PB", "EB"]; + const base = 1024; + const i = Math.floor(Math.log(bytes) / Math.log(base)); + + if (i >= sizes.length) { + throw new Error("Bytes is too large to convert to a human-readable string"); + } + + return `${(bytes / Math.pow(base, i)).toFixed(1)} ${sizes[i]}`; +}; + +export { kFormatter, formatBytes }; diff --git a/src/common/index.js b/src/common/index.js index 5dfb0e1209986..93b50cc07f016 100644 --- a/src/common/index.js +++ b/src/common/index.js @@ -10,7 +10,6 @@ export { ERROR_CARD_LENGTH, renderError, encodeHTML, - kFormatter, parseBoolean, parseArray, clampValue, diff --git a/src/common/utils.js b/src/common/utils.js index a43df79b1b077..2d8659981641f 100644 --- a/src/common/utils.js +++ b/src/common/utils.js @@ -76,28 +76,6 @@ const iconWithLabel = (icon, label, testid, iconSize) => { return flexLayout({ items: [iconSvg, text], gap: 20 }).join(""); }; -/** - * Retrieves num with suffix k(thousands) precise to given decimal places. - * - * @param {number} num The number to format. - * @param {number=} precision The number of decimal places to include. - * @returns {string|number} The formatted number. - */ -const kFormatter = (num, precision) => { - const abs = Math.abs(num); - const sign = Math.sign(num); - - if (typeof precision === "number" && !isNaN(precision)) { - return (sign * (abs / 1000)).toFixed(precision) + "k"; - } - - if (abs < 1000) { - return sign * abs; - } - - return sign * parseFloat((abs / 1000).toFixed(1)) + "k"; -}; - /** * Returns boolean if value is either "true" or "false" else the value as it is. * @@ -399,40 +377,12 @@ const dateDiff = (d1, d2) => { return Math.round(diff / (1000 * 60)); }; -/** - * Convert bytes to a human-readable string representation. - * - * @param {number} bytes The number of bytes to convert. - * @returns {string} The human-readable representation of bytes. - * @throws {Error} If bytes is negative or too large. - */ -const formatBytes = (bytes) => { - if (bytes < 0) { - throw new Error("Bytes must be a non-negative number"); - } - - if (bytes === 0) { - return "0 B"; - } - - const sizes = ["B", "KB", "MB", "GB", "TB", "PB", "EB"]; - const base = 1024; - const i = Math.floor(Math.log(bytes) / Math.log(base)); - - if (i >= sizes.length) { - throw new Error("Bytes is too large to convert to a human-readable string"); - } - - return `${(bytes / Math.pow(base, i)).toFixed(1)} ${sizes[i]}`; -}; - export { ERROR_CARD_LENGTH, renderError, createLanguageNode, iconWithLabel, encodeHTML, - kFormatter, parseBoolean, parseArray, clampValue, @@ -445,5 +395,4 @@ export { chunkArray, parseEmojis, dateDiff, - formatBytes, }; diff --git a/tests/utils.test.js b/tests/utils.test.js index 8cecfa7973cfc..c4af90d99639d 100644 --- a/tests/utils.test.js +++ b/tests/utils.test.js @@ -1,14 +1,15 @@ +// @ts-check + import { describe, expect, it } from "@jest/globals"; import { queryByTestId } from "@testing-library/dom"; import "@testing-library/jest-dom"; import { encodeHTML, - formatBytes, - kFormatter, parseBoolean, renderError, wrapTextMultiline, } from "../src/common/utils.js"; +import { formatBytes, kFormatter } from "../src/common/fmt.js"; describe("Test utils.js", () => { it("should test kFormatter default behavior", () => { From b9c3bf625155f1dd89ab89793074a39c2abe32eb Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Mon, 13 Oct 2025 23:56:07 +0300 Subject: [PATCH 186/265] refactor: move fmt related tests into separate file (#4569) Co-authored-by: Alexandr --- tests/fmt.test.js | 67 +++++++++++++++++++++++++++++++++++++++++++++ tests/utils.test.js | 64 ------------------------------------------- 2 files changed, 67 insertions(+), 64 deletions(-) create mode 100644 tests/fmt.test.js diff --git a/tests/fmt.test.js b/tests/fmt.test.js new file mode 100644 index 0000000000000..9aa4b59f1e637 --- /dev/null +++ b/tests/fmt.test.js @@ -0,0 +1,67 @@ +import { describe, expect, it } from "@jest/globals"; +import { formatBytes, kFormatter } from "../src/common/fmt.js"; + +describe("Test fmt.js", () => { + it("should test kFormatter default behavior", () => { + expect(kFormatter(1)).toBe(1); + expect(kFormatter(-1)).toBe(-1); + expect(kFormatter(500)).toBe(500); + expect(kFormatter(1000)).toBe("1k"); + expect(kFormatter(1200)).toBe("1.2k"); + expect(kFormatter(10000)).toBe("10k"); + expect(kFormatter(12345)).toBe("12.3k"); + expect(kFormatter(99900)).toBe("99.9k"); + expect(kFormatter(9900000)).toBe("9900k"); + }); + + it("should test kFormatter with 0 decimal precision", () => { + expect(kFormatter(1, 0)).toBe("0k"); + expect(kFormatter(-1, 0)).toBe("-0k"); + expect(kFormatter(500, 0)).toBe("1k"); + expect(kFormatter(1000, 0)).toBe("1k"); + expect(kFormatter(1200, 0)).toBe("1k"); + expect(kFormatter(10000, 0)).toBe("10k"); + expect(kFormatter(12345, 0)).toBe("12k"); + expect(kFormatter(99000, 0)).toBe("99k"); + expect(kFormatter(99900, 0)).toBe("100k"); + expect(kFormatter(9900000, 0)).toBe("9900k"); + }); + + it("should test kFormatter with 1 decimal precision", () => { + expect(kFormatter(1, 1)).toBe("0.0k"); + expect(kFormatter(-1, 1)).toBe("-0.0k"); + expect(kFormatter(500, 1)).toBe("0.5k"); + expect(kFormatter(1000, 1)).toBe("1.0k"); + expect(kFormatter(1200, 1)).toBe("1.2k"); + expect(kFormatter(10000, 1)).toBe("10.0k"); + expect(kFormatter(12345, 1)).toBe("12.3k"); + expect(kFormatter(99900, 1)).toBe("99.9k"); + expect(kFormatter(9900000, 1)).toBe("9900.0k"); + }); + + it("should test kFormatter with 2 decimal precision", () => { + expect(kFormatter(1, 2)).toBe("0.00k"); + expect(kFormatter(-1, 2)).toBe("-0.00k"); + expect(kFormatter(500, 2)).toBe("0.50k"); + expect(kFormatter(1000, 2)).toBe("1.00k"); + expect(kFormatter(1200, 2)).toBe("1.20k"); + expect(kFormatter(10000, 2)).toBe("10.00k"); + expect(kFormatter(12345, 2)).toBe("12.35k"); + expect(kFormatter(99900, 2)).toBe("99.90k"); + expect(kFormatter(9900000, 2)).toBe("9900.00k"); + }); + + it("formatBytes: should return expected values", () => { + expect(formatBytes(0)).toBe("0 B"); + expect(formatBytes(100)).toBe("100.0 B"); + expect(formatBytes(1024)).toBe("1.0 KB"); + expect(formatBytes(1024 * 1024)).toBe("1.0 MB"); + expect(formatBytes(1024 * 1024 * 1024)).toBe("1.0 GB"); + expect(formatBytes(1024 * 1024 * 1024 * 1024)).toBe("1.0 TB"); + expect(formatBytes(1024 * 1024 * 1024 * 1024 * 1024)).toBe("1.0 PB"); + expect(formatBytes(1024 * 1024 * 1024 * 1024 * 1024 * 1024)).toBe("1.0 EB"); + + expect(formatBytes(1234 * 1024)).toBe("1.2 MB"); + expect(formatBytes(123.4 * 1024)).toBe("123.4 KB"); + }); +}); diff --git a/tests/utils.test.js b/tests/utils.test.js index c4af90d99639d..9be0ae2f1f568 100644 --- a/tests/utils.test.js +++ b/tests/utils.test.js @@ -9,58 +9,8 @@ import { renderError, wrapTextMultiline, } from "../src/common/utils.js"; -import { formatBytes, kFormatter } from "../src/common/fmt.js"; describe("Test utils.js", () => { - it("should test kFormatter default behavior", () => { - expect(kFormatter(1)).toBe(1); - expect(kFormatter(-1)).toBe(-1); - expect(kFormatter(500)).toBe(500); - expect(kFormatter(1000)).toBe("1k"); - expect(kFormatter(1200)).toBe("1.2k"); - expect(kFormatter(10000)).toBe("10k"); - expect(kFormatter(12345)).toBe("12.3k"); - expect(kFormatter(99900)).toBe("99.9k"); - expect(kFormatter(9900000)).toBe("9900k"); - }); - - it("should test kFormatter with 0 decimal precision", () => { - expect(kFormatter(1, 0)).toBe("0k"); - expect(kFormatter(-1, 0)).toBe("-0k"); - expect(kFormatter(500, 0)).toBe("1k"); - expect(kFormatter(1000, 0)).toBe("1k"); - expect(kFormatter(1200, 0)).toBe("1k"); - expect(kFormatter(10000, 0)).toBe("10k"); - expect(kFormatter(12345, 0)).toBe("12k"); - expect(kFormatter(99000, 0)).toBe("99k"); - expect(kFormatter(99900, 0)).toBe("100k"); - expect(kFormatter(9900000, 0)).toBe("9900k"); - }); - - it("should test kFormatter with 1 decimal precision", () => { - expect(kFormatter(1, 1)).toBe("0.0k"); - expect(kFormatter(-1, 1)).toBe("-0.0k"); - expect(kFormatter(500, 1)).toBe("0.5k"); - expect(kFormatter(1000, 1)).toBe("1.0k"); - expect(kFormatter(1200, 1)).toBe("1.2k"); - expect(kFormatter(10000, 1)).toBe("10.0k"); - expect(kFormatter(12345, 1)).toBe("12.3k"); - expect(kFormatter(99900, 1)).toBe("99.9k"); - expect(kFormatter(9900000, 1)).toBe("9900.0k"); - }); - - it("should test kFormatter with 2 decimal precision", () => { - expect(kFormatter(1, 2)).toBe("0.00k"); - expect(kFormatter(-1, 2)).toBe("-0.00k"); - expect(kFormatter(500, 2)).toBe("0.50k"); - expect(kFormatter(1000, 2)).toBe("1.00k"); - expect(kFormatter(1200, 2)).toBe("1.20k"); - expect(kFormatter(10000, 2)).toBe("10.00k"); - expect(kFormatter(12345, 2)).toBe("12.35k"); - expect(kFormatter(99900, 2)).toBe("99.90k"); - expect(kFormatter(9900000, 2)).toBe("9900.00k"); - }); - it("should test parseBoolean", () => { expect(parseBoolean(true)).toBe(true); expect(parseBoolean(false)).toBe(false); @@ -102,20 +52,6 @@ describe("Test utils.js", () => { queryByTestId(document.body, "message").children[1], ).toHaveTextContent(/Secondary Message/gim); }); - - it("formatBytes: should return expected values", () => { - expect(formatBytes(0)).toBe("0 B"); - expect(formatBytes(100)).toBe("100.0 B"); - expect(formatBytes(1024)).toBe("1.0 KB"); - expect(formatBytes(1024 * 1024)).toBe("1.0 MB"); - expect(formatBytes(1024 * 1024 * 1024)).toBe("1.0 GB"); - expect(formatBytes(1024 * 1024 * 1024 * 1024)).toBe("1.0 TB"); - expect(formatBytes(1024 * 1024 * 1024 * 1024 * 1024)).toBe("1.0 PB"); - expect(formatBytes(1024 * 1024 * 1024 * 1024 * 1024 * 1024)).toBe("1.0 EB"); - - expect(formatBytes(1234 * 1024)).toBe("1.2 MB"); - expect(formatBytes(123.4 * 1024)).toBe("123.4 KB"); - }); }); describe("wrapTextMultiline", () => { From ab53e3052d5d795fa45d7499d4830bc552d2c077 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Tue, 14 Oct 2025 21:11:23 +0300 Subject: [PATCH 187/265] refactor: move wrap text multiline function into fmt module (#4572) Co-authored-by: Alexandr --- src/cards/gist.js | 3 +-- src/cards/repo.js | 3 +-- src/common/fmt.js | 42 ++++++++++++++++++++++++++++++++++- src/common/index.js | 1 - src/common/utils.js | 37 ------------------------------ src/fetchers/stats.js | 3 ++- src/fetchers/top-languages.js | 3 ++- tests/utils.test.js | 9 +++----- 8 files changed, 50 insertions(+), 51 deletions(-) diff --git a/src/cards/gist.js b/src/cards/gist.js index 3c3d059d07ae5..2deaf448dcce8 100644 --- a/src/cards/gist.js +++ b/src/cards/gist.js @@ -2,7 +2,6 @@ import { parseEmojis, - wrapTextMultiline, encodeHTML, measureText, flexLayout, @@ -11,7 +10,7 @@ import { } from "../common/utils.js"; import Card from "../common/Card.js"; import { getCardColors } from "../common/color.js"; -import { kFormatter } from "../common/fmt.js"; +import { kFormatter, wrapTextMultiline } from "../common/fmt.js"; import { icons } from "../common/icons.js"; /** Import language colors. diff --git a/src/cards/repo.js b/src/cards/repo.js index 6ebabeab07963..ccf42645e898c 100644 --- a/src/cards/repo.js +++ b/src/cards/repo.js @@ -2,7 +2,7 @@ import { Card } from "../common/Card.js"; import { getCardColors } from "../common/color.js"; -import { kFormatter } from "../common/fmt.js"; +import { kFormatter, wrapTextMultiline } from "../common/fmt.js"; import { I18n } from "../common/I18n.js"; import { icons } from "../common/icons.js"; import { @@ -10,7 +10,6 @@ import { flexLayout, measureText, parseEmojis, - wrapTextMultiline, iconWithLabel, createLanguageNode, clampValue, diff --git a/src/common/fmt.js b/src/common/fmt.js index 2d40378a88108..ca86f3cf59cae 100644 --- a/src/common/fmt.js +++ b/src/common/fmt.js @@ -1,3 +1,8 @@ +// @ts-check + +import wrap from "word-wrap"; +import { encodeHTML } from "./utils.js"; + /** * Retrieves num with suffix k(thousands) precise to given decimal places. * @@ -47,4 +52,39 @@ const formatBytes = (bytes) => { return `${(bytes / Math.pow(base, i)).toFixed(1)} ${sizes[i]}`; }; -export { kFormatter, formatBytes }; +/** + * Split text over multiple lines based on the card width. + * + * @param {string} text Text to split. + * @param {number} width Line width in number of characters. + * @param {number} maxLines Maximum number of lines. + * @returns {string[]} Array of lines. + */ +const wrapTextMultiline = (text, width = 59, maxLines = 3) => { + const fullWidthComma = ","; + const encoded = encodeHTML(text); + const isChinese = encoded.includes(fullWidthComma); + + let wrapped = []; + + if (isChinese) { + wrapped = encoded.split(fullWidthComma); // Chinese full punctuation + } else { + wrapped = wrap(encoded, { + width, + }).split("\n"); // Split wrapped lines to get an array of lines + } + + const lines = wrapped.map((line) => line.trim()).slice(0, maxLines); // Only consider maxLines lines + + // Add "..." to the last line if the text exceeds maxLines + if (wrapped.length > maxLines) { + lines[maxLines - 1] += "..."; + } + + // Remove empty lines if text fits in less than maxLines lines + const multiLineText = lines.filter(Boolean); + return multiLineText; +}; + +export { kFormatter, formatBytes, wrapTextMultiline }; diff --git a/src/common/index.js b/src/common/index.js index 93b50cc07f016..3a61fead40c02 100644 --- a/src/common/index.js +++ b/src/common/index.js @@ -15,7 +15,6 @@ export { clampValue, request, flexLayout, - wrapTextMultiline, logger, measureText, lowercaseTrim, diff --git a/src/common/utils.js b/src/common/utils.js index 2d8659981641f..6ce2741cce3b2 100644 --- a/src/common/utils.js +++ b/src/common/utils.js @@ -2,7 +2,6 @@ import axios from "axios"; import toEmoji from "emoji-name-map"; -import wrap from "word-wrap"; import { SECONDARY_ERROR_MESSAGES, TRY_AGAIN_LATER } from "./error.js"; import { getCardColors } from "./color.js"; @@ -234,41 +233,6 @@ const renderError = ({ `; }; -/** - * Split text over multiple lines based on the card width. - * - * @param {string} text Text to split. - * @param {number} width Line width in number of characters. - * @param {number} maxLines Maximum number of lines. - * @returns {string[]} Array of lines. - */ -const wrapTextMultiline = (text, width = 59, maxLines = 3) => { - const fullWidthComma = ","; - const encoded = encodeHTML(text); - const isChinese = encoded.includes(fullWidthComma); - - let wrapped = []; - - if (isChinese) { - wrapped = encoded.split(fullWidthComma); // Chinese full punctuation - } else { - wrapped = wrap(encoded, { - width, - }).split("\n"); // Split wrapped lines to get an array of lines - } - - const lines = wrapped.map((line) => line.trim()).slice(0, maxLines); // Only consider maxLines lines - - // Add "..." to the last line if the text exceeds maxLines - if (wrapped.length > maxLines) { - lines[maxLines - 1] += "..."; - } - - // Remove empty lines if text fits in less than maxLines lines - const multiLineText = lines.filter(Boolean); - return multiLineText; -}; - const noop = () => {}; // return console instance based on the environment const logger = @@ -388,7 +352,6 @@ export { clampValue, request, flexLayout, - wrapTextMultiline, logger, measureText, lowercaseTrim, diff --git a/src/fetchers/stats.js b/src/fetchers/stats.js index f22dfaf65f7c0..37ce591f51458 100644 --- a/src/fetchers/stats.js +++ b/src/fetchers/stats.js @@ -5,9 +5,10 @@ import * as dotenv from "dotenv"; import githubUsernameRegex from "github-username-regex"; import { calculateRank } from "../calculateRank.js"; import { retryer } from "../common/retryer.js"; -import { logger, request, wrapTextMultiline } from "../common/utils.js"; +import { logger, request } from "../common/utils.js"; import { excludeRepositories } from "../common/envs.js"; import { CustomError, MissingParamError } from "../common/error.js"; +import { wrapTextMultiline } from "../common/fmt.js"; dotenv.config(); diff --git a/src/fetchers/top-languages.js b/src/fetchers/top-languages.js index 9542678e581b0..9e711b0d1157a 100644 --- a/src/fetchers/top-languages.js +++ b/src/fetchers/top-languages.js @@ -1,9 +1,10 @@ // @ts-check import { retryer } from "../common/retryer.js"; -import { logger, request, wrapTextMultiline } from "../common/utils.js"; +import { logger, request } from "../common/utils.js"; import { excludeRepositories } from "../common/envs.js"; import { CustomError, MissingParamError } from "../common/error.js"; +import { wrapTextMultiline } from "../common/fmt.js"; /** * @typedef {import("axios").AxiosRequestHeaders} AxiosRequestHeaders Axios request headers. diff --git a/tests/utils.test.js b/tests/utils.test.js index 9be0ae2f1f568..92b12f7c93f5c 100644 --- a/tests/utils.test.js +++ b/tests/utils.test.js @@ -3,12 +3,8 @@ import { describe, expect, it } from "@jest/globals"; import { queryByTestId } from "@testing-library/dom"; import "@testing-library/jest-dom"; -import { - encodeHTML, - parseBoolean, - renderError, - wrapTextMultiline, -} from "../src/common/utils.js"; +import { encodeHTML, parseBoolean, renderError } from "../src/common/utils.js"; +import { wrapTextMultiline } from "../src/common/fmt.js"; describe("Test utils.js", () => { it("should test parseBoolean", () => { @@ -25,6 +21,7 @@ describe("Test utils.js", () => { expect(parseBoolean("1")).toBe(undefined); expect(parseBoolean("0")).toBe(undefined); expect(parseBoolean("")).toBe(undefined); + // @ts-ignore expect(parseBoolean(undefined)).toBe(undefined); }); From fda29161e850dd4264cd83c525900d62739926cf Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Tue, 14 Oct 2025 21:19:54 +0300 Subject: [PATCH 188/265] refactor: move wrap text multiline function tests into fmt module (#4573) * refactor: move wrap text multiline function tests into fmt module * lints --------- Co-authored-by: Alexandr --- tests/fmt.test.js | 39 ++++++++++++++++++++++++++++++++++++++- tests/utils.test.js | 33 --------------------------------- 2 files changed, 38 insertions(+), 34 deletions(-) diff --git a/tests/fmt.test.js b/tests/fmt.test.js index 9aa4b59f1e637..d39616cacc608 100644 --- a/tests/fmt.test.js +++ b/tests/fmt.test.js @@ -1,5 +1,9 @@ import { describe, expect, it } from "@jest/globals"; -import { formatBytes, kFormatter } from "../src/common/fmt.js"; +import { + formatBytes, + kFormatter, + wrapTextMultiline, +} from "../src/common/fmt.js"; describe("Test fmt.js", () => { it("should test kFormatter default behavior", () => { @@ -64,4 +68,37 @@ describe("Test fmt.js", () => { expect(formatBytes(1234 * 1024)).toBe("1.2 MB"); expect(formatBytes(123.4 * 1024)).toBe("123.4 KB"); }); + + it("wrapTextMultiline: should not wrap small texts", () => { + { + let multiLineText = wrapTextMultiline("Small text should not wrap"); + expect(multiLineText).toEqual(["Small text should not wrap"]); + } + }); + + it("wrapTextMultiline: should wrap large texts", () => { + let multiLineText = wrapTextMultiline( + "Hello world long long long text", + 20, + 3, + ); + expect(multiLineText).toEqual(["Hello world long", "long long text"]); + }); + + it("wrapTextMultiline: should wrap large texts and limit max lines", () => { + let multiLineText = wrapTextMultiline( + "Hello world long long long text", + 10, + 2, + ); + expect(multiLineText).toEqual(["Hello", "world long..."]); + }); + + it("wrapTextMultiline: should wrap chinese by punctuation", () => { + let multiLineText = wrapTextMultiline( + "专门为刚开始刷题的同学准备的算法基地,没有最细只有更细,立志用动画将晦涩难懂的算法说的通俗易懂!", + ); + expect(multiLineText.length).toEqual(3); + expect(multiLineText[0].length).toEqual(18 * 8); // &#xxxxx; x 8 + }); }); diff --git a/tests/utils.test.js b/tests/utils.test.js index 92b12f7c93f5c..0b37e45acbd07 100644 --- a/tests/utils.test.js +++ b/tests/utils.test.js @@ -4,7 +4,6 @@ import { describe, expect, it } from "@jest/globals"; import { queryByTestId } from "@testing-library/dom"; import "@testing-library/jest-dom"; import { encodeHTML, parseBoolean, renderError } from "../src/common/utils.js"; -import { wrapTextMultiline } from "../src/common/fmt.js"; describe("Test utils.js", () => { it("should test parseBoolean", () => { @@ -50,35 +49,3 @@ describe("Test utils.js", () => { ).toHaveTextContent(/Secondary Message/gim); }); }); - -describe("wrapTextMultiline", () => { - it("should not wrap small texts", () => { - { - let multiLineText = wrapTextMultiline("Small text should not wrap"); - expect(multiLineText).toEqual(["Small text should not wrap"]); - } - }); - it("should wrap large texts", () => { - let multiLineText = wrapTextMultiline( - "Hello world long long long text", - 20, - 3, - ); - expect(multiLineText).toEqual(["Hello world long", "long long text"]); - }); - it("should wrap large texts and limit max lines", () => { - let multiLineText = wrapTextMultiline( - "Hello world long long long text", - 10, - 2, - ); - expect(multiLineText).toEqual(["Hello", "world long..."]); - }); - it("should wrap chinese by punctuation", () => { - let multiLineText = wrapTextMultiline( - "专门为刚开始刷题的同学准备的算法基地,没有最细只有更细,立志用动画将晦涩难懂的算法说的通俗易懂!", - ); - expect(multiLineText.length).toEqual(3); - expect(multiLineText[0].length).toEqual(18 * 8); // &#xxxxx; x 8 - }); -}); From d574feb667da49978fc4cdac50609a17618d77b6 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Tue, 14 Oct 2025 21:33:07 +0300 Subject: [PATCH 189/265] refactor: better naming for kformatter function tests (#4574) Co-authored-by: Alexandr --- tests/fmt.test.js | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/tests/fmt.test.js b/tests/fmt.test.js index d39616cacc608..857221f25073b 100644 --- a/tests/fmt.test.js +++ b/tests/fmt.test.js @@ -6,7 +6,7 @@ import { } from "../src/common/fmt.js"; describe("Test fmt.js", () => { - it("should test kFormatter default behavior", () => { + it("kFormatter: should format numbers correctly by default", () => { expect(kFormatter(1)).toBe(1); expect(kFormatter(-1)).toBe(-1); expect(kFormatter(500)).toBe(500); @@ -18,7 +18,7 @@ describe("Test fmt.js", () => { expect(kFormatter(9900000)).toBe("9900k"); }); - it("should test kFormatter with 0 decimal precision", () => { + it("kFormatter: should format numbers correctly with 0 decimal precision", () => { expect(kFormatter(1, 0)).toBe("0k"); expect(kFormatter(-1, 0)).toBe("-0k"); expect(kFormatter(500, 0)).toBe("1k"); @@ -31,7 +31,7 @@ describe("Test fmt.js", () => { expect(kFormatter(9900000, 0)).toBe("9900k"); }); - it("should test kFormatter with 1 decimal precision", () => { + it("kFormatter: should format numbers correctly with 1 decimal precision", () => { expect(kFormatter(1, 1)).toBe("0.0k"); expect(kFormatter(-1, 1)).toBe("-0.0k"); expect(kFormatter(500, 1)).toBe("0.5k"); @@ -43,7 +43,7 @@ describe("Test fmt.js", () => { expect(kFormatter(9900000, 1)).toBe("9900.0k"); }); - it("should test kFormatter with 2 decimal precision", () => { + it("kFormatter: should format numbers correctly with 2 decimal precision", () => { expect(kFormatter(1, 2)).toBe("0.00k"); expect(kFormatter(-1, 2)).toBe("-0.00k"); expect(kFormatter(500, 2)).toBe("0.50k"); From 306d0a34ceb08f622de8a6e97e2ecd2f585a66d8 Mon Sep 17 00:00:00 2001 From: Wai Yan Naung <60054637+wynaung19@users.noreply.github.com> Date: Wed, 15 Oct 2025 03:40:15 +0900 Subject: [PATCH 190/265] fix: update Burmese translations (#4570) * Fixed Myanmar (my : Burma ) language * Update src/translations.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --------- Co-authored-by: Alexandr Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --- src/translations.js | 44 ++++++++++++++++++++++---------------------- 1 file changed, 22 insertions(+), 22 deletions(-) diff --git a/src/translations.js b/src/translations.js index f62294628bb77..a5d522cd53d39 100644 --- a/src/translations.js +++ b/src/translations.js @@ -48,7 +48,7 @@ const statCardLocales = ({ name, apostrophe }) => { "uk-ua": `Статистика GitHub користувача ${encodedName}`, id: `Statistik GitHub ${encodedName}`, ml: `${encodedName}'${apostrophe} ഗിറ്റ്ഹബ് സ്ഥിതിവിവരക്കണക്കുകൾ`, - my: `Statistik GitHub ${encodedName}`, + my: `${encodedName} ရဲ့ GitHub အခြေအနေများ`, ta: `${encodedName} கிட்ஹப் புள்ளிவிவரங்கள்`, sk: `GitHub štatistiky používateľa ${encodedName}`, tr: `${encodedName} Hesabının GitHub İstatistikleri`, @@ -96,7 +96,7 @@ const statCardLocales = ({ name, apostrophe }) => { "uk-ua": `Рейтинг GitHub користувача ${encodedName}`, id: `Statistik GitHub ${encodedName}`, ml: `${encodedName}'${apostrophe} ഗിറ്റ്ഹബ് സ്ഥിതിവിവരക്കണക്കുകൾ`, - my: `Statistik GitHub ${encodedName}`, + my: `${encodedName} ရဲ့ GitHub အဆင့်`, ta: `${encodedName} கிட்ஹப் தரவரிசை`, sk: `GitHub štatistiky používateľa ${encodedName}`, tr: `${encodedName} Hesabının GitHub Yıldızları`, @@ -144,7 +144,7 @@ const statCardLocales = ({ name, apostrophe }) => { "uk-ua": "Всього зірок", id: "Total Bintang", ml: "ആകെ നക്ഷത്രങ്ങൾ", - my: "Jumlah Bintang", + my: "စုစုပေါင်းကြယ်များ", ta: "சம்பாதித்த மொத்த நட்சத்திரங்கள்", sk: "Hviezdy", tr: "Toplam Yıldız", @@ -192,7 +192,7 @@ const statCardLocales = ({ name, apostrophe }) => { "uk-ua": "Всього комітів", id: "Total Komitmen", ml: "ആകെ കമ്മിറ്റുകൾ", - my: "Jumlah Komitmen", + my: "စုစုပေါင်း Commit များ", ta: `மொத்த கமிட்கள்`, sk: "Všetky commity", tr: "Toplam Commit", @@ -240,7 +240,7 @@ const statCardLocales = ({ name, apostrophe }) => { "uk-ua": "Всього запитів на злиття", id: "Total Permintaan Tarik", ml: "ആകെ പുൾ അഭ്യർത്ഥനകൾ", - my: "Jumlah PR", + my: "စုစုပေါင်း PR များ", ta: `மொத்த இழுக்கும் கோரிக்கைகள்`, sk: "Všetky PR", tr: "Toplam PR", @@ -288,7 +288,7 @@ const statCardLocales = ({ name, apostrophe }) => { "uk-ua": "Всього питань", id: "Total Masalah Dilaporkan", ml: "ആകെ പ്രശ്നങ്ങൾ", - my: "Jumlah Isu Dilaporkan", + my: "စုစုပေါင်းပြဿနာများ", ta: `மொத்த சிக்கல்கள்`, sk: "Všetky problémy", tr: "Toplam Hata", @@ -336,7 +336,7 @@ const statCardLocales = ({ name, apostrophe }) => { "uk-ua": "Зроблено внесок (за минулий рік)", id: "Berkontribusi ke (tahun lalu)", ml: "(കഴിഞ്ഞ വർഷത്തെ)ആകെ സംഭാവനകൾ ", - my: "Menyumbang kepada (tahun lepas)", + my: "အကူအညီပေးခဲ့သည် (ပြီးခဲ့သည့်နှစ်)", ta: "(கடந்த ஆண்டு) பங்களித்தது", sk: "Účasti (minulý rok)", tr: "Katkı Verildi (geçen yıl)", @@ -384,7 +384,7 @@ const statCardLocales = ({ name, apostrophe }) => { "uk-ua": "Всього запитів перевірено", id: "Total PR yang Direview", ml: "ആകെ പുൾ അവലോകനങ്ങൾ", - my: "Jumlah PR Dikaji Semula", + my: "စုစုပေါင်း PR များကို ပြန်လည်သုံးသပ်ခဲ့မှု", ta: "மதிப்பாய்வு செய்யப்பட்ட மொத்த இழுத்தல் கோரிக்கைகள்", sk: "Celkový počet PR", tr: "İncelenen toplam PR", @@ -432,7 +432,7 @@ const statCardLocales = ({ name, apostrophe }) => { "uk-ua": "Всього розпочатих дискусій", id: "Total Diskusi Dimulai", ml: "ആരംഭിച്ച ആലോചനകൾ", - my: "Jumlah Perbincangan Bermula", + my: "စုစုပေါင်း စတင်ခဲ့သော ဆွေးနွေးမှုများ", ta: "மொத்த விவாதங்கள் தொடங்கின", sk: "Celkový počet začatých diskusií", tr: "Başlatılan Toplam Tartışma", @@ -480,7 +480,7 @@ const statCardLocales = ({ name, apostrophe }) => { "uk-ua": "Всього відповідей на дискусії", id: "Total Diskusi Dibalas", ml: "ഉത്തരം നൽകിയ ആലോചനകൾ", - my: "Jumlah Perbincangan Dijawab", + my: "စုစုပေါင်း ပြန်လည်ဖြေကြားခဲ့သော ဆွေးနွေးမှုများ", ta: "பதிலளிக்கப்பட்ட மொத்த விவாதங்கள்", sk: "Celkový počet zodpovedaných diskusií", tr: "Toplam Cevaplanan Tartışma", @@ -527,7 +527,7 @@ const statCardLocales = ({ name, apostrophe }) => { ru: "Всего объединённых запросов", "uk-ua": "Всього об'єднаних запитів", id: "Total PR Digabungkan", - my: "Jumlah PR Digabungkan", + my: "စုစုပေါင်း ပေါင်းစည်းခဲ့သော PR များ", ta: "இணைக்கப்பட்ட மொத்த PRகள்", sk: "Celkový počet zlúčených PR", tr: "Toplam Birleştirilmiş PR", @@ -574,7 +574,7 @@ const statCardLocales = ({ name, apostrophe }) => { ru: "Процент объединённых запросов", "uk-ua": "Відсоток об'єднаних запитів", id: "Persentase PR Digabungkan", - my: "Peratus PR Digabungkan", + my: "PR များကို ပေါင်းစည်းခဲ့သော ရာခိုင်နှုန်း", ta: "இணைக்கப்பட்ட PRகள் சதவீதம்", sk: "Percento zlúčených PR", tr: "Birleştirilmiş PR Yüzdesi", @@ -626,7 +626,7 @@ const repoCardLocales = { "uk-ua": "Шаблон", id: "Pola", ml: "ടെംപ്ലേറ്റ്", - my: "Templat", + my: "ပုံစံ", ta: `டெம்ப்ளேட்`, sk: "Šablóna", tr: "Şablon", @@ -674,7 +674,7 @@ const repoCardLocales = { "uk-ua": "Архивований", id: "Arsip", ml: "ശേഖരിച്ചത്", - my: "Arkib", + my: "သိုလှောင်ပြီး", ta: `காப்பகப்படுத்தப்பட்டது`, sk: "Archivované", tr: "Arşiv", @@ -725,7 +725,7 @@ const langCardLocales = { "uk-ua": "Найбільш використовувані мови", id: "Bahasa Yang Paling Banyak Digunakan", ml: "കൂടുതൽ ഉപയോഗിച്ച ഭാഷകൾ", - my: "Bahasa Paling Digunakan", + my: "အများဆုံးအသုံးပြုသောဘာသာစကားများ", ta: `அதிகம் பயன்படுத்தப்படும் மொழிகள்`, sk: "Najviac používané jazyky", tr: "En Çok Kullanılan Diller", @@ -773,7 +773,7 @@ const langCardLocales = { "uk-ua": "Немає даних про мови.", id: "Tidak ada data bahasa.", ml: "ഭാഷാ ഡാറ്റയില്ല.", - my: "Tiada data bahasa.", + my: "ဒေတာ မရှိပါ။", ta: `மொழி தரவு இல்லை.`, sk: "Žiadne údaje o jazykoch.", tr: "Dil verisi yok.", @@ -824,7 +824,7 @@ const wakatimeCardLocales = { "uk-ua": "Статистика WakaTime", id: "Status WakaTime", ml: "വാകടൈം സ്ഥിതിവിവരക്കണക്കുകൾ", - my: "Statistik WakaTime", + my: "WakaTime အချက်အလက်များ", ta: `WakaTime புள்ளிவிவரங்கள்`, sk: "WakaTime štatistika", tr: "WakaTime İstatistikler", @@ -872,7 +872,7 @@ const wakatimeCardLocales = { "uk-ua": "За минулий рік", id: "Tahun lalu", ml: "കഴിഞ്ഞ വർഷം", - my: "Tahun lepas", + my: "မနှစ်က", ta: `கடந்த ஆண்டு`, sk: "Minulý rok", tr: "Geçen yıl", @@ -920,7 +920,7 @@ const wakatimeCardLocales = { "uk-ua": "Останні 7 днів", id: "7 hari terakhir", ml: "കഴിഞ്ഞ 7 ദിവസം", - my: "7 hari lepas", + my: "7 ရက်အတွင်း", ta: `கடந்த 7 நாட்கள்`, sk: "Posledných 7 dní", tr: "Son 7 gün", @@ -968,7 +968,7 @@ const wakatimeCardLocales = { "uk-ua": "Профіль користувача WakaTime не публічний", id: "Profil pengguna WakaTime tidak publik", ml: "WakaTime ഉപയോക്തൃ പ്രൊഫൈൽ പൊതുവായി പ്രസിദ്ധീകരിക്കപ്പെടാത്തതാണ്", - my: "Profil pengguna WakaTime tidak awam", + my: "Public Profile မဟုတ်ပါ။", ta: `WakaTime பயனர் சுயவிவரம் பொதுவில் இல்லை.`, sk: "Profil používateľa WakaTime nie je verejný", tr: "WakaTime kullanıcı profili herkese açık değil", @@ -1018,7 +1018,7 @@ const wakatimeCardLocales = { "uk-ua": "Користувач не публікує детальну статистику коду", id: "Pengguna tidak membagikan statistik kode terperinci secara publik", ml: "ഉപയോക്താവ് പൊതുവായി വിശദീകരിച്ച കോഡ് സ്റ്റാറ്റിസ്റ്റിക്സ് പങ്കിടുന്നില്ല", - my: "Pengguna tidak berkongsi statistik kod terperinci secara awam", + my: "အသုံးပြုသူသည် အသေးစိတ် ကုဒ် စာရင်းအင်းများကို အများသို့ မမျှဝေပါ။", ta: `பயனர் விரிவான குறியீட்டு புள்ளிவிவரங்களைப் பொதுவில் பகிர்வதில்லை.`, sk: "Používateľ neposkytuje verejne podrobné štatistiky kódu", tr: "Kullanıcı ayrıntılı kod istatistiklerini herkese açık olarak paylaşmıyor", @@ -1066,7 +1066,7 @@ const wakatimeCardLocales = { "uk-ua": "Цього тижня не було активності", id: "Tidak ada aktivitas perkodingan minggu ini", ml: "ഈ ആഴ്ച കോഡിംഗ് പ്രവർത്തനങ്ങളൊന്നുമില്ല", - my: "Tiada aktiviti pengekodan minggu ini", + my: "ဒီအပတ်မှာ ကုဒ်ရေးခြင်း မရှိပါ။", ta: `இந்த வாரம் குறியீட்டு செயல்பாடு இல்லை.`, sk: "Žiadna kódovacia aktivita tento týždeň", tr: "Bu hafta herhangi bir kod yazma aktivitesi olmadı", From 4e44891844acd29a5635da4a7140f95d52ff1ba6 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Tue, 14 Oct 2025 23:33:56 +0300 Subject: [PATCH 191/265] fix: mark Czech as long locale for stats card (#4576) Co-authored-by: Alexandr --- src/cards/stats.js | 1 + 1 file changed, 1 insertion(+) diff --git a/src/cards/stats.js b/src/cards/stats.js index 7737fe22b0afe..949845b837cc9 100644 --- a/src/cards/stats.js +++ b/src/cards/stats.js @@ -377,6 +377,7 @@ const renderStatsCard = (stats, options = {}) => { const longLocales = [ "az", "bg", + "cs", "de", "es", "fil", From da318a67518fe9d3589a53b9a0cfc35ed243edf3 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Tue, 14 Oct 2025 23:55:20 +0300 Subject: [PATCH 192/265] refactor: move long locales const to the top and infer types (#4577) Co-authored-by: Alexandr --- src/cards/stats.js | 57 ++++++++++++++++++++++++++-------------------- 1 file changed, 32 insertions(+), 25 deletions(-) diff --git a/src/cards/stats.js b/src/cards/stats.js index 949845b837cc9..9e6725b0bc7cd 100644 --- a/src/cards/stats.js +++ b/src/cards/stats.js @@ -16,6 +16,36 @@ const RANK_CARD_DEFAULT_WIDTH = 450; const RANK_ONLY_CARD_MIN_WIDTH = 290; const RANK_ONLY_CARD_DEFAULT_WIDTH = 290; +/** + * Long locales that need more space for text. Keep sorted alphabetically. + * + * @type {(keyof typeof wakatimeCardLocales["wakatimecard.title"])[]} + */ +const LONG_LOCALES = [ + "az", + "bg", + "cs", + "de", + "es", + "fil", + "fr", + "id", + "ml", + "my", + "nl", + "pl", + "pt-br", + "pt-pt", + "ru", + "sr", + "sr-latn", + "sw", + "ta", + "uk-ua", + "uz", + "zh-tw", +]; + /** * Create a stats card text item. * @@ -374,31 +404,8 @@ const renderStatsCard = (stats, options = {}) => { id: "contribs", }; - const longLocales = [ - "az", - "bg", - "cs", - "de", - "es", - "fil", - "fr", - "id", - "ml", - "my", - "nl", - "pl", - "pt-br", - "pt-pt", - "ru", - "sr", - "sr-latn", - "sw", - "ta", - "uk-ua", - "uz", - "zh-tw", - ]; - const isLongLocale = locale ? longLocales.includes(locale) : false; + // @ts-ignore + const isLongLocale = locale ? LONG_LOCALES.includes(locale) : false; // filter out hidden stats defined by user & create the text nodes const statItems = Object.keys(STATS) From 2df35521d7f54fb26bffb9278f45184f78884ef4 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Wed, 15 Oct 2025 20:09:34 +0300 Subject: [PATCH 193/265] refactor: move HTTP related code into separate module (#4578) * refactor: move HTTP related code into separate module * dev --------- Co-authored-by: Alexandr --- api/status/pat-info.js | 6 +++++- api/status/up.js | 5 ++++- src/common/http.js | 24 ++++++++++++++++++++++++ src/common/index.js | 1 - src/common/utils.js | 23 ----------------------- src/fetchers/gist.js | 2 +- src/fetchers/repo.js | 2 +- src/fetchers/stats.js | 3 ++- src/fetchers/top-languages.js | 3 ++- 9 files changed, 39 insertions(+), 30 deletions(-) create mode 100644 src/common/http.js diff --git a/api/status/pat-info.js b/api/status/pat-info.js index 1f17bf65aadb9..087abd48cb7d3 100644 --- a/api/status/pat-info.js +++ b/api/status/pat-info.js @@ -1,3 +1,5 @@ +// @ts-check + /** * @file Contains a simple cloud function that can be used to check which PATs are no * longer working. It returns a list of valid PATs, expired PATs and PATs with errors. @@ -5,7 +7,9 @@ * @description This function is currently rate limited to 1 request per 5 minutes. */ -import { logger, request, dateDiff } from "../../src/common/utils.js"; +import { request } from "../../src/common/http.js"; +import { logger, dateDiff } from "../../src/common/utils.js"; + export const RATE_LIMIT_SECONDS = 60 * 5; // 1 request per 5 minutes /** diff --git a/api/status/up.js b/api/status/up.js index 6ed7c37c04ea1..042da14055166 100644 --- a/api/status/up.js +++ b/api/status/up.js @@ -1,3 +1,5 @@ +// @ts-check + /** * @file Contains a simple cloud function that can be used to check if the PATs are still * functional. @@ -5,8 +7,9 @@ * @description This function is currently rate limited to 1 request per 5 minutes. */ +import { request } from "../../src/common/http.js"; import retryer from "../../src/common/retryer.js"; -import { logger, request } from "../../src/common/utils.js"; +import { logger } from "../../src/common/utils.js"; export const RATE_LIMIT_SECONDS = 60 * 5; // 1 request per 5 minutes diff --git a/src/common/http.js b/src/common/http.js new file mode 100644 index 0000000000000..0f3270fe7ac01 --- /dev/null +++ b/src/common/http.js @@ -0,0 +1,24 @@ +import axios from "axios"; + +/** + * @typedef {import('axios').AxiosRequestConfig['data']} AxiosRequestConfigData Axios request data. + * @typedef {import('axios').AxiosRequestConfig['headers']} AxiosRequestConfigHeaders Axios request headers. + */ + +/** + * Send GraphQL request to GitHub API. + * + * @param {AxiosRequestConfigData} data Request data. + * @param {AxiosRequestConfigHeaders} headers Request headers. + * @returns {Promise} Request response. + */ +const request = (data, headers) => { + return axios({ + url: "https://api.github.com/graphql", + method: "post", + headers, + data, + }); +}; + +export { request }; diff --git a/src/common/index.js b/src/common/index.js index 3a61fead40c02..22330a45fb389 100644 --- a/src/common/index.js +++ b/src/common/index.js @@ -13,7 +13,6 @@ export { parseBoolean, parseArray, clampValue, - request, flexLayout, logger, measureText, diff --git a/src/common/utils.js b/src/common/utils.js index 6ce2741cce3b2..39a859de95bdb 100644 --- a/src/common/utils.js +++ b/src/common/utils.js @@ -1,6 +1,5 @@ // @ts-check -import axios from "axios"; import toEmoji from "emoji-name-map"; import { SECONDARY_ERROR_MESSAGES, TRY_AGAIN_LATER } from "./error.js"; import { getCardColors } from "./color.js"; @@ -125,27 +124,6 @@ const clampValue = (number, min, max) => { return Math.max(min, Math.min(number, max)); }; -/** - * @typedef {import('axios').AxiosRequestConfig['data']} AxiosRequestConfigData Axios request data. - * @typedef {import('axios').AxiosRequestConfig['headers']} AxiosRequestConfigHeaders Axios request headers. - */ - -/** - * Send GraphQL request to GitHub API. - * - * @param {AxiosRequestConfigData} data Request data. - * @param {AxiosRequestConfigHeaders} headers Request headers. - * @returns {Promise} Request response. - */ -const request = (data, headers) => { - return axios({ - url: "https://api.github.com/graphql", - method: "post", - headers, - data, - }); -}; - // Script parameters. const ERROR_CARD_LENGTH = 576.5; @@ -350,7 +328,6 @@ export { parseBoolean, parseArray, clampValue, - request, flexLayout, logger, measureText, diff --git a/src/fetchers/gist.js b/src/fetchers/gist.js index ce96c2b111111..635892cf27692 100644 --- a/src/fetchers/gist.js +++ b/src/fetchers/gist.js @@ -1,8 +1,8 @@ // @ts-check -import { request } from "../common/utils.js"; import { retryer } from "../common/retryer.js"; import { MissingParamError } from "../common/error.js"; +import { request } from "../common/http.js"; /** * @typedef {import('axios').AxiosRequestHeaders} AxiosRequestHeaders Axios request headers. diff --git a/src/fetchers/repo.js b/src/fetchers/repo.js index 3cad9c00fd588..aa9bc7c197a06 100644 --- a/src/fetchers/repo.js +++ b/src/fetchers/repo.js @@ -1,8 +1,8 @@ // @ts-check import { MissingParamError } from "../common/error.js"; +import { request } from "../common/http.js"; import { retryer } from "../common/retryer.js"; -import { request } from "../common/utils.js"; /** * @typedef {import('axios').AxiosRequestHeaders} AxiosRequestHeaders Axios request headers. diff --git a/src/fetchers/stats.js b/src/fetchers/stats.js index 37ce591f51458..34e558deb3a19 100644 --- a/src/fetchers/stats.js +++ b/src/fetchers/stats.js @@ -5,10 +5,11 @@ import * as dotenv from "dotenv"; import githubUsernameRegex from "github-username-regex"; import { calculateRank } from "../calculateRank.js"; import { retryer } from "../common/retryer.js"; -import { logger, request } from "../common/utils.js"; +import { logger } from "../common/utils.js"; import { excludeRepositories } from "../common/envs.js"; import { CustomError, MissingParamError } from "../common/error.js"; import { wrapTextMultiline } from "../common/fmt.js"; +import { request } from "../common/http.js"; dotenv.config(); diff --git a/src/fetchers/top-languages.js b/src/fetchers/top-languages.js index 9e711b0d1157a..c0f353eb24755 100644 --- a/src/fetchers/top-languages.js +++ b/src/fetchers/top-languages.js @@ -1,10 +1,11 @@ // @ts-check import { retryer } from "../common/retryer.js"; -import { logger, request } from "../common/utils.js"; +import { logger } from "../common/utils.js"; import { excludeRepositories } from "../common/envs.js"; import { CustomError, MissingParamError } from "../common/error.js"; import { wrapTextMultiline } from "../common/fmt.js"; +import { request } from "../common/http.js"; /** * @typedef {import("axios").AxiosRequestHeaders} AxiosRequestHeaders Axios request headers. From bf021b06704c0764564ce5f4f0318847643161d3 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Wed, 15 Oct 2025 21:51:32 +0300 Subject: [PATCH 194/265] fix: resolve several vscode type errors inside fetchers code (#4579) Co-authored-by: Alexandr --- api/status/pat-info.js | 14 ++++------ api/status/up.js | 9 ++----- src/common/http.js | 9 ++----- src/common/retryer.js | 4 +-- src/fetchers/gist.js | 13 +++++---- src/fetchers/repo.js | 9 ++----- src/fetchers/stats.js | 50 +++++++++++++++++------------------ src/fetchers/top-languages.js | 10 +++---- 8 files changed, 47 insertions(+), 71 deletions(-) diff --git a/api/status/pat-info.js b/api/status/pat-info.js index 087abd48cb7d3..f6d917ce41957 100644 --- a/api/status/pat-info.js +++ b/api/status/pat-info.js @@ -12,17 +12,12 @@ import { logger, dateDiff } from "../../src/common/utils.js"; export const RATE_LIMIT_SECONDS = 60 * 5; // 1 request per 5 minutes -/** - * @typedef {import('axios').AxiosRequestHeaders} AxiosRequestHeaders Axios request headers. - * @typedef {import('axios').AxiosResponse} AxiosResponse Axios response. - */ - /** * Simple uptime check fetcher for the PATs. * - * @param {AxiosRequestHeaders} variables Fetcher variables. + * @param {any} variables Fetcher variables. * @param {string} token GitHub token. - * @returns {Promise} The response. + * @returns {Promise} The response. */ const uptimeFetcher = (variables, token) => { return request( @@ -47,7 +42,7 @@ const getAllPATs = () => { }; /** - * @typedef {(variables: AxiosRequestHeaders, token: string) => Promise} Fetcher The fetcher function. + * @typedef {(variables: any, token: string) => Promise} Fetcher The fetcher function. * @typedef {{validPATs: string[], expiredPATs: string[], exhaustedPATs: string[], suspendedPATs: string[], errorPATs: string[], details: any}} PATInfo The PAT info. */ @@ -55,10 +50,11 @@ const getAllPATs = () => { * Check whether any of the PATs is expired. * * @param {Fetcher} fetcher The fetcher function. - * @param {AxiosRequestHeaders} variables Fetcher variables. + * @param {any} variables Fetcher variables. * @returns {Promise} The response. */ const getPATInfo = async (fetcher, variables) => { + /** @type {Record} */ const details = {}; const PATs = getAllPATs(); diff --git a/api/status/up.js b/api/status/up.js index 042da14055166..35964388b9970 100644 --- a/api/status/up.js +++ b/api/status/up.js @@ -13,17 +13,12 @@ import { logger } from "../../src/common/utils.js"; export const RATE_LIMIT_SECONDS = 60 * 5; // 1 request per 5 minutes -/** - * @typedef {import('axios').AxiosRequestHeaders} AxiosRequestHeaders Axios request headers. - * @typedef {import('axios').AxiosResponse} AxiosResponse Axios response. - */ - /** * Simple uptime check fetcher for the PATs. * - * @param {AxiosRequestHeaders} variables Fetcher variables. + * @param {any} variables Fetcher variables. * @param {string} token GitHub token. - * @returns {Promise} The response. + * @returns {Promise} The response. */ const uptimeFetcher = (variables, token) => { return request( diff --git a/src/common/http.js b/src/common/http.js index 0f3270fe7ac01..388d105289906 100644 --- a/src/common/http.js +++ b/src/common/http.js @@ -1,15 +1,10 @@ import axios from "axios"; -/** - * @typedef {import('axios').AxiosRequestConfig['data']} AxiosRequestConfigData Axios request data. - * @typedef {import('axios').AxiosRequestConfig['headers']} AxiosRequestConfigHeaders Axios request headers. - */ - /** * Send GraphQL request to GitHub API. * - * @param {AxiosRequestConfigData} data Request data. - * @param {AxiosRequestConfigHeaders} headers Request headers. + * @param {import('axios').AxiosRequestConfig['data']} data Request data. + * @param {import('axios').AxiosRequestConfig['headers']} headers Request headers. * @returns {Promise} Request response. */ const request = (data, headers) => { diff --git a/src/common/retryer.js b/src/common/retryer.js index c65d6ededdfdf..569108b10e6cc 100644 --- a/src/common/retryer.js +++ b/src/common/retryer.js @@ -13,14 +13,14 @@ const RETRIES = process.env.NODE_ENV === "test" ? 7 : PATs; /** * @typedef {import("axios").AxiosResponse} AxiosResponse Axios response. - * @typedef {(variables: object, token: string, retriesForTests?: number) => Promise} FetcherFunction Fetcher function. + * @typedef {(variables: any, token: string, retriesForTests?: number) => Promise} FetcherFunction Fetcher function. */ /** * Try to execute the fetcher function until it succeeds or the max number of retries is reached. * * @param {FetcherFunction} fetcher The fetcher function. - * @param {object} variables Object with arguments to pass to the fetcher function. + * @param {any} variables Object with arguments to pass to the fetcher function. * @param {number} retries How many times to retry. * @returns {Promise} The response from the fetcher function. */ diff --git a/src/fetchers/gist.js b/src/fetchers/gist.js index 635892cf27692..d9cccc6761e99 100644 --- a/src/fetchers/gist.js +++ b/src/fetchers/gist.js @@ -4,11 +4,6 @@ import { retryer } from "../common/retryer.js"; import { MissingParamError } from "../common/error.js"; import { request } from "../common/http.js"; -/** - * @typedef {import('axios').AxiosRequestHeaders} AxiosRequestHeaders Axios request headers. - * @typedef {import('axios').AxiosResponse} AxiosResponse Axios response. - */ - const QUERY = ` query gistInfo($gistName: String!) { viewer { @@ -36,9 +31,9 @@ query gistInfo($gistName: String!) { /** * Gist data fetcher. * - * @param {AxiosRequestHeaders} variables Fetcher variables. + * @param {object} variables Fetcher variables. * @param {string} token GitHub token. - * @returns {Promise} The response. + * @returns {Promise} The response. */ const fetcher = async (variables, token) => { return await request( @@ -58,7 +53,9 @@ const fetcher = async (variables, token) => { * @returns {string} Primary language. */ const calculatePrimaryLanguage = (files) => { + /** @type {Record} */ const languages = {}; + for (const file of files) { if (file.language) { if (languages[file.language.name]) { @@ -68,12 +65,14 @@ const calculatePrimaryLanguage = (files) => { } } } + let primaryLanguage = Object.keys(languages)[0]; for (const language in languages) { if (languages[language] > languages[primaryLanguage]) { primaryLanguage = language; } } + return primaryLanguage; }; diff --git a/src/fetchers/repo.js b/src/fetchers/repo.js index aa9bc7c197a06..304aba5fdc23c 100644 --- a/src/fetchers/repo.js +++ b/src/fetchers/repo.js @@ -4,17 +4,12 @@ import { MissingParamError } from "../common/error.js"; import { request } from "../common/http.js"; import { retryer } from "../common/retryer.js"; -/** - * @typedef {import('axios').AxiosRequestHeaders} AxiosRequestHeaders Axios request headers. - * @typedef {import('axios').AxiosResponse} AxiosResponse Axios response. - */ - /** * Repo data fetcher. * - * @param {AxiosRequestHeaders} variables Fetcher variables. + * @param {object} variables Fetcher variables. * @param {string} token GitHub token. - * @returns {Promise} The response. + * @returns {Promise} The response. */ const fetcher = (variables, token) => { return request( diff --git a/src/fetchers/stats.js b/src/fetchers/stats.js index 34e558deb3a19..29b7b97507eb3 100644 --- a/src/fetchers/stats.js +++ b/src/fetchers/stats.js @@ -78,16 +78,12 @@ const GRAPHQL_STATS_QUERY = ` } `; -/** - * @typedef {import('axios').AxiosResponse} AxiosResponse Axios response. - */ - /** * Stats fetcher object. * - * @param {object} variables Fetcher variables. + * @param {object & { after: string | null }} variables Fetcher variables. * @param {string} token GitHub token. - * @returns {Promise} Axios response. + * @returns {Promise} Axios response. */ const fetcher = (variables, token) => { const query = variables.after ? GRAPHQL_REPOS_QUERY : GRAPHQL_STATS_QUERY; @@ -111,7 +107,7 @@ const fetcher = (variables, token) => { * @param {boolean} variables.includeDiscussions Include discussions. * @param {boolean} variables.includeDiscussionsAnswers Include discussions answers. * @param {string|undefined} variables.startTime Time to start the count of total commits. - * @returns {Promise} Axios response. + * @returns {Promise} Axios response. * * @description This function supports multi-page fetching if the 'FETCH_MULTI_PAGE_STARS' environment variable is set to true. */ @@ -162,6 +158,27 @@ const statsFetcher = async ({ return stats; }; +/** + * Fetch total commits using the REST API. + * + * @param {object} variables Fetcher variables. + * @param {string} token GitHub token. + * @returns {Promise} Axios response. + * + * @see https://developer.github.com/v3/search/#search-commits + */ +const fetchTotalCommits = (variables, token) => { + return axios({ + method: "get", + url: `https://api.github.com/search/commits?q=author:${variables.login}`, + headers: { + "Content-Type": "application/json", + Accept: "application/vnd.github.cloak-preview", + Authorization: `token ${token}`, + }, + }); +}; + /** * Fetch all the commits for all the repositories of a given username. * @@ -177,19 +194,6 @@ const totalCommitsFetcher = async (username) => { throw new Error("Invalid username provided."); } - // https://developer.github.com/v3/search/#search-commits - const fetchTotalCommits = (variables, token) => { - return axios({ - method: "get", - url: `https://api.github.com/search/commits?q=author:${variables.login}`, - headers: { - "Content-Type": "application/json", - Accept: "application/vnd.github.cloak-preview", - Authorization: `token ${token}`, - }, - }); - }; - let res; try { res = await retryer(fetchTotalCommits, { login: username }); @@ -208,10 +212,6 @@ const totalCommitsFetcher = async (username) => { return totalCount; }; -/** - * @typedef {import("./types").StatsData} StatsData Stats data. - */ - /** * Fetch stats for a given username. * @@ -222,7 +222,7 @@ const totalCommitsFetcher = async (username) => { * @param {boolean} include_discussions Include discussions. * @param {boolean} include_discussions_answers Include discussions answers. * @param {number|undefined} commits_year Year to count total commits - * @returns {Promise} Stats data. + * @returns {Promise} Stats data. */ const fetchStats = async ( username, diff --git a/src/fetchers/top-languages.js b/src/fetchers/top-languages.js index c0f353eb24755..601de295d82e8 100644 --- a/src/fetchers/top-languages.js +++ b/src/fetchers/top-languages.js @@ -7,17 +7,12 @@ import { CustomError, MissingParamError } from "../common/error.js"; import { wrapTextMultiline } from "../common/fmt.js"; import { request } from "../common/http.js"; -/** - * @typedef {import("axios").AxiosRequestHeaders} AxiosRequestHeaders Axios request headers. - * @typedef {import("axios").AxiosResponse} AxiosResponse Axios response. - */ - /** * Top languages fetcher object. * - * @param {AxiosRequestHeaders} variables Fetcher variables. + * @param {any} variables Fetcher variables. * @param {string} token GitHub token. - * @returns {Promise} Languages fetcher response. + * @returns {Promise} Languages fetcher response. */ const fetcher = (variables, token) => { return request( @@ -97,6 +92,7 @@ const fetchTopLanguages = async ( } let repoNodes = res.data.data.user.repositories.nodes; + /** @type {Record} */ let repoToHide = {}; const allExcludedRepos = [...exclude_repo, ...excludeRepositories]; From 6d1a5e51bcc7b2b9f57144cc370a884541fc7384 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Wed, 15 Oct 2025 23:03:48 +0300 Subject: [PATCH 195/265] refactor: move logger into separate module (#4581) * refactor: move logger into separate module * Update api/status/pat-info.js Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --------- Co-authored-by: Alexandr Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --- api/status/pat-info.js | 3 ++- api/status/up.js | 2 +- src/common/index.js | 1 - src/common/log.js | 14 ++++++++++++++ src/common/retryer.js | 2 +- src/common/utils.js | 6 ------ src/fetchers/stats.js | 2 +- src/fetchers/top-languages.js | 2 +- tests/retryer.test.js | 7 ++++++- 9 files changed, 26 insertions(+), 13 deletions(-) create mode 100644 src/common/log.js diff --git a/api/status/pat-info.js b/api/status/pat-info.js index f6d917ce41957..87cdc6e4356d7 100644 --- a/api/status/pat-info.js +++ b/api/status/pat-info.js @@ -8,7 +8,8 @@ */ import { request } from "../../src/common/http.js"; -import { logger, dateDiff } from "../../src/common/utils.js"; +import { logger } from "../../src/common/log.js"; +import { dateDiff } from "../../src/common/utils.js"; export const RATE_LIMIT_SECONDS = 60 * 5; // 1 request per 5 minutes diff --git a/api/status/up.js b/api/status/up.js index 35964388b9970..4af4530acaff6 100644 --- a/api/status/up.js +++ b/api/status/up.js @@ -9,7 +9,7 @@ import { request } from "../../src/common/http.js"; import retryer from "../../src/common/retryer.js"; -import { logger } from "../../src/common/utils.js"; +import { logger } from "../../src/common/log.js"; export const RATE_LIMIT_SECONDS = 60 * 5; // 1 request per 5 minutes diff --git a/src/common/index.js b/src/common/index.js index 22330a45fb389..84638a6fb7bdc 100644 --- a/src/common/index.js +++ b/src/common/index.js @@ -14,7 +14,6 @@ export { parseArray, clampValue, flexLayout, - logger, measureText, lowercaseTrim, chunkArray, diff --git a/src/common/log.js b/src/common/log.js new file mode 100644 index 0000000000000..8a0e58b6bc566 --- /dev/null +++ b/src/common/log.js @@ -0,0 +1,14 @@ +// @ts-check + +const noop = () => {}; + +/** + * Return console instance based on the environment. + * + * @type {Console | {log: () => void, error: () => void}} + */ +const logger = + process.env.NODE_ENV === "test" ? { log: noop, error: noop } : console; + +export { logger }; +export default logger; diff --git a/src/common/retryer.js b/src/common/retryer.js index 569108b10e6cc..b3ea70644e005 100644 --- a/src/common/retryer.js +++ b/src/common/retryer.js @@ -1,7 +1,7 @@ // @ts-check import { CustomError } from "./error.js"; -import { logger } from "./utils.js"; +import { logger } from "./log.js"; // Script variables. diff --git a/src/common/utils.js b/src/common/utils.js index 39a859de95bdb..28e6774a7bc1f 100644 --- a/src/common/utils.js +++ b/src/common/utils.js @@ -211,11 +211,6 @@ const renderError = ({ `; }; -const noop = () => {}; -// return console instance based on the environment -const logger = - process.env.NODE_ENV === "test" ? { log: noop, error: noop } : console; - /** * Retrieve text length. * @@ -329,7 +324,6 @@ export { parseArray, clampValue, flexLayout, - logger, measureText, lowercaseTrim, chunkArray, diff --git a/src/fetchers/stats.js b/src/fetchers/stats.js index 29b7b97507eb3..376a15816144e 100644 --- a/src/fetchers/stats.js +++ b/src/fetchers/stats.js @@ -5,7 +5,7 @@ import * as dotenv from "dotenv"; import githubUsernameRegex from "github-username-regex"; import { calculateRank } from "../calculateRank.js"; import { retryer } from "../common/retryer.js"; -import { logger } from "../common/utils.js"; +import { logger } from "../common/log.js"; import { excludeRepositories } from "../common/envs.js"; import { CustomError, MissingParamError } from "../common/error.js"; import { wrapTextMultiline } from "../common/fmt.js"; diff --git a/src/fetchers/top-languages.js b/src/fetchers/top-languages.js index 601de295d82e8..91e3618f97716 100644 --- a/src/fetchers/top-languages.js +++ b/src/fetchers/top-languages.js @@ -1,7 +1,7 @@ // @ts-check import { retryer } from "../common/retryer.js"; -import { logger } from "../common/utils.js"; +import { logger } from "../common/log.js"; import { excludeRepositories } from "../common/envs.js"; import { CustomError, MissingParamError } from "../common/error.js"; import { wrapTextMultiline } from "../common/fmt.js"; diff --git a/tests/retryer.test.js b/tests/retryer.test.js index 36ea8d353920a..6f2bc2edebfbe 100644 --- a/tests/retryer.test.js +++ b/tests/retryer.test.js @@ -1,7 +1,9 @@ +// @ts-check + import { describe, expect, it, jest } from "@jest/globals"; import "@testing-library/jest-dom"; import { RETRIES, retryer } from "../src/common/retryer.js"; -import { logger } from "../src/common/utils.js"; +import { logger } from "../src/common/log.js"; const fetcher = jest.fn((variables, token) => { logger.log(variables, token); @@ -17,6 +19,7 @@ const fetcherFail = jest.fn(() => { const fetcherFailOnSecondTry = jest.fn((_vars, _token, retries) => { return new Promise((res) => { // faking rate limit + // @ts-ignore if (retries < 1) { return res({ data: { errors: [{ type: "RATE_LIMITED" }] } }); } @@ -28,6 +31,7 @@ const fetcherFailWithMessageBasedRateLimitErr = jest.fn( (_vars, _token, retries) => { return new Promise((res) => { // faking rate limit + // @ts-ignore if (retries < 1) { return res({ data: { @@ -72,6 +76,7 @@ describe("Test Retryer", () => { await retryer(fetcherFail, {}); } catch (err) { expect(fetcherFail).toHaveBeenCalledTimes(RETRIES + 1); + // @ts-ignore expect(err.message).toBe("Downtime due to GitHub API rate limiting"); } }); From e158f0d27ff2b39704f1d5ea7cfff34bde336d14 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Wed, 15 Oct 2025 23:29:53 +0300 Subject: [PATCH 196/265] refactor: move operations into separate module (#4582) Co-authored-by: Alexandr --- api/gist.js | 3 +- api/index.js | 3 +- api/pin.js | 3 +- api/status/pat-info.js | 2 +- api/top-langs.js | 3 +- api/wakatime.js | 3 +- src/cards/gist.js | 2 +- src/cards/repo.js | 3 +- src/cards/stats.js | 3 +- src/cards/top-languages.js | 9 +-- src/cards/wakatime.js | 3 +- src/common/cache.js | 2 +- src/common/createProgressNode.js | 2 +- src/common/index.js | 6 -- src/common/ops.js | 124 +++++++++++++++++++++++++++++++ src/common/utils.js | 119 ----------------------------- tests/utils.test.js | 3 +- 17 files changed, 147 insertions(+), 146 deletions(-) create mode 100644 src/common/ops.js diff --git a/api/gist.js b/api/gist.js index 88f2f7b23a565..7edbd676a989e 100644 --- a/api/gist.js +++ b/api/gist.js @@ -1,6 +1,6 @@ // @ts-check -import { renderError, parseBoolean } from "../src/common/utils.js"; +import { renderError } from "../src/common/utils.js"; import { isLocaleAvailable } from "../src/translations.js"; import { renderGistCard } from "../src/cards/gist.js"; import { fetchGist } from "../src/fetchers/gist.js"; @@ -15,6 +15,7 @@ import { MissingParamError, retrieveSecondaryMessage, } from "../src/common/error.js"; +import { parseBoolean } from "../src/common/ops.js"; // @ts-ignore export default async (req, res) => { diff --git a/api/index.js b/api/index.js index f353d4c719f82..d6d6514e6f58b 100644 --- a/api/index.js +++ b/api/index.js @@ -12,7 +12,8 @@ import { MissingParamError, retrieveSecondaryMessage, } from "../src/common/error.js"; -import { parseArray, parseBoolean, renderError } from "../src/common/utils.js"; +import { parseArray, parseBoolean } from "../src/common/ops.js"; +import { renderError } from "../src/common/utils.js"; import { fetchStats } from "../src/fetchers/stats.js"; import { isLocaleAvailable } from "../src/translations.js"; diff --git a/api/pin.js b/api/pin.js index 62b06a882da73..ccadb8034f885 100644 --- a/api/pin.js +++ b/api/pin.js @@ -12,7 +12,8 @@ import { MissingParamError, retrieveSecondaryMessage, } from "../src/common/error.js"; -import { parseBoolean, renderError } from "../src/common/utils.js"; +import { parseBoolean } from "../src/common/ops.js"; +import { renderError } from "../src/common/utils.js"; import { fetchRepo } from "../src/fetchers/repo.js"; import { isLocaleAvailable } from "../src/translations.js"; diff --git a/api/status/pat-info.js b/api/status/pat-info.js index 87cdc6e4356d7..db3a8cc5b4112 100644 --- a/api/status/pat-info.js +++ b/api/status/pat-info.js @@ -9,7 +9,7 @@ import { request } from "../../src/common/http.js"; import { logger } from "../../src/common/log.js"; -import { dateDiff } from "../../src/common/utils.js"; +import { dateDiff } from "../../src/common/ops.js"; export const RATE_LIMIT_SECONDS = 60 * 5; // 1 request per 5 minutes diff --git a/api/top-langs.js b/api/top-langs.js index c00fde6b1bf35..a273391877743 100644 --- a/api/top-langs.js +++ b/api/top-langs.js @@ -12,7 +12,8 @@ import { MissingParamError, retrieveSecondaryMessage, } from "../src/common/error.js"; -import { parseArray, parseBoolean, renderError } from "../src/common/utils.js"; +import { parseArray, parseBoolean } from "../src/common/ops.js"; +import { renderError } from "../src/common/utils.js"; import { fetchTopLanguages } from "../src/fetchers/top-languages.js"; import { isLocaleAvailable } from "../src/translations.js"; diff --git a/api/wakatime.js b/api/wakatime.js index af6c4af066d7f..f88eeebfd19f1 100644 --- a/api/wakatime.js +++ b/api/wakatime.js @@ -1,7 +1,7 @@ // @ts-check import { renderWakatimeCard } from "../src/cards/wakatime.js"; -import { parseArray, parseBoolean, renderError } from "../src/common/utils.js"; +import { renderError } from "../src/common/utils.js"; import { fetchWakatimeStats } from "../src/fetchers/wakatime.js"; import { isLocaleAvailable } from "../src/translations.js"; import { @@ -15,6 +15,7 @@ import { MissingParamError, retrieveSecondaryMessage, } from "../src/common/error.js"; +import { parseArray, parseBoolean } from "../src/common/ops.js"; // @ts-ignore export default async (req, res) => { diff --git a/src/cards/gist.js b/src/cards/gist.js index 2deaf448dcce8..2db6782ff6eac 100644 --- a/src/cards/gist.js +++ b/src/cards/gist.js @@ -1,7 +1,6 @@ // @ts-check import { - parseEmojis, encodeHTML, measureText, flexLayout, @@ -12,6 +11,7 @@ import Card from "../common/Card.js"; import { getCardColors } from "../common/color.js"; import { kFormatter, wrapTextMultiline } from "../common/fmt.js"; import { icons } from "../common/icons.js"; +import { parseEmojis } from "../common/ops.js"; /** Import language colors. * diff --git a/src/cards/repo.js b/src/cards/repo.js index ccf42645e898c..fbc232315c0a3 100644 --- a/src/cards/repo.js +++ b/src/cards/repo.js @@ -5,14 +5,13 @@ import { getCardColors } from "../common/color.js"; import { kFormatter, wrapTextMultiline } from "../common/fmt.js"; import { I18n } from "../common/I18n.js"; import { icons } from "../common/icons.js"; +import { clampValue, parseEmojis } from "../common/ops.js"; import { encodeHTML, flexLayout, measureText, - parseEmojis, iconWithLabel, createLanguageNode, - clampValue, } from "../common/utils.js"; import { repoCardLocales } from "../translations.js"; diff --git a/src/cards/stats.js b/src/cards/stats.js index 9e6725b0bc7cd..3120afb55e7a3 100644 --- a/src/cards/stats.js +++ b/src/cards/stats.js @@ -6,7 +6,8 @@ import { CustomError } from "../common/error.js"; import { kFormatter } from "../common/fmt.js"; import { I18n } from "../common/I18n.js"; import { icons, rankIcon } from "../common/icons.js"; -import { clampValue, flexLayout, measureText } from "../common/utils.js"; +import { clampValue } from "../common/ops.js"; +import { flexLayout, measureText } from "../common/utils.js"; import { statCardLocales, wakatimeCardLocales } from "../translations.js"; const CARD_MIN_WIDTH = 287; diff --git a/src/cards/top-languages.js b/src/cards/top-languages.js index ec91fcc996390..7d4ac97709814 100644 --- a/src/cards/top-languages.js +++ b/src/cards/top-languages.js @@ -5,13 +5,8 @@ import { getCardColors } from "../common/color.js"; import { createProgressNode } from "../common/createProgressNode.js"; import { formatBytes } from "../common/fmt.js"; import { I18n } from "../common/I18n.js"; -import { - chunkArray, - clampValue, - flexLayout, - lowercaseTrim, - measureText, -} from "../common/utils.js"; +import { chunkArray, clampValue, lowercaseTrim } from "../common/ops.js"; +import { flexLayout, measureText } from "../common/utils.js"; import { langCardLocales } from "../translations.js"; const DEFAULT_CARD_WIDTH = 300; diff --git a/src/cards/wakatime.js b/src/cards/wakatime.js index b1accd4536887..687750e1a3bfe 100644 --- a/src/cards/wakatime.js +++ b/src/cards/wakatime.js @@ -4,7 +4,8 @@ import { Card } from "../common/Card.js"; import { getCardColors } from "../common/color.js"; import { createProgressNode } from "../common/createProgressNode.js"; import { I18n } from "../common/I18n.js"; -import { clampValue, flexLayout, lowercaseTrim } from "../common/utils.js"; +import { clampValue, lowercaseTrim } from "../common/ops.js"; +import { flexLayout } from "../common/utils.js"; import { wakatimeCardLocales } from "../translations.js"; /** Import language colors. diff --git a/src/common/cache.js b/src/common/cache.js index 596aa5e3db87f..dc6217e28fd2a 100644 --- a/src/common/cache.js +++ b/src/common/cache.js @@ -1,6 +1,6 @@ // @ts-check -import { clampValue } from "./utils.js"; +import { clampValue } from "./ops.js"; const MIN = 60; const HOUR = 60 * MIN; diff --git a/src/common/createProgressNode.js b/src/common/createProgressNode.js index 22a7ad65006e2..e63944e7b1813 100644 --- a/src/common/createProgressNode.js +++ b/src/common/createProgressNode.js @@ -1,6 +1,6 @@ // @ts-check -import { clampValue } from "./utils.js"; +import { clampValue } from "./ops.js"; /** * Create a node to indicate progress in percentage along a horizontal line. diff --git a/src/common/index.js b/src/common/index.js index 84638a6fb7bdc..12fe563b52218 100644 --- a/src/common/index.js +++ b/src/common/index.js @@ -10,12 +10,6 @@ export { ERROR_CARD_LENGTH, renderError, encodeHTML, - parseBoolean, - parseArray, - clampValue, flexLayout, measureText, - lowercaseTrim, - chunkArray, - parseEmojis, } from "./utils.js"; diff --git a/src/common/ops.js b/src/common/ops.js new file mode 100644 index 0000000000000..b4db6e60c8a92 --- /dev/null +++ b/src/common/ops.js @@ -0,0 +1,124 @@ +// @ts-check + +import toEmoji from "emoji-name-map"; + +/** + * Returns boolean if value is either "true" or "false" else the value as it is. + * + * @param {string | boolean} value The value to parse. + * @returns {boolean | undefined } The parsed value. + */ +const parseBoolean = (value) => { + if (typeof value === "boolean") { + return value; + } + + if (typeof value === "string") { + if (value.toLowerCase() === "true") { + return true; + } else if (value.toLowerCase() === "false") { + return false; + } + } + return undefined; +}; + +/** + * Parse string to array of strings. + * + * @param {string} str The string to parse. + * @returns {string[]} The array of strings. + */ +const parseArray = (str) => { + if (!str) { + return []; + } + return str.split(","); +}; + +/** + * Clamp the given number between the given range. + * + * @param {number} number The number to clamp. + * @param {number} min The minimum value. + * @param {number} max The maximum value. + * @returns {number} The clamped number. + */ +const clampValue = (number, min, max) => { + // @ts-ignore + if (Number.isNaN(parseInt(number, 10))) { + return min; + } + return Math.max(min, Math.min(number, max)); +}; + +/** + * Lowercase and trim string. + * + * @param {string} name String to lowercase and trim. + * @returns {string} Lowercased and trimmed string. + */ +const lowercaseTrim = (name) => name.toLowerCase().trim(); + +/** + * Split array of languages in two columns. + * + * @template T Language object. + * @param {Array} arr Array of languages. + * @param {number} perChunk Number of languages per column. + * @returns {Array} Array of languages split in two columns. + */ +const chunkArray = (arr, perChunk) => { + return arr.reduce((resultArray, item, index) => { + const chunkIndex = Math.floor(index / perChunk); + + if (!resultArray[chunkIndex]) { + // @ts-ignore + resultArray[chunkIndex] = []; // start a new chunk + } + + // @ts-ignore + resultArray[chunkIndex].push(item); + + return resultArray; + }, []); +}; + +/** + * Parse emoji from string. + * + * @param {string} str String to parse emoji from. + * @returns {string} String with emoji parsed. + */ +const parseEmojis = (str) => { + if (!str) { + throw new Error("[parseEmoji]: str argument not provided"); + } + return str.replace(/:\w+:/gm, (emoji) => { + return toEmoji.get(emoji) || ""; + }); +}; + +/** + * Get diff in minutes between two dates. + * + * @param {Date} d1 First date. + * @param {Date} d2 Second date. + * @returns {number} Number of minutes between the two dates. + */ +const dateDiff = (d1, d2) => { + const date1 = new Date(d1); + const date2 = new Date(d2); + const diff = date1.getTime() - date2.getTime(); + return Math.round(diff / (1000 * 60)); +}; + +export { + parseBoolean, + parseArray, + clampValue, + lowercaseTrim, + chunkArray, + parseEmojis, + dateDiff, +}; diff --git a/src/common/utils.js b/src/common/utils.js index 28e6774a7bc1f..dd3d2402c8de7 100644 --- a/src/common/utils.js +++ b/src/common/utils.js @@ -1,6 +1,5 @@ // @ts-check -import toEmoji from "emoji-name-map"; import { SECONDARY_ERROR_MESSAGES, TRY_AGAIN_LATER } from "./error.js"; import { getCardColors } from "./color.js"; @@ -74,56 +73,6 @@ const iconWithLabel = (icon, label, testid, iconSize) => { return flexLayout({ items: [iconSvg, text], gap: 20 }).join(""); }; -/** - * Returns boolean if value is either "true" or "false" else the value as it is. - * - * @param {string | boolean} value The value to parse. - * @returns {boolean | undefined } The parsed value. - */ -const parseBoolean = (value) => { - if (typeof value === "boolean") { - return value; - } - - if (typeof value === "string") { - if (value.toLowerCase() === "true") { - return true; - } else if (value.toLowerCase() === "false") { - return false; - } - } - return undefined; -}; - -/** - * Parse string to array of strings. - * - * @param {string} str The string to parse. - * @returns {string[]} The array of strings. - */ -const parseArray = (str) => { - if (!str) { - return []; - } - return str.split(","); -}; - -/** - * Clamp the given number between the given range. - * - * @param {number} number The number to clamp. - * @param {number} min The minimum value. - * @param {number} max The maximum value. - * @returns {number} The clamped number. - */ -const clampValue = (number, min, max) => { - // @ts-ignore - if (Number.isNaN(parseInt(number, 10))) { - return min; - } - return Math.max(min, Math.min(number, max)); -}; - // Script parameters. const ERROR_CARD_LENGTH = 576.5; @@ -253,80 +202,12 @@ const measureText = (str, fontSize = 10) => { ); }; -/** - * Lowercase and trim string. - * - * @param {string} name String to lowercase and trim. - * @returns {string} Lowercased and trimmed string. - */ -const lowercaseTrim = (name) => name.toLowerCase().trim(); - -/** - * Split array of languages in two columns. - * - * @template T Language object. - * @param {Array} arr Array of languages. - * @param {number} perChunk Number of languages per column. - * @returns {Array} Array of languages split in two columns. - */ -const chunkArray = (arr, perChunk) => { - return arr.reduce((resultArray, item, index) => { - const chunkIndex = Math.floor(index / perChunk); - - if (!resultArray[chunkIndex]) { - // @ts-ignore - resultArray[chunkIndex] = []; // start a new chunk - } - - // @ts-ignore - resultArray[chunkIndex].push(item); - - return resultArray; - }, []); -}; - -/** - * Parse emoji from string. - * - * @param {string} str String to parse emoji from. - * @returns {string} String with emoji parsed. - */ -const parseEmojis = (str) => { - if (!str) { - throw new Error("[parseEmoji]: str argument not provided"); - } - return str.replace(/:\w+:/gm, (emoji) => { - return toEmoji.get(emoji) || ""; - }); -}; - -/** - * Get diff in minutes between two dates. - * - * @param {Date} d1 First date. - * @param {Date} d2 Second date. - * @returns {number} Number of minutes between the two dates. - */ -const dateDiff = (d1, d2) => { - const date1 = new Date(d1); - const date2 = new Date(d2); - const diff = date1.getTime() - date2.getTime(); - return Math.round(diff / (1000 * 60)); -}; - export { ERROR_CARD_LENGTH, renderError, createLanguageNode, iconWithLabel, encodeHTML, - parseBoolean, - parseArray, - clampValue, flexLayout, measureText, - lowercaseTrim, - chunkArray, - parseEmojis, - dateDiff, }; diff --git a/tests/utils.test.js b/tests/utils.test.js index 0b37e45acbd07..a079841c459c2 100644 --- a/tests/utils.test.js +++ b/tests/utils.test.js @@ -3,7 +3,8 @@ import { describe, expect, it } from "@jest/globals"; import { queryByTestId } from "@testing-library/dom"; import "@testing-library/jest-dom"; -import { encodeHTML, parseBoolean, renderError } from "../src/common/utils.js"; +import { encodeHTML, renderError } from "../src/common/utils.js"; +import { parseBoolean } from "../src/common/ops.js"; describe("Test utils.js", () => { it("should test parseBoolean", () => { From dff0cfec58faf717ed0e18f00a6de21bcebc9d2d Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Wed, 15 Oct 2025 23:36:50 +0300 Subject: [PATCH 197/265] fix: mark Finnish locale as long for stats card (#4583) Co-authored-by: Alexandr --- src/cards/stats.js | 1 + 1 file changed, 1 insertion(+) diff --git a/src/cards/stats.js b/src/cards/stats.js index 3120afb55e7a3..3c81d4b1f3a20 100644 --- a/src/cards/stats.js +++ b/src/cards/stats.js @@ -29,6 +29,7 @@ const LONG_LOCALES = [ "de", "es", "fil", + "fi", "fr", "id", "ml", From a97ab2dc7a1a6ea90585e5559ada46d28015982f Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Thu, 16 Oct 2025 20:18:28 +0300 Subject: [PATCH 198/265] fix: resolve vscode type errors inside utils tests (#4585) Co-authored-by: Alexandr --- tests/utils.test.js | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/tests/utils.test.js b/tests/utils.test.js index a079841c459c2..a97bb4f929bf5 100644 --- a/tests/utils.test.js +++ b/tests/utils.test.js @@ -2,7 +2,7 @@ import { describe, expect, it } from "@jest/globals"; import { queryByTestId } from "@testing-library/dom"; -import "@testing-library/jest-dom"; +import "@testing-library/jest-dom/jest-globals"; import { encodeHTML, renderError } from "../src/common/utils.js"; import { parseBoolean } from "../src/common/ops.js"; @@ -34,11 +34,11 @@ describe("Test utils.js", () => { it("should test renderError", () => { document.body.innerHTML = renderError({ message: "Something went wrong" }); expect( - queryByTestId(document.body, "message").children[0], + queryByTestId(document.body, "message")?.children[0], ).toHaveTextContent(/Something went wrong/gim); expect( - queryByTestId(document.body, "message").children[1], - ).toBeEmptyDOMElement(2); + queryByTestId(document.body, "message")?.children[1], + ).toBeEmptyDOMElement(); // Secondary message document.body.innerHTML = renderError({ @@ -46,7 +46,7 @@ describe("Test utils.js", () => { secondaryMessage: "Secondary Message", }); expect( - queryByTestId(document.body, "message").children[1], + queryByTestId(document.body, "message")?.children[1], ).toHaveTextContent(/Secondary Message/gim); }); }); From 93e48939d587f6198dd615d157f6d09d18758e8b Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Thu, 16 Oct 2025 20:25:50 +0300 Subject: [PATCH 199/265] refactor: move operations tests into separate module (#4586) Co-authored-by: Alexandr --- tests/ops.test.js | 22 ++++++++++++++++++++++ tests/utils.test.js | 19 ------------------- 2 files changed, 22 insertions(+), 19 deletions(-) create mode 100644 tests/ops.test.js diff --git a/tests/ops.test.js b/tests/ops.test.js new file mode 100644 index 0000000000000..5d8644a113c1f --- /dev/null +++ b/tests/ops.test.js @@ -0,0 +1,22 @@ +import { describe, expect, it } from "@jest/globals"; +import { parseBoolean } from "../src/common/ops.js"; + +describe("Test ops.js", () => { + it("should test parseBoolean", () => { + expect(parseBoolean(true)).toBe(true); + expect(parseBoolean(false)).toBe(false); + + expect(parseBoolean("true")).toBe(true); + expect(parseBoolean("false")).toBe(false); + expect(parseBoolean("True")).toBe(true); + expect(parseBoolean("False")).toBe(false); + expect(parseBoolean("TRUE")).toBe(true); + expect(parseBoolean("FALSE")).toBe(false); + + expect(parseBoolean("1")).toBe(undefined); + expect(parseBoolean("0")).toBe(undefined); + expect(parseBoolean("")).toBe(undefined); + // @ts-ignore + expect(parseBoolean(undefined)).toBe(undefined); + }); +}); diff --git a/tests/utils.test.js b/tests/utils.test.js index a97bb4f929bf5..7e8d3705d17a0 100644 --- a/tests/utils.test.js +++ b/tests/utils.test.js @@ -4,27 +4,8 @@ import { describe, expect, it } from "@jest/globals"; import { queryByTestId } from "@testing-library/dom"; import "@testing-library/jest-dom/jest-globals"; import { encodeHTML, renderError } from "../src/common/utils.js"; -import { parseBoolean } from "../src/common/ops.js"; describe("Test utils.js", () => { - it("should test parseBoolean", () => { - expect(parseBoolean(true)).toBe(true); - expect(parseBoolean(false)).toBe(false); - - expect(parseBoolean("true")).toBe(true); - expect(parseBoolean("false")).toBe(false); - expect(parseBoolean("True")).toBe(true); - expect(parseBoolean("False")).toBe(false); - expect(parseBoolean("TRUE")).toBe(true); - expect(parseBoolean("FALSE")).toBe(false); - - expect(parseBoolean("1")).toBe(undefined); - expect(parseBoolean("0")).toBe(undefined); - expect(parseBoolean("")).toBe(undefined); - // @ts-ignore - expect(parseBoolean(undefined)).toBe(undefined); - }); - it("should test encodeHTML", () => { expect(encodeHTML(`hello world<,.#4^&^@%!))`)).toBe( "<html>hello world<,.#4^&^@%!))", From 516472f17a10748872c429abec3cd8a0a0da23cd Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Thu, 16 Oct 2025 23:08:43 +0300 Subject: [PATCH 200/265] tests: implement more test cases for operations (#4587) Co-authored-by: Alexandr --- tests/ops.test.js | 69 ++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 68 insertions(+), 1 deletion(-) diff --git a/tests/ops.test.js b/tests/ops.test.js index 5d8644a113c1f..dd4e08b88c3bc 100644 --- a/tests/ops.test.js +++ b/tests/ops.test.js @@ -1,5 +1,13 @@ import { describe, expect, it } from "@jest/globals"; -import { parseBoolean } from "../src/common/ops.js"; +import { + parseBoolean, + parseArray, + clampValue, + lowercaseTrim, + chunkArray, + parseEmojis, + dateDiff, +} from "../src/common/ops.js"; describe("Test ops.js", () => { it("should test parseBoolean", () => { @@ -19,4 +27,63 @@ describe("Test ops.js", () => { // @ts-ignore expect(parseBoolean(undefined)).toBe(undefined); }); + + it("should test parseArray", () => { + expect(parseArray("a,b,c")).toEqual(["a", "b", "c"]); + expect(parseArray("a, b, c")).toEqual(["a", " b", " c"]); // preserves spaces + expect(parseArray("")).toEqual([]); + // @ts-ignore + expect(parseArray(undefined)).toEqual([]); + }); + + it("should test clampValue", () => { + expect(clampValue(5, 1, 10)).toBe(5); + expect(clampValue(0, 1, 10)).toBe(1); + expect(clampValue(15, 1, 10)).toBe(10); + + // string inputs are coerced numerically by Math.min/Math.max + // @ts-ignore + expect(clampValue("7", 1, 10)).toBe(7); + + // non-numeric and NaN fall back to min + // @ts-ignore + expect(clampValue("abc", 1, 10)).toBe(1); + expect(clampValue(NaN, 2, 5)).toBe(2); + }); + + it("should test lowercaseTrim", () => { + expect(lowercaseTrim(" Hello World ")).toBe("hello world"); + expect(lowercaseTrim("already lower")).toBe("already lower"); + }); + + it("should test chunkArray", () => { + expect(chunkArray([1, 2, 3, 4, 5], 2)).toEqual([[1, 2], [3, 4], [5]]); + expect(chunkArray([1, 2, 3, 4, 5], 1)).toEqual([[1], [2], [3], [4], [5]]); + expect(chunkArray([1, 2, 3, 4, 5], 10)).toEqual([[1, 2, 3, 4, 5]]); + }); + + it("should test parseEmojis", () => { + // unknown emoji name is stripped + expect(parseEmojis("Hello :nonexistent:")).toBe("Hello "); + // common emoji names should be replaced (at least token removed) + const out = parseEmojis("I :heart: OSS"); + expect(out).not.toContain(":heart:"); + expect(out.startsWith("I ")).toBe(true); + expect(out.endsWith(" OSS")).toBe(true); + + expect(() => parseEmojis("")).toThrow(/parseEmoji/); + // @ts-ignore + expect(() => parseEmojis()).toThrow(/parseEmoji/); + }); + + it("should test dateDiff", () => { + const a = new Date("2020-01-01T00:10:00Z"); + const b = new Date("2020-01-01T00:00:00Z"); + expect(dateDiff(a, b)).toBe(10); + + const c = new Date("2020-01-01T00:00:00Z"); + const d = new Date("2020-01-01T00:10:30Z"); + // rounds to nearest minute + expect(dateDiff(c, d)).toBe(-10); + }); }); From 33f6276b0bfecbd6816d7b676ee88a0f45a25219 Mon Sep 17 00:00:00 2001 From: Sudhanshu Shukla <165203681+Sudhanshu-shukl@users.noreply.github.com> Date: Fri, 17 Oct 2025 01:59:50 +0530 Subject: [PATCH 201/265] docs(readme): making main title bigger to improve appearance (#4580) * Updated Readme.md made the readme header slightly better, doesn't make a huge difference but i think it looks great * review * review * review --------- Co-authored-by: Alexandr --- readme.md | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/readme.md b/readme.md index e0f9597e3a9fe..e7faba9885405 100644 --- a/readme.md +++ b/readme.md @@ -1,8 +1,8 @@ -

- GitHub Readme Stats -

GitHub Readme Stats

-

Get dynamically generated GitHub stats on your READMEs!

-

+
+ GitHub Readme Stats +

GitHub Readme Stats

+

Get dynamically generated GitHub stats on your READMEs!

+

From c43fd65bdd7bbb5e60ca8ccd480c488536516905 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Thu, 16 Oct 2025 23:44:17 +0300 Subject: [PATCH 202/265] refactor: move svg rendering related code into separate module (#4588) Co-authored-by: Alexandr --- api/gist.js | 2 +- api/index.js | 2 +- api/pin.js | 2 +- api/top-langs.js | 2 +- api/wakatime.js | 2 +- src/cards/gist.js | 2 +- src/cards/repo.js | 2 +- src/cards/stats.js | 2 +- src/cards/top-languages.js | 2 +- src/cards/wakatime.js | 2 +- src/common/Card.js | 2 +- src/common/access.js | 2 +- src/common/fmt.js | 2 +- src/common/index.js | 2 +- src/common/{utils.js => render.js} | 0 src/translations.js | 2 +- tests/api.test.js | 2 +- tests/flexLayout.test.js | 2 +- tests/gist.test.js | 2 +- tests/pin.test.js | 2 +- tests/{utils.test.js => render.test.js} | 4 ++-- tests/top-langs.test.js | 2 +- 22 files changed, 22 insertions(+), 22 deletions(-) rename src/common/{utils.js => render.js} (100%) rename tests/{utils.test.js => render.test.js} (90%) diff --git a/api/gist.js b/api/gist.js index 7edbd676a989e..049018a4fffd0 100644 --- a/api/gist.js +++ b/api/gist.js @@ -1,6 +1,6 @@ // @ts-check -import { renderError } from "../src/common/utils.js"; +import { renderError } from "../src/common/render.js"; import { isLocaleAvailable } from "../src/translations.js"; import { renderGistCard } from "../src/cards/gist.js"; import { fetchGist } from "../src/fetchers/gist.js"; diff --git a/api/index.js b/api/index.js index d6d6514e6f58b..6ea4ffe0c20e7 100644 --- a/api/index.js +++ b/api/index.js @@ -13,7 +13,7 @@ import { retrieveSecondaryMessage, } from "../src/common/error.js"; import { parseArray, parseBoolean } from "../src/common/ops.js"; -import { renderError } from "../src/common/utils.js"; +import { renderError } from "../src/common/render.js"; import { fetchStats } from "../src/fetchers/stats.js"; import { isLocaleAvailable } from "../src/translations.js"; diff --git a/api/pin.js b/api/pin.js index ccadb8034f885..ada955169910a 100644 --- a/api/pin.js +++ b/api/pin.js @@ -13,7 +13,7 @@ import { retrieveSecondaryMessage, } from "../src/common/error.js"; import { parseBoolean } from "../src/common/ops.js"; -import { renderError } from "../src/common/utils.js"; +import { renderError } from "../src/common/render.js"; import { fetchRepo } from "../src/fetchers/repo.js"; import { isLocaleAvailable } from "../src/translations.js"; diff --git a/api/top-langs.js b/api/top-langs.js index a273391877743..a2e352e718ee2 100644 --- a/api/top-langs.js +++ b/api/top-langs.js @@ -13,7 +13,7 @@ import { retrieveSecondaryMessage, } from "../src/common/error.js"; import { parseArray, parseBoolean } from "../src/common/ops.js"; -import { renderError } from "../src/common/utils.js"; +import { renderError } from "../src/common/render.js"; import { fetchTopLanguages } from "../src/fetchers/top-languages.js"; import { isLocaleAvailable } from "../src/translations.js"; diff --git a/api/wakatime.js b/api/wakatime.js index f88eeebfd19f1..002f9de072715 100644 --- a/api/wakatime.js +++ b/api/wakatime.js @@ -1,7 +1,7 @@ // @ts-check import { renderWakatimeCard } from "../src/cards/wakatime.js"; -import { renderError } from "../src/common/utils.js"; +import { renderError } from "../src/common/render.js"; import { fetchWakatimeStats } from "../src/fetchers/wakatime.js"; import { isLocaleAvailable } from "../src/translations.js"; import { diff --git a/src/cards/gist.js b/src/cards/gist.js index 2db6782ff6eac..220f530808f31 100644 --- a/src/cards/gist.js +++ b/src/cards/gist.js @@ -6,7 +6,7 @@ import { flexLayout, iconWithLabel, createLanguageNode, -} from "../common/utils.js"; +} from "../common/render.js"; import Card from "../common/Card.js"; import { getCardColors } from "../common/color.js"; import { kFormatter, wrapTextMultiline } from "../common/fmt.js"; diff --git a/src/cards/repo.js b/src/cards/repo.js index fbc232315c0a3..50556c72418ea 100644 --- a/src/cards/repo.js +++ b/src/cards/repo.js @@ -12,7 +12,7 @@ import { measureText, iconWithLabel, createLanguageNode, -} from "../common/utils.js"; +} from "../common/render.js"; import { repoCardLocales } from "../translations.js"; const ICON_SIZE = 16; diff --git a/src/cards/stats.js b/src/cards/stats.js index 3c81d4b1f3a20..5e7bf71714b3a 100644 --- a/src/cards/stats.js +++ b/src/cards/stats.js @@ -7,7 +7,7 @@ import { kFormatter } from "../common/fmt.js"; import { I18n } from "../common/I18n.js"; import { icons, rankIcon } from "../common/icons.js"; import { clampValue } from "../common/ops.js"; -import { flexLayout, measureText } from "../common/utils.js"; +import { flexLayout, measureText } from "../common/render.js"; import { statCardLocales, wakatimeCardLocales } from "../translations.js"; const CARD_MIN_WIDTH = 287; diff --git a/src/cards/top-languages.js b/src/cards/top-languages.js index 7d4ac97709814..4493835f369f8 100644 --- a/src/cards/top-languages.js +++ b/src/cards/top-languages.js @@ -6,7 +6,7 @@ import { createProgressNode } from "../common/createProgressNode.js"; import { formatBytes } from "../common/fmt.js"; import { I18n } from "../common/I18n.js"; import { chunkArray, clampValue, lowercaseTrim } from "../common/ops.js"; -import { flexLayout, measureText } from "../common/utils.js"; +import { flexLayout, measureText } from "../common/render.js"; import { langCardLocales } from "../translations.js"; const DEFAULT_CARD_WIDTH = 300; diff --git a/src/cards/wakatime.js b/src/cards/wakatime.js index 687750e1a3bfe..811fb243035db 100644 --- a/src/cards/wakatime.js +++ b/src/cards/wakatime.js @@ -5,7 +5,7 @@ import { getCardColors } from "../common/color.js"; import { createProgressNode } from "../common/createProgressNode.js"; import { I18n } from "../common/I18n.js"; import { clampValue, lowercaseTrim } from "../common/ops.js"; -import { flexLayout } from "../common/utils.js"; +import { flexLayout } from "../common/render.js"; import { wakatimeCardLocales } from "../translations.js"; /** Import language colors. diff --git a/src/common/Card.js b/src/common/Card.js index d32da56255f89..2c2c2e19ff76f 100644 --- a/src/common/Card.js +++ b/src/common/Card.js @@ -1,4 +1,4 @@ -import { encodeHTML, flexLayout } from "./utils.js"; +import { encodeHTML, flexLayout } from "./render.js"; class Card { /** diff --git a/src/common/access.js b/src/common/access.js index 5b15dc5db652b..891518329454b 100644 --- a/src/common/access.js +++ b/src/common/access.js @@ -1,6 +1,6 @@ // @ts-check -import { renderError } from "./utils.js"; +import { renderError } from "./render.js"; import { blacklist } from "./blacklist.js"; import { whitelist, gistWhitelist } from "./envs.js"; diff --git a/src/common/fmt.js b/src/common/fmt.js index ca86f3cf59cae..a292d002021aa 100644 --- a/src/common/fmt.js +++ b/src/common/fmt.js @@ -1,7 +1,7 @@ // @ts-check import wrap from "word-wrap"; -import { encodeHTML } from "./utils.js"; +import { encodeHTML } from "./render.js"; /** * Retrieves num with suffix k(thousands) precise to given decimal places. diff --git a/src/common/index.js b/src/common/index.js index 12fe563b52218..e87f04a6e46bf 100644 --- a/src/common/index.js +++ b/src/common/index.js @@ -12,4 +12,4 @@ export { encodeHTML, flexLayout, measureText, -} from "./utils.js"; +} from "./render.js"; diff --git a/src/common/utils.js b/src/common/render.js similarity index 100% rename from src/common/utils.js rename to src/common/render.js diff --git a/src/translations.js b/src/translations.js index a5d522cd53d39..d86abc46104bf 100644 --- a/src/translations.js +++ b/src/translations.js @@ -1,6 +1,6 @@ // @ts-check -import { encodeHTML } from "./common/utils.js"; +import { encodeHTML } from "./common/render.js"; /** * Retrieves stat card labels in the available locales. diff --git a/tests/api.test.js b/tests/api.test.js index 967bfae64b500..a9cc12afc149c 100644 --- a/tests/api.test.js +++ b/tests/api.test.js @@ -13,7 +13,7 @@ import MockAdapter from "axios-mock-adapter"; import api from "../api/index.js"; import { calculateRank } from "../src/calculateRank.js"; import { renderStatsCard } from "../src/cards/stats.js"; -import { renderError } from "../src/common/utils.js"; +import { renderError } from "../src/common/render.js"; import { CACHE_TTL, DURATIONS } from "../src/common/cache.js"; /** diff --git a/tests/flexLayout.test.js b/tests/flexLayout.test.js index a2bb580d8a440..740d9daaba8a5 100644 --- a/tests/flexLayout.test.js +++ b/tests/flexLayout.test.js @@ -1,5 +1,5 @@ import { describe, expect, it } from "@jest/globals"; -import { flexLayout } from "../src/common/utils.js"; +import { flexLayout } from "../src/common/render.js"; describe("flexLayout", () => { it("should work with row & col layouts", () => { diff --git a/tests/gist.test.js b/tests/gist.test.js index 186edbdb305f7..15d86b0517ce1 100644 --- a/tests/gist.test.js +++ b/tests/gist.test.js @@ -6,7 +6,7 @@ import axios from "axios"; import MockAdapter from "axios-mock-adapter"; import gist from "../api/gist.js"; import { renderGistCard } from "../src/cards/gist.js"; -import { renderError } from "../src/common/utils.js"; +import { renderError } from "../src/common/render.js"; import { CACHE_TTL, DURATIONS } from "../src/common/cache.js"; const gist_data = { diff --git a/tests/pin.test.js b/tests/pin.test.js index 126bb2aa7469f..6bc8bff96c0da 100644 --- a/tests/pin.test.js +++ b/tests/pin.test.js @@ -6,7 +6,7 @@ import axios from "axios"; import MockAdapter from "axios-mock-adapter"; import pin from "../api/pin.js"; import { renderRepoCard } from "../src/cards/repo.js"; -import { renderError } from "../src/common/utils.js"; +import { renderError } from "../src/common/render.js"; import { CACHE_TTL, DURATIONS } from "../src/common/cache.js"; const data_repo = { diff --git a/tests/utils.test.js b/tests/render.test.js similarity index 90% rename from tests/utils.test.js rename to tests/render.test.js index 7e8d3705d17a0..026bc9fc8d962 100644 --- a/tests/utils.test.js +++ b/tests/render.test.js @@ -3,9 +3,9 @@ import { describe, expect, it } from "@jest/globals"; import { queryByTestId } from "@testing-library/dom"; import "@testing-library/jest-dom/jest-globals"; -import { encodeHTML, renderError } from "../src/common/utils.js"; +import { encodeHTML, renderError } from "../src/common/render.js"; -describe("Test utils.js", () => { +describe("Test render.js", () => { it("should test encodeHTML", () => { expect(encodeHTML(`hello world<,.#4^&^@%!))`)).toBe( "<html>hello world<,.#4^&^@%!))", diff --git a/tests/top-langs.test.js b/tests/top-langs.test.js index fb065fb7719a3..9ba35a78157d5 100644 --- a/tests/top-langs.test.js +++ b/tests/top-langs.test.js @@ -6,7 +6,7 @@ import axios from "axios"; import MockAdapter from "axios-mock-adapter"; import topLangs from "../api/top-langs.js"; import { renderTopLanguages } from "../src/cards/top-languages.js"; -import { renderError } from "../src/common/utils.js"; +import { renderError } from "../src/common/render.js"; import { CACHE_TTL, DURATIONS } from "../src/common/cache.js"; const data_langs = { From 62c43e9f3ab9457b92e7c67ff3bd510223ae2e2e Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Thu, 16 Oct 2025 23:52:58 +0300 Subject: [PATCH 203/265] fix: mark Greek as long locale for stats card (#4589) Co-authored-by: Alexandr --- src/cards/stats.js | 1 + 1 file changed, 1 insertion(+) diff --git a/src/cards/stats.js b/src/cards/stats.js index 5e7bf71714b3a..06aa86d63a1dd 100644 --- a/src/cards/stats.js +++ b/src/cards/stats.js @@ -27,6 +27,7 @@ const LONG_LOCALES = [ "bg", "cs", "de", + "el", "es", "fil", "fi", From 432595e9d7621db8833b449cc34e89832c5b1048 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 17 Oct 2025 19:51:45 +0300 Subject: [PATCH 204/265] ci(deps): bump stefanzweifel/git-auto-commit-action from 6.0.1 to 7.0.0 (#4567) Bumps [stefanzweifel/git-auto-commit-action](https://github.com/stefanzweifel/git-auto-commit-action) from 6.0.1 to 7.0.0. - [Release notes](https://github.com/stefanzweifel/git-auto-commit-action/releases) - [Changelog](https://github.com/stefanzweifel/git-auto-commit-action/blob/master/CHANGELOG.md) - [Commits](https://github.com/stefanzweifel/git-auto-commit-action/compare/778341af668090896ca464160c2def5d1d1a3eb0...28e16e81777b558cc906c8750092100bbb34c5e3) --- updated-dependencies: - dependency-name: stefanzweifel/git-auto-commit-action dependency-version: 7.0.0 dependency-type: direct:production update-type: version-update:semver-major ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- .github/workflows/deploy-prep.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/deploy-prep.yml b/.github/workflows/deploy-prep.yml index 6081ce9a04f71..7b85bac6d9955 100644 --- a/.github/workflows/deploy-prep.yml +++ b/.github/workflows/deploy-prep.yml @@ -13,7 +13,7 @@ jobs: - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 - name: Deployment Prep run: python ./.github/workflows/deploy-prep.py - - uses: stefanzweifel/git-auto-commit-action@778341af668090896ca464160c2def5d1d1a3eb0 # v6.0.1 + - uses: stefanzweifel/git-auto-commit-action@28e16e81777b558cc906c8750092100bbb34c5e3 # v7.0.0 with: branch: vercel create_branch: true From 351da081cf6b9acee88f26c1968c299204094a6b Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 17 Oct 2025 19:53:55 +0300 Subject: [PATCH 205/265] build(deps-dev): bump lint-staged from 16.2.3 to 16.2.4 (#4565) Bumps [lint-staged](https://github.com/lint-staged/lint-staged) from 16.2.3 to 16.2.4. - [Release notes](https://github.com/lint-staged/lint-staged/releases) - [Changelog](https://github.com/lint-staged/lint-staged/blob/main/CHANGELOG.md) - [Commits](https://github.com/lint-staged/lint-staged/compare/v16.2.3...v16.2.4) --- updated-dependencies: - dependency-name: lint-staged dependency-version: 16.2.4 dependency-type: direct:development update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- package-lock.json | 30 +++++++++++++++--------------- package.json | 2 +- 2 files changed, 16 insertions(+), 16 deletions(-) diff --git a/package-lock.json b/package-lock.json index 8d78c098988a5..9a4ca94212710 100644 --- a/package-lock.json +++ b/package-lock.json @@ -35,7 +35,7 @@ "jest": "^30.2.0", "jest-environment-jsdom": "^30.2.0", "js-yaml": "^4.1.0", - "lint-staged": "^16.2.3", + "lint-staged": "^16.2.4", "lodash.snakecase": "^4.1.1", "parse-diff": "^0.11.1", "prettier": "^3.6.2" @@ -5580,15 +5580,15 @@ "dev": true }, "node_modules/lint-staged": { - "version": "16.2.3", - "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-16.2.3.tgz", - "integrity": "sha512-1OnJEESB9zZqsp61XHH2fvpS1es3hRCxMplF/AJUDa8Ho8VrscYDIuxGrj3m8KPXbcWZ8fT9XTMUhEQmOVKpKw==", + "version": "16.2.4", + "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-16.2.4.tgz", + "integrity": "sha512-Pkyr/wd90oAyXk98i/2KwfkIhoYQUMtss769FIT9hFM5ogYZwrk+GRE46yKXSg2ZGhcJ1p38Gf5gmI5Ohjg2yg==", "dev": true, "dependencies": { "commander": "^14.0.1", "listr2": "^9.0.4", "micromatch": "^4.0.8", - "nano-spawn": "^1.0.3", + "nano-spawn": "^2.0.0", "pidtree": "^0.6.0", "string-argv": "^0.3.2", "yaml": "^2.8.1" @@ -5963,9 +5963,9 @@ "dev": true }, "node_modules/nano-spawn": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/nano-spawn/-/nano-spawn-1.0.3.tgz", - "integrity": "sha512-jtpsQDetTnvS2Ts1fiRdci5rx0VYws5jGyC+4IYOTnIQ/wwdf6JdomlHBwqC3bJYOvaKu0C2GSZ1A60anrYpaA==", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/nano-spawn/-/nano-spawn-2.0.0.tgz", + "integrity": "sha512-tacvGzUY5o2D8CBh2rrwxyNojUsZNU2zjNTzKQrkgGJQTbGAfArVWXSKMBokBeeg6C7OLRGUEyoFlYbfeWQIqw==", "dev": true, "engines": { "node": ">=20.17" @@ -11813,15 +11813,15 @@ "dev": true }, "lint-staged": { - "version": "16.2.3", - "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-16.2.3.tgz", - "integrity": "sha512-1OnJEESB9zZqsp61XHH2fvpS1es3hRCxMplF/AJUDa8Ho8VrscYDIuxGrj3m8KPXbcWZ8fT9XTMUhEQmOVKpKw==", + "version": "16.2.4", + "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-16.2.4.tgz", + "integrity": "sha512-Pkyr/wd90oAyXk98i/2KwfkIhoYQUMtss769FIT9hFM5ogYZwrk+GRE46yKXSg2ZGhcJ1p38Gf5gmI5Ohjg2yg==", "dev": true, "requires": { "commander": "^14.0.1", "listr2": "^9.0.4", "micromatch": "^4.0.8", - "nano-spawn": "^1.0.3", + "nano-spawn": "^2.0.0", "pidtree": "^0.6.0", "string-argv": "^0.3.2", "yaml": "^2.8.1" @@ -12083,9 +12083,9 @@ "dev": true }, "nano-spawn": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/nano-spawn/-/nano-spawn-1.0.3.tgz", - "integrity": "sha512-jtpsQDetTnvS2Ts1fiRdci5rx0VYws5jGyC+4IYOTnIQ/wwdf6JdomlHBwqC3bJYOvaKu0C2GSZ1A60anrYpaA==", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/nano-spawn/-/nano-spawn-2.0.0.tgz", + "integrity": "sha512-tacvGzUY5o2D8CBh2rrwxyNojUsZNU2zjNTzKQrkgGJQTbGAfArVWXSKMBokBeeg6C7OLRGUEyoFlYbfeWQIqw==", "dev": true }, "napi-postinstall": { diff --git a/package.json b/package.json index 83d22f5b8d06a..c20ffb100908c 100644 --- a/package.json +++ b/package.json @@ -55,7 +55,7 @@ "jest": "^30.2.0", "jest-environment-jsdom": "^30.2.0", "js-yaml": "^4.1.0", - "lint-staged": "^16.2.3", + "lint-staged": "^16.2.4", "lodash.snakecase": "^4.1.1", "parse-diff": "^0.11.1", "prettier": "^3.6.2" From af1d8cad6f74ae8449d96647b440f5c8cc2d621a Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 17 Oct 2025 19:56:10 +0300 Subject: [PATCH 206/265] build(deps-dev): bump eslint-plugin-jsdoc from 60.8.2 to 61.1.2 (#4566) Bumps [eslint-plugin-jsdoc](https://github.com/gajus/eslint-plugin-jsdoc) from 60.8.2 to 61.1.2. - [Release notes](https://github.com/gajus/eslint-plugin-jsdoc/releases) - [Changelog](https://github.com/gajus/eslint-plugin-jsdoc/blob/main/.releaserc) - [Commits](https://github.com/gajus/eslint-plugin-jsdoc/compare/v60.8.2...v61.1.2) --- updated-dependencies: - dependency-name: eslint-plugin-jsdoc dependency-version: 61.1.2 dependency-type: direct:development update-type: version-update:semver-major ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr --- package-lock.json | 79 +++++++++++++++++++++++------------------------ package.json | 2 +- 2 files changed, 40 insertions(+), 41 deletions(-) diff --git a/package-lock.json b/package-lock.json index 9a4ca94212710..c0525ff1e6021 100644 --- a/package-lock.json +++ b/package-lock.json @@ -27,7 +27,7 @@ "color-contrast-checker": "^2.1.0", "eslint": "^9.37.0", "eslint-config-prettier": "^10.1.8", - "eslint-plugin-jsdoc": "^60.8.2", + "eslint-plugin-jsdoc": "^61.1.2", "express": "^5.1.0", "globals": "^16.4.0", "hjson": "^3.2.2", @@ -744,16 +744,16 @@ } }, "node_modules/@es-joy/jsdoccomment": { - "version": "0.69.0", - "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.69.0.tgz", - "integrity": "sha512-7UgbKSStPxf2RF2fqKqJq3u1QN4kFzhE/lofHtEuptRjQPdYZOLGsqGcKzQGYWoPG5p8PyxUOoc3/Ca+UcFkdA==", + "version": "0.76.0", + "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.76.0.tgz", + "integrity": "sha512-g+RihtzFgGTx2WYCuTHbdOXJeAlGnROws0TeALx9ow/ZmOROOZkVg5wp/B44n0WJgI4SQFP1eWM2iRPlU2Y14w==", "dev": true, "dependencies": { "@types/estree": "^1.0.8", - "@typescript-eslint/types": "^8.45.0", + "@typescript-eslint/types": "^8.46.0", "comment-parser": "1.4.1", "esquery": "^1.6.0", - "jsdoc-type-pratt-parser": "6.4.0" + "jsdoc-type-pratt-parser": "~6.10.0" }, "engines": { "node": ">=20.11.0" @@ -1869,9 +1869,9 @@ "dev": true }, "node_modules/@typescript-eslint/types": { - "version": "8.46.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.46.0.tgz", - "integrity": "sha512-bHGGJyVjSE4dJJIO5yyEWt/cHyNwga/zXGJbJJ8TiO01aVREK6gCTu3L+5wrkb1FbDkQ+TKjMNe9R/QQQP9+rA==", + "version": "8.46.1", + "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.46.1.tgz", + "integrity": "sha512-C+soprGBHwWBdkDpbaRC4paGBrkIXxVlNohadL5o0kfhsXqOC6GYH2S/Obmig+I0HTDl8wMaRySwrfrXVP8/pQ==", "dev": true, "engines": { "node": "^18.18.0 || ^20.9.0 || >=21.1.0" @@ -3296,12 +3296,12 @@ } }, "node_modules/eslint-plugin-jsdoc": { - "version": "60.8.2", - "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-60.8.2.tgz", - "integrity": "sha512-ebEYZiAVL/ejjNQKO7Q1+FumDjGfs0T3+arQ3U54xomFiySUjKnZOzVZQAWhu+mlZXB4oeoizI4wRH+3i+knDg==", + "version": "61.1.2", + "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-61.1.2.tgz", + "integrity": "sha512-gbb4VVKRsMJZ+YqJXte6RQ/pDTIQcMauyQb03n5GTfWG+gAb6T3FaOLeoSHAIrBT90ykLkxzRh3z95DoIrUk3A==", "dev": true, "dependencies": { - "@es-joy/jsdoccomment": "~0.69.0", + "@es-joy/jsdoccomment": "~0.76.0", "are-docs-informative": "^0.0.2", "comment-parser": "1.4.1", "debug": "^4.4.3", @@ -3311,7 +3311,7 @@ "html-entities": "^2.6.0", "object-deep-merge": "^1.0.5", "parse-imports-exports": "^0.2.4", - "semver": "^7.7.2", + "semver": "^7.7.3", "spdx-expression-parse": "^4.0.0" }, "engines": { @@ -3334,11 +3334,10 @@ } }, "node_modules/eslint-plugin-jsdoc/node_modules/semver": { - "version": "7.7.2", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.7.2.tgz", - "integrity": "sha512-RF0Fw+rO5AMf9MAyaRXI4AV0Ulj5lMHqVxxdSgiVbixSCXoEmmX/jk0CuJw4+3SqroYO9VoUh+HcuJivvtJemA==", + "version": "7.7.3", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.7.3.tgz", + "integrity": "sha512-SdsKMrI9TdgjdweUSR9MweHA4EJ8YxHn8DFaDisvhVlUOe4BF1tLD7GAj0lIqWVl+dPb/rExr0Btby5loQm20Q==", "dev": true, - "license": "ISC", "bin": { "semver": "bin/semver.js" }, @@ -5447,9 +5446,9 @@ } }, "node_modules/jsdoc-type-pratt-parser": { - "version": "6.4.0", - "resolved": "https://registry.npmjs.org/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-6.4.0.tgz", - "integrity": "sha512-tVwTg612vD9h2w5hoRFRNOni7xITDYZigHwBDieLUf4IYPQtk6IFXe/NqJc/hGYteFAeIM+Ld6ZvmLuizKAZ7A==", + "version": "6.10.0", + "resolved": "https://registry.npmjs.org/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-6.10.0.tgz", + "integrity": "sha512-+LexoTRyYui5iOhJGn13N9ZazL23nAHGkXsa1p/C8yeq79WRfLBag6ZZ0FQG2aRoc9yfo59JT9EYCQonOkHKkQ==", "dev": true, "engines": { "node": ">=20.0.0" @@ -8303,16 +8302,16 @@ } }, "@es-joy/jsdoccomment": { - "version": "0.69.0", - "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.69.0.tgz", - "integrity": "sha512-7UgbKSStPxf2RF2fqKqJq3u1QN4kFzhE/lofHtEuptRjQPdYZOLGsqGcKzQGYWoPG5p8PyxUOoc3/Ca+UcFkdA==", + "version": "0.76.0", + "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.76.0.tgz", + "integrity": "sha512-g+RihtzFgGTx2WYCuTHbdOXJeAlGnROws0TeALx9ow/ZmOROOZkVg5wp/B44n0WJgI4SQFP1eWM2iRPlU2Y14w==", "dev": true, "requires": { "@types/estree": "^1.0.8", - "@typescript-eslint/types": "^8.45.0", + "@typescript-eslint/types": "^8.46.0", "comment-parser": "1.4.1", "esquery": "^1.6.0", - "jsdoc-type-pratt-parser": "6.4.0" + "jsdoc-type-pratt-parser": "~6.10.0" } }, "@eslint-community/eslint-utils": { @@ -9195,9 +9194,9 @@ "dev": true }, "@typescript-eslint/types": { - "version": "8.46.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.46.0.tgz", - "integrity": "sha512-bHGGJyVjSE4dJJIO5yyEWt/cHyNwga/zXGJbJJ8TiO01aVREK6gCTu3L+5wrkb1FbDkQ+TKjMNe9R/QQQP9+rA==", + "version": "8.46.1", + "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.46.1.tgz", + "integrity": "sha512-C+soprGBHwWBdkDpbaRC4paGBrkIXxVlNohadL5o0kfhsXqOC6GYH2S/Obmig+I0HTDl8wMaRySwrfrXVP8/pQ==", "dev": true }, "@ungap/structured-clone": { @@ -10225,12 +10224,12 @@ "requires": {} }, "eslint-plugin-jsdoc": { - "version": "60.8.2", - "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-60.8.2.tgz", - "integrity": "sha512-ebEYZiAVL/ejjNQKO7Q1+FumDjGfs0T3+arQ3U54xomFiySUjKnZOzVZQAWhu+mlZXB4oeoizI4wRH+3i+knDg==", + "version": "61.1.2", + "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-61.1.2.tgz", + "integrity": "sha512-gbb4VVKRsMJZ+YqJXte6RQ/pDTIQcMauyQb03n5GTfWG+gAb6T3FaOLeoSHAIrBT90ykLkxzRh3z95DoIrUk3A==", "dev": true, "requires": { - "@es-joy/jsdoccomment": "~0.69.0", + "@es-joy/jsdoccomment": "~0.76.0", "are-docs-informative": "^0.0.2", "comment-parser": "1.4.1", "debug": "^4.4.3", @@ -10240,7 +10239,7 @@ "html-entities": "^2.6.0", "object-deep-merge": "^1.0.5", "parse-imports-exports": "^0.2.4", - "semver": "^7.7.2", + "semver": "^7.7.3", "spdx-expression-parse": "^4.0.0" }, "dependencies": { @@ -10251,9 +10250,9 @@ "dev": true }, "semver": { - "version": "7.7.2", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.7.2.tgz", - "integrity": "sha512-RF0Fw+rO5AMf9MAyaRXI4AV0Ulj5lMHqVxxdSgiVbixSCXoEmmX/jk0CuJw4+3SqroYO9VoUh+HcuJivvtJemA==", + "version": "7.7.3", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.7.3.tgz", + "integrity": "sha512-SdsKMrI9TdgjdweUSR9MweHA4EJ8YxHn8DFaDisvhVlUOe4BF1tLD7GAj0lIqWVl+dPb/rExr0Btby5loQm20Q==", "dev": true } } @@ -11712,9 +11711,9 @@ } }, "jsdoc-type-pratt-parser": { - "version": "6.4.0", - "resolved": "https://registry.npmjs.org/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-6.4.0.tgz", - "integrity": "sha512-tVwTg612vD9h2w5hoRFRNOni7xITDYZigHwBDieLUf4IYPQtk6IFXe/NqJc/hGYteFAeIM+Ld6ZvmLuizKAZ7A==", + "version": "6.10.0", + "resolved": "https://registry.npmjs.org/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-6.10.0.tgz", + "integrity": "sha512-+LexoTRyYui5iOhJGn13N9ZazL23nAHGkXsa1p/C8yeq79WRfLBag6ZZ0FQG2aRoc9yfo59JT9EYCQonOkHKkQ==", "dev": true }, "jsdom": { diff --git a/package.json b/package.json index c20ffb100908c..382c661968c7e 100644 --- a/package.json +++ b/package.json @@ -47,7 +47,7 @@ "color-contrast-checker": "^2.1.0", "eslint": "^9.37.0", "eslint-config-prettier": "^10.1.8", - "eslint-plugin-jsdoc": "^60.8.2", + "eslint-plugin-jsdoc": "^61.1.2", "express": "^5.1.0", "globals": "^16.4.0", "hjson": "^3.2.2", From b240a06e7bbd2a861b45a51d9ad95d1563a147c0 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Fri, 17 Oct 2025 21:26:37 +0300 Subject: [PATCH 207/265] refactor: move encode HTML function into separate module (#4591) Co-authored-by: Alexandr --- src/cards/gist.js | 2 +- src/cards/repo.js | 2 +- src/common/Card.js | 5 ++++- src/common/fmt.js | 2 +- src/common/html.js | 19 +++++++++++++++++++ src/common/index.js | 1 - src/common/render.js | 18 +----------------- src/translations.js | 2 +- tests/render.test.js | 3 ++- 9 files changed, 30 insertions(+), 24 deletions(-) create mode 100644 src/common/html.js diff --git a/src/cards/gist.js b/src/cards/gist.js index 220f530808f31..62910420ad2f5 100644 --- a/src/cards/gist.js +++ b/src/cards/gist.js @@ -1,7 +1,6 @@ // @ts-check import { - encodeHTML, measureText, flexLayout, iconWithLabel, @@ -10,6 +9,7 @@ import { import Card from "../common/Card.js"; import { getCardColors } from "../common/color.js"; import { kFormatter, wrapTextMultiline } from "../common/fmt.js"; +import { encodeHTML } from "../common/html.js"; import { icons } from "../common/icons.js"; import { parseEmojis } from "../common/ops.js"; diff --git a/src/cards/repo.js b/src/cards/repo.js index 50556c72418ea..a9c2afc38a222 100644 --- a/src/cards/repo.js +++ b/src/cards/repo.js @@ -3,11 +3,11 @@ import { Card } from "../common/Card.js"; import { getCardColors } from "../common/color.js"; import { kFormatter, wrapTextMultiline } from "../common/fmt.js"; +import { encodeHTML } from "../common/html.js"; import { I18n } from "../common/I18n.js"; import { icons } from "../common/icons.js"; import { clampValue, parseEmojis } from "../common/ops.js"; import { - encodeHTML, flexLayout, measureText, iconWithLabel, diff --git a/src/common/Card.js b/src/common/Card.js index 2c2c2e19ff76f..3e7a80e8cd0d4 100644 --- a/src/common/Card.js +++ b/src/common/Card.js @@ -1,4 +1,7 @@ -import { encodeHTML, flexLayout } from "./render.js"; +// @ts-check + +import { encodeHTML } from "./html.js"; +import { flexLayout } from "./render.js"; class Card { /** diff --git a/src/common/fmt.js b/src/common/fmt.js index a292d002021aa..5820b53e3f078 100644 --- a/src/common/fmt.js +++ b/src/common/fmt.js @@ -1,7 +1,7 @@ // @ts-check import wrap from "word-wrap"; -import { encodeHTML } from "./render.js"; +import { encodeHTML } from "./html.js"; /** * Retrieves num with suffix k(thousands) precise to given decimal places. diff --git a/src/common/html.js b/src/common/html.js new file mode 100644 index 0000000000000..2b1db470f5373 --- /dev/null +++ b/src/common/html.js @@ -0,0 +1,19 @@ +// @ts-check + +/** + * Encode string as HTML. + * + * @see https://stackoverflow.com/a/48073476/10629172 + * + * @param {string} str String to encode. + * @returns {string} Encoded string. + */ +const encodeHTML = (str) => { + return str + .replace(/[\u00A0-\u9999<>&](?!#)/gim, (i) => { + return "&#" + i.charCodeAt(0) + ";"; + }) + .replace(/\u0008/gim, ""); +}; + +export { encodeHTML }; diff --git a/src/common/index.js b/src/common/index.js index e87f04a6e46bf..ccedfa9a8bf00 100644 --- a/src/common/index.js +++ b/src/common/index.js @@ -9,7 +9,6 @@ export { retryer } from "./retryer.js"; export { ERROR_CARD_LENGTH, renderError, - encodeHTML, flexLayout, measureText, } from "./render.js"; diff --git a/src/common/render.js b/src/common/render.js index dd3d2402c8de7..32ecc8eb69dd2 100644 --- a/src/common/render.js +++ b/src/common/render.js @@ -2,6 +2,7 @@ import { SECONDARY_ERROR_MESSAGES, TRY_AGAIN_LATER } from "./error.js"; import { getCardColors } from "./color.js"; +import { encodeHTML } from "./html.js"; /** * Auto layout utility, allows us to layout things vertically or horizontally with @@ -76,22 +77,6 @@ const iconWithLabel = (icon, label, testid, iconSize) => { // Script parameters. const ERROR_CARD_LENGTH = 576.5; -/** - * Encode string as HTML. - * - * @see https://stackoverflow.com/a/48073476/10629172 - * - * @param {string} str String to encode. - * @returns {string} Encoded string. - */ -const encodeHTML = (str) => { - return str - .replace(/[\u00A0-\u9999<>&](?!#)/gim, (i) => { - return "&#" + i.charCodeAt(0) + ";"; - }) - .replace(/\u0008/gim, ""); -}; - const UPSTREAM_API_ERRORS = [ TRY_AGAIN_LATER, SECONDARY_ERROR_MESSAGES.MAX_RETRY, @@ -207,7 +192,6 @@ export { renderError, createLanguageNode, iconWithLabel, - encodeHTML, flexLayout, measureText, }; diff --git a/src/translations.js b/src/translations.js index d86abc46104bf..ad069cc407813 100644 --- a/src/translations.js +++ b/src/translations.js @@ -1,6 +1,6 @@ // @ts-check -import { encodeHTML } from "./common/render.js"; +import { encodeHTML } from "./common/html.js"; /** * Retrieves stat card labels in the available locales. diff --git a/tests/render.test.js b/tests/render.test.js index 026bc9fc8d962..935b7335a9288 100644 --- a/tests/render.test.js +++ b/tests/render.test.js @@ -3,7 +3,8 @@ import { describe, expect, it } from "@jest/globals"; import { queryByTestId } from "@testing-library/dom"; import "@testing-library/jest-dom/jest-globals"; -import { encodeHTML, renderError } from "../src/common/render.js"; +import { renderError } from "../src/common/render.js"; +import { encodeHTML } from "../src/common/html.js"; describe("Test render.js", () => { it("should test encodeHTML", () => { From a72d88fd540ee1175aae750669541a1913eb8432 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Fri, 17 Oct 2025 21:45:43 +0300 Subject: [PATCH 208/265] fix: resolve vscode type errors inside card class (#4592) Co-authored-by: Alexandr --- src/common/Card.js | 27 +++++++++++++-------------- 1 file changed, 13 insertions(+), 14 deletions(-) diff --git a/src/common/Card.js b/src/common/Card.js index 3e7a80e8cd0d4..45bc81fe11460 100644 --- a/src/common/Card.js +++ b/src/common/Card.js @@ -8,19 +8,18 @@ class Card { * Creates a new card instance. * * @param {object} args Card arguments. - * @param {number?=} args.width Card width. - * @param {number?=} args.height Card height. - * @param {number?=} args.border_radius Card border radius. - * @param {string?=} args.customTitle Card custom title. - * @param {string?=} args.defaultTitle Card default title. - * @param {string?=} args.titlePrefixIcon Card title prefix icon. - * @param {object?=} args.colors Card colors arguments. - * @param {string} args.colors.titleColor Card title color. - * @param {string} args.colors.textColor Card text color. - * @param {string} args.colors.iconColor Card icon color. - * @param {string|Array} args.colors.bgColor Card background color. - * @param {string} args.colors.borderColor Card border color. - * @returns {Card} Card instance. + * @param {number=} args.width Card width. + * @param {number=} args.height Card height. + * @param {number=} args.border_radius Card border radius. + * @param {string=} args.customTitle Card custom title. + * @param {string=} args.defaultTitle Card default title. + * @param {string=} args.titlePrefixIcon Card title prefix icon. + * @param {object} [args.colors={}] Card colors arguments. + * @param {string=} args.colors.titleColor Card title color. + * @param {string=} args.colors.textColor Card text color. + * @param {string=} args.colors.iconColor Card icon color. + * @param {string|string[]=} args.colors.bgColor Card background color. + * @param {string=} args.colors.borderColor Card border color. */ constructor({ width = 100, @@ -141,7 +140,7 @@ class Card { transform="translate(${this.paddingX}, ${this.paddingY})" > ${flexLayout({ - items: [this.titlePrefixIcon && prefixIcon, titleText], + items: [this.titlePrefixIcon ? prefixIcon : "", titleText], gap: 25, }).join("")} From f5de29fa6738724db250a8ac245c4d09bbd5ec18 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Fri, 17 Oct 2025 22:40:48 +0300 Subject: [PATCH 209/265] refactor: move encode HTML function tests into separate module (#4593) Co-authored-by: Alexandr --- tests/html.test.js | 10 ++++++++++ tests/render.test.js | 7 ------- 2 files changed, 10 insertions(+), 7 deletions(-) create mode 100644 tests/html.test.js diff --git a/tests/html.test.js b/tests/html.test.js new file mode 100644 index 0000000000000..d83143adc924c --- /dev/null +++ b/tests/html.test.js @@ -0,0 +1,10 @@ +import { describe, expect, it } from "@jest/globals"; +import { encodeHTML } from "../src/common/html.js"; + +describe("Test html.js", () => { + it("should test encodeHTML", () => { + expect(encodeHTML(`hello world<,.#4^&^@%!))`)).toBe( + "<html>hello world<,.#4^&^@%!))", + ); + }); +}); diff --git a/tests/render.test.js b/tests/render.test.js index 935b7335a9288..6bb409b1c47e5 100644 --- a/tests/render.test.js +++ b/tests/render.test.js @@ -4,15 +4,8 @@ import { describe, expect, it } from "@jest/globals"; import { queryByTestId } from "@testing-library/dom"; import "@testing-library/jest-dom/jest-globals"; import { renderError } from "../src/common/render.js"; -import { encodeHTML } from "../src/common/html.js"; describe("Test render.js", () => { - it("should test encodeHTML", () => { - expect(encodeHTML(`hello world<,.#4^&^@%!))`)).toBe( - "<html>hello world<,.#4^&^@%!))", - ); - }); - it("should test renderError", () => { document.body.innerHTML = renderError({ message: "Something went wrong" }); expect( From a11169e2f1b51165c012fb0429beda20ac8b93f9 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Fri, 17 Oct 2025 22:57:15 +0300 Subject: [PATCH 210/265] refactor: move create progress node function into render module (#4594) Co-authored-by: Alexandr --- src/cards/top-languages.js | 7 +++-- src/cards/wakatime.js | 3 +-- src/common/createProgressNode.js | 46 -------------------------------- src/common/index.js | 1 - src/common/render.js | 42 +++++++++++++++++++++++++++++ 5 files changed, 48 insertions(+), 51 deletions(-) delete mode 100644 src/common/createProgressNode.js diff --git a/src/cards/top-languages.js b/src/cards/top-languages.js index 4493835f369f8..6a36bfc61ae6a 100644 --- a/src/cards/top-languages.js +++ b/src/cards/top-languages.js @@ -2,11 +2,14 @@ import { Card } from "../common/Card.js"; import { getCardColors } from "../common/color.js"; -import { createProgressNode } from "../common/createProgressNode.js"; import { formatBytes } from "../common/fmt.js"; import { I18n } from "../common/I18n.js"; import { chunkArray, clampValue, lowercaseTrim } from "../common/ops.js"; -import { flexLayout, measureText } from "../common/render.js"; +import { + createProgressNode, + flexLayout, + measureText, +} from "../common/render.js"; import { langCardLocales } from "../translations.js"; const DEFAULT_CARD_WIDTH = 300; diff --git a/src/cards/wakatime.js b/src/cards/wakatime.js index 811fb243035db..9107e82d51276 100644 --- a/src/cards/wakatime.js +++ b/src/cards/wakatime.js @@ -2,10 +2,9 @@ import { Card } from "../common/Card.js"; import { getCardColors } from "../common/color.js"; -import { createProgressNode } from "../common/createProgressNode.js"; import { I18n } from "../common/I18n.js"; import { clampValue, lowercaseTrim } from "../common/ops.js"; -import { flexLayout } from "../common/render.js"; +import { createProgressNode, flexLayout } from "../common/render.js"; import { wakatimeCardLocales } from "../translations.js"; /** Import language colors. diff --git a/src/common/createProgressNode.js b/src/common/createProgressNode.js deleted file mode 100644 index e63944e7b1813..0000000000000 --- a/src/common/createProgressNode.js +++ /dev/null @@ -1,46 +0,0 @@ -// @ts-check - -import { clampValue } from "./ops.js"; - -/** - * Create a node to indicate progress in percentage along a horizontal line. - * - * @param {Object} params Object that contains the createProgressNode parameters. - * @param {number} params.x X-axis position. - * @param {number} params.y Y-axis position. - * @param {number} params.width Width of progress bar. - * @param {string} params.color Progress color. - * @param {number} params.progress Progress value. - * @param {string} params.progressBarBackgroundColor Progress bar bg color. - * @param {number} params.delay Delay before animation starts. - * @returns {string} Progress node. - */ -const createProgressNode = ({ - x, - y, - width, - color, - progress, - progressBarBackgroundColor, - delay, -}) => { - const progressPercentage = clampValue(progress, 2, 100); - - return ` - - - - - - - `; -}; - -export { createProgressNode }; -export default createProgressNode; diff --git a/src/common/index.js b/src/common/index.js index ccedfa9a8bf00..db914b86b1ebe 100644 --- a/src/common/index.js +++ b/src/common/index.js @@ -2,7 +2,6 @@ export { blacklist } from "./blacklist.js"; export { Card } from "./Card.js"; -export { createProgressNode } from "./createProgressNode.js"; export { I18n } from "./I18n.js"; export { icons } from "./icons.js"; export { retryer } from "./retryer.js"; diff --git a/src/common/render.js b/src/common/render.js index 32ecc8eb69dd2..594abaa549679 100644 --- a/src/common/render.js +++ b/src/common/render.js @@ -3,6 +3,7 @@ import { SECONDARY_ERROR_MESSAGES, TRY_AGAIN_LATER } from "./error.js"; import { getCardColors } from "./color.js"; import { encodeHTML } from "./html.js"; +import { clampValue } from "./ops.js"; /** * Auto layout utility, allows us to layout things vertically or horizontally with @@ -45,6 +46,46 @@ const createLanguageNode = (langName, langColor) => { `; }; +/** + * Create a node to indicate progress in percentage along a horizontal line. + * + * @param {Object} params Object that contains the createProgressNode parameters. + * @param {number} params.x X-axis position. + * @param {number} params.y Y-axis position. + * @param {number} params.width Width of progress bar. + * @param {string} params.color Progress color. + * @param {number} params.progress Progress value. + * @param {string} params.progressBarBackgroundColor Progress bar bg color. + * @param {number} params.delay Delay before animation starts. + * @returns {string} Progress node. + */ +const createProgressNode = ({ + x, + y, + width, + color, + progress, + progressBarBackgroundColor, + delay, +}) => { + const progressPercentage = clampValue(progress, 2, 100); + + return ` + + + + + + + `; +}; + /** * Creates an icon with label to display repository/gist stats like forks, stars, etc. * @@ -191,6 +232,7 @@ export { ERROR_CARD_LENGTH, renderError, createLanguageNode, + createProgressNode, iconWithLabel, flexLayout, measureText, From c9eb6752c5876be067b28a767c17e893cf1ca2c6 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Sat, 18 Oct 2025 21:07:48 +0300 Subject: [PATCH 211/265] fix: resolve vscode type errors inside access module (#4596) Co-authored-by: Alexandr --- src/common/access.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/common/access.js b/src/common/access.js index 891518329454b..25777356b55c5 100644 --- a/src/common/access.js +++ b/src/common/access.js @@ -12,7 +12,7 @@ const BLACKLISTED_MESSAGE = "This username is blacklisted"; * Guards access using whitelist/blacklist. * * @param {Object} args The parameters object. - * @param {Object} args.res The response object. + * @param {any} args.res The response object. * @param {string} args.id Resource identifier (username or gist id). * @param {"username"|"gist"|"wakatime"} args.type The type of identifier. * @param {{ title_color?: string, text_color?: string, bg_color?: string, border_color?: string, theme?: string }} args.colors Color options for the error card. From 81ad1c736f2aa80e7f893af9ac488ebce251b427 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Sat, 18 Oct 2025 21:08:45 +0300 Subject: [PATCH 212/265] ci: add comment with preview theme workflow disable reason (#4597) Co-authored-by: Alexandr --- .github/workflows/preview-theme.yml | 2 ++ 1 file changed, 2 insertions(+) diff --git a/.github/workflows/preview-theme.yml b/.github/workflows/preview-theme.yml index 6db3aeea938ed..595ca5f9303c7 100644 --- a/.github/workflows/preview-theme.yml +++ b/.github/workflows/preview-theme.yml @@ -1,5 +1,7 @@ name: Theme preview on: + # Temporary disabled due to paused themes addition. + # See: https://github.com/anuraghazra/github-readme-stats/issues/3404 # pull_request_target: # types: [opened, edited, reopened, synchronize] # branches: From 5871c68cff31b209dca08039ad66a9c07820a38d Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Sat, 18 Oct 2025 21:21:41 +0300 Subject: [PATCH 213/265] fix: resolve vscode type errors inside color module (#4598) Co-authored-by: Alexandr --- src/common/color.js | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/src/common/color.js b/src/common/color.js index 759a07ca25c7b..a372f24401a9a 100644 --- a/src/common/color.js +++ b/src/common/color.js @@ -1,3 +1,5 @@ +// @ts-check + import { themes } from "../../themes/index.js"; /** @@ -69,7 +71,6 @@ const fallbackColor = (color, fallbackColor) => { * @param {string=} args.border_color Card border color. * @param {string=} args.ring_color Card ring color. * @param {string=} args.theme Card theme. - * @param {string=} args.fallbackTheme Fallback theme. * @returns {CardColors} Card colors. */ const getCardColors = ({ @@ -80,11 +81,13 @@ const getCardColors = ({ border_color, ring_color, theme, - fallbackTheme = "default", }) => { - const defaultTheme = themes[fallbackTheme]; + const defaultTheme = themes["default"]; const isThemeProvided = theme !== null && theme !== undefined; + + // @ts-ignore const selectedTheme = isThemeProvided ? themes[theme] : defaultTheme; + const defaultBorderColor = "border_color" in selectedTheme ? selectedTheme.border_color From 237ef65864d59f00ae424ae86c39d8824308eb82 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Sat, 18 Oct 2025 21:22:23 +0300 Subject: [PATCH 214/265] ci: add comment with stale theme pr closer workflow disable reason (#4599) Co-authored-by: Alexandr --- .github/workflows/stale-theme-pr-closer.yml | 2 ++ 1 file changed, 2 insertions(+) diff --git a/.github/workflows/stale-theme-pr-closer.yml b/.github/workflows/stale-theme-pr-closer.yml index 81c8ee22f0901..6837717c5c9fe 100644 --- a/.github/workflows/stale-theme-pr-closer.yml +++ b/.github/workflows/stale-theme-pr-closer.yml @@ -1,5 +1,7 @@ name: Close stale theme pull requests that have the 'invalid' label. on: + # Temporary disabled due to paused themes addition. + # See: https://github.com/anuraghazra/github-readme-stats/issues/3404 # schedule: # # ┌───────────── minute (0 - 59) # # │ ┌───────────── hour (0 - 23) From 74a564834935b6b07022c6fd4787c8a953c0a8f1 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Sat, 18 Oct 2025 21:31:33 +0300 Subject: [PATCH 215/265] fix: mark Hungarian locale as long for stats card (#4600) Co-authored-by: Alexandr --- src/cards/stats.js | 1 + 1 file changed, 1 insertion(+) diff --git a/src/cards/stats.js b/src/cards/stats.js index 06aa86d63a1dd..44f787c5882a2 100644 --- a/src/cards/stats.js +++ b/src/cards/stats.js @@ -32,6 +32,7 @@ const LONG_LOCALES = [ "fil", "fi", "fr", + "hu", "id", "ml", "my", From 570619752f3a3d2a974c6b5137fd63e2fc1184cc Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Sun, 19 Oct 2025 21:34:30 +0300 Subject: [PATCH 216/265] chore: enable tscheck inside HTTP module (#4601) Co-authored-by: Alexandr --- src/common/http.js | 2 ++ 1 file changed, 2 insertions(+) diff --git a/src/common/http.js b/src/common/http.js index 388d105289906..ef6258b0b85eb 100644 --- a/src/common/http.js +++ b/src/common/http.js @@ -1,3 +1,5 @@ +// @ts-check + import axios from "axios"; /** From 7a5ac44604c8d0b6489849e1307fbd643d5222b8 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Sun, 19 Oct 2025 21:47:24 +0300 Subject: [PATCH 217/265] docs(readme): change available envs formatting to the table instead of list (#4602) * docs(readme): change available envs formatting to the table instead of list * dev * dev * dev * dev * dev * dev * dev * dev * dev * dev * Apply suggestion from @Copilot Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Apply suggestion from @Copilot Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * dev --------- Co-authored-by: Alexandr Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --- readme.md | 41 ++++++++++++++++++++++++++++++++++++----- 1 file changed, 36 insertions(+), 5 deletions(-) diff --git a/readme.md b/readme.md index e7faba9885405..78fe9ae42fb69 100644 --- a/readme.md +++ b/readme.md @@ -890,11 +890,42 @@ Since the GitHub API only allows 5k requests per hour, my `https://github-readme GitHub Readme Stats provides several environment variables that can be used to customize the behavior of your self-hosted instance. These include: -* `CACHE_SECONDS`: Sets the cache duration in seconds for the generated cards. This variable takes precedence over the default cache timings for the public instance. You can also set it to `0` to disable caching completely. If this variable is not set, the default cache duration is 24 hours (86,400 seconds). -* `WHITELIST`: A comma-separated list of GitHub usernames that are allowed to access your instance. If this variable is not set, all usernames are allowed. -* `GIST_WHITELIST`: A comma-separated list of GitHub gist IDs that are allowed to be accessed on your instance. If this variable is not set, all gist IDs are allowed. -* `EXCLUDE_REPO`: A comma-separated list of repositories that will be excluded from stats and top languages cards on your instance. This allows repository exclusion without exposing repository names in public URLs. This enhances privacy for self-hosted instances that include private repositories in stats cards. -* `FETCH_MULTI_PAGE_STARS`: When set to `true`, this enables fetching all starred repositories for accurate star counts, especially for users with more than 100 repositories. This may increase response times and API points usage, so it is disabled on the public instance. + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
NameDescriptionSupported values
CACHE_SECONDSSets the cache duration in seconds for the generated cards. This variable takes precedence over the default cache timings for the public instance. If this variable is not set, the default cache duration is 24 hours (86,400 seconds).Any positive integer or 0 to disable caching
WHITELISTA comma-separated list of GitHub usernames that are allowed to access your instance. If this variable is not set, all usernames are allowed.Comma-separated GitHub usernames
GIST_WHITELISTA comma-separated list of GitHub Gist IDs that are allowed to be accessed on your instance. If this variable is not set, all Gist IDs are allowed.Comma-separated GitHub Gist IDs
EXCLUDE_REPOA comma-separated list of repositories that will be excluded from stats and top languages cards on your instance. This allows repository exclusion without exposing repository names in public URLs. This enhances privacy for self-hosted instances that include private repositories in stats cards.Comma-separated repository names
FETCH_MULTI_PAGE_STARSEnables fetching all starred repositories for accurate star counts, especially for users with more than 100 repositories. This may increase response times and API points usage, so it is disabled on the public instance.true or false
See [the Vercel documentation](https://vercel.com/docs/concepts/projects/environment-variables) on adding these environment variables to your Vercel instance. From 0b21b2b54213b84a2909461b13dec918cf0f9720 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Sun, 19 Oct 2025 21:48:18 +0300 Subject: [PATCH 218/265] chore: enable tscheck inside envs module (#4603) Co-authored-by: Alexandr --- src/common/envs.js | 2 ++ 1 file changed, 2 insertions(+) diff --git a/src/common/envs.js b/src/common/envs.js index f1ae30de4b2e5..5f1319662b94d 100644 --- a/src/common/envs.js +++ b/src/common/envs.js @@ -1,3 +1,5 @@ +// @ts-check + const whitelist = process.env.WHITELIST ? process.env.WHITELIST.split(",") : undefined; From 5de1aa8706efd7f554c19cc0897ad6b869b80856 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Sun, 19 Oct 2025 23:51:42 +0300 Subject: [PATCH 219/265] fix: resolve vscode type errors inside I18n class (#4605) Co-authored-by: Alexandr --- src/common/I18n.js | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/common/I18n.js b/src/common/I18n.js index bd5f29fcb6a84..75b9c91aa2766 100644 --- a/src/common/I18n.js +++ b/src/common/I18n.js @@ -1,3 +1,5 @@ +// @ts-check + const FALLBACK_LOCALE = "en"; /** @@ -9,7 +11,7 @@ class I18n { * * @param {Object} options Options. * @param {string=} options.locale Locale. - * @param {Object} options.translations Translations. + * @param {any} options.translations Translations. */ constructor({ locale, translations }) { this.locale = locale || FALLBACK_LOCALE; From 79162359c19eabb91d4e64ce6fcebc114769a503 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Sun, 19 Oct 2025 23:52:12 +0300 Subject: [PATCH 220/265] chore: enable tscheck inside icons module (#4606) Co-authored-by: Alexandr --- src/common/icons.js | 2 ++ 1 file changed, 2 insertions(+) diff --git a/src/common/icons.js b/src/common/icons.js index 771704a335d12..98023b675e292 100644 --- a/src/common/icons.js +++ b/src/common/icons.js @@ -1,3 +1,5 @@ +// @ts-check + const icons = { star: ``, commits: ``, From 08d7b25d23554b45b4e7da3d1f3a801e8754984c Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Sun, 19 Oct 2025 23:52:42 +0300 Subject: [PATCH 221/265] fix: mark Japanese as long locale for stats card (#4607) Co-authored-by: Alexandr --- src/cards/stats.js | 1 + 1 file changed, 1 insertion(+) diff --git a/src/cards/stats.js b/src/cards/stats.js index 44f787c5882a2..6b428d48c34ae 100644 --- a/src/cards/stats.js +++ b/src/cards/stats.js @@ -34,6 +34,7 @@ const LONG_LOCALES = [ "fr", "hu", "id", + "ja", "ml", "my", "nl", From f023d9e74c39c2915561ad5f673e68d43cb214d6 Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Mon, 20 Oct 2025 20:47:52 +0300 Subject: [PATCH 222/265] chore: add vscode github actions extension into workspace recommended (#4608) Co-authored-by: Alexandr --- .vscode/extensions.json | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.vscode/extensions.json b/.vscode/extensions.json index 540848a504fdf..e9b20fd78b7b6 100644 --- a/.vscode/extensions.json +++ b/.vscode/extensions.json @@ -3,6 +3,7 @@ "yzhang.markdown-all-in-one", "esbenp.prettier-vscode", "dbaeumer.vscode-eslint", - "ms-azuretools.vscode-containers" + "ms-azuretools.vscode-containers", + "github.vscode-github-actions" ] } From 6d90255d0508c8fedbc4040cd97d663d0170159b Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Wed, 22 Oct 2025 21:53:48 +0300 Subject: [PATCH 223/265] fix: resolve vscode type errors inside retryer module (#4614) Co-authored-by: Alexandr --- src/common/retryer.js | 19 ++++++++++++++----- 1 file changed, 14 insertions(+), 5 deletions(-) diff --git a/src/common/retryer.js b/src/common/retryer.js index b3ea70644e005..6703415d92631 100644 --- a/src/common/retryer.js +++ b/src/common/retryer.js @@ -66,21 +66,30 @@ const retryer = async (fetcher, variables, retries = 0) => { // finally return the response return response; } catch (err) { + /** @type {any} */ + const e = err; + + // network/unexpected error → let caller treat as failure + if (!e?.response) { + throw e; + } + // prettier-ignore // also checking for bad credentials if any tokens gets invalidated - const isBadCredential = err.response.data && err.response.data.message === "Bad credentials"; + const isBadCredential = + e?.response?.data?.message === "Bad credentials"; const isAccountSuspended = - err.response.data && - err.response.data.message === "Sorry. Your account was suspended."; + e?.response?.data?.message === "Sorry. Your account was suspended."; if (isBadCredential || isAccountSuspended) { logger.log(`PAT_${retries + 1} Failed`); retries++; // directly return from the function return retryer(fetcher, variables, retries); - } else { - return err.response; } + + // HTTP error with a response → return it for caller-side handling + return e.response; } }; From 98ab3d4172c639ca6316ff58f3bbf34a0a76208d Mon Sep 17 00:00:00 2001 From: Alexandr Garbuzov <186095128+alexandr-garbuzov@users.noreply.github.com> Date: Wed, 22 Oct 2025 22:20:20 +0300 Subject: [PATCH 224/265] chore: add vscode github actions extension into devcontainer (#4615) Co-authored-by: Alexandr --- .devcontainer/devcontainer.json | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.devcontainer/devcontainer.json b/.devcontainer/devcontainer.json index 5c51e8bafae6d..310e627fa0d39 100644 --- a/.devcontainer/devcontainer.json +++ b/.devcontainer/devcontainer.json @@ -22,7 +22,8 @@ "extensions": [ "yzhang.markdown-all-in-one", "esbenp.prettier-vscode", - "dbaeumer.vscode-eslint" + "dbaeumer.vscode-eslint", + "github.vscode-github-actions" ] } }, From 0a060bab32d7654b8e2a35e61e601dcaa9c42788 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 24 Oct 2025 18:35:23 +0300 Subject: [PATCH 225/265] ci(deps): bump actions/setup-node from 5.0.0 to 6.0.0 (#4613) Bumps [actions/setup-node](https://github.com/actions/setup-node) from 5.0.0 to 6.0.0. - [Release notes](https://github.com/actions/setup-node/releases) - [Commits](https://github.com/actions/setup-node/compare/a0853c24544627f65ddf259abe73b1d18a591444...2028fbc5c25fe9cf00d9f06a71cc4710d4507903) --- updated-dependencies: - dependency-name: actions/setup-node dependency-version: 6.0.0 dependency-type: direct:production update-type: version-update:semver-major ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- .github/workflows/e2e-test.yml | 2 +- .github/workflows/generate-theme-doc.yml | 2 +- .github/workflows/preview-theme.yml | 2 +- .github/workflows/stale-theme-pr-closer.yml | 2 +- .github/workflows/test.yml | 2 +- .github/workflows/update-langs.yml | 2 +- 6 files changed, 6 insertions(+), 6 deletions(-) diff --git a/.github/workflows/e2e-test.yml b/.github/workflows/e2e-test.yml index e4d53ad947f47..022713fdafa20 100644 --- a/.github/workflows/e2e-test.yml +++ b/.github/workflows/e2e-test.yml @@ -20,7 +20,7 @@ jobs: - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 - name: Setup Node - uses: actions/setup-node@a0853c24544627f65ddf259abe73b1d18a591444 # v5.0.0 + uses: actions/setup-node@2028fbc5c25fe9cf00d9f06a71cc4710d4507903 # v6.0.0 with: node-version: ${{ matrix.node-version }} cache: npm diff --git a/.github/workflows/generate-theme-doc.yml b/.github/workflows/generate-theme-doc.yml index 123aaaab668c0..cea17a2a13f86 100644 --- a/.github/workflows/generate-theme-doc.yml +++ b/.github/workflows/generate-theme-doc.yml @@ -33,7 +33,7 @@ jobs: - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 - name: Setup Node - uses: actions/setup-node@a0853c24544627f65ddf259abe73b1d18a591444 # v5.0.0 + uses: actions/setup-node@2028fbc5c25fe9cf00d9f06a71cc4710d4507903 # v6.0.0 with: node-version: ${{ matrix.node-version }} cache: npm diff --git a/.github/workflows/preview-theme.yml b/.github/workflows/preview-theme.yml index 595ca5f9303c7..cf16caed1167f 100644 --- a/.github/workflows/preview-theme.yml +++ b/.github/workflows/preview-theme.yml @@ -36,7 +36,7 @@ jobs: - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 - name: Setup Node - uses: actions/setup-node@a0853c24544627f65ddf259abe73b1d18a591444 # v5.0.0 + uses: actions/setup-node@2028fbc5c25fe9cf00d9f06a71cc4710d4507903 # v6.0.0 with: node-version: ${{ matrix.node-version }} cache: npm diff --git a/.github/workflows/stale-theme-pr-closer.yml b/.github/workflows/stale-theme-pr-closer.yml index 6837717c5c9fe..18061309a6b6b 100644 --- a/.github/workflows/stale-theme-pr-closer.yml +++ b/.github/workflows/stale-theme-pr-closer.yml @@ -42,7 +42,7 @@ jobs: - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 - name: Setup Node - uses: actions/setup-node@a0853c24544627f65ddf259abe73b1d18a591444 # v5.0.0 + uses: actions/setup-node@2028fbc5c25fe9cf00d9f06a71cc4710d4507903 # v6.0.0 with: node-version: ${{ matrix.node-version }} cache: npm diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 113716d9ff7ea..1c24dda095aac 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -21,7 +21,7 @@ jobs: - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 - name: Setup Node - uses: actions/setup-node@a0853c24544627f65ddf259abe73b1d18a591444 # v5.0.0 + uses: actions/setup-node@2028fbc5c25fe9cf00d9f06a71cc4710d4507903 # v6.0.0 with: node-version: ${{ matrix.node-version }} cache: npm diff --git a/.github/workflows/update-langs.yml b/.github/workflows/update-langs.yml index 708fe63d80825..751c011d81701 100644 --- a/.github/workflows/update-langs.yml +++ b/.github/workflows/update-langs.yml @@ -39,7 +39,7 @@ jobs: - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 - name: Setup Node - uses: actions/setup-node@a0853c24544627f65ddf259abe73b1d18a591444 # v5.0.0 + uses: actions/setup-node@2028fbc5c25fe9cf00d9f06a71cc4710d4507903 # v6.0.0 with: node-version: ${{ matrix.node-version }} cache: npm From f72f03d8735c93bac14c421f778e6e51c7437d94 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 24 Oct 2025 18:38:56 +0300 Subject: [PATCH 226/265] build(deps-dev): bump lint-staged from 16.2.4 to 16.2.5 (#4611) Bumps [lint-staged](https://github.com/lint-staged/lint-staged) from 16.2.4 to 16.2.5. - [Release notes](https://github.com/lint-staged/lint-staged/releases) - [Changelog](https://github.com/lint-staged/lint-staged/blob/main/CHANGELOG.md) - [Commits](https://github.com/lint-staged/lint-staged/compare/v16.2.4...v16.2.5) --- updated-dependencies: - dependency-name: lint-staged dependency-version: 16.2.5 dependency-type: direct:development update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- package-lock.json | 14 +++++++------- package.json | 2 +- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/package-lock.json b/package-lock.json index c0525ff1e6021..e5ede97e294d9 100644 --- a/package-lock.json +++ b/package-lock.json @@ -35,7 +35,7 @@ "jest": "^30.2.0", "jest-environment-jsdom": "^30.2.0", "js-yaml": "^4.1.0", - "lint-staged": "^16.2.4", + "lint-staged": "^16.2.5", "lodash.snakecase": "^4.1.1", "parse-diff": "^0.11.1", "prettier": "^3.6.2" @@ -5579,9 +5579,9 @@ "dev": true }, "node_modules/lint-staged": { - "version": "16.2.4", - "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-16.2.4.tgz", - "integrity": "sha512-Pkyr/wd90oAyXk98i/2KwfkIhoYQUMtss769FIT9hFM5ogYZwrk+GRE46yKXSg2ZGhcJ1p38Gf5gmI5Ohjg2yg==", + "version": "16.2.5", + "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-16.2.5.tgz", + "integrity": "sha512-o36wH3OX0jRWqDw5dOa8a8x6GXTKaLM+LvhRaucZxez0IxA+KNDUCiyjBfNgsMNmchwSX6urLSL7wShcUqAang==", "dev": true, "dependencies": { "commander": "^14.0.1", @@ -11812,9 +11812,9 @@ "dev": true }, "lint-staged": { - "version": "16.2.4", - "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-16.2.4.tgz", - "integrity": "sha512-Pkyr/wd90oAyXk98i/2KwfkIhoYQUMtss769FIT9hFM5ogYZwrk+GRE46yKXSg2ZGhcJ1p38Gf5gmI5Ohjg2yg==", + "version": "16.2.5", + "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-16.2.5.tgz", + "integrity": "sha512-o36wH3OX0jRWqDw5dOa8a8x6GXTKaLM+LvhRaucZxez0IxA+KNDUCiyjBfNgsMNmchwSX6urLSL7wShcUqAang==", "dev": true, "requires": { "commander": "^14.0.1", diff --git a/package.json b/package.json index 382c661968c7e..13c8877488a26 100644 --- a/package.json +++ b/package.json @@ -55,7 +55,7 @@ "jest": "^30.2.0", "jest-environment-jsdom": "^30.2.0", "js-yaml": "^4.1.0", - "lint-staged": "^16.2.4", + "lint-staged": "^16.2.5", "lodash.snakecase": "^4.1.1", "parse-diff": "^0.11.1", "prettier": "^3.6.2" From 12cad0f7e9d96a3fcff2f5c561d0f57aacfcda48 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 24 Oct 2025 18:45:07 +0300 Subject: [PATCH 227/265] build(deps-dev): bump @eslint/js from 9.37.0 to 9.38.0 (#4610) Bumps [@eslint/js](https://github.com/eslint/eslint/tree/HEAD/packages/js) from 9.37.0 to 9.38.0. - [Release notes](https://github.com/eslint/eslint/releases) - [Commits](https://github.com/eslint/eslint/commits/v9.38.0/packages/js) --- updated-dependencies: - dependency-name: "@eslint/js" dependency-version: 9.38.0 dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- package-lock.json | 32 +++++++++++++++++++++++++------- package.json | 2 +- 2 files changed, 26 insertions(+), 8 deletions(-) diff --git a/package-lock.json b/package-lock.json index e5ede97e294d9..d8cf88b73ba51 100644 --- a/package-lock.json +++ b/package-lock.json @@ -19,7 +19,7 @@ "@actions/core": "^1.11.1", "@actions/github": "^6.0.1", "@eslint/eslintrc": "^3.3.1", - "@eslint/js": "^9.37.0", + "@eslint/js": "^9.38.0", "@testing-library/dom": "^10.4.1", "@testing-library/jest-dom": "^6.9.1", "@uppercod/css-to-object": "^1.1.1", @@ -861,9 +861,9 @@ } }, "node_modules/@eslint/js": { - "version": "9.37.0", - "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.37.0.tgz", - "integrity": "sha512-jaS+NJ+hximswBG6pjNX0uEJZkrT0zwpVi3BA3vX22aFGjJjmgSTSmPpZCRKmoBL5VY/M6p0xsSJx7rk7sy5gg==", + "version": "9.38.0", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.38.0.tgz", + "integrity": "sha512-UZ1VpFvXf9J06YG9xQBdnzU+kthors6KjhMAl6f4gH4usHyh31rUf2DLGInT8RFYIReYXNSydgPY0V2LuWgl7A==", "dev": true, "engines": { "node": "^18.18.0 || ^20.9.0 || >=21.1.0" @@ -3374,6 +3374,18 @@ "url": "https://opencollective.com/eslint" } }, + "node_modules/eslint/node_modules/@eslint/js": { + "version": "9.37.0", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.37.0.tgz", + "integrity": "sha512-jaS+NJ+hximswBG6pjNX0uEJZkrT0zwpVi3BA3vX22aFGjJjmgSTSmPpZCRKmoBL5VY/M6p0xsSJx7rk7sy5gg==", + "dev": true, + "engines": { + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" + }, + "funding": { + "url": "https://eslint.org/donate" + } + }, "node_modules/eslint/node_modules/escape-string-regexp": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", @@ -8384,9 +8396,9 @@ } }, "@eslint/js": { - "version": "9.37.0", - "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.37.0.tgz", - "integrity": "sha512-jaS+NJ+hximswBG6pjNX0uEJZkrT0zwpVi3BA3vX22aFGjJjmgSTSmPpZCRKmoBL5VY/M6p0xsSJx7rk7sy5gg==", + "version": "9.38.0", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.38.0.tgz", + "integrity": "sha512-UZ1VpFvXf9J06YG9xQBdnzU+kthors6KjhMAl6f4gH4usHyh31rUf2DLGInT8RFYIReYXNSydgPY0V2LuWgl7A==", "dev": true }, "@eslint/object-schema": { @@ -10160,6 +10172,12 @@ "optionator": "^0.9.3" }, "dependencies": { + "@eslint/js": { + "version": "9.37.0", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.37.0.tgz", + "integrity": "sha512-jaS+NJ+hximswBG6pjNX0uEJZkrT0zwpVi3BA3vX22aFGjJjmgSTSmPpZCRKmoBL5VY/M6p0xsSJx7rk7sy5gg==", + "dev": true + }, "escape-string-regexp": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", diff --git a/package.json b/package.json index 13c8877488a26..dca67bbd17ba6 100644 --- a/package.json +++ b/package.json @@ -39,7 +39,7 @@ "@actions/core": "^1.11.1", "@actions/github": "^6.0.1", "@eslint/eslintrc": "^3.3.1", - "@eslint/js": "^9.37.0", + "@eslint/js": "^9.38.0", "@testing-library/dom": "^10.4.1", "@testing-library/jest-dom": "^6.9.1", "@uppercod/css-to-object": "^1.1.1", From 86b0a557aab383d588cd0691725bb25564957268 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 24 Oct 2025 18:47:19 +0300 Subject: [PATCH 228/265] build(deps-dev): bump eslint from 9.37.0 to 9.38.0 (#4612) Bumps [eslint](https://github.com/eslint/eslint) from 9.37.0 to 9.38.0. - [Release notes](https://github.com/eslint/eslint/releases) - [Commits](https://github.com/eslint/eslint/compare/v9.37.0...v9.38.0) --- updated-dependencies: - dependency-name: eslint dependency-version: 9.38.0 dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- package-lock.json | 68 +++++++++++++++++++++++------------------------ package.json | 2 +- 2 files changed, 34 insertions(+), 36 deletions(-) diff --git a/package-lock.json b/package-lock.json index d8cf88b73ba51..9b8efb272066f 100644 --- a/package-lock.json +++ b/package-lock.json @@ -25,7 +25,7 @@ "@uppercod/css-to-object": "^1.1.1", "axios-mock-adapter": "^2.1.0", "color-contrast-checker": "^2.1.0", - "eslint": "^9.37.0", + "eslint": "^9.38.0", "eslint-config-prettier": "^10.1.8", "eslint-plugin-jsdoc": "^61.1.2", "express": "^5.1.0", @@ -787,12 +787,12 @@ } }, "node_modules/@eslint/config-array": { - "version": "0.21.0", - "resolved": "https://registry.npmjs.org/@eslint/config-array/-/config-array-0.21.0.tgz", - "integrity": "sha512-ENIdc4iLu0d93HeYirvKmrzshzofPw6VkZRKQGe9Nv46ZnWUzcF1xV01dcvEg/1wXUR61OmmlSfyeyO7EvjLxQ==", + "version": "0.21.1", + "resolved": "https://registry.npmjs.org/@eslint/config-array/-/config-array-0.21.1.tgz", + "integrity": "sha512-aw1gNayWpdI/jSYVgzN5pL0cfzU02GT3NBpeT/DXbx1/1x7ZKxFPd9bwrzygx/qiwIQiJ1sw/zD8qY/kRvlGHA==", "dev": true, "dependencies": { - "@eslint/object-schema": "^2.1.6", + "@eslint/object-schema": "^2.1.7", "debug": "^4.3.1", "minimatch": "^3.1.2" }, @@ -801,9 +801,9 @@ } }, "node_modules/@eslint/config-helpers": { - "version": "0.4.0", - "resolved": "https://registry.npmjs.org/@eslint/config-helpers/-/config-helpers-0.4.0.tgz", - "integrity": "sha512-WUFvV4WoIwW8Bv0KeKCIIEgdSiFOsulyN0xrMu+7z43q/hkOLXjvb5u7UC9jDxvRzcrbEmuZBX5yJZz1741jog==", + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/@eslint/config-helpers/-/config-helpers-0.4.1.tgz", + "integrity": "sha512-csZAzkNhsgwb0I/UAV6/RGFTbiakPCf0ZrGmrIxQpYvGZ00PhTkSnyKNolphgIvmnJeGw6rcGVEXfTzUnFuEvw==", "dev": true, "dependencies": { "@eslint/core": "^0.16.0" @@ -873,9 +873,9 @@ } }, "node_modules/@eslint/object-schema": { - "version": "2.1.6", - "resolved": "https://registry.npmjs.org/@eslint/object-schema/-/object-schema-2.1.6.tgz", - "integrity": "sha512-RBMg5FRL0I0gs51M/guSAj5/e14VQ4tpZnQNWwuDT66P14I43ItmPfIZRhO9fUVIPOAQXU47atlywZ/czoqFPA==", + "version": "2.1.7", + "resolved": "https://registry.npmjs.org/@eslint/object-schema/-/object-schema-2.1.7.tgz", + "integrity": "sha512-VtAOaymWVfZcmZbp6E2mympDIHvyjXs/12LqWYjVw6qjrfF+VK+fyG33kChz3nnK+SU5/NeHOqrTEHS8sXO3OA==", "dev": true, "engines": { "node": "^18.18.0 || ^20.9.0 || >=21.1.0" @@ -3221,24 +3221,23 @@ } }, "node_modules/eslint": { - "version": "9.37.0", - "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.37.0.tgz", - "integrity": "sha512-XyLmROnACWqSxiGYArdef1fItQd47weqB7iwtfr9JHwRrqIXZdcFMvvEcL9xHCmL0SNsOvF0c42lWyM1U5dgig==", + "version": "9.38.0", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.38.0.tgz", + "integrity": "sha512-t5aPOpmtJcZcz5UJyY2GbvpDlsK5E8JqRqoKtfiKE3cNh437KIqfJr3A3AKf5k64NPx6d0G3dno6XDY05PqPtw==", "dev": true, "dependencies": { "@eslint-community/eslint-utils": "^4.8.0", "@eslint-community/regexpp": "^4.12.1", - "@eslint/config-array": "^0.21.0", - "@eslint/config-helpers": "^0.4.0", + "@eslint/config-array": "^0.21.1", + "@eslint/config-helpers": "^0.4.1", "@eslint/core": "^0.16.0", "@eslint/eslintrc": "^3.3.1", - "@eslint/js": "9.37.0", + "@eslint/js": "9.38.0", "@eslint/plugin-kit": "^0.4.0", "@humanfs/node": "^0.16.6", "@humanwhocodes/module-importer": "^1.0.1", "@humanwhocodes/retry": "^0.4.2", "@types/estree": "^1.0.6", - "@types/json-schema": "^7.0.15", "ajv": "^6.12.4", "chalk": "^4.0.0", "cross-spawn": "^7.0.6", @@ -8342,20 +8341,20 @@ "dev": true }, "@eslint/config-array": { - "version": "0.21.0", - "resolved": "https://registry.npmjs.org/@eslint/config-array/-/config-array-0.21.0.tgz", - "integrity": "sha512-ENIdc4iLu0d93HeYirvKmrzshzofPw6VkZRKQGe9Nv46ZnWUzcF1xV01dcvEg/1wXUR61OmmlSfyeyO7EvjLxQ==", + "version": "0.21.1", + "resolved": "https://registry.npmjs.org/@eslint/config-array/-/config-array-0.21.1.tgz", + "integrity": "sha512-aw1gNayWpdI/jSYVgzN5pL0cfzU02GT3NBpeT/DXbx1/1x7ZKxFPd9bwrzygx/qiwIQiJ1sw/zD8qY/kRvlGHA==", "dev": true, "requires": { - "@eslint/object-schema": "^2.1.6", + "@eslint/object-schema": "^2.1.7", "debug": "^4.3.1", "minimatch": "^3.1.2" } }, "@eslint/config-helpers": { - "version": "0.4.0", - "resolved": "https://registry.npmjs.org/@eslint/config-helpers/-/config-helpers-0.4.0.tgz", - "integrity": "sha512-WUFvV4WoIwW8Bv0KeKCIIEgdSiFOsulyN0xrMu+7z43q/hkOLXjvb5u7UC9jDxvRzcrbEmuZBX5yJZz1741jog==", + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/@eslint/config-helpers/-/config-helpers-0.4.1.tgz", + "integrity": "sha512-csZAzkNhsgwb0I/UAV6/RGFTbiakPCf0ZrGmrIxQpYvGZ00PhTkSnyKNolphgIvmnJeGw6rcGVEXfTzUnFuEvw==", "dev": true, "requires": { "@eslint/core": "^0.16.0" @@ -8402,9 +8401,9 @@ "dev": true }, "@eslint/object-schema": { - "version": "2.1.6", - "resolved": "https://registry.npmjs.org/@eslint/object-schema/-/object-schema-2.1.6.tgz", - "integrity": "sha512-RBMg5FRL0I0gs51M/guSAj5/e14VQ4tpZnQNWwuDT66P14I43ItmPfIZRhO9fUVIPOAQXU47atlywZ/czoqFPA==", + "version": "2.1.7", + "resolved": "https://registry.npmjs.org/@eslint/object-schema/-/object-schema-2.1.7.tgz", + "integrity": "sha512-VtAOaymWVfZcmZbp6E2mympDIHvyjXs/12LqWYjVw6qjrfF+VK+fyG33kChz3nnK+SU5/NeHOqrTEHS8sXO3OA==", "dev": true }, "@eslint/plugin-kit": { @@ -10130,24 +10129,23 @@ "dev": true }, "eslint": { - "version": "9.37.0", - "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.37.0.tgz", - "integrity": "sha512-XyLmROnACWqSxiGYArdef1fItQd47weqB7iwtfr9JHwRrqIXZdcFMvvEcL9xHCmL0SNsOvF0c42lWyM1U5dgig==", + "version": "9.38.0", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.38.0.tgz", + "integrity": "sha512-t5aPOpmtJcZcz5UJyY2GbvpDlsK5E8JqRqoKtfiKE3cNh437KIqfJr3A3AKf5k64NPx6d0G3dno6XDY05PqPtw==", "dev": true, "requires": { "@eslint-community/eslint-utils": "^4.8.0", "@eslint-community/regexpp": "^4.12.1", - "@eslint/config-array": "^0.21.0", - "@eslint/config-helpers": "^0.4.0", + "@eslint/config-array": "^0.21.1", + "@eslint/config-helpers": "^0.4.1", "@eslint/core": "^0.16.0", "@eslint/eslintrc": "^3.3.1", - "@eslint/js": "9.37.0", + "@eslint/js": "9.38.0", "@eslint/plugin-kit": "^0.4.0", "@humanfs/node": "^0.16.6", "@humanwhocodes/module-importer": "^1.0.1", "@humanwhocodes/retry": "^0.4.2", "@types/estree": "^1.0.6", - "@types/json-schema": "^7.0.15", "ajv": "^6.12.4", "chalk": "^4.0.0", "cross-spawn": "^7.0.6", diff --git a/package.json b/package.json index dca67bbd17ba6..f8d6a7b614dc9 100644 --- a/package.json +++ b/package.json @@ -45,7 +45,7 @@ "@uppercod/css-to-object": "^1.1.1", "axios-mock-adapter": "^2.1.0", "color-contrast-checker": "^2.1.0", - "eslint": "^9.37.0", + "eslint": "^9.38.0", "eslint-config-prettier": "^10.1.8", "eslint-plugin-jsdoc": "^61.1.2", "express": "^5.1.0", From 8a77b11149845afbb26be8fcd3d9e160e98f05af Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 24 Oct 2025 18:52:42 +0300 Subject: [PATCH 229/265] build(deps-dev): bump eslint-plugin-jsdoc from 61.1.2 to 61.1.5 (#4609) Bumps [eslint-plugin-jsdoc](https://github.com/gajus/eslint-plugin-jsdoc) from 61.1.2 to 61.1.5. - [Release notes](https://github.com/gajus/eslint-plugin-jsdoc/releases) - [Changelog](https://github.com/gajus/eslint-plugin-jsdoc/blob/main/.releaserc) - [Commits](https://github.com/gajus/eslint-plugin-jsdoc/compare/v61.1.2...v61.1.5) --- updated-dependencies: - dependency-name: eslint-plugin-jsdoc dependency-version: 61.1.5 dependency-type: direct:development update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- package-lock.json | 128 ++++++++++++++++++++++++++++++---------------- package.json | 2 +- 2 files changed, 84 insertions(+), 46 deletions(-) diff --git a/package-lock.json b/package-lock.json index 9b8efb272066f..35e37009fc4bc 100644 --- a/package-lock.json +++ b/package-lock.json @@ -27,7 +27,7 @@ "color-contrast-checker": "^2.1.0", "eslint": "^9.38.0", "eslint-config-prettier": "^10.1.8", - "eslint-plugin-jsdoc": "^61.1.2", + "eslint-plugin-jsdoc": "^61.1.5", "express": "^5.1.0", "globals": "^16.4.0", "hjson": "^3.2.2", @@ -1669,6 +1669,18 @@ "integrity": "sha512-6gS8pZzSXdyRHTIqoqSVknxolr1kzfy4/CeDnrzsVz8TTIWUbOBr6gnzOmTYJ3eXQNh4IYHIGi5aIL7sOZ2G/g==", "dev": true }, + "node_modules/@sindresorhus/base62": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/@sindresorhus/base62/-/base62-1.0.0.tgz", + "integrity": "sha512-TeheYy0ILzBEI/CO55CP6zJCSdSWeRtGnHy8U8dWSUH4I68iqTsy7HkMktR4xakThc9jotkPQUXT4ITdbV7cHA==", + "dev": true, + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, "node_modules/@sinonjs/commons": { "version": "3.0.1", "resolved": "https://registry.npmjs.org/@sinonjs/commons/-/commons-3.0.1.tgz", @@ -3295,9 +3307,9 @@ } }, "node_modules/eslint-plugin-jsdoc": { - "version": "61.1.2", - "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-61.1.2.tgz", - "integrity": "sha512-gbb4VVKRsMJZ+YqJXte6RQ/pDTIQcMauyQb03n5GTfWG+gAb6T3FaOLeoSHAIrBT90ykLkxzRh3z95DoIrUk3A==", + "version": "61.1.5", + "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-61.1.5.tgz", + "integrity": "sha512-UZ+7M6WVFBVRTxHZURxYP7M++M+ZEjxPGB/CScdrKAhzpf/LWS1HaNRHMOkISkOTTggMhwRwgKmVlTLQryXV2Q==", "dev": true, "dependencies": { "@es-joy/jsdoccomment": "~0.76.0", @@ -3308,10 +3320,11 @@ "espree": "^10.4.0", "esquery": "^1.6.0", "html-entities": "^2.6.0", - "object-deep-merge": "^1.0.5", + "object-deep-merge": "^2.0.0", "parse-imports-exports": "^0.2.4", "semver": "^7.7.3", - "spdx-expression-parse": "^4.0.0" + "spdx-expression-parse": "^4.0.0", + "to-valid-identifier": "^1.0.0" }, "engines": { "node": ">=20.11.0" @@ -6055,25 +6068,10 @@ "dev": true }, "node_modules/object-deep-merge": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/object-deep-merge/-/object-deep-merge-1.0.5.tgz", - "integrity": "sha512-3DioFgOzetbxbeUq8pB2NunXo8V0n4EvqsWM/cJoI6IA9zghd7cl/2pBOuWRf4dlvA+fcg5ugFMZaN2/RuoaGg==", - "dev": true, - "dependencies": { - "type-fest": "4.2.0" - } - }, - "node_modules/object-deep-merge/node_modules/type-fest": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-4.2.0.tgz", - "integrity": "sha512-5zknd7Dss75pMSED270A1RQS3KloqRJA9XbXLe0eCxyw7xXFb3rd+9B0UQ/0E+LQT6lnrLviEolYORlRWamn4w==", - "dev": true, - "engines": { - "node": ">=16" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/object-deep-merge/-/object-deep-merge-2.0.0.tgz", + "integrity": "sha512-3DC3UMpeffLTHiuXSy/UG4NOIYTLlY9u3V82+djSCLYClWobZiS4ivYzpIUWrRY/nfsJ8cWsKyG3QfyLePmhvg==", + "dev": true }, "node_modules/object-inspect": { "version": "1.13.4", @@ -6555,6 +6553,18 @@ "node": ">=0.10.0" } }, + "node_modules/reserved-identifiers": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/reserved-identifiers/-/reserved-identifiers-1.0.0.tgz", + "integrity": "sha512-h0bP2Katmvf3hv4Z3WtDl4+6xt/OglQ2Xa6TnhZ/Rm9/7IH1crXQqMwD4J2ngKBonVv+fB55zfGgNDAmsevLVQ==", + "dev": true, + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, "node_modules/resolve-cwd": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/resolve-cwd/-/resolve-cwd-3.0.0.tgz", @@ -7253,6 +7263,22 @@ "node": ">=8.0" } }, + "node_modules/to-valid-identifier": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/to-valid-identifier/-/to-valid-identifier-1.0.0.tgz", + "integrity": "sha512-41wJyvKep3yT2tyPqX/4blcfybknGB4D+oETKLs7Q76UiPqRpUJK3hr1nxelyYO0PHKVzJwlu0aCeEAsGI6rpw==", + "dev": true, + "dependencies": { + "@sindresorhus/base62": "^1.0.0", + "reserved-identifiers": "^1.0.0" + }, + "engines": { + "node": ">=20" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, "node_modules/toidentifier": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", @@ -9011,6 +9037,12 @@ "integrity": "sha512-6gS8pZzSXdyRHTIqoqSVknxolr1kzfy4/CeDnrzsVz8TTIWUbOBr6gnzOmTYJ3eXQNh4IYHIGi5aIL7sOZ2G/g==", "dev": true }, + "@sindresorhus/base62": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/@sindresorhus/base62/-/base62-1.0.0.tgz", + "integrity": "sha512-TeheYy0ILzBEI/CO55CP6zJCSdSWeRtGnHy8U8dWSUH4I68iqTsy7HkMktR4xakThc9jotkPQUXT4ITdbV7cHA==", + "dev": true + }, "@sinonjs/commons": { "version": "3.0.1", "resolved": "https://registry.npmjs.org/@sinonjs/commons/-/commons-3.0.1.tgz", @@ -10240,9 +10272,9 @@ "requires": {} }, "eslint-plugin-jsdoc": { - "version": "61.1.2", - "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-61.1.2.tgz", - "integrity": "sha512-gbb4VVKRsMJZ+YqJXte6RQ/pDTIQcMauyQb03n5GTfWG+gAb6T3FaOLeoSHAIrBT90ykLkxzRh3z95DoIrUk3A==", + "version": "61.1.5", + "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-61.1.5.tgz", + "integrity": "sha512-UZ+7M6WVFBVRTxHZURxYP7M++M+ZEjxPGB/CScdrKAhzpf/LWS1HaNRHMOkISkOTTggMhwRwgKmVlTLQryXV2Q==", "dev": true, "requires": { "@es-joy/jsdoccomment": "~0.76.0", @@ -10253,10 +10285,11 @@ "espree": "^10.4.0", "esquery": "^1.6.0", "html-entities": "^2.6.0", - "object-deep-merge": "^1.0.5", + "object-deep-merge": "^2.0.0", "parse-imports-exports": "^0.2.4", "semver": "^7.7.3", - "spdx-expression-parse": "^4.0.0" + "spdx-expression-parse": "^4.0.0", + "to-valid-identifier": "^1.0.0" }, "dependencies": { "escape-string-regexp": { @@ -12155,21 +12188,10 @@ "dev": true }, "object-deep-merge": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/object-deep-merge/-/object-deep-merge-1.0.5.tgz", - "integrity": "sha512-3DioFgOzetbxbeUq8pB2NunXo8V0n4EvqsWM/cJoI6IA9zghd7cl/2pBOuWRf4dlvA+fcg5ugFMZaN2/RuoaGg==", - "dev": true, - "requires": { - "type-fest": "4.2.0" - }, - "dependencies": { - "type-fest": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-4.2.0.tgz", - "integrity": "sha512-5zknd7Dss75pMSED270A1RQS3KloqRJA9XbXLe0eCxyw7xXFb3rd+9B0UQ/0E+LQT6lnrLviEolYORlRWamn4w==", - "dev": true - } - } + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/object-deep-merge/-/object-deep-merge-2.0.0.tgz", + "integrity": "sha512-3DC3UMpeffLTHiuXSy/UG4NOIYTLlY9u3V82+djSCLYClWobZiS4ivYzpIUWrRY/nfsJ8cWsKyG3QfyLePmhvg==", + "dev": true }, "object-inspect": { "version": "1.13.4", @@ -12501,6 +12523,12 @@ "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", "dev": true }, + "reserved-identifiers": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/reserved-identifiers/-/reserved-identifiers-1.0.0.tgz", + "integrity": "sha512-h0bP2Katmvf3hv4Z3WtDl4+6xt/OglQ2Xa6TnhZ/Rm9/7IH1crXQqMwD4J2ngKBonVv+fB55zfGgNDAmsevLVQ==", + "dev": true + }, "resolve-cwd": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/resolve-cwd/-/resolve-cwd-3.0.0.tgz", @@ -13004,6 +13032,16 @@ "is-number": "^7.0.0" } }, + "to-valid-identifier": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/to-valid-identifier/-/to-valid-identifier-1.0.0.tgz", + "integrity": "sha512-41wJyvKep3yT2tyPqX/4blcfybknGB4D+oETKLs7Q76UiPqRpUJK3hr1nxelyYO0PHKVzJwlu0aCeEAsGI6rpw==", + "dev": true, + "requires": { + "@sindresorhus/base62": "^1.0.0", + "reserved-identifiers": "^1.0.0" + } + }, "toidentifier": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", diff --git a/package.json b/package.json index f8d6a7b614dc9..5d8327b1097ba 100644 --- a/package.json +++ b/package.json @@ -47,7 +47,7 @@ "color-contrast-checker": "^2.1.0", "eslint": "^9.38.0", "eslint-config-prettier": "^10.1.8", - "eslint-plugin-jsdoc": "^61.1.2", + "eslint-plugin-jsdoc": "^61.1.5", "express": "^5.1.0", "globals": "^16.4.0", "hjson": "^3.2.2", From 2c3094106556764475ddb58097af0bad65cb7404 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 31 Oct 2025 18:32:39 +0200 Subject: [PATCH 230/265] build(deps-dev): bump lint-staged from 16.2.5 to 16.2.6 (#4623) Bumps [lint-staged](https://github.com/lint-staged/lint-staged) from 16.2.5 to 16.2.6. - [Release notes](https://github.com/lint-staged/lint-staged/releases) - [Changelog](https://github.com/lint-staged/lint-staged/blob/main/CHANGELOG.md) - [Commits](https://github.com/lint-staged/lint-staged/compare/v16.2.5...v16.2.6) --- updated-dependencies: - dependency-name: lint-staged dependency-version: 16.2.6 dependency-type: direct:development update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- package-lock.json | 96 +++++++++++++++++++---------------------------- package.json | 2 +- 2 files changed, 40 insertions(+), 58 deletions(-) diff --git a/package-lock.json b/package-lock.json index 35e37009fc4bc..0d1a9089ceff9 100644 --- a/package-lock.json +++ b/package-lock.json @@ -35,7 +35,7 @@ "jest": "^30.2.0", "jest-environment-jsdom": "^30.2.0", "js-yaml": "^4.1.0", - "lint-staged": "^16.2.5", + "lint-staged": "^16.2.6", "lodash.snakecase": "^4.1.1", "parse-diff": "^0.11.1", "prettier": "^3.6.2" @@ -2686,9 +2686,9 @@ } }, "node_modules/cli-truncate": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/cli-truncate/-/cli-truncate-5.1.0.tgz", - "integrity": "sha512-7JDGG+4Zp0CsknDCedl0DYdaeOhc46QNpXi3NLQblkZpXXgA6LncLDUUyvrjSvZeF3VRQa+KiMGomazQrC1V8g==", + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/cli-truncate/-/cli-truncate-5.1.1.tgz", + "integrity": "sha512-SroPvNHxUnk+vIW/dOSfNqdy1sPEFkrTk6TUtqLCnBlo3N7TNYYkzzN7uSD6+jVjrdO4+p8nH7JzH6cIvUem6A==", "dev": true, "dependencies": { "slice-ansi": "^7.1.0", @@ -3386,18 +3386,6 @@ "url": "https://opencollective.com/eslint" } }, - "node_modules/eslint/node_modules/@eslint/js": { - "version": "9.37.0", - "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.37.0.tgz", - "integrity": "sha512-jaS+NJ+hximswBG6pjNX0uEJZkrT0zwpVi3BA3vX22aFGjJjmgSTSmPpZCRKmoBL5VY/M6p0xsSJx7rk7sy5gg==", - "dev": true, - "engines": { - "node": "^18.18.0 || ^20.9.0 || >=21.1.0" - }, - "funding": { - "url": "https://eslint.org/donate" - } - }, "node_modules/eslint/node_modules/escape-string-regexp": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", @@ -5603,13 +5591,13 @@ "dev": true }, "node_modules/lint-staged": { - "version": "16.2.5", - "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-16.2.5.tgz", - "integrity": "sha512-o36wH3OX0jRWqDw5dOa8a8x6GXTKaLM+LvhRaucZxez0IxA+KNDUCiyjBfNgsMNmchwSX6urLSL7wShcUqAang==", + "version": "16.2.6", + "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-16.2.6.tgz", + "integrity": "sha512-s1gphtDbV4bmW1eylXpVMk2u7is7YsrLl8hzrtvC70h4ByhcMLZFY01Fx05ZUDNuv1H8HO4E+e2zgejV1jVwNw==", "dev": true, "dependencies": { "commander": "^14.0.1", - "listr2": "^9.0.4", + "listr2": "^9.0.5", "micromatch": "^4.0.8", "nano-spawn": "^2.0.0", "pidtree": "^0.6.0", @@ -5627,9 +5615,9 @@ } }, "node_modules/listr2": { - "version": "9.0.4", - "resolved": "https://registry.npmjs.org/listr2/-/listr2-9.0.4.tgz", - "integrity": "sha512-1wd/kpAdKRLwv7/3OKC8zZ5U8e/fajCfWMxacUvB79S5nLrYGPtUI/8chMQhn3LQjsRVErTb9i1ECAwW0ZIHnQ==", + "version": "9.0.5", + "resolved": "https://registry.npmjs.org/listr2/-/listr2-9.0.5.tgz", + "integrity": "sha512-ME4Fb83LgEgwNw96RKNvKV4VTLuXfoKudAmm2lP8Kk87KaMK0/Xrx/aAkMWmT8mDb+3MlFDspfbCs7adjRxA2g==", "dev": true, "dependencies": { "cli-truncate": "^5.0.0", @@ -5656,9 +5644,9 @@ } }, "node_modules/listr2/node_modules/emoji-regex": { - "version": "10.5.0", - "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.5.0.tgz", - "integrity": "sha512-lb49vf1Xzfx080OKA0o6l8DQQpV+6Vg95zyCJX9VB/BqKYlhG7N4wgROUUHRA+ZPUefLnteQOad7z1kT2bV7bg==", + "version": "10.6.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.6.0.tgz", + "integrity": "sha512-toUI84YS5YmxW219erniWD0CIVOo46xGKColeNQRgOzDorgBi1v4D71/OFzgD9GO2UGKIv1C3Sp8DAn0+j5w7A==", "dev": true }, "node_modules/listr2/node_modules/string-width": { @@ -5739,9 +5727,9 @@ } }, "node_modules/log-update/node_modules/ansi-escapes": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-7.1.0.tgz", - "integrity": "sha512-YdhtCd19sKRKfAAUsrcC1wzm4JuzJoiX4pOJqIoW2qmKj5WzG/dL8uUJ0361zaXtHqK7gEhOwtAtz7t3Yq3X5g==", + "version": "7.1.1", + "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-7.1.1.tgz", + "integrity": "sha512-Zhl0ErHcSRUaVfGUeUdDuLgpkEo8KIFjB4Y9uAc46ScOpdDiU1Dbyplh7qWJeJ/ZHpbyMSM26+X3BySgnIz40Q==", "dev": true, "dependencies": { "environment": "^1.0.0" @@ -5766,9 +5754,9 @@ } }, "node_modules/log-update/node_modules/emoji-regex": { - "version": "10.5.0", - "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.5.0.tgz", - "integrity": "sha512-lb49vf1Xzfx080OKA0o6l8DQQpV+6Vg95zyCJX9VB/BqKYlhG7N4wgROUUHRA+ZPUefLnteQOad7z1kT2bV7bg==", + "version": "10.6.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.6.0.tgz", + "integrity": "sha512-toUI84YS5YmxW219erniWD0CIVOo46xGKColeNQRgOzDorgBi1v4D71/OFzgD9GO2UGKIv1C3Sp8DAn0+j5w7A==", "dev": true }, "node_modules/log-update/node_modules/string-width": { @@ -9761,9 +9749,9 @@ } }, "cli-truncate": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/cli-truncate/-/cli-truncate-5.1.0.tgz", - "integrity": "sha512-7JDGG+4Zp0CsknDCedl0DYdaeOhc46QNpXi3NLQblkZpXXgA6LncLDUUyvrjSvZeF3VRQa+KiMGomazQrC1V8g==", + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/cli-truncate/-/cli-truncate-5.1.1.tgz", + "integrity": "sha512-SroPvNHxUnk+vIW/dOSfNqdy1sPEFkrTk6TUtqLCnBlo3N7TNYYkzzN7uSD6+jVjrdO4+p8nH7JzH6cIvUem6A==", "dev": true, "requires": { "slice-ansi": "^7.1.0", @@ -10202,12 +10190,6 @@ "optionator": "^0.9.3" }, "dependencies": { - "@eslint/js": { - "version": "9.37.0", - "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.37.0.tgz", - "integrity": "sha512-jaS+NJ+hximswBG6pjNX0uEJZkrT0zwpVi3BA3vX22aFGjJjmgSTSmPpZCRKmoBL5VY/M6p0xsSJx7rk7sy5gg==", - "dev": true - }, "escape-string-regexp": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", @@ -11861,13 +11843,13 @@ "dev": true }, "lint-staged": { - "version": "16.2.5", - "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-16.2.5.tgz", - "integrity": "sha512-o36wH3OX0jRWqDw5dOa8a8x6GXTKaLM+LvhRaucZxez0IxA+KNDUCiyjBfNgsMNmchwSX6urLSL7wShcUqAang==", + "version": "16.2.6", + "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-16.2.6.tgz", + "integrity": "sha512-s1gphtDbV4bmW1eylXpVMk2u7is7YsrLl8hzrtvC70h4ByhcMLZFY01Fx05ZUDNuv1H8HO4E+e2zgejV1jVwNw==", "dev": true, "requires": { "commander": "^14.0.1", - "listr2": "^9.0.4", + "listr2": "^9.0.5", "micromatch": "^4.0.8", "nano-spawn": "^2.0.0", "pidtree": "^0.6.0", @@ -11876,9 +11858,9 @@ } }, "listr2": { - "version": "9.0.4", - "resolved": "https://registry.npmjs.org/listr2/-/listr2-9.0.4.tgz", - "integrity": "sha512-1wd/kpAdKRLwv7/3OKC8zZ5U8e/fajCfWMxacUvB79S5nLrYGPtUI/8chMQhn3LQjsRVErTb9i1ECAwW0ZIHnQ==", + "version": "9.0.5", + "resolved": "https://registry.npmjs.org/listr2/-/listr2-9.0.5.tgz", + "integrity": "sha512-ME4Fb83LgEgwNw96RKNvKV4VTLuXfoKudAmm2lP8Kk87KaMK0/Xrx/aAkMWmT8mDb+3MlFDspfbCs7adjRxA2g==", "dev": true, "requires": { "cli-truncate": "^5.0.0", @@ -11896,9 +11878,9 @@ "dev": true }, "emoji-regex": { - "version": "10.5.0", - "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.5.0.tgz", - "integrity": "sha512-lb49vf1Xzfx080OKA0o6l8DQQpV+6Vg95zyCJX9VB/BqKYlhG7N4wgROUUHRA+ZPUefLnteQOad7z1kT2bV7bg==", + "version": "10.6.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.6.0.tgz", + "integrity": "sha512-toUI84YS5YmxW219erniWD0CIVOo46xGKColeNQRgOzDorgBi1v4D71/OFzgD9GO2UGKIv1C3Sp8DAn0+j5w7A==", "dev": true }, "string-width": { @@ -11960,9 +11942,9 @@ }, "dependencies": { "ansi-escapes": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-7.1.0.tgz", - "integrity": "sha512-YdhtCd19sKRKfAAUsrcC1wzm4JuzJoiX4pOJqIoW2qmKj5WzG/dL8uUJ0361zaXtHqK7gEhOwtAtz7t3Yq3X5g==", + "version": "7.1.1", + "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-7.1.1.tgz", + "integrity": "sha512-Zhl0ErHcSRUaVfGUeUdDuLgpkEo8KIFjB4Y9uAc46ScOpdDiU1Dbyplh7qWJeJ/ZHpbyMSM26+X3BySgnIz40Q==", "dev": true, "requires": { "environment": "^1.0.0" @@ -11975,9 +11957,9 @@ "dev": true }, "emoji-regex": { - "version": "10.5.0", - "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.5.0.tgz", - "integrity": "sha512-lb49vf1Xzfx080OKA0o6l8DQQpV+6Vg95zyCJX9VB/BqKYlhG7N4wgROUUHRA+ZPUefLnteQOad7z1kT2bV7bg==", + "version": "10.6.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.6.0.tgz", + "integrity": "sha512-toUI84YS5YmxW219erniWD0CIVOo46xGKColeNQRgOzDorgBi1v4D71/OFzgD9GO2UGKIv1C3Sp8DAn0+j5w7A==", "dev": true }, "string-width": { diff --git a/package.json b/package.json index 5d8327b1097ba..436b716c3651e 100644 --- a/package.json +++ b/package.json @@ -55,7 +55,7 @@ "jest": "^30.2.0", "jest-environment-jsdom": "^30.2.0", "js-yaml": "^4.1.0", - "lint-staged": "^16.2.5", + "lint-staged": "^16.2.6", "lodash.snakecase": "^4.1.1", "parse-diff": "^0.11.1", "prettier": "^3.6.2" From 30860b84b18962265cba8e37f64950a6e94922d4 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 31 Oct 2025 18:34:35 +0200 Subject: [PATCH 231/265] build(deps): bump axios from 1.12.2 to 1.13.0 (#4624) Bumps [axios](https://github.com/axios/axios) from 1.12.2 to 1.13.0. - [Release notes](https://github.com/axios/axios/releases) - [Changelog](https://github.com/axios/axios/blob/v1.x/CHANGELOG.md) - [Commits](https://github.com/axios/axios/compare/v1.12.2...v1.13.0) --- updated-dependencies: - dependency-name: axios dependency-version: 1.13.0 dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- package-lock.json | 14 +++++++------- package.json | 2 +- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/package-lock.json b/package-lock.json index 0d1a9089ceff9..102a6fa916341 100644 --- a/package-lock.json +++ b/package-lock.json @@ -9,7 +9,7 @@ "version": "1.0.0", "license": "MIT", "dependencies": { - "axios": "^1.12.2", + "axios": "^1.13.0", "dotenv": "^17.2.3", "emoji-name-map": "^2.0.3", "github-username-regex": "^1.0.0", @@ -2321,9 +2321,9 @@ "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==" }, "node_modules/axios": { - "version": "1.12.2", - "resolved": "https://registry.npmjs.org/axios/-/axios-1.12.2.tgz", - "integrity": "sha512-vMJzPewAlRyOgxV2dU0Cuz2O8zzzx9VYtbJOaBgXFeLc4IV/Eg50n4LowmehOOR61S8ZMpc2K5Sa7g6A4jfkUw==", + "version": "1.13.0", + "resolved": "https://registry.npmjs.org/axios/-/axios-1.13.0.tgz", + "integrity": "sha512-zt40Pz4zcRXra9CVV31KeyofwiNvAbJ5B6YPz9pMJ+yOSLikvPT4Yi5LjfgjRa9CawVYBaD1JQzIVcIvBejKeA==", "dependencies": { "follow-redirects": "^1.15.6", "form-data": "^4.0.4", @@ -9497,9 +9497,9 @@ "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==" }, "axios": { - "version": "1.12.2", - "resolved": "https://registry.npmjs.org/axios/-/axios-1.12.2.tgz", - "integrity": "sha512-vMJzPewAlRyOgxV2dU0Cuz2O8zzzx9VYtbJOaBgXFeLc4IV/Eg50n4LowmehOOR61S8ZMpc2K5Sa7g6A4jfkUw==", + "version": "1.13.0", + "resolved": "https://registry.npmjs.org/axios/-/axios-1.13.0.tgz", + "integrity": "sha512-zt40Pz4zcRXra9CVV31KeyofwiNvAbJ5B6YPz9pMJ+yOSLikvPT4Yi5LjfgjRa9CawVYBaD1JQzIVcIvBejKeA==", "requires": { "follow-redirects": "^1.15.6", "form-data": "^4.0.4", diff --git a/package.json b/package.json index 436b716c3651e..735c84ba0f66f 100644 --- a/package.json +++ b/package.json @@ -61,7 +61,7 @@ "prettier": "^3.6.2" }, "dependencies": { - "axios": "^1.12.2", + "axios": "^1.13.0", "dotenv": "^17.2.3", "emoji-name-map": "^2.0.3", "github-username-regex": "^1.0.0", From 376b7ac04d23f6fc892d845ccbb897f16f35303c Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 31 Oct 2025 18:36:28 +0200 Subject: [PATCH 232/265] build(deps-dev): bump eslint-plugin-jsdoc from 61.1.5 to 61.1.9 (#4626) Bumps [eslint-plugin-jsdoc](https://github.com/gajus/eslint-plugin-jsdoc) from 61.1.5 to 61.1.9. - [Release notes](https://github.com/gajus/eslint-plugin-jsdoc/releases) - [Changelog](https://github.com/gajus/eslint-plugin-jsdoc/blob/main/.releaserc) - [Commits](https://github.com/gajus/eslint-plugin-jsdoc/compare/v61.1.5...v61.1.9) --- updated-dependencies: - dependency-name: eslint-plugin-jsdoc dependency-version: 61.1.9 dependency-type: direct:development update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- package-lock.json | 31 ++++++++++++++++++++++++------- package.json | 2 +- 2 files changed, 25 insertions(+), 8 deletions(-) diff --git a/package-lock.json b/package-lock.json index 102a6fa916341..2ee0d2fc51451 100644 --- a/package-lock.json +++ b/package-lock.json @@ -27,7 +27,7 @@ "color-contrast-checker": "^2.1.0", "eslint": "^9.38.0", "eslint-config-prettier": "^10.1.8", - "eslint-plugin-jsdoc": "^61.1.5", + "eslint-plugin-jsdoc": "^61.1.9", "express": "^5.1.0", "globals": "^16.4.0", "hjson": "^3.2.2", @@ -759,6 +759,15 @@ "node": ">=20.11.0" } }, + "node_modules/@es-joy/resolve.exports": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/@es-joy/resolve.exports/-/resolve.exports-1.0.0.tgz", + "integrity": "sha512-bbrmzsAZ9GA/3oBS6r8PWMtZarEhKHr413hak8ArwMEZ5DtaLErnkcyEWUsXy7urBcmVu/TpDzHPDVM5uIbx9A==", + "dev": true, + "engines": { + "node": ">=10" + } + }, "node_modules/@eslint-community/eslint-utils": { "version": "4.8.0", "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.8.0.tgz", @@ -3307,12 +3316,13 @@ } }, "node_modules/eslint-plugin-jsdoc": { - "version": "61.1.5", - "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-61.1.5.tgz", - "integrity": "sha512-UZ+7M6WVFBVRTxHZURxYP7M++M+ZEjxPGB/CScdrKAhzpf/LWS1HaNRHMOkISkOTTggMhwRwgKmVlTLQryXV2Q==", + "version": "61.1.9", + "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-61.1.9.tgz", + "integrity": "sha512-X2AzSGbq1CzBRgKcVAu2qzOV9ogqygkUDk5AX6eNK5G+kY3I5Op5E5b99fE+FN0/bGnk2KGcsMIG6ZLF+di69A==", "dev": true, "dependencies": { "@es-joy/jsdoccomment": "~0.76.0", + "@es-joy/resolve.exports": "1.0.0", "are-docs-informative": "^0.0.2", "comment-parser": "1.4.1", "debug": "^4.4.3", @@ -8339,6 +8349,12 @@ "jsdoc-type-pratt-parser": "~6.10.0" } }, + "@es-joy/resolve.exports": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/@es-joy/resolve.exports/-/resolve.exports-1.0.0.tgz", + "integrity": "sha512-bbrmzsAZ9GA/3oBS6r8PWMtZarEhKHr413hak8ArwMEZ5DtaLErnkcyEWUsXy7urBcmVu/TpDzHPDVM5uIbx9A==", + "dev": true + }, "@eslint-community/eslint-utils": { "version": "4.8.0", "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.8.0.tgz", @@ -10254,12 +10270,13 @@ "requires": {} }, "eslint-plugin-jsdoc": { - "version": "61.1.5", - "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-61.1.5.tgz", - "integrity": "sha512-UZ+7M6WVFBVRTxHZURxYP7M++M+ZEjxPGB/CScdrKAhzpf/LWS1HaNRHMOkISkOTTggMhwRwgKmVlTLQryXV2Q==", + "version": "61.1.9", + "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-61.1.9.tgz", + "integrity": "sha512-X2AzSGbq1CzBRgKcVAu2qzOV9ogqygkUDk5AX6eNK5G+kY3I5Op5E5b99fE+FN0/bGnk2KGcsMIG6ZLF+di69A==", "dev": true, "requires": { "@es-joy/jsdoccomment": "~0.76.0", + "@es-joy/resolve.exports": "1.0.0", "are-docs-informative": "^0.0.2", "comment-parser": "1.4.1", "debug": "^4.4.3", diff --git a/package.json b/package.json index 735c84ba0f66f..ad889711a4045 100644 --- a/package.json +++ b/package.json @@ -47,7 +47,7 @@ "color-contrast-checker": "^2.1.0", "eslint": "^9.38.0", "eslint-config-prettier": "^10.1.8", - "eslint-plugin-jsdoc": "^61.1.5", + "eslint-plugin-jsdoc": "^61.1.9", "express": "^5.1.0", "globals": "^16.4.0", "hjson": "^3.2.2", From b18d03defd6e77aa695a28e8f5010576e1986b14 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 31 Oct 2025 18:38:34 +0200 Subject: [PATCH 233/265] ci(deps): bump actions/upload-artifact from 4.6.2 to 5.0.0 (#4625) Bumps [actions/upload-artifact](https://github.com/actions/upload-artifact) from 4.6.2 to 5.0.0. - [Release notes](https://github.com/actions/upload-artifact/releases) - [Commits](https://github.com/actions/upload-artifact/compare/ea165f8d65b6e75b540449e92b4886f43607fa02...330a01c490aca151604b8cf639adc76d48f6c5d4) --- updated-dependencies: - dependency-name: actions/upload-artifact dependency-version: 5.0.0 dependency-type: direct:production update-type: version-update:semver-major ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- .github/workflows/ossf-analysis.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/ossf-analysis.yml b/.github/workflows/ossf-analysis.yml index 832a9d6f1234c..4ccd0e31964ee 100644 --- a/.github/workflows/ossf-analysis.yml +++ b/.github/workflows/ossf-analysis.yml @@ -36,7 +36,7 @@ jobs: # Upload the results as artifacts (optional). Commenting out will disable uploads of run results in SARIF # format to the repository Actions tab. - name: "Upload artifact" - uses: actions/upload-artifact@ea165f8d65b6e75b540449e92b4886f43607fa02 # v4.6.2 + uses: actions/upload-artifact@330a01c490aca151604b8cf639adc76d48f6c5d4 # v5.0.0 with: name: SARIF file path: results.sarif From f744de1f0c6e580481b93dbaf61c56593168f75a Mon Sep 17 00:00:00 2001 From: "github-actions[bot]" <41898282+github-actions[bot]@users.noreply.github.com> Date: Fri, 31 Oct 2025 18:41:11 +0200 Subject: [PATCH 234/265] refactor: update languages JSON (#4630) Co-authored-by: qwerty541 <53787217+qwerty541@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- src/common/languageColors.json | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/src/common/languageColors.json b/src/common/languageColors.json index 28d778ff591f1..9d6b0fa287671 100644 --- a/src/common/languageColors.json +++ b/src/common/languageColors.json @@ -31,6 +31,7 @@ "Apollo Guidance Computer": "#0B3D91", "AppleScript": "#101F1F", "Arc": "#aa2afe", + "ArkTS": "#0080ff", "AsciiDoc": "#73a0c5", "AspectJ": "#a957b0", "Assembly": "#6E4C13", @@ -85,6 +86,7 @@ "Cairo": "#ff4a48", "Cairo Zero": "#ff4a48", "CameLIGO": "#3be133", + "Cangjie": "#00868B", "Cap'n Proto": "#c42727", "Carbon": "#222222", "Ceylon": "#dfa535", @@ -198,6 +200,7 @@ "Gerber Image": "#d20b00", "Gherkin": "#5B2063", "Git Attributes": "#F44D27", + "Git Commit": "#F44D27", "Git Config": "#F44D27", "Git Revision List": "#F44D27", "Gleam": "#ffaff3", @@ -243,6 +246,7 @@ "HiveQL": "#dce200", "HolyC": "#ffefaf", "Hosts File": "#308888", + "Hurl": "#FF0288", "Hy": "#7790B2", "IDL": "#a3522f", "IGOR Pro": "#0000cc", @@ -294,7 +298,7 @@ "KiCad Layout": "#2f4aab", "KiCad Legacy Layout": "#2f4aab", "KiCad Schematic": "#2f4aab", - "KoLMafia ASH": "#B9D9B9", + "KoLmafia ASH": "#B9D9B9", "Koka": "#215166", "Kotlin": "#A97BFF", "LFE": "#4C3023", @@ -334,7 +338,6 @@ "Markdown": "#083fa1", "Marko": "#42bff2", "Mask": "#f97732", - "Mathematica": "#dd1100", "Max": "#c4a79c", "Mercury": "#ff2b2b", "Mermaid": "#ff3670", @@ -550,6 +553,7 @@ "Talon": "#333333", "Tcl": "#e4cc98", "TeX": "#3D6117", + "Teal": "#00B1BC", "Terra": "#00004c", "Terraform Template": "#7b42bb", "TextGrid": "#c8506d", @@ -597,6 +601,7 @@ "Wikitext": "#fc5757", "Windows Registry Entries": "#52d5ff", "Witcher Script": "#ff0000", + "Wolfram Language": "#dd1100", "Wollok": "#a23738", "World of Warcraft Addon Data": "#f7e43f", "Wren": "#383838", From 549ed26d72de2a672322c132797334de1543f1a0 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 7 Nov 2025 17:56:10 +0200 Subject: [PATCH 235/265] ci(deps): Bump bahmutov/npm-install from 1.11.1 to 1.11.2 (#4637) Bumps [bahmutov/npm-install](https://github.com/bahmutov/npm-install) from 1.11.1 to 1.11.2. - [Release notes](https://github.com/bahmutov/npm-install/releases) - [Commits](https://github.com/bahmutov/npm-install/compare/4488656f8e90d3c85e3a964db0018dd624f340e7...3e063b974f0d209807684aa23e534b3dde517fd9) --- updated-dependencies: - dependency-name: bahmutov/npm-install dependency-version: 1.11.2 dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- .github/workflows/preview-theme.yml | 2 +- .github/workflows/stale-theme-pr-closer.yml | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/preview-theme.yml b/.github/workflows/preview-theme.yml index cf16caed1167f..e2b3264165c83 100644 --- a/.github/workflows/preview-theme.yml +++ b/.github/workflows/preview-theme.yml @@ -41,7 +41,7 @@ jobs: node-version: ${{ matrix.node-version }} cache: npm - - uses: bahmutov/npm-install@4488656f8e90d3c85e3a964db0018dd624f340e7 # v1.11.1 + - uses: bahmutov/npm-install@3e063b974f0d209807684aa23e534b3dde517fd9 # v1.11.2 with: useLockFile: false diff --git a/.github/workflows/stale-theme-pr-closer.yml b/.github/workflows/stale-theme-pr-closer.yml index 18061309a6b6b..a93e9d9e871ca 100644 --- a/.github/workflows/stale-theme-pr-closer.yml +++ b/.github/workflows/stale-theme-pr-closer.yml @@ -47,7 +47,7 @@ jobs: node-version: ${{ matrix.node-version }} cache: npm - - uses: bahmutov/npm-install@4488656f8e90d3c85e3a964db0018dd624f340e7 # v1.11.1 + - uses: bahmutov/npm-install@3e063b974f0d209807684aa23e534b3dde517fd9 # v1.11.2 with: useLockFile: false From a625dab7db2ba25fd99ffc8d6ebaac3ad6e68517 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 7 Nov 2025 17:58:28 +0200 Subject: [PATCH 236/265] build(deps-dev): Bump @eslint/js from 9.38.0 to 9.39.0 (#4636) Bumps [@eslint/js](https://github.com/eslint/eslint/tree/HEAD/packages/js) from 9.38.0 to 9.39.0. - [Release notes](https://github.com/eslint/eslint/releases) - [Commits](https://github.com/eslint/eslint/commits/v9.39.0/packages/js) --- updated-dependencies: - dependency-name: "@eslint/js" dependency-version: 9.39.0 dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- package-lock.json | 32 +++++++++++++++++++++++++------- package.json | 2 +- 2 files changed, 26 insertions(+), 8 deletions(-) diff --git a/package-lock.json b/package-lock.json index 2ee0d2fc51451..9f8f2a9a72bc6 100644 --- a/package-lock.json +++ b/package-lock.json @@ -19,7 +19,7 @@ "@actions/core": "^1.11.1", "@actions/github": "^6.0.1", "@eslint/eslintrc": "^3.3.1", - "@eslint/js": "^9.38.0", + "@eslint/js": "^9.39.0", "@testing-library/dom": "^10.4.1", "@testing-library/jest-dom": "^6.9.1", "@uppercod/css-to-object": "^1.1.1", @@ -870,9 +870,9 @@ } }, "node_modules/@eslint/js": { - "version": "9.38.0", - "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.38.0.tgz", - "integrity": "sha512-UZ1VpFvXf9J06YG9xQBdnzU+kthors6KjhMAl6f4gH4usHyh31rUf2DLGInT8RFYIReYXNSydgPY0V2LuWgl7A==", + "version": "9.39.0", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.39.0.tgz", + "integrity": "sha512-BIhe0sW91JGPiaF1mOuPy5v8NflqfjIcDNpC+LbW9f609WVRX1rArrhi6Z2ymvrAry9jw+5POTj4t2t62o8Bmw==", "dev": true, "engines": { "node": "^18.18.0 || ^20.9.0 || >=21.1.0" @@ -3396,6 +3396,18 @@ "url": "https://opencollective.com/eslint" } }, + "node_modules/eslint/node_modules/@eslint/js": { + "version": "9.38.0", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.38.0.tgz", + "integrity": "sha512-UZ1VpFvXf9J06YG9xQBdnzU+kthors6KjhMAl6f4gH4usHyh31rUf2DLGInT8RFYIReYXNSydgPY0V2LuWgl7A==", + "dev": true, + "engines": { + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" + }, + "funding": { + "url": "https://eslint.org/donate" + } + }, "node_modules/eslint/node_modules/escape-string-regexp": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", @@ -8425,9 +8437,9 @@ } }, "@eslint/js": { - "version": "9.38.0", - "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.38.0.tgz", - "integrity": "sha512-UZ1VpFvXf9J06YG9xQBdnzU+kthors6KjhMAl6f4gH4usHyh31rUf2DLGInT8RFYIReYXNSydgPY0V2LuWgl7A==", + "version": "9.39.0", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.39.0.tgz", + "integrity": "sha512-BIhe0sW91JGPiaF1mOuPy5v8NflqfjIcDNpC+LbW9f609WVRX1rArrhi6Z2ymvrAry9jw+5POTj4t2t62o8Bmw==", "dev": true }, "@eslint/object-schema": { @@ -10206,6 +10218,12 @@ "optionator": "^0.9.3" }, "dependencies": { + "@eslint/js": { + "version": "9.38.0", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.38.0.tgz", + "integrity": "sha512-UZ1VpFvXf9J06YG9xQBdnzU+kthors6KjhMAl6f4gH4usHyh31rUf2DLGInT8RFYIReYXNSydgPY0V2LuWgl7A==", + "dev": true + }, "escape-string-regexp": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", diff --git a/package.json b/package.json index ad889711a4045..86e3742c363ab 100644 --- a/package.json +++ b/package.json @@ -39,7 +39,7 @@ "@actions/core": "^1.11.1", "@actions/github": "^6.0.1", "@eslint/eslintrc": "^3.3.1", - "@eslint/js": "^9.38.0", + "@eslint/js": "^9.39.0", "@testing-library/dom": "^10.4.1", "@testing-library/jest-dom": "^6.9.1", "@uppercod/css-to-object": "^1.1.1", From d1912d0665173284b56a578b8964cffeb0a53c9b Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 7 Nov 2025 18:00:40 +0200 Subject: [PATCH 237/265] build(deps-dev): Bump globals from 16.4.0 to 16.5.0 (#4634) Bumps [globals](https://github.com/sindresorhus/globals) from 16.4.0 to 16.5.0. - [Release notes](https://github.com/sindresorhus/globals/releases) - [Commits](https://github.com/sindresorhus/globals/compare/v16.4.0...v16.5.0) --- updated-dependencies: - dependency-name: globals dependency-version: 16.5.0 dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- package-lock.json | 14 +++++++------- package.json | 2 +- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/package-lock.json b/package-lock.json index 9f8f2a9a72bc6..5a59acef442a1 100644 --- a/package-lock.json +++ b/package-lock.json @@ -29,7 +29,7 @@ "eslint-config-prettier": "^10.1.8", "eslint-plugin-jsdoc": "^61.1.9", "express": "^5.1.0", - "globals": "^16.4.0", + "globals": "^16.5.0", "hjson": "^3.2.2", "husky": "^9.1.7", "jest": "^30.2.0", @@ -4068,9 +4068,9 @@ } }, "node_modules/globals": { - "version": "16.4.0", - "resolved": "https://registry.npmjs.org/globals/-/globals-16.4.0.tgz", - "integrity": "sha512-ob/2LcVVaVGCYN+r14cnwnoDPUufjiYgSqRhiFD0Q1iI4Odora5RE8Iv1D24hAz5oMophRGkGz+yuvQmmUMnMw==", + "version": "16.5.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-16.5.0.tgz", + "integrity": "sha512-c/c15i26VrJ4IRt5Z89DnIzCGDn9EcebibhAOjw5ibqEHsE1wLUgkPn9RDmNcUKyU87GeaL633nyJ+pplFR2ZQ==", "dev": true, "engines": { "node": ">=18" @@ -10750,9 +10750,9 @@ } }, "globals": { - "version": "16.4.0", - "resolved": "https://registry.npmjs.org/globals/-/globals-16.4.0.tgz", - "integrity": "sha512-ob/2LcVVaVGCYN+r14cnwnoDPUufjiYgSqRhiFD0Q1iI4Odora5RE8Iv1D24hAz5oMophRGkGz+yuvQmmUMnMw==", + "version": "16.5.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-16.5.0.tgz", + "integrity": "sha512-c/c15i26VrJ4IRt5Z89DnIzCGDn9EcebibhAOjw5ibqEHsE1wLUgkPn9RDmNcUKyU87GeaL633nyJ+pplFR2ZQ==", "dev": true }, "gopd": { diff --git a/package.json b/package.json index 86e3742c363ab..34ad2c4f2c913 100644 --- a/package.json +++ b/package.json @@ -49,7 +49,7 @@ "eslint-config-prettier": "^10.1.8", "eslint-plugin-jsdoc": "^61.1.9", "express": "^5.1.0", - "globals": "^16.4.0", + "globals": "^16.5.0", "hjson": "^3.2.2", "husky": "^9.1.7", "jest": "^30.2.0", From 2a552410ff544305d64f178c6f8f8df8dfe3b8d7 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 7 Nov 2025 18:05:38 +0200 Subject: [PATCH 238/265] build(deps-dev): Bump eslint from 9.38.0 to 9.39.0 (#4632) * build(deps-dev): Bump eslint from 9.38.0 to 9.39.0 Bumps [eslint](https://github.com/eslint/eslint) from 9.38.0 to 9.39.0. - [Release notes](https://github.com/eslint/eslint/releases) - [Commits](https://github.com/eslint/eslint/compare/v9.38.0...v9.39.0) --- updated-dependencies: - dependency-name: eslint dependency-version: 9.39.0 dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] * dev --------- Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- package-lock.json | 104 +++++++++++++++++++--------------------------- package.json | 2 +- 2 files changed, 44 insertions(+), 62 deletions(-) diff --git a/package-lock.json b/package-lock.json index 5a59acef442a1..97348206960db 100644 --- a/package-lock.json +++ b/package-lock.json @@ -25,7 +25,7 @@ "@uppercod/css-to-object": "^1.1.1", "axios-mock-adapter": "^2.1.0", "color-contrast-checker": "^2.1.0", - "eslint": "^9.38.0", + "eslint": "^9.39.0", "eslint-config-prettier": "^10.1.8", "eslint-plugin-jsdoc": "^61.1.9", "express": "^5.1.0", @@ -810,21 +810,21 @@ } }, "node_modules/@eslint/config-helpers": { - "version": "0.4.1", - "resolved": "https://registry.npmjs.org/@eslint/config-helpers/-/config-helpers-0.4.1.tgz", - "integrity": "sha512-csZAzkNhsgwb0I/UAV6/RGFTbiakPCf0ZrGmrIxQpYvGZ00PhTkSnyKNolphgIvmnJeGw6rcGVEXfTzUnFuEvw==", + "version": "0.4.2", + "resolved": "https://registry.npmjs.org/@eslint/config-helpers/-/config-helpers-0.4.2.tgz", + "integrity": "sha512-gBrxN88gOIf3R7ja5K9slwNayVcZgK6SOUORm2uBzTeIEfeVaIhOpCtTox3P6R7o2jLFwLFTLnC7kU/RGcYEgw==", "dev": true, "dependencies": { - "@eslint/core": "^0.16.0" + "@eslint/core": "^0.17.0" }, "engines": { "node": "^18.18.0 || ^20.9.0 || >=21.1.0" } }, "node_modules/@eslint/core": { - "version": "0.16.0", - "resolved": "https://registry.npmjs.org/@eslint/core/-/core-0.16.0.tgz", - "integrity": "sha512-nmC8/totwobIiFcGkDza3GIKfAw1+hLiYVrh3I1nIomQ8PEr5cxg34jnkmGawul/ep52wGRAcyeDCNtWKSOj4Q==", + "version": "0.17.0", + "resolved": "https://registry.npmjs.org/@eslint/core/-/core-0.17.0.tgz", + "integrity": "sha512-yL/sLrpmtDaFEiUj1osRP4TI2MDz1AddJL+jZ7KSqvBuliN4xqYY54IfdN8qD8Toa6g1iloph1fxQNkjOxrrpQ==", "dev": true, "dependencies": { "@types/json-schema": "^7.0.15" @@ -870,9 +870,9 @@ } }, "node_modules/@eslint/js": { - "version": "9.39.0", - "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.39.0.tgz", - "integrity": "sha512-BIhe0sW91JGPiaF1mOuPy5v8NflqfjIcDNpC+LbW9f609WVRX1rArrhi6Z2ymvrAry9jw+5POTj4t2t62o8Bmw==", + "version": "9.39.1", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.39.1.tgz", + "integrity": "sha512-S26Stp4zCy88tH94QbBv3XCuzRQiZ9yXofEILmglYTh/Ug/a9/umqvgFtYBAo3Lp0nsI/5/qH1CCrbdK3AP1Tw==", "dev": true, "engines": { "node": "^18.18.0 || ^20.9.0 || >=21.1.0" @@ -891,12 +891,12 @@ } }, "node_modules/@eslint/plugin-kit": { - "version": "0.4.0", - "resolved": "https://registry.npmjs.org/@eslint/plugin-kit/-/plugin-kit-0.4.0.tgz", - "integrity": "sha512-sB5uyeq+dwCWyPi31B2gQlVlo+j5brPlWx4yZBrEaRo/nhdDE8Xke1gsGgtiBdaBTxuTkceLVuVt/pclrasb0A==", + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/@eslint/plugin-kit/-/plugin-kit-0.4.1.tgz", + "integrity": "sha512-43/qtrDUokr7LJqoF2c3+RInu/t4zfrpYdoSDfYyhg52rwLV6TnOvdG4fXm7IkSB3wErkcmJS9iEhjVtOSEjjA==", "dev": true, "dependencies": { - "@eslint/core": "^0.16.0", + "@eslint/core": "^0.17.0", "levn": "^0.4.1" }, "engines": { @@ -3242,19 +3242,19 @@ } }, "node_modules/eslint": { - "version": "9.38.0", - "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.38.0.tgz", - "integrity": "sha512-t5aPOpmtJcZcz5UJyY2GbvpDlsK5E8JqRqoKtfiKE3cNh437KIqfJr3A3AKf5k64NPx6d0G3dno6XDY05PqPtw==", + "version": "9.39.1", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.39.1.tgz", + "integrity": "sha512-BhHmn2yNOFA9H9JmmIVKJmd288g9hrVRDkdoIgRCRuSySRUHH7r/DI6aAXW9T1WwUuY3DFgrcaqB+deURBLR5g==", "dev": true, "dependencies": { "@eslint-community/eslint-utils": "^4.8.0", "@eslint-community/regexpp": "^4.12.1", "@eslint/config-array": "^0.21.1", - "@eslint/config-helpers": "^0.4.1", - "@eslint/core": "^0.16.0", + "@eslint/config-helpers": "^0.4.2", + "@eslint/core": "^0.17.0", "@eslint/eslintrc": "^3.3.1", - "@eslint/js": "9.38.0", - "@eslint/plugin-kit": "^0.4.0", + "@eslint/js": "9.39.1", + "@eslint/plugin-kit": "^0.4.1", "@humanfs/node": "^0.16.6", "@humanwhocodes/module-importer": "^1.0.1", "@humanwhocodes/retry": "^0.4.2", @@ -3396,18 +3396,6 @@ "url": "https://opencollective.com/eslint" } }, - "node_modules/eslint/node_modules/@eslint/js": { - "version": "9.38.0", - "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.38.0.tgz", - "integrity": "sha512-UZ1VpFvXf9J06YG9xQBdnzU+kthors6KjhMAl6f4gH4usHyh31rUf2DLGInT8RFYIReYXNSydgPY0V2LuWgl7A==", - "dev": true, - "engines": { - "node": "^18.18.0 || ^20.9.0 || >=21.1.0" - }, - "funding": { - "url": "https://eslint.org/donate" - } - }, "node_modules/eslint/node_modules/escape-string-regexp": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", @@ -8394,18 +8382,18 @@ } }, "@eslint/config-helpers": { - "version": "0.4.1", - "resolved": "https://registry.npmjs.org/@eslint/config-helpers/-/config-helpers-0.4.1.tgz", - "integrity": "sha512-csZAzkNhsgwb0I/UAV6/RGFTbiakPCf0ZrGmrIxQpYvGZ00PhTkSnyKNolphgIvmnJeGw6rcGVEXfTzUnFuEvw==", + "version": "0.4.2", + "resolved": "https://registry.npmjs.org/@eslint/config-helpers/-/config-helpers-0.4.2.tgz", + "integrity": "sha512-gBrxN88gOIf3R7ja5K9slwNayVcZgK6SOUORm2uBzTeIEfeVaIhOpCtTox3P6R7o2jLFwLFTLnC7kU/RGcYEgw==", "dev": true, "requires": { - "@eslint/core": "^0.16.0" + "@eslint/core": "^0.17.0" } }, "@eslint/core": { - "version": "0.16.0", - "resolved": "https://registry.npmjs.org/@eslint/core/-/core-0.16.0.tgz", - "integrity": "sha512-nmC8/totwobIiFcGkDza3GIKfAw1+hLiYVrh3I1nIomQ8PEr5cxg34jnkmGawul/ep52wGRAcyeDCNtWKSOj4Q==", + "version": "0.17.0", + "resolved": "https://registry.npmjs.org/@eslint/core/-/core-0.17.0.tgz", + "integrity": "sha512-yL/sLrpmtDaFEiUj1osRP4TI2MDz1AddJL+jZ7KSqvBuliN4xqYY54IfdN8qD8Toa6g1iloph1fxQNkjOxrrpQ==", "dev": true, "requires": { "@types/json-schema": "^7.0.15" @@ -8437,9 +8425,9 @@ } }, "@eslint/js": { - "version": "9.39.0", - "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.39.0.tgz", - "integrity": "sha512-BIhe0sW91JGPiaF1mOuPy5v8NflqfjIcDNpC+LbW9f609WVRX1rArrhi6Z2ymvrAry9jw+5POTj4t2t62o8Bmw==", + "version": "9.39.1", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.39.1.tgz", + "integrity": "sha512-S26Stp4zCy88tH94QbBv3XCuzRQiZ9yXofEILmglYTh/Ug/a9/umqvgFtYBAo3Lp0nsI/5/qH1CCrbdK3AP1Tw==", "dev": true }, "@eslint/object-schema": { @@ -8449,12 +8437,12 @@ "dev": true }, "@eslint/plugin-kit": { - "version": "0.4.0", - "resolved": "https://registry.npmjs.org/@eslint/plugin-kit/-/plugin-kit-0.4.0.tgz", - "integrity": "sha512-sB5uyeq+dwCWyPi31B2gQlVlo+j5brPlWx4yZBrEaRo/nhdDE8Xke1gsGgtiBdaBTxuTkceLVuVt/pclrasb0A==", + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/@eslint/plugin-kit/-/plugin-kit-0.4.1.tgz", + "integrity": "sha512-43/qtrDUokr7LJqoF2c3+RInu/t4zfrpYdoSDfYyhg52rwLV6TnOvdG4fXm7IkSB3wErkcmJS9iEhjVtOSEjjA==", "dev": true, "requires": { - "@eslint/core": "^0.16.0", + "@eslint/core": "^0.17.0", "levn": "^0.4.1" } }, @@ -10177,19 +10165,19 @@ "dev": true }, "eslint": { - "version": "9.38.0", - "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.38.0.tgz", - "integrity": "sha512-t5aPOpmtJcZcz5UJyY2GbvpDlsK5E8JqRqoKtfiKE3cNh437KIqfJr3A3AKf5k64NPx6d0G3dno6XDY05PqPtw==", + "version": "9.39.1", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.39.1.tgz", + "integrity": "sha512-BhHmn2yNOFA9H9JmmIVKJmd288g9hrVRDkdoIgRCRuSySRUHH7r/DI6aAXW9T1WwUuY3DFgrcaqB+deURBLR5g==", "dev": true, "requires": { "@eslint-community/eslint-utils": "^4.8.0", "@eslint-community/regexpp": "^4.12.1", "@eslint/config-array": "^0.21.1", - "@eslint/config-helpers": "^0.4.1", - "@eslint/core": "^0.16.0", + "@eslint/config-helpers": "^0.4.2", + "@eslint/core": "^0.17.0", "@eslint/eslintrc": "^3.3.1", - "@eslint/js": "9.38.0", - "@eslint/plugin-kit": "^0.4.0", + "@eslint/js": "9.39.1", + "@eslint/plugin-kit": "^0.4.1", "@humanfs/node": "^0.16.6", "@humanwhocodes/module-importer": "^1.0.1", "@humanwhocodes/retry": "^0.4.2", @@ -10218,12 +10206,6 @@ "optionator": "^0.9.3" }, "dependencies": { - "@eslint/js": { - "version": "9.38.0", - "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.38.0.tgz", - "integrity": "sha512-UZ1VpFvXf9J06YG9xQBdnzU+kthors6KjhMAl6f4gH4usHyh31rUf2DLGInT8RFYIReYXNSydgPY0V2LuWgl7A==", - "dev": true - }, "escape-string-regexp": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", diff --git a/package.json b/package.json index 34ad2c4f2c913..7b81e98405f17 100644 --- a/package.json +++ b/package.json @@ -45,7 +45,7 @@ "@uppercod/css-to-object": "^1.1.1", "axios-mock-adapter": "^2.1.0", "color-contrast-checker": "^2.1.0", - "eslint": "^9.38.0", + "eslint": "^9.39.0", "eslint-config-prettier": "^10.1.8", "eslint-plugin-jsdoc": "^61.1.9", "express": "^5.1.0", From ec8b25f1cbd467e0551dce3c37e8b7e5cc26a02f Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 7 Nov 2025 18:07:28 +0200 Subject: [PATCH 239/265] build(deps-dev): Bump eslint-plugin-jsdoc from 61.1.9 to 61.1.12 (#4633) Bumps [eslint-plugin-jsdoc](https://github.com/gajus/eslint-plugin-jsdoc) from 61.1.9 to 61.1.12. - [Release notes](https://github.com/gajus/eslint-plugin-jsdoc/releases) - [Changelog](https://github.com/gajus/eslint-plugin-jsdoc/blob/main/.releaserc) - [Commits](https://github.com/gajus/eslint-plugin-jsdoc/compare/v61.1.9...v61.1.12) --- updated-dependencies: - dependency-name: eslint-plugin-jsdoc dependency-version: 61.1.12 dependency-type: direct:development update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- package-lock.json | 30 +++++++++++++++--------------- package.json | 2 +- 2 files changed, 16 insertions(+), 16 deletions(-) diff --git a/package-lock.json b/package-lock.json index 97348206960db..8136d23f16f99 100644 --- a/package-lock.json +++ b/package-lock.json @@ -27,7 +27,7 @@ "color-contrast-checker": "^2.1.0", "eslint": "^9.39.0", "eslint-config-prettier": "^10.1.8", - "eslint-plugin-jsdoc": "^61.1.9", + "eslint-plugin-jsdoc": "^61.1.12", "express": "^5.1.0", "globals": "^16.5.0", "hjson": "^3.2.2", @@ -760,9 +760,9 @@ } }, "node_modules/@es-joy/resolve.exports": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/@es-joy/resolve.exports/-/resolve.exports-1.0.0.tgz", - "integrity": "sha512-bbrmzsAZ9GA/3oBS6r8PWMtZarEhKHr413hak8ArwMEZ5DtaLErnkcyEWUsXy7urBcmVu/TpDzHPDVM5uIbx9A==", + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/@es-joy/resolve.exports/-/resolve.exports-1.2.0.tgz", + "integrity": "sha512-Q9hjxWI5xBM+qW2enxfe8wDKdFWMfd0Z29k5ZJnuBqD/CasY5Zryj09aCA6owbGATWz+39p5uIdaHXpopOcG8g==", "dev": true, "engines": { "node": ">=10" @@ -3316,13 +3316,13 @@ } }, "node_modules/eslint-plugin-jsdoc": { - "version": "61.1.9", - "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-61.1.9.tgz", - "integrity": "sha512-X2AzSGbq1CzBRgKcVAu2qzOV9ogqygkUDk5AX6eNK5G+kY3I5Op5E5b99fE+FN0/bGnk2KGcsMIG6ZLF+di69A==", + "version": "61.1.12", + "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-61.1.12.tgz", + "integrity": "sha512-CGJTnltz7ovwOW33xYhvA4fMuriPZpR5OnJf09SV28iU2IUpJwMd6P7zvUK8Sl56u5YzO+1F9m46wpSs2dufEw==", "dev": true, "dependencies": { "@es-joy/jsdoccomment": "~0.76.0", - "@es-joy/resolve.exports": "1.0.0", + "@es-joy/resolve.exports": "1.2.0", "are-docs-informative": "^0.0.2", "comment-parser": "1.4.1", "debug": "^4.4.3", @@ -8350,9 +8350,9 @@ } }, "@es-joy/resolve.exports": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/@es-joy/resolve.exports/-/resolve.exports-1.0.0.tgz", - "integrity": "sha512-bbrmzsAZ9GA/3oBS6r8PWMtZarEhKHr413hak8ArwMEZ5DtaLErnkcyEWUsXy7urBcmVu/TpDzHPDVM5uIbx9A==", + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/@es-joy/resolve.exports/-/resolve.exports-1.2.0.tgz", + "integrity": "sha512-Q9hjxWI5xBM+qW2enxfe8wDKdFWMfd0Z29k5ZJnuBqD/CasY5Zryj09aCA6owbGATWz+39p5uIdaHXpopOcG8g==", "dev": true }, "@eslint-community/eslint-utils": { @@ -10270,13 +10270,13 @@ "requires": {} }, "eslint-plugin-jsdoc": { - "version": "61.1.9", - "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-61.1.9.tgz", - "integrity": "sha512-X2AzSGbq1CzBRgKcVAu2qzOV9ogqygkUDk5AX6eNK5G+kY3I5Op5E5b99fE+FN0/bGnk2KGcsMIG6ZLF+di69A==", + "version": "61.1.12", + "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-61.1.12.tgz", + "integrity": "sha512-CGJTnltz7ovwOW33xYhvA4fMuriPZpR5OnJf09SV28iU2IUpJwMd6P7zvUK8Sl56u5YzO+1F9m46wpSs2dufEw==", "dev": true, "requires": { "@es-joy/jsdoccomment": "~0.76.0", - "@es-joy/resolve.exports": "1.0.0", + "@es-joy/resolve.exports": "1.2.0", "are-docs-informative": "^0.0.2", "comment-parser": "1.4.1", "debug": "^4.4.3", diff --git a/package.json b/package.json index 7b81e98405f17..95ca59832e8af 100644 --- a/package.json +++ b/package.json @@ -47,7 +47,7 @@ "color-contrast-checker": "^2.1.0", "eslint": "^9.39.0", "eslint-config-prettier": "^10.1.8", - "eslint-plugin-jsdoc": "^61.1.9", + "eslint-plugin-jsdoc": "^61.1.12", "express": "^5.1.0", "globals": "^16.5.0", "hjson": "^3.2.2", From adf2a65dcc862006bc1f80e25580c8f5a6ca8504 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 7 Nov 2025 18:10:12 +0200 Subject: [PATCH 240/265] build(deps): Bump axios from 1.13.0 to 1.13.1 (#4635) * build(deps): Bump axios from 1.13.0 to 1.13.1 Bumps [axios](https://github.com/axios/axios) from 1.13.0 to 1.13.1. - [Release notes](https://github.com/axios/axios/releases) - [Changelog](https://github.com/axios/axios/blob/v1.x/CHANGELOG.md) - [Commits](https://github.com/axios/axios/compare/v1.13.0...v1.13.1) --- updated-dependencies: - dependency-name: axios dependency-version: 1.13.1 dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] * dev --------- Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- package-lock.json | 14 +++++++------- package.json | 2 +- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/package-lock.json b/package-lock.json index 8136d23f16f99..450333c46f0d5 100644 --- a/package-lock.json +++ b/package-lock.json @@ -9,7 +9,7 @@ "version": "1.0.0", "license": "MIT", "dependencies": { - "axios": "^1.13.0", + "axios": "^1.13.1", "dotenv": "^17.2.3", "emoji-name-map": "^2.0.3", "github-username-regex": "^1.0.0", @@ -2330,9 +2330,9 @@ "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==" }, "node_modules/axios": { - "version": "1.13.0", - "resolved": "https://registry.npmjs.org/axios/-/axios-1.13.0.tgz", - "integrity": "sha512-zt40Pz4zcRXra9CVV31KeyofwiNvAbJ5B6YPz9pMJ+yOSLikvPT4Yi5LjfgjRa9CawVYBaD1JQzIVcIvBejKeA==", + "version": "1.13.2", + "resolved": "https://registry.npmjs.org/axios/-/axios-1.13.2.tgz", + "integrity": "sha512-VPk9ebNqPcy5lRGuSlKx752IlDatOjT9paPlm8A7yOuW2Fbvp4X3JznJtT4f0GzGLLiWE9W8onz51SqLYwzGaA==", "dependencies": { "follow-redirects": "^1.15.6", "form-data": "^4.0.4", @@ -9513,9 +9513,9 @@ "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==" }, "axios": { - "version": "1.13.0", - "resolved": "https://registry.npmjs.org/axios/-/axios-1.13.0.tgz", - "integrity": "sha512-zt40Pz4zcRXra9CVV31KeyofwiNvAbJ5B6YPz9pMJ+yOSLikvPT4Yi5LjfgjRa9CawVYBaD1JQzIVcIvBejKeA==", + "version": "1.13.2", + "resolved": "https://registry.npmjs.org/axios/-/axios-1.13.2.tgz", + "integrity": "sha512-VPk9ebNqPcy5lRGuSlKx752IlDatOjT9paPlm8A7yOuW2Fbvp4X3JznJtT4f0GzGLLiWE9W8onz51SqLYwzGaA==", "requires": { "follow-redirects": "^1.15.6", "form-data": "^4.0.4", diff --git a/package.json b/package.json index 95ca59832e8af..c99bacc8122b9 100644 --- a/package.json +++ b/package.json @@ -61,7 +61,7 @@ "prettier": "^3.6.2" }, "dependencies": { - "axios": "^1.13.0", + "axios": "^1.13.1", "dotenv": "^17.2.3", "emoji-name-map": "^2.0.3", "github-username-regex": "^1.0.0", From 45973cf12d6c183c255cad2b8f55637153393a8a Mon Sep 17 00:00:00 2001 From: fizahmad <155020130+fizahmad@users.noreply.github.com> Date: Thu, 4 Dec 2025 03:36:11 +0500 Subject: [PATCH 241/265] docs: fixed typo in "fine-grained token" warning message (#4652) --- readme.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/readme.md b/readme.md index 78fe9ae42fb69..473fcc5a2a639 100644 --- a/readme.md +++ b/readme.md @@ -819,7 +819,7 @@ Selecting the right scopes for your token is important in case you want to displ ### Fine-grained token > [!WARNING]\ -> This limits the number of issues to the number of issues on your repositories only and only takes public commits into account. +> This limits the scope to issues in your repositories and includes only public commits. * Go to [Account -> Settings -> Developer Settings -> Personal access tokens -> Fine-grained tokens](https://github.com/settings/tokens). * Click on `Generate new token -> Generate new token`. From d1a88db5a97a920fc18c5d102b162f842d3714f1 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Sat, 6 Dec 2025 18:49:24 +0200 Subject: [PATCH 242/265] ci: temporary disable e2e tests workflow (#4684) Co-authored-by: Alexandr Garbuzov --- .github/workflows/e2e-test.yml | 19 ++++++++++++------- 1 file changed, 12 insertions(+), 7 deletions(-) diff --git a/.github/workflows/e2e-test.yml b/.github/workflows/e2e-test.yml index 022713fdafa20..e202610978afc 100644 --- a/.github/workflows/e2e-test.yml +++ b/.github/workflows/e2e-test.yml @@ -1,15 +1,20 @@ name: Test Deployment on: - deployment_status: + # Temporarily disabled automatic triggers; manual-only for now. + workflow_dispatch: + # Original trigger (restore to re-enable): + # deployment_status: permissions: read-all jobs: e2eTests: - if: - github.repository == 'anuraghazra/github-readme-stats' && - github.event_name == 'deployment_status' && - github.event.deployment_status.state == 'success' + # Temporarily disabled; set to the original condition to re-enable. + # if: + # github.repository == 'anuraghazra/github-readme-stats' && + # github.event_name == 'deployment_status' && + # github.event.deployment_status.state == 'success' + if: false name: Perform 2e2 tests runs-on: ubuntu-latest strategy: @@ -32,5 +37,5 @@ jobs: - name: Run end-to-end tests. run: npm run test:e2e - env: - VERCEL_PREVIEW_URL: ${{ github.event.deployment_status.target_url }} + # env: + # VERCEL_PREVIEW_URL: ${{ github.event.deployment_status.target_url }} From 2a626d7684572b1d6d8975b588c4acc1b2eed25f Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Sat, 6 Dec 2025 18:56:42 +0200 Subject: [PATCH 243/265] docs(readme): remove hacktoberfest notice (#4685) Co-authored-by: Alexandr Garbuzov --- readme.md | 3 --- 1 file changed, 3 deletions(-) diff --git a/readme.md b/readme.md index 473fcc5a2a639..baadc984572fc 100644 --- a/readme.md +++ b/readme.md @@ -98,9 +98,6 @@ # Important Notices -> [!IMPORTANT] -> Please note that we are NOT participating in Hacktoberfest this year. As a small team, we cannot handle the increased volume of PRs and issues that the event brings. We appreciate your understanding. - > [!IMPORTANT] > Since the GitHub API only [allows 5k requests per hour per user account](https://docs.github.com/en/graphql/overview/resource-limitations), the public Vercel instance hosted on `https://github-readme-stats.vercel.app/api` could possibly hit the rate limiter (see [#1471](https://github.com/anuraghazra/github-readme-stats/issues/1471)). We use caching to prevent this from happening (see https://github.com/anuraghazra/github-readme-stats#common-options). You can turn off these rate limit protections by [deploying your own Vercel instance](#deploy-on-your-own). From e6c560f75e8d70c49d747840f4ca09413a2d8904 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Sat, 6 Dec 2025 18:57:24 +0200 Subject: [PATCH 244/265] docs(contributing): remove hacktoberfest notice (#4686) Co-authored-by: Alexandr Garbuzov --- CONTRIBUTING.md | 3 --- 1 file changed, 3 deletions(-) diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index e72d7b9f8013c..8aafae6f58242 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -1,8 +1,5 @@ # Contributing to [github-readme-stats](https://github.com/anuraghazra/github-readme-stats) -> [!IMPORTANT] -> Please note that we are NOT participating in Hacktoberfest this year. As a small team, we cannot handle the increased volume of PRs and issues that the event brings. We appreciate your understanding. - We love your input! We want to make contributing to this project as easy and transparent as possible, whether it's: - Reporting [an issue](https://github.com/anuraghazra/github-readme-stats/issues/new?assignees=&labels=bug&template=bug_report.yml). From daa8ee3ce05a1db1792ba4b68fc7884f3f3e52b7 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Sat, 6 Dec 2025 20:16:22 +0200 Subject: [PATCH 245/265] build(deps-dev): Bump express from 5.1.0 to 5.2.0 (#4667) Bumps [express](https://github.com/expressjs/express) from 5.1.0 to 5.2.0. - [Release notes](https://github.com/expressjs/express/releases) - [Changelog](https://github.com/expressjs/express/blob/master/History.md) - [Commits](https://github.com/expressjs/express/compare/v5.1.0...v5.2.0) --- updated-dependencies: - dependency-name: express dependency-version: 5.2.0 dependency-type: direct:development ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- package-lock.json | 198 +++++++++++++++++++++++----------------------- package.json | 2 +- 2 files changed, 102 insertions(+), 98 deletions(-) diff --git a/package-lock.json b/package-lock.json index 450333c46f0d5..dc2dcbd74fe8e 100644 --- a/package-lock.json +++ b/package-lock.json @@ -28,7 +28,7 @@ "eslint": "^9.39.0", "eslint-config-prettier": "^10.1.8", "eslint-plugin-jsdoc": "^61.1.12", - "express": "^5.1.0", + "express": "^5.2.0", "globals": "^16.5.0", "hjson": "^3.2.2", "husky": "^9.1.7", @@ -2466,24 +2466,43 @@ "license": "Apache-2.0" }, "node_modules/body-parser": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-2.2.0.tgz", - "integrity": "sha512-02qvAaxv8tp7fBa/mw1ga98OGm+eCbqzJOKoRt70sLmfEEi+jyBYVTDGfCL/k06/4EMk/z01gCe7HoCH/f2LTg==", + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-2.2.1.tgz", + "integrity": "sha512-nfDwkulwiZYQIGwxdy0RUmowMhKcFVcYXUU7m4QlKYim1rUtg83xm2yjZ40QjDuc291AJjjeSc9b++AWHSgSHw==", "dev": true, - "license": "MIT", "dependencies": { "bytes": "^3.1.2", "content-type": "^1.0.5", - "debug": "^4.4.0", + "debug": "^4.4.3", "http-errors": "^2.0.0", - "iconv-lite": "^0.6.3", + "iconv-lite": "^0.7.0", "on-finished": "^2.4.1", "qs": "^6.14.0", - "raw-body": "^3.0.0", - "type-is": "^2.0.0" + "raw-body": "^3.0.1", + "type-is": "^2.0.1" }, "engines": { "node": ">=18" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/express" + } + }, + "node_modules/body-parser/node_modules/iconv-lite": { + "version": "0.7.0", + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.7.0.tgz", + "integrity": "sha512-cf6L2Ds3h57VVmkZe+Pn+5APsT7FpqJtEhhieDCvrE2MK5Qk9MyffgQyuxQTm6BChfeZNtcOLHp9IcWRVcIcBQ==", + "dev": true, + "dependencies": { + "safer-buffer": ">= 2.1.2 < 3.0.0" + }, + "engines": { + "node": ">=0.10.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/express" } }, "node_modules/brace-expansion": { @@ -2561,7 +2580,6 @@ "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==", "dev": true, - "license": "MIT", "engines": { "node": ">= 0.8" } @@ -2583,7 +2601,6 @@ "resolved": "https://registry.npmjs.org/call-bound/-/call-bound-1.0.4.tgz", "integrity": "sha512-+ys997U96po4Kx/ABpBCqhA9EuxJaQWDQg7295H4hBphv3IZg0boBKuwYpt4YXp6MZ5AmZQnU/tyMTlRpaSejg==", "dev": true, - "license": "MIT", "dependencies": { "call-bind-apply-helpers": "^1.0.2", "get-intrinsic": "^1.3.0" @@ -2888,7 +2905,6 @@ "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.5.tgz", "integrity": "sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==", "dev": true, - "license": "MIT", "engines": { "node": ">= 0.6" } @@ -3643,19 +3659,19 @@ } }, "node_modules/express": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/express/-/express-5.1.0.tgz", - "integrity": "sha512-DT9ck5YIRU+8GYzzU5kT3eHGA5iL+1Zd0EutOmTE9Dtk+Tvuzd23VBU+ec7HPNSTxXYO55gPV/hq4pSBJDjFpA==", + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/express/-/express-5.2.0.tgz", + "integrity": "sha512-XdpJDLxfztVY59X0zPI6sibRiGcxhTPXRD3IhJmjKf2jwMvkRGV1j7loB8U+heeamoU3XvihAaGRTR4aXXUN3A==", "dev": true, - "license": "MIT", "dependencies": { "accepts": "^2.0.0", - "body-parser": "^2.2.0", + "body-parser": "^2.2.1", "content-disposition": "^1.0.0", "content-type": "^1.0.5", "cookie": "^0.7.1", "cookie-signature": "^1.2.1", "debug": "^4.4.0", + "depd": "^2.0.0", "encodeurl": "^2.0.0", "escape-html": "^1.0.3", "etag": "^1.8.1", @@ -4173,30 +4189,23 @@ "dev": true }, "node_modules/http-errors": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", - "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.1.tgz", + "integrity": "sha512-4FbRdAX+bSdmo4AUFuS0WNiPz8NgFt+r8ThgNWmlrjQjt1Q7ZR9+zTlce2859x4KSXrwIsaeTqDoKQmtP8pLmQ==", "dev": true, - "license": "MIT", "dependencies": { - "depd": "2.0.0", - "inherits": "2.0.4", - "setprototypeof": "1.2.0", - "statuses": "2.0.1", - "toidentifier": "1.0.1" + "depd": "~2.0.0", + "inherits": "~2.0.4", + "setprototypeof": "~1.2.0", + "statuses": "~2.0.2", + "toidentifier": "~1.0.1" }, "engines": { "node": ">= 0.8" - } - }, - "node_modules/http-errors/node_modules/statuses": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", - "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">= 0.8" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/express" } }, "node_modules/http-proxy-agent": { @@ -5870,7 +5879,6 @@ "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-1.1.0.tgz", "integrity": "sha512-aisnrDP4GNe06UcKFnV5bfMNPBUw4jsLGaWwWfnH3v02GnBuXX2MCVn5RbrWo0j3pczUilYblq7fQ7Nw2t5XKw==", "dev": true, - "license": "MIT", "engines": { "node": ">= 0.8" } @@ -6076,7 +6084,6 @@ "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.13.4.tgz", "integrity": "sha512-W67iLl4J2EXEGTbfeHCffrjDfitvLANg0UlX3wFUUSTx92KXRFegMHUVgSqE+wvhAbi4WqjGg9czysTV2Epbew==", "dev": true, - "license": "MIT", "engines": { "node": ">= 0.4" }, @@ -6463,7 +6470,6 @@ "resolved": "https://registry.npmjs.org/qs/-/qs-6.14.0.tgz", "integrity": "sha512-YWWTjgABSKcvs/nWBi9PycY/JiPJqOD4JA6o9Sej2AtvSGarXxKC3OQSk4pAarbdQlKAh5D4FCQkJNkW+GAn3w==", "dev": true, - "license": "BSD-3-Clause", "dependencies": { "side-channel": "^1.1.0" }, @@ -6485,16 +6491,15 @@ } }, "node_modules/raw-body": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-3.0.1.tgz", - "integrity": "sha512-9G8cA+tuMS75+6G/TzW8OtLzmBDMo8p1JRxN5AZ+LAp8uxGA8V8GZm4GQ4/N5QNQEnLmg6SS7wyuSmbKepiKqA==", + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-3.0.2.tgz", + "integrity": "sha512-K5zQjDllxWkf7Z5xJdV0/B0WTNqx6vxG70zJE4N0kBs4LovmEYWJzQGxC9bS9RAKu3bgM40lrd5zoLJ12MQ5BA==", "dev": true, - "license": "MIT", "dependencies": { - "bytes": "3.1.2", - "http-errors": "2.0.0", - "iconv-lite": "0.7.0", - "unpipe": "1.0.0" + "bytes": "~3.1.2", + "http-errors": "~2.0.1", + "iconv-lite": "~0.7.0", + "unpipe": "~1.0.0" }, "engines": { "node": ">= 0.10" @@ -6505,7 +6510,6 @@ "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.7.0.tgz", "integrity": "sha512-cf6L2Ds3h57VVmkZe+Pn+5APsT7FpqJtEhhieDCvrE2MK5Qk9MyffgQyuxQTm6BChfeZNtcOLHp9IcWRVcIcBQ==", "dev": true, - "license": "MIT", "dependencies": { "safer-buffer": ">= 2.1.2 < 3.0.0" }, @@ -6787,7 +6791,6 @@ "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.1.0.tgz", "integrity": "sha512-ZX99e6tRweoUXqR+VBrslhda51Nh5MTQwou5tnUDgbtyM0dBgmhEDtWGP/xbKn6hqfPRHujUNwz5fy/wbbhnpw==", "dev": true, - "license": "MIT", "dependencies": { "es-errors": "^1.3.0", "object-inspect": "^1.13.3", @@ -6807,7 +6810,6 @@ "resolved": "https://registry.npmjs.org/side-channel-list/-/side-channel-list-1.0.0.tgz", "integrity": "sha512-FCLHtRD/gnpCiCHEiJLOwdmFP+wzCmDEkc9y7NsYxeF4u7Btsn1ZuwgwJGxImImHicJArLP4R0yX4c2KCrMrTA==", "dev": true, - "license": "MIT", "dependencies": { "es-errors": "^1.3.0", "object-inspect": "^1.13.3" @@ -6824,7 +6826,6 @@ "resolved": "https://registry.npmjs.org/side-channel-map/-/side-channel-map-1.0.1.tgz", "integrity": "sha512-VCjCNfgMsby3tTdo02nbjtM/ewra6jPHmpThenkTYh8pG9ucZ/1P8So4u4FGBek/BjpOVsDCMoLA/iuBKIFXRA==", "dev": true, - "license": "MIT", "dependencies": { "call-bound": "^1.0.2", "es-errors": "^1.3.0", @@ -6843,7 +6844,6 @@ "resolved": "https://registry.npmjs.org/side-channel-weakmap/-/side-channel-weakmap-1.0.2.tgz", "integrity": "sha512-WPS/HvHQTYnHisLo9McqBHOJk2FkHO/tlpvldyrnem4aeQp4hai3gythswg6p01oSoTl58rcpiFAjF2br2Ak2A==", "dev": true, - "license": "MIT", "dependencies": { "call-bound": "^1.0.2", "es-errors": "^1.3.0", @@ -7365,7 +7365,6 @@ "resolved": "https://registry.npmjs.org/type-is/-/type-is-2.0.1.tgz", "integrity": "sha512-OZs6gsjF4vMp32qrCbiVSkrFmXtG/AZhY3t0iAMrMBiAZyV9oALtXO8hsrHbMXF9x6L3grlFuwW2oAz7cav+Gw==", "dev": true, - "license": "MIT", "dependencies": { "content-type": "^1.0.5", "media-typer": "^1.1.0", @@ -7380,22 +7379,24 @@ "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.54.0.tgz", "integrity": "sha512-aU5EJuIN2WDemCcAp2vFBfp/m4EAhWJnUNSSw0ixs7/kXbd6Pg64EmwJkNdFhB8aWt1sH2CTXrLxo/iAGV3oPQ==", "dev": true, - "license": "MIT", "engines": { "node": ">= 0.6" } }, "node_modules/type-is/node_modules/mime-types": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-3.0.1.tgz", - "integrity": "sha512-xRc4oEhT6eaBpU1XF7AjpOFD+xQmXNB5OVKwp4tqCuBpHLS/ZbBDrc07mYTDqVMg6PfxUjjNp85O6Cd2Z/5HWA==", + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-3.0.2.tgz", + "integrity": "sha512-Lbgzdk0h4juoQ9fCKXW4by0UJqj+nOOrI9MJ1sSj4nI8aI2eo1qmvQEie4VD1glsS250n15LsWsYtCugiStS5A==", "dev": true, - "license": "MIT", "dependencies": { "mime-db": "^1.54.0" }, "engines": { - "node": ">= 0.6" + "node": ">=18" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/express" } }, "node_modules/undici": { @@ -7423,7 +7424,6 @@ "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==", "dev": true, - "license": "MIT", "engines": { "node": ">= 0.8" } @@ -9621,20 +9621,31 @@ "dev": true }, "body-parser": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-2.2.0.tgz", - "integrity": "sha512-02qvAaxv8tp7fBa/mw1ga98OGm+eCbqzJOKoRt70sLmfEEi+jyBYVTDGfCL/k06/4EMk/z01gCe7HoCH/f2LTg==", + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-2.2.1.tgz", + "integrity": "sha512-nfDwkulwiZYQIGwxdy0RUmowMhKcFVcYXUU7m4QlKYim1rUtg83xm2yjZ40QjDuc291AJjjeSc9b++AWHSgSHw==", "dev": true, "requires": { "bytes": "^3.1.2", "content-type": "^1.0.5", - "debug": "^4.4.0", + "debug": "^4.4.3", "http-errors": "^2.0.0", - "iconv-lite": "^0.6.3", + "iconv-lite": "^0.7.0", "on-finished": "^2.4.1", "qs": "^6.14.0", - "raw-body": "^3.0.0", - "type-is": "^2.0.0" + "raw-body": "^3.0.1", + "type-is": "^2.0.1" + }, + "dependencies": { + "iconv-lite": { + "version": "0.7.0", + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.7.0.tgz", + "integrity": "sha512-cf6L2Ds3h57VVmkZe+Pn+5APsT7FpqJtEhhieDCvrE2MK5Qk9MyffgQyuxQTm6BChfeZNtcOLHp9IcWRVcIcBQ==", + "dev": true, + "requires": { + "safer-buffer": ">= 2.1.2 < 3.0.0" + } + } } }, "brace-expansion": { @@ -10434,18 +10445,19 @@ } }, "express": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/express/-/express-5.1.0.tgz", - "integrity": "sha512-DT9ck5YIRU+8GYzzU5kT3eHGA5iL+1Zd0EutOmTE9Dtk+Tvuzd23VBU+ec7HPNSTxXYO55gPV/hq4pSBJDjFpA==", + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/express/-/express-5.2.0.tgz", + "integrity": "sha512-XdpJDLxfztVY59X0zPI6sibRiGcxhTPXRD3IhJmjKf2jwMvkRGV1j7loB8U+heeamoU3XvihAaGRTR4aXXUN3A==", "dev": true, "requires": { "accepts": "^2.0.0", - "body-parser": "^2.2.0", + "body-parser": "^2.2.1", "content-disposition": "^1.0.0", "content-type": "^1.0.5", "cookie": "^0.7.1", "cookie-signature": "^1.2.1", "debug": "^4.4.0", + "depd": "^2.0.0", "encodeurl": "^2.0.0", "escape-html": "^1.0.3", "etag": "^1.8.1", @@ -10803,24 +10815,16 @@ "dev": true }, "http-errors": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", - "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.1.tgz", + "integrity": "sha512-4FbRdAX+bSdmo4AUFuS0WNiPz8NgFt+r8ThgNWmlrjQjt1Q7ZR9+zTlce2859x4KSXrwIsaeTqDoKQmtP8pLmQ==", "dev": true, "requires": { - "depd": "2.0.0", - "inherits": "2.0.4", - "setprototypeof": "1.2.0", - "statuses": "2.0.1", - "toidentifier": "1.0.1" - }, - "dependencies": { - "statuses": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", - "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==", - "dev": true - } + "depd": "~2.0.0", + "inherits": "~2.0.4", + "setprototypeof": "~1.2.0", + "statuses": "~2.0.2", + "toidentifier": "~1.0.1" } }, "http-proxy-agent": { @@ -12472,15 +12476,15 @@ "dev": true }, "raw-body": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-3.0.1.tgz", - "integrity": "sha512-9G8cA+tuMS75+6G/TzW8OtLzmBDMo8p1JRxN5AZ+LAp8uxGA8V8GZm4GQ4/N5QNQEnLmg6SS7wyuSmbKepiKqA==", + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-3.0.2.tgz", + "integrity": "sha512-K5zQjDllxWkf7Z5xJdV0/B0WTNqx6vxG70zJE4N0kBs4LovmEYWJzQGxC9bS9RAKu3bgM40lrd5zoLJ12MQ5BA==", "dev": true, "requires": { - "bytes": "3.1.2", - "http-errors": "2.0.0", - "iconv-lite": "0.7.0", - "unpipe": "1.0.0" + "bytes": "~3.1.2", + "http-errors": "~2.0.1", + "iconv-lite": "~0.7.0", + "unpipe": "~1.0.0" }, "dependencies": { "iconv-lite": { @@ -13117,9 +13121,9 @@ "dev": true }, "mime-types": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-3.0.1.tgz", - "integrity": "sha512-xRc4oEhT6eaBpU1XF7AjpOFD+xQmXNB5OVKwp4tqCuBpHLS/ZbBDrc07mYTDqVMg6PfxUjjNp85O6Cd2Z/5HWA==", + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-3.0.2.tgz", + "integrity": "sha512-Lbgzdk0h4juoQ9fCKXW4by0UJqj+nOOrI9MJ1sSj4nI8aI2eo1qmvQEie4VD1glsS250n15LsWsYtCugiStS5A==", "dev": true, "requires": { "mime-db": "^1.54.0" diff --git a/package.json b/package.json index c99bacc8122b9..cbb5822690604 100644 --- a/package.json +++ b/package.json @@ -48,7 +48,7 @@ "eslint": "^9.39.0", "eslint-config-prettier": "^10.1.8", "eslint-plugin-jsdoc": "^61.1.12", - "express": "^5.1.0", + "express": "^5.2.0", "globals": "^16.5.0", "hjson": "^3.2.2", "husky": "^9.1.7", From 24c335f94224841d36fbabb243521cdff202f0a4 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Sat, 6 Dec 2025 20:18:13 +0200 Subject: [PATCH 246/265] build(deps-dev): Bump js-yaml from 4.1.0 to 4.1.1 (#4650) Bumps [js-yaml](https://github.com/nodeca/js-yaml) from 4.1.0 to 4.1.1. - [Changelog](https://github.com/nodeca/js-yaml/blob/master/CHANGELOG.md) - [Commits](https://github.com/nodeca/js-yaml/compare/4.1.0...4.1.1) --- updated-dependencies: - dependency-name: js-yaml dependency-version: 4.1.1 dependency-type: direct:development ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- package-lock.json | 14 +++++++------- package.json | 2 +- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/package-lock.json b/package-lock.json index dc2dcbd74fe8e..f65c13a39ce53 100644 --- a/package-lock.json +++ b/package-lock.json @@ -34,7 +34,7 @@ "husky": "^9.1.7", "jest": "^30.2.0", "jest-environment-jsdom": "^30.2.0", - "js-yaml": "^4.1.0", + "js-yaml": "^4.1.1", "lint-staged": "^16.2.6", "lodash.snakecase": "^4.1.1", "parse-diff": "^0.11.1", @@ -5465,9 +5465,9 @@ "dev": true }, "node_modules/js-yaml": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", - "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.1.tgz", + "integrity": "sha512-qQKT4zQxXl8lLwBtHMWwaTcGfFOZviOJet3Oy/xmGk2gZH677CJM9EvtfdSkgWcATZhj/55JZ0rmy3myCT5lsA==", "dev": true, "dependencies": { "argparse": "^2.0.1" @@ -11754,9 +11754,9 @@ "dev": true }, "js-yaml": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", - "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.1.tgz", + "integrity": "sha512-qQKT4zQxXl8lLwBtHMWwaTcGfFOZviOJet3Oy/xmGk2gZH677CJM9EvtfdSkgWcATZhj/55JZ0rmy3myCT5lsA==", "dev": true, "requires": { "argparse": "^2.0.1" diff --git a/package.json b/package.json index cbb5822690604..4f56c7e860812 100644 --- a/package.json +++ b/package.json @@ -54,7 +54,7 @@ "husky": "^9.1.7", "jest": "^30.2.0", "jest-environment-jsdom": "^30.2.0", - "js-yaml": "^4.1.0", + "js-yaml": "^4.1.1", "lint-staged": "^16.2.6", "lodash.snakecase": "^4.1.1", "parse-diff": "^0.11.1", From 453f77fd8a53701d46cd90398f9ccbde09991679 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Sat, 6 Dec 2025 20:19:52 +0200 Subject: [PATCH 247/265] build(deps): Bump glob from 10.4.5 to 10.5.0 (#4651) Bumps [glob](https://github.com/isaacs/node-glob) from 10.4.5 to 10.5.0. - [Changelog](https://github.com/isaacs/node-glob/blob/main/changelog.md) - [Commits](https://github.com/isaacs/node-glob/compare/v10.4.5...v10.5.0) --- updated-dependencies: - dependency-name: glob dependency-version: 10.5.0 dependency-type: indirect ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- package-lock.json | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/package-lock.json b/package-lock.json index f65c13a39ce53..4dbcb50f04718 100644 --- a/package-lock.json +++ b/package-lock.json @@ -4016,9 +4016,9 @@ "integrity": "sha512-EqDVkN0/5MQyDPOSDLInVRRXdeISRfcN1UW/1FUqD2knV1HHw8DndMB3UPNn5lO51DvRnjzbLXwWqNNV86PLOw==" }, "node_modules/glob": { - "version": "10.4.5", - "resolved": "https://registry.npmjs.org/glob/-/glob-10.4.5.tgz", - "integrity": "sha512-7Bv8RF0k6xjo7d4A/PxYLbUCfb6c+Vpd2/mB2yRDlew7Jb5hEXiCD9ibfO7wpk8i4sevK6DFny9h7EYbM3/sHg==", + "version": "10.5.0", + "resolved": "https://registry.npmjs.org/glob/-/glob-10.5.0.tgz", + "integrity": "sha512-DfXN8DfhJ7NH3Oe7cFmu3NCu1wKbkReJ8TorzSAFbSKrlNaQSKfIzqYqVY8zlbs2NLBbWpRiU52GX2PbaBVNkg==", "dev": true, "dependencies": { "foreground-child": "^3.1.0", @@ -10701,9 +10701,9 @@ "integrity": "sha512-EqDVkN0/5MQyDPOSDLInVRRXdeISRfcN1UW/1FUqD2knV1HHw8DndMB3UPNn5lO51DvRnjzbLXwWqNNV86PLOw==" }, "glob": { - "version": "10.4.5", - "resolved": "https://registry.npmjs.org/glob/-/glob-10.4.5.tgz", - "integrity": "sha512-7Bv8RF0k6xjo7d4A/PxYLbUCfb6c+Vpd2/mB2yRDlew7Jb5hEXiCD9ibfO7wpk8i4sevK6DFny9h7EYbM3/sHg==", + "version": "10.5.0", + "resolved": "https://registry.npmjs.org/glob/-/glob-10.5.0.tgz", + "integrity": "sha512-DfXN8DfhJ7NH3Oe7cFmu3NCu1wKbkReJ8TorzSAFbSKrlNaQSKfIzqYqVY8zlbs2NLBbWpRiU52GX2PbaBVNkg==", "dev": true, "requires": { "foreground-child": "^3.1.0", From 7b45628291691ff402fc14605a6fa21774e83a56 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Sat, 6 Dec 2025 20:22:04 +0200 Subject: [PATCH 248/265] ci(deps): Bump actions/checkout from 5.0.0 to 6.0.0 (#4653) Bumps [actions/checkout](https://github.com/actions/checkout) from 5.0.0 to 6.0.0. - [Release notes](https://github.com/actions/checkout/releases) - [Changelog](https://github.com/actions/checkout/blob/main/CHANGELOG.md) - [Commits](https://github.com/actions/checkout/compare/08c6903cd8c0fde910a37f88322edcfb5dd907a8...1af3b93b6815bc44a9784bd300feb67ff0d1eeb3) --- updated-dependencies: - dependency-name: actions/checkout dependency-version: 6.0.0 dependency-type: direct:production update-type: version-update:semver-major ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- .github/workflows/codeql-analysis.yml | 2 +- .github/workflows/deploy-prep.yml | 2 +- .github/workflows/e2e-test.yml | 2 +- .github/workflows/empty-issues-closer.yml | 2 +- .github/workflows/generate-theme-doc.yml | 2 +- .github/workflows/ossf-analysis.yml | 2 +- .github/workflows/preview-theme.yml | 2 +- .github/workflows/stale-theme-pr-closer.yml | 2 +- .github/workflows/test.yml | 2 +- .github/workflows/theme-prs-closer.yml | 2 +- .github/workflows/update-langs.yml | 2 +- 11 files changed, 11 insertions(+), 11 deletions(-) diff --git a/.github/workflows/codeql-analysis.yml b/.github/workflows/codeql-analysis.yml index b72a0e9b34409..55a74d1bd9b2b 100644 --- a/.github/workflows/codeql-analysis.yml +++ b/.github/workflows/codeql-analysis.yml @@ -31,7 +31,7 @@ jobs: steps: - name: Checkout repository - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 + uses: actions/checkout@1af3b93b6815bc44a9784bd300feb67ff0d1eeb3 # v6.0.0 # Initializes the CodeQL tools for scanning. - name: Initialize CodeQL diff --git a/.github/workflows/deploy-prep.yml b/.github/workflows/deploy-prep.yml index 7b85bac6d9955..4a62d1ccc18a3 100644 --- a/.github/workflows/deploy-prep.yml +++ b/.github/workflows/deploy-prep.yml @@ -10,7 +10,7 @@ jobs: if: github.repository == 'anuraghazra/github-readme-stats' runs-on: ubuntu-latest steps: - - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 + - uses: actions/checkout@1af3b93b6815bc44a9784bd300feb67ff0d1eeb3 # v6.0.0 - name: Deployment Prep run: python ./.github/workflows/deploy-prep.py - uses: stefanzweifel/git-auto-commit-action@28e16e81777b558cc906c8750092100bbb34c5e3 # v7.0.0 diff --git a/.github/workflows/e2e-test.yml b/.github/workflows/e2e-test.yml index e202610978afc..b43f11db56f3c 100644 --- a/.github/workflows/e2e-test.yml +++ b/.github/workflows/e2e-test.yml @@ -22,7 +22,7 @@ jobs: node-version: [22.x] steps: - - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 + - uses: actions/checkout@1af3b93b6815bc44a9784bd300feb67ff0d1eeb3 # v6.0.0 - name: Setup Node uses: actions/setup-node@2028fbc5c25fe9cf00d9f06a71cc4710d4507903 # v6.0.0 diff --git a/.github/workflows/empty-issues-closer.yml b/.github/workflows/empty-issues-closer.yml index e52dddd368dec..d2118cf90f843 100644 --- a/.github/workflows/empty-issues-closer.yml +++ b/.github/workflows/empty-issues-closer.yml @@ -27,7 +27,7 @@ jobs: runs-on: ubuntu-latest steps: # NOTE: Retrieve issue templates. - - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 + - uses: actions/checkout@1af3b93b6815bc44a9784bd300feb67ff0d1eeb3 # v6.0.0 - name: Run empty issues closer action uses: rickstaa/empty-issues-closer-action@e96914613221511279ca25f50fd4acc85e331d99 # v1.1.74 diff --git a/.github/workflows/generate-theme-doc.yml b/.github/workflows/generate-theme-doc.yml index cea17a2a13f86..c0b7de8a255b0 100644 --- a/.github/workflows/generate-theme-doc.yml +++ b/.github/workflows/generate-theme-doc.yml @@ -30,7 +30,7 @@ jobs: node-version: [22.x] steps: - - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 + - uses: actions/checkout@1af3b93b6815bc44a9784bd300feb67ff0d1eeb3 # v6.0.0 - name: Setup Node uses: actions/setup-node@2028fbc5c25fe9cf00d9f06a71cc4710d4507903 # v6.0.0 diff --git a/.github/workflows/ossf-analysis.yml b/.github/workflows/ossf-analysis.yml index 4ccd0e31964ee..5b21b6737a3ac 100644 --- a/.github/workflows/ossf-analysis.yml +++ b/.github/workflows/ossf-analysis.yml @@ -22,7 +22,7 @@ jobs: steps: - name: "Checkout code" - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 + uses: actions/checkout@1af3b93b6815bc44a9784bd300feb67ff0d1eeb3 # v6.0.0 with: persist-credentials: false diff --git a/.github/workflows/preview-theme.yml b/.github/workflows/preview-theme.yml index e2b3264165c83..14fd34c03cf6d 100644 --- a/.github/workflows/preview-theme.yml +++ b/.github/workflows/preview-theme.yml @@ -33,7 +33,7 @@ jobs: node-version: [22.x] steps: - - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 + - uses: actions/checkout@1af3b93b6815bc44a9784bd300feb67ff0d1eeb3 # v6.0.0 - name: Setup Node uses: actions/setup-node@2028fbc5c25fe9cf00d9f06a71cc4710d4507903 # v6.0.0 diff --git a/.github/workflows/stale-theme-pr-closer.yml b/.github/workflows/stale-theme-pr-closer.yml index a93e9d9e871ca..63d368701cf9f 100644 --- a/.github/workflows/stale-theme-pr-closer.yml +++ b/.github/workflows/stale-theme-pr-closer.yml @@ -39,7 +39,7 @@ jobs: node-version: [22.x] steps: - - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 + - uses: actions/checkout@1af3b93b6815bc44a9784bd300feb67ff0d1eeb3 # v6.0.0 - name: Setup Node uses: actions/setup-node@2028fbc5c25fe9cf00d9f06a71cc4710d4507903 # v6.0.0 diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 1c24dda095aac..cd1b85c3485e3 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -18,7 +18,7 @@ jobs: node-version: [22.x] steps: - - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 + - uses: actions/checkout@1af3b93b6815bc44a9784bd300feb67ff0d1eeb3 # v6.0.0 - name: Setup Node uses: actions/setup-node@2028fbc5c25fe9cf00d9f06a71cc4710d4507903 # v6.0.0 diff --git a/.github/workflows/theme-prs-closer.yml b/.github/workflows/theme-prs-closer.yml index cab367ea30d0c..63f662d735afd 100644 --- a/.github/workflows/theme-prs-closer.yml +++ b/.github/workflows/theme-prs-closer.yml @@ -23,7 +23,7 @@ jobs: runs-on: ubuntu-latest steps: - name: Check out the code - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 + uses: actions/checkout@1af3b93b6815bc44a9784bd300feb67ff0d1eeb3 # v6.0.0 - name: Set up Git run: | diff --git a/.github/workflows/update-langs.yml b/.github/workflows/update-langs.yml index 751c011d81701..4d5ee1a9fc3be 100644 --- a/.github/workflows/update-langs.yml +++ b/.github/workflows/update-langs.yml @@ -36,7 +36,7 @@ jobs: node-version: [22.x] steps: - - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 + - uses: actions/checkout@1af3b93b6815bc44a9784bd300feb67ff0d1eeb3 # v6.0.0 - name: Setup Node uses: actions/setup-node@2028fbc5c25fe9cf00d9f06a71cc4710d4507903 # v6.0.0 From 5f020e91eccf88c1b614269a32732d3d329dd319 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Sat, 6 Dec 2025 20:24:42 +0200 Subject: [PATCH 249/265] ci(deps): Bump peter-evans/create-pull-request from 7.0.8 to 7.0.9 (#4654) Bumps [peter-evans/create-pull-request](https://github.com/peter-evans/create-pull-request) from 7.0.8 to 7.0.9. - [Release notes](https://github.com/peter-evans/create-pull-request/releases) - [Commits](https://github.com/peter-evans/create-pull-request/compare/271a8d0340265f705b14b6d32b9829c1cb33d45e...84ae59a2cdc2258d6fa0732dd66352dddae2a412) --- updated-dependencies: - dependency-name: peter-evans/create-pull-request dependency-version: 7.0.9 dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- .github/workflows/update-langs.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/update-langs.yml b/.github/workflows/update-langs.yml index 4d5ee1a9fc3be..e83fece44b2ea 100644 --- a/.github/workflows/update-langs.yml +++ b/.github/workflows/update-langs.yml @@ -53,7 +53,7 @@ jobs: run: npm run generate-langs-json - name: Create Pull Request if upstream language file is changed - uses: peter-evans/create-pull-request@271a8d0340265f705b14b6d32b9829c1cb33d45e # v7.0.8 + uses: peter-evans/create-pull-request@84ae59a2cdc2258d6fa0732dd66352dddae2a412 # v7.0.9 with: commit-message: "refactor: update languages JSON" branch: "update_langs/patch" From e42de59a332aedb1f1ca37be3743de911943e897 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Sat, 6 Dec 2025 20:26:32 +0200 Subject: [PATCH 250/265] build(deps-dev): Bump lint-staged from 16.2.6 to 16.2.7 (#4655) Bumps [lint-staged](https://github.com/lint-staged/lint-staged) from 16.2.6 to 16.2.7. - [Release notes](https://github.com/lint-staged/lint-staged/releases) - [Changelog](https://github.com/lint-staged/lint-staged/blob/main/CHANGELOG.md) - [Commits](https://github.com/lint-staged/lint-staged/compare/v16.2.6...v16.2.7) --- updated-dependencies: - dependency-name: lint-staged dependency-version: 16.2.7 dependency-type: direct:development update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- package-lock.json | 30 +++++++++++++++--------------- package.json | 2 +- 2 files changed, 16 insertions(+), 16 deletions(-) diff --git a/package-lock.json b/package-lock.json index 4dbcb50f04718..dbc48a5425a37 100644 --- a/package-lock.json +++ b/package-lock.json @@ -35,7 +35,7 @@ "jest": "^30.2.0", "jest-environment-jsdom": "^30.2.0", "js-yaml": "^4.1.1", - "lint-staged": "^16.2.6", + "lint-staged": "^16.2.7", "lodash.snakecase": "^4.1.1", "parse-diff": "^0.11.1", "prettier": "^3.6.2" @@ -2864,9 +2864,9 @@ } }, "node_modules/commander": { - "version": "14.0.1", - "resolved": "https://registry.npmjs.org/commander/-/commander-14.0.1.tgz", - "integrity": "sha512-2JkV3gUZUVrbNA+1sjBOYLsMZ5cEEl8GTFP2a4AVz5hvasAMCQ1D2l2le/cX+pV4N6ZU17zjUahLpIXRrnWL8A==", + "version": "14.0.2", + "resolved": "https://registry.npmjs.org/commander/-/commander-14.0.2.tgz", + "integrity": "sha512-TywoWNNRbhoD0BXs1P3ZEScW8W5iKrnbithIl0YH+uCmBd0QpPOA8yc82DS3BIE5Ma6FnBVUsJ7wVUDz4dvOWQ==", "dev": true, "engines": { "node": ">=20" @@ -5610,12 +5610,12 @@ "dev": true }, "node_modules/lint-staged": { - "version": "16.2.6", - "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-16.2.6.tgz", - "integrity": "sha512-s1gphtDbV4bmW1eylXpVMk2u7is7YsrLl8hzrtvC70h4ByhcMLZFY01Fx05ZUDNuv1H8HO4E+e2zgejV1jVwNw==", + "version": "16.2.7", + "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-16.2.7.tgz", + "integrity": "sha512-lDIj4RnYmK7/kXMya+qJsmkRFkGolciXjrsZ6PC25GdTfWOAWetR0ZbsNXRAj1EHHImRSalc+whZFg56F5DVow==", "dev": true, "dependencies": { - "commander": "^14.0.1", + "commander": "^14.0.2", "listr2": "^9.0.5", "micromatch": "^4.0.8", "nano-spawn": "^2.0.0", @@ -9895,9 +9895,9 @@ } }, "commander": { - "version": "14.0.1", - "resolved": "https://registry.npmjs.org/commander/-/commander-14.0.1.tgz", - "integrity": "sha512-2JkV3gUZUVrbNA+1sjBOYLsMZ5cEEl8GTFP2a4AVz5hvasAMCQ1D2l2le/cX+pV4N6ZU17zjUahLpIXRrnWL8A==", + "version": "14.0.2", + "resolved": "https://registry.npmjs.org/commander/-/commander-14.0.2.tgz", + "integrity": "sha512-TywoWNNRbhoD0BXs1P3ZEScW8W5iKrnbithIl0YH+uCmBd0QpPOA8yc82DS3BIE5Ma6FnBVUsJ7wVUDz4dvOWQ==", "dev": true }, "comment-parser": { @@ -11864,12 +11864,12 @@ "dev": true }, "lint-staged": { - "version": "16.2.6", - "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-16.2.6.tgz", - "integrity": "sha512-s1gphtDbV4bmW1eylXpVMk2u7is7YsrLl8hzrtvC70h4ByhcMLZFY01Fx05ZUDNuv1H8HO4E+e2zgejV1jVwNw==", + "version": "16.2.7", + "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-16.2.7.tgz", + "integrity": "sha512-lDIj4RnYmK7/kXMya+qJsmkRFkGolciXjrsZ6PC25GdTfWOAWetR0ZbsNXRAj1EHHImRSalc+whZFg56F5DVow==", "dev": true, "requires": { - "commander": "^14.0.1", + "commander": "^14.0.2", "listr2": "^9.0.5", "micromatch": "^4.0.8", "nano-spawn": "^2.0.0", diff --git a/package.json b/package.json index 4f56c7e860812..7da3be8eb8209 100644 --- a/package.json +++ b/package.json @@ -55,7 +55,7 @@ "jest": "^30.2.0", "jest-environment-jsdom": "^30.2.0", "js-yaml": "^4.1.1", - "lint-staged": "^16.2.6", + "lint-staged": "^16.2.7", "lodash.snakecase": "^4.1.1", "parse-diff": "^0.11.1", "prettier": "^3.6.2" From 68a8dcbbdb3fc1ae3d1afd764b2ce950b04708f6 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Sat, 6 Dec 2025 20:32:21 +0200 Subject: [PATCH 251/265] build(deps-dev): Bump prettier from 3.6.2 to 3.7.3 (#4668) * build(deps-dev): Bump prettier from 3.6.2 to 3.7.3 Bumps [prettier](https://github.com/prettier/prettier) from 3.6.2 to 3.7.3. - [Release notes](https://github.com/prettier/prettier/releases) - [Changelog](https://github.com/prettier/prettier/blob/main/CHANGELOG.md) - [Commits](https://github.com/prettier/prettier/compare/3.6.2...3.7.3) --- updated-dependencies: - dependency-name: prettier dependency-version: 3.7.3 dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] * dev --------- Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- package-lock.json | 14 +++++++------- package.json | 2 +- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/package-lock.json b/package-lock.json index dbc48a5425a37..0ba250be290d0 100644 --- a/package-lock.json +++ b/package-lock.json @@ -38,7 +38,7 @@ "lint-staged": "^16.2.7", "lodash.snakecase": "^4.1.1", "parse-diff": "^0.11.1", - "prettier": "^3.6.2" + "prettier": "^3.7.3" }, "engines": { "node": ">=22" @@ -6381,9 +6381,9 @@ } }, "node_modules/prettier": { - "version": "3.6.2", - "resolved": "https://registry.npmjs.org/prettier/-/prettier-3.6.2.tgz", - "integrity": "sha512-I7AIg5boAr5R0FFtJ6rCfD+LFsWHp81dolrFD8S79U9tb8Az2nGrJncnMSnys+bpQJfRUzqs9hnA81OAA3hCuQ==", + "version": "3.7.4", + "resolved": "https://registry.npmjs.org/prettier/-/prettier-3.7.4.tgz", + "integrity": "sha512-v6UNi1+3hSlVvv8fSaoUbggEM5VErKmmpGA7Pl3HF8V6uKY7rvClBOJlH6yNwQtfTueNkGVpOv/mtWL9L4bgRA==", "dev": true, "bin": { "prettier": "bin/prettier.cjs" @@ -12409,9 +12409,9 @@ "dev": true }, "prettier": { - "version": "3.6.2", - "resolved": "https://registry.npmjs.org/prettier/-/prettier-3.6.2.tgz", - "integrity": "sha512-I7AIg5boAr5R0FFtJ6rCfD+LFsWHp81dolrFD8S79U9tb8Az2nGrJncnMSnys+bpQJfRUzqs9hnA81OAA3hCuQ==", + "version": "3.7.4", + "resolved": "https://registry.npmjs.org/prettier/-/prettier-3.7.4.tgz", + "integrity": "sha512-v6UNi1+3hSlVvv8fSaoUbggEM5VErKmmpGA7Pl3HF8V6uKY7rvClBOJlH6yNwQtfTueNkGVpOv/mtWL9L4bgRA==", "dev": true }, "pretty-format": { diff --git a/package.json b/package.json index 7da3be8eb8209..00dda29f24efb 100644 --- a/package.json +++ b/package.json @@ -58,7 +58,7 @@ "lint-staged": "^16.2.7", "lodash.snakecase": "^4.1.1", "parse-diff": "^0.11.1", - "prettier": "^3.6.2" + "prettier": "^3.7.3" }, "dependencies": { "axios": "^1.13.1", From f8a4a2626b193b879eac75fd8a09968edda756f9 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Sat, 6 Dec 2025 20:34:09 +0200 Subject: [PATCH 252/265] build(deps-dev): Bump @eslint/eslintrc from 3.3.1 to 3.3.3 (#4669) Bumps [@eslint/eslintrc](https://github.com/eslint/eslintrc) from 3.3.1 to 3.3.3. - [Release notes](https://github.com/eslint/eslintrc/releases) - [Changelog](https://github.com/eslint/eslintrc/blob/main/CHANGELOG.md) - [Commits](https://github.com/eslint/eslintrc/compare/v3.3.1...eslintrc-v3.3.3) --- updated-dependencies: - dependency-name: "@eslint/eslintrc" dependency-version: 3.3.3 dependency-type: direct:development update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- package-lock.json | 19 +++++++++---------- package.json | 2 +- 2 files changed, 10 insertions(+), 11 deletions(-) diff --git a/package-lock.json b/package-lock.json index 0ba250be290d0..134264700be0b 100644 --- a/package-lock.json +++ b/package-lock.json @@ -18,7 +18,7 @@ "devDependencies": { "@actions/core": "^1.11.1", "@actions/github": "^6.0.1", - "@eslint/eslintrc": "^3.3.1", + "@eslint/eslintrc": "^3.3.3", "@eslint/js": "^9.39.0", "@testing-library/dom": "^10.4.1", "@testing-library/jest-dom": "^6.9.1", @@ -834,11 +834,10 @@ } }, "node_modules/@eslint/eslintrc": { - "version": "3.3.1", - "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-3.3.1.tgz", - "integrity": "sha512-gtF186CXhIl1p4pJNGZw8Yc6RlshoePRvE0X91oPGb3vZ8pM3qOS9W9NGPat9LziaBV7XrJWGylNQXkGcnM3IQ==", + "version": "3.3.3", + "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-3.3.3.tgz", + "integrity": "sha512-Kr+LPIUVKz2qkx1HAMH8q1q6azbqBAsXJUxBl/ODDuVPX45Z9DfwB8tPjTi6nNZ8BuM3nbJxC5zCAg5elnBUTQ==", "dev": true, - "license": "MIT", "dependencies": { "ajv": "^6.12.4", "debug": "^4.3.2", @@ -846,7 +845,7 @@ "globals": "^14.0.0", "ignore": "^5.2.0", "import-fresh": "^3.2.1", - "js-yaml": "^4.1.0", + "js-yaml": "^4.1.1", "minimatch": "^3.1.2", "strip-json-comments": "^3.1.1" }, @@ -8400,9 +8399,9 @@ } }, "@eslint/eslintrc": { - "version": "3.3.1", - "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-3.3.1.tgz", - "integrity": "sha512-gtF186CXhIl1p4pJNGZw8Yc6RlshoePRvE0X91oPGb3vZ8pM3qOS9W9NGPat9LziaBV7XrJWGylNQXkGcnM3IQ==", + "version": "3.3.3", + "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-3.3.3.tgz", + "integrity": "sha512-Kr+LPIUVKz2qkx1HAMH8q1q6azbqBAsXJUxBl/ODDuVPX45Z9DfwB8tPjTi6nNZ8BuM3nbJxC5zCAg5elnBUTQ==", "dev": true, "requires": { "ajv": "^6.12.4", @@ -8411,7 +8410,7 @@ "globals": "^14.0.0", "ignore": "^5.2.0", "import-fresh": "^3.2.1", - "js-yaml": "^4.1.0", + "js-yaml": "^4.1.1", "minimatch": "^3.1.2", "strip-json-comments": "^3.1.1" }, diff --git a/package.json b/package.json index 00dda29f24efb..30004672af628 100644 --- a/package.json +++ b/package.json @@ -38,7 +38,7 @@ "devDependencies": { "@actions/core": "^1.11.1", "@actions/github": "^6.0.1", - "@eslint/eslintrc": "^3.3.1", + "@eslint/eslintrc": "^3.3.3", "@eslint/js": "^9.39.0", "@testing-library/dom": "^10.4.1", "@testing-library/jest-dom": "^6.9.1", From 2c51a67a55d5244484f788f329ebfc3127b38f57 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Sat, 6 Dec 2025 20:35:34 +0200 Subject: [PATCH 253/265] build(deps-dev): Bump eslint-plugin-jsdoc from 61.1.12 to 61.4.1 (#4656) Bumps [eslint-plugin-jsdoc](https://github.com/gajus/eslint-plugin-jsdoc) from 61.1.12 to 61.4.1. - [Release notes](https://github.com/gajus/eslint-plugin-jsdoc/releases) - [Changelog](https://github.com/gajus/eslint-plugin-jsdoc/blob/main/.releaserc) - [Commits](https://github.com/gajus/eslint-plugin-jsdoc/compare/v61.1.12...v61.4.1) --- updated-dependencies: - dependency-name: eslint-plugin-jsdoc dependency-version: 61.4.1 dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- package-lock.json | 14 +++++++------- package.json | 2 +- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/package-lock.json b/package-lock.json index 134264700be0b..263209ffd64c3 100644 --- a/package-lock.json +++ b/package-lock.json @@ -27,7 +27,7 @@ "color-contrast-checker": "^2.1.0", "eslint": "^9.39.0", "eslint-config-prettier": "^10.1.8", - "eslint-plugin-jsdoc": "^61.1.12", + "eslint-plugin-jsdoc": "^61.4.2", "express": "^5.2.0", "globals": "^16.5.0", "hjson": "^3.2.2", @@ -3331,9 +3331,9 @@ } }, "node_modules/eslint-plugin-jsdoc": { - "version": "61.1.12", - "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-61.1.12.tgz", - "integrity": "sha512-CGJTnltz7ovwOW33xYhvA4fMuriPZpR5OnJf09SV28iU2IUpJwMd6P7zvUK8Sl56u5YzO+1F9m46wpSs2dufEw==", + "version": "61.4.2", + "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-61.4.2.tgz", + "integrity": "sha512-WzZNvefoUaG/JWikVFhNLYqE2BEd6LQD2ZyfJOe1Ld3Cir05csDMMf0AihGwrSbB/e7fHRSfQOZ4F/hik9fQww==", "dev": true, "dependencies": { "@es-joy/jsdoccomment": "~0.76.0", @@ -10280,9 +10280,9 @@ "requires": {} }, "eslint-plugin-jsdoc": { - "version": "61.1.12", - "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-61.1.12.tgz", - "integrity": "sha512-CGJTnltz7ovwOW33xYhvA4fMuriPZpR5OnJf09SV28iU2IUpJwMd6P7zvUK8Sl56u5YzO+1F9m46wpSs2dufEw==", + "version": "61.4.2", + "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-61.4.2.tgz", + "integrity": "sha512-WzZNvefoUaG/JWikVFhNLYqE2BEd6LQD2ZyfJOe1Ld3Cir05csDMMf0AihGwrSbB/e7fHRSfQOZ4F/hik9fQww==", "dev": true, "requires": { "@es-joy/jsdoccomment": "~0.76.0", diff --git a/package.json b/package.json index 30004672af628..b31158398e11a 100644 --- a/package.json +++ b/package.json @@ -47,7 +47,7 @@ "color-contrast-checker": "^2.1.0", "eslint": "^9.39.0", "eslint-config-prettier": "^10.1.8", - "eslint-plugin-jsdoc": "^61.1.12", + "eslint-plugin-jsdoc": "^61.4.2", "express": "^5.2.0", "globals": "^16.5.0", "hjson": "^3.2.2", From 8994937bd139cd43b6ec431229f009f1e5204d3d Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Sat, 6 Dec 2025 20:39:13 +0200 Subject: [PATCH 254/265] build(deps-dev): Bump express from 5.1.0 to 5.2.1 (#4670) Bumps [express](https://github.com/expressjs/express) from 5.1.0 to 5.2.1. - [Release notes](https://github.com/expressjs/express/releases) - [Changelog](https://github.com/expressjs/express/blob/master/History.md) - [Commits](https://github.com/expressjs/express/compare/v5.1.0...v5.2.1) --- updated-dependencies: - dependency-name: express dependency-version: 5.2.1 dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- package-lock.json | 14 +++++++------- package.json | 2 +- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/package-lock.json b/package-lock.json index 263209ffd64c3..87b4d4366f2a2 100644 --- a/package-lock.json +++ b/package-lock.json @@ -28,7 +28,7 @@ "eslint": "^9.39.0", "eslint-config-prettier": "^10.1.8", "eslint-plugin-jsdoc": "^61.4.2", - "express": "^5.2.0", + "express": "^5.2.1", "globals": "^16.5.0", "hjson": "^3.2.2", "husky": "^9.1.7", @@ -3658,9 +3658,9 @@ } }, "node_modules/express": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/express/-/express-5.2.0.tgz", - "integrity": "sha512-XdpJDLxfztVY59X0zPI6sibRiGcxhTPXRD3IhJmjKf2jwMvkRGV1j7loB8U+heeamoU3XvihAaGRTR4aXXUN3A==", + "version": "5.2.1", + "resolved": "https://registry.npmjs.org/express/-/express-5.2.1.tgz", + "integrity": "sha512-hIS4idWWai69NezIdRt2xFVofaF4j+6INOpJlVOLDO8zXGpUVEVzIYk12UUi2JzjEzWL3IOAxcTubgz9Po0yXw==", "dev": true, "dependencies": { "accepts": "^2.0.0", @@ -10444,9 +10444,9 @@ } }, "express": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/express/-/express-5.2.0.tgz", - "integrity": "sha512-XdpJDLxfztVY59X0zPI6sibRiGcxhTPXRD3IhJmjKf2jwMvkRGV1j7loB8U+heeamoU3XvihAaGRTR4aXXUN3A==", + "version": "5.2.1", + "resolved": "https://registry.npmjs.org/express/-/express-5.2.1.tgz", + "integrity": "sha512-hIS4idWWai69NezIdRt2xFVofaF4j+6INOpJlVOLDO8zXGpUVEVzIYk12UUi2JzjEzWL3IOAxcTubgz9Po0yXw==", "dev": true, "requires": { "accepts": "^2.0.0", diff --git a/package.json b/package.json index b31158398e11a..ed0173da9ed3d 100644 --- a/package.json +++ b/package.json @@ -48,7 +48,7 @@ "eslint": "^9.39.0", "eslint-config-prettier": "^10.1.8", "eslint-plugin-jsdoc": "^61.4.2", - "express": "^5.2.0", + "express": "^5.2.1", "globals": "^16.5.0", "hjson": "^3.2.2", "husky": "^9.1.7", From e807e167efdb97388aa42c5282cdd874a2f537ef Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 19 Dec 2025 21:08:53 +0200 Subject: [PATCH 255/265] ci(deps): Bump actions/checkout from 6.0.0 to 6.0.1 (#4690) Bumps [actions/checkout](https://github.com/actions/checkout) from 6.0.0 to 6.0.1. - [Release notes](https://github.com/actions/checkout/releases) - [Changelog](https://github.com/actions/checkout/blob/main/CHANGELOG.md) - [Commits](https://github.com/actions/checkout/compare/1af3b93b6815bc44a9784bd300feb67ff0d1eeb3...8e8c483db84b4bee98b60c0593521ed34d9990e8) --- updated-dependencies: - dependency-name: actions/checkout dependency-version: 6.0.1 dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- .github/workflows/codeql-analysis.yml | 2 +- .github/workflows/deploy-prep.yml | 2 +- .github/workflows/e2e-test.yml | 2 +- .github/workflows/empty-issues-closer.yml | 2 +- .github/workflows/generate-theme-doc.yml | 2 +- .github/workflows/ossf-analysis.yml | 2 +- .github/workflows/preview-theme.yml | 2 +- .github/workflows/stale-theme-pr-closer.yml | 2 +- .github/workflows/test.yml | 2 +- .github/workflows/theme-prs-closer.yml | 2 +- .github/workflows/update-langs.yml | 2 +- 11 files changed, 11 insertions(+), 11 deletions(-) diff --git a/.github/workflows/codeql-analysis.yml b/.github/workflows/codeql-analysis.yml index 55a74d1bd9b2b..174c78de0e2bd 100644 --- a/.github/workflows/codeql-analysis.yml +++ b/.github/workflows/codeql-analysis.yml @@ -31,7 +31,7 @@ jobs: steps: - name: Checkout repository - uses: actions/checkout@1af3b93b6815bc44a9784bd300feb67ff0d1eeb3 # v6.0.0 + uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1 # Initializes the CodeQL tools for scanning. - name: Initialize CodeQL diff --git a/.github/workflows/deploy-prep.yml b/.github/workflows/deploy-prep.yml index 4a62d1ccc18a3..760ce2e08669c 100644 --- a/.github/workflows/deploy-prep.yml +++ b/.github/workflows/deploy-prep.yml @@ -10,7 +10,7 @@ jobs: if: github.repository == 'anuraghazra/github-readme-stats' runs-on: ubuntu-latest steps: - - uses: actions/checkout@1af3b93b6815bc44a9784bd300feb67ff0d1eeb3 # v6.0.0 + - uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1 - name: Deployment Prep run: python ./.github/workflows/deploy-prep.py - uses: stefanzweifel/git-auto-commit-action@28e16e81777b558cc906c8750092100bbb34c5e3 # v7.0.0 diff --git a/.github/workflows/e2e-test.yml b/.github/workflows/e2e-test.yml index b43f11db56f3c..86d42e869c985 100644 --- a/.github/workflows/e2e-test.yml +++ b/.github/workflows/e2e-test.yml @@ -22,7 +22,7 @@ jobs: node-version: [22.x] steps: - - uses: actions/checkout@1af3b93b6815bc44a9784bd300feb67ff0d1eeb3 # v6.0.0 + - uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1 - name: Setup Node uses: actions/setup-node@2028fbc5c25fe9cf00d9f06a71cc4710d4507903 # v6.0.0 diff --git a/.github/workflows/empty-issues-closer.yml b/.github/workflows/empty-issues-closer.yml index d2118cf90f843..7fe827662f513 100644 --- a/.github/workflows/empty-issues-closer.yml +++ b/.github/workflows/empty-issues-closer.yml @@ -27,7 +27,7 @@ jobs: runs-on: ubuntu-latest steps: # NOTE: Retrieve issue templates. - - uses: actions/checkout@1af3b93b6815bc44a9784bd300feb67ff0d1eeb3 # v6.0.0 + - uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1 - name: Run empty issues closer action uses: rickstaa/empty-issues-closer-action@e96914613221511279ca25f50fd4acc85e331d99 # v1.1.74 diff --git a/.github/workflows/generate-theme-doc.yml b/.github/workflows/generate-theme-doc.yml index c0b7de8a255b0..216e309f07448 100644 --- a/.github/workflows/generate-theme-doc.yml +++ b/.github/workflows/generate-theme-doc.yml @@ -30,7 +30,7 @@ jobs: node-version: [22.x] steps: - - uses: actions/checkout@1af3b93b6815bc44a9784bd300feb67ff0d1eeb3 # v6.0.0 + - uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1 - name: Setup Node uses: actions/setup-node@2028fbc5c25fe9cf00d9f06a71cc4710d4507903 # v6.0.0 diff --git a/.github/workflows/ossf-analysis.yml b/.github/workflows/ossf-analysis.yml index 5b21b6737a3ac..70b0b1d8381c2 100644 --- a/.github/workflows/ossf-analysis.yml +++ b/.github/workflows/ossf-analysis.yml @@ -22,7 +22,7 @@ jobs: steps: - name: "Checkout code" - uses: actions/checkout@1af3b93b6815bc44a9784bd300feb67ff0d1eeb3 # v6.0.0 + uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1 with: persist-credentials: false diff --git a/.github/workflows/preview-theme.yml b/.github/workflows/preview-theme.yml index 14fd34c03cf6d..59786ebcce6a8 100644 --- a/.github/workflows/preview-theme.yml +++ b/.github/workflows/preview-theme.yml @@ -33,7 +33,7 @@ jobs: node-version: [22.x] steps: - - uses: actions/checkout@1af3b93b6815bc44a9784bd300feb67ff0d1eeb3 # v6.0.0 + - uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1 - name: Setup Node uses: actions/setup-node@2028fbc5c25fe9cf00d9f06a71cc4710d4507903 # v6.0.0 diff --git a/.github/workflows/stale-theme-pr-closer.yml b/.github/workflows/stale-theme-pr-closer.yml index 63d368701cf9f..369b667bf3f79 100644 --- a/.github/workflows/stale-theme-pr-closer.yml +++ b/.github/workflows/stale-theme-pr-closer.yml @@ -39,7 +39,7 @@ jobs: node-version: [22.x] steps: - - uses: actions/checkout@1af3b93b6815bc44a9784bd300feb67ff0d1eeb3 # v6.0.0 + - uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1 - name: Setup Node uses: actions/setup-node@2028fbc5c25fe9cf00d9f06a71cc4710d4507903 # v6.0.0 diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index cd1b85c3485e3..c8db08ad80a11 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -18,7 +18,7 @@ jobs: node-version: [22.x] steps: - - uses: actions/checkout@1af3b93b6815bc44a9784bd300feb67ff0d1eeb3 # v6.0.0 + - uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1 - name: Setup Node uses: actions/setup-node@2028fbc5c25fe9cf00d9f06a71cc4710d4507903 # v6.0.0 diff --git a/.github/workflows/theme-prs-closer.yml b/.github/workflows/theme-prs-closer.yml index 63f662d735afd..614ccfc26079c 100644 --- a/.github/workflows/theme-prs-closer.yml +++ b/.github/workflows/theme-prs-closer.yml @@ -23,7 +23,7 @@ jobs: runs-on: ubuntu-latest steps: - name: Check out the code - uses: actions/checkout@1af3b93b6815bc44a9784bd300feb67ff0d1eeb3 # v6.0.0 + uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1 - name: Set up Git run: | diff --git a/.github/workflows/update-langs.yml b/.github/workflows/update-langs.yml index e83fece44b2ea..981b95867705d 100644 --- a/.github/workflows/update-langs.yml +++ b/.github/workflows/update-langs.yml @@ -36,7 +36,7 @@ jobs: node-version: [22.x] steps: - - uses: actions/checkout@1af3b93b6815bc44a9784bd300feb67ff0d1eeb3 # v6.0.0 + - uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1 - name: Setup Node uses: actions/setup-node@2028fbc5c25fe9cf00d9f06a71cc4710d4507903 # v6.0.0 From a3f234a4c393a847b3b48150c63b046582783e3a Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 19 Dec 2025 21:11:16 +0200 Subject: [PATCH 256/265] ci(deps): Bump actions/setup-node from 6.0.0 to 6.1.0 (#4689) Bumps [actions/setup-node](https://github.com/actions/setup-node) from 6.0.0 to 6.1.0. - [Release notes](https://github.com/actions/setup-node/releases) - [Commits](https://github.com/actions/setup-node/compare/2028fbc5c25fe9cf00d9f06a71cc4710d4507903...395ad3262231945c25e8478fd5baf05154b1d79f) --- updated-dependencies: - dependency-name: actions/setup-node dependency-version: 6.1.0 dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- .github/workflows/e2e-test.yml | 2 +- .github/workflows/generate-theme-doc.yml | 2 +- .github/workflows/preview-theme.yml | 2 +- .github/workflows/stale-theme-pr-closer.yml | 2 +- .github/workflows/test.yml | 2 +- .github/workflows/update-langs.yml | 2 +- 6 files changed, 6 insertions(+), 6 deletions(-) diff --git a/.github/workflows/e2e-test.yml b/.github/workflows/e2e-test.yml index 86d42e869c985..9ad5caac32ba9 100644 --- a/.github/workflows/e2e-test.yml +++ b/.github/workflows/e2e-test.yml @@ -25,7 +25,7 @@ jobs: - uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1 - name: Setup Node - uses: actions/setup-node@2028fbc5c25fe9cf00d9f06a71cc4710d4507903 # v6.0.0 + uses: actions/setup-node@395ad3262231945c25e8478fd5baf05154b1d79f # v6.1.0 with: node-version: ${{ matrix.node-version }} cache: npm diff --git a/.github/workflows/generate-theme-doc.yml b/.github/workflows/generate-theme-doc.yml index 216e309f07448..4767188320af7 100644 --- a/.github/workflows/generate-theme-doc.yml +++ b/.github/workflows/generate-theme-doc.yml @@ -33,7 +33,7 @@ jobs: - uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1 - name: Setup Node - uses: actions/setup-node@2028fbc5c25fe9cf00d9f06a71cc4710d4507903 # v6.0.0 + uses: actions/setup-node@395ad3262231945c25e8478fd5baf05154b1d79f # v6.1.0 with: node-version: ${{ matrix.node-version }} cache: npm diff --git a/.github/workflows/preview-theme.yml b/.github/workflows/preview-theme.yml index 59786ebcce6a8..3d855eb1f1256 100644 --- a/.github/workflows/preview-theme.yml +++ b/.github/workflows/preview-theme.yml @@ -36,7 +36,7 @@ jobs: - uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1 - name: Setup Node - uses: actions/setup-node@2028fbc5c25fe9cf00d9f06a71cc4710d4507903 # v6.0.0 + uses: actions/setup-node@395ad3262231945c25e8478fd5baf05154b1d79f # v6.1.0 with: node-version: ${{ matrix.node-version }} cache: npm diff --git a/.github/workflows/stale-theme-pr-closer.yml b/.github/workflows/stale-theme-pr-closer.yml index 369b667bf3f79..763caf639655c 100644 --- a/.github/workflows/stale-theme-pr-closer.yml +++ b/.github/workflows/stale-theme-pr-closer.yml @@ -42,7 +42,7 @@ jobs: - uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1 - name: Setup Node - uses: actions/setup-node@2028fbc5c25fe9cf00d9f06a71cc4710d4507903 # v6.0.0 + uses: actions/setup-node@395ad3262231945c25e8478fd5baf05154b1d79f # v6.1.0 with: node-version: ${{ matrix.node-version }} cache: npm diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index c8db08ad80a11..a767eac81b269 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -21,7 +21,7 @@ jobs: - uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1 - name: Setup Node - uses: actions/setup-node@2028fbc5c25fe9cf00d9f06a71cc4710d4507903 # v6.0.0 + uses: actions/setup-node@395ad3262231945c25e8478fd5baf05154b1d79f # v6.1.0 with: node-version: ${{ matrix.node-version }} cache: npm diff --git a/.github/workflows/update-langs.yml b/.github/workflows/update-langs.yml index 981b95867705d..5bf298c03342c 100644 --- a/.github/workflows/update-langs.yml +++ b/.github/workflows/update-langs.yml @@ -39,7 +39,7 @@ jobs: - uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1 - name: Setup Node - uses: actions/setup-node@2028fbc5c25fe9cf00d9f06a71cc4710d4507903 # v6.0.0 + uses: actions/setup-node@395ad3262231945c25e8478fd5baf05154b1d79f # v6.1.0 with: node-version: ${{ matrix.node-version }} cache: npm From 8ee077b14bdd5b930bcc3055fa302f2715ba34b1 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 19 Dec 2025 21:14:21 +0200 Subject: [PATCH 257/265] ci(deps): Bump actions/upload-artifact from 5.0.0 to 6.0.0 (#4705) Bumps [actions/upload-artifact](https://github.com/actions/upload-artifact) from 5.0.0 to 6.0.0. - [Release notes](https://github.com/actions/upload-artifact/releases) - [Commits](https://github.com/actions/upload-artifact/compare/330a01c490aca151604b8cf639adc76d48f6c5d4...b7c566a772e6b6bfb58ed0dc250532a479d7789f) --- updated-dependencies: - dependency-name: actions/upload-artifact dependency-version: 6.0.0 dependency-type: direct:production update-type: version-update:semver-major ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- .github/workflows/ossf-analysis.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/ossf-analysis.yml b/.github/workflows/ossf-analysis.yml index 70b0b1d8381c2..d1245cb8e0a16 100644 --- a/.github/workflows/ossf-analysis.yml +++ b/.github/workflows/ossf-analysis.yml @@ -36,7 +36,7 @@ jobs: # Upload the results as artifacts (optional). Commenting out will disable uploads of run results in SARIF # format to the repository Actions tab. - name: "Upload artifact" - uses: actions/upload-artifact@330a01c490aca151604b8cf639adc76d48f6c5d4 # v5.0.0 + uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f # v6.0.0 with: name: SARIF file path: results.sarif From 61b9adbf609a069678227237703001b5041feda9 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 19 Dec 2025 21:15:47 +0200 Subject: [PATCH 258/265] ci(deps): Bump peter-evans/create-pull-request from 7.0.9 to 8.0.0 (#4706) Bumps [peter-evans/create-pull-request](https://github.com/peter-evans/create-pull-request) from 7.0.9 to 8.0.0. - [Release notes](https://github.com/peter-evans/create-pull-request/releases) - [Commits](https://github.com/peter-evans/create-pull-request/compare/84ae59a2cdc2258d6fa0732dd66352dddae2a412...98357b18bf14b5342f975ff684046ec3b2a07725) --- updated-dependencies: - dependency-name: peter-evans/create-pull-request dependency-version: 8.0.0 dependency-type: direct:production update-type: version-update:semver-major ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- .github/workflows/update-langs.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/update-langs.yml b/.github/workflows/update-langs.yml index 5bf298c03342c..c7a64ba21b35e 100644 --- a/.github/workflows/update-langs.yml +++ b/.github/workflows/update-langs.yml @@ -53,7 +53,7 @@ jobs: run: npm run generate-langs-json - name: Create Pull Request if upstream language file is changed - uses: peter-evans/create-pull-request@84ae59a2cdc2258d6fa0732dd66352dddae2a412 # v7.0.9 + uses: peter-evans/create-pull-request@98357b18bf14b5342f975ff684046ec3b2a07725 # v8.0.0 with: commit-message: "refactor: update languages JSON" branch: "update_langs/patch" From 696dd6c774a984efdd9c510862bdfba0a489935e Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Sun, 21 Dec 2025 13:43:45 +0200 Subject: [PATCH 259/265] ci: restore e2e test workflow (#4708) * ci: restore e2e test workflow * Update .github/workflows/e2e-test.yml Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --------- Co-authored-by: Alexandr Garbuzov Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --- .github/workflows/e2e-test.yml | 21 ++++++++------------- 1 file changed, 8 insertions(+), 13 deletions(-) diff --git a/.github/workflows/e2e-test.yml b/.github/workflows/e2e-test.yml index 9ad5caac32ba9..2d8dc6b665066 100644 --- a/.github/workflows/e2e-test.yml +++ b/.github/workflows/e2e-test.yml @@ -1,21 +1,16 @@ name: Test Deployment on: - # Temporarily disabled automatic triggers; manual-only for now. - workflow_dispatch: - # Original trigger (restore to re-enable): - # deployment_status: + deployment_status: permissions: read-all jobs: e2eTests: - # Temporarily disabled; set to the original condition to re-enable. - # if: - # github.repository == 'anuraghazra/github-readme-stats' && - # github.event_name == 'deployment_status' && - # github.event.deployment_status.state == 'success' - if: false - name: Perform 2e2 tests + if: + github.repository == 'anuraghazra/github-readme-stats' && + github.event_name == 'deployment_status' && + github.event.deployment_status.state == 'success' + name: Perform e2e tests runs-on: ubuntu-latest strategy: matrix: @@ -37,5 +32,5 @@ jobs: - name: Run end-to-end tests. run: npm run test:e2e - # env: - # VERCEL_PREVIEW_URL: ${{ github.event.deployment_status.target_url }} + env: + VERCEL_PREVIEW_URL: ${{ github.event.deployment_status.target_url }} From 6ade6b4ef14d0a5a1a01c8f46078451ad1e1c752 Mon Sep 17 00:00:00 2001 From: Ophelia Goldstein <159258143+opheliagoldstein@users.noreply.github.com> Date: Sun, 21 Dec 2025 14:23:28 +0200 Subject: [PATCH 260/265] ci: revert restoring e2e test workflow (#4709) Co-authored-by: Alexandr Garbuzov --- .github/workflows/e2e-test.yml | 19 ++++++++++++------- 1 file changed, 12 insertions(+), 7 deletions(-) diff --git a/.github/workflows/e2e-test.yml b/.github/workflows/e2e-test.yml index 2d8dc6b665066..61c257cd9227c 100644 --- a/.github/workflows/e2e-test.yml +++ b/.github/workflows/e2e-test.yml @@ -1,15 +1,20 @@ name: Test Deployment on: - deployment_status: + # Temporarily disabled automatic triggers; manual-only for now. + workflow_dispatch: + # Original trigger (restore to re-enable): + # deployment_status: permissions: read-all jobs: e2eTests: - if: - github.repository == 'anuraghazra/github-readme-stats' && - github.event_name == 'deployment_status' && - github.event.deployment_status.state == 'success' + # Temporarily disabled; set to the original condition to re-enable. + # if: + # github.repository == 'anuraghazra/github-readme-stats' && + # github.event_name == 'deployment_status' && + # github.event.deployment_status.state == 'success' + if: false name: Perform e2e tests runs-on: ubuntu-latest strategy: @@ -32,5 +37,5 @@ jobs: - name: Run end-to-end tests. run: npm run test:e2e - env: - VERCEL_PREVIEW_URL: ${{ github.event.deployment_status.target_url }} + # env: + # VERCEL_PREVIEW_URL: ${{ github.event.deployment_status.target_url }} From 903588b3000db753cc3c0d8460317806249e167d Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Sun, 21 Dec 2025 14:26:04 +0200 Subject: [PATCH 261/265] build(deps-dev): Bump @eslint/js from 9.39.1 to 9.39.2 (#4703) Bumps [@eslint/js](https://github.com/eslint/eslint/tree/HEAD/packages/js) from 9.39.1 to 9.39.2. - [Release notes](https://github.com/eslint/eslint/releases) - [Commits](https://github.com/eslint/eslint/commits/v9.39.2/packages/js) --- updated-dependencies: - dependency-name: "@eslint/js" dependency-version: 9.39.2 dependency-type: direct:development update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- package-lock.json | 32 +++++++++++++++++++++++++------- package.json | 2 +- 2 files changed, 26 insertions(+), 8 deletions(-) diff --git a/package-lock.json b/package-lock.json index 87b4d4366f2a2..cc965d655b47d 100644 --- a/package-lock.json +++ b/package-lock.json @@ -19,7 +19,7 @@ "@actions/core": "^1.11.1", "@actions/github": "^6.0.1", "@eslint/eslintrc": "^3.3.3", - "@eslint/js": "^9.39.0", + "@eslint/js": "^9.39.2", "@testing-library/dom": "^10.4.1", "@testing-library/jest-dom": "^6.9.1", "@uppercod/css-to-object": "^1.1.1", @@ -869,9 +869,9 @@ } }, "node_modules/@eslint/js": { - "version": "9.39.1", - "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.39.1.tgz", - "integrity": "sha512-S26Stp4zCy88tH94QbBv3XCuzRQiZ9yXofEILmglYTh/Ug/a9/umqvgFtYBAo3Lp0nsI/5/qH1CCrbdK3AP1Tw==", + "version": "9.39.2", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.39.2.tgz", + "integrity": "sha512-q1mjIoW1VX4IvSocvM/vbTiveKC4k9eLrajNEuSsmjymSDEbpGddtpfOoN7YGAqBK3NG+uqo8ia4PDTt8buCYA==", "dev": true, "engines": { "node": "^18.18.0 || ^20.9.0 || >=21.1.0" @@ -3411,6 +3411,18 @@ "url": "https://opencollective.com/eslint" } }, + "node_modules/eslint/node_modules/@eslint/js": { + "version": "9.39.1", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.39.1.tgz", + "integrity": "sha512-S26Stp4zCy88tH94QbBv3XCuzRQiZ9yXofEILmglYTh/Ug/a9/umqvgFtYBAo3Lp0nsI/5/qH1CCrbdK3AP1Tw==", + "dev": true, + "engines": { + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" + }, + "funding": { + "url": "https://eslint.org/donate" + } + }, "node_modules/eslint/node_modules/escape-string-regexp": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", @@ -8424,9 +8436,9 @@ } }, "@eslint/js": { - "version": "9.39.1", - "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.39.1.tgz", - "integrity": "sha512-S26Stp4zCy88tH94QbBv3XCuzRQiZ9yXofEILmglYTh/Ug/a9/umqvgFtYBAo3Lp0nsI/5/qH1CCrbdK3AP1Tw==", + "version": "9.39.2", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.39.2.tgz", + "integrity": "sha512-q1mjIoW1VX4IvSocvM/vbTiveKC4k9eLrajNEuSsmjymSDEbpGddtpfOoN7YGAqBK3NG+uqo8ia4PDTt8buCYA==", "dev": true }, "@eslint/object-schema": { @@ -10216,6 +10228,12 @@ "optionator": "^0.9.3" }, "dependencies": { + "@eslint/js": { + "version": "9.39.1", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.39.1.tgz", + "integrity": "sha512-S26Stp4zCy88tH94QbBv3XCuzRQiZ9yXofEILmglYTh/Ug/a9/umqvgFtYBAo3Lp0nsI/5/qH1CCrbdK3AP1Tw==", + "dev": true + }, "escape-string-regexp": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", diff --git a/package.json b/package.json index ed0173da9ed3d..684e1aef992e2 100644 --- a/package.json +++ b/package.json @@ -39,7 +39,7 @@ "@actions/core": "^1.11.1", "@actions/github": "^6.0.1", "@eslint/eslintrc": "^3.3.3", - "@eslint/js": "^9.39.0", + "@eslint/js": "^9.39.2", "@testing-library/dom": "^10.4.1", "@testing-library/jest-dom": "^6.9.1", "@uppercod/css-to-object": "^1.1.1", From a92b817795b583cdec58a2eade20eb19b1cad6f7 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Sun, 21 Dec 2025 14:28:27 +0200 Subject: [PATCH 262/265] build(deps-dev): Bump eslint from 9.39.1 to 9.39.2 (#4704) Bumps [eslint](https://github.com/eslint/eslint) from 9.39.1 to 9.39.2. - [Release notes](https://github.com/eslint/eslint/releases) - [Commits](https://github.com/eslint/eslint/compare/v9.39.1...v9.39.2) --- updated-dependencies: - dependency-name: eslint dependency-version: 9.39.2 dependency-type: direct:development update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- package-lock.json | 18 +++++++++--------- package.json | 2 +- 2 files changed, 10 insertions(+), 10 deletions(-) diff --git a/package-lock.json b/package-lock.json index cc965d655b47d..ae6440fd9acf3 100644 --- a/package-lock.json +++ b/package-lock.json @@ -25,7 +25,7 @@ "@uppercod/css-to-object": "^1.1.1", "axios-mock-adapter": "^2.1.0", "color-contrast-checker": "^2.1.0", - "eslint": "^9.39.0", + "eslint": "^9.39.2", "eslint-config-prettier": "^10.1.8", "eslint-plugin-jsdoc": "^61.4.2", "express": "^5.2.1", @@ -3257,9 +3257,9 @@ } }, "node_modules/eslint": { - "version": "9.39.1", - "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.39.1.tgz", - "integrity": "sha512-BhHmn2yNOFA9H9JmmIVKJmd288g9hrVRDkdoIgRCRuSySRUHH7r/DI6aAXW9T1WwUuY3DFgrcaqB+deURBLR5g==", + "version": "9.39.2", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.39.2.tgz", + "integrity": "sha512-LEyamqS7W5HB3ujJyvi0HQK/dtVINZvd5mAAp9eT5S/ujByGjiZLCzPcHVzuXbpJDJF/cxwHlfceVUDZ2lnSTw==", "dev": true, "dependencies": { "@eslint-community/eslint-utils": "^4.8.0", @@ -3268,7 +3268,7 @@ "@eslint/config-helpers": "^0.4.2", "@eslint/core": "^0.17.0", "@eslint/eslintrc": "^3.3.1", - "@eslint/js": "9.39.1", + "@eslint/js": "9.39.2", "@eslint/plugin-kit": "^0.4.1", "@humanfs/node": "^0.16.6", "@humanwhocodes/module-importer": "^1.0.1", @@ -10187,9 +10187,9 @@ "dev": true }, "eslint": { - "version": "9.39.1", - "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.39.1.tgz", - "integrity": "sha512-BhHmn2yNOFA9H9JmmIVKJmd288g9hrVRDkdoIgRCRuSySRUHH7r/DI6aAXW9T1WwUuY3DFgrcaqB+deURBLR5g==", + "version": "9.39.2", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.39.2.tgz", + "integrity": "sha512-LEyamqS7W5HB3ujJyvi0HQK/dtVINZvd5mAAp9eT5S/ujByGjiZLCzPcHVzuXbpJDJF/cxwHlfceVUDZ2lnSTw==", "dev": true, "requires": { "@eslint-community/eslint-utils": "^4.8.0", @@ -10198,7 +10198,7 @@ "@eslint/config-helpers": "^0.4.2", "@eslint/core": "^0.17.0", "@eslint/eslintrc": "^3.3.1", - "@eslint/js": "9.39.1", + "@eslint/js": "9.39.2", "@eslint/plugin-kit": "^0.4.1", "@humanfs/node": "^0.16.6", "@humanwhocodes/module-importer": "^1.0.1", diff --git a/package.json b/package.json index 684e1aef992e2..9ec2766b51125 100644 --- a/package.json +++ b/package.json @@ -45,7 +45,7 @@ "@uppercod/css-to-object": "^1.1.1", "axios-mock-adapter": "^2.1.0", "color-contrast-checker": "^2.1.0", - "eslint": "^9.39.0", + "eslint": "^9.39.2", "eslint-config-prettier": "^10.1.8", "eslint-plugin-jsdoc": "^61.4.2", "express": "^5.2.1", From 7d8dad0130abfe7fdd6d9f021f22fba8dd462a8c Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Sun, 21 Dec 2025 14:29:39 +0200 Subject: [PATCH 263/265] build(deps-dev): Bump eslint-plugin-jsdoc from 61.4.2 to 61.5.0 (#4688) Bumps [eslint-plugin-jsdoc](https://github.com/gajus/eslint-plugin-jsdoc) from 61.4.2 to 61.5.0. - [Release notes](https://github.com/gajus/eslint-plugin-jsdoc/releases) - [Commits](https://github.com/gajus/eslint-plugin-jsdoc/compare/v61.4.2...v61.5.0) --- updated-dependencies: - dependency-name: eslint-plugin-jsdoc dependency-version: 61.5.0 dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- package-lock.json | 14 +++++++------- package.json | 2 +- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/package-lock.json b/package-lock.json index ae6440fd9acf3..b73cf130a2f9f 100644 --- a/package-lock.json +++ b/package-lock.json @@ -27,7 +27,7 @@ "color-contrast-checker": "^2.1.0", "eslint": "^9.39.2", "eslint-config-prettier": "^10.1.8", - "eslint-plugin-jsdoc": "^61.4.2", + "eslint-plugin-jsdoc": "^61.5.0", "express": "^5.2.1", "globals": "^16.5.0", "hjson": "^3.2.2", @@ -3331,9 +3331,9 @@ } }, "node_modules/eslint-plugin-jsdoc": { - "version": "61.4.2", - "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-61.4.2.tgz", - "integrity": "sha512-WzZNvefoUaG/JWikVFhNLYqE2BEd6LQD2ZyfJOe1Ld3Cir05csDMMf0AihGwrSbB/e7fHRSfQOZ4F/hik9fQww==", + "version": "61.5.0", + "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-61.5.0.tgz", + "integrity": "sha512-PR81eOGq4S7diVnV9xzFSBE4CDENRQGP0Lckkek8AdHtbj+6Bm0cItwlFnxsLFriJHspiE3mpu8U20eODyToIg==", "dev": true, "dependencies": { "@es-joy/jsdoccomment": "~0.76.0", @@ -10298,9 +10298,9 @@ "requires": {} }, "eslint-plugin-jsdoc": { - "version": "61.4.2", - "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-61.4.2.tgz", - "integrity": "sha512-WzZNvefoUaG/JWikVFhNLYqE2BEd6LQD2ZyfJOe1Ld3Cir05csDMMf0AihGwrSbB/e7fHRSfQOZ4F/hik9fQww==", + "version": "61.5.0", + "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-61.5.0.tgz", + "integrity": "sha512-PR81eOGq4S7diVnV9xzFSBE4CDENRQGP0Lckkek8AdHtbj+6Bm0cItwlFnxsLFriJHspiE3mpu8U20eODyToIg==", "dev": true, "requires": { "@es-joy/jsdoccomment": "~0.76.0", diff --git a/package.json b/package.json index 9ec2766b51125..813ebe0b19c9b 100644 --- a/package.json +++ b/package.json @@ -47,7 +47,7 @@ "color-contrast-checker": "^2.1.0", "eslint": "^9.39.2", "eslint-config-prettier": "^10.1.8", - "eslint-plugin-jsdoc": "^61.4.2", + "eslint-plugin-jsdoc": "^61.5.0", "express": "^5.2.1", "globals": "^16.5.0", "hjson": "^3.2.2", From 8108ba1417faaad7182399e01dd724777adc63e5 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Sun, 21 Dec 2025 14:36:28 +0200 Subject: [PATCH 264/265] build(deps-dev): Bump @actions/core from 1.11.1 to 2.0.1 (#4702) Bumps [@actions/core](https://github.com/actions/toolkit/tree/HEAD/packages/core) from 1.11.1 to 2.0.1. - [Changelog](https://github.com/actions/toolkit/blob/main/packages/core/RELEASES.md) - [Commits](https://github.com/actions/toolkit/commits/@actions/artifact@2.0.1/packages/core) --- updated-dependencies: - dependency-name: "@actions/core" dependency-version: 2.0.1 dependency-type: direct:development update-type: version-update:semver-major ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alexandr Garbuzov --- package-lock.json | 72 +++++++++++++++++++++++++++++++---------------- package.json | 2 +- 2 files changed, 48 insertions(+), 26 deletions(-) diff --git a/package-lock.json b/package-lock.json index b73cf130a2f9f..a12246692d8fd 100644 --- a/package-lock.json +++ b/package-lock.json @@ -16,7 +16,7 @@ "word-wrap": "^1.2.5" }, "devDependencies": { - "@actions/core": "^1.11.1", + "@actions/core": "^2.0.1", "@actions/github": "^6.0.1", "@eslint/eslintrc": "^3.3.3", "@eslint/js": "^9.39.2", @@ -54,22 +54,32 @@ } }, "node_modules/@actions/core": { - "version": "1.11.1", - "resolved": "https://registry.npmjs.org/@actions/core/-/core-1.11.1.tgz", - "integrity": "sha512-hXJCSrkwfA46Vd9Z3q4cpEpHB1rL5NG04+/rbqW9d3+CSvtB1tYe8UTpAlixa1vj0m/ULglfEK2UKxMGxCxv5A==", + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/@actions/core/-/core-2.0.1.tgz", + "integrity": "sha512-oBfqT3GwkvLlo1fjvhQLQxuwZCGTarTE5OuZ2Wg10hvhBj7LRIlF611WT4aZS6fDhO5ZKlY7lCAZTlpmyaHaeg==", "dev": true, "dependencies": { - "@actions/exec": "^1.1.1", - "@actions/http-client": "^2.0.1" + "@actions/exec": "^2.0.0", + "@actions/http-client": "^3.0.0" + } + }, + "node_modules/@actions/core/node_modules/@actions/http-client": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/@actions/http-client/-/http-client-3.0.0.tgz", + "integrity": "sha512-1s3tXAfVMSz9a4ZEBkXXRQD4QhY3+GAsWSbaYpeknPOKEeyRiU3lH+bHiLMZdo2x/fIeQ/hscL1wCkDLVM2DZQ==", + "dev": true, + "dependencies": { + "tunnel": "^0.0.6", + "undici": "^5.28.5" } }, "node_modules/@actions/exec": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/@actions/exec/-/exec-1.1.1.tgz", - "integrity": "sha512-+sCcHHbVdk93a0XT19ECtO/gIXoxvdsgQLzb2fE2/5sIZmWQuluYyjPQtrtTHdU1YzTZ7bAPN4sITq2xi1679w==", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/@actions/exec/-/exec-2.0.0.tgz", + "integrity": "sha512-k8ngrX2voJ/RIN6r9xB82NVqKpnMRtxDoiO+g3olkIUpQNqjArXrCQceduQZCQj3P3xm32pChRLqRrtXTlqhIw==", "dev": true, "dependencies": { - "@actions/io": "^1.0.1" + "@actions/io": "^2.0.0" } }, "node_modules/@actions/github": { @@ -99,9 +109,9 @@ } }, "node_modules/@actions/io": { - "version": "1.1.3", - "resolved": "https://registry.npmjs.org/@actions/io/-/io-1.1.3.tgz", - "integrity": "sha512-wi9JjgKLYS7U/z8PPbco+PvTb/nRWjeoFlJ1Qer83k/3C5PHQi28hiVdeE2kHXmIL99mQFawx8qt/JPjZilJ8Q==", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/@actions/io/-/io-2.0.0.tgz", + "integrity": "sha512-Jv33IN09XLO+0HS79aaODsvIRyduiF7NY/F6LYeK5oeUmrsz7aFdRphQjFoESF4jS7lMauDOttKALcpapVDIAg==", "dev": true }, "node_modules/@adobe/css-tools": { @@ -7864,22 +7874,34 @@ "dev": true }, "@actions/core": { - "version": "1.11.1", - "resolved": "https://registry.npmjs.org/@actions/core/-/core-1.11.1.tgz", - "integrity": "sha512-hXJCSrkwfA46Vd9Z3q4cpEpHB1rL5NG04+/rbqW9d3+CSvtB1tYe8UTpAlixa1vj0m/ULglfEK2UKxMGxCxv5A==", + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/@actions/core/-/core-2.0.1.tgz", + "integrity": "sha512-oBfqT3GwkvLlo1fjvhQLQxuwZCGTarTE5OuZ2Wg10hvhBj7LRIlF611WT4aZS6fDhO5ZKlY7lCAZTlpmyaHaeg==", "dev": true, "requires": { - "@actions/exec": "^1.1.1", - "@actions/http-client": "^2.0.1" + "@actions/exec": "^2.0.0", + "@actions/http-client": "^3.0.0" + }, + "dependencies": { + "@actions/http-client": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/@actions/http-client/-/http-client-3.0.0.tgz", + "integrity": "sha512-1s3tXAfVMSz9a4ZEBkXXRQD4QhY3+GAsWSbaYpeknPOKEeyRiU3lH+bHiLMZdo2x/fIeQ/hscL1wCkDLVM2DZQ==", + "dev": true, + "requires": { + "tunnel": "^0.0.6", + "undici": "^5.28.5" + } + } } }, "@actions/exec": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/@actions/exec/-/exec-1.1.1.tgz", - "integrity": "sha512-+sCcHHbVdk93a0XT19ECtO/gIXoxvdsgQLzb2fE2/5sIZmWQuluYyjPQtrtTHdU1YzTZ7bAPN4sITq2xi1679w==", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/@actions/exec/-/exec-2.0.0.tgz", + "integrity": "sha512-k8ngrX2voJ/RIN6r9xB82NVqKpnMRtxDoiO+g3olkIUpQNqjArXrCQceduQZCQj3P3xm32pChRLqRrtXTlqhIw==", "dev": true, "requires": { - "@actions/io": "^1.0.1" + "@actions/io": "^2.0.0" } }, "@actions/github": { @@ -7908,9 +7930,9 @@ } }, "@actions/io": { - "version": "1.1.3", - "resolved": "https://registry.npmjs.org/@actions/io/-/io-1.1.3.tgz", - "integrity": "sha512-wi9JjgKLYS7U/z8PPbco+PvTb/nRWjeoFlJ1Qer83k/3C5PHQi28hiVdeE2kHXmIL99mQFawx8qt/JPjZilJ8Q==", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/@actions/io/-/io-2.0.0.tgz", + "integrity": "sha512-Jv33IN09XLO+0HS79aaODsvIRyduiF7NY/F6LYeK5oeUmrsz7aFdRphQjFoESF4jS7lMauDOttKALcpapVDIAg==", "dev": true }, "@adobe/css-tools": { diff --git a/package.json b/package.json index 813ebe0b19c9b..dac23de7a7852 100644 --- a/package.json +++ b/package.json @@ -36,7 +36,7 @@ "author": "Anurag Hazra", "license": "MIT", "devDependencies": { - "@actions/core": "^1.11.1", + "@actions/core": "^2.0.1", "@actions/github": "^6.0.1", "@eslint/eslintrc": "^3.3.3", "@eslint/js": "^9.39.2", From 5df91f9bfa89c356a55cbb3c2bbc164fdbf94a86 Mon Sep 17 00:00:00 2001 From: Rick Staa Date: Sun, 18 Jan 2026 12:50:25 +0100 Subject: [PATCH 265/265] docs: add github action as recommended usage method (#4716) * docs: add github action as recommended usage method Add new github action as recommended usage method now that we are no longer sponsored by vercel and the hosted endpoint is not available anymore. Co-authored-by: Ulysses Zhan Co-authored-by: Zohan Subhash Co-authored-by: Alexandr * docs: improve action section --------- Co-authored-by: Ulysses Zhan Co-authored-by: Zohan Subhash Co-authored-by: Alexandr --- readme.md | 79 +++++++++++++++++++++++++++++++++++++++++++++---------- 1 file changed, 65 insertions(+), 14 deletions(-) diff --git a/readme.md b/readme.md index baadc984572fc..6abfa97e75127 100644 --- a/readme.md +++ b/readme.md @@ -85,13 +85,13 @@ - [Stats and top languages cards](#stats-and-top-languages-cards) - [Pinning repositories](#pinning-repositories) - [Deploy on your own](#deploy-on-your-own) - - [First step: get your Personal Access Token (PAT)](#first-step-get-your-personal-access-token-pat) - - [Classic token](#classic-token) - - [Fine-grained token](#fine-grained-token) - - [On Vercel](#on-vercel) + - [GitHub Actions (Recommended)](#github-actions-recommended) + - [Self-hosted (Vercel/Other) (Recommended)](#self-hosted-vercelother-recommended) + - [First step: get your Personal Access Token (PAT)](#first-step-get-your-personal-access-token-pat) + - [On Vercel](#on-vercel) - [:film\_projector: Check Out Step By Step Video Tutorial By @codeSTACKr](#film_projector-check-out-step-by-step-video-tutorial-by-codestackr) - - [On other platforms](#on-other-platforms) - - [Available environment variables](#available-environment-variables) + - [On other platforms](#on-other-platforms) + - [Available environment variables](#available-environment-variables) - [Keep your fork up to date](#keep-your-fork-up-to-date) - [:sparkling\_heart: Support the project](#sparkling_heart-support-the-project)

@@ -99,7 +99,7 @@ # Important Notices > [!IMPORTANT] -> Since the GitHub API only [allows 5k requests per hour per user account](https://docs.github.com/en/graphql/overview/resource-limitations), the public Vercel instance hosted on `https://github-readme-stats.vercel.app/api` could possibly hit the rate limiter (see [#1471](https://github.com/anuraghazra/github-readme-stats/issues/1471)). We use caching to prevent this from happening (see https://github.com/anuraghazra/github-readme-stats#common-options). You can turn off these rate limit protections by [deploying your own Vercel instance](#deploy-on-your-own). +> The public Vercel instance at `https://github-readme-stats.vercel.app/api` is best-effort and can be unreliable due to rate limits and traffic spikes (see [#1471](https://github.com/anuraghazra/github-readme-stats/issues/1471)). We use caching to improve stability (see [common options](#common-options)), but for reliable cards we recommend [self-hosting](#deploy-on-your-own) (Vercel or other) or using the [GitHub Actions workflow](#github-actions-recommended) to generate cards in your [profile repository](https://docs.github.com/en/account-and-profile/how-tos/profile-customization/managing-your-profile-readme). Uptime Badge @@ -796,15 +796,66 @@ By default, GitHub does not lay out the cards side by side. To do that, you can -# Deploy on your own +# Deploy on your own (recommended) -## First step: get your Personal Access Token (PAT) +Because the public endpoint is [not reliable](#Important-Notices), we recommend self-deployment via GitHub Actions or your own hosted instance. GitHub Actions is the simplest setup with static SVGs stored in your repo but less frequent updates, while self-hosting takes more work and can serve fresher stats (with caching). + +## GitHub Actions + +GitHub Actions generates static SVGs and avoids per-request API calls. By default it uses `GITHUB_TOKEN` (public stats only), for private stats, set a [PAT](https://docs.github.com/en/authentication/keeping-your-account-and-data-secure/managing-your-personal-access-tokens) as a secret and pass it to the action instead. + +Create `/.github/workflows/grs.yml` in your profile repo (`USERNAME/USERNAME`): + +```yaml +name: Update README cards + +on: + schedule: + - cron: "0 3 * * *" + workflow_dispatch: + +jobs: + build: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + + - name: Generate stats card + uses: readme-tools/github-readme-stats-action@v1 + with: + card: stats + options: username=${{ github.repository_owner }}&show_icons=true + path: profile/stats.svg + token: ${{ secrets.GITHUB_TOKEN }} + + - name: Commit cards + run: | + git config user.name "github-actions" + git config user.email "github-actions@users.noreply.github.com" + git add profile/*.svg + git commit -m "Update README cards" || exit 0 + git push +``` + +Then embed from your profile README: + +```md +![Stats](./profile/stats.svg) +``` + +See more options and examples in the [GitHub Readme Stats Action README](https://github.com/readme-tools/github-readme-stats-action#readme). + +## Self-hosted (Vercel/Other) + +Running your own instance avoids public rate limits and gives you full control over caching, tokens, and private stats. + +### First step: get your Personal Access Token (PAT) For deploying your own instance of GitHub Readme Stats, you will need to create a GitHub Personal Access Token (PAT). Below are the steps to create one and the scopes you need to select for both classic and fine-grained tokens. Selecting the right scopes for your token is important in case you want to display private contributions on your cards. -### Classic token +#### Classic token * Go to [Account -> Settings -> Developer Settings -> Personal access tokens -> Tokens (classic)](https://github.com/settings/tokens). * Click on `Generate new token -> Generate new token (classic)`. @@ -813,7 +864,7 @@ Selecting the right scopes for your token is important in case you want to displ * read:user * Click on `Generate token` and copy it. -### Fine-grained token +#### Fine-grained token > [!WARNING]\ > This limits the scope to issues in your repositories and includes only public commits. @@ -830,7 +881,7 @@ Selecting the right scopes for your token is important in case you want to displ * Pull requests: read-only * Click on `Generate token` and copy it. -## On Vercel +### On Vercel ### :film\_projector: [Check Out Step By Step Video Tutorial By @codeSTACKr](https://youtu.be/n6d4KHSKqGk?t=107) @@ -866,7 +917,7 @@ Since the GitHub API only allows 5k requests per hour, my `https://github-readme -## On other platforms +### On other platforms > [!WARNING] > This way of using GRS is not officially supported and was added to cater to some particular use cases where Vercel could not be used (e.g. [#2341](https://github.com/anuraghazra/github-readme-stats/discussions/2341)). The support for this method, therefore, is limited. @@ -883,7 +934,7 @@ Since the GitHub API only allows 5k requests per hour, my `https://github-readme 5. You're done 🎉 -## Available environment variables +### Available environment variables GitHub Readme Stats provides several environment variables that can be used to customize the behavior of your self-hosted instance. These include: