cancel
Showing results for 
Search instead for 
Did you mean: 
Reply
BenGin
Advocate II
Advocate II

How can I stop phone screen from turning off?

I have a Canvas App built to be used on a phone. I have a button to send the data to the Dataverse. This can take some time. However, because it takes some time, the iPhone screen turns off and the Power App gets interrupted and the data write fails.

Is there a way to set the iPhone screen to not turn off if there is a process running, so, like a piece of code I can put in the "OnSelect" of the button at the top and bottom that will set the phone to not turn off the screen until it reaches the end of the code?

2 ACCEPTED SOLUTIONS

Accepted Solutions
Pstork1
Most Valuable Professional
Most Valuable Professional

Apple doesn't provide an API to turn off the screen shutdown.  You can do it manually in the settings, but there is no way to do it programmatically. The only way Apple made it possible was in Objective C when writing a native app.



-------------------------------------------------------------------------
If I have answered your question, please mark your post as Solved.
If you like my response, please give it a Thumbs Up.

View solution in original post

Pstork1
Most Valuable Professional
Most Valuable Professional

I normally avoid using the ForAll() to do patches for this very reason.  Instead, I would send the collection to a Power Automate flow to do the patching.  I would do the same for loading data.  Flows have much better capabilities for handling large complex databases without having to worry about delegation issues.  Since you are using Dataverse the need for a Premium license to receive a data set from Power Automate shouldn't be an issue.  Properly designed this can be much faster than doing it in Power Apps and it has the advantage that the flow should keep running even if Power Apps goes offline (once the raw dataset has been transmitted)



-------------------------------------------------------------------------
If I have answered your question, please mark your post as Solved.
If you like my response, please give it a Thumbs Up.

View solution in original post

11 REPLIES 11
Pstork1
Most Valuable Professional
Most Valuable Professional

Apple doesn't provide an API to turn off the screen shutdown.  You can do it manually in the settings, but there is no way to do it programmatically. The only way Apple made it possible was in Objective C when writing a native app.



-------------------------------------------------------------------------
If I have answered your question, please mark your post as Solved.
If you like my response, please give it a Thumbs Up.

Hi, thanks for the fast response. This is going to be a real pain. The end users are not the most tech savvy, and they need to use this app in areas where there is little to no connectivity. Hence I have built this app to store data in the offline cache. This is why it takes a long time to send the data to the Database when they finally get into an area with connectivity.

Pstork1
Most Valuable Professional
Most Valuable Professional

The app should keep running even when the screen shuts down.  If they press the Power button it should open the app right where they left off.  If they are then in an area with connectivity it should pick up and download the data.  



-------------------------------------------------------------------------
If I have answered your question, please mark your post as Solved.
If you like my response, please give it a Thumbs Up.

Interesting, because it didn't work when I tested it. When I pressed the Power button and turned the phone back on, the Power Apps showed a warning message (I don't remember exactly what). Then it appeared to continue to execute the code (I have an overlay rectangle that only disappears after the OnSelect code has finished). This overlay disappeared, but the data is not in the Database. At the end of the OnSelect code, I remove it from the cached Collection, so those records have disappeared off the phone too.

 

So, to clarify, I am not downloading data from the Dataverse to the phone. I am trying to Patch data from the phone into the Dataverse.

Pstork1
Most Valuable Professional
Most Valuable Professional

I thought you were saving the data locally? and then patching back to Dataverse when you were online.

 

How long does the patch take to run?  Yes, I believe there will be a problem if the patch() is in the middle of running when the phone shuts down.  But you don't want a patch that runs that long anyway.  If the patch completes before the phone shuts down or goes offline it shouldn't be a problem.



-------------------------------------------------------------------------
If I have answered your question, please mark your post as Solved.
If you like my response, please give it a Thumbs Up.

Thanks for taking the time to respond again.

Correct, I am saving data locally into Collections and using the "SaveData" function to ensure the Collections retain data between sessions.

Then, when back online, a button will have the DisplayMode set to Edit and the user can then tap the button to Patch.

The Patch can take a minute or two depending on the amount of data.

The use case is:

  1. The user can initiate multiple "Parent" records (one for each activity they are doing) which are then stored in a Collection
  2. There are also two "Child" tables that are set up in the Dataverse with "Many-to-One" relationships back to the "Parent"
  3. One of the "Child" tables is to hold Photos taken by the user
  4. Because of the relationships, when I patch all the "Parent" records, I need to return their Records to attach to each of the "Child" records with the correct relationship back to the "Parent".

All of these contribute to the Patch taking a lengthy amount of time.

It doesn't help that a "ForAll" is not a proper "For" loop and I cannot use "Set", or "ClearCollect", so I had to be creative with the code and Collections to be able to match the "Child" record to the "Parent" and ensure integrity when Patching the "Child" tables.

Added to the complexity is dealing with records that can be loaded from the DB that can then be edited, and must also stored in the Offline Collections but with Patch code to deal with the fact they are already in the Database compared to other Records that are purely local device only.

So much for Microsoft's "Low Code" platform!

Pstork1
Most Valuable Professional
Most Valuable Professional

I normally avoid using the ForAll() to do patches for this very reason.  Instead, I would send the collection to a Power Automate flow to do the patching.  I would do the same for loading data.  Flows have much better capabilities for handling large complex databases without having to worry about delegation issues.  Since you are using Dataverse the need for a Premium license to receive a data set from Power Automate shouldn't be an issue.  Properly designed this can be much faster than doing it in Power Apps and it has the advantage that the flow should keep running even if Power Apps goes offline (once the raw dataset has been transmitted)



-------------------------------------------------------------------------
If I have answered your question, please mark your post as Solved.
If you like my response, please give it a Thumbs Up.
Pstork1
Most Valuable Professional
Most Valuable Professional

Just to add.  Low code platforms have always had issues with really complex data operations.  That's not just Microsoft.  Thats true for all of them.  But they aren't primarily designed for professional developers or those kinds of situation.  Its the old 80/20 rule.  80% of development in low code can be done quite easily, but 20% is almost easier to do using traditional development.



-------------------------------------------------------------------------
If I have answered your question, please mark your post as Solved.
If you like my response, please give it a Thumbs Up.

I hear you. It comes down to Stakeholder management that what they want may not be possible or at the very least, not easy to implement and then likely with limitations. Then there needs to be a compromise, or if those requirements are "must haves", then Power Apps is not the right tool.

Helpful resources

Announcements

Community will be READ ONLY July 16th, 5p PDT -July 22nd

Dear Community Members,   We'd like to let you know of an upcoming change to the community platform: starting July 16th, the platform will transition to a READ ONLY mode until July 22nd.   During this period, members will not be able to Kudo, Comment, or Reply to any posts.   On July 22nd, please be on the lookout for a message sent to the email address registered on your community profile. This email is crucial as it will contain your unique code and link to register for the new platform encompassing all of the communities.   What to Expect in the New Community: A more unified experience where all products, including Power Apps, Power Automate, Copilot Studio, and Power Pages, will be accessible from one community.Community Blogs that you can syndicate and link to for automatic updates. We appreciate your understanding and cooperation during this transition. Stay tuned for the exciting new features and a seamless community experience ahead!

Summer of Solutions | Week 4 Results | Winners will be posted on July 24th

We are excited to announce the Summer of Solutions Challenge!   This challenge is kicking off on Monday, June 17th and will run for (4) weeks.  The challenge is open to all Power Platform (Power Apps, Power Automate, Copilot Studio & Power Pages) community members. We invite you to participate in a quest to provide solutions in the Forums to as many questions as you can. Answers can be provided in all the communities.    Entry Period: This Challenge will consist of four weekly Entry Periods as follows (each an “Entry Period”)   - 12:00 a.m. PT on June 17, 2024 – 11:59 p.m. PT on June 23, 2024 - 12:00 a.m. PT on June 24, 2024 – 11:59 p.m. PT on June 30, 2024 - 12:00 a.m. PT on July 1, 2024 – 11:59 p.m. PT on July 7, 2024 - 12:00 a.m. PT on July 8, 2024 – 11:59 p.m. PT on July 14, 2024   Entries will be eligible for the Entry Period in which they are received and will not carryover to subsequent weekly entry periods.  You must enter into each weekly Entry Period separately.   How to Enter: We invite you to participate in a quest to provide "Accepted Solutions" to as many questions as you can. Answers can be provided in all the communities. Users must provide a solution which can be an “Accepted Solution” in the Forums in all of the communities and there are no limits to the number of “Accepted Solutions” that a member can provide for entries in this challenge, but each entry must be substantially unique and different.    Winner Selection and Prizes: At the end of each week, we will list the top ten (10) Community users which will consist of: 5 Community Members & 5 Super Users and they will advance to the final drawing. We will post each week in the News & Announcements the top 10 Solution providers.  At the end of the challenge, we will add all of the top 10 weekly names and enter them into a random drawing.  Then we will randomly select ten (10) winners (5 Community Members & 5 Super Users) from among all eligible entrants received across all weekly Entry Periods to receive the prize listed below. If a winner declines, we will draw again at random for the next winner.  A user will only be able to win once overall. If they are drawn multiple times, another user will be drawn at random.  Individuals will be contacted before the announcement with the opportunity to claim or deny the prize.  Once all of the winners have been notified, we will post in the News & Announcements of each community with the list of winners.   Each winner will receive one (1) Pass to the Power Platform Conference in Las Vegas, Sep. 18-20, 2024 ($1800 value). NOTE: Prize is for conference attendance only and any other costs such as airfare, lodging, transportation, and food are the sole responsibility of the winner. Tickets are not transferable to any other party or to next year’s event.   ** PLEASE SEE THE ATTACHED RULES for this CHALLENGE**   Week 1 Results: Congratulations to the Week 1 qualifiers, you are being entered in the random drawing that will take place at the end of the challenge. Community MembersNumber of SolutionsSuper UsersNumber of Solutions @anandm08  23 @WarrenBelz  31 @DBO_DV  10 @Amik  19 AmínAA 6 @mmbr1606  12 @rzuber  4 @happyume  7 @Giraldoj  3@ANB 6 (tie)   @SpongYe  6 (tie)     Week 2 Results: Congratulations to the Week 2 qualifiers, you are being entered in the random drawing that will take place at the end of the challenge. Community MembersSolutionsSuper UsersSolutions @anandm08  10@WarrenBelz 25 @DBO_DV  6@mmbr1606 14 @AmínAA 4 @Amik  12 @royg  3 @ANB  10 @AllanDeCastro  2 @SunilPashikanti  5 @Michaelfp  2 @FLMike  5 @eduardo_izzo  2   Meekou 2   @rzuber  2   @Velegandla  2     @PowerPlatform-P  2   @Micaiah  2     Week 3 Results: Congratulations to the Week 3 qualifiers, you are being entered in the random drawing that will take place at the end of the challenge.   Week 3:Community MembersSolutionsSuper UsersSolutionsPower Apps anandm0861WarrenBelz86DBO_DV25Amik66Michaelfp13mmbr160647Giraldoj13FLMike31AmínAA13SpongYe27     Week 4 Results: Congratulations to the Week 4 qualifiers, you are being entered in the random drawing that will take place at the end of the challenge.   Week 4:Community MembersSolutionsSuper UsersSolutionsPower Apps DBO-DV21WarranBelz26Giraldoj7mmbr160618Muzammmil_0695067Amik14samfawzi_acml6FLMike12tzuber6ANB8   SunilPashikanti8

Check Out | 2024 Release Wave 2 Plans for Microsoft Dynamics 365 and Microsoft Power Platform

On July 16, 2024, we published the 2024 release wave 2 plans for Microsoft Dynamics 365 and Microsoft Power Platform. These plans are a compilation of the new capabilities planned to be released between October 2024 to March 2025. This release introduces a wealth of new features designed to enhance customer understanding and improve overall user experience, showcasing our dedication to driving digital transformation for our customers and partners.    The upcoming wave is centered around utilizing advanced AI and Microsoft Copilot technologies to enhance user productivity and streamline operations across diverse business applications. These enhancements include intelligent automation, AI-powered insights, and immersive user experiences that are designed to break down barriers between data, insights, and individuals. Watch a summary of the release highlights.    Discover the latest features that empower organizations to operate more efficiently and adaptively. From AI-driven sales insights and customer service enhancements to predictive analytics in supply chain management and autonomous financial processes, the new capabilities enable businesses to proactively address challenges and capitalize on opportunities.    

Updates to Transitions in the Power Platform Communities

We're embarking on a journey to enhance your experience by transitioning to a new community platform. Our team has been diligently working to create a fresh community site, leveraging the very Dynamics 365 and Power Platform tools our community advocates for.  We started this journey with transitioning Copilot Studio forums and blogs in June. The move marks the beginning of a new chapter, and we're eager for you to be a part of it. The rest of the Power Platform product sites will be moving over this summer.   Stay tuned for more updates as we get closer to the launch. We can't wait to welcome you to our new community space, designed with you in mind. Let's connect, learn, and grow together.   Here's to new beginnings and endless possibilities!   If you have any questions, observations or concerns throughout this process please go to https://aka.ms/PPCommSupport.   To stay up to date on the latest details of this migration and other important Community updates subscribe to our News and Announcements forums: Copilot Studio, Power Apps, Power Automate, Power Pages

Users online (862)