From 43f10c52c3c1507ab1eac1dcb8d9116e72aedd51 Mon Sep 17 00:00:00 2001 From: Andrew n marshall Date: Tue, 7 Aug 2018 13:36:21 -0700 Subject: [PATCH] Empty/baseline project for iOS app. --- .../Blockly WebView.xcodeproj/project.pbxproj | 339 ++++++++++++++++++ .../contents.xcworkspacedata | 7 + .../xcshareddata/IDEWorkspaceChecks.plist | 8 + .../UserInterfaceState.xcuserstate | Bin 0 -> 18262 bytes .../xcschemes/xcschememanagement.plist | 14 + demos/ios/Blockly WebView/AppDelegate.swift | 46 +++ .../AppIcon.appiconset/Contents.json | 98 +++++ .../Assets.xcassets/Contents.json | 6 + .../Base.lproj/LaunchScreen.storyboard | 25 ++ .../Base.lproj/Main.storyboard | 24 ++ demos/ios/Blockly WebView/Info.plist | 45 +++ .../ios/Blockly WebView/ViewController.swift | 25 ++ 12 files changed, 637 insertions(+) create mode 100644 demos/ios/Blockly WebView.xcodeproj/project.pbxproj create mode 100644 demos/ios/Blockly WebView.xcodeproj/project.xcworkspace/contents.xcworkspacedata create mode 100644 demos/ios/Blockly WebView.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist create mode 100644 demos/ios/Blockly WebView.xcodeproj/project.xcworkspace/xcuserdata/marshalla.xcuserdatad/UserInterfaceState.xcuserstate create mode 100644 demos/ios/Blockly WebView.xcodeproj/xcuserdata/marshalla.xcuserdatad/xcschemes/xcschememanagement.plist create mode 100644 demos/ios/Blockly WebView/AppDelegate.swift create mode 100644 demos/ios/Blockly WebView/Assets.xcassets/AppIcon.appiconset/Contents.json create mode 100644 demos/ios/Blockly WebView/Assets.xcassets/Contents.json create mode 100644 demos/ios/Blockly WebView/Base.lproj/LaunchScreen.storyboard create mode 100644 demos/ios/Blockly WebView/Base.lproj/Main.storyboard create mode 100644 demos/ios/Blockly WebView/Info.plist create mode 100644 demos/ios/Blockly WebView/ViewController.swift diff --git a/demos/ios/Blockly WebView.xcodeproj/project.pbxproj b/demos/ios/Blockly WebView.xcodeproj/project.pbxproj new file mode 100644 index 000000000..94ba7cea4 --- /dev/null +++ b/demos/ios/Blockly WebView.xcodeproj/project.pbxproj @@ -0,0 +1,339 @@ +// !$*UTF8*$! +{ + archiveVersion = 1; + classes = { + }; + objectVersion = 50; + objects = { + +/* Begin PBXBuildFile section */ + AB980111211A37B50025AFF2 /* AppDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = AB980110211A37B50025AFF2 /* AppDelegate.swift */; }; + AB980113211A37B50025AFF2 /* ViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = AB980112211A37B50025AFF2 /* ViewController.swift */; }; + AB980116211A37B50025AFF2 /* Main.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = AB980114211A37B50025AFF2 /* Main.storyboard */; }; + AB980118211A37B70025AFF2 /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = AB980117211A37B70025AFF2 /* Assets.xcassets */; }; + AB98011B211A37B70025AFF2 /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = AB980119211A37B70025AFF2 /* LaunchScreen.storyboard */; }; +/* End PBXBuildFile section */ + +/* Begin PBXFileReference section */ + AB98010D211A37B50025AFF2 /* Blockly WebView.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = "Blockly WebView.app"; sourceTree = BUILT_PRODUCTS_DIR; }; + AB980110211A37B50025AFF2 /* AppDelegate.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AppDelegate.swift; sourceTree = ""; }; + AB980112211A37B50025AFF2 /* ViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ViewController.swift; sourceTree = ""; }; + AB980115211A37B50025AFF2 /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/Main.storyboard; sourceTree = ""; }; + AB980117211A37B70025AFF2 /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = ""; }; + AB98011A211A37B70025AFF2 /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/LaunchScreen.storyboard; sourceTree = ""; }; + AB98011C211A37B70025AFF2 /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = ""; }; +/* End PBXFileReference section */ + +/* Begin PBXFrameworksBuildPhase section */ + AB98010A211A37B50025AFF2 /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXFrameworksBuildPhase section */ + +/* Begin PBXGroup section */ + AB980104211A37B50025AFF2 = { + isa = PBXGroup; + children = ( + AB98010F211A37B50025AFF2 /* Blockly WebView */, + AB98010E211A37B50025AFF2 /* Products */, + ); + sourceTree = ""; + }; + AB98010E211A37B50025AFF2 /* Products */ = { + isa = PBXGroup; + children = ( + AB98010D211A37B50025AFF2 /* Blockly WebView.app */, + ); + name = Products; + sourceTree = ""; + }; + AB98010F211A37B50025AFF2 /* Blockly WebView */ = { + isa = PBXGroup; + children = ( + AB980110211A37B50025AFF2 /* AppDelegate.swift */, + AB980112211A37B50025AFF2 /* ViewController.swift */, + AB980114211A37B50025AFF2 /* Main.storyboard */, + AB980117211A37B70025AFF2 /* Assets.xcassets */, + AB980119211A37B70025AFF2 /* LaunchScreen.storyboard */, + AB98011C211A37B70025AFF2 /* Info.plist */, + ); + path = "Blockly WebView"; + sourceTree = ""; + }; +/* End PBXGroup section */ + +/* Begin PBXNativeTarget section */ + AB98010C211A37B50025AFF2 /* Blockly WebView */ = { + isa = PBXNativeTarget; + buildConfigurationList = AB98011F211A37B70025AFF2 /* Build configuration list for PBXNativeTarget "Blockly WebView" */; + buildPhases = ( + AB980109211A37B50025AFF2 /* Sources */, + AB98010A211A37B50025AFF2 /* Frameworks */, + AB98010B211A37B50025AFF2 /* Resources */, + ); + buildRules = ( + ); + dependencies = ( + ); + name = "Blockly WebView"; + productName = "Blockly WebView"; + productReference = AB98010D211A37B50025AFF2 /* Blockly WebView.app */; + productType = "com.apple.product-type.application"; + }; +/* End PBXNativeTarget section */ + +/* Begin PBXProject section */ + AB980105211A37B50025AFF2 /* Project object */ = { + isa = PBXProject; + attributes = { + LastSwiftUpdateCheck = 0940; + LastUpgradeCheck = 0940; + ORGANIZATIONNAME = Google; + TargetAttributes = { + AB98010C211A37B50025AFF2 = { + CreatedOnToolsVersion = 9.4.1; + }; + }; + }; + buildConfigurationList = AB980108211A37B50025AFF2 /* Build configuration list for PBXProject "Blockly WebView" */; + compatibilityVersion = "Xcode 9.3"; + developmentRegion = en; + hasScannedForEncodings = 0; + knownRegions = ( + en, + Base, + ); + mainGroup = AB980104211A37B50025AFF2; + productRefGroup = AB98010E211A37B50025AFF2 /* Products */; + projectDirPath = ""; + projectRoot = ""; + targets = ( + AB98010C211A37B50025AFF2 /* Blockly WebView */, + ); + }; +/* End PBXProject section */ + +/* Begin PBXResourcesBuildPhase section */ + AB98010B211A37B50025AFF2 /* Resources */ = { + isa = PBXResourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + AB98011B211A37B70025AFF2 /* LaunchScreen.storyboard in Resources */, + AB980118211A37B70025AFF2 /* Assets.xcassets in Resources */, + AB980116211A37B50025AFF2 /* Main.storyboard in Resources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXResourcesBuildPhase section */ + +/* Begin PBXSourcesBuildPhase section */ + AB980109211A37B50025AFF2 /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + AB980113211A37B50025AFF2 /* ViewController.swift in Sources */, + AB980111211A37B50025AFF2 /* AppDelegate.swift in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXSourcesBuildPhase section */ + +/* Begin PBXVariantGroup section */ + AB980114211A37B50025AFF2 /* Main.storyboard */ = { + isa = PBXVariantGroup; + children = ( + AB980115211A37B50025AFF2 /* Base */, + ); + name = Main.storyboard; + sourceTree = ""; + }; + AB980119211A37B70025AFF2 /* LaunchScreen.storyboard */ = { + isa = PBXVariantGroup; + children = ( + AB98011A211A37B70025AFF2 /* Base */, + ); + name = LaunchScreen.storyboard; + sourceTree = ""; + }; +/* End PBXVariantGroup section */ + +/* Begin XCBuildConfiguration section */ + AB98011D211A37B70025AFF2 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_NONNULL = YES; + CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++14"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_ENABLE_OBJC_WEAK = YES; + CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_COMMA = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; + CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; + CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; + CLANG_WARN_STRICT_PROTOTYPES = YES; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + CODE_SIGN_IDENTITY = "iPhone Developer"; + COPY_PHASE_STRIP = NO; + DEBUG_INFORMATION_FORMAT = dwarf; + ENABLE_STRICT_OBJC_MSGSEND = YES; + ENABLE_TESTABILITY = YES; + GCC_C_LANGUAGE_STANDARD = gnu11; + GCC_DYNAMIC_NO_PIC = NO; + GCC_NO_COMMON_BLOCKS = YES; + GCC_OPTIMIZATION_LEVEL = 0; + GCC_PREPROCESSOR_DEFINITIONS = ( + "DEBUG=1", + "$(inherited)", + ); + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 11.4; + MTL_ENABLE_DEBUG_INFO = YES; + ONLY_ACTIVE_ARCH = YES; + SDKROOT = iphoneos; + SWIFT_ACTIVE_COMPILATION_CONDITIONS = DEBUG; + SWIFT_OPTIMIZATION_LEVEL = "-Onone"; + }; + name = Debug; + }; + AB98011E211A37B70025AFF2 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_NONNULL = YES; + CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++14"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_ENABLE_OBJC_WEAK = YES; + CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_COMMA = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; + CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; + CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; + CLANG_WARN_STRICT_PROTOTYPES = YES; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + CODE_SIGN_IDENTITY = "iPhone Developer"; + COPY_PHASE_STRIP = NO; + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + ENABLE_NS_ASSERTIONS = NO; + ENABLE_STRICT_OBJC_MSGSEND = YES; + GCC_C_LANGUAGE_STANDARD = gnu11; + GCC_NO_COMMON_BLOCKS = YES; + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 11.4; + MTL_ENABLE_DEBUG_INFO = NO; + SDKROOT = iphoneos; + SWIFT_COMPILATION_MODE = wholemodule; + SWIFT_OPTIMIZATION_LEVEL = "-O"; + VALIDATE_PRODUCT = YES; + }; + name = Release; + }; + AB980120211A37B70025AFF2 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + CODE_SIGN_STYLE = Automatic; + DEVELOPMENT_TEAM = 3KZF7Q7Q49; + INFOPLIST_FILE = "Blockly WebView/Info.plist"; + LD_RUNPATH_SEARCH_PATHS = ( + "$(inherited)", + "@executable_path/Frameworks", + ); + PRODUCT_BUNDLE_IDENTIFIER = "com.google.kidscoding.Blockly-WebView"; + PRODUCT_NAME = "$(TARGET_NAME)"; + SWIFT_VERSION = 4.0; + TARGETED_DEVICE_FAMILY = "1,2"; + }; + name = Debug; + }; + AB980121211A37B70025AFF2 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + CODE_SIGN_STYLE = Automatic; + DEVELOPMENT_TEAM = 3KZF7Q7Q49; + INFOPLIST_FILE = "Blockly WebView/Info.plist"; + LD_RUNPATH_SEARCH_PATHS = ( + "$(inherited)", + "@executable_path/Frameworks", + ); + PRODUCT_BUNDLE_IDENTIFIER = "com.google.kidscoding.Blockly-WebView"; + PRODUCT_NAME = "$(TARGET_NAME)"; + SWIFT_VERSION = 4.0; + TARGETED_DEVICE_FAMILY = "1,2"; + }; + name = Release; + }; +/* End XCBuildConfiguration section */ + +/* Begin XCConfigurationList section */ + AB980108211A37B50025AFF2 /* Build configuration list for PBXProject "Blockly WebView" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + AB98011D211A37B70025AFF2 /* Debug */, + AB98011E211A37B70025AFF2 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + AB98011F211A37B70025AFF2 /* Build configuration list for PBXNativeTarget "Blockly WebView" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + AB980120211A37B70025AFF2 /* Debug */, + AB980121211A37B70025AFF2 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; +/* End XCConfigurationList section */ + }; + rootObject = AB980105211A37B50025AFF2 /* Project object */; +} diff --git a/demos/ios/Blockly WebView.xcodeproj/project.xcworkspace/contents.xcworkspacedata b/demos/ios/Blockly WebView.xcodeproj/project.xcworkspace/contents.xcworkspacedata new file mode 100644 index 000000000..2a4f4ae83 --- /dev/null +++ b/demos/ios/Blockly WebView.xcodeproj/project.xcworkspace/contents.xcworkspacedata @@ -0,0 +1,7 @@ + + + + + diff --git a/demos/ios/Blockly WebView.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist b/demos/ios/Blockly WebView.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist new file mode 100644 index 000000000..18d981003 --- /dev/null +++ b/demos/ios/Blockly WebView.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist @@ -0,0 +1,8 @@ + + + + + IDEDidComputeMac32BitWarning + + + diff --git a/demos/ios/Blockly WebView.xcodeproj/project.xcworkspace/xcuserdata/marshalla.xcuserdatad/UserInterfaceState.xcuserstate b/demos/ios/Blockly WebView.xcodeproj/project.xcworkspace/xcuserdata/marshalla.xcuserdatad/UserInterfaceState.xcuserstate new file mode 100644 index 0000000000000000000000000000000000000000..a4dea93447f0a4fd008ddf4293e753e1c1970851 GIT binary patch literal 18262 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 sUQ5}U@>a_Bl$|M`r~KY8uwP8S_ + + + + SchemeUserState + + Blockly WebView.xcscheme + + orderHint + 0 + + + + diff --git a/demos/ios/Blockly WebView/AppDelegate.swift b/demos/ios/Blockly WebView/AppDelegate.swift new file mode 100644 index 000000000..1f2bf6eed --- /dev/null +++ b/demos/ios/Blockly WebView/AppDelegate.swift @@ -0,0 +1,46 @@ +// +// AppDelegate.swift +// Blockly WebView +// +// Created by Andrew Marshall on 8/7/18. +// Copyright © 2018 Google. All rights reserved. +// + +import UIKit + +@UIApplicationMain +class AppDelegate: UIResponder, UIApplicationDelegate { + + var window: UIWindow? + + + func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool { + // Override point for customization after application launch. + return true + } + + func applicationWillResignActive(_ application: UIApplication) { + // Sent when the application is about to move from active to inactive state. This can occur for certain types of temporary interruptions (such as an incoming phone call or SMS message) or when the user quits the application and it begins the transition to the background state. + // Use this method to pause ongoing tasks, disable timers, and invalidate graphics rendering callbacks. Games should use this method to pause the game. + } + + func applicationDidEnterBackground(_ application: UIApplication) { + // Use this method to release shared resources, save user data, invalidate timers, and store enough application state information to restore your application to its current state in case it is terminated later. + // If your application supports background execution, this method is called instead of applicationWillTerminate: when the user quits. + } + + func applicationWillEnterForeground(_ application: UIApplication) { + // Called as part of the transition from the background to the active state; here you can undo many of the changes made on entering the background. + } + + func applicationDidBecomeActive(_ application: UIApplication) { + // Restart any tasks that were paused (or not yet started) while the application was inactive. If the application was previously in the background, optionally refresh the user interface. + } + + func applicationWillTerminate(_ application: UIApplication) { + // Called when the application is about to terminate. Save data if appropriate. See also applicationDidEnterBackground:. + } + + +} + diff --git a/demos/ios/Blockly WebView/Assets.xcassets/AppIcon.appiconset/Contents.json b/demos/ios/Blockly WebView/Assets.xcassets/AppIcon.appiconset/Contents.json new file mode 100644 index 000000000..d8db8d65f --- /dev/null +++ b/demos/ios/Blockly WebView/Assets.xcassets/AppIcon.appiconset/Contents.json @@ -0,0 +1,98 @@ +{ + "images" : [ + { + "idiom" : "iphone", + "size" : "20x20", + "scale" : "2x" + }, + { + "idiom" : "iphone", + "size" : "20x20", + "scale" : "3x" + }, + { + "idiom" : "iphone", + "size" : "29x29", + "scale" : "2x" + }, + { + "idiom" : "iphone", + "size" : "29x29", + "scale" : "3x" + }, + { + "idiom" : "iphone", + "size" : "40x40", + "scale" : "2x" + }, + { + "idiom" : "iphone", + "size" : "40x40", + "scale" : "3x" + }, + { + "idiom" : "iphone", + "size" : "60x60", + "scale" : "2x" + }, + { + "idiom" : "iphone", + "size" : "60x60", + "scale" : "3x" + }, + { + "idiom" : "ipad", + "size" : "20x20", + "scale" : "1x" + }, + { + "idiom" : "ipad", + "size" : "20x20", + "scale" : "2x" + }, + { + "idiom" : "ipad", + "size" : "29x29", + "scale" : "1x" + }, + { + "idiom" : "ipad", + "size" : "29x29", + "scale" : "2x" + }, + { + "idiom" : "ipad", + "size" : "40x40", + "scale" : "1x" + }, + { + "idiom" : "ipad", + "size" : "40x40", + "scale" : "2x" + }, + { + "idiom" : "ipad", + "size" : "76x76", + "scale" : "1x" + }, + { + "idiom" : "ipad", + "size" : "76x76", + "scale" : "2x" + }, + { + "idiom" : "ipad", + "size" : "83.5x83.5", + "scale" : "2x" + }, + { + "idiom" : "ios-marketing", + "size" : "1024x1024", + "scale" : "1x" + } + ], + "info" : { + "version" : 1, + "author" : "xcode" + } +} \ No newline at end of file diff --git a/demos/ios/Blockly WebView/Assets.xcassets/Contents.json b/demos/ios/Blockly WebView/Assets.xcassets/Contents.json new file mode 100644 index 000000000..da4a164c9 --- /dev/null +++ b/demos/ios/Blockly WebView/Assets.xcassets/Contents.json @@ -0,0 +1,6 @@ +{ + "info" : { + "version" : 1, + "author" : "xcode" + } +} \ No newline at end of file diff --git a/demos/ios/Blockly WebView/Base.lproj/LaunchScreen.storyboard b/demos/ios/Blockly WebView/Base.lproj/LaunchScreen.storyboard new file mode 100644 index 000000000..f83f6fd58 --- /dev/null +++ b/demos/ios/Blockly WebView/Base.lproj/LaunchScreen.storyboard @@ -0,0 +1,25 @@ + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/demos/ios/Blockly WebView/Base.lproj/Main.storyboard b/demos/ios/Blockly WebView/Base.lproj/Main.storyboard new file mode 100644 index 000000000..03c13c228 --- /dev/null +++ b/demos/ios/Blockly WebView/Base.lproj/Main.storyboard @@ -0,0 +1,24 @@ + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/demos/ios/Blockly WebView/Info.plist b/demos/ios/Blockly WebView/Info.plist new file mode 100644 index 000000000..16be3b681 --- /dev/null +++ b/demos/ios/Blockly WebView/Info.plist @@ -0,0 +1,45 @@ + + + + + CFBundleDevelopmentRegion + $(DEVELOPMENT_LANGUAGE) + CFBundleExecutable + $(EXECUTABLE_NAME) + CFBundleIdentifier + $(PRODUCT_BUNDLE_IDENTIFIER) + CFBundleInfoDictionaryVersion + 6.0 + CFBundleName + $(PRODUCT_NAME) + CFBundlePackageType + APPL + CFBundleShortVersionString + 1.0 + CFBundleVersion + 1 + LSRequiresIPhoneOS + + UILaunchStoryboardName + LaunchScreen + UIMainStoryboardFile + Main + UIRequiredDeviceCapabilities + + armv7 + + UISupportedInterfaceOrientations + + UIInterfaceOrientationPortrait + UIInterfaceOrientationLandscapeLeft + UIInterfaceOrientationLandscapeRight + + UISupportedInterfaceOrientations~ipad + + UIInterfaceOrientationPortrait + UIInterfaceOrientationPortraitUpsideDown + UIInterfaceOrientationLandscapeLeft + UIInterfaceOrientationLandscapeRight + + + diff --git a/demos/ios/Blockly WebView/ViewController.swift b/demos/ios/Blockly WebView/ViewController.swift new file mode 100644 index 000000000..94df7b750 --- /dev/null +++ b/demos/ios/Blockly WebView/ViewController.swift @@ -0,0 +1,25 @@ +// +// ViewController.swift +// Blockly WebView +// +// Created by Andrew Marshall on 8/7/18. +// Copyright © 2018 Google. All rights reserved. +// + +import UIKit + +class ViewController: UIViewController { + + override func viewDidLoad() { + super.viewDidLoad() + // Do any additional setup after loading the view, typically from a nib. + } + + override func didReceiveMemoryWarning() { + super.didReceiveMemoryWarning() + // Dispose of any resources that can be recreated. + } + + +} +