mirror of
https://gitee.com/spark-store-project/spark-store
synced 2025-12-15 21:32:05 +08:00
Compare commits
149 Commits
4.1.1
...
4.2.3test3
| Author | SHA1 | Date | |
|---|---|---|---|
| 3b83b335be | |||
| 1f0a0e48ff | |||
| 432215e040 | |||
| 1a65386c6b | |||
|
|
757dced302 | ||
|
|
854caafd6b | ||
| 1332107642 | |||
|
|
4825417de8 | ||
| 0001df153b | |||
| f88b38dd39 | |||
| 3f2404ec1c | |||
| 5b822194fa | |||
| 33ea9ee065 | |||
| d742e85332 | |||
|
|
8dfb1fbe2f | ||
| 4114b51d87 | |||
|
|
deec70f14b | ||
| 80adfd5dc1 | |||
| e81c846432 | |||
| 03d60d74f1 | |||
| 4f2c5f1bdc | |||
|
|
da03261cbb | ||
|
|
48d551424a | ||
|
|
ab6c3d37d2 | ||
| de2db98324 | |||
|
|
66d1aacbbe | ||
| 57f1b69663 | |||
|
|
cb093dcc2b | ||
| eaf268a10d | |||
|
|
1074e941a6 | ||
|
|
05cb318737 | ||
| 17c152ce8b | |||
|
|
9275074e10 | ||
| e69eaa6296 | |||
| 35bc1efbad | |||
| 9420959023 | |||
| 7a16b5c52f | |||
| 24519e6560 | |||
| 2104b99208 | |||
|
|
cf549c540d | ||
|
|
4b40e3caca | ||
| 1a89c2a1a6 | |||
| b1fd1a3c3c | |||
| 50e895938b | |||
| 18d2b1edbb | |||
|
|
f91ee56d97 | ||
| 1266b16d83 | |||
| 4359a9c58d | |||
| c243a30dec | |||
| f629dca03c | |||
| f2e1219a83 | |||
| e2f27c7746 | |||
| 72ba481180 | |||
| 8d41966d67 | |||
| f2a4ce3b25 | |||
| 0b2290344b | |||
| a7cb44348d | |||
| 384d4b300d | |||
| 19a1ba4289 | |||
| c160f4105d | |||
| e4a3a974b5 | |||
| eb38f2af05 | |||
| 7163f8ee80 | |||
| a934373f1e | |||
| ce6ded25f2 | |||
| f707fef65b | |||
| 721e6580c9 | |||
| e20572b28d | |||
| 05a6af8f86 | |||
| d4e84344c3 | |||
| f856060d3d | |||
| 49829f8d3c | |||
| 4cd3ca56e0 | |||
| 0538777ceb | |||
| d3b303c66c | |||
| 98c4e8a699 | |||
| 69b7cbe472 | |||
| 539a21ccec | |||
| eb40a32cc2 | |||
| 440b7ea88d | |||
| 6bdc1ee51c | |||
| ecfa9a166d | |||
| 199700495c | |||
| 0bafab7f94 | |||
| dd4deff19d | |||
| 8b88573283 | |||
| 2717cf695c | |||
| 385803754f | |||
| 8ba377cf0b | |||
| c21d4dac96 | |||
| a85200338c | |||
| 5d34dd6413 | |||
| bd3daeba75 | |||
|
|
8b2a61e4b2 | ||
| 116f14845e | |||
| 77bf544c59 | |||
| f809d7c15d | |||
| 1f7f3edbba | |||
| 90f6b6a574 | |||
| 3e51ce8381 | |||
| b7df4a5801 | |||
| 980e4a17d9 | |||
| d5248f4c1b | |||
|
|
c169622806 | ||
|
|
cc54014b29 | ||
|
|
c636e0882b | ||
|
|
4120af7e24 | ||
| 09a5789c26 | |||
| fc658f324d | |||
| 2861b0573b | |||
| 2ab4ebc0e3 | |||
| e344b16aa0 | |||
| 30b65350ca | |||
| 0db8c8b1bb | |||
| 9e25584bdc | |||
| ee6d6f145f | |||
| 347f6e918f | |||
| 0fcbd15ab4 | |||
| 6bdac50059 | |||
| f45b2af260 | |||
| d744c1d978 | |||
| 0544761094 | |||
| e645c5e526 | |||
| d75fdd9f80 | |||
| 30f74db0dc | |||
| 2d0069ce18 | |||
| 48b91d1887 | |||
| 32cb3d7453 | |||
|
|
ba3071d62b | ||
|
|
dca80a3fbb | ||
| f99c0839dd | |||
| 1b9c925183 | |||
| 09221bc2e9 | |||
| 98da0c22fc | |||
| cadbb351fb | |||
| 2de237ce83 | |||
| 511fbaa0b0 | |||
| a6d85b6ade | |||
| 5889ac3045 | |||
| c1ba14bbd0 | |||
| 7bdccc7783 | |||
|
|
3a54cba3e5 | ||
| 79463246fb | |||
| cc8ff5eff2 | |||
| 613327b2cc | |||
| 8b31db843c | |||
| fd4fdbe970 | |||
| 89a3ab0b4c | |||
| 0179c2f04f |
@@ -2,6 +2,8 @@
|
|||||||
|
|
||||||
参数只有一个Url,该url应当遵循这种格式:`spk://<任意合法字符>/web分类/包名`
|
参数只有一个Url,该url应当遵循这种格式:`spk://<任意合法字符>/web分类/包名`
|
||||||
|
|
||||||
|
目前第一字段不进行处理,以后可能会对此识别。在目前阶段,这个字段可以填写任意合法字符
|
||||||
|
|
||||||
例如:
|
例如:
|
||||||
|
|
||||||
[spk://abcdefg/games/store.spark-app.hmcl](spk://abcdefg/games/store.spark-app.hmcl)
|
[spk://abcdefg/games/store.spark-app.hmcl](spk://abcdefg/games/store.spark-app.hmcl)
|
||||||
@@ -11,15 +13,15 @@
|
|||||||
|
|
||||||
| 分类名称 | web分类 |
|
| 分类名称 | web分类 |
|
||||||
| -------- | -------------- |
|
| -------- | -------------- |
|
||||||
| 网络应用 | network |
|
| 网络 | network |
|
||||||
| 社交沟通 | chat |
|
| 社交 | chat |
|
||||||
| 音乐欣赏 | music |
|
| 音乐 | music |
|
||||||
| 视频播放 | video |
|
| 视频 | video |
|
||||||
| 图形图像 | graphics |
|
| 图像 | image_graphics |
|
||||||
| 游戏娱乐 | games |
|
| 游戏 | games |
|
||||||
| 办公学习 | office |
|
| 办公 | office |
|
||||||
| 阅读翻译 | reading |
|
| 阅读 | reading |
|
||||||
| 编程开发 | development |
|
| 开发 | development |
|
||||||
| 系统工具 | tools |
|
| 工具 | tools |
|
||||||
| 主题美化 | beautify |
|
| 主题 | themes |
|
||||||
| 其他应用 | others |
|
| 其他 | others |
|
||||||
|
|||||||
7
DOCS/内网部署.md
Normal file
7
DOCS/内网部署.md
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
需要修改的内容:商店默认源位置,aptss获取apt-fast.conf和sparkstore.list的地址,ssinstall做安装检查的源位置
|
||||||
|
|
||||||
|
服务器使用update.sh进行同步。
|
||||||
|
|
||||||
|
为方便使用(其实是早期屎山使然),请将仓库放置于 `/home/ftp/spark-store`
|
||||||
|
|
||||||
|
仓库管理相关代码请移步 [这里](https://gitee.com/deepin-community-store/repo_auto_update_script),update.sh请联系 @shenmo 获取
|
||||||
73
README.en.md
73
README.en.md
@@ -1,73 +0,0 @@
|
|||||||
# Spark App Store
|
|
||||||
[](https://gitee.com/deepin-community-store/spark-store/stargazers) [](https://gitee.com/deepin-community-store/spark-store/members)
|
|
||||||
|
|
||||||
Spark Store aims to collect Linux apps for the convieniece of Linux new comers
|
|
||||||
|
|
||||||
The collecting process needs everyone's help
|
|
||||||
|
|
||||||
We set up this APP Store and collect APPs/tools that everyone need widely. Also we pack Windows apps with wine.
|
|
||||||
|
|
||||||
All packages will be shared in our repository for users to get freely.
|
|
||||||
|
|
||||||
Distrobution supported:Deepin 20 ; Ubuntu 22.04 LTS / Ubuntu 20.04 LTS(May stop support in the future) ; UniontechOS Home 21
|
|
||||||
|
|
||||||
*About OpenKylin and deepin 23*
|
|
||||||
|
|
||||||
The adaptation work is scheduled after their official release.
|
|
||||||
|
|
||||||
You can track our Issue resoving progress here https://gitee.com/deepin-community-store/spark-store/board
|
|
||||||
|
|
||||||
|
|
||||||
We hope people who see here can also join our team,development help or submit applications are welcomed
|
|
||||||
|
|
||||||
If you want to submit an APP to share with others,Please [Click here](https://upload.deepinos.org/index)
|
|
||||||
|
|
||||||
|
|
||||||
## 🙌 A simple start
|
|
||||||
|
|
||||||
If you simply want to install the Spark Store,just enter the [Release] page, find the version you want and install.
|
|
||||||
|
|
||||||
If you are using Debian11/Ubuntu 20.04, you will need extra dependency package. Available [here](https://code.gitlink.org.cn/shenmo7192/spark-store-dependencies/raw/branch/master/spark-store-dependencies-kylin.zip)
|
|
||||||
|
|
||||||
---
|
|
||||||
#### Compile and developement
|
|
||||||
|
|
||||||
|
|
||||||
For Deepin V20/UOS 21/ Debian 11
|
|
||||||
|
|
||||||
```shell
|
|
||||||
sudo apt install git qt5-default debhelper pkg-config qtchooser libqt5core5a libqt5gui5 libqt5widgets5 libqt5network5 libqt5concurrent5 libdtkcore-dev libdtkgui-dev libdtkwidget-dev qttools5-private-dev libnotify-dev qtwebengine5-dev
|
|
||||||
|
|
||||||
```
|
|
||||||
|
|
||||||
Ubuntu 22.04
|
|
||||||
```shell
|
|
||||||
sudo apt install git qtbase5-dev debhelper pkg-config qtchooser libqt5core5a libqt5gui5 libqt5widgets5 libqt5network5 libqt5concurrent5 libdtkcore-dev libdtkgui-dev libdtkwidget-dev qttools5-private-dev libnotify-dev qtwebengine5-dev
|
|
||||||
|
|
||||||
```
|
|
||||||
|
|
||||||
Then
|
|
||||||
|
|
||||||
```shell
|
|
||||||
git clone https://gitee.com/deepin-community-store/spark-store.git
|
|
||||||
cd spark-store
|
|
||||||
dpkg-buildpackage
|
|
||||||
```
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
## 🚀 Coorperation
|
|
||||||
|
|
||||||
We use Gitee as our code hosting platform. Please click here to contact us.
|
|
||||||
|
|
||||||
https://gitee.com/deepin-community-store/spark-store
|
|
||||||
|
|
||||||
### Rocket Chat
|
|
||||||
|
|
||||||
https://chat.shenmo.tech/
|
|
||||||
|
|
||||||
PWA Client:
|
|
||||||
|
|
||||||
spk://store/chat/store.spark-app.feedback
|
|
||||||
|
|
||||||
(Copy and paste to search bar or in browser address bar after installing Spark Store)
|
|
||||||
57
README.md
57
README.md
@@ -1,50 +1,53 @@
|
|||||||
# 星火应用商店
|
# Spark App Store
|
||||||
[](https://gitee.com/deepin-community-store/spark-store/stargazers) [](https://gitee.com/deepin-community-store/spark-store/members)
|
[](https://gitee.com/deepin-community-store/spark-store/stargazers) [](https://gitee.com/deepin-community-store/spark-store/members)
|
||||||
|
|
||||||
众所周知,国内的Linux应用比较少,wine应用难以获取,优质工具分散在民间各大论坛,无法形成合力,难以改善生态
|
Spark Store aims to collect Linux apps for the convieniece of Linux new comers
|
||||||
|
|
||||||
生态构建需要的不是某一方的单打独斗,而是人人行动起来,汇聚星火,产生燎原之势
|
The collecting process needs everyone's help
|
||||||
|
|
||||||
我们创建了这个应用商店,广泛收录大家需要的软件包,搜集优质小工具,主动适配wine应用,存放到储存库供大家获取
|
We set up this APP Store and collect APPs/tools that everyone need widely. Also we pack Windows apps with wine.
|
||||||
我们支持:Deepin 20 ; Ubuntu 22.04 LTS / Ubuntu 20.04 LTS(将会逐渐停止支持) ; UOS Home 21
|
|
||||||
|
|
||||||
## 关于协作:分支相关的文档见 [这里](https://deepin-community-store.gitee.io/spark-wiki/#/Dev/Spark-Store-Git-Repo)
|
All packages will be shared in our repository for users to get freely.
|
||||||
|
|
||||||
*关于OpenKylin和deepin 23*
|
Distrobution supported:Deepin 20 ; Ubuntu 22.04 LTS / Ubuntu 20.04 LTS(May stop support in the future) ; UniontechOS Home 21
|
||||||
|
|
||||||
支持计划将会在对应系统发布正式版之后开始评估和执行
|
*About OpenKylin and deepin 23*
|
||||||
|
|
||||||
希望看到这里的人也可以加入我们的队伍,开发或者投递应用都很欢迎,共同构建Linux应用生态
|
The adaptation work is scheduled after their official release.
|
||||||
|
|
||||||
在这里追踪我们的Issue处理情况 https://gitee.com/deepin-community-store/spark-store/board
|
You can track our Issue resoving progress here https://gitee.com/deepin-community-store/spark-store/board
|
||||||
|
|
||||||
如果有想要提交的软件包,请 [在这里投稿](https://upload.deepinos.org/index)
|
|
||||||
|
|
||||||
|
|
||||||
## 🙌 简单的开始
|
We hope people who see here can also join our team,development help or submit applications are welcomed
|
||||||
|
|
||||||
如果想安装 `星火应用商店` ,请打开右侧的 [Release] 页面,找到最新版本,并选择适用于当前系统的安装包下载。
|
If you want to submit an APP to share with others,Please [Click here](https://upload.deepinos.org/index)
|
||||||
|
|
||||||
如果你在使用 `Debian 11/Ubuntu 20.04`,你需要额外下载[依赖补充包](https://code.gitlink.org.cn/shenmo7192/spark-store-dependencies/raw/branch/master/spark-store-dependencies-kylin.zip)
|
|
||||||
|
## 🙌 A simple start
|
||||||
|
|
||||||
|
If you simply want to install the Spark Store,just enter the [Release] page, find the version you want and install.
|
||||||
|
|
||||||
|
If you are using Debian11/Ubuntu 20.04, you will need extra dependency package. Available [here](https://code.gitlink.org.cn/shenmo7192/spark-store-dependencies/raw/branch/master/spark-store-dependencies-kylin.zip)
|
||||||
|
|
||||||
---
|
---
|
||||||
#### 编译安装
|
#### Compile and developement
|
||||||
|
|
||||||
|
|
||||||
Deepin V20/UOS 21 系统下, 安装依赖
|
For Deepin V20/UOS 21/ Debian 11
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
sudo apt install git qt5-default debhelper pkg-config qtchooser libqt5core5a libqt5gui5 libqt5widgets5 libqt5network5 libqt5concurrent5 libdtkcore-dev libdtkgui-dev libdtkwidget-dev qttools5-private-dev libnotify-dev qtwebengine5-dev fakeroot
|
sudo apt install git qt5-default debhelper pkg-config qtchooser libqt5core5a libqt5gui5 libqt5widgets5 libqt5network5 libqt5concurrent5 libdtkcore-dev libdtkgui-dev libdtkwidget-dev qttools5-private-dev libnotify-dev qtwebengine5-dev fakeroot qtwayland5 qtwayland5-dev-tools dde-qt5wayland-plugin
|
||||||
|
|
||||||
```
|
```
|
||||||
|
|
||||||
Ubuntu 22.04 系统下, 安装依赖
|
Ubuntu 22.04
|
||||||
```shell
|
```shell
|
||||||
sudo apt install git qtbase5-dev debhelper pkg-config qtchooser libqt5core5a libqt5gui5 libqt5widgets5 libqt5network5 libqt5concurrent5 libdtkcore-dev libdtkgui-dev libdtkwidget-dev qttools5-private-dev libnotify-dev qtwebengine5-dev
|
sudo apt install git qtbase5-dev debhelper pkg-config qtchooser libqt5core5a libqt5gui5 libqt5widgets5 libqt5network5 libqt5concurrent5 libdtkcore-dev libdtkgui-dev libdtkwidget-dev qttools5-private-dev libnotify-dev qtwebengine5-dev qtwayland5 qtwayland5-dev-tools
|
||||||
|
|
||||||
```
|
```
|
||||||
|
|
||||||
然后
|
Then
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
git clone https://gitee.com/deepin-community-store/spark-store.git
|
git clone https://gitee.com/deepin-community-store/spark-store.git
|
||||||
cd spark-store
|
cd spark-store
|
||||||
@@ -53,16 +56,18 @@ dpkg-buildpackage
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
## 🚀 协作
|
## 🚀 Coorperation
|
||||||
|
|
||||||
非常感谢有兴趣的开发者或爱好者参与 `星火应用商店` 项目,分享你的见解与思路。
|
We use Gitee as our code hosting platform. Please click here to contact us.
|
||||||
|
|
||||||
### 交流平台
|
https://gitee.com/deepin-community-store/spark-store
|
||||||
|
|
||||||
|
### Rocket Chat
|
||||||
|
|
||||||
https://chat.shenmo.tech/
|
https://chat.shenmo.tech/
|
||||||
|
|
||||||
客户端PWA:
|
PWA Client:
|
||||||
|
|
||||||
spk://store/chat/store.spark-app.feedback
|
spk://store/chat/store.spark-app.feedback
|
||||||
|
|
||||||
(安装星火商店后在浏览器打开或复制到搜索栏打开)
|
(Copy and paste to search bar or in browser address bar after installing Spark Store)
|
||||||
68
README.zh.md
Normal file
68
README.zh.md
Normal file
@@ -0,0 +1,68 @@
|
|||||||
|
# 星火应用商店
|
||||||
|
[](https://gitee.com/deepin-community-store/spark-store/stargazers) [](https://gitee.com/deepin-community-store/spark-store/members)
|
||||||
|
|
||||||
|
众所周知,国内的Linux应用比较少,wine应用难以获取,优质工具分散在民间各大论坛,无法形成合力,难以改善生态
|
||||||
|
|
||||||
|
生态构建需要的不是某一方的单打独斗,而是人人行动起来,汇聚星火,产生燎原之势
|
||||||
|
|
||||||
|
我们创建了这个应用商店,广泛收录大家需要的软件包,搜集优质小工具,主动适配wine应用,存放到储存库供大家获取
|
||||||
|
我们支持:Deepin 20 ; Ubuntu 22.04 LTS / Ubuntu 20.04 LTS(将会逐渐停止支持) ; UOS Home 21
|
||||||
|
|
||||||
|
## 关于协作:分支相关的文档见 [这里](https://deepin-community-store.gitee.io/spark-wiki/#/Dev/Spark-Store-Git-Repo)
|
||||||
|
|
||||||
|
*关于OpenKylin和deepin 23*
|
||||||
|
|
||||||
|
支持计划将会在对应系统发布正式版之后开始评估和执行
|
||||||
|
|
||||||
|
希望看到这里的人也可以加入我们的队伍,开发或者投递应用都很欢迎,共同构建Linux应用生态
|
||||||
|
|
||||||
|
在这里追踪我们的Issue处理情况 https://gitee.com/deepin-community-store/spark-store/board
|
||||||
|
|
||||||
|
如果有想要提交的软件包,请 [在这里投稿](https://upload.deepinos.org/index)
|
||||||
|
|
||||||
|
|
||||||
|
## 🙌 简单的开始
|
||||||
|
|
||||||
|
如果想安装 `星火应用商店` ,请打开右侧的 [Release] 页面,找到最新版本,并选择适用于当前系统的安装包下载。
|
||||||
|
|
||||||
|
如果你在使用 `Debian 11/Ubuntu 20.04`,你需要额外下载[依赖补充包](https://code.gitlink.org.cn/shenmo7192/spark-store-dependencies/raw/branch/master/spark-store-dependencies-kylin.zip)
|
||||||
|
|
||||||
|
---
|
||||||
|
#### 编译安装
|
||||||
|
|
||||||
|
|
||||||
|
Deepin V20/UOS 21 系统下, 安装依赖
|
||||||
|
|
||||||
|
```shell
|
||||||
|
sudo apt install git qt5-default debhelper pkg-config qtchooser libqt5core5a libqt5gui5 libqt5widgets5 libqt5network5 libqt5concurrent5 libdtkcore-dev libdtkgui-dev libdtkwidget-dev qttools5-private-dev libnotify-dev qtwebengine5-dev fakeroot qtwayland5 qtwayland5-dev-tools dde-qt5wayland-plugin
|
||||||
|
|
||||||
|
```
|
||||||
|
|
||||||
|
Ubuntu 22.04 系统下, 安装依赖
|
||||||
|
```shell
|
||||||
|
sudo apt install git qtbase5-dev debhelper pkg-config qtchooser libqt5core5a libqt5gui5 libqt5widgets5 libqt5network5 libqt5concurrent5 libdtkcore-dev libdtkgui-dev libdtkwidget-dev qttools5-private-dev libnotify-dev qtwebengine5-dev qtwayland5 qtwayland5-dev-tools
|
||||||
|
|
||||||
|
```
|
||||||
|
|
||||||
|
然后
|
||||||
|
```shell
|
||||||
|
git clone https://gitee.com/deepin-community-store/spark-store.git
|
||||||
|
cd spark-store
|
||||||
|
dpkg-buildpackage
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
## 🚀 协作
|
||||||
|
|
||||||
|
非常感谢有兴趣的开发者或爱好者参与 `星火应用商店` 项目,分享你的见解与思路。
|
||||||
|
|
||||||
|
### 交流平台
|
||||||
|
|
||||||
|
https://chat.shenmo.tech/
|
||||||
|
|
||||||
|
客户端PWA:
|
||||||
|
|
||||||
|
spk://store/chat/store.spark-app.feedback
|
||||||
|
|
||||||
|
(安装星火商店后在浏览器打开或复制到搜索栏打开)
|
||||||
238
debian/changelog
vendored
238
debian/changelog
vendored
@@ -1,39 +1,207 @@
|
|||||||
|
spark-store (4.2.3~test3) stable; urgency=medium
|
||||||
|
|
||||||
|
* 调整:打包时从 debian/changelog 自动获取构建版本号并写入关于窗口保证与deb一致
|
||||||
|
* 新增:支持 DTK 5.6.4 关于对话框“版本特性”显示功能。目前只在deepin编译安装时开启
|
||||||
|
* 修复:修复下载列表对话框中,点击某个 item 取消下载按钮后下载列表无法再次显示的问题
|
||||||
|
* 修复:多个应用安装可能会出现某一个应用没有安装
|
||||||
|
* 修复:修复下载按钮点击/双击/拖动时,主窗口动作与下载管理对话框动作同时触发问题
|
||||||
|
* aptss 获取线路信息 转到从 d. 服务器获取
|
||||||
|
|
||||||
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
spark-store (4.2.3~test2) stable; urgency=medium
|
||||||
|
|
||||||
|
* 调整:开启安装包加固
|
||||||
|
* 添加:zh_TW翻译
|
||||||
|
|
||||||
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
|
spark-store (4.2.3~test1) stable; urgency=medium
|
||||||
|
|
||||||
|
* 修复:因判断安装状态错误创建多个相同任务的bug
|
||||||
|
* 测试中:尝试修复安装结束的闪退问题 https://gitee.com/deepin-community-store/spark-store/commit/cb093dcc2bb0a193db89aa0ce5f20ea9cc5d56eb
|
||||||
|
* 修复:Deepin 显示开发者模式未开启
|
||||||
|
* 修复:从托盘打开主窗口时透明度动画不流畅
|
||||||
|
* 修复:主窗口关闭后,从托盘打开关于窗口会被主窗口遮挡
|
||||||
|
|
||||||
|
-- shenmo <shenmo@spark-app.store> Sun, 05 Feb 2023 23:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
|
spark-store (4.2.2) stable; urgency=medium
|
||||||
|
|
||||||
|
* 调整:脚本应用的transhell支持转为source导入
|
||||||
|
* 修复:ssinstall弹窗支持wayland
|
||||||
|
* 新增:应用托盘,下载时候可以放心关闭窗口了
|
||||||
|
* 新增:支持spk://search/内容 格式链接
|
||||||
|
|
||||||
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
|
spark-store (4.2.1) stable; urgency=medium
|
||||||
|
|
||||||
|
* 调整:支持在安装前进行测试(ss-do-upgrade-worker),但是未实装到appinfo
|
||||||
|
* 修复:因依赖不完全导致在LinuxMint下无法下载统计
|
||||||
|
* 新增:脚本系列应用支持英文
|
||||||
|
|
||||||
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
|
spark-store (4.2) stable; urgency=medium
|
||||||
|
|
||||||
|
* 调整:UOS开发者模式提示现在不会那么挤了
|
||||||
|
* 修复:wayland下可正常弹出更新提示
|
||||||
|
* 调整:dwine5标签的文案改为:Wine应用
|
||||||
|
* 新增:更新软件时弹窗会显示正在更新的软件包名
|
||||||
|
|
||||||
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
|
spark-store (4.2~test3) stable; urgency=medium
|
||||||
|
|
||||||
|
* 修复: aptss ssupdates
|
||||||
|
|
||||||
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
|
spark-store (4.2~test2) stable; urgency=medium
|
||||||
|
|
||||||
|
* 修复: 420t1版本中ssinstall有时会重新下载软件包的问题
|
||||||
|
* 新增: 安装前会对软件包安装进行dry run以判断是否能正确安装
|
||||||
|
* 调整: aptss在进行任何操作前均检测是否存在Packages文件,若存在,则不进行ssupdate
|
||||||
|
* 调整: 修改apt-fast源代码以指定conf位置为/tmp/apt-fast,这部分不再使用bwrap模拟
|
||||||
|
* 新增: aptss检测Package文件支持分目录(目前指定为store)
|
||||||
|
|
||||||
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
|
spark-store (4.2~test1) stable; urgency=medium
|
||||||
|
|
||||||
|
* 新增: aptss支持显示报错
|
||||||
|
* 新增: aptss部分提示汉化
|
||||||
|
* 修复: 修复部分情况下ssinstall实际未安装但是错误显示
|
||||||
|
|
||||||
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
|
spark-store (4.1.2) stable; urgency=medium
|
||||||
|
|
||||||
|
* feat: 初步的wayland支持
|
||||||
|
* feat: UOS下检测开发者模式是否开启,若未开启则拒绝安装
|
||||||
|
* fix: 首页的捐赠页面在中文环境下显示中文
|
||||||
|
* fix: 更新检测模块在aptss ssupdate操作失败后现在会正确地移除锁而不是错误的残留锁。
|
||||||
|
* chore: ssinstall现在拒绝安装验证失败的包,审核操作现在需要改用ssaudit
|
||||||
|
* fix: Ubuntu下下载列表无法关闭
|
||||||
|
* fix: 修复进入详情页时焦点默认在分享链接按钮上的问题
|
||||||
|
* fix: 修复特定情况下的内存泄漏问题
|
||||||
|
* fix: 适配c11代码规范,消除qt编译警告
|
||||||
|
* fix: 默认服务器域名指向cdn域名
|
||||||
|
* fix: 消除内部函数的无用变量,限制作用域
|
||||||
|
* feat: aptss 除ssupdate外的操作时候如果检测到存在源文件存在则不再重复获取
|
||||||
|
* fix: 修复在apt list锁被锁定的时候异常弹出有更新可用
|
||||||
|
* chore: 去除安装依赖:g++
|
||||||
|
* fix: 修复下载列表中进度提示文字显示不完整的问题
|
||||||
|
* feat: ssinstall支持从单独文件夹中校验软件包
|
||||||
|
* feat: 支持分单文件夹下载。具体内容参见:https://gitee.com/deepin-community-store/repo_auto_update_script/blob/master/mirror-list-for-apt-fast/sources.list.d/sparkstore.list
|
||||||
|
* info: 非常感谢 @jwyh 对星火商店代码仓库设计了很多标准,参见 https://deepin-community-store.gitee.io/spark-wiki/#/Dev/Spark-Store-Git-Repo?id=%e6%9b%b4%e6%96%b0%e6%97%a5%e5%bf%97%e8%a7%84%e5%88%99 ,不过shenmo是自由的
|
||||||
|
|
||||||
|
|
||||||
|
* chore: 添加 Application 类,继承 DApplication,将 main 函数中设置属性、关于信息等操作移至 Application 构造函数中进行
|
||||||
|
* chore: 添加 setOrganizationName 操作,设置组织名称为 spark-union,与 SWRT 保持一致
|
||||||
|
* chore: 设置组织名称后,QStandardPaths::AppConfigLocation 等路径相应改变,修改所有配置文件和缓存文件路径
|
||||||
|
* chore: 关于对话框设置父对象后,对话框背景色受主窗口样式表影响,移动部分控件样式表设置方式与位置
|
||||||
|
* chore: 去除 .pro 文件中无效的更新翻译文件脚本调用,整理 .pro 文件,添加编译时更新 ts 文件脚本调用
|
||||||
|
* chore: 继续修复偶现关闭客户端时崩溃问题(疑似 aria2c 进程未启动,pid 未初始化为随机值,执行 kill 操作时未判断导致)
|
||||||
|
* chore: 新增编译依赖,测试安装时不会出现报错
|
||||||
|
* chore: 暂时去除没有意义的 DBus 接口,使用 DGuiApplicationHelper::newProcessInstance 获取新进程的启动参数
|
||||||
|
* chore: 更新翻译文件,去除已经不存在的翻译
|
||||||
|
|
||||||
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
|
spark-store (4.1.2~test2) stable; urgency=medium
|
||||||
|
|
||||||
|
* feat: ssinstall支持从单独文件夹中校验软件包
|
||||||
|
* feat: 支持分单文件夹下载。具体内容参见:https://gitee.com/deepin-community-store/repo_auto_update_script/blob/master/mirror-list-for-apt-fast/sources.list.d/sparkstore.list
|
||||||
|
* info: 非常感谢 @jwyh 对星火商店代码仓库设计了很多标准,参见 https://deepin-community-store.gitee.io/spark-wiki/#/Dev/Spark-Store-Git-Repo ,不过shenmo是自由的
|
||||||
|
|
||||||
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
|
spark-store (4.1.2~test1) stable; urgency=medium
|
||||||
|
|
||||||
|
* feat: 初步的wayland支持
|
||||||
|
* feat: UOS下检测开发者模式是否开启,若未开启则拒绝安装
|
||||||
|
* fix: 首页的捐赠页面在中文环境下显示中文
|
||||||
|
* fix: 更新检测模块在aptss ssupdate操作失败后现在会正确地移除锁而不是错误的残留锁。
|
||||||
|
* chore: ssinstall现在拒绝安装验证失败的包,审核操作现在需要改用ssaudit
|
||||||
|
* fix: Ubuntu下下载列表无法关闭
|
||||||
|
* fix: 修复进入详情页时焦点默认在分享链接按钮上的问题
|
||||||
|
* fix: 修复特定情况下的内存泄漏问题
|
||||||
|
* fix: 适配c11代码规范,消除qt编译警告
|
||||||
|
* fix: 默认服务器域名指向cdn域名
|
||||||
|
* fix: 消除内部函数的无用变量,限制作用域
|
||||||
|
* feat: aptss 除ssupdate外的操作时候如果检测到存在源文件存在则不再重复获取
|
||||||
|
* fix: 修复在apt list锁被锁定的时候异常弹出有更新可用
|
||||||
|
* chore: 去除安装依赖:g++
|
||||||
|
* fix: 修复下载列表中进度提示文字显示不完整的问题
|
||||||
|
|
||||||
|
|
||||||
|
* chore: 添加 Application 类,继承 DApplication,将 main 函数中设置属性、关于信息等操作移至 Application 构造函数中进行
|
||||||
|
* chore: 添加 setOrganizationName 操作,设置组织名称为 spark-union,与 SWRT 保持一致
|
||||||
|
* chore: 设置组织名称后,QStandardPaths::AppConfigLocation 等路径相应改变,修改所有配置文件和缓存文件路径
|
||||||
|
* chore: 关于对话框设置父对象后,对话框背景色受主窗口样式表影响,移动部分控件样式表设置方式与位置
|
||||||
|
* chore: 去除 .pro 文件中无效的更新翻译文件脚本调用,整理 .pro 文件,添加编译时更新 ts 文件脚本调用
|
||||||
|
* chore: 继续修复偶现关闭客户端时崩溃问题(疑似 aria2c 进程未启动,pid 未初始化为随机值,执行 kill 操作时未判断导致)
|
||||||
|
* chore: 新增编译依赖,测试安装时不会出现报错
|
||||||
|
* chore: 暂时去除没有意义的 DBus 接口,使用 DGuiApplicationHelper::newProcessInstance 获取新进程的启动参数
|
||||||
|
* chore: 更新翻译文件,去除已经不存在的翻译
|
||||||
|
|
||||||
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (4.1.1) stable; urgency=medium
|
spark-store (4.1.1) stable; urgency=medium
|
||||||
|
|
||||||
* fix:更新失效
|
* fix:更新失效
|
||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (4.1.0) stable; urgency=medium
|
spark-store (4.1.0) stable; urgency=medium
|
||||||
|
|
||||||
* feat: 现在可以支持UOS签名包问题了
|
* feat: 现在可以支持UOS签名包问题了
|
||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (4.0.1) stable; urgency=medium
|
spark-store (4.0.1) stable; urgency=medium
|
||||||
|
|
||||||
* feat: 提升Ubuntu下的显示效果
|
* feat: 提升Ubuntu下的显示效果
|
||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (4.0.0) stable; urgency=medium
|
spark-store (4.0.0) stable; urgency=medium
|
||||||
|
|
||||||
* feat: 修复了成吨的bug后开始正式版
|
* feat: 修复了成吨的bug后开始正式版
|
||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (4.0.0~test2) stable; urgency=medium
|
spark-store (4.0.0~test2) stable; urgency=medium
|
||||||
|
|
||||||
* feat: 修复了成吨的bug后开始公测
|
* feat: 修复了成吨的bug后开始公测
|
||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (4.0.0~test1) stable; urgency=medium
|
spark-store (4.0.0~test1) stable; urgency=medium
|
||||||
|
|
||||||
* feat: 柚子过来补充一下啦
|
* feat: 柚子过来补充一下啦
|
||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.4~test1) stable; urgency=medium
|
spark-store (3.4~test1) stable; urgency=medium
|
||||||
|
|
||||||
* feat: aptss不再尝试安装apt-fast,转而自带
|
* feat: aptss不再尝试安装apt-fast,转而自带
|
||||||
@@ -41,13 +209,15 @@ spark-store (3.4~test1) stable; urgency=medium
|
|||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.3.3) stable; urgency=medium
|
spark-store (3.3.3) stable; urgency=medium
|
||||||
|
|
||||||
* feat: 首页链接调用浏览器打开
|
* feat: 首页链接调用浏览器打开
|
||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
0spark-store (3.3.3~test5) stable; urgency=medium
|
|
||||||
|
spark-store (3.3.3~test5) stable; urgency=medium
|
||||||
|
|
||||||
* 修复可能的内存泄漏问题
|
* 修复可能的内存泄漏问题
|
||||||
* 修复应用搜索为空但仍显示上一次搜索结果的问题
|
* 修复应用搜索为空但仍显示上一次搜索结果的问题
|
||||||
@@ -63,6 +233,7 @@ spark-store (3.3.3~test4) stable; urgency=medium
|
|||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.3.3~test3) stable; urgency=medium
|
spark-store (3.3.3~test3) stable; urgency=medium
|
||||||
|
|
||||||
* Now use ss-apt-fast instead of apt-fast
|
* Now use ss-apt-fast instead of apt-fast
|
||||||
@@ -70,12 +241,14 @@ spark-store (3.3.3~test3) stable; urgency=medium
|
|||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.3.3~test2) stable; urgency=medium
|
spark-store (3.3.3~test2) stable; urgency=medium
|
||||||
|
|
||||||
* bug fix: 更新和检查更新出错时不报错.此更新需要一个推送
|
* bug fix: 更新和检查更新出错时不报错.此更新需要一个推送
|
||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.3.3~test1) stable; urgency=medium
|
spark-store (3.3.3~test1) stable; urgency=medium
|
||||||
|
|
||||||
* 3.3.3将会是修复大部分bug后的最终版本
|
* 3.3.3将会是修复大部分bug后的最终版本
|
||||||
@@ -84,41 +257,43 @@ spark-store (3.3.3~test1) stable; urgency=medium
|
|||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.3.1~test1) stable; urgency=medium
|
spark-store (3.3.1~test1) stable; urgency=medium
|
||||||
|
|
||||||
* 安装时不再需要联网
|
* 安装时不再需要联网
|
||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.3.0.4) stable; urgency=medium
|
spark-store (3.3.0.4) stable; urgency=medium
|
||||||
|
|
||||||
* 为减轻服务器压力,不再单独更新某一个应用,而是作为整体更新
|
* 为减轻服务器压力,不再单独更新某一个应用,而是作为整体更新
|
||||||
|
|
||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.3.0.3) stable; urgency=medium
|
spark-store (3.3.0.3) stable; urgency=medium
|
||||||
|
|
||||||
* 回滚 更新中行为到进度条而不是实时输出
|
* 回滚 更新中行为到进度条而不是实时输出
|
||||||
* 更新应用时显示正在更新哪个应用
|
* 更新应用时显示正在更新哪个应用
|
||||||
|
|
||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.3.0.2) stable; urgency=medium
|
spark-store (3.3.0.2) stable; urgency=medium
|
||||||
|
|
||||||
* 修复 pkexec未执行
|
* 修复 pkexec未执行
|
||||||
|
|
||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.3.0.1) stable; urgency=medium
|
spark-store (3.3.0.1) stable; urgency=medium
|
||||||
|
|
||||||
* 修复 检查更新的更新进程未实际运行
|
* 修复 检查更新的更新进程未实际运行
|
||||||
|
|
||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.3) stable; urgency=medium
|
spark-store (3.3) stable; urgency=medium
|
||||||
|
|
||||||
* 修复 检查更新 未刷新软件源
|
* 修复 检查更新 未刷新软件源
|
||||||
@@ -126,18 +301,21 @@ spark-store (3.3) stable; urgency=medium
|
|||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.3~test3) stable; urgency=medium
|
spark-store (3.3~test3) stable; urgency=medium
|
||||||
|
|
||||||
* 把检查更新加入免密码
|
* 把检查更新加入免密码
|
||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.3~test2) stable; urgency=medium
|
spark-store (3.3~test2) stable; urgency=medium
|
||||||
|
|
||||||
* 更新检测功能全部更改到zenity
|
* 更新检测功能全部更改到zenity
|
||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.3~test1) stable; urgency=medium
|
spark-store (3.3~test1) stable; urgency=medium
|
||||||
|
|
||||||
* zenity,选择可更新应用
|
* zenity,选择可更新应用
|
||||||
@@ -145,6 +323,7 @@ spark-store (3.3~test1) stable; urgency=medium
|
|||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.2.4) stable; urgency=medium
|
spark-store (3.2.4) stable; urgency=medium
|
||||||
|
|
||||||
* 修改tag相关的文案内容:wine相关环境已可自动配置了
|
* 修改tag相关的文案内容:wine相关环境已可自动配置了
|
||||||
@@ -152,42 +331,39 @@ spark-store (3.2.4) stable; urgency=medium
|
|||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.2.4~test4) stable; urgency=medium
|
spark-store (3.2.4~test4) stable; urgency=medium
|
||||||
|
|
||||||
* 现在在商店启动后点击spk链接仍会正常启动 https://gitee.com/deepin-community-store/spark-store/commit/dd6780d636042bf12d77414e6f1552cc7d1ed24c
|
* 现在在商店启动后点击spk链接仍会正常启动 https://gitee.com/deepin-community-store/spark-store/commit/dd6780d636042bf12d77414e6f1552cc7d1ed24c
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.2.4~test3) stable; urgency=medium
|
spark-store (3.2.4~test3) stable; urgency=medium
|
||||||
|
|
||||||
* 发版,合入到master
|
* 发版,合入到master
|
||||||
* 翻译完毕
|
* 翻译完毕
|
||||||
* 合入先前的各项改动,为:客户端集成投稿器入口和支持,修复:安装依赖时间较长时错误地返回“安装完毕”结果,现在客户端版本更新时不关闭免密码登录,UOS安装进程合并正常aptss中
|
* 合入先前的各项改动,为:客户端集成投稿器入口和支持,修复:安装依赖时间较长时错误地返回“安装完毕”结果,现在客户端版本更新时不关闭免密码登录,UOS安装进程合并正常aptss中
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.2.4~test2) stable; urgency=medium
|
spark-store (3.2.4~test2) stable; urgency=medium
|
||||||
|
|
||||||
* 客户端集成投稿器入口和支持
|
* 客户端集成投稿器入口和支持
|
||||||
* 修复:安装依赖时间较长时错误地返回“安装完毕”结果
|
* 修复:安装依赖时间较长时错误地返回“安装完毕”结果
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.2.4~test1) stable; urgency=medium
|
spark-store (3.2.4~test1) stable; urgency=medium
|
||||||
|
|
||||||
* 客户端更新时不关闭免密码登录
|
* 客户端更新时不关闭免密码登录
|
||||||
* UOS合并正常aptss中
|
* UOS合并正常aptss中
|
||||||
|
|
||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.2.3) stable; urgency=medium
|
spark-store (3.2.3) stable; urgency=medium
|
||||||
|
|
||||||
* 客户端异常退出时仍然占用资源问题修复
|
* 客户端异常退出时仍然占用资源问题修复
|
||||||
@@ -195,6 +371,7 @@ spark-store (3.2.3) stable; urgency=medium
|
|||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.2.2) stable; urgency=medium
|
spark-store (3.2.2) stable; urgency=medium
|
||||||
|
|
||||||
* aptss will now refresh the system source before doing install, policy....etc
|
* aptss will now refresh the system source before doing install, policy....etc
|
||||||
@@ -202,13 +379,14 @@ spark-store (3.2.2) stable; urgency=medium
|
|||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.2.1) stable; urgency=medium
|
spark-store (3.2.1) stable; urgency=medium
|
||||||
|
|
||||||
* 更改刷新系统源的功能
|
* 更改刷新系统源的功能
|
||||||
|
|
||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.2) stable; urgency=medium
|
spark-store (3.2) stable; urgency=medium
|
||||||
|
|
||||||
* 新增 下载量统计功能
|
* 新增 下载量统计功能
|
||||||
@@ -222,6 +400,7 @@ spark-store (3.2) stable; urgency=medium
|
|||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.1.6) stable; urgency=medium
|
spark-store (3.1.6) stable; urgency=medium
|
||||||
|
|
||||||
* 修复部分情况下无法选中正确的镜像源的问题
|
* 修复部分情况下无法选中正确的镜像源的问题
|
||||||
@@ -229,6 +408,7 @@ spark-store (3.1.6) stable; urgency=medium
|
|||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.1.5-5) stable; urgency=medium
|
spark-store (3.1.5-5) stable; urgency=medium
|
||||||
|
|
||||||
* 从所有镜像源中选取最快镜像源高速下载
|
* 从所有镜像源中选取最快镜像源高速下载
|
||||||
@@ -245,45 +425,45 @@ spark-store (3.1.5-4) stable; urgency=medium
|
|||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.1.5-3) stable; urgency=medium
|
spark-store (3.1.5-3) stable; urgency=medium
|
||||||
|
|
||||||
* 包内自带密钥
|
* 包内自带密钥
|
||||||
|
|
||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.1.5-2) stable; urgency=medium
|
spark-store (3.1.5-2) stable; urgency=medium
|
||||||
|
|
||||||
* 下载软件时跳过获取大小,修复部分软件无法下载的问题
|
* 下载软件时跳过获取大小,修复部分软件无法下载的问题
|
||||||
* 修复 获取key时出错,指定使用http1.1
|
* 修复 获取key时出错,指定使用http1.1
|
||||||
|
|
||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.1.5-1) stable; urgency=medium
|
spark-store (3.1.5-1) stable; urgency=medium
|
||||||
|
|
||||||
* 改变更新策略,UOS也下载加速,但是安装不加速
|
* 改变更新策略,UOS也下载加速,但是安装不加速
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.1.5) stable; urgency=medium
|
spark-store (3.1.5) stable; urgency=medium
|
||||||
|
|
||||||
* 改变更新策略,现在支持应用在更新时引入新依赖
|
* 改变更新策略,现在支持应用在更新时引入新依赖
|
||||||
* ss-apt-fast现在默认允许降级,以与apt使用体验一致
|
* ss-apt-fast现在默认允许降级,以与apt使用体验一致
|
||||||
|
|
||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.1.4-2) stable; urgency=medium
|
spark-store (3.1.4-2) stable; urgency=medium
|
||||||
|
|
||||||
* 客户端下载使用metalink来支持bt下载加速
|
* 客户端下载使用metalink来支持bt下载加速
|
||||||
* 修复使用更新和安装设置更新商店本体时出错
|
* 修复使用更新和安装设置更新商店本体时出错
|
||||||
|
|
||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.1.4-1) stable; urgency=medium
|
spark-store (3.1.4-1) stable; urgency=medium
|
||||||
|
|
||||||
* 安装脚本和检测更新脚本检查网络时间超时时间延长至5s
|
* 安装脚本和检测更新脚本检查网络时间超时时间延长至5s
|
||||||
@@ -291,6 +471,7 @@ spark-store (3.1.4-1) stable; urgency=medium
|
|||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.1.4) stable; urgency=medium
|
spark-store (3.1.4) stable; urgency=medium
|
||||||
|
|
||||||
* 发布正式版,同步到官网
|
* 发布正式版,同步到官网
|
||||||
@@ -302,6 +483,7 @@ spark-store (3.1.4) stable; urgency=medium
|
|||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.1.3-2) stable; urgency=medium
|
spark-store (3.1.3-2) stable; urgency=medium
|
||||||
|
|
||||||
* 调整 现在与系统更新分开,不再导致更新失败
|
* 调整 现在与系统更新分开,不再导致更新失败
|
||||||
@@ -310,17 +492,17 @@ spark-store (3.1.3-2) stable; urgency=medium
|
|||||||
* 修改ss-apt-fast的策略,现在除了安装,下载和更新都改用apt
|
* 修改ss-apt-fast的策略,现在除了安装,下载和更新都改用apt
|
||||||
* ssinstall 现在也会在不适用ss-apt-fast的时候模拟源了(针对UOS)
|
* ssinstall 现在也会在不适用ss-apt-fast的时候模拟源了(针对UOS)
|
||||||
|
|
||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.1.3-1) stable; urgency=medium
|
spark-store (3.1.3-1) stable; urgency=medium
|
||||||
|
|
||||||
* 修复 下载提前退出
|
* 修复 下载提前退出
|
||||||
* 移除 下载量显示
|
* 移除 下载量显示
|
||||||
|
|
||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.1.3) stable; urgency=medium
|
spark-store (3.1.3) stable; urgency=medium
|
||||||
|
|
||||||
* Now uses aria2 to download softwares form all mirrors
|
* Now uses aria2 to download softwares form all mirrors
|
||||||
@@ -332,6 +514,7 @@ spark-store (3.1.3) stable; urgency=medium
|
|||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Fri, 30 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.1.2) stable; urgency=medium
|
spark-store (3.1.2) stable; urgency=medium
|
||||||
|
|
||||||
* Now let apt-fast method support all mirrors
|
* Now let apt-fast method support all mirrors
|
||||||
@@ -340,8 +523,6 @@ spark-store (3.1.2) stable; urgency=medium
|
|||||||
-- shenmo <shenmo@spark-app.store> Mon, 17 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Mon, 17 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.1.1) stable; urgency=medium
|
spark-store (3.1.1) stable; urgency=medium
|
||||||
|
|
||||||
* Now will delete the link of policy file after uninstall or upgrade
|
* Now will delete the link of policy file after uninstall or upgrade
|
||||||
@@ -350,8 +531,6 @@ spark-store (3.1.1) stable; urgency=medium
|
|||||||
-- shenmo <shenmo@spark-app.store> Mon, 17 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Mon, 17 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.1.0) stable; urgency=medium
|
spark-store (3.1.0) stable; urgency=medium
|
||||||
|
|
||||||
* Add pkexec policy: ssinstall. Only will be enabled after permitted.
|
* Add pkexec policy: ssinstall. Only will be enabled after permitted.
|
||||||
@@ -360,7 +539,6 @@ spark-store (3.1.0) stable; urgency=medium
|
|||||||
-- shenmo <shenmo@spark-app.store> Mon, 17 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Mon, 17 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.0.3-13) stable; urgency=medium
|
spark-store (3.0.3-13) stable; urgency=medium
|
||||||
|
|
||||||
* Update the ssinstall script. Now support apt-fast and will temporarily increase the spark store source priority to 500 to make depends install correctly
|
* Update the ssinstall script. Now support apt-fast and will temporarily increase the spark store source priority to 500 to make depends install correctly
|
||||||
@@ -370,7 +548,6 @@ spark-store (3.0.3-13) stable; urgency=medium
|
|||||||
-- shenmo <shenmo@spark-app.store> Mon, 17 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Mon, 17 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.0.3-12) stable; urgency=medium
|
spark-store (3.0.3-12) stable; urgency=medium
|
||||||
|
|
||||||
* Rollback to use DApplication::loadDXcbPlugin() to make titlebar behave normally in ubuntu
|
* Rollback to use DApplication::loadDXcbPlugin() to make titlebar behave normally in ubuntu
|
||||||
@@ -380,8 +557,6 @@ spark-store (3.0.3-12) stable; urgency=medium
|
|||||||
-- shenmo <shenmo@spark-app.store> Mon, 17 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Mon, 17 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.0.3-11) stable; urgency=medium
|
spark-store (3.0.3-11) stable; urgency=medium
|
||||||
|
|
||||||
* Now support autoupdate
|
* Now support autoupdate
|
||||||
@@ -389,8 +564,6 @@ spark-store (3.0.3-11) stable; urgency=medium
|
|||||||
-- shenmo <shenmo@spark-app.store> Mon, 17 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Mon, 17 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
spark-store (3.0.3-10) stable; urgency=medium
|
spark-store (3.0.3-10) stable; urgency=medium
|
||||||
|
|
||||||
* Now also compile dstore patch
|
* Now also compile dstore patch
|
||||||
@@ -403,3 +576,4 @@ spark-store (3.0.3-9) stable; urgency=medium
|
|||||||
* Support dpkg-buildpackage
|
* Support dpkg-buildpackage
|
||||||
|
|
||||||
-- shenmo <shenmo@spark-app.store> Mon, 17 Jan 2022 00:00:00 +0800
|
-- shenmo <shenmo@spark-app.store> Mon, 17 Jan 2022 00:00:00 +0800
|
||||||
|
|
||||||
|
|||||||
16
debian/control
vendored
16
debian/control
vendored
@@ -15,11 +15,14 @@ Build-Depends:
|
|||||||
libdtkgui-dev(>=5.0),
|
libdtkgui-dev(>=5.0),
|
||||||
libdtkwidget-dev(>=5.0),
|
libdtkwidget-dev(>=5.0),
|
||||||
qttools5-private-dev,
|
qttools5-private-dev,
|
||||||
qtwebengine5-dev
|
qtwebengine5-dev,
|
||||||
Standards-Version: 3.0
|
qtwayland5,
|
||||||
|
qtwayland5-dev-tools,
|
||||||
|
gcc,
|
||||||
|
g++
|
||||||
|
Standards-Version: 4.0.0
|
||||||
Homepage: https://www.spark-app.store/
|
Homepage: https://www.spark-app.store/
|
||||||
|
|
||||||
|
|
||||||
Package: spark-store
|
Package: spark-store
|
||||||
Architecture: any
|
Architecture: any
|
||||||
Depends:${shlibs:Depends}, ${misc:Depends},
|
Depends:${shlibs:Depends}, ${misc:Depends},
|
||||||
@@ -28,18 +31,17 @@ Depends:${shlibs:Depends}, ${misc:Depends},
|
|||||||
libqt5widgets5,
|
libqt5widgets5,
|
||||||
libqt5network5,
|
libqt5network5,
|
||||||
libqt5concurrent5,
|
libqt5concurrent5,
|
||||||
|
qtwayland5,
|
||||||
libdtkcore5,
|
libdtkcore5,
|
||||||
libdtkgui5,
|
libdtkgui5,
|
||||||
libdtkwidget5,
|
libdtkwidget5,
|
||||||
curl,
|
curl,
|
||||||
openssl,
|
openssl,
|
||||||
libssl-dev,
|
|
||||||
dde-qt5integration,
|
dde-qt5integration,
|
||||||
bubblewrap,
|
bubblewrap,
|
||||||
aria2,
|
aria2,
|
||||||
gcc,
|
gcc,
|
||||||
g++,
|
zenity,
|
||||||
zenity
|
libc6-dev
|
||||||
Description: Spark Store
|
Description: Spark Store
|
||||||
A community powered app store, based on DTK.
|
A community powered app store, based on DTK.
|
||||||
Recommends: apt-fast
|
|
||||||
|
|||||||
11
debian/rules
vendored
11
debian/rules
vendored
@@ -1,10 +1,11 @@
|
|||||||
#!/usr/bin/make -f
|
#!/usr/bin/make -f
|
||||||
|
|
||||||
export QT_SELECT=5
|
export QT_SELECT = qt5
|
||||||
|
export DEB_BUILD_MAINT_OPTIONS = hardening=+all
|
||||||
include /usr/share/dpkg/default.mk
|
include /usr/share/dpkg/default.mk
|
||||||
|
|
||||||
DEB_BUILD_ARCH ?= $(shell dpkg-architecture -qDEB_BUILD_ARCH)
|
DEB_BUILD_ARCH ?= $(shell dpkg-architecture -qDEB_BUILD_ARCH)
|
||||||
DH_AUTO_ARGS = --parallel --buildsystem=qmake
|
DEB_HOST_MULTIARCH ?= $(shell dpkg-architecture -qDEB_HOST_MULTIARCH)
|
||||||
|
|
||||||
# Uncomment this to turn on verbose mode.
|
# Uncomment this to turn on verbose mode.
|
||||||
#export DH_VERBOSE = 1
|
#export DH_VERBOSE = 1
|
||||||
@@ -18,19 +19,17 @@ override_dh_auto_clean:
|
|||||||
override_dh_auto_configure:
|
override_dh_auto_configure:
|
||||||
mkdir -p $(CURDIR)/build
|
mkdir -p $(CURDIR)/build
|
||||||
|
|
||||||
dh_auto_configure MAKEFLAGS=-j$(JOBS) -- spark-store-project.pro \
|
qmake BUILD_VERSION=$(DEB_VERSION_UPSTREAM) spark-store-project.pro \
|
||||||
-spec linux-g++ CONFIG+=qtquickcompiler \
|
-spec linux-g++ CONFIG+=qtquickcompiler \
|
||||||
-o $(CURDIR)/build/
|
-o $(CURDIR)/build/
|
||||||
|
|
||||||
|
|
||||||
override_dh_auto_build:
|
override_dh_auto_build:
|
||||||
make -C $(CURDIR)/build -j$(JOBS)
|
make MAKEFLAGS="$(MAKEFLAGS)" -C $(CURDIR)/build
|
||||||
|
|
||||||
override_dh_auto_install:
|
override_dh_auto_install:
|
||||||
make -C $(CURDIR)/build install \
|
make -C $(CURDIR)/build install \
|
||||||
INSTALL_ROOT=$(CURDIR)/debian/spark-store
|
INSTALL_ROOT=$(CURDIR)/debian/spark-store
|
||||||
|
|
||||||
|
|
||||||
# Ignore the dpkg-shlibdeps: warning (it uses none of the library's symbols)
|
# Ignore the dpkg-shlibdeps: warning (it uses none of the library's symbols)
|
||||||
# Qt Mutidedia lib will ref to network libraray.
|
# Qt Mutidedia lib will ref to network libraray.
|
||||||
override_dh_shlibdeps:
|
override_dh_shlibdeps:
|
||||||
|
|||||||
21
debian/spark-store.postinst
vendored
21
debian/spark-store.postinst
vendored
@@ -2,9 +2,8 @@
|
|||||||
|
|
||||||
case "$1" in
|
case "$1" in
|
||||||
configure)
|
configure)
|
||||||
|
|
||||||
# Enable i386 arch
|
# Enable i386 arch
|
||||||
echo "Enable i386 arch..."
|
echo "Enabling i386 arch..."
|
||||||
dpkg --add-architecture i386
|
dpkg --add-architecture i386
|
||||||
|
|
||||||
# config for aptss
|
# config for aptss
|
||||||
@@ -12,10 +11,7 @@ case "$1" in
|
|||||||
ln -s -f /etc/apt/sources.list /etc/aptss/sources.list
|
ln -s -f /etc/apt/sources.list /etc/aptss/sources.list
|
||||||
|
|
||||||
# Remove the sources.list file
|
# Remove the sources.list file
|
||||||
if [ -e /etc/apt/sources.list.d/sparkstore.list ];then
|
rm -f /etc/apt/sources.list.d/sparkstore.list
|
||||||
rm /etc/apt/sources.list.d/sparkstore.list
|
|
||||||
fi
|
|
||||||
|
|
||||||
|
|
||||||
# Check if /usr/local/bin existed
|
# Check if /usr/local/bin existed
|
||||||
mkdir -p /usr/local/bin
|
mkdir -p /usr/local/bin
|
||||||
@@ -25,6 +21,7 @@ case "$1" in
|
|||||||
ln -s -f /opt/durapps/spark-store/bin/ussremove /usr/local/bin/ussremove
|
ln -s -f /opt/durapps/spark-store/bin/ussremove /usr/local/bin/ussremove
|
||||||
ln -s -f /opt/durapps/spark-store/bin/spark-store /usr/local/bin/spark-store
|
ln -s -f /opt/durapps/spark-store/bin/spark-store /usr/local/bin/spark-store
|
||||||
ln -s -f /opt/durapps/spark-store/bin/ssinstall /usr/local/bin/ssinstall
|
ln -s -f /opt/durapps/spark-store/bin/ssinstall /usr/local/bin/ssinstall
|
||||||
|
ln -s -f /opt/durapps/spark-store/bin/ssaudit /usr/local/bin/ssaudit
|
||||||
ln -s -f /opt/durapps/spark-store/bin/spark-dstore-patch /usr/local/bin/spark-dstore-patch
|
ln -s -f /opt/durapps/spark-store/bin/spark-dstore-patch /usr/local/bin/spark-dstore-patch
|
||||||
ln -s -f /opt/durapps/spark-store/bin/aptss /usr/local/bin/ss-apt-fast
|
ln -s -f /opt/durapps/spark-store/bin/aptss /usr/local/bin/ss-apt-fast
|
||||||
|
|
||||||
@@ -33,9 +30,9 @@ case "$1" in
|
|||||||
# Create symbol links for SSINSTALL
|
# Create symbol links for SSINSTALL
|
||||||
ln -s -f /opt/durapps/spark-store/bin/auto-install-policy/store.spark-app.ssinstall.policy /usr/share/polkit-1/actions/store.spark-app.ssinstall.policy
|
ln -s -f /opt/durapps/spark-store/bin/auto-install-policy/store.spark-app.ssinstall.policy /usr/share/polkit-1/actions/store.spark-app.ssinstall.policy
|
||||||
|
|
||||||
|
# Compile sender module
|
||||||
echo "Compiling the Sender module..."
|
echo "Compiling the Sender module..."
|
||||||
|
gcc -Wformat -Wformat-security -Werror=format-security /opt/durapps/spark-store/bin/ss-feedback/sender-d.sh.c -o /opt/durapps/spark-store/bin/ss-feedback/sender-d
|
||||||
gcc /opt/durapps/spark-store/bin/ss-feedback/sender-d.sh.c -o /opt/durapps/spark-store/bin/ss-feedback/sender-d
|
|
||||||
|
|
||||||
# Install key
|
# Install key
|
||||||
mkdir -p /tmp/spark-store-install/
|
mkdir -p /tmp/spark-store-install/
|
||||||
@@ -43,17 +40,13 @@ case "$1" in
|
|||||||
gpg --dearmor /tmp/spark-store-install/spark-store.asc
|
gpg --dearmor /tmp/spark-store-install/spark-store.asc
|
||||||
cp -f /tmp/spark-store-install/spark-store.asc.gpg /etc/apt/trusted.gpg.d/spark-store.gpg
|
cp -f /tmp/spark-store-install/spark-store.asc.gpg /etc/apt/trusted.gpg.d/spark-store.gpg
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# Run apt update to avoid users being fucked up by the non-exist dependency problem
|
# Run apt update to avoid users being fucked up by the non-exist dependency problem
|
||||||
# Now abandoned as aptss now run ssupdate everytime
|
# Now abandoned as aptss now run ssupdate everytime
|
||||||
#aptss ssupdate
|
#aptss ssupdate
|
||||||
|
|
||||||
|
|
||||||
# Start upgrade detect service
|
# Start upgrade detect service
|
||||||
systemctl enable spark-update-notifier
|
systemctl enable spark-update-notifier
|
||||||
service spark-update-notifier start
|
systemctl start spark-update-notifier
|
||||||
|
|
||||||
|
|
||||||
# Update certain caches
|
# Update certain caches
|
||||||
update-icon-caches /usr/share/icons/hicolor || true
|
update-icon-caches /usr/share/icons/hicolor || true
|
||||||
@@ -66,8 +59,6 @@ case "$1" in
|
|||||||
|
|
||||||
# Remove temp dir
|
# Remove temp dir
|
||||||
rm -rf /tmp/spark-store-install
|
rm -rf /tmp/spark-store-install
|
||||||
|
|
||||||
|
|
||||||
;;
|
;;
|
||||||
|
|
||||||
triggered)
|
triggered)
|
||||||
|
|||||||
40
debian/spark-store.prerm
vendored
40
debian/spark-store.prerm
vendored
@@ -2,46 +2,34 @@
|
|||||||
|
|
||||||
if [ "$1" = "remove" ] || [ "$1" = "purge" ] ; then
|
if [ "$1" = "remove" ] || [ "$1" = "purge" ] ; then
|
||||||
# Remove residual symbol links
|
# Remove residual symbol links
|
||||||
rm /usr/local/bin/spark-store
|
rm -f /usr/local/bin/spark-store
|
||||||
rm /usr/local/bin/ssinstall
|
rm -f /usr/local/bin/ssinstall
|
||||||
rm /usr/local/bin/spark-dstore-patch
|
rm -f /usr/local/bin/ssaudit
|
||||||
rm /usr/local/bin/ussinstall
|
rm -f /usr/local/bin/spark-dstore-patch
|
||||||
rm /usr/local/bin/ussremove
|
rm -f /usr/local/bin/ussinstall
|
||||||
rm /usr/local/bin/ss-apt-fast
|
rm -f /usr/local/bin/ussremove
|
||||||
rm /usr/bin/aptss
|
rm -f /usr/local/bin/ss-apt-fast
|
||||||
|
rm -f /usr/bin/aptss
|
||||||
|
|
||||||
rm -rf /etc/aptss/
|
rm -rf /etc/aptss/
|
||||||
|
|
||||||
# Remove Sender module
|
# Remove Sender module
|
||||||
rm /opt/durapps/spark-store/bin/ss-feedback/sender-d
|
rm -f /opt/durapps/spark-store/bin/ss-feedback/sender-d
|
||||||
|
|
||||||
# Remove residual symbol links to stop upgrade detect if exist
|
# Remove residual symbol links to stop upgrade detect
|
||||||
if [ -e /etc/xdg/autostart/spark-update-notifier.desktop ];then
|
rm -f /etc/xdg/autostart/spark-update-notifier.desktop
|
||||||
rm /etc/xdg/autostart/spark-update-notifier.desktop
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Shutdown services
|
# Shutdown services
|
||||||
service spark-update-notifier stop
|
systemctl stop spark-update-notifier
|
||||||
|
|
||||||
# Stop update detect service
|
# Stop update detect service
|
||||||
systemctl disable spark-update-notifier
|
systemctl disable spark-update-notifier
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# Clean the auto install polkit file if exist
|
# Clean the auto install polkit file if exist
|
||||||
if [ -f "/usr/share/polkit-1/actions/store.spark-app.ssinstall.policy" ] ; then
|
rm -f /usr/share/polkit-1/actions/store.spark-app.ssinstall.policy
|
||||||
rm /usr/share/polkit-1/actions/store.spark-app.ssinstall.policy
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Remove gpg key file
|
# Remove gpg key file
|
||||||
if [ -f "/etc/apt/trusted.gpg.d/spark-store.gpg" ] ; then
|
rm -f /etc/apt/trusted.gpg.d/spark-store.gpg
|
||||||
rm /etc/apt/trusted.gpg.d/spark-store.gpg
|
|
||||||
fi
|
|
||||||
|
|
||||||
apt-key del '9D9A A859 F750 24B1 A1EC E16E 0E41 D354 A29A 440C'
|
apt-key del '9D9A A859 F750 24B1 A1EC E16E 0E41 D354 A29A 440C'
|
||||||
|
|
||||||
else
|
else
|
||||||
|
|
||||||
echo "非卸载操作,不进行配置清理"
|
echo "非卸载操作,不进行配置清理"
|
||||||
|
|
||||||
fi
|
fi
|
||||||
|
|||||||
44
patchs/README.md
Normal file
44
patchs/README.md
Normal file
@@ -0,0 +1,44 @@
|
|||||||
|
# 补丁操作说明
|
||||||
|
|
||||||
|
- 克隆与构建本项目
|
||||||
|
|
||||||
|
> 用于 zinface-community-cmake-build-system.patch 补丁化构建方式
|
||||||
|
|
||||||
|
```shell
|
||||||
|
git clone https://gitee.com/deepin-community-store/spark-store
|
||||||
|
cd spark-store
|
||||||
|
git am < patchs/zinface-community-cmake-build-system.patch
|
||||||
|
make package
|
||||||
|
sudo dpkg -i build/*.deb
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
- 在应用补丁时,并对补丁进行的更新操作
|
||||||
|
|
||||||
|
```shell
|
||||||
|
# 切换到一个新的分支,即可开始进行补丁内的更新提交
|
||||||
|
git checkout -b cmake-build-system
|
||||||
|
|
||||||
|
# origin/dev 表示本仓库的 dev 开发分支
|
||||||
|
# 在应用过补丁,并产生了新的提交,即可在当前所在补丁更新分支内
|
||||||
|
# 相对基于 origin/dev 为参考,目前所包含的所有最新提交内容将生成为一个补丁文件(其中尾部为增量更新)
|
||||||
|
git format-patch --stdout origin/dev > patchs/zinface-community-cmake-build-system.patch
|
||||||
|
|
||||||
|
# 最后,回到你的原 dev 分支,将被改变的补丁文件进行提交
|
||||||
|
# 在推送完成后,即可放弃你在 cmake-build-system 分支中所有产生的内容(因为都已经进入补丁)
|
||||||
|
```
|
||||||
|
|
||||||
|
- 一些注意事项
|
||||||
|
|
||||||
|
```shell
|
||||||
|
# 在不了解补丁时,你需要认识一下补丁,但补丁与补丁之间有着不同的用法
|
||||||
|
# 本 patchs/zinface-community-cmake-build-system.patch 补丁为 cmake 化构建
|
||||||
|
|
||||||
|
# 关于补丁的一些方面
|
||||||
|
# 1. 首先你需要了解 git 是什么,以及简单的使用
|
||||||
|
# 2. 你需要了解补丁是什么,以及简单的使用(应用补丁)
|
||||||
|
# 3. 你需要了解如何创建一个补丁,最基本的就是相对于旧目标分支,将本分区新增的提交进行导出为补丁
|
||||||
|
# 4. 你可能只会将单个提交、或多个提交导出为补丁,但这还不够,你需要具有绝对的对于补丁的理解
|
||||||
|
# 5. 对于不同的目的补丁,应该是多个 patch 文件存在的形式
|
||||||
|
# 6. 最后,不管在什么时候,你在应用补丁前,你应该考虑是否应用到当前分支?为什么不切换到一个新的分支呢?
|
||||||
|
```
|
||||||
@@ -1,7 +1,7 @@
|
|||||||
From 9d1714ec7ceb3748bd151af059389ed10d37e676 Mon Sep 17 00:00:00 2001
|
From 2d49950909e0327b0ad72e008cb82ac97b7bae0e Mon Sep 17 00:00:00 2001
|
||||||
From: zinface <zinface@163.com>
|
From: zinface <zinface@163.com>
|
||||||
Date: Sun, 11 Dec 2022 22:27:23 +0800
|
Date: Sun, 11 Dec 2022 22:27:23 +0800
|
||||||
Subject: [PATCH 1/5] =?UTF-8?q?repo:=20=E4=B8=80=E6=AC=A1=E6=80=A7?=
|
Subject: [PATCH 01/11] =?UTF-8?q?repo:=20=E4=B8=80=E6=AC=A1=E6=80=A7?=
|
||||||
=?UTF-8?q?=E5=AF=BC=E5=85=A5=20spark=20=E9=AA=A8=E6=9E=B6=E4=BB=A5?=
|
=?UTF-8?q?=E5=AF=BC=E5=85=A5=20spark=20=E9=AA=A8=E6=9E=B6=E4=BB=A5?=
|
||||||
=?UTF-8?q?=E5=8F=98=E4=B8=BA=20cmake=20=E6=9E=84=E5=BB=BA?=
|
=?UTF-8?q?=E5=8F=98=E4=B8=BA=20cmake=20=E6=9E=84=E5=BB=BA?=
|
||||||
MIME-Version: 1.0
|
MIME-Version: 1.0
|
||||||
@@ -1789,10 +1789,10 @@ index 0000000..0fa070b
|
|||||||
2.20.1
|
2.20.1
|
||||||
|
|
||||||
|
|
||||||
From 1e1cb19995536d74626960ae863bf4c5cd9e3a4b Mon Sep 17 00:00:00 2001
|
From d2524f967848e6ba0d2c8a097183264d0d197d68 Mon Sep 17 00:00:00 2001
|
||||||
From: zinface <zinface@163.com>
|
From: zinface <zinface@163.com>
|
||||||
Date: Sun, 11 Dec 2022 22:37:26 +0800
|
Date: Sun, 11 Dec 2022 22:37:26 +0800
|
||||||
Subject: [PATCH 2/5] =?UTF-8?q?repo:=20=E5=A4=84=E7=90=86=20deb=20?=
|
Subject: [PATCH 02/11] =?UTF-8?q?repo:=20=E5=A4=84=E7=90=86=20deb=20?=
|
||||||
=?UTF-8?q?=E5=AE=89=E8=A3=85=E8=84=9A=E6=9C=AC=E7=9A=84=E9=97=AE=E9=A2=98?=
|
=?UTF-8?q?=E5=AE=89=E8=A3=85=E8=84=9A=E6=9C=AC=E7=9A=84=E9=97=AE=E9=A2=98?=
|
||||||
=?UTF-8?q?=EF=BC=8C=E5=AE=8C=E6=88=90=20cmake=20=E5=8C=96=E6=9E=84?=
|
=?UTF-8?q?=EF=BC=8C=E5=AE=8C=E6=88=90=20cmake=20=E5=8C=96=E6=9E=84?=
|
||||||
=?UTF-8?q?=E5=BB=BA?=
|
=?UTF-8?q?=E5=BB=BA?=
|
||||||
@@ -1856,10 +1856,10 @@ index 2ab24e7..38ad2d7 100644
|
|||||||
2.20.1
|
2.20.1
|
||||||
|
|
||||||
|
|
||||||
From 4f07b34bc268bc3c49ef1c51c524d50ccbbf6d07 Mon Sep 17 00:00:00 2001
|
From 7cd97a939b63143921936b9db3978d14f18a4f33 Mon Sep 17 00:00:00 2001
|
||||||
From: zinface <zinface@163.com>
|
From: zinface <zinface@163.com>
|
||||||
Date: Mon, 12 Dec 2022 00:50:01 +0800
|
Date: Mon, 12 Dec 2022 00:50:01 +0800
|
||||||
Subject: [PATCH 3/5] =?UTF-8?q?docs:=20=E6=B7=BB=E5=8A=A0=20Spark=20?=
|
Subject: [PATCH 03/11] =?UTF-8?q?docs:=20=E6=B7=BB=E5=8A=A0=20Spark=20?=
|
||||||
=?UTF-8?q?=E6=9E=84=E5=BB=BA=20=E4=B8=8E=20CMake=20=E6=9E=84=E5=BB=BA?=
|
=?UTF-8?q?=E6=9E=84=E5=BB=BA=20=E4=B8=8E=20CMake=20=E6=9E=84=E5=BB=BA?=
|
||||||
=?UTF-8?q?=E7=B3=BB=E7=BB=9F=E9=A2=84=E8=A7=88=E6=96=87=E6=A1=A3?=
|
=?UTF-8?q?=E7=B3=BB=E7=BB=9F=E9=A2=84=E8=A7=88=E6=96=87=E6=A1=A3?=
|
||||||
MIME-Version: 1.0
|
MIME-Version: 1.0
|
||||||
@@ -2184,10 +2184,10 @@ index 0000000..a807009
|
|||||||
2.20.1
|
2.20.1
|
||||||
|
|
||||||
|
|
||||||
From cb59139fcfd74b530a14f2a987aa38d28d403225 Mon Sep 17 00:00:00 2001
|
From bb128568ab7d1463c0002ffff470ad5c93364c99 Mon Sep 17 00:00:00 2001
|
||||||
From: zinface <zinface@163.com>
|
From: zinface <zinface@163.com>
|
||||||
Date: Thu, 15 Dec 2022 19:59:46 +0800
|
Date: Thu, 15 Dec 2022 19:59:46 +0800
|
||||||
Subject: [PATCH 4/5] =?UTF-8?q?repo:=20=E6=9B=B4=E6=96=B0=E7=94=A8?=
|
Subject: [PATCH 04/11] =?UTF-8?q?repo:=20=E6=9B=B4=E6=96=B0=E7=94=A8?=
|
||||||
=?UTF-8?q?=E4=BA=8E=20Qt5=20Svg=20=E4=BE=9D=E8=B5=96=E7=9A=84=E6=9E=84?=
|
=?UTF-8?q?=E4=BA=8E=20Qt5=20Svg=20=E4=BE=9D=E8=B5=96=E7=9A=84=E6=9E=84?=
|
||||||
=?UTF-8?q?=E5=BB=BA=E5=86=85=E5=AE=B9?=
|
=?UTF-8?q?=E5=BB=BA=E5=86=85=E5=AE=B9?=
|
||||||
MIME-Version: 1.0
|
MIME-Version: 1.0
|
||||||
@@ -2236,10 +2236,10 @@ index b56399f..67e29b6 100644
|
|||||||
2.20.1
|
2.20.1
|
||||||
|
|
||||||
|
|
||||||
From 72e5ca47cef718cdbd4ea45134d574874fb43ba9 Mon Sep 17 00:00:00 2001
|
From 877a52f4b753f55e087a6c58794d690fabb6ddbb Mon Sep 17 00:00:00 2001
|
||||||
From: zinface <zinface@163.com>
|
From: zinface <zinface@163.com>
|
||||||
Date: Mon, 19 Dec 2022 02:58:17 +0800
|
Date: Mon, 19 Dec 2022 02:58:17 +0800
|
||||||
Subject: [PATCH 5/5] =?UTF-8?q?repo:=20=E6=9B=B4=E6=96=B0=E7=94=A8?=
|
Subject: [PATCH 05/11] =?UTF-8?q?repo:=20=E6=9B=B4=E6=96=B0=E7=94=A8?=
|
||||||
=?UTF-8?q?=E4=BA=8E=E6=94=AF=E6=8C=81=20BaseWidgetOpacity=20=E5=9F=BA?=
|
=?UTF-8?q?=E4=BA=8E=E6=94=AF=E6=8C=81=20BaseWidgetOpacity=20=E5=9F=BA?=
|
||||||
=?UTF-8?q?=E7=A1=80=E7=B1=BB=E7=9A=84=E6=9E=84=E5=BB=BA?=
|
=?UTF-8?q?=E7=A1=80=E7=B1=BB=E7=9A=84=E6=9E=84=E5=BB=BA?=
|
||||||
MIME-Version: 1.0
|
MIME-Version: 1.0
|
||||||
@@ -2282,3 +2282,348 @@ index 14530e1..b5e32d8 100644
|
|||||||
--
|
--
|
||||||
2.20.1
|
2.20.1
|
||||||
|
|
||||||
|
|
||||||
|
From f89bb6a145f2a77fa0e1b55b3ad17ade69c53a69 Mon Sep 17 00:00:00 2001
|
||||||
|
From: zinface <zinface@163.com>
|
||||||
|
Date: Mon, 30 Jan 2023 20:48:25 +0800
|
||||||
|
Subject: [PATCH 06/11] =?UTF-8?q?spark:=20=E5=88=9B=E5=BB=BA=E6=96=B0?=
|
||||||
|
=?UTF-8?q?=E7=9A=84=E6=A8=A1=E5=9D=97=E7=94=A8=E4=BA=8E=20debian/changelo?=
|
||||||
|
=?UTF-8?q?g=20=E7=9A=84=E7=89=88=E6=9C=AC=E5=8F=B7=E9=87=8D=E5=86=99?=
|
||||||
|
=?UTF-8?q?=E8=A7=84=E5=88=99?=
|
||||||
|
MIME-Version: 1.0
|
||||||
|
Content-Type: text/plain; charset=UTF-8
|
||||||
|
Content-Transfer-Encoding: 8bit
|
||||||
|
|
||||||
|
1. SparkDebianChangelogVersion.cmake
|
||||||
|
在此文件中提供 spark_debian_changelog_override_version 宏:
|
||||||
|
基于指定的 debian/changelog 文件并用于读取最新版本号并覆盖到项目版本
|
||||||
|
|
||||||
|
@Since: v4.0.0
|
||||||
|
---
|
||||||
|
CMakeLists.txt | 4 ++
|
||||||
|
cmake/SparkDebianChangelogVersion.cmake | 58 +++++++++++++++++++++++++
|
||||||
|
2 files changed, 62 insertions(+)
|
||||||
|
create mode 100644 cmake/SparkDebianChangelogVersion.cmake
|
||||||
|
|
||||||
|
diff --git a/CMakeLists.txt b/CMakeLists.txt
|
||||||
|
index b5e32d8..73221bc 100644
|
||||||
|
--- a/CMakeLists.txt
|
||||||
|
+++ b/CMakeLists.txt
|
||||||
|
@@ -11,6 +11,10 @@ include(cmake/SparkFindDtkConfig.cmake) # 提供了 target_link_dtk 用
|
||||||
|
include(cmake/SparkTranslatorConfig.cmake) # 提供了 qt5 ts转qm 的操作,最终生成 SPARK_QM_TRANSLATIONS 变量用于构建可执行文件时参与编译
|
||||||
|
include(cmake/SparkMacrosExtendConfig.cmake) # 使用了 spark_ 宏基于已提供的宏参数自动展开构建可执行目标文件
|
||||||
|
include(cmake/SparkInstallMacrosConfig.cmake) # 提供了 spark_install 开头的 macro 宏用于安装 target、file、program、directory、changelog 等内容
|
||||||
|
+include(cmake/SparkDebianChangelogVersion.cmake)# 提供了 spark_debian_ 开头的宏进行进行覆盖 PROJECT_VERSION
|
||||||
|
+
|
||||||
|
+# 在开始之前,使用项目中提供的 debian/changelog 进行重写本构建系统的 PROJECT_VERSION
|
||||||
|
+spark_debian_changelog_override_version(debian/changelog)
|
||||||
|
|
||||||
|
# 资源文件路径
|
||||||
|
set(QRC_SOURCES "src/assets/assets.qrc")
|
||||||
|
diff --git a/cmake/SparkDebianChangelogVersion.cmake b/cmake/SparkDebianChangelogVersion.cmake
|
||||||
|
new file mode 100644
|
||||||
|
index 0000000..9d8bca2
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/cmake/SparkDebianChangelogVersion.cmake
|
||||||
|
@@ -0,0 +1,58 @@
|
||||||
|
+# SparkDebianChangelogVersion
|
||||||
|
+
|
||||||
|
+# 尝试读取 debian/changelog 文件的第一行数据,并查找
|
||||||
|
+# spark-store (4.2.2) stable; urgency=medium
|
||||||
|
+# 将 (version) 信息应用用于 PROJECT_VERSION
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+macro(spark_debian_changelog_override_version _CHANGELOG_FILE_PATH)
|
||||||
|
+ set(CHANGELOG_FILE_PATH ${_CHANGELOG_FILE_PATH})
|
||||||
|
+ set(CHANGELOG_FILE_EXISTS FALSE)
|
||||||
|
+
|
||||||
|
+ # 首次判断,如果判断文件不存在,将尽可能的判断文件是存在的
|
||||||
|
+ if(NOT EXISTS ${CHANGELOG_FILE_PATH})
|
||||||
|
+
|
||||||
|
+ # 在 CMake v3.19 起,可以使用 file(REAL_PATH <path> <out-var>) 进行获取 path 的绝对路径
|
||||||
|
+ if(CMAKE_VERSION GREATER_EQUAL 3.19)
|
||||||
|
+ file(REAL_PATH ${CHANGELOG_FILE_PATH} CHANGELOG_FILE_ABSOLUTE_PATH)
|
||||||
|
+ if(EXISTS ${CHANGELOG_FILE_ABSOLUTE_PATH})
|
||||||
|
+ set(CHANGELOG_FILE_EXISTS TRUE)
|
||||||
|
+ set(CHANGELOG_FILE_PATH ${CHANGELOG_FILE_ABSOLUTE_PATH})
|
||||||
|
+ endif(EXISTS ${CHANGELOG_FILE_ABSOLUTE_PATH})
|
||||||
|
+ endif(CMAKE_VERSION GREATER_EQUAL 3.19)
|
||||||
|
+
|
||||||
|
+ # 第二次判断与处理 使用 file(SIZE) 方式
|
||||||
|
+ if(NOT CHANGELOG_FILE_EXISTS)
|
||||||
|
+ file(SIZE ${CHANGELOG_FILE_PATH} CHANGELOG_FILE_SIZE)
|
||||||
|
+ if(CHANGELOG_FILE_SIZE GREATER 0)
|
||||||
|
+ set(CHANGELOG_FILE_EXISTS TRUE)
|
||||||
|
+ endif(CHANGELOG_FILE_SIZE GREATER 0)
|
||||||
|
+ endif(NOT CHANGELOG_FILE_EXISTS)
|
||||||
|
+
|
||||||
|
+ # 第三次判断与处理 使用路径拼接方式
|
||||||
|
+ if(NOT CHANGELOG_FILE_EXISTS)
|
||||||
|
+ if(EXISTS ${CMAKE_SOURCE_DIR}/${CHANGELOG_FILE_PATH})
|
||||||
|
+ set(CHANGELOG_FILE_PATH ${CMAKE_SOURCE_DIR}/${CHANGELOG_FILE_PATH})
|
||||||
|
+ set(CHANGELOG_FILE_EXISTS TRUE)
|
||||||
|
+ endif(EXISTS ${CMAKE_SOURCE_DIR}/${CHANGELOG_FILE_PATH})
|
||||||
|
+ endif(NOT CHANGELOG_FILE_EXISTS)
|
||||||
|
+ endif(NOT EXISTS ${CHANGELOG_FILE_PATH})
|
||||||
|
+
|
||||||
|
+ message("> V = ${CHANGELOG_FILE_PATH}")
|
||||||
|
+ if(CHANGELOG_FILE_EXISTS)
|
||||||
|
+ file(READ ${CHANGELOG_FILE_PATH} CHANGELOG_CONTENT LIMIT 20)
|
||||||
|
+
|
||||||
|
+ string(FIND ${CHANGELOG_CONTENT} "(" V_PRE) # +1 to V_BEGIN
|
||||||
|
+ string(FIND ${CHANGELOG_CONTENT} ")" V_END)
|
||||||
|
+
|
||||||
|
+ math(EXPR V_BEGIN "${V_PRE}+1")
|
||||||
|
+ math(EXPR V_LENGTH "${V_END}-${V_BEGIN}")
|
||||||
|
+
|
||||||
|
+ string(SUBSTRING ${CHANGELOG_CONTENT} ${V_BEGIN} ${V_LENGTH} V)
|
||||||
|
+
|
||||||
|
+ message("> V = ${CHANGELOG_CONTENT}")
|
||||||
|
+ message("> V = [${V}]")
|
||||||
|
+
|
||||||
|
+ set(PROJECT_VERSION ${V})
|
||||||
|
+ endif(CHANGELOG_FILE_EXISTS)
|
||||||
|
+endmacro(spark_debian_changelog_override_version _CHANGELOG_FILE_PATH)
|
||||||
|
--
|
||||||
|
2.20.1
|
||||||
|
|
||||||
|
|
||||||
|
From b26bac7572ab7477ab4b94174fbdece759be8bc7 Mon Sep 17 00:00:00 2001
|
||||||
|
From: zinface <zinface@163.com>
|
||||||
|
Date: Mon, 30 Jan 2023 21:23:15 +0800
|
||||||
|
Subject: [PATCH 07/11] =?UTF-8?q?spark:=20=E5=AF=B9=20SparkDebianChangelog?=
|
||||||
|
=?UTF-8?q?Version.cmake=20=E6=A8=A1=E5=9D=97=E7=9A=84=E6=89=A9=E5=B1=95?=
|
||||||
|
MIME-Version: 1.0
|
||||||
|
Content-Type: text/plain; charset=UTF-8
|
||||||
|
Content-Transfer-Encoding: 8bit
|
||||||
|
|
||||||
|
1. 增加 SPARK_OVERRIDE_VERSION 的文件输出
|
||||||
|
以解决 Makefile 中无法明确多个 deb 包时无法确定最新版本的情况
|
||||||
|
---
|
||||||
|
Makefile | 15 +++++++++++++--
|
||||||
|
cmake/SparkDebianChangelogVersion.cmake | 1 +
|
||||||
|
2 files changed, 14 insertions(+), 2 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/Makefile b/Makefile
|
||||||
|
index c673c76..81ca078 100644
|
||||||
|
--- a/Makefile
|
||||||
|
+++ b/Makefile
|
||||||
|
@@ -8,6 +8,17 @@ SUFFIX=_$(OSID)$(OSRELEASE)
|
||||||
|
endif
|
||||||
|
|
||||||
|
PROJECT_NAME=spark-store
|
||||||
|
+PROJECT_VERSION=*
|
||||||
|
+
|
||||||
|
+ifneq ($(wildcard build/SPARK_OVERRIDE_VERSION),)
|
||||||
|
+SPARK_OVERRIDE_VERSION=`cat build/SPARK_OVERRIDE_VERSION`
|
||||||
|
+.PHONY: override-version
|
||||||
|
+override-version:
|
||||||
|
+ @echo $(SPARK_OVERRIDE_VERSION)
|
||||||
|
+ @echo "wildcard - good: $(wildcard build/SPARK_OVERRIDE_VERSION)"
|
||||||
|
+ @echo "wildcard - bad.: $(wildcard build/SPARK_OVERRIDE_VERSIONS)"
|
||||||
|
+PROJECT_VERSION=$(SPARK_OVERRIDE_VERSION)-
|
||||||
|
+endif
|
||||||
|
|
||||||
|
all:
|
||||||
|
mkdir -p build
|
||||||
|
@@ -44,7 +55,7 @@ debian-build-scripts:
|
||||||
|
package: release debian-build-scripts
|
||||||
|
cd build && make package
|
||||||
|
tree build/_CPack_Packages/Linux/DEB/$(PROJECT_NAME)-*
|
||||||
|
- dpkg-deb --contents build/$(PROJECT_NAME)_*$(CALENDAR)*$(SUFFIX).deb
|
||||||
|
+ dpkg-deb --contents build/$(PROJECT_NAME)_$(PROJECT_VERSION)$(CALENDAR)*$(SUFFIX).deb
|
||||||
|
# cd build/_CPack_Packages/Linux/DEB/$(PROJECT_NAME)_*$(CALENDAR)*$(SUFFIX).deb && find .
|
||||||
|
|
||||||
|
builddeps:
|
||||||
|
@@ -54,7 +65,7 @@ cpus:
|
||||||
|
@echo "CPU数量: $(CPUS)"
|
||||||
|
|
||||||
|
copytosource:package
|
||||||
|
- cp build/$(PROJECT_NAME)_*$(CALENDAR)*.deb .
|
||||||
|
+ cp build/$(PROJECT_NAME)_$(PROJECT_VERSION)$(CALENDAR)*.deb .
|
||||||
|
|
||||||
|
# 进入 qdebug 模式,在 deepin 中默认被禁用,可 env | grep QT 查看,并在 /etc/X11/Xsession.d/00deepin-dde-env 配置中已定义
|
||||||
|
# 1. 禁止 qt 的 debug 打印: qt.*.debug=false
|
||||||
|
diff --git a/cmake/SparkDebianChangelogVersion.cmake b/cmake/SparkDebianChangelogVersion.cmake
|
||||||
|
index 9d8bca2..65e1c16 100644
|
||||||
|
--- a/cmake/SparkDebianChangelogVersion.cmake
|
||||||
|
+++ b/cmake/SparkDebianChangelogVersion.cmake
|
||||||
|
@@ -54,5 +54,6 @@ macro(spark_debian_changelog_override_version _CHANGELOG_FILE_PATH)
|
||||||
|
message("> V = [${V}]")
|
||||||
|
|
||||||
|
set(PROJECT_VERSION ${V})
|
||||||
|
+ file(WRITE ${CMAKE_BINARY_DIR}/SPARK_OVERRIDE_VERSION ${V})
|
||||||
|
endif(CHANGELOG_FILE_EXISTS)
|
||||||
|
endmacro(spark_debian_changelog_override_version _CHANGELOG_FILE_PATH)
|
||||||
|
--
|
||||||
|
2.20.1
|
||||||
|
|
||||||
|
|
||||||
|
From 26f00f79a2b8613477059beb6c2f492bc24a7bb5 Mon Sep 17 00:00:00 2001
|
||||||
|
From: zinface <zinface@163.com>
|
||||||
|
Date: Mon, 30 Jan 2023 23:17:24 +0800
|
||||||
|
Subject: [PATCH 08/11] =?UTF-8?q?repo:=20=E5=A4=84=E7=90=86=20v4.2.2=20?=
|
||||||
|
=?UTF-8?q?=E7=89=88=E6=9C=AC=E6=97=B6=E6=9C=9F=E6=96=B0=E5=A2=9E=E7=9A=84?=
|
||||||
|
=?UTF-8?q?=E5=AE=89=E8=A3=85=E6=96=87=E4=BB=B6?=
|
||||||
|
MIME-Version: 1.0
|
||||||
|
Content-Type: text/plain; charset=UTF-8
|
||||||
|
Content-Transfer-Encoding: 8bit
|
||||||
|
|
||||||
|
pkg/usr/share/ssinstall/transhell
|
||||||
|
-> /usr/share/ssinstall
|
||||||
|
---
|
||||||
|
CMakeLists.txt | 5 +++++
|
||||||
|
cmake/SparkInstallMacrosConfig.cmake | 2 +-
|
||||||
|
2 files changed, 6 insertions(+), 1 deletion(-)
|
||||||
|
|
||||||
|
diff --git a/CMakeLists.txt b/CMakeLists.txt
|
||||||
|
index 73221bc..22a788d 100644
|
||||||
|
--- a/CMakeLists.txt
|
||||||
|
+++ b/CMakeLists.txt
|
||||||
|
@@ -86,6 +86,11 @@ spark_install_file(/usr/share/icons/hicolor/scalable/apps
|
||||||
|
spark_install_program(/tmp/spark-store-install
|
||||||
|
pkg/tmp/spark-store-install/feedback.sh)
|
||||||
|
|
||||||
|
+# 安装什么翻译? Since: v4.2.2
|
||||||
|
+spark_install_directory(/usr/share/ssinstall
|
||||||
|
+ pkg/usr/share/ssinstall/transhell
|
||||||
|
+)
|
||||||
|
+
|
||||||
|
# 安装 qm 文件?
|
||||||
|
spark_install_file(/usr/share/spark-store/translations
|
||||||
|
${SPARK_QM_TRANSLATIONS})
|
||||||
|
diff --git a/cmake/SparkInstallMacrosConfig.cmake b/cmake/SparkInstallMacrosConfig.cmake
|
||||||
|
index bbb958a..c7ea53b 100644
|
||||||
|
--- a/cmake/SparkInstallMacrosConfig.cmake
|
||||||
|
+++ b/cmake/SparkInstallMacrosConfig.cmake
|
||||||
|
@@ -79,7 +79,7 @@ macro(spark_install_directory INSTALL_DIRECTORY_DIR INSTALL_DIRECOTRY)
|
||||||
|
# message(FATAL_ERROR " directory: ${INSTALL_DIRECTORY_FIND_INDEX_SUBSTRING_FILE_GLOB_LIST_LENGTH}")
|
||||||
|
|
||||||
|
else()
|
||||||
|
- message(FATAL_ERROR "install: ${INSTALL_DIRECTORY_DIR}")
|
||||||
|
+ # message(FATAL_ERROR "install: ${INSTALL_DIRECTORY_DIR}")
|
||||||
|
|
||||||
|
install(DIRECTORY
|
||||||
|
${INSTALL_DIRECOTRY} ${ARGN}
|
||||||
|
--
|
||||||
|
2.20.1
|
||||||
|
|
||||||
|
|
||||||
|
From e4401b16037cb3b1b10c59f4c7a0fa3c2cd563b3 Mon Sep 17 00:00:00 2001
|
||||||
|
From: zinface <zinface@163.com>
|
||||||
|
Date: Mon, 30 Jan 2023 23:18:44 +0800
|
||||||
|
Subject: [PATCH 09/11] =?UTF-8?q?spark:=20=E5=AF=B9=20SparkTranslatorConfi?=
|
||||||
|
=?UTF-8?q?g.cmake=20=E6=A8=A1=E5=9D=97=E7=9A=84=E6=89=A9=E5=B1=95?=
|
||||||
|
MIME-Version: 1.0
|
||||||
|
Content-Type: text/plain; charset=UTF-8
|
||||||
|
Content-Transfer-Encoding: 8bit
|
||||||
|
|
||||||
|
1. 增加 SPARK_QM_TRANSLATIONS 的文件输出
|
||||||
|
无任何其它变动
|
||||||
|
---
|
||||||
|
cmake/SparkTranslatorConfig.cmake | 5 +++++
|
||||||
|
1 file changed, 5 insertions(+)
|
||||||
|
|
||||||
|
diff --git a/cmake/SparkTranslatorConfig.cmake b/cmake/SparkTranslatorConfig.cmake
|
||||||
|
index 272dd9d..689e70d 100644
|
||||||
|
--- a/cmake/SparkTranslatorConfig.cmake
|
||||||
|
+++ b/cmake/SparkTranslatorConfig.cmake
|
||||||
|
@@ -12,6 +12,11 @@ endforeach(item IN LISTS SPARK_TRANSLATIONS)
|
||||||
|
qt5_add_translation(SPARK_QM_TRANSLATIONS
|
||||||
|
${SPARK_TRANSLATIONS})
|
||||||
|
|
||||||
|
+file(WRITE ${CMAKE_BINARY_DIR}/SPARK_QM_TRANSLATIONS "")
|
||||||
|
+foreach(item IN LISTS SPARK_QM_TRANSLATIONS)
|
||||||
|
+ file(APPEND ${CMAKE_BINARY_DIR}/SPARK_QM_TRANSLATIONS "${item}\n")
|
||||||
|
+endforeach(item IN LISTS SPARK_QM_TRANSLATIONS)
|
||||||
|
+
|
||||||
|
message("translator(ts -> qm):")
|
||||||
|
foreach(item IN LISTS SPARK_QM_TRANSLATIONS)
|
||||||
|
message("-> ${item}")
|
||||||
|
--
|
||||||
|
2.20.1
|
||||||
|
|
||||||
|
|
||||||
|
From 2d8046099776e3909359ce49818ae28378af930c Mon Sep 17 00:00:00 2001
|
||||||
|
From: zinface <zinface@163.com>
|
||||||
|
Date: Mon, 30 Jan 2023 23:20:12 +0800
|
||||||
|
Subject: [PATCH 10/11] =?UTF-8?q?make:=20=E5=A4=84=E7=90=86=E9=BB=98?=
|
||||||
|
=?UTF-8?q?=E8=AE=A4=20make=20=E7=9B=AE=E6=A0=87=E4=B8=BA=20override-versi?=
|
||||||
|
=?UTF-8?q?on=20=E7=9A=84=E9=97=AE=E9=A2=98?=
|
||||||
|
MIME-Version: 1.0
|
||||||
|
Content-Type: text/plain; charset=UTF-8
|
||||||
|
Content-Transfer-Encoding: 8bit
|
||||||
|
|
||||||
|
---
|
||||||
|
Makefile | 16 ++++++++++------
|
||||||
|
1 file changed, 10 insertions(+), 6 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/Makefile b/Makefile
|
||||||
|
index 81ca078..076502c 100644
|
||||||
|
--- a/Makefile
|
||||||
|
+++ b/Makefile
|
||||||
|
@@ -12,11 +12,6 @@ PROJECT_VERSION=*
|
||||||
|
|
||||||
|
ifneq ($(wildcard build/SPARK_OVERRIDE_VERSION),)
|
||||||
|
SPARK_OVERRIDE_VERSION=`cat build/SPARK_OVERRIDE_VERSION`
|
||||||
|
-.PHONY: override-version
|
||||||
|
-override-version:
|
||||||
|
- @echo $(SPARK_OVERRIDE_VERSION)
|
||||||
|
- @echo "wildcard - good: $(wildcard build/SPARK_OVERRIDE_VERSION)"
|
||||||
|
- @echo "wildcard - bad.: $(wildcard build/SPARK_OVERRIDE_VERSIONS)"
|
||||||
|
PROJECT_VERSION=$(SPARK_OVERRIDE_VERSION)-
|
||||||
|
endif
|
||||||
|
|
||||||
|
@@ -82,4 +77,13 @@ copytosource:package
|
||||||
|
enter-qdebug-mode:
|
||||||
|
# 进入新的 bash 环境
|
||||||
|
@# export QT_LOGGING_RULES=".debug=true; qt.*.debug=false; dtk.*.debug=false; dde.*.debug=false; qtc*=false; " && bash
|
||||||
|
- export QT_LOGGING_RULES=".debug=true" && bash
|
||||||
|
\ No newline at end of file
|
||||||
|
+ export QT_LOGGING_RULES=".debug=true" && bash
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+ifneq ($(wildcard build/SPARK_OVERRIDE_VERSION),)
|
||||||
|
+.PHONY: override-version
|
||||||
|
+override-version:
|
||||||
|
+ @echo $(SPARK_OVERRIDE_VERSION)
|
||||||
|
+ @echo "wildcard - good: $(wildcard build/SPARK_OVERRIDE_VERSION)"
|
||||||
|
+ @echo "wildcard - bad.: $(wildcard build/SPARK_OVERRIDE_VERSIONS)"
|
||||||
|
+endif
|
||||||
|
\ No newline at end of file
|
||||||
|
--
|
||||||
|
2.20.1
|
||||||
|
|
||||||
|
|
||||||
|
From 043e6fb78e2bcb1a6fecefe2ba9aceb9df84e96e Mon Sep 17 00:00:00 2001
|
||||||
|
From: zinface <zinface@163.com>
|
||||||
|
Date: Sun, 5 Feb 2023 16:09:40 +0800
|
||||||
|
Subject: [PATCH 11/11] =?UTF-8?q?spark:=20=E5=A4=84=E7=90=86=E7=89=88?=
|
||||||
|
=?UTF-8?q?=E6=9C=AC=E5=8F=B7=204.2.3~test1=20=E6=97=B6=E9=BB=98=E8=AE=A4?=
|
||||||
|
=?UTF-8?q?=E7=9A=84=E6=88=AA=E5=8F=96=E5=AD=97=E7=AC=A6=E6=95=B0=E8=BF=87?=
|
||||||
|
=?UTF-8?q?=E7=9F=AD=E9=97=AE=E9=A2=98?=
|
||||||
|
MIME-Version: 1.0
|
||||||
|
Content-Type: text/plain; charset=UTF-8
|
||||||
|
Content-Transfer-Encoding: 8bit
|
||||||
|
|
||||||
|
---
|
||||||
|
cmake/SparkDebianChangelogVersion.cmake | 3 ++-
|
||||||
|
1 file changed, 2 insertions(+), 1 deletion(-)
|
||||||
|
|
||||||
|
diff --git a/cmake/SparkDebianChangelogVersion.cmake b/cmake/SparkDebianChangelogVersion.cmake
|
||||||
|
index 65e1c16..3ed5fa2 100644
|
||||||
|
--- a/cmake/SparkDebianChangelogVersion.cmake
|
||||||
|
+++ b/cmake/SparkDebianChangelogVersion.cmake
|
||||||
|
@@ -40,7 +40,8 @@ macro(spark_debian_changelog_override_version _CHANGELOG_FILE_PATH)
|
||||||
|
|
||||||
|
message("> V = ${CHANGELOG_FILE_PATH}")
|
||||||
|
if(CHANGELOG_FILE_EXISTS)
|
||||||
|
- file(READ ${CHANGELOG_FILE_PATH} CHANGELOG_CONTENT LIMIT 20)
|
||||||
|
+ file(READ ${CHANGELOG_FILE_PATH} CHANGELOG_CONTENT LIMIT 30)
|
||||||
|
+ # fix: spark-store (4.2.3~test1) 已经超过 20 字符位,所以使用 30 进行保守计算
|
||||||
|
|
||||||
|
string(FIND ${CHANGELOG_CONTENT} "(" V_PRE) # +1 to V_BEGIN
|
||||||
|
string(FIND ${CHANGELOG_CONTENT} ")" V_END)
|
||||||
|
--
|
||||||
|
2.20.1
|
||||||
|
|
||||||
|
|||||||
26
pkg/usr/share/dsg/org.deepin.dtkwidget.feature-display.json
Normal file
26
pkg/usr/share/dsg/org.deepin.dtkwidget.feature-display.json
Normal file
@@ -0,0 +1,26 @@
|
|||||||
|
{
|
||||||
|
"magic": "dsg.config.meta",
|
||||||
|
"version": "1.0",
|
||||||
|
"contents": {
|
||||||
|
"featureUpdated": {
|
||||||
|
"value": false,
|
||||||
|
"serial": 0,
|
||||||
|
"flags": [],
|
||||||
|
"name": "Whether the application has new feature updates",
|
||||||
|
"name[zh_CN]": "配置应用的更新状态",
|
||||||
|
"description": "Configure the update status of the application",
|
||||||
|
"permissions": "readwrite",
|
||||||
|
"visibility": "public"
|
||||||
|
},
|
||||||
|
"autoDisplayFeature": {
|
||||||
|
"value": false,
|
||||||
|
"serial": 0,
|
||||||
|
"flags": [],
|
||||||
|
"name": "The application automatically display new features once",
|
||||||
|
"name[zh_CN]": "配置应用是否自动展示一次新特性",
|
||||||
|
"description": "The application automatically display updated contents once",
|
||||||
|
"permissions": "readwrite",
|
||||||
|
"visibility": "public"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,4 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
TRANSHELL_CONTENT_HASH_CHECK_FAILED="Failed in checking package hash! \nPossibly reason can be the package is broken, laggy in sync of Spark Store repository, or, there is a malware attempt to attack. \nIf you don't know what happend, please try install again after execute the command below\n sudo aptss ssupdate\n\nIf the problem still happen, please click APP Feedback button in the APP information page to feedback to us.\n\n If you are in the Audition Group,Please use ssaudit instead of ssinstall to audit APPs,for ssinstall is used for password-free install now.\nIf you want to install an app that is removed from Spark Store repository,you can also use ssaudit."
|
||||||
|
TRANSHELL_CONTENT_PLEASE_RUN_AS_ROOT="Please run ssinstall as root"
|
||||||
|
TRANSHELL_CONTENT_FILE_NOT_EXIST="File not exist"
|
||||||
@@ -0,0 +1,4 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
TRANSHELL_CONTENT_HASH_CHECK_FAILED="软件包校验失败!这不应该发生!\n可能是因为软件包已损坏,星火仓库未同步,或者最坏的情况:恶意软件尝试利用自动安装来入侵系统!\n如果你不清楚发生了什么,请执行 sudo aptss ssupdate 后再尝试安装。\n如果问题仍然存在,请在应用信息界面点击 应用反馈 来提交反馈给我们!\n\n 如果你是审核人员,请使用 ssaudit来替代ssinstall进行审核工作,因为现在ssinstall已经被用于免密安装。\n如果你正在尝试安装已经下架的星火应用,也可用ssaudit来替代ssinstall"
|
||||||
|
TRANSHELL_CONTENT_PLEASE_RUN_AS_ROOT="请使用root启动ssinstall"
|
||||||
|
TRANSHELL_CONTENT_FILE_NOT_EXIST="文件不存在"
|
||||||
@@ -8,18 +8,23 @@ TARGET = spark-store
|
|||||||
TEMPLATE = subdirs
|
TEMPLATE = subdirs
|
||||||
|
|
||||||
CONFIG += ordered
|
CONFIG += ordered
|
||||||
|
CONFIG += wayland-compositor
|
||||||
|
|
||||||
SUBDIRS += \
|
SUBDIRS += \
|
||||||
src/spark-dstore-patch \
|
src/spark-dstore-patch \
|
||||||
src/spark-store.pro
|
src/spark-store.pro
|
||||||
|
|
||||||
#TRANSLATIONS += \
|
# https://wiki.debian.org/Hardening
|
||||||
# translations/spark-store_fr.ts \
|
QMAKE_CFLAGS *= $(shell dpkg-buildflags --get CFLAGS)
|
||||||
# translations/spark-store_en.ts \
|
QMAKE_CPPFLAGS *= $(shell dpkg-buildflags --get CPPFLAGS)
|
||||||
# translations/spark-store_zh_CN.ts
|
QMAKE_CXXFLAGS *= $(shell dpkg-buildflags --get CXXFLAGS)
|
||||||
|
QMAKE_LFLAGS *= $(shell dpkg-buildflags --get LDFLAGS)
|
||||||
|
|
||||||
# Update translation files
|
# Update translation files
|
||||||
CONFIG(release, debug|release): system(bash $${PWD}/translate_generation.sh)
|
CONFIG(release, debug | release) {
|
||||||
|
system(bash $${PWD}/translate_update.sh)
|
||||||
|
system(bash $${PWD}/translate_generation.sh)
|
||||||
|
}
|
||||||
|
|
||||||
# Rules for deployment
|
# Rules for deployment
|
||||||
tool.files += tool/*
|
tool.files += tool/*
|
||||||
@@ -49,6 +54,9 @@ polkit-1.path = /usr/share/polkit-1/actions/
|
|||||||
icon.files += pkg/usr/share/icons/hicolor/scalable/apps/spark-store.svg
|
icon.files += pkg/usr/share/icons/hicolor/scalable/apps/spark-store.svg
|
||||||
icon.path = /usr/share/icons/hicolor/scalable/apps
|
icon.path = /usr/share/icons/hicolor/scalable/apps
|
||||||
|
|
||||||
|
ssinstall-transhell.files += pkg/usr/share/ssinstall/transhell
|
||||||
|
ssinstall-transhell.path = /usr/share/ssinstall/
|
||||||
|
|
||||||
tmp.files += pkg/tmp/spark-store-install/feedback.sh
|
tmp.files += pkg/tmp/spark-store-install/feedback.sh
|
||||||
tmp.path = /tmp/spark-store-install
|
tmp.path = /tmp/spark-store-install
|
||||||
|
|
||||||
@@ -57,7 +65,7 @@ INSTALLS += \
|
|||||||
qm \
|
qm \
|
||||||
desktop \
|
desktop \
|
||||||
icon \
|
icon \
|
||||||
# preferences \
|
ssinstall-transhell \
|
||||||
# sourceslist \
|
# sourceslist \
|
||||||
tmp \
|
tmp \
|
||||||
service \
|
service \
|
||||||
|
|||||||
212
src/application.cpp
Normal file
212
src/application.cpp
Normal file
@@ -0,0 +1,212 @@
|
|||||||
|
#include "application.h"
|
||||||
|
#include "mainwindow-dtk.h"
|
||||||
|
#include "utils/utils.h"
|
||||||
|
|
||||||
|
#include <DPlatformWindowHandle>
|
||||||
|
#include <DLog>
|
||||||
|
#include <DGuiApplicationHelper>
|
||||||
|
#include <DAboutDialog>
|
||||||
|
#if (DTK_VERSION >= DTK_VERSION_CHECK(5, 6, 4, 0))
|
||||||
|
#include <DFeatureDisplayDialog>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <QSettings>
|
||||||
|
#include <QStandardPaths>
|
||||||
|
|
||||||
|
DCORE_USE_NAMESPACE
|
||||||
|
|
||||||
|
Application::Application(int &argc, char **argv)
|
||||||
|
: DApplication(argc, argv)
|
||||||
|
{
|
||||||
|
// Wayland 环境下使用,防止子控件 Native 化
|
||||||
|
if (!DPlatformWindowHandle::pluginVersion().isEmpty()) {
|
||||||
|
setAttribute(Qt::AA_DontCreateNativeWidgetSiblings, true);
|
||||||
|
}
|
||||||
|
setAttribute(Qt::AA_UseHighDpiPixmaps);
|
||||||
|
|
||||||
|
setQuitOnLastWindowClosed(false); // 启用托盘图标时,关闭窗口程序仍然运行
|
||||||
|
|
||||||
|
loadTranslator(); // 载入翻译
|
||||||
|
|
||||||
|
setOrganizationName("spark-union");
|
||||||
|
setApplicationName("spark-store"); // 影响 ~/.config/spark-union ~/.local/share/spark-union 下文件夹名称
|
||||||
|
setApplicationDisplayName(QObject::tr("Spark Store")); // 设置窗口显示标题 (Wayland 下会显示 Qt 原生标题栏)
|
||||||
|
setProductName(QObject::tr("Spark Store"));
|
||||||
|
setProductIcon(QIcon::fromTheme("spark-store"));
|
||||||
|
setApplicationHomePage("https://gitee.com/deepin-community-store");
|
||||||
|
setApplicationDescription(
|
||||||
|
QObject::tr(
|
||||||
|
"<span style=' font-size:10pt;font-weight:60;'>An appstore powered by community</span><br/>"
|
||||||
|
"<a href='https://www.spark-app.store/'>https://www.spark-app.store</a><br/>"
|
||||||
|
"<span style=' font-size:12pt;'>Spark developers</span>"));
|
||||||
|
setApplicationLicense(" <a href='https://gitee.com/deepin-community-store/spark-store/blob/Flamescion/LICENSE'>GPLv3</a> ");
|
||||||
|
|
||||||
|
// 检查 ~/.config/spark-union/spark-store 文件夹是否存在
|
||||||
|
checkAppConfigLocation();
|
||||||
|
|
||||||
|
// 初始化日志模块 (默认日志位置 ~/.cache/spark-union/spark-store)
|
||||||
|
DLogManager::registerConsoleAppender();
|
||||||
|
DLogManager::registerFileAppender();
|
||||||
|
|
||||||
|
// 获取版本特性信息
|
||||||
|
m_featuresJsonObj = Utils::parseFeatureJsonFile();
|
||||||
|
}
|
||||||
|
|
||||||
|
void Application::handleAboutAction()
|
||||||
|
{
|
||||||
|
if (aboutDialog() && aboutDialog()->parent() == m_mainWindow) {
|
||||||
|
DApplication::handleAboutAction();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
initAboutDialog();
|
||||||
|
#if (DTK_VERSION >= DTK_VERSION_CHECK(5, 6, 4, 0))
|
||||||
|
initFeatureDisplayDialog(); // 初始化版本特性对话框
|
||||||
|
#endif
|
||||||
|
DApplication::handleAboutAction();
|
||||||
|
}
|
||||||
|
|
||||||
|
bool Application::notify(QObject *receiver, QEvent *event)
|
||||||
|
{
|
||||||
|
if (m_mainWindow) {
|
||||||
|
m_mainWindow->notify(receiver, event);
|
||||||
|
}
|
||||||
|
|
||||||
|
return DApplication::notify(receiver, event);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Application::checkAppConfigLocation()
|
||||||
|
{
|
||||||
|
QDir dir(QStandardPaths::writableLocation(QStandardPaths::AppConfigLocation));
|
||||||
|
if (!dir.exists()) {
|
||||||
|
qWarning() << "AppConfigLocation not existed, creating...";
|
||||||
|
dir.mkpath(dir.absolutePath());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void Application::setBuildDateTime(const QString &buildDateTime)
|
||||||
|
{
|
||||||
|
QSettings config(QStandardPaths::writableLocation(QStandardPaths::AppConfigLocation) + "/config.ini", QSettings::IniFormat);
|
||||||
|
if (config.value("build/version").toString() != QString(APP_VERSION)) {
|
||||||
|
qDebug() << "Spark Store has been updated!";
|
||||||
|
|
||||||
|
config.setValue("build/version", QString(APP_VERSION));
|
||||||
|
config.setValue("build/time", buildDateTime);
|
||||||
|
config.sync();
|
||||||
|
}
|
||||||
|
|
||||||
|
setApplicationVersion(DApplication::buildVersion(QString(APP_VERSION) + "-" + "Flamescion" + "-" + buildDateTime));
|
||||||
|
}
|
||||||
|
|
||||||
|
void Application::setMainWindow(MainWindow *window)
|
||||||
|
{
|
||||||
|
m_mainWindow = window;
|
||||||
|
if (aboutDialog() == nullptr || aboutDialog()->parent() != m_mainWindow)
|
||||||
|
{
|
||||||
|
initAboutDialog();
|
||||||
|
}
|
||||||
|
#if (DTK_VERSION >= DTK_VERSION_CHECK(5, 6, 4, 0))
|
||||||
|
if (featureDisplayDialog() == nullptr || featureDisplayDialog()->parent() != m_mainWindow)
|
||||||
|
{
|
||||||
|
initFeatureDisplayDialog(); // 初始化版本特性对话框
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
void Application::initAboutDialog()
|
||||||
|
{
|
||||||
|
if (m_mainWindow == nullptr)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (aboutDialog())
|
||||||
|
{
|
||||||
|
aboutDialog()->deleteLater();
|
||||||
|
setAboutDialog(nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 自定义 DAboutDialog
|
||||||
|
DAboutDialog *dialog = new DAboutDialog(m_mainWindow);
|
||||||
|
dialog->setProductName(productName());
|
||||||
|
dialog->setProductIcon(productIcon());
|
||||||
|
dialog->setVersion(translate("DAboutDialog", "Version: %1").arg(applicationVersion()));
|
||||||
|
#if (DTK_VERSION >= DTK_VERSION_CHECK(5, 6, 4, 0))
|
||||||
|
dialog->setVersion(applicationVersion());
|
||||||
|
#endif
|
||||||
|
// 根据 shenmo 要求,不显示组织 Logo
|
||||||
|
// dialog->setCompanyLogo(QPixmap(":/icon/Logo-Spark.png"));
|
||||||
|
dialog->setCompanyLogo(QPixmap());
|
||||||
|
dialog->setWebsiteName(QObject::tr("Spark Project"));
|
||||||
|
dialog->setWebsiteLink(applicationHomePage());
|
||||||
|
dialog->setDescription(applicationDescription());
|
||||||
|
dialog->setLicense(translate("DAboutDialog", "%1 is released under %2").arg(productName()).arg(applicationLicense()));
|
||||||
|
|
||||||
|
setAboutDialog(dialog);
|
||||||
|
connect(aboutDialog(), &DAboutDialog::destroyed, this, [=]() {
|
||||||
|
setAboutDialog(nullptr);
|
||||||
|
});
|
||||||
|
|
||||||
|
dialog->hide();
|
||||||
|
}
|
||||||
|
|
||||||
|
#if (DTK_VERSION >= DTK_VERSION_CHECK(5, 6, 4, 0))
|
||||||
|
/**
|
||||||
|
* @brief Application::initFeatureDisplayDialog 初始化版本特性对话框
|
||||||
|
*/
|
||||||
|
void Application::initFeatureDisplayDialog()
|
||||||
|
{
|
||||||
|
if (featureDisplayDialog())
|
||||||
|
{
|
||||||
|
featureDisplayDialog()->deleteLater();
|
||||||
|
setFeatureDisplayDialog(nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 自定义 DFeatureDisplayDialog
|
||||||
|
DFeatureDisplayDialog *dialog = new DFeatureDisplayDialog(m_mainWindow);
|
||||||
|
// 标题
|
||||||
|
dialog->setTitle(m_featuresJsonObj.value("title").toString());
|
||||||
|
// NOTE: json 文件中支持多语言;考虑到维护性,不放入翻译文件处理
|
||||||
|
if (m_featuresJsonObj.contains(QString("title[%1]").arg(QLocale::system().name())))
|
||||||
|
{
|
||||||
|
dialog->setTitle(m_featuresJsonObj.value(QString("title[%1]").arg(QLocale::system().name())).toString());
|
||||||
|
}
|
||||||
|
|
||||||
|
// 特性项
|
||||||
|
QList<DFeatureItem *> items;
|
||||||
|
foreach (const QJsonValue &jsonValue, m_featuresJsonObj.value("items").toArray())
|
||||||
|
{
|
||||||
|
QJsonObject jsonObj = jsonValue.toObject();
|
||||||
|
QString name = jsonObj.value("name").toString();
|
||||||
|
if (jsonObj.contains(QString("name[%1]").arg(QLocale::system().name())))
|
||||||
|
{
|
||||||
|
name = jsonObj.value(QString("name[%1]").arg(QLocale::system().name())).toString();
|
||||||
|
}
|
||||||
|
QString description = jsonObj.value("description").toString();
|
||||||
|
if (jsonObj.contains(QString("description[%1]").arg(QLocale::system().name())))
|
||||||
|
{
|
||||||
|
description = jsonObj.value(QString("description[%1]").arg(QLocale::system().name())).toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
DFeatureItem *item = new DFeatureItem(QIcon::fromTheme("spark-store"), name, description, dialog);
|
||||||
|
items.append(item);
|
||||||
|
}
|
||||||
|
dialog->addItems(items); // NOTE: 也支持 addItem 依次添加单个 item
|
||||||
|
|
||||||
|
// “了解更多”链接按钮
|
||||||
|
dialog->setLinkUrl(m_featuresJsonObj.value("linkUrl").toString());
|
||||||
|
dialog->setLinkButtonVisible(m_featuresJsonObj.value("linkButtonVisible").toBool());
|
||||||
|
|
||||||
|
setFeatureDisplayDialog(dialog);
|
||||||
|
connect(featureDisplayDialog(), &DFeatureDisplayDialog::destroyed, this, [=]() {
|
||||||
|
setFeatureDisplayDialog(nullptr);
|
||||||
|
});
|
||||||
|
#if (DTK_VERSION >= DTK_VERSION_CHECK(5, 6, 4, 0))
|
||||||
|
connect(aboutDialog(), &DAboutDialog::featureActivated, this, [=]() {
|
||||||
|
featureDisplayDialog()->show();
|
||||||
|
});
|
||||||
|
#endif
|
||||||
|
|
||||||
|
dialog->hide();
|
||||||
|
}
|
||||||
|
#endif
|
||||||
37
src/application.h
Normal file
37
src/application.h
Normal file
@@ -0,0 +1,37 @@
|
|||||||
|
#ifndef APPLICATION_H
|
||||||
|
#define APPLICATION_H
|
||||||
|
|
||||||
|
#include <DApplication>
|
||||||
|
|
||||||
|
#include <QJsonObject>
|
||||||
|
|
||||||
|
DWIDGET_USE_NAMESPACE
|
||||||
|
|
||||||
|
class MainWindow;
|
||||||
|
class Application : public DApplication
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
|
||||||
|
public:
|
||||||
|
Application(int &argc, char **argv);
|
||||||
|
void handleAboutAction() override;
|
||||||
|
bool notify(QObject *receiver, QEvent *event) override;
|
||||||
|
|
||||||
|
static void checkAppConfigLocation();
|
||||||
|
|
||||||
|
void setBuildDateTime(const QString &buildDateTime);
|
||||||
|
void setMainWindow(MainWindow *window);
|
||||||
|
|
||||||
|
private:
|
||||||
|
void initAboutDialog();
|
||||||
|
#if (DTK_VERSION >= DTK_VERSION_CHECK(5, 6, 4, 0))
|
||||||
|
void initFeatureDisplayDialog();
|
||||||
|
#endif
|
||||||
|
|
||||||
|
private:
|
||||||
|
QJsonObject m_featuresJsonObj;
|
||||||
|
|
||||||
|
MainWindow *m_mainWindow = nullptr;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // APPLICATION_H
|
||||||
@@ -1,43 +1,6 @@
|
|||||||
<RCC>
|
<RCC>
|
||||||
<qresource prefix="/">
|
<qresource prefix="/">
|
||||||
<file>icon/logo.svg</file>
|
<file>icon/Logo-Spark.png</file>
|
||||||
<file>tags/a2d-small.png</file>
|
|
||||||
<file>tags/a2d.png</file>
|
|
||||||
<file>tags/community-small.png</file>
|
|
||||||
<file>tags/community.png</file>
|
|
||||||
<file>tags/community.svg</file>
|
|
||||||
<file>tags/deepin-small.png</file>
|
|
||||||
<file>tags/deepin.svg</file>
|
|
||||||
<file>tags/dtk-small.png</file>
|
|
||||||
<file>tags/dwine2-small.png</file>
|
|
||||||
<file>tags/dwine5-small.png</file>
|
|
||||||
<file>tags/dwine5.svg</file>
|
|
||||||
<file>tags/logo_icon.svg</file>
|
|
||||||
<file>tags/ubuntu-small.png</file>
|
|
||||||
<file>tags/ubuntu.png</file>
|
|
||||||
<file>tags/uos-authorize.svg</file>
|
|
||||||
<file>tags/uos-small.png</file>
|
|
||||||
<file>tags/uos.svg</file>
|
|
||||||
<file>icon/light/back.svg</file>
|
|
||||||
<file>icon/light/download.svg</file>
|
|
||||||
<file>icon/light/leftbutton_0.svg</file>
|
|
||||||
<file>icon/light/leftbutton_1.svg</file>
|
|
||||||
<file>icon/light/leftbutton_2.svg</file>
|
|
||||||
<file>icon/light/leftbutton_3.svg</file>
|
|
||||||
<file>icon/light/leftbutton_4.svg</file>
|
|
||||||
<file>icon/light/leftbutton_5.svg</file>
|
|
||||||
<file>icon/light/leftbutton_6.svg</file>
|
|
||||||
<file>icon/light/leftbutton_7.svg</file>
|
|
||||||
<file>icon/light/leftbutton_8.svg</file>
|
|
||||||
<file>icon/light/leftbutton_9.svg</file>
|
|
||||||
<file>icon/light/leftbutton_10.svg</file>
|
|
||||||
<file>icon/light/leftbutton_11.svg</file>
|
|
||||||
<file>icon/light/leftbutton_12.svg</file>
|
|
||||||
<file>icon/light/box.svg</file>
|
|
||||||
<file>icon/light/calendar.svg</file>
|
|
||||||
<file>icon/light/globe.svg</file>
|
|
||||||
<file>icon/light/folder.svg</file>
|
|
||||||
<file>icon/light/text.svg</file>
|
|
||||||
<file>icon/dark/back.svg</file>
|
<file>icon/dark/back.svg</file>
|
||||||
<file>icon/dark/box.svg</file>
|
<file>icon/dark/box.svg</file>
|
||||||
<file>icon/dark/calendar.svg</file>
|
<file>icon/dark/calendar.svg</file>
|
||||||
@@ -58,7 +21,46 @@
|
|||||||
<file>icon/dark/leftbutton_11.svg</file>
|
<file>icon/dark/leftbutton_11.svg</file>
|
||||||
<file>icon/dark/leftbutton_12.svg</file>
|
<file>icon/dark/leftbutton_12.svg</file>
|
||||||
<file>icon/dark/text.svg</file>
|
<file>icon/dark/text.svg</file>
|
||||||
<file>icon/light/update.svg</file>
|
|
||||||
<file>icon/dark/update.svg</file>
|
<file>icon/dark/update.svg</file>
|
||||||
|
<file>icon/light/back.svg</file>
|
||||||
|
<file>icon/light/download.svg</file>
|
||||||
|
<file>icon/light/leftbutton_0.svg</file>
|
||||||
|
<file>icon/light/leftbutton_1.svg</file>
|
||||||
|
<file>icon/light/leftbutton_2.svg</file>
|
||||||
|
<file>icon/light/leftbutton_3.svg</file>
|
||||||
|
<file>icon/light/leftbutton_4.svg</file>
|
||||||
|
<file>icon/light/leftbutton_5.svg</file>
|
||||||
|
<file>icon/light/leftbutton_6.svg</file>
|
||||||
|
<file>icon/light/leftbutton_7.svg</file>
|
||||||
|
<file>icon/light/leftbutton_8.svg</file>
|
||||||
|
<file>icon/light/leftbutton_9.svg</file>
|
||||||
|
<file>icon/light/leftbutton_10.svg</file>
|
||||||
|
<file>icon/light/leftbutton_11.svg</file>
|
||||||
|
<file>icon/light/leftbutton_12.svg</file>
|
||||||
|
<file>icon/light/box.svg</file>
|
||||||
|
<file>icon/light/calendar.svg</file>
|
||||||
|
<file>icon/light/globe.svg</file>
|
||||||
|
<file>icon/light/folder.svg</file>
|
||||||
|
<file>icon/light/text.svg</file>
|
||||||
|
<file>icon/light/update.svg</file>
|
||||||
|
<file>icon/logo.svg</file>
|
||||||
|
<file>json/features.json</file>
|
||||||
|
<file>tags/a2d-small.png</file>
|
||||||
|
<file>tags/a2d.png</file>
|
||||||
|
<file>tags/community-small.png</file>
|
||||||
|
<file>tags/community.png</file>
|
||||||
|
<file>tags/community.svg</file>
|
||||||
|
<file>tags/deepin-small.png</file>
|
||||||
|
<file>tags/deepin.svg</file>
|
||||||
|
<file>tags/dtk-small.png</file>
|
||||||
|
<file>tags/dwine2-small.png</file>
|
||||||
|
<file>tags/dwine5-small.png</file>
|
||||||
|
<file>tags/dwine5.svg</file>
|
||||||
|
<file>tags/logo_icon.svg</file>
|
||||||
|
<file>tags/ubuntu-small.png</file>
|
||||||
|
<file>tags/ubuntu.png</file>
|
||||||
|
<file>tags/uos-authorize.svg</file>
|
||||||
|
<file>tags/uos-small.png</file>
|
||||||
|
<file>tags/uos.svg</file>
|
||||||
</qresource>
|
</qresource>
|
||||||
</RCC>
|
</RCC>
|
||||||
|
|||||||
Binary file not shown.
|
Before Width: | Height: | Size: 46 KiB After Width: | Height: | Size: 11 KiB |
25
src/assets/json/features.json
Normal file
25
src/assets/json/features.json
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
{
|
||||||
|
"title": "Features",
|
||||||
|
"title[zh_CN]": "版本特性",
|
||||||
|
"items": [
|
||||||
|
{
|
||||||
|
"icon": "/usr/share/icons/hicolor/scalable/apps/spark-store.svg",
|
||||||
|
"name": "Feature 1",
|
||||||
|
"name[zh_CN]": "特性 1",
|
||||||
|
"description": "Please click the learn more button to check",
|
||||||
|
"description[zh_CN]": "请点击 了解更多 按钮来获取特性"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"icon": ":/icon/logo.svg",
|
||||||
|
"name": "Feature 2",
|
||||||
|
"description": "Feature 2 detailed description..."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"icon": "spark-store",
|
||||||
|
"name": "Fix 1",
|
||||||
|
"description": "Fix 1 detailed description..."
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"linkUrl": "https://gitee.com/deepin-community-store/spark-store/releases/4.2.3test3",
|
||||||
|
"linkButtonVisible": true
|
||||||
|
}
|
||||||
@@ -1,9 +1,9 @@
|
|||||||
#include "downloadworker.h"
|
#include "downloadworker.h"
|
||||||
#include <QEventLoop>
|
|
||||||
#include <QProcess>
|
#include <QProcess>
|
||||||
#include <QRegularExpression>
|
#include <QRegularExpression>
|
||||||
#include <QDir>
|
|
||||||
#include <QtConcurrent>
|
#include <QtConcurrent>
|
||||||
|
#include <QStandardPaths>
|
||||||
|
|
||||||
DownloadController::DownloadController(QObject *parent)
|
DownloadController::DownloadController(QObject *parent)
|
||||||
{
|
{
|
||||||
@@ -30,7 +30,6 @@ void DownloadController::setFilename(QString filename)
|
|||||||
this->filename = filename;
|
this->filename = filename;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
bool checkMeatlink(QString metaUrl)
|
bool checkMeatlink(QString metaUrl)
|
||||||
{
|
{
|
||||||
QFile metaStatus("/tmp/spark-store/metaStatus.txt");
|
QFile metaStatus("/tmp/spark-store/metaStatus.txt");
|
||||||
@@ -49,7 +48,7 @@ bool checkMeatlink(QString metaUrl)
|
|||||||
|
|
||||||
void gennerateDomain(QVector<QString> &domains)
|
void gennerateDomain(QVector<QString> &domains)
|
||||||
{
|
{
|
||||||
QFile serverList(QDir::homePath().toUtf8() + "/.config/spark-store/server.list");
|
QFile serverList(QStandardPaths::writableLocation(QStandardPaths::AppConfigLocation) + "/server.list");
|
||||||
if (serverList.open(QFile::ReadOnly))
|
if (serverList.open(QFile::ReadOnly))
|
||||||
{
|
{
|
||||||
QStringList list = QString(serverList.readAll()).trimmed().split("\n");
|
QStringList list = QString(serverList.readAll()).trimmed().split("\n");
|
||||||
@@ -92,10 +91,13 @@ void DownloadController::startDownload(const QString &url)
|
|||||||
QString metaUrl = url + ".metalink";
|
QString metaUrl = url + ".metalink";
|
||||||
qDebug() << "metalink" << metaUrl;
|
qDebug() << "metalink" << metaUrl;
|
||||||
bool useMetalink = false;
|
bool useMetalink = false;
|
||||||
if (checkMeatlink(metaUrl)){
|
if (checkMeatlink(metaUrl))
|
||||||
|
{
|
||||||
useMetalink = true;
|
useMetalink = true;
|
||||||
qDebug() << "useMetalink:" << useMetalink;
|
qDebug() << "useMetalink:" << useMetalink;
|
||||||
}else{
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
gennerateDomain(domains);
|
gennerateDomain(domains);
|
||||||
// qDebug() << domains << domains.size();
|
// qDebug() << domains << domains.size();
|
||||||
}
|
}
|
||||||
@@ -112,10 +114,12 @@ void DownloadController::startDownload(const QString &url)
|
|||||||
QString aria2ConnectionMax = "--max-concurrent-downloads=16";
|
QString aria2ConnectionMax = "--max-concurrent-downloads=16";
|
||||||
QString aria2DNSCommand = "--async-dns-server=119.29.29.29,223.5.5.5";
|
QString aria2DNSCommand = "--async-dns-server=119.29.29.29,223.5.5.5";
|
||||||
|
|
||||||
if (useMetalink){
|
if (useMetalink)
|
||||||
|
{
|
||||||
command.append(metaUrl.toUtf8());
|
command.append(metaUrl.toUtf8());
|
||||||
}
|
}
|
||||||
else{
|
else
|
||||||
|
{
|
||||||
for (int i = 0; i < domains.size(); i++)
|
for (int i = 0; i < domains.size(); i++)
|
||||||
{
|
{
|
||||||
command.append(replaceDomain(url, domains.at(i)).replace("+","%2B").toUtf8()); //对+进行转译,避免oss出错
|
command.append(replaceDomain(url, domains.at(i)).replace("+","%2B").toUtf8()); //对+进行转译,避免oss出错
|
||||||
@@ -134,22 +138,24 @@ void DownloadController::startDownload(const QString &url)
|
|||||||
command.append(aria2ConnectionPerServer.toUtf8());
|
command.append(aria2ConnectionPerServer.toUtf8());
|
||||||
command.append(aria2ConnectionMax.toUtf8());
|
command.append(aria2ConnectionMax.toUtf8());
|
||||||
command.append(aria2DNSCommand.toUtf8());
|
command.append(aria2DNSCommand.toUtf8());
|
||||||
if (useMetalink){
|
if (useMetalink)
|
||||||
|
{
|
||||||
command.append(aria2NoSeeds.toUtf8());
|
command.append(aria2NoSeeds.toUtf8());
|
||||||
}
|
}
|
||||||
qDebug() << command;
|
qDebug() << command;
|
||||||
auto cmd = new QProcess(this);
|
|
||||||
cmd->setProcessChannelMode(QProcess::MergedChannels);
|
|
||||||
cmd->setProgram("aria2c");
|
|
||||||
cmd->setArguments(command);
|
|
||||||
cmd->start();
|
|
||||||
cmd->waitForStarted(); //等待启动完成
|
|
||||||
|
|
||||||
QObject::connect(cmd, &QProcess::readyReadStandardOutput,
|
bool downloadSuccess = true;
|
||||||
[&]()
|
QProcess cmd;
|
||||||
|
cmd.setProcessChannelMode(QProcess::MergedChannels);
|
||||||
|
cmd.setProgram("aria2c");
|
||||||
|
cmd.setArguments(command);
|
||||||
|
cmd.start();
|
||||||
|
cmd.waitForStarted(-1); //等待启动完成
|
||||||
|
|
||||||
|
connect(&cmd, &QProcess::readyReadStandardOutput, [&]()
|
||||||
{
|
{
|
||||||
//通过读取输出计算下载速度
|
//通过读取输出计算下载速度
|
||||||
QString message = cmd->readAllStandardOutput().data();
|
QString message = cmd.readAllStandardOutput().data();
|
||||||
// qDebug() << message;
|
// qDebug() << message;
|
||||||
message = message.replace(" ", "");
|
message = message.replace(" ", "");
|
||||||
QStringList list;
|
QStringList list;
|
||||||
@@ -189,18 +195,21 @@ void DownloadController::startDownload(const QString &url)
|
|||||||
emit downloadProcess(speedInfo, downloadSizeRecord, fileSize);
|
emit downloadProcess(speedInfo, downloadSizeRecord, fileSize);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
QObject::connect(cmd, &QProcess::readyReadStandardError,
|
connect(&cmd, &QProcess::readyReadStandardError, [&]()
|
||||||
[&]()
|
|
||||||
{
|
{
|
||||||
emit errorOccur(cmd->readAllStandardError().data());
|
emit errorOccur(cmd.readAllStandardError().data());
|
||||||
return;
|
downloadSuccess = false;
|
||||||
|
cmd.close();
|
||||||
});
|
});
|
||||||
|
|
||||||
auto pidNumber = cmd->processId();
|
pidNumber = cmd.processId();
|
||||||
this->pidNumber = pidNumber;
|
|
||||||
while (cmd->waitForFinished(-1))
|
cmd.waitForFinished(-1);
|
||||||
|
cmd.close();
|
||||||
|
|
||||||
|
if(!downloadSuccess)
|
||||||
{
|
{
|
||||||
continue;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// 统计下载量
|
// 统计下载量
|
||||||
@@ -210,10 +219,10 @@ void DownloadController::startDownload(const QString &url)
|
|||||||
* HD 70642 is a star with an exoplanetary companion in the southern constellation of Puppis.
|
* HD 70642 is a star with an exoplanetary companion in the southern constellation of Puppis.
|
||||||
*/
|
*/
|
||||||
QProcess mailProcess;
|
QProcess mailProcess;
|
||||||
mailProcess.start(SenderdPath.toUtf8() + " " + metaUrl.toUtf8() + " " + "HD70642");
|
mailProcess.start(SenderdPath.toUtf8(), QStringList() << metaUrl << "HD70642");
|
||||||
mailProcess.waitForStarted();
|
mailProcess.waitForStarted();
|
||||||
mailProcess.waitForFinished(3000);
|
mailProcess.waitForFinished(3000);
|
||||||
mailProcess.deleteLater();
|
mailProcess.close();
|
||||||
|
|
||||||
emit downloadFinished(); });
|
emit downloadFinished(); });
|
||||||
}
|
}
|
||||||
@@ -223,15 +232,22 @@ void DownloadController::startDownload(const QString &url)
|
|||||||
*/
|
*/
|
||||||
void DownloadController::stopDownload()
|
void DownloadController::stopDownload()
|
||||||
{
|
{
|
||||||
|
if (pidNumber < 0)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
// 实现下载进程退出
|
// 实现下载进程退出
|
||||||
QString killCmd = QString("kill -9 %1").arg(pidNumber);
|
QString killCmd = QString("kill -9 %1").arg(pidNumber);
|
||||||
system(killCmd.toUtf8());
|
system(killCmd.toUtf8());
|
||||||
qDebug() << "kill aria2!";
|
qDebug() << "kill aria2!";
|
||||||
|
pidNumber = -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
qint64 DownloadController::getFileSize(const QString &url)
|
qint64 DownloadController::getFileSize(const QString &url)
|
||||||
{
|
{
|
||||||
// 已经无需使用 qtnetwork 再获取 filesize,完全交给 aria2 来计算进度。 为保证兼容性,故保留此函数。
|
// 已经无需使用 qtnetwork 再获取 filesize,完全交给 aria2 来计算进度。 为保证兼容性,故保留此函数。
|
||||||
|
qDebug() << "Begin download:" << url;
|
||||||
qint64 fileSize = 10000;
|
qint64 fileSize = 10000;
|
||||||
return fileSize;
|
return fileSize;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,9 +2,7 @@
|
|||||||
#define DOWNLOADWORKER_H
|
#define DOWNLOADWORKER_H
|
||||||
|
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
#include <QList>
|
#include <QVector>
|
||||||
#include <QFile>
|
|
||||||
#include <QNetworkReply>
|
|
||||||
|
|
||||||
class DownloadController : public QObject
|
class DownloadController : public QObject
|
||||||
{
|
{
|
||||||
@@ -19,23 +17,19 @@ public:
|
|||||||
qint64 getFileSize(const QString& url);
|
qint64 getFileSize(const QString& url);
|
||||||
QString replaceDomain(const QString& url, const QString domain);
|
QString replaceDomain(const QString& url, const QString domain);
|
||||||
|
|
||||||
private:
|
|
||||||
int threadNum;
|
|
||||||
int pidNumber;
|
|
||||||
QString filename;
|
|
||||||
qint64 fileSize;
|
|
||||||
QVector<QPair<qint64, qint64>> ranges;
|
|
||||||
QFile *file;
|
|
||||||
bool finished = false;
|
|
||||||
QVector<QString> domains;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
signals:
|
signals:
|
||||||
void errorOccur(const QString& msg);
|
void errorOccur(const QString& msg);
|
||||||
void downloadProcess(QString, qint64, qint64);
|
void downloadProcess(QString, qint64, qint64);
|
||||||
void downloadFinished();
|
void downloadFinished();
|
||||||
|
|
||||||
|
private:
|
||||||
|
int threadNum;
|
||||||
|
qint64 pidNumber = -1;
|
||||||
|
QString filename;
|
||||||
|
qint64 fileSize;
|
||||||
|
QVector<QPair<qint64, qint64>> ranges;
|
||||||
|
bool finished = false;
|
||||||
|
QVector<QString> domains;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // FILEDOWNLOADWORKER_H
|
#endif // FILEDOWNLOADWORKER_H
|
||||||
|
|||||||
@@ -4,8 +4,7 @@
|
|||||||
#include <QScreen> // Qt5 不再建议使用 QDesktopWidget
|
#include <QScreen> // Qt5 不再建议使用 QDesktopWidget
|
||||||
#include <QGuiApplication>
|
#include <QGuiApplication>
|
||||||
|
|
||||||
image_show::image_show(QWidget *parent) :
|
image_show::image_show(QWidget *parent) : QWidget(parent),
|
||||||
QWidget(parent),
|
|
||||||
m_dialog(new big_image),
|
m_dialog(new big_image),
|
||||||
m_label(new QLabel)
|
m_label(new QLabel)
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -1,23 +1,27 @@
|
|||||||
#include "sparkapi.h"
|
#include "sparkapi.h"
|
||||||
|
|
||||||
|
#include <QSettings>
|
||||||
|
#include <QStandardPaths>
|
||||||
#include <QDebug>
|
#include <QDebug>
|
||||||
|
|
||||||
QString SparkAPI::serverUrl = "";
|
QString SparkAPI::serverUrl = "";
|
||||||
|
|
||||||
SparkAPI::SparkAPI(QObject *parent) : QObject(parent)
|
SparkAPI::SparkAPI(QObject *parent) : QObject(parent)
|
||||||
{
|
{
|
||||||
QSettings readConfig(QDir::homePath() + "/.config/spark-store/config.ini", QSettings::IniFormat);
|
QSettings config(QStandardPaths::writableLocation(QStandardPaths::AppConfigLocation) + "/config.ini", QSettings::IniFormat);
|
||||||
if(!readConfig.value("server/choose").toString().isEmpty() && readConfig.value("server/updated").toString() == "TRUE")
|
if (!config.value("server/choose").toString().isEmpty() && config.value("server/updated").toBool())
|
||||||
{
|
{
|
||||||
SparkAPI::setServerUrl(readConfig.value("server/choose").toString());
|
SparkAPI::setServerUrl(config.value("server/choose").toString());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void SparkAPI::get(QUrl url)
|
void SparkAPI::get(QUrl url)
|
||||||
{
|
{
|
||||||
QNetworkRequest request;
|
QNetworkRequest request;
|
||||||
HttpRequest *httprequest = new HttpRequest;
|
HttpRequest *httprequest = new HttpRequest;
|
||||||
request.setUrl(QUrl(url.toString().replace("+", "%2B")));
|
request.setUrl(QUrl(url.toString().replace("+", "%2B")));
|
||||||
connect(httprequest,&HttpRequest::finished,[=](QString data){
|
connect(httprequest, &HttpRequest::finished, [=](QString data)
|
||||||
|
{
|
||||||
QByteArray arr = data.toUtf8();
|
QByteArray arr = data.toUtf8();
|
||||||
// 解析 Json
|
// 解析 Json
|
||||||
QJsonParseError error;
|
QJsonParseError error;
|
||||||
@@ -32,43 +36,52 @@ void SparkAPI::get(QUrl url)
|
|||||||
|
|
||||||
httprequest->deleteLater();
|
httprequest->deleteLater();
|
||||||
});
|
});
|
||||||
|
|
||||||
httprequest->getRequest(request);
|
httprequest->getRequest(request);
|
||||||
}
|
}
|
||||||
|
|
||||||
void SparkAPI::getRAW(QUrl url)
|
void SparkAPI::getRAW(QUrl url)
|
||||||
{
|
{
|
||||||
QNetworkRequest request;
|
QNetworkRequest request;
|
||||||
HttpRequest *httprequest = new HttpRequest;
|
HttpRequest *httprequest = new HttpRequest;
|
||||||
request.setUrl(QUrl(url.toString().replace("+", "%2B")));
|
request.setUrl(QUrl(url.toString().replace("+", "%2B")));
|
||||||
connect(httprequest,&HttpRequest::finished,[=](QString data){
|
connect(httprequest, &HttpRequest::finished, [=](QString data)
|
||||||
|
{
|
||||||
emit finishedRAW(data);
|
emit finishedRAW(data);
|
||||||
httprequest->deleteLater();
|
httprequest->deleteLater(); });
|
||||||
});
|
|
||||||
httprequest->getRequest(request);
|
httprequest->getRequest(request);
|
||||||
}
|
}
|
||||||
|
|
||||||
void SparkAPI::getAppList(QString type)
|
void SparkAPI::getAppList(QString type)
|
||||||
{
|
{
|
||||||
get(QUrl(getServerUrl() + "store/" + type + "/applist.json"));
|
get(QUrl(getServerUrl() + "store/" + type + "/applist.json"));
|
||||||
}
|
}
|
||||||
|
|
||||||
void SparkAPI::getSearchList(QString keyword)
|
void SparkAPI::getSearchList(QString keyword)
|
||||||
{
|
{
|
||||||
get(QUrl("https://search.deepinos.org.cn/appinfo/search?keyword=" + keyword));
|
get(QUrl("https://search.deepinos.org.cn/appinfo/search?keyword=" + keyword));
|
||||||
}
|
}
|
||||||
|
|
||||||
void SparkAPI::getAppInfo(QUrl spk)
|
void SparkAPI::getAppInfo(QUrl spk)
|
||||||
{
|
{
|
||||||
get(QUrl(getServerUrl() + "store" + spk.path().replace("+", "%2B") + "/app.json"));
|
get(QUrl(getServerUrl() + "store" + spk.path().replace("+", "%2B") + "/app.json"));
|
||||||
}
|
}
|
||||||
|
|
||||||
void SparkAPI::getAppDownloadTimes(QUrl spk)
|
void SparkAPI::getAppDownloadTimes(QUrl spk)
|
||||||
{
|
{
|
||||||
getRAW(QUrl(getServerUrl() + "store" + spk.path().replace("+", "%2B") + "/download-times.txt"));
|
getRAW(QUrl(getServerUrl() + "store" + spk.path().replace("+", "%2B") + "/download-times.txt"));
|
||||||
}
|
}
|
||||||
|
|
||||||
QString SparkAPI::getServerUrl()
|
QString SparkAPI::getServerUrl()
|
||||||
{
|
{
|
||||||
return SparkAPI::serverUrl;
|
return SparkAPI::serverUrl;
|
||||||
}
|
}
|
||||||
|
|
||||||
QString SparkAPI::getImgServerUrl()
|
QString SparkAPI::getImgServerUrl()
|
||||||
{
|
{
|
||||||
return SparkAPI::serverUrl;
|
return SparkAPI::serverUrl;
|
||||||
}
|
}
|
||||||
|
|
||||||
void SparkAPI::setServerUrl(QString url)
|
void SparkAPI::setServerUrl(QString url)
|
||||||
{
|
{
|
||||||
SparkAPI::serverUrl = url;
|
SparkAPI::serverUrl = url;
|
||||||
|
|||||||
@@ -1,16 +1,21 @@
|
|||||||
#ifndef SPARKAPI_H
|
#ifndef SPARKAPI_H
|
||||||
#define SPARKAPI_H
|
#define SPARKAPI_H
|
||||||
|
|
||||||
|
#include "utils/httprequest.h"
|
||||||
|
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
#include <QJsonObject>
|
#include <QJsonObject>
|
||||||
#include <QJsonArray>
|
#include <QJsonArray>
|
||||||
#include <QJsonParseError>
|
#include <QJsonParseError>
|
||||||
#include "utils/httprequest.h"
|
|
||||||
#include <QSettings>
|
|
||||||
#include <QDir>
|
#include <QDir>
|
||||||
|
|
||||||
class SparkAPI : public QObject
|
class SparkAPI : public QObject
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
explicit SparkAPI(QObject *parent = nullptr);
|
||||||
|
|
||||||
static QString getServerUrl();
|
static QString getServerUrl();
|
||||||
static QString getImgServerUrl();
|
static QString getImgServerUrl();
|
||||||
static void setServerUrl(QString url);
|
static void setServerUrl(QString url);
|
||||||
@@ -20,17 +25,14 @@ public:
|
|||||||
void getRAW(QUrl url);
|
void getRAW(QUrl url);
|
||||||
void getAppList(QString type);
|
void getAppList(QString type);
|
||||||
void getAppInfo(QUrl spk);
|
void getAppInfo(QUrl spk);
|
||||||
explicit SparkAPI(QObject *parent = nullptr);
|
|
||||||
|
|
||||||
private:
|
|
||||||
static QString serverUrl;
|
|
||||||
|
|
||||||
signals:
|
signals:
|
||||||
void finished(QJsonArray);
|
void finished(QJsonArray);
|
||||||
void finishedRAW(QString);
|
void finishedRAW(QString);
|
||||||
void finishedObject(QJsonObject);
|
void finishedObject(QJsonObject);
|
||||||
|
|
||||||
public slots:
|
private:
|
||||||
|
static QString serverUrl;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // SPARKAPI_H
|
#endif // SPARKAPI_H
|
||||||
|
|||||||
@@ -3,7 +3,6 @@
|
|||||||
DBusSparkStoreService::DBusSparkStoreService(QObject *parent)
|
DBusSparkStoreService::DBusSparkStoreService(QObject *parent)
|
||||||
: QDBusAbstractAdaptor(parent)
|
: QDBusAbstractAdaptor(parent)
|
||||||
{
|
{
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void DBusSparkStoreService::activeWindow(const QString &arg)
|
void DBusSparkStoreService::activeWindow(const QString &arg)
|
||||||
|
|||||||
142
src/main.cpp
142
src/main.cpp
@@ -1,128 +1,86 @@
|
|||||||
|
#include "application.h"
|
||||||
#include "mainwindow-dtk.h"
|
#include "mainwindow-dtk.h"
|
||||||
|
#include "utils/utils.h"
|
||||||
|
|
||||||
#include <DApplication>
|
#include <DSysInfo>
|
||||||
#include <DLog>
|
|
||||||
#include <DPlatformWindowHandle>
|
|
||||||
#include <DApplicationSettings>
|
#include <DApplicationSettings>
|
||||||
#include <DAboutDialog>
|
|
||||||
#include <QLabel>
|
|
||||||
#include <DWidgetUtil>
|
#include <DWidgetUtil>
|
||||||
|
|
||||||
|
#include <QDate>
|
||||||
|
#include <QProcessEnvironment>
|
||||||
|
#include <QSettings>
|
||||||
|
#include <QFile>
|
||||||
|
#include <QStandardPaths>
|
||||||
|
|
||||||
DCORE_USE_NAMESPACE
|
DCORE_USE_NAMESPACE
|
||||||
DWIDGET_USE_NAMESPACE
|
DWIDGET_USE_NAMESPACE
|
||||||
|
|
||||||
int main(int argc, char *argv[])
|
int main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
// Get build time
|
// Get build time
|
||||||
static const QString version = "Version 4.1.1";
|
|
||||||
static const QDate buildDate = QLocale(QLocale::English).toDate(QString(__DATE__).replace(" ", " 0"), "MMM dd yyyy");
|
static const QDate buildDate = QLocale(QLocale::English).toDate(QString(__DATE__).replace(" ", " 0"), "MMM dd yyyy");
|
||||||
static const QTime buildTime = QTime::fromString(__TIME__, "hh:mm:ss");
|
static const QTime buildTime = QTime::fromString(__TIME__, "hh:mm:ss");
|
||||||
|
static const QString buildDateTime = buildDate.toString("yyyy.MM.dd") + "-" + buildTime.toString("hh:mm:ss");
|
||||||
|
|
||||||
//设置桌面环境环境变量
|
// NOTE: 提前设置组织名称和应用名称,避免配置文件位置错误
|
||||||
if (!QString(qgetenv("XDG_CURRENT_DESKTOP")).toLower().startsWith("deepin")) {
|
DApplication::setOrganizationName("spark-union");
|
||||||
setenv("XDG_CURRENT_DESKTOP", "Deepin", 1);
|
DApplication::setApplicationName("spark-store");
|
||||||
}
|
Application::checkAppConfigLocation(); // 检查 ~/.config/spark-union/spark-store 文件夹是否存在
|
||||||
DApplication::setAttribute(Qt::AA_EnableHighDpiScaling); // 开启 Hidpi 支持
|
|
||||||
#ifndef DSTORE_NO_DXCBs
|
// 初始化 config.ini 配置文件
|
||||||
DApplication::loadDXcbPlugin(); // 加载 DXCB 插件
|
Utils::initConfig();
|
||||||
|
|
||||||
|
// Set display backend
|
||||||
|
Utils::setQPAPlatform();
|
||||||
|
|
||||||
|
// 龙芯机器配置,使得 DApplication 能正确加载 QTWEBENGINE
|
||||||
|
qputenv("DTK_FORCE_RASTER_WIDGETS", "FALSE");
|
||||||
|
// qputenv("QTWEBENGINE_CHROMIUM_FLAGS", "--disable-features=UseModernMediaControls");
|
||||||
|
// qputenv("QTWEBENGINE_CHROMIUM_FLAGS", "--disable-web-security");
|
||||||
|
// 浏览器开启 GPU 支持
|
||||||
|
#ifdef __sw_64__
|
||||||
|
qputenv("QTWEBENGINE_CHROMIUM_FLAGS", "--ignore-gpu-blocklist --enable-gpu-rasterization --enable-native-gpu-memory-buffers --enable-accelerated-video-decode --no-sandbox");
|
||||||
|
#else
|
||||||
|
qputenv("QTWEBENGINE_CHROMIUM_FLAGS", "--ignore-gpu-blocklist --enable-gpu-rasterization --enable-native-gpu-memory-buffers --enable-accelerated-video-decode");
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// 浏览器开启 GPU 支持
|
DApplication::setAttribute(Qt::AA_EnableHighDpiScaling); // 开启 Hidpi 支持
|
||||||
qputenv("QTWEBENGINE_CHROMIUM_FLAGS", "--ignore-gpu-blocklist --enable-gpu-rasterization --enable-native-gpu-memory-buffers --enable-accelerated-video-decode");
|
|
||||||
|
|
||||||
|
// 强制使用 DTK 平台插件
|
||||||
QVector<char *> fakeArgs(argc + 2);
|
QVector<char *> fakeArgs(argc + 2);
|
||||||
fakeArgs[0] = argv[0];
|
fakeArgs[0] = argv[0];
|
||||||
fakeArgs[1] = "-platformtheme";
|
fakeArgs[1] = const_cast<char *>("-platformtheme");
|
||||||
fakeArgs[2] = "deepin";
|
fakeArgs[2] = const_cast<char *>("deepin");
|
||||||
for(int i = 1; i < argc; i++) fakeArgs[i + 2] = argv[i];
|
for (int i = 1; i < argc; i++)
|
||||||
int fakeArgc = argc + 2; // 为啥DApplication的argc要用引用啊?
|
{
|
||||||
DApplication a(fakeArgc, fakeArgs.data());
|
fakeArgs[i + 2] = argv[i];
|
||||||
|
|
||||||
|
|
||||||
//初始化日志模块 (默认日志位置 ~/.cache/deepin/spark-store)
|
|
||||||
DLogManager::registerConsoleAppender();
|
|
||||||
DLogManager::registerFileAppender();
|
|
||||||
|
|
||||||
|
|
||||||
//Wayland 环境下使用,防止子控件 Native 化
|
|
||||||
if (!DPlatformWindowHandle::pluginVersion().isEmpty()) {
|
|
||||||
a.setAttribute(Qt::AA_DontCreateNativeWidgetSiblings, true);
|
|
||||||
}
|
}
|
||||||
a.setAttribute(Qt::AA_UseHighDpiPixmaps);
|
int fakeArgc = argc + 2; // QCoreApplication 的 argc 要用引用,避免 c++ 编译器优化
|
||||||
a.loadDXcbPlugin();
|
Application a(fakeArgc, fakeArgs.data());
|
||||||
|
// 设置版本和构建时间
|
||||||
|
a.setBuildDateTime(buildDateTime);
|
||||||
|
|
||||||
a.loadTranslator(); // 载入翻译
|
|
||||||
|
|
||||||
QSettings readConfig(QDir::homePath() + "/.config/spark-store/config.ini", QSettings::IniFormat);
|
|
||||||
|
|
||||||
if (readConfig.value("build/version").toString() != version){
|
|
||||||
qDebug() << "Spark Store has been updated!";
|
|
||||||
QSettings *setConfig = new QSettings(QDir::homePath() + "/.config/spark-store/config.ini", QSettings::IniFormat);
|
|
||||||
setConfig->setValue("build/version", version);
|
|
||||||
setConfig->setValue("build/time", buildDate.toString("yyyy.MM.dd")+"-"+buildTime.toString());
|
|
||||||
setConfig->deleteLater();
|
|
||||||
}
|
|
||||||
|
|
||||||
//Customized DAboutDialog
|
|
||||||
|
|
||||||
DAboutDialog dialog;
|
|
||||||
a.setAboutDialog(&dialog);
|
|
||||||
dialog.setLicense(QObject::tr("We publish this program under GPL V3"));
|
|
||||||
dialog.setVersion(DApplication::buildVersion(readConfig.value("build/version").toString()+"-"+"Flamescion"+"-"+readConfig.value("build/time").toString()));
|
|
||||||
dialog.setProductIcon(QIcon::fromTheme("spark-store")); // 设置Logo
|
|
||||||
dialog.setProductName(QLabel::tr("Spark Store"));
|
|
||||||
dialog.setDescription(
|
|
||||||
QObject::tr(
|
|
||||||
"<span style=' font-size:10pt;font-weight:60;'>An appstore powered by community</span><br/>"
|
|
||||||
"<a href='https://www.spark-app.store/'>https://www.spark-app.store</a><br/>"
|
|
||||||
"<span style=' font-size:12pt;'>Spark developers</span>"
|
|
||||||
)
|
|
||||||
);
|
|
||||||
|
|
||||||
dialog.setProductName(QLabel::tr("Spark Store"));
|
|
||||||
dialog.setCompanyLogo(QPixmap(":/spark-store.png"));
|
|
||||||
dialog.setWebsiteName(QObject::tr("The Spark Project"));
|
|
||||||
dialog.setWebsiteLink("https://gitee.com/deepin-community-store");
|
|
||||||
|
|
||||||
a.setOrganizationName("spark-union");
|
|
||||||
a.setProductName(QObject::tr("Spark Store"));
|
|
||||||
a.setApplicationName("Spark Store"); // 不用翻译,影响 ~/.local/share/spark-union 下文件夹名称
|
|
||||||
a.setApplicationDisplayName(QObject::tr("Spark Store")); // 设置窗口显示标题 (Wayland 下会显示 Qt 原生标题栏)
|
|
||||||
a.setWindowIcon(QIcon::fromTheme("spark-store"));
|
|
||||||
a.setApplicationDescription(
|
|
||||||
QObject::tr(
|
|
||||||
"<span style='font-size:10pt;font-weight:60;'>An appstore powered by deepin community</span><br/>"
|
|
||||||
"<a href='https://www.spark-app.store/'>https://www.spark-app.store</a><br/>"
|
|
||||||
"<span style='font-size:12pt;'>Spark developers</span><br/><br/>"
|
|
||||||
"Published under GPL V3"
|
|
||||||
)
|
|
||||||
);
|
|
||||||
// 限制单实例运行
|
// 限制单实例运行
|
||||||
if (!a.setSingleInstance("spark-store"))
|
if (!a.setSingleInstance("spark-store"))
|
||||||
{
|
{
|
||||||
qDebug() << "The application is already running!";
|
qWarning() << "Another instance has already started, activating...";
|
||||||
QDBusInterface iface("com.gitee.spark.store",
|
|
||||||
"/com/gitee/spark/store",
|
|
||||||
"com.gitee.spark.store",
|
|
||||||
QDBusConnection::sessionBus());
|
|
||||||
|
|
||||||
QString arg1 = argv[1];
|
|
||||||
|
|
||||||
iface.asyncCall("activeWindow",arg1);
|
|
||||||
|
|
||||||
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
DGuiApplicationHelper::instance()->setPaletteType(DGuiApplicationHelper::LightType); //固定主题为浅色主题
|
|
||||||
DApplicationSettings settings; // 定义 DApplicationSettings,自动保存主题设置
|
DApplicationSettings settings; // 定义 DApplicationSettings,自动保存主题设置
|
||||||
|
|
||||||
MainWindow w;
|
MainWindow w;
|
||||||
|
a.setMainWindow(&w); // 设置应用程序主窗口,用于初始化关于对话框
|
||||||
// 让打开时界面显示在正中
|
// 让打开时界面显示在正中
|
||||||
Dtk::Widget::moveToCenter(&w);
|
Dtk::Widget::moveToCenter(&w);
|
||||||
|
|
||||||
|
if (argc > 1)
|
||||||
|
{
|
||||||
QString arg1 = argv[1];
|
QString arg1 = argv[1];
|
||||||
if (arg1.startsWith("spk://")) {
|
if (arg1.trimmed().startsWith("spk://"))
|
||||||
w.openUrl(QUrl(argv[1]));
|
{
|
||||||
|
w.openUrl(arg1);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
w.show();
|
w.show();
|
||||||
|
|
||||||
|
|||||||
@@ -1,220 +1,52 @@
|
|||||||
#include "mainwindow-dtk.h"
|
#include "mainwindow-dtk.h"
|
||||||
#include "ui_mainwindow-dtk.h"
|
#include "ui_mainwindow-dtk.h"
|
||||||
|
#include "utils/widgetanimation.h"
|
||||||
|
#include "widgets/common/progressbutton.h"
|
||||||
|
#include "widgets/downloadlistwidget.h"
|
||||||
|
#include "widgets/common/downloaditem.h"
|
||||||
|
#include "dbus/dbussparkstoreservice.h"
|
||||||
|
#include "application.h"
|
||||||
|
|
||||||
|
#include <DLabel>
|
||||||
#include <DWidgetUtil>
|
#include <DWidgetUtil>
|
||||||
#include <DGuiApplicationHelper>
|
#include <DGuiApplicationHelper>
|
||||||
#include <QSizePolicy>
|
|
||||||
|
#include <QDesktopServices>
|
||||||
|
#include <QAbstractButton>
|
||||||
|
#include <QtConcurrent>
|
||||||
|
|
||||||
#define AppPageApplist 0
|
#define AppPageApplist 0
|
||||||
#define AppPageSearchlist 1
|
#define AppPageSearchlist 1
|
||||||
#define AppPageAppdetail 2
|
#define AppPageAppdetail 2
|
||||||
#define AppPageSettings 3
|
#define AppPageSettings 3
|
||||||
|
#define WaylandSearchCenter 1
|
||||||
|
#define OtherSearchCenter 2
|
||||||
|
#define RightSearchSpace 1
|
||||||
|
#define UploadServerUrl "https://upload.deepinos.org/"
|
||||||
|
|
||||||
MainWindow::MainWindow(QWidget *parent)
|
MainWindow::MainWindow(QWidget *parent)
|
||||||
: BaseWidgetOpacity(parent)
|
: BaseWidgetOpacity(parent)
|
||||||
, ui(new Ui::MainWindow)
|
, ui(new Ui::MainWindow)
|
||||||
|
, downloadlistwidget(new DownloadListWidget)
|
||||||
|
, trayIcon(new QSystemTrayIcon(QIcon::fromTheme("spark-store"), this))
|
||||||
{
|
{
|
||||||
ui->setupUi(this);
|
ui->setupUi(this);
|
||||||
initConfig();
|
|
||||||
moveToCenter(this); //让窗口居中显示
|
|
||||||
|
|
||||||
WidgetAnimation::widgetOpacity(this,true);
|
initTmpDir();
|
||||||
|
|
||||||
|
initUI();
|
||||||
|
initConnections();
|
||||||
|
|
||||||
downloadlistwidget = new DownloadListWidget;
|
|
||||||
downloadButton = new ProgressButton(ui->titlebar);
|
|
||||||
backButtom = new QPushButton(ui->titlebar);
|
|
||||||
ui->appintopage->setDownloadWidget(downloadlistwidget);
|
ui->appintopage->setDownloadWidget(downloadlistwidget);
|
||||||
ui->stackedWidget->setCurrentIndex(0);
|
|
||||||
ui->titlebar->setBackgroundTransparent(true);
|
|
||||||
//ui->titlebar->setSwitchThemeMenuVisible(false); // 去除 dtk 标题栏主题切换菜单
|
|
||||||
setMaskAlpha(250);
|
|
||||||
|
|
||||||
updateUi(0);
|
|
||||||
|
|
||||||
QAction *actionSubmission = new QAction(tr("Submit App"), this);
|
|
||||||
QAction *actionSubmissionWithClient = new QAction(tr("Submit App with client(Recommanded)"), this);
|
|
||||||
QAction *setting = new QAction(tr("Settings"));
|
|
||||||
QAction *upgrade = new QAction(tr("APP Upgrade and Install Settings"));
|
|
||||||
QMenu *menu = new QMenu;
|
|
||||||
menu->addAction(setting);
|
|
||||||
menu->addAction(upgrade);
|
|
||||||
menu->addAction(actionSubmission);
|
|
||||||
menu->addAction(actionSubmissionWithClient);
|
|
||||||
|
|
||||||
ui->titlebar->setMenu(menu);
|
|
||||||
connect(actionSubmission, &QAction::triggered, this, [=]{QDesktopServices::openUrl(QUrl("https://upload.deepinos.org/"));});
|
|
||||||
connect(setting, &QAction::triggered, this, [=]{
|
|
||||||
switchPage(AppPageSettings);
|
|
||||||
ui->settingspage->updateUI();
|
|
||||||
});
|
|
||||||
connect(upgrade, &QAction::triggered, this, [=]{QProcess::startDetached("/opt/durapps/spark-store/bin/update-upgrade/ss-update-controler.sh");});
|
|
||||||
// 投稿器
|
|
||||||
connect(actionSubmissionWithClient, &QAction::triggered, this, [=]
|
|
||||||
{
|
|
||||||
QString submitterSpk = "spk://store/tools/spark-store-submitter";
|
|
||||||
QFile actionSubmissionClientStatus("/opt/spark-store-submitter/bin/spark-store-submitter");
|
|
||||||
if (actionSubmissionClientStatus.exists())
|
|
||||||
{
|
|
||||||
qDebug() << "投稿器存在";
|
|
||||||
QProcess::startDetached("/opt/spark-store-submitter/bin/spark-store-submitter");
|
|
||||||
}
|
|
||||||
else{
|
|
||||||
qDebug() << "投稿器不存在,跳转页面";
|
|
||||||
openUrl(submitterSpk);
|
|
||||||
}
|
|
||||||
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
//主题切换
|
|
||||||
connect(DGuiApplicationHelper::instance(), &DGuiApplicationHelper::themeTypeChanged, this, [=](DGuiApplicationHelper::ColorType themeType) {
|
|
||||||
if (themeType == DGuiApplicationHelper::DarkType) {
|
|
||||||
//深色模式
|
|
||||||
setMaskColor(QColor("#2a2b2b"));
|
|
||||||
this->setStyleSheet("#mainpage{background-color: transparent;border-radius:14px;}\
|
|
||||||
QLabel#cardtitle,QLabel#title,QLabel#title_1,QLabel#title_2,QLabel#title_3 {color:#FFFFFF}\
|
|
||||||
");
|
|
||||||
backButtom->setIcon(QIcon(":/icon/dark/back.svg"));
|
|
||||||
downloadButton->setIcon(":/icon/dark/download.svg");
|
|
||||||
downloadButton->setBackgroundColor(QColor("#444444"));
|
|
||||||
downloadButton->setColor(QColor("#66CCFF"));
|
|
||||||
ui->pushButton_14->setIcon(QIcon(":/icon/dark/update.svg"));
|
|
||||||
int i = 0;
|
|
||||||
while (i < ui->buttonGroup->buttons().size()) {
|
|
||||||
ui->buttonGroup->buttons()[i]->setIcon(QIcon(":/icon/dark/leftbutton_" + QString::number(i) + ".svg"));
|
|
||||||
if (QLocale::system().name() == "zh_CN") {
|
|
||||||
ui->buttonGroup->buttons()[i]->setStyleSheet("QPushButton{background-color:transparent;}\
|
|
||||||
QPushButton:hover{background-color:#7a7a7a;border:0px;border-radius:8px;}\
|
|
||||||
QPushButton:checked{background-color:#6e6e6e;border:0px;border-radius:8px;}");
|
|
||||||
} else {
|
|
||||||
ui->buttonGroup->buttons()[i]->setStyleSheet("QPushButton{background-color:transparent;text-align: left; padding-left: 15px;}\
|
|
||||||
QPushButton:hover{background-color:#7a7a7a;border:0px;border-radius:8px;text-align: left; padding-left: 15px;}\
|
|
||||||
QPushButton:checked{background-color:#6e6e6e;border:0px;border-radius:8px;text-align: left; padding-left: 15px;}");
|
|
||||||
}
|
|
||||||
i++;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
//亮色模式
|
|
||||||
setMaskColor(QColor("#f3f7f8"));
|
|
||||||
this->setStyleSheet("#mainpage{background-color: transparent;border-radius:14px;}\
|
|
||||||
QLabel#cardtitle,QLabel#title,QLabel#title_1,QLabel#title_2,QLabel#title_3 {color:#000000}\
|
|
||||||
");
|
|
||||||
backButtom->setIcon(QIcon(":/icon/light/back.svg"));
|
|
||||||
downloadButton->setBackgroundColor(QColor("#e3e4e4"));
|
|
||||||
downloadButton->setColor(QColor("#66CCFF"));
|
|
||||||
downloadButton->setIcon(":/icon/light/download.svg");
|
|
||||||
ui->pushButton_14->setIcon(QIcon(":/icon/light/update.svg"));
|
|
||||||
int i = 0;
|
|
||||||
while (i < ui->buttonGroup->buttons().size()) {
|
|
||||||
ui->buttonGroup->buttons()[i]->setIcon(QIcon(":/icon/light/leftbutton_" + QString::number(i) + ".svg"));
|
|
||||||
if (QLocale::system().name() == "zh_CN") {
|
|
||||||
ui->buttonGroup->buttons()[i]->setStyleSheet("QPushButton{background-color:transparent;}\
|
|
||||||
QPushButton:hover{background-color:#eAeAeA;border:0px;border-radius:8px;}\
|
|
||||||
QPushButton:checked{background-color:#dddddd;border:0px;border-radius:8px;}");
|
|
||||||
} else {
|
|
||||||
ui->buttonGroup->buttons()[i]->setStyleSheet("QPushButton{background-color:transparent;text-align: left; padding-left: 15px;}\
|
|
||||||
QPushButton:hover{background-color:#eAeAeA;border:0px;border-radius:8px;text-align: left; padding-left: 15px;}\
|
|
||||||
QPushButton:checked{background-color:#dddddd;border:0px;border-radius:8px;text-align: left; padding-left: 15px;}");
|
|
||||||
}
|
|
||||||
i++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
ui->pushButton_14->setStyleSheet(ui->pushButton_4->styleSheet());
|
|
||||||
ui->applistpage->setTheme(themeType == DGuiApplicationHelper::DarkType);
|
|
||||||
ui->applistpage_1->setTheme(themeType == DGuiApplicationHelper::DarkType);
|
|
||||||
ui->appintopage->setTheme(themeType == DGuiApplicationHelper::DarkType);
|
|
||||||
ui->settingspage->setTheme(themeType == DGuiApplicationHelper::DarkType);
|
|
||||||
});
|
|
||||||
|
|
||||||
//初始化标题栏控件
|
|
||||||
connect(downloadButton, &ProgressButton::clicked, [=]() {
|
|
||||||
QPoint pos;
|
|
||||||
pos.setX(downloadButton->mapToGlobal(QPoint(0, 0)).x() + downloadButton->width() / 2 - downloadlistwidget->width() / 2);
|
|
||||||
pos.setY(downloadButton->mapToGlobal(QPoint(0, 0)).y() + downloadButton->height() + 5);
|
|
||||||
downloadlistwidget->m_move(pos.x(), pos.y());
|
|
||||||
downloadlistwidget->show();
|
|
||||||
});
|
|
||||||
|
|
||||||
//appintopage按下下载按钮时标题栏下载列表按钮抖动
|
|
||||||
connect(ui->appintopage, &AppIntoPage::clickedDownloadBtn, [=]() {
|
|
||||||
WidgetAnimation::widgetShake(downloadButton,6);//第一个参数是抖动的控件,第二个参数是抖动范围(像素)
|
|
||||||
});
|
|
||||||
|
|
||||||
connect(backButtom, &QPushButton::clicked, [=]() {
|
|
||||||
ui->stackedWidget->setCurrentIndex(pageHistory.at(pageHistory.count() - 2));
|
|
||||||
pageHistory.removeLast();
|
|
||||||
if (pageHistory.count() > 1) {
|
|
||||||
backButtom->show();
|
|
||||||
} else {
|
|
||||||
backButtom->hide();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
downloadlistwidget->hide();
|
|
||||||
backButtom->hide();
|
|
||||||
ui->titlebar->setIcon(QIcon::fromTheme(":/icon/logo.svg"));
|
|
||||||
QWidget *w_titlebar = new QWidget(ui->titlebar);
|
|
||||||
QHBoxLayout *ly_titlebar = new QHBoxLayout(w_titlebar);
|
|
||||||
QLabel *title = new QLabel(this);
|
|
||||||
title->setText(tr("Spark Store"));
|
|
||||||
searchEdit->setPlaceholderText(tr("Search or enter spk://"));
|
|
||||||
ly_titlebar->addWidget(title);
|
|
||||||
ly_titlebar->addWidget(backButtom);
|
|
||||||
ly_titlebar->addStretch(2.5);
|
|
||||||
ly_titlebar->addWidget(searchEdit);
|
|
||||||
ly_titlebar->addWidget(downloadButton);
|
|
||||||
ly_titlebar->addStretch(1);
|
|
||||||
ui->titlebar->setCustomWidget(w_titlebar);
|
|
||||||
//侧边栏按钮
|
|
||||||
int i = 0;
|
|
||||||
while (i < ui->buttonGroup->buttons().size()) {
|
|
||||||
ui->buttonGroup->buttons()[i]->setStyleSheet("QPushButton{qproperty-icon: url(data/images/userMangaer/teacher.png);}");
|
|
||||||
connect(ui->buttonGroup->buttons()[i], &QPushButton::toggled, [=](bool checked) {
|
|
||||||
if (checked == true) {
|
|
||||||
searchEdit->clearEdit();
|
|
||||||
updateUi(i);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
i++;
|
|
||||||
}
|
|
||||||
|
|
||||||
// 搜索事件
|
|
||||||
connect(searchEdit, &DSearchEdit::returnPressed, this, [=]() {
|
|
||||||
QString searchtext = searchEdit->text();
|
|
||||||
if (!searchtext.isEmpty()) {
|
|
||||||
if (searchtext.startsWith("spk://")) {
|
|
||||||
openUrl(QUrl(searchtext));
|
|
||||||
searchEdit->clearEdit();
|
|
||||||
} else {
|
|
||||||
ui->applistpage_1->getSearchList(searchtext);
|
|
||||||
switchPage(AppPageSearchlist);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
this->setFocus();
|
|
||||||
});
|
|
||||||
|
|
||||||
connect(downloadlistwidget, &DownloadListWidget::downloadProgress, this, [=](int i) {
|
|
||||||
downloadButton->setProgress(i);
|
|
||||||
});
|
|
||||||
// 列表点击事件
|
|
||||||
connect(ui->applistpage, &AppListPage::clicked, this, [=](QUrl spk) {
|
|
||||||
openUrl(spk);
|
|
||||||
});
|
|
||||||
connect(ui->applistpage_1, &AppListPage::clicked, this, [=](QUrl spk) {
|
|
||||||
openUrl(spk);
|
|
||||||
});
|
|
||||||
connect(ui->settingspage, &SettingsPage::openUrl, this, [=](QUrl spk) {
|
|
||||||
openUrl(spk);
|
|
||||||
});
|
|
||||||
emit DGuiApplicationHelper::instance()->themeTypeChanged(DGuiApplicationHelper::instance()->themeType());
|
emit DGuiApplicationHelper::instance()->themeTypeChanged(DGuiApplicationHelper::instance()->themeType());
|
||||||
|
|
||||||
initDbus();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
MainWindow::~MainWindow()
|
MainWindow::~MainWindow()
|
||||||
{
|
{
|
||||||
delete searchEdit;
|
|
||||||
delete downloadlistwidget;
|
|
||||||
delete ui;
|
delete ui;
|
||||||
|
|
||||||
|
downloadlistwidget->deleteLater();
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::initDbus()
|
void MainWindow::initDbus()
|
||||||
@@ -228,24 +60,319 @@ void MainWindow::initDbus()
|
|||||||
|
|
||||||
void MainWindow::onGetUrl(const QString &url)
|
void MainWindow::onGetUrl(const QString &url)
|
||||||
{
|
{
|
||||||
if(url.left(6)=="spk://")
|
if (url.trimmed().startsWith("spk://"))
|
||||||
{
|
{
|
||||||
openUrl(QUrl(url));
|
openUrl(url);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
showWindowAnimation = false;
|
||||||
|
closeWindowAnimation = false;
|
||||||
|
|
||||||
|
setWindowState(windowState() & Qt::WindowActive);
|
||||||
activateWindow();
|
activateWindow();
|
||||||
|
show();
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::openUrl(QUrl url)
|
void MainWindow::onNewProcessInstance(qint64 pid, const QStringList &arguments)
|
||||||
{
|
{
|
||||||
if (url.toString().startsWith("spk://")) {
|
Q_UNUSED(pid)
|
||||||
ui->appintopage->openUrl(QUrl(url.toString().replace("+","%2B")));
|
|
||||||
|
onGetUrl(arguments.value(1, ""));
|
||||||
|
}
|
||||||
|
|
||||||
|
void MainWindow::openUrl(const QString &url)
|
||||||
|
{
|
||||||
|
if (url.startsWith("spk://search/"))
|
||||||
|
{
|
||||||
|
QString keyword = url.mid(13);
|
||||||
|
if (keyword == "%")
|
||||||
|
{
|
||||||
|
qWarning() << "keyword '%' is not valid, which will cause QtWebEngine crash.";
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
ui->applistpage_1->getSearchList(keyword);
|
||||||
|
switchPage(AppPageSearchlist);
|
||||||
|
}
|
||||||
|
else if (url.startsWith("spk://"))
|
||||||
|
{
|
||||||
|
ui->appintopage->openUrl(QUrl::fromUserInput(url));
|
||||||
switchPage(AppPageAppdetail);
|
switchPage(AppPageAppdetail);
|
||||||
} else {
|
}
|
||||||
QDesktopServices::openUrl(QUrl(url.toString().replace("+","%2B")));
|
else
|
||||||
|
{
|
||||||
|
QDesktopServices::openUrl(QUrl::fromUserInput(url));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::initConfig()
|
void MainWindow::initUI()
|
||||||
|
{
|
||||||
|
setWindowTitle(QObject::tr("Spark Store"));
|
||||||
|
setMaskAlpha(250);
|
||||||
|
|
||||||
|
initTitleBar();
|
||||||
|
initLeftMenu();
|
||||||
|
|
||||||
|
ui->stackedWidget->setCurrentIndex(0);
|
||||||
|
updateUi(0);
|
||||||
|
|
||||||
|
initTrayIcon();
|
||||||
|
}
|
||||||
|
|
||||||
|
void MainWindow::initTitleBar()
|
||||||
|
{
|
||||||
|
ui->titlebar->setIcon(QIcon::fromTheme("spark-store"));
|
||||||
|
ui->titlebar->setBackgroundTransparent(true);
|
||||||
|
// ui->titlebar->setSwitchThemeMenuVisible(false); // 去除 dtk 标题栏主题切换菜单
|
||||||
|
|
||||||
|
// 初始化标题栏控件
|
||||||
|
DLabel *title = new DLabel(ui->titlebar);
|
||||||
|
title->setText(tr("Spark Store"));
|
||||||
|
|
||||||
|
backButton = new DPushButton(ui->titlebar);
|
||||||
|
|
||||||
|
searchEdit = new DSearchEdit(ui->titlebar);
|
||||||
|
searchEdit->setPlaceholderText(tr("Search or enter spk://"));
|
||||||
|
|
||||||
|
downloadButton = new ProgressButton(ui->titlebar);
|
||||||
|
downloadButton->setDownloadListWidget(downloadlistwidget);
|
||||||
|
downloadButton->setFocusPolicy(Qt::FocusPolicy::ClickFocus);
|
||||||
|
downloadlistwidget->setFocusProxy(downloadButton);
|
||||||
|
|
||||||
|
QWidget *w_titlebar = new QWidget(ui->titlebar);
|
||||||
|
QHBoxLayout *ly_titlebar = new QHBoxLayout(w_titlebar);
|
||||||
|
ly_titlebar->addWidget(title);
|
||||||
|
ly_titlebar->addWidget(backButton);
|
||||||
|
// Check wayland configs
|
||||||
|
QSettings config(QStandardPaths::writableLocation(QStandardPaths::AppConfigLocation) + "/config.ini", QSettings::IniFormat);
|
||||||
|
if (!config.value("runtime/isDDE").toBool() && config.value("runtime/useWayland").toBool())
|
||||||
|
{
|
||||||
|
// Wayland 搜索栏居中
|
||||||
|
ly_titlebar->addStretch(WaylandSearchCenter);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// dwayland dxcb 搜索栏顶部右侧居中
|
||||||
|
ly_titlebar->addStretch(OtherSearchCenter);
|
||||||
|
}
|
||||||
|
ly_titlebar->addWidget(searchEdit);
|
||||||
|
ly_titlebar->addWidget(downloadButton);
|
||||||
|
ly_titlebar->addStretch(RightSearchSpace);
|
||||||
|
ui->titlebar->setCustomWidget(w_titlebar);
|
||||||
|
|
||||||
|
initTitleBarMenu();
|
||||||
|
|
||||||
|
backButton->hide();
|
||||||
|
downloadlistwidget->hide();
|
||||||
|
}
|
||||||
|
|
||||||
|
void MainWindow::initTitleBarMenu()
|
||||||
|
{
|
||||||
|
QAction *actionSubmission = new QAction(tr("Submit App"), this);
|
||||||
|
QAction *actionSubmissionWithClient = new QAction(tr("Submit App with client(Recommanded)"), this);
|
||||||
|
QAction *setting = new QAction(tr("Settings"));
|
||||||
|
QAction *upgrade = new QAction(tr("APP Upgrade and Install Settings"));
|
||||||
|
QMenu *menu = new QMenu(ui->titlebar);
|
||||||
|
menu->addAction(setting);
|
||||||
|
menu->addAction(upgrade);
|
||||||
|
menu->addAction(actionSubmission);
|
||||||
|
menu->addAction(actionSubmissionWithClient);
|
||||||
|
|
||||||
|
ui->titlebar->setMenu(menu);
|
||||||
|
|
||||||
|
connect(actionSubmission, &QAction::triggered, this, [=]
|
||||||
|
{ QDesktopServices::openUrl(QUrl(UploadServerUrl)); });
|
||||||
|
connect(setting, &QAction::triggered, this, [=]
|
||||||
|
{
|
||||||
|
switchPage(AppPageSettings);
|
||||||
|
ui->settingspage->updateUI(); });
|
||||||
|
connect(upgrade, &QAction::triggered, this, [=]
|
||||||
|
{ QProcess::startDetached("/opt/durapps/spark-store/bin/update-upgrade/ss-update-controler.sh", QStringList()); });
|
||||||
|
// 投稿器
|
||||||
|
connect(actionSubmissionWithClient, &QAction::triggered, this, [=]
|
||||||
|
{
|
||||||
|
QString submitterSpk = "spk://store/tools/spark-store-submitter";
|
||||||
|
QFile actionSubmissionClientStatus("/opt/spark-store-submitter/bin/spark-store-submitter");
|
||||||
|
if (actionSubmissionClientStatus.exists())
|
||||||
|
{
|
||||||
|
qDebug() << "投稿器存在";
|
||||||
|
QProcess::startDetached("/opt/spark-store-submitter/bin/spark-store-submitter", QStringList());
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
qDebug() << "投稿器不存在,跳转页面";
|
||||||
|
openUrl(submitterSpk);
|
||||||
|
} });
|
||||||
|
}
|
||||||
|
|
||||||
|
void MainWindow::initLeftMenu()
|
||||||
|
{
|
||||||
|
// 侧边栏按钮
|
||||||
|
foreach (QAbstractButton *button, ui->buttonGroup->buttons())
|
||||||
|
{
|
||||||
|
button->setStyleSheet("QPushButton{qproperty-icon: url(data/images/userMangaer/teacher.png);}");
|
||||||
|
connect(button, &QPushButton::toggled, [=](bool checked)
|
||||||
|
{
|
||||||
|
if (checked == true) {
|
||||||
|
searchEdit->clearEdit();
|
||||||
|
updateUi(ui->buttonGroup->buttons().indexOf(button));
|
||||||
|
} });
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void MainWindow::initTrayIcon()
|
||||||
|
{
|
||||||
|
trayIcon->setToolTip(tr("Spark Store"));
|
||||||
|
|
||||||
|
QMenu *menu = new QMenu(this);
|
||||||
|
QAction *showAction = new QAction(QObject::tr("Show MainWindow"), menu);
|
||||||
|
QAction *aboutAction = new QAction(qApp->translate("TitleBarMenu", "About"), menu);
|
||||||
|
QAction *exitAction = new QAction(qApp->translate("TitleBarMenu", "Exit"), menu);
|
||||||
|
menu->addAction(showAction);
|
||||||
|
menu->addAction(aboutAction);
|
||||||
|
menu->addAction(exitAction);
|
||||||
|
trayIcon->setContextMenu(menu);
|
||||||
|
|
||||||
|
connect(showAction, &QAction::triggered, this, [=]()
|
||||||
|
{
|
||||||
|
showWindowAnimation = false;
|
||||||
|
closeWindowAnimation = false;
|
||||||
|
|
||||||
|
setWindowState(windowState() & Qt::WindowActive);
|
||||||
|
activateWindow();
|
||||||
|
show(); });
|
||||||
|
connect(aboutAction, &QAction::triggered, this, [=]()
|
||||||
|
{
|
||||||
|
qobject_cast<Application *>(qApp)->handleAboutAction(); });
|
||||||
|
connect(exitAction, &QAction::triggered, this, [=]()
|
||||||
|
{
|
||||||
|
qobject_cast<Application *>(qApp)->quit(); });
|
||||||
|
|
||||||
|
trayIcon->show();
|
||||||
|
}
|
||||||
|
|
||||||
|
void MainWindow::initConnections()
|
||||||
|
{
|
||||||
|
// 主题切换
|
||||||
|
connect(DGuiApplicationHelper::instance(), &DGuiApplicationHelper::themeTypeChanged, this, [=](DGuiApplicationHelper::ColorType themeType)
|
||||||
|
{
|
||||||
|
if (themeType == DGuiApplicationHelper::DarkType) {
|
||||||
|
//深色模式
|
||||||
|
setMaskColor(QColor("#2a2b2b"));
|
||||||
|
backButton->setIcon(QIcon(":/icon/dark/back.svg"));
|
||||||
|
downloadButton->setIcon(":/icon/dark/download.svg");
|
||||||
|
downloadButton->setBackgroundColor(QColor("#444444"));
|
||||||
|
downloadButton->setColor(QColor("#66CCFF"));
|
||||||
|
ui->pushButton_14->setIcon(QIcon(":/icon/dark/update.svg"));
|
||||||
|
for (int i = 0; i < ui->buttonGroup->buttons().size(); i++) {
|
||||||
|
ui->buttonGroup->buttons()[i]->setIcon(QIcon(":/icon/dark/leftbutton_" + QString::number(i) + ".svg"));
|
||||||
|
if (QLocale::system().name() == "zh_CN") {
|
||||||
|
ui->buttonGroup->buttons()[i]->setStyleSheet("QPushButton{background-color:transparent;}\
|
||||||
|
QPushButton:hover{background-color:#7a7a7a;border:0px;border-radius:8px;}\
|
||||||
|
QPushButton:checked{background-color:#6e6e6e;border:0px;border-radius:8px;}");
|
||||||
|
} else {
|
||||||
|
ui->buttonGroup->buttons()[i]->setStyleSheet("QPushButton{background-color:transparent;text-align: left; padding-left: 15px;}\
|
||||||
|
QPushButton:hover{background-color:#7a7a7a;border:0px;border-radius:8px;text-align: left; padding-left: 15px;}\
|
||||||
|
QPushButton:checked{background-color:#6e6e6e;border:0px;border-radius:8px;text-align: left; padding-left: 15px;}");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
//亮色模式
|
||||||
|
setMaskColor(QColor("#f3f7f8"));
|
||||||
|
backButton->setIcon(QIcon(":/icon/light/back.svg"));
|
||||||
|
downloadButton->setBackgroundColor(QColor("#e3e4e4"));
|
||||||
|
downloadButton->setColor(QColor("#66CCFF"));
|
||||||
|
downloadButton->setIcon(":/icon/light/download.svg");
|
||||||
|
ui->pushButton_14->setIcon(QIcon(":/icon/light/update.svg"));
|
||||||
|
for (int i = 0; i < ui->buttonGroup->buttons().size(); i++) {
|
||||||
|
ui->buttonGroup->buttons()[i]->setIcon(QIcon(":/icon/light/leftbutton_" + QString::number(i) + ".svg"));
|
||||||
|
if (QLocale::system().name() == "zh_CN") {
|
||||||
|
ui->buttonGroup->buttons()[i]->setStyleSheet("QPushButton{background-color:transparent;}\
|
||||||
|
QPushButton:hover{background-color:#eAeAeA;border:0px;border-radius:8px;}\
|
||||||
|
QPushButton:checked{background-color:#dddddd;border:0px;border-radius:8px;}");
|
||||||
|
} else {
|
||||||
|
ui->buttonGroup->buttons()[i]->setStyleSheet("QPushButton{background-color:transparent;text-align: left; padding-left: 15px;}\
|
||||||
|
QPushButton:hover{background-color:#eAeAeA;border:0px;border-radius:8px;text-align: left; padding-left: 15px;}\
|
||||||
|
QPushButton:checked{background-color:#dddddd;border:0px;border-radius:8px;text-align: left; padding-left: 15px;}");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
ui->pushButton_14->setStyleSheet(ui->pushButton_4->styleSheet());
|
||||||
|
ui->applistpage->setTheme(themeType == DGuiApplicationHelper::DarkType);
|
||||||
|
ui->applistpage_1->setTheme(themeType == DGuiApplicationHelper::DarkType);
|
||||||
|
ui->appintopage->setTheme(themeType == DGuiApplicationHelper::DarkType);
|
||||||
|
ui->settingspage->setTheme(themeType == DGuiApplicationHelper::DarkType); });
|
||||||
|
|
||||||
|
// appintopage按下下载按钮时标题栏下载列表按钮抖动
|
||||||
|
connect(ui->appintopage, &AppIntoPage::clickedDownloadBtn, [=]()
|
||||||
|
{
|
||||||
|
WidgetAnimation::widgetShake(downloadButton, 6); // 第一个参数是抖动的控件,第二个参数是抖动范围(像素)
|
||||||
|
});
|
||||||
|
|
||||||
|
connect(backButton, &QPushButton::clicked, [=]()
|
||||||
|
{
|
||||||
|
ui->stackedWidget->setCurrentIndex(pageHistory.at(pageHistory.count() - 2));
|
||||||
|
pageHistory.removeLast();
|
||||||
|
if (pageHistory.count() > 1) {
|
||||||
|
backButton->show();
|
||||||
|
} else {
|
||||||
|
backButton->hide();
|
||||||
|
} });
|
||||||
|
|
||||||
|
// 搜索事件
|
||||||
|
connect(searchEdit, &DSearchEdit::returnPressed, this, [=]()
|
||||||
|
{
|
||||||
|
QString searchtext = searchEdit->text();
|
||||||
|
if (!searchtext.isEmpty()) {
|
||||||
|
if (searchtext.startsWith("spk://")) {
|
||||||
|
openUrl(searchtext);
|
||||||
|
searchEdit->clearEdit();
|
||||||
|
} else {
|
||||||
|
if (searchtext == "%")
|
||||||
|
{
|
||||||
|
qWarning() << "keyword '%' matches too many results, which will cause QtWebEngine crash.";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ui->applistpage_1->getSearchList(searchtext);
|
||||||
|
switchPage(AppPageSearchlist);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
this->setFocus(); });
|
||||||
|
|
||||||
|
connect(downloadlistwidget, &DownloadListWidget::downloadProgress, this, [=](int i)
|
||||||
|
{ downloadButton->setProgress(i); });
|
||||||
|
// 列表点击事件
|
||||||
|
connect(ui->applistpage, &AppListPage::clicked, this, [=](QUrl spk)
|
||||||
|
{ openUrl(spk.toString()); });
|
||||||
|
connect(ui->applistpage_1, &AppListPage::clicked, this, [=](QUrl spk)
|
||||||
|
{ openUrl(spk.toString()); });
|
||||||
|
connect(ui->settingspage, &SettingsPage::openUrl, this, [=](QUrl spk)
|
||||||
|
{ openUrl(spk.toString()); });
|
||||||
|
|
||||||
|
// 托盘图标点击事件
|
||||||
|
connect(trayIcon, &QSystemTrayIcon::activated, this, [=](QSystemTrayIcon::ActivationReason reason)
|
||||||
|
{
|
||||||
|
switch (reason) {
|
||||||
|
case QSystemTrayIcon::Trigger:
|
||||||
|
{
|
||||||
|
showWindowAnimation = false;
|
||||||
|
closeWindowAnimation = false;
|
||||||
|
|
||||||
|
setWindowState(windowState() & Qt::WindowActive);
|
||||||
|
activateWindow();
|
||||||
|
show();
|
||||||
|
|
||||||
|
Q_FALLTHROUGH();
|
||||||
|
}
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
} });
|
||||||
|
|
||||||
|
connect(DGuiApplicationHelper::instance(), &DGuiApplicationHelper::newProcessInstance, this, &MainWindow::onNewProcessInstance);
|
||||||
|
}
|
||||||
|
|
||||||
|
void MainWindow::initTmpDir()
|
||||||
{
|
{
|
||||||
// 新建临时文件夹
|
// 新建临时文件夹
|
||||||
QDir dir;
|
QDir dir;
|
||||||
@@ -255,12 +382,16 @@ void MainWindow::initConfig()
|
|||||||
void MainWindow::switchPage(int now) // 临时方案,回家后修改
|
void MainWindow::switchPage(int now) // 临时方案,回家后修改
|
||||||
{
|
{
|
||||||
qDebug() << pageHistory.count();
|
qDebug() << pageHistory.count();
|
||||||
if (pageHistory.count() >= 1) {
|
if (pageHistory.count() >= 1)
|
||||||
backButtom->show();
|
{
|
||||||
} else {
|
backButton->show();
|
||||||
backButtom->hide();
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
backButton->hide();
|
||||||
}
|
}
|
||||||
ui->stackedWidget->setCurrentIndex(now);
|
ui->stackedWidget->setCurrentIndex(now);
|
||||||
|
ui->stackedWidget->currentWidget()->setFocus();
|
||||||
pageHistory << now;
|
pageHistory << now;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -287,15 +418,69 @@ void MainWindow::updateUi(int now)
|
|||||||
switchPage(AppPageApplist);
|
switchPage(AppPageApplist);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void MainWindow::notify(QObject *receiver, QEvent *event)
|
||||||
|
{
|
||||||
|
if (!receiver) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
Dtk::Widget::DStyle *o_ptr = qobject_cast<Dtk::Widget::DStyle *>(receiver);
|
||||||
|
if (o_ptr) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (receiver->inherits("QWidgetWindow")
|
||||||
|
|| receiver->inherits("QStyleSheetStyle")) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (event->type() == QEvent::FocusIn) {
|
||||||
|
QList<QObject *> list = downloadButton->findChildren<QObject *>(QString(), Qt::FindChildrenRecursively);
|
||||||
|
list << downloadlistwidget->findChildren<QObject *>(QString(), Qt::FindChildrenRecursively);
|
||||||
|
if (receiver != downloadButton && receiver != downloadlistwidget && !list.contains(receiver)) {
|
||||||
|
downloadlistwidget->hide();
|
||||||
|
}
|
||||||
|
} else if (event->type() == QEvent::FocusOut) {
|
||||||
|
if (!downloadlistwidget->isActiveWindow() && !isActiveWindow()) {
|
||||||
|
downloadlistwidget->hide();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void MainWindow::on_pushButton_14_clicked()
|
void MainWindow::on_pushButton_14_clicked()
|
||||||
{
|
{
|
||||||
QFile upgradeStatus("/tmp/spark-store/upgradeStatus.txt");
|
// Check UOS
|
||||||
if (!upgradeStatus.exists()){
|
QSettings config(QStandardPaths::writableLocation(QStandardPaths::AppConfigLocation) + "/config.ini", QSettings::IniFormat);
|
||||||
QtConcurrent::run([=]{
|
if (config.contains("UOS/EnableDeveloperMode") && !config.value("UOS/EnableDeveloperMode").toBool())
|
||||||
|
{
|
||||||
|
qDebug() << "UOS Developer Mode has not been enabled!";
|
||||||
|
QtConcurrent::run([=]
|
||||||
|
{
|
||||||
auto upgradeP = new QProcess();
|
auto upgradeP = new QProcess();
|
||||||
upgradeP->startDetached("/opt/durapps/spark-store/bin/update-upgrade/ss-do-upgrade.sh");
|
upgradeP->startDetached("zenity", QStringList() << "--info"
|
||||||
|
<< "--text"
|
||||||
|
<< "UOS开发者模式未开启,相关功能被禁用"
|
||||||
|
<< "--title"
|
||||||
|
<< "功能禁用提示"
|
||||||
|
<< "--width"
|
||||||
|
<< "360"
|
||||||
|
);
|
||||||
|
upgradeP->waitForStarted();
|
||||||
|
upgradeP->waitForFinished(30);
|
||||||
|
upgradeP->deleteLater(); });
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
QFile upgradeStatus("/tmp/spark-store/upgradeStatus.txt");
|
||||||
|
if (!upgradeStatus.exists())
|
||||||
|
{
|
||||||
|
QtConcurrent::run([=]
|
||||||
|
{
|
||||||
|
auto upgradeP = new QProcess();
|
||||||
|
upgradeP->startDetached("/opt/durapps/spark-store/bin/update-upgrade/ss-do-upgrade.sh", QStringList());
|
||||||
upgradeP->waitForStarted();
|
upgradeP->waitForStarted();
|
||||||
upgradeP->waitForFinished(-1);
|
upgradeP->waitForFinished(-1);
|
||||||
});
|
upgradeP->deleteLater(); });
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,21 +1,15 @@
|
|||||||
#ifndef MAINWINDOWDTK_H
|
#ifndef MAINWINDOWDTK_H
|
||||||
#define MAINWINDOWDTK_H
|
#define MAINWINDOWDTK_H
|
||||||
|
|
||||||
|
#include "widgets/base/basewidgetopacity.h"
|
||||||
|
|
||||||
#include <DMainWindow>
|
#include <DMainWindow>
|
||||||
#include <DTitlebar>
|
#include <DTitlebar>
|
||||||
|
#include <DPushButton>
|
||||||
#include <DSearchEdit>
|
#include <DSearchEdit>
|
||||||
#include <QGraphicsDropShadowEffect>
|
|
||||||
#include <DGuiApplicationHelper>
|
#include <DGuiApplicationHelper>
|
||||||
|
|
||||||
#include <QPushButton>
|
#include <QSystemTrayIcon>
|
||||||
#include <QDir>
|
|
||||||
#include <QDesktopServices>
|
|
||||||
|
|
||||||
#include "widgets/base/basewidgetopacity.h"
|
|
||||||
#include "widgets/downloadlistwidget.h"
|
|
||||||
#include "widgets/common/progressbutton.h"
|
|
||||||
#include "utils/widgetanimation.h"
|
|
||||||
#include "dbus/dbussparkstoreservice.h"
|
|
||||||
|
|
||||||
DWIDGET_USE_NAMESPACE
|
DWIDGET_USE_NAMESPACE
|
||||||
|
|
||||||
@@ -23,36 +17,50 @@ namespace Ui {
|
|||||||
class MainWindow;
|
class MainWindow;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
class ProgressButton;
|
||||||
|
class DownloadListWidget;
|
||||||
class MainWindow : public BaseWidgetOpacity
|
class MainWindow : public BaseWidgetOpacity
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
public:
|
public:
|
||||||
explicit MainWindow(QWidget *parent = nullptr);
|
explicit MainWindow(QWidget *parent = nullptr);
|
||||||
~MainWindow();
|
~MainWindow() override;
|
||||||
|
|
||||||
void openUrl(QUrl);
|
void openUrl(const QString &url);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
void initUI();
|
||||||
|
void initTitleBar();
|
||||||
|
void initTitleBarMenu();
|
||||||
|
void initLeftMenu();
|
||||||
|
void initTrayIcon();
|
||||||
|
void initConnections();
|
||||||
void initDbus();
|
void initDbus();
|
||||||
void initConfig();
|
void initTmpDir();
|
||||||
void switchPage(int now);
|
void switchPage(int now);
|
||||||
void updateUi(int now);
|
void updateUi(int now);
|
||||||
|
|
||||||
private:
|
public slots:
|
||||||
QList<int> pageHistory;
|
void notify(QObject *receiver, QEvent *event);
|
||||||
|
|
||||||
DownloadListWidget *downloadlistwidget;
|
|
||||||
ProgressButton *downloadButton;
|
|
||||||
QPushButton *backButtom;
|
|
||||||
DSearchEdit *searchEdit = new DSearchEdit;
|
|
||||||
Ui::MainWindow *ui;
|
|
||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
//接受来自dbus的url
|
//接受来自dbus的url
|
||||||
void onGetUrl(const QString &url);
|
void onGetUrl(const QString &url);
|
||||||
|
void onNewProcessInstance(qint64 pid, const QStringList &arguments);
|
||||||
void on_pushButton_14_clicked();
|
void on_pushButton_14_clicked();
|
||||||
|
|
||||||
|
private:
|
||||||
|
Ui::MainWindow *ui;
|
||||||
|
|
||||||
|
DPushButton *backButton;
|
||||||
|
DSearchEdit *searchEdit;
|
||||||
|
ProgressButton *downloadButton;
|
||||||
|
DownloadListWidget *downloadlistwidget;
|
||||||
|
|
||||||
|
QSystemTrayIcon *trayIcon = nullptr;
|
||||||
|
|
||||||
|
QList<int> pageHistory;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // MAINWINDOWDTK_H
|
#endif // MAINWINDOWDTK_H
|
||||||
|
|||||||
@@ -7,7 +7,7 @@
|
|||||||
<x>0</x>
|
<x>0</x>
|
||||||
<y>0</y>
|
<y>0</y>
|
||||||
<width>1190</width>
|
<width>1190</width>
|
||||||
<height>651</height>
|
<height>656</height>
|
||||||
</rect>
|
</rect>
|
||||||
</property>
|
</property>
|
||||||
<property name="windowTitle">
|
<property name="windowTitle">
|
||||||
@@ -34,6 +34,12 @@
|
|||||||
<property name="autoFillBackground">
|
<property name="autoFillBackground">
|
||||||
<bool>true</bool>
|
<bool>true</bool>
|
||||||
</property>
|
</property>
|
||||||
|
<property name="styleSheet">
|
||||||
|
<string notr="true">.QWidget#mainpage {
|
||||||
|
background: transparent;
|
||||||
|
border-radius: 14px;
|
||||||
|
}</string>
|
||||||
|
</property>
|
||||||
<layout class="QGridLayout" name="gridLayout_2">
|
<layout class="QGridLayout" name="gridLayout_2">
|
||||||
<property name="leftMargin">
|
<property name="leftMargin">
|
||||||
<number>0</number>
|
<number>0</number>
|
||||||
|
|||||||
@@ -1,84 +1,42 @@
|
|||||||
#include "appintopage.h"
|
#include "appintopage.h"
|
||||||
#include "ui_appintopage.h"
|
#include "ui_appintopage.h"
|
||||||
AppIntoPage::AppIntoPage(QWidget *parent) :
|
#include "backend/sparkapi.h"
|
||||||
QWidget(parent),
|
#include "widgets/downloadlistwidget.h"
|
||||||
ui(new Ui::AppIntoPage)
|
#include "widgets/common/downloaditem.h"
|
||||||
|
#include "backend/image_show.h"
|
||||||
|
#include "application.h"
|
||||||
|
#include "utils/utils.h"
|
||||||
|
|
||||||
|
#include <QtConcurrent>
|
||||||
|
#include <QClipboard>
|
||||||
|
|
||||||
|
AppIntoPage::AppIntoPage(QWidget *parent)
|
||||||
|
: QWidget(parent)
|
||||||
|
, ui(new Ui::AppIntoPage)
|
||||||
|
, api(new SparkAPI(this))
|
||||||
{
|
{
|
||||||
ui->setupUi(this);
|
initUI();
|
||||||
ui->listWidget->setViewMode(QListView::IconMode);
|
initConnections();
|
||||||
ui->listWidget->setMovement(QListView::Static);
|
|
||||||
ui->listWidget->setMaximumHeight(200);
|
|
||||||
ui->listWidget->setFlow(QListView::TopToBottom);
|
|
||||||
api1=new SparkAPI(this);
|
|
||||||
connect(api1,&SparkAPI::finishedRAW,[=](QString download_times){
|
|
||||||
download_times.remove(QRegExp("\\n"));
|
|
||||||
ui->download_times->setText(download_times);
|
|
||||||
qDebug()<<"Download Times:"+download_times;
|
|
||||||
});
|
|
||||||
clear();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void AppIntoPage::clear()
|
AppIntoPage::~AppIntoPage()
|
||||||
{
|
{
|
||||||
ui->tag_a2d->hide();
|
delete ui;
|
||||||
ui->tag_uos->hide();
|
|
||||||
ui->tag_dtk5->hide();
|
|
||||||
ui->tag_deepin->hide();
|
|
||||||
ui->tag_dwine2->hide();
|
|
||||||
ui->tag_dwine5->hide();
|
|
||||||
ui->tag_ubuntu->hide();
|
|
||||||
ui->tag_community->hide();
|
|
||||||
ui->icon->clear();
|
|
||||||
ui->title->clear();
|
|
||||||
ui->author->clear();
|
|
||||||
ui->label_2->clear();
|
|
||||||
ui->downloadButton->hide();
|
|
||||||
ui->downloadButton->setEnabled(true);
|
|
||||||
ui->pushButton_3->hide();
|
|
||||||
int n=ui->listWidget->count();
|
|
||||||
for(int i=0;i<n;i++)
|
|
||||||
{
|
|
||||||
QListWidgetItem *item = ui->listWidget->takeItem(0);
|
|
||||||
QWidget *card = ui->listWidget->itemWidget(item);
|
|
||||||
delete card;
|
|
||||||
card = NULL;
|
|
||||||
delete item;
|
|
||||||
item = NULL;
|
|
||||||
}
|
}
|
||||||
ui->listWidget->clear();
|
|
||||||
}
|
|
||||||
void AppIntoPage::setDownloadWidget(DownloadListWidget *w)
|
|
||||||
{
|
|
||||||
dw=w;
|
|
||||||
connect(w, &DownloadListWidget::downloadFinished, [=]() {
|
|
||||||
isDownloading(SparkAPI::getServerUrl()+"store"+spk.path()+"/"+info["Filename"].toString());
|
|
||||||
});
|
|
||||||
}
|
|
||||||
void AppIntoPage::openUrl(QUrl url)
|
|
||||||
{
|
|
||||||
spk=url;
|
|
||||||
SparkAPI *api=new SparkAPI(this);
|
|
||||||
clear();
|
|
||||||
connect(api,&SparkAPI::finishedObject,[=](QJsonObject appinfo){
|
|
||||||
|
|
||||||
info = appinfo;
|
void AppIntoPage::openUrl(const QUrl &url)
|
||||||
|
{
|
||||||
|
clear();
|
||||||
|
|
||||||
// qDebug() << url;
|
// qDebug() << url;
|
||||||
//获取图标
|
spk = url;
|
||||||
QNetworkAccessManager *naManager;
|
|
||||||
QNetworkRequest request;
|
SparkAPI *api1 = new SparkAPI(this);
|
||||||
naManager=new QNetworkAccessManager(this);
|
connect(api1, &SparkAPI::finishedObject, [=](const QJsonObject &appinfo)
|
||||||
qDebug()<<api->getImgServerUrl()+"store"+url.path().replace("+","%2B") + "/icon.png";
|
{
|
||||||
request.setUrl(QUrl(api->getImgServerUrl()+"store"+url.path().replace("+","%2B") + "/icon.png"));
|
info = appinfo;
|
||||||
request.setRawHeader("User-Agent", "Mozilla/5.0");
|
|
||||||
request.setRawHeader("Content-Type", "charset='utf-8'");
|
// 显示基本信息
|
||||||
naManager->get(request);
|
|
||||||
QObject::connect(naManager,&QNetworkAccessManager::finished,[=](QNetworkReply *reply){
|
|
||||||
QByteArray jpegData = reply->readAll();
|
|
||||||
iconpixmap.loadFromData(jpegData);
|
|
||||||
iconpixmap.scaled(210, 200, Qt::IgnoreAspectRatio, Qt::SmoothTransformation);
|
|
||||||
ui->icon->setPixmap(iconpixmap);
|
|
||||||
ui->icon->setScaledContents(true);
|
|
||||||
});
|
|
||||||
ui->title->setText(info["Name"].toString());
|
ui->title->setText(info["Name"].toString());
|
||||||
ui->version->setText(info["Version"].toString());
|
ui->version->setText(info["Version"].toString());
|
||||||
ui->author->setText(info["Author"].toString());
|
ui->author->setText(info["Author"].toString());
|
||||||
@@ -90,11 +48,78 @@ void AppIntoPage::openUrl(QUrl url)
|
|||||||
ui->d_contributor->setText(info["Contributor"].toString());
|
ui->d_contributor->setText(info["Contributor"].toString());
|
||||||
ui->label_2->setText(info["More"].toString());
|
ui->label_2->setText(info["More"].toString());
|
||||||
|
|
||||||
|
// 显示 tags
|
||||||
|
QStringList taglist = info["Tags"].toString().split(";", QString::SkipEmptyParts);
|
||||||
|
setAppinfoTags(taglist);
|
||||||
|
|
||||||
|
// 获取图标
|
||||||
|
QNetworkRequest request;
|
||||||
|
QNetworkAccessManager *manager = new QNetworkAccessManager(this);
|
||||||
|
qDebug() << api->getImgServerUrl() + "store" + url.path() + "/icon.png";
|
||||||
|
request.setUrl(QUrl(api->getImgServerUrl() + "store" + url.path() + "/icon.png"));
|
||||||
|
request.setRawHeader("User-Agent", "Mozilla/5.0");
|
||||||
|
request.setRawHeader("Content-Type", "charset='utf-8'");
|
||||||
|
manager->get(request);
|
||||||
|
QObject::connect(manager, &QNetworkAccessManager::finished, [=](QNetworkReply *reply)
|
||||||
|
{
|
||||||
|
QByteArray jpegData = reply->readAll();
|
||||||
|
iconpixmap.loadFromData(jpegData);
|
||||||
|
iconpixmap.scaled(210, 200, Qt::IgnoreAspectRatio, Qt::SmoothTransformation);
|
||||||
|
ui->icon->setPixmap(iconpixmap);
|
||||||
|
ui->icon->setScaledContents(true);
|
||||||
|
|
||||||
|
manager->deleteLater(); });
|
||||||
|
|
||||||
|
// 获取截图
|
||||||
|
QJsonParseError error;
|
||||||
|
QJsonArray array = QJsonDocument::fromJson(info.value("img_urls").toString().toUtf8(), &error).array();
|
||||||
|
QStringList imglist;
|
||||||
|
foreach (const QJsonValue &value, array) {
|
||||||
|
QString imgUrl = value.toString();
|
||||||
|
imglist.append(imgUrl);
|
||||||
|
}
|
||||||
|
qDebug() << imglist;
|
||||||
|
|
||||||
|
for (int i = 0; i < imglist.size(); i++)
|
||||||
|
{
|
||||||
|
QNetworkRequest request;
|
||||||
|
QNetworkAccessManager *manager = new QNetworkAccessManager(this);
|
||||||
|
request.setUrl(QUrl(imglist.value(i)));
|
||||||
|
request.setRawHeader("User-Agent", "Mozilla/5.0");
|
||||||
|
request.setRawHeader("Content-Type", "charset='utf-8'");
|
||||||
|
manager->get(request);
|
||||||
|
QObject::connect(manager, &QNetworkAccessManager::finished, [=](QNetworkReply *reply)
|
||||||
|
{
|
||||||
|
QByteArray jpegData = reply->readAll();
|
||||||
|
QPixmap pixmap;
|
||||||
|
pixmap.loadFromData(jpegData);
|
||||||
|
pixmap.scaled(100, 100, Qt::IgnoreAspectRatio, Qt::SmoothTransformation);
|
||||||
|
image_show *img=new image_show(this);
|
||||||
|
img->setImage(pixmap);
|
||||||
|
//img->setScaledContents(true);
|
||||||
|
QListWidgetItem* pItem = new QListWidgetItem();
|
||||||
|
pItem->setSizeHint(QSize(280, 200));
|
||||||
|
ui->listWidget->addItem(pItem);
|
||||||
|
ui->listWidget->setItemWidget(pItem, img);
|
||||||
|
|
||||||
|
manager->deleteLater(); });
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check UOS
|
||||||
|
QSettings config(QStandardPaths::writableLocation(QStandardPaths::AppConfigLocation) + "/config.ini", QSettings::IniFormat);
|
||||||
|
if (config.contains("UOS/EnableDeveloperMode") && !config.value("UOS/EnableDeveloperMode").toBool()){
|
||||||
|
qDebug() << "UOS Developer Mode has not been enabled!";
|
||||||
|
ui->downloadButton->setText(tr("Developer Mode Disabled"));
|
||||||
|
ui->downloadButton->setEnabled(false);
|
||||||
|
ui->downloadButton->show();
|
||||||
|
}
|
||||||
|
else // 非 UOS 或 UOS 已经开启开发者模式
|
||||||
|
{
|
||||||
QProcess isInstall;
|
QProcess isInstall;
|
||||||
bool isInstalled;
|
bool isInstalled;
|
||||||
bool isUpdated;
|
bool isUpdated;
|
||||||
QString packagename = info["Pkgname"].toString();
|
QString packagename = info["Pkgname"].toString();
|
||||||
isInstall.start("dpkg -s " + info["Pkgname"].toString());
|
isInstall.start("dpkg", QStringList() << "-s" << info["Pkgname"].toString());
|
||||||
qDebug() << info["Pkgname"].toString();
|
qDebug() << info["Pkgname"].toString();
|
||||||
isInstall.waitForFinished(180 * 1000); // 默认超时 3 分钟
|
isInstall.waitForFinished(180 * 1000); // 默认超时 3 分钟
|
||||||
int error = QString::fromStdString(isInstall.readAllStandardError().toStdString()).length();
|
int error = QString::fromStdString(isInstall.readAllStandardError().toStdString()).length();
|
||||||
@@ -103,12 +128,13 @@ void AppIntoPage::openUrl(QUrl url)
|
|||||||
isInstalled = true;
|
isInstalled = true;
|
||||||
|
|
||||||
QProcess isUpdate;
|
QProcess isUpdate;
|
||||||
isUpdate.start("dpkg-query --showformat='${Version}' --show " + info["Pkgname"].toString());
|
isUpdate.start("dpkg-query", QStringList() << "--showformat='${Version}'"
|
||||||
|
<< "--show" << info["Pkgname"].toString());
|
||||||
isUpdate.waitForFinished(180 * 1000); // 默认超时 3 分钟
|
isUpdate.waitForFinished(180 * 1000); // 默认超时 3 分钟
|
||||||
QString localVersion = isUpdate.readAllStandardOutput();
|
QString localVersion = isUpdate.readAllStandardOutput();
|
||||||
localVersion.replace("'", "");
|
localVersion.replace("'", "");
|
||||||
|
|
||||||
isUpdate.start("dpkg --compare-versions " + localVersion + " ge " + info["Version"].toString());
|
isUpdate.start("dpkg", QStringList() << "--compare-versions" << localVersion << "ge" << info["Version"].toString());
|
||||||
isUpdate.waitForFinished(180 * 1000); // 默认超时 3 分钟
|
isUpdate.waitForFinished(180 * 1000); // 默认超时 3 分钟
|
||||||
if (!isUpdate.exitCode())
|
if (!isUpdate.exitCode())
|
||||||
{
|
{
|
||||||
@@ -145,79 +171,162 @@ void AppIntoPage::openUrl(QUrl url)
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
ui->downloadButton->setText(tr("Download"));
|
ui->downloadButton->setText(tr("Download"));
|
||||||
isDownloading(SparkAPI::getServerUrl()+"store"+spk.path()+"/"+info["Filename"].toString());
|
|
||||||
ui->downloadButton->setEnabled(true);
|
ui->downloadButton->setEnabled(true);
|
||||||
ui->downloadButton->show();
|
ui->downloadButton->show();
|
||||||
}
|
}
|
||||||
|
|
||||||
QStringList taglist = info["Tags"].toString().split(";");
|
isDownloading(SparkAPI::getServerUrl() + "store" + spk.path() + "/" + info["Filename"].toString());
|
||||||
QString tmp=info["img_urls"].toString();
|
|
||||||
qDebug()<<tmp;
|
|
||||||
if(tmp.left(2)=="[\"")
|
|
||||||
{
|
|
||||||
tmp.remove(0,2);
|
|
||||||
}
|
|
||||||
if(tmp.right(2)=="\"]")
|
|
||||||
{
|
|
||||||
tmp.remove(tmp.size()-2,tmp.size());
|
|
||||||
}
|
|
||||||
QStringList imglist = tmp.split("\",\"");
|
|
||||||
qDebug()<<imglist;
|
|
||||||
for(int i=0;i < imglist.size();i++)
|
|
||||||
{
|
|
||||||
QNetworkAccessManager *naManager;
|
|
||||||
QNetworkRequest request;
|
|
||||||
naManager=new QNetworkAccessManager(this);
|
|
||||||
request.setUrl(QUrl(imglist[i].replace("+","%2B")));
|
|
||||||
request.setRawHeader("User-Agent", "Mozilla/5.0");
|
|
||||||
request.setRawHeader("Content-Type", "charset='utf-8'");
|
|
||||||
naManager->get(request);
|
|
||||||
QObject::connect(naManager,&QNetworkAccessManager::finished,[=](QNetworkReply *reply){
|
|
||||||
QByteArray jpegData = reply->readAll();
|
|
||||||
QPixmap pixmap;
|
|
||||||
pixmap.loadFromData(jpegData);
|
|
||||||
pixmap.scaled(100, 100, Qt::IgnoreAspectRatio, Qt::SmoothTransformation);
|
|
||||||
image_show *img=new image_show(this);
|
|
||||||
img->setImage(pixmap);
|
|
||||||
//img->setScaledContents(true);
|
|
||||||
QListWidgetItem* pItem = new QListWidgetItem();
|
|
||||||
pItem->setSizeHint(QSize(280, 200));
|
|
||||||
ui->listWidget->addItem(pItem);
|
|
||||||
ui->listWidget->setItemWidget(pItem, img);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
this->sltAppinfoTags(&taglist);
|
|
||||||
disconnect(api,&SparkAPI::finished,nullptr,nullptr);
|
|
||||||
api->deleteLater();
|
|
||||||
});
|
|
||||||
api->getAppInfo(url);
|
|
||||||
api1->getAppDownloadTimes(url);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void AppIntoPage::isDownloading(QUrl url)
|
api1->disconnect();
|
||||||
|
api1->deleteLater(); });
|
||||||
|
|
||||||
|
api1->getAppInfo(url);
|
||||||
|
|
||||||
|
api->getAppDownloadTimes(url);
|
||||||
|
}
|
||||||
|
|
||||||
|
void AppIntoPage::clear()
|
||||||
|
{
|
||||||
|
ui->tag_a2d->hide();
|
||||||
|
ui->tag_uos->hide();
|
||||||
|
ui->tag_dtk5->hide();
|
||||||
|
ui->tag_deepin->hide();
|
||||||
|
ui->tag_dwine2->hide();
|
||||||
|
ui->tag_dwine5->hide();
|
||||||
|
ui->tag_ubuntu->hide();
|
||||||
|
ui->tag_community->hide();
|
||||||
|
ui->icon->clear();
|
||||||
|
ui->title->clear();
|
||||||
|
ui->author->clear();
|
||||||
|
ui->label_2->clear();
|
||||||
|
ui->downloadButton->hide();
|
||||||
|
ui->downloadButton->setEnabled(false);
|
||||||
|
ui->pushButton_3->hide();
|
||||||
|
|
||||||
|
// QListWidgetItem *item = nullptr;
|
||||||
|
// while ((item = ui->listWidget->takeItem(0)) != nullptr)
|
||||||
|
// {
|
||||||
|
// QWidget *card = ui->listWidget->itemWidget(item);
|
||||||
|
// if (card)
|
||||||
|
// {
|
||||||
|
// card->deleteLater();
|
||||||
|
// card = nullptr;
|
||||||
|
// }
|
||||||
|
// delete item;
|
||||||
|
// item = nullptr;
|
||||||
|
// }
|
||||||
|
|
||||||
|
ui->listWidget->clear(); // NOTE: QListWidget::clear() 会析构所有 items
|
||||||
|
}
|
||||||
|
|
||||||
|
void AppIntoPage::setTheme(bool dark)
|
||||||
|
{
|
||||||
|
if (dark)
|
||||||
|
{
|
||||||
|
QString frameStyleSheet ="#frame,#frame_2,#frame_3,#frame_4 {background-color: #252525; border-radius: 14px; border: 1px solid rgb(64, 64, 64);}\
|
||||||
|
QLabel#cardtitle,QLabel#title,QLabel#title_1,QLabel#title_2,QLabel#title_3 {color: #FFFFFF}";
|
||||||
|
ui->frame->setStyleSheet(frameStyleSheet);
|
||||||
|
ui->frame_2->setStyleSheet(frameStyleSheet);
|
||||||
|
ui->frame_3->setStyleSheet(frameStyleSheet);
|
||||||
|
ui->frame_4->setStyleSheet(frameStyleSheet);
|
||||||
|
|
||||||
|
ui->icon_1->setPixmap(QPixmap(":/icon/dark/box.svg"));
|
||||||
|
ui->icon_2->setPixmap(QPixmap(":/icon/dark/box.svg"));
|
||||||
|
ui->icon_3->setPixmap(QPixmap(":/icon/dark/calendar.svg"));
|
||||||
|
ui->icon_4->setPixmap(QPixmap(":/icon/dark/text.svg"));
|
||||||
|
ui->icon_5->setPixmap(QPixmap(":/icon/dark/folder.svg"));
|
||||||
|
ui->icon_6->setPixmap(QPixmap(":/icon/dark/globe.svg"));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
//亮色模式
|
||||||
|
QString frameStyleSheet ="#frame,#frame_2,#frame_3,#frame_4 {background-color: #fbfbfb; border-radius: 14px; border: 1px solid rgb(229,229,229);}\
|
||||||
|
QLabel#cardtitle,QLabel#title,QLabel#title_1,QLabel#title_2,QLabel#title_3 {color: #000000}";
|
||||||
|
ui->frame->setStyleSheet(frameStyleSheet);
|
||||||
|
ui->frame_2->setStyleSheet(frameStyleSheet);
|
||||||
|
ui->frame_3->setStyleSheet(frameStyleSheet);
|
||||||
|
ui->frame_4->setStyleSheet(frameStyleSheet);
|
||||||
|
|
||||||
|
ui->icon_1->setPixmap(QPixmap(":/icon/light/box.svg"));
|
||||||
|
ui->icon_2->setPixmap(QPixmap(":/icon/light/box.svg"));
|
||||||
|
ui->icon_3->setPixmap(QPixmap(":/icon/light/calendar.svg"));
|
||||||
|
ui->icon_4->setPixmap(QPixmap(":/icon/light/text.svg"));
|
||||||
|
ui->icon_5->setPixmap(QPixmap(":/icon/light/folder.svg"));
|
||||||
|
ui->icon_6->setPixmap(QPixmap(":/icon/light/globe.svg"));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void AppIntoPage::setDownloadWidget(DownloadListWidget *w)
|
||||||
|
{
|
||||||
|
if (dw)
|
||||||
|
{
|
||||||
|
dw->deleteLater();
|
||||||
|
dw = nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
dw = w;
|
||||||
|
connect(w, &DownloadListWidget::downloadFinished, [=]()
|
||||||
|
{ isDownloading(SparkAPI::getServerUrl() + "store" + spk.path() + "/" + info["Filename"].toString()); });
|
||||||
|
}
|
||||||
|
|
||||||
|
void AppIntoPage::initUI()
|
||||||
|
{
|
||||||
|
ui->setupUi(this);
|
||||||
|
|
||||||
|
ui->listWidget->setViewMode(QListView::IconMode);
|
||||||
|
ui->listWidget->setFlow(QListView::TopToBottom);
|
||||||
|
ui->listWidget->setMovement(QListView::Static);
|
||||||
|
ui->listWidget->setMaximumHeight(200);
|
||||||
|
|
||||||
|
clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
void AppIntoPage::initConnections()
|
||||||
|
{
|
||||||
|
connect(api, &SparkAPI::finishedRAW, [=](QString download_times)
|
||||||
|
{
|
||||||
|
download_times = download_times.trimmed();
|
||||||
|
qDebug() << "Download Times:" + download_times;
|
||||||
|
ui->download_times->setText(download_times); });
|
||||||
|
}
|
||||||
|
|
||||||
|
void AppIntoPage::isDownloading(const QUrl &url)
|
||||||
|
{
|
||||||
|
int index = dw->getUrlList().lastIndexOf(url);
|
||||||
|
if (index == -1)
|
||||||
{
|
{
|
||||||
if (dw->getUrlList().lastIndexOf(url) == -1) {
|
|
||||||
ui->downloadButton->setEnabled(true);
|
ui->downloadButton->setEnabled(true);
|
||||||
return;
|
return;
|
||||||
} else {
|
|
||||||
ui->downloadButton->setEnabled(false);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
DownloadItem *item = dw->getDIList().at(index);
|
||||||
|
if (item == nullptr)
|
||||||
|
{
|
||||||
|
ui->downloadButton->setEnabled(true);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
ui->downloadButton->setEnabled(false);
|
||||||
ui->pushButton_3->hide();
|
ui->pushButton_3->hide();
|
||||||
if (dw->getDIList()[dw->getUrlList().lastIndexOf(url)]->download == 2) {
|
if (item->download == 2)
|
||||||
|
{
|
||||||
ui->downloadButton->setEnabled(true);
|
ui->downloadButton->setEnabled(true);
|
||||||
ui->downloadButton->setText(tr("Download"));
|
ui->downloadButton->setText(tr("Download"));
|
||||||
}
|
}
|
||||||
if (dw->getDIList()[dw->getUrlList().lastIndexOf(url)]->download == 1) {
|
if (item->download == 1)
|
||||||
|
{
|
||||||
ui->downloadButton->setEnabled(true);
|
ui->downloadButton->setEnabled(true);
|
||||||
ui->downloadButton->setText(tr("Install"));
|
ui->downloadButton->setText(tr("Install"));
|
||||||
}
|
}
|
||||||
if (dw->getDIList()[dw->getUrlList().lastIndexOf(url)]->isInstall) {
|
if (item->isInstall)
|
||||||
|
{
|
||||||
ui->downloadButton->setEnabled(false);
|
ui->downloadButton->setEnabled(false);
|
||||||
ui->downloadButton->setText(tr("Installing"));
|
ui->downloadButton->setText(tr("Installing"));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (dw->getDIList()[dw->getUrlList().lastIndexOf(url)]->download == 3) {
|
if (item->download == 3)
|
||||||
|
{
|
||||||
ui->downloadButton->setEnabled(true);
|
ui->downloadButton->setEnabled(true);
|
||||||
ui->downloadButton->setText(tr("Reinstall"));
|
ui->downloadButton->setText(tr("Reinstall"));
|
||||||
ui->downloadButton->show();
|
ui->downloadButton->show();
|
||||||
@@ -225,9 +334,9 @@ void AppIntoPage::isDownloading(QUrl url)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void AppIntoPage::sltAppinfoTags(QStringList *tagList)
|
void AppIntoPage::setAppinfoTags(const QStringList &tagList)
|
||||||
{
|
{
|
||||||
foreach(const QString &tag, *tagList)
|
foreach (const QString &tag, tagList)
|
||||||
{
|
{
|
||||||
if (tag == "community")
|
if (tag == "community")
|
||||||
{
|
{
|
||||||
@@ -263,68 +372,42 @@ void AppIntoPage::sltAppinfoTags(QStringList *tagList)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
void AppIntoPage::setTheme(bool dark)
|
|
||||||
{
|
|
||||||
if(dark)
|
|
||||||
{
|
|
||||||
QString frameStyleSheet ="#frame,#frame_2,#frame_3,#frame_4{background-color: #252525;border-radius:14px;border:1px solid rgb(64, 64, 64);}";
|
|
||||||
ui->frame->setStyleSheet(frameStyleSheet);
|
|
||||||
ui->frame_2->setStyleSheet(frameStyleSheet);
|
|
||||||
ui->frame_3->setStyleSheet(frameStyleSheet);
|
|
||||||
ui->frame_4->setStyleSheet(frameStyleSheet);
|
|
||||||
|
|
||||||
ui->icon_1->setPixmap(QPixmap(":/icon/dark/box.svg"));
|
|
||||||
ui->icon_2->setPixmap(QPixmap(":/icon/dark/box.svg"));
|
|
||||||
ui->icon_3->setPixmap(QPixmap(":/icon/dark/calendar.svg"));
|
|
||||||
ui->icon_4->setPixmap(QPixmap(":/icon/dark/text.svg"));
|
|
||||||
ui->icon_5->setPixmap(QPixmap(":/icon/dark/folder.svg"));
|
|
||||||
ui->icon_6->setPixmap(QPixmap(":/icon/dark/globe.svg"));
|
|
||||||
}else {
|
|
||||||
//亮色模式
|
|
||||||
QString frameStyleSheet ="#frame,#frame_2,#frame_3,#frame_4{background-color: #fbfbfb;border-radius:14px;border:1px solid rgb(229,229,229);}";
|
|
||||||
ui->frame->setStyleSheet(frameStyleSheet);
|
|
||||||
ui->frame_2->setStyleSheet(frameStyleSheet);
|
|
||||||
ui->frame_3->setStyleSheet(frameStyleSheet);
|
|
||||||
ui->frame_4->setStyleSheet(frameStyleSheet);
|
|
||||||
|
|
||||||
ui->icon_1->setPixmap(QPixmap(":/icon/light/box.svg"));
|
|
||||||
ui->icon_2->setPixmap(QPixmap(":/icon/light/box.svg"));
|
|
||||||
ui->icon_3->setPixmap(QPixmap(":/icon/light/calendar.svg"));
|
|
||||||
ui->icon_4->setPixmap(QPixmap(":/icon/light/text.svg"));
|
|
||||||
ui->icon_5->setPixmap(QPixmap(":/icon/light/folder.svg"));
|
|
||||||
ui->icon_6->setPixmap(QPixmap(":/icon/light/globe.svg"));
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
AppIntoPage::~AppIntoPage()
|
|
||||||
{
|
|
||||||
delete ui;
|
|
||||||
}
|
|
||||||
|
|
||||||
void AppIntoPage::on_downloadButton_clicked()
|
void AppIntoPage::on_downloadButton_clicked()
|
||||||
{
|
{
|
||||||
|
QString downloadUrl = SparkAPI::getServerUrl() + "store" + spk.path() + "/" + info["Filename"].toString();
|
||||||
if (ui->downloadButton->text() == tr("Install"))
|
if (ui->downloadButton->text() == tr("Install"))
|
||||||
{
|
{
|
||||||
dw->getDIList()[dw->getUrlList().lastIndexOf(SparkAPI::getServerUrl()+"store"+spk.path()+"/"+info["Filename"].toString())]->install(0);
|
DownloadItem *item = dw->getDIList()[dw->getUrlList().lastIndexOf(downloadUrl)];
|
||||||
isDownloading(SparkAPI::getServerUrl()+"store"+spk.path()+"/"+info["Filename"].toString());
|
if (item == nullptr)
|
||||||
QObject::connect(dw->getDIList()[dw->getUrlList().lastIndexOf(SparkAPI::getServerUrl()+"store"+spk.path()+"/"+info["Filename"].toString())],&DownloadItem::finished,[=](){
|
{
|
||||||
isDownloading(SparkAPI::getServerUrl()+"store"+spk.path()+"/"+info["Filename"].toString());
|
|
||||||
disconnect(dw->getDIList()[dw->getUrlList().lastIndexOf(SparkAPI::getServerUrl()+"store"+spk.path()+"/"+info["Filename"].toString())],&DownloadItem::finished,nullptr,nullptr);
|
|
||||||
});
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
connect(item, &DownloadItem::finished, [=]() { isDownloading(downloadUrl); });
|
||||||
|
|
||||||
|
item->install(0);
|
||||||
|
isDownloading(downloadUrl);
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
emit clickedDownloadBtn();
|
emit clickedDownloadBtn();
|
||||||
dw->addItem(info["Name"].toString(),info["Filename"].toString(),info["Pkgname"].toString(),iconpixmap,SparkAPI::getServerUrl()+"store"+spk.path()+"/"+info["Filename"].toString());
|
|
||||||
|
DownloadItem *item = dw->addItem(info["Name"].toString(), info["Filename"].toString(), info["Pkgname"].toString(), iconpixmap, downloadUrl);
|
||||||
|
if (item == nullptr)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (ui->downloadButton->text() == tr("Reinstall"))
|
if (ui->downloadButton->text() == tr("Reinstall"))
|
||||||
{
|
{
|
||||||
dw->getDIList()[dw->allDownload - 1]->reinstall = true;
|
item->reinstall = true;
|
||||||
}
|
}
|
||||||
ui->downloadButton->setEnabled(false);
|
ui->downloadButton->setEnabled(false);
|
||||||
QObject::connect(dw->getDIList()[dw->getUrlList().lastIndexOf(SparkAPI::getServerUrl()+"store"+spk.path()+"/"+info["Filename"].toString())],&DownloadItem::finished,[=](){
|
connect(item, &DownloadItem::finished, [=]() { isDownloading(downloadUrl); });
|
||||||
isDownloading(SparkAPI::getServerUrl()+"store"+spk.path()+"/"+info["Filename"].toString());
|
|
||||||
disconnect(dw->getDIList()[dw->getUrlList().lastIndexOf(SparkAPI::getServerUrl()+"store"+spk.path()+"/"+info["Filename"].toString())],&DownloadItem::finished,nullptr,nullptr);
|
isDownloading(downloadUrl);
|
||||||
});
|
|
||||||
isDownloading(SparkAPI::getServerUrl()+"store"+spk.path()+"/"+info["Filename"].toString());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void AppIntoPage::on_pushButton_3_clicked()
|
void AppIntoPage::on_pushButton_3_clicked()
|
||||||
@@ -344,7 +427,7 @@ void AppIntoPage::on_pushButton_3_clicked()
|
|||||||
|
|
||||||
if (check.readAllStandardOutput().isEmpty())
|
if (check.readAllStandardOutput().isEmpty())
|
||||||
{
|
{
|
||||||
ui->downloadButton->setText(tr("Install"));
|
ui->downloadButton->setText(tr("Download"));
|
||||||
ui->pushButton_3->hide();
|
ui->pushButton_3->hide();
|
||||||
|
|
||||||
updatesEnabled();
|
updatesEnabled();
|
||||||
@@ -359,24 +442,23 @@ void AppIntoPage::on_pushButton_3_clicked()
|
|||||||
void AppIntoPage::on_shareButton_clicked()
|
void AppIntoPage::on_shareButton_clicked()
|
||||||
{
|
{
|
||||||
qDebug() << "Share" << spk;
|
qDebug() << "Share" << spk;
|
||||||
Utils::sendNotification("spark-store",tr("Spark Store"),tr("The URL has been copied to the clipboard"));
|
Application::clipboard()->setText(spk.toString());
|
||||||
QClipboard *clipboard = QApplication::clipboard();
|
|
||||||
clipboard->setText(spk.toString());
|
|
||||||
}
|
|
||||||
|
|
||||||
|
Utils::sendNotification("spark-store", tr("Spark Store"), tr("The URL has been copied to the clipboard"));
|
||||||
|
}
|
||||||
|
|
||||||
void AppIntoPage::on_updateButton_clicked()
|
void AppIntoPage::on_updateButton_clicked()
|
||||||
{
|
{
|
||||||
QString feedbackSpk = "spk://store/chat/store.spark-app.feedback";
|
QString feedbackSpk = "spk://store/chat/store.spark-app.feedback";
|
||||||
QFile actionSubmissionClientStatus("/opt/durapps/store.spark-app.feedback");
|
QFileInfo actionSubmissionClientStatus("/opt/durapps/store.spark-app.feedback");
|
||||||
if (actionSubmissionClientStatus.exists())
|
if (actionSubmissionClientStatus.exists() && actionSubmissionClientStatus.isDir())
|
||||||
{
|
{
|
||||||
qDebug() << "反馈器存在";
|
qDebug() << "反馈器存在";
|
||||||
QProcess::startDetached("sh /opt/durapps/store.spark-app.feedback/launch.sh");
|
QProcess::startDetached("sh", QStringList() << "/opt/durapps/store.spark-app.feedback/launch.sh");
|
||||||
}
|
}
|
||||||
else{
|
else
|
||||||
|
{
|
||||||
qDebug() << "反馈器不存在,跳转页面";
|
qDebug() << "反馈器不存在,跳转页面";
|
||||||
openUrl(feedbackSpk);
|
openUrl(feedbackSpk);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -2,51 +2,52 @@
|
|||||||
#define APPINTOPAGE_H
|
#define APPINTOPAGE_H
|
||||||
|
|
||||||
#include <QWidget>
|
#include <QWidget>
|
||||||
|
#include <QJsonObject>
|
||||||
#include <QUrl>
|
#include <QUrl>
|
||||||
#include <QString>
|
|
||||||
#include <QtConcurrent>
|
|
||||||
#include <QClipboard>
|
|
||||||
#include "backend/sparkapi.h"
|
|
||||||
#include "backend/image_show.h"
|
|
||||||
#include "widgets/downloadlistwidget.h"
|
|
||||||
#include "utils/utils.h"
|
|
||||||
namespace Ui {
|
namespace Ui {
|
||||||
class AppIntoPage;
|
class AppIntoPage;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
class SparkAPI;
|
||||||
|
class DownloadListWidget;
|
||||||
class AppIntoPage : public QWidget
|
class AppIntoPage : public QWidget
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
public:
|
public:
|
||||||
void clear();
|
|
||||||
void setDownloadWidget(DownloadListWidget *w);
|
|
||||||
void setTheme(bool dark);
|
|
||||||
void openUrl(QUrl url);
|
|
||||||
explicit AppIntoPage(QWidget *parent = nullptr);
|
explicit AppIntoPage(QWidget *parent = nullptr);
|
||||||
~AppIntoPage();
|
~AppIntoPage() override;
|
||||||
|
|
||||||
private slots:
|
void openUrl(const QUrl &url);
|
||||||
void on_downloadButton_clicked();
|
void clear();
|
||||||
|
void setTheme(bool dark);
|
||||||
void on_pushButton_3_clicked();
|
void setDownloadWidget(DownloadListWidget *w);
|
||||||
|
|
||||||
void on_shareButton_clicked();
|
|
||||||
|
|
||||||
void on_updateButton_clicked();
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
SparkAPI *api1;
|
void initUI();
|
||||||
QJsonObject info;
|
void initConnections();
|
||||||
QPixmap iconpixmap;
|
void isDownloading(const QUrl &url);
|
||||||
QUrl spk;
|
void setAppinfoTags(const QStringList &tagList);
|
||||||
void isDownloading(QUrl url);
|
|
||||||
void sltAppinfoTags(QStringList *tagList);
|
|
||||||
DownloadListWidget *dw;
|
|
||||||
Ui::AppIntoPage *ui;
|
|
||||||
|
|
||||||
signals:
|
signals:
|
||||||
void clickedDownloadBtn();
|
void clickedDownloadBtn();
|
||||||
|
|
||||||
|
private slots:
|
||||||
|
void on_downloadButton_clicked();
|
||||||
|
void on_pushButton_3_clicked();
|
||||||
|
void on_shareButton_clicked();
|
||||||
|
void on_updateButton_clicked();
|
||||||
|
|
||||||
|
private:
|
||||||
|
Ui::AppIntoPage *ui;
|
||||||
|
|
||||||
|
SparkAPI *api;
|
||||||
|
DownloadListWidget *dw = nullptr;
|
||||||
|
|
||||||
|
QJsonObject info;
|
||||||
|
QPixmap iconpixmap;
|
||||||
|
QUrl spk;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // APPINTOPAGE_H
|
#endif // APPINTOPAGE_H
|
||||||
|
|||||||
@@ -426,10 +426,10 @@
|
|||||||
</size>
|
</size>
|
||||||
</property>
|
</property>
|
||||||
<property name="toolTip">
|
<property name="toolTip">
|
||||||
<string><html><head/><body><p>Capable to Ubuntu 20.04</p></body></html></string>
|
<string><html><head/><body><p>Capable to Ubuntu 22.04</p></body></html></string>
|
||||||
</property>
|
</property>
|
||||||
<property name="whatsThis">
|
<property name="whatsThis">
|
||||||
<string><html><head/><body><p>Capable to Ubuntu 20.04</p></body></html></string>
|
<string><html><head/><body><p>Capable to Ubuntu 22.04</p></body></html></string>
|
||||||
</property>
|
</property>
|
||||||
<property name="text">
|
<property name="text">
|
||||||
<string><html><head/><body><p><img src=":/tags/ubuntu-small.png"/></p></body></html></string>
|
<string><html><head/><body><p><img src=":/tags/ubuntu-small.png"/></p></body></html></string>
|
||||||
@@ -540,10 +540,10 @@
|
|||||||
</size>
|
</size>
|
||||||
</property>
|
</property>
|
||||||
<property name="toolTip">
|
<property name="toolTip">
|
||||||
<string><html><head/><body><p>A deepin-wine5 app.Spark Store will automatically configure the wine kit for you</p></body></html></string>
|
<string><html><head/><body><p>A Wine app.Spark Store will automatically configure the wine kit for you</p></body></html></string>
|
||||||
</property>
|
</property>
|
||||||
<property name="whatsThis">
|
<property name="whatsThis">
|
||||||
<string><html><head/><body><p>A deepin-wine5 app.Spark Store will automatically configure the wine kit for you</p></body></html></string>
|
<string><html><head/><body><p>A Wine app.Spark Store will automatically configure the wine kit for you</p></body></html></string>
|
||||||
</property>
|
</property>
|
||||||
<property name="text">
|
<property name="text">
|
||||||
<string><html><head/><body><p><img src=":/tags/dwine5-small.png"/></p></body></html></string>
|
<string><html><head/><body><p><img src=":/tags/dwine5-small.png"/></p></body></html></string>
|
||||||
|
|||||||
@@ -1,8 +1,7 @@
|
|||||||
#include "applistpage.h"
|
#include "applistpage.h"
|
||||||
#include "ui_applistpage.h"
|
#include "ui_applistpage.h"
|
||||||
|
|
||||||
AppListPage::AppListPage(QWidget *parent) :
|
AppListPage::AppListPage(QWidget *parent) : QWidget(parent),
|
||||||
QWidget(parent),
|
|
||||||
ui(new Ui::AppListPage)
|
ui(new Ui::AppListPage)
|
||||||
{
|
{
|
||||||
ui->setupUi(this);
|
ui->setupUi(this);
|
||||||
@@ -14,14 +13,18 @@ void AppListPage::setTheme(bool dark)
|
|||||||
if (dark)
|
if (dark)
|
||||||
{
|
{
|
||||||
this->setStyleSheet("#frame{background-color: #252525;border-radius:14px;border:1px solid rgb(64, 64, 64);}");
|
this->setStyleSheet("#frame{background-color: #252525;border-radius:14px;border:1px solid rgb(64, 64, 64);}");
|
||||||
}else {
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
// 亮色模式
|
// 亮色模式
|
||||||
this->setStyleSheet("#frame{background-color: #ffffff;border-radius:14px;border:1px solid rgb(229,229,229);}");
|
this->setStyleSheet("#frame{background-color: #ffffff;border-radius:14px;border:1px solid rgb(229,229,229);}");
|
||||||
}
|
}
|
||||||
if (isSearch)
|
if (isSearch)
|
||||||
{
|
{
|
||||||
getSearchList(nowType);
|
getSearchList(nowType);
|
||||||
}else{
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
getAppList(nowType);
|
getAppList(nowType);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -35,20 +38,25 @@ void AppListPage::getAppList(QString type)
|
|||||||
if (isDark)
|
if (isDark)
|
||||||
{
|
{
|
||||||
theme = "theme=dark";
|
theme = "theme=dark";
|
||||||
}else{
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
theme = "theme=light";
|
theme = "theme=light";
|
||||||
}
|
}
|
||||||
if (type == "")
|
if (type == "")
|
||||||
{
|
{
|
||||||
url = api->getServerUrl() + "store/#/flamescion/?" + theme;
|
url = api->getServerUrl() + "store/#/flamescion/?" + theme;
|
||||||
}else{
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
url = api->getServerUrl() + "store/#/flamescion/applist?type=" + type + "&" + theme;
|
url = api->getServerUrl() + "store/#/flamescion/applist?type=" + type + "&" + theme;
|
||||||
}
|
}
|
||||||
|
|
||||||
ui->webEngineView->setUrl(url);
|
ui->webEngineView->setUrl(url);
|
||||||
|
delete api;
|
||||||
}
|
}
|
||||||
|
|
||||||
void AppListPage::getSearchList(QString keyword)
|
void AppListPage::getSearchList(const QString &keyword)
|
||||||
{
|
{
|
||||||
isSearch = true;
|
isSearch = true;
|
||||||
nowType = keyword;
|
nowType = keyword;
|
||||||
@@ -58,11 +66,14 @@ void AppListPage::getSearchList(QString keyword)
|
|||||||
if (isDark)
|
if (isDark)
|
||||||
{
|
{
|
||||||
theme = "theme=dark";
|
theme = "theme=dark";
|
||||||
}else{
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
theme = "theme=light";
|
theme = "theme=light";
|
||||||
}
|
}
|
||||||
url=api->getServerUrl()+"store/#/flamescion/search?keywords="+keyword+"&"+theme;
|
url = api->getServerUrl() + "store/#/flamescion/search?keywords=" + QUrl::toPercentEncoding(keyword) + "&" + theme;
|
||||||
ui->webEngineView->setUrl(url);
|
ui->webEngineView->setUrl(url);
|
||||||
|
delete api;
|
||||||
}
|
}
|
||||||
|
|
||||||
AppListPage::~AppListPage()
|
AppListPage::~AppListPage()
|
||||||
@@ -83,4 +94,3 @@ void AppListPage::on_webEngineView_urlChanged(const QUrl &arg1)
|
|||||||
emit clicked(url);
|
emit clicked(url);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -14,7 +14,7 @@ class AppListPage : public QWidget
|
|||||||
|
|
||||||
public:
|
public:
|
||||||
void setTheme(bool dark);
|
void setTheme(bool dark);
|
||||||
void getSearchList(QString keyword);
|
void getSearchList(const QString &keyword);
|
||||||
void getAppList(QString type);
|
void getAppList(QString type);
|
||||||
explicit AppListPage(QWidget *parent = nullptr);
|
explicit AppListPage(QWidget *parent = nullptr);
|
||||||
~AppListPage();
|
~AppListPage();
|
||||||
|
|||||||
@@ -1,11 +1,24 @@
|
|||||||
#include "settingspage.h"
|
#include "settingspage.h"
|
||||||
#include "ui_settingspage.h"
|
#include "ui_settingspage.h"
|
||||||
|
#include "../backend/sparkapi.h"
|
||||||
|
#include "utils/utils.h"
|
||||||
|
|
||||||
|
#include <QSettings>
|
||||||
|
#include <QtConcurrent>
|
||||||
|
#include <QDebug>
|
||||||
|
|
||||||
|
#define TMP_PATH "/tmp/spark-store"
|
||||||
|
#define DEFAULT_SERVER_URL "https://cdn.d.store.deepinos.org.cn/"
|
||||||
|
#define DEFAULT_CHECK_DOMAIN "deepinos"
|
||||||
|
|
||||||
bool SettingsPage::isdownload = false;
|
bool SettingsPage::isdownload = false;
|
||||||
SettingsPage::SettingsPage(QWidget *parent) :
|
|
||||||
QWidget(parent),
|
SettingsPage::SettingsPage(QWidget *parent)
|
||||||
ui(new Ui::SettingsPage)
|
: QWidget(parent)
|
||||||
|
, ui(new Ui::SettingsPage)
|
||||||
{
|
{
|
||||||
ui->setupUi(this);
|
ui->setupUi(this);
|
||||||
|
|
||||||
configCanSave = false;
|
configCanSave = false;
|
||||||
initConfig();
|
initConfig();
|
||||||
}
|
}
|
||||||
@@ -15,7 +28,9 @@ void SettingsPage::setTheme(bool dark)
|
|||||||
if (dark)
|
if (dark)
|
||||||
{
|
{
|
||||||
this->setStyleSheet("#frame{background-color: #252525;border-radius:14px;border:1px solid rgb(64, 64, 64);}");
|
this->setStyleSheet("#frame{background-color: #252525;border-radius:14px;border:1px solid rgb(64, 64, 64);}");
|
||||||
}else {
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
// 亮色模式
|
// 亮色模式
|
||||||
this->setStyleSheet("#frame{background-color: #ffffff;border-radius:14px;border:1px solid rgb(229,229,229);}");
|
this->setStyleSheet("#frame{background-color: #ffffff;border-radius:14px;border:1px solid rgb(229,229,229);}");
|
||||||
}
|
}
|
||||||
@@ -24,22 +39,28 @@ void SettingsPage::setTheme(bool dark)
|
|||||||
void SettingsPage::readServerList()
|
void SettingsPage::readServerList()
|
||||||
{
|
{
|
||||||
// 读取服务器列表并初始化
|
// 读取服务器列表并初始化
|
||||||
QFile file(QDir::homePath().toUtf8() + "/.config/spark-store/server.list");
|
QFile file(QStandardPaths::writableLocation(QStandardPaths::AppConfigLocation) + "/server.list");
|
||||||
|
|
||||||
// 判断文件是否存在
|
// 判断文件是否存在
|
||||||
if (!file.exists())
|
if (!file.exists())
|
||||||
{
|
{
|
||||||
ui->comboBox_server->addItem("https://d.store.deepinos.org.cn/");
|
ui->comboBox_server->addItem(DEFAULT_SERVER_URL);
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!file.open(QIODevice::ReadOnly | QIODevice::Text))
|
if (!file.open(QIODevice::ReadOnly | QIODevice::Text))
|
||||||
{
|
{
|
||||||
qDebug()<<"无法读取server.list";
|
qWarning() << "无法读取 server.list";
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// 创建 QTextStream 对象
|
// 创建 QTextStream 对象
|
||||||
QTextStream textStream(&file);
|
QTextStream textStream(&file);
|
||||||
|
if (!textStream.readAll().contains(DEFAULT_CHECK_DOMAIN)) // 校验配置文件有效性
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
textStream.seek(0); // 回到开头
|
||||||
QString lineData = textStream.readLine(); // 读取文件的第一行
|
QString lineData = textStream.readLine(); // 读取文件的第一行
|
||||||
ui->comboBox_server->addItem(lineData);
|
ui->comboBox_server->addItem(lineData);
|
||||||
while (!lineData.isNull())
|
while (!lineData.isNull())
|
||||||
@@ -70,12 +91,12 @@ void SettingsPage::initConfig()
|
|||||||
readServerList();
|
readServerList();
|
||||||
|
|
||||||
// 读取服务器URL并初始化菜单项的链接
|
// 读取服务器URL并初始化菜单项的链接
|
||||||
QSettings readConfig(QDir::homePath() + "/.config/spark-store/config.ini", QSettings::IniFormat);
|
QSettings config(QStandardPaths::writableLocation(QStandardPaths::AppConfigLocation) + "/config.ini", QSettings::IniFormat);
|
||||||
if(!readConfig.value("server/choose").toString().isEmpty() && readConfig.value("server/updated").toString() == "TRUE")
|
if (!config.value("server/choose").toString().isEmpty() && config.value("server/updated").toBool())
|
||||||
{
|
{
|
||||||
qDebug()<<readConfig.value("server/choose").toString();
|
qDebug() << config.value("server/choose").toString();
|
||||||
ui->comboBox_server->setCurrentText(readConfig.value("server/choose").toString());
|
ui->comboBox_server->setCurrentText(config.value("server/choose").toString());
|
||||||
SparkAPI::setServerUrl(readConfig.value("server/choose").toString());
|
SparkAPI::setServerUrl(config.value("server/choose").toString());
|
||||||
}
|
}
|
||||||
configCanSave = true; // 防止触发保存配置信号
|
configCanSave = true; // 防止触发保存配置信号
|
||||||
}
|
}
|
||||||
@@ -90,30 +111,40 @@ void SettingsPage::on_pushButton_updateServer_clicked()
|
|||||||
QtConcurrent::run([=]()
|
QtConcurrent::run([=]()
|
||||||
{
|
{
|
||||||
ui->pushButton_updateServer->setEnabled(false);
|
ui->pushButton_updateServer->setEnabled(false);
|
||||||
|
|
||||||
|
|
||||||
|
QFile::remove(QStandardPaths::writableLocation(QStandardPaths::AppConfigLocation) + "/server.list");
|
||||||
|
auto updateSuccess = system("curl -o " + QStandardPaths::writableLocation(QStandardPaths::AppConfigLocation).toUtf8() + "/server.list https://d.store.deepinos.org.cn/store/server-and-mirror.list");
|
||||||
|
qDebug() << "Update serverlist status:" << updateSuccess;
|
||||||
|
if (updateSuccess != 0) // 更新失败不换服务器配置
|
||||||
|
{
|
||||||
|
QFile file(QStandardPaths::writableLocation(QStandardPaths::AppConfigLocation) + "/server.list");
|
||||||
|
if (file.exists())
|
||||||
|
{
|
||||||
|
file.remove();
|
||||||
|
}
|
||||||
|
// FIXME: 向用户提示更新失败
|
||||||
|
ui->pushButton_updateServer->setEnabled(true);
|
||||||
|
return;
|
||||||
|
}
|
||||||
ui->comboBox_server->clear();
|
ui->comboBox_server->clear();
|
||||||
|
|
||||||
QFile::remove(QDir::homePath().toUtf8() + "/.config/spark-store/server.list");
|
|
||||||
system("curl -o " + QDir::homePath().toUtf8() + "/.config/spark-store/server.list https://d.store.deepinos.org.cn/store/server-and-mirror.list");
|
|
||||||
|
|
||||||
ui->pushButton_updateServer->setEnabled(true);
|
ui->pushButton_updateServer->setEnabled(true);
|
||||||
readServerList();
|
readServerList();
|
||||||
ui->comboBox_server->setCurrentIndex(0);
|
ui->comboBox_server->setCurrentIndex(0); });
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void SettingsPage::on_comboBox_server_currentIndexChanged(const QString &arg1)
|
void SettingsPage::on_comboBox_server_currentIndexChanged(const QString &arg1)
|
||||||
{
|
{
|
||||||
SparkAPI::setServerUrl(arg1); // 服务器信息更新
|
SparkAPI::setServerUrl(arg1); // 服务器信息更新
|
||||||
qDebug() << arg1;
|
qDebug() << arg1;
|
||||||
const QString updatedInfo = "TRUE";
|
bool updatedInfo = true;
|
||||||
if(configCanSave)
|
if(configCanSave)
|
||||||
{
|
{
|
||||||
// ui->label_setting1->show();
|
// ui->label_setting1->show();
|
||||||
QSettings *setConfig = new QSettings(QDir::homePath() + "/.config/spark-store/config.ini", QSettings::IniFormat);
|
QSettings config(QStandardPaths::writableLocation(QStandardPaths::AppConfigLocation) + "/config.ini", QSettings::IniFormat);
|
||||||
setConfig->setValue("server/choose", arg1);
|
config.setValue("server/choose", arg1);
|
||||||
setConfig->setValue("server/updated", updatedInfo);
|
config.setValue("server/updated", updatedInfo);
|
||||||
setConfig->deleteLater();
|
config.sync();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -188,14 +219,13 @@ void SettingsPage::on_pushButton_updateApt_clicked()
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void SettingsPage::on_pushButton_clear_clicked()
|
void SettingsPage::on_pushButton_clear_clicked()
|
||||||
{
|
{
|
||||||
QtConcurrent::run([=]()
|
QtConcurrent::run([=]()
|
||||||
{
|
{
|
||||||
ui->pushButton_clear->setEnabled(false);
|
ui->pushButton_clear->setEnabled(false);
|
||||||
|
|
||||||
QDir tmpdir("/tmp/spark-store");
|
QDir tmpdir(QString::fromUtf8(TMP_PATH));
|
||||||
tmpdir.setFilter(QDir::Files);
|
tmpdir.setFilter(QDir::Files);
|
||||||
int quantity = int(tmpdir.count());
|
int quantity = int(tmpdir.count());
|
||||||
for(int i = 0; i < quantity; i++)
|
for(int i = 0; i < quantity; i++)
|
||||||
@@ -204,23 +234,21 @@ void SettingsPage::on_pushButton_clear_clicked()
|
|||||||
}
|
}
|
||||||
Utils::sendNotification("spark-store",tr("Spark Store"),tr("Temporary cache was cleaned"));
|
Utils::sendNotification("spark-store",tr("Spark Store"),tr("Temporary cache was cleaned"));
|
||||||
ui->pushButton_clear->setEnabled(true);
|
ui->pushButton_clear->setEnabled(true);
|
||||||
updateUI();
|
updateUI(); });
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void SettingsPage::on_pushButton_clearWebCache_clicked()
|
void SettingsPage::on_pushButton_clearWebCache_clicked()
|
||||||
{
|
{
|
||||||
QtConcurrent::run([=]()
|
QtConcurrent::run([=]()
|
||||||
{
|
{
|
||||||
QString dataLocal = QStandardPaths::writableLocation(QStandardPaths::AppLocalDataLocation);
|
QString localDataLocation = QStandardPaths::writableLocation(QStandardPaths::AppLocalDataLocation) + "/QtWebEngine";
|
||||||
qDebug() << dataLocal;
|
qDebug() << localDataLocation;
|
||||||
QDir dataDir(dataLocal);
|
QDir dataDir(localDataLocation);
|
||||||
dataDir.removeRecursively();
|
dataDir.removeRecursively();
|
||||||
dataLocal = QStandardPaths::writableLocation(QStandardPaths::TempLocation);
|
|
||||||
qDebug() << dataLocal;
|
QString cacheLocation = QStandardPaths::writableLocation(QStandardPaths::CacheLocation) + "/QtWebEngine";
|
||||||
QDir cacheDir(dataLocal);
|
qDebug() << cacheLocation;
|
||||||
|
QDir cacheDir(cacheLocation);
|
||||||
cacheDir.removeRecursively();
|
cacheDir.removeRecursively();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -2,14 +2,7 @@
|
|||||||
#define SETTINGSPAGE_H
|
#define SETTINGSPAGE_H
|
||||||
|
|
||||||
#include <QWidget>
|
#include <QWidget>
|
||||||
#include <QFile>
|
#include <QUrl>
|
||||||
#include <QDir>
|
|
||||||
#include <QDebug>
|
|
||||||
#include <QSettings>
|
|
||||||
#include <QtConcurrent>
|
|
||||||
#include "../backend/sparkapi.h"
|
|
||||||
#include "utils/utils.h"
|
|
||||||
#define TMP_PATH "/tmp/spark-store"
|
|
||||||
|
|
||||||
namespace Ui {
|
namespace Ui {
|
||||||
class SettingsPage;
|
class SettingsPage;
|
||||||
|
|||||||
@@ -4,7 +4,7 @@
|
|||||||
#
|
#
|
||||||
#-------------------------------------------------
|
#-------------------------------------------------
|
||||||
|
|
||||||
QT += core gui network concurrent webenginewidgets dbus svg
|
QT += core gui concurrent dbus network svg webenginewidgets
|
||||||
|
|
||||||
greaterThan(QT_MAJOR_VERSION, 4): QT += widgets
|
greaterThan(QT_MAJOR_VERSION, 4): QT += widgets
|
||||||
|
|
||||||
@@ -22,77 +22,80 @@ DEFINES += QT_DEPRECATED_WARNINGS
|
|||||||
# You can also select to disable deprecated APIs only up to a certain version of Qt.
|
# You can also select to disable deprecated APIs only up to a certain version of Qt.
|
||||||
#DEFINES += QT_DISABLE_DEPRECATED_BEFORE=0x060000 # disables all the APIs deprecated before Qt 6.0.0
|
#DEFINES += QT_DISABLE_DEPRECATED_BEFORE=0x060000 # disables all the APIs deprecated before Qt 6.0.0
|
||||||
|
|
||||||
DEFINES += QT_APP_DEBUG
|
# Get build version from qmake
|
||||||
|
VERSION = $$BUILD_VERSION
|
||||||
|
isEmpty(VERSION): VERSION = 4.0.0
|
||||||
|
DEFINES += APP_VERSION=\\\"'$${VERSION}'\\\"
|
||||||
|
|
||||||
|
# Disable qWarning / qDebug output in Release
|
||||||
|
#CONFIG(release, debug | release): DEFINES += QT_NO_WARNING_OUTPUT QT_NO_DEBUG_OUTPUT
|
||||||
|
|
||||||
CONFIG += c++11 link_pkgconfig
|
CONFIG += c++11 link_pkgconfig
|
||||||
PKGCONFIG += dtkcore dtkgui dtkwidget
|
PKGCONFIG += dtkcore dtkgui dtkwidget
|
||||||
|
|
||||||
# Disable qWarning / qDebug output in Release
|
SOURCES += \
|
||||||
CONFIG(release, debug|release): DEFINES += QT_NO_WARNING_OUTPUT QT_NO_DEBUG_OUTPUT
|
backend/downloadworker.cpp \
|
||||||
|
backend/image_show.cpp \
|
||||||
|
backend/sparkapi.cpp \
|
||||||
|
dbus/dbussparkstoreservice.cpp \
|
||||||
|
pages/appintopage.cpp \
|
||||||
|
pages/applistpage.cpp \
|
||||||
|
pages/settingspage.cpp \
|
||||||
|
utils/httprequest.cpp \
|
||||||
|
utils/utils.cpp \
|
||||||
|
utils/widgetanimation.cpp \
|
||||||
|
widgets/base/basewidgetopacity.cpp \
|
||||||
|
widgets/common/downloaditem.cpp \
|
||||||
|
widgets/common/progressbutton.cpp \
|
||||||
|
widgets/common/smoothlistwidget.cpp \
|
||||||
|
widgets/common/smoothscrollbar.cpp \
|
||||||
|
widgets/common/webenginepage.cpp \
|
||||||
|
widgets/common/webengineview.cpp \
|
||||||
|
widgets/big_image.cpp \
|
||||||
|
widgets/downloadlistwidget.cpp \
|
||||||
|
application.cpp \
|
||||||
|
main.cpp \
|
||||||
|
mainwindow-dtk.cpp
|
||||||
|
|
||||||
# Update translation files
|
HEADERS += \
|
||||||
CONFIG(release, debug|release): system(bash $${PWD}/translate_generation.sh)
|
backend/downloadworker.h \
|
||||||
|
backend/image_show.h \
|
||||||
|
backend/sparkapi.h \
|
||||||
|
dbus/dbussparkstoreservice.h \
|
||||||
|
pages/appintopage.h \
|
||||||
|
pages/applistpage.h \
|
||||||
|
pages/settingspage.h \
|
||||||
|
utils/httprequest.h \
|
||||||
|
utils/utils.h \
|
||||||
|
utils/widgetanimation.h \
|
||||||
|
widgets/base/basewidgetopacity.h \
|
||||||
|
widgets/common/downloaditem.h \
|
||||||
|
widgets/common/progressbutton.h \
|
||||||
|
widgets/common/smoothlistwidget.h \
|
||||||
|
widgets/common/smoothscrollbar.h \
|
||||||
|
widgets/common/webenginepage.h \
|
||||||
|
widgets/common/webengineview.h \
|
||||||
|
widgets/big_image.h \
|
||||||
|
widgets/downloadlistwidget.h \
|
||||||
|
application.h \
|
||||||
|
mainwindow-dtk.h
|
||||||
|
|
||||||
|
FORMS += \
|
||||||
|
pages/appintopage.ui \
|
||||||
|
pages/applistpage.ui \
|
||||||
|
pages/settingspage.ui \
|
||||||
|
widgets/common/downloaditem.ui \
|
||||||
|
widgets/downloadlistwidget.ui \
|
||||||
|
mainwindow-dtk.ui
|
||||||
|
|
||||||
|
RESOURCES += \
|
||||||
|
assets/assets.qrc
|
||||||
|
|
||||||
TRANSLATIONS += \
|
TRANSLATIONS += \
|
||||||
../translations/spark-store_en.ts \
|
../translations/spark-store_en.ts \
|
||||||
../translations/spark-store_fr.ts \
|
../translations/spark-store_fr.ts \
|
||||||
../translations/spark-store_zh_CN.ts
|
../translations/spark-store_zh_CN.ts \
|
||||||
|
../translations/spark-store_zh_TW.ts
|
||||||
SOURCES += \
|
|
||||||
dbus/dbussparkstoreservice.cpp \
|
|
||||||
main.cpp \
|
|
||||||
mainwindow-dtk.cpp \
|
|
||||||
backend/sparkapi.cpp \
|
|
||||||
pages/settingspage.cpp \
|
|
||||||
utils/utils.cpp \
|
|
||||||
utils/widgetanimation.cpp \
|
|
||||||
widgets/common/progressbutton.cpp \
|
|
||||||
widgets/common/webenginepage.cpp \
|
|
||||||
widgets/common/webengineview.cpp \
|
|
||||||
widgets/downloadlistwidget.cpp \
|
|
||||||
widgets/common/downloaditem.cpp \
|
|
||||||
widgets/common/smoothlistwidget.cpp \
|
|
||||||
widgets/common/smoothscrollbar.cpp \
|
|
||||||
utils/httprequest.cpp \
|
|
||||||
pages/applistpage.cpp \
|
|
||||||
backend/downloadworker.cpp \
|
|
||||||
pages/appintopage.cpp \
|
|
||||||
widgets/big_image.cpp \
|
|
||||||
backend/image_show.cpp \
|
|
||||||
widgets/base/basewidgetopacity.cpp
|
|
||||||
|
|
||||||
HEADERS += \
|
|
||||||
dbus/dbussparkstoreservice.h \
|
|
||||||
mainwindow-dtk.h \
|
|
||||||
backend/sparkapi.h \
|
|
||||||
pages/settingspage.h \
|
|
||||||
utils/utils.h \
|
|
||||||
utils/widgetanimation.h \
|
|
||||||
widgets/common/progressbutton.h \
|
|
||||||
widgets/common/webenginepage.h \
|
|
||||||
widgets/common/webengineview.h \
|
|
||||||
widgets/downloadlistwidget.h \
|
|
||||||
widgets/common/downloaditem.h \
|
|
||||||
widgets/common/smoothlistwidget.h \
|
|
||||||
widgets/common/smoothscrollbar.h \
|
|
||||||
utils/httprequest.h \
|
|
||||||
pages/applistpage.h \
|
|
||||||
backend/downloadworker.h \
|
|
||||||
pages/appintopage.h \
|
|
||||||
widgets/big_image.h \
|
|
||||||
backend/image_show.h \
|
|
||||||
widgets/base/basewidgetopacity.h
|
|
||||||
|
|
||||||
FORMS += \
|
|
||||||
mainwindow-dtk.ui \
|
|
||||||
pages/settingspage.ui \
|
|
||||||
widgets/downloadlistwidget.ui \
|
|
||||||
widgets/common/downloaditem.ui \
|
|
||||||
pages/applistpage.ui \
|
|
||||||
pages/appintopage.ui
|
|
||||||
|
|
||||||
RESOURCES += \
|
|
||||||
assets/assets.qrc
|
|
||||||
|
|
||||||
# Default rules for deployment.
|
# Default rules for deployment.
|
||||||
qnx: target.path = /tmp/$${TARGET}/bin
|
qnx: target.path = /tmp/$${TARGET}/bin
|
||||||
|
|||||||
@@ -1,10 +1,7 @@
|
|||||||
#include "httprequest.h"
|
#include "httprequest.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
HttpRequest::HttpRequest()
|
HttpRequest::HttpRequest()
|
||||||
{
|
{
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void HttpRequest::getRequest(QNetworkRequest request)
|
void HttpRequest::getRequest(QNetworkRequest request)
|
||||||
|
|||||||
@@ -1,20 +1,33 @@
|
|||||||
#include "utils.h"
|
#include "utils.h"
|
||||||
|
#include "application.h"
|
||||||
|
|
||||||
Utils::Utils()
|
#include <DSysInfo>
|
||||||
|
|
||||||
|
#include <QDBusInterface>
|
||||||
|
#include <QProcessEnvironment>
|
||||||
|
#include <QSettings>
|
||||||
|
#include <QStandardPaths>
|
||||||
|
#include <QFile>
|
||||||
|
#include <QJsonDocument>
|
||||||
|
|
||||||
|
#define UOSDeveloperModeFile "/var/lib/deepin/developer-mode/enabled"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author chatGPT
|
||||||
|
* @brief Utils::sendNotification 发送系统通知
|
||||||
|
* @param icon 图标名称
|
||||||
|
* @param title 通知标题
|
||||||
|
* @param body 通知内容
|
||||||
|
*/
|
||||||
|
void Utils::sendNotification(const QString &icon, const QString &title, const QString &body)
|
||||||
{
|
{
|
||||||
|
QDBusInterface interface("org.freedesktop.Notifications",
|
||||||
}
|
|
||||||
|
|
||||||
//这个函数是chatGPT写的
|
|
||||||
void Utils::sendNotification(QString icon,QString title,QString body)
|
|
||||||
{
|
|
||||||
QDBusInterface iface("org.freedesktop.Notifications",
|
|
||||||
"/org/freedesktop/Notifications",
|
"/org/freedesktop/Notifications",
|
||||||
"org.freedesktop.Notifications");
|
"org.freedesktop.Notifications");
|
||||||
|
|
||||||
QVariantList args;
|
QVariantList args;
|
||||||
args << QCoreApplication::applicationName() // the name of the application
|
args << Application::applicationName() // the name of the application
|
||||||
<< (uint)0 // replaces the previous notification with the same ID
|
<< static_cast<quint32>(0) // replaces the previous notification with the same ID
|
||||||
<< icon // the application icon of the notification
|
<< icon // the application icon of the notification
|
||||||
<< title // the title of the notification
|
<< title // the title of the notification
|
||||||
<< body // the body of the notification
|
<< body // the body of the notification
|
||||||
@@ -22,5 +35,181 @@ void Utils::sendNotification(QString icon,QString title,QString body)
|
|||||||
<< QVariantMap() // no hints
|
<< QVariantMap() // no hints
|
||||||
<< -1; // no timeout
|
<< -1; // no timeout
|
||||||
|
|
||||||
iface.callWithArgumentList(QDBus::AutoDetect, "Notify", args);
|
interface.callWithArgumentList(QDBus::AutoDetect, "Notify", args);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Utils::isDDE 判断是否使用 DDE 桌面环境
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
bool Utils::isDDE()
|
||||||
|
{
|
||||||
|
bool isDDE = true;
|
||||||
|
if (!QString::fromUtf8(qgetenv("XDG_CURRENT_DESKTOP")).toLower().startsWith("deepin"))
|
||||||
|
{
|
||||||
|
qputenv("XDG_CURRENT_DESKTOP", "Deepin");
|
||||||
|
isDDE = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return isDDE;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Utils::isWayland 判断是否使用 wayland 显示协议
|
||||||
|
* @return bool true: 使用 wayland 显示协议 false: 使用 x11 显示协议
|
||||||
|
*/
|
||||||
|
bool Utils::isWayland()
|
||||||
|
{
|
||||||
|
bool isWayland = false;
|
||||||
|
QProcessEnvironment env = QProcessEnvironment::systemEnvironment();
|
||||||
|
QString XDG_SESSION_TYPE = env.value(QStringLiteral("XDG_SESSION_TYPE"));
|
||||||
|
QString WAYLAND_DISPLAY = env.value(QStringLiteral("WAYLAND_DISPLAY"));
|
||||||
|
if (XDG_SESSION_TYPE == QLatin1String("wayland") || WAYLAND_DISPLAY.contains(QLatin1String("wayland"), Qt::CaseInsensitive))
|
||||||
|
{
|
||||||
|
isWayland = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return isWayland;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Utils::initConfig 初始化 config.ini 配置文件,去除废弃字段
|
||||||
|
*/
|
||||||
|
void Utils::initConfig()
|
||||||
|
{
|
||||||
|
// WARNING: 请在 组织名称 和 应用程序名称 初始化完成后调用
|
||||||
|
bool useWayland = true;
|
||||||
|
|
||||||
|
QSettings config(QStandardPaths::writableLocation(QStandardPaths::AppConfigLocation) + "/config.ini", QSettings::IniFormat);
|
||||||
|
if (config.contains("build/useWayland"))
|
||||||
|
{
|
||||||
|
useWayland = config.value("build/useWayland").toBool();
|
||||||
|
}
|
||||||
|
config.remove("build/isDeepinOS");
|
||||||
|
config.remove("build/isWayland");
|
||||||
|
config.remove("build/useWayland");
|
||||||
|
|
||||||
|
config.setValue("runtime/isDDE", isDDE());
|
||||||
|
config.setValue("runtime/isWayland", isWayland());
|
||||||
|
// Check config file, if there is no wayland config, then set it to default, which means use wayland if possible.
|
||||||
|
if (!config.contains("runtime/useWayland"))
|
||||||
|
{
|
||||||
|
config.setValue("runtime/useWayland", useWayland);
|
||||||
|
}
|
||||||
|
config.sync(); // 写入更改至 config.ini,并同步最新内容
|
||||||
|
|
||||||
|
checkUOSDeveloperMode(); // Check UOS developer mode
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Utils::isUOS 判断是否为 UOS 操作系统
|
||||||
|
* @return bool true: UOS 操作系统 false: 非 UOS 操作系统
|
||||||
|
*/
|
||||||
|
bool Utils::isUOS()
|
||||||
|
{
|
||||||
|
// WARNING: 请在 组织名称 和 应用程序名称 初始化完成后调用
|
||||||
|
bool isUOS = false;
|
||||||
|
|
||||||
|
QSettings config(QStandardPaths::writableLocation(QStandardPaths::AppConfigLocation) + "/config.ini", QSettings::IniFormat);
|
||||||
|
if (Dtk::Core::DSysInfo::productType() == Dtk::Core::DSysInfo::Uos)
|
||||||
|
{
|
||||||
|
isUOS = true;
|
||||||
|
config.setValue("UOS/isUOS", true);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
isUOS = false;
|
||||||
|
config.remove("UOS");
|
||||||
|
}
|
||||||
|
config.sync(); // 写入更改至 config.ini,并同步最新内容
|
||||||
|
|
||||||
|
return isUOS;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Utils::setQPAPlatform Set display backend
|
||||||
|
*/
|
||||||
|
void Utils::setQPAPlatform()
|
||||||
|
{
|
||||||
|
// WARNING: 请在 initConfig() 执行后调用
|
||||||
|
bool isDDE = Utils::isDDE(); // WARNING: 只能执行一次,后续执行时环境变量已经被覆盖,导致判断错误
|
||||||
|
bool isWayland = Utils::isWayland();
|
||||||
|
|
||||||
|
QSettings config(QStandardPaths::writableLocation(QStandardPaths::AppConfigLocation) + "/config.ini", QSettings::IniFormat);
|
||||||
|
bool useWayland = config.value("runtime/useWayland").toBool();
|
||||||
|
|
||||||
|
qDebug() << "System Wayland enabled:" << isWayland << "Spark Wayland enabled:" << useWayland;
|
||||||
|
|
||||||
|
if (isWayland && useWayland && !(Dtk::Core::DSysInfo::isDeepin() || isDDE))
|
||||||
|
{
|
||||||
|
qputenv("QT_QPA_PLATFORM", "wayland");
|
||||||
|
}
|
||||||
|
else if (isWayland && useWayland && (Dtk::Core::DSysInfo::isDeepin() && isDDE))
|
||||||
|
{
|
||||||
|
qputenv("QT_QPA_PLATFORM", "dwayland");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
qputenv("QT_QPA_PLATFORM", "dxcb");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Utils::checkUOSDeveloperMode Check UOS developer mode
|
||||||
|
*/
|
||||||
|
void Utils::checkUOSDeveloperMode()
|
||||||
|
{
|
||||||
|
QSettings config(QStandardPaths::writableLocation(QStandardPaths::AppConfigLocation) + "/config.ini", QSettings::IniFormat);
|
||||||
|
|
||||||
|
QFile file(UOSDeveloperModeFile);
|
||||||
|
if (Utils::isUOS() && file.exists() && file.open(QFile::ReadOnly | QFile::Text))
|
||||||
|
{
|
||||||
|
QString lineData = QString::fromUtf8(file.readLine());
|
||||||
|
bool devmode = lineData.trimmed().toInt();
|
||||||
|
qDebug() << "UOS Developer Mode Status:" << devmode;
|
||||||
|
config.setValue("UOS/EnableDeveloperMode", devmode);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* NOTE: Utils::isUOS() 中,判断为非 UOS 时已经从 config 中删除 UOS 组,
|
||||||
|
* 此处若包含该字段则一定是 UOS,直接写入开发者模式开关状态即可
|
||||||
|
*/
|
||||||
|
if (config.contains("UOS/EnableDeveloperMode"))
|
||||||
|
{
|
||||||
|
config.setValue("UOS/EnableDeveloperMode", false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
file.close();
|
||||||
|
config.sync(); // 写入更改至 config.ini,并同步最新内容
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Utils::parseFeatureJsonFile 解析版本特性 json 文件
|
||||||
|
* @return 返回 QJsonObject
|
||||||
|
*/
|
||||||
|
QJsonObject Utils::parseFeatureJsonFile()
|
||||||
|
{
|
||||||
|
QFile file(":/json/features.json");
|
||||||
|
if (!file.open(QFile::ReadOnly))
|
||||||
|
{
|
||||||
|
qWarning() << Q_FUNC_INFO << "features.json open failed";
|
||||||
|
return QJsonObject();
|
||||||
|
}
|
||||||
|
|
||||||
|
QJsonParseError error;
|
||||||
|
QJsonDocument jsonDoc = QJsonDocument::fromJson(file.readAll(), &error);
|
||||||
|
if (error.error != QJsonParseError::NoError || jsonDoc.isNull())
|
||||||
|
{
|
||||||
|
qWarning() << Q_FUNC_INFO << "features.json validate failed:" << error.errorString();
|
||||||
|
return QJsonObject();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (jsonDoc.isEmpty() || !jsonDoc.isObject())
|
||||||
|
{
|
||||||
|
qWarning() << Q_FUNC_INFO << "features jsonDoc parse failed:" << jsonDoc;
|
||||||
|
return QJsonObject();
|
||||||
|
}
|
||||||
|
|
||||||
|
return jsonDoc.object();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,13 +2,19 @@
|
|||||||
#define UTILS_H
|
#define UTILS_H
|
||||||
|
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
#include <QtDBus>
|
#include <QJsonObject>
|
||||||
|
|
||||||
class Utils
|
class Utils
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
Utils();
|
static void sendNotification(const QString &icon, const QString &title, const QString &body);
|
||||||
static void sendNotification(QString icon,QString title,QString body);
|
static bool isDDE();
|
||||||
|
static bool isWayland();
|
||||||
|
static void initConfig();
|
||||||
|
static bool isUOS();
|
||||||
|
static void setQPAPlatform();
|
||||||
|
static void checkUOSDeveloperMode();
|
||||||
|
static QJsonObject parseFeatureJsonFile();
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // UTILS_H
|
#endif // UTILS_H
|
||||||
|
|||||||
@@ -1,9 +1,5 @@
|
|||||||
#include "widgetanimation.h"
|
#include "widgetanimation.h"
|
||||||
|
#include "widgets/base/basewidgetopacity.h"
|
||||||
WidgetAnimation::WidgetAnimation()
|
|
||||||
{
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
void WidgetAnimation::widgetShake(QWidget *pWidget, int nRange)
|
void WidgetAnimation::widgetShake(QWidget *pWidget, int nRange)
|
||||||
{
|
{
|
||||||
@@ -16,7 +12,8 @@ void WidgetAnimation::widgetShake(QWidget *pWidget, int nRange)
|
|||||||
|
|
||||||
int nShakeCount = 8;
|
int nShakeCount = 8;
|
||||||
double nStep = 1.0 / nShakeCount;
|
double nStep = 1.0 / nShakeCount;
|
||||||
for(int i = 1; i < nShakeCount; i++){
|
for (int i = 1; i < nShakeCount; i++)
|
||||||
|
{
|
||||||
nRange = i & 1 ? -nRange : nRange;
|
nRange = i & 1 ? -nRange : nRange;
|
||||||
pAnimation->setKeyValueAt(nStep * i, QRect(QPoint(nX + nRange, nY), pWidget->size()));
|
pAnimation->setKeyValueAt(nStep * i, QRect(QPoint(nX + nRange, nY), pWidget->size()));
|
||||||
}
|
}
|
||||||
@@ -28,25 +25,35 @@ void WidgetAnimation::widgetShake(QWidget *pWidget, int nRange)
|
|||||||
QPropertyAnimation *WidgetAnimation::createWidgetOpacity(QWidget *pWidget, bool isAppear)
|
QPropertyAnimation *WidgetAnimation::createWidgetOpacity(QWidget *pWidget, bool isAppear)
|
||||||
{
|
{
|
||||||
QPropertyAnimation *animation = new QPropertyAnimation(pWidget, "windowOpacity", pWidget);
|
QPropertyAnimation *animation = new QPropertyAnimation(pWidget, "windowOpacity", pWidget);
|
||||||
//设置动画效果
|
|
||||||
animation->setEasingCurve(QEasingCurve::Linear);
|
|
||||||
// 设置动画时间(单位:毫秒)
|
// 设置动画时间(单位:毫秒)
|
||||||
animation->setDuration(500);
|
animation->setDuration(500);
|
||||||
// 设置动画步长值,以及在该位置时显示的透明度
|
|
||||||
if (isAppear)
|
if (isAppear)
|
||||||
{
|
{
|
||||||
animation->setKeyValueAt(0, 0);
|
// 设置动画效果
|
||||||
// m_animation->setKeyValueAt(0.5, 0);
|
animation->setEasingCurve(QEasingCurve::Linear);
|
||||||
animation->setKeyValueAt(1, 1);
|
// 设置动画步长值,以及在该位置时显示的透明度(即动画关键帧)
|
||||||
}else{
|
animation->setKeyValueAt(0.0, 0.0);
|
||||||
animation->setKeyValueAt(0, 1);
|
animation->setKeyValueAt(1.0, 1.0);
|
||||||
animation->setKeyValueAt(1, 0);
|
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
animation->setEasingCurve(QEasingCurve::OutQuart);
|
||||||
|
animation->setKeyValueAt(0.0, 1.0);
|
||||||
|
animation->setKeyValueAt(1.0, 0.0);
|
||||||
|
|
||||||
|
QObject::connect(animation, &QPropertyAnimation::finished, pWidget, [=]() { pWidget->close(); });
|
||||||
|
}
|
||||||
|
|
||||||
|
QObject::connect(animation, &QPropertyAnimation::valueChanged, pWidget, [=]()
|
||||||
|
{
|
||||||
|
pWidget->update(); // NOTE: 保证窗口透明度动画平滑
|
||||||
|
});
|
||||||
|
|
||||||
return animation;
|
return animation;
|
||||||
}
|
}
|
||||||
|
|
||||||
void WidgetAnimation::widgetOpacity(QWidget *pWidget, bool isAppear)
|
void WidgetAnimation::widgetOpacity(QWidget *pWidget, bool isAppear)
|
||||||
{
|
{
|
||||||
// 开始动画
|
// 启动/关闭动画
|
||||||
createWidgetOpacity(pWidget, isAppear)->start();
|
createWidgetOpacity(pWidget, isAppear)->start(QPropertyAnimation::DeleteWhenStopped);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,14 +1,12 @@
|
|||||||
#ifndef WIDGETANIMATION_H
|
#ifndef WIDGETANIMATION_H
|
||||||
#define WIDGETANIMATION_H
|
#define WIDGETANIMATION_H
|
||||||
|
|
||||||
#include <QObject>
|
|
||||||
#include <QWidget>
|
#include <QWidget>
|
||||||
#include <QPropertyAnimation>
|
#include <QPropertyAnimation>
|
||||||
|
|
||||||
class WidgetAnimation
|
class WidgetAnimation
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
WidgetAnimation();
|
|
||||||
static void widgetShake(QWidget *pWidget, int nRange);
|
static void widgetShake(QWidget *pWidget, int nRange);
|
||||||
|
|
||||||
static QPropertyAnimation* createWidgetOpacity(QWidget *pWidget, bool isAppear);
|
static QPropertyAnimation* createWidgetOpacity(QWidget *pWidget, bool isAppear);
|
||||||
|
|||||||
@@ -1,38 +1,60 @@
|
|||||||
#include "basewidgetopacity.h"
|
#include "basewidgetopacity.h"
|
||||||
|
#include "utils/widgetanimation.h"
|
||||||
|
#include "utils/utils.h"
|
||||||
|
|
||||||
#include <QCloseEvent>
|
#include <QSettings>
|
||||||
|
#include <QStandardPaths>
|
||||||
#include <QPropertyAnimation>
|
#include <QPropertyAnimation>
|
||||||
|
#include <QCloseEvent>
|
||||||
|
|
||||||
BaseWidgetOpacity::BaseWidgetOpacity(QWidget *parent) : DBlurEffectWidget(parent)
|
BaseWidgetOpacity::BaseWidgetOpacity(QWidget *parent) : DBlurEffectWidget(parent)
|
||||||
{
|
{
|
||||||
// WidgetAnimation::widgetOpacity(this,true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// @brief 窗口关闭事件
|
/**
|
||||||
/// @param event
|
* @brief 窗口显示事件
|
||||||
|
* @param event
|
||||||
|
*/
|
||||||
|
void BaseWidgetOpacity::showEvent(QShowEvent *event)
|
||||||
|
{
|
||||||
|
// FIXME: wayland 不支持直接设置窗口透明度,需要调用 wayland 相关库(考虑抄控制中心“窗口移动时启用透明特效”代码?)
|
||||||
|
QSettings config(QStandardPaths::writableLocation(QStandardPaths::AppConfigLocation) + "/config.ini", QSettings::IniFormat);
|
||||||
|
bool isWayland = Utils::isWayland();
|
||||||
|
if (!isWayland)
|
||||||
|
{
|
||||||
|
if (!showWindowAnimation)
|
||||||
|
{
|
||||||
|
showWindowAnimation = true;
|
||||||
|
WidgetAnimation::widgetOpacity(this, true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
DBlurEffectWidget::showEvent(event);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief 窗口关闭事件
|
||||||
|
* @param event
|
||||||
|
*/
|
||||||
void BaseWidgetOpacity::closeEvent(QCloseEvent *event)
|
void BaseWidgetOpacity::closeEvent(QCloseEvent *event)
|
||||||
{
|
{
|
||||||
if (!closeWindowAnimation) {
|
// FIXME: wayland 不支持直接设置窗口透明度,需要调用 wayland 相关库(考虑抄控制中心“窗口移动时启用透明特效”代码?)
|
||||||
|
QSettings config(QStandardPaths::writableLocation(QStandardPaths::AppConfigLocation) + "/config.ini", QSettings::IniFormat);
|
||||||
|
bool isWayland = Utils::isWayland();
|
||||||
|
if (isWayland)
|
||||||
|
{
|
||||||
|
return DBlurEffectWidget::closeEvent(event);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!closeWindowAnimation)
|
||||||
|
{
|
||||||
closeWindowAnimation = true;
|
closeWindowAnimation = true;
|
||||||
|
WidgetAnimation::widgetOpacity(this, false);
|
||||||
|
|
||||||
QPropertyAnimation *animation = new QPropertyAnimation(this, "windowOpacity");
|
|
||||||
animation->setEasingCurve(QEasingCurve::OutQuart);
|
|
||||||
animation->setDuration(500);
|
|
||||||
animation->setStartValue(1.0);
|
|
||||||
animation->setEndValue(0.0);
|
|
||||||
|
|
||||||
QObject::connect(animation, &QPropertyAnimation::valueChanged, this, [=](const QVariant &value){
|
|
||||||
this->update();
|
|
||||||
// setWindowTitle(QString("ヾ(⌒∇⌒*)See You♪ - %1%").arg(int(value.toFloat() * 100)));
|
|
||||||
});
|
|
||||||
|
|
||||||
QObject::connect(animation, &QPropertyAnimation::finished, this, [=](){
|
|
||||||
this->close();
|
|
||||||
});
|
|
||||||
|
|
||||||
animation->start();
|
|
||||||
event->ignore();
|
event->ignore();
|
||||||
} else {
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
event->accept();
|
event->accept();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -8,17 +8,17 @@ DWIDGET_USE_NAMESPACE
|
|||||||
class BaseWidgetOpacity : public DBlurEffectWidget
|
class BaseWidgetOpacity : public DBlurEffectWidget
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
public:
|
public:
|
||||||
explicit BaseWidgetOpacity(QWidget *parent = nullptr);
|
explicit BaseWidgetOpacity(QWidget *parent = nullptr);
|
||||||
|
|
||||||
signals:
|
|
||||||
|
|
||||||
public slots:
|
|
||||||
|
|
||||||
// QWidget interface
|
|
||||||
protected:
|
protected:
|
||||||
bool closeWindowAnimation = false;
|
void showEvent(QShowEvent *event) override;
|
||||||
void closeEvent(QCloseEvent *event) override;
|
void closeEvent(QCloseEvent *event) override;
|
||||||
|
|
||||||
|
protected:
|
||||||
|
bool showWindowAnimation = false;
|
||||||
|
bool closeWindowAnimation = false;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // BASEWIDGETOPACITY_H
|
#endif // BASEWIDGETOPACITY_H
|
||||||
|
|||||||
@@ -3,8 +3,7 @@
|
|||||||
#include <QHBoxLayout>
|
#include <QHBoxLayout>
|
||||||
#include <QtConcurrent>
|
#include <QtConcurrent>
|
||||||
|
|
||||||
big_image::big_image(DBlurEffectWidget *parent) :
|
big_image::big_image(DBlurEffectWidget *parent) : DBlurEffectWidget(parent),
|
||||||
DBlurEffectWidget(parent),
|
|
||||||
m_image(new QLabel)
|
m_image(new QLabel)
|
||||||
{
|
{
|
||||||
// setWindowFlags(this->windowFlags() | Qt::WindowStaysOnTopHint); // 设置图片对话框总在最前
|
// setWindowFlags(this->windowFlags() | Qt::WindowStaysOnTopHint); // 设置图片对话框总在最前
|
||||||
|
|||||||
@@ -6,8 +6,7 @@
|
|||||||
|
|
||||||
bool DownloadItem::isInstall = false;
|
bool DownloadItem::isInstall = false;
|
||||||
|
|
||||||
DownloadItem::DownloadItem(QWidget *parent) :
|
DownloadItem::DownloadItem(QWidget *parent) : QWidget(parent),
|
||||||
QWidget(parent),
|
|
||||||
reinstall(false),
|
reinstall(false),
|
||||||
close(false),
|
close(false),
|
||||||
ui(new Ui::DownloadItem),
|
ui(new Ui::DownloadItem),
|
||||||
@@ -23,6 +22,9 @@ DownloadItem::DownloadItem(QWidget *parent) :
|
|||||||
ui->pushButton_3->hide();
|
ui->pushButton_3->hide();
|
||||||
ui->widget_spinner->start();
|
ui->widget_spinner->start();
|
||||||
ui->widget_spinner->hide();
|
ui->widget_spinner->hide();
|
||||||
|
|
||||||
|
ui->label->setElideMode(Qt::TextElideMode::ElideRight);
|
||||||
|
ui->label_2->setElideMode(Qt::TextElideMode::ElideRight);
|
||||||
}
|
}
|
||||||
|
|
||||||
DownloadItem::~DownloadItem()
|
DownloadItem::~DownloadItem()
|
||||||
@@ -34,10 +36,12 @@ void DownloadItem::setValue(qint64 value)
|
|||||||
{
|
{
|
||||||
ui->progressBar->setValue(qint32(value));
|
ui->progressBar->setValue(qint32(value));
|
||||||
ui->label_2->setText(QString::number(double(value) / 100) + "% (" + speed + ")");
|
ui->label_2->setText(QString::number(double(value) / 100) + "% (" + speed + ")");
|
||||||
|
ui->label_2->setToolTip(QString::number(double(value) / 100) + "% (" + speed + ")");
|
||||||
if (ui->label_2->text().left(4) == "100%")
|
if (ui->label_2->text().left(4) == "100%")
|
||||||
{
|
{
|
||||||
download = 1;
|
download = 1;
|
||||||
ui->label_2->setText(tr("Download Complete."));
|
ui->label_2->setText(tr("Download Complete."));
|
||||||
|
ui->label_2->setToolTip(tr("Download Complete."));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -49,6 +53,7 @@ void DownloadItem::setMax(qint64 max)
|
|||||||
void DownloadItem::setName(QString name)
|
void DownloadItem::setName(QString name)
|
||||||
{
|
{
|
||||||
ui->label->setText(name);
|
ui->label->setText(name);
|
||||||
|
ui->label->setToolTip(name);
|
||||||
}
|
}
|
||||||
|
|
||||||
QString DownloadItem::getName()
|
QString DownloadItem::getName()
|
||||||
@@ -56,8 +61,21 @@ QString DownloadItem::getName()
|
|||||||
return ui->label_filename->text();
|
return ui->label_filename->text();
|
||||||
}
|
}
|
||||||
|
|
||||||
void DownloadItem::readyInstall()
|
|
||||||
|
/***************************************************************
|
||||||
|
* @brief 告知界面,准备安装
|
||||||
|
* @param
|
||||||
|
* @note 如果正在安装,返回-1
|
||||||
|
* @Sample usage: DownloadItem::install(0);
|
||||||
|
**************************************************************/
|
||||||
|
int DownloadItem::readyInstall()
|
||||||
{
|
{
|
||||||
|
// 检查是否正在安装,如果是返回错误 -1
|
||||||
|
if (isInstall)
|
||||||
|
{
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
if (!close)
|
if (!close)
|
||||||
{
|
{
|
||||||
ui->progressBar->hide();
|
ui->progressBar->hide();
|
||||||
@@ -65,7 +83,9 @@ void DownloadItem::readyInstall()
|
|||||||
ui->pushButton_install->show();
|
ui->pushButton_install->show();
|
||||||
DownloadItem::install(0);
|
DownloadItem::install(0);
|
||||||
ui->pushButton_2->hide();
|
ui->pushButton_2->hide();
|
||||||
|
return 1;
|
||||||
}
|
}
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void DownloadItem::setFileName(QString fileName)
|
void DownloadItem::setFileName(QString fileName)
|
||||||
@@ -88,6 +108,12 @@ void DownloadItem::setSpeed(QString s)
|
|||||||
speed = s;
|
speed = s;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/***************************************************************
|
||||||
|
* @brief 安装当前应用
|
||||||
|
* @param int t, t为安装方式,可以为 0,1,2
|
||||||
|
* @note 备注
|
||||||
|
* @Sample usage: DownloadItem::install(0);
|
||||||
|
**************************************************************/
|
||||||
void DownloadItem::install(int t)
|
void DownloadItem::install(int t)
|
||||||
{
|
{
|
||||||
if (!isInstall)
|
if (!isInstall)
|
||||||
@@ -97,8 +123,53 @@ void DownloadItem::install(int t)
|
|||||||
ui->widget_spinner->show();
|
ui->widget_spinner->show();
|
||||||
qDebug() << "/tmp/spark-store/" + ui->label_filename->text().toUtf8();
|
qDebug() << "/tmp/spark-store/" + ui->label_filename->text().toUtf8();
|
||||||
ui->label_2->setText(tr("Installing"));
|
ui->label_2->setText(tr("Installing"));
|
||||||
|
ui->label_2->setToolTip(tr("Installing"));
|
||||||
|
|
||||||
QtConcurrent::run([=]()
|
QtConcurrent::run([=]()
|
||||||
|
{
|
||||||
|
slotAsyncInstall(t);
|
||||||
|
});
|
||||||
|
|
||||||
|
qDebug() << ui->label_filename->text().toUtf8();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void DownloadItem::on_pushButton_install_clicked()
|
||||||
|
{
|
||||||
|
DownloadItem::install(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
void DownloadItem::on_pushButton_2_clicked()
|
||||||
|
{
|
||||||
|
ui->label_2->setText(tr("Download canceled"));
|
||||||
|
ui->label_2->setToolTip(tr("Download canceled"));
|
||||||
|
download = 2;
|
||||||
|
ui->pushButton_2->setEnabled(false);
|
||||||
|
ui->progressBar->hide();
|
||||||
|
close = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
void DownloadItem::on_pushButton_3_clicked()
|
||||||
|
{
|
||||||
|
textbrowser->setLineWidth(0);
|
||||||
|
textbrowser->setText(out);
|
||||||
|
textbrowser->setMinimumHeight(500);
|
||||||
|
|
||||||
|
output_w->setMinimumHeight(600);
|
||||||
|
output_w->setAttribute(Qt::WA_TranslucentBackground);
|
||||||
|
output_w->setTitle(ui->label->text());
|
||||||
|
output_w->layout()->setMargin(20);
|
||||||
|
output_w->layout()->addWidget(textbrowser);
|
||||||
|
output_w->show();
|
||||||
|
}
|
||||||
|
|
||||||
|
/***************************************************************
|
||||||
|
* @brief 实际安装应用
|
||||||
|
* @param int t, t为安装方式,可以为 0,1,2
|
||||||
|
* @note 备注
|
||||||
|
* @Sample usage: slotAsyncInstall(0);
|
||||||
|
**************************************************************/
|
||||||
|
void DownloadItem::slotAsyncInstall(int t)
|
||||||
{
|
{
|
||||||
QProcess installer;
|
QProcess installer;
|
||||||
switch(t)
|
switch(t)
|
||||||
@@ -133,14 +204,15 @@ void DownloadItem::install(int t)
|
|||||||
}
|
}
|
||||||
|
|
||||||
QProcess isInstall;
|
QProcess isInstall;
|
||||||
isInstall.start("dpkg -s " + pkgName);
|
isInstall.start("dpkg", QStringList() << "-s" << pkgName);
|
||||||
isInstall.waitForFinished(180*1000); // 默认超时 3 分钟
|
isInstall.waitForFinished(180*1000); // 默认超时 3 分钟
|
||||||
int error = QString::fromStdString(isInstall.readAllStandardError().toStdString()).length();
|
int error = QString::fromStdString(isInstall.readAllStandardError().toStdString()).length();
|
||||||
if(error == 0)
|
if (error == 0 && !haveError)
|
||||||
{
|
{
|
||||||
ui->pushButton_install->hide();
|
ui->pushButton_install->hide();
|
||||||
Utils::sendNotification("spark-store",tr("Spark Store"),ui->label->text() + " " + tr("Installation complete."));
|
Utils::sendNotification("spark-store",tr("Spark Store"),ui->label->text() + " " + tr("Installation complete."));
|
||||||
ui->label_2->setText(tr("Finish"));
|
ui->label_2->setText(tr("Finish"));
|
||||||
|
ui->label_2->setToolTip(tr("Finish"));
|
||||||
download = 3;
|
download = 3;
|
||||||
ui->pushButton_3->show();
|
ui->pushButton_3->show();
|
||||||
}
|
}
|
||||||
@@ -151,6 +223,7 @@ void DownloadItem::install(int t)
|
|||||||
download = 1;
|
download = 1;
|
||||||
Utils::sendNotification("spark-store",tr("Spark Store"),tr("Error happened in dpkg progress , you can try it again."));
|
Utils::sendNotification("spark-store",tr("Spark Store"),tr("Error happened in dpkg progress , you can try it again."));
|
||||||
ui->label_2->setText(tr("Error happened in dpkg progress , you can try it again"));
|
ui->label_2->setText(tr("Error happened in dpkg progress , you can try it again"));
|
||||||
|
ui->label_2->setToolTip(tr("Error happened in dpkg progress , you can try it again"));
|
||||||
ui->pushButton_3->show();
|
ui->pushButton_3->show();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -158,6 +231,7 @@ void DownloadItem::install(int t)
|
|||||||
{
|
{
|
||||||
Utils::sendNotification("spark-store",tr("Spark Store"),tr("dpkg progress had been aborted,you can retry installation."));
|
Utils::sendNotification("spark-store",tr("Spark Store"),tr("dpkg progress had been aborted,you can retry installation."));
|
||||||
ui->label_2->setText(tr("dpkg progress had been aborted,you can retry installation"));
|
ui->label_2->setText(tr("dpkg progress had been aborted,you can retry installation"));
|
||||||
|
ui->label_2->setToolTip(tr("dpkg progress had been aborted,you can retry installation"));
|
||||||
ui->pushButton_install->show();
|
ui->pushButton_install->show();
|
||||||
ui->pushButton_3->hide();
|
ui->pushButton_3->hide();
|
||||||
}
|
}
|
||||||
@@ -165,36 +239,4 @@ void DownloadItem::install(int t)
|
|||||||
ui->widget_spinner->hide();
|
ui->widget_spinner->hide();
|
||||||
DownloadItem::isInstall = false;
|
DownloadItem::isInstall = false;
|
||||||
emit finished();
|
emit finished();
|
||||||
});
|
|
||||||
// emit finished();
|
|
||||||
qDebug()<<ui->label_filename->text().toUtf8();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void DownloadItem::on_pushButton_install_clicked()
|
|
||||||
{
|
|
||||||
DownloadItem::install(0);
|
|
||||||
}
|
|
||||||
|
|
||||||
void DownloadItem::on_pushButton_2_clicked()
|
|
||||||
{
|
|
||||||
ui->label_2->setText(tr("Download canceled"));
|
|
||||||
download = 2;
|
|
||||||
ui->pushButton_2->setEnabled(false);
|
|
||||||
ui->progressBar->hide();
|
|
||||||
close = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
void DownloadItem::on_pushButton_3_clicked()
|
|
||||||
{
|
|
||||||
textbrowser->setLineWidth(0);
|
|
||||||
textbrowser->setText(out);
|
|
||||||
textbrowser->setMinimumHeight(500);
|
|
||||||
|
|
||||||
output_w->setMinimumHeight(600);
|
|
||||||
output_w->setAttribute(Qt::WA_TranslucentBackground);
|
|
||||||
output_w->setTitle(ui->label->text());
|
|
||||||
output_w->layout()->setMargin(20);
|
|
||||||
output_w->layout()->addWidget(textbrowser);
|
|
||||||
output_w->show();
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -34,7 +34,7 @@ public:
|
|||||||
void setMax(qint64);
|
void setMax(qint64);
|
||||||
void setName(QString);
|
void setName(QString);
|
||||||
QString getName();
|
QString getName();
|
||||||
void readyInstall();
|
int readyInstall();
|
||||||
|
|
||||||
void setFileName(QString);
|
void setFileName(QString);
|
||||||
void seticon(const QPixmap);
|
void seticon(const QPixmap);
|
||||||
@@ -59,6 +59,8 @@ private slots:
|
|||||||
void on_pushButton_2_clicked();
|
void on_pushButton_2_clicked();
|
||||||
void on_pushButton_3_clicked();
|
void on_pushButton_3_clicked();
|
||||||
|
|
||||||
|
void slotAsyncInstall(int t);
|
||||||
|
|
||||||
signals:
|
signals:
|
||||||
void finished();
|
void finished();
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -7,13 +7,25 @@
|
|||||||
<x>0</x>
|
<x>0</x>
|
||||||
<y>0</y>
|
<y>0</y>
|
||||||
<width>666</width>
|
<width>666</width>
|
||||||
<height>54</height>
|
<height>56</height>
|
||||||
</rect>
|
</rect>
|
||||||
</property>
|
</property>
|
||||||
|
<property name="sizePolicy">
|
||||||
|
<sizepolicy hsizetype="Preferred" vsizetype="Fixed">
|
||||||
|
<horstretch>0</horstretch>
|
||||||
|
<verstretch>0</verstretch>
|
||||||
|
</sizepolicy>
|
||||||
|
</property>
|
||||||
|
<property name="minimumSize">
|
||||||
|
<size>
|
||||||
|
<width>0</width>
|
||||||
|
<height>56</height>
|
||||||
|
</size>
|
||||||
|
</property>
|
||||||
<property name="maximumSize">
|
<property name="maximumSize">
|
||||||
<size>
|
<size>
|
||||||
<width>16777215</width>
|
<width>16777215</width>
|
||||||
<height>54</height>
|
<height>56</height>
|
||||||
</size>
|
</size>
|
||||||
</property>
|
</property>
|
||||||
<property name="windowTitle">
|
<property name="windowTitle">
|
||||||
@@ -40,10 +52,22 @@
|
|||||||
</property>
|
</property>
|
||||||
<item>
|
<item>
|
||||||
<widget class="QLabel" name="label_3">
|
<widget class="QLabel" name="label_3">
|
||||||
|
<property name="sizePolicy">
|
||||||
|
<sizepolicy hsizetype="Fixed" vsizetype="Fixed">
|
||||||
|
<horstretch>0</horstretch>
|
||||||
|
<verstretch>0</verstretch>
|
||||||
|
</sizepolicy>
|
||||||
|
</property>
|
||||||
|
<property name="minimumSize">
|
||||||
|
<size>
|
||||||
|
<width>48</width>
|
||||||
|
<height>48</height>
|
||||||
|
</size>
|
||||||
|
</property>
|
||||||
<property name="maximumSize">
|
<property name="maximumSize">
|
||||||
<size>
|
<size>
|
||||||
<width>48</width>
|
<width>48</width>
|
||||||
<height>16777215</height>
|
<height>48</height>
|
||||||
</size>
|
</size>
|
||||||
</property>
|
</property>
|
||||||
<property name="text">
|
<property name="text">
|
||||||
@@ -52,6 +76,9 @@
|
|||||||
<property name="scaledContents">
|
<property name="scaledContents">
|
||||||
<bool>true</bool>
|
<bool>true</bool>
|
||||||
</property>
|
</property>
|
||||||
|
<property name="alignment">
|
||||||
|
<set>Qt::AlignCenter</set>
|
||||||
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item>
|
<item>
|
||||||
@@ -70,6 +97,31 @@
|
|||||||
</property>
|
</property>
|
||||||
</spacer>
|
</spacer>
|
||||||
</item>
|
</item>
|
||||||
|
<item>
|
||||||
|
<widget class="DLabel" name="label">
|
||||||
|
<property name="sizePolicy">
|
||||||
|
<sizepolicy hsizetype="Fixed" vsizetype="Fixed">
|
||||||
|
<horstretch>0</horstretch>
|
||||||
|
<verstretch>0</verstretch>
|
||||||
|
</sizepolicy>
|
||||||
|
</property>
|
||||||
|
<property name="minimumSize">
|
||||||
|
<size>
|
||||||
|
<width>120</width>
|
||||||
|
<height>48</height>
|
||||||
|
</size>
|
||||||
|
</property>
|
||||||
|
<property name="maximumSize">
|
||||||
|
<size>
|
||||||
|
<width>120</width>
|
||||||
|
<height>48</height>
|
||||||
|
</size>
|
||||||
|
</property>
|
||||||
|
<property name="text">
|
||||||
|
<string>Name</string>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
<item>
|
<item>
|
||||||
<widget class="QLabel" name="label_filename">
|
<widget class="QLabel" name="label_filename">
|
||||||
<property name="maximumSize">
|
<property name="maximumSize">
|
||||||
@@ -83,33 +135,6 @@
|
|||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item>
|
|
||||||
<widget class="QLabel" name="label">
|
|
||||||
<property name="minimumSize">
|
|
||||||
<size>
|
|
||||||
<width>80</width>
|
|
||||||
<height>0</height>
|
|
||||||
</size>
|
|
||||||
</property>
|
|
||||||
<property name="maximumSize">
|
|
||||||
<size>
|
|
||||||
<width>16777215</width>
|
|
||||||
<height>16777215</height>
|
|
||||||
</size>
|
|
||||||
</property>
|
|
||||||
<property name="font">
|
|
||||||
<font>
|
|
||||||
<pointsize>13</pointsize>
|
|
||||||
</font>
|
|
||||||
</property>
|
|
||||||
<property name="text">
|
|
||||||
<string>Name</string>
|
|
||||||
</property>
|
|
||||||
<property name="wordWrap">
|
|
||||||
<bool>true</bool>
|
|
||||||
</property>
|
|
||||||
</widget>
|
|
||||||
</item>
|
|
||||||
<item>
|
<item>
|
||||||
<spacer name="horizontalSpacer_2">
|
<spacer name="horizontalSpacer_2">
|
||||||
<property name="orientation">
|
<property name="orientation">
|
||||||
@@ -153,11 +178,14 @@
|
|||||||
<property name="leftMargin">
|
<property name="leftMargin">
|
||||||
<number>0</number>
|
<number>0</number>
|
||||||
</property>
|
</property>
|
||||||
|
<property name="topMargin">
|
||||||
|
<number>8</number>
|
||||||
|
</property>
|
||||||
<property name="rightMargin">
|
<property name="rightMargin">
|
||||||
<number>0</number>
|
<number>0</number>
|
||||||
</property>
|
</property>
|
||||||
<property name="bottomMargin">
|
<property name="bottomMargin">
|
||||||
<number>0</number>
|
<number>8</number>
|
||||||
</property>
|
</property>
|
||||||
<item>
|
<item>
|
||||||
<widget class="QProgressBar" name="progressBar">
|
<widget class="QProgressBar" name="progressBar">
|
||||||
@@ -188,7 +216,7 @@
|
|||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item>
|
<item>
|
||||||
<widget class="QLabel" name="label_2">
|
<widget class="DLabel" name="label_2">
|
||||||
<property name="font">
|
<property name="font">
|
||||||
<font>
|
<font>
|
||||||
<pointsize>9</pointsize>
|
<pointsize>9</pointsize>
|
||||||
@@ -297,6 +325,11 @@
|
|||||||
<header location="global">dspinner.h</header>
|
<header location="global">dspinner.h</header>
|
||||||
<container>1</container>
|
<container>1</container>
|
||||||
</customwidget>
|
</customwidget>
|
||||||
|
<customwidget>
|
||||||
|
<class>DLabel</class>
|
||||||
|
<extends>QLabel</extends>
|
||||||
|
<header>dlabel.h</header>
|
||||||
|
</customwidget>
|
||||||
</customwidgets>
|
</customwidgets>
|
||||||
<resources/>
|
<resources/>
|
||||||
<connections/>
|
<connections/>
|
||||||
|
|||||||
@@ -1,20 +1,20 @@
|
|||||||
#include "progressbutton.h"
|
#include "progressbutton.h"
|
||||||
|
#include "widgets/downloadlistwidget.h"
|
||||||
|
|
||||||
#include <QPainter>
|
#include <QPainter>
|
||||||
#include <QPainterPath>
|
#include <QPainterPath>
|
||||||
#include <QRect>
|
#include <QMoveEvent>
|
||||||
#include <QConicalGradient>
|
|
||||||
#include <QVariantAnimation>
|
|
||||||
#include <QSvgRenderer>
|
#include <QSvgRenderer>
|
||||||
|
|
||||||
ProgressButton::ProgressButton(QWidget *parent)
|
ProgressButton::ProgressButton(QWidget *parent)
|
||||||
: QWidget{parent}
|
: QWidget{parent}
|
||||||
{
|
{
|
||||||
// this->setWindowFlags(Qt::FramelessWindowHint);
|
// this->setWindowFlags(Qt::FramelessWindowHint);
|
||||||
this->setAttribute(Qt::WA_TranslucentBackground, true);
|
// this->setAttribute(Qt::WA_TranslucentBackground, true);
|
||||||
setMinimumWidth(36);
|
setMinimumSize(36, 36);
|
||||||
setMinimumHeight(36);
|
|
||||||
svgPath = "";
|
svgPath = "";
|
||||||
backColor = Qt::transparent;
|
backColor = Qt::transparent;
|
||||||
setMouseTracking(true);
|
|
||||||
|
|
||||||
connect(this, &ProgressButton::startProcessing, this, &ProgressButton::operationProcessing, Qt::QueuedConnection);
|
connect(this, &ProgressButton::startProcessing, this, &ProgressButton::operationProcessing, Qt::QueuedConnection);
|
||||||
}
|
}
|
||||||
@@ -23,69 +23,6 @@ ProgressButton::~ProgressButton()
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void ProgressButton::paintEvent(QPaintEvent *event)
|
|
||||||
{
|
|
||||||
QPainter painter(this);
|
|
||||||
painter.setRenderHint(QPainter::Antialiasing,true);
|
|
||||||
auto rect = event->rect();
|
|
||||||
|
|
||||||
if(buttonState == state::normal || buttonState == state::hover)
|
|
||||||
{
|
|
||||||
auto radiu = (rect.height() - 6) / 2;
|
|
||||||
painter.translate(rect.center());
|
|
||||||
painter.setPen(Qt::transparent);
|
|
||||||
painter.setBrush(QColor(buttonState == state::normal ? color : color.darker()));
|
|
||||||
//painter.drawEllipse(QPoint(0,0),radiu,radiu);
|
|
||||||
|
|
||||||
//radiu -= 3;
|
|
||||||
painter.setBrush(backColor);
|
|
||||||
painter.drawEllipse(QPoint(0,0),radiu,radiu);
|
|
||||||
|
|
||||||
QSvgRenderer m_svgRender;
|
|
||||||
m_svgRender.load(svgPath);
|
|
||||||
m_svgRender.render(&painter ,QRectF(-radiu / 2,-radiu / 2,radiu,radiu));
|
|
||||||
}
|
|
||||||
else if(buttonState == state::openProgress)
|
|
||||||
{
|
|
||||||
painter.translate(rect.center());
|
|
||||||
auto radiu = (rect.height() - 6) / 2 -3;
|
|
||||||
painter.setBrush(backColor);
|
|
||||||
painter.setPen(QPen(backColor,3));
|
|
||||||
painter.drawEllipse(QPoint(0,0),radiu,radiu);
|
|
||||||
|
|
||||||
painter.setPen(QPen(backColor,3));
|
|
||||||
|
|
||||||
QSvgRenderer m_svgRender;
|
|
||||||
m_svgRender.load(svgPath);
|
|
||||||
m_svgRender.render(&painter ,QRectF(-radiu / 2,-radiu / 2,radiu,radiu));
|
|
||||||
|
|
||||||
QRect rect = QRect(-radiu, -radiu,
|
|
||||||
radiu*2, radiu*2);
|
|
||||||
|
|
||||||
painter.setPen(QPen(color.darker(100),3));
|
|
||||||
auto angle = progress * 360 / 100;
|
|
||||||
painter.drawArc(rect.adjusted(-3,-3,3,3),90 * 16,-static_cast<int>(angle * 16));
|
|
||||||
}
|
|
||||||
else if(buttonState == state::closeProgress)
|
|
||||||
{
|
|
||||||
auto radiu = (rect.height() - 6) / 2;
|
|
||||||
painter.translate(rect.center());
|
|
||||||
painter.setPen(Qt::transparent);
|
|
||||||
painter.setBrush(QColor(0, 0, 0, 63));
|
|
||||||
painter.drawEllipse(QPoint(0,0),radiu,radiu);
|
|
||||||
|
|
||||||
radiu -= 3;
|
|
||||||
painter.setBrush(backColor);
|
|
||||||
painter.drawEllipse(QPoint(0,0),radiu,radiu);
|
|
||||||
|
|
||||||
painter.setPen(QPen(color,3,Qt::SolidLine,Qt::RoundCap,Qt::RoundJoin));
|
|
||||||
painter.drawLine(QPoint(-radiu / 3,0),
|
|
||||||
QPoint(-radiu / 5,radiu / 3));
|
|
||||||
painter.drawLine(QPoint(-radiu / 5,radiu / 3),
|
|
||||||
QPoint(radiu / 4,-radiu / 4));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void ProgressButton::setProgress(int progress)
|
void ProgressButton::setProgress(int progress)
|
||||||
{
|
{
|
||||||
buttonState = state::openProgress;
|
buttonState = state::openProgress;
|
||||||
@@ -99,14 +36,19 @@ void ProgressButton::setProgress(int progress)
|
|||||||
{
|
{
|
||||||
buttonState = state::closeProgress;
|
buttonState = state::closeProgress;
|
||||||
update();
|
update();
|
||||||
auto waterDrop = new WaterDrop();
|
WaterDrop *waterDrop = new WaterDrop(parentWidget());
|
||||||
waterDrop->move(this->mapToGlobal(this->rect().center()));
|
waterDrop->move(geometry().center());
|
||||||
waterDrop->show();
|
waterDrop->show();
|
||||||
}
|
}
|
||||||
repaint();
|
repaint();
|
||||||
update();
|
update();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ProgressButton::setDownloadListWidget(DownloadListWidget *widget)
|
||||||
|
{
|
||||||
|
m_downloadListWidget = widget;
|
||||||
|
}
|
||||||
|
|
||||||
void ProgressButton::setIcon(QString svgPATH)
|
void ProgressButton::setIcon(QString svgPATH)
|
||||||
{
|
{
|
||||||
svgPath = svgPATH;
|
svgPath = svgPATH;
|
||||||
@@ -125,17 +67,15 @@ void ProgressButton::setColor(QColor color)
|
|||||||
update();
|
update();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ProgressButton::leaveEvent(QEvent *event)
|
void ProgressButton::mousePressEvent(QMouseEvent *event)
|
||||||
{
|
{
|
||||||
if(buttonState == state::hover)
|
m_mouseMoved = false;
|
||||||
{
|
m_isDownloadListWidgetVisible = m_downloadListWidget->isVisible();
|
||||||
buttonState = state::normal;
|
m_downloadListWidget->hide();
|
||||||
update();
|
QWidget::mousePressEvent(event);
|
||||||
}
|
|
||||||
QWidget::leaveEvent(event);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void ProgressButton::mousePressEvent(QMouseEvent *event)
|
void ProgressButton::mouseReleaseEvent(QMouseEvent *event)
|
||||||
{
|
{
|
||||||
if (buttonState == state::hover || buttonState == state::normal)
|
if (buttonState == state::hover || buttonState == state::normal)
|
||||||
{
|
{
|
||||||
@@ -146,26 +86,126 @@ void ProgressButton::mousePressEvent(QMouseEvent *event)
|
|||||||
{
|
{
|
||||||
update();
|
update();
|
||||||
}
|
}
|
||||||
emit clicked();
|
|
||||||
QWidget::mousePressEvent(event);
|
if (m_mouseMoved) {
|
||||||
|
return QWidget::mouseReleaseEvent(event);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (m_isDownloadListWidgetVisible) {
|
||||||
|
m_downloadListWidget->hide();
|
||||||
|
} else {
|
||||||
|
QPoint pos(this->mapToGlobal(QPoint(0, 0)));
|
||||||
|
pos += QPoint(width() / 2 - m_downloadListWidget->width() / 2, height() + 5);
|
||||||
|
m_downloadListWidget->m_move(pos.x(), pos.y());
|
||||||
|
m_downloadListWidget->setWindowState(windowState() & Qt::WindowState::WindowActive);
|
||||||
|
m_downloadListWidget->activateWindow();
|
||||||
|
m_downloadListWidget->show();
|
||||||
|
m_downloadListWidget->raise();
|
||||||
|
}
|
||||||
|
m_isDownloadListWidgetVisible = m_downloadListWidget->isVisible();
|
||||||
|
QWidget::mouseReleaseEvent(event);
|
||||||
|
}
|
||||||
|
|
||||||
|
void ProgressButton::mouseDoubleClickEvent(QMouseEvent *event)
|
||||||
|
{
|
||||||
|
event->accept();
|
||||||
|
}
|
||||||
|
|
||||||
|
void ProgressButton::mouseMoveEvent(QMouseEvent *event)
|
||||||
|
{
|
||||||
|
m_mouseMoved = true;
|
||||||
|
QWidget::mouseMoveEvent(event);
|
||||||
|
}
|
||||||
|
|
||||||
|
void ProgressButton::leaveEvent(QEvent *event)
|
||||||
|
{
|
||||||
|
if (buttonState == state::hover)
|
||||||
|
{
|
||||||
|
buttonState = state::normal;
|
||||||
|
update();
|
||||||
|
}
|
||||||
|
QWidget::leaveEvent(event);
|
||||||
|
}
|
||||||
|
|
||||||
|
void ProgressButton::paintEvent(QPaintEvent *event)
|
||||||
|
{
|
||||||
|
QPainter painter(this);
|
||||||
|
painter.setRenderHint(QPainter::Antialiasing, true);
|
||||||
|
QRect rect = event->rect();
|
||||||
|
|
||||||
|
if (buttonState == state::normal || buttonState == state::hover)
|
||||||
|
{
|
||||||
|
int radius = (rect.height() - 6) / 2;
|
||||||
|
painter.translate(rect.center());
|
||||||
|
painter.setPen(Qt::transparent);
|
||||||
|
painter.setBrush(QColor(buttonState == state::normal ? color : color.darker()));
|
||||||
|
// painter.drawEllipse(QPoint(0, 0), radius, radius);
|
||||||
|
|
||||||
|
// radiu -= 3;
|
||||||
|
painter.setBrush(backColor);
|
||||||
|
painter.drawEllipse(QPoint(0, 0), radius, radius);
|
||||||
|
|
||||||
|
QSvgRenderer m_svgRender;
|
||||||
|
m_svgRender.load(svgPath);
|
||||||
|
m_svgRender.render(&painter, QRectF(-radius / 2, -radius / 2, radius, radius));
|
||||||
|
}
|
||||||
|
else if (buttonState == state::openProgress)
|
||||||
|
{
|
||||||
|
painter.translate(rect.center());
|
||||||
|
int radius = (rect.height() - 6) / 2 - 3;
|
||||||
|
painter.setBrush(backColor);
|
||||||
|
painter.setPen(QPen(backColor, 3));
|
||||||
|
painter.drawEllipse(QPoint(0, 0), radius, radius);
|
||||||
|
|
||||||
|
painter.setPen(QPen(backColor, 3));
|
||||||
|
|
||||||
|
QSvgRenderer m_svgRender;
|
||||||
|
m_svgRender.load(svgPath);
|
||||||
|
m_svgRender.render(&painter, QRectF(-radius / 2, -radius / 2, radius, radius));
|
||||||
|
|
||||||
|
QRect rect = QRect(-radius, -radius,
|
||||||
|
radius * 2, radius * 2);
|
||||||
|
|
||||||
|
painter.setPen(QPen(color.darker(100), 3));
|
||||||
|
qreal angle = progress * 360 / 100 * 1.0;
|
||||||
|
painter.drawArc(rect.adjusted(-3, -3, 3, 3), 90 * 16, -qIntCast(angle * 16));
|
||||||
|
}
|
||||||
|
else if (buttonState == state::closeProgress)
|
||||||
|
{
|
||||||
|
auto radius = (rect.height() - 6) / 2;
|
||||||
|
painter.translate(rect.center());
|
||||||
|
painter.setPen(Qt::transparent);
|
||||||
|
painter.setBrush(QColor(0, 0, 0, 63));
|
||||||
|
painter.drawEllipse(QPoint(0, 0), radius, radius);
|
||||||
|
|
||||||
|
radius -= 3;
|
||||||
|
painter.setBrush(backColor);
|
||||||
|
painter.drawEllipse(QPoint(0, 0), radius, radius);
|
||||||
|
|
||||||
|
painter.setPen(QPen(color, 3, Qt::SolidLine, Qt::RoundCap, Qt::RoundJoin));
|
||||||
|
painter.drawLine(QPoint(-radius / 3, 0),
|
||||||
|
QPoint(-radius / 5, radius / 3));
|
||||||
|
painter.drawLine(QPoint(-radius / 5, radius / 3),
|
||||||
|
QPoint(radius / 4, -radius / 4));
|
||||||
|
}
|
||||||
|
QWidget::paintEvent(event);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ProgressButton::operationProcessing()
|
void ProgressButton::operationProcessing()
|
||||||
{
|
{
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const int RADIUS = 60;
|
const int RADIUS = 60;
|
||||||
WaterDrop::WaterDrop(QWidget *parent)
|
WaterDrop::WaterDrop(QWidget *parent)
|
||||||
: QWidget(parent)
|
: QWidget(parent)
|
||||||
, m_waterDropAnimation(nullptr)
|
, m_waterDropAnimation(new QVariantAnimation(this))
|
||||||
, m_animationRadius(0)
|
, m_animationRadius(0)
|
||||||
{
|
{
|
||||||
this->setFixedSize(QSize(RADIUS * 2, RADIUS * 2));
|
this->setFixedSize(QSize(RADIUS * 2, RADIUS * 2));
|
||||||
this->setWindowFlags(Qt::FramelessWindowHint | Qt::Tool);
|
// this->setWindowFlags(Qt::FramelessWindowHint | Qt::Tool);
|
||||||
this->setAttribute(Qt::WA_TranslucentBackground);
|
// this->setAttribute(Qt::WA_TranslucentBackground);
|
||||||
this->setAttribute(Qt::WA_DeleteOnClose);
|
// this->setAttribute(Qt::WA_DeleteOnClose);
|
||||||
m_waterDropAnimation = new QVariantAnimation(this);
|
|
||||||
// m_waterDropAnimation->setEasingCurve(QEasingCurve(static_cast<QEasingCurve::Type>(QRandomGenerator::global()->bounded(40))));
|
// m_waterDropAnimation->setEasingCurve(QEasingCurve(static_cast<QEasingCurve::Type>(QRandomGenerator::global()->bounded(40))));
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -182,9 +222,9 @@ void WaterDrop::show()
|
|||||||
m_waterDropAnimation->setEndValue(RADIUS);
|
m_waterDropAnimation->setEndValue(RADIUS);
|
||||||
m_waterDropAnimation->setDuration(350);
|
m_waterDropAnimation->setDuration(350);
|
||||||
|
|
||||||
connect(m_waterDropAnimation, &QVariantAnimation::valueChanged, this, &WaterDrop::onRaduisChanged);
|
connect(m_waterDropAnimation, &QVariantAnimation::valueChanged, this, &WaterDrop::onRadiusChanged);
|
||||||
connect(m_waterDropAnimation, &QVariantAnimation::finished, this, &WaterDrop::close);
|
connect(m_waterDropAnimation, &QVariantAnimation::finished, this, &WaterDrop::close);
|
||||||
m_waterDropAnimation->start();
|
m_waterDropAnimation->start(QVariantAnimation::DeleteWhenStopped);
|
||||||
QWidget::show();
|
QWidget::show();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -192,14 +232,15 @@ void WaterDrop::paintEvent(QPaintEvent *event)
|
|||||||
{
|
{
|
||||||
QPainter painter(this);
|
QPainter painter(this);
|
||||||
painter.setRenderHint(QPainter::Antialiasing);
|
painter.setRenderHint(QPainter::Antialiasing);
|
||||||
QPen pen;
|
QPen pen(QBrush(QColor("#ffff80")), 5.0);
|
||||||
pen.setColor(QColor(0xffffff80));
|
|
||||||
pen.setWidth(5);
|
pen.setWidth(5);
|
||||||
painter.setPen(pen);
|
painter.setPen(pen);
|
||||||
painter.drawEllipse(event->rect().center(), m_animationRadius, m_animationRadius);
|
painter.drawEllipse(event->rect().center(), m_animationRadius, m_animationRadius);
|
||||||
|
|
||||||
|
QWidget::paintEvent(event);
|
||||||
}
|
}
|
||||||
|
|
||||||
void WaterDrop::onRaduisChanged(QVariant value)
|
void WaterDrop::onRadiusChanged(const QVariant &value)
|
||||||
{
|
{
|
||||||
m_animationRadius = value.toInt();
|
m_animationRadius = value.toInt();
|
||||||
update();
|
update();
|
||||||
|
|||||||
@@ -1,53 +1,62 @@
|
|||||||
#ifndef PROGRESSBUTTON_H
|
#ifndef PROGRESSBUTTON_H
|
||||||
#define PROGRESSBUTTON_H
|
#define PROGRESSBUTTON_H
|
||||||
|
|
||||||
|
#include <QWidget>
|
||||||
#include <QtWidgets/QWidget>
|
|
||||||
|
|
||||||
#include <QPaintEvent>
|
|
||||||
|
|
||||||
#include <QTimer>
|
#include <QTimer>
|
||||||
#include <QTimerEvent>
|
#include <QVariantAnimation>
|
||||||
#include<QColor>
|
|
||||||
#include <QList>
|
|
||||||
#include <QMouseEvent>
|
|
||||||
|
|
||||||
|
|
||||||
|
class DownloadListWidget;
|
||||||
class ProgressButton : public QWidget
|
class ProgressButton : public QWidget
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
public:
|
public:
|
||||||
ProgressButton(QWidget *parent = nullptr);
|
explicit ProgressButton(QWidget *parent = nullptr);
|
||||||
|
~ProgressButton() override;
|
||||||
|
|
||||||
void setIcon(QString svgPATH);
|
void setIcon(QString svgPATH);
|
||||||
void setBackgroundColor(QColor color);
|
void setBackgroundColor(QColor color);
|
||||||
void setColor(QColor color);
|
void setColor(QColor color);
|
||||||
void setProgress(int progress);
|
void setProgress(int progress);
|
||||||
~ProgressButton();
|
|
||||||
|
void setDownloadListWidget(DownloadListWidget *widget);
|
||||||
|
|
||||||
|
protected:
|
||||||
|
void mousePressEvent(QMouseEvent *event) override;
|
||||||
|
void mouseReleaseEvent(QMouseEvent *event) override;
|
||||||
|
void mouseDoubleClickEvent(QMouseEvent *event) override;
|
||||||
|
void mouseMoveEvent(QMouseEvent *event) override;
|
||||||
|
void leaveEvent(QEvent *event) override;
|
||||||
|
void paintEvent(QPaintEvent *event) override;
|
||||||
|
|
||||||
signals:
|
signals:
|
||||||
void startProcessing();
|
void startProcessing();
|
||||||
void clicked();
|
void clicked();
|
||||||
|
|
||||||
protected:
|
private slots:
|
||||||
void paintEvent(QPaintEvent *event)override;
|
void operationProcessing();
|
||||||
void leaveEvent(QEvent *event)override;
|
|
||||||
void mousePressEvent(QMouseEvent *event)override;
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
enum class state
|
enum state
|
||||||
{
|
{
|
||||||
normal,
|
normal,
|
||||||
hover,
|
hover,
|
||||||
openProgress,
|
openProgress,
|
||||||
closeProgress,
|
closeProgress,
|
||||||
recovery
|
recovery
|
||||||
}
|
};
|
||||||
buttonState{state::normal};
|
|
||||||
|
DownloadListWidget *m_downloadListWidget = nullptr;
|
||||||
|
|
||||||
|
state buttonState{state::normal};
|
||||||
QColor backColor;
|
QColor backColor;
|
||||||
QColor color;
|
QColor color;
|
||||||
QString svgPath;
|
QString svgPath;
|
||||||
int widthChangeValue{0};
|
int widthChangeValue{0};
|
||||||
void operationProcessing();
|
|
||||||
int progress{0};//处理百分比
|
int progress{0};//处理百分比
|
||||||
|
|
||||||
|
bool m_mouseMoved = false;
|
||||||
|
bool m_isDownloadListWidgetVisible = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
class WaterDrop : public QWidget
|
class WaterDrop : public QWidget
|
||||||
@@ -55,19 +64,19 @@ class WaterDrop : public QWidget
|
|||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
public:
|
public:
|
||||||
WaterDrop(QWidget *parent = Q_NULLPTR);
|
explicit WaterDrop(QWidget *parent = nullptr);
|
||||||
void show();
|
void show();
|
||||||
void move(const QPoint &point);
|
void move(const QPoint &point);
|
||||||
|
|
||||||
private:
|
protected:
|
||||||
void paintEvent(QPaintEvent *event);
|
void paintEvent(QPaintEvent *event);
|
||||||
void onRaduisChanged(QVariant value);
|
|
||||||
|
private slots:
|
||||||
|
void onRadiusChanged(const QVariant &value);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
class QVariantAnimation* m_waterDropAnimation;
|
QVariantAnimation *m_waterDropAnimation = nullptr;
|
||||||
int m_animationRadius;
|
int m_animationRadius;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#endif // PROGRESSBUTTON_H
|
#endif // PROGRESSBUTTON_H
|
||||||
|
|||||||
@@ -16,7 +16,6 @@ void SmoothListWidget::wheelEvent(QWheelEvent *e)
|
|||||||
}
|
}
|
||||||
void SmoothListWidget::onSliderChanged(int p)
|
void SmoothListWidget::onSliderChanged(int p)
|
||||||
{
|
{
|
||||||
int startRow = count();
|
|
||||||
if (p == vScrollBar->maximum())
|
if (p == vScrollBar->maximum())
|
||||||
{
|
{
|
||||||
emit reachedBottom(); // 1
|
emit reachedBottom(); // 1
|
||||||
|
|||||||
@@ -1,10 +1,26 @@
|
|||||||
#include "webenginepage.h"
|
#include "webenginepage.h"
|
||||||
|
|
||||||
#include <QDesktopServices>
|
#include <QDesktopServices>
|
||||||
|
#include <QWebEngineSettings>
|
||||||
|
#include <QWebEngineProfile>
|
||||||
|
|
||||||
WebEnginePage::WebEnginePage(QObject *parent)
|
WebEnginePage::WebEnginePage(QObject *parent)
|
||||||
: QWebEnginePage(parent)
|
: QWebEnginePage(parent)
|
||||||
{
|
{
|
||||||
|
QLocale ql;
|
||||||
|
switch (ql.language())
|
||||||
|
{
|
||||||
|
case QLocale::Chinese:
|
||||||
|
{
|
||||||
|
// 系统语言是中文,获取网页为中文 @momen @uniartisan
|
||||||
|
QWebEngineProfile *profile = QWebEngineProfile::defaultProfile();
|
||||||
|
qDebug() << profile->httpAcceptLanguage();
|
||||||
|
profile->setHttpAcceptLanguage("zh-CN,zh;q=0.8,en;q=0.6");
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
WebEnginePage::~WebEnginePage()
|
WebEnginePage::~WebEnginePage()
|
||||||
@@ -13,7 +29,8 @@ WebEnginePage::~WebEnginePage()
|
|||||||
|
|
||||||
void WebEnginePage::setUrl(const QUrl &url)
|
void WebEnginePage::setUrl(const QUrl &url)
|
||||||
{
|
{
|
||||||
if (m_currentUrl == url) {
|
if (m_currentUrl == url)
|
||||||
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -32,7 +49,8 @@ QWebEnginePage *WebEnginePage::createWindow(QWebEnginePage::WebWindowType type)
|
|||||||
|
|
||||||
void WebEnginePage::slotUrlChanged(const QUrl &url)
|
void WebEnginePage::slotUrlChanged(const QUrl &url)
|
||||||
{
|
{
|
||||||
if (m_currentUrl == url) {
|
if (m_currentUrl == url)
|
||||||
|
{
|
||||||
sender()->deleteLater();
|
sender()->deleteLater();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,13 +1,20 @@
|
|||||||
#include "downloadlistwidget.h"
|
#include "downloadlistwidget.h"
|
||||||
#include "ui_downloadlistwidget.h"
|
#include "ui_downloadlistwidget.h"
|
||||||
#include <QGraphicsOpacityEffect>
|
#include "widgets/common/downloaditem.h"
|
||||||
#include <QPropertyAnimation>
|
#include "backend/sparkapi.h"
|
||||||
|
#include "backend/downloadworker.h"
|
||||||
|
#include "utils/utils.h"
|
||||||
|
#include "application.h"
|
||||||
|
|
||||||
|
#include <QDesktopServices>
|
||||||
|
#include <QtConcurrent>
|
||||||
#include <QDebug>
|
#include <QDebug>
|
||||||
DownloadListWidget::DownloadListWidget(QWidget *parent) :
|
|
||||||
DBlurEffectWidget(parent),
|
DownloadListWidget::DownloadListWidget(QWidget *parent) : DBlurEffectWidget(parent),
|
||||||
ui(new Ui::DownloadListWidget)
|
ui(new Ui::DownloadListWidget)
|
||||||
{
|
{
|
||||||
ui->setupUi(this);
|
ui->setupUi(this);
|
||||||
|
setWindowTitle(QObject::tr("Download list"));
|
||||||
installEventFilter(this);
|
installEventFilter(this);
|
||||||
this->setAttribute(Qt::WA_Hover, true);
|
this->setAttribute(Qt::WA_Hover, true);
|
||||||
setFocus();
|
setFocus();
|
||||||
@@ -47,44 +54,36 @@ DownloadListWidget::DownloadListWidget(QWidget *parent) :
|
|||||||
downloaditemlist[nowDownload - 1]->setSpeed(theSpeed);
|
downloaditemlist[nowDownload - 1]->setSpeed(theSpeed);
|
||||||
}else{
|
}else{
|
||||||
emit downloadProgress(0);
|
emit downloadProgress(0);
|
||||||
}
|
} });
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
DownloadListWidget::~DownloadListWidget()
|
DownloadListWidget::~DownloadListWidget()
|
||||||
{
|
{
|
||||||
if (downloadController) {
|
if (downloadController)
|
||||||
|
{
|
||||||
|
downloadController->disconnect();
|
||||||
downloadController->stopDownload();
|
downloadController->stopDownload();
|
||||||
downloadController->deleteLater();
|
// 这里没有释放 downloadController,使用懒汉式单例
|
||||||
}
|
}
|
||||||
|
|
||||||
|
clearItem();
|
||||||
delete ui;
|
delete ui;
|
||||||
}
|
}
|
||||||
|
|
||||||
void DownloadListWidget::clearItem()
|
void DownloadListWidget::clearItem()
|
||||||
{
|
{
|
||||||
ui->listWidget->vScrollBar->scrollTop();
|
|
||||||
int n=ui->listWidget->count();
|
|
||||||
for(int i=0;i<n;i++)
|
|
||||||
{
|
|
||||||
QListWidgetItem *item = ui->listWidget->takeItem(0);
|
|
||||||
QWidget *card = ui->listWidget->itemWidget(item);
|
|
||||||
delete card;
|
|
||||||
card = NULL;
|
|
||||||
delete item;
|
|
||||||
item = NULL;
|
|
||||||
}
|
|
||||||
ui->listWidget->clear();
|
ui->listWidget->clear();
|
||||||
}
|
}
|
||||||
void DownloadListWidget::addItem(QString name,QString fileName,QString pkgName,const QPixmap icon,QString downloadurl)
|
|
||||||
|
DownloadItem* DownloadListWidget::addItem(QString name, QString fileName, QString pkgName, const QPixmap icon, QString downloadurl)
|
||||||
{
|
{
|
||||||
if (fileName.isEmpty())
|
if (fileName.isEmpty())
|
||||||
{
|
{
|
||||||
return;
|
return nullptr;
|
||||||
}
|
}
|
||||||
urList.append(downloadurl);
|
urList.append(downloadurl);
|
||||||
allDownload += 1;
|
allDownload += 1;
|
||||||
DownloadItem *di=new DownloadItem(this);
|
DownloadItem *di = new DownloadItem;
|
||||||
dlist << downloadurl;
|
dlist << downloadurl;
|
||||||
downloaditemlist << di;
|
downloaditemlist << di;
|
||||||
di->setName(name);
|
di->setName(name);
|
||||||
@@ -92,7 +91,7 @@ void DownloadListWidget::addItem(QString name,QString fileName,QString pkgName,c
|
|||||||
di->pkgName = pkgName;
|
di->pkgName = pkgName;
|
||||||
di->seticon(icon);
|
di->seticon(icon);
|
||||||
QListWidgetItem *pItem = new QListWidgetItem();
|
QListWidgetItem *pItem = new QListWidgetItem();
|
||||||
pItem->setSizeHint(QSize(240, 50));
|
pItem->setSizeHint(QSize(240, 56)); // ui 中单个 downloaditem 高度固定 56px(上下 margin 8px,图片固定 48x48)
|
||||||
ui->listWidget->addItem(pItem);
|
ui->listWidget->addItem(pItem);
|
||||||
ui->listWidget->setItemWidget(pItem, di);
|
ui->listWidget->setItemWidget(pItem, di);
|
||||||
if (!isBusy)
|
if (!isBusy)
|
||||||
@@ -100,6 +99,8 @@ void DownloadListWidget::addItem(QString name,QString fileName,QString pkgName,c
|
|||||||
nowDownload += 1;
|
nowDownload += 1;
|
||||||
startRequest(urList.at(nowDownload - 1), fileName); // 进行链接请求
|
startRequest(urList.at(nowDownload - 1), fileName); // 进行链接请求
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return di;
|
||||||
}
|
}
|
||||||
|
|
||||||
QList<DownloadItem *> DownloadListWidget::getDIList()
|
QList<DownloadItem *> DownloadListWidget::getDIList()
|
||||||
@@ -120,7 +121,18 @@ void DownloadListWidget::startRequest(QUrl url, QString fileName)
|
|||||||
isdownload = true;
|
isdownload = true;
|
||||||
downloaditemlist[allDownload - 1]->free = false;
|
downloaditemlist[allDownload - 1]->free = false;
|
||||||
|
|
||||||
downloadController = new DownloadController(this); // 并发下载,在点击下载按钮的时候才会初始化
|
// 使用懒汉式单例来存储downloadController
|
||||||
|
if (downloadController == nullptr)
|
||||||
|
{
|
||||||
|
downloadController = new DownloadController; // 并发下载,在第一次点击下载按钮的时候才会初始化
|
||||||
|
}
|
||||||
|
|
||||||
|
if (downloadController)
|
||||||
|
{
|
||||||
|
downloadController->disconnect();
|
||||||
|
downloadController->stopDownload();
|
||||||
|
}
|
||||||
|
|
||||||
connect(downloadController, &DownloadController::downloadProcess, this, &DownloadListWidget::updateDataReadProgress);
|
connect(downloadController, &DownloadController::downloadProcess, this, &DownloadListWidget::updateDataReadProgress);
|
||||||
connect(downloadController, &DownloadController::downloadFinished, this, &DownloadListWidget::httpFinished);
|
connect(downloadController, &DownloadController::downloadFinished, this, &DownloadListWidget::httpFinished);
|
||||||
// connect(downloadController, &DownloadController::errorOccur, this, [=](QString msg){this->sendNotification(msg);});
|
// connect(downloadController, &DownloadController::errorOccur, this, [=](QString msg){this->sendNotification(msg);});
|
||||||
@@ -128,11 +140,24 @@ void DownloadListWidget::startRequest(QUrl url, QString fileName)
|
|||||||
downloadController->startDownload(url.toString());
|
downloadController->startDownload(url.toString());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/***************************************************************
|
||||||
|
* @brief 下载列表完成下载的回调函数
|
||||||
|
* @param
|
||||||
|
* @note 如果正在安装,则在新开的线程空间中等待上一个安装完
|
||||||
|
* @Sample usage:
|
||||||
|
**************************************************************/
|
||||||
void DownloadListWidget::httpFinished() // 完成下载
|
void DownloadListWidget::httpFinished() // 完成下载
|
||||||
{
|
{
|
||||||
isdownload = false;
|
isdownload = false;
|
||||||
isBusy = false;
|
isBusy = false;
|
||||||
downloaditemlist[nowDownload - 1]->readyInstall();
|
|
||||||
|
QtConcurrent::run([=]()
|
||||||
|
{
|
||||||
|
while (downloaditemlist[nowDownload - 1]->readyInstall() == -1)
|
||||||
|
{
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
downloaditemlist[nowDownload - 1]->free = true;
|
downloaditemlist[nowDownload - 1]->free = true;
|
||||||
emit downloadFinished();
|
emit downloadFinished();
|
||||||
if (nowDownload < allDownload)
|
if (nowDownload < allDownload)
|
||||||
@@ -152,6 +177,7 @@ void DownloadListWidget::httpFinished() // 完成下载
|
|||||||
QString fileName = downloaditemlist[nowDownload - 1]->getName();
|
QString fileName = downloaditemlist[nowDownload - 1]->getName();
|
||||||
startRequest(urList.at(nowDownload - 1), fileName);
|
startRequest(urList.at(nowDownload - 1), fileName);
|
||||||
}
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
void DownloadListWidget::updateDataReadProgress(QString speedInfo, qint64 bytesRead, qint64 totalBytes)
|
void DownloadListWidget::updateDataReadProgress(QString speedInfo, qint64 bytesRead, qint64 totalBytes)
|
||||||
@@ -175,7 +201,6 @@ void DownloadListWidget::updateDataReadProgress(QString speedInfo, qint64 bytesR
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void DownloadListWidget::m_move(int x, int y)
|
void DownloadListWidget::m_move(int x, int y)
|
||||||
{
|
{
|
||||||
m_rect.setX(x);
|
m_rect.setX(x);
|
||||||
@@ -183,18 +208,7 @@ void DownloadListWidget::m_move(int x,int y)
|
|||||||
move(x, y);
|
move(x, y);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
bool DownloadListWidget::eventFilter(QObject *watched, QEvent *event)
|
|
||||||
{
|
|
||||||
if (Q_NULLPTR == watched) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if (QEvent::ActivationChange == event->type()) {
|
|
||||||
if(QApplication::activeWindow() != this){
|
|
||||||
this->close();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return QWidget::eventFilter(watched, event);
|
|
||||||
}
|
|
||||||
void DownloadListWidget::mouseMoveEvent(QMouseEvent *event)
|
void DownloadListWidget::mouseMoveEvent(QMouseEvent *event)
|
||||||
{
|
{
|
||||||
setGeometry(m_rect);
|
setGeometry(m_rect);
|
||||||
|
|||||||
@@ -1,33 +1,35 @@
|
|||||||
#ifndef DOWNLOADLISTWIDGET_H
|
#ifndef DOWNLOADLISTWIDGET_H
|
||||||
#define DOWNLOADLISTWIDGET_H
|
#define DOWNLOADLISTWIDGET_H
|
||||||
|
|
||||||
|
#include <DBlurEffectWidget>
|
||||||
|
|
||||||
#include <QWidget>
|
#include <QWidget>
|
||||||
#include <QTimer>
|
#include <QTimer>
|
||||||
#include <DBlurEffectWidget>
|
|
||||||
#include <QNetworkAccessManager>
|
|
||||||
#include <QDesktopServices>
|
|
||||||
#include "widgets/common/downloaditem.h"
|
|
||||||
#include "backend/sparkapi.h"
|
|
||||||
#include "backend/downloadworker.h"
|
|
||||||
#include "utils/utils.h"
|
|
||||||
DWIDGET_USE_NAMESPACE
|
|
||||||
namespace Ui {
|
namespace Ui {
|
||||||
class DownloadListWidget;
|
class DownloadListWidget;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
DWIDGET_USE_NAMESPACE
|
||||||
|
|
||||||
|
class DownloadItem;
|
||||||
|
class DownloadController;
|
||||||
class DownloadListWidget : public DBlurEffectWidget
|
class DownloadListWidget : public DBlurEffectWidget
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
public:
|
public:
|
||||||
void addItem(QString name, QString fileName, QString pkgName, const QPixmap icon, QString downloadurl);
|
DownloadItem *addItem(QString name, QString fileName, QString pkgName, const QPixmap icon, QString downloadurl);
|
||||||
int nowDownload = 0;
|
int nowDownload = 0;
|
||||||
int allDownload = 0;
|
int allDownload = 0;
|
||||||
QList<DownloadItem *> getDIList();
|
QList<DownloadItem *> getDIList();
|
||||||
QList<QUrl> getUrlList();
|
QList<QUrl> getUrlList();
|
||||||
void m_move(int x, int y);
|
void m_move(int x, int y);
|
||||||
explicit DownloadListWidget(QWidget *parent = nullptr);
|
explicit DownloadListWidget(QWidget *parent = nullptr);
|
||||||
~DownloadListWidget();
|
~DownloadListWidget() override;
|
||||||
|
|
||||||
|
protected:
|
||||||
|
void mouseMoveEvent(QMouseEvent *event) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
int isdownload = false;
|
int isdownload = false;
|
||||||
@@ -35,7 +37,7 @@ private:
|
|||||||
QStringList dlist;
|
QStringList dlist;
|
||||||
QList<QUrl> urList;
|
QList<QUrl> urList;
|
||||||
QList<DownloadItem *> downloaditemlist;
|
QList<DownloadItem *> downloaditemlist;
|
||||||
DownloadController *downloadController;
|
DownloadController *downloadController = nullptr;
|
||||||
int nowdownload = 0;
|
int nowdownload = 0;
|
||||||
QString theSpeed;
|
QString theSpeed;
|
||||||
QTimer download_speed;
|
QTimer download_speed;
|
||||||
@@ -48,13 +50,13 @@ private:
|
|||||||
void clearItem();
|
void clearItem();
|
||||||
QRect m_rect;
|
QRect m_rect;
|
||||||
Ui::DownloadListWidget *ui;
|
Ui::DownloadListWidget *ui;
|
||||||
private slots:
|
|
||||||
bool eventFilter(QObject *, QEvent *);
|
|
||||||
void mouseMoveEvent(QMouseEvent *event);
|
|
||||||
void on_pushButton_clicked();
|
|
||||||
signals:
|
signals:
|
||||||
void downloadFinished();
|
void downloadFinished();
|
||||||
void downloadProgress(int i);
|
void downloadProgress(int i);
|
||||||
|
|
||||||
|
private slots:
|
||||||
|
void on_pushButton_clicked();
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // DOWNLOADLISTWIDGET_H
|
#endif // DOWNLOADLISTWIDGET_H
|
||||||
|
|||||||
@@ -85,7 +85,7 @@ QListWidget::item::selected
|
|||||||
}</string>
|
}</string>
|
||||||
</property>
|
</property>
|
||||||
<property name="frameShape">
|
<property name="frameShape">
|
||||||
<enum>QFrame::StyledPanel</enum>
|
<enum>QFrame::NoFrame</enum>
|
||||||
</property>
|
</property>
|
||||||
<property name="verticalScrollBarPolicy">
|
<property name="verticalScrollBarPolicy">
|
||||||
<enum>Qt::ScrollBarAsNeeded</enum>
|
<enum>Qt::ScrollBarAsNeeded</enum>
|
||||||
@@ -99,9 +99,15 @@ QListWidget::item::selected
|
|||||||
<property name="autoScrollMargin">
|
<property name="autoScrollMargin">
|
||||||
<number>10</number>
|
<number>10</number>
|
||||||
</property>
|
</property>
|
||||||
|
<property name="editTriggers">
|
||||||
|
<set>QAbstractItemView::NoEditTriggers</set>
|
||||||
|
</property>
|
||||||
<property name="resizeMode">
|
<property name="resizeMode">
|
||||||
<enum>QListView::Fixed</enum>
|
<enum>QListView::Fixed</enum>
|
||||||
</property>
|
</property>
|
||||||
|
<property name="spacing">
|
||||||
|
<number>4</number>
|
||||||
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item>
|
<item>
|
||||||
|
|||||||
@@ -11,8 +11,20 @@
|
|||||||
#
|
#
|
||||||
# Default: apt-get
|
# Default: apt-get
|
||||||
#
|
#
|
||||||
_APTMGR=apt
|
_APTMGR=apt-get
|
||||||
|
|
||||||
|
if [ -x "$(command -v apt)" ]; then
|
||||||
|
_APTMGR=apt
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
if grep -Eqi "linuxmint" /etc/os-release;then
|
||||||
|
_APTMGR=apt-get
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -x "$(command -v oyo)" ]; then
|
||||||
|
_APTMGR=/usr/bin/apt
|
||||||
|
fi
|
||||||
|
|
||||||
####
|
####
|
||||||
#
|
#
|
||||||
@@ -25,6 +37,8 @@ AUTH_UOS_PASSWD="`cat /etc/apt/auth.conf.d/uos.conf | grep home-packages.chinau
|
|||||||
AUTH_UOS_PASSWD=`echo ${AUTH_UOS_PASSWD#*password }`
|
AUTH_UOS_PASSWD=`echo ${AUTH_UOS_PASSWD#*password }`
|
||||||
|
|
||||||
fi
|
fi
|
||||||
|
##### UOS自动读取账号密码以实现使用aptss来加速下载
|
||||||
|
|
||||||
# Enable DOWNLOADBEFORE to suppress apt-fast confirmation dialog and download
|
# Enable DOWNLOADBEFORE to suppress apt-fast confirmation dialog and download
|
||||||
# packages directly.
|
# packages directly.
|
||||||
#
|
#
|
||||||
@@ -65,7 +79,7 @@ DOWNLOADBEFORE=true
|
|||||||
#
|
#
|
||||||
# Default: disabled
|
# Default: disabled
|
||||||
#
|
#
|
||||||
MIRRORS=( 'https://d.store.deepinos.org.cn/,https://mirrors.sdu.edu.cn/spark-store-repository/,http://cdn.dl.uniartisan.com:9000/deepinos/,https://d1.store.deepinos.org.cn/,https://d2.store.deepinos.org.cn/,https://d4.store.deepinos.org.cn/,https://d5.store.deepinos.org.cn/' )
|
MIRRORS=( 'https://d.store.deepinos.org.cn/,https://zunyun01.store.deepinos.org.cn/,https://mirrors.sdu.edu.cn/spark-store-repository/,http://cdn.dl.uniartisan.com:9000/deepinos/,https://d1.store.deepinos.org.cn/,https://d2.store.deepinos.org.cn/,https://d3.store.deepinos.org.cn/,https://d4.store.deepinos.org.cn/,https://d5.store.deepinos.org.cn/' )
|
||||||
|
|
||||||
|
|
||||||
# Maximum number of connections
|
# Maximum number of connections
|
||||||
@@ -73,7 +87,7 @@ MIRRORS=( 'https://d.store.deepinos.org.cn/,https://mirrors.sdu.edu.cn/spark-sto
|
|||||||
#
|
#
|
||||||
# Default: 5
|
# Default: 5
|
||||||
#
|
#
|
||||||
_MAXNUM=5
|
_MAXNUM=16
|
||||||
|
|
||||||
|
|
||||||
# Maximum number of connections per server
|
# Maximum number of connections per server
|
||||||
|
|||||||
@@ -161,7 +161,8 @@ VERBOSE_OUTPUT=
|
|||||||
_DOWNLOADER='aria2c --no-conf -c -j ${_MAXNUM} -x ${_MAXCONPERSRV} -s ${_SPLITCON} -i ${DLLIST} --min-split-size=${_MINSPLITSZ} --stream-piece-selector=${_PIECEALGO} --connect-timeout=600 --timeout=600 -m0'
|
_DOWNLOADER='aria2c --no-conf -c -j ${_MAXNUM} -x ${_MAXCONPERSRV} -s ${_SPLITCON} -i ${DLLIST} --min-split-size=${_MINSPLITSZ} --stream-piece-selector=${_PIECEALGO} --connect-timeout=600 --timeout=600 -m0'
|
||||||
|
|
||||||
# Load config file.
|
# Load config file.
|
||||||
CONFFILE="/etc/apt-fast.conf"
|
CONFFILE="/tmp/aptss-conf/apt-fast.conf"
|
||||||
|
#### Spark Store apt-fast conf is in /tmp
|
||||||
if [ -e "$CONFFILE" ]; then
|
if [ -e "$CONFFILE" ]; then
|
||||||
source "$CONFFILE"
|
source "$CONFFILE"
|
||||||
fi
|
fi
|
||||||
@@ -207,7 +208,9 @@ fi
|
|||||||
msg_already_running()
|
msg_already_running()
|
||||||
{
|
{
|
||||||
msg "apt-fast already running!" "warning"
|
msg "apt-fast already running!" "warning"
|
||||||
|
msg "apt-fast 已经在运行了" "warning"
|
||||||
msg "Verify that all apt-fast processes are finished then remove $LCK_FILE.lock and try again." "hint"
|
msg "Verify that all apt-fast processes are finished then remove $LCK_FILE.lock and try again." "hint"
|
||||||
|
msg "请确认所有的apt-fast进程已经结束,然后删除 $LCK_FILE.lock 后重试." "hint"
|
||||||
}
|
}
|
||||||
|
|
||||||
# Check if a lock file exists.
|
# Check if a lock file exists.
|
||||||
@@ -246,6 +249,7 @@ cleanup_dllist()
|
|||||||
if ! rm -f -- "$DLLIST" 2>/dev/null
|
if ! rm -f -- "$DLLIST" 2>/dev/null
|
||||||
then
|
then
|
||||||
msg "Could not clean up download list file." "warning"
|
msg "Could not clean up download list file." "warning"
|
||||||
|
msg "无法清除下载列表文件." "warning"
|
||||||
CLEANUP_STATE=1
|
CLEANUP_STATE=1
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
@@ -304,12 +308,14 @@ get_uris(){
|
|||||||
if ! mkdir -p -- "$(dirname "$DLLIST")"
|
if ! mkdir -p -- "$(dirname "$DLLIST")"
|
||||||
then
|
then
|
||||||
msg "Could not create download file directory." "warning"
|
msg "Could not create download file directory." "warning"
|
||||||
|
msg "无法创建下载文件夹" "warning"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
elif [ -f "$DLLIST" ]; then
|
elif [ -f "$DLLIST" ]; then
|
||||||
if ! rm -f -- "$DLLIST" 2>/dev/null && ! touch -- "$DLLIST" 2>/dev/null
|
if ! rm -f -- "$DLLIST" 2>/dev/null && ! touch -- "$DLLIST" 2>/dev/null
|
||||||
then
|
then
|
||||||
msg "Unable to write to download file. Try restarting with root permissions or run 'apt-fast clean' first." "warning"
|
msg "Unable to write to download file. Try restarting with root permissions or run 'aptss clean' first." "warning"
|
||||||
|
msg "无法下载文件。尝试使用root权限,或者运行 'aptss clean'" "warning"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
@@ -318,15 +324,19 @@ get_uris(){
|
|||||||
echo "# apt-fast mirror list: $(date)" > "$DLLIST"
|
echo "# apt-fast mirror list: $(date)" > "$DLLIST"
|
||||||
#NOTE: aptitude doesn't have this functionality, so we use apt-get to get
|
#NOTE: aptitude doesn't have this functionality, so we use apt-get to get
|
||||||
# package URIs.
|
# package URIs.
|
||||||
case "$_APTMGR" in
|
# case "$_APTMGR" in
|
||||||
apt|apt-get) uri_mgr=$_APTMGR;;
|
# apt|apt-get) uri_mgr=$_APTMGR;;
|
||||||
*) uri_mgr=apt-get;;
|
# *) uri_mgr=apt-get;;
|
||||||
esac
|
# esac
|
||||||
|
# NOTE:apt可能出现变动,不建议在脚本中使用,因此在此统一改用apt-get
|
||||||
|
uri_mgr=apt-get
|
||||||
uris_full="$("$uri_mgr" "${APT_SCRIPT_WARNING[@]}" -y --print-uris "$@")"
|
uris_full="$("$uri_mgr" "${APT_SCRIPT_WARNING[@]}" -y --print-uris "$@")"
|
||||||
uris_full_ret="$?"
|
uris_full_ret="$?"
|
||||||
if [ "$uris_full_ret" -ne 0 ]
|
if [ "$uris_full_ret" -ne 0 ]
|
||||||
then
|
then
|
||||||
msg "Package manager quit with exit code." "warning"
|
msg "Package manager quit with exit code.Here is the log" "warning"
|
||||||
|
msg "包管理器以错误代码退出.日志如下" "warning"
|
||||||
|
msg "${uris_full}"
|
||||||
exit "$uris_full_ret"
|
exit "$uris_full_ret"
|
||||||
fi
|
fi
|
||||||
while read -r pkg_uri_info
|
while read -r pkg_uri_info
|
||||||
@@ -396,6 +406,7 @@ get_uris(){
|
|||||||
checksum="$(echo "$patch_checksum" | cut -d' ' -f2)"
|
checksum="$(echo "$patch_checksum" | cut -d' ' -f2)"
|
||||||
else
|
else
|
||||||
msg "Couldn't get supported checksum for $pkg_name ($pkg_version)." "warning"
|
msg "Couldn't get supported checksum for $pkg_name ($pkg_version)." "warning"
|
||||||
|
msg "无法获得 $pkg_name ($pkg_version) 的受支持的散列验证值" "warning"
|
||||||
REMOVE_WORKING_MESSAGE=
|
REMOVE_WORKING_MESSAGE=
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
@@ -434,6 +445,7 @@ display_downloadfile(){
|
|||||||
done <<<"$(echo -e "$DOWNLOAD_DISPLAY" | sort "${DISPLAY_SORT_OPTIONS[@]}")"
|
done <<<"$(echo -e "$DOWNLOAD_DISPLAY" | sort "${DISPLAY_SORT_OPTIONS[@]}")"
|
||||||
fi
|
fi
|
||||||
msg "Download size: $(echo "$DOWNLOAD_SIZE" | numfmt --to=iec-i --suffix=B)" "normal"
|
msg "Download size: $(echo "$DOWNLOAD_SIZE" | numfmt --to=iec-i --suffix=B)" "normal"
|
||||||
|
msg "下载大小: $(echo "$DOWNLOAD_SIZE" | numfmt --to=iec-i --suffix=B)" "normal"
|
||||||
}
|
}
|
||||||
|
|
||||||
# Create and insert a PID number to lockfile.
|
# Create and insert a PID number to lockfile.
|
||||||
@@ -477,6 +489,7 @@ if [ "$CMD" == "aria2c" ]; then
|
|||||||
done
|
done
|
||||||
if [ -z "$HASH_SUPPORTED" ]; then
|
if [ -z "$HASH_SUPPORTED" ]; then
|
||||||
msg "Couldn't find supported checksum algorithm from aria2c. Checksums disabled." "warning"
|
msg "Couldn't find supported checksum algorithm from aria2c. Checksums disabled." "warning"
|
||||||
|
msg "无法找到aria2c支持的散列验证算法. 散列验证已被禁用." "warning"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -531,6 +544,7 @@ fi
|
|||||||
if [ "$option" == "install" ]; then
|
if [ "$option" == "install" ]; then
|
||||||
msg
|
msg
|
||||||
msg "Working... this may take a while." "normal"
|
msg "Working... this may take a while." "normal"
|
||||||
|
msg "正在工作中,请稍等" "normal"
|
||||||
REMOVE_WORKING_MESSAGE=y
|
REMOVE_WORKING_MESSAGE=y
|
||||||
|
|
||||||
get_uris "$@"
|
get_uris "$@"
|
||||||
@@ -598,6 +612,7 @@ elif [ "$option" == "clean" ]; then
|
|||||||
elif [ "$option" == "download" ]; then
|
elif [ "$option" == "download" ]; then
|
||||||
msg
|
msg
|
||||||
msg "Working... this may take a while." "normal"
|
msg "Working... this may take a while." "normal"
|
||||||
|
msg "正在工作中,请稍等" "normal"
|
||||||
REMOVE_WORKING_MESSAGE=y
|
REMOVE_WORKING_MESSAGE=y
|
||||||
|
|
||||||
get_uris "$@"
|
get_uris "$@"
|
||||||
@@ -616,6 +631,7 @@ elif [ "$option" == "download" ]; then
|
|||||||
elif [ "$option" == "source" ]; then
|
elif [ "$option" == "source" ]; then
|
||||||
msg
|
msg
|
||||||
msg "Working... this may take a while." "normal"
|
msg "Working... this may take a while." "normal"
|
||||||
|
msg "正在工作中,请稍等" "normal"
|
||||||
REMOVE_WORKING_MESSAGE=y
|
REMOVE_WORKING_MESSAGE=y
|
||||||
|
|
||||||
get_uris "$@"
|
get_uris "$@"
|
||||||
|
|||||||
45
tool/aptss
45
tool/aptss
@@ -1,6 +1,6 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
SS_APT_FAST="/opt/durapps/spark-store/bin/apt-fast/ss-apt-fast"
|
||||||
|
|
||||||
if [ ! -e "/tmp/aptss-conf/apt-fast.conf" ];then
|
if [ ! -e "/tmp/aptss-conf/apt-fast.conf" ];then
|
||||||
###刷新apt-fast配置
|
###刷新apt-fast配置
|
||||||
@@ -8,43 +8,60 @@ mkdir -p /tmp/aptss-conf/
|
|||||||
echo "从服务器获取配置和镜像列表..."
|
echo "从服务器获取配置和镜像列表..."
|
||||||
echo "Getting server and mirror lists..."
|
echo "Getting server and mirror lists..."
|
||||||
echo
|
echo
|
||||||
curl --progress-bar -o /tmp/aptss-conf/apt-fast.conf "https://gitee.com/deepin-community-store/repo_auto_update_script/raw/master/mirror-list-for-apt-fast/apt-fast.conf"
|
curl --progress-bar -o /tmp/aptss-conf/apt-fast.conf "https://d.store.deepinos.org.cn/apt-fast.conf"
|
||||||
chmod -R 755 /tmp/aptss-conf
|
chmod -R 755 /tmp/aptss-conf
|
||||||
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
if [ ! -e "/var/lib/apt/lists/d.store.deepinos.org.cn_Packages" ] && [ ! -e "/var/lib/apt/lists/d.store.deepinos.org.cn_store_Packages" ];then
|
||||||
|
echo "接收星火仓库软件信息中..."
|
||||||
|
|
||||||
|
mkdir -p /tmp/aptss-conf/
|
||||||
|
echo "从服务器获取配置和镜像列表..."
|
||||||
|
echo "Getting server and mirror lists..."
|
||||||
|
echo
|
||||||
|
curl --silent -o /tmp/aptss-conf/apt-fast.conf "https://d.store.deepinos.org.cn/apt-fast.conf"
|
||||||
|
chmod -R 755 /tmp/aptss-conf
|
||||||
|
|
||||||
|
sudo curl --silent -o /opt/durapps/spark-store/bin/apt-fast-conf/sources.list.d/sparkstore.list "https://d.store.deepinos.org.cn/sparkstore.list"
|
||||||
|
sudo bwrap --dev-bind / / --bind '/opt/durapps/spark-store/bin/apt-fast-conf/sources.list.d/sparkstore.list' /etc/apt/sources.list.d/sparkstore.list apt update -o Dir::Etc::sourcelist="sources.list.d/sparkstore.list" -o Dir::Etc::sourceparts="-" -o APT::Get::List-Cleanup="0"
|
||||||
|
|
||||||
|
#只更新星火源
|
||||||
|
|
||||||
|
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if [ "$1" = "install" ] || [ "$1" = "upgrade" ] || [ "$1" = "full-upgrade" ] ; then
|
if [ "$1" = "install" ] || [ "$1" = "upgrade" ] || [ "$1" = "full-upgrade" ] ; then
|
||||||
|
|
||||||
|
|
||||||
sudo bwrap --dev-bind / / --bind '/opt/durapps/spark-store/bin/apt-fast-conf/sources.list.d/sparkstore.list' /etc/apt/sources.list.d/sparkstore.list apt update -o Dir::Etc::sourcelist="sources.list.d/sparkstore.list" -o Dir::etc::sourceparts="-" -o APT::Get::List-Cleanup="0"
|
|
||||||
|
|
||||||
###执行
|
###执行
|
||||||
bwrap --dev-bind / / \
|
bwrap --dev-bind / / \
|
||||||
--bind '/tmp/aptss-conf/apt-fast.conf' /etc/apt-fast.conf \
|
|
||||||
--bind '/opt/durapps/spark-store/bin/apt-fast-conf/sources.list.d/sparkstore.list' /etc/apt/sources.list.d/sparkstore.list \
|
--bind '/opt/durapps/spark-store/bin/apt-fast-conf/sources.list.d/sparkstore.list' /etc/apt/sources.list.d/sparkstore.list \
|
||||||
/opt/durapps/spark-store/bin/apt-fast/ss-apt-fast "$@" --allow-downgrades
|
${SS_APT_FAST} "$@" --allow-downgrades
|
||||||
|
|
||||||
|
|
||||||
elif [ "$1" = "download" ];then
|
elif [ "$1" = "download" ];then
|
||||||
|
|
||||||
###执行
|
###执行
|
||||||
bwrap --dev-bind / / \
|
bwrap --dev-bind / / \
|
||||||
--bind '/tmp/aptss-conf/apt-fast.conf' /etc/apt-fast.conf \
|
|
||||||
--bind '/opt/durapps/spark-store/bin/apt-fast-conf/sources.list.d/sparkstore.list' /etc/apt/sources.list.d/sparkstore.list \
|
--bind '/opt/durapps/spark-store/bin/apt-fast-conf/sources.list.d/sparkstore.list' /etc/apt/sources.list.d/sparkstore.list \
|
||||||
/opt/durapps/spark-store/bin/apt-fast/ss-apt-fast "$@" --allow-downgrades
|
${SS_APT_FAST} "$@" --allow-downgrades
|
||||||
|
|
||||||
|
|
||||||
elif [ "$1" = "policy" ] || [ "$1" = "search" ];then
|
elif [ "$1" = "policy" ] || [ "$1" = "search" ];then
|
||||||
sudo bwrap --dev-bind / / --bind '/opt/durapps/spark-store/bin/apt-fast-conf/sources.list.d/sparkstore.list' /etc/apt/sources.list.d/sparkstore.list apt update -o Dir::Etc::sourcelist="sources.list.d/sparkstore.list" -o Dir::etc::sourceparts="-" -o APT::Get::List-Cleanup="0"
|
|
||||||
|
|
||||||
|
|
||||||
###执行
|
###执行
|
||||||
bwrap --dev-bind / / \
|
bwrap --dev-bind / / \
|
||||||
--bind '/tmp/aptss-conf/apt-fast.conf' /etc/apt-fast.conf \
|
|
||||||
--bind '/opt/durapps/spark-store/bin/apt-fast-conf/sources.list.d/sparkstore.list' /etc/apt/sources.list.d/sparkstore.list \
|
--bind '/opt/durapps/spark-store/bin/apt-fast-conf/sources.list.d/sparkstore.list' /etc/apt/sources.list.d/sparkstore.list \
|
||||||
apt "$@" --allow-downgrades
|
apt "$@"
|
||||||
|
|
||||||
elif [ "$1" = "ssupdate" ];then
|
elif [ "$1" = "ssupdate" ];then
|
||||||
|
|
||||||
@@ -52,23 +69,23 @@ mkdir -p /tmp/aptss-conf/
|
|||||||
echo "从服务器获取配置和镜像列表..."
|
echo "从服务器获取配置和镜像列表..."
|
||||||
echo "Getting server and mirror lists..."
|
echo "Getting server and mirror lists..."
|
||||||
echo
|
echo
|
||||||
curl --silent -o /tmp/aptss-conf/apt-fast.conf "https://gitee.com/deepin-community-store/repo_auto_update_script/raw/master/mirror-list-for-apt-fast/apt-fast.conf"
|
curl --silent -o /tmp/aptss-conf/apt-fast.conf "https://d.store.deepinos.org.cn/apt-fast.conf"
|
||||||
chmod -R 755 /tmp/aptss-conf
|
chmod -R 755 /tmp/aptss-conf
|
||||||
|
|
||||||
sudo curl --silent -o /opt/durapps/spark-store/bin/apt-fast-conf/sources.list.d/sparkstore.list "https://gitee.com/deepin-community-store/repo_auto_update_script/raw/master/mirror-list-for-apt-fast/sources.list.d/sparkstore.list"
|
sudo curl --silent -o /opt/durapps/spark-store/bin/apt-fast-conf/sources.list.d/sparkstore.list "https://d.store.deepinos.org.cn/sparkstore.list"
|
||||||
sudo bwrap --dev-bind / / --bind '/opt/durapps/spark-store/bin/apt-fast-conf/sources.list.d/sparkstore.list' /etc/apt/sources.list.d/sparkstore.list apt update -o Dir::Etc::sourcelist="sources.list.d/sparkstore.list" -o Dir::Etc::sourceparts="-" -o APT::Get::List-Cleanup="0"
|
sudo bwrap --dev-bind / / --bind '/opt/durapps/spark-store/bin/apt-fast-conf/sources.list.d/sparkstore.list' /etc/apt/sources.list.d/sparkstore.list apt update -o Dir::Etc::sourcelist="sources.list.d/sparkstore.list" -o Dir::Etc::sourceparts="-" -o APT::Get::List-Cleanup="0"
|
||||||
|
|
||||||
#只更新星火源
|
#只更新星火源
|
||||||
|
|
||||||
elif [ "$1" = "update" ];then
|
elif [ "$1" = "update" ];then
|
||||||
sudo curl --progress-bar -o /opt/durapps/spark-store/bin/apt-fast-conf/sources.list.d/sparkstore.list "https://gitee.com/deepin-community-store/repo_auto_update_script/raw/master/mirror-list-for-apt-fast/sources.list.d/sparkstore.list"
|
sudo curl --progress-bar -o /opt/durapps/spark-store/bin/apt-fast-conf/sources.list.d/sparkstore.list "https://d.store.deepinos.org.cn/sparkstore.list"
|
||||||
|
|
||||||
|
|
||||||
mkdir -p /tmp/aptss-conf/
|
mkdir -p /tmp/aptss-conf/
|
||||||
echo "从服务器获取配置和镜像列表..."
|
echo "从服务器获取配置和镜像列表..."
|
||||||
echo "Getting server and mirror lists..."
|
echo "Getting server and mirror lists..."
|
||||||
echo
|
echo
|
||||||
curl --progress-bar -o /tmp/aptss-conf/apt-fast.conf "https://gitee.com/deepin-community-store/repo_auto_update_script/raw/master/mirror-list-for-apt-fast/apt-fast.conf"
|
curl --progress-bar -o /tmp/aptss-conf/apt-fast.conf "https://d.store.deepinos.org.cn/apt-fast.conf"
|
||||||
chmod -R 755 /tmp/aptss-conf
|
chmod -R 755 /tmp/aptss-conf
|
||||||
### 额外一份拿来给aptss自动补全用
|
### 额外一份拿来给aptss自动补全用
|
||||||
bwrap --dev-bind / / \
|
bwrap --dev-bind / / \
|
||||||
|
|||||||
31
tool/bashimport/transhell.amber
Executable file
31
tool/bashimport/transhell.amber
Executable file
@@ -0,0 +1,31 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
##load transhell
|
||||||
|
function load_transhell_debug()
|
||||||
|
{
|
||||||
|
local WORK_PATH="$(cd "$(dirname "${0}")" && pwd)"
|
||||||
|
local CURRENT_LANG="$(echo ${LANG%.*})"
|
||||||
|
if [ -e "/usr/share/$(basename $0)/transhell/$(basename $0)_en_US.transhell" ]; then source /usr/share/$(basename $0)/transhell/$(basename $0)_en_US.transhell; echo "Loading transhell from /usr/share/$(basename $0)/transhell/$(basename $0)_en_US.transhell ..."; fi
|
||||||
|
if [ -e "/usr/share/$(basename $0)/transhell/$(basename $0)_$CURRENT_LANG.transhell" ]; then source /usr/share/$(basename $0)/transhell/$(basename $0)_$CURRENT_LANG.transhell; echo "Loading transhell from /usr/share/$(basename $0)/transhell/$(basename $0)_$CURRENT_LANG.transhell ..."; fi
|
||||||
|
if [ -e "${WORK_PATH}/transhell/$(basename $0)_en_US.transhell" ]; then source ${WORK_PATH}/transhell/$(basename $0)_en_US.transhell; echo "Loading transhell from ${WORK_PATH}/transhell/$(basename $0)_en_US.transhell ..."; fi
|
||||||
|
if [ -e "${WORK_PATH}/transhell/$(basename $0)_$CURRENT_LANG.transhell" ]; then source ${WORK_PATH}/transhell/$(basename $0)_$CURRENT_LANG.transhell; echo "Loading transhell from ${WORK_PATH}/transhell/$(basename $0)_$CURRENT_LANG.transhell ..."; fi
|
||||||
|
|
||||||
|
echo "-----------------------------------------------------------------------------"
|
||||||
|
}
|
||||||
|
|
||||||
|
function load_transhell()
|
||||||
|
{
|
||||||
|
local WORK_PATH="$(cd "$(dirname "${0}")" && pwd)"
|
||||||
|
local CURRENT_LANG="$(echo ${LANG%.*})"
|
||||||
|
if [ -e "/usr/share/$(basename $0)/transhell/$(basename $0)_en_US.transhell" ]; then source /usr/share/$(basename $0)/transhell/$(basename $0)_en_US.transhell; fi
|
||||||
|
if [ -e "/usr/share/$(basename $0)/transhell/$(basename $0)_$CURRENT_LANG.transhell" ]; then source /usr/share/$(basename $0)/transhell/$(basename $0)_$CURRENT_LANG.transhell; fi
|
||||||
|
if [ -e "${WORK_PATH}/transhell/$(basename $0)_en_US.transhell" ]; then source ${WORK_PATH}/transhell/$(basename $0)_en_US.transhell; fi
|
||||||
|
if [ -e "${WORK_PATH}/transhell/$(basename $0)_$CURRENT_LANG.transhell" ]; then source ${WORK_PATH}/transhell/$(basename $0)_$CURRENT_LANG.transhell; fi
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
function update_transhell()
|
||||||
|
{
|
||||||
|
load_transhell $@
|
||||||
|
}
|
||||||
|
|
||||||
44
tool/ssaudit
Executable file
44
tool/ssaudit
Executable file
@@ -0,0 +1,44 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
echo "Spark Store Audit script.星火商店审核脚本"
|
||||||
|
|
||||||
|
|
||||||
|
#################检测文件是否存在
|
||||||
|
if [ $# -eq 0 ];then
|
||||||
|
echo "没有接收到参数,退出"
|
||||||
|
echo "用法:$0 deb路径"
|
||||||
|
exit
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ ! -f "$1" ]
|
||||||
|
then
|
||||||
|
echo "文件不存在"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$(id -u)" != "0" ];then
|
||||||
|
#############################无root权限时
|
||||||
|
echo "请使用root启动ssaudit"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
###
|
||||||
|
|
||||||
|
|
||||||
|
DEBPATH=`realpath $1`
|
||||||
|
|
||||||
|
echo ----------------------------------------------------------------------------------
|
||||||
|
try_run_output=$(aptss --dry-run install $DEBPATH)
|
||||||
|
try_run_ret="$?"
|
||||||
|
|
||||||
|
if [ "$try_run_ret" -ne 0 ]
|
||||||
|
then
|
||||||
|
echo "Package manager quit with exit code.Here is the log"
|
||||||
|
echo "包管理器以错误代码退出.日志如下"
|
||||||
|
echo
|
||||||
|
echo -e "${try_run_output}"
|
||||||
|
exit "$try_run_ret"
|
||||||
|
fi
|
||||||
|
dpkg -i "$DEBPATH" || aptss install -yf
|
||||||
|
|
||||||
|
|
||||||
@@ -1,33 +1,35 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
source /opt/durapps/spark-store/bin/bashimport/transhell.amber
|
||||||
|
load_transhell_debug
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
echo "Spark Store Install script.星火商店安装脚本"
|
echo "Spark Store Install script.星火商店安装脚本"
|
||||||
|
|
||||||
function pkexec_as_current_user() {
|
function pkexec_as_current_user() {
|
||||||
#Detect the name of the display in use
|
|
||||||
local display=":$(ls /tmp/.X11-unix/* | sed 's#/tmp/.X11-unix/X##' | head -n 1)"
|
|
||||||
|
|
||||||
#Detect the user using such display
|
|
||||||
local user=$(who | grep '('$display')' | awk '{print $1}' | head -n 1)
|
|
||||||
|
|
||||||
#Detect the id of the user
|
#Detect the id of the user
|
||||||
local uid=$(id -u $user)
|
local uid=$(id -u $user)
|
||||||
|
|
||||||
sudo -u $user DISPLAY=$display DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/$uid/bus pkexec "$@"
|
sudo -u $user DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/$uid/bus pkexec "$@"
|
||||||
}
|
}
|
||||||
|
|
||||||
function zenity() {
|
function zenity()
|
||||||
#Detect the name of the display in use
|
{
|
||||||
local display=":$(ls /tmp/.X11-unix/* | sed 's#/tmp/.X11-unix/X##' | head -n 1)"
|
|
||||||
|
|
||||||
#Detect the user using such display
|
#Detect the user using such display
|
||||||
local user=$(who | grep '('$display')' | awk '{print $1}' | head -n 1)
|
local user=$(who | awk '{print $1}' | head -n 1)
|
||||||
|
|
||||||
#Detect the id of the user
|
#Detect the id of the user
|
||||||
local uid=$(id -u $user)
|
local uid=$(id -u $user)
|
||||||
|
|
||||||
sudo -u $user DISPLAY=$display DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/$uid/bus zenity "$@"
|
|
||||||
}
|
|
||||||
|
|
||||||
|
sudo -u $user DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/$uid/bus zenity "$@"
|
||||||
|
}
|
||||||
#################检测文件是否存在
|
#################检测文件是否存在
|
||||||
if [ $# -eq 0 ];then
|
if [ $# -eq 0 ];then
|
||||||
echo "没有接收到参数,退出"
|
echo "没有接收到参数,退出"
|
||||||
@@ -37,13 +39,13 @@ fi
|
|||||||
|
|
||||||
if [ ! -f "$1" ]
|
if [ ! -f "$1" ]
|
||||||
then
|
then
|
||||||
echo "文件不存在"
|
echo "${TRANSHELL_CONTENT_FILE_NOT_EXIST}"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$(id -u)" != "0" ];then
|
if [ "$(id -u)" != "0" ];then
|
||||||
#############################无root权限时
|
#############################无root权限时
|
||||||
echo "请使用root启动ssinstall"
|
echo "${TRANSHELL_CONTENT_PLEASE_RUN_AS_ROOT}"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -52,32 +54,56 @@ fi
|
|||||||
|
|
||||||
DEBPATH=`realpath $1`
|
DEBPATH=`realpath $1`
|
||||||
|
|
||||||
if [ ! -e "/var/lib/apt/lists/d.store.deepinos.org.cn_Packages" ];then
|
if [ ! -e "/var/lib/apt/lists/d.store.deepinos.org.cn_Packages" ] && [ ! -e "/var/lib/apt/lists/d.store.deepinos.org.cn_store_Packages" ] && [ ! -e "/var/lib/apt/lists/mirrors.sdu.edu.cn_spark-store-repository_store_Packages" ];then
|
||||||
echo "接收星火仓库软件信息中..."
|
echo "接收星火仓库软件信息中..."
|
||||||
aptss ssupdate
|
aptss ssupdate
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
### 选择包信息位置
|
||||||
|
|
||||||
|
if [ -e "/var/lib/apt/lists/d.store.deepinos.org.cn_store_Packages" ];then
|
||||||
|
PACKAGES_DATA_PATH="/var/lib/apt/lists/d.store.deepinos.org.cn_store_Packages"
|
||||||
|
echo "星火仓库的Packages位置为 $PACKAGES_DATA_PATH,是单目录仓库配置"
|
||||||
|
elif [ -e "/var/lib/apt/lists/d.store.deepinos.org.cn_Packages" ]
|
||||||
|
PACKAGES_DATA_PATH="/var/lib/apt/lists/d.store.deepinos.org.cn_Packages"
|
||||||
|
echo "星火仓库的Packages位置为 $PACKAGES_DATA_PATH,是根目录仓库配置"
|
||||||
|
else
|
||||||
|
PACKAGES_DATA_PATH="/var/lib/apt/lists/mirrors.sdu.edu.cn_spark-store-repository_store_Packages"
|
||||||
|
echo "星火仓库的Packages位置为 $PACKAGES_DATA_PATH,是SDU镜像仓库配置"
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
echo "正在计算hash并与星火仓库匹配..."
|
echo "正在计算hash并与星火仓库匹配..."
|
||||||
|
|
||||||
DEB_MD5SUM=`md5sum "$DEBPATH" | cut -c -32`
|
DEB_MD5SUM=`md5sum "$DEBPATH" | cut -c -32`
|
||||||
|
|
||||||
IS_MD5SUM_CHECKD=`cat /var/lib/apt/lists/d.store.deepinos.org.cn_Packages | grep $DEB_MD5SUM`
|
IS_MD5SUM_CHECKD=`cat $PACKAGES_DATA_PATH | grep $DEB_MD5SUM`
|
||||||
if [ ! -z "$IS_MD5SUM_CHECKD" ];then
|
if [ ! -z "$IS_MD5SUM_CHECKD" ];then
|
||||||
|
|
||||||
echo "校验成功,开始安装"
|
echo "校验成功,开始安装"
|
||||||
echo ----------------------------------------------------------------------------------
|
echo ----------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
try_run_output=$(aptss --dry-run install $DEBPATH)
|
||||||
|
try_run_ret="$?"
|
||||||
|
|
||||||
|
if [ "$try_run_ret" -ne 0 ]
|
||||||
|
then
|
||||||
|
echo "Package manager quit with exit code.Here is the log"
|
||||||
|
echo "包管理器以错误代码退出.日志如下"
|
||||||
|
echo
|
||||||
|
echo -e "${try_run_output}"
|
||||||
|
exit "$try_run_ret"
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
dpkg -i "$DEBPATH" || aptss install -yf
|
dpkg -i "$DEBPATH" || aptss install -yf
|
||||||
|
|
||||||
else
|
else
|
||||||
|
|
||||||
|
|
||||||
zenity --info --icon-name=spark-store --height 270 --width 500 --text "软件包校验失败!这不应该发生!\n可能是因为软件包已损坏,星火仓库未同步,或者最坏的情况:恶意软件尝试利用自动安装来入侵系统!\n如果你不清楚发生了什么,请在接下来的认证窗口中选择取消认证\n执行 sudo aptss ssupdate 后再尝试安装。\n如果问题仍然存在,请在应用信息界面点击 应用反馈 来提交反馈给我们!\n\n如果你是审核人员,这是正常现象,在审核通过前星火仓库不会保存相关信息。请在接下来的弹窗中进行认证即可"
|
zenity --info --icon-name=spark-store --height 270 --width 500 --text "${TRANSHELL_CONTENT_HASH_CHECK_FAILED}"
|
||||||
|
|
||||||
echo "软件包校验失败!这不应该发生!"
|
echo -e ${TRANSHELL_CONTENT_HASH_CHECK_FAILED}
|
||||||
echo "执行 sudo aptss ssupdate 后再尝试安装。"
|
|
||||||
echo "如果问题仍然存在,请在应用信息界面点击 应用反馈 来提交反馈给我们!"
|
|
||||||
echo "如果你是审核人员,这是正常现象,在审核通过前星火仓库不会保存相关信息。请在接下来的弹窗中进行认证即可"
|
|
||||||
|
|
||||||
pkexec_as_current_user bash -c "dpkg -i "$DEBPATH" || aptss install -yf "
|
|
||||||
|
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -32,6 +32,21 @@ case $1 in
|
|||||||
IS_UPGRADE_ERROR=`cat /tmp/spark-store-app-upgrade-log.txt | grep "Package manager quit with exit code."`
|
IS_UPGRADE_ERROR=`cat /tmp/spark-store-app-upgrade-log.txt | grep "Package manager quit with exit code."`
|
||||||
echo "$IS_UPGRADE_ERROR" > /tmp/spark-store-app-upgrade-status.txt
|
echo "$IS_UPGRADE_ERROR" > /tmp/spark-store-app-upgrade-status.txt
|
||||||
;;
|
;;
|
||||||
|
test-install-app)
|
||||||
|
try_run_output=$(aptss --dry-run install $2)
|
||||||
|
try_run_ret="$?"
|
||||||
|
|
||||||
|
if [ "$try_run_ret" -ne 0 ]
|
||||||
|
then
|
||||||
|
echo "Package manager quit with exit code.Here is the log"
|
||||||
|
echo "包管理器以错误代码退出.日志如下"
|
||||||
|
echo
|
||||||
|
echo -e "${try_run_output}"
|
||||||
|
exit "$try_run_ret"
|
||||||
|
fi
|
||||||
|
|
||||||
|
exit 0
|
||||||
|
;;
|
||||||
|
|
||||||
clean-log)
|
clean-log)
|
||||||
rm -f /tmp/spark-store-app-ssupdate-status.txt /tmp/spark-store-app-ssupdate-log.txt /tmp/spark-store-app-upgrade-log.txt /tmp/spark-store-app-upgrade-status.txt
|
rm -f /tmp/spark-store-app-ssupdate-status.txt /tmp/spark-store-app-ssupdate-log.txt /tmp/spark-store-app-upgrade-log.txt /tmp/spark-store-app-upgrade-status.txt
|
||||||
|
|||||||
@@ -1,17 +1,21 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
source /opt/durapps/spark-store/bin/bashimport/transhell.amber
|
||||||
|
load_transhell_debug
|
||||||
|
|
||||||
|
|
||||||
touch /tmp/spark-store/upgradeStatus.txt
|
touch /tmp/spark-store/upgradeStatus.txt
|
||||||
|
|
||||||
# 执行 apt update
|
# 执行 apt update
|
||||||
pkexec /opt/durapps/spark-store/bin/update-upgrade/ss-do-upgrade-worker.sh ssupdate | zenity --progress --auto-close --pulsate --no-cancel --text="正在检查更新,请稍候..." --height 70 --width 400 --title="星火商店更新模块" --window-icon=/usr/share/icons/hicolor/scalable/apps/spark-store.svg
|
pkexec /opt/durapps/spark-store/bin/update-upgrade/ss-do-upgrade-worker.sh ssupdate | zenity --progress --auto-close --pulsate --no-cancel --text="${TRANSHELL_CONTENT_UPDATE_CHEKING_PLEASE_WAIT}" --height 70 --width 400 --title="${TRANSHELL_CONTENT_SPARK_STORE_UPGRADE_MODEL}" --window-icon=/usr/share/icons/hicolor/scalable/apps/spark-store.svg
|
||||||
|
|
||||||
if [ -z `cat /tmp/spark-store-app-ssupdate-status.txt` ] ; then
|
if [ -z `cat /tmp/spark-store-app-ssupdate-status.txt` ] ; then
|
||||||
echo "无错误"
|
|
||||||
pkexec /opt/durapps/spark-store/bin/update-upgrade/ss-do-upgrade-worker.sh clean-log
|
pkexec /opt/durapps/spark-store/bin/update-upgrade/ss-do-upgrade-worker.sh clean-log
|
||||||
else
|
else
|
||||||
zenity --error --text "检查更新进程出现错误!按确定查看报错,可用于反馈" --title "星火商店更新检测模块" --height 200 --width 350 --window-icon=/usr/share/icons/hicolor/scalable/apps/spark-store.svg
|
zenity --error --text "${TRANSHELL_CONTENT_CHECK_UPDATE_PROCESS_ERROR_PRESS_CONFIRM_TO_CHECK}" --title "${TRANSHELL_CONTENT_SPARK_STORE_UPGRADE_MODEL}" --height 200 --width 350 --window-icon=/usr/share/icons/hicolor/scalable/apps/spark-store.svg
|
||||||
zenity --text-info --filename=/tmp/spark-store-app-ssupdate-log.txt --checkbox="我已复制了此文本框中的日志,且将会在反馈时附上。反馈渠道可以在右上角菜单的设置中找到" --title="反馈渠道在商店右上角的设置里" --window-icon=/usr/share/icons/hicolor/scalable/apps/spark-store.svg
|
zenity --text-info --filename=/tmp/spark-store-app-ssupdate-log.txt --checkbox="${TRANSHELL_CONTENT_I_ALREDY_COPIED_THE_LOG_HERE_AND_WILL_USE_IT_TO_FEEDBACK}" --title="${TRANSHELL_CONTENT_FEEDBACK_CAN_BE_FOUND_IN_THE_SETTINGS}" --window-icon=/usr/share/icons/hicolor/scalable/apps/spark-store.svg
|
||||||
pkexec /opt/durapps/spark-store/bin/update-upgrade/ss-do-upgrade-worker.sh clean-log
|
pkexec /opt/durapps/spark-store/bin/update-upgrade/ss-do-upgrade-worker.sh clean-log
|
||||||
|
rm -f /tmp/spark-store/upgradeStatus.txt
|
||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -19,7 +23,7 @@ fi
|
|||||||
PKG_LIST="$(pkexec /opt/durapps/spark-store/bin/update-upgrade/ss-do-upgrade-worker.sh upgradable-list)"
|
PKG_LIST="$(pkexec /opt/durapps/spark-store/bin/update-upgrade/ss-do-upgrade-worker.sh upgradable-list)"
|
||||||
## 如果没更新,就弹出不需要更新
|
## 如果没更新,就弹出不需要更新
|
||||||
if [ -z "$PKG_LIST" ] ; then
|
if [ -z "$PKG_LIST" ] ; then
|
||||||
zenity --info --text "没有软件需要更新\n但是你并没有站在世界之巅" --title "星火商店更新检测模块" --height 150 --width 300 --window-icon=/usr/share/icons/hicolor/scalable/apps/spark-store.svg
|
zenity --info --text "${TRANSHELL_CONTENT_NO_NEED_TO_UPGRADE}" --title "${TRANSHELL_CONTENT_SPARK_STORE_UPGRADE_MODEL}" --height 150 --width 300 --window-icon=/usr/share/icons/hicolor/scalable/apps/spark-store.svg
|
||||||
else
|
else
|
||||||
## 获取用户选择的要更新的应用
|
## 获取用户选择的要更新的应用
|
||||||
### 指定分隔符为 \n
|
### 指定分隔符为 \n
|
||||||
@@ -44,7 +48,7 @@ else
|
|||||||
echo "$PKG_CUR_VER"
|
echo "$PKG_CUR_VER"
|
||||||
else
|
else
|
||||||
echo "false"
|
echo "false"
|
||||||
echo "$PKG_NAME(无法更新:已被标记为保留)"
|
echo "$PKG_NAME${TRANSHELL_CONTENT_CAN_NOT_UPGRADE_FOR_BEING_HOLD}"
|
||||||
echo "$PKG_NEW_VER"
|
echo "$PKG_NEW_VER"
|
||||||
echo "$PKG_CUR_VER"
|
echo "$PKG_CUR_VER"
|
||||||
fi
|
fi
|
||||||
@@ -55,27 +59,29 @@ done`
|
|||||||
|
|
||||||
## 如果没有应用需要更新,则直接退出
|
## 如果没有应用需要更新,则直接退出
|
||||||
if [ -z "$PKG_UPGRADE_LIST" ] ; then
|
if [ -z "$PKG_UPGRADE_LIST" ] ; then
|
||||||
zenity --info --text "没有软件需要更新\n但是你并没有站在世界之巅" --title "星火商店更新检测服务" --height 150 --width 300 --window-icon=/usr/share/icons/hicolor/scalable/apps/spark-store.svg
|
zenity --info --text "${TRANSHELL_CONTENT_NO_NEED_TO_UPGRADE}" --title "${TRANSHELL_CONTENT_SPARK_STORE_UPGRADE_MODEL}" --height 150 --width 300 --window-icon=/usr/share/icons/hicolor/scalable/apps/spark-store.svg
|
||||||
else
|
else
|
||||||
PKG_UPGRADE_LIST=$(echo "$PKG_UPGRADE_LIST" | zenity --list --text="选择你想更新的应用" --column="是否更新" --column="包名" --column="新版本" --column="从该版本更新" --separator=" " --checklist --multiple --print-column=2 --height 350 --width 550 --window-icon=/usr/share/icons/hicolor/scalable/apps/spark-store.svg)
|
PKG_UPGRADE_LIST=$(echo "$PKG_UPGRADE_LIST" | zenity --list --text="${TRANSHELL_CONTENT_CHOOSE_APP_TO_UPGRADE}" --column="${TRANSHELL_CONTENT_CHOOSE}" --column="${TRANSHELL_CONTENT_PKG_NAME}" --column="${TRANSHELL_CONTENT_NEW_VERSION}" --column="${TRANSHELL_CONTENT_UPGRADE_FROM}" --separator=" " --checklist --multiple --print-column=2 --height 350 --width 550 --window-icon=/usr/share/icons/hicolor/scalable/apps/spark-store.svg)
|
||||||
## 如果没有选择,则直接退出
|
## 如果没有选择,则直接退出
|
||||||
if [ -z "$PKG_UPGRADE_LIST" ] ; then
|
if [ -z "$PKG_UPGRADE_LIST" ] ; then
|
||||||
zenity --info --text "没有选中任何软件\n但是你并没有站在世界之巅" --title "星火商店更新检测服务" --height 150 --width 300 --window-icon=/usr/share/icons/hicolor/scalable/apps/spark-store.svg
|
zenity --info --text "${TRANSHELL_CONTENT_NO_APP_IS_CHOSEN}" --title "${TRANSHELL_CONTENT_SPARK_STORE_UPGRADE_MODEL}" --height 150 --width 300 --window-icon=/usr/share/icons/hicolor/scalable/apps/spark-store.svg
|
||||||
else
|
else
|
||||||
### 更新用户选择的应用
|
### 更新用户选择的应用
|
||||||
pkexec /opt/durapps/spark-store/bin/update-upgrade/ss-do-upgrade-worker.sh upgrade-app $PKG_UPGRADE_LIST -y | zenity --progress --auto-close --no-cancel --pulsate --text="正在更新已选中的应用,请稍候..." --height 70 --width 400 --title="星火商店更新模块" --window-icon=/usr/share/icons/hicolor/scalable/apps/spark-store.svg
|
for PKG_UPGRADE in $PKG_UPGRADE_LIST;do
|
||||||
|
update_transhell
|
||||||
|
pkexec /opt/durapps/spark-store/bin/update-upgrade/ss-do-upgrade-worker.sh upgrade-app $PKG_UPGRADE -y | zenity --progress --auto-close --no-cancel --pulsate --text="${TRANSHELL_CONTENT_UPGRADING_PLEASE_WAIT}" --height 70 --width 400 --title="${TRANSHELL_CONTENT_SPARK_STORE_UPGRADE_MODEL}" --window-icon=/usr/share/icons/hicolor/scalable/apps/spark-store.svg
|
||||||
|
done
|
||||||
#### 更新成功
|
#### 更新成功
|
||||||
if [ -z "`cat /tmp/spark-store-app-upgrade-status.txt`" ] ; then
|
if [ -z "`cat /tmp/spark-store-app-upgrade-status.txt`" ] ; then
|
||||||
zenity --info --text "选中的软件已经更新完毕" --title "星火商店更新检测模块" --height 150 --width 300 --window-icon=/usr/share/icons/hicolor/scalable/apps/spark-store.svg
|
zenity --info --text "${TRANSHELL_CONTENT_CHOSEN_APP_UPGRADE_FINISHED}" --title "${TRANSHELL_CONTENT_SPARK_STORE_UPGRADE_MODEL}" --height 150 --width 300 --window-icon=/usr/share/icons/hicolor/scalable/apps/spark-store.svg
|
||||||
else
|
else
|
||||||
#### 更新异常
|
#### 更新异常
|
||||||
zenity --error --text "更新出现错误!按确定查看报错,可用于反馈" --title "星火商店更新检测模块" --height 200 --width 350 --window-icon=/usr/share/icons/hicolor/scalable/apps/spark-store.svg
|
zenity --error --text "${TRANSHELL_CONTENT_APP_UGRADE_PROCESS_ERROR_PRESS_CONFIRM_TO_CHECK}" --title "${TRANSHELL_CONTENT_SPARK_STORE_UPGRADE_MODEL}" --height 200 --width 350 --window-icon=/usr/share/icons/hicolor/scalable/apps/spark-store.svg
|
||||||
zenity --text-info --filename=/tmp/spark-store-app-upgrade-log.txt --checkbox="我已复制了此文本框中的日志,且将会在反馈时附上 。反馈渠道可以在右上角菜单的设置中找到" --title="反馈渠道在商店右上角的设置里往下拉" --window-icon=/usr/share/icons/hicolor/scalable/apps/spark-store.svg
|
zenity --text-info --filename=/tmp/spark-store-app-upgrade-log.txt --checkbox="${TRANSHELL_CONTENT_I_ALREDY_COPIED_THE_LOG_HERE_AND_WILL_USE_IT_TO_FEEDBACK}" --title="${TRANSHELL_CONTENT_FEEDBACK_CAN_BE_FOUND_IN_THE_SETTINGS}" --window-icon=/usr/share/icons/hicolor/scalable/apps/spark-store.svg
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
rm -f touch /tmp/spark-store/upgradeStatus.txt
|
rm -f /tmp/spark-store/upgradeStatus.txt
|
||||||
# 从最开头
|
# 从最开头
|
||||||
|
|||||||
@@ -1,5 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
source /opt/durapps/spark-store/bin/bashimport/transhell.amber
|
||||||
|
load_transhell_debug
|
||||||
|
|
||||||
endloop=0
|
endloop=0
|
||||||
|
|
||||||
@@ -7,38 +9,35 @@ endloop=0
|
|||||||
while [ $endloop -eq 0 ] ;do
|
while [ $endloop -eq 0 ] ;do
|
||||||
|
|
||||||
if [ -e /etc/systemd/system/multi-user.target.wants/spark-update-notifier.service ];then
|
if [ -e /etc/systemd/system/multi-user.target.wants/spark-update-notifier.service ];then
|
||||||
text_update_open="关闭"
|
text_update_open="${TRANSHELL_CONTENT_CLOSE}"
|
||||||
#已经开启了就显示关闭
|
#已经开启了就显示关闭
|
||||||
else
|
else
|
||||||
text_update_open="开启"
|
text_update_open="${TRANSHELL_CONTENT_OPEN}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
update_transhell
|
||||||
|
|
||||||
|
option=`zenity --list --text="${TRANSHELL_CONTENT_WELCOME_AND_CHOOSE_ONE_TO_RUN}" --column 数字 --column=${TRANSHELL_CONTENT_OPTIONS} --print-column=2 --height 350 --width 760 0 "${TRANSHELL_CONTENT_OPEN_OR_CLOSE_UPGRADE_CHECK}" 1 "${TRANSHELL_CONTENT_CHECK_FOR_UPDATE}" 2 "${TRANSHELL_CONTENT_EXIT}" --hide-column=1 --print-column=1`
|
||||||
option=`zenity --list --text="欢迎使用星火更新和安装设置工具\n请在以下操作中选择一个进行~" --column 数字 --column=操作选项 --print-column=2 --height 350 --width 760 0 "查看自动更新相关功能使用前须知(重要)" 1 "$text_update_open星火更新检测工具(如果开启则会在系统启动后自动检测更新。如有更新则会弹出通知)" 2 查看可更新软件包列表并决定是否更新 4 退出脚本 --hide-column=1 --print-column=1`
|
|
||||||
|
|
||||||
case $option in
|
case $option in
|
||||||
0)
|
0)
|
||||||
zenity --info --icon-name=spark-store --height 450 --width 500 --text "此须知适用于自动更新功能\n\n此脚本可以检测星火源中是否有比当前系统更高版本的软件包,由您决定是否安装;在安装更新过程中请不要直接点击关闭本页面,以免发生错误\n\n此脚本使用apt update/apt list --upgrade/apt upgrade来更新软件源、列出更新列表和操作更新\n\n该脚本不对其使用效果有任何明示或暗示的担保,在使用前请您确保您清楚地知道您在干什么。您应当清楚,星火商店的软件包并不是适配所有发行版的;尽管绝大多数的软件更新是无害的,您仍然应该仔细检查显示出来的更新内容,以确保不会对您的依赖环境造成破坏,尤其是那些看起来和系统依赖相关的软件包。在查看过更新列表之后,确认更新之前,您仍有取消更新的机会。\n\n本脚本的开发者不对使用该脚本可能造成的后果负责"
|
|
||||||
;;
|
|
||||||
1)
|
|
||||||
if [ -e /etc/systemd/system/multi-user.target.wants/spark-update-notifier.service ];then
|
if [ -e /etc/systemd/system/multi-user.target.wants/spark-update-notifier.service ];then
|
||||||
zenity --info --icon-name=spark-store --height 150 --width 200 --text "检测到已经启动了自动更新检测,执行关闭" --timeout=2
|
zenity --info --icon-name=spark-store --height 150 --width 200 --text "${TRANSHELL_CONTENT_CLOSING_UPGRADE_CHECK}" --timeout=2
|
||||||
pkexec systemctl disable spark-update-notifier
|
pkexec systemctl disable spark-update-notifier
|
||||||
zenity --info --icon-name=spark-store --height 150 --width 200 --text "已关闭" --timeout=2
|
zenity --info --icon-name=spark-store --height 150 --width 200 --text "${TRANSHELL_CONTENT_CLOSED}" --timeout=2
|
||||||
else
|
else
|
||||||
zenity --info --icon-name=spark-store --height 150 --width 200 --text "未检测到自动更新检测,执行启动" --timeout=2
|
zenity --info --icon-name=spark-store --height 150 --width 200 --text "${TRANSHELL_CONTENT_OPENING_UPGRADE_CHECK}" --timeout=2
|
||||||
pkexec systemctl enable spark-update-notifier
|
pkexec systemctl enable spark-update-notifier
|
||||||
pkexec service spark-update-notifier start
|
pkexec service spark-update-notifier start
|
||||||
zenity --info --icon-name=spark-store --height 150 --width 200 --text "已启动" --timeout=2
|
zenity --info --icon-name=spark-store --height 150 --width 200 --text "${TRANSHELL_CONTENT_OPENED}" --timeout=2
|
||||||
fi
|
fi
|
||||||
;;
|
;;
|
||||||
|
|
||||||
2)
|
1)
|
||||||
/opt/durapps/spark-store/bin/update-upgrade/ss-do-upgrade.sh
|
/opt/durapps/spark-store/bin/update-upgrade/ss-do-upgrade.sh
|
||||||
;;
|
;;
|
||||||
|
|
||||||
4)
|
2)
|
||||||
exit 0
|
exit 0
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
|
|||||||
@@ -1,18 +1,23 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
LANGUAGE=en_US
|
LANGUAGE=en_US
|
||||||
|
|
||||||
|
source /opt/durapps/spark-store/bin/bashimport/transhell.amber
|
||||||
|
load_transhell_debug
|
||||||
|
|
||||||
|
#############################################################
|
||||||
|
|
||||||
|
|
||||||
# 发送通知
|
# 发送通知
|
||||||
function notify-send() {
|
function notify-send() {
|
||||||
# Detect name of the display in use
|
|
||||||
local display=":$(ls /tmp/.X11-unix/* | sed 's#/tmp/.X11-unix/X##' | head -n 1)"
|
|
||||||
|
|
||||||
# Detect user using the display
|
# Detect user using the display
|
||||||
local user=$(who | grep '('$display')' | awk '{print $1}' | head -n 1)
|
local user=$(who | awk '{print $1}' | head -n 1)
|
||||||
|
|
||||||
# Detect uid of the user
|
# Detect uid of the user
|
||||||
local uid=$(id -u $user)
|
local uid=$(id -u $user)
|
||||||
|
|
||||||
sudo -u $user DISPLAY=$display DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/${uid}/bus notify-send "$@"
|
sudo -u $user DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/${uid}/bus notify-send "$@"
|
||||||
}
|
}
|
||||||
|
|
||||||
# 检测网络链接畅通
|
# 检测网络链接畅通
|
||||||
@@ -38,7 +43,7 @@ function network()
|
|||||||
|
|
||||||
network
|
network
|
||||||
if [ $? -ne 0 ] ; then
|
if [ $? -ne 0 ] ; then
|
||||||
echo "Network fail. Stop to avoid bother dpkg"
|
echo "$TRANSHELL_CONTENT_NETWORK_FAIL"
|
||||||
exit -1
|
exit -1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -47,7 +52,19 @@ fi
|
|||||||
# 每日更新星火源文件
|
# 每日更新星火源文件
|
||||||
curl --progress-bar -o /opt/durapps/spark-store/bin/apt-fast-conf/sources.list.d/sparkstore.list "https://gitee.com/deepin-community-store/repo_auto_update_script/raw/master/mirror-list-for-apt-fast/sources.list.d/sparkstore.list"
|
curl --progress-bar -o /opt/durapps/spark-store/bin/apt-fast-conf/sources.list.d/sparkstore.list "https://gitee.com/deepin-community-store/repo_auto_update_script/raw/master/mirror-list-for-apt-fast/sources.list.d/sparkstore.list"
|
||||||
|
|
||||||
updatetext=`aptss ssupdate`
|
|
||||||
|
|
||||||
|
updatetext=`aptss ssupdate 2>&1`
|
||||||
|
|
||||||
|
until [ "`echo $updatetext | grep E: `" = "" ];do
|
||||||
|
echo "${TRANSHELL_CONTENT_UPDATE_ERROR_AND_WAIT_15_SEC}"
|
||||||
|
sleep 15
|
||||||
|
updatetext=`aptss ssupdate 2>&1`
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
done
|
||||||
|
|
||||||
isupdate=`echo ${updatetext: -5}`
|
isupdate=`echo ${updatetext: -5}`
|
||||||
if [ "$isupdate" = "date." ] ; then
|
if [ "$isupdate" = "date." ] ; then
|
||||||
exit 0
|
exit 0
|
||||||
@@ -84,10 +101,10 @@ done
|
|||||||
|
|
||||||
# 还原分隔符
|
# 还原分隔符
|
||||||
IFS="$IFS_OLD"
|
IFS="$IFS_OLD"
|
||||||
|
|
||||||
if [ $update_app_number -le 0 ] ; then
|
if [ $update_app_number -le 0 ] ; then
|
||||||
exit 0
|
exit 0
|
||||||
fi
|
fi
|
||||||
|
update_transhell
|
||||||
|
|
||||||
## 如果都是hold或者版本一致的那就直接退出,否则把剩余的给提醒了
|
## 如果都是hold或者版本一致的那就直接退出,否则把剩余的给提醒了
|
||||||
notify-send -a spark-store "星火更新提醒" "星火商店仓库中有$update_app_number个软件包可以更新啦!请到星火商店的菜单处理"
|
notify-send -a spark-store "${TRANSHELL_CONTENT_SPARK_STORE_UPGRADE_NOTIFY}" "${TRANSHELL_CONTENT_THERE_ARE_APPS_TO_UPGRADE}"
|
||||||
|
|||||||
@@ -0,0 +1,17 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
TRANSHELL_CONTENT_UPDATE_CHEKING_PLEASE_WAIT="Checking for update, please wait..."
|
||||||
|
TRANSHELL_CONTENT_SPARK_STORE_UPGRADE_MODEL="Spark Store APP Upgrade model"
|
||||||
|
TRANSHELL_CONTENT_CHECK_UPDATE_PROCESS_ERROR_PRESS_CONFIRM_TO_CHECK="Error occured in checking for update! Press Confirm to get the error log (Can be useful when feedback)"
|
||||||
|
TRANSHELL_CONTENT_I_ALREDY_COPIED_THE_LOG_HERE_AND_WILL_USE_IT_TO_FEEDBACK="I already copied the log in the text box and I will attach it when feeding back. You can find feedback entry in the settings which is located in the top right of the store."
|
||||||
|
TRANSHELL_CONTENT_FEEDBACK_CAN_BE_FOUND_IN_THE_SETTINGS="Feedback entry in the settings which is located in the top right of the store"
|
||||||
|
TRANSHELL_CONTENT_NO_NEED_TO_UPGRADE="All APPs are up to date.\nBut you are not standing at the top of the world"
|
||||||
|
TRANSHELL_CONTENT_CAN_NOT_UPGRADE_FOR_BEING_HOLD="(Unable to upgrade: Being marked as hold)"
|
||||||
|
TRANSHELL_CONTENT_CHOOSE_APP_TO_UPGRADE="Choose the app you want to upgrade"
|
||||||
|
TRANSHELL_CONTENT_CHOOSE="Choose"
|
||||||
|
TRANSHELL_CONTENT_PKG_NAME="Pkg name"
|
||||||
|
TRANSHELL_CONTENT_NEW_VERSION="New version"
|
||||||
|
TRANSHELL_CONTENT_UPGRADE_FROM="Upgrade from"
|
||||||
|
TRANSHELL_CONTENT_NO_APP_IS_CHOSEN="No app is chosen\nBut you are not standing at the top of the world"
|
||||||
|
TRANSHELL_CONTENT_UPGRADING_PLEASE_WAIT="Upgrading $PKG_UPGRADE , please wait..."
|
||||||
|
TRANSHELL_CONTENT_CHOSEN_APP_UPGRADE_FINISHED="The chosen app is upgraded"
|
||||||
|
TRANSHELL_CONTENT_APP_UGRADE_PROCESS_ERROR_PRESS_CONFIRM_TO_CHECK="Error occured when upgrading! Press Confirm to get the error log (Can be useful when feedback)"
|
||||||
@@ -0,0 +1,17 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
TRANSHELL_CONTENT_UPDATE_CHEKING_PLEASE_WAIT="正在检查更新,请稍候..."
|
||||||
|
TRANSHELL_CONTENT_SPARK_STORE_UPGRADE_MODEL="星火商店更新模块"
|
||||||
|
TRANSHELL_CONTENT_CHECK_UPDATE_PROCESS_ERROR_PRESS_CONFIRM_TO_CHECK="检查更新进程出现错误!按确定查看报错,可用于反馈"
|
||||||
|
TRANSHELL_CONTENT_I_ALREDY_COPIED_THE_LOG_HERE_AND_WILL_USE_IT_TO_FEEDBACK="我已复制了此文本框中的日志,且将会在反馈时附上。反馈渠道可以在右上角菜单的设置中找到"
|
||||||
|
TRANSHELL_CONTENT_FEEDBACK_CAN_BE_FOUND_IN_THE_SETTINGS="反馈渠道在商店右上角的设置里"
|
||||||
|
TRANSHELL_CONTENT_NO_NEED_TO_UPGRADE="没有软件需要更新\n但是你并没有站在世界之巅"
|
||||||
|
TRANSHELL_CONTENT_CAN_NOT_UPGRADE_FOR_BEING_HOLD="(无法更新:已被标记为保留)"
|
||||||
|
TRANSHELL_CONTENT_CHOOSE_APP_TO_UPGRADE="选择你想更新的应用"
|
||||||
|
TRANSHELL_CONTENT_CHOOSE="选择"
|
||||||
|
TRANSHELL_CONTENT_PKG_NAME="包名"
|
||||||
|
TRANSHELL_CONTENT_NEW_VERSION="新版本"
|
||||||
|
TRANSHELL_CONTENT_UPGRADE_FROM="从该版本更新"
|
||||||
|
TRANSHELL_CONTENT_NO_APP_IS_CHOSEN="没有选中任何软件\n但是你并没有站在世界之巅"
|
||||||
|
TRANSHELL_CONTENT_UPGRADING_PLEASE_WAIT="正在更新 $PKG_UPGRADE ,请稍候..."
|
||||||
|
TRANSHELL_CONTENT_CHOSEN_APP_UPGRADE_FINISHED="选中的软件已经更新完毕"
|
||||||
|
TRANSHELL_CONTENT_APP_UGRADE_PROCESS_ERROR_PRESS_CONFIRM_TO_CHECK="更新出现错误!按确定查看报错,可用于反馈"
|
||||||
@@ -0,0 +1,17 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
TRANSHELL_CONTENT_UPDATE_CHEKING_PLEASE_WAIT="正在檢查更新,請稍候…"
|
||||||
|
TRANSHELL_CONTENT_SPARK_STORE_UPGRADE_MODEL="星火商店更新模塊"
|
||||||
|
TRANSHELL_CONTENT_CHECK_UPDATE_PROCESS_ERROR_PRESS_CONFIRM_TO_CHECK="檢查更新行程出現錯誤! 按確定查看報錯,可用於回報"
|
||||||
|
TRANSHELL_CONTENT_I_ALREDY_COPIED_THE_LOG_HERE_AND_WILL_USE_IT_TO_FEEDBACK="我已複製了此文字方塊中的日誌,且將會在回報時附上。 迴響通路可以在右上角選單的設定中找到 "
|
||||||
|
TRANSHELL_CONTENT_FEEDBACK_CAN_BE_FOUND_IN_THE_SETTINGS="回報入口在商店右上角的設定裏"
|
||||||
|
TRANSHELL_CONTENT_NO_NEED_TO_UPGRADE="沒有軟體需要更新\n但是你並沒有站在世界之巔"
|
||||||
|
TRANSHELL_CONTENT_CAN_NOT_UPGRADE_FOR_BEING_HOLD="(无法更新:已被标记为保留)"
|
||||||
|
TRANSHELL_CONTENT_CHOOSE_APP_TO_UPGRADE="选择你想更新的应用"
|
||||||
|
TRANSHELL_CONTENT_CHOOSE="选择"
|
||||||
|
TRANSHELL_CONTENT_PKG_NAME="包名"
|
||||||
|
TRANSHELL_CONTENT_NEW_VERSION="新版本"
|
||||||
|
TRANSHELL_CONTENT_UPGRADE_FROM="从该版本更新"
|
||||||
|
TRANSHELL_CONTENT_NO_APP_IS_CHOSEN="没有选中任何軟體\n但是你並沒有站在世界之巔"
|
||||||
|
TRANSHELL_CONTENT_UPGRADING_PLEASE_WAIT="正在更新 $PKG_UPGRADE ,请稍候..."
|
||||||
|
TRANSHELL_CONTENT_CHOSEN_APP_UPGRADE_FINISHED="选中的軟體已经更新完毕"
|
||||||
|
TRANSHELL_CONTENT_APP_UGRADE_PROCESS_ERROR_PRESS_CONFIRM_TO_CHECK="更新出现错误!按确定查看报错,可用于反馈"
|
||||||
@@ -0,0 +1,12 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
TRANSHELL_CONTENT_CLOSE="关闭"
|
||||||
|
TRANSHELL_CONTENT_OPEN="开启"
|
||||||
|
TRANSHELL_CONTENT_WELCOME_AND_CHOOSE_ONE_TO_RUN="欢迎使用星火更新和安装设置工具\n请在以下操作中选择一个进行~"
|
||||||
|
TRANSHELL_CONTENT_OPTIONS="操作选项"
|
||||||
|
TRANSHELL_CONTENT_OPEN_OR_CLOSE_UPGRADE_CHECK="$text_update_open星火更新检测工具(如果开启则会在系统启动后自动检测更新。如有更新则会弹出通知)"
|
||||||
|
TRANSHELL_CONTENT_CHECK_FOR_UPDATE="查看可更新软件包列表"
|
||||||
|
TRANSHELL_CONTENT_EXIT="退出"
|
||||||
|
TRANSHELL_CONTENT_CLOSING_UPGRADE_CHECK="执行关闭自动更新检测,请授权"
|
||||||
|
TRANSHELL_CONTENT_CLOSED="已关闭"
|
||||||
|
TRANSHELL_CONTENT_OPENING_UPGRADE_CHECK="执行启动自动更新检测,请授权"
|
||||||
|
TRANSHELL_CONTENT_OPENED="已开启"
|
||||||
@@ -0,0 +1,12 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
TRANSHELL_CONTENT_CLOSE="Close"
|
||||||
|
TRANSHELL_CONTENT_OPEN="Open"
|
||||||
|
TRANSHELL_CONTENT_WELCOME_AND_CHOOSE_ONE_TO_RUN="Welcome to Spark Store APP Upgrade Settings\nPlease choose one option to run"
|
||||||
|
TRANSHELL_CONTENT_OPTIONS="Options"
|
||||||
|
TRANSHELL_CONTENT_OPEN_OR_CLOSE_UPGRADE_CHECK="$text_update_open Spark Store APP upgrade check. (Will notify APP upgrade at start up if opened.)"
|
||||||
|
TRANSHELL_CONTENT_CHECK_FOR_UPDATE="Check Upgradable app list."
|
||||||
|
TRANSHELL_CONTENT_EXIT="Exit"
|
||||||
|
TRANSHELL_CONTENT_CLOSING_UPGRADE_CHECK="Please authorize to close APP upgrade check"
|
||||||
|
TRANSHELL_CONTENT_CLOSED="Closed"
|
||||||
|
TRANSHELL_CONTENT_OPENING_UPGRADE_CHECK="Please authorize to open APP upgrade check"
|
||||||
|
TRANSHELL_CONTENT_OPENED="Opened"
|
||||||
@@ -0,0 +1,12 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
TRANSHELL_CONTENT_CLOSE="关闭"
|
||||||
|
TRANSHELL_CONTENT_OPEN="开启"
|
||||||
|
TRANSHELL_CONTENT_WELCOME_AND_CHOOSE_ONE_TO_RUN="欢迎使用星火更新和安装设置工具\n请在以下操作中选择一个进行~"
|
||||||
|
TRANSHELL_CONTENT_OPTIONS="操作选项"
|
||||||
|
TRANSHELL_CONTENT_OPEN_OR_CLOSE_UPGRADE_CHECK="$text_update_open星火更新检测工具(如果开启则会在系统启动后自动检测更新。如有更新则会弹出通知)"
|
||||||
|
TRANSHELL_CONTENT_CHECK_FOR_UPDATE="查看可更新软件包列表"
|
||||||
|
TRANSHELL_CONTENT_EXIT="退出"
|
||||||
|
TRANSHELL_CONTENT_CLOSING_UPGRADE_CHECK="执行关闭自动更新检测,请授权"
|
||||||
|
TRANSHELL_CONTENT_CLOSED="已关闭"
|
||||||
|
TRANSHELL_CONTENT_OPENING_UPGRADE_CHECK="执行启动自动更新检测,请授权"
|
||||||
|
TRANSHELL_CONTENT_OPENED="已开启"
|
||||||
@@ -0,0 +1,5 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
TRANSHELL_CONTENT_NETWORK_FAIL="Network fail. Stop to avoid bother dpkg"
|
||||||
|
TRANSHELL_CONTENT_UPDATE_ERROR_AND_WAIT_15_SEC="Update error! Wait for 15 seconds..."
|
||||||
|
TRANSHELL_CONTENT_SPARK_STORE_UPGRADE_NOTIFY="Spark Store Upgrade Notifier"
|
||||||
|
TRANSHELL_CONTENT_THERE_ARE_APPS_TO_UPGRADE="There are ${update_app_number} APPs available to upgrade! Please go to Spark Store to upgrade."
|
||||||
@@ -0,0 +1,5 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
TRANSHELL_CONTENT_NETWORK_FAIL="网络错误!为防止阻塞dpkg,停止"
|
||||||
|
TRANSHELL_CONTENT_UPDATE_ERROR_AND_WAIT_15_SEC="更新出现异常状况,等待十五秒"
|
||||||
|
TRANSHELL_CONTENT_SPARK_STORE_UPGRADE_NOTIFY="星火更新提醒"
|
||||||
|
TRANSHELL_CONTENT_THERE_ARE_APPS_TO_UPGRADE="星火商店仓库中有$update_app_number个软件包可以更新啦!请到星火商店的菜单处理"
|
||||||
@@ -0,0 +1,5 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
TRANSHELL_CONTENT_NETWORK_FAIL="网络错误!为防止阻塞dpkg,停止"
|
||||||
|
TRANSHELL_CONTENT_UPDATE_ERROR_AND_WAIT_15_SEC="更新出现异常状况,等待十五秒"
|
||||||
|
TRANSHELL_CONTENT_SPARK_STORE_UPGRADE_NOTIFY="星火更新提醒"
|
||||||
|
TRANSHELL_CONTENT_THERE_ARE_APPS_TO_UPGRADE="星火商店仓库中有$update_app_number个软件包可以更新啦!请到星火商店的菜单处理"
|
||||||
@@ -1,10 +1,6 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
# this file is used to auto-generate .qm file from .ts file.
|
# this file is used to auto-generate .qm file from .ts file.
|
||||||
|
|
||||||
ts_list=(`ls ./translations/*.ts`)
|
cd $(dirname $0)
|
||||||
|
|
||||||
for ts in "${ts_list[@]}"
|
lrelease ./src/spark-store.pro
|
||||||
do
|
|
||||||
printf "\nprocess ${ts}\n"
|
|
||||||
lrelease "${ts}"
|
|
||||||
done
|
|
||||||
|
|||||||
6
translate_update.sh
Executable file
6
translate_update.sh
Executable file
@@ -0,0 +1,6 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
# this file is used to auto-update .ts file.
|
||||||
|
|
||||||
|
cd $(dirname $0)
|
||||||
|
|
||||||
|
lupdate ./src/spark-store.pro -no-obsolete
|
||||||
@@ -10,8 +10,9 @@
|
|||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/pages/appintopage.ui" line="244"/>
|
<location filename="../src/pages/appintopage.ui" line="244"/>
|
||||||
<location filename="../src/pages/appintopage.cpp" line="147"/>
|
<location filename="../src/pages/appintopage.cpp" line="173"/>
|
||||||
<location filename="../src/pages/appintopage.cpp" line="209"/>
|
<location filename="../src/pages/appintopage.cpp" line="315"/>
|
||||||
|
<location filename="../src/pages/appintopage.cpp" line="430"/>
|
||||||
<source>Download</source>
|
<source>Download</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
@@ -41,12 +42,6 @@
|
|||||||
<source><html><head/><body><p><img src=":/tags/community-small.png"/></p></body></html></source>
|
<source><html><head/><body><p><img src=":/tags/community-small.png"/></p></body></html></source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
|
||||||
<location filename="../src/pages/appintopage.ui" line="429"/>
|
|
||||||
<location filename="../src/pages/appintopage.ui" line="432"/>
|
|
||||||
<source><html><head/><body><p>Capable to Ubuntu 20.04</p></body></html></source>
|
|
||||||
<translation type="unfinished"></translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/pages/appintopage.ui" line="435"/>
|
<location filename="../src/pages/appintopage.ui" line="435"/>
|
||||||
<source><html><head/><body><p><img src=":/tags/ubuntu-small.png"/></p></body></html></source>
|
<source><html><head/><body><p><img src=":/tags/ubuntu-small.png"/></p></body></html></source>
|
||||||
@@ -107,12 +102,6 @@
|
|||||||
<source><html><head/><body><p><img src=":/tags/a2d-small.png"/></p></body></html></source>
|
<source><html><head/><body><p><img src=":/tags/a2d-small.png"/></p></body></html></source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
|
||||||
<location filename="../src/pages/appintopage.ui" line="543"/>
|
|
||||||
<location filename="../src/pages/appintopage.ui" line="546"/>
|
|
||||||
<source><html><head/><body><p>A deepin-wine5 app.Spark Store will automatically configure the wine kit for you</p></body></html></source>
|
|
||||||
<translation type="unfinished"></translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/pages/appintopage.ui" line="549"/>
|
<location filename="../src/pages/appintopage.ui" line="549"/>
|
||||||
<source><html><head/><body><p><img src=":/tags/dwine5-small.png"/></p></body></html></source>
|
<source><html><head/><body><p><img src=":/tags/dwine5-small.png"/></p></body></html></source>
|
||||||
@@ -143,6 +132,18 @@
|
|||||||
<source>Screen capture</source>
|
<source>Screen capture</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="429"/>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="432"/>
|
||||||
|
<source><html><head/><body><p>Capable to Ubuntu 22.04</p></body></html></source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="543"/>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="546"/>
|
||||||
|
<source><html><head/><body><p>A Wine app.Spark Store will automatically configure the wine kit for you</p></body></html></source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/pages/appintopage.ui" line="1161"/>
|
<location filename="../src/pages/appintopage.ui" line="1161"/>
|
||||||
<source>Update</source>
|
<source>Update</source>
|
||||||
@@ -174,47 +175,51 @@
|
|||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/pages/appintopage.cpp" line="89"/>
|
<location filename="../src/pages/appintopage.cpp" line="47"/>
|
||||||
<source>Click Open</source>
|
<source>Click Open</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/pages/appintopage.cpp" line="132"/>
|
<location filename="../src/pages/appintopage.cpp" line="112"/>
|
||||||
<location filename="../src/pages/appintopage.cpp" line="224"/>
|
<source>Developer Mode Disabled</source>
|
||||||
<location filename="../src/pages/appintopage.cpp" line="316"/>
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.cpp" line="158"/>
|
||||||
|
<location filename="../src/pages/appintopage.cpp" line="331"/>
|
||||||
|
<location filename="../src/pages/appintopage.cpp" line="403"/>
|
||||||
<source>Reinstall</source>
|
<source>Reinstall</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/pages/appintopage.cpp" line="139"/>
|
<location filename="../src/pages/appintopage.cpp" line="165"/>
|
||||||
<source>Upgrade</source>
|
<source>Upgrade</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/pages/appintopage.cpp" line="214"/>
|
<location filename="../src/pages/appintopage.cpp" line="320"/>
|
||||||
<location filename="../src/pages/appintopage.cpp" line="308"/>
|
<location filename="../src/pages/appintopage.cpp" line="379"/>
|
||||||
<location filename="../src/pages/appintopage.cpp" line="341"/>
|
|
||||||
<source>Install</source>
|
<source>Install</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/pages/appintopage.cpp" line="219"/>
|
<location filename="../src/pages/appintopage.cpp" line="325"/>
|
||||||
<source>Installing</source>
|
<source>Installing</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/pages/appintopage.cpp" line="345"/>
|
<location filename="../src/pages/appintopage.cpp" line="434"/>
|
||||||
<location filename="../src/pages/appintopage.cpp" line="356"/>
|
<location filename="../src/pages/appintopage.cpp" line="447"/>
|
||||||
<source>Spark Store</source>
|
<source>Spark Store</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/pages/appintopage.cpp" line="345"/>
|
<location filename="../src/pages/appintopage.cpp" line="434"/>
|
||||||
<source>Uninstall succeeded</source>
|
<source>Uninstall succeeded</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/pages/appintopage.cpp" line="356"/>
|
<location filename="../src/pages/appintopage.cpp" line="447"/>
|
||||||
<source>The URL has been copied to the clipboard</source>
|
<source>The URL has been copied to the clipboard</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
@@ -232,102 +237,121 @@
|
|||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
</context>
|
</context>
|
||||||
|
<context>
|
||||||
|
<name>DAboutDialog</name>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/application.cpp" line="133"/>
|
||||||
|
<source>Version: %1</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/application.cpp" line="143"/>
|
||||||
|
<source>%1 is released under %2</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
</context>
|
||||||
<context>
|
<context>
|
||||||
<name>DownloadItem</name>
|
<name>DownloadItem</name>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.ui" line="20"/>
|
<location filename="../src/widgets/common/downloaditem.ui" line="32"/>
|
||||||
<source>Form</source>
|
<source>Form</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.ui" line="50"/>
|
<location filename="../src/widgets/common/downloaditem.ui" line="74"/>
|
||||||
<source>icon</source>
|
<source>icon</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.ui" line="82"/>
|
<location filename="../src/widgets/common/downloaditem.ui" line="134"/>
|
||||||
<source>TextLabel</source>
|
<source>TextLabel</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.ui" line="106"/>
|
<location filename="../src/widgets/common/downloaditem.ui" line="121"/>
|
||||||
<source>Name</source>
|
<source>Name</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.ui" line="198"/>
|
<location filename="../src/widgets/common/downloaditem.ui" line="226"/>
|
||||||
<source>Waiting to download</source>
|
<source>Waiting to download</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.ui" line="249"/>
|
<location filename="../src/widgets/common/downloaditem.ui" line="277"/>
|
||||||
<source>Install</source>
|
<source>Install</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.ui" line="268"/>
|
<location filename="../src/widgets/common/downloaditem.ui" line="296"/>
|
||||||
<source>Cancel</source>
|
<source>Cancel</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.ui" line="287"/>
|
<location filename="../src/widgets/common/downloaditem.ui" line="315"/>
|
||||||
<source>Info</source>
|
<source>Info</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.cpp" line="40"/>
|
<location filename="../src/widgets/common/downloaditem.cpp" line="43"/>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.cpp" line="44"/>
|
||||||
<source>Download Complete.</source>
|
<source>Download Complete.</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.cpp" line="142"/>
|
<location filename="../src/widgets/common/downloaditem.cpp" line="213"/>
|
||||||
<location filename="../src/widgets/common/downloaditem.cpp" line="152"/>
|
<location filename="../src/widgets/common/downloaditem.cpp" line="224"/>
|
||||||
<location filename="../src/widgets/common/downloaditem.cpp" line="159"/>
|
<location filename="../src/widgets/common/downloaditem.cpp" line="232"/>
|
||||||
<source>Spark Store</source>
|
<source>Spark Store</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.cpp" line="99"/>
|
<location filename="../src/widgets/common/downloaditem.cpp" line="125"/>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.cpp" line="126"/>
|
||||||
<source>Installing</source>
|
<source>Installing</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.cpp" line="142"/>
|
<location filename="../src/widgets/common/downloaditem.cpp" line="213"/>
|
||||||
<source>Installation complete.</source>
|
<source>Installation complete.</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.cpp" line="143"/>
|
<location filename="../src/widgets/common/downloaditem.cpp" line="214"/>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.cpp" line="215"/>
|
||||||
<source>Finish</source>
|
<source>Finish</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.cpp" line="150"/>
|
<location filename="../src/widgets/common/downloaditem.cpp" line="222"/>
|
||||||
<source>Retry</source>
|
<source>Retry</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.cpp" line="152"/>
|
<location filename="../src/widgets/common/downloaditem.cpp" line="224"/>
|
||||||
<source>Error happened in dpkg progress , you can try it again.</source>
|
<source>Error happened in dpkg progress , you can try it again.</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.cpp" line="153"/>
|
<location filename="../src/widgets/common/downloaditem.cpp" line="225"/>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.cpp" line="226"/>
|
||||||
<source>Error happened in dpkg progress , you can try it again</source>
|
<source>Error happened in dpkg progress , you can try it again</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.cpp" line="159"/>
|
<location filename="../src/widgets/common/downloaditem.cpp" line="232"/>
|
||||||
<source>dpkg progress had been aborted,you can retry installation.</source>
|
<source>dpkg progress had been aborted,you can retry installation.</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.cpp" line="160"/>
|
<location filename="../src/widgets/common/downloaditem.cpp" line="233"/>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.cpp" line="234"/>
|
||||||
<source>dpkg progress had been aborted,you can retry installation</source>
|
<source>dpkg progress had been aborted,you can retry installation</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.cpp" line="181"/>
|
<location filename="../src/widgets/common/downloaditem.cpp" line="144"/>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.cpp" line="145"/>
|
||||||
<source>Download canceled</source>
|
<source>Download canceled</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
@@ -345,7 +369,7 @@
|
|||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/downloadlistwidget.ui" line="110"/>
|
<location filename="../src/widgets/downloadlistwidget.ui" line="116"/>
|
||||||
<source>Open download directory</source>
|
<source>Open download directory</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
@@ -358,141 +382,134 @@
|
|||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.ui" line="160"/>
|
<location filename="../src/mainwindow-dtk.ui" line="166"/>
|
||||||
<source>Home</source>
|
<source>Home</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.ui" line="197"/>
|
<location filename="../src/mainwindow-dtk.ui" line="203"/>
|
||||||
<source>Network</source>
|
<source>Network</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.ui" line="225"/>
|
<location filename="../src/mainwindow-dtk.ui" line="231"/>
|
||||||
<source>Chat</source>
|
<source>Chat</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.ui" line="253"/>
|
<location filename="../src/mainwindow-dtk.ui" line="259"/>
|
||||||
<source>Music</source>
|
<source>Music</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.ui" line="281"/>
|
<location filename="../src/mainwindow-dtk.ui" line="287"/>
|
||||||
<source>Video</source>
|
<source>Video</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.ui" line="309"/>
|
<location filename="../src/mainwindow-dtk.ui" line="315"/>
|
||||||
<source>Picture</source>
|
<source>Picture</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.ui" line="337"/>
|
<location filename="../src/mainwindow-dtk.ui" line="343"/>
|
||||||
<source>Game</source>
|
<source>Game</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.ui" line="365"/>
|
<location filename="../src/mainwindow-dtk.ui" line="371"/>
|
||||||
<source>Office</source>
|
<source>Office</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.ui" line="393"/>
|
<location filename="../src/mainwindow-dtk.ui" line="399"/>
|
||||||
<source>Reading</source>
|
<source>Reading</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.ui" line="421"/>
|
<location filename="../src/mainwindow-dtk.ui" line="427"/>
|
||||||
<source>Development</source>
|
<source>Development</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.ui" line="449"/>
|
<location filename="../src/mainwindow-dtk.ui" line="455"/>
|
||||||
<source>Tool</source>
|
<source>Tool</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.ui" line="477"/>
|
<location filename="../src/mainwindow-dtk.ui" line="483"/>
|
||||||
<source>Theme</source>
|
<source>Theme</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.ui" line="505"/>
|
<location filename="../src/mainwindow-dtk.ui" line="511"/>
|
||||||
<source>Other</source>
|
<source>Other</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.ui" line="533"/>
|
<location filename="../src/mainwindow-dtk.ui" line="539"/>
|
||||||
<source>APP Upgrade</source>
|
<source>APP Upgrade</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.cpp" line="34"/>
|
<location filename="../src/mainwindow-dtk.cpp" line="170"/>
|
||||||
<source>Submit App</source>
|
<source>Submit App</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.cpp" line="35"/>
|
<location filename="../src/mainwindow-dtk.cpp" line="171"/>
|
||||||
<source>Submit App with client(Recommanded)</source>
|
<source>Submit App with client(Recommanded)</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.cpp" line="36"/>
|
<location filename="../src/mainwindow-dtk.cpp" line="172"/>
|
||||||
<source>Settings</source>
|
<source>Settings</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.cpp" line="37"/>
|
<location filename="../src/mainwindow-dtk.cpp" line="173"/>
|
||||||
<source>APP Upgrade and Install Settings</source>
|
<source>APP Upgrade and Install Settings</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.cpp" line="158"/>
|
<location filename="../src/mainwindow-dtk.cpp" line="129"/>
|
||||||
|
<location filename="../src/mainwindow-dtk.cpp" line="224"/>
|
||||||
<source>Spark Store</source>
|
<source>Spark Store</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.cpp" line="159"/>
|
<location filename="../src/mainwindow-dtk.cpp" line="134"/>
|
||||||
<source>Search or enter spk://</source>
|
<source>Search or enter spk://</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
</context>
|
</context>
|
||||||
<context>
|
|
||||||
<name>QLabel</name>
|
|
||||||
<message>
|
|
||||||
<location filename="../src/main.cpp" line="64"/>
|
|
||||||
<location filename="../src/main.cpp" line="73"/>
|
|
||||||
<source>Spark Store</source>
|
|
||||||
<translation type="unfinished"></translation>
|
|
||||||
</message>
|
|
||||||
</context>
|
|
||||||
<context>
|
<context>
|
||||||
<name>QObject</name>
|
<name>QObject</name>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/main.cpp" line="61"/>
|
<location filename="../src/application.cpp" line="33"/>
|
||||||
<source>We publish this program under GPL V3</source>
|
<location filename="../src/application.cpp" line="34"/>
|
||||||
<translation type="unfinished"></translation>
|
<location filename="../src/mainwindow-dtk.cpp" line="109"/>
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<location filename="../src/main.cpp" line="66"/>
|
|
||||||
<source><span style=' font-size:10pt;font-weight:60;'>An appstore powered by community</span><br/><a href='https://www.spark-app.store/'>https://www.spark-app.store</a><br/><span style=' font-size:12pt;'>Spark developers</span></source>
|
|
||||||
<translation type="unfinished"></translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<location filename="../src/main.cpp" line="75"/>
|
|
||||||
<source>The Spark Project</source>
|
|
||||||
<translation type="unfinished"></translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<location filename="../src/main.cpp" line="79"/>
|
|
||||||
<location filename="../src/main.cpp" line="81"/>
|
|
||||||
<source>Spark Store</source>
|
<source>Spark Store</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/main.cpp" line="84"/>
|
<location filename="../src/application.cpp" line="38"/>
|
||||||
<source><span style='font-size:10pt;font-weight:60;'>An appstore powered by deepin community</span><br/><a href='https://www.spark-app.store/'>https://www.spark-app.store</a><br/><span style='font-size:12pt;'>Spark developers</span><br/><br/>Published under GPL V3</source>
|
<source><span style=' font-size:10pt;font-weight:60;'>An appstore powered by community</span><br/><a href='https://www.spark-app.store/'>https://www.spark-app.store</a><br/><span style=' font-size:12pt;'>Spark developers</span></source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/application.cpp" line="140"/>
|
||||||
|
<source>Spark Project</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/widgets/downloadlistwidget.cpp" line="17"/>
|
||||||
|
<source>Download list</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/mainwindow-dtk.cpp" line="227"/>
|
||||||
|
<source>Show MainWindow</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
</context>
|
</context>
|
||||||
@@ -584,30 +601,32 @@
|
|||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/pages/settingspage.cpp" line="181"/>
|
<location filename="../src/pages/settingspage.cpp" line="213"/>
|
||||||
<source>Updating, please wait...</source>
|
<source>Updating, please wait...</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/pages/settingspage.cpp" line="204"/>
|
<location filename="../src/pages/settingspage.cpp" line="235"/>
|
||||||
<source>Spark Store</source>
|
<source>Spark Store</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/pages/settingspage.cpp" line="204"/>
|
<location filename="../src/pages/settingspage.cpp" line="235"/>
|
||||||
<source>Temporary cache was cleaned</source>
|
<source>Temporary cache was cleaned</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
</context>
|
</context>
|
||||||
<context>
|
<context>
|
||||||
<name>Widget</name>
|
<name>TitleBarMenu</name>
|
||||||
<message>
|
<message>
|
||||||
<source>Share</source>
|
<location filename="../src/mainwindow-dtk.cpp" line="228"/>
|
||||||
<translation type="obsolete">Spk share link</translation>
|
<source>About</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>0B</source>
|
<location filename="../src/mainwindow-dtk.cpp" line="229"/>
|
||||||
<translation type="obsolete">0B</translation>
|
<source>Exit</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
</context>
|
</context>
|
||||||
</TS>
|
</TS>
|
||||||
|
|||||||
@@ -10,8 +10,9 @@
|
|||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/pages/appintopage.ui" line="244"/>
|
<location filename="../src/pages/appintopage.ui" line="244"/>
|
||||||
<location filename="../src/pages/appintopage.cpp" line="147"/>
|
<location filename="../src/pages/appintopage.cpp" line="173"/>
|
||||||
<location filename="../src/pages/appintopage.cpp" line="209"/>
|
<location filename="../src/pages/appintopage.cpp" line="315"/>
|
||||||
|
<location filename="../src/pages/appintopage.cpp" line="430"/>
|
||||||
<source>Download</source>
|
<source>Download</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
@@ -41,12 +42,6 @@
|
|||||||
<source><html><head/><body><p><img src=":/tags/community-small.png"/></p></body></html></source>
|
<source><html><head/><body><p><img src=":/tags/community-small.png"/></p></body></html></source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
|
||||||
<location filename="../src/pages/appintopage.ui" line="429"/>
|
|
||||||
<location filename="../src/pages/appintopage.ui" line="432"/>
|
|
||||||
<source><html><head/><body><p>Capable to Ubuntu 20.04</p></body></html></source>
|
|
||||||
<translation type="unfinished"></translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/pages/appintopage.ui" line="435"/>
|
<location filename="../src/pages/appintopage.ui" line="435"/>
|
||||||
<source><html><head/><body><p><img src=":/tags/ubuntu-small.png"/></p></body></html></source>
|
<source><html><head/><body><p><img src=":/tags/ubuntu-small.png"/></p></body></html></source>
|
||||||
@@ -107,12 +102,6 @@
|
|||||||
<source><html><head/><body><p><img src=":/tags/a2d-small.png"/></p></body></html></source>
|
<source><html><head/><body><p><img src=":/tags/a2d-small.png"/></p></body></html></source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
|
||||||
<location filename="../src/pages/appintopage.ui" line="543"/>
|
|
||||||
<location filename="../src/pages/appintopage.ui" line="546"/>
|
|
||||||
<source><html><head/><body><p>A deepin-wine5 app.Spark Store will automatically configure the wine kit for you</p></body></html></source>
|
|
||||||
<translation type="unfinished"></translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/pages/appintopage.ui" line="549"/>
|
<location filename="../src/pages/appintopage.ui" line="549"/>
|
||||||
<source><html><head/><body><p><img src=":/tags/dwine5-small.png"/></p></body></html></source>
|
<source><html><head/><body><p><img src=":/tags/dwine5-small.png"/></p></body></html></source>
|
||||||
@@ -143,6 +132,18 @@
|
|||||||
<source>Screen capture</source>
|
<source>Screen capture</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="429"/>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="432"/>
|
||||||
|
<source><html><head/><body><p>Capable to Ubuntu 22.04</p></body></html></source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="543"/>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="546"/>
|
||||||
|
<source><html><head/><body><p>A Wine app.Spark Store will automatically configure the wine kit for you</p></body></html></source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/pages/appintopage.ui" line="1161"/>
|
<location filename="../src/pages/appintopage.ui" line="1161"/>
|
||||||
<source>Update</source>
|
<source>Update</source>
|
||||||
@@ -174,47 +175,51 @@
|
|||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/pages/appintopage.cpp" line="89"/>
|
<location filename="../src/pages/appintopage.cpp" line="47"/>
|
||||||
<source>Click Open</source>
|
<source>Click Open</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/pages/appintopage.cpp" line="132"/>
|
<location filename="../src/pages/appintopage.cpp" line="112"/>
|
||||||
<location filename="../src/pages/appintopage.cpp" line="224"/>
|
<source>Developer Mode Disabled</source>
|
||||||
<location filename="../src/pages/appintopage.cpp" line="316"/>
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.cpp" line="158"/>
|
||||||
|
<location filename="../src/pages/appintopage.cpp" line="331"/>
|
||||||
|
<location filename="../src/pages/appintopage.cpp" line="403"/>
|
||||||
<source>Reinstall</source>
|
<source>Reinstall</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/pages/appintopage.cpp" line="139"/>
|
<location filename="../src/pages/appintopage.cpp" line="165"/>
|
||||||
<source>Upgrade</source>
|
<source>Upgrade</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/pages/appintopage.cpp" line="214"/>
|
<location filename="../src/pages/appintopage.cpp" line="320"/>
|
||||||
<location filename="../src/pages/appintopage.cpp" line="308"/>
|
<location filename="../src/pages/appintopage.cpp" line="379"/>
|
||||||
<location filename="../src/pages/appintopage.cpp" line="341"/>
|
|
||||||
<source>Install</source>
|
<source>Install</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/pages/appintopage.cpp" line="219"/>
|
<location filename="../src/pages/appintopage.cpp" line="325"/>
|
||||||
<source>Installing</source>
|
<source>Installing</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/pages/appintopage.cpp" line="345"/>
|
<location filename="../src/pages/appintopage.cpp" line="434"/>
|
||||||
<location filename="../src/pages/appintopage.cpp" line="356"/>
|
<location filename="../src/pages/appintopage.cpp" line="447"/>
|
||||||
<source>Spark Store</source>
|
<source>Spark Store</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/pages/appintopage.cpp" line="345"/>
|
<location filename="../src/pages/appintopage.cpp" line="434"/>
|
||||||
<source>Uninstall succeeded</source>
|
<source>Uninstall succeeded</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/pages/appintopage.cpp" line="356"/>
|
<location filename="../src/pages/appintopage.cpp" line="447"/>
|
||||||
<source>The URL has been copied to the clipboard</source>
|
<source>The URL has been copied to the clipboard</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
@@ -232,102 +237,121 @@
|
|||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
</context>
|
</context>
|
||||||
|
<context>
|
||||||
|
<name>DAboutDialog</name>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/application.cpp" line="133"/>
|
||||||
|
<source>Version: %1</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/application.cpp" line="143"/>
|
||||||
|
<source>%1 is released under %2</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
</context>
|
||||||
<context>
|
<context>
|
||||||
<name>DownloadItem</name>
|
<name>DownloadItem</name>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.ui" line="20"/>
|
<location filename="../src/widgets/common/downloaditem.ui" line="32"/>
|
||||||
<source>Form</source>
|
<source>Form</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.ui" line="50"/>
|
<location filename="../src/widgets/common/downloaditem.ui" line="74"/>
|
||||||
<source>icon</source>
|
<source>icon</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.ui" line="82"/>
|
<location filename="../src/widgets/common/downloaditem.ui" line="134"/>
|
||||||
<source>TextLabel</source>
|
<source>TextLabel</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.ui" line="106"/>
|
<location filename="../src/widgets/common/downloaditem.ui" line="121"/>
|
||||||
<source>Name</source>
|
<source>Name</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.ui" line="198"/>
|
<location filename="../src/widgets/common/downloaditem.ui" line="226"/>
|
||||||
<source>Waiting to download</source>
|
<source>Waiting to download</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.ui" line="249"/>
|
<location filename="../src/widgets/common/downloaditem.ui" line="277"/>
|
||||||
<source>Install</source>
|
<source>Install</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.ui" line="268"/>
|
<location filename="../src/widgets/common/downloaditem.ui" line="296"/>
|
||||||
<source>Cancel</source>
|
<source>Cancel</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.ui" line="287"/>
|
<location filename="../src/widgets/common/downloaditem.ui" line="315"/>
|
||||||
<source>Info</source>
|
<source>Info</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.cpp" line="40"/>
|
<location filename="../src/widgets/common/downloaditem.cpp" line="43"/>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.cpp" line="44"/>
|
||||||
<source>Download Complete.</source>
|
<source>Download Complete.</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.cpp" line="142"/>
|
<location filename="../src/widgets/common/downloaditem.cpp" line="213"/>
|
||||||
<location filename="../src/widgets/common/downloaditem.cpp" line="152"/>
|
<location filename="../src/widgets/common/downloaditem.cpp" line="224"/>
|
||||||
<location filename="../src/widgets/common/downloaditem.cpp" line="159"/>
|
<location filename="../src/widgets/common/downloaditem.cpp" line="232"/>
|
||||||
<source>Spark Store</source>
|
<source>Spark Store</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.cpp" line="99"/>
|
<location filename="../src/widgets/common/downloaditem.cpp" line="125"/>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.cpp" line="126"/>
|
||||||
<source>Installing</source>
|
<source>Installing</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.cpp" line="142"/>
|
<location filename="../src/widgets/common/downloaditem.cpp" line="213"/>
|
||||||
<source>Installation complete.</source>
|
<source>Installation complete.</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.cpp" line="143"/>
|
<location filename="../src/widgets/common/downloaditem.cpp" line="214"/>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.cpp" line="215"/>
|
||||||
<source>Finish</source>
|
<source>Finish</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.cpp" line="150"/>
|
<location filename="../src/widgets/common/downloaditem.cpp" line="222"/>
|
||||||
<source>Retry</source>
|
<source>Retry</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.cpp" line="152"/>
|
<location filename="../src/widgets/common/downloaditem.cpp" line="224"/>
|
||||||
<source>Error happened in dpkg progress , you can try it again.</source>
|
<source>Error happened in dpkg progress , you can try it again.</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.cpp" line="153"/>
|
<location filename="../src/widgets/common/downloaditem.cpp" line="225"/>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.cpp" line="226"/>
|
||||||
<source>Error happened in dpkg progress , you can try it again</source>
|
<source>Error happened in dpkg progress , you can try it again</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.cpp" line="159"/>
|
<location filename="../src/widgets/common/downloaditem.cpp" line="232"/>
|
||||||
<source>dpkg progress had been aborted,you can retry installation.</source>
|
<source>dpkg progress had been aborted,you can retry installation.</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.cpp" line="160"/>
|
<location filename="../src/widgets/common/downloaditem.cpp" line="233"/>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.cpp" line="234"/>
|
||||||
<source>dpkg progress had been aborted,you can retry installation</source>
|
<source>dpkg progress had been aborted,you can retry installation</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/common/downloaditem.cpp" line="181"/>
|
<location filename="../src/widgets/common/downloaditem.cpp" line="144"/>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.cpp" line="145"/>
|
||||||
<source>Download canceled</source>
|
<source>Download canceled</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
@@ -345,7 +369,7 @@
|
|||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/widgets/downloadlistwidget.ui" line="110"/>
|
<location filename="../src/widgets/downloadlistwidget.ui" line="116"/>
|
||||||
<source>Open download directory</source>
|
<source>Open download directory</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
@@ -358,152 +382,134 @@
|
|||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.ui" line="160"/>
|
<location filename="../src/mainwindow-dtk.ui" line="166"/>
|
||||||
<source>Home</source>
|
<source>Home</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.ui" line="197"/>
|
<location filename="../src/mainwindow-dtk.ui" line="203"/>
|
||||||
<source>Network</source>
|
<source>Network</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.ui" line="225"/>
|
<location filename="../src/mainwindow-dtk.ui" line="231"/>
|
||||||
<source>Chat</source>
|
<source>Chat</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.ui" line="253"/>
|
<location filename="../src/mainwindow-dtk.ui" line="259"/>
|
||||||
<source>Music</source>
|
<source>Music</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.ui" line="281"/>
|
<location filename="../src/mainwindow-dtk.ui" line="287"/>
|
||||||
<source>Video</source>
|
<source>Video</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.ui" line="309"/>
|
<location filename="../src/mainwindow-dtk.ui" line="315"/>
|
||||||
<source>Picture</source>
|
<source>Picture</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.ui" line="337"/>
|
<location filename="../src/mainwindow-dtk.ui" line="343"/>
|
||||||
<source>Game</source>
|
<source>Game</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.ui" line="365"/>
|
<location filename="../src/mainwindow-dtk.ui" line="371"/>
|
||||||
<source>Office</source>
|
<source>Office</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.ui" line="393"/>
|
<location filename="../src/mainwindow-dtk.ui" line="399"/>
|
||||||
<source>Reading</source>
|
<source>Reading</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.ui" line="421"/>
|
<location filename="../src/mainwindow-dtk.ui" line="427"/>
|
||||||
<source>Development</source>
|
<source>Development</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.ui" line="449"/>
|
<location filename="../src/mainwindow-dtk.ui" line="455"/>
|
||||||
<source>Tool</source>
|
<source>Tool</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.ui" line="477"/>
|
<location filename="../src/mainwindow-dtk.ui" line="483"/>
|
||||||
<source>Theme</source>
|
<source>Theme</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.ui" line="505"/>
|
<location filename="../src/mainwindow-dtk.ui" line="511"/>
|
||||||
<source>Other</source>
|
<source>Other</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.ui" line="533"/>
|
<location filename="../src/mainwindow-dtk.ui" line="539"/>
|
||||||
<source>APP Upgrade</source>
|
<source>APP Upgrade</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.cpp" line="34"/>
|
<location filename="../src/mainwindow-dtk.cpp" line="170"/>
|
||||||
<source>Submit App</source>
|
<source>Submit App</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.cpp" line="35"/>
|
<location filename="../src/mainwindow-dtk.cpp" line="171"/>
|
||||||
<source>Submit App with client(Recommanded)</source>
|
<source>Submit App with client(Recommanded)</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.cpp" line="36"/>
|
<location filename="../src/mainwindow-dtk.cpp" line="172"/>
|
||||||
<source>Settings</source>
|
<source>Settings</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.cpp" line="37"/>
|
<location filename="../src/mainwindow-dtk.cpp" line="173"/>
|
||||||
<source>APP Upgrade and Install Settings</source>
|
<source>APP Upgrade and Install Settings</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.cpp" line="158"/>
|
<location filename="../src/mainwindow-dtk.cpp" line="129"/>
|
||||||
|
<location filename="../src/mainwindow-dtk.cpp" line="224"/>
|
||||||
<source>Spark Store</source>
|
<source>Spark Store</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/mainwindow-dtk.cpp" line="159"/>
|
<location filename="../src/mainwindow-dtk.cpp" line="134"/>
|
||||||
<source>Search or enter spk://</source>
|
<source>Search or enter spk://</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
</context>
|
</context>
|
||||||
<context>
|
|
||||||
<name>QLabel</name>
|
|
||||||
<message>
|
|
||||||
<source>Spark应用商店</source>
|
|
||||||
<translation type="vanished">Spark Store</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>社区驱动的一款为第三方应用商店,为改变而生
|
|
||||||
本程序按GPL第三版开源</source>
|
|
||||||
<translation type="vanished">Un app store tier alimenté par la communauté Deepin
|
|
||||||
Spark Store est publié sous licence GPL V3
|
|
||||||
Nous sommes nés pour le changement.</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<location filename="../src/main.cpp" line="64"/>
|
|
||||||
<location filename="../src/main.cpp" line="73"/>
|
|
||||||
<source>Spark Store</source>
|
|
||||||
<translation type="unfinished"></translation>
|
|
||||||
</message>
|
|
||||||
</context>
|
|
||||||
<context>
|
<context>
|
||||||
<name>QObject</name>
|
<name>QObject</name>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/main.cpp" line="61"/>
|
<location filename="../src/application.cpp" line="33"/>
|
||||||
<source>We publish this program under GPL V3</source>
|
<location filename="../src/application.cpp" line="34"/>
|
||||||
<translation type="unfinished"></translation>
|
<location filename="../src/mainwindow-dtk.cpp" line="109"/>
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<location filename="../src/main.cpp" line="66"/>
|
|
||||||
<source><span style=' font-size:10pt;font-weight:60;'>An appstore powered by community</span><br/><a href='https://www.spark-app.store/'>https://www.spark-app.store</a><br/><span style=' font-size:12pt;'>Spark developers</span></source>
|
|
||||||
<translation type="unfinished"></translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<location filename="../src/main.cpp" line="75"/>
|
|
||||||
<source>The Spark Project</source>
|
|
||||||
<translation type="unfinished"></translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<location filename="../src/main.cpp" line="79"/>
|
|
||||||
<location filename="../src/main.cpp" line="81"/>
|
|
||||||
<source>Spark Store</source>
|
<source>Spark Store</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/main.cpp" line="84"/>
|
<location filename="../src/application.cpp" line="38"/>
|
||||||
<source><span style='font-size:10pt;font-weight:60;'>An appstore powered by deepin community</span><br/><a href='https://www.spark-app.store/'>https://www.spark-app.store</a><br/><span style='font-size:12pt;'>Spark developers</span><br/><br/>Published under GPL V3</source>
|
<source><span style=' font-size:10pt;font-weight:60;'>An appstore powered by community</span><br/><a href='https://www.spark-app.store/'>https://www.spark-app.store</a><br/><span style=' font-size:12pt;'>Spark developers</span></source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/application.cpp" line="140"/>
|
||||||
|
<source>Spark Project</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/widgets/downloadlistwidget.cpp" line="17"/>
|
||||||
|
<source>Download list</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/mainwindow-dtk.cpp" line="227"/>
|
||||||
|
<source>Show MainWindow</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
</context>
|
</context>
|
||||||
@@ -595,212 +601,32 @@ Nous sommes nés pour le changement.</translation>
|
|||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/pages/settingspage.cpp" line="181"/>
|
<location filename="../src/pages/settingspage.cpp" line="213"/>
|
||||||
<source>Updating, please wait...</source>
|
<source>Updating, please wait...</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/pages/settingspage.cpp" line="204"/>
|
<location filename="../src/pages/settingspage.cpp" line="235"/>
|
||||||
<source>Spark Store</source>
|
<source>Spark Store</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="../src/pages/settingspage.cpp" line="204"/>
|
<location filename="../src/pages/settingspage.cpp" line="235"/>
|
||||||
<source>Temporary cache was cleaned</source>
|
<source>Temporary cache was cleaned</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
</context>
|
</context>
|
||||||
<context>
|
<context>
|
||||||
<name>Widget</name>
|
<name>TitleBarMenu</name>
|
||||||
<message>
|
<message>
|
||||||
<source>视频播放</source>
|
<location filename="../src/mainwindow-dtk.cpp" line="228"/>
|
||||||
<translatorcomment>Lecteurs vidéo et créateurs vidéo</translatorcomment>
|
<source>About</source>
|
||||||
<translation type="vanished">Vidéo</translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>下载列表</source>
|
<location filename="../src/mainwindow-dtk.cpp" line="229"/>
|
||||||
<translation type="vanished">Liste de téléchargement</translation>
|
<source>Exit</source>
|
||||||
</message>
|
<translation type="unfinished"></translation>
|
||||||
<message>
|
|
||||||
<source>系统工具</source>
|
|
||||||
<translation type="vanished">Outils</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>主题美化</source>
|
|
||||||
<translatorcomment>Thème des icônes et autres </translatorcomment>
|
|
||||||
<translation type="vanished">Thèmes</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>音乐欣赏</source>
|
|
||||||
<translation type="vanished">Musique</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>编程开发</source>
|
|
||||||
<translation type="vanished">Développement</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>办公学习</source>
|
|
||||||
<translation type="vanished">Bureau</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>阅读翻译</source>
|
|
||||||
<translation type="vanished">Traduire</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>其他应用</source>
|
|
||||||
<translation type="vanished">Autres</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>商店首页</source>
|
|
||||||
<translation type="vanished">Accueil</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>图形图像</source>
|
|
||||||
<translation type="vanished">Images</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>游戏娱乐</source>
|
|
||||||
<translation type="vanished">Jeux</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>社交沟通</source>
|
|
||||||
<translation type="vanished">Chat</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>网络应用</source>
|
|
||||||
<translation type="vanished">Réseau</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>当前下载列表为空</source>
|
|
||||||
<translation type="vanished">La liste de téléchargement est vide</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>打开文件夹</source>
|
|
||||||
<translation type="vanished">Ouvrir dans le gestionnaire de fichiers</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>安装</source>
|
|
||||||
<translation type="vanished">Installer</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>卸载</source>
|
|
||||||
<translation type="vanished">Supprimer</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>官网</source>
|
|
||||||
<translation type="vanished">Site</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>软件名</source>
|
|
||||||
<translation type="vanished">Nom</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>图标</source>
|
|
||||||
<translation type="vanished">Icon</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>分享</source>
|
|
||||||
<translation type="vanished">Partager</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>详细介绍</source>
|
|
||||||
<translation type="vanished">Détails</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source><html><head/><body><p>由社区爱好者开发的软件商店</p></body></html></source>
|
|
||||||
<translation type="vanished"><html><head/><body><p>magasin de logiciels développé par des passionnés de la communauté</p></body></html></translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>软件截图</source>
|
|
||||||
<translation type="vanished">Captures d'écran</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>线路设置</source>
|
|
||||||
<translation type="vanished">Line Settings</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>线路选择:</source>
|
|
||||||
<translation type="vanished">Choisissez: </translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>刷新</source>
|
|
||||||
<translation type="vanished">Mise à jour</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source> 重启商店后生效</source>
|
|
||||||
<translation type="vanished">Redémarrez pour prendre effet</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source><html><head/><body><p>源服务器的作用是保证软件更新,并且支持使用apt工具获取软件。通常我们更建议你使用第一个线路作为更新源,一般是最稳定的。</p></body></html></source>
|
|
||||||
<translation type="vanished"><html><head/><body><p>Le rôle du serveur source est de s'assurer que le logiciel est mis à jour et prend en charge l'utilisation de l'outil apt pour obtenir le logiciel. Nous préférons généralement que vous utilisiez la première ligne comme source de mise à jour, qui est généralement la plus stable. </p></body></html></translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>更新源</source>
|
|
||||||
<translation type="vanished">Mettre à jour la source APT</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>更新源服务器:</source>
|
|
||||||
<translation type="vanished">Source APT: </translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>服务器</source>
|
|
||||||
<translation type="vanished">serveur</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>缓存目录</source>
|
|
||||||
<translation type="vanished">Temp</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>清空</source>
|
|
||||||
<translation type="vanished">Nettoyer</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>因为这个目录位于/tmp下,所以即使你不手动清空的话,其也将在系统重启时自动清空。</source>
|
|
||||||
<translation type="vanished">Étant donné que ce répertoire se trouve sous /tmp, même si vous ne l'effacez pas manuellement, il sera effacé automatiquement au redémarrage du système.</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>目录大小:</source>
|
|
||||||
<translation type="vanished">Taille: </translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>0B</source>
|
|
||||||
<translation type="obsolete">0B</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>目录位置:/tmp/spark-store</source>
|
|
||||||
<translation type="vanished">Emplacement:/tmp/spark-store</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>关于我们</source>
|
|
||||||
<translation type="vanished">À propos de nous</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source><html><head/><body><p>我们并不是官方团队,和你一样,我们也只是众多Linux/deepin系统爱好者和用户之中的一员,我们开发并且运营这个“Spark应用商店”,是为了让社区的朋友们一起分享好用的软件,或者一起参与开发,让大家都用到最新的,最优秀的软件。</p><p>我们并没有因此盈利,所有开发和维护人员都不会获得报酬,我们的主要支出大部分依赖于社区对我们的捐助,很感谢大家,这部分捐助让我们并不需要耗费太多精力去担心资金问题。</p><p>我们的服务和开发的软件都是免费供给大家使用,交流,学习的,但是在您的使用过程中一定要遵守当地的法律法规,否则出现任何问题和我们无关。</p><p>如果商店中任何一部分有侵犯您权益的行为,请告知我们&lt;jifengshenmo@outlook.com&gt;,我们会第一时间删除侵权内容。</p><p>如果你也想参与我们,不管是参与开发,设计,投递还是投稿作品,我们都欢迎你的加入。</p><p>QQ群:872690351<br/></p></body></html></source>
|
|
||||||
<translation type="vanished"><html><head/><body><p>Nous ne sommes pas l'équipe officielle, tout comme vous, nous ne sommes qu'un des nombreux passionnés et utilisateurs de systèmes Linux / deepin, nous développons et gérons le "Spark Store"! ", est de rassembler la communauté pour partager des logiciels utiles, ou pour participer au développement ensemble, afin que nous utilisions tous les derniers et meilleurs logiciels. </p><p> Nous n'en tirons aucun profit, tous les développeurs et mainteneurs ne sont pas payés, et nous comptons sur les dons de la communauté pour la plupart de nos dépenses, dont nous sommes reconnaissants et qui nous permettent de ne pas dépenser trop d'énergie se soucier du financement. </p><p>Notre service et nos logiciels sont gratuits pour tout le monde à utiliser, à communiquer et à apprendre, mais vous devez vous conformer aux lois et réglementations locales dans le processus de votre utilisation, sinon tout problème n'a rien à voir avec nous. </p><p>Si une partie du magasin enfreint vos droits, veuillez nous en informer &lt;jifengshenmo@outlook.com&gt; nous retirerons le contenu en infraction dès que possible. </p><p>Si vous souhaitez également vous impliquer avec nous, que vous soyez impliqué dans le développement, la conception, le pitching ou la soumission de travaux, nous vous invitons à nous rejoindre. </p><p>QQ group:872690351<br/></p></body></html></translation>
|
|
||||||
</message>
|
|
||||||
</context>
|
|
||||||
<context>
|
|
||||||
<name>downloadlist</name>
|
|
||||||
<message>
|
|
||||||
<source>名称</source>
|
|
||||||
<translation type="vanished">Nom</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>等待开始下载</source>
|
|
||||||
<translatorcomment>Attendez pour téléchargerd</translatorcomment>
|
|
||||||
<translation type="vanished">Attendez pour télécharger</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>安装</source>
|
|
||||||
<translation type="vanished">Installer</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>取消</source>
|
|
||||||
<translation type="vanished">Annuler</translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
|
||||||
<source>详情</source>
|
|
||||||
<translation type="vanished">Détail</translation>
|
|
||||||
</message>
|
</message>
|
||||||
</context>
|
</context>
|
||||||
</TS>
|
</TS>
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
632
translations/spark-store_zh_TW.ts
Normal file
632
translations/spark-store_zh_TW.ts
Normal file
@@ -0,0 +1,632 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!DOCTYPE TS>
|
||||||
|
<TS version="2.1" language="zh_TW">
|
||||||
|
<context>
|
||||||
|
<name>AppIntoPage</name>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="14"/>
|
||||||
|
<source>Form</source>
|
||||||
|
<translation></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="244"/>
|
||||||
|
<location filename="../src/pages/appintopage.cpp" line="173"/>
|
||||||
|
<location filename="../src/pages/appintopage.cpp" line="315"/>
|
||||||
|
<location filename="../src/pages/appintopage.cpp" line="430"/>
|
||||||
|
<source>Download</source>
|
||||||
|
<translation>下载</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="290"/>
|
||||||
|
<source>Uninstall</source>
|
||||||
|
<translation>移除安裝</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="346"/>
|
||||||
|
<source>0</source>
|
||||||
|
<translation></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="356"/>
|
||||||
|
<source>Download Times</source>
|
||||||
|
<translation>下載次數</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="410"/>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="413"/>
|
||||||
|
<source><html><head/><body><p>This app is developed by community user,we give this tag to honor those who contribute to the Linux Ecology</p></body></html></source>
|
||||||
|
<translation><html><head/><body><p>这款应用是社区开发者开发的,我们为社区开发者颁发这款勋章以表彰他们对Linux生态的贡献</p></body></html></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="416"/>
|
||||||
|
<source><html><head/><body><p><img src=":/tags/community-small.png"/></p></body></html></source>
|
||||||
|
<translation></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="435"/>
|
||||||
|
<source><html><head/><body><p><img src=":/tags/ubuntu-small.png"/></p></body></html></source>
|
||||||
|
<translation></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="448"/>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="451"/>
|
||||||
|
<source><html><head/><body><p>Capable to UOS home 20</p></body></html></source>
|
||||||
|
<translation><html><head/><body><p>支持UOS家庭版 20</p></body></html></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="454"/>
|
||||||
|
<source><html><head/><body><p><img src=":/tags/uos-small.png"/></p></body></html></source>
|
||||||
|
<translation></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="467"/>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="470"/>
|
||||||
|
<source><html><head/><body><p>A deepin-wine2 app. Spark Store will automatically configure the wine kit for you.</p></body></html></source>
|
||||||
|
<translation>这是一款 deepin-wine2 应用。星火商店会为你自动配置wine环境</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="473"/>
|
||||||
|
<source><html><head/><body><p><img src=":/tags/dwine2-small.png"/></p></body></html></source>
|
||||||
|
<translation></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="486"/>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="489"/>
|
||||||
|
<source><html><head/><body><p>This is a DTK5 app,which means it would have better effect on Deepin Desktop Environment</p></body></html></source>
|
||||||
|
<translation><html><head/><body><p>这是一款DTK5应用,请使用深度桌面环境来获得最完美的体验</p></body></html></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="492"/>
|
||||||
|
<source><html><head/><body><p><img src=":/tags/dtk-small.png"/></p></body></html></source>
|
||||||
|
<translation></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="505"/>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="508"/>
|
||||||
|
<source><html><head/><body><p>Capable to deepin 20</p></body></html></source>
|
||||||
|
<translation><html><head/><body><p>支持deepin 20</p></body></html></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="511"/>
|
||||||
|
<source><html><head/><body><p><img src=":/tags/deepin-small.png"/></p></body></html></source>
|
||||||
|
<translation></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="524"/>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="527"/>
|
||||||
|
<source><html><head/><body><p>An Appimage to deb app.</p></body></html></source>
|
||||||
|
<translation><html><head/><body><p>这是一款Appimage转制应用.</p></body></html></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="530"/>
|
||||||
|
<source><html><head/><body><p><img src=":/tags/a2d-small.png"/></p></body></html></source>
|
||||||
|
<translation></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="549"/>
|
||||||
|
<source><html><head/><body><p><img src=":/tags/dwine5-small.png"/></p></body></html></source>
|
||||||
|
<translation></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="602"/>
|
||||||
|
<source>Share</source>
|
||||||
|
<translation>Spk共享链接</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="609"/>
|
||||||
|
<source>APP Feedback</source>
|
||||||
|
<translation>軟件錯誤回報</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="1068"/>
|
||||||
|
<source>Description</source>
|
||||||
|
<translation>軟體詳細資料</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="903"/>
|
||||||
|
<source>Screen capture</source>
|
||||||
|
<translation>軟體演示</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="429"/>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="432"/>
|
||||||
|
<source><html><head/><body><p>Capable to Ubuntu 22.04</p></body></html></source>
|
||||||
|
<translation><html><head/><body><p>支持Ubuntu 22.04</p></body></html></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="543"/>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="546"/>
|
||||||
|
<source><html><head/><body><p>A Wine app.Spark Store will automatically configure the wine kit for you</p></body></html></source>
|
||||||
|
<translation>这是一款 Wine 应用。星火商店会为你自动配置wine环境</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="765"/>
|
||||||
|
<source>Introduction</source>
|
||||||
|
<translation>軟體介紹</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="1161"/>
|
||||||
|
<source>Update</source>
|
||||||
|
<translation>更新时间</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="1190"/>
|
||||||
|
<source>Contributor</source>
|
||||||
|
<translation>投稿用户</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="1197"/>
|
||||||
|
<source>Pkgname</source>
|
||||||
|
<translation>软件包名</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="1303"/>
|
||||||
|
<source>Author</source>
|
||||||
|
<translation>软件作者</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="1339"/>
|
||||||
|
<source>Size</source>
|
||||||
|
<translation>软件大小</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.ui" line="1375"/>
|
||||||
|
<source>Website</source>
|
||||||
|
<translation>软件官网</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.cpp" line="47"/>
|
||||||
|
<source>Click Open</source>
|
||||||
|
<translation>点击跳转</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.cpp" line="112"/>
|
||||||
|
<source>Developer Mode Disabled</source>
|
||||||
|
<translation>开发者模式未开启</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.cpp" line="158"/>
|
||||||
|
<location filename="../src/pages/appintopage.cpp" line="331"/>
|
||||||
|
<location filename="../src/pages/appintopage.cpp" line="403"/>
|
||||||
|
<source>Reinstall</source>
|
||||||
|
<translation>重新安裝</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.cpp" line="165"/>
|
||||||
|
<source>Upgrade</source>
|
||||||
|
<translation>升级</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.cpp" line="320"/>
|
||||||
|
<location filename="../src/pages/appintopage.cpp" line="379"/>
|
||||||
|
<source>Install</source>
|
||||||
|
<translation>安装</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.cpp" line="325"/>
|
||||||
|
<source>Installing</source>
|
||||||
|
<translation>正在安装</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.cpp" line="434"/>
|
||||||
|
<location filename="../src/pages/appintopage.cpp" line="447"/>
|
||||||
|
<source>Spark Store</source>
|
||||||
|
<translation>星火应用商店</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.cpp" line="434"/>
|
||||||
|
<source>Uninstall succeeded</source>
|
||||||
|
<translation>卸载成功</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/appintopage.cpp" line="447"/>
|
||||||
|
<source>The URL has been copied to the clipboard</source>
|
||||||
|
<translation>链接已复制到剪贴板</translation>
|
||||||
|
</message>
|
||||||
|
</context>
|
||||||
|
<context>
|
||||||
|
<name>AppListPage</name>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/applistpage.ui" line="14"/>
|
||||||
|
<source>Form</source>
|
||||||
|
<translation></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/applistpage.ui" line="60"/>
|
||||||
|
<source>about:blank</source>
|
||||||
|
<translation></translation>
|
||||||
|
</message>
|
||||||
|
</context>
|
||||||
|
<context>
|
||||||
|
<name>DAboutDialog</name>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/application.cpp" line="133"/>
|
||||||
|
<source>Version: %1</source>
|
||||||
|
<translation>版本:%1</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/application.cpp" line="143"/>
|
||||||
|
<source>%1 is released under %2</source>
|
||||||
|
<translation>%1遵循%2协议发布</translation>
|
||||||
|
</message>
|
||||||
|
</context>
|
||||||
|
<context>
|
||||||
|
<name>DownloadItem</name>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.ui" line="32"/>
|
||||||
|
<source>Form</source>
|
||||||
|
<translation></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.ui" line="74"/>
|
||||||
|
<source>icon</source>
|
||||||
|
<translation></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.ui" line="134"/>
|
||||||
|
<source>TextLabel</source>
|
||||||
|
<translation></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.ui" line="121"/>
|
||||||
|
<source>Name</source>
|
||||||
|
<translation>软件名</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.ui" line="226"/>
|
||||||
|
<source>Waiting to download</source>
|
||||||
|
<translation>正在等待下载</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.ui" line="277"/>
|
||||||
|
<source>Install</source>
|
||||||
|
<translation>安裝</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.ui" line="296"/>
|
||||||
|
<source>Cancel</source>
|
||||||
|
<translation>取消</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.ui" line="315"/>
|
||||||
|
<source>Info</source>
|
||||||
|
<translation>详情</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.cpp" line="43"/>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.cpp" line="44"/>
|
||||||
|
<source>Download Complete.</source>
|
||||||
|
<translation>下載完成.</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.cpp" line="213"/>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.cpp" line="224"/>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.cpp" line="232"/>
|
||||||
|
<source>Spark Store</source>
|
||||||
|
<translation>星火应用商店</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.cpp" line="125"/>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.cpp" line="126"/>
|
||||||
|
<source>Installing</source>
|
||||||
|
<translation>正在安裝</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.cpp" line="213"/>
|
||||||
|
<source>Installation complete.</source>
|
||||||
|
<translation>安裝完成.</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.cpp" line="214"/>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.cpp" line="215"/>
|
||||||
|
<source>Finish</source>
|
||||||
|
<translation>完成</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.cpp" line="222"/>
|
||||||
|
<source>Retry</source>
|
||||||
|
<translation>重试</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.cpp" line="224"/>
|
||||||
|
<source>Error happened in dpkg progress , you can try it again.</source>
|
||||||
|
<translation>安装被中止,可重新安装。</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.cpp" line="225"/>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.cpp" line="226"/>
|
||||||
|
<source>Error happened in dpkg progress , you can try it again</source>
|
||||||
|
<translation>dpkg出现错误,可重新安装</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.cpp" line="232"/>
|
||||||
|
<source>dpkg progress had been aborted,you can retry installation.</source>
|
||||||
|
<translation>dpkg进程被中断,您可重试安装。</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.cpp" line="233"/>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.cpp" line="234"/>
|
||||||
|
<source>dpkg progress had been aborted,you can retry installation</source>
|
||||||
|
<translation>安装被中止,可重新安装</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.cpp" line="144"/>
|
||||||
|
<location filename="../src/widgets/common/downloaditem.cpp" line="145"/>
|
||||||
|
<source>Download canceled</source>
|
||||||
|
<translation>下载已取消</translation>
|
||||||
|
</message>
|
||||||
|
</context>
|
||||||
|
<context>
|
||||||
|
<name>DownloadListWidget</name>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/widgets/downloadlistwidget.ui" line="14"/>
|
||||||
|
<source>Form</source>
|
||||||
|
<translation></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/widgets/downloadlistwidget.ui" line="41"/>
|
||||||
|
<source>The list is currently empty. Go and download some softwares!</source>
|
||||||
|
<translation>当前下载列表为空。去下载些软件吧!</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/widgets/downloadlistwidget.ui" line="116"/>
|
||||||
|
<source>Open download directory</source>
|
||||||
|
<translation>打开下载文件夹</translation>
|
||||||
|
</message>
|
||||||
|
</context>
|
||||||
|
<context>
|
||||||
|
<name>MainWindow</name>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/mainwindow-dtk.ui" line="14"/>
|
||||||
|
<source>MainWindow</source>
|
||||||
|
<translation></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/mainwindow-dtk.ui" line="166"/>
|
||||||
|
<source>Home</source>
|
||||||
|
<translation>首頁</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/mainwindow-dtk.ui" line="203"/>
|
||||||
|
<source>Network</source>
|
||||||
|
<translation>網路</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/mainwindow-dtk.ui" line="231"/>
|
||||||
|
<source>Chat</source>
|
||||||
|
<translation>聊天</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/mainwindow-dtk.ui" line="259"/>
|
||||||
|
<source>Music</source>
|
||||||
|
<translation>音樂</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/mainwindow-dtk.ui" line="287"/>
|
||||||
|
<source>Video</source>
|
||||||
|
<translation>播放</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/mainwindow-dtk.ui" line="315"/>
|
||||||
|
<source>Picture</source>
|
||||||
|
<translation>圖片</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/mainwindow-dtk.ui" line="343"/>
|
||||||
|
<source>Game</source>
|
||||||
|
<translation>遊戲</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/mainwindow-dtk.ui" line="371"/>
|
||||||
|
<source>Office</source>
|
||||||
|
<translation>辦公</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/mainwindow-dtk.ui" line="399"/>
|
||||||
|
<source>Reading</source>
|
||||||
|
<translation>閱讀</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/mainwindow-dtk.ui" line="427"/>
|
||||||
|
<source>Development</source>
|
||||||
|
<translation>開發</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/mainwindow-dtk.ui" line="455"/>
|
||||||
|
<source>Tool</source>
|
||||||
|
<translation>工具</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/mainwindow-dtk.ui" line="483"/>
|
||||||
|
<source>Theme</source>
|
||||||
|
<translation>主題</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/mainwindow-dtk.ui" line="511"/>
|
||||||
|
<source>Other</source>
|
||||||
|
<translation>其他</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/mainwindow-dtk.ui" line="539"/>
|
||||||
|
<source>APP Upgrade</source>
|
||||||
|
<translation>軟體更新</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/mainwindow-dtk.cpp" line="170"/>
|
||||||
|
<source>Submit App</source>
|
||||||
|
<translation>上傳軟體</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/mainwindow-dtk.cpp" line="171"/>
|
||||||
|
<source>Submit App with client(Recommanded)</source>
|
||||||
|
<translation>從客戶端上傳軟體(推薦的)</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/mainwindow-dtk.cpp" line="172"/>
|
||||||
|
<source>Settings</source>
|
||||||
|
<translation>設定</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/mainwindow-dtk.cpp" line="173"/>
|
||||||
|
<source>APP Upgrade and Install Settings</source>
|
||||||
|
<translation>軟體升級 和 安裝設定</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/mainwindow-dtk.cpp" line="129"/>
|
||||||
|
<location filename="../src/mainwindow-dtk.cpp" line="224"/>
|
||||||
|
<source>Spark Store</source>
|
||||||
|
<translation>星火应用商店</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/mainwindow-dtk.cpp" line="134"/>
|
||||||
|
<source>Search or enter spk://</source>
|
||||||
|
<translation>搜索或打开链接</translation>
|
||||||
|
</message>
|
||||||
|
</context>
|
||||||
|
<context>
|
||||||
|
<name>QObject</name>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/application.cpp" line="33"/>
|
||||||
|
<location filename="../src/application.cpp" line="34"/>
|
||||||
|
<location filename="../src/mainwindow-dtk.cpp" line="109"/>
|
||||||
|
<source>Spark Store</source>
|
||||||
|
<translation>星火应用商店</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/application.cpp" line="38"/>
|
||||||
|
<source><span style=' font-size:10pt;font-weight:60;'>An appstore powered by community</span><br/><a href='https://www.spark-app.store/'>https://www.spark-app.store</a><br/><span style=' font-size:12pt;'>Spark developers</span></source>
|
||||||
|
<translation><span style=' font-size:10pt;font-weight:60;'>一款由社区提供的应用商店</span><br/><a href='https://www.spark-app.store/'>https://www.spark-app.store</a><br/><span style=' font-size:12pt;'>星火计划开发者</span></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/application.cpp" line="140"/>
|
||||||
|
<source>Spark Project</source>
|
||||||
|
<translation>星火计划</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/widgets/downloadlistwidget.cpp" line="17"/>
|
||||||
|
<source>Download list</source>
|
||||||
|
<translation>下载列表</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/mainwindow-dtk.cpp" line="227"/>
|
||||||
|
<source>Show MainWindow</source>
|
||||||
|
<translation>显示主窗口</translation>
|
||||||
|
</message>
|
||||||
|
</context>
|
||||||
|
<context>
|
||||||
|
<name>SettingsPage</name>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/settingspage.ui" line="14"/>
|
||||||
|
<source>Form</source>
|
||||||
|
<translation></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/settingspage.ui" line="91"/>
|
||||||
|
<source>Line Settings</source>
|
||||||
|
<translation>线路设置</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/settingspage.ui" line="107"/>
|
||||||
|
<source>Choose Line:</source>
|
||||||
|
<translation>线路选择:</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/settingspage.ui" line="130"/>
|
||||||
|
<source>Refresh</source>
|
||||||
|
<translation>刷新</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/settingspage.ui" line="143"/>
|
||||||
|
<source>Take effect when restart</source>
|
||||||
|
<translation>重启商店后生效</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/settingspage.ui" line="185"/>
|
||||||
|
<source><html><head/><body><p>Check update for Spark Store. </p></body></html></source>
|
||||||
|
<translation>检查星火应用商店更新</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/settingspage.ui" line="202"/>
|
||||||
|
<source>Update</source>
|
||||||
|
<translation>更新</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/settingspage.ui" line="195"/>
|
||||||
|
<source>Spark Store Update</source>
|
||||||
|
<translation>星火应用商店更新检测</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/settingspage.ui" line="230"/>
|
||||||
|
<source>Temp</source>
|
||||||
|
<translation>缓存目录</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/settingspage.ui" line="243"/>
|
||||||
|
<source>Since the dictionary is at /tmp,It would be cleaned automatically when system reboot.</source>
|
||||||
|
<translation>因为这个目录位于/tmp下,所以即使你不手动清空的话,其也将在系统重启时自动清空。</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/settingspage.ui" line="250"/>
|
||||||
|
<source>0B</source>
|
||||||
|
<translation></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/settingspage.ui" line="257"/>
|
||||||
|
<source>Location:/tmp/spark-store</source>
|
||||||
|
<translation>目录位置:/tmp/spark-store</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/settingspage.ui" line="277"/>
|
||||||
|
<source>Clean</source>
|
||||||
|
<translation>清空</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/settingspage.ui" line="290"/>
|
||||||
|
<source>Size:</source>
|
||||||
|
<translation>目录大小:</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/settingspage.ui" line="297"/>
|
||||||
|
<source>Clear Web Cache</source>
|
||||||
|
<translation>清理网页缓存</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/settingspage.ui" line="318"/>
|
||||||
|
<source>About us</source>
|
||||||
|
<translation>关于我们</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/settingspage.ui" line="325"/>
|
||||||
|
<source><html><head/><body><p>We are <span style=" font-weight:600;">NOT</span> the official team, just like you, we are just one of the many Linux/deepin system enthusiasts and users, we develop and run the &quot;Spark Store&quot;! &quot;, is to bring the community together to share useful software, or to participate in development together, so that we all use the latest and greatest software. </p><p>We don't make a profit from this, all developers and maintainers don't get paid, and we rely on the community's donations to us for most of our expenses, which we are grateful for and which allow us not to spend too much energy worrying about funding. </p><p>Our service and software are free for everyone to use, communicate, and learn, but you must comply with local laws and regulations in the process of your use, otherwise any problems have nothing to do with us. </p><p>If any part of the store infringes your rights, please tell us &lt;jifengshenmo@outlook.com&gt; we will remove the infringing content as soon as possible. </p><p>If you'd like to get involved with us too, whether you're involved in development, design, pitching or submitting work, we welcome you to join us. </p><p>Connect us on Spark IM: <a href="https://chat.shenmo.tech"><span style=" text-decoration: underline; color:#0000ff;">https://chat.shenmo.tech<br/></span></a>Our QQ Group number:872690351</p></body></html></source>
|
||||||
|
<translation><html><head/><body><p>我们并<span style=" font-weight:600;">不是</span>官方团队,和你一样,我们也只是众多Linux/deepin系统爱好者和用户之中的一员,我们开发并且运营这个“Spark应用商店”,是为了让社区的朋友们一起分享好用的软件,或者一起参与开发,让大家都用到最新的,最优秀的软件。</p><p>我们并没有因此盈利,所有开发和维护人员都不会获得报酬,我们的主要支出大部分依赖于社区对我们的捐助,很感谢大家,这部分捐助让我们并不需要耗费太多精力去担心资金问题。</p><p>我们的服务和开发的软件都是免费供给大家使用,交流,学习的,但是在您的使用过程中一定要遵守当地的法律法规,否则出现任何问题和我们无关。</p><p>如果商店中任何一部分有侵犯您权益的行为,请告知我们 &lt;jifengshenmo@outlook.com&gt; ,我们会第一时间删除侵权内容。</p><p>如果你也想参与我们,不管是参与开发,设计,投递还是投稿作品,我们都欢迎你的加入。</p><p>在 Spark IM 联系我们:<a href="https://chat.shenmo.tech"><span style=" text-decoration: underline; color:#0000ff;">https://chat.shenmo.tech<br/></span></a>QQ 群:872690351</p></body></html></translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/settingspage.cpp" line="213"/>
|
||||||
|
<source>Updating, please wait...</source>
|
||||||
|
<translation>正在更新,请稍候……</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/settingspage.cpp" line="235"/>
|
||||||
|
<source>Spark Store</source>
|
||||||
|
<translation>星火应用商店</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/pages/settingspage.cpp" line="235"/>
|
||||||
|
<source>Temporary cache was cleaned</source>
|
||||||
|
<translation>缓存目录已清空</translation>
|
||||||
|
</message>
|
||||||
|
</context>
|
||||||
|
<context>
|
||||||
|
<name>TitleBarMenu</name>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/mainwindow-dtk.cpp" line="228"/>
|
||||||
|
<source>About</source>
|
||||||
|
<translation>关于</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="../src/mainwindow-dtk.cpp" line="229"/>
|
||||||
|
<source>Exit</source>
|
||||||
|
<translation>退出</translation>
|
||||||
|
</message>
|
||||||
|
</context>
|
||||||
|
</TS>
|
||||||
Reference in New Issue
Block a user