Setting up the Mashup SDK for iOS app development in Pega 7.2.1
The Mashup SDK extends the functionality of a custom third-party app. It consists of a library that, when included in a custom third-party app, provides access to at least one screen in which a Pega 7 Platform app (or its part) is embedded in a web view. You can set up the Mashup SDK in the Xcode development environment so that its API can be used to develop native iOS apps.
- Prerequisites
- Adding the Mashup SDK to Xcode (Objective-C project)
- Adding the Mashup SDK to Xcode (Swift project)
- Verifying the Mashup SDK configuration
Prerequisites
The native iOS app that uses the Mashup SDK must be developed by using the following resources:
- Objective-C programming language
- Xcode 7.2 or later to create apps on iOS 8.x and 9.x.
Make sure that you have completed the following tasks:
- Read the Mashup SDK overview article
- Downloaded and installed CocoaPods 0.38.2 from the CocoaPods website
- Have experience developing iOS apps
- Downloaded the MashupDemo application that is distributed in the same package as the Mashup SDK
Adding the Mashup SDK to Xcode (Objective-C project)
To add the Mashup SDK to Xcode for an Objective-C project:
- Create an Objective-C project or open an existing project in Xcode.
- From the terminal, go to the main project directory and enter
pod init.
- Open the Podfile that is created.
- In the main target, add the following code:
pod 'CocoaLumberjack', '2.2.0' pod 'ZXingObjC', '3.1.0' pod 'PMBase', :path => 'path to module base' # example '../ProductModules/PMBase' pod 'PMBarcodeScanner', :path => 'path to barcode scanner module' # example '../ProductModules/PMBarcodeScanner' pod 'PMPRPCAuthentication', :path => 'path to PRPCAuthentication module' # path example '../ProductModules/PMPRPCAuthentication' pod 'PMPRPCSnapStart', :path => 'path to PRPCSnapStart module' # path example '../MashupModules/PMPRPCSnapStart'
- Save the changes.
- From the command line, install pods by entering
pod install
. - Open a new
*.xcworkspace
. - Close the project in the other windows.
- Edit the AppDelegate.h file:
- Add the import statement:
#import <PMBase/PMApplicationDelegate.h>
- Set PMApplicationDelegate as a super class, changing the @interface line to:
@interface AppDelegate : PMApplicationDelegate <UIApplicationDelegate>
- To extend the methods from
AppDelegate
, invoke its counterpart method from the parent class, for example:- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { if (![super application:application didFinishLaunchingWithOptions:launchOptions]) { return NO; } // add more code here return YES; }
- Add the import statement:
Adding the Mashup SDK to Xcode (Swift project)
To add the Mashup SDK to Xcode for a Swift project:
- Create a Swift project or open an existing project in Xcode.
- From the terminal, enter the main project directory and enter
pod init.
- Open the Podfile that is created.
- In the main target, add the following code:
use_frameworks! pod 'CocoaLumberjack', '2.2.0' pod 'PMBase', :path => '../ProductModules/PMBase' pod 'PMBarcodeScanner', :path => '../ProductModules/PMBarcodeScanner' pod 'PMPRPCAuthentication', :path => '../ProductModules/PMPRPCAuthentication' pod 'PMPRPCSnapStart', :path => '../MashupModules/PMPRPCSnapStart'
Theuse_frameworks!
option is required; without it, Cocoapods cannot generate an Xcode workspace with a Swift project. - Save the changes.
- From the command line, install pods by entering
pod install.
- Open a new
*.xcworkspace
. - Close the project in the other windows.
Verifying the Mashup SDK configuration
To verify that the Mashup SDK is correctly configured in your Objective-C Xcode project, examine the Mashup SDK Demo app that is included in the distribution package that you received. To test the custom modules feature, you can add the four example pod modules that are in the Examples folder of the distribution package into your application.