mirror of
https://gitee.com/spark-store-project/spark-store
synced 2025-12-14 04:42:03 +08:00
跟随到5.2
This commit is contained in:
140
widget.cpp
140
widget.cpp
@@ -24,14 +24,17 @@ Widget::Widget(QWidget *parent) :
|
||||
{
|
||||
QString serverUrl;
|
||||
std::fstream server;
|
||||
|
||||
ui->setupUi(this);
|
||||
ui->webView->page()->setLinkDelegationPolicy(QWebPage::DelegateAllLinks);//用来激活接受linkClicked信号
|
||||
ui->webView->page()->settings()->setAttribute(QWebSettings::JavascriptEnabled,true);
|
||||
ui->stackedWidget->setCurrentIndex(0);
|
||||
ui->listWidget->hide();
|
||||
ui->label_setting1->hide();
|
||||
ui->pushButton_5->hide();
|
||||
ui->line1_widget->setStyleSheet("background-color:#808080");
|
||||
ui->line2_widget->setStyleSheet("background-color:#808080");
|
||||
manager = new QNetworkAccessManager(this);
|
||||
//初始化菜单数组
|
||||
left_list[0]=ui->menu_btn_main;left_menu_bg[0]=ui->menu_bg_main;
|
||||
left_list[1]=ui->menu_btn_network;left_menu_bg[1]=ui->menu_bg_network;
|
||||
left_list[2]=ui->menu_btn_chat;left_menu_bg[2]=ui->menu_bg_chat;
|
||||
@@ -47,30 +50,25 @@ Widget::Widget(QWidget *parent) :
|
||||
left_list[12]=ui->menu_btn_theme;left_menu_bg[12]=ui->menu_bg_theme;
|
||||
left_list[13]=ui->menu_btn_download;left_menu_bg[13]=ui->menu_bg_download;
|
||||
left_list[14]=ui->menu_btn_settings;left_menu_bg[14]=ui->menu_bg_settings;
|
||||
server.open(QDir::homePath().toUtf8()+"/.config/deepin-community-store/server.list",std::ios::in);
|
||||
// system("mkdir /etc/deepin-community-store/");
|
||||
// server.open("/etc/deepin-community-store/server.list",std::ios::in);
|
||||
std::string lineTmp;
|
||||
|
||||
server.open(QDir::homePath().toUtf8()+"/.config/spark-store/server.list",std::ios::in);
|
||||
std::string lineTmp;
|
||||
if(server){
|
||||
while (getline(server,lineTmp)) {
|
||||
ui->comboBox_server->addItem(QString::fromStdString(lineTmp));
|
||||
}
|
||||
}else {
|
||||
ui->comboBox_server->addItem("http://dcstore.shenmo.tech/");
|
||||
ui->comboBox_server->addItem("http://store.jerrywang.top/");
|
||||
}
|
||||
|
||||
QSettings readConfig(QDir::homePath()+"/.config/deepin-community-store/config.ini",QSettings::IniFormat);
|
||||
QSettings readConfig(QDir::homePath()+"/.config/spark-store/config.ini",QSettings::IniFormat);
|
||||
if(readConfig.value("server/choose").toString()!=""){
|
||||
ui->comboBox_server->setCurrentText(readConfig.value("server/choose").toString());
|
||||
serverUrl=readConfig.value("server/choose").toString();
|
||||
}else {
|
||||
serverUrl="http://dcstore.shenmo.tech/";
|
||||
serverUrl="http://store.jerrywang.top/";
|
||||
}
|
||||
configCanSeve=true;
|
||||
qDebug()<<serverUrl;
|
||||
menuUrl[0]=serverUrl + "store/#/";
|
||||
// menuUrl[0]="http://127.0.0.1:8000/#/relations";
|
||||
menuUrl[1]=serverUrl + "store/#/network/";
|
||||
menuUrl[2]=serverUrl + "store/#/relations";
|
||||
menuUrl[3]=serverUrl + "store/#/musicandsound";
|
||||
@@ -83,21 +81,23 @@ Widget::Widget(QWidget *parent) :
|
||||
menuUrl[10]=serverUrl + "store/#/tools/";
|
||||
menuUrl[11]=serverUrl + "store/#/others/";
|
||||
menuUrl[12]=serverUrl + "store/#/themes";
|
||||
configCanSeve=true;
|
||||
qDebug()<<serverUrl;
|
||||
|
||||
ui->webView->setUrl(menuUrl[0]);
|
||||
for (int i =0; i<15;i++){
|
||||
download_list[i].num=i;
|
||||
}
|
||||
//分界线
|
||||
QGraphicsOpacityEffect *opacityEffect_1=new QGraphicsOpacityEffect;
|
||||
QGraphicsOpacityEffect *opacityEffect_2=new QGraphicsOpacityEffect;
|
||||
ui->line1_widget->setStyleSheet("background-color:#808080");
|
||||
ui->line2_widget->setStyleSheet("background-color:#808080");
|
||||
opacityEffect_1->setOpacity(0.2);
|
||||
opacityEffect_2->setOpacity(0.2);
|
||||
ui->line1_widget->setGraphicsEffect(opacityEffect_1);
|
||||
ui->line2_widget->setGraphicsEffect(opacityEffect_2);
|
||||
connect(ui->webView->page(),SIGNAL(javaScriptWindowObjectCleared()),this,SLOT([=](){qDebug()<<" ";}));
|
||||
download_speed.setInterval(1000);
|
||||
download_speed.start();
|
||||
//计算显示网速
|
||||
connect(&download_speed,&QTimer::timeout,[=](){
|
||||
if(isdownload){
|
||||
size1=download_size;
|
||||
@@ -105,13 +105,13 @@ Widget::Widget(QWidget *parent) :
|
||||
double bspeed;
|
||||
bspeed=size1-size2;
|
||||
if(bspeed<1024){
|
||||
theSpeed=QString::number(bspeed)+"B";
|
||||
theSpeed=QString::number(bspeed)+"B/s";
|
||||
}else if (bspeed<(1024*1024)) {
|
||||
theSpeed=QString::number(0.01*int(100*(bspeed/1024)))+"KB";
|
||||
theSpeed=QString::number(0.01*int(100*(bspeed/1024)))+"KB/s";
|
||||
}else if (bspeed<(1024*1024*1024)) {
|
||||
theSpeed=QString::number(0.01*int(100*(bspeed/(1024*1024))))+"MB";
|
||||
theSpeed=QString::number(0.01*int(100*(bspeed/(1024*1024))))+"MB/s";
|
||||
}else {
|
||||
theSpeed=QString::number(0.01*int(100*(bspeed/(1024*1024*1024))))+"GB";
|
||||
theSpeed=QString::number(0.01*int(100*(bspeed/(1024*1024*1024))))+"GB/s";
|
||||
}
|
||||
download_list[nowDownload-1].setSpeed(theSpeed);
|
||||
size2=download_size;
|
||||
@@ -126,7 +126,6 @@ Widget::Widget(QWidget *parent) :
|
||||
ui->label_aptserver->setText("不存在");
|
||||
}
|
||||
aptserver.close();
|
||||
ui->pushButton_5->hide();
|
||||
|
||||
}
|
||||
|
||||
@@ -142,7 +141,7 @@ void Widget::on_webView_loadStarted()
|
||||
//判断,如果末尾是/就直接访问,如果是app.json就打开详情页
|
||||
if(arg1.path().right(8)=="app.json"){
|
||||
load.cancel();//打开并发加载线程前关闭正在执行的线程
|
||||
QPixmap pixmap_null;//一个空的图片指针,用来清空先有内容
|
||||
QPixmap pixmap_null;//一个空的图片,用来清空现有内容
|
||||
ui->label_appicon->setPixmap(pixmap_null);
|
||||
ui->screen_1->setPixmap(pixmap_null);
|
||||
ui->screen_2->setPixmap(pixmap_null);
|
||||
@@ -174,10 +173,9 @@ void Widget::loadappinfo(QUrl arg1)
|
||||
ui->label_show->setText("正在加载,请稍候");
|
||||
ui->label_show->show();
|
||||
QProcess get_json;
|
||||
QDir dir;
|
||||
dir.cd("/tmp");
|
||||
dir.mkdir("deepin-community-store");
|
||||
QDir::setCurrent("/tmp/deepin-community-store");
|
||||
QDir dir("/tmp");
|
||||
dir.mkdir("spark-store");
|
||||
QDir::setCurrent("/tmp/spark-store");
|
||||
get_json.start("wget -O app.json "+arg1.toString());
|
||||
get_json.waitForFinished();
|
||||
QFile app_json("app.json");
|
||||
@@ -300,6 +298,7 @@ void Widget::chooseLeftMenu(int index)
|
||||
left_menu_bg[index]->setStyleSheet("background-color:#0081FF;border-radius:8");
|
||||
if(index<=12){
|
||||
ui->webView->setUrl(menuUrl[index]);
|
||||
qDebug()<<menuUrl[index];
|
||||
ui->stackedWidget->setCurrentIndex(0);
|
||||
}else if (index==13) {
|
||||
ui->stackedWidget->setCurrentIndex(1);
|
||||
@@ -308,6 +307,8 @@ void Widget::chooseLeftMenu(int index)
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
void Widget::on_pushButton_clicked()
|
||||
{
|
||||
on_menu_btn_download_clicked();
|
||||
@@ -317,12 +318,13 @@ void Widget::on_pushButton_clicked()
|
||||
download_list[allDownload-1].pkgName=pkgName;
|
||||
if(fileName.isEmpty())
|
||||
{
|
||||
fileName = "index.html";
|
||||
system("notify-send 获取失败 --icon=spark-store");
|
||||
return;
|
||||
}
|
||||
|
||||
download_list[allDownload-1].setParent(ui->listWidget);
|
||||
QListWidgetItem *item=new QListWidgetItem(ui->listWidget);
|
||||
item->setSizeHint(download_list[allDownload-1].size());
|
||||
item->setFlags(item->flags() & ~Qt::ItemIsEnabled & ~Qt::ItemIsSelectable);
|
||||
ui->listWidget->setItemWidget(item,&download_list[allDownload-1]);
|
||||
urList.append(url);
|
||||
qDebug()<<"下载:"<<url;
|
||||
@@ -410,14 +412,7 @@ void Widget::httpFinished() //完成下载
|
||||
startRequest(urList.at(nowDownload-1));
|
||||
}
|
||||
}
|
||||
void Widget::on_listWidget_currentRowChanged(int currentRow)
|
||||
{
|
||||
qDebug()<<currentRow;
|
||||
for (int i=0;i<allDownload;i++) {
|
||||
download_list[i].choose(false);
|
||||
}
|
||||
download_list[currentRow].choose(true);
|
||||
}
|
||||
|
||||
//菜单切换逻辑
|
||||
void Widget::on_menu_btn_main_clicked() //主页
|
||||
{
|
||||
@@ -478,6 +473,18 @@ void Widget::on_menu_btn_download_clicked()
|
||||
void Widget::on_menu_btn_settings_clicked()
|
||||
{
|
||||
chooseLeftMenu(14);
|
||||
quint64 tmp_size=dirFileSize(QString::fromUtf8(TMP_PATH));
|
||||
QString tmp_size_str;
|
||||
if(tmp_size<1024){
|
||||
tmp_size_str=QString::number(tmp_size)+"B";
|
||||
}else if (tmp_size<(1024*1024)) {
|
||||
tmp_size_str=QString::number(0.01*int(100*(tmp_size/1024)))+"KB";
|
||||
}else if (tmp_size<(1024*1024*1024)) {
|
||||
tmp_size_str=QString::number(0.01*int(100*(tmp_size/(1024*1024))))+"MB";
|
||||
}else {
|
||||
tmp_size_str=QString::number(0.01*int(100*(tmp_size/(1024*1024*1024))))+"GB";
|
||||
}
|
||||
ui->tmp_size_ui->setText(tmp_size_str);
|
||||
}
|
||||
void Widget::on_pushButton_2_clicked()
|
||||
{
|
||||
@@ -494,38 +501,31 @@ void Widget::on_webView_loadFinished()
|
||||
ui->label_show->hide();
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
void Widget::on_comboBox_server_currentIndexChanged(const QString &arg1)
|
||||
{
|
||||
if(configCanSeve){
|
||||
ui->label_setting1->show();
|
||||
QSettings *setConfig=new QSettings(QDir::homePath()+"/.config/deepin-community-store/config.ini",QSettings::IniFormat);
|
||||
QSettings *setConfig=new QSettings(QDir::homePath()+"/.config/spark-store/config.ini",QSettings::IniFormat);
|
||||
qDebug()<<arg1;
|
||||
setConfig->setValue("server/choose",arg1);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
void Widget::on_pushButton_3_clicked()
|
||||
{
|
||||
QtConcurrent::run([=](){
|
||||
ui->pushButton_3->setEnabled(false);
|
||||
ui->comboBox_server->clear();
|
||||
system("rm "+QDir::homePath().toUtf8()+"/.config/deepin-community-store/server.list");
|
||||
system("wget -P "+QDir::homePath().toUtf8()+"/.config/deepin-community-store http://dcstore.shenmo.tech/store/server.list");
|
||||
QFile::remove(QDir::homePath().toUtf8()+"/.config/spark-store/server.list");
|
||||
system("wget -P "+QDir::homePath().toUtf8()+"/.config/spark-store http://dcstore.shenmo.tech/store/server.list");
|
||||
std::fstream server;
|
||||
server.open(QDir::homePath().toUtf8()+"/.config/deepin-community-store/server.list",std::ios::in);
|
||||
server.open(QDir::homePath().toUtf8()+"/.config/spark-store/server.list",std::ios::in);
|
||||
std::string lineTmp;
|
||||
if(server){
|
||||
while (getline(server,lineTmp)) {
|
||||
ui->comboBox_server->addItem(QString::fromStdString(lineTmp));
|
||||
}
|
||||
}else {
|
||||
ui->comboBox_server->addItem("http://dcstore.shenmo.tech/");
|
||||
ui->comboBox_server->addItem("http://store.jerrywang.top/");
|
||||
}
|
||||
ui->pushButton_3->setEnabled(true);
|
||||
ui->comboBox_server->setCurrentIndex(0);
|
||||
@@ -538,20 +538,21 @@ void Widget::on_pushButton_4_clicked()
|
||||
ui->pushButton_4->setEnabled(false);
|
||||
ui->label_aptserver->setText("请稍等,正在更新");
|
||||
std::fstream sourcesList;
|
||||
system("mkdir /tmp/spark-store");
|
||||
sourcesList.open("/tmp/spark-store/sparkstore.list",std::ios::out);
|
||||
QDir tmpdir("/tmp");
|
||||
tmpdir.mkpath("spark-store");
|
||||
sourcesList.open(QString::fromUtf8(TMP_PATH).toStdString()+"/sparkstore.list",std::ios::out);
|
||||
if(sourcesList){
|
||||
sourcesList<<"deb [by-hash=force] ";
|
||||
sourcesList<<QString::fromUtf8(ui->comboBox_server->currentText().toUtf8()).toStdString();
|
||||
sourcesList<<" /";
|
||||
std::fstream update;
|
||||
update.open("/tmp/spark-store/update.sh",std::ios::out);
|
||||
update.open(QString::fromUtf8(TMP_PATH).toStdString()+"/update.sh",std::ios::out);
|
||||
update<<"#!/bin/sh\n";
|
||||
update<<"mv /tmp/spark-store/sparkstore.list /etc/apt/sources.list.d/sparkstore.list && apt update";
|
||||
update<<"mv "+QString::fromUtf8(TMP_PATH).toStdString()+"/sparkstore.list /etc/apt/sources.list.d/sparkstore.list && apt update";
|
||||
update.close();
|
||||
system("chmod +x /tmp/spark-store/update.sh");
|
||||
system("chmod +x "+QString::fromUtf8(TMP_PATH).toUtf8()+"/update.sh");
|
||||
QProcess runupdate;
|
||||
runupdate.start("pkexec /tmp/spark-store/update.sh");
|
||||
runupdate.start("pkexec "+QString::fromUtf8(TMP_PATH)+"/update.sh");
|
||||
runupdate.waitForFinished();
|
||||
qDebug()<<runupdate.readAllStandardError();
|
||||
QString error=QString::fromStdString(runupdate.readAllStandardError().toStdString());
|
||||
@@ -592,3 +593,38 @@ void Widget::on_pushButton_5_clicked()
|
||||
system("notify-send 卸载完成 --icon=spark-store");
|
||||
});
|
||||
}
|
||||
|
||||
void Widget::on_pushButton_6_clicked()//清空临时缓存目录
|
||||
{
|
||||
QtConcurrent::run([=](){
|
||||
ui->pushButton_6->setEnabled(false);
|
||||
QDir tmpdir("/tmp/spark-store");
|
||||
tmpdir.setFilter(QDir::Files);
|
||||
int quantity=int(tmpdir.count());
|
||||
for (int i=0;i<quantity;i++) {
|
||||
tmpdir.remove(tmpdir[i]);
|
||||
}
|
||||
system("notify-send 已清除所有临时缓存 --icon=spark-store");
|
||||
ui->pushButton_6->setEnabled(true);
|
||||
on_menu_btn_settings_clicked();
|
||||
});
|
||||
}
|
||||
|
||||
quint64 Widget::dirFileSize(const QString &path)
|
||||
{
|
||||
QDir dir(path);
|
||||
quint64 size = 0;
|
||||
//dir.entryInfoList(QDir::Files)返回文件信息
|
||||
foreach(QFileInfo fileInfo, dir.entryInfoList(QDir::Files))
|
||||
{
|
||||
//计算文件大小
|
||||
size += fileInfo.size();
|
||||
}
|
||||
//dir.entryList(QDir::Dirs|QDir::NoDotAndDotDot)返回所有子目录,并进行过滤
|
||||
foreach(QString subDir, dir.entryList(QDir::Dirs | QDir::NoDotAndDotDot))
|
||||
{
|
||||
//若存在子目录,则递归调用dirFileSize()函数
|
||||
size += dirFileSize(path + QDir::separator() + subDir);
|
||||
}
|
||||
return size;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user