From f08de5cb39a1682360e29aa38cf6e05acd536c44 Mon Sep 17 00:00:00 2001 From: Chad Morales Date: Mon, 16 Dec 2024 08:59:24 -0800 Subject: [PATCH] Add output_file parameter for type -onboarding Signed-off-by: Chad Morales --- Notification Agent Core/Controllers/HelpBuilder.swift | 6 ++++-- .../Views/OnboardingViewModel.swift | 2 +- Shared/Model/UIObjects/NotificationObject.swift | 1 + Shared/Model/UIObjects/OnboardingData.swift | 6 ++++++ 4 files changed, 12 insertions(+), 3 deletions(-) diff --git a/Notification Agent Core/Controllers/HelpBuilder.swift b/Notification Agent Core/Controllers/HelpBuilder.swift index 12a3ebe..fdf654f 100644 --- a/Notification Agent Core/Controllers/HelpBuilder.swift +++ b/Notification Agent Core/Controllers/HelpBuilder.swift @@ -70,7 +70,8 @@ public final class HelpBuilder { "-background_panel".yellow(), "-unmovable".yellow(), "-timeout".yellow(), - "-disable_quit".yellow()] + "-disable_quit".yellow(), + "-output_file".yellow()] static let systemAlertArguments: [String] = ["-type".green(), "-title".yellow(), "-subtitle".yellow(), @@ -162,7 +163,8 @@ public final class HelpBuilder { "[ opaque | translucent ]".red() + "\n The style for the background panel that will cover all the screens.\n Example: -background_panel opaque", "\n Flag that make the UI unmovable for the user.\n Example: -unmovable", "\n The timeout for the onboarding. After this amount of seconds the agent exit with the timeout exit code.\n Example: -timeout 300", - "\n Flag that tells the agent to ignore cmd+q shortcut.\n Example: -disable_quit"] + "\n Flag that tells the agent to ignore cmd+q shortcut.\n Example: -disable_quit", + "[ filename.plist ]".red() + "\n Flag that tells the agent the filename used to store onboarding output.\n Example: -output_file custom.plist"] static let systemAlertDescriptions: [String] = ["[ systemAlert ]".red() + "\n The UI type of the notification.\n Example: -type systemAlert", "\n The title of the notification.\n Example: -title \"Title\"", "\n The subtitle of the notification.\n Example: -subtitle \"Subtitle\"", diff --git a/Notification Agent Onboarding/Views/OnboardingViewModel.swift b/Notification Agent Onboarding/Views/OnboardingViewModel.swift index 9c74d4f..adb3460 100644 --- a/Notification Agent Onboarding/Views/OnboardingViewModel.swift +++ b/Notification Agent Onboarding/Views/OnboardingViewModel.swift @@ -198,7 +198,7 @@ class OnboardingViewModel: NSObject, ObservableObject { plistDictionary[index.description] = pageDictionary } let dictionaryResult = NSDictionary(dictionary: plistDictionary) - Utils.write(dictionaryResult, to: Constants.storeFileName) + Utils.write(dictionaryResult, to: onboardingData.outputFile ?? Constants.storeFileName) } /// Update the state of the progress bar if it's set to automatic. diff --git a/Shared/Model/UIObjects/NotificationObject.swift b/Shared/Model/UIObjects/NotificationObject.swift index 8e92ad2..7a40e76 100644 --- a/Shared/Model/UIObjects/NotificationObject.swift +++ b/Shared/Model/UIObjects/NotificationObject.swift @@ -145,6 +145,7 @@ public final class NotificationObject: NSObject, Codable, NSSecureCoding { switch type { case .onboarding: self.payload = try Self.loadOnboardingPayload(payloadRawData) + self.payload?.outputFile = dict["output_file"] as? String default: break } diff --git a/Shared/Model/UIObjects/OnboardingData.swift b/Shared/Model/UIObjects/OnboardingData.swift index 3056955..0e259b3 100644 --- a/Shared/Model/UIObjects/OnboardingData.swift +++ b/Shared/Model/UIObjects/OnboardingData.swift @@ -16,12 +16,14 @@ public final class OnboardingData: Codable { /// An array of pages. var pages: [InteractiveOnboardingPage] var progressBarPayload: String? + var outputFile: String? // MARK: - Codable protocol conformity - START enum ODCodingKeys: String, CodingKey { case pages case progressBarPayload + case outputFile } required public init(from decoder: Decoder) throws { @@ -34,12 +36,16 @@ public final class OnboardingData: Codable { if let payload = try? container.decodeIfPresent(String.self, forKey: .progressBarPayload) { self.progressBarPayload = payload } + if let outputFile = try? container.decodeIfPresent(String.self, forKey: .outputFile) { + self.outputFile = outputFile + } } public func encode(to encoder: Encoder) throws { var container = encoder.container(keyedBy: ODCodingKeys.self) try container.encodeIfPresent(progressBarPayload, forKey: .progressBarPayload) + try container.encodeIfPresent(outputFile, forKey: .outputFile) try container.encode(pages, forKey: .pages) }