Mobile platform resources
Important
The finance and operations (Dynamics 365) mobile app and platform are no longer supported. The platform components supporting the mobile app will be removed in a future update. The mobile app has also been removed from app stores. Previously installed instances of the app will continue to work. For more information, see Removed or deprecated platform features.
By using mobile apps, you can reuse business logic and modeling. Mobile apps enable rich offline and mobile interactions, and provide an easy-to-use designer experience. Developers can create simplified forms in Microsoft Visual Studio and then design mobile apps that expose this functionality. The mobile platform makes it easy to change the forms and mobile app definitions to include customizations that are made to your cloud app.
Get started
- Getting started
- Architecture
- Page design guidelines
- Action design guidelines
- Form design requirements
Check out the following series of how-to videos that show how to create a mobile app.
- Tutorial 1: Building the sales order page
- Tutorial 2: Building the sales order details page
- Tutorial 3: Building the create new sales order action
- Tutorial 4: Adding a lookup to the create new sales order action
- Tutorial 5: Adding a lookup and hiding pages using mobile business logic
Common configurations
These topics describe some common customizations that you can add to your mobile app.
- Localize mobile workspaces
- Help secure mobile workspaces
- Set up clickable fields
- Set up mandatory fields through workspace classes
- Display item counts in a field
Client-side development
Client-side APIs are used in the business logic file, which provides an extensibility layer to the mobile workspace that allows for customization. Some things that you can access and influence through the client-side APIs include:
- Metadata
- Runtime control/page instances
- Business data
- Offline-first business behaviors
- Layout and style
The process for client-side development is described in these topics:
You can download a sample business logic file (with a .js file name extension) for the Reservation management workspace. Go to Dynamics365-for-Operations-mobile-FleetManagementSamples, open the business_logic folder, and locate the FM.js file
Server-side development
Workspace attributes and classes are used to create, configure, and publish workspaces on the server. These server-side X++ APIs can be used instead of using the task recorder-based mechanism to build a workspace. Workspaces created using either mechanism can then be styled and augmented using the client-side APIs.
Server-side development is described in these topics:
You can download the sample project (with an .axpp file name extension) for the Fleet Management mobile app. Go to Dynamics365-for-Operations-mobile-FleetManagementSamples and download the FMMobileApp.axpp file.
Debugging during development
During development it can be useful to attach a debugger to get more detailed information and insight into what is happening in the background. A web debugger can be used with the client-side JavaScript logic and styling and the Visual Studio debugger can be used with the server-side X++ business logic.
Debugging the client side
Prerequisites
- Android device plus PC
- Azure-hosted development machine (so the mobile device can point to it)
Steps to debug the client side
On the web client that is exposed by the Azure-hosted development machine, ensure that there are mobile workspaces published for the finance and operations app. For information about publishing a mobile workspace, see Publish mobile workspaces.
Install the Android debug apk for the finance and operations app on an Android device:
- One time only, allow the installation of apk files - Go to Menu > Settings > Security and then check Unknown Sources to allow the phone to install apps from sources other than the Google Play Store.
- Uninstall the finance and operations app. Ensure that any previous version of the finance and operations app is uninstalled.
- Download the apk file - From the device’s browser, navigate to the latest finance and operations Android debug apk on GitHub and click Download (or use this direct link to the file).
- Install the finance and operations apk file - Confirm install of the finance and operations app via the apk file.
- Run the debug finance and operations app on the device and sign in.
Connect to the device from the debugging machine.
- On the Azure-hosted development machine or a separate PC, follow Android developer instructions to Get Started with Remote Debugging Android Devices. You can also find a wide selection of instructional videos on YouTube by searching for Chrome for Android remote debugging.
After you connect the debugger, find the active tab on your device. You may need to click View more tabs on Android. One of the tabs should look similar to
/www.index.html#/app/appList
or/www.index.html#/app/app_landing
.Expand the nodes to find the workspace JavaScript, such as File > (no domain) > ExpenseMobile.js. Click the JavaScript file to view it and add breakpoints.
Reflect the mobile device on your desktop so that you can interact with it on the desktop screen.
Go to through the desired workspace and forms.
If breakpoints are encountered, then the browser developer tools allow you to control the flow of execution and see the values and parameters being passed.
To change styling at runtime, use the elements tab to help you determine what elements JavaScript should target and how those elements should be styled.
If a needed change is identified, make those changes in JavaScript, and then push those changes into the environment.
If more changes or validation is needed, repeat the process.
Debugging the server side
Prerequisites
- Azure-hosted development machine (so the mobile device can point to it)
Steps to debug the server side
On the web client exposed by the Azure-hosted development machine, ensure that there are mobile workspaces published for the finance and operations app. For information about publishing a mobile workspace, see Publish mobile workspaces.
Open the app on your device, point to the Azure-hosted development machine, and sign in.
Open Visual Studio on the Azure-hosted development machine and attach the debugger to the w3wp process.
After you connect the debugger, find the desired business logic, and insert breakpoints as needed.
Either use the app on your device as usual, or reflect the mobile device on your desktop so you can interact with it on the desktop screen.
Navigate through the desired workspace and forms.
If breakpoints are encountered, then Visual Studio allows you to control the flow of execution and see the values and parameters being passed.
If a needed change is identified, make those changes in X++, and push those changes into the environment.
If more changes or validation is needed, repeat the process.
Troubleshooting the app
[Resolved] - No support for iOS14 due to issues with date and time controls
Version 2.2.8 of the finance and operations mobile app fixes the known issues with the date and time pickers in iOS14. Ensure that you have the latest version of the app if you're experiencing issues running the application on iOS14.
The Mobile Client app isn't working on particular devices
Sometimes the cache associated with the app becomes corrupt or obsolete and needs to be cleared. Unfortunately, the only way to clear the data associated with the app is to uninstall the app. To completely uninstall the app, don't use the "long-press wiggle and x on the app icon" method. Instead, completely uninstall the app by navigating to Settings > General > iPhone Storage > Finance and operations (Dynamics 365), and then click Delete App. After 10-15 seconds, the app can be reinstalled.
On Android devices with non-English regions, the comma can't be used as the decimal separator in an amount field
On Android devices with non-English regions, using a comma as the decimal separator is standard practice. Problems using a comma in an amount field is an Android-specific problem because iPhone works as expected. On Android, use of the comma in an amount field is a problem with the default "gboard" keyboard and some other keyboards. Installing the SwiftKey keyboard (published by Microsoft) allows the entry of commas just like on iPhone: SwiftKey Keyboard.
Change needed for ADFS to support Mobile Client in on-premises environments
If Active Directory Federation Services (ADFS) is in use on the domain and the environment is on-premises, then ADFS must be configured to provide a regular forms-based authentication screen instead of using Windows Integrated Authentication (WIA). The finance and operations apps for iOS and Android require the regular forms-based authentication screen. ADFS should be configured to only provide WIA for browser clients (use cases). For more information, see Configure intranet forms based authentication for devices that don't support WIA.
Using multifactor authentication with the finance and operations app
The finance and operations (Mobile Client) app facilitates user authentication with Microsoft Entra ID by presenting the Microsoft Entra sign-in web page within an embedded browser. After a successful sign-in, it will retrieve the user token from the cookies and use that when communicating with the user interaction service that it shares with the web client. Some multifactor authentication mechanisms that involve switching to a different app on the same device can cause the embedded browser to close, causing the sign-in to fail. The workarounds for this scenario include:
- Different device - Use a different device for the multifactor authentication response so the app remains active on the original device.
- Multifactor authentication via phone call - Use a phone call for the multifactor authentication response so an app switch isn't needed.
- Use the "touch and hold" gesture on the authentication notification and then select the Accept option. Because the notification acceptance doesn't require an app switch, the sign-in proceeds as usual.
If there are continued problems with MFA authentication, it's helpful to submit the Microsoft Authenticator app logs and provide support with the resulting Incident ID.
Intune support and conditional access
The finance and operations (Mobile Client) app doesn't have Microsoft Intune policies implemented, so it doesn't support Intune. Manually adding the app (following Add iOS store apps to Microsoft Intune) is also not supported because the device identifier can't be passed.
Trouble signing out of the app and signing in with new credentials
If you experience trouble signing out of the app and signing in with new credentials, then you might need to "forget old credentials" on the Microsoft Entra sign-in screen.
- To sign out of the app, follow these steps:
- Open the app.
- Sign out of the app.
- Force close the app.
- To forget old credentials, follow these steps:
- Open the app.
- Connect to the server.
- On the Microsoft Entra sign-in screen, if there are saved credentials, select the ellipsis (...) button on that card, and then select Forget the credential.
- Force close the app.
- To sign in to the app, follow these steps:
- Open the app.
- Connect to the server
- Sign in using the Microsoft Entra sign-in screen.
Troubleshooting app content
I can't figure out how to build or change something in my Mobile Client content
There are many resources that you can use to figure out how to build or change content for the Mobile Client.
- Review the documentation provided in the Help system.
- Review the Fleet Management Samples for examples.
- Publish and review the Expense Management workspace, and other standard workspaces, for examples. Demo data for the USSI company is useful when using the Expense Management workspace. The forms and X++ code that make up the Expense Management workspace can be found in the Application Explorer by searching for the "ExpenseMobile" prefix.
- Use the Dynamics Community forums by searching for answers and asking questions when needed.
Tips for workspace creation and modification
Here are some tips for workspace creation and modification:
- Create new simplified forms for recording rather than recording large complex forms.
- After recording a form, you have to close the form instead of clicking Done, otherwise the form remains open.
- Verify that recordings are correct using the "Job steps".
- Play back recordings using task recorder playback to verify them.
- Don't navigate to a page before starting the recording, because the context from the previous page might need to be captured.
- If you rerecord a page with a grid, then you need to rerecord the link to the Details page because otherwise it isn't there.
- When recording an action, change the value of the fields to add them. When recording is complete, close the form instead of clicking Save.
- Lookups in mobile are list pages that have been recorded. Select field data and Select field to display are used to select the field to use as the value to save (data) and the field to show the user (display).
- When adding a lookup field, select a value in a lookup instead of just adding the lookup field. This action ensures that the correct value is selected.
- If you rerecord a lookup, all the references also need to be rerecorded because the GUID for the lookup changes.
- If you want to add a field to a page, you must add all the fields again, because the list is cleared at the beginning of each edit. This functionality is a limitation of task recorder. Reordering isn't possible.
- In the workspace XML, GUIDs are used as references to forms and controls instead of names. GUIDs ensure uniqueness, but come at the cost of maintainability. Those GUIDs are regenerated on each modification, so partial edits are difficult. The use of GUIDs is costly to change, so it's unlikely that changes would be made in the future to use simpler string name references.
- Relationships between form datasources need to be via RecordId instead of string. For example, primary keys of the datasources shouldn't be strings.
- Customers and partners can fork a workspace by creating a copy of it and then make changes as needed.
- There's no checkbox in mobile. You have to manually bind the field to a Yes/No enum in JavaScript.
Common problems with form recordings
Avoid using forms with these patterns and controls when creating workspace recordings:
- Datasources with DelayedJoin (common on transaction forms).
- FastTabs (common on existing forms).
- Recorded forms shouldn't have FastTabs because the FastTabs expansion state can interfere with playback.
- Any user interface (UI) that has state, like an expandable or hide/show region.
- There's no checkbox in mobile. You have to manually bind the field to a Yes/No enum in JavaScript.