diff --git a/MultiTaskUnitConverter/MultiTaskUnitConverter.xcodeproj/project.pbxproj b/MultiTaskUnitConverter/MultiTaskUnitConverter.xcodeproj/project.pbxproj new file mode 100644 index 0000000..2527479 --- /dev/null +++ b/MultiTaskUnitConverter/MultiTaskUnitConverter.xcodeproj/project.pbxproj @@ -0,0 +1,349 @@ +// !$*UTF8*$! +{ + archiveVersion = 1; + classes = { + }; + objectVersion = 50; + objects = { + +/* Begin PBXBuildFile section */ + 923D85092408DE2C000F70E6 /* AppDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = 923D85082408DE2C000F70E6 /* AppDelegate.swift */; }; + 923D850B2408DE2C000F70E6 /* SceneDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = 923D850A2408DE2C000F70E6 /* SceneDelegate.swift */; }; + 923D85102408DE2C000F70E6 /* Main.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 923D850E2408DE2C000F70E6 /* Main.storyboard */; }; + 923D85122408DE2E000F70E6 /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 923D85112408DE2E000F70E6 /* Assets.xcassets */; }; + 923D85152408DE2E000F70E6 /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 923D85132408DE2E000F70E6 /* LaunchScreen.storyboard */; }; + 923D851D2408E2C0000F70E6 /* UnitConverterViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 923D851C2408E2C0000F70E6 /* UnitConverterViewController.swift */; }; + 9286007A240F55AC00EE54C8 /* CurrencyUnitViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 92860079240F55AC00EE54C8 /* CurrencyUnitViewController.swift */; }; + 92881F69240DFC35004692FC /* CurrencyUnitConverter.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 92881F68240DFC35004692FC /* CurrencyUnitConverter.storyboard */; }; +/* End PBXBuildFile section */ + +/* Begin PBXFileReference section */ + 923D85052408DE2C000F70E6 /* MultiTaskUnitConverter.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = MultiTaskUnitConverter.app; sourceTree = BUILT_PRODUCTS_DIR; }; + 923D85082408DE2C000F70E6 /* AppDelegate.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AppDelegate.swift; sourceTree = ""; }; + 923D850A2408DE2C000F70E6 /* SceneDelegate.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SceneDelegate.swift; sourceTree = ""; }; + 923D850F2408DE2C000F70E6 /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/Main.storyboard; sourceTree = ""; }; + 923D85112408DE2E000F70E6 /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = ""; }; + 923D85142408DE2E000F70E6 /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/LaunchScreen.storyboard; sourceTree = ""; }; + 923D85162408DE2E000F70E6 /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = ""; }; + 923D851C2408E2C0000F70E6 /* UnitConverterViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = UnitConverterViewController.swift; sourceTree = ""; }; + 92860079240F55AC00EE54C8 /* CurrencyUnitViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CurrencyUnitViewController.swift; sourceTree = ""; }; + 92881F68240DFC35004692FC /* CurrencyUnitConverter.storyboard */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; path = CurrencyUnitConverter.storyboard; sourceTree = ""; }; +/* End PBXFileReference section */ + +/* Begin PBXFrameworksBuildPhase section */ + 923D85022408DE2C000F70E6 /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXFrameworksBuildPhase section */ + +/* Begin PBXGroup section */ + 923D84FC2408DE2C000F70E6 = { + isa = PBXGroup; + children = ( + 923D85072408DE2C000F70E6 /* MultiTaskUnitConverter */, + 923D85062408DE2C000F70E6 /* Products */, + ); + sourceTree = ""; + }; + 923D85062408DE2C000F70E6 /* Products */ = { + isa = PBXGroup; + children = ( + 923D85052408DE2C000F70E6 /* MultiTaskUnitConverter.app */, + ); + name = Products; + sourceTree = ""; + }; + 923D85072408DE2C000F70E6 /* MultiTaskUnitConverter */ = { + isa = PBXGroup; + children = ( + 923D85082408DE2C000F70E6 /* AppDelegate.swift */, + 923D850A2408DE2C000F70E6 /* SceneDelegate.swift */, + 923D850E2408DE2C000F70E6 /* Main.storyboard */, + 923D85112408DE2E000F70E6 /* Assets.xcassets */, + 923D85132408DE2E000F70E6 /* LaunchScreen.storyboard */, + 923D85162408DE2E000F70E6 /* Info.plist */, + 923D851C2408E2C0000F70E6 /* UnitConverterViewController.swift */, + 92881F68240DFC35004692FC /* CurrencyUnitConverter.storyboard */, + 92860079240F55AC00EE54C8 /* CurrencyUnitViewController.swift */, + ); + path = MultiTaskUnitConverter; + sourceTree = ""; + }; +/* End PBXGroup section */ + +/* Begin PBXNativeTarget section */ + 923D85042408DE2C000F70E6 /* MultiTaskUnitConverter */ = { + isa = PBXNativeTarget; + buildConfigurationList = 923D85192408DE2E000F70E6 /* Build configuration list for PBXNativeTarget "MultiTaskUnitConverter" */; + buildPhases = ( + 923D85012408DE2C000F70E6 /* Sources */, + 923D85022408DE2C000F70E6 /* Frameworks */, + 923D85032408DE2C000F70E6 /* Resources */, + ); + buildRules = ( + ); + dependencies = ( + ); + name = MultiTaskUnitConverter; + productName = MultiTaskUnitConverter; + productReference = 923D85052408DE2C000F70E6 /* MultiTaskUnitConverter.app */; + productType = "com.apple.product-type.application"; + }; +/* End PBXNativeTarget section */ + +/* Begin PBXProject section */ + 923D84FD2408DE2C000F70E6 /* Project object */ = { + isa = PBXProject; + attributes = { + LastSwiftUpdateCheck = 1130; + LastUpgradeCheck = 1130; + ORGANIZATIONNAME = Lambda_School_Loaner_241; + TargetAttributes = { + 923D85042408DE2C000F70E6 = { + CreatedOnToolsVersion = 11.3.1; + }; + }; + }; + buildConfigurationList = 923D85002408DE2C000F70E6 /* Build configuration list for PBXProject "MultiTaskUnitConverter" */; + compatibilityVersion = "Xcode 9.3"; + developmentRegion = en; + hasScannedForEncodings = 0; + knownRegions = ( + en, + Base, + ); + mainGroup = 923D84FC2408DE2C000F70E6; + productRefGroup = 923D85062408DE2C000F70E6 /* Products */; + projectDirPath = ""; + projectRoot = ""; + targets = ( + 923D85042408DE2C000F70E6 /* MultiTaskUnitConverter */, + ); + }; +/* End PBXProject section */ + +/* Begin PBXResourcesBuildPhase section */ + 923D85032408DE2C000F70E6 /* Resources */ = { + isa = PBXResourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + 92881F69240DFC35004692FC /* CurrencyUnitConverter.storyboard in Resources */, + 923D85152408DE2E000F70E6 /* LaunchScreen.storyboard in Resources */, + 923D85122408DE2E000F70E6 /* Assets.xcassets in Resources */, + 923D85102408DE2C000F70E6 /* Main.storyboard in Resources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXResourcesBuildPhase section */ + +/* Begin PBXSourcesBuildPhase section */ + 923D85012408DE2C000F70E6 /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + 923D85092408DE2C000F70E6 /* AppDelegate.swift in Sources */, + 923D850B2408DE2C000F70E6 /* SceneDelegate.swift in Sources */, + 9286007A240F55AC00EE54C8 /* CurrencyUnitViewController.swift in Sources */, + 923D851D2408E2C0000F70E6 /* UnitConverterViewController.swift in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXSourcesBuildPhase section */ + +/* Begin PBXVariantGroup section */ + 923D850E2408DE2C000F70E6 /* Main.storyboard */ = { + isa = PBXVariantGroup; + children = ( + 923D850F2408DE2C000F70E6 /* Base */, + ); + name = Main.storyboard; + sourceTree = ""; + }; + 923D85132408DE2E000F70E6 /* LaunchScreen.storyboard */ = { + isa = PBXVariantGroup; + children = ( + 923D85142408DE2E000F70E6 /* Base */, + ); + name = LaunchScreen.storyboard; + sourceTree = ""; + }; +/* End PBXVariantGroup section */ + +/* Begin XCBuildConfiguration section */ + 923D85172408DE2E000F70E6 /* 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; + 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 = 13.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; + }; + 923D85182408DE2E000F70E6 /* 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; + 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 = 13.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; + }; + 923D851A2408DE2E000F70E6 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + CODE_SIGN_STYLE = Automatic; + INFOPLIST_FILE = MultiTaskUnitConverter/Info.plist; + LD_RUNPATH_SEARCH_PATHS = ( + "$(inherited)", + "@executable_path/Frameworks", + ); + PRODUCT_BUNDLE_IDENTIFIER = com.kennedysamarakody.MultiTaskUnitConverter; + PRODUCT_NAME = "$(TARGET_NAME)"; + SWIFT_VERSION = 5.0; + TARGETED_DEVICE_FAMILY = "1,2"; + }; + name = Debug; + }; + 923D851B2408DE2E000F70E6 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + CODE_SIGN_STYLE = Automatic; + INFOPLIST_FILE = MultiTaskUnitConverter/Info.plist; + LD_RUNPATH_SEARCH_PATHS = ( + "$(inherited)", + "@executable_path/Frameworks", + ); + PRODUCT_BUNDLE_IDENTIFIER = com.kennedysamarakody.MultiTaskUnitConverter; + PRODUCT_NAME = "$(TARGET_NAME)"; + SWIFT_VERSION = 5.0; + TARGETED_DEVICE_FAMILY = "1,2"; + }; + name = Release; + }; +/* End XCBuildConfiguration section */ + +/* Begin XCConfigurationList section */ + 923D85002408DE2C000F70E6 /* Build configuration list for PBXProject "MultiTaskUnitConverter" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 923D85172408DE2E000F70E6 /* Debug */, + 923D85182408DE2E000F70E6 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + 923D85192408DE2E000F70E6 /* Build configuration list for PBXNativeTarget "MultiTaskUnitConverter" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 923D851A2408DE2E000F70E6 /* Debug */, + 923D851B2408DE2E000F70E6 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; +/* End XCConfigurationList section */ + }; + rootObject = 923D84FD2408DE2C000F70E6 /* Project object */; +} diff --git a/MultiTaskUnitConverter/MultiTaskUnitConverter.xcodeproj/project.xcworkspace/contents.xcworkspacedata b/MultiTaskUnitConverter/MultiTaskUnitConverter.xcodeproj/project.xcworkspace/contents.xcworkspacedata new file mode 100644 index 0000000..5c84833 --- /dev/null +++ b/MultiTaskUnitConverter/MultiTaskUnitConverter.xcodeproj/project.xcworkspace/contents.xcworkspacedata @@ -0,0 +1,7 @@ + + + + + diff --git a/MultiTaskUnitConverter/MultiTaskUnitConverter.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist b/MultiTaskUnitConverter/MultiTaskUnitConverter.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist new file mode 100644 index 0000000..18d9810 --- /dev/null +++ b/MultiTaskUnitConverter/MultiTaskUnitConverter.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist @@ -0,0 +1,8 @@ + + + + + IDEDidComputeMac32BitWarning + + + diff --git a/MultiTaskUnitConverter/MultiTaskUnitConverter/AppDelegate.swift b/MultiTaskUnitConverter/MultiTaskUnitConverter/AppDelegate.swift new file mode 100644 index 0000000..596129b --- /dev/null +++ b/MultiTaskUnitConverter/MultiTaskUnitConverter/AppDelegate.swift @@ -0,0 +1,37 @@ +// +// AppDelegate.swift +// MultiTaskUnitConverter +// +// Created by Lambda_School_Loaner_241 on 2/28/20. +// Copyright © 2020 Lambda_School_Loaner_241. All rights reserved. +// + +import UIKit + +@UIApplicationMain +class AppDelegate: UIResponder, UIApplicationDelegate { + + + + func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool { + // Override point for customization after application launch. + return true + } + + // MARK: UISceneSession Lifecycle + + func application(_ application: UIApplication, configurationForConnecting connectingSceneSession: UISceneSession, options: UIScene.ConnectionOptions) -> UISceneConfiguration { + // Called when a new scene session is being created. + // Use this method to select a configuration to create the new scene with. + return UISceneConfiguration(name: "Default Configuration", sessionRole: connectingSceneSession.role) + } + + func application(_ application: UIApplication, didDiscardSceneSessions sceneSessions: Set) { + // Called when the user discards a scene session. + // If any sessions were discarded while the application was not running, this will be called shortly after application:didFinishLaunchingWithOptions. + // Use this method to release any resources that were specific to the discarded scenes, as they will not return. + } + + +} + diff --git a/MultiTaskUnitConverter/MultiTaskUnitConverter/Assets.xcassets/AppIcon.appiconset/Contents.json b/MultiTaskUnitConverter/MultiTaskUnitConverter/Assets.xcassets/AppIcon.appiconset/Contents.json new file mode 100644 index 0000000..d8db8d6 --- /dev/null +++ b/MultiTaskUnitConverter/MultiTaskUnitConverter/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/MultiTaskUnitConverter/MultiTaskUnitConverter/Assets.xcassets/Contents.json b/MultiTaskUnitConverter/MultiTaskUnitConverter/Assets.xcassets/Contents.json new file mode 100644 index 0000000..da4a164 --- /dev/null +++ b/MultiTaskUnitConverter/MultiTaskUnitConverter/Assets.xcassets/Contents.json @@ -0,0 +1,6 @@ +{ + "info" : { + "version" : 1, + "author" : "xcode" + } +} \ No newline at end of file diff --git a/MultiTaskUnitConverter/MultiTaskUnitConverter/Assets.xcassets/kelly-sikkema-cXkrqY2wFyc-unsplash.imageset/Contents.json b/MultiTaskUnitConverter/MultiTaskUnitConverter/Assets.xcassets/kelly-sikkema-cXkrqY2wFyc-unsplash.imageset/Contents.json new file mode 100644 index 0000000..5619e5a --- /dev/null +++ b/MultiTaskUnitConverter/MultiTaskUnitConverter/Assets.xcassets/kelly-sikkema-cXkrqY2wFyc-unsplash.imageset/Contents.json @@ -0,0 +1,23 @@ +{ + "images" : [ + { + "idiom" : "universal", + "filename" : "kelly-sikkema-cXkrqY2wFyc-unsplash.jpg", + "scale" : "1x" + }, + { + "idiom" : "universal", + "filename" : "kelly-sikkema-cXkrqY2wFyc-unsplash-1.jpg", + "scale" : "2x" + }, + { + "idiom" : "universal", + "filename" : "kelly-sikkema-cXkrqY2wFyc-unsplash-2.jpg", + "scale" : "3x" + } + ], + "info" : { + "version" : 1, + "author" : "xcode" + } +} \ No newline at end of file diff --git a/MultiTaskUnitConverter/MultiTaskUnitConverter/Assets.xcassets/kelly-sikkema-cXkrqY2wFyc-unsplash.imageset/kelly-sikkema-cXkrqY2wFyc-unsplash-1.jpg b/MultiTaskUnitConverter/MultiTaskUnitConverter/Assets.xcassets/kelly-sikkema-cXkrqY2wFyc-unsplash.imageset/kelly-sikkema-cXkrqY2wFyc-unsplash-1.jpg new file mode 100644 index 0000000..5ea1dc1 Binary files /dev/null and b/MultiTaskUnitConverter/MultiTaskUnitConverter/Assets.xcassets/kelly-sikkema-cXkrqY2wFyc-unsplash.imageset/kelly-sikkema-cXkrqY2wFyc-unsplash-1.jpg differ diff --git a/MultiTaskUnitConverter/MultiTaskUnitConverter/Assets.xcassets/kelly-sikkema-cXkrqY2wFyc-unsplash.imageset/kelly-sikkema-cXkrqY2wFyc-unsplash-2.jpg b/MultiTaskUnitConverter/MultiTaskUnitConverter/Assets.xcassets/kelly-sikkema-cXkrqY2wFyc-unsplash.imageset/kelly-sikkema-cXkrqY2wFyc-unsplash-2.jpg new file mode 100644 index 0000000..5ea1dc1 Binary files /dev/null and b/MultiTaskUnitConverter/MultiTaskUnitConverter/Assets.xcassets/kelly-sikkema-cXkrqY2wFyc-unsplash.imageset/kelly-sikkema-cXkrqY2wFyc-unsplash-2.jpg differ diff --git a/MultiTaskUnitConverter/MultiTaskUnitConverter/Assets.xcassets/kelly-sikkema-cXkrqY2wFyc-unsplash.imageset/kelly-sikkema-cXkrqY2wFyc-unsplash.jpg b/MultiTaskUnitConverter/MultiTaskUnitConverter/Assets.xcassets/kelly-sikkema-cXkrqY2wFyc-unsplash.imageset/kelly-sikkema-cXkrqY2wFyc-unsplash.jpg new file mode 100644 index 0000000..5ea1dc1 Binary files /dev/null and b/MultiTaskUnitConverter/MultiTaskUnitConverter/Assets.xcassets/kelly-sikkema-cXkrqY2wFyc-unsplash.imageset/kelly-sikkema-cXkrqY2wFyc-unsplash.jpg differ diff --git a/MultiTaskUnitConverter/MultiTaskUnitConverter/Assets.xcassets/william-warby-WahfNoqbYnM-unsplash.imageset/Contents.json b/MultiTaskUnitConverter/MultiTaskUnitConverter/Assets.xcassets/william-warby-WahfNoqbYnM-unsplash.imageset/Contents.json new file mode 100644 index 0000000..fb509f3 --- /dev/null +++ b/MultiTaskUnitConverter/MultiTaskUnitConverter/Assets.xcassets/william-warby-WahfNoqbYnM-unsplash.imageset/Contents.json @@ -0,0 +1,23 @@ +{ + "images" : [ + { + "idiom" : "universal", + "filename" : "william-warby-WahfNoqbYnM-unsplash.jpg", + "scale" : "1x" + }, + { + "idiom" : "universal", + "filename" : "william-warby-WahfNoqbYnM-unsplash-1.jpg", + "scale" : "2x" + }, + { + "idiom" : "universal", + "filename" : "william-warby-WahfNoqbYnM-unsplash-2.jpg", + "scale" : "3x" + } + ], + "info" : { + "version" : 1, + "author" : "xcode" + } +} \ No newline at end of file diff --git a/MultiTaskUnitConverter/MultiTaskUnitConverter/Assets.xcassets/william-warby-WahfNoqbYnM-unsplash.imageset/william-warby-WahfNoqbYnM-unsplash-1.jpg b/MultiTaskUnitConverter/MultiTaskUnitConverter/Assets.xcassets/william-warby-WahfNoqbYnM-unsplash.imageset/william-warby-WahfNoqbYnM-unsplash-1.jpg new file mode 100644 index 0000000..222a6fc Binary files /dev/null and b/MultiTaskUnitConverter/MultiTaskUnitConverter/Assets.xcassets/william-warby-WahfNoqbYnM-unsplash.imageset/william-warby-WahfNoqbYnM-unsplash-1.jpg differ diff --git a/MultiTaskUnitConverter/MultiTaskUnitConverter/Assets.xcassets/william-warby-WahfNoqbYnM-unsplash.imageset/william-warby-WahfNoqbYnM-unsplash-2.jpg b/MultiTaskUnitConverter/MultiTaskUnitConverter/Assets.xcassets/william-warby-WahfNoqbYnM-unsplash.imageset/william-warby-WahfNoqbYnM-unsplash-2.jpg new file mode 100644 index 0000000..222a6fc Binary files /dev/null and b/MultiTaskUnitConverter/MultiTaskUnitConverter/Assets.xcassets/william-warby-WahfNoqbYnM-unsplash.imageset/william-warby-WahfNoqbYnM-unsplash-2.jpg differ diff --git a/MultiTaskUnitConverter/MultiTaskUnitConverter/Assets.xcassets/william-warby-WahfNoqbYnM-unsplash.imageset/william-warby-WahfNoqbYnM-unsplash.jpg b/MultiTaskUnitConverter/MultiTaskUnitConverter/Assets.xcassets/william-warby-WahfNoqbYnM-unsplash.imageset/william-warby-WahfNoqbYnM-unsplash.jpg new file mode 100644 index 0000000..222a6fc Binary files /dev/null and b/MultiTaskUnitConverter/MultiTaskUnitConverter/Assets.xcassets/william-warby-WahfNoqbYnM-unsplash.imageset/william-warby-WahfNoqbYnM-unsplash.jpg differ diff --git a/MultiTaskUnitConverter/MultiTaskUnitConverter/Base.lproj/LaunchScreen.storyboard b/MultiTaskUnitConverter/MultiTaskUnitConverter/Base.lproj/LaunchScreen.storyboard new file mode 100644 index 0000000..865e932 --- /dev/null +++ b/MultiTaskUnitConverter/MultiTaskUnitConverter/Base.lproj/LaunchScreen.storyboard @@ -0,0 +1,25 @@ + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/MultiTaskUnitConverter/MultiTaskUnitConverter/Base.lproj/Main.storyboard b/MultiTaskUnitConverter/MultiTaskUnitConverter/Base.lproj/Main.storyboard new file mode 100644 index 0000000..7386088 --- /dev/null +++ b/MultiTaskUnitConverter/MultiTaskUnitConverter/Base.lproj/Main.storyboard @@ -0,0 +1,210 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/MultiTaskUnitConverter/MultiTaskUnitConverter/CurrencyUnitConverter.storyboard b/MultiTaskUnitConverter/MultiTaskUnitConverter/CurrencyUnitConverter.storyboard new file mode 100644 index 0000000..526de88 --- /dev/null +++ b/MultiTaskUnitConverter/MultiTaskUnitConverter/CurrencyUnitConverter.storyboard @@ -0,0 +1,163 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/MultiTaskUnitConverter/MultiTaskUnitConverter/CurrencyUnitViewController.swift b/MultiTaskUnitConverter/MultiTaskUnitConverter/CurrencyUnitViewController.swift new file mode 100644 index 0000000..d1ab9fb --- /dev/null +++ b/MultiTaskUnitConverter/MultiTaskUnitConverter/CurrencyUnitViewController.swift @@ -0,0 +1,113 @@ +// +// CurrencyUnitViewController.swift +// MultiTaskUnitConverter +// +// Created by Lambda_School_Loaner_241 on 3/3/20. +// Copyright © 2020 Lambda_School_Loaner_241. All rights reserved. +// + +import UIKit + +enum Currency { + case bitcoin + case peso + case euro + case rupees + case pounds +} + +class CurrencyUnitViewController: UIViewController { + var currency: Currency = .bitcoin + + // Mark:- IBOutlets/Properties + @IBOutlet weak var currencyTextField: UITextField! + @IBOutlet weak var secondCurrencyTextField: UITextField! + @IBOutlet weak var secondCurrencyLabel: UILabel! + + @IBOutlet weak var euroCurrencyButton: UIButton! + @IBOutlet weak var rupeesCurrencyButton: UIButton! + @IBOutlet weak var poundsCurrencyButton: UIButton! + @IBOutlet weak var bitCoinButton: UIButton! + @IBOutlet weak var pesoCurrencyButton: UIButton! + + + + override func viewDidLoad() { + super.viewDidLoad() + + } + + // Mark:- IBActions + @IBAction func calculateButtonPressed(_ sender: Any) { + guard let userInput = currencyTextField.text, !userInput.isEmpty, let userInputDouble = Double(userInput) else { return } + + secondCurrencyTextField.text = "\(convert(userInputDouble))" + } + @IBAction func euroButtonPressed(_ sender: UIButton) { + sender.isSelected.toggle() + + if sender.isSelected { + currency = .euro + secondCurrencyLabel.text = " Euro: " + } + } + + @IBAction func rupeesButtonPressed(_ sender: UIButton) { + sender.isSelected.toggle() + + if sender.isSelected { + currency = .rupees + secondCurrencyLabel.text = " Rupees: " + } + } + @IBAction func poundsButtonPressed(_ sender: UIButton) { + sender.isSelected.toggle() + + if sender.isSelected { + currency = .pounds + secondCurrencyLabel.text = " Pounds: " + } + } + @IBAction func bitCoinPressed(_ sender: UIButton) { + sender.isSelected.toggle() + + if sender.isSelected { + currency = .bitcoin + secondCurrencyLabel.text = " Bitcoin: " + } + } + @IBAction func pesoButtonPressed(_ sender: UIButton) { + sender.isSelected.toggle() + + if sender.isSelected { + currency = .peso + secondCurrencyLabel.text = " Peso: " + } + } + + // Mark:- Helper Methods + func convert(_ money: Double) -> Double { + let euroConstant = 0.9 + let rupeesConstant = 0.01 + let poundsConstant = 0.78 + let pesoConstant = 19.4 + let bitCoin = 0.0001 + + switch(currency){ + case .bitcoin: + return money * bitCoin + case .euro: + return money * euroConstant + case .peso: + return money * pesoConstant + case .pounds: + return Double(round(money * poundsConstant*100)/100) + case .rupees: + return money * rupeesConstant + + } + + } + + +} diff --git a/MultiTaskUnitConverter/MultiTaskUnitConverter/Info.plist b/MultiTaskUnitConverter/MultiTaskUnitConverter/Info.plist new file mode 100644 index 0000000..2a3483c --- /dev/null +++ b/MultiTaskUnitConverter/MultiTaskUnitConverter/Info.plist @@ -0,0 +1,64 @@ + + + + + CFBundleDevelopmentRegion + $(DEVELOPMENT_LANGUAGE) + CFBundleExecutable + $(EXECUTABLE_NAME) + CFBundleIdentifier + $(PRODUCT_BUNDLE_IDENTIFIER) + CFBundleInfoDictionaryVersion + 6.0 + CFBundleName + $(PRODUCT_NAME) + CFBundlePackageType + $(PRODUCT_BUNDLE_PACKAGE_TYPE) + CFBundleShortVersionString + 1.0 + CFBundleVersion + 1 + LSRequiresIPhoneOS + + UIApplicationSceneManifest + + UIApplicationSupportsMultipleScenes + + UISceneConfigurations + + UIWindowSceneSessionRoleApplication + + + UISceneConfigurationName + Default Configuration + UISceneDelegateClassName + $(PRODUCT_MODULE_NAME).SceneDelegate + UISceneStoryboardFile + Main + + + + + UILaunchStoryboardName + LaunchScreen + UIMainStoryboardFile + Main + UIRequiredDeviceCapabilities + + armv7 + + UISupportedInterfaceOrientations + + UIInterfaceOrientationPortrait + UIInterfaceOrientationLandscapeLeft + UIInterfaceOrientationLandscapeRight + + UISupportedInterfaceOrientations~ipad + + UIInterfaceOrientationPortrait + UIInterfaceOrientationPortraitUpsideDown + UIInterfaceOrientationLandscapeLeft + UIInterfaceOrientationLandscapeRight + + + diff --git a/MultiTaskUnitConverter/MultiTaskUnitConverter/SceneDelegate.swift b/MultiTaskUnitConverter/MultiTaskUnitConverter/SceneDelegate.swift new file mode 100644 index 0000000..f2615b5 --- /dev/null +++ b/MultiTaskUnitConverter/MultiTaskUnitConverter/SceneDelegate.swift @@ -0,0 +1,53 @@ +// +// SceneDelegate.swift +// MultiTaskUnitConverter +// +// Created by Lambda_School_Loaner_241 on 2/28/20. +// Copyright © 2020 Lambda_School_Loaner_241. All rights reserved. +// + +import UIKit + +class SceneDelegate: UIResponder, UIWindowSceneDelegate { + + var window: UIWindow? + + + func scene(_ scene: UIScene, willConnectTo session: UISceneSession, options connectionOptions: UIScene.ConnectionOptions) { + // Use this method to optionally configure and attach the UIWindow `window` to the provided UIWindowScene `scene`. + // If using a storyboard, the `window` property will automatically be initialized and attached to the scene. + // This delegate does not imply the connecting scene or session are new (see `application:configurationForConnectingSceneSession` instead). + guard let _ = (scene as? UIWindowScene) else { return } + } + + func sceneDidDisconnect(_ scene: UIScene) { + // Called as the scene is being released by the system. + // This occurs shortly after the scene enters the background, or when its session is discarded. + // Release any resources associated with this scene that can be re-created the next time the scene connects. + // The scene may re-connect later, as its session was not neccessarily discarded (see `application:didDiscardSceneSessions` instead). + } + + func sceneDidBecomeActive(_ scene: UIScene) { + // Called when the scene has moved from an inactive state to an active state. + // Use this method to restart any tasks that were paused (or not yet started) when the scene was inactive. + } + + func sceneWillResignActive(_ scene: UIScene) { + // Called when the scene will move from an active state to an inactive state. + // This may occur due to temporary interruptions (ex. an incoming phone call). + } + + func sceneWillEnterForeground(_ scene: UIScene) { + // Called as the scene transitions from the background to the foreground. + // Use this method to undo the changes made on entering the background. + } + + func sceneDidEnterBackground(_ scene: UIScene) { + // Called as the scene transitions from the foreground to the background. + // Use this method to save data, release shared resources, and store enough scene-specific state information + // to restore the scene back to its current state. + } + + +} + diff --git a/MultiTaskUnitConverter/MultiTaskUnitConverter/UnitConverterViewController.swift b/MultiTaskUnitConverter/MultiTaskUnitConverter/UnitConverterViewController.swift new file mode 100644 index 0000000..5cacfd8 --- /dev/null +++ b/MultiTaskUnitConverter/MultiTaskUnitConverter/UnitConverterViewController.swift @@ -0,0 +1,160 @@ +// +// UnitConverterViewController.swift +// MultiTaskUnitConverter +// +// Created by Lambda_School_Loaner_241 on 2/28/20. +// Copyright © 2020 Lambda_School_Loaner_241. All rights reserved. +// + +import UIKit + +enum Metric { + case deka + case hecto + case kilo + case deci + case centi + case mili + +} + +class UnitConverterViewController: UIViewController { + var metric: Metric = .centi + + // Mark:- IBOutlets/Properties + @IBOutlet weak var basicUnitTextField: UITextField! + + @IBOutlet weak var metricUnitLabel: UILabel! + + @IBOutlet weak var metricUnitTextField: UITextField! + + @IBOutlet weak var dekaButton: UIButton! + @IBOutlet weak var hectoButton: UIButton! + + @IBOutlet weak var kiloButton: UIButton! + @IBOutlet weak var deciButton: UIButton! + @IBOutlet weak var centiButton: UIButton! + @IBOutlet weak var miliButton: UIButton! + + override func viewDidLoad() { + super.viewDidLoad() + + + + + + // Do any additional setup after loading the view. + } + + // Mark: - IBActions + @IBAction func calculateButtonTapped(_ sender: UIButton) { + /* if let userInput = metricUnitTextField.text { + if let userInputDouble = Double(userInput) { + basicUnitTextField.text = "\(convert(userInputDouble))" + + } + + } */ + if let userInput2 = basicUnitTextField.text { + if let userInput2Double = Double(userInput2){ + metricUnitTextField.text = "\(convert(userInput2Double))" + } + + } + } + + + @IBAction func hectoButtonPressed(_ sender: UIButton) { + sender.isSelected.toggle() + + if sender.isSelected { + metric = .hecto + metricUnitLabel.text = " hecto: " + } + } + + + @IBAction func dekaButtonTapped(_ sender: UIButton) { + sender.isSelected.toggle() + + if sender.isSelected { + metric = .deka + metricUnitLabel.text = " deka: " + + } + } + + @IBAction func kiloButtonPressed(_ sender: UIButton) { + sender.isSelected.toggle() + + if sender.isSelected { + metric = .kilo + metricUnitLabel.text = " kilo: " + } + } + + @IBAction func deciButtonPressed(_ sender: UIButton) { + sender.isSelected.toggle() + + if sender.isSelected { + metric = .deci + metricUnitLabel.text = " deci: " + } + + } + + @IBAction func centiButtonPressed(_ sender: UIButton) { + sender.isSelected.toggle() + + if sender.isSelected { + metric = .centi + metricUnitLabel.text = " centi: " + } + } + @IBAction func miliButtonPressed(_ sender: UIButton) { + sender.isSelected.toggle() + + if sender.isSelected { + metric = .mili + metricUnitLabel.text = " mili: " + } + } + + // Mark :- Helper Method + + func convert(_ m: Double) -> Double { + let hectoConversionRate = 0.01 + let kiloConversionRate = 0.001 + let centiConversionRate = 100.0 + let miliConversionRate = 1000.0 + let dekaConversionRate = 0.1 + let deciConversionRate = 10.0 + + + + switch(metric){ + case .hecto: + return Double(m * hectoConversionRate) + case .kilo: + return Double(m * kiloConversionRate) + case .centi: + return Double(m * centiConversionRate) + case .mili: + return Double(m * miliConversionRate) + case .deka: + return Double(m * dekaConversionRate) + + case .deci: + return Double(m * deciConversionRate) + + } + + + + } + + + +} + +