Merge pull request #6310 from 21pages/install_after_connect

fix install after connection
This commit is contained in:
RustDesk 2023-11-07 11:37:52 +08:00 committed by GitHub
commit 05a254c682
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 123 additions and 96 deletions

View File

@ -336,11 +336,17 @@ class _DesktopHomePageState extends State<DesktopHomePage>
} }
if (Platform.isWindows) { if (Platform.isWindows) {
if (!bind.mainIsInstalled()) { if (!bind.mainIsInstalled()) {
return buildInstallCard( return buildInstallCard("", "install_tip", "Install", () async {
"", "install_tip", "Install", bind.mainGotoInstall); await rustDeskWinManager.closeAllSubWindows();
bind.mainGotoInstall();
});
} else if (bind.mainIsInstalledLowerVersion()) { } else if (bind.mainIsInstalledLowerVersion()) {
return buildInstallCard("Status", "Your installation is lower version.", return buildInstallCard(
"Click to upgrade", bind.mainUpdateMe); "Status", "Your installation is lower version.", "Click to upgrade",
() async {
await rustDeskWinManager.closeAllSubWindows();
bind.mainUpdateMe();
});
} }
} else if (Platform.isMacOS) { } else if (Platform.isMacOS) {
if (!bind.mainIsCanScreenRecording(prompt: false)) { if (!bind.mainIsCanScreenRecording(prompt: false)) {
@ -384,7 +390,10 @@ class _DesktopHomePageState extends State<DesktopHomePage>
final keyShowSelinuxHelpTip = "show-selinux-help-tip"; final keyShowSelinuxHelpTip = "show-selinux-help-tip";
if (bind.mainGetLocalOption(key: keyShowSelinuxHelpTip) != 'N') { if (bind.mainGetLocalOption(key: keyShowSelinuxHelpTip) != 'N') {
LinuxCards.add(buildInstallCard( LinuxCards.add(buildInstallCard(
"Warning", "selinux_tip", "", () async {}, "Warning",
"selinux_tip",
"",
() async {},
marginTop: LinuxCards.isEmpty ? 20.0 : 5.0, marginTop: LinuxCards.isEmpty ? 20.0 : 5.0,
help: 'Help', help: 'Help',
link: link:
@ -418,7 +427,11 @@ class _DesktopHomePageState extends State<DesktopHomePage>
Widget buildInstallCard(String title, String content, String btnText, Widget buildInstallCard(String title, String content, String btnText,
GestureTapCallback onPressed, GestureTapCallback onPressed,
{double marginTop = 20.0, String? help, String? link, bool? closeButton, String? closeOption}) { {double marginTop = 20.0,
String? help,
String? link,
bool? closeButton,
String? closeOption}) {
void closeCard() async { void closeCard() async {
if (closeOption != null) { if (closeOption != null) {
await bind.mainSetLocalOption(key: closeOption, value: 'N'); await bind.mainSetLocalOption(key: closeOption, value: 'N');
@ -502,7 +515,8 @@ class _DesktopHomePageState extends State<DesktopHomePage>
child: Text( child: Text(
translate(help), translate(help),
style: TextStyle( style: TextStyle(
decoration: TextDecoration.underline, decoration:
TextDecoration.underline,
color: Colors.white, color: Colors.white,
fontSize: 12), fontSize: 12),
)).marginOnly(top: 6)), )).marginOnly(top: 6)),

View File

@ -123,14 +123,21 @@ class CmFileModel {
} }
int removeUnreadCount = 0; int removeUnreadCount = 0;
if (data.dir) { if (data.dir) {
bool isChild(String parent, String child) {
if (child.startsWith(parent) && child.length > parent.length) {
final suffix = child.substring(parent.length);
return suffix.startsWith('/') || suffix.startsWith('\\');
}
return false;
}
removeUnreadCount = jobTable removeUnreadCount = jobTable
.where((e) => .where((e) =>
e.action == CmFileAction.remove && e.action == CmFileAction.remove &&
e.fileName.startsWith(data.path)) isChild(data.path, e.fileName))
.length; .length;
jobTable.removeWhere((e) => jobTable.removeWhere((e) =>
e.action == CmFileAction.remove && e.action == CmFileAction.remove && isChild(data.path, e.fileName));
e.fileName.startsWith(data.path));
} }
jobTable.add(CmFileLog() jobTable.add(CmFileLog()
..id = data.id ..id = data.id

View File

@ -49,6 +49,7 @@ use sha2::{Digest, Sha256};
use std::sync::atomic::Ordering; use std::sync::atomic::Ordering;
use std::{ use std::{
num::NonZeroI64, num::NonZeroI64,
path::PathBuf,
sync::{atomic::AtomicI64, mpsc as std_mpsc}, sync::{atomic::AtomicI64, mpsc as std_mpsc},
}; };
#[cfg(not(any(target_os = "android", target_os = "ios")))] #[cfg(not(any(target_os = "android", target_os = "ios")))]
@ -2953,12 +2954,17 @@ impl FileRemoveLogControl {
fn on_remove_dir(&mut self, d: FileRemoveDir) -> Option<ipc::Data> { fn on_remove_dir(&mut self, d: FileRemoveDir) -> Option<ipc::Data> {
self.instant = Instant::now(); self.instant = Instant::now();
self.removed_files.retain(|f| !f.path.starts_with(&d.path)); let direct_child = |parent: &str, child: &str| {
self.removed_dirs.retain(|x| !x.path.starts_with(&d.path)); PathBuf::from(child).parent().map(|x| x.to_path_buf()) == Some(PathBuf::from(parent))
};
self.removed_files
.retain(|f| !direct_child(&f.path, &d.path));
self.removed_dirs
.retain(|x| !direct_child(&d.path, &x.path));
if !self if !self
.removed_dirs .removed_dirs
.iter() .iter()
.any(|x| d.path.starts_with(&x.path)) .any(|x| direct_child(&x.path, &d.path))
{ {
self.removed_dirs.push(d.clone()); self.removed_dirs.push(d.clone());
} }