From 407f22bdadd7620979eac74090f946cae7197e16 Mon Sep 17 00:00:00 2001 From: Cody Cutrer Date: Mon, 4 Sep 2023 11:30:55 -0600 Subject: [PATCH 1/2] Handle iconcolor in basicui for iconify icons (#728) And for dark mode, if no color is specified, use white Note that for icons that are already colored, they won't change. Iconify only modifies icons with `fill="currentColor"`. Signed-off-by: Cody Cutrer --- OpenHABCore/Sources/OpenHABCore/Model/OpenHABWidget.swift | 4 ++-- OpenHABCore/Sources/OpenHABCore/Util/Endpoint.swift | 8 ++++++-- .../Tests/OpenHABCoreTests/OpenHABCoreGeneralTests.swift | 3 ++- openHAB/OpenHABNotificationsViewController.swift | 3 ++- openHAB/OpenHABSitemapViewController.swift | 7 ++++++- openHABWatch Extension/Views/Rows/ImageRow.swift | 3 ++- openHABWatch Extension/Views/Utils/IconView.swift | 3 ++- 7 files changed, 22 insertions(+), 9 deletions(-) diff --git a/OpenHABCore/Sources/OpenHABCore/Model/OpenHABWidget.swift b/OpenHABCore/Sources/OpenHABCore/Model/OpenHABWidget.swift index 86971fb8e..a7fcaaa71 100644 --- a/OpenHABCore/Sources/OpenHABCore/Model/OpenHABWidget.swift +++ b/OpenHABCore/Sources/OpenHABCore/Model/OpenHABWidget.swift @@ -310,7 +310,7 @@ public extension OpenHABWidget { let refresh: Int? let height: Double? let isLeaf: Bool? - let iconColor: String? + let iconcolor: String? let labelcolor: String? let valuecolor: String? let service: String? @@ -333,7 +333,7 @@ public extension OpenHABWidget { extension OpenHABWidget.CodingData { var openHABWidget: OpenHABWidget { let mappedWidgets = widgets.map(\.openHABWidget) - return OpenHABWidget(widgetId: widgetId, label: label, icon: icon, type: type, url: url, period: period, minValue: minValue, maxValue: maxValue, step: step, refresh: refresh, height: height, isLeaf: isLeaf, iconColor: iconColor, labelColor: labelcolor, valueColor: valuecolor, service: service, state: state, text: text, legend: legend, encoding: encoding, item: item?.openHABItem, linkedPage: linkedPage, mappings: mappings, widgets: mappedWidgets, visibility: visibility, switchSupport: switchSupport, forceAsItem: forceAsItem) + return OpenHABWidget(widgetId: widgetId, label: label, icon: icon, type: type, url: url, period: period, minValue: minValue, maxValue: maxValue, step: step, refresh: refresh, height: height, isLeaf: isLeaf, iconColor: iconcolor, labelColor: labelcolor, valueColor: valuecolor, service: service, state: state, text: text, legend: legend, encoding: encoding, item: item?.openHABItem, linkedPage: linkedPage, mappings: mappings, widgets: mappedWidgets, visibility: visibility, switchSupport: switchSupport, forceAsItem: forceAsItem) } } diff --git a/OpenHABCore/Sources/OpenHABCore/Util/Endpoint.swift b/OpenHABCore/Sources/OpenHABCore/Util/Endpoint.swift index b00ebedb6..b2197efd1 100644 --- a/OpenHABCore/Sources/OpenHABCore/Util/Endpoint.swift +++ b/OpenHABCore/Sources/OpenHABCore/Util/Endpoint.swift @@ -147,7 +147,7 @@ public extension Endpoint { return endpoint } - static func icon(rootUrl: String, version: Int, icon: String?, state: String, iconType: IconType) -> Endpoint { + static func icon(rootUrl: String, version: Int, icon: String?, state: String, iconType: IconType, iconColor: String) -> Endpoint { guard var icon, !icon.isEmpty else { return Endpoint(baseURL: "", path: "", queryItems: []) } @@ -171,10 +171,14 @@ public extension Endpoint { icon = components[2] } if source == "if" || source == "iconify" { + queryItems = [URLQueryItem(name: "height", value: "64")] + if !iconColor.isEmpty { + queryItems.append(URLQueryItem(name: "color", value: iconColor)) + } return Endpoint( baseURL: "https://api.iconify.design/", path: "/\(set)/\(icon).svg", - queryItems: [URLQueryItem(name: "height", value: "64")] + queryItems: queryItems ) } } diff --git a/OpenHABCore/Tests/OpenHABCoreTests/OpenHABCoreGeneralTests.swift b/OpenHABCore/Tests/OpenHABCoreTests/OpenHABCoreGeneralTests.swift index 5b80d3f04..71a4c70e0 100644 --- a/OpenHABCore/Tests/OpenHABCoreTests/OpenHABCoreGeneralTests.swift +++ b/OpenHABCore/Tests/OpenHABCoreTests/OpenHABCoreGeneralTests.swift @@ -22,7 +22,8 @@ final class OpenHABCoreGeneralTests: XCTestCase { version: 2, icon: "switch", state: "OFF", - iconType: .svg + iconType: .svg, + iconColor: "" ).url XCTAssertEqual(urlc, URL(string: "http://192.169.2.1/icon/switch?state=OFF&format=SVG"), "Check endpoint creation") } diff --git a/openHAB/OpenHABNotificationsViewController.swift b/openHAB/OpenHABNotificationsViewController.swift index 1f604b87c..df9274fd8 100644 --- a/openHAB/OpenHABNotificationsViewController.swift +++ b/openHAB/OpenHABNotificationsViewController.swift @@ -100,7 +100,8 @@ class OpenHABNotificationsViewController: UITableViewController { version: appData!.openHABVersion, icon: notification.icon, state: "", - iconType: .png + iconType: .png, + iconColor: "" ).url { cell?.imageView?.kf.setImage( with: iconUrl, diff --git a/openHAB/OpenHABSitemapViewController.swift b/openHAB/OpenHABSitemapViewController.swift index 019f6b272..76288e47c 100644 --- a/openHAB/OpenHABSitemapViewController.swift +++ b/openHAB/OpenHABSitemapViewController.swift @@ -679,6 +679,10 @@ extension OpenHABSitemapViewController: UITableViewDelegate, UITableViewDataSour cell = tableView.dequeueReusableCell(for: indexPath) as GenericUITableViewCell } + var iconColor = widget?.iconColor + if (iconColor == nil || iconColor!.isEmpty), traitCollection.userInterfaceStyle == .dark { + iconColor = "white" + } // No icon is needed for image, video, frame and web widgets if widget?.icon != nil, !((cell is NewImageUITableViewCell) || (cell is VideoUITableViewCell) || (cell is FrameUITableViewCell) || (cell is WebUITableViewCell)) { if let urlc = Endpoint.icon( @@ -686,7 +690,8 @@ extension OpenHABSitemapViewController: UITableViewDelegate, UITableViewDataSour version: appData?.openHABVersion ?? 2, icon: widget?.icon, state: widget?.iconState() ?? "", - iconType: iconType + iconType: iconType, + iconColor: iconColor! ).url { var imageRequest = URLRequest(url: urlc) imageRequest.timeoutInterval = 10.0 diff --git a/openHABWatch Extension/Views/Rows/ImageRow.swift b/openHABWatch Extension/Views/Rows/ImageRow.swift index 333902e2f..f6ecef106 100644 --- a/openHABWatch Extension/Views/Rows/ImageRow.swift +++ b/openHABWatch Extension/Views/Rows/ImageRow.swift @@ -43,7 +43,8 @@ struct ImageRow_Previews: PreviewProvider { version: 2, icon: "Switch", state: "ON", - iconType: .png + iconType: .png, + iconColor: "" ).url // let widget = UserData().widgets[8] return ImageRow(URL: iconURL) diff --git a/openHABWatch Extension/Views/Utils/IconView.swift b/openHABWatch Extension/Views/Utils/IconView.swift index 9a586150b..661b791c2 100644 --- a/openHABWatch Extension/Views/Utils/IconView.swift +++ b/openHABWatch Extension/Views/Utils/IconView.swift @@ -24,7 +24,8 @@ struct IconView: View { version: 2, icon: widget.icon, state: widget.item?.state ?? "", - iconType: .png + iconType: .png, + iconColor: "" ).url } From 2c45224dc75c777371abc58fd3734f8f89412436 Mon Sep 17 00:00:00 2001 From: openhab-bot Date: Mon, 4 Sep 2023 18:32:02 +0000 Subject: [PATCH 2/2] committed version bump: 2.4.60 (1580410538) Signed-off-by: runner --- openHAB.xcodeproj/project.pbxproj | 40 +++++++++++++++---------------- 1 file changed, 20 insertions(+), 20 deletions(-) diff --git a/openHAB.xcodeproj/project.pbxproj b/openHAB.xcodeproj/project.pbxproj index fe69ae156..4bcd4489f 100644 --- a/openHAB.xcodeproj/project.pbxproj +++ b/openHAB.xcodeproj/project.pbxproj @@ -1517,7 +1517,7 @@ CODE_SIGN_IDENTITY = "Apple Development"; "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "Apple Development"; CODE_SIGN_STYLE = Automatic; - CURRENT_PROJECT_VERSION = 1580410537; + CURRENT_PROJECT_VERSION = 1580410538; DEBUG_INFORMATION_FORMAT = dwarf; DEVELOPMENT_TEAM = PBAPXHRAM9; GCC_C_LANGUAGE_STANDARD = gnu11; @@ -1531,7 +1531,7 @@ "@executable_path/Frameworks", "@executable_path/../../Frameworks", ); - MARKETING_VERSION = 2.4.59; + MARKETING_VERSION = 2.4.60; MTL_ENABLE_DEBUG_INFO = INCLUDE_SOURCE; MTL_FAST_MATH = YES; PRODUCT_BUNDLE_IDENTIFIER = es.spaphone.openhab.openHABIntents; @@ -1560,7 +1560,7 @@ CODE_SIGN_IDENTITY = "iPhone Distribution"; "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "Apple Distribution"; CODE_SIGN_STYLE = Manual; - CURRENT_PROJECT_VERSION = 1580410537; + CURRENT_PROJECT_VERSION = 1580410538; DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; DEVELOPMENT_TEAM = PBAPXHRAM9; GCC_C_LANGUAGE_STANDARD = gnu11; @@ -1573,7 +1573,7 @@ "@executable_path/Frameworks", "@executable_path/../../Frameworks", ); - MARKETING_VERSION = 2.4.59; + MARKETING_VERSION = 2.4.60; MTL_ENABLE_DEBUG_INFO = NO; MTL_FAST_MATH = YES; PRODUCT_BUNDLE_IDENTIFIER = es.spaphone.openhab.openHABIntents; @@ -1600,7 +1600,7 @@ CODE_SIGN_IDENTITY = "iPhone Developer"; "CODE_SIGN_IDENTITY[sdk=macosx*]" = "-"; CODE_SIGN_STYLE = Automatic; - CURRENT_PROJECT_VERSION = 1580410537; + CURRENT_PROJECT_VERSION = 1580410538; DEBUG_INFORMATION_FORMAT = dwarf; DEVELOPMENT_TEAM = PBAPXHRAM9; GCC_C_LANGUAGE_STANDARD = gnu11; @@ -1611,7 +1611,7 @@ "@executable_path/Frameworks", "@loader_path/Frameworks", ); - MARKETING_VERSION = 2.4.59; + MARKETING_VERSION = 2.4.60; MTL_ENABLE_DEBUG_INFO = INCLUDE_SOURCE; MTL_FAST_MATH = YES; PRODUCT_BUNDLE_IDENTIFIER = es.spaphone.openHABUITests; @@ -1642,7 +1642,7 @@ "CODE_SIGN_IDENTITY[sdk=macosx*]" = "-"; CODE_SIGN_STYLE = Automatic; COPY_PHASE_STRIP = NO; - CURRENT_PROJECT_VERSION = 1580410537; + CURRENT_PROJECT_VERSION = 1580410538; DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; DEVELOPMENT_TEAM = PBAPXHRAM9; GCC_C_LANGUAGE_STANDARD = gnu11; @@ -1653,7 +1653,7 @@ "@executable_path/Frameworks", "@loader_path/Frameworks", ); - MARKETING_VERSION = 2.4.59; + MARKETING_VERSION = 2.4.60; MTL_ENABLE_DEBUG_INFO = NO; MTL_FAST_MATH = YES; PRODUCT_BUNDLE_IDENTIFIER = es.spaphone.openHABUITests; @@ -1684,7 +1684,7 @@ CODE_SIGN_IDENTITY = "Apple Development"; CODE_SIGN_STYLE = Automatic; "CODE_SIGN_STYLE[sdk=*]" = Automatic; - CURRENT_PROJECT_VERSION = 1580410537; + CURRENT_PROJECT_VERSION = 1580410538; DEBUG_INFORMATION_FORMAT = dwarf; DEVELOPMENT_TEAM = PBAPXHRAM9; GCC_C_LANGUAGE_STANDARD = "compiler-default"; @@ -1695,7 +1695,7 @@ "@executable_path/Frameworks", "@executable_path/../../Frameworks", ); - MARKETING_VERSION = 2.4.59; + MARKETING_VERSION = 2.4.60; MTL_ENABLE_DEBUG_INFO = INCLUDE_SOURCE; MTL_FAST_MATH = YES; PRODUCT_BUNDLE_IDENTIFIER = es.spaphone.openhab.watchkitapp; @@ -1729,7 +1729,7 @@ CODE_SIGN_IDENTITY = "iPhone Distribution"; CODE_SIGN_STYLE = Manual; COPY_PHASE_STRIP = NO; - CURRENT_PROJECT_VERSION = 1580410537; + CURRENT_PROJECT_VERSION = 1580410538; DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; DEVELOPMENT_TEAM = PBAPXHRAM9; GCC_C_LANGUAGE_STANDARD = "compiler-default"; @@ -1740,7 +1740,7 @@ "@executable_path/Frameworks", "@executable_path/../../Frameworks", ); - MARKETING_VERSION = 2.4.59; + MARKETING_VERSION = 2.4.60; MTL_ENABLE_DEBUG_INFO = NO; MTL_FAST_MATH = YES; PRODUCT_BUNDLE_IDENTIFIER = es.spaphone.openhab.watchkitapp; @@ -1771,7 +1771,7 @@ CODE_SIGN_IDENTITY = "Apple Development"; "CODE_SIGN_IDENTITY[sdk=macosx*]" = "Apple Development"; CODE_SIGN_STYLE = Automatic; - CURRENT_PROJECT_VERSION = 1580410537; + CURRENT_PROJECT_VERSION = 1580410538; DEBUG_INFORMATION_FORMAT = dwarf; DEVELOPMENT_TEAM = PBAPXHRAM9; GCC_C_LANGUAGE_STANDARD = gnu11; @@ -1782,7 +1782,7 @@ "@executable_path/Frameworks", "@loader_path/Frameworks", ); - MARKETING_VERSION = 2.4.59; + MARKETING_VERSION = 2.4.60; MTL_ENABLE_DEBUG_INFO = INCLUDE_SOURCE; MTL_FAST_MATH = YES; PRODUCT_BUNDLE_IDENTIFIER = "com.reg-labs.openHABTestsSwift"; @@ -1814,7 +1814,7 @@ "CODE_SIGN_IDENTITY[sdk=macosx*]" = "Apple Development"; CODE_SIGN_STYLE = Automatic; COPY_PHASE_STRIP = NO; - CURRENT_PROJECT_VERSION = 1580410537; + CURRENT_PROJECT_VERSION = 1580410538; DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; DEVELOPMENT_TEAM = PBAPXHRAM9; GCC_C_LANGUAGE_STANDARD = gnu11; @@ -1825,7 +1825,7 @@ "@executable_path/Frameworks", "@loader_path/Frameworks", ); - MARKETING_VERSION = 2.4.59; + MARKETING_VERSION = 2.4.60; MTL_ENABLE_DEBUG_INFO = NO; MTL_FAST_MATH = YES; PRODUCT_BUNDLE_IDENTIFIER = "com.reg-labs.openHABTestsSwift"; @@ -1968,7 +1968,7 @@ CODE_SIGN_IDENTITY = "Apple Development"; "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "Apple Development"; CODE_SIGN_STYLE = Automatic; - CURRENT_PROJECT_VERSION = 1580410537; + CURRENT_PROJECT_VERSION = 1580410538; DEAD_CODE_STRIPPING = NO; DEVELOPMENT_TEAM = PBAPXHRAM9; GCC_PRECOMPILE_PREFIX_HEADER = YES; @@ -1984,7 +1984,7 @@ "@loader_path/../../Frameworks", ); LIBRARY_SEARCH_PATHS = "$(inherited)"; - MARKETING_VERSION = 2.4.59; + MARKETING_VERSION = 2.4.60; OTHER_SWIFT_FLAGS = "$(inherited) -DDEBUG -Xfrontend -warn-long-expression-type-checking=200 -Xfrontend -warn-long-function-bodies=200"; PRODUCT_BUNDLE_IDENTIFIER = es.spaphone.openhab; PRODUCT_NAME = "$(TARGET_NAME)"; @@ -2013,7 +2013,7 @@ CODE_SIGN_IDENTITY = "Apple Distribution"; "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "Apple Distribution"; CODE_SIGN_STYLE = Manual; - CURRENT_PROJECT_VERSION = 1580410537; + CURRENT_PROJECT_VERSION = 1580410538; DEAD_CODE_STRIPPING = NO; DEVELOPMENT_TEAM = PBAPXHRAM9; GCC_PRECOMPILE_PREFIX_HEADER = YES; @@ -2029,7 +2029,7 @@ "@loader_path/../../Frameworks", ); LIBRARY_SEARCH_PATHS = "$(inherited)"; - MARKETING_VERSION = 2.4.59; + MARKETING_VERSION = 2.4.60; PRODUCT_BUNDLE_IDENTIFIER = es.spaphone.openhab; PRODUCT_NAME = "$(TARGET_NAME)"; PROVISIONING_PROFILE = "";