cancel
Showing results for 
Search instead for 
Did you mean: 
Reply

Global Variable works on Desktop but not on Phone

This post is related to a previous post that I made on on 1-16-18.  The new post was made after extensive testing and will bring more clarity to issue than the original post:

https://powerusers.microsoft.com/t5/General-Discussion/Data-Refresh-Problem-when-Navigating-between-...

 

The App runs with no problems on my Desktop but on my Mobile Device (IPhone 7) the Global Variable does not update to the Selected Account fast enough.

 

Problem: On the Mobile Device when selecting the Set and Navigate control for an account from the AccountControl screen - it navigates and populates the data in the AccountLog screen prior to Global Variable being posted.  Therefore, it displays the data from the previous selected account.  If I naviagate back to the AccountControl screen and select another account it displays the previous selected account again which means the Global Variable is getting updated at some point after the AccountLog screen is loaded. 

 

What's involved in this Scenario - 2 Screens and Code - Uses SharePoint Lists as Datasources:

 

AccountControl screen - OnSelect:

Set(CurrentAcctID,BrowseGallery1.Selected.ID);Navigate(AccountLog, ScreenTransition.None)

 

AccountLog screen - Gallery3 - Items:

SortByColumns(Filter(AcctLog,AcctID = Text(CurrentAcctID)),"DateEntered",Ascending)

 

I have done numerous test including a Collection with the exact same results.

 

I would appreciate any insight, solution, or workarounds on this matter.

 

Thanks - Marc

22 REPLIES 22

 

Hi Sienna,

 

Quick update - I tested the Timer and still have the same problem when running the App on the IPhone.

 

I have been working with several members of the PowerApps Product Team on another issue which they just provided me with a workaround on it that I can use until it is fixed in the next release.  In my thank you response back to them I included the "Global Variable works on Desktop but not on Phone" issue for their review.  I shared a very simplified App that reflects the issue so they can fully test it.  I will provide you an update when I hear back from them.

 

Thanks for all of the help - Marc !!

 

Account Control screenAccount Control screenAccount Log screenAccount Log screen

 

 

 

Hi again

I've been trying to reproduce the same error but with no luck. I have tested all possible variants on my iPhone and they all works. But obviously I didn't try sharepoint. My last suggestions would be to reinstall the PA player on your phone try if this will work. I would also try to save the app with different name and try to republish it. And if all this fail then try to create brand new app and test it in small steps and see when it will starting to fail. Good luck and let us know

Hi again,

 

I have tried all of your suggestions and even created a new App using CDS as the DataSouce and it still displays the previous selected Account in my Global Variable.  I am hoping the PA Product Team will review this and provide a response.  I know they are working on Gallery related issues that are supposed to be corrected in the next release.

 

Has issue updating variable:

App is running 2.0.750 on my IPhone 7 on iOS 11.2.2 with 235GB available

 

Works fine using:

App is running 2.0.750 on the Desktop (Edit on the Web) - Windows 8.1 - Chrome or IE browsers

 

Its definitely a time consuming mystery...

 

Please let me know if you or anyone else has additional suggestions.

 

Thanks - Marc...

I've got only one more.. Have you tried also change a database connected in your gallery to something else then sharepoint?

@CarlosFigueira

@CWesener

@rgruian

 

Sienna,

 

I have tried all of your suggestions and even created a new App using CDS as the DataSouce and it still displays the previous selected Account in my Global Variable. 

 

I have reviewed my settings on my IPhone - definitely think this is a PowerApps issue.

 

In the meantime I am going to have to use a Temporary Workaround which utilizes two separate OnSelect controls the first Sets the variable (which will update it to the previous ID) without navigating and then the second Sets the variable again (which will update to the previous ID again but will be the Account that user needs selected) with navigation to the AccountLog screen.  See images below:

 

First ClickFirst ClickSecond ClickSecond Click

I've just encountered this exact same issue.  Running the app on a desktop, no problem.  Using it on an iPad, the Global Variable is always one step behind.  I am using the variable to take the ID of a record in a gallery to a new screen where changes can be made to that record.  When the navigation takes place the new screen shows the record from the previously selected record, not the current one.

 

I have tried blanking the variable before setting it, but the previous value is still the one used when loading the new screen.   The setting of the global variable is marching to the beat of a different drummer.

 

Any chance of an update on what is happening with this issue?

@CarlosFigueira

@CWesener

@rgruian

 

There is definitely a problem with the way global variables are handled in the PowerApp app in iOS.  The difference between how things work on a pc desktop and on an iPad is stark.

KroonOfficeSol
Resident Rockstar
Resident Rockstar

He MarcBailey,

 

I respond on the main threat because off all nonsense solutions mentioned earlier (sorry for saying so). The behaviour you're experience is quit logic in my opinion (when you really thing about it a little longer). It is simple caused by the fact that a screen does nothing when not visible (for performance reasons), which means that on visible it will first go out and update the data source t screen and the controls rely on to be able to show the right content. Meanwile it will do nothing, giving the former data to be visible. Looks to me like normal behaviour in every way.

 

The behaviour is simple to overcome. Try this:

  1.  Set a local variable in the navigation() formula and set this to equal the global variable. Like:
    Navigate(MyScreen, None, {MyLocalVariable: MyGlobalVariable})
  2. Connect the Gallery to the local variable by using a lookup() function in the Item property, like
    LookUp(DataSource, MyID = MyLocalVariable)
  3. Reset the local variable on leaving the screen (so in the OnHidden Property), Like
    UpdateContext({MyLocalVariable:Blank()})

What the 3 line does is basically clear the gallery, simple because a blank() in the condition is no match to an existing record. So if you go to the screen in design the Gallery will be empty therefor. My good practice btw is to reset all the variables and temperal collections always when leaving the screen (only off course when a go up in my hirarchie, so not when I drill down to a deeper detail level (hope this makes sense) Smiley Very Happy

 

Still you have to wait for the gallery to update the connected data source, but the gallery will be empty (so white) or not visible till this is finished and the lookup is executed.

 

Btw I made a youtube video serie which explains these concepts in great detail with an example on a re-usable screen. If you want to learn on this topic here is the link: PowerApps - Re-Use Screens 

 

 

Btw 2: Storing your datasource in a collection can make the load time off the screen faster (which will mean that the record is shown faster), this is because there is no call needed to the datasource to update (the collection is already in place and locally available). But there are some side effects which can be tricky depending on the data you're using in the gallery.

 

Hope this helps.

Here is a description of an app that demostrates the problem so it can be replicated.

 

Screen1 contains a gallery of records several records.  Each record has a unique ID field called RecordID.  There is a button in the gallery used to navigate to Screen2 and set the value of global variable SelectedItem to the ID of the record in the gallery:

 

  • Gallery Button OnSelect = Set(SelectedItem,GalleryScreen1.Selected.RecordID); Navigate(Screen2, None)

 

Screen 2 contains 2 labels:

 

  • Label1.Text = SelectedItem
  • Label2.Text = GalleryScreen1.Selected.RecordID

For ease of demo add a button to Screen 2 with OnSelect = Back()

 

Now try the app in PowerApps in a browser.  Result: Label1 shows same value as Label2 no matter which record is selected in the gallery on Screen1.

 

Try the same app in PowerApps in iOS. Result: Label1 will show the value for the previously selected record.  In iOS the Set action is being completed before GalleryScreen1.Selected is updated.  This is not the expected behaviour.

 

The issue is independent of the order of the Navigate and Set actions in the button OnSelect.

 

Anyone got any thoughts on how to work around this problem until it is fixed?  If it is fixed?

Again, this is behaviour which comes from the way the screen reacts and loads. A screen which is NOT visible won't preform any actions on the global variable change in another screen. 

 

So what happens is that

  • when you leave the screen (let call this the invisible screen) the value in label 1 is that off the global variable on that time. 
  • Then you change your global variable, but on this moment your invisible screen stays the same.
  • You go back to the invisible screen then the screen will updates the controls on it with the specific datasource.
  • Probably in the app on a ios this process takes more time then in the browser, so you see the value for the previous time for a short moment.
  • That the other box has the correct value is just luck and it could be that when you go to this screen a hunderd time it won't be the case in a number off them. Probably this box is updated first and the other second. To test try add a third label en connect it also to the gallery and see what happens. Probably this will be processed after the second box because you added this later to the screen. I'm not sure if this is the case, it could also be that the gallery.selected relations works different in initiating during the onvisible process off a screen then a global variable.

Just try to reset the global variable on the OnHidden Property off the screen like

Set(MyGlobalVariable, Blank())

Then go to the screen again from the gallery and see if this helps.

 

Then again, why use a global variable and not a local variable you pass to the invisible screen in the navigate() formula. Like

Navigate(TheInvisibleScreen, None, {MyLocalVariable:Gallery.Selected.ID})

There is you're workarond.

 

btw It won't be fixed, because it aint broken.

 

Success,

 

Paul

 

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 (833)