Hello!

This is a Condo Miniapps playground for iOS, it is still under development, but already allows you to feel the real process of interaction with the application.

You can find the Cordova app itself in the MainCordovaApplication folder, where in the www folder there is an example of interaction with the native api and you can develop something of your own.


Warning

Known Issues:

  1. Some inputs may not work until you call the corresponding setInputsEnabled(true) method. Don't forget to disable this when the user leaves the screen where the required inputs are located.

Content.

  1. Getting started

  2. Important differences.

  3. Working with user input.

    3.1 File Sharing

    3.2 File Imporing

  4. Navigation system.

  5. Environment.

  6. Testing.

    6.1 Testing in Demo environment

    6.2 Testing in Production environment

  7. Publishing.

  8. Plugin addition.

  9. Common methods.

  10. Supported plugins.


1. Getting started.

  1. Installing the necessary dependencies:

    • Make sure you have the latest version of the Mac OS, Xcode, and Xcode CLT installed

    • Make sure that the desired Xcode CLTs are selected, this can be done in the Xcode settings:

      Xcode -> Preferences -> Locations -> Command Line Tools

    • Homebrew installation

      /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"
      

      then run the three commands suggested in the terminal to add homebrew to the environment variables

      echo '# Set PATH, MANPATH, etc., for Homebrew.' >> ~/.zprofile
      echo 'eval "$(/opt/homebrew/bin/brew shellenv)"' >> ~/.zprofile
      eval "$(/opt/homebrew/bin/brew shellenv)"
      
    • Cocoapods installation

      brew install cocoapods
      

      Note that the installation is not done in the recommended way, but through a third-party package manager. If you install it using any other method, you may encounter errors when working with modern hardware.

    • Installing NVM or Node.JS with npm (or yarn) package manager

      https://github.com/nvm-sh/nvm#installing-and-updating

    • Install Cordova and required packages

      cd MainCordovaApplication
      npm install
      

      You can also use the command yarn install if you use Yarn as your package manager.

  2. Editing the application

    • Open the project directory and navigate to the ./MainCordovaApplication/www subdirectory, where you will find the application code. Feel free to make any necessary edits.

    • After editing the code in the MainCordovaApplication directory, run the command

      npm run cordova prepare ios
      

      You can also use the command yarn cordova prepare ios if you use Yarn as your package manager. Alternatively, you can use the cordova prepare ios command if you have Cordova installed globally, following the official instructions.

  3. Launching and testing the application

    • In the main project directory, execute the following command:

      pod install
      

      This command needs to be executed only once, before the first run.

    • In the main project directory, locate and open the file named 'CordovaDemoApp.xcworkspace'. Please take note of the file extension.

    • After you have opened the project in Xcode, proceed to run it.

      cmd + R
      
  4. Optimizing

    So that you don't have to run the Cordova prepare ios command in the terminal after each code change, you can set it to work automatically when you start the project in Xcode. To do this, do the following steps:

    • open the project in Xcode

    • in the project navigator tab (cmd + 1) select the topmost node named CordovaDemoApp, it will have a blue square icon with the App Store icon

    • select CordovaDemoApp in the TARGETS subsection

    • open the Build Phases tab

    • expand the 4th element in the list that opens called "Run Script"

    • add there a line by the example from the comment

      path/to/installed/cordova prepare ios
      

      after that, each time you start the project, the corresponding command will be executed automatically.


2. Important differences.

Unlike the standard Cordova, our application uses an additional configuration file, which must be located in the www directory and named native_config.json

This file is a json file and may contain the following fields:

  1. presentationStyle - application display type, required, should be set to native
  2. mobile_permissions - An array of strings describing the necessary permissions for the application to work. the array can contain the following values: record_audio, camera, audio_settings

3. Working with user input.

We try to mimic our mini-apps to the native app as much as possible. Unfortunately on iOS this can have a negative impact on some controls that require focus. If you notice issues with the components you are using, on the screen where they are being used and only while they are being displayed/used you need to enable additional webkit events by calling the method:

function setInputsEnabled(enabled, success, error)

example:

cordova.plugins.condo.setInputsEnabled(true, function(response) {}, function(error) {});

Important! Don't forget to disable this back when the user leaves the screen where the inputs that required it are located.

example:

cordova.plugins.condo.setInputsEnabled(false, function(response) {}, function(error) {});

3.1 Sharing Files.

Original Documentation: WEB File API

Example for sharing local document:

    <script>
       function shareSomeDocument() {
           fetch('some/path/to/local/document.pdf')
              .then(function(response) {
                   return response.blob()
               })
               .then(function(blob) {
                  var file = new File([blob], "document.pdf", {type: blob.type});
                  var filesArray = [file];
                     navigator.share({
                     files: filesArray
                  });
               });
           }
    </script>

Caution

On iOS calls to navigator.share with files argument must be called in responce to user interaction (button tap, or alike). Otherwise it throws an error

3.2 Importing Files.

Original Documentation: Using files from web applications

Importing images:

Button opens camera:

<input type="file" accept="image/*" capture>

Button opens image picker (select one image):

<input type="file" accept="image/*">

Button opens image picker (select multiple images):

<input type="file" accept="image/*" multiple>

Importing video:

Exactly same as image, but accept="video/*"


4. Navigation system.

We provide native navigation for your minapps with js code side control. Each miniapp launches with a system navigation bar and a close button on it. In general, you can implement everything else on your side, make an additional panel or controls for nested navigation and work with them.

But we strongly recommend to do otherwise. You can control what the system navigation bar shows on your side. This is achieved by using the following methods on history object inside condo plugin:

  • Add a new item to the navigation stack:

    function pushState(state, title)

    example:

    cordova.plugins.condo.history.pushState({"StateKey": "StateValue"}, "Title for navigation bar");
    
  • Replace the current item in the navigation stack:

    function replaceState(state, title)

    example:

    cordova.plugins.condo.history.replaceState({"StateKey": "StateValue"}, "Title for navigation bar");
    
  • Take a step back:

    function back()

    example:

    cordova.plugins.condo.history.back();
    
  • Take a few steps back:

    function go(amount)

    example:

    cordova.plugins.condo.history.go(-1);
    

    Note that unlike the system history object, the parameter passed here is always negative and can only lead backwards. We have no possibility to go forward to the place we came back from.

Note: you can make the titles on your side big and beautiful and always pass the title blank to the methods above.

In addition, you need to recognize when a user has pressed the system back button. This is achieved by subscribing to the already existing Cordova backbutton event https://cordova.apache.org/docs/en/12.x/cordova/events/events.html#backbutton This event is called for the system button on iOS as well.

document.addEventListener("backbutton", onBackKeyDown, false);

function onBackKeyDown() {
    // Handle the back button
}

And of course after all these changes you can get the State that is now showing on the navigation bar. This is done similarly to the standard system method - by subscribing to the condoPopstate event:

addEventListener("condoPopstate", (event) => {console.log("condoPopstate => ", JSON.stringify(event.state));});

5. Environment.

The plugin provides a hostApplication object that can synchronously output information about the current environment in which the mini-app is running.

  • Find out whether the application is looking at the production server or not:

    function isDemoEnvironment()

    example:

    console.log(cordova.plugins.condo.hostApplication.isDemoEnvironment());
    
  • The base address of the current server:

    function baseURL()

    example:

    console.log(cordova.plugins.condo.hostApplication.baseURL());
    
  • Main application installation ID:

    function installationID()

    example:

    console.log(cordova.plugins.condo.hostApplication.installationID());
    
  • Device ID:

    function deviceID()

    example:

    console.log(cordova.plugins.condo.hostApplication.deviceID());
    
  • Application locale:

    function locale()

    example:

    console.log(cordova.plugins.condo.hostApplication.locale());
    

6. Testing(as of November 1, 2022).

Demo environment

  1. Open safari on the device running the simulator with your application inside the CordovaDemoApp

  2. Open safari settings

    Settings

  3. Open the Advanced tab and activate the "Show Develop menu in menu bar" setting ShowDeveloperMenu

  4. Open the Develop menu in Safari, find your simulator and select your mini-application there. OpenDeveloperMenu

  5. The standard Safari debugging tools connected to your mini-application will open DebuggingToolsShowed

Production environment

  1. Open the project directory and navigate to the subdirectory ./MainCordovaApplication/platforms/ios/

    In it you will find the www directory.

    Create a zip archive from the www directory by right-clicking on the folder and selecting Compress "www".

  2. Place the resulting archive in the iCloud storage of the account connected to the device on which you will be testing the application.

  3. Install the Doma app from the AppStore and log in to it

    https://apps.apple.com/us/app/doma/id1573897686

  4. The app you downloaded has built-in functionality for debugging mini-applications. To turn it on and off, you use links to open it on your device:

    • Switching on:

      ai.doma.client.service://miniapps/local/enable
      
    • Switching off:

      ai.doma.client.service://miniapps/local/disable
      
  5. Now, on the main application screen in the list of mini-applications, the last button allows you to download or replace a previously downloaded mini-application from files. When you click on it, you need to select the previously downloaded archive in iCloud.

  6. The application loaded in this way has a built-in js console, which is accessible by clicking on the button at the bottom right of the open mini-application and is able to show a lot of additional information, including various errors.


7. Publishing

To publish the mini-application, send the archive you received during the testing phase to the people at Doma with whom you interact.


8. Plugin addition.

using the Device plugin as an example

  1. Adding a plugin to the Cordova project
cd MainCordovaApplication
npm run cordova plugin add cordova-plugin-device
# or `yarn cordova plugin add cordova-plugin-device` if you are using Yarn as your package manager
  1. Adding native code to the main project
  • open the plugins directory PluginsDirectory

  • drag and drop the directory of the new plugin into the plugins directory of the main project DragAndDropPluginsDirectory

  • expand the resulting directory and select everything except the src/ios directory SelectExceptPluginsDirectory

  • press delete and select Remove References ClearPluginsDirectory

  1. Adding a dependency
  • open ./MainCordovaApplication/platforms/ios/HelloCordova/config.xml file

  • select and copy everything new that was added when installing the plugin CopyDeps

  • Paste this into the appropriate places in the Cordova/config file of the main project PasteDeps

  1. just need to write some code and check how it works AddCode RunAndCheck

10. Common methods.

Authorization

function requestServerAuthorizationByUrl(miniapp_server_init_auth_url, custom_params_reserver_for_future_use, success, error)

Example:

cordova.plugins.condo.requestServerAuthorizationByUrl('https://miniapp.d.doma.ai/oidc/auth', {}, function(response) {
    console.log('recive authorication result => ', JSON.stringify(response));
    window.location.reload();
}, function(error) {
    console.log(error);
});

Obtaining a current resident/address

function getCurrentResident(success, error)

Example:

cordova.plugins.condo.getCurrentResident(function(response) {
    console.log("current resident\address => ", JSON.stringify(response));
}, function(error) {
    console.log(error);
});

Closing application

function closeApplication(success, error)

Example:

cordova.plugins.condo.closeApplication(function(response) {}, function(error) {});

application launch context (from notification)

function getLaunchContext(success, error)

Example:

cordova.plugins.condo.getLaunchContext(function(b2cAppContextString) {}, function(error) {});

activation of additional events required for some inputs

function setInputsEnabled(enabled, success, error)`

Example:

cordova.plugins.condo.setInputsEnabled(true, function(response) {}, function(error) {});

Important

Don't forget to disable inputs when the user leaves the screen where the inputs that required it are located.

  cordova.plugins.condo.setInputsEnabled(false, function(response) {}, function(error) {});

11. Supported plugins

cordova-plugin-condo:

link

cordova-plugin-ble-central:

link

⚠️ This plugin has additional feature-flag/permission enabling background functionality: bluetooth_central_background

Enable it by adding flag to www/native_config.json into mobile_permissions field

Example:

{
    "presentationStyle": "native",
    "mobile_permissions": ["bluetooth_central_background"],
    "hostApplication": {
        "iOS": {
          "minimumSupportedVersion": "1.1.22"
        }
    }
}

Possible flow of miniapp work with background functionality:

  1. App launched
  2. miniapp launched -> miniapp starts scanning
  3. miniapp closed (while actively scanning) => app proceeds scanning for miniapp
  4. application goes to background
  5. application is suspended by iOS (while app still actively scanning) => iOS proceeds scanning for app
  6. BT device detected
  7. iOS raises application in background
  8. Application raises miniapp in background
  9. miniapp recieves events
  10. things happen :D

Additional flows are: 2 -> 6 -> 9 and 4 -> 6 -> 8

cordova-plugin-ble-peripheral:

link

⚠️ This plugin has additional feature-flag/permission enabling background functionality: bluetooth_peripheral_background

Enable it by adding flag to www/native_config.json into mobile_permissions field

Example:

{
    "presentationStyle": "native",
    "mobile_permissions": ["bluetooth_peripheral_background"],
    "hostApplication": {
        "iOS": {
          "minimumSupportedVersion": "1.1.22"
        }
    }
}

cordova-plugin-device:

link

⚠️ This plugin has additional feature-flag/permission enabling background functionality: bluetooth_beacon_background.

Enable it by adding flag to www/native_config.json into mobile_permissions field

Example:

{
    "presentationStyle": "native",
    "mobile_permissions": ["bluetooth_beacon_background"],
    "hostApplication": {
        "iOS": {
          "minimumSupportedVersion": "1.1.22"
        }
    }
}

cordova-plugin-file:

link

cordova-plugin-media-capture:

link

cordova-plugin-network-information:

link

com.unarin.cordova.beacon:

link