Compare commits

..

67 Commits

Author SHA1 Message Date
2d0a5d38bb docs: Stargazers over time 2025-01-05 10:41:22 +08:00
16e01b7a13 chore: bump version to 1.1.10 2024-12-07 16:02:00 +08:00
8f492376a0 chore: update idJson 2024-12-07 16:01:20 +08:00
0642c52db2 chore: bump version to 1.1.9 2024-09-27 21:15:19 +08:00
af256fba7d chore: update idJson 2024-09-27 21:14:44 +08:00
6599fbe6d3 chore: bump version to 1.1.8 2024-09-08 12:23:13 +08:00
a99959e6e5 chore: update idJson 2024-09-08 12:22:27 +08:00
c9c92da926 chore: bump version to 1.1.7 2024-08-21 12:27:56 +08:00
fcff120657 chore: update idJson and add display for idJson version 2024-08-21 12:27:19 +08:00
0ec7cb7c4f fix: winreg compatibility issues
sync with upstream
2024-08-07 17:17:54 +08:00
5a3159d4cb chore: bump version to 1.1.6 2024-08-07 17:08:15 +08:00
38b99bf4dc feat: import export ui layout 2024-08-07 17:07:18 +08:00
0cd9c071d7 chore: bump version to 1.1.5 2024-08-03 23:23:33 +08:00
bf582d0194 fix: update color 2024-08-03 23:19:49 +08:00
5dec6a8273 chore: bump version to 1.1.4 2024-07-29 15:44:10 +08:00
0e429a4762 fix: OS servers log path 2024-07-29 15:43:25 +08:00
5164a17dca style: pylint 2024-07-28 10:13:21 +08:00
a660c03bb5 docs: fix old project name 2024-07-27 15:56:13 +08:00
d7457f2bfb chore: bump version to 1.1.3 2024-07-27 15:50:31 +08:00
223ab899e0 fix(uigf): add bangboo to ID table
close: #5
2024-07-27 15:50:02 +08:00
f62ca1d7e7 chore: bump version to 1.1.2 2024-07-26 10:06:44 +08:00
c034b2e70a feat(uigf): metadata from local db 2024-07-26 10:05:02 +08:00
a2faa86f0c chore: bump version to 1.1.1 2024-07-25 21:45:45 +08:00
510bfdab7a feat: add support for Europe, America, TW,HK,MO servers 2024-07-25 21:44:38 +08:00
f616944755 chore: bump version to 1.1.0 2024-07-25 13:47:37 +08:00
7300c6e719 refactor(i18n): UIGF v4.0 is no longer in beta 2024-07-25 13:26:57 +08:00
6fe12da9be feat(uigf): import UIGFv4.0
BREAKING CHANGES: `region` is no longer stored in/read from local file
2024-07-25 13:25:26 +08:00
14cfda3986 chore: bump version to 1.0.10 2024-07-24 21:02:40 +08:00
8156b5a9b7 fix: UIGF prod_gf_jp timezone 2024-07-24 21:00:50 +08:00
dd098fcd08 chore: bump version to 1.0.9 2024-07-23 15:03:52 +08:00
0cdc7662f7 feat(uigf): support multiple account export 2024-07-23 15:03:30 +08:00
2814ed211b fix(uigf): incorrect timezone 2024-07-23 12:51:22 +08:00
2f14a4d320 chore: bump version to 1.0.8 2024-07-23 11:11:10 +08:00
0e4f3599c9 feat(uigf): support UIGFv4.0(Beta)
Users don't have to delete their data. New data structure is used automatically when new data is fetched

- Set `count` to `"1"` as default for old data
- Record `count` from API
- Link to the UIGF website

BREAKING CHANGE: SRGF is no longer supported, use UIGFv4.0(Beta) instead
2024-07-23 11:10:27 +08:00
f1e3b76d85 chore: bump version to 1.0.7 2024-07-23 07:47:20 +08:00
2736ee0398 fix(excel): fix excel output style 2024-07-23 07:46:30 +08:00
66188231bc chore: bump version to 1.0.6 2024-07-22 21:59:23 +08:00
5624af3fb2 fix(build): fix icon 2024-07-22 21:58:17 +08:00
3c848a97f8 docs(readme): update project name in Chinese title 2024-07-21 23:25:56 +08:00
6ddc29af5a docs(readme): update readme links 2024-07-21 23:13:30 +08:00
e83fe42268 fix(utils): update hash keys 2024-07-21 21:42:19 +08:00
f9e74b4fb8 chore: bump version to 1.0.5 2024-07-21 20:46:26 +08:00
84179ccc8d ci: fix yarn lock for actions 2024-07-21 20:46:05 +08:00
8b725053ce feat(update): re-implement auto update 2024-07-21 19:45:51 +08:00
bebb14b63d chore: bump version to 1.0.4 2024-07-21 14:30:40 +08:00
2adf56d062 fix(gachaDetail): reset countMio when get S-Rank 2024-07-21 14:26:14 +08:00
ee94ae36cd chore: bump version to 1.0.3 2024-07-21 13:33:58 +08:00
e575e46238 fix(getData): update API host for OS servers 2024-07-21 13:33:04 +08:00
3fac233471 fix(getData): game path for test not removed 2024-07-21 13:26:29 +08:00
d99af2cc26 chore: bump version to v1.0.2 2024-07-20 19:25:15 +08:00
681e664e32 feat: check url from cache
1. NEVER MODIFY THE `yarn.lock` YOU GET. YOU NEVER KNOW WHAT IT CRASHES
2. FUCK REGEX
2024-07-20 19:24:01 +08:00
5f9fc94709 chore: bump version to v1.0.1 2024-07-19 01:42:02 +08:00
d96bd9f355 fix: read url from log
Directly get url from `Player.log`

Closes #2
2024-07-19 01:37:21 +08:00
3ff2879041 add lanzou link 2024-07-17 17:16:31 +08:00
2aa754d471 v1.0.0 2024-07-17 17:07:46 +08:00
mio
60bc7b43ee Replace invalid npm registry 2024-05-09 13:56:02 +08:00
mio
23d102fe67 fix: sometimes appid error 2024-03-31 15:01:35 +08:00
mio
e307d21bb2 feat: save data only in the current program directory 2024-01-22 15:15:17 +08:00
mio
8ff629b655 Upgrade version 2023-10-28 10:01:55 +08:00
ToooAir
0c778c09f4 fixed: unknown host (#54)
Closes #53 
我這邊yarn build之後運行正常

---------

Co-authored-by: biuuu <10892119+biuuu@users.noreply.github.com>
2023-10-28 09:57:14 +08:00
Ludovic Six
8c370ff0a7 Update Français.json (#50)
Added : 
- ui.setting.dataManagerHint

Updated :
- ui.button.files

Small fix. Translation is now complete. And no formatting issues this
time (sorry for that).
2023-10-14 16:46:01 +08:00
mio
1ab284c880 upgrade version 2023-10-11 18:16:04 +08:00
Ludovic Six
dc5053cb03 Zenshio patch 2 (#49)
Added :
- ui.button.files
- ui.button.solution
- ui.button.cacheFolder
- ui.button.copyUrl
- ui.common.data
- ui.common.dataManage
- ui.common.updateTime
- ui.common.status
- ui.common.action
- ui.common.deleted
- ui.common.normal
- ui.common.delete
- ui.common.restore
- srgf.fileType
- ui.extra.cacheClean
- ui.extra.findCacheFolder
- ui.extra.urlCopied

Updated :
- ui.hint.init
- ui.win.title
- ui.data.no5star
- ui.data.weapon
- ui.data.average
- ui.data.weapon5
- ui.data.weapon4
- ui.data.weapon3
- ui.setting.hideNovice
- log.file.notFound
- log.fetch.authTimeout
- log.fetch.gachaType
- log.fetch.gachaTypeOk
- log.proxy.hint
- log.url.notFound2
- excel.wish2
- excel.filePrefix
2023-10-11 09:35:05 +08:00
mio
49c1685e5e fix: Russian records cannot be exported to Excel file (#32) 2023-09-24 11:40:57 +08:00
mio
89a0553c59 upgrade version 2023-09-24 03:29:51 +08:00
BlackHazel
3605826953 fix: Update utils.js for French HSR. (#47)
For some reason mihoyo renamed "cônes de lumière" to "Cône de lumière"
and "Personnages" to "Personnage". This patch only includes the newer
term without removing the old ones for retro-compatibility.


![PR](https://github.com/biuuu/star-rail-warp-export/assets/12218001/c68c4fe9-66bf-4d54-bcca-7bf48b052ad5)
2023-09-24 03:15:47 +08:00
XyLyXyRR
75f2f2dd4f fix(package): homepage (#46)
Same as
[genshin-wish-export](https://github.com/biuuu/genshin-wish-export/pull/217).
2023-09-05 17:44:31 +08:00
53 changed files with 3554 additions and 1440 deletions

View File

@@ -2,10 +2,10 @@ const fs = require('fs-extra')
const path = require('path') const path = require('path')
const crypto = require('crypto') const crypto = require('crypto')
const AdmZip = require('adm-zip') const AdmZip = require('adm-zip')
const { version } = require('../package.json') const { version, autoUpdateActive, autoUpdateFrom } = require('../package.json')
const hash = (data, type = 'sha256') => { const hash = (data, type = 'sha256') => {
const hmac = crypto.createHmac(type, 'hk4e') const hmac = crypto.createHmac(type, 'nap')
hmac.update(data) hmac.update(data)
return hmac.digest('hex') return hmac.digest('hex')
} }
@@ -19,13 +19,12 @@ const createZip = (filePath, dest) => {
const start = async () => { const start = async () => {
copyAppZip() copyAppZip()
const appPath = './build/win-unpacked/resources/app' const appPath = './build/win-ia32-unpacked/resources/app'
const name = 'app.zip' const name = 'app.zip'
const outputPath = path.resolve('./build/update/update/') const outputPath = path.resolve('./build/update/update/')
const zipPath = path.resolve(outputPath, name) const zipPath = path.resolve(outputPath, name)
await fs.ensureDir(outputPath) await fs.ensureDir(outputPath)
await fs.emptyDir(outputPath) await fs.emptyDir(outputPath)
await fs.outputFile('./build/update/CNAME', 'star-rail-warp-export.css.moe')
createZip(appPath, zipPath) createZip(appPath, zipPath)
const buffer = await fs.readFile(zipPath) const buffer = await fs.readFile(zipPath)
const sha256 = hash(buffer) const sha256 = hash(buffer)
@@ -33,9 +32,9 @@ const start = async () => {
await fs.copy(zipPath, path.resolve(outputPath, `${hashName}.zip`)) await fs.copy(zipPath, path.resolve(outputPath, `${hashName}.zip`))
await fs.remove(zipPath) await fs.remove(zipPath)
await fs.outputJSON(path.join(outputPath, 'manifest.json'), { await fs.outputJSON(path.join(outputPath, 'manifest.json'), {
active: true, active: autoUpdateActive,
version, version: version,
from: '0.0.1', from: autoUpdateFrom,
name: `${hashName}.zip`, name: `${hashName}.zip`,
hash: sha256 hash: sha256
}) })
@@ -44,19 +43,9 @@ const start = async () => {
const copyAppZip = () => { const copyAppZip = () => {
try { try {
const dir = path.resolve('./build') const dir = path.resolve('./build')
const filePath = path.resolve(dir, `StarRailWarpExport-${version}-win.zip`) const filePath = path.resolve(dir, `ZzzSignalSearchExport-${version}-ia32-win.zip`)
fs.copySync(filePath, path.join(dir, 'app.zip')) fs.copySync(filePath, path.join(dir, 'app.zip'))
} catch (e) {} } catch (e) {}
} }
const copyHTML = () => {
try {
const output = path.resolve('./build/update/')
const dir = path.resolve('./src/web/')
fs.copySync(dir, output)
} catch (e) {
console.error(e)
}
}
start() start()

13
.github/FUNDING.yml vendored
View File

@@ -1,13 +0,0 @@
# These are supported funding model platforms
github: # Replace with up to 4 GitHub Sponsors-enabled usernames e.g., [user1, user2]
patreon: # Replace with a single Patreon username
open_collective: # Replace with a single Open Collective username
ko_fi: # Replace with a single Ko-fi username
tidelift: # Replace with a single Tidelift platform-name/package-name e.g., npm/babel
community_bridge: # Replace with a single Community Bridge project-name e.g., cloud-foundry
liberapay: # Replace with a single Liberapay username
issuehunt: # Replace with a single IssueHunt username
otechie: # Replace with a single Otechie username
lfx_crowdfunding: # Replace with a single LFX Crowdfunding project-name e.g., cloud-foundry
custom: https://afdian.net/a/haisha

View File

@@ -1,14 +1,15 @@
on: on:
workflow_dispatch:
push: push:
# Sequence of patterns matched against refs/tags # Sequence of patterns matched against refs/tag
tags: tags:
- 'v*' # Push events to matching v*, i.e. v1.0, v20.15.10 - 'v*' # Push events to matching v*, i.e. v1.0, v20.15.10
name: Upload Release Asset name: Release
jobs: jobs:
build: build:
name: Upload Release Asset name: Release
runs-on: windows-latest runs-on: windows-latest
steps: steps:
- name: Checkout code - name: Checkout code
@@ -20,17 +21,17 @@ jobs:
- name: Build App - name: Build App
run: | run: |
yarn --frozen-lockfile yarn --frozen-lockfile
yarn build:win64 yarn build:win32
yarn build-update yarn build-update
- name: Create Release - name: Create Release
if: success() if: success()
id: create_release id: create_release
uses: actions/create-release@v1 uses: actions/create-release@v1
env: env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} GITHUB_TOKEN: ${{ secrets.TOKEN }}
with: with:
tag_name: ${{ github.ref }} tag_name: ${{ github.ref }}
release_name: Release ${{ github.ref }} release_name: ZzzSignalSearchExport ${{ github.ref }}
draft: false draft: false
prerelease: false prerelease: false
- name: Upload Release Asset - name: Upload Release Asset
@@ -38,11 +39,11 @@ jobs:
id: upload-release-asset id: upload-release-asset
uses: actions/upload-release-asset@v1 uses: actions/upload-release-asset@v1
env: env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} GITHUB_TOKEN: ${{ secrets.TOKEN }}
with: with:
upload_url: ${{ steps.create_release.outputs.upload_url }} # This pulls from the CREATE RELEASE step above, referencing it's ID to get its outputs object, which include a `upload_url`. See this blog post for more info: https://jasonet.co/posts/new-features-of-github-actions/#passing-data-to-future-steps upload_url: ${{ steps.create_release.outputs.upload_url }} # This pulls from the CREATE RELEASE step above, referencing it's ID to get its outputs object, which include a `upload_url`. See this blog post for more info: https://jasonet.co/posts/new-features-of-github-actions/#passing-data-to-future-steps
asset_path: ./build/app.zip asset_path: ./build/app.zip
asset_name: StarRailWarpExport.zip asset_name: ZzzSignalSearchExport.zip
asset_content_type: application/zip asset_content_type: application/zip
- name: Deploy update - name: Deploy update
if: success() if: success()
@@ -51,4 +52,4 @@ jobs:
commit_message: Update app commit_message: Update app
build_dir: ./build/update build_dir: ./build/update
env: env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} GITHUB_TOKEN: ${{ secrets.TOKEN }}

2
.npmrc
View File

@@ -1 +1 @@
ELECTRON_MIRROR=https://npm.taobao.org/mirrors/electron/ ELECTRON_MIRROR=https://npmmirror.com/mirrors/electron/

View File

@@ -1,6 +1,6 @@
MIT License MIT License
Copyright (c) 2023 biuuu Copyright (c) 2024 earthjasonlin
Permission is hereby granted, free of charge, to any person obtaining a copy Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal of this software and associated documentation files (the "Software"), to deal

View File

@@ -1,12 +1,12 @@
# 星穹铁道跃迁记录导出工具 # 绝区零调频记录导出工具
中文 | [English](https://github.com/biuuu/star-rail-warp-export/blob/main/docs/README_EN.md) 中文 | [English](https://github.com/earthjasonlin/zzz-signal-search-export/blob/main/docs/README_EN.md)
这个项目由[genshin-wish-export](https://github.com/biuuu/genshin-wish-export/)修改而来,功能基本一致。 这个项目由[star-rail-warp-export](https://github.com/biuuu/star-rail-warp-export/)修改而来,功能基本一致。
一个使用 Electron 制作的小工具,需要在 Windows 64位操作系统上运行。 一个使用 Electron 制作的小工具,需要在 Windows 操作系统上运行。
通过读取游戏日志或者代理模式获取访问游戏跃迁记录 API 所需的 authKey然后再使用获取到的 authKey 来读取游戏跃迁记录。 通过读取游戏日志或者代理模式获取访问游戏调频记录 API 所需的 authKey然后再使用获取到的 authKey 来读取游戏调频记录。
## 其它语言 ## 其它语言
@@ -14,10 +14,10 @@
## 使用说明 ## 使用说明
1. 下载工具后解压 - 下载地址: [Github](https://github.com/biuuu/star-rail-warp-export/releases/latest/download/StarRailWarpExport.zip) / [蓝奏云](https://wwvt.lanzoum.com/b022mikwh) 密码:f1iy 1. 下载工具后解压 - 下载地址: [GitHub](https://github.com/earthjasonlin/zzz-signal-search-export/releases/latest/download/ZzzSignalSearchExport.zip) / [123云盘](https://www.123pan.com/s/Vs9uVv-ShhE.html) / [蓝奏云(密码:zzzz](https://www.lanzouh.com/b00eewtvxa)
2. 打开游戏的跃迁详情页面 2. 打开游戏的调频详情页面
![详情页面](/docs/wish-history.png) ![详情页面](/docs/wish-history.jpg)
3. 点击工具的“加载数据”按钮 3. 点击工具的“加载数据”按钮
@@ -34,11 +34,15 @@
如果需要导出多个账号的数据,可以点击旁边的加号按钮。 如果需要导出多个账号的数据,可以点击旁边的加号按钮。
然后游戏切换的新账号,再打开跃迁历史记录,工具再点击“加载数据”按钮。 然后游戏切换的新账号,再打开调频历史记录,工具再点击“加载数据”按钮。
## Stargazers over time
[![Stargazers over time](https://starchart.cc/earthjasonlin/zzz-signal-search-export.svg)](https://starchart.cc/earthjasonlin/zzz-signal-search-export)
## Devlopment ## Devlopment
``` ```bash
# 安装模块 # 安装模块
yarn install yarn install
@@ -51,4 +55,4 @@ yarn build
## License ## License
[MIT](https://github.com/biuuu/star-rail-warp-export/blob/main/LICENSE) [MIT](https://github.com/earthjasonlin/zzz-signal-search-export/blob/main/LICENSE)

Binary file not shown.

Before

Width:  |  Height:  |  Size: 126 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 382 KiB

Binary file not shown.

Binary file not shown.

Before

Width:  |  Height:  |  Size: 210 KiB

After

Width:  |  Height:  |  Size: 42 KiB

BIN
build/icons/image.jpeg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 429 KiB

View File

@@ -1,12 +1,12 @@
# Star Rail Warp History Exporter # Zenless Zone Zero Signal Search History Exporter
[中文](https://github.com/biuuu/star-rail-warp-export/blob/main/README.md) | English [中文](https://github.com/earthjasonlin/zzz-signal-search-export) | English
This project is modified from the [genshin-wish-export](https://github.com/biuuu/genshin-wish-export/) repository, and its functions are basically the same. This project is modified from the [star-rail-warp-export](https://github.com/biuuu/star-rail-warp-export/) repository, and its functions are basically the same.
A tool made from Electron that runs on the Windows 64 bit operating system. A tool made from Electron that runs on the Windows operating system.
Read the game log or proxy to get the authKey needed to access the game warp history API, and then use the authKey to read the game wish history. Read the game log or proxy to get the authKey needed to access the game signal search history API, and then use the authKey to read the game wish history.
## Other languages ## Other languages
@@ -16,10 +16,11 @@ If you feel that the existing translation is inappropriate, you can send a pull
## Usage ## Usage
1. Unzip after downloading the tool - [Download](https://github.com/biuuu/star-rail-warp-export/releases/latest/download/StarRailWarpExport.zip) 1. Unzip after downloading the tool - [GitHub](https://github.com/earthjasonlin/zzz-signal-search-export/releases/latest/download/ZzzSignalSearchExport.zip)
2. Open the warp details page of the game
![warp details](/docs/wish-history-en.png) 2. Open the signal search details page of the game
![warp details](/docs/wish-history-en.jpg)
3. Click the tool's "Load data" button 3. Click the tool's "Load data" button
@@ -39,7 +40,7 @@ Then switch to the new account of the game, open the wish history, and click the
## Devlopment ## Devlopment
``` ```bash
# install node modules # install node modules
yarn install yarn install
@@ -52,5 +53,4 @@ yarn build
## License ## License
[MIT](https://github.com/biuuu/star-rail-warp-export/blob/main/LICENSE) [MIT](https://github.com/earthjasonlin/zzz-signal-search-export/blob/main/LICENSE)

Binary file not shown.

Before

Width:  |  Height:  |  Size: 6.7 KiB

After

Width:  |  Height:  |  Size: 5.1 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 9.0 KiB

After

Width:  |  Height:  |  Size: 15 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 55 KiB

After

Width:  |  Height:  |  Size: 185 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 65 KiB

After

Width:  |  Height:  |  Size: 136 KiB

BIN
docs/wish-history-en.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 30 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 45 KiB

BIN
docs/wish-history.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 43 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 46 KiB

View File

@@ -1,8 +1,11 @@
{ {
"name": "star-rail-warp-export", "name": "zzz-signal-search-export",
"version": "0.1.2", "version": "1.1.10",
"autoUpdateActive": true,
"autoUpdateFrom": "1.1.0",
"main": "./dist/electron/main/main.js", "main": "./dist/electron/main/main.js",
"author": "biuuu <https://github.com/biuuu>", "author": "earthjasonlin <https://git.loliquq.cn/earthjasonlin>",
"homepage": "https://github.com/earthjasonlin/zzz-signal-search-export",
"license": "MIT", "license": "MIT",
"scripts": { "scripts": {
"dev": "node .electron-vite/dev-runner.js", "dev": "node .electron-vite/dev-runner.js",
@@ -15,9 +18,9 @@
"build:dir": "cross-env BUILD_TARGET=clean node .electron-vite/build.js && electron-builder --dir", "build:dir": "cross-env BUILD_TARGET=clean node .electron-vite/build.js && electron-builder --dir",
"build:clean": "cross-env BUILD_TARGET=onlyClean node .electron-vite/build.js", "build:clean": "cross-env BUILD_TARGET=onlyClean node .electron-vite/build.js",
"build:web": "cross-env BUILD_TARGET=web node .electron-vite/build.js", "build:web": "cross-env BUILD_TARGET=web node .electron-vite/build.js",
"build-update": "node .electron-vite/update.js",
"dev:web": "cross-env TARGET=web node .electron-vite/dev-runner.js", "dev:web": "cross-env TARGET=web node .electron-vite/dev-runner.js",
"start": "electron ./src/main/main.js", "start": "electron ./src/main/main.js",
"build-update": "node .electron-vite/update.js",
"dep:upgrade": "yarn upgrade-interactive --latest", "dep:upgrade": "yarn upgrade-interactive --latest",
"postinstall": "electron-builder install-app-deps" "postinstall": "electron-builder install-app-deps"
}, },
@@ -34,8 +37,8 @@
"url": "http://127.0.0.1" "url": "http://127.0.0.1"
} }
], ],
"productName": "StarRailWarpExport", "productName": "ZzzSignalSearchExport",
"appId": "org.biuuu.star-rail-warp-export", "appId": "org.earthjasonlin.zzz-signal-search-export",
"directories": { "directories": {
"output": "build" "output": "build"
}, },
@@ -107,7 +110,7 @@
"tailwindcss": "^3.0.16", "tailwindcss": "^3.0.16",
"vite": "2.7.13", "vite": "2.7.13",
"vue": "^3.2.29", "vue": "^3.2.29",
"winreg": "^1.2.4", "winreg": "1.2.4",
"yauzl": "^2.10.0" "yauzl": "^2.10.0"
}, },
"keywords": [ "keywords": [

View File

@@ -1,85 +1,22 @@
[ [
[
"de-de",
[
{
"key": "11",
"name": "Figuren-Aktionswarp"
},
{
"key": "12",
"name": "Lichtkegel-Aktionswarp"
},
{
"key": "1",
"name": "Standardwarp"
},
{
"key": "2",
"name": "Einsteigerwarp"
}
]
],
[
"ru-ru",
[
{
"key": "11",
"name": "Прыжок события: Персонаж"
},
{
"key": "12",
"name": "Прыжок события: Световой конус"
},
{
"key": "1",
"name": "Стандартный прыжок"
},
{
"key": "2",
"name": "Прыжок новичка"
}
]
],
[
"th-th",
[
{
"key": "11",
"name": "กิจกรรมวาร์ปตัวละคร"
},
{
"key": "12",
"name": "กิจกรรมวาร์ป Light Cone"
},
{
"key": "1",
"name": "วาร์ปถาวร"
},
{
"key": "2",
"name": "วาร์ปสำหรับมือใหม่"
}
]
],
[ [
"zh-cn", "zh-cn",
[ [
{ {
"key": "11", "key": "2",
"name": "角色活动跃迁" "name": "独家频段"
}, },
{ {
"key": "12", "key": "3",
"name": "光锥活动跃迁" "name": "音擎频段"
}, },
{ {
"key": "1", "key": "1",
"name": "常驻跃迁" "name": "常驻频段"
}, },
{ {
"key": "2", "key": "5",
"name": "新手跃迁" "name": "邦布频段"
} }
] ]
], ],
@@ -87,20 +24,20 @@
"zh-tw", "zh-tw",
[ [
{ {
"key": "11", "key": "2",
"name": "角色活動躍遷" "name": "獨家頻段"
}, },
{ {
"key": "12", "key": "3",
"name": "光錐活動躍遷" "name": "音擎頻段"
}, },
{ {
"key": "1", "key": "1",
"name": "常駐躍遷" "name": "常駐頻段"
}, },
{ {
"key": "2", "key": "5",
"name": "新手躍遷" "name": "邦布頻段"
} }
] ]
], ],
@@ -108,167 +45,20 @@
"en-us", "en-us",
[ [
{ {
"key": "11", "key": "2",
"name": "Character Event Warp" "name": "Exclusive Channel"
}, },
{ {
"key": "12", "key": "3",
"name": "Light Cone Event Warp" "name": "W-Engine Channel"
}, },
{ {
"key": "1", "key": "1",
"name": "Regular Warp" "name": "Stable Channel"
}, },
{ {
"key": "2", "key": "5",
"name": "Starter Warp" "name": "Bangboo Channel"
}
]
],
[
"es-es",
[
{
"key": "11",
"name": "Salto de evento de personaje"
},
{
"key": "12",
"name": "Salto de evento de cono de luz"
},
{
"key": "1",
"name": "Salto normal"
},
{
"key": "2",
"name": "Salto de principiante"
}
]
],
[
"fr-fr",
[
{
"key": "11",
"name": "Saut hyperespace événement de personnage"
},
{
"key": "12",
"name": "Saut hyperespace événement de cônes de lumière"
},
{
"key": "1",
"name": "Saut hyperespace classique"
},
{
"key": "2",
"name": "Saut hyperespace de départ"
}
]
],
[
"id-id",
[
{
"key": "11",
"name": "Event Warp Karakter"
},
{
"key": "12",
"name": "Event Warp Light Cone"
},
{
"key": "1",
"name": "Warp Reguler"
},
{
"key": "2",
"name": "Warp Pemula"
}
]
],
[
"ja-jp",
[
{
"key": "11",
"name": "イベント跳躍・キャラクター"
},
{
"key": "12",
"name": "イベント跳躍・光円錐"
},
{
"key": "1",
"name": "恒常跳躍"
},
{
"key": "2",
"name": "初心者跳躍"
}
]
],
[
"ko-kr",
[
{
"key": "11",
"name": "캐릭터 이벤트 워프"
},
{
"key": "12",
"name": "광추 이벤트 워프"
},
{
"key": "1",
"name": "상시 워프"
},
{
"key": "2",
"name": "초보자 워프"
}
]
],
[
"pt-pt",
[
{
"key": "11",
"name": "Salto Hiperespacial de Evento de Personagem"
},
{
"key": "12",
"name": "Salto Hiperespacial de Evento de Cone de Luz"
},
{
"key": "1",
"name": "Salto Hiperespacial Permanente"
},
{
"key": "2",
"name": "Salto Hiperespacial Inicial"
}
]
],
[
"vi-vn",
[
{
"key": "11",
"name": "Bước Nhảy Sự Kiện Nhân Vật"
},
{
"key": "12",
"name": "Bước Nhảy Sự Kiện Nón Ánh Sáng"
},
{
"key": "1",
"name": "Bước Nhảy Vĩnh Viễn"
},
{
"key": "2",
"name": "Bước Nhảy Tân Thủ"
} }
] ]
] ]

View File

@@ -1,81 +0,0 @@
{
"symbol.colon": ": ",
"ui.button.load": "Lade Daten",
"ui.button.update": "Aktualisieren",
"ui.button.excel": "In Excel exportieren",
"ui.button.srgf": "In JSON exportieren",
"ui.button.url": "Eingabe URL",
"ui.button.setting": "Einstellungen",
"ui.button.option": "Optionen",
"ui.button.startProxy": "Proxy modus",
"ui.select.newAccount": "Neuer Nutzer",
"ui.hint.newAccount": "Daten von anderen Nutzern exportieren",
"ui.hint.init": "Bitte öffne deinen Wunschlverlauf im Spiel bevor du versuchst deine Wunschdaten zu laden",
"ui.hint.lastUpdate": "Letzte Aktualisierung",
"ui.hint.failed": "Oops, irgendetwas ist schief gelaufen",
"ui.win.title": "",
"ui.data.total": "Total",
"ui.data.times": "Wünsche",
"ui.data.sum": "Angehäuft",
"ui.data.no5star": "Wünsche ohne 5 Sterne",
"ui.data.character": "Character",
"ui.data.weapon": "",
"ui.data.star5": "5 Sterne",
"ui.data.star4": "4 Sterne",
"ui.data.star3": "3 Sterne",
"ui.data.history": "5 Sterne verlauf",
"ui.data.average": "Durschnittlicher 5 Sterne",
"ui.data.chara5": "5 Sterne Character",
"ui.data.chara4": "4 Sterne Character",
"ui.data.weapon5": "",
"ui.data.weapon4": "",
"ui.data.weapon3": "",
"ui.setting.title": "Einstellungen",
"ui.setting.language": "Sprache",
"ui.setting.languageHint": "Wenn eine Übersetzung fehlt, wird Englisch als Standardsparche ausgewählt.",
"ui.setting.logType": "Aufzeichnungstyp",
"ui.setting.auto": "Automatisch",
"ui.setting.cnServer": "CN Server",
"ui.setting.seaServer": "Globaler Server",
"ui.setting.logTypeHint": "Wähle aus, welche von dem Server generierten Aufzeichnungen benutzt werden sollen, wenn zum ersten mal die URL von den Spielaufzeichnungen erworben wird",
"ui.setting.autoUpdate": "Automatische Aktualisierung",
"ui.setting.proxyMode": "Proxy modus",
"ui.setting.proxyModeHint": "Wenn das Erwerben der URL von den Systemaufzeichnungen scheitert, nutz den Systemproxy",
"ui.setting.closeProxy": "Deaktiviere den Systemproxy",
"ui.setting.closeProxyHint": "Wenn der Proxymodus aktiviert ist und das Programm abstürzt kann es zu unerwünschten Folgen für dein System führen. Du kannst diesen Knopf drücken, um die Systemproxy Einstellungen zurückzusetzen.",
"ui.about.title": "Über uns",
"ui.about.license": "Diese Software ist Open-Source und nutzt die MIT Lizenz.",
"ui.urlDialog.title": "Gebe die URL manuell ein",
"ui.urlDialog.hint": "Diese Funktion sollte nur benutzt werden, falls Sie wissen, welche URL hier benötigt wird",
"ui.urlDialog.placeholder": "Bitte gebe die URL mit den Authentifizierungsinformationen ein",
"ui.common.cancel": "Abbrechen",
"ui.common.ok": "Weiter",
"log.save.failed": "Lokale Daten konnten nicht gespeichert werden",
"log.file.notFound": "Die Wunschaufzeichnungen konnten nicht gefunden werden, stelle sicher, dass du im Spiel deinen Wunschverlauf schon geöffnet hast",
"log.url.notFound": "Konnte die URL nicht finden",
"log.file.readFailed": "Konnte die Aufzeichnungen nicht lesen",
"log.fetch.retry": "Das Verarbeiten von ${name} auf Seite ${page} ist gescheitertversuche in 5 Sekunden erneut, zum ${count}. mal…",
"log.fetch.retryFailed": "Das Verarbeiten von ${name} auf Seite ${page} ist gescheitert, maximale Versuche wurden erreicht",
"log.fetch.interval": "Verarbeite ${name} auf Seite ${page}1 Sekunde Timeout für 10 Seiten…",
"log.fetch.current": "Verarbeite ${name} auf Seite ${page}",
"log.fetch.authTimeout": "Die Nutzer Authentifizierung ist abgelaufen, bitte öffne im Spiel die Wunschaufzeichnungen erneut.",
"log.fetch.gachaType": "Wunschtyp wird erworben, bitte warten",
"log.fetch.gachaTypeOk": "Wunschtyp erworben",
"log.url.lackAuth": "Der Authentifizierungsschlüssel konnte in der URL nicht aufgefunden werden",
"log.proxy.hint": "Nutze den Proxymodus [${ip}:${port}] um die URL zu erwerben, bitte öffne im Spiel die Wunschaufzeichnungen erneut.",
"log.url.notFound2": "URL konnte nicht gefunden werden, bitte stelle sicher, dass du deinen Wunschverlauf schon einmal im Spiel geöffnet hast",
"log.url.incorrect": "URL Parameter konnten nicht erworben werden",
"log.autoUpdate.success": "Die automatische aktualisierung war erfolgreich, bitte starten sie das Programm neu",
"excel.header.time": "zeit",
"excel.header.name": "name",
"excel.header.type": "typ",
"excel.header.rank": "seltenheit",
"excel.header.total": "ingesammt",
"excel.header.pity": "innerhalb von pity",
"excel.header.remark": "bemerkung",
"excel.wish2": "Wunsch 2",
"excel.customFont": "Arial",
"excel.filePrefix": "",
"excel.fileType": "Excel Datei",
"srgf.fileType": "Star Rail Gacha Log Format Datei"
}

View File

@@ -3,9 +3,10 @@
"ui.button.load": "Load data", "ui.button.load": "Load data",
"ui.button.update": "Update", "ui.button.update": "Update",
"ui.button.directUpdate": "Direct update", "ui.button.directUpdate": "Direct update",
"ui.button.files": "Export Files", "ui.button.files": "Import/Export",
"ui.button.excel": "Export Excel", "ui.button.excel": "Export Excel",
"ui.button.srgf": "Export JSON", "ui.button.uigf": "Export UIGF",
"ui.button.import": "Import UIGF",
"ui.button.url": "Input URL", "ui.button.url": "Input URL",
"ui.button.setting": "Settings", "ui.button.setting": "Settings",
"ui.button.option": "Option", "ui.button.option": "Option",
@@ -19,23 +20,26 @@
"ui.hint.lastUpdate": "Last update", "ui.hint.lastUpdate": "Last update",
"ui.hint.failed": "Oops, something failed", "ui.hint.failed": "Oops, something failed",
"ui.hint.relaunchHint": "The update has been completed, it will take effect after clicking the button to restart the tool", "ui.hint.relaunchHint": "The update has been completed, it will take effect after clicking the button to restart the tool",
"ui.win.title": "Star Rail Warp History Exporter", "ui.win.title": "Zenless Zone Zero Signal Search History Exporter",
"ui.data.total": "Total", "ui.data.total": "Total",
"ui.data.times": "Pulls", "ui.data.times": "Pulls",
"ui.data.sum": "Accumulated", "ui.data.sum": "Accumulated",
"ui.data.no5star": "pulls without a 5 star", "ui.data.no4star": "pulls without a S-Rank",
"ui.data.character": "Character", "ui.data.character": "Agents",
"ui.data.weapon": "Light Cone", "ui.data.weapon": "W-Engines",
"ui.data.star5": "5 star", "ui.data.bang": "Bangboo",
"ui.data.star4": "4 star", "ui.data.star4": "S-Rank",
"ui.data.star3": "3 star", "ui.data.star3": "A-Rank",
"ui.data.history": "5 star history", "ui.data.star2": "B-Rank",
"ui.data.average": "5 star on average", "ui.data.history": "S-Rank history",
"ui.data.chara5": "5 star character", "ui.data.average": "S-Rank on average",
"ui.data.chara4": "4 star character", "ui.data.chara4": "S-Rank Agents",
"ui.data.weapon5": "5 star Light Cone", "ui.data.chara3": "A-Rank Agents",
"ui.data.weapon4": "4 star Light Cone", "ui.data.weapon4": "S-Rank W-Engines",
"ui.data.weapon3": "3 star Light Cone", "ui.data.weapon3": "A-Rank W-Engines",
"ui.data.weapon2": "B-Rank W-Engines",
"ui.data.bang4": "S-Rank Bangboo",
"ui.data.bang3": "A-Rank Bangboo",
"ui.setting.title": "Settings", "ui.setting.title": "Settings",
"ui.setting.language": "Language", "ui.setting.language": "Language",
"ui.setting.languageHint": "When the translation is missing, English will be displayed by default.", "ui.setting.languageHint": "When the translation is missing, English will be displayed by default.",
@@ -53,6 +57,7 @@
"ui.setting.fetchFullHistoryHint": "When this option is enabled, click the \"Update Data\" button to get all the card draw records within 6 months. When there are incorrect data within 6 months, this function can be used to repair.", "ui.setting.fetchFullHistoryHint": "When this option is enabled, click the \"Update Data\" button to get all the card draw records within 6 months. When there are incorrect data within 6 months, this function can be used to repair.",
"ui.setting.closeProxy": "Disable system proxy", "ui.setting.closeProxy": "Disable system proxy",
"ui.setting.closeProxyHint": "When you choose proxy mode, if the program crashes it can cause unwanted results that may affect your system. You can click this button to clear the system proxy settings.", "ui.setting.closeProxyHint": "When you choose proxy mode, if the program crashes it can cause unwanted results that may affect your system. You can click this button to clear the system proxy settings.",
"ui.setting.idVersion": "ID database version",
"ui.about.title": "About", "ui.about.title": "About",
"ui.about.license": "This software is opensource using MIT license.", "ui.about.license": "This software is opensource using MIT license.",
"ui.urlDialog.title": "Input URL manually", "ui.urlDialog.title": "Input URL manually",
@@ -78,8 +83,8 @@
"log.fetch.interval": "Processing ${name} of page ${page}1 second timeout every 10 pages……", "log.fetch.interval": "Processing ${name} of page ${page}1 second timeout every 10 pages……",
"log.fetch.current": "Processing ${name} of page ${page}", "log.fetch.current": "Processing ${name} of page ${page}",
"log.fetch.authTimeout": "User authentication expired, please reopen warp history inside the game client.", "log.fetch.authTimeout": "User authentication expired, please reopen warp history inside the game client.",
"log.fetch.gachaType": "Getting warp type, please wait", "log.fetch.gachaType": "Getting signal search type, please wait",
"log.fetch.gachaTypeOk": "Warp type acquired", "log.fetch.gachaTypeOk": "Signal search type acquired",
"log.url.lackAuth": "Authkey not found in URL", "log.url.lackAuth": "Authkey not found in URL",
"log.proxy.hint": "Using proxy mode [${ip}:${port}] to get URLplease reopen warp history inside the game client.", "log.proxy.hint": "Using proxy mode [${ip}:${port}] to get URLplease reopen warp history inside the game client.",
"log.url.notFound2": "Unable to find URL, please make sure you already opened warp history inside the game client", "log.url.notFound2": "Unable to find URL, please make sure you already opened warp history inside the game client",
@@ -92,12 +97,13 @@
"excel.header.total": "total", "excel.header.total": "total",
"excel.header.pity": "within pity", "excel.header.pity": "within pity",
"excel.header.remark": "remark", "excel.header.remark": "remark",
"excel.wish2": "Warp 2", "excel.wish2": "Signal Search 2",
"excel.customFont": "Arial", "excel.customFont": "Arial",
"excel.filePrefix": "Star Rail Warp logger", "excel.filePrefix": "Zenless Zone Zero Signal Search Log",
"excel.fileType": "Excel file", "excel.fileType": "Excel file",
"srgf.fileType": "Star Rail Gacha Log Format file", "uigf.fileType": "Uniformed Interchangeable GachaLog Format v4.0 (Beta)",
"ui.extra.cacheClean": "1. Confirm whether the warp history in the game has been opened, and if the error \"User authentication expired\" still appears, try the following steps \n2. Close the game window of Star Rail \n3. Click the \"Open Web Cache Folder\" button above to open the \"Cache\" folder \n4. Delete the \"Cache_ Data\" folder \n5. Start the Star Rail game and open the warp history page in the game \n6. Close this dialog and click the \"Update Data\" button", "ui.extra.cacheClean": "1. Confirm whether the search history in the game has been opened, and if the error \"User authentication expired\" still appears, try the following steps \n2. Close the game window of Zenless Zone Zero \n3. Click the \"Open Web Cache Folder\" button above to open the \"Cache\" folder \n4. Delete the \"Cache_Data\" folder \n5. Start the Zenless Zone Zero game and open the search history page in the game \n6. Close this dialog and click the \"Update Data\" button",
"ui.extra.findCacheFolder": "If the \"Open cache folder\" button does not respond, you can manually find the game's web cache folder. The directory is \"Your game installation path/Star Rail/Games/StarRail_Data/webCaches/Cache/\"", "ui.extra.findCacheFolder": "If the \"Open cache folder\" button does not respond, you can manually find the game's web cache folder. The directory is \"Your game installation path/ZenlessZoneZero_Data/webCaches/Cache/\"",
"ui.extra.urlCopied": "URL Copied" "ui.extra.urlCopied": "URL Copied",
"ui.uigf.title": "Please select the UID(s) you want to export"
} }

View File

@@ -1,77 +0,0 @@
{
"symbol.colon": ": ",
"ui.button.load": "Obtener datos",
"ui.button.update": "Actualizar",
"ui.button.excel": "Exportar a Excel",
"ui.button.url": "Introducir URL",
"ui.button.setting": "Ajustes",
"ui.button.option": "Opciones",
"ui.button.startProxy": "Modo proxy",
"ui.select.newAccount": "Nueva cuenta",
"ui.hint.newAccount": "Exportar datos de otras cuentas",
"ui.hint.init": "Por favor, abre el historial de deseos en el juego antes de pulsar en el botón 'Obtener datos'.",
"ui.hint.lastUpdate": "Última actualización",
"ui.hint.failed": "Ups, algo ha fallado",
"ui.win.title": "",
"ui.data.total": "Total",
"ui.data.times": "tiradas",
"ui.data.sum": "acumuladas.",
"ui.data.no5star": "tiradas sin un 5 estrellas",
"ui.data.character": "Personaje",
"ui.data.weapon": "",
"ui.data.star5": "5 estrellas",
"ui.data.star4": "4 estrellas",
"ui.data.star3": "3 estrellas",
"ui.data.history": "Historial de 5 estrellas",
"ui.data.average": "Promedio de tiradas para un 5 estrellas",
"ui.data.chara5": "Personaje 5 estrellas",
"ui.data.chara4": "Personaje 4 estrellas",
"ui.data.weapon5": "",
"ui.data.weapon4": "",
"ui.data.weapon3": "",
"ui.setting.title": "Ajustes",
"ui.setting.language": "Idiomas",
"ui.setting.languageHint": "Si no se encuentra una traducción se mostrará en inglés por defecto.",
"ui.setting.logType": "Tipo de log",
"ui.setting.auto": "Auto",
"ui.setting.cnServer": "Servidor CN",
"ui.setting.seaServer": "Servidor global",
"ui.setting.logTypeHint": "Elige qué logs generados por el servidor se utilizarán primero al obtener la URL de los logs del juego.",
"ui.setting.autoUpdate": "Actualización automática",
"ui.setting.proxyMode": "Modo proxy",
"ui.setting.proxyModeHint": "Cuando no se pueda obtener la URL de los logs del sistema utiliza el modo proxy.",
"ui.setting.closeProxy": "Desactivar proxy del sistema",
"ui.setting.closeProxyHint": "Al seleccionar el modo proxy si el programa falla puede causar resultados no deseados que pueden afectar a tu sistema. Puede hacer click en este botón para borrar la configuración del proxy del sistema.",
"ui.about.title": "",
"ui.about.license": "Este software es opensource con licencia MIT.",
"ui.urlDialog.title": "Introducir URL manualmente",
"ui.urlDialog.hint": "Utiliza esta función solo si sabes qué URL se necesita introducir",
"ui.urlDialog.placeholder": "Introduce la URL con la información de autenticación",
"ui.common.cancel": "Cancelar",
"ui.common.ok": "OK",
"log.save.failed": "Error al guardar datos locales",
"log.file.notFound": "No se han podido encontrar los logs del juego, asegurate de que has abierto el historial de deseos dentro del juego.",
"log.url.notFound": "No se ha podido encontrar la URL",
"log.file.readFailed": "Error al leer los logs",
"log.fetch.retry": "Error al procesar ${name} en la página ${page}. Reintentando en 5 segudos por ${count} vez",
"log.fetch.retryFailed": "Error al procesar ${name} en la página ${page}alcanzado el número máximo de intentos",
"log.fetch.interval": "Procesando ${name} en la página ${page}1 segundo de tiempo de espera cada 10 páginas",
"log.fetch.current": "Procesando ${name} en la página ${page}",
"log.fetch.authTimeout": "La autenticación ha expirado, Abre de nuevo el historial de deseos en el juego.",
"log.fetch.gachaType": "Obteniendo el tipo de deseo",
"log.fetch.gachaTypeOk": "Tipo de deseo obtenido",
"log.url.lackAuth": "No se encuentra la Authkey en la URL",
"log.proxy.hint": "Usando modo proxy [${ip}:${port}] para obtener la URL, Abre de nuevo el historial de deseos en el juego.",
"log.url.notFound2": "Error al obtener la URL, asegurate de que has abierto el historial de deseos dentro del juego.",
"log.url.incorrect": "Error al obtener los parámetros de la URL",
"log.autoUpdate.success": "Actualizado correctamente, reinicia el programa",
"excel.header.time": "tiempo",
"excel.header.name": "nombre",
"excel.header.type": "tipo",
"excel.header.rank": "rareza",
"excel.header.total": "total",
"excel.header.pity": "pity",
"excel.customFont": "Arial",
"excel.filePrefix": "",
"excel.fileType": "Excel file"
}

View File

@@ -1,85 +0,0 @@
{
"symbol.colon": " : ",
"ui.button.load": "Charger les données",
"ui.button.update": "Mettre à jour",
"ui.button.directUpdate": "Mise à jour directe",
"ui.button.excel": "Exporter vers Excel",
"ui.button.srgf": "Exporter vers JSON",
"ui.button.url": "URL d'import",
"ui.button.setting": "Paramètres",
"ui.button.option": "Options",
"ui.button.startProxy": "Mode Proxy",
"ui.select.newAccount": "Nouveau compte",
"ui.hint.newAccount": "Charger les données d'autres comptes",
"ui.hint.init": "Veuillez ouvrir votre historique de vœux depuis le client du jeu avant de cliquer sur le bouton 'Charger les données'.",
"ui.hint.lastUpdate": "Dernière mise à jour",
"ui.hint.failed": "Oups, une erreur est survenue...",
"ui.hint.relaunchHint": "La mise à jour est terminée, elle prendra effet après avoir cliqué sur le bouton permettant le redémarrage de l'outil",
"ui.win.title": "",
"ui.data.total": "Total de",
"ui.data.times": "tirages.",
"ui.data.sum": "Vous avez effectué",
"ui.data.no5star": "tirages sans objet 5★.",
"ui.data.character": "Personnage",
"ui.data.weapon": "Arme",
"ui.data.star5": "5★",
"ui.data.star4": "4★",
"ui.data.star3": "3★",
"ui.data.history": "Historique de 5★",
"ui.data.average": "Moyenne de tirages d'objet 5★",
"ui.data.chara5": "Personnage 5★",
"ui.data.chara4": "Personnage 4★",
"ui.data.weapon5": "Arme 5★",
"ui.data.weapon4": "Arme 4★",
"ui.data.weapon3": "Arme 3★",
"ui.setting.title": "Paramètres",
"ui.setting.language": "Langue",
"ui.setting.languageHint": "L'anglais sera utilisé par défaut si la traduction sélectionnée n'est pas disponible.",
"ui.setting.logType": "Type de journalisation",
"ui.setting.auto": "Automatique",
"ui.setting.cnServer": "Serveur Chinois",
"ui.setting.seaServer": "Serveur Global",
"ui.setting.logTypeHint": "Choisissez les journaux générés par le serveur à utiliser en priorité lors de la récupération de l'URL à partir des journaux du jeu.",
"ui.setting.autoUpdate": "Mise à jour automatique",
"ui.setting.hideNovice": "Masquer les vœux du débutant",
"ui.setting.proxyMode": "Mode Proxy",
"ui.setting.proxyModeHint": "Si la récupération de l'URL depuis les journaux système échoue, utilisez le proxy système.",
"ui.setting.fetchFullHistory": "Récupérer l'intégralité des données",
"ui.setting.fetchFullHistoryHint": "Lorsque cette option est active, cliquez sur le bouton \"Mettre à jour les données\" pour récupérer tous les enregistrements des tirages des 6 derniers mois. Cette fonction peut être utilisée si des erreurs figurent dans les données des 6 derniers mois.",
"ui.setting.closeProxy": "Désactiver le proxy système",
"ui.setting.closeProxyHint": "Si le programme se bloque lorsque vous choisissez le mode proxy, des résultats indésirables susceptibles d'affecter votre système peuvent survenir. Vous pouvez cliquer sur ce bouton pour réinitialiser les paramètres du proxy système.",
"ui.about.title": "À propos",
"ui.about.license": "Ce logiciel est open source et sous licence MIT.",
"ui.urlDialog.title": "Saisir l'URL d'import manuellement",
"ui.urlDialog.hint": "Cette fonctionnalité ne doit être utilisée que lorsque vous savez quel type d'URL est nécessaire ici.",
"ui.urlDialog.placeholder": "Veuillez saisir l'URL avec les informations d'authentification.",
"ui.common.cancel": "Annuler",
"ui.common.ok": "OK",
"log.save.failed": "Échec de la sauvegarde des données locales.",
"log.file.notFound": "Les journaux du jeu sont introuvables, veuillez vous assurer que vous avez déjà ouvert l'historique de vœux dans le client du jeu.",
"log.url.notFound": "URL introuvable.",
"log.file.readFailed": "Échec de la lecture des journaux.",
"log.fetch.retry": "Échec de la récupération des ${name} - page ${page}, nouvelle tentative dans 5 secondes pour la ${count}e fois……",
"log.fetch.retryFailed": "Échec de la récupération des ${name} - page ${page}, nombre de tentatives maximum atteint.",
"log.fetch.interval": "Récupération des ${name} - page ${page}, délai de 1 seconde toutes les 10 pages……",
"log.fetch.current": "Récupération des ${name} - page ${page}.",
"log.fetch.authTimeout": "L'authentification de l'utilisateur a expiré, veuillez rouvrir l'historique des vœux dans le client du jeu.",
"log.fetch.gachaType": "Récupération du type de vœux, veuillez patienter.",
"log.fetch.gachaTypeOk": "Le type de vœux a été récupéré.",
"log.url.lackAuth": "Clé d'authentification introuvable dans l'URL.",
"log.proxy.hint": "Utilisation du mode proxy [${ip}:${port}] pour obtenir l'URL, veuillez rouvrir l'historique des vœux dans le client du jeu.",
"log.url.notFound2": "URL introuvable, veuillez vous assurer que vous avez déjà ouvert l'historique de vœux dans le client du jeu.",
"log.url.incorrect": "Impossible d'obtenir les paramètres d'URL.",
"log.autoUpdate.success": "Mise à jour automatique réussie, veuillez redémarrer le programme.",
"excel.header.time": "Date",
"excel.header.name": "Nom",
"excel.header.type": "Type",
"excel.header.rank": "Rareté",
"excel.header.total": "Tirages",
"excel.header.pity": "Pity 5★",
"excel.header.remark": "Commentaire",
"excel.wish2": "",
"excel.customFont": "Arial",
"excel.filePrefix": "",
"excel.fileType": "Classeur Excel"
}

View File

@@ -1,77 +0,0 @@
{
"symbol.colon": ": ",
"ui.button.load": "Muat data",
"ui.button.update": "Perbarui",
"ui.button.excel": "Ekspor Excel",
"ui.button.url": "Masukkan URL",
"ui.button.setting": "Pengaturan",
"ui.button.option": "Pilihan",
"ui.button.startProxy": "Mode proksi",
"ui.select.newAccount": "Akun baru",
"ui.hint.newAccount": "Ekspor data dari akun lain",
"ui.hint.init": "Silakan buka riwayat permohonan anda di dalam klien permainan sebelum klik pada tombol 'Muat data' ",
"ui.hint.lastUpdate": "Terakhir diperbarui",
"ui.hint.failed": "Aduhh, tampaknya gagal",
"ui.win.title": "",
"ui.data.total": "Total",
"ui.data.times": "Pulls",
"ui.data.sum": "Akumulasi",
"ui.data.no5star": "pulls tanpa ★ 5",
"ui.data.character": "Karakter",
"ui.data.weapon": "★ 5",
"ui.data.star4": "★ 4",
"ui.data.star3": "★ 3",
"ui.data.history": "Riwayat ★ 5",
"ui.data.average": "★ 5 dalam rata - rata",
"ui.data.chara5": "★ 5 karakter",
"ui.data.chara4": "★ 4 karakter",
"ui.data.weapon5": "★ 5 senjata",
"ui.data.weapon4": "★ 4 senjata",
"ui.data.weapon3": "★ 3 senjata",
"ui.setting.title": "Pengatuan",
"ui.setting.language": "Bahasa",
"ui.setting.languageHint": "Jika terjemahan hilang, Bahasa Inggris akan ditampilkan secara default.",
"ui.setting.logType": "Tipe catatan",
"ui.setting.auto": "Auto",
"ui.setting.cnServer": "Server China",
"ui.setting.seaServer": "Server Global",
"ui.setting.logTypeHint": "Pilih catatan yang dihasilkan dari server mana yang akan digunakan pertama kali saat memperoleh URL di dalam catatan permainan",
"ui.setting.autoUpdate": "Automatis perbarui",
"ui.setting.proxyMode": "Mode proksi",
"ui.setting.proxyModeHint": "Ketika kita gagal mengambil URL dari catatan sistem, gunakan proksi sistem",
"ui.setting.closeProxy": "Matikan sistem proksi",
"ui.setting.closeProxyHint": "Ketika anda memilih mode proksi, jika program macet dapat menyebabkan hasil yang tidak diinginkan yang dapat mempengaruhi sistem anda. Anda dapat klik tombol ini untuk menghapus pengaturan sistem proksi.",
"ui.about.title": "Tentang",
"ui.about.license": "Perangkat lunak ini opensource menggunakan lisensi MIT.",
"ui.urlDialog.title": "Masukkan URL secara manual",
"ui.urlDialog.hint": "Fungsi ini hanya boleh digunakan jika anda memahami URL apa yang dibutuhkan di sini",
"ui.urlDialog.placeholder": "Silakan masukkan URL dengan informasi autentikasi",
"ui.common.cancel": "Batalkan",
"ui.common.ok": "OK",
"log.save.failed": "Gagal untuk menyimpan data lokal",
"log.file.notFound": "Tidak bisa menemukan catatan permainan, pastikan anda telah membuka riwayat permohonan di dalam klien permainan",
"log.url.notFound": "Tidak dapat menemukan URL",
"log.file.readFailed": "Gagal membaca catatan",
"log.fetch.retry": "Proses ${name} dari halaman $ {page} gagal, mencoba lagi dalam 5 detik untuk waktu ${count} ……",
"log.fetch.retryFailed": "Proses ${name} dari halaman $ {page} gagal, waktu coba lagi telah mencapai batas maksimum",
"log.fetch.interval": "Proses ${name} dari halaman ${page} waktu tunggu 1 detik setiap 10 halaman ……",
"log.fetch.current": "Proses ${name} dari halaman $ {page}",
"log.fetch.authTimeout": "Autentikasi pengguna kedaluwarsa, buka kembali riwayat permohonan di dalam klien permainan.",
"log.fetch.gachaType": "Sedang mengambil tipe permohonan, silahkan tunggu",
"log.fetch.gachaTypeOk": "Jenis permohonan diperoleh",
"log.url.lackAuth": "Authkey tidak ditemukan di URL",
"log.proxy.hint": "Menggunakan mode proksi [${ip}:${port}] untuk mendapatkan URL, buka kembali riwayat permohonan di dalam klien permainan.",
"log.url.notFound2": "Tidak dapat menemukan URL, pastikan Anda telah membuka riwayat permohonan di dalam klien permainan",
"log.url.incorrect": "Tidak bisa mendapatkan parameter URL",
"log.autoUpdate.success": "Pembaruan otomatis berhasil, mulai ulang program",
"excel.header.time": "waktu",
"excel.header.name": "nama",
"excel.header.type": "tipe",
"excel.header.rank": "rarity",
"excel.header.total": "total",
"excel.header.pity": "dengan pity",
"excel.customFont": "Arial",
"excel.filePrefix": "",
"excel.fileType": "Excel file"
}

View File

@@ -1,69 +0,0 @@
{
"symbol.colon": ": ",
"ui.button.load": "Carregar dados",
"ui.button.update": "Atualizar",
"ui.button.excel": "Exportar Planilha",
"ui.button.setting": "Configurações",
"ui.select.newAccount": "Nova conta",
"ui.hint.newAccount": "Exportar dados de outras contas",
"ui.hint.init": "Abra o Histórico de Desejos dentro do jogo antes de clicar no botão 'Carregar dados'",
"ui.hint.lastUpdate": "Última atualização",
"ui.hint.failed": "Ops falha inesperada!",
"ui.win.title": "",
"ui.data.total": "Total",
"ui.data.times": "Desejos",
"ui.data.sum": "Acumulados",
"ui.data.no5star": "Desejos sem 5 estrelas",
"ui.data.character": "Personagem",
"ui.data.weapon": "Arma",
"ui.data.star5": "5 estrelas",
"ui.data.star4": "4 estrelas",
"ui.data.star3": "3 estrelas",
"ui.data.history": "Histórico 5 estrelas",
"ui.data.average": "Média 5 estrelas",
"ui.data.chara5": "Personagem 5 estrelas",
"ui.data.chara4": "Personagem 4 estrelas",
"ui.data.weapon5": "Arma 5 estrelas",
"ui.data.weapon4": "Arma 4 estrelas",
"ui.data.weapon3": "Arma 3 estrelas",
"ui.setting.title": "Configurações",
"ui.setting.language": "Idioma",
"ui.setting.languageHint": "Caso uma tradução esteja faltando, por padrão é exibido o idioma Inglês.",
"ui.setting.logType": "Tipo de registro",
"ui.setting.auto": "Auto",
"ui.setting.cnServer": "Servidor CN",
"ui.setting.seaServer": "Servidor Global",
"ui.setting.logTypeHint": "Selecione o servidor em que serão gerados os registros ao adquirir a URL dos registros dentro do jogo.",
"ui.setting.autoUpdate": "Atualizar automáticamente",
"ui.setting.proxyMode": "Modo Proxy",
"ui.setting.proxyModeHint": "Caso não seja possível obter a URL registros do sistema, use o proxy do sistema.",
"ui.setting.closeProxy": "Desativar proxy do sistema",
"ui.setting.closeProxyHint": "Ao escolher o modo proxy, caso o programa pare de funcionar possa ser que ocorra resultados indesejados que afetem o seu sistema. Caso isso aconteça, clique neste botão para limpar as configurações de proxy do sistema.",
"ui.about.title": "Sobre",
"ui.about.license": "Este é um software de código aberto usando licença MIT.",
"log.save.failed": "Falha ao salvar dados",
"log.file.notFound": "Não foi possível encontrar registros do jogo, tenha certeza de ter aberto o Histórico de Desejos dentro do jogo",
"log.url.notFound": "Não foi possível encontrar a URL",
"log.file.readFailed": "Falha ao ler registros",
"log.fetch.retry": "Processando ${name} da página ${page} falhoutentando novamente em 5 segundos pela ${count} vez……",
"log.fetch.retryFailed": "Processando ${name} da página ${page} falhou, número de tentativas atingiu o limite",
"log.fetch.interval": "Processando ${name} da página ${page}intervalo de 1 segundo a cada 10 páginas……",
"log.fetch.current": "Processando ${name} da página ${page}",
"log.fetch.authTimeout": "Autenticação do usuário expirou, reabra novamente o Histórico de Desejos em seu jogo.",
"log.fetch.gachaType": "Carregando tipo de Desejo, aguarde.",
"log.fetch.gachaTypeOk": "Tipo de Desejo adquirido",
"log.url.lackAuth": "Chave-acesso não encontrada na URL",
"log.proxy.hint": "Usando modo proxy [${ip}:${port}] para conseguir a URL, reabra novamente o Histórico de Desejos em seu jogo.",
"log.url.notFound2": "Não foi possível encontrar a URL, tenha certeza de ter aberto o Histórico de Desejos dentro do jogo",
"log.url.incorrect": "Não foi possível conseguir os parametros de URL",
"log.autoUpdate.success": "Atualização automática bem-sucedida, por gentiliza reabra o programa",
"excel.header.time": "DATA/HORÁRIO",
"excel.header.name": "NOME",
"excel.header.type": "TIPO",
"excel.header.rank": "RARIDADE",
"excel.header.total": "TOTAL",
"excel.header.pity": "DENTRO DO PITY",
"excel.customFont": "Arial",
"excel.filePrefix": "",
"excel.fileType": "Excel file"
}

View File

@@ -1,72 +0,0 @@
{
"symbol.colon": ": ",
"ui.button.load": "Загрузить данные",
"ui.button.update": "Обновить данные",
"ui.button.excel": "Экспортировать в Excel",
"ui.button.setting": "Настройки",
"ui.select.newAccount": "Добавить аккаунт",
"ui.hint.newAccount": "Экспорт данных из другой учетной записи",
"ui.hint.init": "Пожалуйста, откройте любую историю своих молитв в игре, прежде чем нажимать кнопку 'Загрузить данные'",
"ui.hint.lastUpdate": "Последнее обновление",
"ui.hint.failed": "Упс, что-то пошло не так..",
"ui.win.title": "",
"ui.data.total": "Всего",
"ui.data.times": "Молитв",
"ui.data.sum": "Прокручено",
"ui.data.no5star": "Молитв после выпадения 5*",
"ui.data.character": "Персонаж",
"ui.data.weapon": "Оружие",
"ui.data.star5": "5 Звёзд",
"ui.data.star4": "4 Звезды",
"ui.data.star3": "3 Звезды",
"ui.data.history": "Полученные 5* награды",
"ui.data.average": "Среднее число получения 5*",
"ui.data.chara5": "5* Персонаж",
"ui.data.chara4": "4* Персонаж",
"ui.data.weapon5": "5* Оружие",
"ui.data.weapon4": "4* Оружие",
"ui.data.weapon3": "3* Оружие",
"ui.setting.title": "Настройки",
"ui.setting.language": "Язык",
"ui.setting.languageHint": "Если перевод отсутствует, то по умолчанию будет использован английский язык.",
"ui.setting.logType": "Тип журнала",
"ui.setting.auto": "Автоматически",
"ui.setting.cnServer": "CN сервер",
"ui.setting.seaServer": "Глобальный сервер",
"ui.setting.logTypeHint": "Выберите, какие сгенерированные сервером файлы журнала, будут использоваться в первую очередь при получении URL из игрового журнала.",
"ui.setting.autoUpdate": "Авто обновление",
"ui.setting.proxyMode": "Прокси-режим",
"ui.setting.proxyModeHint": "Если нам не удаётся получить URL из системного журнала, воспользуйтесь системным Прокси.",
"ui.setting.closeProxy": "Отключить системный Прокси",
"ui.setting.closeProxyHint": "Если при выборе Прокси-режима, программа выйдет из строя, это может привести к негативным результатам, которые могут повлиять на Вашу систему. Вы можете нажать эту кнопку, чтобы очистить настройки системного прокси.",
"ui.setting.hideNovice": "Скрыть молитвы новичка",
"ui.setting.fetchFullHistory": "Получить полные данные",
"ui.setting.fetchFullHistoryHint": "Когда эта опция включена, нажмите кнопку \"Обновить данные\" чтобы получить все данные о молитвах в течение 6 месяцев. При наличии неправильных данных в течение 6 месяцев эту функцию можно использовать для исправления.",
"ui.about.title": "О нас",
"ui.about.license": "Это программное обеспечение с открытым исходным кодом, использующее MIT-лицензию.",
"log.save.failed": "Не удалось сохранить локальные данные.",
"log.file.notFound": "Невозможно найти лог-файлы игры. Пожалуйста убедитесь, что вы уже открыли историю Молитв внутри игры.",
"log.url.notFound": "Невозможно найти URL",
"log.file.readFailed": "Не удалось прочитать журнал",
"log.fetch.retry": "Обработка ${name} страницы ${page} прервалось,новая попытка через 5 секнуд для ${count} времени...",
"log.fetch.retryFailed": "Обработка ${name} страницы ${page} прервалось,максимальное время для повторных попыток превышено.",
"log.fetch.interval": "Обработка ${name} страницы ${page}1 повторный тайм-аут через каждые 10 страниц...",
"log.fetch.current": "Обработка ${name} страницы ${page}",
"log.fetch.authTimeout": "Идентификация пользователя истекла. Пожалуйста, откройте историю Молитв внутри игрового клиента.",
"log.fetch.gachaType": "Получение типа Банера. Пожалуйста, подождите...",
"log.fetch.gachaTypeOk": "Тип Банера определён",
"log.url.lackAuth": "Ключ авторизации не найден в URL",
"log.proxy.hint": "Используйте Прокси-режим [${ip}:${port}] для получения URL, откройте историю Молитв внутри игрового клиента.",
"log.url.notFound2": "Невозможно найти URL. Пожалуйста убедитесь, что вы уже открыли историю молитв внутри игры.",
"log.url.incorrect": "Невозможно получить параметры URL-адреса",
"log.autoUpdate.success": "Автоматическое обновление прошло успешно. Просто перезапустите программу.",
"excel.header.time": "Время",
"excel.header.name": "Имя",
"excel.header.type": "Тип",
"excel.header.rank": "Редкость",
"excel.header.total": "Всего",
"excel.header.pity": "Молитв после выпадения 5*",
"excel.customFont": "Times New Roman",
"excel.filePrefix": "",
"excel.fileType": "Excel file"
}

View File

@@ -1,77 +0,0 @@
{
"symbol.colon": ": ",
"ui.button.load": "Tải dữ liệu",
"ui.button.update": "Cập nhật",
"ui.button.excel": "Xuất tập tin Excel",
"ui.button.url": "Nhập URL",
"ui.button.setting": "Cài đặt",
"ui.button.option": "Tùy chọn",
"ui.button.startProxy": "Chế độ Proxy",
"ui.select.newAccount": "Chọn tài khoản",
"ui.hint.newAccount": "Xuất dữ liệu từ tài khoản khác",
"ui.hint.init": "Vui lòng mở lịch sử cầu nguyện của bạn bên trong trò chơi trước khi nhấp vào nút 'Tải dữ liệu'",
"ui.hint.lastUpdate": "Lần cập nhật cuối",
"ui.hint.failed": "Rất tiếc, đã xảy ra lỗi",
"ui.win.title": "",
"ui.data.total": "Tổng cộng",
"ui.data.times": "lần.",
"ui.data.sum": "Đã tích luỹ",
"ui.data.no5star": "lần chưa ra 5 sao",
"ui.data.character": "Nhân vật",
"ui.data.weapon": "Vũ khí",
"ui.data.star5": "5 sao",
"ui.data.star4": "4 sao",
"ui.data.star3": "3 sao",
"ui.data.history": "Lịch sử 5 sao",
"ui.data.average": "Tỉ lệ 5 sao trung bình",
"ui.data.chara5": "Nhân vật 5 sao",
"ui.data.chara4": "Nhân vật 4 sao",
"ui.data.weapon5": "Vũ khí 5 sao",
"ui.data.weapon4": "Vũ khí 4 sao",
"ui.data.weapon3": "Vũ khí 3 sao",
"ui.setting.title": "Cài đặt",
"ui.setting.language": "Ngôn ngữ",
"ui.setting.languageHint": "Khi bản dịch bị thiếu, tiếng Anh sẽ được hiển thị theo mặc định.",
"ui.setting.logType": "Loại nhật ký",
"ui.setting.auto": "Tự động",
"ui.setting.cnServer": "Máy chủ Trung Quốc",
"ui.setting.seaServer": "Máy chủ toàn cầu",
"ui.setting.logTypeHint": "Chọn nhật ký do máy chủ tạo sẽ được sử dụng đầu tiên khi lấy URL từ nhật ký trò chơi",
"ui.setting.autoUpdate": "Tự động cập nhật",
"ui.setting.proxyMode": "Chế độ Proxy",
"ui.setting.proxyModeHint": "Khi chúng tôi không lấy được URL từ nhật ký hệ thống, hãy sử dụng proxy hệ thống",
"ui.setting.closeProxy": "Tắt proxy hệ thống",
"ui.setting.closeProxyHint": "Khi bạn chọn chế độ proxy, nếu chương trình bị treo, nó có thể gây ra các kết quả không mong muốn có thể ảnh hưởng đến hệ thống của bạn. Bạn có thể nhấp vào nút này để tắt cài đặt proxy hệ thống.",
"ui.about.title": "Về tác giả",
"ui.about.license": "Phần mềm này là mã nguồn mở sử dụng giấy phép MIT.",
"ui.urlDialog.title": "Nhập URL thủ công",
"ui.urlDialog.hint": "Chức năng này chỉ nên được sử dụng khi bạn hiểu URL nào là cần thiết ở đây",
"ui.urlDialog.placeholder": "Vui lòng nhập URL với thông tin xác thực",
"ui.common.cancel": "Hủy bỏ",
"ui.common.ok": "Đồng ý",
"log.save.failed": "Không lưu được dữ liệu cục bộ",
"log.file.notFound": "Không thể tìm thấy nhật ký trò chơi, vui lòng đảm bảo rằng bạn đã mở lịch sử cầu nguyện bên trong trò chơi",
"log.url.notFound": "Không thể tìm thấy URL",
"log.file.readFailed": "Không đọc được nhật ký",
"log.fetch.retry": "Xử lý ${name} trang ${page} không thành công, sẽ thử lại sau 5 giây với thời gian ${count}...",
"log.fetch.retryFailed": "Xử lý ${name} trang ${page} không thành công, số lần thử lại đã hết",
"log.fetch.interval": "Đang xử lý ${name} trang ${page}, gian chờ 1 giây sau mỗi 10 trang...",
"log.fetch.current": "Đang xử lý ${name} trang ${page}",
"log.fetch.authTimeout": "Xác thực người dùng đã hết hạn, vui lòng mở lại lịch sử cầu nguyện bên trong trò chơi.",
"log.fetch.gachaType": "Đang nhận loại cầu nguyện, vui lòng đợi",
"log.fetch.gachaTypeOk": "Nhận loại cầu nguyện thành công",
"log.url.lackAuth": "Không tìm thấy mã xác thực trong URL",
"log.proxy.hint": "Sử dụng chế độ proxy [${ip}:${port}] để nhận URL, vui lòng mở lại lịch sử cầu nguyện bên trong trò chơi.",
"log.url.notFound2": "Không thể tìm thấy URL, vui lòng đảm bảo rằng bạn đã mở lịch sử cầu nguyện bên trong trò chơi",
"log.url.incorrect": "Không thể nhận thông số URL",
"log.autoUpdate.success": "Tự động cập nhật thành công, vui lòng khởi động lại chương trình",
"excel.header.time": "Thời gian",
"excel.header.name": "Tên",
"excel.header.type": "Loại",
"excel.header.rank": "Sao",
"excel.header.total": "Số lần",
"excel.header.pity": "Bảo hiểm",
"excel.customFont": "Arial",
"excel.filePrefix": "",
"excel.fileType": "Tập tin Excel"
}

View File

@@ -1,80 +0,0 @@
{
"symbol.colon": ": ",
"ui.button.load": "โหลดข้อมูล",
"ui.button.update": "อัพเดตข้อมูล",
"ui.button.directUpdate": "อัพเดตโดยตรง",
"ui.button.excel": "แปลงเป็น Excel",
"ui.button.url": "กรอก URL",
"ui.button.setting": "ตั้งค่า",
"ui.button.option": "ตัวเลือก",
"ui.button.startProxy": "โหมด Proxy",
"ui.select.newAccount": "บัญชีใหม่",
"ui.hint.newAccount": "สร้่างข้อมูลบัญชีใหม่",
"ui.hint.init": "โปรดทำการเปิดประวัติตู้อธิษฐานของคุณภายในเกมส์ก่อนที่จะกดปุ่ม 'โหลดข้อมูล'",
"ui.hint.lastUpdate": "อัพเดตเมื่อ",
"ui.hint.failed": "เอ๊ะ? มีบางผิดปกติ",
"ui.win.title": "",
"ui.data.total": "ทั้งหมด",
"ui.data.times": "ครั้ง",
"ui.data.sum": "รวมทั้งหมด",
"ui.data.no5star": "โดยที่ไม่ได้รับ 5 ดาว",
"ui.data.character": "ตัวละคร",
"ui.data.weapon": "อาวุธ",
"ui.data.star5": "5 ดาว",
"ui.data.star4": "4 ดาว",
"ui.data.star3": "3 ดาว",
"ui.data.history": "ประวัติ 5 ดาว",
"ui.data.average": "ค่าเฉลี่ย 5 ดาว",
"ui.data.chara5": "ตัวละคร 5 ดาว",
"ui.data.chara4": "ตัวละคร 4 ดาว",
"ui.data.weapon5": "อาวุธ 5 ดาว",
"ui.data.weapon4": "อาวุธ 4 ดาว",
"ui.data.weapon3": "อาวุธ 3 ดาว",
"ui.setting.title": "ตั้งค่า",
"ui.setting.language": "ภาษา",
"ui.setting.languageHint": "หากภาษาไม่แสดงผล ภาษาอังกฤษจะถูกแสดงแทนภาษานั้น",
"ui.setting.logType": "ชนิด Log",
"ui.setting.auto": "ออโต้",
"ui.setting.cnServer": "เซิฟจีน (CN)",
"ui.setting.seaServer": "เซิฟต่างประเทศ (Global)",
"ui.setting.logTypeHint": "เลือกเซิฟเวอร์ที่จะให้เซิฟเวอร์สร้าง Log ก่อนที่จะดึงข้อมูลประวัติตู้อธิษฐาน",
"ui.setting.autoUpdate": "เปิดอัพเดตอัตโนมัติ",
"ui.setting.proxyMode": "โหมดพร็อกซี่",
"ui.setting.proxyModeHint": "ในกรณีที่ไม่สามารถดึงข้อมูลจาก URL ที่ระบุได้ ให้ใช้โหมดพร็อกซี่",
"ui.setting.closeProxy": "ิปิดโหมดพร็อกซี่",
"ui.setting.closeProxyHint": "ในขณะที่เลือกโหมดพร็อกซี่ หากโปรแกรมเกิดขัดข้อง อาจทำให้เกิดผลลัพธ์ไม่ถูกต้องซึ่งอาจส่งผลกระทบระบบของคุณ คุณสามารถคลิกที่นี่เพื่อล้างการตั้งค่าพร็อกซี่",
"ui.setting.fetchFullHistory": "ดึงข้อมูลทั้งหมด",
"ui.setting.fetchFullHistoryHint": "เมื่อการตั้งค่านี้ถูกเปิดใช้งาน กดปุ่ม \"อัพเดตข้อมูล\" เพื่อดึงข้อมูลอธิษฐานในช่วง 6 เดือนที่ผ่านมา หากพบว่าข้อมูลที่ดึงมานั้นไม่ถูกต้องในช่วง 6 เดือนที่ผ่านมา คุณสามารถใช้ฟังชั่นนี้้เพื่อเรียกซ่อมแซมได้",
"ui.about.title": "เกี่ยวกับ",
"ui.about.license": "โปรแกรมนี้เป็น Open Source โดยอยู่ในอยู่ในใบอนุญาต MIT",
"ui.urlDialog.title": "กรอก URL ด้วยตัวเอง",
"ui.urlDialog.hint": "ฟังชั่นนี้ควรจะใช้ก็ต่อเมื่อคุณเข้าใจว่าแหล่ง URL นี้มาจากไหน",
"ui.urlDialog.placeholder": "โปรดกรอก URL ที่มีคีย์ข้อมูลของคุณ",
"ui.common.cancel": "ยกเลิก",
"ui.common.ok": "โอเค",
"log.save.failed": "บันทึกข้อมูลไม่สำเร็จ",
"log.file.notFound": "ไม่พบ Log ข้อมูลเกมส์, โปรดตรวจสอบให้แน่ใจว่าคุณได้เปิดประวัติตู้อธิษฐานในเกมส์ของคุณแล้ว",
"log.url.notFound": "ไม่พบ URL",
"log.file.readFailed": "ไม่สามารถอ่านไฟล์ข้อมูลได้",
"log.fetch.retry": "ดึงข้อมูลตู้อธิษฐาน ${name} ในหน้าที่ ${page} ไม่สำเร็จ กำลังดึงข้อมูลใหม่ภายใน 5 วินาทีในครั้งที่ ${count}",
"log.fetch.retryFailed": "ดึงข้อมูลตู้อธิษฐาน ${name} ในหน้าที่ ${page} ไม่สำเร็จ หมดเวลาการดึงข้อมูล",
"log.fetch.interval": "ดึงข้อมูลตู้อธิษฐาน ${name} ในหน้าที่ ${page} ทุก ๆ 1 วินาทีต่อ 10 หน้า",
"log.fetch.current": "ดึงข้อมูลตู้อธิษฐาน ${name} ในหน้าที่ ${page}",
"log.fetch.authTimeout": "ข้อมูลยืนยันตัวตนหมดอายุ โปรดทำการเปิดประวัติตู้อธิษฐานใหม่ภายในเกมส์",
"log.fetch.gachaType": "กำลังดึงข้อมูลตู้อธิษฐาน",
"log.fetch.gachaTypeOk": "ได้ข้อมูลตู้อธิษฐานสำเร็จ",
"log.url.lackAuth": "ไม่พบสิทธิ์การเข้าถึงข้อมูล",
"log.proxy.hint": "กำลังใช้โหมดพร็อกซี [${ip}:${port}] เพื่อดึงข้อมูลตู้อธิษฐาน โปรดทำการเปิดประวัติตู้อธิษฐานใหม่ภายในเกมส์",
"log.url.notFound2": "ไม่พบ URL ที่ต้องการ โปรดตรวจสอบให้แน่ใจว่าคุณได้เปิดประวัติตู้กาชาในเกมส์ของคุณแล้ว",
"log.url.incorrect": "ไม่พบพารามิเตอร์ที่ต้องการ",
"log.autoUpdate.success": "อัพเดตสำเร็จ,โปรดรีสตาร์จโปรแกรม",
"excel.header.time": "เวลา",
"excel.header.name": "ชื่อ",
"excel.header.type": "ประเภท",
"excel.header.rank": "แรงค์",
"excel.header.total": "ทั้งหมด",
"excel.header.pity": "การันตี",
"excel.customFont": "Arial",
"excel.filePrefix": "",
"excel.fileType": "ไฟล์ Excel"
}

View File

@@ -1,78 +0,0 @@
{
"symbol.colon": "",
"ui.button.load": "データの読み込み",
"ui.button.update": "更新データ",
"ui.button.excel": "Excelにエクスポート",
"ui.button.srgf": "JSONにエクスポート",
"ui.button.url": "URL入力",
"ui.button.setting": "設定",
"ui.button.option": "オプション",
"ui.button.startProxy": "プロキシモード",
"ui.select.newAccount": "他のアカウント",
"ui.hint.newAccount": "他のアカウントからデータをエクスポートする ",
"ui.hint.init": "ゲーム内の「跳躍履歴」を開いて、「データの読み込み」をクリックしてください ",
"ui.hint.lastUpdate": "最終データ更新時間は",
"ui.hint.failed": "操作に失敗しました",
"ui.win.title": "",
"ui.data.total": "総計",
"ui.data.times": "連",
"ui.data.sum": "合計",
"ui.data.no5star": "連星5取得しません",
"ui.data.character": "キャラ",
"ui.data.weapon": "光円錐",
"ui.data.star5": "星5",
"ui.data.star4": "星4",
"ui.data.star3": "星3",
"ui.data.history": "星5跳躍記録",
"ui.data.average": "星5取得平均回数",
"ui.data.chara5": "星5キャラ",
"ui.data.chara4": "星4キャラ",
"ui.data.weapon5": "星5光円錐",
"ui.data.weapon4": "星4光円錐",
"ui.data.weapon3": "星3光円錐",
"ui.setting.title": "設定",
"ui.setting.language": "言語",
"ui.setting.languageHint": "翻訳されていない場合は、デフォルトで英語が表示されます。",
"ui.setting.logType": "ログタイプ",
"ui.setting.auto": "自動",
"ui.setting.cnServer": "中国サーバー",
"ui.setting.seaServer": "グローバルサーバー",
"ui.setting.logTypeHint": "ゲームログを使ってURLを取得する場合、どのサーバー生成のログファイルが望ましいか。",
"ui.setting.autoUpdate": "自動更新",
"ui.setting.proxyMode": "プロキシモード",
"ui.setting.proxyModeHint": "システムプロキシの設定によるURLの取得、ログから有効なURLを取得できない場合にプロキシを起動します。",
"ui.setting.closeProxy": "システムプロキシをオフにする",
"ui.setting.closeProxyHint": "システムプロキシの設定が異常な場合に、このボタンで設定されたシステムプロキシをクリアします。",
"ui.about.title": "About",
"ui.about.license": "本ソフトウェアは、MITライセンスによるオープンソースです。",
"ui.urlDialog.title": "URLを手動で入力する",
"ui.urlDialog.hint": "この機能は、ここで必要とされるURLを理解している場合にのみ使用してください。",
"ui.urlDialog.placeholder": "authkey付きのURLを入力してください。",
"ui.common.cancel": "キャンセル",
"ui.common.ok": "確認",
"log.save.failed": "ローカルデータの保存に失敗しました",
"log.file.notFound": "ゲームログが見つかりません、跳躍記録を開いているか確認してください。",
"log.url.notFound": "URLが見つかりません。",
"log.file.readFailed": "ログの読み取りに失敗しました。",
"log.fetch.retry": "${name}のページ${page}を取得に失敗しました、5秒後に、${count}回目の再試行...",
"log.fetch.retryFailed": "${name}のページ${page}を取得に失敗しました、再試行回数を超えた。",
"log.fetch.interval": "${name}のページ${page}を処理中、10ページごとに1秒のタイムアウト...",
"log.fetch.current": "${name}のページ${page}を処理中",
"log.fetch.authTimeout": "authkeyの有効期限が切れているので、跳躍記録を再開してください。",
"log.fetch.gachaType": "跳躍のタイプ取得中",
"log.fetch.gachaTypeOk": "跳躍のタイプに成功を得る",
"log.url.lackAuth": "URLにauthkeyが含まれていない",
"log.proxy.hint": "URLを取得するためにプロキシモード[${ip}:${port}]を使用しています、跳躍記録を再開してください。",
"log.url.notFound2": "URLが見つかりません、跳躍記録を開いているか確認してください。",
"log.url.incorrect": "URLパラメータの取得に失敗しました",
"log.autoUpdate.success": "自動更新が完了しました、ツールを再起動してください。",
"excel.header.time": "時間",
"excel.header.name": "名称",
"excel.header.type": "タイプ",
"excel.header.rank": "ランク",
"excel.header.total": "総計",
"excel.header.pity": "天井内",
"excel.customFont": "メイリオ",
"excel.filePrefix": "",
"excel.fileType": "Excelファイル"
}

View File

@@ -3,9 +3,10 @@
"ui.button.load": "加载数据", "ui.button.load": "加载数据",
"ui.button.update": "更新数据", "ui.button.update": "更新数据",
"ui.button.directUpdate": "直接更新", "ui.button.directUpdate": "直接更新",
"ui.button.files": "导出文件", "ui.button.files": "导入/导出",
"ui.button.excel": "导出Excel", "ui.button.excel": "导出Excel",
"ui.button.srgf":"导出JSON", "ui.button.uigf":"导出UIGF",
"ui.button.import":"导入UIGF",
"ui.button.url": "输入URL", "ui.button.url": "输入URL",
"ui.button.setting": "设置", "ui.button.setting": "设置",
"ui.button.option": "选项", "ui.button.option": "选项",
@@ -19,23 +20,26 @@
"ui.hint.lastUpdate": "上次数据更新时间为", "ui.hint.lastUpdate": "上次数据更新时间为",
"ui.hint.relaunchHint": "更新已完成,点击按钮重启工具后生效", "ui.hint.relaunchHint": "更新已完成,点击按钮重启工具后生效",
"ui.hint.failed": "操作失败", "ui.hint.failed": "操作失败",
"ui.win.title": "崩坏:星穹铁道跃迁记录导出工具", "ui.win.title": "绝区零调频记录导出工具",
"ui.data.total": "一共", "ui.data.total": "一共",
"ui.data.times": "抽", "ui.data.times": "抽",
"ui.data.sum": "已累计", "ui.data.sum": "已累计",
"ui.data.no5star": "抽未出5星", "ui.data.no4star": "抽未出S级",
"ui.data.character": "角色", "ui.data.character": "代理人",
"ui.data.weapon": "光锥", "ui.data.weapon": "音擎",
"ui.data.star5": "5星", "ui.data.bang": "邦布",
"ui.data.star4": "4星", "ui.data.star4": "S级",
"ui.data.star3": "3星", "ui.data.star3": "A级",
"ui.data.history": "5星历史记录", "ui.data.star2": "B级",
"ui.data.average": "5星平均出货次数为", "ui.data.history": "S级历史记录",
"ui.data.chara5": "5星角色", "ui.data.average": "S级平均出货次数为",
"ui.data.chara4": "4星角色", "ui.data.chara4": "S级代理人",
"ui.data.weapon5": "5星光锥", "ui.data.chara3": "A级代理人",
"ui.data.weapon4": "4星光锥", "ui.data.weapon4": "S级音擎",
"ui.data.weapon3": "3星光锥", "ui.data.weapon3": "A级音擎",
"ui.data.weapon2": "B级音擎",
"ui.data.bang4": "S级邦布",
"ui.data.bang3": "A级邦布",
"ui.setting.title": "设置", "ui.setting.title": "设置",
"ui.setting.language": "语言", "ui.setting.language": "语言",
"ui.setting.languageHint": "缺少翻译时,会默认显示简体中文", "ui.setting.languageHint": "缺少翻译时,会默认显示简体中文",
@@ -46,13 +50,13 @@
"ui.setting.logTypeHint": "使用游戏日志获取URL时优先选择哪种服务器生成的日志文件。", "ui.setting.logTypeHint": "使用游戏日志获取URL时优先选择哪种服务器生成的日志文件。",
"ui.setting.dataManagerHint": "可以删除不需要的数据。", "ui.setting.dataManagerHint": "可以删除不需要的数据。",
"ui.setting.autoUpdate": "自动更新", "ui.setting.autoUpdate": "自动更新",
"ui.setting.hideNovice": "隐藏新手跃迁",
"ui.setting.proxyMode": "代理模式", "ui.setting.proxyMode": "代理模式",
"ui.setting.proxyModeHint": "通过设置系统代理来获取URL无法从日志中获取到有效的URL时才会启动代理服务器。", "ui.setting.proxyModeHint": "通过设置系统代理来获取URL无法从日志中获取到有效的URL时才会启动代理服务器。",
"ui.setting.fetchFullHistory": "获取完整数据", "ui.setting.fetchFullHistory": "获取完整数据",
"ui.setting.fetchFullHistoryHint": "开启时点击“更新数据”按钮会完整获取6个月内所有的抽卡记录当记录里有6个月范围以内的错误数据时可以通过这个功能修复。", "ui.setting.fetchFullHistoryHint": "开启时点击“更新数据”按钮会完整获取6个月内所有的抽卡记录当记录里有6个月范围以内的错误数据时可以通过这个功能修复。",
"ui.setting.closeProxy": "关闭系统代理", "ui.setting.closeProxy": "关闭系统代理",
"ui.setting.closeProxyHint": "如果使用过代理模式时工具非正常关闭,可能导致系统代理设置没能清除,可以通过这个按钮来清除设置过的系统代理。", "ui.setting.closeProxyHint": "如果使用过代理模式时工具非正常关闭,可能导致系统代理设置没能清除,可以通过这个按钮来清除设置过的系统代理。",
"ui.setting.idVersion": "ID 数据库版本",
"ui.about.title": "关于", "ui.about.title": "关于",
"ui.about.license": "本工具为开源软件,源代码使用 MIT 协议授权", "ui.about.license": "本工具为开源软件,源代码使用 MIT 协议授权",
"ui.urlDialog.title": "手动输入URL", "ui.urlDialog.title": "手动输入URL",
@@ -78,8 +82,8 @@
"log.fetch.interval": "正在获取${name}第${page}页每10页休息1秒……", "log.fetch.interval": "正在获取${name}第${page}页每10页休息1秒……",
"log.fetch.current": "正在获取${name}第${page}页", "log.fetch.current": "正在获取${name}第${page}页",
"log.fetch.authTimeout": "身份认证已过期,请重新打开游戏抽卡记录", "log.fetch.authTimeout": "身份认证已过期,请重新打开游戏抽卡记录",
"log.fetch.gachaType": "正在获取跃迁活动类型", "log.fetch.gachaType": "正在获取调频活动类型",
"log.fetch.gachaTypeOk": "获取跃迁活动类型成功", "log.fetch.gachaTypeOk": "获取调频活动类型成功",
"log.url.lackAuth": "URL中缺少authkey", "log.url.lackAuth": "URL中缺少authkey",
"log.proxy.hint": "正在使用代理模式[${ip}:${port}]获取URL请重新打开游戏抽卡记录。", "log.proxy.hint": "正在使用代理模式[${ip}:${port}]获取URL请重新打开游戏抽卡记录。",
"log.url.notFound2": "未找到URL请确认是否已打开游戏抽卡记录", "log.url.notFound2": "未找到URL请确认是否已打开游戏抽卡记录",
@@ -92,12 +96,13 @@
"excel.header.total": "总次数", "excel.header.total": "总次数",
"excel.header.pity": "保底内", "excel.header.pity": "保底内",
"excel.header.remark": "备注", "excel.header.remark": "备注",
"excel.wish2": "跃迁2", "excel.wish2": "调频2",
"excel.customFont": "微软雅黑", "excel.customFont": "微软雅黑",
"excel.filePrefix": "星穹铁道跃迁记录", "excel.filePrefix": "绝区零调频记录",
"excel.fileType": "Excel文件", "excel.fileType": "Excel文件",
"srgf.fileType":"星穹铁道跃迁记录格式文件", "uigf.fileType":"统一可交换抽卡记录标准 v4.0Beta",
"ui.extra.cacheClean": "1. 确认是否已经打开游戏内的抽卡历史记录,如果仍然出现“身份认证已过期”的错误,再尝试下面的步骤\n2. 关闭星穹铁道的游戏窗口\n3. 点击上方的“打开缓存文件夹”按钮打开Cache文件夹\n4. 删除Cache_Data文件夹\n5. 启动星穹铁道游戏,打开游戏内抽卡历史记录页面\n6. 关闭这个对话框,再点击“更新数据”按钮", "ui.extra.cacheClean": "1. 确认是否已经打开游戏内的抽卡历史记录,如果仍然出现“身份认证已过期”的错误,再尝试下面的步骤\n2. 关闭绝区零的游戏窗口\n3. 点击上方的“打开缓存文件夹”按钮打开Cache文件夹\n4. 删除Cache_Data文件夹\n5. 启动绝区零游戏,打开游戏内抽卡历史记录页面\n6. 关闭这个对话框,再点击“更新数据”按钮",
"ui.extra.findCacheFolder": "如果点“打开缓存文件夹”按钮没有反应,可以手动找到游戏的网页缓存文件夹,目录为“你的游戏安装路径/Star Rail/Game/StarRail_Data/webCaches/Cache/”", "ui.extra.findCacheFolder": "如果点“打开缓存文件夹”按钮没有反应,可以手动找到游戏的网页缓存文件夹,目录为“你的游戏安装路径/ZenlessZoneZero_Data/webCaches/Cache/”",
"ui.extra.urlCopied": "URL已复制" "ui.extra.urlCopied": "URL已复制",
"ui.uigf.title": "请选择要导出的UID"
} }

View File

@@ -1,91 +1,107 @@
{ {
"symbol.colon": "", "symbol.colon": "",
"ui.button.load": "載入資料", "ui.button.load": "加載數據",
"ui.button.update": "更新資料", "ui.button.update": "更新數據",
"ui.button.directUpdate": "直接更新", "ui.button.directUpdate": "直接更新",
"ui.button.files": "匯出檔案", "ui.button.files": "導入/匯出",
"ui.button.excel": "匯出 Excel", "ui.button.excel": "導出Excel",
"ui.button.srgf": "匯出 JSON", "ui.button.uigf":"導出UIGF",
"ui.button.url": "輸入 URL", "ui.button.import":"導入UIGF",
"ui.button.setting": "設定", "ui.button.url": "輸入URL",
"ui.button.setting": "設置",
"ui.button.option": "選項", "ui.button.option": "選項",
"ui.button.startProxy": "Proxy 模式", "ui.button.startProxy": "代理模式",
"ui.button.solution": "解決法", "ui.button.solution": "解決法",
"ui.button.cacheFolder": "開啟快取資料夾", "ui.button.cacheFolder": "打開網頁緩存文件夾",
"ui.select.newAccount": "新帳號", "ui.button.copyUrl": "復製URL",
"ui.hint.newAccount": "從其他帳號匯出資料", "ui.select.newAccount": "新賬號",
"ui.hint.init": "請先在遊戲中開啟任意一個躍遷紀錄,再按下「載入資料」按鈕。", "ui.hint.newAccount": "從其它賬號導出數據",
"ui.hint.lastUpdate": "上次資料更新時間為", "ui.hint.init": "請先在遊戲裏打開任意一個抽卡記錄後再點擊「加載數據」按鈕",
"ui.hint.relaunchHint": "更新已完成,按下按鈕重新啟動工具後生效", "ui.hint.lastUpdate": "上次數據更新時間為",
"ui.hint.failed": "作失敗", "ui.hint.failed": "作失敗",
"ui.win.title": "崩壞:星穹鐵道 躍遷記錄出工具", "ui.win.title": "絕區零調頻記錄出工具",
"ui.data.total": "總計", "ui.data.total": "一共",
"ui.data.times": "抽", "ui.data.times": "抽",
"ui.data.sum": "已累計", "ui.data.sum": "已累計",
"ui.data.no5star": "抽未出5星", "ui.data.no4star": "抽未出S級",
"ui.data.character": "角色", "ui.data.character": "代理人",
"ui.data.weapon": "光錐", "ui.data.weapon": "音擎",
"ui.data.star5": "5星", "ui.data.bang": "邦布",
"ui.data.star4": "4星", "ui.data.star4": "S級",
"ui.data.star3": "3星", "ui.data.star3": "A級",
"ui.data.history": "5星歷史紀錄", "ui.data.star2": "B級",
"ui.data.average": "5星平均出貨次數為", "ui.data.history": "S級歷史記錄",
"ui.data.chara5": "5星角色", "ui.data.average": "S級平均出貨次數為",
"ui.data.chara4": "4星角色", "ui.data.chara4": "S級代理人",
"ui.data.weapon5": "5星光錐", "ui.data.chara3": "A級代理人",
"ui.data.weapon4": "4星光錐", "ui.data.weapon4": "S級音擎",
"ui.data.weapon3": "3星光錐", "ui.data.weapon3": "A級音擎",
"ui.setting.title": "設定", "ui.data.weapon2": "B級音擎",
"ui.data.bang4": "S級邦布",
"ui.data.bang3": "A級邦布",
"ui.setting.title": "設置",
"ui.setting.language": "語言", "ui.setting.language": "語言",
"ui.setting.languageHint": "缺少翻譯時,預設會顯示簡體中文", "ui.setting.languageHint": "缺少翻譯時,會默認顯示簡體中文",
"ui.setting.logType": "記錄類型", "ui.setting.logType": "日誌類型",
"ui.setting.auto": "自動", "ui.setting.auto": "自動",
"ui.setting.cnServer": "服", "ui.setting.cnServer": "服",
"ui.setting.seaServer": "國際服", "ui.setting.seaServer": "服",
"ui.setting.logTypeHint": "使用遊戲記錄取得 URL 時,優先選擇哪種伺服器產生的記錄檔案。", "ui.setting.logTypeHint": "使用遊戲日誌獲取URL時優先選擇哪種服務器生成的日誌文件。",
"ui.setting.dataManagerHint": "可以刪除不需要的數據。",
"ui.setting.autoUpdate": "自動更新", "ui.setting.autoUpdate": "自動更新",
"ui.setting.hideNovice": "隱藏新手躍遷", "ui.setting.proxyMode": "代理模式",
"ui.setting.proxyMode": "Proxy 模式", "ui.setting.proxyModeHint": "通過設置系統代理來獲取URL無法從日誌中獲取到有效的URL時才會啟動代理服務器。",
"ui.setting.proxyModeHint": "透過設定系統 Proxy 以取得 URL將會在從系統記錄中取得 URL 失敗時啟動。", "ui.setting.fetchFullHistory": "獲取完整數據",
"ui.setting.fetchFullHistory": "取得完整資料", "ui.setting.fetchFullHistoryHint": "開啟時點擊「更新數據」按鈕會完整獲取6個月內所有的抽卡記錄當記錄裏有6個月範圍以內的錯誤數據時可以通過這個功能修復。",
"ui.setting.fetchFullHistoryHint": "開啟時按下「更新資料」按鈕將會完整取得 6 個月內所有的抽卡紀錄,紀錄內有 6 個月範圍以內的錯誤資料時可以透過此功能修復。", "ui.setting.closeProxy": "關閉系統代理",
"ui.setting.closeProxy": "停用系統 Proxy", "ui.setting.closeProxyHint": "如果使用過代理模式時工具非正常關閉,可能導致系統代理設置沒能清除,可以通過這個按鈕來清除設置過的系統代理。",
"ui.setting.closeProxyHint": "如果使用 Proxy 模式時程式當機,可能會影響系統網路,可以透過這個按鈕以清除系統 Proxy 設定。", "ui.setting.idVersion": "ID 數據庫版本",
"ui.about.title": "關於", "ui.about.title": "關於",
"ui.about.license": "本工具為開放原始碼軟體,原始碼使用 MIT 授權", "ui.about.license": "本工具為開源軟件,源代碼使用 MIT 協議授權",
"ui.urlDialog.title": "手動輸入 URL", "ui.urlDialog.title": "手動輸入URL",
"ui.urlDialog.hint": "功能應當在你理解這需要什URL 時使用", "ui.urlDialog.hint": "這個功能應當在你理解這需要什URL時使用",
"ui.urlDialog.placeholder": "請輸入帶有身分驗證資訊的 URL", "ui.urlDialog.placeholder": "請輸入帶有身份認證信息的URL",
"ui.common.cancel": "取消", "ui.common.cancel": "取消",
"ui.common.ok": "確定", "ui.common.ok": "確定",
"log.save.failed": "儲存本機資料失敗", "ui.common.data": "數據",
"log.file.notFound": "未找到遊戲記錄,請確認是否已開啟遊戲躍遷紀錄。", "ui.common.dataManage": "數據管理",
"log.url.notFound": "未找到 URL", "ui.common.updateTime": "更新日期",
"log.file.readFailed": "讀取記錄失敗。", "ui.common.status": "狀態",
"log.fetch.retry": "處理${name}第 ${page} 頁失敗5 秒後進行第 ${count} 次重試……", "ui.common.action": "操作",
"log.fetch.retryFailed": "處理${name}第 ${page} 頁失敗,已超出重試次數", "ui.common.deleted": "已刪除",
"log.fetch.interval": "正在處理${name}第 ${page} 頁,每 10 頁休息 1 秒…", "ui.common.normal": "正常",
"log.fetch.current": "正在處理${name}第 ${page} 頁", "ui.common.delete": "刪除",
"log.fetch.authTimeout": "身分驗證已過期,請重新開啟遊戲躍遷紀錄。", "ui.common.restore": "恢復",
"log.fetch.gachaType": "正在取得躍遷活動類型", "log.save.failed": "保存本地數據失敗",
"log.fetch.gachaTypeOk": "已成功取得躍遷活動類型", "log.file.notFound": "未找到遊戲日誌,確認是否已打開遊戲抽卡記錄",
"log.url.lackAuth": "URL 中找不到驗證金鑰", "log.url.notFound": "未找到URL",
"log.proxy.hint": "正在使用 Proxy 模式 [${ip}:${port}] 取得 URL請重新開啟遊戲躍遷紀錄。", "log.file.readFailed": "讀取日誌失敗",
"log.url.notFound2": "無法找到 URL請確認是否已開啟遊戲躍遷紀錄。", "log.fetch.retry": "獲取${name}第${page}頁失敗5秒後進行第${count}次重試……",
"log.url.incorrect": "無法取得 URL 參數。", "log.fetch.retryFailed": "獲取${name}第${page}頁失敗,已超出重試次數",
"log.autoUpdate.success": "自動更新已完成,重新啟動工具後生效。", "log.fetch.interval": "正在獲取${name}第${page}頁每10頁休息1秒……",
"log.fetch.current": "正在獲取${name}第${page}頁",
"log.fetch.authTimeout": "身份認證已過期,請重新打開遊戲抽卡記錄",
"log.fetch.gachaType": "正在獲取調頻活動類型",
"log.fetch.gachaTypeOk": "獲取調頻活動類型成功",
"log.url.lackAuth": "URL中缺少authkey",
"log.proxy.hint": "正在使用代理模式[${ip}:${port}]獲取URL請重新打開遊戲抽卡記錄。",
"log.url.notFound2": "未找到URL請確認是否已打開遊戲抽卡記錄",
"log.url.incorrect": "獲取URL參數失敗",
"log.autoUpdate.success": "自動更新已完成,重啟工具後生效",
"excel.header.time": "時間", "excel.header.time": "時間",
"excel.header.name": "名稱", "excel.header.name": "名稱",
"excel.header.type": "類", "excel.header.type": "類",
"excel.header.rank": "星級", "excel.header.rank": "星級",
"excel.header.total": "總次數", "excel.header.total": "總次數",
"excel.header.pity": "保底內", "excel.header.pity": "保底內",
"excel.header.remark": "備註", "excel.header.remark": "備註",
"excel.wish2": "躍遷-2", "excel.wish2": "調頻2",
"excel.customFont": "微軟正黑體", "excel.customFont": "微軟雅黑",
"excel.filePrefix": "星穹鐵道躍遷紀錄", "excel.filePrefix": "絕區零調頻記錄",
"excel.fileType": "Excel 檔案", "excel.fileType": "Excel文件",
"srgf.fileType":"星穹鐵道躍遷紀錄格式檔案", "uigf.fileType":"統一可交換抽卡記錄標準 v4.0Beta",
"ui.extra.cacheClean": "1. 確認是否已經開遊戲內的躍遷歷史錄,如果仍然出現「身分驗證已過期」的錯誤,再嘗試下面的步驟\n2. 關閉「崩壞:星穹鐵道」的遊戲窗\n3. 按一下上方的「開啟快取資料夾」按鈕,開啟「Cache」資料夾\n4. 刪除Cache_Data」資料夾\n5. 啟動「崩壞:星穹鐵道」遊戲,開遊戲內躍遷歷史錄頁面\n6. 關閉這個對話方塊,再按下「更新資料」按鈕", "ui.extra.cacheClean": "1. 確認是否已經開遊戲內的抽卡歷史錄,如果仍然出現「身份認證已過期」的錯誤,再嘗試下面的步驟\n2. 關閉絕區零的遊戲窗\n3. 點擊上方的「打開緩存文件夾」按鈕,開Cache文件夾\n4. 刪除Cache_Data文件夾\n5. 啟動絕區零遊戲,開遊戲內抽卡歷史錄頁面\n6. 關閉這個對話框,再點擊「更新數據」按鈕",
"ui.extra.findCacheFolder": "如果按下「開啟快取資料夾」按鈕沒有應,可以手動找到遊戲的網頁快取資料夾,目錄為「的遊戲安裝路徑/Star Rail/Games/StarRail_Data/webCaches/Cache/」" "ui.extra.findCacheFolder": "如果點「打開緩存文件夾」按鈕沒有應,可以手動找到遊戲的網頁緩存文件夾,目錄為「的遊戲安裝路徑/ZenlessZoneZero_Data/webCaches/Cache/」",
"ui.extra.urlCopied": "URL已復製",
"ui.uigf.title": "請選擇要導出的UID"
} }

View File

@@ -1,77 +0,0 @@
{
"symbol.colon": ": ",
"ui.button.load": "데이터 로드",
"ui.button.update": "업데이트",
"ui.button.excel": "엑셀로 내보내기",
"ui.button.url": "URL 입력",
"ui.button.setting": "설정",
"ui.button.option": "옵션",
"ui.button.startProxy": "프록시 모드",
"ui.select.newAccount": "계정 추가",
"ui.hint.newAccount": "다른 계정에서 데이터 내보내기",
"ui.hint.init": "'데이터 로드' 버튼을 클릭하기 전에 게임 클라이언트 내에서 뽑기 기록을 여세요.",
"ui.hint.lastUpdate": "마지막 업데이트",
"ui.hint.failed": "앗, 뭔가 실패했어요",
"ui.win.title": "",
"ui.data.total": "총",
"ui.data.times": "기원",
"ui.data.sum": "누적",
"ui.data.no5star": "기원(천장: 90)",
"ui.data.character": "캐릭터",
"ui.data.weapon": "무기",
"ui.data.star5": "5★",
"ui.data.star4": "4★",
"ui.data.star3": "3★",
"ui.data.history": "5★ 기록",
"ui.data.average": "5★ 뽑기 평균",
"ui.data.chara5": "5★ 캐릭터",
"ui.data.chara4": "4★ 캐릭터",
"ui.data.weapon5": "5★ 무기",
"ui.data.weapon4": "4★ 무기",
"ui.data.weapon3": "3★ 무기",
"ui.setting.title": "설정",
"ui.setting.language": "언어",
"ui.setting.languageHint": "번역이 누락되면 기본적으로 영어가 표시됩니다..",
"ui.setting.logType": "로그 유형",
"ui.setting.auto": "자동",
"ui.setting.cnServer": "중국 서버",
"ui.setting.seaServer": "글로벌 서버",
"ui.setting.logTypeHint": "게임 로그에서 URL을 가져올 때 먼저 사용할 서버 생성 로그 선택",
"ui.setting.autoUpdate": "자동 업데이트",
"ui.setting.proxyMode": "프록시 모드",
"ui.setting.proxyModeHint": "시스템 로그에서 URL을 가져오지 못한 경우 시스템 프록시를 사용합니다.",
"ui.setting.closeProxy": "시스템 프록시 사용 안 함",
"ui.setting.closeProxyHint": "프록시 모드를 선택할 때 프로그램이 충돌하면 시스템에 영향을 줄 수 있는 원하지 않는 결과가 발생할 수 있습니다. 이 버튼을 눌러 시스템 프록시 설정을 지울 수 있습니다.",
"ui.about.title": "About",
"ui.about.license": "This software is opensource using MIT license.",
"ui.urlDialog.title": "수동으로 URL 입력",
"ui.urlDialog.hint": "이 기능은 여기서 필요한 URL을 알고 있는 경우에만 사용해야 합니다.",
"ui.urlDialog.placeholder": "인증 정보가 포함된 URL을 입력하세요.",
"ui.common.cancel": "Cancel",
"ui.common.ok": "OK",
"log.save.failed": "로컬 데이터를 저장 실패",
"log.file.notFound": "게임 로그를 찾을 수 없습니다. 게임 클라이언트 내에서 뽑기 기록을 열었는지 확인하세요.",
"log.url.notFound": "URL을 찾을 수 없습니다.",
"log.file.readFailed": "로그를 읽기 실패",
"log.fetch.retry": "${name}의 ${page}페이지 처리 중 실패했습니다5초 후 ${count}번 재시도",
"log.fetch.retryFailed": "${name}의 ${page}페이지 처리 중 실패했습니다,재시도 최대 시간 초과",
"log.fetch.interval": "${name}의 ${page}페이지 처리 중10 페이지마다 1초씩 대기 중",
"log.fetch.current": "${name}의 ${page}페이지 처리 중",
"log.fetch.authTimeout": "사용자 인증이 만료되었습니다. 게임 클라이언트 내에서 뽑기 기록을 다시 여세요.",
"log.fetch.gachaType": "기원 유형을 가져오는 중입니다. 잠시 기다려 주세요.",
"log.fetch.gachaTypeOk": "기원 유형 가져오기 성공",
"log.url.lackAuth": "URL에서 인증 키를 찾을 수 없습니다.",
"log.proxy.hint": "프록시 모드를 사용하여 [${ip}:${port}] URL을 가져왔습니다,게임 클라이언트 내에서 뽑기 기록을 다시 여세요.",
"log.url.notFound2": "URL을 찾을 수 없습니다. 게임 클라이언트 내에서 뽑기 기록을 열었는지 확인하세요.",
"log.url.incorrect": "URL 매개 변수를 가져올 수 없습니다.",
"log.autoUpdate.success": "자동 업데이트 성공,프로그램을 재시작 해주세요.",
"excel.header.time": "시간",
"excel.header.name": "이름",
"excel.header.type": "유형",
"excel.header.rank": "등급",
"excel.header.total": "총 기원 횟수",
"excel.header.pity": "기원(천장: 90)",
"excel.customFont": "Arial",
"excel.filePrefix": "",
"excel.fileType": "Excel file"
}

2838
src/idJson.json Normal file

File diff suppressed because it is too large Load Diff

View File

@@ -1,74 +0,0 @@
const { app, ipcMain, dialog } = require('electron')
const fs = require('fs-extra')
const path = require('path')
const getData = require('./getData').getData
const { version } = require('../../package.json')
const i18n = require('./i18n')
const getTimeString = () => {
return new Date().toLocaleString('sv').replace(/[- :]/g, '').slice(0, -2)
}
const formatDate = (date) => {
let y = date.getFullYear()
let m = `${date.getMonth()+1}`.padStart(2, '0')
let d = `${date.getDate()}`.padStart(2, '0')
return `${y}-${m}-${d} ${date.toLocaleString('zh-cn', { hour12: false }).slice(-8)}`
}
const start = async () => {
const { dataMap, current } = await getData()
const data = dataMap.get(current)
if (!data.result.size) {
throw new Error('数据为空')
}
const result = {
info: {
uid: data.uid,
lang: data.lang,
export_time: formatDate(new Date()),
export_timestamp: Math.ceil(Date.now() / 1000),
export_app: 'star-rail-warp-export',
export_app_version: `v${version}`,
region_time_zone: data.region_time_zone,
srgf_version: 'v1.0'
},
list: []
}
const listTemp = []
for (let [type, arr] of data.result) {
arr.forEach(log => {
listTemp.push({
gacha_id: log.gacha_id,
gacha_type: log.gacha_type,
item_id: log.item_id,
count: '1',
time: log.time,
name: log.name,
item_type: log.item_type,
rank_type: log.rank_type,
id: log.id
})
})
}
listTemp.sort((a, b) => Number(BigInt(a.id) - BigInt(b.id)))
listTemp.forEach(item => {
result.list.push({
...item
})
})
const filePath = dialog.showSaveDialogSync({
defaultPath: path.join(app.getPath('downloads'), `SRGF_${data.uid}_${getTimeString()}`),
filters: [
{ name: i18n.srgf.fileType, extensions: ['json'] }
]
})
if (filePath) {
await fs.ensureFile(filePath)
await fs.writeFile(filePath, JSON.stringify(result))
}
}
ipcMain.handle('EXPORT_SRGF_JSON', async () => {
await start()
})

174
src/main/UIGFJson.js Normal file
View File

@@ -0,0 +1,174 @@
const { app, ipcMain, dialog } = require('electron')
const fs = require('fs-extra')
const path = require('path')
const { getData, saveData, changeCurrent, convertTimeZone } = require('./getData')
const config = require('./config')
const { name, version } = require('../../package.json')
const i18n = require('./i18n')
const { mergeData } = require('./utils/mergeData')
const { sendMsg } = require('./utils')
const idJson = require('../idJson.json')
const getTimeString = () => {
return new Date().toLocaleString('sv').replace(/[- :]/g, '').slice(0, -2)
}
const formatDate = (date) => {
let y = date.getFullYear()
let m = `${date.getMonth()+1}`.padStart(2, '0')
let d = `${date.getDate()}`.padStart(2, '0')
return `${y}-${m}-${d} ${date.toLocaleString('zh-cn', { hour12: false }).slice(-8)}`
}
const exportUIGF = async (uids) => {
const result = {
info: {
export_timestamp: Math.ceil(Date.now() / 1000),
export_app: `${name}`,
export_app_version: `v${version}`,
version: "v4.0"
},
nap: []
}
const { dataMap, current } = await getData()
let fulldata = []
uids.forEach(uid => {
fulldata.push(dataMap.get(uid))
})
if (!fulldata.length) {
throw new Error('数据为空')
}
fulldata.forEach(data => {
const listTemp = []
for (let [type, arr] of data.result) {
arr.forEach(log => {
listTemp.push({
gacha_id: log.gacha_id,
gacha_type: log.gacha_type,
item_id: log.item_id,
count: log.count,
time: log.time,
name: log.name,
item_type: log.item_type,
rank_type: log.rank_type,
id: log.id
})
})
}
listTemp.sort((a, b) => Number(BigInt(a.id) - BigInt(b.id)))
let dataTemp = {
uid: data.uid,
timezone: data.region_time_zone,
lang: data.lang,
list: []
}
listTemp.forEach(item => {
dataTemp.list.push({
...item
})
})
result.nap.push(dataTemp)
})
const filePath = dialog.showSaveDialogSync({
defaultPath: path.join(app.getPath('downloads'), fulldata.length > 1 ? `UIGF_${getTimeString()}` : `UIGF_${fulldata[0].uid}_${getTimeString()}`),
filters: [
{ name: i18n.uigf.fileType, extensions: ['json'] }
]
})
if (filePath) {
await fs.ensureFile(filePath)
await fs.writeFile(filePath, JSON.stringify(result))
}
}
const importUIGF = async () => {
const filepath = await dialog.showOpenDialogSync({
properties: ['openFile'],
filters: [
{ name: i18n.uigf.fileType, extensions: ['json'] }
]
})
if (!filepath) return
const { dataMap, current } = await getData()
try {
const jsonData = fs.readJsonSync(filepath[0])
if('info' in jsonData && 'version' in jsonData.info) {
if (jsonData.info.version !== 'v4.0') {
sendMsg('不支持此版本UIGF')
console.error('不支持此版本UIGF')
return
}
} else {
sendMsg('UIGF格式错误')
console.error('UIGF格式错误')
return
}
jsonData.nap.forEach(uidData => {
const resultTemp = []
const isNew = !Boolean(dataMap.has(uidData.uid))
let region_time_zone
if (!isNew) region_time_zone = dataMap.get(uidData.uid).region_time_zone
else region_time_zone = uidData.timezone
let targetLang
if (!isNew) targetLang = dataMap.get(uidData.uid).lang
else targetLang = uidData.lang
if(!idJson[targetLang] && (!uidData.list[0].name || !uidData.list[0].item_type || !uidData.list[0].rank_type)) targetLang = config.lang
let idTargetLangJson = idJson[targetLang]
uidData.list.forEach(recordEntry => {
let rank_type
if (idTargetLangJson?.[recordEntry.item_id].rank_type) rank_type = String(idTargetLangJson[recordEntry.item_id].rank_type)
else rank_type = recordEntry.rank_type
resultTemp.push({
gacha_id: recordEntry.gacha_id,
gacha_type: recordEntry.gacha_type,
item_id: recordEntry.item_id,
count: recordEntry.count ?? "1",
time: convertTimeZone(recordEntry.time, uidData.timezone, region_time_zone),
name: idTargetLangJson?.[recordEntry.item_id].name ?? recordEntry.name,
item_type: idTargetLangJson?.[recordEntry.item_id].item_type ?? recordEntry.item_type,
rank_type: rank_type,
id: recordEntry.id
})
})
const resultTempGrouped = resultTemp.reduce((acc, curr) => {
if (!acc[curr.gacha_type]) {
acc[curr.gacha_type] = []
}
acc[curr.gacha_type].push(curr)
return acc;
}, {})
const resultTempMap = new Map(Object.entries(resultTempGrouped))
const resultMap = { result: resultTempMap, uid: uidData.uid}
let data
const mergedData = mergeData(dataMap.get(uidData.uid), resultMap)
if (isNew) {
data = { result: mergedData, time: Date.now(), uid: uidData.uid, lang: targetLang, region_time_zone: uidData.timezone, deleted: false }
} else {
data = { result: mergedData, time: Date.now(), uid: dataMap.get(uidData.uid).uid, lang: targetLang, region_time_zone: dataMap.get(uidData.uid).region_time_zone, deleted: dataMap.get(uidData.uid).deleted }
}
saveData(data, '')
changeCurrent(uidData.uid)
dataMap.set(uidData.uid, data)
})
return {
dataMap,
current: config.current
}
} catch (error) {
sendMsg(error, 'ERROR')
console.error(error)
}
}
ipcMain.handle('EXPORT_UIGF_JSON', async (event, uids) => {
await exportUIGF(uids)
})
ipcMain.handle('IMPORT_UIGF_JSON', async () => {
return await importUIGF()
})

View File

@@ -1,4 +1,4 @@
const { readJSON, saveJSON, decipherAes, cipherAes, detectLocale, userDataPath, globalUserDataPath } = require('./utils') const { readJSON, saveJSON, decipherAes, cipherAes, detectLocale, userDataPath } = require('./utils')
const config = { const config = {
urls: [], urls: [],
@@ -14,9 +14,7 @@ const config = {
const getLocalConfig = async () => { const getLocalConfig = async () => {
let localConfig = await readJSON(userDataPath, 'config.json') let localConfig = await readJSON(userDataPath, 'config.json')
if (!localConfig) {
localConfig = await readJSON(globalUserDataPath, 'config.json')
}
if (!localConfig) return if (!localConfig) return
const configTemp = {} const configTemp = {}
for (let key in localConfig) { for (let key in localConfig) {

View File

@@ -57,7 +57,7 @@ const start = async () => {
const workbook = new ExcelJS.Workbook() const workbook = new ExcelJS.Workbook()
for (let [key, value] of data.result) { for (let [key, value] of data.result) {
const name = data.typeMap.get(key) const name = data.typeMap.get(key)
const sheet = workbook.addWorksheet(name, {views: [{state: 'frozen', ySplit: 1}]}) const sheet = workbook.addWorksheet(name.replace(/[*?:\/\\]/g, ' '), {views: [{state: 'frozen', ySplit: 1}]})
let width = [24, 14, 8, 8, 8, 8, 8] let width = [24, 14, 8, 8, 8, 8, 8]
if (!data.lang.includes('zh-')) { if (!data.lang.includes('zh-')) {
width = [24, 32, 16, 12, 12, 12, 8] width = [24, 32, 16, 12, 12, 12, 8]
@@ -82,11 +82,17 @@ const start = async () => {
arr.push(log.time) arr.push(log.time)
arr.push(log.name) arr.push(log.name)
arr.push(log.item_type) arr.push(log.item_type)
arr.push(log.rank_type) if(log.rank_type === '2') {
arr.push(i18n.ui.data.star2)
} else if(log.rank_type === '3') {
arr.push(i18n.ui.data.star3)
} else {
arr.push(i18n.ui.data.star4)
}
arr.push(total) arr.push(total)
arr.push(pity) arr.push(pity)
temp.push(arr) temp.push(arr)
if (log.rank_type === '5') { if (log.rank_type === '4') {
pity = 0 pity = 0
} }
// if (key === '301') { // if (key === '301') {
@@ -133,14 +139,14 @@ const start = async () => {
} }
// rare rank background color // rare rank background color
const rankColor = { const rankColor = {
3: "ff8e8e8e", 2: "ff8e8e8e",
4: "ffa256e1", 3: "ffa256e1",
5: "ffbd6932", 4: "ffbd6932",
} }
sheet.getCell(`${c}${i + 2}`).font = { sheet.getCell(`${c}${i + 2}`).font = {
name: customFont, name: customFont,
color: { argb: rankColor[v.rank_type] }, color: { argb: rankColor[v.rank_type] },
bold : v.rank_type != "3" bold : v.rank_type != "2"
} }
}) })
}) })

View File

@@ -3,7 +3,7 @@ const util = require('util')
const path = require('path') const path = require('path')
const { URL } = require('url') const { URL } = require('url')
const { app, ipcMain, shell } = require('electron') const { app, ipcMain, shell } = require('electron')
const { sleep, request, sendMsg, readJSON, saveJSON, detectLocale, getCacheText, userDataPath, userPath, localIp, langMap, globalUserDataPath } = require('./utils') const { sleep, request, sendMsg, readJSON, saveJSON, detectLocale, getCacheText, userDataPath, userPath, localIp, langMap } = require('./utils')
const config = require('./config') const config = require('./config')
const i18n = require('./i18n') const i18n = require('./i18n')
const { enableProxy, disableProxy } = require('./module/system-proxy') const { enableProxy, disableProxy } = require('./module/system-proxy')
@@ -12,8 +12,8 @@ const { mergeData } = require('./utils/mergeData')
const gachaTypeRaw = require('../gachaType.json') const gachaTypeRaw = require('../gachaType.json')
const dataMap = new Map() const dataMap = new Map()
const order = ['11', '12', '1', '2'] const order = ['2', '3', '1', '5']
let apiDomain = 'https://api-takumi.mihoyo.com' let apiDomain = 'https://public-operation-nap.mihoyo.com'
const saveData = async (data, url) => { const saveData = async (data, url) => {
const obj = Object.assign({}, data) const obj = Object.assign({}, data)
@@ -23,12 +23,33 @@ const saveData = async (data, url) => {
} }
const defaultTypeMap = new Map([ const defaultTypeMap = new Map([
['11', '角色活动跃迁'], ['2', '独家频段'],
['12', '光锥活动跃迁'], ['3', '音擎频段'],
['1', '常驻跃迁'], ['1', '常驻频段'],
['2', '新手跃迁'] ['5', '邦布频段']
]) ])
const serverTimeZone = new Map([
["prod_gf_cn", 8],
["prod_gf_jp", 8],
["prod_gf_us", -5],
["prod_gf_eu", 1],
["prod_gf_sg", 8]
])
const convertTimeZone = (dateTimeStr, fromTimeZoneOffset, toTimeZoneOffset) => {
let date = new Date(dateTimeStr.replace(' ', 'T') + 'Z');
let utcDate = new Date(date.getTime() - fromTimeZoneOffset * 60 * 60 * 1000);
let targetDate = new Date(utcDate.getTime() + toTimeZoneOffset * 60 * 60 * 1000);
let year = targetDate.getUTCFullYear();
let month = String(targetDate.getUTCMonth() + 1).padStart(2, '0');
let day = String(targetDate.getUTCDate()).padStart(2, '0');
let hours = String(targetDate.getUTCHours()).padStart(2, '0');
let minutes = String(targetDate.getUTCMinutes()).padStart(2, '0');
let seconds = String(targetDate.getUTCSeconds()).padStart(2, '0');
return `${year}-${month}-${day} ${hours}:${minutes}:${seconds}`;
}
const findDataFiles = async (dataPath, fileMap) => { const findDataFiles = async (dataPath, fileMap) => {
const files = await readdir(dataPath) const files = await readdir(dataPath)
if (files?.length) { if (files?.length) {
@@ -42,10 +63,8 @@ const findDataFiles = async (dataPath, fileMap) => {
const collectDataFiles = async () => { const collectDataFiles = async () => {
await fs.ensureDir(userDataPath) await fs.ensureDir(userDataPath)
await fs.ensureDir(globalUserDataPath)
const fileMap = new Map() const fileMap = new Map()
await findDataFiles(userDataPath, fileMap) await findDataFiles(userDataPath, fileMap)
await findDataFiles(globalUserDataPath, fileMap)
return fileMap return fileMap
} }
@@ -60,6 +79,13 @@ const readData = async () => {
const data = await readJSON(dataPath, name) const data = await readJSON(dataPath, name)
data.typeMap = new Map(data.typeMap) || defaultTypeMap data.typeMap = new Map(data.typeMap) || defaultTypeMap
data.result = new Map(data.result) data.result = new Map(data.result)
data.result.forEach((value, key) => {
value.forEach(item => {
if (!('count' in item)) {
item.count = "1";
}
});
});
if (data.uid) { if (data.uid) {
dataMap.set(data.uid, data) dataMap.set(data.uid, data)
} }
@@ -88,7 +114,7 @@ const changeCurrent = async (uid) => {
const detectGameLocale = async (userPath) => { const detectGameLocale = async (userPath) => {
let list = [] let list = []
const lang = app.getLocale() const lang = app.getLocale()
const arr = ['/miHoYo/崩坏:星穹铁道/', '/Cognosphere/Star Rail/'] const arr = ['/miHoYo/绝区零/', '/miHoYo/ZenlessZoneZero/']
arr.forEach(str => { arr.forEach(str => {
try { try {
const pathname = path.join(userPath, '/AppData/LocalLow/', str, 'Player.log') const pathname = path.join(userPath, '/AppData/LocalLow/', str, 'Player.log')
@@ -140,15 +166,20 @@ const readLog = async () => {
} }
const promises = logPaths.map(async logpath => { const promises = logPaths.map(async logpath => {
const logText = await fs.readFile(logpath, 'utf8') const logText = await fs.readFile(logpath, 'utf8')
const gamePathMch = logText.match(/\w:\/.*?\/StarRail_Data\//i) const url = logText.match(/https:\/\/.*?\/info/g)
if (url) {
return getLatestUrl(url)
}
const gamePathMch = logText.match(/([A-Z]:\/.*?\/)(?=ZenlessZoneZero_Data)/i)
if (gamePathMch) { if (gamePathMch) {
const [cacheText, cacheFile] = await getCacheText(gamePathMch[0]) const[cacheText, cacheFile] = await getCacheText(gamePathMch[0]+"/ZenlessZoneZero_Data")
const urlMch = cacheText.match(/https.+?&auth_appid=webview_gacha&.+?authkey=.+?&game_biz=hkrpg_.+?&plat_type=pc/g) const urlMch = cacheText.match(/https.+?authkey=.+?end_id=/g)
if (urlMch) { if (urlMch) {
cacheFolder = cacheFile.replace(/Cache_Data[/\\]data_2$/, '') cacheFolder = cacheFile.replace(/Cache_Data[/\\]data_2$/, '')
return getLatestUrl(urlMch) return getLatestUrl(urlMch)
} }
} }
}) })
const result = await Promise.all(promises) const result = await Promise.all(promises)
for (let url of result) { for (let url of result) {
@@ -167,7 +198,7 @@ const readLog = async () => {
const getGachaLog = async ({ key, page, name, retryCount, url, endId }) => { const getGachaLog = async ({ key, page, name, retryCount, url, endId }) => {
const text = i18n.log const text = i18n.log
try { try {
const res = await request(`${url}&gacha_type=${key}&page=${page}&size=${20}${endId ? '&end_id=' + endId : ''}`) const res = await request(`${url}&real_gacha_type=${key}&page=${page}&size=${20}${endId ? '&end_id=' + endId : ''}`)
if (res?.data?.list) { if (res?.data?.list) {
return res?.data return res?.data
} }
@@ -193,7 +224,6 @@ const getGachaLogs = async ({ name, key }, queryString) => {
let logs = [] let logs = []
let uid = '' let uid = ''
let region = '' let region = ''
let region_time_zone = ''
let endId = '0' let endId = '0'
const url = `${apiDomain}/common/gacha_record/api/getGachaLog?${queryString}` const url = `${apiDomain}/common/gacha_record/api/getGachaLog?${queryString}`
do { do {
@@ -211,9 +241,6 @@ const getGachaLogs = async ({ name, key }, queryString) => {
if (!region) { if (!region) {
region = res.region region = res.region
} }
if (!region_time_zone) {
region_time_zone = res.region_time_zone
}
list.push(...logs) list.push(...logs)
page += 1 page += 1
@@ -242,7 +269,7 @@ const getGachaLogs = async ({ name, key }, queryString) => {
} }
} }
} while (logs.length > 0) } while (logs.length > 0)
return { list, uid, region, region_time_zone } return { list, uid, region }
} }
const checkResStatus = (res) => { const checkResStatus = (res) => {
@@ -264,7 +291,7 @@ const tryGetUid = async (queryString) => {
const url = `${apiDomain}/common/gacha_record/api/getGachaLog?${queryString}` const url = `${apiDomain}/common/gacha_record/api/getGachaLog?${queryString}`
try { try {
for (let [key] of defaultTypeMap) { for (let [key] of defaultTypeMap) {
const res = await request(`${url}&gacha_type=${key}&page=1&size=6`) const res = await request(`${url}&real_gacha_type=${key}&page=1&size=6`)
if (res.data.list && res.data.list.length) { if (res.data.list && res.data.list.length) {
return res.data.list[0].uid return res.data.list[0].uid
} }
@@ -290,10 +317,10 @@ const fixAuthkey = (url) => {
const getQuerystring = (url) => { const getQuerystring = (url) => {
const text = i18n.log const text = i18n.log
const { searchParams, host } = new URL(fixAuthkey(url)) const { searchParams, host } = new URL(fixAuthkey(url))
if (host.includes('webstatic-sea') || host.includes('hkrpg-api-os') || host.includes("api-os-takumi")) { if (host.includes('webstatic-sea') || host.includes('hoyoverse.com')) {
apiDomain = 'https://api-os-takumi.mihoyo.com' apiDomain = 'https://public-operation-nap-sg.hoyoverse.com'
} else { } else {
apiDomain = 'https://api-takumi.mihoyo.com' apiDomain = 'https://public-operation-nap.mihoyo.com'
} }
const authkey = searchParams.get('authkey') const authkey = searchParams.get('authkey')
if (!authkey) { if (!authkey) {
@@ -302,7 +329,7 @@ const getQuerystring = (url) => {
} }
searchParams.delete('page') searchParams.delete('page')
searchParams.delete('size') searchParams.delete('size')
searchParams.delete('gacha_type') searchParams.delete('real_gacha_type')
searchParams.delete('end_id') searchParams.delete('end_id')
return searchParams return searchParams
} }
@@ -359,7 +386,7 @@ const getUrlFromConfig = () => {
const tryRequest = async (url, retry = false) => { const tryRequest = async (url, retry = false) => {
const queryString = getQuerystring(url) const queryString = getQuerystring(url)
if (!queryString) return false if (!queryString) return false
const gachaTypeUrl = `${apiDomain}/common/gacha_record/api/getGachaLog?${queryString}&page=1&size=5&gacha_type=1&end_id=0` const gachaTypeUrl = `${apiDomain}/common/gacha_record/api/getGachaLog?${queryString}&page=1&size=5&real_gacha_type=1&end_id=0`
try { try {
const res = await request(gachaTypeUrl) const res = await request(gachaTypeUrl)
checkResStatus(res) checkResStatus(res)
@@ -415,13 +442,28 @@ const fetchData = async (urlOverride) => {
const typeMap = new Map() const typeMap = new Map()
const lang = searchParams.get('lang') const lang = searchParams.get('lang')
let originUid = '' let originUid = ''
let originRegion = '' let localTimeZone
let originTimeZone = ''
for (const type of gachaType) { for (const type of gachaType) {
const { list, uid, region, region_time_zone } = await getGachaLogs(type, queryString) const { list, uid, region} = await getGachaLogs(type, queryString)
const region_time_zone = serverTimeZone.get(region)
if(!region_time_zone) {
sendMsg('不支持此服务器')
console.error('不支持此服务器')
return
}
if (localTimeZone === undefined) {
localTimeZone = dataMap.get(uid)?.region_time_zone
if (localTimeZone === undefined) {
localTimeZone = region_time_zone
}
}
localTimeZone === Number(localTimeZone)
list.forEach(item => {
item.time = convertTimeZone(item.time, region_time_zone, localTimeZone)
})
const logs = list.map((item) => { const logs = list.map((item) => {
const { id, item_id, item_type, name, rank_type, time, gacha_id, gacha_type } = item const { id, item_id, item_type, name, rank_type, time, gacha_id, gacha_type, count} = item
return { id, item_id, item_type, name, rank_type, time, gacha_id, gacha_type } return { id, item_id, item_type, name, rank_type, time, gacha_id, gacha_type, count }
}) })
logs.reverse() logs.reverse()
typeMap.set(type.key, type.name) typeMap.set(type.key, type.name)
@@ -429,14 +471,8 @@ const fetchData = async (urlOverride) => {
if (!originUid) { if (!originUid) {
originUid = uid originUid = uid
} }
if (!originRegion) {
originRegion = region
} }
if (!originTimeZone) { const data = { result, typeMap, time: Date.now(), uid: originUid, lang, region_time_zone: localTimeZone }
originTimeZone = region_time_zone
}
}
const data = { result, typeMap, time: Date.now(), uid: originUid, lang, region: originRegion, region_time_zone: originTimeZone }
const localData = dataMap.get(originUid) const localData = dataMap.get(originUid)
const mergedResult = mergeData(localData, data) const mergedResult = mergeData(localData, data)
data.result = mergedResult data.result = mergedResult
@@ -517,5 +553,9 @@ exports.getData = () => {
} }
} }
exports.serverTimeZone = serverTimeZone
exports.getUrl = getUrl exports.getUrl = getUrl
exports.deleteData = deleteData exports.deleteData = deleteData
exports.saveData = saveData
exports.changeCurrent = changeCurrent
exports.convertTimeZone = convertTimeZone

View File

@@ -1,17 +1,7 @@
const raw = { const raw = {
'zh-cn': require('../i18n/简体中文.json'), 'zh-cn': require('../i18n/简体中文.json'),
'zh-tw': require('../i18n/繁體中文.json'), 'zh-tw': require('../i18n/繁體中文.json'),
'de-de': require('../i18n/Deutsch.json'), 'en-us': require('../i18n/English.json')
'en-us': require('../i18n/English.json'),
'es-es': require('../i18n/Español.json'),
'fr-fr': require('../i18n/Français.json'),
'id-id': require('../i18n/Indonesia.json'),
'ja-jp': require('../i18n/日本語.json'),
'ko-kr': require('../i18n/한국어.json'),
'pt-pt': require('../i18n/Português.json'),
'ru-ru': require('../i18n/Pусский.json'),
'th-th': require('../i18n/ภาษาไทย.json'),
'vi-vn': require('../i18n/Tiếng Việt.json')
} }
const config = require('./config') const config = require('./config')
const isPlainObject = require('lodash/isPlainObject') const isPlainObject = require('lodash/isPlainObject')
@@ -76,7 +66,7 @@ const parseText = (text, data) => {
} }
const mainProps = [ const mainProps = [
'symbol', 'ui', 'log', 'excel',"srgf" 'symbol', 'ui', 'log', 'excel',"uigf"
] ]
const i18n = new Proxy(raw, { const i18n = new Proxy(raw, {

View File

@@ -4,7 +4,7 @@ const { disableProxy, proxyStatus } = require('./module/system-proxy')
require('./getData') require('./getData')
require('./bridge') require('./bridge')
require('./excel') require('./excel')
require('./SRGFJson') require('./UIGFJson')
const { getUpdateInfo } = require('./update/index') const { getUpdateInfo } = require('./update/index')
const isDev = !app.isPackaged const isDev = !app.isPackaged

View File

@@ -28,7 +28,7 @@ const updatePath = isDev ? path.resolve(__dirname, '../../', 'update-dev/downloa
const update = async () => { const update = async () => {
if (isDev) return if (isDev) return
try { try {
const url = 'https://star-rail-warp-export.css.moe/update' const url = 'https://earthjasonlin.github.io/zzz-signal-search-export/update'
const res = await fetch(`${url}/manifest.json?t=${Math.floor(Date.now() / (1000 * 60 * 10))}`) const res = await fetch(`${url}/manifest.json?t=${Math.floor(Date.now() / (1000 * 60 * 10))}`)
const data = await res.json() const data = await res.json()
if (!data.active) return if (!data.active) return

View File

@@ -13,7 +13,7 @@ const isDev = !app.isPackaged
const userPath = app.getPath('userData') const userPath = app.getPath('userData')
const appRoot = isDev ? path.resolve(__dirname, '..', '..') : path.resolve(app.getAppPath(), '..', '..') const appRoot = isDev ? path.resolve(__dirname, '..', '..') : path.resolve(app.getAppPath(), '..', '..')
const userDataPath = path.resolve(appRoot, 'userData') const userDataPath = path.resolve(appRoot, 'userData')
const globalUserDataPath = path.resolve(userPath, 'userData') // const globalUserDataPath = path.resolve(userPath, 'userData')
let win = null let win = null
const initWindow = () => { const initWindow = () => {
@@ -103,33 +103,13 @@ const sortData = (data) => {
const langMap = new Map([ const langMap = new Map([
['zh-cn', '简体中文'], ['zh-cn', '简体中文'],
['zh-tw', '繁體中文'], ['zh-tw', '繁體中文'],
['de-de', 'Deutsch'], ['en-us', 'English']
['en-us', 'English'],
['es-es', 'Español'],
['fr-fr', 'Français'],
['id-id', 'Indonesia'],
['ja-jp', '日本語'],
['ko-kr', '한국어'],
['pt-pt', 'Português'],
['ru-ru', 'Pусский'],
['th-th', 'ภาษาไทย'],
['vi-vn', 'Tiếng Việt']
]) ])
const localeMap = new Map([ const localeMap = new Map([
['zh-cn', ['zh', 'zh-CN']], ['zh-cn', ['zh', 'zh-CN']],
['zh-tw', ['zh-TW']], ['zh-tw', ['zh-TW']],
['de-de', ['de-AT', 'de-CH', 'de-DE', 'de']], ['en-us', ['en-AU', 'en-CA', 'en-GB', 'en-NZ', 'en-US', 'en-ZA', 'en']]
['en-us', ['en-AU', 'en-CA', 'en-GB', 'en-NZ', 'en-US', 'en-ZA', 'en']],
['es-es', ['es', 'es-419']],
['fr-fr', ['fr-CA', 'fr-CH', 'fr-FR', 'fr']],
['id-id', ['id']],
['ja-jp', ['ja']],
['ko-kr', ['ko']],
['pt-pt', ['pt-BR', 'pt-PT', 'pt']],
['ru-ru', ['ru']],
['th-th', ['th']],
['vi-vn', ['vi']]
]) ])
const detectLocale = (value) => { const detectLocale = (value) => {
@@ -147,9 +127,6 @@ const detectLocale = (value) => {
const saveJSON = async (name, data) => { const saveJSON = async (name, data) => {
try { try {
await fs.outputJSON(path.join(userDataPath, name), data) await fs.outputJSON(path.join(userDataPath, name), data)
if (!isDev) {
await fs.outputJSON(path.join(globalUserDataPath, name), data)
}
} catch (e) { } catch (e) {
sendMsg(e, 'ERROR') sendMsg(e, 'ERROR')
await sleep(3) await sleep(3)
@@ -165,12 +142,12 @@ const readJSON = async (dataPath, name) => {
} }
const hash = (data, type = 'sha256') => { const hash = (data, type = 'sha256') => {
const hmac = crypto.createHmac(type, 'hk4e') const hmac = crypto.createHmac(type, 'nap')
hmac.update(data) hmac.update(data)
return hmac.digest('hex') return hmac.digest('hex')
} }
const scryptKey = crypto.scryptSync(userPath, 'hk4e', 24) const scryptKey = crypto.scryptSync(userPath, 'nap', 24)
const cipherAes = (data) => { const cipherAes = (data) => {
const algorithm = 'aes-192-cbc' const algorithm = 'aes-192-cbc'
const iv = Buffer.alloc(16, 0) const iv = Buffer.alloc(16, 0)
@@ -221,5 +198,5 @@ async function getCacheText(gamePath) {
module.exports = { module.exports = {
sleep, request, hash, cipherAes, decipherAes, saveLog, getCacheText, sleep, request, hash, cipherAes, decipherAes, saveLog, getCacheText,
sendMsg, readJSON, saveJSON, initWindow, getWin, localIp, userPath, detectLocale, langMap, sendMsg, readJSON, saveJSON, initWindow, getWin, localIp, userPath, detectLocale, langMap,
appRoot, userDataPath, globalUserDataPath appRoot, userDataPath
} }

View File

@@ -11,7 +11,8 @@
<template #dropdown> <template #dropdown>
<el-dropdown-menu> <el-dropdown-menu>
<el-dropdown-item command="excel">{{ui.button.excel}}</el-dropdown-item> <el-dropdown-item command="excel">{{ui.button.excel}}</el-dropdown-item>
<el-dropdown-item command="srgf-json">{{ui.button.srgf}}</el-dropdown-item> <el-dropdown-item command="uigf-json">{{ui.button.uigf}}</el-dropdown-item>
<el-dropdown-item command="import-json" divided>{{ui.button.import}}</el-dropdown-item>
</el-dropdown-menu> </el-dropdown-menu>
</template> </template>
</el-dropdown> </el-dropdown>
@@ -91,7 +92,7 @@ import Setting from './components/Setting.vue'
import gachaDetail from './gachaDetail' import gachaDetail from './gachaDetail'
import { version } from '../../package.json' import { version } from '../../package.json'
import gachaType from '../gachaType.json' import gachaType from '../gachaType.json'
import { ElMessage } from 'element-plus' import { ElMessage, ElMessageBox } from 'element-plus'
const state = reactive({ const state = reactive({
status: 'init', status: 'init',
@@ -238,18 +239,61 @@ const saveExcel = async () => {
await ipcRenderer.invoke('SAVE_EXCEL') await ipcRenderer.invoke('SAVE_EXCEL')
} }
const exportSRGFJSON = () => { const exportUIGFJSON = () => {
ipcRenderer.invoke('EXPORT_SRGF_JSON') let uidList = []
dataMap.value.forEach(item => {
uidList.push(item.uid)
})
ElMessageBox({
title: state.i18n.ui.uigf.title,
message: `
<div>
${uidList.map(uid => `
<div>
<input type="checkbox" id="${uid}" value="${uid}" />
<label for="${uid}">${uid}</label>
</div>
`).join('')}
</div>
`,
dangerouslyUseHTMLString: true,
showCancelButton: true,
confirmButtonText: state.i18n.ui.common.ok,
cancelButtonText: state.i18n.ui.common.cancel,
beforeClose: (action, instance, done) => {
if (action === 'confirm') {
const selected_uids = uidList.filter(uid => document.getElementById(uid).checked);
ipcRenderer.invoke('EXPORT_UIGF_JSON', selected_uids);
}
done();
}
}).then(() => {
}).catch(() => {
});
}
const importData = async () => {
state.status = 'loading'
const data = await ipcRenderer.invoke('IMPORT_UIGF_JSON')
if (data) {
state.dataMap = data.dataMap
state.current = data.current
state.status = 'loaded'
} else {
state.status = 'failed'
}
} }
const exportCommand = (type) => { const exportCommand = (type) => {
if (type === 'excel') { if (type === 'excel') {
saveExcel() saveExcel()
} else if (type === 'srgf-json') { } else if (type === 'uigf-json') {
exportSRGFJSON() exportUIGFJSON()
} else if (type === 'import-json') {
importData()
} }
} }
const openCacheFolder = async () => { const openCacheFolder = async () => {
await ipcRenderer.invoke('OPEN_CACHE_FOLDER') await ipcRenderer.invoke('OPEN_CACHE_FOLDER')
} }

View File

@@ -8,21 +8,21 @@
<span class="mr-1">{{text.total}} <span class="mr-1">{{text.total}}
<span class="text-blue-600">{{detail.total}}</span> {{text.times}} <span class="text-blue-600">{{detail.total}}</span> {{text.times}}
</span> </span>
<span v-if="type !== '100'">{{text.sum}}<span class="mx-1 text-green-600">{{detail.countMio}}</span>{{text.no5star}}</span> <span v-if="type !== '100'">{{text.sum}}<span class="mx-1 text-green-600">{{detail.countMio}}</span>{{text.no4star}}</span>
</p> </p>
<p class="text-gray-600 text-xs mb-1"> <p class="text-gray-600 text-xs mb-1">
<span :title="`${text.character}${colon}${detail.count5c}\n${text.weapon}${colon}${detail.count5w}`" class="mr-3 whitespace-pre cursor-help text-yellow-500"> <span :title="`${text.character}${colon}${detail.count4c}\n${text.weapon}${colon}${detail.count4w}\n${text.bang}${colon}${detail.count4b}`" class="mr-3 whitespace-pre cursor-help text-yellow-500">
<span class="min-w-10 inline-block">{{text.star5}}{{colon}}{{detail.count5}}</span>
[{{percent(detail.count5, detail.total)}}]
</span>
<br><span :title="`${text.character}${colon}${detail.count4c}\n${text.weapon}${colon}${detail.count4w}`" class="mr-3 whitespace-pre cursor-help text-purple-600">
<span class="min-w-10 inline-block">{{text.star4}}{{colon}}{{detail.count4}}</span> <span class="min-w-10 inline-block">{{text.star4}}{{colon}}{{detail.count4}}</span>
[{{percent(detail.count4, detail.total)}}] [{{percent(detail.count4, detail.total)}}]
</span> </span>
<br><span class="text-blue-500 whitespace-pre"> <br><span :title="`${text.character}${colon}${detail.count3c}\n${text.weapon}${colon}${detail.count3w}\n${text.bang}${colon}${detail.count3b}`" class="mr-3 whitespace-pre cursor-help text-purple-600">
<span class="min-w-10 inline-block">{{text.star3}}{{colon}}{{detail.count3}}</span> <span class="min-w-10 inline-block">{{text.star3}}{{colon}}{{detail.count3}}</span>
[{{percent(detail.count3, detail.total)}}] [{{percent(detail.count3, detail.total)}}]
</span> </span>
<br><span class="text-blue-500 whitespace-pre">
<span class="min-w-10 inline-block">{{text.star2}}{{colon}}{{detail.count2}}</span>
[{{percent(detail.count2, detail.total)}}]
</span>
</p> </p>
<p class="text-gray-600 text-xs mb-1" v-if="detail.ssrPos.length"> <p class="text-gray-600 text-xs mb-1" v-if="detail.ssrPos.length">

View File

@@ -32,21 +32,23 @@ const props = defineProps({
const chart = ref(null); const chart = ref(null);
const colors = ["#fac858", "#ee6666", "#5470c6", "#91cc75", "#73c0de"]; const colors = ["#fac858", "#fac858", "#ee6666", "#5470c6", "#5470c6", "#91cc75", "#73c0de"];
const parseData = (detail, type) => { const parseData = (detail, type) => {
const text = props.i18n.ui.data; const text = props.i18n.ui.data;
const keys = [ const keys = [
[text.chara5, "count5c"], [text.bang4, "count4b"],
[text.weapon5, "count5w"],
[text.chara4, "count4c"], [text.chara4, "count4c"],
[text.weapon4, "count4w"], [text.weapon4, "count4w"],
[text.chara3, "count3c"],
[text.bang3, "count3b"],
[text.weapon3, "count3w"], [text.weapon3, "count3w"],
[text.weapon2, "count2w"]
]; ];
const result = []; const result = [];
const color = []; const color = [];
const selected = { const selected = {
[text.weapon3]: false, [text.weapon2]: false,
}; };
keys.forEach((key, index) => { keys.forEach((key, index) => {
if (!detail[key[1]]) return; if (!detail[key[1]]) return;
@@ -58,9 +60,9 @@ const parseData = (detail, type) => {
}); });
if ( if (
type === "100" || type === "100" ||
result.findIndex((item) => item.name.includes("5")) === -1 result.findIndex((item) => item.name.includes("S")) === -1
) { ) {
selected[text.weapon3] = true; selected[text.weapon2] = true;
} }
return [result, color, selected]; return [result, color, selected];
}; };

View File

@@ -29,12 +29,6 @@
v-model="settingForm.autoUpdate"> v-model="settingForm.autoUpdate">
</el-switch> </el-switch>
</el-form-item> </el-form-item>
<el-form-item :label="text.hideNovice">
<el-switch
@change="saveSetting"
v-model="settingForm.hideNovice">
</el-switch>
</el-form-item>
<el-form-item :label="text.fetchFullHistory"> <el-form-item :label="text.fetchFullHistory">
<el-switch <el-switch
@change="saveSetting" @change="saveSetting"
@@ -53,8 +47,10 @@
</el-form-item> </el-form-item>
</el-form> </el-form>
<h3 class="text-lg my-4">{{about.title}}</h3> <h3 class="text-lg my-4">{{about.title}}</h3>
<p class="text-gray-600 text-xs mt-1">{{text.idVersion}} {{idJson.version}}</p>
<p class="text-gray-600 text-xs mt-1">{{about.license}}</p> <p class="text-gray-600 text-xs mt-1">{{about.license}}</p>
<p class="text-gray-600 text-xs mt-1 pb-6">Github: <a @click="openGithub" class="cursor-pointer text-blue-400">https://github.com/biuuu/star-rail-warp-export</a></p> <p class="text-gray-600 text-xs mt-1">GitHub: <a @click="openGithub" class="cursor-pointer text-blue-400">https://github.com/earthjasonlin/zzz-signal-search-export</a></p>
<p class="text-gray-600 text-xs mt-1 pb-6">UIGF: <a @click="openUIGF" class="cursor-pointer text-blue-400">https://uigf.org/</a></p>
<el-dialog v-model="state.showDataDialog" :title="common.dataManage" width="90%"> <el-dialog v-model="state.showDataDialog" :title="common.dataManage" width="90%">
<div class=""> <div class="">
<el-table :data="gachaDataInfo" border stripe> <el-table :data="gachaDataInfo" border stripe>
@@ -87,6 +83,7 @@
<script setup> <script setup>
const { ipcRenderer, shell } = require('electron') const { ipcRenderer, shell } = require('electron')
import idJson from '../../idJson.json'
import { reactive, onMounted, computed } from 'vue' import { reactive, onMounted, computed } from 'vue'
const emit = defineEmits(['close', 'changeLang', 'refreshData']) const emit = defineEmits(['close', 'changeLang', 'refreshData'])
@@ -106,7 +103,6 @@ const settingForm = reactive({
proxyMode: true, proxyMode: true,
autoUpdate: true, autoUpdate: true,
fetchFullHistory: false, fetchFullHistory: false,
hideNovice: true
}) })
const state = reactive({ const state = reactive({
@@ -119,7 +115,7 @@ const text = computed(() => props.i18n.ui.setting)
const about = computed(() => props.i18n.ui.about) const about = computed(() => props.i18n.ui.about)
const saveSetting = async () => { const saveSetting = async () => {
const keys = ['lang', 'logType', 'proxyMode', 'autoUpdate', 'fetchFullHistory', 'hideNovice'] const keys = ['lang', 'logType', 'proxyMode', 'autoUpdate', 'fetchFullHistory']
for (let key of keys) { for (let key of keys) {
await ipcRenderer.invoke('SAVE_CONFIG', [key, settingForm[key]]) await ipcRenderer.invoke('SAVE_CONFIG', [key, settingForm[key]])
} }
@@ -136,7 +132,8 @@ const disableProxy = async () => {
await ipcRenderer.invoke('DISABLE_PROXY') await ipcRenderer.invoke('DISABLE_PROXY')
} }
const openGithub = () => shell.openExternal('https://github.com/biuuu/star-rail-warp-export') const openGithub = () => shell.openExternal('https://github.com/earthjasonlin/zzz-signal-search-export')
const openUIGF = () => shell.openExternal('https://uigf.org/')
const openLink = (link) => shell.openExternal(link) const openLink = (link) => shell.openExternal(link)
const deleteData = async (uid, action) => { const deleteData = async (uid, action) => {

View File

@@ -1,4 +1,4 @@
import { isWeapon, isCharacter } from './utils' import { isWeapon, isCharacter, isBangboo } from './utils'
const itemCount = (map, name) => { const itemCount = (map, name) => {
if (!map.has(name)) { if (!map.has(name)) {
@@ -12,10 +12,11 @@ const gachaDetail = (data) => {
const detailMap = new Map() const detailMap = new Map()
for (let [key, value] of data) { for (let [key, value] of data) {
let detail = { let detail = {
count3: 0, count4: 0, count5: 0, count2: 0, count3: 0, count4: 0,
count3w: 0, count4w: 0, count5w: 0, count4c: 0, count5c: 0, count2w: 0, count3w: 0, count4w: 0, count3c: 0, count4c: 0, count3b: 0, count4b: 0,
weapon3: new Map(), weapon4: new Map(), weapon5: new Map(), weapon2: new Map(), weapon3: new Map(), weapon4: new Map(),
char4: new Map(), char5: new Map(), char3: new Map(), char4: new Map(),
bang3: new Map(), bang4: new Map(),
date: [], date: [],
ssrPos: [], countMio: 0, total: value.length, ssrPos: [], countMio: 0, total: value.length,
} }
@@ -29,35 +30,41 @@ const gachaDetail = (data) => {
if (!dateMax) dateMax = timestamp if (!dateMax) dateMax = timestamp
if (dateMin > timestamp) dateMin = timestamp if (dateMin > timestamp) dateMin = timestamp
if (dateMax < timestamp) dateMax = timestamp if (dateMax < timestamp) dateMax = timestamp
if (rank === '3') { if (rank === '2') {
detail.count2++
detail.countMio++
if (isWeapon(type)) {
detail.count2w++
itemCount(detail.weapon2, name)
}
} else if (rank === '3') {
detail.count3++ detail.count3++
detail.countMio++ detail.countMio++
if (isWeapon(type)) { if (isWeapon(type)) {
detail.count3w++ detail.count3w++
itemCount(detail.weapon3, name) itemCount(detail.weapon3, name)
} else if (isBangboo(type)) {
detail.count3b++
itemCount(detail.bang3, name)
} else if (isCharacter(type)) {
detail.count3c++
itemCount(detail.char3, name)
} }
} else if (rank === '4') { } else if (rank === '4') {
detail.ssrPos.push([name, index + 1 - lastSSR, time, key])
lastSSR = index + 1
detail.count4++ detail.count4++
detail.countMio++ detail.countMio = 0
if (isWeapon(type)) { if (isWeapon(type)) {
detail.count4w++ detail.count4w++
itemCount(detail.weapon4, name) itemCount(detail.weapon4, name)
} else if (isBangboo(type)) {
detail.count4b++
itemCount(detail.bang4, name)
} else if (isCharacter(type)) { } else if (isCharacter(type)) {
detail.count4c++ detail.count4c++
itemCount(detail.char4, name) itemCount(detail.char4, name)
} }
} else if (rank === '5') {
detail.ssrPos.push([name, index + 1 - lastSSR, time, key])
lastSSR = index + 1
detail.count5++
detail.countMio = 0
if (isWeapon(type)) {
detail.count5w++
itemCount(detail.weapon5, name)
} else if (isCharacter(type)) {
detail.count5c++
itemCount(detail.char5, name)
}
} }
}) })
detail.date = [dateMin, dateMax] detail.date = [dateMin, dateMax]

View File

@@ -1,15 +1,20 @@
import * as IconComponents from '@element-plus/icons-vue' import * as IconComponents from '@element-plus/icons-vue'
const weaponTypeNames = new Set([ const weaponTypeNames = new Set([
'光锥', '光錐', 'Lichtkegel', 'Light Cone', 'Conos de luz', 'cônes de lumière', '光円錐', '광추', 'Cones de Luz', 'Световые конусы', 'Nón Ánh Sáng' '音擎', 'W-Engines', '音擎'
])
const bangbooTypeNames = new Set([
'邦布', 'Bangboo', '邦布'
]) ])
const characterTypeNames = new Set([ const characterTypeNames = new Set([
'角色', 'Figur', 'Character', 'Personajes', 'Personnages', 'Karakter', 'キャラクター', '캐릭터', 'Personagens', 'Персонажи', 'ตัวละคร', 'Nhân Vật' '代理人', 'Agents', '代理人'
]) ])
const isCharacter = (name) => characterTypeNames.has(name) const isCharacter = (name) => characterTypeNames.has(name)
const isWeapon = (name) => weaponTypeNames.has(name) const isWeapon = (name) => weaponTypeNames.has(name)
const isBangboo = (name) => bangbooTypeNames.has(name)
const IconInstaller = (app) => { const IconInstaller = (app) => {
Object.values(IconComponents).forEach(component => { Object.values(IconComponents).forEach(component => {
@@ -20,5 +25,6 @@ const IconInstaller = (app) => {
export { export {
isWeapon, isWeapon,
isCharacter, isCharacter,
isBangboo,
IconInstaller, IconInstaller,
} }

81
tools/getIdMap.py Normal file
View File

@@ -0,0 +1,81 @@
# pylint: disable=C0116, C0103, C0201
"""Download and process data from the Hakushin API"""
import json
import requests
from opencc import OpenCC
# 初始化 OpenCC 转换器
cc = OpenCC('s2t')
# 获取 JSON 数据
weapon_url = 'https://api.hakush.in/zzz/data/weapon.json'
character_url = 'https://api.hakush.in/zzz/data/character.json'
bangboo_url = 'https://api.hakush.in/zzz/data/bangboo.json'
version_url = 'https://api.hakush.in/zzz/new.json'
# 语言映射配置
language_map = {
"zh-cn": "CHS",
"zh-tw": "CHS", # 简体转繁体
"en-us": "EN",
"ja-jp": "JA",
"ko-kr": "KO"
}
# 类型映射配置
type_map = {
"weapon": {"zh-cn": "音擎", "zh-tw": "音擎", "en-us": "W-Engines", "ja-jp": "音動機", "ko-kr": "W-엔진"},
"character": {"zh-cn": "代理人", "zh-tw": "代理人", "en-us": "Agents",
"ja-jp": "エージェント", "ko-kr": "에이전트"},
"bangboo": {"zh-cn": "邦布", "zh-tw": "邦布", "en-us": "Bangboo",
"ja-jp": "ボンプ", "ko-kr": "「Bangboo」"}
}
def fetch_json(url):
response = requests.get(url, timeout=10)
response.raise_for_status()
return response.json()
def transform_data(data, item_type):
transformed = {lang: {} for lang in language_map.keys()}
for id_, item in data.items():
for lang, key in language_map.items():
name = item[key] if lang != 'zh-tw' else cc.convert(item['CHS'])
transformed[lang][id_] = {
"name": name,
"item_type": type_map[item_type][lang],
"rank_type": item['rank']
}
return transformed
def main():
try:
weapon_data = fetch_json(weapon_url)
character_data = fetch_json(character_url)
bangboo_data = fetch_json(bangboo_url)
version_data = fetch_json(version_url)
transformed_data = {lang: {} for lang in language_map.keys()}
transformed_data["version"] = version_data["version"]
weapon_transformed = transform_data(weapon_data, "weapon")
character_transformed = transform_data(character_data, "character")
bangboo_transformed = transform_data(bangboo_data, "bangboo")
for lang in language_map.keys():
transformed_data[lang].update(weapon_transformed[lang])
transformed_data[lang].update(character_transformed[lang])
transformed_data[lang].update(bangboo_transformed[lang])
with open('./src/idJson.json', 'w', encoding='utf-8') as f:
json.dump(transformed_data, f, ensure_ascii=False, indent=2)
print("Data successfully transformed and saved")
except requests.RequestException as e:
print(f"Error fetching data: {e}")
if __name__ == "__main__":
main()

View File

@@ -4,7 +4,7 @@
"7zip-bin@~5.1.1": "7zip-bin@~5.1.1":
version "5.1.1" version "5.1.1"
resolved "https://registry.npm.taobao.org/7zip-bin/download/7zip-bin-5.1.1.tgz?cache=0&sync_timestamp=1615729238959&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2F7zip-bin%2Fdownload%2F7zip-bin-5.1.1.tgz#9274ec7460652f9c632c59addf24efb1684ef876" resolved "https://registry.npmmirror.com/7zip-bin/download/7zip-bin-5.1.1.tgz?cache=0&sync_timestamp=1615729238959&other_urls=https%3A%2F%2Fregistry.npmmirror.com%2F7zip-bin%2Fdownload%2F7zip-bin-5.1.1.tgz#9274ec7460652f9c632c59addf24efb1684ef876"
integrity sha1-knTsdGBlL5xjLFmt3yTvsWhO+HY= integrity sha1-knTsdGBlL5xjLFmt3yTvsWhO+HY=
"@ampproject/remapping@^2.2.0": "@ampproject/remapping@^2.2.0":
@@ -655,7 +655,7 @@
"@malept/flatpak-bundler@^0.4.0": "@malept/flatpak-bundler@^0.4.0":
version "0.4.0" version "0.4.0"
resolved "https://registry.nlark.com/@malept/flatpak-bundler/download/@malept/flatpak-bundler-0.4.0.tgz#e8a32c30a95d20c2b1bb635cc580981a06389858" resolved "https://registry.npmmirror.com/@malept/flatpak-bundler/download/@malept/flatpak-bundler-0.4.0.tgz#e8a32c30a95d20c2b1bb635cc580981a06389858"
integrity sha1-6KMsMKldIMKxu2NcxYCYGgY4mFg= integrity sha1-6KMsMKldIMKxu2NcxYCYGgY4mFg=
dependencies: dependencies:
debug "^4.1.1" debug "^4.1.1"
@@ -1163,7 +1163,7 @@ ansi-regex@^5.0.0:
ansi-regex@^5.0.1: ansi-regex@^5.0.1:
version "5.0.1" version "5.0.1"
resolved "https://registry.nlark.com/ansi-regex/download/ansi-regex-5.0.1.tgz?cache=0&sync_timestamp=1631634988487&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fansi-regex%2Fdownload%2Fansi-regex-5.0.1.tgz#082cb2c89c9fe8659a311a53bd6a4dc5301db304" resolved "https://registry.npmmirror.com/ansi-regex/download/ansi-regex-5.0.1.tgz?cache=0&sync_timestamp=1631634988487"
integrity sha1-CCyyyJyf6GWaMRpTvWpNxTAdswQ= integrity sha1-CCyyyJyf6GWaMRpTvWpNxTAdswQ=
ansi-regex@^6.0.1: ansi-regex@^6.0.1:
@@ -1294,7 +1294,7 @@ assert-plus@^1.0.0:
astral-regex@^2.0.0: astral-regex@^2.0.0:
version "2.0.0" version "2.0.0"
resolved "https://registry.nlark.com/astral-regex/download/astral-regex-2.0.0.tgz#483143c567aeed4785759c0865786dc77d7d2e31" resolved "https://registry.npmmirror.com/astral-regex/download/astral-regex-2.0.0.tgz#483143c567aeed4785759c0865786dc77d7d2e31"
integrity sha1-SDFDxWeu7UeFdZwIZXhtx319LjE= integrity sha1-SDFDxWeu7UeFdZwIZXhtx319LjE=
async-exit-hook@^2.0.1: async-exit-hook@^2.0.1:
@@ -1321,7 +1321,7 @@ async@^3.2.3:
asynckit@^0.4.0: asynckit@^0.4.0:
version "0.4.0" version "0.4.0"
resolved "https://registry.npm.taobao.org/asynckit/download/asynckit-0.4.0.tgz#c79ed97f7f34cb8f2ba1bc9790bcc366474b4b79" resolved "https://registry.npmmirror.com/asynckit/download/asynckit-0.4.0.tgz#c79ed97f7f34cb8f2ba1bc9790bcc366474b4b79"
integrity sha1-x57Zf380y48robyXkLzDZkdLS3k= integrity sha1-x57Zf380y48robyXkLzDZkdLS3k=
at-least-node@^1.0.0: at-least-node@^1.0.0:
@@ -1494,12 +1494,12 @@ bser@2.1.1:
buffer-alloc-unsafe@^1.1.0: buffer-alloc-unsafe@^1.1.0:
version "1.1.0" version "1.1.0"
resolved "https://registry.nlark.com/buffer-alloc-unsafe/download/buffer-alloc-unsafe-1.1.0.tgz#bd7dc26ae2972d0eda253be061dba992349c19f0" resolved "https://registry.npmmirror.com/buffer-alloc-unsafe/download/buffer-alloc-unsafe-1.1.0.tgz#bd7dc26ae2972d0eda253be061dba992349c19f0"
integrity sha1-vX3CauKXLQ7aJTvgYdupkjScGfA= integrity sha1-vX3CauKXLQ7aJTvgYdupkjScGfA=
buffer-alloc@^1.2.0: buffer-alloc@^1.2.0:
version "1.2.0" version "1.2.0"
resolved "https://registry.npm.taobao.org/buffer-alloc/download/buffer-alloc-1.2.0.tgz#890dd90d923a873e08e10e5fd51a57e5b7cce0ec" resolved "https://registry.npmmirror.com/buffer-alloc/download/buffer-alloc-1.2.0.tgz#890dd90d923a873e08e10e5fd51a57e5b7cce0ec"
integrity sha1-iQ3ZDZI6hz4I4Q5f1RpX5bfM4Ow= integrity sha1-iQ3ZDZI6hz4I4Q5f1RpX5bfM4Ow=
dependencies: dependencies:
buffer-alloc-unsafe "^1.1.0" buffer-alloc-unsafe "^1.1.0"
@@ -1517,7 +1517,7 @@ buffer-equal@1.0.0:
buffer-fill@^1.0.0: buffer-fill@^1.0.0:
version "1.0.0" version "1.0.0"
resolved "https://registry.npm.taobao.org/buffer-fill/download/buffer-fill-1.0.0.tgz#f8f78b76789888ef39f205cd637f68e702122b2c" resolved "https://registry.npmmirror.com/buffer-fill/download/buffer-fill-1.0.0.tgz#f8f78b76789888ef39f205cd637f68e702122b2c"
integrity sha1-+PeLdniYiO858gXNY39o5wISKyw= integrity sha1-+PeLdniYiO858gXNY39o5wISKyw=
buffer-from@^1.0.0: buffer-from@^1.0.0:
@@ -1795,7 +1795,7 @@ colors@1.0.3:
combined-stream@^1.0.8: combined-stream@^1.0.8:
version "1.0.8" version "1.0.8"
resolved "https://registry.nlark.com/combined-stream/download/combined-stream-1.0.8.tgz#c3d45a8b34fd730631a110a8a2520682b31d5a7f" resolved "https://registry.npmmirror.com/combined-stream/download/combined-stream-1.0.8.tgz#c3d45a8b34fd730631a110a8a2520682b31d5a7f"
integrity sha1-w9RaizT9cwYxoRCoolIGgrMdWn8= integrity sha1-w9RaizT9cwYxoRCoolIGgrMdWn8=
dependencies: dependencies:
delayed-stream "~1.0.0" delayed-stream "~1.0.0"
@@ -1819,7 +1819,7 @@ commondir@^1.0.1:
compare-version@^0.1.2: compare-version@^0.1.2:
version "0.1.2" version "0.1.2"
resolved "https://registry.npm.taobao.org/compare-version/download/compare-version-0.1.2.tgz#0162ec2d9351f5ddd59a9202cba935366a725080" resolved "https://registry.npmmirror.com/compare-version/download/compare-version-0.1.2.tgz#0162ec2d9351f5ddd59a9202cba935366a725080"
integrity sha1-AWLsLZNR9d3VmpICy6k1NmpyUIA= integrity sha1-AWLsLZNR9d3VmpICy6k1NmpyUIA=
concat-map@0.0.1: concat-map@0.0.1:
@@ -2008,7 +2008,7 @@ del@^6.0.0:
delayed-stream@~1.0.0: delayed-stream@~1.0.0:
version "1.0.0" version "1.0.0"
resolved "https://registry.nlark.com/delayed-stream/download/delayed-stream-1.0.0.tgz#df3ae199acadfb7d440aaae0b29e2272b24ec619" resolved "https://registry.npmmirror.com/delayed-stream/download/delayed-stream-1.0.0.tgz#df3ae199acadfb7d440aaae0b29e2272b24ec619"
integrity sha1-3zrhmayt+31ECqrgsp4icrJOxhk= integrity sha1-3zrhmayt+31ECqrgsp4icrJOxhk=
detect-newline@^3.0.0: detect-newline@^3.0.0:
@@ -2592,7 +2592,7 @@ foreground-child@^3.1.0:
form-data@^4.0.0: form-data@^4.0.0:
version "4.0.0" version "4.0.0"
resolved "https://registry.npm.taobao.org/form-data/download/form-data-4.0.0.tgz#93919daeaf361ee529584b9b31664dc12c9fa452" resolved "https://registry.npmmirror.com/form-data/download/form-data-4.0.0.tgz#93919daeaf361ee529584b9b31664dc12c9fa452"
integrity sha1-k5Gdrq82HuUpWEubMWZNwSyfpFI= integrity sha1-k5Gdrq82HuUpWEubMWZNwSyfpFI=
dependencies: dependencies:
asynckit "^0.4.0" asynckit "^0.4.0"
@@ -2694,7 +2694,7 @@ get-stream@^5.1.0:
get-stream@^6.0.0, get-stream@^6.0.1: get-stream@^6.0.0, get-stream@^6.0.1:
version "6.0.1" version "6.0.1"
resolved "https://registry.nlark.com/get-stream/download/get-stream-6.0.1.tgz#a262d8eef67aced57c2852ad6167526a43cbf7b7" resolved "https://registry.npmmirror.com/get-stream/download/get-stream-6.0.1.tgz#a262d8eef67aced57c2852ad6167526a43cbf7b7"
integrity sha1-omLY7vZ6ztV8KFKtYWdSakPL97c= integrity sha1-omLY7vZ6ztV8KFKtYWdSakPL97c=
glob-parent@^5.1.0, glob-parent@^5.1.2, glob-parent@~5.1.2: glob-parent@^5.1.0, glob-parent@^5.1.2, glob-parent@~5.1.2:
@@ -2748,7 +2748,7 @@ glob@^7.1.4:
global-agent@^3.0.0: global-agent@^3.0.0:
version "3.0.0" version "3.0.0"
resolved "https://registry.nlark.com/global-agent/download/global-agent-3.0.0.tgz?cache=0&sync_timestamp=1627082437079&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fglobal-agent%2Fdownload%2Fglobal-agent-3.0.0.tgz#ae7cd31bd3583b93c5a16437a1afe27cc33a1ab6" resolved "https://registry.npmmirror.com/global-agent/download/global-agent-3.0.0.tgz?cache=0&sync_timestamp=1627082437079"
integrity sha1-rnzTG9NYO5PFoWQ3oa/ifMM6GrY= integrity sha1-rnzTG9NYO5PFoWQ3oa/ifMM6GrY=
dependencies: dependencies:
boolean "^3.0.1" boolean "^3.0.1"
@@ -3102,7 +3102,7 @@ isarray@~1.0.0:
isbinaryfile@^3.0.2: isbinaryfile@^3.0.2:
version "3.0.3" version "3.0.3"
resolved "https://registry.nlark.com/isbinaryfile/download/isbinaryfile-3.0.3.tgz#5d6def3edebf6e8ca8cae9c30183a804b5f8be80" resolved "https://registry.npmmirror.com/isbinaryfile/download/isbinaryfile-3.0.3.tgz#5d6def3edebf6e8ca8cae9c30183a804b5f8be80"
integrity sha1-XW3vPt6/boyoyunDAYOoBLX4voA= integrity sha1-XW3vPt6/boyoyunDAYOoBLX4voA=
dependencies: dependencies:
buffer-alloc "^1.2.0" buffer-alloc "^1.2.0"
@@ -3603,7 +3603,7 @@ json5@^2.2.2:
jsonc-parser@^3.0.0: jsonc-parser@^3.0.0:
version "3.0.0" version "3.0.0"
resolved "https://registry.nlark.com/jsonc-parser/download/jsonc-parser-3.0.0.tgz#abdd785701c7e7eaca8a9ec8cf070ca51a745a22" resolved "https://registry.npmmirror.com/jsonc-parser/download/jsonc-parser-3.0.0.tgz#abdd785701c7e7eaca8a9ec8cf070ca51a745a22"
integrity sha1-q914VwHH5+rKip7IzwcMpRp0WiI= integrity sha1-q914VwHH5+rKip7IzwcMpRp0WiI=
jsonfile@^4.0.0: jsonfile@^4.0.0:
@@ -3615,7 +3615,7 @@ jsonfile@^4.0.0:
jsonfile@^6.0.1: jsonfile@^6.0.1:
version "6.1.0" version "6.1.0"
resolved "https://registry.nlark.com/jsonfile/download/jsonfile-6.1.0.tgz#bc55b2634793c679ec6403094eb13698a6ec0aae" resolved "https://registry.npmmirror.com/jsonfile/download/jsonfile-6.1.0.tgz#bc55b2634793c679ec6403094eb13698a6ec0aae"
integrity sha1-vFWyY0eTxnnsZAMJTrE2mKbsCq4= integrity sha1-vFWyY0eTxnnsZAMJTrE2mKbsCq4=
dependencies: dependencies:
universalify "^2.0.0" universalify "^2.0.0"
@@ -3660,7 +3660,7 @@ lazy-val@^1.0.4:
lazy-val@^1.0.5: lazy-val@^1.0.5:
version "1.0.5" version "1.0.5"
resolved "https://registry.nlark.com/lazy-val/download/lazy-val-1.0.5.tgz?cache=0&sync_timestamp=1620971390189&other_urls=https%3A%2F%2Fregistry.nlark.com%2Flazy-val%2Fdownload%2Flazy-val-1.0.5.tgz#6cf3b9f5bc31cee7ee3e369c0832b7583dcd923d" resolved "https://registry.npmmirror.com/lazy-val/download/lazy-val-1.0.5.tgz?cache=0&sync_timestamp=1620971390189"
integrity sha1-bPO59bwxzufuPjacCDK3WD3Nkj0= integrity sha1-bPO59bwxzufuPjacCDK3WD3Nkj0=
leven@^3.1.0: leven@^3.1.0:
@@ -4275,7 +4275,7 @@ path-parse@^1.0.6:
path-parse@^1.0.7: path-parse@^1.0.7:
version "1.0.7" version "1.0.7"
resolved "https://registry.nlark.com/path-parse/download/path-parse-1.0.7.tgz#fbc114b60ca42b30d9daf5858e4bd68bbedb6735" resolved "https://registry.npmmirror.com/path-parse/download/path-parse-1.0.7.tgz#fbc114b60ca42b30d9daf5858e4bd68bbedb6735"
integrity sha1-+8EUtgykKzDZ2vWFjkvWi77bZzU= integrity sha1-+8EUtgykKzDZ2vWFjkvWi77bZzU=
path-scurry@^1.10.1: path-scurry@^1.10.1:
@@ -4339,7 +4339,7 @@ plist@^3.0.1:
plist@^3.0.4: plist@^3.0.4:
version "3.0.4" version "3.0.4"
resolved "https://registry.nlark.com/plist/download/plist-3.0.4.tgz?cache=0&sync_timestamp=1630103302758&other_urls=https%3A%2F%2Fregistry.nlark.com%2Fplist%2Fdownload%2Fplist-3.0.4.tgz#a62df837e3aed2bb3b735899d510c4f186019cbe" resolved "https://registry.npmmirror.com/plist/download/plist-3.0.4.tgz?cache=0&sync_timestamp=1630103302758"
integrity sha1-pi34N+Ou0rs7c1iZ1RDE8YYBnL4= integrity sha1-pi34N+Ou0rs7c1iZ1RDE8YYBnL4=
dependencies: dependencies:
base64-js "^1.5.1" base64-js "^1.5.1"
@@ -4479,7 +4479,7 @@ react-is@^18.0.0:
read-config-file@6.2.0: read-config-file@6.2.0:
version "6.2.0" version "6.2.0"
resolved "https://registry.nlark.com/read-config-file/download/read-config-file-6.2.0.tgz#71536072330bcd62ba814f91458b12add9fc7ade" resolved "https://registry.npmmirror.com/read-config-file/download/read-config-file-6.2.0.tgz#71536072330bcd62ba814f91458b12add9fc7ade"
integrity sha1-cVNgcjMLzWK6gU+RRYsSrdn8et4= integrity sha1-cVNgcjMLzWK6gU+RRYsSrdn8et4=
dependencies: dependencies:
dotenv "^9.0.2" dotenv "^9.0.2"
@@ -4749,7 +4749,7 @@ slash@^3.0.0:
slice-ansi@^3.0.0: slice-ansi@^3.0.0:
version "3.0.0" version "3.0.0"
resolved "https://registry.npm.taobao.org/slice-ansi/download/slice-ansi-3.0.0.tgz?cache=0&sync_timestamp=1618554984144&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fslice-ansi%2Fdownload%2Fslice-ansi-3.0.0.tgz#31ddc10930a1b7e0b67b08c96c2f49b77a789787" resolved "https://registry.npmmirror.com/slice-ansi/download/slice-ansi-3.0.0.tgz?cache=0&sync_timestamp=1618554984144&other_urls=https%3A%2F%2Fregistry.npmmirror.com%2Fslice-ansi%2Fdownload%2Fslice-ansi-3.0.0.tgz#31ddc10930a1b7e0b67b08c96c2f49b77a789787"
integrity sha1-Md3BCTCht+C2ewjJbC9Jt3p4l4c= integrity sha1-Md3BCTCht+C2ewjJbC9Jt3p4l4c=
dependencies: dependencies:
ansi-styles "^4.0.0" ansi-styles "^4.0.0"
@@ -5000,7 +5000,7 @@ tar@^6.1.11:
temp-file@^3.4.0: temp-file@^3.4.0:
version "3.4.0" version "3.4.0"
resolved "https://registry.nlark.com/temp-file/download/temp-file-3.4.0.tgz#766ea28911c683996c248ef1a20eea04d51652c7" resolved "https://registry.npmmirror.com/temp-file/download/temp-file-3.4.0.tgz#766ea28911c683996c248ef1a20eea04d51652c7"
integrity sha1-dm6iiRHGg5lsJI7xog7qBNUWUsc= integrity sha1-dm6iiRHGg5lsJI7xog7qBNUWUsc=
dependencies: dependencies:
async-exit-hook "^2.0.1" async-exit-hook "^2.0.1"
@@ -5024,7 +5024,7 @@ tmp-promise@^3.0.2:
tmp@^0.2.0: tmp@^0.2.0:
version "0.2.1" version "0.2.1"
resolved "https://registry.npm.taobao.org/tmp/download/tmp-0.2.1.tgz#8457fc3037dcf4719c251367a1af6500ee1ccf14" resolved "https://registry.npmmirror.com/tmp/download/tmp-0.2.1.tgz#8457fc3037dcf4719c251367a1af6500ee1ccf14"
integrity sha1-hFf8MDfc9HGcJRNnoa9lAO4czxQ= integrity sha1-hFf8MDfc9HGcJRNnoa9lAO4czxQ=
dependencies: dependencies:
rimraf "^3.0.0" rimraf "^3.0.0"
@@ -5095,7 +5095,7 @@ universalify@^0.1.0:
universalify@^2.0.0: universalify@^2.0.0:
version "2.0.0" version "2.0.0"
resolved "https://registry.npm.taobao.org/universalify/download/universalify-2.0.0.tgz?cache=0&sync_timestamp=1603179967633&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Funiversalify%2Fdownload%2Funiversalify-2.0.0.tgz#75a4984efedc4b08975c5aeb73f530d02df25717" resolved "https://registry.npmmirror.com/universalify/download/universalify-2.0.0.tgz?cache=0&sync_timestamp=1603179967633&other_urls=https%3A%2F%2Fregistry.npmmirror.com%2Funiversalify%2Fdownload%2Funiversalify-2.0.0.tgz#75a4984efedc4b08975c5aeb73f530d02df25717"
integrity sha1-daSYTv7cSwiXXFrrc/Uw0C3yVxc= integrity sha1-daSYTv7cSwiXXFrrc/Uw0C3yVxc=
update-browserslist-db@^1.0.10: update-browserslist-db@^1.0.10:
@@ -5205,10 +5205,10 @@ window-size@^1.1.1:
define-property "^1.0.0" define-property "^1.0.0"
is-number "^3.0.0" is-number "^3.0.0"
winreg@^1.2.4: winreg@1.2.4:
version "1.2.4" version "1.2.4"
resolved "https://registry.yarnpkg.com/winreg/-/winreg-1.2.4.tgz#ba065629b7a925130e15779108cf540990e98d1b" resolved "https://registry.yarnpkg.com/winreg/-/winreg-1.2.4.tgz#ba065629b7a925130e15779108cf540990e98d1b"
integrity sha1-ugZWKbepJRMOFXeRCM9UCZDpjRs= integrity sha512-IHpzORub7kYlb8A43Iig3reOvlcBJGX9gZ0WycHhghHtA65X0LYnMRuJs+aH1abVnMJztQkvQNlltnbPi5aGIA==
"wrap-ansi-cjs@npm:wrap-ansi@^7.0.0": "wrap-ansi-cjs@npm:wrap-ansi@^7.0.0":
version "7.0.0" version "7.0.0"