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

Setting variable to Item that was submitted via a NewForm, not EditForm.

I have an App where the first screen is a Gallery is pulling information from a SharePoint List. 

I have a New button that goes to the Newform for the SP list and an Edit button that set a variable to the Gallery's selected Item Set(selecteditem, Gallery1.selected) and goes to the edit form for this list. 

On the Next screen a form mode  Variable sets the form for that SP list to either NewForm or EditForm based on what they wanted to do from the first screen. 

 

What I want to happen with the FormMode.New is when they Submit the form, I want the selecteditem to now become the item that was just created, not gallery1.selected. Or, have a way to have Gallery1 to select the current item just added so the variable matched the current item. 

I want to avoid having the User go back to the first gallery and select the item again just to set the variable. 

 

The reason I want this is I also have galleries that use the selecteditem variable elsewhere and they are not updating the current items because they are set to what ever was last selected from gallery 1, not the New item. 

1 ACCEPTED SOLUTION

Accepted Solutions

@ChrisSullivan 

Very good.  I thought it was the case, but didn't want to offer a long response based on a bad assumption.

 

So, with that in mind, here is the details for each step:

A) You have a Gallery with a list of records from your SharePoint list. 

Assuming some Items property on the Gallery of: yourList or Filter(yourList, someCriteria)

 

B) Users can select a record to Edit.  This will take then to Screen INITIAL

Your OnSelect action of the Gallery should be:

   Set(selecteditem, ThisItem); EditForm(Form2); Navigate(INITIAL)

 

  C) Your INITIAL screen has a Form in it for the Record Selected from step B.  The screen ALSO contains a Gallery  (Apps Gallery) pulling records from another datasource based on the SourceID being the same as the current record under edit.

Your DataSource property for Form2 should be: yourList

The Item property of Form2 should be: selecteditem

The submit button for this form should be: If(Form2.Unsaved && Form2.Valid, SubmitForm(Form2))

The OnSuccess action of Form2 should be: Set(selecteditem, Self.LastSubmit); EditForm(Form2)

 

D) The user can select a record in the Apps Gallery which will take them to another Screen - AppsDataScreen with an Edit form to edit the record selected in step C

Your Apps Gallery has a Items property of : Filter('App Data', SourceID=selecteditem.ID)

The Visible property of the Gallery should be: !(Form2.Mode = FormMode.New)

The Visible property of the Add App button should be : AppsGallery.Visible

The OnSelect action of AppsGallery should be: EditForm(AppDataForm); Navigate(AppDataScreen) (note: not sure the name of your AppData Edit form, so replace as needed)

The Item property of AppDataForm should be : AppsGallery.Selected

The SourceID field in your AppDataForm should have the following Update property on the DataCard: selecteditem.ID

The submit for the AppDataForm should be : SubmitForm(AppDataForm)

The OnSuccess for the AppDataForm should be: Back()

 

E) The screen mentioned in Step C also contains an "Add New App" button to allow the user to create a new record on the AppsDataScreen.  When doing so, the EditForm for the Apps data needs to know the SourceID from the Primary record in order to relate the record to the master record.

Now the simplicity...the OnSelect action of the Add New App button is : NewForm(AppsDataForm); Navigate(AppDataScreen)

 

That should be all you need. Put it in place and get rid of all the other variables and things, you don't need them.

_____________________________________________________________________________________
Digging it? - Click on the Thumbs Up below. Solved your problem? - Click on Accept as Solution below. Others seeking the same answers will be happy you did.
NOTE: My normal response times will be Mon to Fri from 1 PM to 10 PM UTC (and lots of other times too!)
Check out my PowerApps Videos too! And, follow me on Twitter @RandyHayes

Really want to show your appreciation? Buy Me A Cup Of Coffee!

View solution in original post

16 REPLIES 16

@ChrisSullivan 

There is no difference between a "NewForm" and an EditForm.

PowerApps has two form types - ViewForm and EditForm.

ViewForm can only be in view mode.

EditForm can be in New or Edit or View modes.

 

As with any Edit form, you can capture the Record that was submitted in the OnSuccess action of the form using the following formula:

   Set(varLastRecord, Self.LastSubmit)

 

I hope this is helpful for you.

_____________________________________________________________________________________
Digging it? - Click on the Thumbs Up below. Solved your problem? - Click on Accept as Solution below. Others seeking the same answers will be happy you did.
NOTE: My normal response times will be Mon to Fri from 1 PM to 10 PM UTC (and lots of other times too!)
Check out my PowerApps Videos too! And, follow me on Twitter @RandyHayes

Really want to show your appreciation? Buy Me A Cup Of Coffee!

I suppose my question is then how would I set the New and edit form to work with what I have so far. 

The New item button:  Onselect =  Set(varMode,"New");Navigate(INITIAL);

The Edit button : Onselect = Set(selecteditem,Gallery1.Selected);Set(varMode,"Edit");Select( Parent            );Navigate(INITIAL,ScreenTransition.None)

Second screen on visible = If(
varMode = "New",
NewForm(Form2),
EditForm(Form2)
);
UpdateContext({TimerReset: true});
UpdateContext({TimerReset: false});
UpdateContext({ResetText: false});
ClearCollect(
AppsData,
AppsGallery.AllItems.Application_x002f_System_x0020_N
)



I forgot to mention the Form in question Item is set to selecteditem. This work perfect right now. Edit form grabs the data from selecteitem. New gives a blank form. 

@ChrisSullivan 

 

Change your formula to the following on the OnSelect of the New Item button:    

NewForm(Form2); Navigate(INITIAL)

 

Change the formula on the Edit Button OnSelect to the following:

Set(selecteitem, ThisItem); EditForm(Form2); Navigate(INITIAL)

 

Get rid of OnVisible formula.

Change the Reset property of your Timer to :  App.ActiveScreen.Name = "INITIAL"

 

Not sure what ResetText is used for, but that can be replaced if I had more details on it.

Not sure what you are using AppsData for, but that can be moved elsewhere and the collection gotten rid of as you don't need a collection for what you have there unless you plan to Add or Remove rows from the collection table in the app...which wouldn't really apply when related to the AppsGallery.

Bottomline - Your AppsGallery already is a table/collection, just reference it as needed and cut the performance overhead of the collection.

 

 

 

_____________________________________________________________________________________
Digging it? - Click on the Thumbs Up below. Solved your problem? - Click on Accept as Solution below. Others seeking the same answers will be happy you did.
NOTE: My normal response times will be Mon to Fri from 1 PM to 10 PM UTC (and lots of other times too!)
Check out my PowerApps Videos too! And, follow me on Twitter @RandyHayes

Really want to show your appreciation? Buy Me A Cup Of Coffee!

Thanks for the feedback Randy!

 

This still does not solve my issue though. 

 

My understanding is you cant LastSubmit from a FormMode.New

The reason I need this to happen is this

The first Gallery populates all the items in SP list (Initial),

In this gallery I have a button to edit an item;      

 

Set(selecteditem,Gallery1.Selected);Set(varMode,"Edit");Select( Parent );Navigate(INITIAL,ScreenTransition.None)

 

I also have a New button outside of the gallery to make new items in the Initial list;

 

Set(varMode,"New");Navigate(INITIAL);

 

On the second screen is the form for Initial and a Gallery (AppsGallery)

AppsGallery pulls its data from a separate SP List (Appsdata)  

 

Filter('App Data',SourceID=selecteditem.ID)

 

There is also an Add New App  button;

 

 Set(VarNewApp,true);Navigate(AppDataScreen,ScreenTransition.None)

 

Onselect of the Gallery Item brings them to the edit form for that specific item in the Appsdata list

 

Set(VarNewApp,false);Set(VarEditApp,true);Set(Appselecteditem,AppsGallery.Selected);Navigate(AppDataScreen,ScreenTransition.None)

 

 

When the User presses Add New App, they navigate to the next screen with Appsdata's Form on it set to New form. They fill it out, and submit, but when they do a a field called SourceID is updated to be selecteditems.ID. This is the common data element between the to lists, and how Apps gallery shows just apps associated with the Initial project. This work seamlessly. Now for the big but,

 

But, When you start a new project on screen1 with the New button it brings you to Screen2 to fill out the New form for Initial. Now selecteditem is not selected, so there is no data for AppsGallery to use. And if they try to add a new app, there is no selecteditem.ID so it never populates in SourceID so the item gets orphaned on the list with no owner. Another big problem is if the user has just worked on another project and then want to make a new one. When they hit new Screen2 show a new form but Appsgallery is still populated with the items from the last project.

My thoughts were to hide the AppsGallery on screen2 if formmode is New and have the Add New App button onselect:
        

 

SubmitForm(Form2);
        Set(VarNewApp,true);
        Navigate(AppDataScreen,ScreenTransition.None)

 


And then, have the OnSuccess of the Initial form to;

       

 

 Set(selecteditem, Form2.Lastsubmit)

 

This would grab the correct ID for the app to keep working, but unfortunately it is not grabbing the data, and research is showing that you can not get data from LastSubmit from a Formode.New. 

The only other option I can think of id forcing the user to go back to the first screen select the project they just created and then edit it, and have the AppsGallery visible only when the form is in Formmode.Edit. This seems like a silly way to do this, I was hoping to find a better way around this. 

Also for the Collection. This is doing what you were suggesting. It is pulling just the apps names from the Items with the same source ID as selecteditems.ID and Concat them into a data card for the Initial List Item, just so there is a place when I make reports to show all apps associated with the project. 

@ChrisSullivan 

I am not sure where you got the incorrect information that LastSubmit is not available for a form in New mode, but it is wrong.  You most certainly can get that info/record.

 

You're overcomplicating the solution a bit.  It is far simpler than I believe you are going.

To be sure I am on the right track with you...

As I understand it:

  A) You have a Gallery with a list of records from your SharePoint list. 

 

  B) Users can select a record to Edit.  This will take then to Screen INITIAL

 

  C) Your INITIAL screen has a Form in it for the Record Selected from step B.  The screen ALSO contains a Gallery  (Apps Gallery) pulling records from another datasource based on the SourceID being the same as the current record under edit.

 

  D) The user can select a record in the Apps Gallery which will take them to another Screen - AppsDataScreen with an Edit form to edit the record selected in step C

 

  E) The screen mentioned in Step C also contains an "Add New App" button to allow the user to create a new record on the AppsDataScreen.  When doing so, the EditForm for the Apps data needs to know the SourceID from the Primary record in order to relate the record to the master record.

 

This is all classic Parent/Child record creation that is not a problem to do and will not have this complexity you are experiencing.

But first, please confirm that I have the above assumptions correct and then I will provide the details of what you need to do.

 

_____________________________________________________________________________________
Digging it? - Click on the Thumbs Up below. Solved your problem? - Click on Accept as Solution below. Others seeking the same answers will be happy you did.
NOTE: My normal response times will be Mon to Fri from 1 PM to 10 PM UTC (and lots of other times too!)
Check out my PowerApps Videos too! And, follow me on Twitter @RandyHayes

Really want to show your appreciation? Buy Me A Cup Of Coffee!

Yup you got it!
That is how it works, and it does work perfectly in till you try to make an entirely New project. 

 

@ChrisSullivan 

Very good.  I thought it was the case, but didn't want to offer a long response based on a bad assumption.

 

So, with that in mind, here is the details for each step:

A) You have a Gallery with a list of records from your SharePoint list. 

Assuming some Items property on the Gallery of: yourList or Filter(yourList, someCriteria)

 

B) Users can select a record to Edit.  This will take then to Screen INITIAL

Your OnSelect action of the Gallery should be:

   Set(selecteditem, ThisItem); EditForm(Form2); Navigate(INITIAL)

 

  C) Your INITIAL screen has a Form in it for the Record Selected from step B.  The screen ALSO contains a Gallery  (Apps Gallery) pulling records from another datasource based on the SourceID being the same as the current record under edit.

Your DataSource property for Form2 should be: yourList

The Item property of Form2 should be: selecteditem

The submit button for this form should be: If(Form2.Unsaved && Form2.Valid, SubmitForm(Form2))

The OnSuccess action of Form2 should be: Set(selecteditem, Self.LastSubmit); EditForm(Form2)

 

D) The user can select a record in the Apps Gallery which will take them to another Screen - AppsDataScreen with an Edit form to edit the record selected in step C

Your Apps Gallery has a Items property of : Filter('App Data', SourceID=selecteditem.ID)

The Visible property of the Gallery should be: !(Form2.Mode = FormMode.New)

The Visible property of the Add App button should be : AppsGallery.Visible

The OnSelect action of AppsGallery should be: EditForm(AppDataForm); Navigate(AppDataScreen) (note: not sure the name of your AppData Edit form, so replace as needed)

The Item property of AppDataForm should be : AppsGallery.Selected

The SourceID field in your AppDataForm should have the following Update property on the DataCard: selecteditem.ID

The submit for the AppDataForm should be : SubmitForm(AppDataForm)

The OnSuccess for the AppDataForm should be: Back()

 

E) The screen mentioned in Step C also contains an "Add New App" button to allow the user to create a new record on the AppsDataScreen.  When doing so, the EditForm for the Apps data needs to know the SourceID from the Primary record in order to relate the record to the master record.

Now the simplicity...the OnSelect action of the Add New App button is : NewForm(AppsDataForm); Navigate(AppDataScreen)

 

That should be all you need. Put it in place and get rid of all the other variables and things, you don't need them.

_____________________________________________________________________________________
Digging it? - Click on the Thumbs Up below. Solved your problem? - Click on Accept as Solution below. Others seeking the same answers will be happy you did.
NOTE: My normal response times will be Mon to Fri from 1 PM to 10 PM UTC (and lots of other times too!)
Check out my PowerApps Videos too! And, follow me on Twitter @RandyHayes

Really want to show your appreciation? Buy Me A Cup Of Coffee!

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