diff --git a/src/apps/iOS/libreevent-entry-control/libreevent-entry-control.xcodeproj/project.pbxproj b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control.xcodeproj/project.pbxproj new file mode 100755 index 0000000..33aa908 --- /dev/null +++ b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control.xcodeproj/project.pbxproj @@ -0,0 +1,393 @@ +// !$*UTF8*$! +{ + archiveVersion = 1; + classes = { + }; + objectVersion = 56; + objects = { + +/* Begin PBXBuildFile section */ + 921EDBF82A827CF200F8965C /* libreevent_entry_controlApp.swift in Sources */ = {isa = PBXBuildFile; fileRef = 921EDBF72A827CF200F8965C /* libreevent_entry_controlApp.swift */; }; + 921EDBFA2A827CF200F8965C /* ContentView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 921EDBF92A827CF200F8965C /* ContentView.swift */; }; + 921EDBFC2A827CF400F8965C /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 921EDBFB2A827CF400F8965C /* Assets.xcassets */; }; + 921EDBFF2A827CF400F8965C /* Preview Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 921EDBFE2A827CF400F8965C /* Preview Assets.xcassets */; }; + 92DBBD892AA9B6A6006F6094 /* LoginView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 92DBBD882AA9B6A6006F6094 /* LoginView.swift */; }; + 92DBBD8C2AA9C0C5006F6094 /* CodeScanner in Frameworks */ = {isa = PBXBuildFile; productRef = 92DBBD8B2AA9C0C5006F6094 /* CodeScanner */; }; + 92DBBD922AA9D0AF006F6094 /* Launch Screen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 92DBBD912AA9D0AF006F6094 /* Launch Screen.storyboard */; }; +/* End PBXBuildFile section */ + +/* Begin PBXFileReference section */ + 921EDBF42A827CF200F8965C /* libreevent-entry-control.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = "libreevent-entry-control.app"; sourceTree = BUILT_PRODUCTS_DIR; }; + 921EDBF72A827CF200F8965C /* libreevent_entry_controlApp.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = libreevent_entry_controlApp.swift; sourceTree = ""; }; + 921EDBF92A827CF200F8965C /* ContentView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ContentView.swift; sourceTree = ""; }; + 921EDBFB2A827CF400F8965C /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = ""; }; + 921EDBFE2A827CF400F8965C /* Preview Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = "Preview Assets.xcassets"; sourceTree = ""; }; + 92DBBD882AA9B6A6006F6094 /* LoginView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = LoginView.swift; sourceTree = ""; }; + 92DBBD912AA9D0AF006F6094 /* Launch Screen.storyboard */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; path = "Launch Screen.storyboard"; sourceTree = ""; }; + 92DBBD932AA9D5AD006F6094 /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist; path = Info.plist; sourceTree = ""; }; +/* End PBXFileReference section */ + +/* Begin PBXFrameworksBuildPhase section */ + 921EDBF12A827CF200F8965C /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + 92DBBD8C2AA9C0C5006F6094 /* CodeScanner in Frameworks */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXFrameworksBuildPhase section */ + +/* Begin PBXGroup section */ + 921EDBEB2A827CF200F8965C = { + isa = PBXGroup; + children = ( + 921EDBF62A827CF200F8965C /* libreevent-entry-control */, + 921EDBF52A827CF200F8965C /* Products */, + ); + sourceTree = ""; + }; + 921EDBF52A827CF200F8965C /* Products */ = { + isa = PBXGroup; + children = ( + 921EDBF42A827CF200F8965C /* libreevent-entry-control.app */, + ); + name = Products; + sourceTree = ""; + }; + 921EDBF62A827CF200F8965C /* libreevent-entry-control */ = { + isa = PBXGroup; + children = ( + 92DBBD932AA9D5AD006F6094 /* Info.plist */, + 921EDBF72A827CF200F8965C /* libreevent_entry_controlApp.swift */, + 921EDBF92A827CF200F8965C /* ContentView.swift */, + 92DBBD882AA9B6A6006F6094 /* LoginView.swift */, + 921EDBFB2A827CF400F8965C /* Assets.xcassets */, + 921EDBFD2A827CF400F8965C /* Preview Content */, + 92DBBD912AA9D0AF006F6094 /* Launch Screen.storyboard */, + ); + path = "libreevent-entry-control"; + sourceTree = ""; + }; + 921EDBFD2A827CF400F8965C /* Preview Content */ = { + isa = PBXGroup; + children = ( + 921EDBFE2A827CF400F8965C /* Preview Assets.xcassets */, + ); + path = "Preview Content"; + sourceTree = ""; + }; +/* End PBXGroup section */ + +/* Begin PBXNativeTarget section */ + 921EDBF32A827CF200F8965C /* libreevent-entry-control */ = { + isa = PBXNativeTarget; + buildConfigurationList = 921EDC022A827CF400F8965C /* Build configuration list for PBXNativeTarget "libreevent-entry-control" */; + buildPhases = ( + 921EDBF02A827CF200F8965C /* Sources */, + 921EDBF12A827CF200F8965C /* Frameworks */, + 921EDBF22A827CF200F8965C /* Resources */, + ); + buildRules = ( + ); + dependencies = ( + ); + name = "libreevent-entry-control"; + packageProductDependencies = ( + 92DBBD8B2AA9C0C5006F6094 /* CodeScanner */, + ); + productName = "libreevent-entry-control"; + productReference = 921EDBF42A827CF200F8965C /* libreevent-entry-control.app */; + productType = "com.apple.product-type.application"; + }; +/* End PBXNativeTarget section */ + +/* Begin PBXProject section */ + 921EDBEC2A827CF200F8965C /* Project object */ = { + isa = PBXProject; + attributes = { + BuildIndependentTargetsInParallel = 1; + LastSwiftUpdateCheck = 1420; + LastUpgradeCheck = 1420; + TargetAttributes = { + 921EDBF32A827CF200F8965C = { + CreatedOnToolsVersion = 14.2; + }; + }; + }; + buildConfigurationList = 921EDBEF2A827CF200F8965C /* Build configuration list for PBXProject "libreevent-entry-control" */; + compatibilityVersion = "Xcode 14.0"; + developmentRegion = en; + hasScannedForEncodings = 0; + knownRegions = ( + en, + Base, + ); + mainGroup = 921EDBEB2A827CF200F8965C; + packageReferences = ( + 92DBBD8A2AA9C0C5006F6094 /* XCRemoteSwiftPackageReference "CodeScanner" */, + ); + productRefGroup = 921EDBF52A827CF200F8965C /* Products */; + projectDirPath = ""; + projectRoot = ""; + targets = ( + 921EDBF32A827CF200F8965C /* libreevent-entry-control */, + ); + }; +/* End PBXProject section */ + +/* Begin PBXResourcesBuildPhase section */ + 921EDBF22A827CF200F8965C /* Resources */ = { + isa = PBXResourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + 92DBBD922AA9D0AF006F6094 /* Launch Screen.storyboard in Resources */, + 921EDBFF2A827CF400F8965C /* Preview Assets.xcassets in Resources */, + 921EDBFC2A827CF400F8965C /* Assets.xcassets in Resources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXResourcesBuildPhase section */ + +/* Begin PBXSourcesBuildPhase section */ + 921EDBF02A827CF200F8965C /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + 92DBBD892AA9B6A6006F6094 /* LoginView.swift in Sources */, + 921EDBFA2A827CF200F8965C /* ContentView.swift in Sources */, + 921EDBF82A827CF200F8965C /* libreevent_entry_controlApp.swift in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXSourcesBuildPhase section */ + +/* Begin XCBuildConfiguration section */ + 921EDC002A827CF400F8965C /* 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++20"; + 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 = 16.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; + }; + 921EDC012A827CF400F8965C /* 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++20"; + 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 = 16.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; + }; + 921EDC032A827CF400F8965C /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + ASSETCATALOG_COMPILER_GLOBAL_ACCENT_COLOR_NAME = AccentColor; + CODE_SIGN_STYLE = Automatic; + CURRENT_PROJECT_VERSION = 2; + DEVELOPMENT_ASSET_PATHS = "\"libreevent-entry-control/Preview Content\""; + DEVELOPMENT_TEAM = 8CRQNHKNVF; + ENABLE_PREVIEWS = YES; + GENERATE_INFOPLIST_FILE = YES; + INFOPLIST_FILE = "libreevent-entry-control/Info.plist"; + INFOPLIST_KEY_CFBundleDisplayName = libreevent; + INFOPLIST_KEY_LSApplicationCategoryType = "public.app-category.business"; + INFOPLIST_KEY_NSCameraUsageDescription = "We need to scan QR codes"; + INFOPLIST_KEY_UIApplicationSceneManifest_Generation = YES; + INFOPLIST_KEY_UIApplicationSupportsIndirectInputEvents = YES; + INFOPLIST_KEY_UILaunchScreen_Generation = YES; + INFOPLIST_KEY_UILaunchStoryboardName = "Launch Screen.storyboard"; + INFOPLIST_KEY_UISupportedInterfaceOrientations_iPad = "UIInterfaceOrientationPortrait UIInterfaceOrientationPortraitUpsideDown UIInterfaceOrientationLandscapeLeft UIInterfaceOrientationLandscapeRight"; + INFOPLIST_KEY_UISupportedInterfaceOrientations_iPhone = "UIInterfaceOrientationPortrait UIInterfaceOrientationLandscapeLeft UIInterfaceOrientationLandscapeRight"; + IPHONEOS_DEPLOYMENT_TARGET = 16.0; + LD_RUNPATH_SEARCH_PATHS = ( + "$(inherited)", + "@executable_path/Frameworks", + ); + MARKETING_VERSION = 1; + PRODUCT_BUNDLE_IDENTIFIER = "com.janishutz.libreevent-entry-control"; + PRODUCT_NAME = "$(TARGET_NAME)"; + SWIFT_EMIT_LOC_STRINGS = YES; + SWIFT_VERSION = 5.0; + TARGETED_DEVICE_FAMILY = "1,2"; + }; + name = Debug; + }; + 921EDC042A827CF400F8965C /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + ASSETCATALOG_COMPILER_GLOBAL_ACCENT_COLOR_NAME = AccentColor; + CODE_SIGN_STYLE = Automatic; + CURRENT_PROJECT_VERSION = 2; + DEVELOPMENT_ASSET_PATHS = "\"libreevent-entry-control/Preview Content\""; + DEVELOPMENT_TEAM = 8CRQNHKNVF; + ENABLE_PREVIEWS = YES; + GENERATE_INFOPLIST_FILE = YES; + INFOPLIST_FILE = "libreevent-entry-control/Info.plist"; + INFOPLIST_KEY_CFBundleDisplayName = libreevent; + INFOPLIST_KEY_LSApplicationCategoryType = "public.app-category.business"; + INFOPLIST_KEY_NSCameraUsageDescription = "We need to scan QR codes"; + INFOPLIST_KEY_UIApplicationSceneManifest_Generation = YES; + INFOPLIST_KEY_UIApplicationSupportsIndirectInputEvents = YES; + INFOPLIST_KEY_UILaunchScreen_Generation = YES; + INFOPLIST_KEY_UILaunchStoryboardName = "Launch Screen.storyboard"; + INFOPLIST_KEY_UISupportedInterfaceOrientations_iPad = "UIInterfaceOrientationPortrait UIInterfaceOrientationPortraitUpsideDown UIInterfaceOrientationLandscapeLeft UIInterfaceOrientationLandscapeRight"; + INFOPLIST_KEY_UISupportedInterfaceOrientations_iPhone = "UIInterfaceOrientationPortrait UIInterfaceOrientationLandscapeLeft UIInterfaceOrientationLandscapeRight"; + IPHONEOS_DEPLOYMENT_TARGET = 16.0; + LD_RUNPATH_SEARCH_PATHS = ( + "$(inherited)", + "@executable_path/Frameworks", + ); + MARKETING_VERSION = 1; + PRODUCT_BUNDLE_IDENTIFIER = "com.janishutz.libreevent-entry-control"; + PRODUCT_NAME = "$(TARGET_NAME)"; + SWIFT_EMIT_LOC_STRINGS = YES; + SWIFT_VERSION = 5.0; + TARGETED_DEVICE_FAMILY = "1,2"; + }; + name = Release; + }; +/* End XCBuildConfiguration section */ + +/* Begin XCConfigurationList section */ + 921EDBEF2A827CF200F8965C /* Build configuration list for PBXProject "libreevent-entry-control" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 921EDC002A827CF400F8965C /* Debug */, + 921EDC012A827CF400F8965C /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + 921EDC022A827CF400F8965C /* Build configuration list for PBXNativeTarget "libreevent-entry-control" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 921EDC032A827CF400F8965C /* Debug */, + 921EDC042A827CF400F8965C /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; +/* End XCConfigurationList section */ + +/* Begin XCRemoteSwiftPackageReference section */ + 92DBBD8A2AA9C0C5006F6094 /* XCRemoteSwiftPackageReference "CodeScanner" */ = { + isa = XCRemoteSwiftPackageReference; + repositoryURL = "https://github.com/twostraws/CodeScanner"; + requirement = { + kind = upToNextMajorVersion; + minimumVersion = 2.0.0; + }; + }; +/* End XCRemoteSwiftPackageReference section */ + +/* Begin XCSwiftPackageProductDependency section */ + 92DBBD8B2AA9C0C5006F6094 /* CodeScanner */ = { + isa = XCSwiftPackageProductDependency; + package = 92DBBD8A2AA9C0C5006F6094 /* XCRemoteSwiftPackageReference "CodeScanner" */; + productName = CodeScanner; + }; +/* End XCSwiftPackageProductDependency section */ + }; + rootObject = 921EDBEC2A827CF200F8965C /* Project object */; +} diff --git a/src/apps/iOS/libreevent-entry-control/libreevent-entry-control.xcodeproj/project.xcworkspace/contents.xcworkspacedata b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control.xcodeproj/project.xcworkspace/contents.xcworkspacedata new file mode 100755 index 0000000..919434a --- /dev/null +++ b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control.xcodeproj/project.xcworkspace/contents.xcworkspacedata @@ -0,0 +1,7 @@ + + + + + diff --git a/src/apps/iOS/libreevent-entry-control/libreevent-entry-control.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist new file mode 100755 index 0000000..18d9810 --- /dev/null +++ b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist @@ -0,0 +1,8 @@ + + + + + IDEDidComputeMac32BitWarning + + + diff --git a/src/apps/iOS/libreevent-entry-control/libreevent-entry-control.xcodeproj/project.xcworkspace/xcshareddata/swiftpm/Package.resolved b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control.xcodeproj/project.xcworkspace/xcshareddata/swiftpm/Package.resolved new file mode 100755 index 0000000..9a3f6da --- /dev/null +++ b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control.xcodeproj/project.xcworkspace/xcshareddata/swiftpm/Package.resolved @@ -0,0 +1,14 @@ +{ + "pins" : [ + { + "identity" : "codescanner", + "kind" : "remoteSourceControl", + "location" : "https://github.com/twostraws/CodeScanner", + "state" : { + "revision" : "bf5d7087015620b250ee6c865b3c9039fc159d1a", + "version" : "2.3.3" + } + } + ], + "version" : 2 +} diff --git a/src/apps/iOS/libreevent-entry-control/libreevent-entry-control.xcodeproj/project.xcworkspace/xcuserdata/janishutz.xcuserdatad/UserInterfaceState.xcuserstate b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control.xcodeproj/project.xcworkspace/xcuserdata/janishutz.xcuserdatad/UserInterfaceState.xcuserstate new file mode 100755 index 0000000..b5b2b65 Binary files /dev/null and b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control.xcodeproj/project.xcworkspace/xcuserdata/janishutz.xcuserdatad/UserInterfaceState.xcuserstate differ diff --git a/src/apps/iOS/libreevent-entry-control/libreevent-entry-control.xcodeproj/xcuserdata/janishutz.xcuserdatad/xcschemes/xcschememanagement.plist b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control.xcodeproj/xcuserdata/janishutz.xcuserdatad/xcschemes/xcschememanagement.plist new file mode 100755 index 0000000..14547d2 --- /dev/null +++ b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control.xcodeproj/xcuserdata/janishutz.xcuserdatad/xcschemes/xcschememanagement.plist @@ -0,0 +1,14 @@ + + + + + SchemeUserState + + libreevent-entry-control.xcscheme_^#shared#^_ + + orderHint + 0 + + + + diff --git a/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AccentColor.colorset/Contents.json b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AccentColor.colorset/Contents.json new file mode 100755 index 0000000..eb87897 --- /dev/null +++ b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AccentColor.colorset/Contents.json @@ -0,0 +1,11 @@ +{ + "colors" : [ + { + "idiom" : "universal" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/100.png b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/100.png new file mode 100755 index 0000000..581bbf5 Binary files /dev/null and b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/100.png differ diff --git a/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/1024.png b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/1024.png new file mode 100755 index 0000000..8bd9aae Binary files /dev/null and b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/1024.png differ diff --git a/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/114.png b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/114.png new file mode 100755 index 0000000..978696e Binary files /dev/null and b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/114.png differ diff --git a/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/120.png b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/120.png new file mode 100755 index 0000000..1918e4c Binary files /dev/null and b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/120.png differ diff --git a/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/144.png b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/144.png new file mode 100755 index 0000000..6de1b19 Binary files /dev/null and b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/144.png differ diff --git a/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/152.png b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/152.png new file mode 100755 index 0000000..07d84fb Binary files /dev/null and b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/152.png differ diff --git a/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/167.png b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/167.png new file mode 100755 index 0000000..60f96ba Binary files /dev/null and b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/167.png differ diff --git a/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/180.png b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/180.png new file mode 100755 index 0000000..5693d3f Binary files /dev/null and b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/180.png differ diff --git a/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/20.png b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/20.png new file mode 100755 index 0000000..993bd36 Binary files /dev/null and b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/20.png differ diff --git a/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/29.png b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/29.png new file mode 100755 index 0000000..6af93a2 Binary files /dev/null and b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/29.png differ diff --git a/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/40.png b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/40.png new file mode 100755 index 0000000..3ab7e0e Binary files /dev/null and b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/40.png differ diff --git a/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/50.png b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/50.png new file mode 100755 index 0000000..48779ae Binary files /dev/null and b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/50.png differ diff --git a/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/57.png b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/57.png new file mode 100755 index 0000000..be32bd6 Binary files /dev/null and b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/57.png differ diff --git a/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/58.png b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/58.png new file mode 100755 index 0000000..b415b4c Binary files /dev/null and b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/58.png differ diff --git a/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/60.png b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/60.png new file mode 100755 index 0000000..15b4680 Binary files /dev/null and b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/60.png differ diff --git a/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/72.png b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/72.png new file mode 100755 index 0000000..80c7eec Binary files /dev/null and b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/72.png differ diff --git a/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/76.png b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/76.png new file mode 100755 index 0000000..c2764b2 Binary files /dev/null and b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/76.png differ diff --git a/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/80.png b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/80.png new file mode 100755 index 0000000..bb1ee62 Binary files /dev/null and b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/80.png differ diff --git a/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/87.png b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/87.png new file mode 100755 index 0000000..08c3454 Binary files /dev/null and b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/87.png differ diff --git a/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/Contents.json b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/Contents.json new file mode 100755 index 0000000..4fdf882 --- /dev/null +++ b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/AppIcon.appiconset/Contents.json @@ -0,0 +1,158 @@ +{ + "images" : [ + { + "filename" : "40.png", + "idiom" : "iphone", + "scale" : "2x", + "size" : "20x20" + }, + { + "filename" : "60.png", + "idiom" : "iphone", + "scale" : "3x", + "size" : "20x20" + }, + { + "filename" : "29.png", + "idiom" : "iphone", + "scale" : "1x", + "size" : "29x29" + }, + { + "filename" : "58.png", + "idiom" : "iphone", + "scale" : "2x", + "size" : "29x29" + }, + { + "filename" : "87.png", + "idiom" : "iphone", + "scale" : "3x", + "size" : "29x29" + }, + { + "filename" : "80.png", + "idiom" : "iphone", + "scale" : "2x", + "size" : "40x40" + }, + { + "filename" : "120.png", + "idiom" : "iphone", + "scale" : "3x", + "size" : "40x40" + }, + { + "filename" : "57.png", + "idiom" : "iphone", + "scale" : "1x", + "size" : "57x57" + }, + { + "filename" : "114.png", + "idiom" : "iphone", + "scale" : "2x", + "size" : "57x57" + }, + { + "filename" : "120.png", + "idiom" : "iphone", + "scale" : "2x", + "size" : "60x60" + }, + { + "filename" : "180.png", + "idiom" : "iphone", + "scale" : "3x", + "size" : "60x60" + }, + { + "filename" : "20.png", + "idiom" : "ipad", + "scale" : "1x", + "size" : "20x20" + }, + { + "filename" : "40.png", + "idiom" : "ipad", + "scale" : "2x", + "size" : "20x20" + }, + { + "filename" : "29.png", + "idiom" : "ipad", + "scale" : "1x", + "size" : "29x29" + }, + { + "filename" : "58.png", + "idiom" : "ipad", + "scale" : "2x", + "size" : "29x29" + }, + { + "filename" : "40.png", + "idiom" : "ipad", + "scale" : "1x", + "size" : "40x40" + }, + { + "filename" : "80.png", + "idiom" : "ipad", + "scale" : "2x", + "size" : "40x40" + }, + { + "filename" : "50.png", + "idiom" : "ipad", + "scale" : "1x", + "size" : "50x50" + }, + { + "filename" : "100.png", + "idiom" : "ipad", + "scale" : "2x", + "size" : "50x50" + }, + { + "filename" : "72.png", + "idiom" : "ipad", + "scale" : "1x", + "size" : "72x72" + }, + { + "filename" : "144.png", + "idiom" : "ipad", + "scale" : "2x", + "size" : "72x72" + }, + { + "filename" : "76.png", + "idiom" : "ipad", + "scale" : "1x", + "size" : "76x76" + }, + { + "filename" : "152.png", + "idiom" : "ipad", + "scale" : "2x", + "size" : "76x76" + }, + { + "filename" : "167.png", + "idiom" : "ipad", + "scale" : "2x", + "size" : "83.5x83.5" + }, + { + "filename" : "1024.png", + "idiom" : "ios-marketing", + "scale" : "1x", + "size" : "1024x1024" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/Contents.json b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/Contents.json new file mode 100755 index 0000000..73c0059 --- /dev/null +++ b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Assets.xcassets/Contents.json @@ -0,0 +1,6 @@ +{ + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/ContentView.swift b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/ContentView.swift new file mode 100755 index 0000000..43e3b68 --- /dev/null +++ b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/ContentView.swift @@ -0,0 +1,106 @@ +// +// ContentView.swift +// libreevent-entry-control +// +// Created by Janis Hutz on 08.08.23. +// + +import SwiftUI +import CodeScanner +import AVFoundation + +struct ContentView: View { + @State var isShowingLoginSheet = !UserDefaults.standard.bool(forKey: "auth") + @State var isShowingTicketValid = false + @State var isShowingError = false + @State var isShowingTicketInvalid = false + @State var isShowingCredentialsWrong = false + @State var username = "" + @State var instance = "" + @State var scanResult = "" + var body: some View { + NavigationStack { + Text(String.localizedStringWithFormat(NSLocalizedString("connectionDetails", value: "You are connected to %@ as %@", comment: "This shows connection details for the "), instance, username)).padding().font(.footnote).italic() + CodeScannerView(codeTypes: [.qr], scanMode: .continuous, simulatedData: "dsgkgjkdsagjdksagdklsadgakjs_dgf", shouldVibrateOnSuccess: true, completion: handleScanAdd).navigationTitle(NSLocalizedString("app.name", value: "libreevent", comment: "Title of the app")) + .toolbar { + Button { + UserDefaults.standard.set(false, forKey: "auth") + isShowingLoginSheet = true + } label: { + Text(NSLocalizedString("toobar.logout", value: "Log out", comment: "Logout button in toolbar on main screen")) + } + }.onAppear { + username = UserDefaults.standard.string(forKey: "email") ?? "" + instance = UserDefaults.standard.string(forKey: "url") ?? "" + }.onChange(of: isShowingLoginSheet) { newValue in + if newValue == false { + print("reloading") + username = UserDefaults.standard.string(forKey: "email") ?? "" + instance = UserDefaults.standard.string(forKey: "url") ?? "" + } + } + }.sheet(isPresented: $isShowingLoginSheet) { + LoginView(isShowingLoginSheet: $isShowingLoginSheet).interactiveDismissDisabled(true) + }.alert(NSLocalizedString("lookup.error", value: "An unknown error occurred whilst looking up data. Please try again!", comment: "Tells the user that lookup of data did not succeed"), isPresented: $isShowingError) { + Button { + isShowingError = false + } label: { + Text("Ok") + } + }.alert(NSLocalizedString("lookup.invalid", value: "Ticket is INVALID!", comment: "Tells the user that the ticket scanned is not valid"), isPresented: $isShowingTicketInvalid) { + Button { + isShowingTicketInvalid = false + } label: { + Text("Ok") + } + }.alert(NSLocalizedString("lookup.valid", value: "Ticket is VALID!", comment: "Tells the user that the ticket scanned is valid"), isPresented: $isShowingTicketValid) { + Button { + isShowingTicketValid = false + } label: { + Text("Ok") + } + }.alert(NSLocalizedString("lookup.credWrong", value: "Authentication credentials are incorrect! Please reauthenticate!", comment: "Tells the user that the authentication credentials are not valid"), isPresented: $isShowingCredentialsWrong) { + Button { + isShowingCredentialsWrong = false + } label: { + Text("Ok") + } + } + } + func handleScanAdd(result: Result) { + switch result { + case.success(let result): + var req = URLRequest(url: URL(string: UserDefaults.standard.string(forKey: "url")! + "/app/ticketLookup")!) + req.httpMethod = "POST" + let body = ["email": UserDefaults.standard.string(forKey: "email")!, + "password": UserDefaults.standard.string(forKey: "password")!, + "ticketID": result.string] + let bodyData = try? JSONSerialization.data( + withJSONObject: body, + options: [] + ) + req.httpBody = bodyData + req.setValue("application/json", forHTTPHeaderField: "Content-Type") + let task = URLSession.shared.dataTask(with: req) { data, res, err in + if err != nil { + isShowingError = true + } + + if let data = data, let dataString = String(data: data, encoding: .utf8) { + if dataString == "ticketInvalid" { + isShowingTicketInvalid = true + } else if dataString == "wrong" { + isShowingCredentialsWrong = true + } else { + isShowingTicketValid = true + } + } else { + isShowingTicketInvalid = false + } + } + task.resume() + case.failure(let error): + print(error.localizedDescription) + } + } +} diff --git a/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Info.plist b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Info.plist new file mode 100755 index 0000000..0c67376 --- /dev/null +++ b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Info.plist @@ -0,0 +1,5 @@ + + + + + diff --git a/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Launch Screen.storyboard b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Launch Screen.storyboard new file mode 100755 index 0000000..cb7311d --- /dev/null +++ b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Launch Screen.storyboard @@ -0,0 +1,48 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/LoginView.swift b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/LoginView.swift new file mode 100755 index 0000000..e25a481 --- /dev/null +++ b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/LoginView.swift @@ -0,0 +1,94 @@ +// +// LoginView.swift +// libreevent-entry-control +// +// Created by Janis Hutz on 07.09.23. +// + +import SwiftUI + +struct LoginView: View { + @State var url: String = UserDefaults.standard.string(forKey: "url") ?? "" + @State var username: String = UserDefaults.standard.string(forKey: "email") ?? "" + @State var password: String = "" + @State var isShowingAuthError: Bool = false + @Binding var isShowingLoginSheet: Bool + @State var isShowingIncorrect: Bool = false + @State var isLogginIn = false + var body: some View { + NavigationStack { + Spacer() + VStack { + Text(NSLocalizedString("home.title", value: "Welcome to libreevent!", comment: "Title for login page")).font(.largeTitle).bold() + Spacer().frame(height: 50) + Text("Please enter the libreevent server URL, the username and password of that user in the corresponding fields below to log in") + TextField(NSLocalizedString("url", value: "libreevent server url", comment: "The field where the user is supposed to enter the libreevent server url."), text: $url).keyboardType(.URL) + TextField(NSLocalizedString("username", value: "Username", comment: "The username entry field on login screen"), text: $username).keyboardType(.emailAddress) + SecureField(NSLocalizedString("password", value: "Password", comment: "The password entry field on login screen"), text: $password) + Button { + connect() + } label: { + Text("Sign in") + } + if isLogginIn { + Text("Logging in...").padding() + } + } + Spacer() + Text(NSLocalizedString("home.explanation", value: "libreevent entry control requires a operational libreevent server instance. Click the link below for more info", comment: "")).font(.footnote).foregroundColor(.gray).italic() + Link(destination: URL(string: "https://libreevent.janishutz.com")!) { + Text("libreevent website").font(.footnote).italic() + } + Spacer().frame(height: 30).alert(NSLocalizedString("auth.error", value: "Could not authenticate! Please check that URL is correct.", comment: "Tells the user that authentication did not succeed"), isPresented: $isShowingAuthError) { + Button { + isShowingAuthError = false + } label: { + Text("Ok") + } + }.alert(NSLocalizedString("auth.incorrect", value: "Some values are incorrect!", comment: "Tells the user that authentication did not succeed"), isPresented: $isShowingIncorrect) { + Button { + isShowingIncorrect = false + } label: { + Text("Ok") + } + } + }.padding() + } + + func connect() { + isLogginIn = true + var req = URLRequest(url: URL(string: $url.wrappedValue + "/app/authenticate")!) + req.httpMethod = "POST" + let body = ["email": $username.wrappedValue, "password": $password.wrappedValue] + let bodyData = try? JSONSerialization.data( + withJSONObject: body, + options: [] + ) + req.httpBody = bodyData + req.setValue("application/json", forHTTPHeaderField: "Content-Type") + let task = URLSession.shared.dataTask(with: req) { data, res, err in + if err != nil { + isShowingAuthError = true + } + + if let data = data, let dataString = String(data: data, encoding: .utf8) { + print(dataString) + if dataString == "authOk" { + UserDefaults.standard.set(true, forKey: "auth") + UserDefaults.standard.set($username.wrappedValue, forKey: "email") + UserDefaults.standard.set($password.wrappedValue, forKey: "password") + UserDefaults.standard.set($url.wrappedValue, forKey: "url") + isShowingLoginSheet = false + isLogginIn = false + } else { + isShowingIncorrect = true + isLogginIn = false + } + } else { + isShowingIncorrect = true + isLogginIn = false + } + } + task.resume() + } +} diff --git a/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Preview Content/Preview Assets.xcassets/Contents.json b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Preview Content/Preview Assets.xcassets/Contents.json new file mode 100755 index 0000000..73c0059 --- /dev/null +++ b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/Preview Content/Preview Assets.xcassets/Contents.json @@ -0,0 +1,6 @@ +{ + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/libreevent_entry_controlApp.swift b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/libreevent_entry_controlApp.swift new file mode 100755 index 0000000..d048fd2 --- /dev/null +++ b/src/apps/iOS/libreevent-entry-control/libreevent-entry-control/libreevent_entry_controlApp.swift @@ -0,0 +1,17 @@ +// +// libreevent_entry_controlApp.swift +// libreevent-entry-control +// +// Created by Janis Hutz on 08.08.23. +// + +import SwiftUI + +@main +struct libreevent_entry_controlApp: App { + var body: some Scene { + WindowGroup { + ContentView() + } + } +}