mirror of
https://git.um-react.app/um/um-react.git
synced 2025-11-28 19:43:02 +00:00
Compare commits
8 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
602d6865f5 | ||
|
|
8d4194772e | ||
|
|
1ef1db30ab | ||
|
|
80fc595833 | ||
|
|
be9a1b6724 | ||
|
|
6cccb722ce | ||
|
|
2f9cfaa763 | ||
|
|
5d7f5b76ef |
11
README.MD
11
README.MD
@@ -73,12 +73,21 @@
|
|||||||
|
|
||||||
满足上述条件后发起 Pull Request,仓库管理员审阅后将合并到主分支。
|
满足上述条件后发起 Pull Request,仓库管理员审阅后将合并到主分支。
|
||||||
|
|
||||||
|
## 相关项目
|
||||||
|
|
||||||
|
- [Unlock Music (Web)](https://git.unlock-music.dev/um/web) - 原始项目
|
||||||
|
- [Unlock Music (Cli)](https://git.unlock-music.dev/um/cli) - 命令行批量处理版
|
||||||
|
- [um-react (Electron 前端)](https://github.com/CarlGao4/um-react-electron) - 使用 Electron 框架封装的本地可执行文件。
|
||||||
|
- [GitHub 下载](https://github.com/CarlGao4/um-react-electron/releases/latest) | [仓库镜像](https://git.unlock-music.dev/CarlGao4/um-react-electron)
|
||||||
|
|
||||||
|
有新的项目提交?欢迎[提交 issue][project-issues],请带上项目名称和链接。
|
||||||
|
|
||||||
## TODO
|
## TODO
|
||||||
|
|
||||||
- 待定
|
- 待定
|
||||||
- [ ] 各类算法 [追踪 `crypto` 标签](https://git.unlock-music.dev/um/um-react/issues?labels=67)
|
- [ ] 各类算法 [追踪 `crypto` 标签](https://git.unlock-music.dev/um/um-react/issues?labels=67)
|
||||||
- [ ] #7 简易元数据编辑器
|
|
||||||
- 完成
|
- 完成
|
||||||
|
- [x] #7 ~~简易元数据编辑器~~ 放弃
|
||||||
- [x] #8 ~~添加单元测试~~ 框架加上了,以后慢慢添加更多测试即可。
|
- [x] #8 ~~添加单元测试~~ 框架加上了,以后慢慢添加更多测试即可。
|
||||||
- [x] #2 解密内容探测 (解密过程)
|
- [x] #2 解密内容探测 (解密过程)
|
||||||
- [x] #6 文件拖放 (利用 `react-dropzone`?)
|
- [x] #6 文件拖放 (利用 `react-dropzone`?)
|
||||||
|
|||||||
@@ -63,6 +63,8 @@
|
|||||||
|
|
||||||
如果希望不破坏系统完整性,你可以考虑使用模拟器。
|
如果希望不破坏系统完整性,你可以考虑使用模拟器。
|
||||||
|
|
||||||
|
※ **注意**:根据应用厂商的风控策略,使用模拟器登录的账号**有可能会被封锁**;使用前请自行评估风险。
|
||||||
|
|
||||||
目前常见的带有 root 特权支持的的安卓模拟器方案,分别是雷电模拟器(※ 官方版有内置广告)和微软在 Windows 11 开始支援的适用于 Android™ 的 Windows 子系统 (WSA)。
|
目前常见的带有 root 特权支持的的安卓模拟器方案,分别是雷电模拟器(※ 官方版有内置广告)和微软在 Windows 11 开始支援的适用于 Android™ 的 Windows 子系统 (WSA)。
|
||||||
|
|
||||||
- WSA 可以参考 [MagiskOnWSALocal](https://github.com/LSPosed/MagiskOnWSALocal) 的说明操作。
|
- WSA 可以参考 [MagiskOnWSALocal](https://github.com/LSPosed/MagiskOnWSALocal) 的说明操作。
|
||||||
|
|||||||
@@ -1,11 +1,11 @@
|
|||||||
{
|
{
|
||||||
"name": "um-react",
|
"name": "um-react",
|
||||||
"private": true,
|
"private": true,
|
||||||
"version": "0.2.4",
|
"version": "0.2.6",
|
||||||
"type": "module",
|
"type": "module",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"start": "vite",
|
"start": "vite",
|
||||||
"build": "tsc -p tsconfig.prod.json && vite build",
|
"build": "tsc -p tsconfig.prod.json && vite build && node scripts/write-version.mjs",
|
||||||
"lint": "eslint src --ext ts,tsx --report-unused-disable-directives --max-warnings 0",
|
"lint": "eslint src --ext ts,tsx --report-unused-disable-directives --max-warnings 0",
|
||||||
"format": "prettier -w .",
|
"format": "prettier -w .",
|
||||||
"test": "vitest run",
|
"test": "vitest run",
|
||||||
|
|||||||
14
scripts/write-version.mjs
Normal file
14
scripts/write-version.mjs
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
/* eslint-env node */
|
||||||
|
import { readFileSync, writeFileSync } from 'node:fs';
|
||||||
|
import { fileURLToPath } from 'node:url';
|
||||||
|
import { dirname } from 'node:path';
|
||||||
|
import { execSync } from 'node:child_process';
|
||||||
|
|
||||||
|
const __filename = fileURLToPath(import.meta.url);
|
||||||
|
const __dirname = dirname(__filename);
|
||||||
|
|
||||||
|
const commitHash = execSync('git rev-parse --short HEAD').toString('utf-8').trim();
|
||||||
|
|
||||||
|
const pkgJson = JSON.parse(readFileSync(__dirname + '/../package.json', 'utf-8'));
|
||||||
|
const pkgVer = `${pkgJson.version ?? 'unknown'}-${commitHash ?? 'unknown'}` + '\n';
|
||||||
|
writeFileSync(__dirname + '/../dist/version.txt', pkgVer, 'utf-8');
|
||||||
@@ -10,6 +10,7 @@ export const workerParseMusicExMediaName = async ({ id, blobURI }: FetchMusicExN
|
|||||||
const blob = await timedLogger(`${label}/fetch-src`, async () =>
|
const blob = await timedLogger(`${label}/fetch-src`, async () =>
|
||||||
fetch(blobURI, { headers: { Range: 'bytes=-1024' } }).then((r) => r.blob()),
|
fetch(blobURI, { headers: { Range: 'bytes=-1024' } }).then((r) => r.blob()),
|
||||||
);
|
);
|
||||||
|
|
||||||
const buffer = await timedLogger(`${label}/read-src`, async () => {
|
const buffer = await timedLogger(`${label}/read-src`, async () => {
|
||||||
// Firefox: the range header does not work...?
|
// Firefox: the range header does not work...?
|
||||||
const blobBuffer = await blob.arrayBuffer();
|
const blobBuffer = await blob.arrayBuffer();
|
||||||
@@ -18,10 +19,12 @@ export const workerParseMusicExMediaName = async ({ id, blobURI }: FetchMusicExN
|
|||||||
}
|
}
|
||||||
return blobBuffer;
|
return blobBuffer;
|
||||||
});
|
});
|
||||||
|
|
||||||
const parsed = makeQMCv2FooterParser(parakeet).parse(buffer);
|
const parsed = makeQMCv2FooterParser(parakeet).parse(buffer);
|
||||||
if (parsed.state === FooterParserState.OK) {
|
if (parsed.state === FooterParserState.OK) {
|
||||||
return parsed.mediaName;
|
return parsed.mediaName;
|
||||||
}
|
}
|
||||||
return '# N/A';
|
|
||||||
|
return null;
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
import { Img, ListItem, Text, UnorderedList } from '@chakra-ui/react';
|
import { Alert, AlertIcon, Code, Container, Flex, Img, ListItem, Text, UnorderedList } from '@chakra-ui/react';
|
||||||
import { ExtLink } from '~/components/ExtLink';
|
import { ExtLink } from '~/components/ExtLink';
|
||||||
import { Header4 } from '~/components/HelpText/Header4';
|
import { Header4 } from '~/components/HelpText/Header4';
|
||||||
import { VQuote } from '~/components/HelpText/VQuote';
|
import { VQuote } from '~/components/HelpText/VQuote';
|
||||||
@@ -57,6 +57,19 @@ export function OtherFAQ() {
|
|||||||
</ExtLink>
|
</ExtLink>
|
||||||
。
|
。
|
||||||
</Text>
|
</Text>
|
||||||
|
|
||||||
|
<Container p={2}>
|
||||||
|
<Alert status="warning" borderRadius={5}>
|
||||||
|
<AlertIcon />
|
||||||
|
<Flex flexDir="column">
|
||||||
|
<Text>
|
||||||
|
<strong>注意</strong>:根据应用厂商的风控策略,使用模拟器登录的账号<strong>有可能会被封锁</strong>
|
||||||
|
{';使用前请自行评估风险。'}
|
||||||
|
</Text>
|
||||||
|
</Flex>
|
||||||
|
</Alert>
|
||||||
|
</Container>
|
||||||
|
|
||||||
<UnorderedList>
|
<UnorderedList>
|
||||||
<ListItem>
|
<ListItem>
|
||||||
<Text>
|
<Text>
|
||||||
@@ -73,6 +86,20 @@ export function OtherFAQ() {
|
|||||||
</ListItem>
|
</ListItem>
|
||||||
</UnorderedList>
|
</UnorderedList>
|
||||||
|
|
||||||
|
<Header4>相关项目</Header4>
|
||||||
|
<UnorderedList>
|
||||||
|
<ListItem>
|
||||||
|
<Text>
|
||||||
|
<ExtLink href="https://github.com/CarlGao4/um-react-electron">
|
||||||
|
<strong>
|
||||||
|
<Code>um-react-electron</Code>
|
||||||
|
</strong>
|
||||||
|
</ExtLink>
|
||||||
|
: 利用 Electron 框架打包的本地版,提供适用于 Windows、Linux 和 Mac 平台的可执行文件。
|
||||||
|
</Text>
|
||||||
|
</ListItem>
|
||||||
|
</UnorderedList>
|
||||||
|
|
||||||
<Header4>有更多问题?</Header4>
|
<Header4>有更多问题?</Header4>
|
||||||
<Text>
|
<Text>
|
||||||
{'欢迎进入 '}
|
{'欢迎进入 '}
|
||||||
|
|||||||
Reference in New Issue
Block a user