From c54ff3d39277088d32bf89a1145ff1c9958a0d6f Mon Sep 17 00:00:00 2001 From: Mattia541993 Date: Sun, 19 Apr 2020 15:34:53 +0200 Subject: [PATCH] aggregate view iOS --- .../project.pbxproj | 345 ++++++++++++++++++ .../contents.xcworkspacedata | 7 + .../xcshareddata/IDEWorkspaceChecks.plist | 8 + .../UserInterfaceState.xcuserstate | Bin 0 -> 20542 bytes .../xcschemes/xcschememanagement.plist | 14 + .../iOSAggregateViews/AppDelegate.swift | 37 ++ .../AppIcon.appiconset/Contents.json | 98 +++++ .../Assets.xcassets/Contents.json | 6 + .../Base.lproj/LaunchScreen.storyboard | 25 ++ .../Base.lproj/Main.storyboard | 106 ++++++ .../iOSAggregateViews/Info.plist | 64 ++++ .../iOSAggregateViews/SceneDelegate.swift | 53 +++ .../iOSAggregateViews/ViewController.swift | 24 ++ 13 files changed, 787 insertions(+) create mode 100644 AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews.xcodeproj/project.pbxproj create mode 100644 AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews.xcodeproj/project.xcworkspace/contents.xcworkspacedata create mode 100644 AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist create mode 100644 AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews.xcodeproj/project.xcworkspace/xcuserdata/mattiaducci.xcuserdatad/UserInterfaceState.xcuserstate create mode 100644 AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews.xcodeproj/xcuserdata/mattiaducci.xcuserdatad/xcschemes/xcschememanagement.plist create mode 100644 AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews/AppDelegate.swift create mode 100644 AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews/Assets.xcassets/AppIcon.appiconset/Contents.json create mode 100644 AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews/Assets.xcassets/Contents.json create mode 100644 AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews/Base.lproj/LaunchScreen.storyboard create mode 100644 AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews/Base.lproj/Main.storyboard create mode 100644 AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews/Info.plist create mode 100644 AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews/SceneDelegate.swift create mode 100644 AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews/ViewController.swift diff --git a/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews.xcodeproj/project.pbxproj b/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews.xcodeproj/project.pbxproj new file mode 100644 index 00000000..601b74ed --- /dev/null +++ b/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews.xcodeproj/project.pbxproj @@ -0,0 +1,345 @@ +// !$*UTF8*$! +{ + archiveVersion = 1; + classes = { + }; + objectVersion = 50; + objects = { + +/* Begin PBXBuildFile section */ + 4B69E3EC244C4A3600A39004 /* AppDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4B69E3EB244C4A3600A39004 /* AppDelegate.swift */; }; + 4B69E3EE244C4A3600A39004 /* SceneDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4B69E3ED244C4A3600A39004 /* SceneDelegate.swift */; }; + 4B69E3F0244C4A3600A39004 /* ViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4B69E3EF244C4A3600A39004 /* ViewController.swift */; }; + 4B69E3F3244C4A3600A39004 /* Main.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 4B69E3F1244C4A3600A39004 /* Main.storyboard */; }; + 4B69E3F5244C4A3700A39004 /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 4B69E3F4244C4A3700A39004 /* Assets.xcassets */; }; + 4B69E3F8244C4A3700A39004 /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 4B69E3F6244C4A3700A39004 /* LaunchScreen.storyboard */; }; +/* End PBXBuildFile section */ + +/* Begin PBXFileReference section */ + 4B69E3E8244C4A3600A39004 /* iOSAggregateViews.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = iOSAggregateViews.app; sourceTree = BUILT_PRODUCTS_DIR; }; + 4B69E3EB244C4A3600A39004 /* AppDelegate.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AppDelegate.swift; sourceTree = ""; }; + 4B69E3ED244C4A3600A39004 /* SceneDelegate.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SceneDelegate.swift; sourceTree = ""; }; + 4B69E3EF244C4A3600A39004 /* ViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ViewController.swift; sourceTree = ""; }; + 4B69E3F2244C4A3600A39004 /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/Main.storyboard; sourceTree = ""; }; + 4B69E3F4244C4A3700A39004 /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = ""; }; + 4B69E3F7244C4A3700A39004 /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/LaunchScreen.storyboard; sourceTree = ""; }; + 4B69E3F9244C4A3700A39004 /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = ""; }; +/* End PBXFileReference section */ + +/* Begin PBXFrameworksBuildPhase section */ + 4B69E3E5244C4A3600A39004 /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXFrameworksBuildPhase section */ + +/* Begin PBXGroup section */ + 4B69E3DF244C4A3600A39004 = { + isa = PBXGroup; + children = ( + 4B69E3EA244C4A3600A39004 /* iOSAggregateViews */, + 4B69E3E9244C4A3600A39004 /* Products */, + ); + sourceTree = ""; + }; + 4B69E3E9244C4A3600A39004 /* Products */ = { + isa = PBXGroup; + children = ( + 4B69E3E8244C4A3600A39004 /* iOSAggregateViews.app */, + ); + name = Products; + sourceTree = ""; + }; + 4B69E3EA244C4A3600A39004 /* iOSAggregateViews */ = { + isa = PBXGroup; + children = ( + 4B69E3EB244C4A3600A39004 /* AppDelegate.swift */, + 4B69E3ED244C4A3600A39004 /* SceneDelegate.swift */, + 4B69E3EF244C4A3600A39004 /* ViewController.swift */, + 4B69E3F1244C4A3600A39004 /* Main.storyboard */, + 4B69E3F4244C4A3700A39004 /* Assets.xcassets */, + 4B69E3F6244C4A3700A39004 /* LaunchScreen.storyboard */, + 4B69E3F9244C4A3700A39004 /* Info.plist */, + ); + path = iOSAggregateViews; + sourceTree = ""; + }; +/* End PBXGroup section */ + +/* Begin PBXNativeTarget section */ + 4B69E3E7244C4A3600A39004 /* iOSAggregateViews */ = { + isa = PBXNativeTarget; + buildConfigurationList = 4B69E3FC244C4A3700A39004 /* Build configuration list for PBXNativeTarget "iOSAggregateViews" */; + buildPhases = ( + 4B69E3E4244C4A3600A39004 /* Sources */, + 4B69E3E5244C4A3600A39004 /* Frameworks */, + 4B69E3E6244C4A3600A39004 /* Resources */, + ); + buildRules = ( + ); + dependencies = ( + ); + name = iOSAggregateViews; + productName = iOSAggregateViews; + productReference = 4B69E3E8244C4A3600A39004 /* iOSAggregateViews.app */; + productType = "com.apple.product-type.application"; + }; +/* End PBXNativeTarget section */ + +/* Begin PBXProject section */ + 4B69E3E0244C4A3600A39004 /* Project object */ = { + isa = PBXProject; + attributes = { + LastSwiftUpdateCheck = 1140; + LastUpgradeCheck = 1140; + ORGANIZATIONNAME = "Mattia Ducci"; + TargetAttributes = { + 4B69E3E7244C4A3600A39004 = { + CreatedOnToolsVersion = 11.4; + }; + }; + }; + buildConfigurationList = 4B69E3E3244C4A3600A39004 /* Build configuration list for PBXProject "iOSAggregateViews" */; + compatibilityVersion = "Xcode 9.3"; + developmentRegion = en; + hasScannedForEncodings = 0; + knownRegions = ( + en, + Base, + ); + mainGroup = 4B69E3DF244C4A3600A39004; + productRefGroup = 4B69E3E9244C4A3600A39004 /* Products */; + projectDirPath = ""; + projectRoot = ""; + targets = ( + 4B69E3E7244C4A3600A39004 /* iOSAggregateViews */, + ); + }; +/* End PBXProject section */ + +/* Begin PBXResourcesBuildPhase section */ + 4B69E3E6244C4A3600A39004 /* Resources */ = { + isa = PBXResourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + 4B69E3F8244C4A3700A39004 /* LaunchScreen.storyboard in Resources */, + 4B69E3F5244C4A3700A39004 /* Assets.xcassets in Resources */, + 4B69E3F3244C4A3600A39004 /* Main.storyboard in Resources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXResourcesBuildPhase section */ + +/* Begin PBXSourcesBuildPhase section */ + 4B69E3E4244C4A3600A39004 /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + 4B69E3F0244C4A3600A39004 /* ViewController.swift in Sources */, + 4B69E3EC244C4A3600A39004 /* AppDelegate.swift in Sources */, + 4B69E3EE244C4A3600A39004 /* SceneDelegate.swift in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXSourcesBuildPhase section */ + +/* Begin PBXVariantGroup section */ + 4B69E3F1244C4A3600A39004 /* Main.storyboard */ = { + isa = PBXVariantGroup; + children = ( + 4B69E3F2244C4A3600A39004 /* Base */, + ); + name = Main.storyboard; + sourceTree = ""; + }; + 4B69E3F6244C4A3700A39004 /* LaunchScreen.storyboard */ = { + isa = PBXVariantGroup; + children = ( + 4B69E3F7244C4A3700A39004 /* Base */, + ); + name = LaunchScreen.storyboard; + sourceTree = ""; + }; +/* End PBXVariantGroup section */ + +/* Begin XCBuildConfiguration section */ + 4B69E3FA244C4A3700A39004 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_NONNULL = YES; + CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++14"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_ENABLE_OBJC_WEAK = YES; + CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_COMMA = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; + CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; + CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; + CLANG_WARN_STRICT_PROTOTYPES = YES; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + COPY_PHASE_STRIP = NO; + DEBUG_INFORMATION_FORMAT = dwarf; + ENABLE_STRICT_OBJC_MSGSEND = YES; + ENABLE_TESTABILITY = YES; + GCC_C_LANGUAGE_STANDARD = gnu11; + GCC_DYNAMIC_NO_PIC = NO; + GCC_NO_COMMON_BLOCKS = YES; + GCC_OPTIMIZATION_LEVEL = 0; + GCC_PREPROCESSOR_DEFINITIONS = ( + "DEBUG=1", + "$(inherited)", + ); + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 13.4; + 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; + }; + 4B69E3FB244C4A3700A39004 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_NONNULL = YES; + CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++14"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_ENABLE_OBJC_WEAK = YES; + CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_COMMA = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; + CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; + CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; + CLANG_WARN_STRICT_PROTOTYPES = YES; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + COPY_PHASE_STRIP = NO; + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + ENABLE_NS_ASSERTIONS = NO; + ENABLE_STRICT_OBJC_MSGSEND = YES; + GCC_C_LANGUAGE_STANDARD = gnu11; + GCC_NO_COMMON_BLOCKS = YES; + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 13.4; + MTL_ENABLE_DEBUG_INFO = NO; + MTL_FAST_MATH = YES; + SDKROOT = iphoneos; + SWIFT_COMPILATION_MODE = wholemodule; + SWIFT_OPTIMIZATION_LEVEL = "-O"; + VALIDATE_PRODUCT = YES; + }; + name = Release; + }; + 4B69E3FD244C4A3700A39004 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + CODE_SIGN_STYLE = Automatic; + DEVELOPMENT_TEAM = 4EN39QDU46; + INFOPLIST_FILE = iOSAggregateViews/Info.plist; + IPHONEOS_DEPLOYMENT_TARGET = 13.0; + LD_RUNPATH_SEARCH_PATHS = ( + "$(inherited)", + "@executable_path/Frameworks", + ); + PRODUCT_BUNDLE_IDENTIFIER = com.example.iOSAggregateViews; + PRODUCT_NAME = "$(TARGET_NAME)"; + SWIFT_VERSION = 5.0; + TARGETED_DEVICE_FAMILY = "1,2"; + }; + name = Debug; + }; + 4B69E3FE244C4A3700A39004 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + CODE_SIGN_STYLE = Automatic; + DEVELOPMENT_TEAM = 4EN39QDU46; + INFOPLIST_FILE = iOSAggregateViews/Info.plist; + IPHONEOS_DEPLOYMENT_TARGET = 13.0; + LD_RUNPATH_SEARCH_PATHS = ( + "$(inherited)", + "@executable_path/Frameworks", + ); + PRODUCT_BUNDLE_IDENTIFIER = com.example.iOSAggregateViews; + PRODUCT_NAME = "$(TARGET_NAME)"; + SWIFT_VERSION = 5.0; + TARGETED_DEVICE_FAMILY = "1,2"; + }; + name = Release; + }; +/* End XCBuildConfiguration section */ + +/* Begin XCConfigurationList section */ + 4B69E3E3244C4A3600A39004 /* Build configuration list for PBXProject "iOSAggregateViews" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 4B69E3FA244C4A3700A39004 /* Debug */, + 4B69E3FB244C4A3700A39004 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + 4B69E3FC244C4A3700A39004 /* Build configuration list for PBXNativeTarget "iOSAggregateViews" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 4B69E3FD244C4A3700A39004 /* Debug */, + 4B69E3FE244C4A3700A39004 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; +/* End XCConfigurationList section */ + }; + rootObject = 4B69E3E0244C4A3600A39004 /* Project object */; +} diff --git a/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews.xcodeproj/project.xcworkspace/contents.xcworkspacedata b/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews.xcodeproj/project.xcworkspace/contents.xcworkspacedata new file mode 100644 index 00000000..97aac044 --- /dev/null +++ b/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews.xcodeproj/project.xcworkspace/contents.xcworkspacedata @@ -0,0 +1,7 @@ + + + + + diff --git a/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist b/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist new file mode 100644 index 00000000..18d98100 --- /dev/null +++ b/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist @@ -0,0 +1,8 @@ + + + + + IDEDidComputeMac32BitWarning + + + diff --git a/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews.xcodeproj/project.xcworkspace/xcuserdata/mattiaducci.xcuserdatad/UserInterfaceState.xcuserstate b/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews.xcodeproj/project.xcworkspace/xcuserdata/mattiaducci.xcuserdatad/UserInterfaceState.xcuserstate new file mode 100644 index 0000000000000000000000000000000000000000..f3a247ed94fd8e18c9875723a3973b1c8bc0c56e GIT binary patch literal 20542 zcmeHvd3;mF_vp;MNt!lonzl*PmZfRaHEr5-U)Z_^3SEFMECMBM(l)eBN|KfxCkUu4 zf}psdVhggW@I^#G5JV9bLoNrVF6I-|v0iAMbrWFa4yMJL{P_ zXU?2$ZdFr*+3wKkzC;)?h(!V+E2H&)Dg zvVN?R4Q5rWnvG#&*+e##O=EM}JT{-zvjf>dYyn%uma=8+7j;&{@mmyPkcM-N?ShZee$@@3K4D zBkWQ3OZFIhoISywWWQp+W>2xF*>Biy+3(mh>{<3__A>hm`zw20fCN~;2v~tYAQXrM zGJ%i4SKue;CFm^(7N`UoL5v_)5HA=Y$P#1=as;`8fr7z;A%a4|P(g)Yv|y~DT2Naa zW@&C{IEuWG6nP^V@C&{xNhx}5c6v^VHa{gPJ3l8WFF89ewNfT8$jcvLwbk334ArJQ zYjty@$>MMg9E3uVW)13rdZJ#aHws276heeVMBIp&xDyW|S%cIl427czs1k+3i6`+Q zYVsab@rU1-akO`{#b}+Rw;38um9qX_hbuEw&jiGEpDY zmq>{>kr5x_OZ5}&ZBqu?3{7=;rmE)JT9a)|h1oR8^-w8` zrBiefNw=lRGuh3x7TQrMuxbZw)(J|v!wh+5lYK0-&o`Rehje$%ei$l4nl>~Xm68Aw z*oI0`1qmcUbT&SvrUrn~WbA;yQl=VNZ8e(WpsyijM_fliT&cs>T*fUI+2TNs+`CS%T&ay#q~nKuQZeOdScC|)|&p&I}> zrW&iw)G-`iT|RA^E>@+Z#F&_t5Ua{aNu4o6>{_)JG#UA~qDdsY6-^-#l!wp}D+~?I zCVMtFC0ErM=uxC;MKeicDt47HhROg5XzmZL=8wzn`LmXek_k+@lL4htL<4u0BVHNng^hjqYV` z2g5QcC?m9&SQ@4jnhf=@gBq;W^)Qp*k;6Mm+IO4YW^L?XZLY3QqOa-7e?AIG^aq>?{$wDD9SdFZOIBkBPEDUW4p%dUA^b5^)ZE}OH-Qj953Qj#b0e^kLcBxQg4)YpyY6 zs{m5_kQ^X96jA@W5@ve`4DGaq`{Mqt4S)xbF(if~cASIuwc%WxN5+!z9fXbtg7S4A zq2ofpZ!sAMxU3|xqW~x#UUk+2SvP7b#UmbQI}+NCCI)C*VE?J?_TFv2lT<2z|)Wg+i zG?*=&*_9xlQsOG9akcF%Ba=xznMNiMz;b+t0L2RpaEelvlxL;g#dUDO4ta{l-c(Fp z!_)9|JOj_fkCFz`L~O)Cn#rW2cou#PW-uGi!E;A6sHFzyvhu7l` z_;vgS&`%|P6K}+u;QOCPjO|)g`S3!J4eSns%>i=-@vgbiQrz5FMP)l*lg0QzrcZU9 z!Dav{*f!i?sWkx+0`lP~)#iAR{OiHs5?^R& zvD&Qh<;4X>1@YwtrDfVgU7{|&(OLyf?bRR%Ti`qZLBnonGRJop5#t|_|NdJ!-LcGz zS3G5H!EaZ}lyC-?nI?A#-L8$a5^u%tP_p``3cv@UscR3pn(;kv$2)kPvfI|_B;f9x zwhg~a2cp9Lf2%&f({`bKt@u4MqmxIzkM{we!+YVx{E*Cq)A7-j_#?a@e@qB*l3677 z5xRkgm@P)Iasl`}yBq{Z28e~g+&QVo+f}EMFP5?VaG%rR4wJ`7<`H}pX!uKf47Azm zW)Lkcj&42C4#;e>;UqqRPvWoe*HHTuK8?SDt@Rx~gU{mcfeHM8&jTlNQG2&}7jw#g z2&E>fa+ghMGR4_J!nD+OUpG)WfLD${DI{~^ zCY7ClB`hL~$sDpCc-2C(t}92rfG=_!Ih4#Nb2$cT1y08FICL=bt3@PaoZWxUIaOMywXF;cF>rsk>!b2Y!cw03K= zt=gqwGrmkOq*>4SF>*%1_%li-fC*%Rm>x_|@-$gOmXc@4vt${0jyz9ZATO?GdUKj~ zI1|dKnJ^rR!kI|2oRikoWCeMZyavmmCabB`7F5cOlnY`NPlIuGPUi)w2M&Y>3qf`& zGFw1`17;WU&|=zEt`#iAhFUn*gCAO_z|z87k?ararGXO-J17Y1JlKoFS_`HpV{RQ~ z)lftI;5gOP(gnNHVT!ZX)YwfRY(50yF0~qfrT^2Uvzr}tRvQfT;F?e~iQd{kPX~@> znPf~_nH2I8nZ!S*W3r0LU^3~Kyi8uc1SN&W#wtZ#jE3ng5AO1Z0}rie$$L&D%-6yob{=lF;aHc#*C*# zPR*YWusXhN6;llY^Zn%XBv@Q_IvbW@Z9;gS<&Ll1;0a2Bs0u zVXWjoWGe_r+epkvDu>cDZ4@Vp($r{PLgh3LZkP@grb9e;4b#F*qr*&MCNoo*sbn*G zi)v4qE|=43)M(Uo=hP6x!j2NxXpvHeUDAc0*HXwY3Ro zP}QxFYi_kUKnAF`nVaCS0Xp>WR)y=G@_84WbD1YVH((wo@3i7jfQc$-po8134ee$s zI$2lch0G$CBEc*s+uIchW+^BV%rnfhWCz*VaY!=HGcVn*3^27Qidg|`?oZyO8ttrZ z8ZEPuS@S@PI%u&TaO6*RaV=iusPzc*CUDS=%qGe`jc|08_y}%Qxx7-CVFf~wTg3ma zH|jf?x7gi7;^`&zmihSl$rb*}fWV+0J$v*HR)vJB!@|cFmv%9q0}N$mM+2b42Ta*~ z0dLSY*}yFThS?mdn?kh$JIDhSz|9K^^1u{U0IHgq3XjF5db7^Nz;r5)xC=DMkE)LnbL1 z{3D)iscB%d@gx36Gy5d;?bjcKD_BoXBIeh(yu2U}lr2t(_w8Op&1k%b1w1(kIr@a` z1YN2&BPA_Ko3GEy(B>rMr)YI)Ir)kDY+ZJ8Uh)|5FJvTwe<2}JH{(c7ZeISw45)yb zt^l;<={pRi6v#mZ{lR}DB@%AX6mSqF>9iS%2|8^~PIjI)AvGyotJCR{larDY^}5_# z7&IdhOv(wmblr@j#U%+thYbf2(1m|~mR$%K&du&+U4h{|M7-MrR_dQTC%|Vqt=R2T z1}d0A=Ug$OgY@{J+bZ-Fs!^kdQ#T6n1=yxdOGr;mk5#25aXy)39e|&as+%zb7$B5! zYnaTL$X!!Q;XAJ!-_5|>R;eGSo19i-NK8sKR3#=?>AgMz>t77f1RH1Hcw0E0RK zKky2)27JKpfEDvNx`eJ_30S{^!MCdezb^09r9Rz0xE~$>Ufo=r52lequqQO)r|>hN zQSQMPz#l6D0WFYGfdB=<6L@4}!5gb%(!l3h3+GEc(+G^Qm01lQ)g8lgx z+kXW9WH)~{Zf4#B*5tCp16y3lY-YBgrNDBieD7l8TbVsbvyOR(*~V-Ku-;{MGP{`f znBC-kvX^{7J|z3dM`Si1UT`hPAqd`KPOf@ah?50c@8L*^-Wf@#bM`McOX=OBPOWbh{Yf2oTz2jTWuiJ+Q;x7zS8PC6Lmz& z`N!eS7C6K}ALn#xuyq$2><()3YcN5Fo#r>bSq_NLMy?^4t3eZiBM>we7l+^p9Ztd^ zK1Hq7APZ85DtBrZSZcto;O#OGc2p1GeMH?Q8Va&&8ILhvAljyfz$DxfbQOb`x}>1#j?t3 zuo+#zon_9!QH_5f3tO2V$e|AR1#^MW3o$deE5jr)A|3f+g>kc{s z>p{M5*AZB+hw2FJSZC#|qML@m2CzLi4S@{;4dI(MwkK!^-%<_XVOjwj!f6Gr&cfJ8 zP7`1wKodCg&uv}xwQM|)92-ZzZ)J7l2OzmlJ(o@4blP*3vRD3Zv|Ytbrpj3pY*5!^ z(pd-rSOx4klkLOyCFjYHAjNA>)JV(+qzYxT#yF^ zWU~jWb6O)im=fan2-rl}5_Tw?!VVwRVGba_l3&O<@`pNmZ$$3mlowK5 zOIps31kWH_!Hyumkt=QND0VctN`5CX75u;zJbVuw{~ry%aBxCYNw02mxqnqwvehi7 z8UA~*0_ZyY6jsG{2dptcc;~FTv z$5RyqjDGi>A8a!_mC}C;JBgjlP9cAhTjVymvx=Pta>@*LCi$D(b7JJgEZqTtE_#HR z6|kFkx*UKW+e1dcP6T_Q#SGdF7-0%>I!~+)zXnxbJH>gBC<}6O4VD%fNz}D~C&f9G z6z7t=WYXxCq>MRT4q%2qarRVxbd@oY>8Y#ZK(LnqAJm z#J`yYOrs0SS8m?E1cNhiIq+q;KYGW z9OT43oVe#Y_G55NhqDLRgY0MQA@*|=<;1-}dKf_{_zi@oK<(N3&!;+U1}9rkbbt`o;PvDS&>DCjhfu{#{y zAcdF&s|}QlN?FXmSIhw)PpJta6!?(8=zp)xkHJ~|)LCMF+f*Y}ID=FVJNViWB5)H( z9x^L|r@)IMMCZf_975Dte2-|Ds+@~1awlD)ID_gY8Ze6W<36KH&p$!JJiGQa)<*Bjc)TnkG%2{%Ct-FK_V!<4Ze6_y{+! zFmwi9K}2r|VMmpMx7B1anv6#k{!(R7uZNhO+5!TJfC$@q^n|$Eo@qr-*^g_K9Cvm$sj`aB^6GnO0aF*>ePUtFrq z0kixODH!TN0V^+{BXqXy0(KB_r=aRmGFK%ef+Y;1glSmts?@af3@)-&NuxbEb0Y17 z!qd?j49x&^8O_(5AlA}mDm8)2*-~qNSe5dEay$5RO2D;agY&*i6)?2%y|h>9C_3UV z&B|%b1~ZdC1u}17ueN+WjkIkWRKN$@f|(qex(25~sMaoW1{{4IrPR9JDSh*!|L(* z(9@W)+^V|FGMxdEV}_SOapib8PVPtCN<&rIL$V=@C!$UiLk~t%J888U%Z}C7nI}l= z8yYQE0Cq$j2ox|&%71~U1FPj8fci>lU^yH_P}U66Un577TxO0A<$@ts#zI`K>dT2X zyVTKK)KUiK>O62n7Ubqazuf60bEk2;B|biN2>H|*nwlCIpwLE$93MD5d(_BLqg8IF z!TP3zQ299IZK$?4We*)%NQu}2u<*p(_5bzbh_i4V)zZGYmi#x;LL+P#sJ92cQ;hcN zMuc!*gxoGxH`yErxraf%dXl4wrUyYAGrr?r2CyLAtHZR6y|rYsP+Rb`+FB8pdOPwONPL`Wl1;eT}BPd_G@L zQ*RwYVF-o%E%ugDn$N*JwJw*!31bP4PcRG~3Ta?sfIfK60ZW7ZcyS`X>Tb+$n?ALc81uc?8f zGguSR9b5BoI(L|(o8Dw8r)x;*f*5T110fA-<+c-5U;{G2y`d`jUkx{i&LS1ELkM~c zm#T$G^+x!r0D@Tf4uo13_}ZX`9o0jAEu_zPl+$P0g0^Xb5-WtXo8fNKz>ZuM1iG8r z+tEI(@TIM2zZbcFtJ}wmgYj~EzXtc1RHzPJhVnW{6`?a+&SZeE5uS4)w;9T6A>DP9 zM4+QYxE)1dy_kLi z9XFZ{YD_^|F266A=Nh$h=5%hCI!2ucuy&n&*Y$F(@%yk|4(Pc7W=L;zQ5ft1%^iTd zzP+_;jcFU0=i;E|sHUc6PYo*=x0-{P&RsRjR%x#Oe9@JE!CEJ_T%&8d;jN@AU2v3Q ze1I-sEa4I1Vd1yJFOdptr& zhvK3E{wQ7^gtHT8d_VW~fLU%_O0(HqFO;Y%@V;?{H^jBfyZ@OR~EAlCx7?YcsF zKSe=r`={>=K&s;l_I!d=ugkW7%#FgW_A$Y>F-JZ3Pp`2o4r*!|w|e?*Q&VRt#e?bb z;_Jm|R;+H5?y_!`?seTCx^Fvc=uYT<(H+yZLdnnUQt*T90zb$O_8?Nh(+<%5wsWc1 z;pW#)&@|gIe;|b*rTwmZoUWH^wP<}8rY3N!_8=y@QVhjd z_dWMd5OwXRJ4fKL!|gh$TACnrlWL?X(rhV~hQMEOy6dR3gR%L^fV^S4Zs^h4& zB>_%1Dl^eK2>mgPlZCMVK?wY7;qwIaM~FN?o|418*xqo*FA6Y1y_$XC%*+QFpaiaN zje^@%)qu@LSg}cP_tlB!!rj-!=vnk4_&iskb>Q{f41Uj@=zX~NdH@}UJFlnUJfXK; zufT2B+Zbav>;*Rh0>K{|j$^%Kl`fZVl^&7)>h10w?w##D&U>o&GViy%Kli>YbC*TPa%BeDOxbeTcG(Hp zH6K5p1fLS0MxO;f>wP})x#;WW8{wPpYxJG%yVCaq-*bMfpV}|iuiEc1zg2$w{Lafo z@<@4se1d$w{0;db`4xq)B3V(Pn5dO^_f+6ErMnQqU_w`+_d_koV}* zqq@hu9-Di7-IM95={daTw4N(_9_)FoSMOc}do}fXq1Ok!F8B8Doz;6n?`L|y*ZWei zUvU3mbMQ04yMupHDOB022G#Sb4^>w}dWH-NX%1-(ITUg`G%~b2bXMrb&~MZp>U4FD z`Wf|J^_8&Tu%fW(VH?7}4tEbv53dV_e4!%b>i~G zFO$5I^hu8^Dy z7o>ljA|b+qIkud)b8h5j=FZ67lgH)_%$t{Y zDBm}~JpaY~Z}p-2TKxw7m4PV(rw!aQNH}Q7pr;3&DCkvCU9hg;%HXuYGX{S+#B)gL zkQax1U#Kax749fviUt=gEjnEsUTi6Trv#N0lq@azW@zNli9_EVCK@($*z#dN4o?_9 zefa)TztYOm^`+O#a>^E!ohpwiZ!X_k;axGNVqL|J5qTq)j5sqge&mdi2Sx>rGLPCe z+HG{j=+&dIJ(B;(vyYq~lQL%RnB!w3$4(ym$+)0#4dZrIdRH1M-x@C*KVtm)@plX* zhBm{ss)DMQs;*S$RzFw$voXu~jPa7GpJ|EdLQTJ#B{dgo`_(S3y;L`#Zdu)BbFTSC z^VJE1CajonqrRkmP5r%w5e*v~#f{?|w_AKI^_CB~Ux6R+5Y z*jC%IeXM<(LkCWkAXJpT4orz~w&D{H_`q9~so`;)cYn>j>dgo`ebhDPs`tz|7kL{SpSoLM`3?T72q)~#FLbN!+X%!cL- zmtG(9`r$Y7-q`l0_RZFf{u}3SLYta5{q&#l|2e*S$mYForN8y&mhdevz3un*ysdca zl&x3Zse9+lwo%)@*gkms-W`2*y!~$6yK8oa>|DM}v1`$L9`DV5@80gIyRYqO+H?8+ z+V{`xt=xO+gOMM6`Qfk+5A7SW@8gg3AAPVtd;ji_`+dCglgv-Hf13X3I|ot^Y(1EA z@a@l1K70F6>Y=Tlr+vQdaK_;sU-bRry(0sTyni(B=to}`e0ktl@v$$CmmfcQV$6v% zCyggBe%0{R)vsH=z725>!qfATd+__x?@yhpKKJtv z_8;z?pZ%lPkIOCuUs!iB@#4-)`b&p@dgQ0`KR5k+`|{jhe13W9*Qj5&{Fe3G!7C%L zoWE+jdhhoIe+2%q=Fj9m_g))%?c3{(*KgmLcQf$j+P~8O+J9@rtqZp&-Eq6~{NK@k z@3=eU?&*7t_wIqMXUf!W7M!+eW!;{k#*CRR3uD_1YF{Ew&dk$cYlEw4G`6j678sbo z{BwW)1MyOYXc$}ppNwY0UE!xdif98FVl})!V>7%v<9)bt^Evtgf`^YIdOPzpItNn3 zb@VqDf&35zmjfek6kH07g*RmM1=-;dcqfJtn{hovQCZ=NRSUcmV=71zGckcTVQh!H z3pel`e3wBC!?=U=AcZ$w_(3eY5@M{<;7t~#OgX&E!o*mZY0OOKad>ORa%Kgy2Ev%W zV2(p9%N39y=zA!F;oTEy;H%GO3*l`O2G#=am6!`M!~*syc(23@;F?JhvtNE9Tow?Oht z;T_vvO5kVgE7UT=`Kvi+{1{3Gk|Ka)NXPr2k3p)eps{jm; zwC^^-AhdK`nbiokGlN5wkdm30Ap41P)d-5}2j9WHuwhM5RzsNda*2milxM+$aa zAlS}g;q5k=@Ir}Ur~=-RFb=}4?t(1r$M$B!Sq;2RC5}ykK#Md8Nf{4L`PrZkKMNk{ z7r@#4GP{CprL+uhMcK-30~vWIcuM!MpTk>DG6Y7!TtS;)m*Aw}yx_Xvrr?&~4oJmF z$Os`wTBsBT3VR5934?_pLbWhl7%7Yv_7#>0tAvwl7NULt-* z{G9j&@pAE6@doi5;!Wbs;w|C>;*;W2;%~%f#NUg55MLGlF8)J&&7E--9bZ1Z^6W0%KnkE0;ZpYu5Halzw~$Il)&J?=@cgp~*-o)W1< zCh?WXLDG+xnJ0N#vQ+Y{-GsQE_GsClwXNji`^oPx!$2`w@UiS+0it;M@!N=e5V{ z6R$&FhrNz?ed%@9>!R0BUYEUo^}6PD!|N}v+g^Wz^+6`>B@L5CNTa|GkswV1TSS^P zLpnrSCN)dzrH#_5(x;@Y(v{NJq;E=hNOwyQNKZeL@Xqnh^VWM0 z@*eD6=snZ>aqlJG&wzgNy!VUVFL}S>y}^5{_fGHky!UwT^*-$VmG@2WzhymT(Xtqs zRu(VoFB>8&l9kAY$x3D8WmPhxtVU*+HOnT+rpOk`mVs9Dq3p2ig6xiu%t!5$>XYSD z?ql|;2mQwCGttNH)9f?TSL2)HTjX2jYXKc+q3<@|UA`B6uloM!d)@b@pU}_KPwFT0 z^Ysh#>*3eSFW4`{PYe1_x!(xC@t_5n{A&H0{O0>D^jqY&$?u@w6*(hU$&=+-@^SL< z@+!GeUL&sq?WjR+kv}G%BY#}}Bxp(t<;&zR%U8%-a-d=v0pz}bLv0p|mL4Y(P|2KESy3QP!03QP%13(N@2 z3Cs)B2M!7x99S4QA@K3Q^?@G*9u7Pjcr5T_;Makt1Fr=B9fX3IAYqVOkb97CkTM8v zVFdL8oiQOODJUf*6l4o>1hoWB4sr&~3tAGq zICx3$^5AvBn}Xj7{xJAN@K?d7g1-s=F8FNlx#07`7lJPZ-wD2}0>h$8q;gkzs=QUc zpiL@OajGGzkt(aIO|?b!h3cH@ZipnrH$)!d9}*A}91;?u4hav53^9Z(4_O@sa zO(B~@wuHPNay;Z@$k!pKL%t0;6Y_n?4Tnzasl2ETu?@*sm zzfeVJV(75Y=FsOt-vteoRY$7zYLnWco~X8~o7FSbkE@?l&sQ&0FH%3Penq`P{i?c6 zy-~eIy;Z$Uy-U4Y{l5AG^%3YvqD)W56$RR5*Et^QkmFH9QNBdm9rDhzI{ zghhrWhoy$4hh>JH3cDC~HSCYDYhgFS{t9Qp1>vG_akxjgXL#T6`tTRSKM4OO{P*zN z;ddiY1QX#G(JLZ2A|yf`5grj2(I+A+A}1m*q99^OL{UUZL`B5d2wTM5h(!?_Beq5y zkGLH1SH!J|+Yx_9dPI6fdPn+3$|L=AL$iJePC_$7c z%00?6N*bk!>K|o{nh`ZO>dC12Q46D>OP%{Yen)*R8C)?A1|F@7M)H?{9*w`+H64{DEUk88iu zp4Ohz{;0jAy{!FJdqaCGP8!!EE;KGYE-Ef2E-@}8E_ zACe!IADOSo*XHZ;`{ifl=j7+-56T~$UzlHAt>qUBZy{|q{-&?QM z$LrJeef0hG1N4RZ68$iJnSO+Rl)g%D0$YGtZ`0fL&H9=8Ir=B`^Yjb!PwAKIU)HbC TxACGf!|=ZX@D6wV3@rX%3Fslx literal 0 HcmV?d00001 diff --git a/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews.xcodeproj/xcuserdata/mattiaducci.xcuserdatad/xcschemes/xcschememanagement.plist b/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews.xcodeproj/xcuserdata/mattiaducci.xcuserdatad/xcschemes/xcschememanagement.plist new file mode 100644 index 00000000..04276f08 --- /dev/null +++ b/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews.xcodeproj/xcuserdata/mattiaducci.xcuserdatad/xcschemes/xcschememanagement.plist @@ -0,0 +1,14 @@ + + + + + SchemeUserState + + iOSAggregateViews.xcscheme_^#shared#^_ + + orderHint + 0 + + + + diff --git a/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews/AppDelegate.swift b/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews/AppDelegate.swift new file mode 100644 index 00000000..94500c5b --- /dev/null +++ b/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews/AppDelegate.swift @@ -0,0 +1,37 @@ +// +// AppDelegate.swift +// iOSAggregateViews +// +// Created by Mattia Ducci on 19/04/2020. +// Copyright © 2020 Mattia Ducci. 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/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews/Assets.xcassets/AppIcon.appiconset/Contents.json b/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews/Assets.xcassets/AppIcon.appiconset/Contents.json new file mode 100644 index 00000000..9221b9bb --- /dev/null +++ b/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews/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/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews/Assets.xcassets/Contents.json b/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews/Assets.xcassets/Contents.json new file mode 100644 index 00000000..73c00596 --- /dev/null +++ b/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews/Assets.xcassets/Contents.json @@ -0,0 +1,6 @@ +{ + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews/Base.lproj/LaunchScreen.storyboard b/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews/Base.lproj/LaunchScreen.storyboard new file mode 100644 index 00000000..865e9329 --- /dev/null +++ b/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews/Base.lproj/LaunchScreen.storyboard @@ -0,0 +1,25 @@ + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews/Base.lproj/Main.storyboard b/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews/Base.lproj/Main.storyboard new file mode 100644 index 00000000..6517918a --- /dev/null +++ b/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews/Base.lproj/Main.storyboard @@ -0,0 +1,106 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews/Info.plist b/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews/Info.plist new file mode 100644 index 00000000..2a3483c0 --- /dev/null +++ b/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews/Info.plist @@ -0,0 +1,64 @@ + + + + + CFBundleDevelopmentRegion + $(DEVELOPMENT_LANGUAGE) + CFBundleExecutable + $(EXECUTABLE_NAME) + CFBundleIdentifier + $(PRODUCT_BUNDLE_IDENTIFIER) + CFBundleInfoDictionaryVersion + 6.0 + CFBundleName + $(PRODUCT_NAME) + CFBundlePackageType + $(PRODUCT_BUNDLE_PACKAGE_TYPE) + CFBundleShortVersionString + 1.0 + CFBundleVersion + 1 + LSRequiresIPhoneOS + + UIApplicationSceneManifest + + UIApplicationSupportsMultipleScenes + + UISceneConfigurations + + UIWindowSceneSessionRoleApplication + + + UISceneConfigurationName + Default Configuration + UISceneDelegateClassName + $(PRODUCT_MODULE_NAME).SceneDelegate + UISceneStoryboardFile + Main + + + + + UILaunchStoryboardName + LaunchScreen + UIMainStoryboardFile + Main + UIRequiredDeviceCapabilities + + armv7 + + UISupportedInterfaceOrientations + + UIInterfaceOrientationPortrait + UIInterfaceOrientationLandscapeLeft + UIInterfaceOrientationLandscapeRight + + UISupportedInterfaceOrientations~ipad + + UIInterfaceOrientationPortrait + UIInterfaceOrientationPortraitUpsideDown + UIInterfaceOrientationLandscapeLeft + UIInterfaceOrientationLandscapeRight + + + diff --git a/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews/SceneDelegate.swift b/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews/SceneDelegate.swift new file mode 100644 index 00000000..50883ddc --- /dev/null +++ b/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews/SceneDelegate.swift @@ -0,0 +1,53 @@ +// +// SceneDelegate.swift +// iOSAggregateViews +// +// Created by Mattia Ducci on 19/04/2020. +// Copyright © 2020 Mattia Ducci. All rights reserved. +// + +import UIKit + +class SceneDelegate: UIResponder, UIWindowSceneDelegate { + + var window: UIWindow? + + + func scene(_ scene: UIScene, willConnectTo session: UISceneSession, options connectionOptions: UIScene.ConnectionOptions) { + // Use this method to optionally configure and attach the UIWindow `window` to the provided UIWindowScene `scene`. + // If using a storyboard, the `window` property will automatically be initialized and attached to the scene. + // This delegate does not imply the connecting scene or session are new (see `application:configurationForConnectingSceneSession` instead). + guard let _ = (scene as? UIWindowScene) else { return } + } + + func sceneDidDisconnect(_ scene: UIScene) { + // Called as the scene is being released by the system. + // This occurs shortly after the scene enters the background, or when its session is discarded. + // Release any resources associated with this scene that can be re-created the next time the scene connects. + // The scene may re-connect later, as its session was not neccessarily discarded (see `application:didDiscardSceneSessions` instead). + } + + func sceneDidBecomeActive(_ scene: UIScene) { + // Called when the scene has moved from an inactive state to an active state. + // Use this method to restart any tasks that were paused (or not yet started) when the scene was inactive. + } + + func sceneWillResignActive(_ scene: UIScene) { + // Called when the scene will move from an active state to an inactive state. + // This may occur due to temporary interruptions (ex. an incoming phone call). + } + + func sceneWillEnterForeground(_ scene: UIScene) { + // Called as the scene transitions from the background to the foreground. + // Use this method to undo the changes made on entering the background. + } + + func sceneDidEnterBackground(_ scene: UIScene) { + // Called as the scene transitions from the foreground to the background. + // Use this method to save data, release shared resources, and store enough scene-specific state information + // to restore the scene back to its current state. + } + + +} + diff --git a/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews/ViewController.swift b/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews/ViewController.swift new file mode 100644 index 00000000..00ae7069 --- /dev/null +++ b/AggregateViews/iOSAggregateViews/iOSAggregateViews/iOSAggregateViews/ViewController.swift @@ -0,0 +1,24 @@ +// +// ViewController.swift +// iOSAggregateViews +// +// Created by Mattia Ducci on 19/04/2020. +// Copyright © 2020 Mattia Ducci. All rights reserved. +// + +import UIKit + +class ViewController: UIViewController { + + @IBOutlet weak var stackView: UIStackView! + + + override func viewDidLoad() { + super.viewDidLoad() + + stackView.shouldGroupAccessibilityChildren = true + } + + +} + -- 2.18.1