From 8f8cf1bbd987178907325d6ea149ce725e6eb84d Mon Sep 17 00:00:00 2001 From: phlpsong Date: Fri, 19 Jan 2024 14:10:09 +0800 Subject: [PATCH] fix: refactor disable app item view --- .../SettingView/Tabs/DisabledAppTab.swift | 47 ++++++++++--------- 1 file changed, 26 insertions(+), 21 deletions(-) diff --git a/Easydict/NewApp/View/SettingView/Tabs/DisabledAppTab.swift b/Easydict/NewApp/View/SettingView/Tabs/DisabledAppTab.swift index 62c131753..1853c41fb 100644 --- a/Easydict/NewApp/View/SettingView/Tabs/DisabledAppTab.swift +++ b/Easydict/NewApp/View/SettingView/Tabs/DisabledAppTab.swift @@ -88,7 +88,7 @@ struct DisabledAppTab: View { var appListView: some View { List(selection: $disabledAppViewModel.selectedAppModels) { ForEach(disabledAppViewModel.appModelList, id: \.self) { app in - BlockAppItemView(appModel: app) + BlockAppItemView(with: app) .tag(app) } .listRowSeparator(.hidden) @@ -172,11 +172,33 @@ private struct ListButton: View { private struct BlockAppItemView: View { @EnvironmentObject var disabledAppViewModel: DisabledAppViewModel - var appModel: EZAppModel + let appIcon: NSImage + let appName: String - @State private var appIcon: NSImage = .init() + init(with appModel: EZAppModel) { + let appBundleId = appModel.appBundleID + let workspace = NSWorkspace.shared + let appURL = workspace.urlForApplication(withBundleIdentifier: appBundleId) + guard let appURL else { + appIcon = .init() + appName = "" + return + } - @State private var appName = "" + let appPath = NSWorkspace.shared.urlForApplication(withBundleIdentifier: appBundleId) + guard let appPath else { + appIcon = .init() + appName = "" + return + } + appIcon = workspace.icon(forFile: appPath.path(percentEncoded: false)) + + guard let appBundle = Bundle(url: appURL) else { + appName = "" + return + } + appName = appBundle.applicationName + } var body: some View { HStack(alignment: .center) { @@ -193,23 +215,6 @@ private struct BlockAppItemView: View { .contentShape(Rectangle()) .padding(.vertical, 4) .padding(.leading, 6) - .onAppear { - getAppBundleInfo() - } - } - - func getAppBundleInfo() { - let appBundleId = appModel.appBundleID - let workspace = NSWorkspace.shared - let appURL = workspace.urlForApplication(withBundleIdentifier: appBundleId) - guard let appURL else { return } - - let appPath = NSWorkspace.shared.urlForApplication(withBundleIdentifier: appBundleId) - guard let appPath else { return } - appIcon = workspace.icon(forFile: appPath.path(percentEncoded: false)) - - guard let appBundle = Bundle(url: appURL) else { return } - appName = appBundle.applicationName } }