From e41ba3b8e0a2c5214536d9ba095951a0adf30884 Mon Sep 17 00:00:00 2001 From: Jordan Koch Date: Sat, 2 Mar 2019 19:26:02 -0500 Subject: [PATCH] initial commit --- README.md | 13 + .../AppIcon.appiconset/Contents.json | 81 +++ .../Assets.xcassets/Contents.json | 6 + .../Base.lproj/Interface.storyboard | 15 + SimpleBattery WatchKit App/Info.plist | 33 + .../Circular.imageset/Contents.json | 28 + .../Contents.json | 48 ++ .../Extra Large.imageset/Contents.json | 28 + .../Graphic Bezel.imageset/Contents.json | 28 + .../Graphic Circular.imageset/Contents.json | 28 + .../Graphic Corner.imageset/Contents.json | 28 + .../Contents.json | 28 + .../Modular.imageset/Contents.json | 28 + .../Utilitarian.imageset/Contents.json | 28 + .../Assets.xcassets/Contents.json | 6 + .../ComplicationController.swift | 77 +++ .../ExtensionDelegate.swift | 74 +++ SimpleBattery WatchKit Extension/Info.plist | 43 ++ .../InterfaceController.swift | 31 + SimpleBattery.xcodeproj/project.pbxproj | 626 ++++++++++++++++++ .../contents.xcworkspacedata | 7 + .../xcshareddata/IDEWorkspaceChecks.plist | 8 + .../UserInterfaceState.xcuserstate | Bin 0 -> 18897 bytes .../xcschemes/xcschememanagement.plist | 24 + SimpleBattery/AppDelegate.swift | 46 ++ .../AppIcon.appiconset/Contents.json | 98 +++ SimpleBattery/Assets.xcassets/Contents.json | 6 + .../Base.lproj/LaunchScreen.storyboard | 25 + SimpleBattery/Base.lproj/Main.storyboard | 24 + SimpleBattery/Info.plist | 45 ++ SimpleBattery/ViewController.swift | 20 + 31 files changed, 1580 insertions(+) create mode 100644 README.md create mode 100644 SimpleBattery WatchKit App/Assets.xcassets/AppIcon.appiconset/Contents.json create mode 100644 SimpleBattery WatchKit App/Assets.xcassets/Contents.json create mode 100644 SimpleBattery WatchKit App/Base.lproj/Interface.storyboard create mode 100644 SimpleBattery WatchKit App/Info.plist create mode 100644 SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Circular.imageset/Contents.json create mode 100644 SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Contents.json create mode 100644 SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Extra Large.imageset/Contents.json create mode 100644 SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Graphic Bezel.imageset/Contents.json create mode 100644 SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Graphic Circular.imageset/Contents.json create mode 100644 SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Graphic Corner.imageset/Contents.json create mode 100644 SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Graphic Large Rectangular.imageset/Contents.json create mode 100644 SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Modular.imageset/Contents.json create mode 100644 SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Utilitarian.imageset/Contents.json create mode 100644 SimpleBattery WatchKit Extension/Assets.xcassets/Contents.json create mode 100644 SimpleBattery WatchKit Extension/ComplicationController.swift create mode 100644 SimpleBattery WatchKit Extension/ExtensionDelegate.swift create mode 100644 SimpleBattery WatchKit Extension/Info.plist create mode 100644 SimpleBattery WatchKit Extension/InterfaceController.swift create mode 100644 SimpleBattery.xcodeproj/project.pbxproj create mode 100644 SimpleBattery.xcodeproj/project.xcworkspace/contents.xcworkspacedata create mode 100644 SimpleBattery.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist create mode 100644 SimpleBattery.xcodeproj/project.xcworkspace/xcuserdata/me.xcuserdatad/UserInterfaceState.xcuserstate create mode 100644 SimpleBattery.xcodeproj/xcuserdata/me.xcuserdatad/xcschemes/xcschememanagement.plist create mode 100644 SimpleBattery/AppDelegate.swift create mode 100644 SimpleBattery/Assets.xcassets/AppIcon.appiconset/Contents.json create mode 100644 SimpleBattery/Assets.xcassets/Contents.json create mode 100644 SimpleBattery/Base.lproj/LaunchScreen.storyboard create mode 100644 SimpleBattery/Base.lproj/Main.storyboard create mode 100644 SimpleBattery/Info.plist create mode 100644 SimpleBattery/ViewController.swift diff --git a/README.md b/README.md new file mode 100644 index 0000000..76f2d08 --- /dev/null +++ b/README.md @@ -0,0 +1,13 @@ +# Simple-Battery + +Seems to work? I'm new to Apple Watch dev and made this in a few minutes. + +Basically when I got my Watch Series 4 I was disgusted at the circular battery on the Utility face and thought it should be more like how everything else gets displayed. + +Feel free to improve if I did something horribly wrong. + +## Before: +![Before](https://i.arxius.io/80bed78f) + +## After: +![After](https://i.arxius.io/b6bf771e) diff --git a/SimpleBattery WatchKit App/Assets.xcassets/AppIcon.appiconset/Contents.json b/SimpleBattery WatchKit App/Assets.xcassets/AppIcon.appiconset/Contents.json new file mode 100644 index 0000000..6c0f2b4 --- /dev/null +++ b/SimpleBattery WatchKit App/Assets.xcassets/AppIcon.appiconset/Contents.json @@ -0,0 +1,81 @@ +{ + "images" : [ + { + "size" : "24x24", + "idiom" : "watch", + "scale" : "2x", + "role" : "notificationCenter", + "subtype" : "38mm" + }, + { + "size" : "27.5x27.5", + "idiom" : "watch", + "scale" : "2x", + "role" : "notificationCenter", + "subtype" : "42mm" + }, + { + "size" : "29x29", + "idiom" : "watch", + "role" : "companionSettings", + "scale" : "2x" + }, + { + "size" : "29x29", + "idiom" : "watch", + "role" : "companionSettings", + "scale" : "3x" + }, + { + "size" : "40x40", + "idiom" : "watch", + "scale" : "2x", + "role" : "appLauncher", + "subtype" : "38mm" + }, + { + "size" : "44x44", + "idiom" : "watch", + "scale" : "2x", + "role" : "appLauncher", + "subtype" : "40mm" + }, + { + "size" : "50x50", + "idiom" : "watch", + "scale" : "2x", + "role" : "appLauncher", + "subtype" : "44mm" + }, + { + "size" : "86x86", + "idiom" : "watch", + "scale" : "2x", + "role" : "quickLook", + "subtype" : "38mm" + }, + { + "size" : "98x98", + "idiom" : "watch", + "scale" : "2x", + "role" : "quickLook", + "subtype" : "42mm" + }, + { + "size" : "108x108", + "idiom" : "watch", + "scale" : "2x", + "role" : "quickLook", + "subtype" : "44mm" + }, + { + "idiom" : "watch-marketing", + "size" : "1024x1024", + "scale" : "1x" + } + ], + "info" : { + "version" : 1, + "author" : "xcode" + } +} \ No newline at end of file diff --git a/SimpleBattery WatchKit App/Assets.xcassets/Contents.json b/SimpleBattery WatchKit App/Assets.xcassets/Contents.json new file mode 100644 index 0000000..da4a164 --- /dev/null +++ b/SimpleBattery WatchKit App/Assets.xcassets/Contents.json @@ -0,0 +1,6 @@ +{ + "info" : { + "version" : 1, + "author" : "xcode" + } +} \ No newline at end of file diff --git a/SimpleBattery WatchKit App/Base.lproj/Interface.storyboard b/SimpleBattery WatchKit App/Base.lproj/Interface.storyboard new file mode 100644 index 0000000..cf05d24 --- /dev/null +++ b/SimpleBattery WatchKit App/Base.lproj/Interface.storyboard @@ -0,0 +1,15 @@ + + + + + + + + + + + + + + + diff --git a/SimpleBattery WatchKit App/Info.plist b/SimpleBattery WatchKit App/Info.plist new file mode 100644 index 0000000..625a2f2 --- /dev/null +++ b/SimpleBattery WatchKit App/Info.plist @@ -0,0 +1,33 @@ + + + + + CFBundleDevelopmentRegion + $(DEVELOPMENT_LANGUAGE) + CFBundleDisplayName + SimpleBattery WatchKit App + CFBundleExecutable + $(EXECUTABLE_NAME) + CFBundleIdentifier + $(PRODUCT_BUNDLE_IDENTIFIER) + CFBundleInfoDictionaryVersion + 6.0 + CFBundleName + $(PRODUCT_NAME) + CFBundlePackageType + APPL + CFBundleShortVersionString + 1.0 + CFBundleVersion + 1 + UISupportedInterfaceOrientations + + UIInterfaceOrientationPortrait + UIInterfaceOrientationPortraitUpsideDown + + WKCompanionAppBundleIdentifier + com.jordankoch.SimpleBattery + WKWatchKitApp + + + diff --git a/SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Circular.imageset/Contents.json b/SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Circular.imageset/Contents.json new file mode 100644 index 0000000..aefef29 --- /dev/null +++ b/SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Circular.imageset/Contents.json @@ -0,0 +1,28 @@ +{ + "images" : [ + { + "idiom" : "watch", + "scale" : "2x", + "screen-width" : "<=145" + }, + { + "idiom" : "watch", + "scale" : "2x", + "screen-width" : ">161" + }, + { + "idiom" : "watch", + "scale" : "2x", + "screen-width" : ">145" + }, + { + "idiom" : "watch", + "scale" : "2x", + "screen-width" : ">183" + } + ], + "info" : { + "version" : 1, + "author" : "xcode" + } +} \ No newline at end of file diff --git a/SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Contents.json b/SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Contents.json new file mode 100644 index 0000000..1571c7e --- /dev/null +++ b/SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Contents.json @@ -0,0 +1,48 @@ +{ + "assets" : [ + { + "idiom" : "watch", + "filename" : "Circular.imageset", + "role" : "circular" + }, + { + "idiom" : "watch", + "filename" : "Extra Large.imageset", + "role" : "extra-large" + }, + { + "idiom" : "watch", + "filename" : "Graphic Bezel.imageset", + "role" : "graphic-bezel" + }, + { + "idiom" : "watch", + "filename" : "Graphic Circular.imageset", + "role" : "graphic-circular" + }, + { + "idiom" : "watch", + "filename" : "Graphic Corner.imageset", + "role" : "graphic-corner" + }, + { + "idiom" : "watch", + "filename" : "Graphic Large Rectangular.imageset", + "role" : "graphic-large-rectangular" + }, + { + "idiom" : "watch", + "filename" : "Modular.imageset", + "role" : "modular" + }, + { + "idiom" : "watch", + "filename" : "Utilitarian.imageset", + "role" : "utilitarian" + } + ], + "info" : { + "version" : 1, + "author" : "xcode" + } +} \ No newline at end of file diff --git a/SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Extra Large.imageset/Contents.json b/SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Extra Large.imageset/Contents.json new file mode 100644 index 0000000..aefef29 --- /dev/null +++ b/SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Extra Large.imageset/Contents.json @@ -0,0 +1,28 @@ +{ + "images" : [ + { + "idiom" : "watch", + "scale" : "2x", + "screen-width" : "<=145" + }, + { + "idiom" : "watch", + "scale" : "2x", + "screen-width" : ">161" + }, + { + "idiom" : "watch", + "scale" : "2x", + "screen-width" : ">145" + }, + { + "idiom" : "watch", + "scale" : "2x", + "screen-width" : ">183" + } + ], + "info" : { + "version" : 1, + "author" : "xcode" + } +} \ No newline at end of file diff --git a/SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Graphic Bezel.imageset/Contents.json b/SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Graphic Bezel.imageset/Contents.json new file mode 100644 index 0000000..aefef29 --- /dev/null +++ b/SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Graphic Bezel.imageset/Contents.json @@ -0,0 +1,28 @@ +{ + "images" : [ + { + "idiom" : "watch", + "scale" : "2x", + "screen-width" : "<=145" + }, + { + "idiom" : "watch", + "scale" : "2x", + "screen-width" : ">161" + }, + { + "idiom" : "watch", + "scale" : "2x", + "screen-width" : ">145" + }, + { + "idiom" : "watch", + "scale" : "2x", + "screen-width" : ">183" + } + ], + "info" : { + "version" : 1, + "author" : "xcode" + } +} \ No newline at end of file diff --git a/SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Graphic Circular.imageset/Contents.json b/SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Graphic Circular.imageset/Contents.json new file mode 100644 index 0000000..aefef29 --- /dev/null +++ b/SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Graphic Circular.imageset/Contents.json @@ -0,0 +1,28 @@ +{ + "images" : [ + { + "idiom" : "watch", + "scale" : "2x", + "screen-width" : "<=145" + }, + { + "idiom" : "watch", + "scale" : "2x", + "screen-width" : ">161" + }, + { + "idiom" : "watch", + "scale" : "2x", + "screen-width" : ">145" + }, + { + "idiom" : "watch", + "scale" : "2x", + "screen-width" : ">183" + } + ], + "info" : { + "version" : 1, + "author" : "xcode" + } +} \ No newline at end of file diff --git a/SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Graphic Corner.imageset/Contents.json b/SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Graphic Corner.imageset/Contents.json new file mode 100644 index 0000000..aefef29 --- /dev/null +++ b/SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Graphic Corner.imageset/Contents.json @@ -0,0 +1,28 @@ +{ + "images" : [ + { + "idiom" : "watch", + "scale" : "2x", + "screen-width" : "<=145" + }, + { + "idiom" : "watch", + "scale" : "2x", + "screen-width" : ">161" + }, + { + "idiom" : "watch", + "scale" : "2x", + "screen-width" : ">145" + }, + { + "idiom" : "watch", + "scale" : "2x", + "screen-width" : ">183" + } + ], + "info" : { + "version" : 1, + "author" : "xcode" + } +} \ No newline at end of file diff --git a/SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Graphic Large Rectangular.imageset/Contents.json b/SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Graphic Large Rectangular.imageset/Contents.json new file mode 100644 index 0000000..aefef29 --- /dev/null +++ b/SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Graphic Large Rectangular.imageset/Contents.json @@ -0,0 +1,28 @@ +{ + "images" : [ + { + "idiom" : "watch", + "scale" : "2x", + "screen-width" : "<=145" + }, + { + "idiom" : "watch", + "scale" : "2x", + "screen-width" : ">161" + }, + { + "idiom" : "watch", + "scale" : "2x", + "screen-width" : ">145" + }, + { + "idiom" : "watch", + "scale" : "2x", + "screen-width" : ">183" + } + ], + "info" : { + "version" : 1, + "author" : "xcode" + } +} \ No newline at end of file diff --git a/SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Modular.imageset/Contents.json b/SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Modular.imageset/Contents.json new file mode 100644 index 0000000..aefef29 --- /dev/null +++ b/SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Modular.imageset/Contents.json @@ -0,0 +1,28 @@ +{ + "images" : [ + { + "idiom" : "watch", + "scale" : "2x", + "screen-width" : "<=145" + }, + { + "idiom" : "watch", + "scale" : "2x", + "screen-width" : ">161" + }, + { + "idiom" : "watch", + "scale" : "2x", + "screen-width" : ">145" + }, + { + "idiom" : "watch", + "scale" : "2x", + "screen-width" : ">183" + } + ], + "info" : { + "version" : 1, + "author" : "xcode" + } +} \ No newline at end of file diff --git a/SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Utilitarian.imageset/Contents.json b/SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Utilitarian.imageset/Contents.json new file mode 100644 index 0000000..aefef29 --- /dev/null +++ b/SimpleBattery WatchKit Extension/Assets.xcassets/Complication.complicationset/Utilitarian.imageset/Contents.json @@ -0,0 +1,28 @@ +{ + "images" : [ + { + "idiom" : "watch", + "scale" : "2x", + "screen-width" : "<=145" + }, + { + "idiom" : "watch", + "scale" : "2x", + "screen-width" : ">161" + }, + { + "idiom" : "watch", + "scale" : "2x", + "screen-width" : ">145" + }, + { + "idiom" : "watch", + "scale" : "2x", + "screen-width" : ">183" + } + ], + "info" : { + "version" : 1, + "author" : "xcode" + } +} \ No newline at end of file diff --git a/SimpleBattery WatchKit Extension/Assets.xcassets/Contents.json b/SimpleBattery WatchKit Extension/Assets.xcassets/Contents.json new file mode 100644 index 0000000..da4a164 --- /dev/null +++ b/SimpleBattery WatchKit Extension/Assets.xcassets/Contents.json @@ -0,0 +1,6 @@ +{ + "info" : { + "version" : 1, + "author" : "xcode" + } +} \ No newline at end of file diff --git a/SimpleBattery WatchKit Extension/ComplicationController.swift b/SimpleBattery WatchKit Extension/ComplicationController.swift new file mode 100644 index 0000000..51d4e95 --- /dev/null +++ b/SimpleBattery WatchKit Extension/ComplicationController.swift @@ -0,0 +1,77 @@ +// +// ComplicationController.swift +// SimpleBattery WatchKit Extension +// +// Created by Jordan Koch on 3/2/19. +// Copyright © 2019 Jordan Koch. All rights reserved. +// + +import WatchKit +import ClockKit + + +class ComplicationController: NSObject, CLKComplicationDataSource { + + // MARK: - Timeline Configuration + + func getSupportedTimeTravelDirections(for complication: CLKComplication, withHandler handler: @escaping (CLKComplicationTimeTravelDirections) -> Void) { + //handler([.forward, .backward]) + handler([]) + } + + func getTimelineStartDate(for complication: CLKComplication, withHandler handler: @escaping (Date?) -> Void) { + handler(nil) + } + + func getTimelineEndDate(for complication: CLKComplication, withHandler handler: @escaping (Date?) -> Void) { + handler(nil) + } + + func getPrivacyBehavior(for complication: CLKComplication, withHandler handler: @escaping (CLKComplicationPrivacyBehavior) -> Void) { + handler(.showOnLockScreen) + } + + // MARK: - Timeline Population + + func getCurrentTimelineEntry(for complication: CLKComplication, withHandler handler: @escaping (CLKComplicationTimelineEntry?) -> Void) { + // Call the handler with the current timeline entry + + let device = WKInterfaceDevice.current() + device.isBatteryMonitoringEnabled = true + let battery = device.batteryLevel + let theTemplate = CLKComplicationTemplateUtilitarianSmallFlat() + theTemplate.textProvider = CLKSimpleTextProvider(text: String(format: "%.0f", (battery * 100))+"%") + + let entry = CLKComplicationTimelineEntry(date: Date(), complicationTemplate: theTemplate) + + handler(entry) + } + + func getTimelineEntries(for complication: CLKComplication, before date: Date, limit: Int, withHandler handler: @escaping ([CLKComplicationTimelineEntry]?) -> Void) { + // Call the handler with the timeline entries prior to the given date + handler(nil) + } + + func getTimelineEntries(for complication: CLKComplication, after date: Date, limit: Int, withHandler handler: @escaping ([CLKComplicationTimelineEntry]?) -> Void) { + // Call the handler with the timeline entries after to the given date + handler(nil) + } + + // MARK: - Placeholder Templates + + func getLocalizableSampleTemplate(for complication: CLKComplication, withHandler handler: @escaping (CLKComplicationTemplate?) -> Void) { + // This method will be called once per supported complication, and the results will be cached + + switch complication.family { + case .utilitarianSmall: + let theTemplate = CLKComplicationTemplateUtilitarianSmallFlat() + theTemplate.textProvider = CLKSimpleTextProvider(text: "50%") + + handler(theTemplate) + + default: + handler(nil) + } + } + +} diff --git a/SimpleBattery WatchKit Extension/ExtensionDelegate.swift b/SimpleBattery WatchKit Extension/ExtensionDelegate.swift new file mode 100644 index 0000000..2c3ee83 --- /dev/null +++ b/SimpleBattery WatchKit Extension/ExtensionDelegate.swift @@ -0,0 +1,74 @@ +// +// ExtensionDelegate.swift +// SimpleBattery WatchKit Extension +// +// Created by Jordan Koch on 3/2/19. +// Copyright © 2019 Jordan Koch. All rights reserved. +// + +import WatchKit + +class ExtensionDelegate: NSObject, WKExtensionDelegate { + + func scheduleTask() { + let next = Date(timeIntervalSinceNow: 5) + WKExtension.shared().scheduleBackgroundRefresh(withPreferredDate: next, userInfo: nil) { (error) in + if (error != nil) { + print("error") + } + } + } + + func applicationDidFinishLaunching() { + // Perform any final initialization of your application. + + scheduleTask() + } + + func applicationDidBecomeActive() { + // Restart any tasks that were paused (or not yet started) while the application was inactive. If the application was previously in the background, optionally refresh the user interface. + } + + func applicationWillResignActive() { + // Sent when the application is about to move from active to inactive state. This can occur for certain types of temporary interruptions (such as an incoming phone call or SMS message) or when the user quits the application and it begins the transition to the background state. + // Use this method to pause ongoing tasks, disable timers, etc. + } + + func handle(_ backgroundTasks: Set) { + // Sent when the system needs to launch the application in the background to process tasks. Tasks arrive in a set, so loop through and process each one. + for task in backgroundTasks { + // Use a switch statement to check the task type + switch task { + case let backgroundTask as WKApplicationRefreshBackgroundTask: + // Be sure to complete the background task once you’re done. + + let server = CLKComplicationServer.sharedInstance() + server.activeComplications?.forEach(server.extendTimeline) + server.activeComplications?.forEach(server.reloadTimeline) + + scheduleTask() + + backgroundTask.setTaskCompletedWithSnapshot(false) + case let snapshotTask as WKSnapshotRefreshBackgroundTask: + // Snapshot tasks have a unique completion call, make sure to set your expiration date + snapshotTask.setTaskCompleted(restoredDefaultState: true, estimatedSnapshotExpiration: Date.distantFuture, userInfo: nil) + case let connectivityTask as WKWatchConnectivityRefreshBackgroundTask: + // Be sure to complete the connectivity task once you’re done. + connectivityTask.setTaskCompletedWithSnapshot(false) + case let urlSessionTask as WKURLSessionRefreshBackgroundTask: + // Be sure to complete the URL session task once you’re done. + urlSessionTask.setTaskCompletedWithSnapshot(false) + case let relevantShortcutTask as WKRelevantShortcutRefreshBackgroundTask: + // Be sure to complete the relevant-shortcut task once you're done. + relevantShortcutTask.setTaskCompletedWithSnapshot(false) + case let intentDidRunTask as WKIntentDidRunRefreshBackgroundTask: + // Be sure to complete the intent-did-run task once you're done. + intentDidRunTask.setTaskCompletedWithSnapshot(false) + default: + // make sure to complete unhandled task types + task.setTaskCompletedWithSnapshot(false) + } + } + } + +} diff --git a/SimpleBattery WatchKit Extension/Info.plist b/SimpleBattery WatchKit Extension/Info.plist new file mode 100644 index 0000000..482a1f1 --- /dev/null +++ b/SimpleBattery WatchKit Extension/Info.plist @@ -0,0 +1,43 @@ + + + + + CFBundleDevelopmentRegion + $(DEVELOPMENT_LANGUAGE) + CFBundleDisplayName + SimpleBattery WatchKit Extension + CFBundleExecutable + $(EXECUTABLE_NAME) + CFBundleIdentifier + $(PRODUCT_BUNDLE_IDENTIFIER) + CFBundleInfoDictionaryVersion + 6.0 + CFBundleName + $(PRODUCT_NAME) + CFBundlePackageType + XPC! + CFBundleShortVersionString + 1.0 + CFBundleVersion + 1 + CLKComplicationPrincipalClass + $(PRODUCT_MODULE_NAME).ComplicationController + CLKComplicationSupportedFamilies + + CLKComplicationFamilyUtilitarianSmall + CLKComplicationFamilyUtilitarianSmallFlat + + NSExtension + + NSExtensionAttributes + + WKAppBundleIdentifier + com.jordankoch.SimpleBattery.watchkitapp + + NSExtensionPointIdentifier + com.apple.watchkit + + WKExtensionDelegateClassName + $(PRODUCT_MODULE_NAME).ExtensionDelegate + + diff --git a/SimpleBattery WatchKit Extension/InterfaceController.swift b/SimpleBattery WatchKit Extension/InterfaceController.swift new file mode 100644 index 0000000..24b9421 --- /dev/null +++ b/SimpleBattery WatchKit Extension/InterfaceController.swift @@ -0,0 +1,31 @@ +// +// InterfaceController.swift +// SimpleBattery WatchKit Extension +// +// Created by Jordan Koch on 3/2/19. +// Copyright © 2019 Jordan Koch. All rights reserved. +// + +import WatchKit +import Foundation + + +class InterfaceController: WKInterfaceController { + + override func awake(withContext context: Any?) { + super.awake(withContext: context) + + // Configure interface objects here. + } + + override func willActivate() { + // This method is called when watch view controller is about to be visible to user + super.willActivate() + } + + override func didDeactivate() { + // This method is called when watch view controller is no longer visible + super.didDeactivate() + } + +} diff --git a/SimpleBattery.xcodeproj/project.pbxproj b/SimpleBattery.xcodeproj/project.pbxproj new file mode 100644 index 0000000..ce1d5e4 --- /dev/null +++ b/SimpleBattery.xcodeproj/project.pbxproj @@ -0,0 +1,626 @@ +// !$*UTF8*$! +{ + archiveVersion = 1; + classes = { + }; + objectVersion = 50; + objects = { + +/* Begin PBXBuildFile section */ + 8CB25D2F222B52FB00E76BE0 /* AppDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8CB25D2E222B52FB00E76BE0 /* AppDelegate.swift */; }; + 8CB25D31222B52FB00E76BE0 /* ViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8CB25D30222B52FB00E76BE0 /* ViewController.swift */; }; + 8CB25D34222B52FB00E76BE0 /* Main.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 8CB25D32222B52FB00E76BE0 /* Main.storyboard */; }; + 8CB25D36222B52FB00E76BE0 /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 8CB25D35222B52FB00E76BE0 /* Assets.xcassets */; }; + 8CB25D39222B52FB00E76BE0 /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 8CB25D37222B52FB00E76BE0 /* LaunchScreen.storyboard */; }; + 8CB25D3E222B52FB00E76BE0 /* SimpleBattery WatchKit App.app in Embed Watch Content */ = {isa = PBXBuildFile; fileRef = 8CB25D3D222B52FB00E76BE0 /* SimpleBattery WatchKit App.app */; }; + 8CB25D44222B52FB00E76BE0 /* Interface.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 8CB25D42222B52FB00E76BE0 /* Interface.storyboard */; }; + 8CB25D46222B52FC00E76BE0 /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 8CB25D45222B52FC00E76BE0 /* Assets.xcassets */; }; + 8CB25D4D222B52FC00E76BE0 /* SimpleBattery WatchKit Extension.appex in Embed App Extensions */ = {isa = PBXBuildFile; fileRef = 8CB25D4C222B52FC00E76BE0 /* SimpleBattery WatchKit Extension.appex */; settings = {ATTRIBUTES = (RemoveHeadersOnCopy, ); }; }; + 8CB25D52222B52FC00E76BE0 /* InterfaceController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8CB25D51222B52FC00E76BE0 /* InterfaceController.swift */; }; + 8CB25D54222B52FC00E76BE0 /* ExtensionDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8CB25D53222B52FC00E76BE0 /* ExtensionDelegate.swift */; }; + 8CB25D56222B52FC00E76BE0 /* ComplicationController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8CB25D55222B52FC00E76BE0 /* ComplicationController.swift */; }; + 8CB25D58222B52FC00E76BE0 /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 8CB25D57222B52FC00E76BE0 /* Assets.xcassets */; }; +/* End PBXBuildFile section */ + +/* Begin PBXContainerItemProxy section */ + 8CB25D3F222B52FB00E76BE0 /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 8CB25D23222B52FB00E76BE0 /* Project object */; + proxyType = 1; + remoteGlobalIDString = 8CB25D3C222B52FB00E76BE0; + remoteInfo = "SimpleBattery WatchKit App"; + }; + 8CB25D4E222B52FC00E76BE0 /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 8CB25D23222B52FB00E76BE0 /* Project object */; + proxyType = 1; + remoteGlobalIDString = 8CB25D4B222B52FC00E76BE0; + remoteInfo = "SimpleBattery WatchKit Extension"; + }; +/* End PBXContainerItemProxy section */ + +/* Begin PBXCopyFilesBuildPhase section */ + 8CB25D5F222B52FC00E76BE0 /* Embed App Extensions */ = { + isa = PBXCopyFilesBuildPhase; + buildActionMask = 2147483647; + dstPath = ""; + dstSubfolderSpec = 13; + files = ( + 8CB25D4D222B52FC00E76BE0 /* SimpleBattery WatchKit Extension.appex in Embed App Extensions */, + ); + name = "Embed App Extensions"; + runOnlyForDeploymentPostprocessing = 0; + }; + 8CB25D63222B52FC00E76BE0 /* Embed Watch Content */ = { + isa = PBXCopyFilesBuildPhase; + buildActionMask = 2147483647; + dstPath = "$(CONTENTS_FOLDER_PATH)/Watch"; + dstSubfolderSpec = 16; + files = ( + 8CB25D3E222B52FB00E76BE0 /* SimpleBattery WatchKit App.app in Embed Watch Content */, + ); + name = "Embed Watch Content"; + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXCopyFilesBuildPhase section */ + +/* Begin PBXFileReference section */ + 8CB25D2B222B52FB00E76BE0 /* SimpleBattery.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = SimpleBattery.app; sourceTree = BUILT_PRODUCTS_DIR; }; + 8CB25D2E222B52FB00E76BE0 /* AppDelegate.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AppDelegate.swift; sourceTree = ""; }; + 8CB25D30222B52FB00E76BE0 /* ViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ViewController.swift; sourceTree = ""; }; + 8CB25D33222B52FB00E76BE0 /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/Main.storyboard; sourceTree = ""; }; + 8CB25D35222B52FB00E76BE0 /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = ""; }; + 8CB25D38222B52FB00E76BE0 /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/LaunchScreen.storyboard; sourceTree = ""; }; + 8CB25D3A222B52FB00E76BE0 /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = ""; }; + 8CB25D3D222B52FB00E76BE0 /* SimpleBattery WatchKit App.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = "SimpleBattery WatchKit App.app"; sourceTree = BUILT_PRODUCTS_DIR; }; + 8CB25D43222B52FB00E76BE0 /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/Interface.storyboard; sourceTree = ""; }; + 8CB25D45222B52FC00E76BE0 /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = ""; }; + 8CB25D47222B52FC00E76BE0 /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = ""; }; + 8CB25D4C222B52FC00E76BE0 /* SimpleBattery WatchKit Extension.appex */ = {isa = PBXFileReference; explicitFileType = "wrapper.app-extension"; includeInIndex = 0; path = "SimpleBattery WatchKit Extension.appex"; sourceTree = BUILT_PRODUCTS_DIR; }; + 8CB25D51222B52FC00E76BE0 /* InterfaceController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = InterfaceController.swift; sourceTree = ""; }; + 8CB25D53222B52FC00E76BE0 /* ExtensionDelegate.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ExtensionDelegate.swift; sourceTree = ""; }; + 8CB25D55222B52FC00E76BE0 /* ComplicationController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ComplicationController.swift; sourceTree = ""; }; + 8CB25D57222B52FC00E76BE0 /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = ""; }; + 8CB25D59222B52FC00E76BE0 /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = ""; }; +/* End PBXFileReference section */ + +/* Begin PBXFrameworksBuildPhase section */ + 8CB25D28222B52FB00E76BE0 /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + runOnlyForDeploymentPostprocessing = 0; + }; + 8CB25D49222B52FC00E76BE0 /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXFrameworksBuildPhase section */ + +/* Begin PBXGroup section */ + 8CB25D22222B52FB00E76BE0 = { + isa = PBXGroup; + children = ( + 8CB25D2D222B52FB00E76BE0 /* SimpleBattery */, + 8CB25D41222B52FB00E76BE0 /* SimpleBattery WatchKit App */, + 8CB25D50222B52FC00E76BE0 /* SimpleBattery WatchKit Extension */, + 8CB25D2C222B52FB00E76BE0 /* Products */, + ); + sourceTree = ""; + }; + 8CB25D2C222B52FB00E76BE0 /* Products */ = { + isa = PBXGroup; + children = ( + 8CB25D2B222B52FB00E76BE0 /* SimpleBattery.app */, + 8CB25D3D222B52FB00E76BE0 /* SimpleBattery WatchKit App.app */, + 8CB25D4C222B52FC00E76BE0 /* SimpleBattery WatchKit Extension.appex */, + ); + name = Products; + sourceTree = ""; + }; + 8CB25D2D222B52FB00E76BE0 /* SimpleBattery */ = { + isa = PBXGroup; + children = ( + 8CB25D2E222B52FB00E76BE0 /* AppDelegate.swift */, + 8CB25D30222B52FB00E76BE0 /* ViewController.swift */, + 8CB25D32222B52FB00E76BE0 /* Main.storyboard */, + 8CB25D35222B52FB00E76BE0 /* Assets.xcassets */, + 8CB25D37222B52FB00E76BE0 /* LaunchScreen.storyboard */, + 8CB25D3A222B52FB00E76BE0 /* Info.plist */, + ); + path = SimpleBattery; + sourceTree = ""; + }; + 8CB25D41222B52FB00E76BE0 /* SimpleBattery WatchKit App */ = { + isa = PBXGroup; + children = ( + 8CB25D42222B52FB00E76BE0 /* Interface.storyboard */, + 8CB25D45222B52FC00E76BE0 /* Assets.xcassets */, + 8CB25D47222B52FC00E76BE0 /* Info.plist */, + ); + path = "SimpleBattery WatchKit App"; + sourceTree = ""; + }; + 8CB25D50222B52FC00E76BE0 /* SimpleBattery WatchKit Extension */ = { + isa = PBXGroup; + children = ( + 8CB25D51222B52FC00E76BE0 /* InterfaceController.swift */, + 8CB25D53222B52FC00E76BE0 /* ExtensionDelegate.swift */, + 8CB25D55222B52FC00E76BE0 /* ComplicationController.swift */, + 8CB25D57222B52FC00E76BE0 /* Assets.xcassets */, + 8CB25D59222B52FC00E76BE0 /* Info.plist */, + ); + path = "SimpleBattery WatchKit Extension"; + sourceTree = ""; + }; +/* End PBXGroup section */ + +/* Begin PBXNativeTarget section */ + 8CB25D2A222B52FB00E76BE0 /* SimpleBattery */ = { + isa = PBXNativeTarget; + buildConfigurationList = 8CB25D64222B52FC00E76BE0 /* Build configuration list for PBXNativeTarget "SimpleBattery" */; + buildPhases = ( + 8CB25D27222B52FB00E76BE0 /* Sources */, + 8CB25D28222B52FB00E76BE0 /* Frameworks */, + 8CB25D29222B52FB00E76BE0 /* Resources */, + 8CB25D63222B52FC00E76BE0 /* Embed Watch Content */, + ); + buildRules = ( + ); + dependencies = ( + 8CB25D40222B52FB00E76BE0 /* PBXTargetDependency */, + ); + name = SimpleBattery; + productName = SimpleBattery; + productReference = 8CB25D2B222B52FB00E76BE0 /* SimpleBattery.app */; + productType = "com.apple.product-type.application"; + }; + 8CB25D3C222B52FB00E76BE0 /* SimpleBattery WatchKit App */ = { + isa = PBXNativeTarget; + buildConfigurationList = 8CB25D60222B52FC00E76BE0 /* Build configuration list for PBXNativeTarget "SimpleBattery WatchKit App" */; + buildPhases = ( + 8CB25D3B222B52FB00E76BE0 /* Resources */, + 8CB25D5F222B52FC00E76BE0 /* Embed App Extensions */, + ); + buildRules = ( + ); + dependencies = ( + 8CB25D4F222B52FC00E76BE0 /* PBXTargetDependency */, + ); + name = "SimpleBattery WatchKit App"; + productName = "SimpleBattery WatchKit App"; + productReference = 8CB25D3D222B52FB00E76BE0 /* SimpleBattery WatchKit App.app */; + productType = "com.apple.product-type.application.watchapp2"; + }; + 8CB25D4B222B52FC00E76BE0 /* SimpleBattery WatchKit Extension */ = { + isa = PBXNativeTarget; + buildConfigurationList = 8CB25D5C222B52FC00E76BE0 /* Build configuration list for PBXNativeTarget "SimpleBattery WatchKit Extension" */; + buildPhases = ( + 8CB25D48222B52FC00E76BE0 /* Sources */, + 8CB25D49222B52FC00E76BE0 /* Frameworks */, + 8CB25D4A222B52FC00E76BE0 /* Resources */, + ); + buildRules = ( + ); + dependencies = ( + ); + name = "SimpleBattery WatchKit Extension"; + productName = "SimpleBattery WatchKit Extension"; + productReference = 8CB25D4C222B52FC00E76BE0 /* SimpleBattery WatchKit Extension.appex */; + productType = "com.apple.product-type.watchkit2-extension"; + }; +/* End PBXNativeTarget section */ + +/* Begin PBXProject section */ + 8CB25D23222B52FB00E76BE0 /* Project object */ = { + isa = PBXProject; + attributes = { + LastSwiftUpdateCheck = 1020; + LastUpgradeCheck = 1020; + ORGANIZATIONNAME = "Jordan Koch"; + TargetAttributes = { + 8CB25D2A222B52FB00E76BE0 = { + CreatedOnToolsVersion = 10.2; + }; + 8CB25D3C222B52FB00E76BE0 = { + CreatedOnToolsVersion = 10.2; + }; + 8CB25D4B222B52FC00E76BE0 = { + CreatedOnToolsVersion = 10.2; + }; + }; + }; + buildConfigurationList = 8CB25D26222B52FB00E76BE0 /* Build configuration list for PBXProject "SimpleBattery" */; + compatibilityVersion = "Xcode 9.3"; + developmentRegion = en; + hasScannedForEncodings = 0; + knownRegions = ( + en, + Base, + ); + mainGroup = 8CB25D22222B52FB00E76BE0; + productRefGroup = 8CB25D2C222B52FB00E76BE0 /* Products */; + projectDirPath = ""; + projectRoot = ""; + targets = ( + 8CB25D2A222B52FB00E76BE0 /* SimpleBattery */, + 8CB25D3C222B52FB00E76BE0 /* SimpleBattery WatchKit App */, + 8CB25D4B222B52FC00E76BE0 /* SimpleBattery WatchKit Extension */, + ); + }; +/* End PBXProject section */ + +/* Begin PBXResourcesBuildPhase section */ + 8CB25D29222B52FB00E76BE0 /* Resources */ = { + isa = PBXResourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + 8CB25D39222B52FB00E76BE0 /* LaunchScreen.storyboard in Resources */, + 8CB25D36222B52FB00E76BE0 /* Assets.xcassets in Resources */, + 8CB25D34222B52FB00E76BE0 /* Main.storyboard in Resources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; + 8CB25D3B222B52FB00E76BE0 /* Resources */ = { + isa = PBXResourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + 8CB25D46222B52FC00E76BE0 /* Assets.xcassets in Resources */, + 8CB25D44222B52FB00E76BE0 /* Interface.storyboard in Resources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; + 8CB25D4A222B52FC00E76BE0 /* Resources */ = { + isa = PBXResourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + 8CB25D58222B52FC00E76BE0 /* Assets.xcassets in Resources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXResourcesBuildPhase section */ + +/* Begin PBXSourcesBuildPhase section */ + 8CB25D27222B52FB00E76BE0 /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + 8CB25D31222B52FB00E76BE0 /* ViewController.swift in Sources */, + 8CB25D2F222B52FB00E76BE0 /* AppDelegate.swift in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; + 8CB25D48222B52FC00E76BE0 /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + 8CB25D54222B52FC00E76BE0 /* ExtensionDelegate.swift in Sources */, + 8CB25D52222B52FC00E76BE0 /* InterfaceController.swift in Sources */, + 8CB25D56222B52FC00E76BE0 /* ComplicationController.swift in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXSourcesBuildPhase section */ + +/* Begin PBXTargetDependency section */ + 8CB25D40222B52FB00E76BE0 /* PBXTargetDependency */ = { + isa = PBXTargetDependency; + target = 8CB25D3C222B52FB00E76BE0 /* SimpleBattery WatchKit App */; + targetProxy = 8CB25D3F222B52FB00E76BE0 /* PBXContainerItemProxy */; + }; + 8CB25D4F222B52FC00E76BE0 /* PBXTargetDependency */ = { + isa = PBXTargetDependency; + target = 8CB25D4B222B52FC00E76BE0 /* SimpleBattery WatchKit Extension */; + targetProxy = 8CB25D4E222B52FC00E76BE0 /* PBXContainerItemProxy */; + }; +/* End PBXTargetDependency section */ + +/* Begin PBXVariantGroup section */ + 8CB25D32222B52FB00E76BE0 /* Main.storyboard */ = { + isa = PBXVariantGroup; + children = ( + 8CB25D33222B52FB00E76BE0 /* Base */, + ); + name = Main.storyboard; + sourceTree = ""; + }; + 8CB25D37222B52FB00E76BE0 /* LaunchScreen.storyboard */ = { + isa = PBXVariantGroup; + children = ( + 8CB25D38222B52FB00E76BE0 /* Base */, + ); + name = LaunchScreen.storyboard; + sourceTree = ""; + }; + 8CB25D42222B52FB00E76BE0 /* Interface.storyboard */ = { + isa = PBXVariantGroup; + children = ( + 8CB25D43222B52FB00E76BE0 /* Base */, + ); + name = Interface.storyboard; + sourceTree = ""; + }; +/* End PBXVariantGroup section */ + +/* Begin XCBuildConfiguration section */ + 8CB25D5A222B52FC00E76BE0 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_NONNULL = YES; + CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++14"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_ENABLE_OBJC_WEAK = YES; + CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_COMMA = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; + CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; + CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; + CLANG_WARN_STRICT_PROTOTYPES = YES; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + CODE_SIGN_IDENTITY = "iPhone Developer"; + COPY_PHASE_STRIP = NO; + DEBUG_INFORMATION_FORMAT = dwarf; + ENABLE_STRICT_OBJC_MSGSEND = YES; + ENABLE_TESTABILITY = YES; + GCC_C_LANGUAGE_STANDARD = gnu11; + GCC_DYNAMIC_NO_PIC = NO; + GCC_NO_COMMON_BLOCKS = YES; + GCC_OPTIMIZATION_LEVEL = 0; + GCC_PREPROCESSOR_DEFINITIONS = ( + "DEBUG=1", + "$(inherited)", + ); + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 12.2; + MTL_ENABLE_DEBUG_INFO = INCLUDE_SOURCE; + MTL_FAST_MATH = YES; + ONLY_ACTIVE_ARCH = YES; + SDKROOT = iphoneos; + SWIFT_ACTIVE_COMPILATION_CONDITIONS = DEBUG; + SWIFT_OPTIMIZATION_LEVEL = "-Onone"; + }; + name = Debug; + }; + 8CB25D5B222B52FC00E76BE0 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_NONNULL = YES; + CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++14"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_ENABLE_OBJC_WEAK = YES; + CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_COMMA = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; + CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; + CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; + CLANG_WARN_STRICT_PROTOTYPES = YES; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + CODE_SIGN_IDENTITY = "iPhone Developer"; + COPY_PHASE_STRIP = NO; + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + ENABLE_NS_ASSERTIONS = NO; + ENABLE_STRICT_OBJC_MSGSEND = YES; + GCC_C_LANGUAGE_STANDARD = gnu11; + GCC_NO_COMMON_BLOCKS = YES; + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 12.2; + MTL_ENABLE_DEBUG_INFO = NO; + MTL_FAST_MATH = YES; + SDKROOT = iphoneos; + SWIFT_COMPILATION_MODE = wholemodule; + SWIFT_OPTIMIZATION_LEVEL = "-O"; + VALIDATE_PRODUCT = YES; + }; + name = Release; + }; + 8CB25D5D222B52FC00E76BE0 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + ASSETCATALOG_COMPILER_COMPLICATION_NAME = Complication; + CODE_SIGN_STYLE = Automatic; + DEVELOPMENT_TEAM = 5JAGPKCDD7; + INFOPLIST_FILE = "SimpleBattery WatchKit Extension/Info.plist"; + LD_RUNPATH_SEARCH_PATHS = ( + "$(inherited)", + "@executable_path/Frameworks", + "@executable_path/../../Frameworks", + ); + PRODUCT_BUNDLE_IDENTIFIER = com.jordankoch.SimpleBattery.watchkitapp.watchkitextension; + PRODUCT_NAME = "${TARGET_NAME}"; + SDKROOT = watchos; + SKIP_INSTALL = YES; + SWIFT_VERSION = 5.0; + TARGETED_DEVICE_FAMILY = 4; + WATCHOS_DEPLOYMENT_TARGET = 5.2; + }; + name = Debug; + }; + 8CB25D5E222B52FC00E76BE0 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + ASSETCATALOG_COMPILER_COMPLICATION_NAME = Complication; + CODE_SIGN_STYLE = Automatic; + DEVELOPMENT_TEAM = 5JAGPKCDD7; + INFOPLIST_FILE = "SimpleBattery WatchKit Extension/Info.plist"; + LD_RUNPATH_SEARCH_PATHS = ( + "$(inherited)", + "@executable_path/Frameworks", + "@executable_path/../../Frameworks", + ); + PRODUCT_BUNDLE_IDENTIFIER = com.jordankoch.SimpleBattery.watchkitapp.watchkitextension; + PRODUCT_NAME = "${TARGET_NAME}"; + SDKROOT = watchos; + SKIP_INSTALL = YES; + SWIFT_VERSION = 5.0; + TARGETED_DEVICE_FAMILY = 4; + WATCHOS_DEPLOYMENT_TARGET = 5.2; + }; + name = Release; + }; + 8CB25D61222B52FC00E76BE0 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_EMBED_SWIFT_STANDARD_LIBRARIES = YES; + ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + CODE_SIGN_STYLE = Automatic; + DEVELOPMENT_TEAM = 5JAGPKCDD7; + IBSC_MODULE = SimpleBattery_WatchKit_Extension; + INFOPLIST_FILE = "SimpleBattery WatchKit App/Info.plist"; + PRODUCT_BUNDLE_IDENTIFIER = com.jordankoch.SimpleBattery.watchkitapp; + PRODUCT_NAME = "$(TARGET_NAME)"; + SDKROOT = watchos; + SKIP_INSTALL = YES; + SWIFT_VERSION = 5.0; + TARGETED_DEVICE_FAMILY = 4; + WATCHOS_DEPLOYMENT_TARGET = 5.2; + }; + name = Debug; + }; + 8CB25D62222B52FC00E76BE0 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_EMBED_SWIFT_STANDARD_LIBRARIES = YES; + ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + CODE_SIGN_STYLE = Automatic; + DEVELOPMENT_TEAM = 5JAGPKCDD7; + IBSC_MODULE = SimpleBattery_WatchKit_Extension; + INFOPLIST_FILE = "SimpleBattery WatchKit App/Info.plist"; + PRODUCT_BUNDLE_IDENTIFIER = com.jordankoch.SimpleBattery.watchkitapp; + PRODUCT_NAME = "$(TARGET_NAME)"; + SDKROOT = watchos; + SKIP_INSTALL = YES; + SWIFT_VERSION = 5.0; + TARGETED_DEVICE_FAMILY = 4; + WATCHOS_DEPLOYMENT_TARGET = 5.2; + }; + name = Release; + }; + 8CB25D65222B52FC00E76BE0 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + CODE_SIGN_STYLE = Automatic; + DEVELOPMENT_TEAM = 5JAGPKCDD7; + INFOPLIST_FILE = SimpleBattery/Info.plist; + LD_RUNPATH_SEARCH_PATHS = ( + "$(inherited)", + "@executable_path/Frameworks", + ); + PRODUCT_BUNDLE_IDENTIFIER = com.jordankoch.SimpleBattery; + PRODUCT_NAME = "$(TARGET_NAME)"; + SWIFT_VERSION = 5.0; + TARGETED_DEVICE_FAMILY = "1,2"; + }; + name = Debug; + }; + 8CB25D66222B52FC00E76BE0 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + CODE_SIGN_STYLE = Automatic; + DEVELOPMENT_TEAM = 5JAGPKCDD7; + INFOPLIST_FILE = SimpleBattery/Info.plist; + LD_RUNPATH_SEARCH_PATHS = ( + "$(inherited)", + "@executable_path/Frameworks", + ); + PRODUCT_BUNDLE_IDENTIFIER = com.jordankoch.SimpleBattery; + PRODUCT_NAME = "$(TARGET_NAME)"; + SWIFT_VERSION = 5.0; + TARGETED_DEVICE_FAMILY = "1,2"; + }; + name = Release; + }; +/* End XCBuildConfiguration section */ + +/* Begin XCConfigurationList section */ + 8CB25D26222B52FB00E76BE0 /* Build configuration list for PBXProject "SimpleBattery" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 8CB25D5A222B52FC00E76BE0 /* Debug */, + 8CB25D5B222B52FC00E76BE0 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + 8CB25D5C222B52FC00E76BE0 /* Build configuration list for PBXNativeTarget "SimpleBattery WatchKit Extension" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 8CB25D5D222B52FC00E76BE0 /* Debug */, + 8CB25D5E222B52FC00E76BE0 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + 8CB25D60222B52FC00E76BE0 /* Build configuration list for PBXNativeTarget "SimpleBattery WatchKit App" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 8CB25D61222B52FC00E76BE0 /* Debug */, + 8CB25D62222B52FC00E76BE0 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + 8CB25D64222B52FC00E76BE0 /* Build configuration list for PBXNativeTarget "SimpleBattery" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 8CB25D65222B52FC00E76BE0 /* Debug */, + 8CB25D66222B52FC00E76BE0 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; +/* End XCConfigurationList section */ + }; + rootObject = 8CB25D23222B52FB00E76BE0 /* Project object */; +} diff --git a/SimpleBattery.xcodeproj/project.xcworkspace/contents.xcworkspacedata b/SimpleBattery.xcodeproj/project.xcworkspace/contents.xcworkspacedata new file mode 100644 index 0000000..3a12b99 --- /dev/null +++ b/SimpleBattery.xcodeproj/project.xcworkspace/contents.xcworkspacedata @@ -0,0 +1,7 @@ + + + + + diff --git a/SimpleBattery.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist b/SimpleBattery.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist new file mode 100644 index 0000000..18d9810 --- /dev/null +++ b/SimpleBattery.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist @@ -0,0 +1,8 @@ + + + + + IDEDidComputeMac32BitWarning + + + diff --git a/SimpleBattery.xcodeproj/project.xcworkspace/xcuserdata/me.xcuserdatad/UserInterfaceState.xcuserstate b/SimpleBattery.xcodeproj/project.xcworkspace/xcuserdata/me.xcuserdatad/UserInterfaceState.xcuserstate new file mode 100644 index 0000000000000000000000000000000000000000..e74399032096a1cbe95aff9ecdc11bc729659034 GIT binary patch literal 18897 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 literal 0 HcmV?d00001 diff --git a/SimpleBattery.xcodeproj/xcuserdata/me.xcuserdatad/xcschemes/xcschememanagement.plist b/SimpleBattery.xcodeproj/xcuserdata/me.xcuserdatad/xcschemes/xcschememanagement.plist new file mode 100644 index 0000000..c735c3c --- /dev/null +++ b/SimpleBattery.xcodeproj/xcuserdata/me.xcuserdatad/xcschemes/xcschememanagement.plist @@ -0,0 +1,24 @@ + + + + + SchemeUserState + + SimpleBattery WatchKit App (Complication).xcscheme_^#shared#^_ + + orderHint + 2 + + SimpleBattery WatchKit App.xcscheme_^#shared#^_ + + orderHint + 1 + + SimpleBattery.xcscheme_^#shared#^_ + + orderHint + 0 + + + + diff --git a/SimpleBattery/AppDelegate.swift b/SimpleBattery/AppDelegate.swift new file mode 100644 index 0000000..fb60c5a --- /dev/null +++ b/SimpleBattery/AppDelegate.swift @@ -0,0 +1,46 @@ +// +// AppDelegate.swift +// SimpleBattery +// +// Created by Jordan Koch on 3/2/19. +// Copyright © 2019 Jordan Koch. All rights reserved. +// + +import UIKit + +@UIApplicationMain +class AppDelegate: UIResponder, UIApplicationDelegate { + + var window: UIWindow? + + + func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool { + // Override point for customization after application launch. + return true + } + + func applicationWillResignActive(_ application: UIApplication) { + // Sent when the application is about to move from active to inactive state. This can occur for certain types of temporary interruptions (such as an incoming phone call or SMS message) or when the user quits the application and it begins the transition to the background state. + // Use this method to pause ongoing tasks, disable timers, and invalidate graphics rendering callbacks. Games should use this method to pause the game. + } + + func applicationDidEnterBackground(_ application: UIApplication) { + // Use this method to release shared resources, save user data, invalidate timers, and store enough application state information to restore your application to its current state in case it is terminated later. + // If your application supports background execution, this method is called instead of applicationWillTerminate: when the user quits. + } + + func applicationWillEnterForeground(_ application: UIApplication) { + // Called as part of the transition from the background to the active state; here you can undo many of the changes made on entering the background. + } + + func applicationDidBecomeActive(_ application: UIApplication) { + // Restart any tasks that were paused (or not yet started) while the application was inactive. If the application was previously in the background, optionally refresh the user interface. + } + + func applicationWillTerminate(_ application: UIApplication) { + // Called when the application is about to terminate. Save data if appropriate. See also applicationDidEnterBackground:. + } + + +} + diff --git a/SimpleBattery/Assets.xcassets/AppIcon.appiconset/Contents.json b/SimpleBattery/Assets.xcassets/AppIcon.appiconset/Contents.json new file mode 100644 index 0000000..d8db8d6 --- /dev/null +++ b/SimpleBattery/Assets.xcassets/AppIcon.appiconset/Contents.json @@ -0,0 +1,98 @@ +{ + "images" : [ + { + "idiom" : "iphone", + "size" : "20x20", + "scale" : "2x" + }, + { + "idiom" : "iphone", + "size" : "20x20", + "scale" : "3x" + }, + { + "idiom" : "iphone", + "size" : "29x29", + "scale" : "2x" + }, + { + "idiom" : "iphone", + "size" : "29x29", + "scale" : "3x" + }, + { + "idiom" : "iphone", + "size" : "40x40", + "scale" : "2x" + }, + { + "idiom" : "iphone", + "size" : "40x40", + "scale" : "3x" + }, + { + "idiom" : "iphone", + "size" : "60x60", + "scale" : "2x" + }, + { + "idiom" : "iphone", + "size" : "60x60", + "scale" : "3x" + }, + { + "idiom" : "ipad", + "size" : "20x20", + "scale" : "1x" + }, + { + "idiom" : "ipad", + "size" : "20x20", + "scale" : "2x" + }, + { + "idiom" : "ipad", + "size" : "29x29", + "scale" : "1x" + }, + { + "idiom" : "ipad", + "size" : "29x29", + "scale" : "2x" + }, + { + "idiom" : "ipad", + "size" : "40x40", + "scale" : "1x" + }, + { + "idiom" : "ipad", + "size" : "40x40", + "scale" : "2x" + }, + { + "idiom" : "ipad", + "size" : "76x76", + "scale" : "1x" + }, + { + "idiom" : "ipad", + "size" : "76x76", + "scale" : "2x" + }, + { + "idiom" : "ipad", + "size" : "83.5x83.5", + "scale" : "2x" + }, + { + "idiom" : "ios-marketing", + "size" : "1024x1024", + "scale" : "1x" + } + ], + "info" : { + "version" : 1, + "author" : "xcode" + } +} \ No newline at end of file diff --git a/SimpleBattery/Assets.xcassets/Contents.json b/SimpleBattery/Assets.xcassets/Contents.json new file mode 100644 index 0000000..da4a164 --- /dev/null +++ b/SimpleBattery/Assets.xcassets/Contents.json @@ -0,0 +1,6 @@ +{ + "info" : { + "version" : 1, + "author" : "xcode" + } +} \ No newline at end of file diff --git a/SimpleBattery/Base.lproj/LaunchScreen.storyboard b/SimpleBattery/Base.lproj/LaunchScreen.storyboard new file mode 100644 index 0000000..bfa3612 --- /dev/null +++ b/SimpleBattery/Base.lproj/LaunchScreen.storyboard @@ -0,0 +1,25 @@ + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/SimpleBattery/Base.lproj/Main.storyboard b/SimpleBattery/Base.lproj/Main.storyboard new file mode 100644 index 0000000..2f037a6 --- /dev/null +++ b/SimpleBattery/Base.lproj/Main.storyboard @@ -0,0 +1,24 @@ + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/SimpleBattery/Info.plist b/SimpleBattery/Info.plist new file mode 100644 index 0000000..16be3b6 --- /dev/null +++ b/SimpleBattery/Info.plist @@ -0,0 +1,45 @@ + + + + + CFBundleDevelopmentRegion + $(DEVELOPMENT_LANGUAGE) + CFBundleExecutable + $(EXECUTABLE_NAME) + CFBundleIdentifier + $(PRODUCT_BUNDLE_IDENTIFIER) + CFBundleInfoDictionaryVersion + 6.0 + CFBundleName + $(PRODUCT_NAME) + CFBundlePackageType + APPL + CFBundleShortVersionString + 1.0 + CFBundleVersion + 1 + LSRequiresIPhoneOS + + UILaunchStoryboardName + LaunchScreen + UIMainStoryboardFile + Main + UIRequiredDeviceCapabilities + + armv7 + + UISupportedInterfaceOrientations + + UIInterfaceOrientationPortrait + UIInterfaceOrientationLandscapeLeft + UIInterfaceOrientationLandscapeRight + + UISupportedInterfaceOrientations~ipad + + UIInterfaceOrientationPortrait + UIInterfaceOrientationPortraitUpsideDown + UIInterfaceOrientationLandscapeLeft + UIInterfaceOrientationLandscapeRight + + + diff --git a/SimpleBattery/ViewController.swift b/SimpleBattery/ViewController.swift new file mode 100644 index 0000000..8062b1f --- /dev/null +++ b/SimpleBattery/ViewController.swift @@ -0,0 +1,20 @@ +// +// ViewController.swift +// SimpleBattery +// +// Created by Jordan Koch on 3/2/19. +// Copyright © 2019 Jordan Koch. All rights reserved. +// + +import UIKit + +class ViewController: UIViewController { + + override func viewDidLoad() { + super.viewDidLoad() + // Do any additional setup after loading the view. + } + + +} +