ソースを参照

新增Apex CRM 工程

Ray Zhang 7 年 前
コミット
c2e54a57a2
24 ファイル変更1463 行追加0 行削除
  1. 424 0
      RedAnt CRM/APEX CRM/APEX CRM.xcodeproj/project.pbxproj
  2. 7 0
      RedAnt CRM/APEX CRM/APEX CRM.xcodeproj/project.xcworkspace/contents.xcworkspacedata
  3. 8 0
      RedAnt CRM/APEX CRM/APEX CRM.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist
  4. BIN
      RedAnt CRM/APEX CRM/APEX CRM.xcodeproj/project.xcworkspace/xcuserdata/ray.xcuserdatad/UserInterfaceState.xcuserstate
  5. 14 0
      RedAnt CRM/APEX CRM/APEX CRM.xcodeproj/xcuserdata/ray.xcuserdatad/xcschemes/xcschememanagement.plist
  6. 17 0
      RedAnt CRM/APEX CRM/APEX CRM/AppDelegate.h
  7. 51 0
      RedAnt CRM/APEX CRM/APEX CRM/AppDelegate.m
  8. 98 0
      RedAnt CRM/APEX CRM/APEX CRM/Assets.xcassets/AppIcon.appiconset/Contents.json
  9. 6 0
      RedAnt CRM/APEX CRM/APEX CRM/Assets.xcassets/Contents.json
  10. 25 0
      RedAnt CRM/APEX CRM/APEX CRM/Base.lproj/LaunchScreen.storyboard
  11. 81 0
      RedAnt CRM/APEX CRM/APEX CRM/Base.lproj/Main.storyboard
  12. 45 0
      RedAnt CRM/APEX CRM/APEX CRM/Info.plist
  13. 22 0
      RedAnt CRM/APEX CRM/APEX CRM/RAWKWebView.h
  14. 262 0
      RedAnt CRM/APEX CRM/APEX CRM/RAWKWebView.m
  15. 15 0
      RedAnt CRM/APEX CRM/APEX CRM/ViewController.h
  16. 34 0
      RedAnt CRM/APEX CRM/APEX CRM/ViewController.m
  17. 17 0
      RedAnt CRM/APEX CRM/APEX CRM/WKWebTestViewController.h
  18. 79 0
      RedAnt CRM/APEX CRM/APEX CRM/WKWebTestViewController.m
  19. 16 0
      RedAnt CRM/APEX CRM/APEX CRM/main.m
  20. 7 0
      RedAnt CRM/RedAnt CRM.xcworkspace/contents.xcworkspacedata
  21. 8 0
      RedAnt CRM/RedAnt CRM.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist
  22. BIN
      RedAnt CRM/RedAnt CRM.xcworkspace/xcuserdata/ray.xcuserdatad/UserInterfaceState.xcuserstate
  23. 205 0
      RedAnt CRM/RedAnt CRM.xcworkspace/xcuserdata/ray.xcuserdatad/xcdebugger/Breakpoints_v2.xcbkptlist
  24. 22 0
      RedAnt CRM/RedAnt CRM.xcworkspace/xcuserdata/ray.xcuserdatad/xcdebugger/Expressions.xcexplist

+ 424 - 0
RedAnt CRM/APEX CRM/APEX CRM.xcodeproj/project.pbxproj

@@ -0,0 +1,424 @@
+// !$*UTF8*$!
+{
+	archiveVersion = 1;
+	classes = {
+	};
+	objectVersion = 50;
+	objects = {
+
+/* Begin PBXBuildFile section */
+		7106E80A21A684F20056DD20 /* AppDelegate.m in Sources */ = {isa = PBXBuildFile; fileRef = 7106E80921A684F20056DD20 /* AppDelegate.m */; };
+		7106E80D21A684F20056DD20 /* ViewController.m in Sources */ = {isa = PBXBuildFile; fileRef = 7106E80C21A684F20056DD20 /* ViewController.m */; };
+		7106E81021A684F20056DD20 /* Main.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 7106E80E21A684F20056DD20 /* Main.storyboard */; };
+		7106E81221A684F50056DD20 /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 7106E81121A684F50056DD20 /* Assets.xcassets */; };
+		7106E81521A684F50056DD20 /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 7106E81321A684F50056DD20 /* LaunchScreen.storyboard */; };
+		7106E81821A684F50056DD20 /* main.m in Sources */ = {isa = PBXBuildFile; fileRef = 7106E81721A684F50056DD20 /* main.m */; };
+		7106E82221A6856E0056DD20 /* WKWebTestViewController.m in Sources */ = {isa = PBXBuildFile; fileRef = 7106E81E21A6856E0056DD20 /* WKWebTestViewController.m */; };
+		7106E82621A698D20056DD20 /* RAWKWebView.m in Sources */ = {isa = PBXBuildFile; fileRef = 7106E82521A698D20056DD20 /* RAWKWebView.m */; };
+		7106E82A21ABF2190056DD20 /* RAConvertor.m in Sources */ = {isa = PBXBuildFile; fileRef = 7106E82821ABF2180056DD20 /* RAConvertor.m */; };
+		7106E82F21AD1ACD0056DD20 /* RAUtils.m in Sources */ = {isa = PBXBuildFile; fileRef = 7106E82D21AD1ACC0056DD20 /* RAUtils.m */; };
+		7106E83A21AD1B070056DD20 /* mztools.c in Sources */ = {isa = PBXBuildFile; fileRef = 7106E83121AD1B070056DD20 /* mztools.c */; };
+		7106E83B21AD1B070056DD20 /* unzip.c in Sources */ = {isa = PBXBuildFile; fileRef = 7106E83521AD1B070056DD20 /* unzip.c */; };
+		7106E83C21AD1B070056DD20 /* ioapi.c in Sources */ = {isa = PBXBuildFile; fileRef = 7106E83621AD1B070056DD20 /* ioapi.c */; };
+		7106E83D21AD1B070056DD20 /* zip.c in Sources */ = {isa = PBXBuildFile; fileRef = 7106E83821AD1B070056DD20 /* zip.c */; };
+		7106E84021AD1B0D0056DD20 /* ZipArchive.mm in Sources */ = {isa = PBXBuildFile; fileRef = 7106E83F21AD1B0D0056DD20 /* ZipArchive.mm */; };
+/* End PBXBuildFile section */
+
+/* Begin PBXFileReference section */
+		7106E80521A684F20056DD20 /* APEX CRM.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = "APEX CRM.app"; sourceTree = BUILT_PRODUCTS_DIR; };
+		7106E80821A684F20056DD20 /* AppDelegate.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = AppDelegate.h; sourceTree = "<group>"; };
+		7106E80921A684F20056DD20 /* AppDelegate.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = AppDelegate.m; sourceTree = "<group>"; };
+		7106E80B21A684F20056DD20 /* ViewController.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = ViewController.h; sourceTree = "<group>"; };
+		7106E80C21A684F20056DD20 /* ViewController.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = ViewController.m; sourceTree = "<group>"; };
+		7106E80F21A684F20056DD20 /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/Main.storyboard; sourceTree = "<group>"; };
+		7106E81121A684F50056DD20 /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = "<group>"; };
+		7106E81421A684F50056DD20 /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/LaunchScreen.storyboard; sourceTree = "<group>"; };
+		7106E81621A684F50056DD20 /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; };
+		7106E81721A684F50056DD20 /* main.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = main.m; sourceTree = "<group>"; };
+		7106E81E21A6856E0056DD20 /* WKWebTestViewController.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = WKWebTestViewController.m; sourceTree = "<group>"; };
+		7106E82121A6856E0056DD20 /* WKWebTestViewController.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = WKWebTestViewController.h; sourceTree = "<group>"; };
+		7106E82421A698D20056DD20 /* RAWKWebView.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = RAWKWebView.h; sourceTree = "<group>"; };
+		7106E82521A698D20056DD20 /* RAWKWebView.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = RAWKWebView.m; sourceTree = "<group>"; };
+		7106E82821ABF2180056DD20 /* RAConvertor.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = RAConvertor.m; path = ../../../../common/RAConvertor.m; sourceTree = "<group>"; };
+		7106E82921ABF2180056DD20 /* RAConvertor.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = RAConvertor.h; path = ../../../../common/RAConvertor.h; sourceTree = "<group>"; };
+		7106E82C21ABF29F0056DD20 /* const.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; name = const.h; path = "../../../../RedAnt ERP Mobile/common/const.h"; sourceTree = "<group>"; };
+		7106E82D21AD1ACC0056DD20 /* RAUtils.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = RAUtils.m; path = "../../../../RedAnt ERP Mobile/common/RAUtils.m"; sourceTree = "<group>"; };
+		7106E82E21AD1ACD0056DD20 /* RAUtils.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = RAUtils.h; path = "../../../../RedAnt ERP Mobile/common/RAUtils.h"; sourceTree = "<group>"; };
+		7106E83121AD1B070056DD20 /* mztools.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; name = mztools.c; path = "../../../../../RedAnt ERP Mobile/common/zip/minizip/mztools.c"; sourceTree = "<group>"; };
+		7106E83221AD1B070056DD20 /* ioapi.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = ioapi.h; path = "../../../../../RedAnt ERP Mobile/common/zip/minizip/ioapi.h"; sourceTree = "<group>"; };
+		7106E83321AD1B070056DD20 /* unzip.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = unzip.h; path = "../../../../../RedAnt ERP Mobile/common/zip/minizip/unzip.h"; sourceTree = "<group>"; };
+		7106E83421AD1B070056DD20 /* zip.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = zip.h; path = "../../../../../RedAnt ERP Mobile/common/zip/minizip/zip.h"; sourceTree = "<group>"; };
+		7106E83521AD1B070056DD20 /* unzip.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; name = unzip.c; path = "../../../../../RedAnt ERP Mobile/common/zip/minizip/unzip.c"; sourceTree = "<group>"; };
+		7106E83621AD1B070056DD20 /* ioapi.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; name = ioapi.c; path = "../../../../../RedAnt ERP Mobile/common/zip/minizip/ioapi.c"; sourceTree = "<group>"; };
+		7106E83721AD1B070056DD20 /* mztools.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = mztools.h; path = "../../../../../RedAnt ERP Mobile/common/zip/minizip/mztools.h"; sourceTree = "<group>"; };
+		7106E83821AD1B070056DD20 /* zip.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; name = zip.c; path = "../../../../../RedAnt ERP Mobile/common/zip/minizip/zip.c"; sourceTree = "<group>"; };
+		7106E83921AD1B070056DD20 /* crypt.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = crypt.h; path = "../../../../../RedAnt ERP Mobile/common/zip/minizip/crypt.h"; sourceTree = "<group>"; };
+		7106E83E21AD1B0D0056DD20 /* ZipArchive.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = ZipArchive.h; path = "../../../../../RedAnt ERP Mobile/common/zip/ZipArchive.h"; sourceTree = "<group>"; };
+		7106E83F21AD1B0D0056DD20 /* ZipArchive.mm */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.objcpp; name = ZipArchive.mm; path = "../../../../../RedAnt ERP Mobile/common/zip/ZipArchive.mm"; sourceTree = "<group>"; };
+/* End PBXFileReference section */
+
+/* Begin PBXFrameworksBuildPhase section */
+		7106E80221A684F20056DD20 /* Frameworks */ = {
+			isa = PBXFrameworksBuildPhase;
+			buildActionMask = 2147483647;
+			files = (
+			);
+			runOnlyForDeploymentPostprocessing = 0;
+		};
+/* End PBXFrameworksBuildPhase section */
+
+/* Begin PBXGroup section */
+		7106E7FC21A684F20056DD20 = {
+			isa = PBXGroup;
+			children = (
+				7106E80721A684F20056DD20 /* APEX CRM */,
+				7106E80621A684F20056DD20 /* Products */,
+			);
+			sourceTree = "<group>";
+		};
+		7106E80621A684F20056DD20 /* Products */ = {
+			isa = PBXGroup;
+			children = (
+				7106E80521A684F20056DD20 /* APEX CRM.app */,
+			);
+			name = Products;
+			sourceTree = "<group>";
+		};
+		7106E80721A684F20056DD20 /* APEX CRM */ = {
+			isa = PBXGroup;
+			children = (
+				7106E82B21ABF26C0056DD20 /* config */,
+				7106E82721ABF1F90056DD20 /* utils */,
+				7106E80821A684F20056DD20 /* AppDelegate.h */,
+				7106E80921A684F20056DD20 /* AppDelegate.m */,
+				7106E82121A6856E0056DD20 /* WKWebTestViewController.h */,
+				7106E81E21A6856E0056DD20 /* WKWebTestViewController.m */,
+				7106E80B21A684F20056DD20 /* ViewController.h */,
+				7106E80C21A684F20056DD20 /* ViewController.m */,
+				7106E82421A698D20056DD20 /* RAWKWebView.h */,
+				7106E82521A698D20056DD20 /* RAWKWebView.m */,
+				7106E80E21A684F20056DD20 /* Main.storyboard */,
+				7106E81121A684F50056DD20 /* Assets.xcassets */,
+				7106E81321A684F50056DD20 /* LaunchScreen.storyboard */,
+				7106E81621A684F50056DD20 /* Info.plist */,
+				7106E81721A684F50056DD20 /* main.m */,
+			);
+			path = "APEX CRM";
+			sourceTree = "<group>";
+		};
+		7106E82721ABF1F90056DD20 /* utils */ = {
+			isa = PBXGroup;
+			children = (
+				7106E83021AD1AF40056DD20 /* zip */,
+				7106E82E21AD1ACD0056DD20 /* RAUtils.h */,
+				7106E82D21AD1ACC0056DD20 /* RAUtils.m */,
+				7106E82921ABF2180056DD20 /* RAConvertor.h */,
+				7106E82821ABF2180056DD20 /* RAConvertor.m */,
+			);
+			path = utils;
+			sourceTree = "<group>";
+		};
+		7106E82B21ABF26C0056DD20 /* config */ = {
+			isa = PBXGroup;
+			children = (
+				7106E82C21ABF29F0056DD20 /* const.h */,
+			);
+			path = config;
+			sourceTree = "<group>";
+		};
+		7106E83021AD1AF40056DD20 /* zip */ = {
+			isa = PBXGroup;
+			children = (
+				7106E83E21AD1B0D0056DD20 /* ZipArchive.h */,
+				7106E83F21AD1B0D0056DD20 /* ZipArchive.mm */,
+				7106E83921AD1B070056DD20 /* crypt.h */,
+				7106E83621AD1B070056DD20 /* ioapi.c */,
+				7106E83221AD1B070056DD20 /* ioapi.h */,
+				7106E83121AD1B070056DD20 /* mztools.c */,
+				7106E83721AD1B070056DD20 /* mztools.h */,
+				7106E83521AD1B070056DD20 /* unzip.c */,
+				7106E83321AD1B070056DD20 /* unzip.h */,
+				7106E83821AD1B070056DD20 /* zip.c */,
+				7106E83421AD1B070056DD20 /* zip.h */,
+			);
+			path = zip;
+			sourceTree = "<group>";
+		};
+/* End PBXGroup section */
+
+/* Begin PBXNativeTarget section */
+		7106E80421A684F20056DD20 /* APEX CRM */ = {
+			isa = PBXNativeTarget;
+			buildConfigurationList = 7106E81B21A684F50056DD20 /* Build configuration list for PBXNativeTarget "APEX CRM" */;
+			buildPhases = (
+				7106E80121A684F20056DD20 /* Sources */,
+				7106E80221A684F20056DD20 /* Frameworks */,
+				7106E80321A684F20056DD20 /* Resources */,
+			);
+			buildRules = (
+			);
+			dependencies = (
+			);
+			name = "APEX CRM";
+			productName = "APEX CRM";
+			productReference = 7106E80521A684F20056DD20 /* APEX CRM.app */;
+			productType = "com.apple.product-type.application";
+		};
+/* End PBXNativeTarget section */
+
+/* Begin PBXProject section */
+		7106E7FD21A684F20056DD20 /* Project object */ = {
+			isa = PBXProject;
+			attributes = {
+				LastUpgradeCheck = 1010;
+				ORGANIZATIONNAME = USAI;
+				TargetAttributes = {
+					7106E80421A684F20056DD20 = {
+						CreatedOnToolsVersion = 10.1;
+					};
+				};
+			};
+			buildConfigurationList = 7106E80021A684F20056DD20 /* Build configuration list for PBXProject "APEX CRM" */;
+			compatibilityVersion = "Xcode 9.3";
+			developmentRegion = en;
+			hasScannedForEncodings = 0;
+			knownRegions = (
+				en,
+				Base,
+			);
+			mainGroup = 7106E7FC21A684F20056DD20;
+			productRefGroup = 7106E80621A684F20056DD20 /* Products */;
+			projectDirPath = "";
+			projectRoot = "";
+			targets = (
+				7106E80421A684F20056DD20 /* APEX CRM */,
+			);
+		};
+/* End PBXProject section */
+
+/* Begin PBXResourcesBuildPhase section */
+		7106E80321A684F20056DD20 /* Resources */ = {
+			isa = PBXResourcesBuildPhase;
+			buildActionMask = 2147483647;
+			files = (
+				7106E81521A684F50056DD20 /* LaunchScreen.storyboard in Resources */,
+				7106E81221A684F50056DD20 /* Assets.xcassets in Resources */,
+				7106E81021A684F20056DD20 /* Main.storyboard in Resources */,
+			);
+			runOnlyForDeploymentPostprocessing = 0;
+		};
+/* End PBXResourcesBuildPhase section */
+
+/* Begin PBXSourcesBuildPhase section */
+		7106E80121A684F20056DD20 /* Sources */ = {
+			isa = PBXSourcesBuildPhase;
+			buildActionMask = 2147483647;
+			files = (
+				7106E83D21AD1B070056DD20 /* zip.c in Sources */,
+				7106E83B21AD1B070056DD20 /* unzip.c in Sources */,
+				7106E82221A6856E0056DD20 /* WKWebTestViewController.m in Sources */,
+				7106E82A21ABF2190056DD20 /* RAConvertor.m in Sources */,
+				7106E83A21AD1B070056DD20 /* mztools.c in Sources */,
+				7106E83C21AD1B070056DD20 /* ioapi.c in Sources */,
+				7106E80D21A684F20056DD20 /* ViewController.m in Sources */,
+				7106E81821A684F50056DD20 /* main.m in Sources */,
+				7106E82F21AD1ACD0056DD20 /* RAUtils.m in Sources */,
+				7106E80A21A684F20056DD20 /* AppDelegate.m in Sources */,
+				7106E84021AD1B0D0056DD20 /* ZipArchive.mm in Sources */,
+				7106E82621A698D20056DD20 /* RAWKWebView.m in Sources */,
+			);
+			runOnlyForDeploymentPostprocessing = 0;
+		};
+/* End PBXSourcesBuildPhase section */
+
+/* Begin PBXVariantGroup section */
+		7106E80E21A684F20056DD20 /* Main.storyboard */ = {
+			isa = PBXVariantGroup;
+			children = (
+				7106E80F21A684F20056DD20 /* Base */,
+			);
+			name = Main.storyboard;
+			sourceTree = "<group>";
+		};
+		7106E81321A684F50056DD20 /* LaunchScreen.storyboard */ = {
+			isa = PBXVariantGroup;
+			children = (
+				7106E81421A684F50056DD20 /* Base */,
+			);
+			name = LaunchScreen.storyboard;
+			sourceTree = "<group>";
+		};
+/* End PBXVariantGroup section */
+
+/* Begin XCBuildConfiguration section */
+		7106E81921A684F50056DD20 /* 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 = 12.1;
+				MTL_ENABLE_DEBUG_INFO = INCLUDE_SOURCE;
+				MTL_FAST_MATH = YES;
+				ONLY_ACTIVE_ARCH = YES;
+				SDKROOT = iphoneos;
+			};
+			name = Debug;
+		};
+		7106E81A21A684F50056DD20 /* 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 = 12.1;
+				MTL_ENABLE_DEBUG_INFO = NO;
+				MTL_FAST_MATH = YES;
+				SDKROOT = iphoneos;
+				VALIDATE_PRODUCT = YES;
+			};
+			name = Release;
+		};
+		7106E81C21A684F50056DD20 /* Debug */ = {
+			isa = XCBuildConfiguration;
+			buildSettings = {
+				ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
+				CODE_SIGN_STYLE = Automatic;
+				DEVELOPMENT_TEAM = HXWLAA5YN5;
+				INFOPLIST_FILE = "APEX CRM/Info.plist";
+				LD_RUNPATH_SEARCH_PATHS = (
+					"$(inherited)",
+					"@executable_path/Frameworks",
+				);
+				PRODUCT_BUNDLE_IDENTIFIER = "usai.redant.APEX-CRM";
+				PRODUCT_NAME = "$(TARGET_NAME)";
+				TARGETED_DEVICE_FAMILY = "1,2";
+			};
+			name = Debug;
+		};
+		7106E81D21A684F50056DD20 /* Release */ = {
+			isa = XCBuildConfiguration;
+			buildSettings = {
+				ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
+				CODE_SIGN_STYLE = Automatic;
+				DEVELOPMENT_TEAM = HXWLAA5YN5;
+				INFOPLIST_FILE = "APEX CRM/Info.plist";
+				LD_RUNPATH_SEARCH_PATHS = (
+					"$(inherited)",
+					"@executable_path/Frameworks",
+				);
+				PRODUCT_BUNDLE_IDENTIFIER = "usai.redant.APEX-CRM";
+				PRODUCT_NAME = "$(TARGET_NAME)";
+				TARGETED_DEVICE_FAMILY = "1,2";
+			};
+			name = Release;
+		};
+/* End XCBuildConfiguration section */
+
+/* Begin XCConfigurationList section */
+		7106E80021A684F20056DD20 /* Build configuration list for PBXProject "APEX CRM" */ = {
+			isa = XCConfigurationList;
+			buildConfigurations = (
+				7106E81921A684F50056DD20 /* Debug */,
+				7106E81A21A684F50056DD20 /* Release */,
+			);
+			defaultConfigurationIsVisible = 0;
+			defaultConfigurationName = Release;
+		};
+		7106E81B21A684F50056DD20 /* Build configuration list for PBXNativeTarget "APEX CRM" */ = {
+			isa = XCConfigurationList;
+			buildConfigurations = (
+				7106E81C21A684F50056DD20 /* Debug */,
+				7106E81D21A684F50056DD20 /* Release */,
+			);
+			defaultConfigurationIsVisible = 0;
+			defaultConfigurationName = Release;
+		};
+/* End XCConfigurationList section */
+	};
+	rootObject = 7106E7FD21A684F20056DD20 /* Project object */;
+}

+ 7 - 0
RedAnt CRM/APEX CRM/APEX CRM.xcodeproj/project.xcworkspace/contents.xcworkspacedata

@@ -0,0 +1,7 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<Workspace
+   version = "1.0">
+   <FileRef
+      location = "self:APEX CRM.xcodeproj">
+   </FileRef>
+</Workspace>

+ 8 - 0
RedAnt CRM/APEX CRM/APEX CRM.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist

@@ -0,0 +1,8 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
+<plist version="1.0">
+<dict>
+	<key>IDEDidComputeMac32BitWarning</key>
+	<true/>
+</dict>
+</plist>

BIN
RedAnt CRM/APEX CRM/APEX CRM.xcodeproj/project.xcworkspace/xcuserdata/ray.xcuserdatad/UserInterfaceState.xcuserstate


+ 14 - 0
RedAnt CRM/APEX CRM/APEX CRM.xcodeproj/xcuserdata/ray.xcuserdatad/xcschemes/xcschememanagement.plist

@@ -0,0 +1,14 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
+<plist version="1.0">
+<dict>
+	<key>SchemeUserState</key>
+	<dict>
+		<key>APEX CRM.xcscheme_^#shared#^_</key>
+		<dict>
+			<key>orderHint</key>
+			<integer>0</integer>
+		</dict>
+	</dict>
+</dict>
+</plist>

+ 17 - 0
RedAnt CRM/APEX CRM/APEX CRM/AppDelegate.h

@@ -0,0 +1,17 @@
+//
+//  AppDelegate.h
+//  APEX CRM
+//
+//  Created by Ray on 2018/11/22.
+//  Copyright © 2018 USAI. All rights reserved.
+//
+
+#import <UIKit/UIKit.h>
+
+@interface AppDelegate : UIResponder <UIApplicationDelegate>
+
+@property (strong, nonatomic) UIWindow *window;
+
+
+@end
+

+ 51 - 0
RedAnt CRM/APEX CRM/APEX CRM/AppDelegate.m

@@ -0,0 +1,51 @@
+//
+//  AppDelegate.m
+//  APEX CRM
+//
+//  Created by Ray on 2018/11/22.
+//  Copyright © 2018 USAI. All rights reserved.
+//
+
+#import "AppDelegate.h"
+
+@interface AppDelegate ()
+
+@end
+
+@implementation AppDelegate
+
+
+- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
+    // Override point for customization after application launch.
+    return YES;
+}
+
+
+- (void)applicationWillResignActive:(UIApplication *)application {
+    // 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.
+}
+
+
+- (void)applicationDidEnterBackground:(UIApplication *)application {
+    // 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.
+}
+
+
+- (void)applicationWillEnterForeground:(UIApplication *)application {
+    // 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.
+}
+
+
+- (void)applicationDidBecomeActive:(UIApplication *)application {
+    // 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.
+}
+
+
+- (void)applicationWillTerminate:(UIApplication *)application {
+    // Called when the application is about to terminate. Save data if appropriate. See also applicationDidEnterBackground:.
+}
+
+
+@end

+ 98 - 0
RedAnt CRM/APEX CRM/APEX CRM/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"
+  }
+}

+ 6 - 0
RedAnt CRM/APEX CRM/APEX CRM/Assets.xcassets/Contents.json

@@ -0,0 +1,6 @@
+{
+  "info" : {
+    "version" : 1,
+    "author" : "xcode"
+  }
+}

+ 25 - 0
RedAnt CRM/APEX CRM/APEX CRM/Base.lproj/LaunchScreen.storyboard

@@ -0,0 +1,25 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<document type="com.apple.InterfaceBuilder3.CocoaTouch.Storyboard.XIB" version="3.0" toolsVersion="13122.16" targetRuntime="iOS.CocoaTouch" propertyAccessControl="none" useAutolayout="YES" launchScreen="YES" useTraitCollections="YES" useSafeAreas="YES" colorMatched="YES" initialViewController="01J-lp-oVM">
+    <dependencies>
+        <plugIn identifier="com.apple.InterfaceBuilder.IBCocoaTouchPlugin" version="13104.12"/>
+        <capability name="Safe area layout guides" minToolsVersion="9.0"/>
+        <capability name="documents saved in the Xcode 8 format" minToolsVersion="8.0"/>
+    </dependencies>
+    <scenes>
+        <!--View Controller-->
+        <scene sceneID="EHf-IW-A2E">
+            <objects>
+                <viewController id="01J-lp-oVM" sceneMemberID="viewController">
+                    <view key="view" contentMode="scaleToFill" id="Ze5-6b-2t3">
+                        <rect key="frame" x="0.0" y="0.0" width="375" height="667"/>
+                        <autoresizingMask key="autoresizingMask" widthSizable="YES" heightSizable="YES"/>
+                        <color key="backgroundColor" red="1" green="1" blue="1" alpha="1" colorSpace="custom" customColorSpace="sRGB"/>
+                        <viewLayoutGuide key="safeArea" id="6Tk-OE-BBY"/>
+                    </view>
+                </viewController>
+                <placeholder placeholderIdentifier="IBFirstResponder" id="iYj-Kq-Ea1" userLabel="First Responder" sceneMemberID="firstResponder"/>
+            </objects>
+            <point key="canvasLocation" x="53" y="375"/>
+        </scene>
+    </scenes>
+</document>

+ 81 - 0
RedAnt CRM/APEX CRM/APEX CRM/Base.lproj/Main.storyboard

@@ -0,0 +1,81 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<document type="com.apple.InterfaceBuilder3.CocoaTouch.Storyboard.XIB" version="3.0" toolsVersion="14460.31" targetRuntime="iOS.CocoaTouch" propertyAccessControl="none" useAutolayout="YES" useTraitCollections="YES" useSafeAreas="YES" colorMatched="YES" initialViewController="wvU-6h-Xd3">
+    <device id="retina6_5" orientation="portrait">
+        <adaptation id="fullscreen"/>
+    </device>
+    <dependencies>
+        <deployment identifier="iOS"/>
+        <plugIn identifier="com.apple.InterfaceBuilder.IBCocoaTouchPlugin" version="14460.20"/>
+        <capability name="Safe area layout guides" minToolsVersion="9.0"/>
+        <capability name="documents saved in the Xcode 8 format" minToolsVersion="8.0"/>
+    </dependencies>
+    <scenes>
+        <!--Navigation Controller-->
+        <scene sceneID="Mbo-KZ-IGY">
+            <objects>
+                <navigationController id="wvU-6h-Xd3" sceneMemberID="viewController">
+                    <navigationBar key="navigationBar" contentMode="scaleToFill" insetsLayoutMarginsFromSafeArea="NO" id="e99-t0-tv2">
+                        <rect key="frame" x="0.0" y="44" width="414" height="44"/>
+                        <autoresizingMask key="autoresizingMask"/>
+                    </navigationBar>
+                    <connections>
+                        <segue destination="BYZ-38-t0r" kind="relationship" relationship="rootViewController" id="hN4-RQ-yXC"/>
+                    </connections>
+                </navigationController>
+                <placeholder placeholderIdentifier="IBFirstResponder" id="OiB-pV-Ue7" userLabel="First Responder" sceneMemberID="firstResponder"/>
+            </objects>
+            <point key="canvasLocation" x="-777" y="27"/>
+        </scene>
+        <!--View Controller-->
+        <scene sceneID="tne-QT-ifu">
+            <objects>
+                <viewController id="BYZ-38-t0r" customClass="ViewController" sceneMemberID="viewController">
+                    <view key="view" contentMode="scaleToFill" id="8bC-Xf-vdC">
+                        <rect key="frame" x="0.0" y="0.0" width="414" height="896"/>
+                        <autoresizingMask key="autoresizingMask" widthSizable="YES" heightSizable="YES"/>
+                        <subviews>
+                            <button opaque="NO" contentMode="scaleToFill" fixedFrame="YES" contentHorizontalAlignment="center" contentVerticalAlignment="center" buttonType="roundedRect" lineBreakMode="middleTruncation" translatesAutoresizingMaskIntoConstraints="NO" id="Kfy-n6-Izt">
+                                <rect key="frame" x="74" y="254" width="122" height="30"/>
+                                <autoresizingMask key="autoresizingMask" flexibleMaxX="YES" flexibleMaxY="YES"/>
+                                <state key="normal" title="test"/>
+                                <connections>
+                                    <action selector="onClick:" destination="BYZ-38-t0r" eventType="touchUpInside" id="tFY-i5-7fW"/>
+                                </connections>
+                            </button>
+                        </subviews>
+                        <color key="backgroundColor" red="1" green="1" blue="1" alpha="1" colorSpace="custom" customColorSpace="sRGB"/>
+                        <viewLayoutGuide key="safeArea" id="6Tk-OE-BBY"/>
+                    </view>
+                    <navigationItem key="navigationItem" id="C2f-WF-qb3"/>
+                </viewController>
+                <placeholder placeholderIdentifier="IBFirstResponder" id="dkx-z0-nzr" sceneMemberID="firstResponder"/>
+            </objects>
+            <point key="canvasLocation" x="40.799999999999997" y="26.53673163418291"/>
+        </scene>
+        <!--Web Test View Controller-->
+        <scene sceneID="LRz-0P-tr7">
+            <objects>
+                <viewController storyboardIdentifier="WKWebTestViewController" useStoryboardIdentifierAsRestorationIdentifier="YES" id="OVy-gX-1F6" customClass="WKWebTestViewController" sceneMemberID="viewController">
+                    <view key="view" contentMode="scaleToFill" id="R2t-PK-wn8">
+                        <rect key="frame" x="0.0" y="0.0" width="414" height="896"/>
+                        <autoresizingMask key="autoresizingMask" widthSizable="YES" heightSizable="YES"/>
+                        <subviews>
+                            <view contentMode="scaleToFill" fixedFrame="YES" translatesAutoresizingMaskIntoConstraints="NO" id="nSN-pu-SH2" customClass="RAWKWebView">
+                                <rect key="frame" x="0.0" y="0.0" width="414" height="896"/>
+                                <autoresizingMask key="autoresizingMask"/>
+                                <color key="backgroundColor" white="1" alpha="1" colorSpace="custom" customColorSpace="genericGamma22GrayColorSpace"/>
+                            </view>
+                        </subviews>
+                        <color key="backgroundColor" white="1" alpha="1" colorSpace="custom" customColorSpace="genericGamma22GrayColorSpace"/>
+                        <viewLayoutGuide key="safeArea" id="Wtw-Bc-GH6"/>
+                    </view>
+                    <connections>
+                        <outlet property="webview" destination="nSN-pu-SH2" id="Nbp-Ie-Lhw"/>
+                    </connections>
+                </viewController>
+                <placeholder placeholderIdentifier="IBFirstResponder" id="jPz-V5-dTe" userLabel="First Responder" sceneMemberID="firstResponder"/>
+            </objects>
+            <point key="canvasLocation" x="897" y="27"/>
+        </scene>
+    </scenes>
+</document>

+ 45 - 0
RedAnt CRM/APEX CRM/APEX CRM/Info.plist

@@ -0,0 +1,45 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
+<plist version="1.0">
+<dict>
+	<key>CFBundleDevelopmentRegion</key>
+	<string>$(DEVELOPMENT_LANGUAGE)</string>
+	<key>CFBundleExecutable</key>
+	<string>$(EXECUTABLE_NAME)</string>
+	<key>CFBundleIdentifier</key>
+	<string>$(PRODUCT_BUNDLE_IDENTIFIER)</string>
+	<key>CFBundleInfoDictionaryVersion</key>
+	<string>6.0</string>
+	<key>CFBundleName</key>
+	<string>$(PRODUCT_NAME)</string>
+	<key>CFBundlePackageType</key>
+	<string>APPL</string>
+	<key>CFBundleShortVersionString</key>
+	<string>1.0</string>
+	<key>CFBundleVersion</key>
+	<string>1</string>
+	<key>LSRequiresIPhoneOS</key>
+	<true/>
+	<key>UILaunchStoryboardName</key>
+	<string>LaunchScreen</string>
+	<key>UIMainStoryboardFile</key>
+	<string>Main</string>
+	<key>UIRequiredDeviceCapabilities</key>
+	<array>
+		<string>armv7</string>
+	</array>
+	<key>UISupportedInterfaceOrientations</key>
+	<array>
+		<string>UIInterfaceOrientationPortrait</string>
+		<string>UIInterfaceOrientationLandscapeLeft</string>
+		<string>UIInterfaceOrientationLandscapeRight</string>
+	</array>
+	<key>UISupportedInterfaceOrientations~ipad</key>
+	<array>
+		<string>UIInterfaceOrientationPortrait</string>
+		<string>UIInterfaceOrientationPortraitUpsideDown</string>
+		<string>UIInterfaceOrientationLandscapeLeft</string>
+		<string>UIInterfaceOrientationLandscapeRight</string>
+	</array>
+</dict>
+</plist>

+ 22 - 0
RedAnt CRM/APEX CRM/APEX CRM/RAWKWebView.h

@@ -0,0 +1,22 @@
+//
+//  RAWKWebView.h
+//  APEX CRM
+//
+//  Created by Ray on 2018/11/22.
+//  Copyright © 2018 USAI. All rights reserved.
+//
+
+#import <UIKit/UIKit.h>
+#import <WebKit/WebKit.h>
+NS_ASSUME_NONNULL_BEGIN
+
+@interface RAWKWebView : UIView <WKUIDelegate,WKNavigationDelegate,WKScriptMessageHandler>
+
+- (void)LoadFromURL:(NSString*)url;
+
+
+@property (nonatomic , copy) void (^JumpTo)(NSString* url,NSString* module);
+
+@end
+
+NS_ASSUME_NONNULL_END

+ 262 - 0
RedAnt CRM/APEX CRM/APEX CRM/RAWKWebView.m

@@ -0,0 +1,262 @@
+//
+//  RAWKWebView.m
+//  APEX CRM
+//
+//  Created by Ray on 2018/11/22.
+//  Copyright © 2018 USAI. All rights reserved.
+//
+
+#import "RAWKWebView.h"
+#import "RAConvertor.h"
+
+@interface RAWKWebView ()
+@property (strong, nonatomic)   WKWebView                   *wkwebView;
+@end
+
+@implementation RAWKWebView
+
+/*
+// Only override drawRect: if you perform custom drawing.
+// An empty implementation adversely affects performance during animation.
+- (void)drawRect:(CGRect)rect {
+    // Drawing code
+}
+*/
+- (instancetype)initWithFrame:(CGRect)frame
+{
+    self = [super initWithFrame:frame];
+    if (self) {
+        
+        [self initWKWebView];
+        [self initMessageHandler];
+//        WKPreferences *preferences = [WKPreferences new];
+//        preferences.javaScriptCanOpenWindowsAutomatically = YES;
+//        preferences.minimumFontSize = 40.0;
+//        self.configuration.preferences = preferences;
+    }
+    return self;
+}
+- (instancetype)initWithCoder:(NSCoder *)coder
+{
+    self = [super initWithCoder:coder];
+    if (self) {
+      
+        [self initWKWebView];
+        [self initMessageHandler];
+        
+    }
+    return self;
+}
+-(void) initWKWebView
+{
+    WKWebViewConfiguration *configuration = [[WKWebViewConfiguration alloc] init];
+    
+    WKPreferences *preferences = [WKPreferences new];
+    preferences.javaScriptCanOpenWindowsAutomatically = YES;
+    preferences.minimumFontSize = 40.0;
+    configuration.preferences = preferences;
+    
+    self.wkwebView = [[WKWebView alloc] initWithFrame:self.frame configuration:configuration];
+    self.wkwebView.UIDelegate = self;
+    self.wkwebView.navigationDelegate = self;
+    [self addSubview:self.wkwebView];
+}
+-(void)LoadFromURL:(NSString *)url
+{
+    if(self.wkwebView==nil)
+        return;
+    NSURL* U=[NSURL URLWithString:url];
+    NSURLRequest* request=[NSURLRequest requestWithURL:U];
+    [self.wkwebView loadRequest:request];
+}
+
+
+
+-(void) initMessageHandler
+{
+    [self.wkwebView.configuration.userContentController addScriptMessageHandler:self name:@"CamScan"];
+    [self.wkwebView.configuration.userContentController addScriptMessageHandler:self name:@"Location"];
+    [self.wkwebView.configuration.userContentController addScriptMessageHandler:self name:@"Share"];
+    [self.wkwebView.configuration.userContentController addScriptMessageHandler:self name:@"JumpTo"];
+    [self.wkwebView.configuration.userContentController addScriptMessageHandler:self name:@"ViewImage"];
+    [self.wkwebView.configuration.userContentController addScriptMessageHandler:self name:@"PostDialog"];
+    [self.wkwebView.configuration.userContentController addScriptMessageHandler:self name:@"Photo"];
+    [self.wkwebView.configuration.userContentController addScriptMessageHandler:self name:@"Email"];
+    [self.wkwebView.configuration.userContentController addScriptMessageHandler:self name:@"Preview"];
+    
+    //    [self.configuration.userContentController addScriptMessageHandler:self name:@"Color"];
+    //    [self.configuration.userContentController addScriptMessageHandler:self name:@"Pay"];
+    //    [self.configuration.userContentController addScriptMessageHandler:self name:@"Shake"];
+    //    [self.configuration.userContentController addScriptMessageHandler:self name:@"GoBack"];
+    //    [self.configuration.userContentController addScriptMessageHandler:self name:@"PlaySound"];
+}
+-(void)destroyMessageHandler
+{
+    [self.wkwebView.configuration.userContentController removeScriptMessageHandlerForName:@"CamScan"];
+    [self.wkwebView.configuration.userContentController removeScriptMessageHandlerForName:@"Location"];
+    [self.wkwebView.configuration.userContentController removeScriptMessageHandlerForName:@"Share"];
+    [self.wkwebView.configuration.userContentController removeScriptMessageHandlerForName:@"JumpTo"];
+    [self.wkwebView.configuration.userContentController addScriptMessageHandler:self name:@"ViewImage"];
+    [self.wkwebView.configuration.userContentController addScriptMessageHandler:self name:@"PostDialog"];
+        [self.wkwebView.configuration.userContentController addScriptMessageHandler:self name:@"Photo"];
+        [self.wkwebView.configuration.userContentController addScriptMessageHandler:self name:@"Email"];
+        [self.wkwebView.configuration.userContentController addScriptMessageHandler:self name:@"Preview"];
+}
+- (void)dealloc
+{
+    [self destroyMessageHandler];
+
+}
+
+#pragma mark - WKUIDelegate
+- (void)webView:(WKWebView *)webView runJavaScriptAlertPanelWithMessage:(NSString *)message initiatedByFrame:(WKFrameInfo *)frame completionHandler:(void (^)(void))completionHandler
+{
+    
+    UIAlertController *alert = [UIAlertController alertControllerWithTitle:@"提醒" message:message preferredStyle:UIAlertControllerStyleAlert];
+    [alert addAction:[UIAlertAction actionWithTitle:@"知道了" style:UIAlertActionStyleCancel handler:^(UIAlertAction * _Nonnull action) {
+        completionHandler();
+    }]];
+    
+//    UIViewController* vc=[self getViewController];
+//    [vc presentViewController:alert animated:YES completion:nil];
+}
+-(UIViewController*) getViewController
+{
+    for (UIView* next = [self superview]; next; next = next.superview) {
+        UIResponder* nextResponder = [next nextResponder];
+        if ([nextResponder isKindOfClass:[UIViewController class]]) {
+            return (UIViewController*)nextResponder;
+        }
+    }
+    return nil;
+}
+
+
+#pragma mark - WKScriptMessageHandler
+- (void)userContentController:(WKUserContentController *)userContentController didReceiveScriptMessage:(WKScriptMessage *)message
+{
+    //    message.body  --  Allowed types are NSNumber, NSString, NSDate, NSArray,NSDictionary, and NSNull.
+    NSLog(message.name);
+    NSLog(@"body:%@",message.body);
+    
+    NSDictionary* params=[RAConvertor string2dict:message.body];
+//    RAConvertor 
+    if ([message.name isEqualToString:@"CamScan"]) {
+        
+        [self handleCamScan:params];
+    } else if ([message.name isEqualToString:@"Location"]) {
+        
+        [self handleLocation:params];
+    } else if ([message.name isEqualToString:@"Share"]) {
+        
+        [self handleShare:params];
+    } else if ([message.name isEqualToString:@"JumpTo"]) {
+        
+        
+        [self handleJumpTo:params];
+    } else if ([message.name isEqualToString:@"ViewImage"]) {
+        
+        
+        [self handleViewImage:params];
+    } else if ([message.name isEqualToString:@"PostDialog"]) {
+        
+        
+        [self handlePostDialog:params];
+    }else if ([message.name isEqualToString:@"Photo"]) {
+        
+        
+        [self handlePhoto:params];
+    }else if ([message.name isEqualToString:@"Email"]) {
+        
+        
+        
+        [self handleEmail:params];
+    }else if ([message.name isEqualToString:@"Preview"]) {
+        
+        
+        
+        [self handlePreview:params];
+    }
+    else
+    {
+        NSLog(@"%@",params);
+    }
+}
+- (void)handleCamScan:(NSDictionary *)params
+{
+}
+- (void)handleLocation:(NSDictionary *)params
+{
+}
+- (void)handleShare:(NSDictionary *)params
+{
+}
+- (void)handleViewImage:(NSDictionary *)params
+{
+}
+- (void)handlePostDialog:(NSDictionary *)params
+{
+}
+- (void)handlePhoto:(NSDictionary *)params
+{
+}
+- (void)handleEmail:(NSDictionary *)params
+{
+}
+- (void)handlePreview:(NSDictionary *)params
+{
+}
+- (void)handleJumpTo:(NSDictionary *)params
+{
+    
+    if(self.JumpTo!=nil)
+    {
+        self.JumpTo(params[@"url"], params[@"ios_module"]);
+        return;
+    }
+//    UIViewController* vc=[self getViewController];
+    
+}
+
+#pragma mark - WKNavigationDelegate
+- (void)webView:(WKWebView *)webView didFinishNavigation:(WKNavigation *)navigation
+{
+    self.wkwebView.scrollView.scrollEnabled = NO;
+    [webView evaluateJavaScript:@"document.body.scrollHeight"
+              completionHandler:^(id result, NSError *_Nullable error) {
+                  
+                  NSLog(@"web page height:%@",result);
+                  //result 就是加载完成后 webView的实际高度
+                  //获取后返回重新布局
+              }];
+    
+ 
+}
+
+
+- (void)webView:(WKWebView *)webView didFailNavigation:(WKNavigation *)navigation withError:(NSError *)error
+{
+    NSLog(@"%@",error);
+}
+
+
+//禁止链接跳转
+- (void)webView:(WKWebView *)webView decidePolicyForNavigationAction:(WKNavigationAction *)navigationAction decisionHandler:(void (^)(WKNavigationActionPolicy))decisionHandler {
+    
+    NSLog(@"navigationAction = %@, \r!!!!!!!!!!!!!!!!!!!!!!\n request = %@",navigationAction,navigationAction.request.URL);
+    
+//    if ([navigationAction.request.URL.scheme containsString:@"http"]) {
+//        decisionHandler(WKNavigationActionPolicyCancel);
+//    } else {
+    
+//    navigationAction.sourceFrame.
+        decisionHandler(WKNavigationActionPolicyAllow);
+//    }
+}
+
+
+- (void)webView:(WKWebView *)webView decidePolicyForNavigationResponse:(WKNavigationResponse *)navigationResponse decisionHandler:(void (^)(WKNavigationResponsePolicy))decisionHandler
+{
+    decisionHandler(WKNavigationResponsePolicyAllow);
+}
+@end

+ 15 - 0
RedAnt CRM/APEX CRM/APEX CRM/ViewController.h

@@ -0,0 +1,15 @@
+//
+//  ViewController.h
+//  APEX CRM
+//
+//  Created by Ray on 2018/11/22.
+//  Copyright © 2018 USAI. All rights reserved.
+//
+
+#import <UIKit/UIKit.h>
+
+@interface ViewController : UIViewController
+
+
+@end
+

+ 34 - 0
RedAnt CRM/APEX CRM/APEX CRM/ViewController.m

@@ -0,0 +1,34 @@
+//
+//  ViewController.m
+//  APEX CRM
+//
+//  Created by Ray on 2018/11/22.
+//  Copyright © 2018 USAI. All rights reserved.
+//
+
+#import "ViewController.h"
+#import "WKWebTestViewController.h"
+@interface ViewController ()
+
+@end
+
+@implementation ViewController
+
+- (void)viewDidLoad {
+    [super viewDidLoad];
+    // Do any additional setup after loading the view, typically from a nib.
+}
+- (IBAction)onClick:(id)sender {
+    
+    
+    WKWebTestViewController *vc = [self.storyboard instantiateViewControllerWithIdentifier:@"WKWebTestViewController"];
+    vc.url=@"http://10.0.0.4:8080/backend_test/index.html";
+    [self.navigationController pushViewController:vc animated:YES];
+    
+    
+//    WKWebTestViewController *wkWebVC = [[WKWebTestViewController alloc] init];
+//    [self.navigationController pushViewController:wkWebVC animated:YES];
+}
+
+
+@end

+ 17 - 0
RedAnt CRM/APEX CRM/APEX CRM/WKWebTestViewController.h

@@ -0,0 +1,17 @@
+//
+//  ViewController1.h
+//  JS_OC_MessageHandler
+//
+//  Created by Ray on 2018/11/22.
+//  Copyright © 2018 Haley. All rights reserved.
+//
+
+#import <UIKit/UIKit.h>
+
+NS_ASSUME_NONNULL_BEGIN
+
+@interface WKWebTestViewController : UIViewController
+@property (strong, nonatomic) NSString *url;
+@end
+
+NS_ASSUME_NONNULL_END

+ 79 - 0
RedAnt CRM/APEX CRM/APEX CRM/WKWebTestViewController.m

@@ -0,0 +1,79 @@
+//
+//  ViewController1.m
+//  JS_OC_MessageHandler
+//
+//  Created by Ray on 2018/11/22.
+//  Copyright © 2018 Haley. All rights reserved.
+//
+
+#import "WKWebTestViewController.h"
+#import "RAWKWebView.h"
+
+@interface WKWebTestViewController ()
+@property (weak, nonatomic) IBOutlet RAWKWebView *webview;
+
+@end
+
+@implementation WKWebTestViewController
+
+- (void)viewDidLoad {
+    [super viewDidLoad];
+    
+    [self.webview LoadFromURL:_url];
+    
+    
+    self.webview.JumpTo = ^(NSString* url, NSString* module){
+        
+//        Class class_container =NSClassFromString(module);
+        UIViewController *vc = [self.storyboard instantiateViewControllerWithIdentifier:module];
+        [vc performSelector:@selector(setUrl:) withObject:url];
+//        [vc performSelector:@selector(setTitle:) withObject:_dataSource[indexPath.row]];
+//        vc.url=@"http://10.0.0.4:8080/backend_test/index.html";
+        [self.navigationController pushViewController:vc animated:YES];
+    };
+    
+    // Do any additional setup after loading the view.
+    
+//    if(self.webview==nil)
+//    {
+//        WKWebViewConfiguration *configuration = [[WKWebViewConfiguration alloc] init];
+//
+//        WKPreferences *preferences = [WKPreferences new];
+//        preferences.javaScriptCanOpenWindowsAutomatically = YES;
+//        preferences.minimumFontSize = 40.0;
+//        configuration.preferences = preferences;
+//
+//
+//        self.webview = [[WKWebView alloc] initWithFrame:self.view.frame configuration:configuration];
+//
+//        [self.view addSubview:self.webview];
+//    }
+    
+    
+    
+    
+//    NSString *urlStr = [[NSBundle mainBundle] pathForResource:@"index.html" ofType:nil];
+//    NSURL *fileURL = [NSURL fileURLWithPath:urlStr];
+//    NSURL* U=[NSURL URLWithString:@"http://10.0.0.4:8080/backend_test/index.html"];
+//    //    [self.webView loadFileURL:fileURL allowingReadAccessToURL:fileURL];
+//    
+//    NSURLRequest* request=[NSURLRequest requestWithURL:U];
+//    [self.webview loadRequest:request];
+}
+- (void)viewWillAppear:(BOOL)animated
+{
+    
+
+}
+
+/*
+#pragma mark - Navigation
+
+// In a storyboard-based application, you will often want to do a little preparation before navigation
+- (void)prepareForSegue:(UIStoryboardSegue *)segue sender:(id)sender {
+    // Get the new view controller using [segue destinationViewController].
+    // Pass the selected object to the new view controller.
+}
+*/
+
+@end

+ 16 - 0
RedAnt CRM/APEX CRM/APEX CRM/main.m

@@ -0,0 +1,16 @@
+//
+//  main.m
+//  APEX CRM
+//
+//  Created by Ray on 2018/11/22.
+//  Copyright © 2018 USAI. All rights reserved.
+//
+
+#import <UIKit/UIKit.h>
+#import "AppDelegate.h"
+
+int main(int argc, char * argv[]) {
+    @autoreleasepool {
+        return UIApplicationMain(argc, argv, nil, NSStringFromClass([AppDelegate class]));
+    }
+}

+ 7 - 0
RedAnt CRM/RedAnt CRM.xcworkspace/contents.xcworkspacedata

@@ -0,0 +1,7 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<Workspace
+   version = "1.0">
+   <FileRef
+      location = "group:APEX CRM/APEX CRM.xcodeproj">
+   </FileRef>
+</Workspace>

+ 8 - 0
RedAnt CRM/RedAnt CRM.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist

@@ -0,0 +1,8 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
+<plist version="1.0">
+<dict>
+	<key>IDEDidComputeMac32BitWarning</key>
+	<true/>
+</dict>
+</plist>

BIN
RedAnt CRM/RedAnt CRM.xcworkspace/xcuserdata/ray.xcuserdatad/UserInterfaceState.xcuserstate


+ 205 - 0
RedAnt CRM/RedAnt CRM.xcworkspace/xcuserdata/ray.xcuserdatad/xcdebugger/Breakpoints_v2.xcbkptlist

@@ -0,0 +1,205 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<Bucket
+   type = "0"
+   version = "2.0">
+   <Breakpoints>
+      <BreakpointProxy
+         BreakpointExtensionID = "Xcode.Breakpoint.FileBreakpoint">
+         <BreakpointContent
+            shouldBeEnabled = "No"
+            ignoreCount = "0"
+            continueAfterRunningActions = "No"
+            filePath = "APEX CRM/APEX CRM/RAWKWebView.m"
+            timestampString = "564992316.2673039"
+            startingColumnNumber = "9223372036854775807"
+            endingColumnNumber = "9223372036854775807"
+            startingLineNumber = "263"
+            endingLineNumber = "263">
+         </BreakpointContent>
+      </BreakpointProxy>
+      <BreakpointProxy
+         BreakpointExtensionID = "Xcode.Breakpoint.FileBreakpoint">
+         <BreakpointContent
+            shouldBeEnabled = "No"
+            ignoreCount = "0"
+            continueAfterRunningActions = "No"
+            filePath = "APEX CRM/APEX CRM/RAWKWebView.m"
+            timestampString = "564992316.268046"
+            startingColumnNumber = "9223372036854775807"
+            endingColumnNumber = "9223372036854775807"
+            startingLineNumber = "263"
+            endingLineNumber = "263">
+         </BreakpointContent>
+      </BreakpointProxy>
+      <BreakpointProxy
+         BreakpointExtensionID = "Xcode.Breakpoint.FileBreakpoint">
+         <BreakpointContent
+            shouldBeEnabled = "No"
+            ignoreCount = "0"
+            continueAfterRunningActions = "No"
+            filePath = "APEX CRM/APEX CRM/RAWKWebView.m"
+            timestampString = "564992316.26863"
+            startingColumnNumber = "9223372036854775807"
+            endingColumnNumber = "9223372036854775807"
+            startingLineNumber = "263"
+            endingLineNumber = "263">
+         </BreakpointContent>
+      </BreakpointProxy>
+      <BreakpointProxy
+         BreakpointExtensionID = "Xcode.Breakpoint.FileBreakpoint">
+         <BreakpointContent
+            shouldBeEnabled = "No"
+            ignoreCount = "0"
+            continueAfterRunningActions = "No"
+            filePath = "APEX CRM/APEX CRM/RAWKWebView.m"
+            timestampString = "564992316.269218"
+            startingColumnNumber = "9223372036854775807"
+            endingColumnNumber = "9223372036854775807"
+            startingLineNumber = "263"
+            endingLineNumber = "263">
+         </BreakpointContent>
+      </BreakpointProxy>
+      <BreakpointProxy
+         BreakpointExtensionID = "Xcode.Breakpoint.FileBreakpoint">
+         <BreakpointContent
+            shouldBeEnabled = "No"
+            ignoreCount = "0"
+            continueAfterRunningActions = "No"
+            filePath = "APEX CRM/APEX CRM/RAWKWebView.m"
+            timestampString = "564992316.2699161"
+            startingColumnNumber = "9223372036854775807"
+            endingColumnNumber = "9223372036854775807"
+            startingLineNumber = "263"
+            endingLineNumber = "263">
+         </BreakpointContent>
+      </BreakpointProxy>
+      <BreakpointProxy
+         BreakpointExtensionID = "Xcode.Breakpoint.FileBreakpoint">
+         <BreakpointContent
+            shouldBeEnabled = "No"
+            ignoreCount = "0"
+            continueAfterRunningActions = "No"
+            filePath = "APEX CRM/APEX CRM/WKWebTestViewController.m"
+            timestampString = "564992316.270487"
+            startingColumnNumber = "9223372036854775807"
+            endingColumnNumber = "9223372036854775807"
+            startingLineNumber = "28"
+            endingLineNumber = "28"
+            landmarkName = "-viewDidLoad"
+            landmarkType = "7">
+         </BreakpointContent>
+      </BreakpointProxy>
+      <BreakpointProxy
+         BreakpointExtensionID = "Xcode.Breakpoint.FileBreakpoint">
+         <BreakpointContent
+            shouldBeEnabled = "No"
+            ignoreCount = "0"
+            continueAfterRunningActions = "No"
+            filePath = "APEX CRM/APEX CRM/WKWebTestViewController.m"
+            timestampString = "564992316.270589"
+            startingColumnNumber = "9223372036854775807"
+            endingColumnNumber = "9223372036854775807"
+            startingLineNumber = "22"
+            endingLineNumber = "22"
+            landmarkName = "-viewDidLoad"
+            landmarkType = "7">
+         </BreakpointContent>
+      </BreakpointProxy>
+      <BreakpointProxy
+         BreakpointExtensionID = "Xcode.Breakpoint.FileBreakpoint">
+         <BreakpointContent
+            shouldBeEnabled = "No"
+            ignoreCount = "0"
+            continueAfterRunningActions = "No"
+            filePath = "APEX CRM/APEX CRM/RAWKWebView.m"
+            timestampString = "564992316.270676"
+            startingColumnNumber = "9223372036854775807"
+            endingColumnNumber = "9223372036854775807"
+            startingLineNumber = "224"
+            endingLineNumber = "224"
+            landmarkName = "-webView:didFinishNavigation:"
+            landmarkType = "7">
+         </BreakpointContent>
+      </BreakpointProxy>
+      <BreakpointProxy
+         BreakpointExtensionID = "Xcode.Breakpoint.FileBreakpoint">
+         <BreakpointContent
+            shouldBeEnabled = "No"
+            ignoreCount = "0"
+            continueAfterRunningActions = "No"
+            filePath = "APEX CRM/APEX CRM/RAWKWebView.m"
+            timestampString = "564992316.27115"
+            startingColumnNumber = "9223372036854775807"
+            endingColumnNumber = "9223372036854775807"
+            startingLineNumber = "239"
+            endingLineNumber = "239"
+            landmarkName = "-webView:didFailNavigation:withError:"
+            landmarkType = "7">
+         </BreakpointContent>
+      </BreakpointProxy>
+      <BreakpointProxy
+         BreakpointExtensionID = "Xcode.Breakpoint.FileBreakpoint">
+         <BreakpointContent
+            shouldBeEnabled = "No"
+            ignoreCount = "0"
+            continueAfterRunningActions = "No"
+            filePath = "APEX CRM/APEX CRM/RAWKWebView.m"
+            timestampString = "564992316.271578"
+            startingColumnNumber = "9223372036854775807"
+            endingColumnNumber = "9223372036854775807"
+            startingLineNumber = "66"
+            endingLineNumber = "66"
+            landmarkName = "-LoadFromURL:"
+            landmarkType = "7">
+         </BreakpointContent>
+      </BreakpointProxy>
+      <BreakpointProxy
+         BreakpointExtensionID = "Xcode.Breakpoint.FileBreakpoint">
+         <BreakpointContent
+            shouldBeEnabled = "No"
+            ignoreCount = "0"
+            continueAfterRunningActions = "No"
+            filePath = "APEX CRM/APEX CRM/RAWKWebView.m"
+            timestampString = "564992316.272011"
+            startingColumnNumber = "9223372036854775807"
+            endingColumnNumber = "9223372036854775807"
+            startingLineNumber = "244"
+            endingLineNumber = "244"
+            landmarkName = "-webView:decidePolicyForNavigationAction:decisionHandler:"
+            landmarkType = "7">
+         </BreakpointContent>
+      </BreakpointProxy>
+      <BreakpointProxy
+         BreakpointExtensionID = "Xcode.Breakpoint.FileBreakpoint">
+         <BreakpointContent
+            shouldBeEnabled = "No"
+            ignoreCount = "0"
+            continueAfterRunningActions = "No"
+            filePath = "APEX CRM/APEX CRM/RAWKWebView.m"
+            timestampString = "564992316.2724251"
+            startingColumnNumber = "9223372036854775807"
+            endingColumnNumber = "9223372036854775807"
+            startingLineNumber = "246"
+            endingLineNumber = "246"
+            landmarkName = "-webView:decidePolicyForNavigationAction:decisionHandler:"
+            landmarkType = "7">
+         </BreakpointContent>
+      </BreakpointProxy>
+      <BreakpointProxy
+         BreakpointExtensionID = "Xcode.Breakpoint.FileBreakpoint">
+         <BreakpointContent
+            shouldBeEnabled = "No"
+            ignoreCount = "0"
+            continueAfterRunningActions = "No"
+            filePath = "APEX CRM/APEX CRM/RAWKWebView.m"
+            timestampString = "564992316.272844"
+            startingColumnNumber = "9223372036854775807"
+            endingColumnNumber = "9223372036854775807"
+            startingLineNumber = "260"
+            endingLineNumber = "260"
+            landmarkName = "-webView:decidePolicyForNavigationResponse:decisionHandler:"
+            landmarkType = "7">
+         </BreakpointContent>
+      </BreakpointProxy>
+   </Breakpoints>
+</Bucket>

+ 22 - 0
RedAnt CRM/RedAnt CRM.xcworkspace/xcuserdata/ray.xcuserdatad/xcdebugger/Expressions.xcexplist

@@ -0,0 +1,22 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<VariablesViewState
+   version = "1.0">
+   <ContextStates>
+      <ContextState
+         contextName = "-[RAWKWebView initWithCoder:]:RAWKWebView.m">
+         <PersistentStrings>
+            <PersistentString
+               value = "self.configuration">
+            </PersistentString>
+         </PersistentStrings>
+      </ContextState>
+      <ContextState
+         contextName = "-[WKWebTestViewController viewDidLoad]:WKWebTestViewController.m">
+         <PersistentStrings>
+            <PersistentString
+               value = "self.webview.configuration.preferences.minimumFontSize">
+            </PersistentString>
+         </PersistentStrings>
+      </ContextState>
+   </ContextStates>
+</VariablesViewState>