From 5df92a32f878924dcfb62ba4d3cf0023c6dcc364 Mon Sep 17 00:00:00 2001 From: haoyang Date: Sun, 20 Sep 2020 15:35:54 +0800 Subject: [PATCH] Initial Commit --- Testing.xcodeproj/project.pbxproj | 416 ++++++++++++++++++ .../contents.xcworkspacedata | 7 + .../xcshareddata/IDEWorkspaceChecks.plist | 8 + .../xcshareddata/swiftpm/Package.resolved | 16 + .../xcschemes/xcschememanagement.plist | 14 + Testing/AppDelegate.swift | 37 ++ .../AppIcon.appiconset/Contents.json | 98 +++++ Testing/Assets.xcassets/Contents.json | 6 + .../profile.imageset/Contents.json | 21 + .../profile.imageset/profile.png | Bin 0 -> 17253 bytes Testing/Base.lproj/LaunchScreen.storyboard | 25 ++ Testing/Info.plist | 60 +++ .../Preview Assets.xcassets/Contents.json | 6 + Testing/SceneDelegate.swift | 65 +++ Testing/View/ContentView.swift | 110 +++++ Testing/View/FullModal.swift | 78 ++++ Testing/View/HideTab.swift | 136 ++++++ Testing/View/MerchantPromotionView.swift | 80 ++++ Testing/View/codeScanner.swift | 69 +++ Testing/View/msgData.json | 36 ++ Testing/View/profile.png | Bin 0 -> 17253 bytes Testing/View/select profile.swift | 121 +++++ Testing/merchantPromotionData.json | 29 ++ Testing/promotionData.json | 122 +++++ 24 files changed, 1560 insertions(+) create mode 100644 Testing.xcodeproj/project.pbxproj create mode 100644 Testing.xcodeproj/project.xcworkspace/contents.xcworkspacedata create mode 100644 Testing.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist create mode 100644 Testing.xcodeproj/project.xcworkspace/xcshareddata/swiftpm/Package.resolved create mode 100644 Testing.xcodeproj/xcuserdata/haoyangyip.xcuserdatad/xcschemes/xcschememanagement.plist create mode 100644 Testing/AppDelegate.swift create mode 100644 Testing/Assets.xcassets/AppIcon.appiconset/Contents.json create mode 100644 Testing/Assets.xcassets/Contents.json create mode 100644 Testing/Assets.xcassets/profile.imageset/Contents.json create mode 100644 Testing/Assets.xcassets/profile.imageset/profile.png create mode 100644 Testing/Base.lproj/LaunchScreen.storyboard create mode 100644 Testing/Info.plist create mode 100644 Testing/Preview Content/Preview Assets.xcassets/Contents.json create mode 100644 Testing/SceneDelegate.swift create mode 100644 Testing/View/ContentView.swift create mode 100644 Testing/View/FullModal.swift create mode 100644 Testing/View/HideTab.swift create mode 100644 Testing/View/MerchantPromotionView.swift create mode 100644 Testing/View/codeScanner.swift create mode 100644 Testing/View/msgData.json create mode 100644 Testing/View/profile.png create mode 100644 Testing/View/select profile.swift create mode 100644 Testing/merchantPromotionData.json create mode 100644 Testing/promotionData.json diff --git a/Testing.xcodeproj/project.pbxproj b/Testing.xcodeproj/project.pbxproj new file mode 100644 index 0000000..c55b216 --- /dev/null +++ b/Testing.xcodeproj/project.pbxproj @@ -0,0 +1,416 @@ +// !$*UTF8*$! +{ + archiveVersion = 1; + classes = { + }; + objectVersion = 52; + objects = { + +/* Begin PBXBuildFile section */ + 812786D824FA51E300CB5211 /* promotionData.json in Resources */ = {isa = PBXBuildFile; fileRef = 812786D724FA51E300CB5211 /* promotionData.json */; }; + 812786E024FA527200CB5211 /* merchantPromotionData.json in Resources */ = {isa = PBXBuildFile; fileRef = 812786DF24FA527200CB5211 /* merchantPromotionData.json */; }; + 81330FAE24FF639900B44848 /* msgData.json in Resources */ = {isa = PBXBuildFile; fileRef = 81330FAD24FF639900B44848 /* msgData.json */; }; + 8133101F2508E3A100B44848 /* profile.png in Resources */ = {isa = PBXBuildFile; fileRef = 8133101E2508E3A100B44848 /* profile.png */; }; + 8133102D250B249C00B44848 /* CodeScanner in Frameworks */ = {isa = PBXBuildFile; productRef = 8133102C250B249C00B44848 /* CodeScanner */; }; + 813FE7C824F3BE5D001635D9 /* AppDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = 813FE7C724F3BE5D001635D9 /* AppDelegate.swift */; }; + 813FE7CA24F3BE5D001635D9 /* SceneDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = 813FE7C924F3BE5D001635D9 /* SceneDelegate.swift */; }; + 813FE7CC24F3BE5D001635D9 /* ContentView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 813FE7CB24F3BE5D001635D9 /* ContentView.swift */; }; + 813FE7CE24F3BE6A001635D9 /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 813FE7CD24F3BE6A001635D9 /* Assets.xcassets */; }; + 813FE7D124F3BE6A001635D9 /* Preview Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 813FE7D024F3BE6A001635D9 /* Preview Assets.xcassets */; }; + 813FE7D424F3BE6A001635D9 /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 813FE7D224F3BE6A001635D9 /* LaunchScreen.storyboard */; }; + 814064E9251731CB0082EB1F /* FullModal.swift in Sources */ = {isa = PBXBuildFile; fileRef = 814064E8251731CB0082EB1F /* FullModal.swift */; }; + 81C842C3250F6F6D00937DA9 /* codeScanner.swift in Sources */ = {isa = PBXBuildFile; fileRef = 81C842C2250F6F6D00937DA9 /* codeScanner.swift */; }; + 81C842C5250F6FA200937DA9 /* select profile.swift in Sources */ = {isa = PBXBuildFile; fileRef = 81C842C4250F6FA200937DA9 /* select profile.swift */; }; + 81C842C7250F706F00937DA9 /* HideTab.swift in Sources */ = {isa = PBXBuildFile; fileRef = 81C842C6250F706F00937DA9 /* HideTab.swift */; }; +/* End PBXBuildFile section */ + +/* Begin PBXFileReference section */ + 812786D724FA51E300CB5211 /* promotionData.json */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.json; path = promotionData.json; sourceTree = ""; }; + 812786DF24FA527200CB5211 /* merchantPromotionData.json */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.json; path = merchantPromotionData.json; sourceTree = ""; }; + 81330FAD24FF639900B44848 /* msgData.json */ = {isa = PBXFileReference; lastKnownFileType = text.json; path = msgData.json; sourceTree = ""; }; + 8133101E2508E3A100B44848 /* profile.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = profile.png; sourceTree = ""; }; + 813FE7C424F3BE5D001635D9 /* Testing.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = Testing.app; sourceTree = BUILT_PRODUCTS_DIR; }; + 813FE7C724F3BE5D001635D9 /* AppDelegate.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AppDelegate.swift; sourceTree = ""; }; + 813FE7C924F3BE5D001635D9 /* SceneDelegate.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SceneDelegate.swift; sourceTree = ""; }; + 813FE7CB24F3BE5D001635D9 /* ContentView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ContentView.swift; sourceTree = ""; }; + 813FE7CD24F3BE6A001635D9 /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = ""; }; + 813FE7D024F3BE6A001635D9 /* Preview Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = "Preview Assets.xcassets"; sourceTree = ""; }; + 813FE7D324F3BE6A001635D9 /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/LaunchScreen.storyboard; sourceTree = ""; }; + 813FE7D524F3BE6A001635D9 /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = ""; }; + 814064E8251731CB0082EB1F /* FullModal.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = FullModal.swift; sourceTree = ""; }; + 81C842C2250F6F6D00937DA9 /* codeScanner.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = codeScanner.swift; sourceTree = ""; }; + 81C842C4250F6FA200937DA9 /* select profile.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "select profile.swift"; sourceTree = ""; }; + 81C842C6250F706F00937DA9 /* HideTab.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = HideTab.swift; sourceTree = ""; }; +/* End PBXFileReference section */ + +/* Begin PBXFrameworksBuildPhase section */ + 813FE7C124F3BE5D001635D9 /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + 8133102D250B249C00B44848 /* CodeScanner in Frameworks */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXFrameworksBuildPhase section */ + +/* Begin PBXGroup section */ + 812786E724FA52AC00CB5211 /* View */ = { + isa = PBXGroup; + children = ( + 813FE7CB24F3BE5D001635D9 /* ContentView.swift */, + 81330FAD24FF639900B44848 /* msgData.json */, + 8133101E2508E3A100B44848 /* profile.png */, + 81C842C2250F6F6D00937DA9 /* codeScanner.swift */, + 81C842C4250F6FA200937DA9 /* select profile.swift */, + 81C842C6250F706F00937DA9 /* HideTab.swift */, + 814064E8251731CB0082EB1F /* FullModal.swift */, + ); + path = View; + sourceTree = ""; + }; + 813FE7BB24F3BE5D001635D9 = { + isa = PBXGroup; + children = ( + 813FE7C624F3BE5D001635D9 /* Testing */, + 813FE7C524F3BE5D001635D9 /* Products */, + ); + sourceTree = ""; + }; + 813FE7C524F3BE5D001635D9 /* Products */ = { + isa = PBXGroup; + children = ( + 813FE7C424F3BE5D001635D9 /* Testing.app */, + ); + name = Products; + sourceTree = ""; + }; + 813FE7C624F3BE5D001635D9 /* Testing */ = { + isa = PBXGroup; + children = ( + 812786E724FA52AC00CB5211 /* View */, + 813FE7C724F3BE5D001635D9 /* AppDelegate.swift */, + 813FE7C924F3BE5D001635D9 /* SceneDelegate.swift */, + 813FE7CD24F3BE6A001635D9 /* Assets.xcassets */, + 813FE7D224F3BE6A001635D9 /* LaunchScreen.storyboard */, + 812786D724FA51E300CB5211 /* promotionData.json */, + 812786DF24FA527200CB5211 /* merchantPromotionData.json */, + 813FE7D524F3BE6A001635D9 /* Info.plist */, + 813FE7CF24F3BE6A001635D9 /* Preview Content */, + ); + path = Testing; + sourceTree = ""; + }; + 813FE7CF24F3BE6A001635D9 /* Preview Content */ = { + isa = PBXGroup; + children = ( + 813FE7D024F3BE6A001635D9 /* Preview Assets.xcassets */, + ); + path = "Preview Content"; + sourceTree = ""; + }; +/* End PBXGroup section */ + +/* Begin PBXNativeTarget section */ + 813FE7C324F3BE5D001635D9 /* Testing */ = { + isa = PBXNativeTarget; + buildConfigurationList = 813FE7D824F3BE6A001635D9 /* Build configuration list for PBXNativeTarget "Testing" */; + buildPhases = ( + 813FE7C024F3BE5D001635D9 /* Sources */, + 813FE7C124F3BE5D001635D9 /* Frameworks */, + 813FE7C224F3BE5D001635D9 /* Resources */, + ); + buildRules = ( + ); + dependencies = ( + ); + name = Testing; + packageProductDependencies = ( + 8133102C250B249C00B44848 /* CodeScanner */, + ); + productName = Testing; + productReference = 813FE7C424F3BE5D001635D9 /* Testing.app */; + productType = "com.apple.product-type.application"; + }; +/* End PBXNativeTarget section */ + +/* Begin PBXProject section */ + 813FE7BC24F3BE5D001635D9 /* Project object */ = { + isa = PBXProject; + attributes = { + LastSwiftUpdateCheck = 1160; + LastUpgradeCheck = 1200; + ORGANIZATIONNAME = "Hao Yang Yip"; + TargetAttributes = { + 813FE7C324F3BE5D001635D9 = { + CreatedOnToolsVersion = 11.6; + }; + }; + }; + buildConfigurationList = 813FE7BF24F3BE5D001635D9 /* Build configuration list for PBXProject "Testing" */; + compatibilityVersion = "Xcode 9.3"; + developmentRegion = en; + hasScannedForEncodings = 0; + knownRegions = ( + en, + Base, + ); + mainGroup = 813FE7BB24F3BE5D001635D9; + packageReferences = ( + 8133102B250B249C00B44848 /* XCRemoteSwiftPackageReference "CodeScanner" */, + ); + productRefGroup = 813FE7C524F3BE5D001635D9 /* Products */; + projectDirPath = ""; + projectRoot = ""; + targets = ( + 813FE7C324F3BE5D001635D9 /* Testing */, + ); + }; +/* End PBXProject section */ + +/* Begin PBXResourcesBuildPhase section */ + 813FE7C224F3BE5D001635D9 /* Resources */ = { + isa = PBXResourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + 813FE7D424F3BE6A001635D9 /* LaunchScreen.storyboard in Resources */, + 813FE7D124F3BE6A001635D9 /* Preview Assets.xcassets in Resources */, + 813FE7CE24F3BE6A001635D9 /* Assets.xcassets in Resources */, + 812786E024FA527200CB5211 /* merchantPromotionData.json in Resources */, + 812786D824FA51E300CB5211 /* promotionData.json in Resources */, + 81330FAE24FF639900B44848 /* msgData.json in Resources */, + 8133101F2508E3A100B44848 /* profile.png in Resources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXResourcesBuildPhase section */ + +/* Begin PBXSourcesBuildPhase section */ + 813FE7C024F3BE5D001635D9 /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + 81C842C3250F6F6D00937DA9 /* codeScanner.swift in Sources */, + 81C842C5250F6FA200937DA9 /* select profile.swift in Sources */, + 81C842C7250F706F00937DA9 /* HideTab.swift in Sources */, + 814064E9251731CB0082EB1F /* FullModal.swift in Sources */, + 813FE7C824F3BE5D001635D9 /* AppDelegate.swift in Sources */, + 813FE7CA24F3BE5D001635D9 /* SceneDelegate.swift in Sources */, + 813FE7CC24F3BE5D001635D9 /* ContentView.swift in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXSourcesBuildPhase section */ + +/* Begin PBXVariantGroup section */ + 813FE7D224F3BE6A001635D9 /* LaunchScreen.storyboard */ = { + isa = PBXVariantGroup; + children = ( + 813FE7D324F3BE6A001635D9 /* Base */, + ); + name = LaunchScreen.storyboard; + sourceTree = ""; + }; +/* End PBXVariantGroup section */ + +/* Begin XCBuildConfiguration section */ + 813FE7D624F3BE6A001635D9 /* 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_QUOTED_INCLUDE_IN_FRAMEWORK_HEADER = YES; + 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.0; + 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; + }; + 813FE7D724F3BE6A001635D9 /* 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_QUOTED_INCLUDE_IN_FRAMEWORK_HEADER = YES; + 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.0; + MTL_ENABLE_DEBUG_INFO = NO; + MTL_FAST_MATH = YES; + SDKROOT = iphoneos; + SWIFT_COMPILATION_MODE = wholemodule; + SWIFT_OPTIMIZATION_LEVEL = "-O"; + VALIDATE_PRODUCT = YES; + }; + name = Release; + }; + 813FE7D924F3BE6A001635D9 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + CODE_SIGN_STYLE = Automatic; + DEVELOPMENT_ASSET_PATHS = "\"Testing/Preview Content\""; + DEVELOPMENT_TEAM = ""; + ENABLE_PREVIEWS = YES; + INFOPLIST_FILE = Testing/Info.plist; + LD_RUNPATH_SEARCH_PATHS = ( + "$(inherited)", + "@executable_path/Frameworks", + ); + PRODUCT_BUNDLE_IDENTIFIER = co.julytech.Testing; + PRODUCT_NAME = "$(TARGET_NAME)"; + SWIFT_VERSION = 5.0; + TARGETED_DEVICE_FAMILY = "1,2"; + }; + name = Debug; + }; + 813FE7DA24F3BE6A001635D9 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + CODE_SIGN_STYLE = Automatic; + DEVELOPMENT_ASSET_PATHS = "\"Testing/Preview Content\""; + DEVELOPMENT_TEAM = TW9MAJP3U3; + ENABLE_PREVIEWS = YES; + INFOPLIST_FILE = Testing/Info.plist; + LD_RUNPATH_SEARCH_PATHS = ( + "$(inherited)", + "@executable_path/Frameworks", + ); + PRODUCT_BUNDLE_IDENTIFIER = co.julytech.Testing; + PRODUCT_NAME = "$(TARGET_NAME)"; + SWIFT_VERSION = 5.0; + TARGETED_DEVICE_FAMILY = "1,2"; + }; + name = Release; + }; +/* End XCBuildConfiguration section */ + +/* Begin XCConfigurationList section */ + 813FE7BF24F3BE5D001635D9 /* Build configuration list for PBXProject "Testing" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 813FE7D624F3BE6A001635D9 /* Debug */, + 813FE7D724F3BE6A001635D9 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + 813FE7D824F3BE6A001635D9 /* Build configuration list for PBXNativeTarget "Testing" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 813FE7D924F3BE6A001635D9 /* Debug */, + 813FE7DA24F3BE6A001635D9 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; +/* End XCConfigurationList section */ + +/* Begin XCRemoteSwiftPackageReference section */ + 8133102B250B249C00B44848 /* XCRemoteSwiftPackageReference "CodeScanner" */ = { + isa = XCRemoteSwiftPackageReference; + repositoryURL = "https://github.com/twostraws/CodeScanner.git"; + requirement = { + kind = upToNextMajorVersion; + minimumVersion = 1.0.6; + }; + }; +/* End XCRemoteSwiftPackageReference section */ + +/* Begin XCSwiftPackageProductDependency section */ + 8133102C250B249C00B44848 /* CodeScanner */ = { + isa = XCSwiftPackageProductDependency; + package = 8133102B250B249C00B44848 /* XCRemoteSwiftPackageReference "CodeScanner" */; + productName = CodeScanner; + }; +/* End XCSwiftPackageProductDependency section */ + }; + rootObject = 813FE7BC24F3BE5D001635D9 /* Project object */; +} diff --git a/Testing.xcodeproj/project.xcworkspace/contents.xcworkspacedata b/Testing.xcodeproj/project.xcworkspace/contents.xcworkspacedata new file mode 100644 index 0000000..919434a --- /dev/null +++ b/Testing.xcodeproj/project.xcworkspace/contents.xcworkspacedata @@ -0,0 +1,7 @@ + + + + + diff --git a/Testing.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist b/Testing.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist new file mode 100644 index 0000000..18d9810 --- /dev/null +++ b/Testing.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist @@ -0,0 +1,8 @@ + + + + + IDEDidComputeMac32BitWarning + + + diff --git a/Testing.xcodeproj/project.xcworkspace/xcshareddata/swiftpm/Package.resolved b/Testing.xcodeproj/project.xcworkspace/xcshareddata/swiftpm/Package.resolved new file mode 100644 index 0000000..b4d1648 --- /dev/null +++ b/Testing.xcodeproj/project.xcworkspace/xcshareddata/swiftpm/Package.resolved @@ -0,0 +1,16 @@ +{ + "object": { + "pins": [ + { + "package": "CodeScanner", + "repositoryURL": "https://github.com/twostraws/CodeScanner.git", + "state": { + "branch": null, + "revision": "9d902dec616bd70b1a2a1b1e6d821c10c392ba9f", + "version": "1.0.6" + } + } + ] + }, + "version": 1 +} diff --git a/Testing.xcodeproj/xcuserdata/haoyangyip.xcuserdatad/xcschemes/xcschememanagement.plist b/Testing.xcodeproj/xcuserdata/haoyangyip.xcuserdatad/xcschemes/xcschememanagement.plist new file mode 100644 index 0000000..d7d7de8 --- /dev/null +++ b/Testing.xcodeproj/xcuserdata/haoyangyip.xcuserdatad/xcschemes/xcschememanagement.plist @@ -0,0 +1,14 @@ + + + + + SchemeUserState + + Testing.xcscheme_^#shared#^_ + + orderHint + 0 + + + + diff --git a/Testing/AppDelegate.swift b/Testing/AppDelegate.swift new file mode 100644 index 0000000..78d68fe --- /dev/null +++ b/Testing/AppDelegate.swift @@ -0,0 +1,37 @@ +// +// AppDelegate.swift +// Testing +// +// Created by Hao Yang Yip on 24/08/2020. +// Copyright © 2020 Hao Yang Yip. 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/Testing/Assets.xcassets/AppIcon.appiconset/Contents.json b/Testing/Assets.xcassets/AppIcon.appiconset/Contents.json new file mode 100644 index 0000000..9221b9b --- /dev/null +++ b/Testing/Assets.xcassets/AppIcon.appiconset/Contents.json @@ -0,0 +1,98 @@ +{ + "images" : [ + { + "idiom" : "iphone", + "scale" : "2x", + "size" : "20x20" + }, + { + "idiom" : "iphone", + "scale" : "3x", + "size" : "20x20" + }, + { + "idiom" : "iphone", + "scale" : "2x", + "size" : "29x29" + }, + { + "idiom" : "iphone", + "scale" : "3x", + "size" : "29x29" + }, + { + "idiom" : "iphone", + "scale" : "2x", + "size" : "40x40" + }, + { + "idiom" : "iphone", + "scale" : "3x", + "size" : "40x40" + }, + { + "idiom" : "iphone", + "scale" : "2x", + "size" : "60x60" + }, + { + "idiom" : "iphone", + "scale" : "3x", + "size" : "60x60" + }, + { + "idiom" : "ipad", + "scale" : "1x", + "size" : "20x20" + }, + { + "idiom" : "ipad", + "scale" : "2x", + "size" : "20x20" + }, + { + "idiom" : "ipad", + "scale" : "1x", + "size" : "29x29" + }, + { + "idiom" : "ipad", + "scale" : "2x", + "size" : "29x29" + }, + { + "idiom" : "ipad", + "scale" : "1x", + "size" : "40x40" + }, + { + "idiom" : "ipad", + "scale" : "2x", + "size" : "40x40" + }, + { + "idiom" : "ipad", + "scale" : "1x", + "size" : "76x76" + }, + { + "idiom" : "ipad", + "scale" : "2x", + "size" : "76x76" + }, + { + "idiom" : "ipad", + "scale" : "2x", + "size" : "83.5x83.5" + }, + { + "idiom" : "ios-marketing", + "scale" : "1x", + "size" : "1024x1024" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/Testing/Assets.xcassets/Contents.json b/Testing/Assets.xcassets/Contents.json new file mode 100644 index 0000000..73c0059 --- /dev/null +++ b/Testing/Assets.xcassets/Contents.json @@ -0,0 +1,6 @@ +{ + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/Testing/Assets.xcassets/profile.imageset/Contents.json b/Testing/Assets.xcassets/profile.imageset/Contents.json new file mode 100644 index 0000000..962e49c --- /dev/null +++ b/Testing/Assets.xcassets/profile.imageset/Contents.json @@ -0,0 +1,21 @@ +{ + "images" : [ + { + "filename" : "profile.png", + "idiom" : "universal", + "scale" : "1x" + }, + { + "idiom" : "universal", + "scale" : "2x" + }, + { + "idiom" : "universal", + "scale" : "3x" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/Testing/Assets.xcassets/profile.imageset/profile.png b/Testing/Assets.xcassets/profile.imageset/profile.png new file mode 100644 index 0000000000000000000000000000000000000000..31dc9315eac71ee69934ad1f8221c56182acd701 GIT binary patch literal 17253 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 D4maS) literal 0 HcmV?d00001 diff --git a/Testing/Base.lproj/LaunchScreen.storyboard b/Testing/Base.lproj/LaunchScreen.storyboard new file mode 100644 index 0000000..865e932 --- /dev/null +++ b/Testing/Base.lproj/LaunchScreen.storyboard @@ -0,0 +1,25 @@ + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/Testing/Info.plist b/Testing/Info.plist new file mode 100644 index 0000000..9742bf0 --- /dev/null +++ b/Testing/Info.plist @@ -0,0 +1,60 @@ + + + + + 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 + + + + + UILaunchStoryboardName + LaunchScreen + UIRequiredDeviceCapabilities + + armv7 + + UISupportedInterfaceOrientations + + UIInterfaceOrientationPortrait + UIInterfaceOrientationLandscapeLeft + UIInterfaceOrientationLandscapeRight + + UISupportedInterfaceOrientations~ipad + + UIInterfaceOrientationPortrait + UIInterfaceOrientationPortraitUpsideDown + UIInterfaceOrientationLandscapeLeft + UIInterfaceOrientationLandscapeRight + + + diff --git a/Testing/Preview Content/Preview Assets.xcassets/Contents.json b/Testing/Preview Content/Preview Assets.xcassets/Contents.json new file mode 100644 index 0000000..73c0059 --- /dev/null +++ b/Testing/Preview Content/Preview Assets.xcassets/Contents.json @@ -0,0 +1,6 @@ +{ + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/Testing/SceneDelegate.swift b/Testing/SceneDelegate.swift new file mode 100644 index 0000000..a9a459f --- /dev/null +++ b/Testing/SceneDelegate.swift @@ -0,0 +1,65 @@ +// +// SceneDelegate.swift +// Testing +// +// Created by Hao Yang Yip on 24/08/2020. +// Copyright © 2020 Hao Yang Yip. All rights reserved. +// + +import UIKit +import SwiftUI + +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). + + // Create the SwiftUI view that provides the window contents. + let contentView = ContentView() + + // Use a UIHostingController as window root view controller. + + if let windowScene = scene as? UIWindowScene { + let window = UIWindow(windowScene: windowScene) + window.rootViewController = UIHostingController(rootView: contentView) + self.window = window + window.makeKeyAndVisible() + } + } + + 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/Testing/View/ContentView.swift b/Testing/View/ContentView.swift new file mode 100644 index 0000000..a3463f8 --- /dev/null +++ b/Testing/View/ContentView.swift @@ -0,0 +1,110 @@ + +//struct ImagePicker : UIViewControllerRepresentable { +// +// @Binding var isShown : Bool +// @Binding var image : Image? +// +// func updateUIViewController(_ uiViewController: UIImagePickerController, context: UIViewControllerRepresentableContext) { +// +// } +// +// func makeCoordinator() -> ImagePickerCordinator { +// return ImagePickerCordinator(isShown: $isShown, image: $image) +// } +// +// func makeUIViewController(context: UIViewControllerRepresentableContext) -> UIImagePickerController { +// let picker = UIImagePickerController() +// picker.delegate = context.coordinator +// return picker +// } +//} +//class ImagePickerCordinator : NSObject, UINavigationControllerDelegate, UIImagePickerControllerDelegate{ +// +// @Binding var isShown : Bool +// @Binding var image : Image? +// +// init(isShown : Binding, image: Binding) { +// _isShown = isShown +// _image = image +// } +// +// //Selected Image +// func imagePickerController(_ picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [UIImagePickerController.InfoKey : Any]) { +// let uiImage = info[UIImagePickerController.InfoKey.originalImage] as! UIImage +// +// let imageData = uiImage.jpegData(compressionQuality: 1) +// let imageBase64String = imageData?.base64EncodedString() +// print(imageBase64String ?? "Could not encode image to Base64") +// +// image = Image(uiImage: uiImage) +// print("test") +// //print(imageData!) +// //print(image! as Any) +// isShown = false +// } +// +// //Image selection got cancel +// func imagePickerControllerDidCancel(_ picker: UIImagePickerController) { +// isShown = false +// } +//} +//struct PhotoCaptureView: View { +// +// @Binding var showImagePicker : Bool +// @Binding var image : Image? +// +// var body: some View { +// ImagePicker(isShown: $showImagePicker, image: $image) +// } +//} +// +// +import SwiftUI +//struct ContentView: View { +// @State private var showingAlert = false +// @State var code : String = "60" +// @State var number : String = "" +// @ObservedObject var ans = num() +// +// var body: some View { +// // PhoneNumberField(code: $code, number: $number) +// PhoneNumberField(ans: ans) +// +// } +//} +// +//struct PhoneNumberField: View { +// // @Binding var code: String +// // @Binding var number: String +// @ObservedObject var ans: num +// var body: some View { +// VStack{ +// HStack { +// Text(ans.code) +// TextField("Number", text: $ans.phone) +// } +// .padding() +// .background(Color.gray) +// .clipShape(RoundedRectangle(cornerRadius: 10)) +// Button(action: { +// print("Register tapped") +// print(self.ans.num) +// }) +// { +// Text("+") +// } +// } +// +// } +//} +//class num: ObservableObject { +// @Published var code: String = "60" +// @Published var phone: String = "" +// var num: String { +// return self.code + self.phone +// } +// func testP() { +// print(self.num) +// } +//} + diff --git a/Testing/View/FullModal.swift b/Testing/View/FullModal.swift new file mode 100644 index 0000000..5685c6d --- /dev/null +++ b/Testing/View/FullModal.swift @@ -0,0 +1,78 @@ +// +// FullModal.swift +// Testing +// +// Created by Hao Yang Yip on 20/09/2020. +// Copyright © 2020 Hao Yang Yip. All rights reserved. +// + +import SwiftUI + +struct FullModal: View { + @Binding var isPresented:Bool + var backgroundColor:UIColor? + var buttonColor:UIColor? + let modalView: () -> Content + let thisWindow = UIApplication.shared.windows.filter{$0.isKeyWindow}.first + var body: some View { + ZStack { + Color((backgroundColor == nil ? UIColor.white : backgroundColor)!) + VStack { + HStack { + Button(action: { + withAnimation { + self.isPresented = false + } + }) { + Image(systemName:"xmark.circle.fill") + .foregroundColor(buttonColor == nil ? Color(UIColor.orange) : Color(buttonColor!)) + } + Spacer() + + } + .padding(.horizontal) + modalView() + }.padding(.top,thisWindow?.safeAreaInsets.top) + Spacer() + } + .offset(x: 0, y: isPresented ? 0 : thisWindow?.frame.height ?? 0) + .edgesIgnoringSafeArea(.all) + } +} +struct ModalView: View { + var body: some View { + NavigationView { + VStack { + // This is your modal content here + RoundedRectangle(cornerRadius: 10) + .fill(Color.green) + .frame(width: 200, height: 200) + // The spacer is to push up the FullModal close button + Text("testing 123") + Spacer() + }.navigationBarTitle("test", displayMode: .inline) + .navigationBarItems(leading: Image(systemName:"xmark.circle.fill")) + + } + + } +} +struct ContentView: View { + @State private var isPresented = false + var body: some View { + ZStack { + NavigationView { + Button("Show Modal") { + withAnimation { + self.isPresented = true + } + } + .navigationBarTitle("Full Screen Modal") + } + FullModal(isPresented: $isPresented) { + ModalView() + } + } + } + } + diff --git a/Testing/View/HideTab.swift b/Testing/View/HideTab.swift new file mode 100644 index 0000000..9f5a472 --- /dev/null +++ b/Testing/View/HideTab.swift @@ -0,0 +1,136 @@ +//// +//// HideTab.swift +//// Testing +//// +//// Created by Hao Yang Yip on 14/09/2020. +//// Copyright © 2020 Hao Yang Yip. All rights reserved. +//// +// +//import SwiftUI +//import UIKit +// +//struct ContentView: View { +// @State private var tabSelection = 1 +// +// var body: some View { +// TabView(selection: $tabSelection) { +// NavigationView{FirstView()}.tabItem { +// Text("1") +// } +// .tag(1) +// SecondView().tabItem { +// Text("2") +// } +// .tag(2) +// } +// +// +// } +//} +//struct FirstView: View { +// @State var isPresent = false +// var body: some View { +// +// VStack{ +// Text("test") +// .onTapGesture(perform: { +// self.isPresent.toggle() +// }) +// }.sheet(isPresented: $isPresent, content: { +// DetailView() +// }) +// } +//} +// +// +//struct DetailView: View { +// var body: some View { +// NavigationView{ +// VStack{ +// NavigationLink(destination: DetailView2()) { +// Text("Go to detail detail") +// } +// } +// } +// +//// .onAppear(perform: Tool.hiddenTabBar) +//// .onDisappear(perform: Tool.showTabBar) +// +// } +//} +//struct DetailView2: View { +// +// var body: some View{ +// VStack{ +// NavigationLink(destination: FirstView()) { +// Text("Go to First") +// } } +// .onAppear(perform: Tool.hiddenTabBar) +// } +// +//} +//struct SecondView: View { +// var body: some View { +// NavigationView{ +// VStack{ +// NavigationLink(destination: DetailView()) { +// Text("Go to details") +// } +// } +// }.onAppear(perform: Tool.showTabBar) +// .onDisappear(perform: Tool.hiddenTabBar) +// } +//} +//extension UIView { +// +// func allSubviews() -> [UIView] { +// var res = self.subviews +// for subview in self.subviews { +// let riz = subview.allSubviews() +// res.append(contentsOf: riz) +// } +// return res +// } +//} +// +//struct Tool { +// static func showTabBar() { +// UIApplication.shared.windows.first(where: { $0.isKeyWindow })?.allSubviews().forEach({ (v) in +// if let view = v as? UITabBar { +// view.isHidden = false +// } +// }) +// } +// +// static func hiddenTabBar() { +// UIApplication.shared.windows.first(where: { $0.isKeyWindow })?.allSubviews().forEach({ (v) in +// if let view = v as? UITabBar { +// view.isHidden = true +// } +// }) +// } +//} +// +//struct ShowTabBar: ViewModifier { +// func body(content: Content) -> some View { +// return content.padding(.zero).onAppear { +// Tool.showTabBar() +// } +// } +//} +//struct HiddenTabBar: ViewModifier { +// func body(content: Content) -> some View { +// return content.padding(.zero).onAppear { +// Tool.hiddenTabBar() +// } +// } +//} +// +//extension View { +// func showTabBar() -> some View { +// return self.modifier(ShowTabBar()) +// } +// func hiddenTabBar() -> some View { +// return self.modifier(HiddenTabBar()) +// } +//} diff --git a/Testing/View/MerchantPromotionView.swift b/Testing/View/MerchantPromotionView.swift new file mode 100644 index 0000000..7d08e0f --- /dev/null +++ b/Testing/View/MerchantPromotionView.swift @@ -0,0 +1,80 @@ +// +// MerchantPromotionView.swift +// Proj1 +// +// Created by Hao Yang Yip on 18/08/2020. +// Copyright © 2020 Hao Yang Yip. All rights reserved. +// + +import SwiftUI + +struct MerchantPromotionView: View { + @ObservedObject var datas = MerchantPromotionJson() + + var body: some View { + + List(datas.json){ item in + + + VStack(alignment: .leading){ + HStack{ + Image("\(item.img)") + .resizable() + .aspectRatio(contentMode: .fill) + .frame(width: 50, height: 50) + .clipShape(Circle()) + .overlay(Circle().stroke(Color.white, lineWidth: 2)) + + .padding(3) + VStack(alignment: .leading){ + Text(item.shop) + .font(.headline) + Text(item.date) + .font(.subheadline) + } + } + Text(item.msg) + .font(.body) + Image(item.img) + .resizable() + .aspectRatio(contentMode: .fit) + .clipped() + .cornerRadius(30) + .padding(.bottom, 20) + } + + } + } +} + +struct MerchantPromotionView_Previews: PreviewProvider { + static var previews: some View { + MerchantPromotionView() + } +} + +class MerchantPromotionJson: ObservableObject { + @Published var json = [Promotion]() + + init() { + load() + } + func load() { + let path = Bundle.main.path(forResource: "merchantPromotionData", ofType: "json") + let url = URL(fileURLWithPath: path!) + URLSession.shared.dataTask(with: url) { (data, response, error) in do{ + if let data = data { + let json = try JSONDecoder().decode([Promotion].self, from: data) + DispatchQueue.main.sync { + self.json = json + } + } else { + print("No data") + } + } catch{ + print(error) + } + }.resume() + } + +} diff --git a/Testing/View/codeScanner.swift b/Testing/View/codeScanner.swift new file mode 100644 index 0000000..4ada23a --- /dev/null +++ b/Testing/View/codeScanner.swift @@ -0,0 +1,69 @@ +// +// codeScanner.swift +// Testing +// +// Created by Hao Yang Yip on 14/09/2020. +// Copyright © 2020 Hao Yang Yip. All rights reserved. +// +// +//import SwiftUI +// +//import CodeScanner +//struct ContentView: View { +// @State var isPresentingScanner = false +// @State var scannedCode: String? +// @State private var selectedItem = 1 +// @State private var oldSelectedItem = 1 +// +// var body: some View { +// TabView(selection: $selectedItem){ +// Text("1") +// .tabItem { +// Image(systemName: "house") +// }.tag(1) +// .onAppear { +// self.oldSelectedItem = self.selectedItem +// } +// +// Text("Add") +// .tabItem { Image(systemName: "plus.circle") } +// .tag(2) +// .onAppear { +// self.isPresentingScanner.toggle() +// self.selectedItem = self.oldSelectedItem +// } +// +// Text("3") +// .tabItem { +// Image(systemName: "calendar") +// }.tag(3) +// .onAppear { +// self.oldSelectedItem = self.selectedItem +// } +// } +// .sheet(isPresented: $isPresentingScanner) { +// self.scannerSheet +// } +// .accentColor(Color.orange) +// .navigationBarBackButtonHidden(true) +// .navigationBarHidden(true) +// +// } +// +// var scannerSheet : some View { +// CodeScannerView( +// codeTypes: [.qr], +// completion: { result in +// if case let .success(code) = result { +// self.scannedCode = code +// self.isPresentingScanner = false +// } +// } +// ) +// } +//} +//struct NextView : View { +// var body : some View { +// Text("Second") +// } +//} diff --git a/Testing/View/msgData.json b/Testing/View/msgData.json new file mode 100644 index 0000000..fda0b4c --- /dev/null +++ b/Testing/View/msgData.json @@ -0,0 +1,36 @@ + +[ + { + "id": "1", + "msg": "Hi ABC, your appointment at Sunway, on Friday, August 7th 2020, 9:30 am is confirmed. For more information, please contact 60123456789", + "shop": "Salon A", + "date": "2020-08-08", + "tel": "01111639290", + "img": "A" + }, + { + "id": "2", + "msg": "Hi ABC, your outstandings balance at Salon B is 65.00", + "shop": "Salon B", + "date": "2020-08-08", + "tel": "0123456789", + "img": "B" + }, + { + "id": "3", + "msg": "Hi ABC, your outstan0.00", + "shop": "Salon C", + "date": "2020-08-08", + "tel": "0112345678", + "img": "C" + }, + { + "id": "3", + "msg": "Hi ABC, your outstandings balance at Salon C is 100.00 asd dds xczxc", + "shop": "Salon D", + "date": "2020-08-08", + "tel": "0112345678", + "img": "D" + } +] + diff --git a/Testing/View/profile.png b/Testing/View/profile.png new file mode 100644 index 0000000000000000000000000000000000000000..31dc9315eac71ee69934ad1f8221c56182acd701 GIT binary patch literal 17253 zcmeHvRalf?)bBgP07D~)Gz@|$jdZ613L+xiC?VZl14t-{AR;9o(jlNo*B~h!5;DRN z(%m({dB^|FxjeV$d%g=F@!fl`z2djlUVE*Lue3B($%q+<0RSL-pmt9i0H8?RA2^g00lq+3jhM7f!`Hk!4J`QLCSZ*8Hi4BsGUv$K+=J8DW8Lrp8fBn|A8uC3Gk^- zQn`U|adN@R(V6l?DOH5Lm92W%JDP!sJvvrbfyMIpcRF{E=Dbn&c6#xLqr3_-~|6amr zWGb3A7$3I`0l+m_ChwebakP`2SN+JAcOLc25wZZPgEJ}>|F?;PRD~6`@|Z1xv-4li zyEHr2aVwCosG`Q3WUEn?5+ovj&Vp8t390JQ&U8j6qSMEJro|WYjS^!@7*GA(xC)kO z-QD#Paz@MDPZo8K-Zpp7%zd3^sqIp|ZR@^qdGXzy&35aYM}NXS$T-QU$+GMFrwxLw z6j`6XP@;h0yNL=`{&2)0C`A!9;jh7L+k|BnLT#67-hqJu0c*_tKTGCW)_y_Cd%X_x zw80D+#yj(WE(}A4KMxx7rkn=aaTuFiItB0T=V0uftWJK7 z`ns}(cH^T=9`F6u)L@&~zK%{4F=l?F|3<0l795fbg}`Uu-p2%0ijp=D;bRoS%L~*S ztF0Q=pSk!oIX*cYF#rDQkA_G>fXm&Z-ip!krsA%*b_s>ls&AfTa7pa$t zv#gr6UJnfSt{w1_H-C+8DtItI=2MdyAajg>%hJAN?MZj{b+<`>1SMGr?L;L0<7Ria zd~rHc#oXNI@0zBu>39{_WUQ@vt~?B*%^kK`WvzStbk$x{_iRuWf8%*T)ps|J^zu`lqQ0(w64n_Oz|}H)X@eu2acz7HL*z zQnv0La~Oa{u;Rhi{V*6Epj#1y2H3X#jm_Ws(mwf7sCw1zOa%BX*C-D_VR^ z0pS5hDiDy>2gp9fmy(baooLGG*qhx6uDI&9M_dR!99?x&i+ zl>B#T%k0OH4&IlOb9@B=wzH=~;gOPMYVyFcm^(-3Vn<*Myo-@NEqFO2f?Fay#8(X*c=4M@^lbWS{qzXl2nWB~Nt;SJ3-6KC7H}vRuYyz>ulG!o>%>qPmYbUf(2X(P+w-=tbD`PWh8E3 zPYG4mM*pJh_7b!Zh9WE^sV_fwdm6{xD8#lpbHZ*g8KS4?n~AAqKJpD4qcrBbLxyB1(i)CLM)ZAb zLA>7<7Z=jwz_O(hoQJD_s|>lr#;6RGPy&$N_VsCo{(w|hPOkyh9J6?X-H)i8eGj5S z7<3%8+>PP3;ln_?!z;c=gWa{lKjUpVG9wkfSgkLmA>c%z0EALuBYQfjZ2hoKNV4J1 z^ZVZCH<=#>8T}l8edM%nCL@o4LBR;}&^Es=RKTORq~0oPCrW3y#rDe!+5+205e>_y zFBL%XtkUhyqBA{_WzESqv1~~P+eSR-u?TCo3#8&OxJh@J?>MG)murrqs2~JW-{b1_ zJSHCujc}`{e|7`B0=jBxtyE-KY_?Zk?h4}Oe~7wj3SWC@X|K{ev>QWuS|VJ_#*)#B z8zK(6`g_{k$6MA-_lUKd?jm4fVD^WO*UNjDHZGAOEe7 z|BF3M{J#xzlYj3rzH|@v>xH4yJ3N*Zo)4>oYG)^vz5C z@FKS%s)w?(qT3J%hz%wGj>V{izVdP3V?wMJK2|$ZNcpq$bf%~2;A;#|ybVlYHXL)Y z$-?wgEz~CjHOQt_g6yplC88t40||=^JrR)F%Nut5>09)pL4LMI`LnvaXE48Fx2_-< z8K?$g1BrgLb|-5`tg-GeQZL&5)GywfTy>=(1sDHi*f?EWqxJQssWA9(tBE+SmY4wa zC#dYf>X=LA*vKPRlMARoEwP+rLp-v~0tdMMoi%;JY4<~t#vN`0)mv5lD;yKAF~aej zAe*w~!EI{fagTo=L9h>KDzrX~Rgn?hB)EqM0+LNic0xyhIH~wA&!`?#vBJCSoVI<9 zeI>@sl$+F0P!AU3!utZRbDQh<>Y#X8q4H1G7=1YN>MMB52LJ7BpkaIImnksuCSOnB z1r{)C;HjNmc}o0`I?8O**=Oh^TlnhZgW?br&nh)>(8FP|$2>3K5D@Iv-=*dVvzan8 z*Xc-pulV8ccHc(o9AhyZJ)xK0W60d^2xal2dSQ&7$vYzqyhk&X`u=ww&2AX#wF?k`4^(kdpUF3G)jgdnBt;o?MhhPXM*=Qa zNZu2)vBDA*bgEh5;*d?2j24vb5T);ZRU8K70=LZRe)4-mX>;lAkDi^ zLkUW^J&wJ0|J%1}>#{7SvXIcndAcV*f8TeL9enKqi-&>yKOS$E{dPoF5h2&wP1EBZ zT(mw{_)oAmRgpR7-bWPl7f^$nEJT$%RUpW1aPHoSH$ibw|DZghR00doEs6gQ^tIw3 z1tp(}GduSW6-X8*qvz8rmDmBWP4rgB7L%lVlhyMLkjdBJTGwrtAdmDV3Y1WuC4NPH z1xMy%d>o@Lli1-^e{HL60Smq$65r_;X%4e`=r|Wb3wBUVef_M#ls&7*>OU9NMM8iZ z?vd$=<263NNpa3Do_0YS`EAFmUx)7F+D95f7Nog&`1=wMo5wy~@3#LVKx)&WV{Ci% z$nAo}!1?=ZcSq6yESDaKDeWfzF zf)WXv6?dCfb~xi=fJ~P2wW08ZrLv;!SEUj|fXrLrKV*Tf?wpVX3mk;r9f$b4ZZI>g zDk_2eAkG4qc|JTk4yKG~!~@}q+L!s>(6-6y)!70NOD{yor`F*6zhe$|^B5Jmf-vKnub6GGhawD%H#X$a>6N zMI<Il@;IrRA2jl2#gL7_=s%E?G3B2{pHfGvak{d*n}`_~SDj3At0hM1YW zYdA;{3r>W@Ewh95Wp4rbcyww>zSlM0 z{G(+7BaJ6J3m6wi#_${};t##sCdZi{jx?e#baH$UcTG^C`2E@U$`F6c2htZ`PL{xI z2SpW3_Y+JIqdKX8(D%aw!P8r#UZyIohxG8>6QznVE#%0`Lk#y6%?}z_{2XA@2P4rEsO}Y5mCsLYnKs^zDt_Z}rvpfqP3h z8qnFxVO-W)BmwYGOx%ivBfG^w=Trv%$V$9p0taq^D`{BHs`N5O-i324&- z?L!2rqyyqQS3;oBiNYo~Nvk^;8~+fLxeB#Fefdj1DxCsEK7wb6Q!2R_f1y{(cpp3R z(dsrODenVJ$GISc_rj>EnD{q%ZZ;F35LC;}(8Dmua_;V_#^A#w8 zP$)kx9ASlkEg?cmHNGVPcm7SJE09mZpt-tCfc}K|BrL3t9e~PjK;<~W8wU*`s)|gn z6#~v{0BSMoKXnqot4zXWnTNHpRJ!SZyUD;51mJl-{+xB6`SdES+et`JFYzpX#w`UA zz!a=N)%n7aWy`(4mr0nZE!%sEQR*-Sp0y(iXeSDR2H}F&wZAyOXJo?zn);0hu*Qse zt17!ogzT08^>49K>kcLbVY-E?YEg8F+ z0l?`{Z;~{+PXcDVK(q!p0fUdqUVlCI0<`e^v@gH@V)wY~_uQU$R}zA5?$YNbTU7Od z!)5G^uOTF*v{5&49W8w^DLkKw%SiA}6cPJ8PEIh(8{kFH|C{;Qo{ylX)hvigC!9i_ z2wF;vh(4+31C^Q^o4GMT`{Cd+>)Id__-{HYAl&sj*{l8}&|qmR+kW}lNfAeBCv)A= zwm1jXAVMnM35ZhNz$4J+oWc8JLxGDF!DfWCYTE~+zRV`!Uaks8?ZyiA4FRR0c%YWV z#VODVp7+`vBP@p$(gLTU?!J9D{zb7nYor?#xi2PC@!`3BoZQQXS z$&d}mJ?8>FGRWqiy;a38LSdG7Vz#A(+V0RHL=Wy^oCj3r%3Zqm2|%4hMys|uZf!gS zZ`8SAmvLUT4di~uc>gV>g=h&xvoamh;p64Lyo@^xFRT1*4Z|f4!OVc^U~*-QIv<2_ zcMmF^>b}=gAa`zG75;*1LZOc@xM#X2)wBO zMpfwzwu!1HYOK;!C=t5{%9`>kCRqgkgS&&y0*hF^|2tzcX<;KqW=V!6oO(Id?J=aN zL`DU0kD8DnuI-dU{%R&t_A>Pld8eRu*Ky~{} zhPb6(eR+z2{KrUTt%*qdvoAko6%g5;z`^QigfA%)7Y(1Ew%*}p?bow^CMt;!d&hC< z%1Fw*b%paOyJMiCA;3rlEU^%MUNqmlG`08PfGgLD{;h+ign_Q=%<_r#-eS(G`&e`` z1G1q13jG_MjIg?71?9{HqnV%;3nKoWKeP~UnmOZYLVO|hzjd8XA(T!O24=>|^hZ#< zSJ~$wB_1U6zM0nssZb)|#@7NuDg0$qxs77OAyf#4EA49QAcug)s~UO1c|T~%OE78q zOj;@sA2$7ol$7ITT!^HkG_8OI7MEIFzGIEE%5GAjr&B|&D1RA#m%T1@i4Q_&kOwbB zLgHN!m9+)R>MT^uwA$J$NcqRLMRU+0WWv3#nN82EcDS>fxdXwEJad_vQV;~mF+kpF%3P8n^$#;Sg7E22Ejg!I&RwJiG}HwNEu<^DHt_we+WJFv}|f% zuY1?eg|O&eq1_yC;VZYVX}&f{jPe9^DPRLNGcoOT%(HLrrRc8T-H=y53b;)*goS{J zN;V~%NJtd|MIx%a;?--xSv@ID@eUpy=f}$=-rtj#s$ubCF1YY+DP{k8%E&^NX(#fb zDD#zea!I;$Q>JBmB}5Gh2ErO)NL#|j#%3iw%(r*x?KkHBCDI@9!veUa8U2Wwi|p$q zk5qmDF4qCC{jQdUe%ALPxUAHl-EwAKjZPC1s!tJeTApLB#GXl{@DAk7)|E-WZ2L^R z!a=)O^o{RbsG%Us#WU4@12ctx`gL(7p8O3)f&@WSNukWf#TNno7}}u|oLJ%vq(Ocj z)MSzTV|~7gP`eux!EzfJu4lN+T6_b}GTr-dSvEX7RR2>!NY!|lgc;%@n|=_2umjCu zHPPlqOX(Xi+7h0_QV@bW!RD^Ja%{fgOI^B7={r2ya`xj}ZFAOZ8o zGoTT?p6$3hU{CpYSf&*Kwwq|Ov&RILp+ zKI(eDBMeR;%`Kod`Ya_UnPid>XEA&F+?@McU1f=nqvQn`mXUSNEjw)qyiMzZObot} zVWzYtIEPqcHf9gTC@_HPpf$UeY%3wMQ##txwm?k;Ud6!^fvWwvrC7Dk;jKl6WebjYR6v|y?(xN4k}B*-R}6a_g$lYKQ1j| zf=h!l*_Or|6Z`)pP;l?ao1Iy`{qqSp(r{q>-7}Fq59hJD$|l5SXwd$mZm7XL%s0ON z4qPQ^1gEu;=Z%~LiAD|&wk5AYL$@EcobJ|(KWqVQsYV-AwAyhL)9a9Gtst_~hFX5B z+C`;xhU0?aKHg_l_TSU;@3|hfcGup)COH~zI;siQ-^PM|foO7$8kjI`9o-;SQCYnT znkjxY{c(c-RABOu1XRm=#`;Xs$T)*Ds=smwA+>Ua6~du{81-E&a#SA2t+@z8C&j^H zSCE30X5hBV_Krc=wc|_heihHQFf4eyw_8{spsWc=Alhwg8L&wXzyYs2zn04?$U!yV zfF|nw=+$=WH$D&b5-Fw(zkj3rK}2i4uEBYH!Xgofy!rgM+CiGmgvxFy$2gqxjwXK+ zi+Dj4gahuLQkV@j+*4B)#t>EoY zwfLx=f^~BGV<=rT08iP-W@@afDkqM7LqEJySJ1;Atg} zhqGK*B+AvZe7beY`T@KhJ$TBaXXWQ)`UmlAr>j&R0bULipmy+I*X}k*-QKY@@a%|J zKyF0;FmHW#)cN7WQe-XSn?O9+vO#2jwj4fYKlS|;Q_oMbLEg!;eKeNXa<~P}n9ymKnF2u(Y+ZY;$UPj0EI#Woc*Z-ktjs8s>@N~0AF{H90z(uk z^^#U5R5m)K!Q%6IQ_&BbOESplrOJHejxUfRV8o@TOnTXt5C~>Y1yU5IKSZKum-#WD zr{lwCYX3@mn*Lyo*9H~9-g#?Ii)k=l8{41`45j z=4;{EjGNcCGBWQAPrKhwZwRHQ$vRu)(cNU2m{m;{h`)CAd|UH4ZSsR)EaoZ#ASOzs zwuy&Dzofs%nJVm6zi{hUc5y(eRZiCzbarB}95%$4NwR*mvB;1vj5rdm? zj?NR-oc+I19Q1PQHMP}t##Vtxr_fhQAbxv_Lo>=?7tJO!e;!)e-OpbV(!sl(;&5y< zR%7rXv2wp+ZTYb93__%gtN&(@{bFkY>m+(aA2SE-ED&%_O7V%uwo1;iw|eORJpepnA%P`) z8~8WqH08}!HWZktKhqMz!|pDJWjXJuE%%N{NL6cL_VMhh(J$q}6bZoCk7P}3p#k7mm=$5>V;YDuXJL_`FQH2VpsafRT!TkuOFeph3lW>&v+ zrOdWuk^uJK>@PRzsv-yF%zEahBAwo+1Sh;6AhLNz^?~zM|1OW-!S>)`W1vr|1PFKk^^PR~~jC4arf-@9Gx9vI9IHsWi%U!>$u;RsmB$kZ2Gh&&#e5S-jJy6;fZ z%ySw+qrd5Ynlgb9`5G!{%s>|C(k2|l5GhJ(pZ8ec*CfVxkRo#M$nH~IN6T&GPw))b z=_(E@yT5VTtV_@!i{XE}0X92EI`boPQa#P`2{)h7W_EI4uOB?tomF49TDs4z|1M(8 zOM2AD&!Z%J^2gU@CG(O;D|n!L3L1+1i8W&ZJ02aIaVA0aZ=jaCOX@U!=|3IvG>miE zb(QqFJcaUF+?@x9hs2qVHuf{lsH}Q#oUAnjOcB>8_LtpUI}GFw!ku~V7QadsdfQR1 z9eq|f`8>AOvw0EzG1I(T^EsyYW$Ip7pH0lTRK~*wixWE1F2O6=9O*FfQjg+BcfFaa4sN-u zeN*;(MtVr^dqf`vt^QQnIMOytwS-xh`#hAy|7h7qrHv(&Lc#GG0ExXtqMyUotM|)r zObhR`E_qPXll8FAM3IMlGHYE4+sDlEf@V5DJs>WWdqyx>;Q1>MLO1OYU{>b~a8iMR z0zg=T$_D^k^a21iIw%5ZaGtchpSJZmdd-vh9MeD4g8itofBtOG2aXFBUr9Zc<-3#& z8ytjzHguyb#(AFH`JlKN#?62?TFKUXwC{OOy*)W@`M&>IK-!0Ilynh_7r|qGbB6>i z`Rf$H<*qE*!Td+dgclRykpb5RYs_gcQfGGhEjw;eNkf|)%| z!%9qmrIWJWjIMQ4eVzxNlg;e;h4OECxvJFA0#*U1%h|F1FI$r1sV~LShoE2Z4KYv$ z!Rt(>FM?!k@=qytPs9lXFLBA6A*%8Vb2y~GbN>sm?dHUJmu(#j%TS9;v$oF9U46L3~SBJ zpZgmvJBV&fYQ;p-y{qntaaXOWLS> zS8+=;x{iGy}P@<4p)|>*pooDq%AgV@4Ki+jYOIakr3b z1dVH2D4zFxsJ>j&+RC1fx~)s@?Acprwud2sKZ1Bf$bWqPRbi&2blp^$Z#>+UfrmT8YMx%FeUai$!cVWg8HSXLJ;@K)l zS4Kxg90~)IE9$iX%fbDiCWr$qjpo4MA#Y}8+o*jeft14oqeU*6=eBb{lvp4FH@@Gx zI3#}dK>75OI~{)8=}4IAv)_eI4uZdgqZkhO;AcTfZ1G^_#6pQQYr>&w>c)|Od0VDw zbKw}HKYc4SJR(Bp`oRY2lzzAwuM$P`vR91kQwHM5-(h{E+>tj9V$^%TIcM(}@Vhu) zn&07|gi?d4dMwxRGwfQQnf#D<)*CI!ZxuBqmV=!cjX$sd=^!Bs4*#TYgjl(S>TcP8 z!E@?$r_@<}K}&h=i|NklX|QLBGydOyl_BRa1MvKz0_uVpIEj>9*s) zP)ss$Y`J_{jht89$4vAnt@Cl%7gqDACMrt`c~)Z6^GO?l{0+`;{f?zu8&hv~&I@c; zeZz?@3)Y{o!JdIt!}e(W<`+w5T~(gpD6!`zU}Z$_`D2Pbbaztf_l8&LKA~^L_=6e6 z@$Nn~sz~pyWPop~)S3!?HJ)dzs?WSzrLbai-@iG7?U%UFhAP1`P)*n|)C7a`dOhtU zhoWgYnMtSqq&LNxn3!ry1L zraJhF!*Q38IKcxl-P1GwxWSrj>5G#m%QdTaK9pB^N;X6poZBKkYW`-B55mi-IbeT$eHM{x#oLgu%>Na%xvN8Xl7tnS8w9bB*`ftr8+eLpF5Dw!C5m~ zT3G@c$=On2<>D!4V)C$Z^lOs$<*fHzOI+`3p*NyAd%P^pcK9oUl&7INY+8?OVtj0k zD3pTQZpX&v1Z&Y*9PW@V%B!CL1&rF;KumF zwGT~`zfVX_|FUK-=JXH-N|V;daQKV-hZ1Z^PuZY5@0#S%P9kQ+Q$%$do z&vN!clnp!>6@J8UCNW5eE&d(8rRPRRaF|o|>hS>ok6odQ6*0GxFG;>MF}C=WK43wN zaNzLtqGHcA;0kfrgvT80V0&f*?zf$5ZrsznIn}-zXb5InUf|pR+Gi1wkg6Y)ORL_AU^NBUGy5=U578}!;lwzDMgDa*A z_{`8&6=u`bjIW;-#Ws>Dvx@tK(si$-wz`ggnklPMFfcMq1YbGXRZq>K?25xc?3~b! z$(7J;u(GIIJ}_?F5>l0P-2DI#R$!_Vw{`&^Pu7Os>k=R<4h#A>+jn=+9<$j0rgVZ} ztl6+Q2sP=(H$PWwVQp<1rz!tZS8;$Cv@FNl=KT==Ip@8#nnOo(H#;w_O`i9+l=CR) z0?bQ@^}cZX3N*R0ewCvwgx_?7Bh^Tck;jdhWDd-QHDO?b-(-U$Q+&@9T&mGW$YZk={+ThKsvS-jiRK7<)_BD45iMQ8 zq_1w8gtu)+*1Su3hF*ouKGn#y#0gupAC#51;0H$d>}8}$y1qF8iW*i|JnJ~gGQK@} znpy4C9`

M>h7=eW1PFtyKViR?meRI9}vY7h*PBL!3ZdKPm=DWPDY(NJo3s)ioru zJhu|e205ZL55p`szw!EQx3QWJ)W~uB*RZ~&WdwF}2VZ$+^KN~d1+!R9Lb@iwJ&pU6 z3t*Gyt9ao_M5_y!p<`Md)T8!;fZ)!ZDM@LuZ?#KdpSHsgv?_w*a3r0vSkIz*M>!Y& zNk1hPz*Zw_*=WVZ=TBjZvEoof=YZBuW!qHMSy`VoiBRH_iU3lc8b+%p{&)U0B6=4T zW0Fp8;dsZY_3_}*-5z{YR+FR*6>MU0er*cBRS+h&u-gZ=;^`dbm|EgCSAv|Y;laQ& zI+(a)XCW(0N-okK@eE{k@{9_LRhXJC1M~6K*VQZTge6lzI|sZO9&TZ#C+<*h-Ms{_ z{>>Xk#}3@|{)0EVA5PoMlo1qf;`bz9o1Pn_X}1#l$%(#rYs0?lhZOA>Z}1L3$p+li zJ78P&lTEMl0=u9ci@K?r*4ARGJ9v~K=1cIkyzeGYX0}-$mY}P~T@w+}bl`#;2ib*A zW-XYB)pMypUE`+ulEhg;i;YQ}1SP|KZNpRnzV5lzRL=nKCod_Z4G_RhmSyZ&mJ?=4 zA12V7jqMwSywu}PB^j&qSl4msO3GsYbzeg zYS?zFw4bNH$H=SKCgn^qt6C7mY@A}lapjvwclf{bTt`a-8WPg1bf(u+duejrTsfEr zbNEQ12u}2njJ(5fbII7|^bYSb7T}1MW|esEG)FUiN68p`&#aMOF};pvTL~|mmR4?{ z1(8@?;jJ)UV!WsJZ)fP3*A!?9o=H9$qRV_)hZj;YnrG z+X<4~=7!tCt4zA`z=^Ug9#5}>`_)0|n1T`ljy&<08{8(`+d1G!O7cpbFJ%R=!-y9i zc>DNZOJ{=brvGjn0;CkYK#tL@Z96`}{)qh0oI3dQ5D(cx30>Z^2C-(9Q|)vz<6Z4lL_Wc=sMVMH)8)g3c!D1_B$a zX5NDo611QSn%!o~(N%420buRtFunKgBt6h+SgXR%PExY{9a^XuPYF&k%Q`kLasGLI z{SRRAthRM{Kks3!dhJyzIA$>tv47!NqWYAWgy-Wi9+Jo^JjdfcBaMe|@iH`(HpLT$ zf|2OgA1;Ddpj={WzcxR4AjP0<8R`SpXZ{xaB(7_}32?qQJ%XRPAMI)j_`A+f08~m@ zhf)Gss)1esa>>e6uYnW=qoWC7#CcTL_}-&sgH;0H!Mt8KUul_o$#jx)xhhJaaHzEdHGgWlaI76~1`!z3k*yUHKnMO>lzJ3awYcx?x=iSXz0yv5${zADw{6 z61?aCu()(&hDG+XJx~NRfQx72vlI3{x!=BVj)HY2)Xq}8<8at)R16Q10c$cGh9X-2 zfm!f)>b`hC1ONUB9?-}_{qzpHZYKwPC0q#8l!4B|JcKW|vNFAZJI~Dk;41mes|U8$ zS0_498+=U>=XQzm;l@5(Z`qlr8kU8P4aap|{B)u3^}> zP10z4ZeuhMctyL*iY5FEJ}oxla_q^!&c%5B8W)W8r3gT#UE= z2MqO^!TCf@IkSLK{jRR~8a^_eIJ9cgx6{tRv&M zB*=dj19Y@zrES3Zx+aw8K2RF}%NxUU_SOB$^3RP+pc^%Pn&%Gty|o;^a(J#}aUYa1 z;fJ|>L&(WNjYyK|2_AxEHQ@bt+U| zkn(k3aqvP%KjE?xJgmB>T(u4om)D2I??^d7E%GB5%$k|1p7{rJD0e}YD`RWMz@ zC>WSEAwtqi*;n>37b;4T26FH0X|@3i#6* z^5##^PIuHjNfs>K*#R4y$=&oDPMCUQ>Pw(7_uwL}bWruVpXk)|&8ak{Z#MxOj))e| zy_%+TRVk^71BgOi9%YKngq-gl@7ZF#1e+i&)Phs{Wc}dvi)ziD{I?BhasVBqEk9mA zef#+*7C}aExJT6GLXo#zHdeY4H_F_W(b{lMxN3YGMvTPj9{cz+433LCo&gqrbGMD` z;YC>&nct;{SC3vQKwKNi#Dg4zu-BebxsWrq_1?klhTe7o z*Q(|fKquW6)S7j46bt_9iK@BZ;kj+yTK|{;@Vvx3-^9PdQ($V^`J-pOVPHX51mN2? zS3a@b#d=Oy1dQV*@iB+xK1Fp6PUMvH7ywMVt83ykjbeJ^&w9Yodze09nPo|93gV&SN5}t=7K*$6Qc0R8R_xbzOCeGe< zS9i94fv>kwS8K$XADwdB-t7(jy_4v2Qb+~3%&v(?wD=gK@7^^9jXvw53EBR|uv(Fe zb*`TB3+z%&0(|?m`IL+8QcMjVh>{yNS^@Dn*P)}9Kha+{R~+EifD-%36VT5iJ1KyZ zvdH+3gA%rTKxux63pV9r)fO4RkER@%pu7p_JzCe;F7JFBIVum--cwdfOG_YsQeVWD zo77bk^d63!sNQ`}na(N_44~xg;H!t{hJk3+H-K*jqx=W`(ayKLW}HCbyZy*`|G>$w zxGj(e$RomV-wS6RXFDu_WYv~VB!BWD*pG7hhXEZ#(4**i(e$QDkligWA?sZ#hyo2+ z*N;Zbj2rPCU}+tDuq`4s<0y53hvbRZge>cie>OhQex-W@bN&PYnC-5bujf(=ll0!5 z23!Atz8i50x$aEkm4(E2ASKIvWq;KU3|m#%gMe#9{?d(S&Z}mgBi>))o+>~D*;fzB ze@neuJ-rY1=UvGPkmX|HWKlPO{ktZoM;m!bE`Td@Pg_z)l7yYlmuPBW-_`7VB5t+w z9ZoULPf;Q^kN7?TDP5~s1Li<&UEJ(<$LypB0 zv{{;8jd?>yN6H7xoXjpCzS)D6N`rc56#du`FtYXUd#qjope-Kxl?n^F)bh@3HfN=#5(;s>%QKjUUEbt|ZT0R?Tiu$N{kp?i}d( zhaWu~Y@ozQeStAr@F>b#$MCZF0-toY7BRms*!}+v<(;~eU^pFqumXQMrh6Xs<&U`v z^rGwY9V{R_#gXy_ze5;ZX7abpOE3UUK+9^eRy{9pTjSM7V6fr zAHg<;7|cwG8vFf?0*?nw_ULM7vinJ8Qw!+FXB}EAhx#t05jTMHm9rZ8=o({mq&%KN zzBcf&bg*l0s%_oicD%jndR)FM0K^M7gyN%k&=+W_)piX@+in^`;4k;|NFKUg ze7pLy3sWp`^0+Kybfe{QK!9Dd)(r}AVCQ(jV#H}W{Py7I5PRGNimsN%zzZ>&5A~P$ z$i7GYd@9fV#w0+Eb}?sg5ri8AoZP!$1$5f2zFZ@WdgKK{n_}WBuPLmkQVsWA;o>v- z&h)tV^)&z=)oag^yp9=B`006;+@VYc1Y(S8!D#y2g5?u%lCyth)`EU*ymkeA5*oRa z5)p8mV_XZp0SFWs4qQn;%D9Icc{XxX_PwKIdetU@2RsIY@2?>qX54#v7{SY81I(iB z7maG`PAV!HWpSKXd)7BeykIG)5;BzO15mft0Nb@)bT4KTAEc^(HL-rY&{i;=l9Cxy zf6)SH(YJ*TIkd=eb=5If?RC>iUISW2fN#4tqreNG@KaG;#Ea5WdN?0o#t-C=@2WmF zZ+9X?09ulE!7lc&2ahtq7l1I-cG7E=43sg_v?M0eARNnuYcSD&2B6V7~8gtzPTj~KtBD5tOP)J6erR8w}>{X z|2gjSJoq`w11;7M|9{EK>NQEDU zYH1-S095YrpWdW}A^=nh*Z>1M!PYn+XajaQkaxj?JrD~%;{q)Da80e};0p?XPWbgAX-GYQxV14#F3Sh}U$;YfP$|BFbu22%e2?FXV66YsL+!fS~*aUR^)yjP}V5%zxo D4maS) literal 0 HcmV?d00001 diff --git a/Testing/View/select profile.swift b/Testing/View/select profile.swift new file mode 100644 index 0000000..24598dd --- /dev/null +++ b/Testing/View/select profile.swift @@ -0,0 +1,121 @@ +//// +//// select profile.swift +//// Testing +//// +//// Created by Hao Yang Yip on 14/09/2020. +//// Copyright © 2020 Hao Yang Yip. All rights reserved. +//// +// +//import SwiftUI +// +//struct ContentView: View { +// +// @State var isShowPicker: Bool = false +// @State var image: Image? = Image("profile") +// +// var body: some View { +// NavigationView { +// ZStack { +// VStack { +// image? +// .resizable() +// .clipShape(Circle()) +// .frame(width: 150, height: 150) +// .scaledToFit() +// .onTapGesture { +// self.isShowPicker.toggle() +// } +// Spacer() +// } +// } +// .sheet(isPresented: $isShowPicker) { +// ImagePicker(image: self.$image) +// } +// .navigationBarTitle("Pick Image") +// } +// } +//} +// +// +//struct ImagePicker: UIViewControllerRepresentable { +// +// @Environment(\.presentationMode) +// var presentationMode +// +// @Binding var image: Image? +// +// class Coordinator: NSObject, UINavigationControllerDelegate, UIImagePickerControllerDelegate { +// +// @Binding var presentationMode: PresentationMode +// @Binding var image: Image? +// +// init(presentationMode: Binding, image: Binding) { +// _presentationMode = presentationMode +// _image = image +// } +// +// func imagePickerController(_ picker: UIImagePickerController, +// didFinishPickingMediaWithInfo info: [UIImagePickerController.InfoKey : Any]) { +// let uiImage = info[UIImagePickerController.InfoKey.originalImage] as! UIImage +// image = Image(uiImage: uiImage) +// print(image! as Any) +// presentationMode.dismiss() +// +// } +// +// func imagePickerControllerDidCancel(_ picker: UIImagePickerController) { +// presentationMode.dismiss() +// } +// +// } +// +// func makeCoordinator() -> Coordinator { +// return Coordinator(presentationMode: presentationMode, image: $image) +// } +// +// func makeUIViewController(context: UIViewControllerRepresentableContext) -> UIImagePickerController { +// let picker = UIImagePickerController() +// picker.delegate = context.coordinator +// return picker +// } +// +// func updateUIViewController(_ uiViewController: UIImagePickerController, +// context: UIViewControllerRepresentableContext) { +// +// } +// +//} +// +////import SwiftUI +//// +////struct ContentView: View { +//// +//// @State private var showImagePicker : Bool = false +//// @State private var image : Image? = Image("profile") +//// +//// var body: some View { +//// NavigationView{ +//// +//// VStack { +//// +//// image?.resizable().scaledToFit() +//// .onTapGesture { +//// self.showImagePicker = true +//// +//// } +//// Button("Open Camera"){ +//// self.showImagePicker = true +//// }.padding() +//// .foregroundColor(Color.white) +//// .background(Color.purple) +//// .cornerRadius(10) +//// }.sheet(isPresented: self.$showImagePicker){ +//// PhotoCaptureView(showImagePicker: self.$showImagePicker, image: self.$image) +//// } +//// +//// .navigationBarTitle(Text("Camera")) +//// } +//// } +//// +//// +////} diff --git a/Testing/merchantPromotionData.json b/Testing/merchantPromotionData.json new file mode 100644 index 0000000..5a2a972 --- /dev/null +++ b/Testing/merchantPromotionData.json @@ -0,0 +1,29 @@ +[ + { + "id": "1", + "title": "promotion C", + "img": "C", + "shop": "Salon C", + "date": "2020-09-01", + "tel": "0123456789", + "msg": "This is Promotion A by Salon A", + }, + { + "id": "2", + "title": "promotion C", + "img": "C", + "shop": "Salon B", + "date": "2020-09-01", + "tel": "0123456789", + "msg": "This is Promotion B by Salon B", + }, + { + "id": "3", + "title": "promotion C", + "img": "C", + "shop": "Salon C", + "date": "2020-09-01", + "tel": "0123456789", + "msg": "This is Promotion C by Salon C", + }, +] diff --git a/Testing/promotionData.json b/Testing/promotionData.json new file mode 100644 index 0000000..e4f3a99 --- /dev/null +++ b/Testing/promotionData.json @@ -0,0 +1,122 @@ +[ + { + "id": "1", + "title": "promotion A", + "imgURL": "https://img.tunai.io/89ea35db-fd6c-4a7c-937a-7c69fe6acfb1.png", + "img": "https://img.tunai.io/0ACFE8DE-7C69-480A-9946-AA5CABBFBC19.jpg", + "shop": "Salon A", + "date": "2020-09-01", + "tel": "01111639290", + "msg": "This is Promotion A by Salon A kjasdh kjahds kjhsd kjahdkja shdkjashd ksdja hkjahd kajshdkjhsa dkjhasdkj", + }, + { + "id": "2", + "title": "promotion B", + "imgURL": "https://m.tunai.io/c51090c5-cdd8-42b5-bba4-3f55714c829f.png", + "shop": "Salon B", + "img": "https://img.tunai.io/3A9870F5-6E0C-4A39-BC51-07A709394722.jpg", + "date": "2020-09-01", + "tel": "0123456789", + "msg": "This is Promotion B by Salon B", + }, + { + "id": "3", + "title": "promotion C", + "imgURL": "https://img.tunai.io/fe99d557-7a29-4193-aaf5-8a4193dbe54c.png", + "img": "https://img.tunai.io/283AD3D2-6CC3-428D-93F8-B16DCCFC2F43.jpg", + "shop": "Salon C", + "date": "2020-09-01", + "tel": "0112345678", + "msg": "This is Promotion C by Salon C", + }, + { + "id": "1", + "title": "promotion A", + "imgURL": "https://img.tunai.io/89ea35db-fd6c-4a7c-937a-7c69fe6acfb1.png", + "img": "https://img.tunai.io/83B118A4-2E8D-4480-AE0A-C3A4FCDA0AC6.jpg", + "shop": "Salon A", + "date": "2020-09-01", + "tel": "01111639290", + "msg": "This is Promotion A by Salon A kjasdh kjahds kjhsd kjahdkja shdkjashd ksdja hkjahd kajshdkjhsa dkjhasdkj", + }, + { + "id": "1", + "title": "promotion A", + "imgURL": "https://img.tunai.io/89ea35db-fd6c-4a7c-937a-7c69fe6acfb1.png", + "img": "https://img.tunai.io/0ACFE8DE-7C69-480A-9946-AA5CABBFBC19.jpg", + "shop": "Salon A", + "date": "2020-09-01", + "tel": "01111639290", + "msg": "This is Promotion A by Salon A kjasdh kjahds kjhsd kjahdkja shdkjashd ksdja hkjahd kajshdkjhsa dkjhasdkj", + }, + { + "id": "2", + "title": "promotion B", + "imgURL": "https://m.tunai.io/c51090c5-cdd8-42b5-bba4-3f55714c829f.png", + "shop": "Salon B", + "img": "https://img.tunai.io/3A9870F5-6E0C-4A39-BC51-07A709394722.jpg", + "date": "2020-09-01", + "tel": "0123456789", + "msg": "This is Promotion B by Salon B", + }, + { + "id": "3", + "title": "promotion C", + "imgURL": "https://img.tunai.io/fe99d557-7a29-4193-aaf5-8a4193dbe54c.png", + "img": "https://img.tunai.io/283AD3D2-6CC3-428D-93F8-B16DCCFC2F43.jpg", + "shop": "Salon C", + "date": "2020-09-01", + "tel": "0112345678", + "msg": "This is Promotion C by Salon C", + }, + { + "id": "1", + "title": "promotion A", + "imgURL": "https://img.tunai.io/89ea35db-fd6c-4a7c-937a-7c69fe6acfb1.png", + "img": "https://img.tunai.io/83B118A4-2E8D-4480-AE0A-C3A4FCDA0AC6.jpg", + "shop": "Salon A", + "date": "2020-09-01", + "tel": "01111639290", + "msg": "This is Promotion A by Salon A kjasdh kjahds kjhsd kjahdkja shdkjashd ksdja hkjahd kajshdkjhsa dkjhasdkj", + }, + { + "id": "1", + "title": "promotion A", + "imgURL": "https://img.tunai.io/89ea35db-fd6c-4a7c-937a-7c69fe6acfb1.png", + "img": "https://img.tunai.io/0ACFE8DE-7C69-480A-9946-AA5CABBFBC19.jpg", + "shop": "Salon A", + "date": "2020-09-01", + "tel": "01111639290", + "msg": "This is Promotion A by Salon A kjasdh kjahds kjhsd kjahdkja shdkjashd ksdja hkjahd kajshdkjhsa dkjhasdkj", + }, + { + "id": "2", + "title": "promotion B", + "imgURL": "https://m.tunai.io/c51090c5-cdd8-42b5-bba4-3f55714c829f.png", + "shop": "Salon B", + "img": "https://img.tunai.io/3A9870F5-6E0C-4A39-BC51-07A709394722.jpg", + "date": "2020-09-01", + "tel": "0123456789", + "msg": "This is Promotion B by Salon B", + }, + { + "id": "3", + "title": "promotion C", + "imgURL": "https://img.tunai.io/fe99d557-7a29-4193-aaf5-8a4193dbe54c.png", + "img": "https://img.tunai.io/283AD3D2-6CC3-428D-93F8-B16DCCFC2F43.jpg", + "shop": "Salon C", + "date": "2020-09-01", + "tel": "0112345678", + "msg": "This is Promotion C by Salon C", + }, + { + "id": "1", + "title": "promotion A", + "imgURL": "https://img.tunai.io/89ea35db-fd6c-4a7c-937a-7c69fe6acfb1.png", + "img": "https://img.tunai.io/83B118A4-2E8D-4480-AE0A-C3A4FCDA0AC6.jpg", + "shop": "Salon A", + "date": "2020-09-01", + "tel": "01111639290", + "msg": "This is Promotion A by Salon A kjasdh kjahds kjhsd kjahdkja shdkjashd ksdja hkjahd kajshdkjhsa dkjhasdkj", + }, +]