SOLVED

MC211640: Conditionally show or hide columns in a SharePoint list or library form

Brass Contributor

After several attempts to operate a conditional field on item form, the formula still invalid.

The use case is the following one:

  • 1 column Provider, type Choice with 2 values
  • 2 other columns msProducts and pnpProducts, type Choice
  • When the provider is equals to Microsoft, the column msProducts should appear
  • From the default SP form, click on Edit form > Edit columns > (Ellipsis on msPorducts) > Edit conditional formula
  • The tested formulas with invalid condition are:
    1. =if([$Provider]=='Microsoft', 'true', 'false') : formula suggested by the official documentation https://docs.microsoft.com/en-us/sharepoint/dev/declarative-customization/list-form-conditional-show...
    2. =if([Provider]=='Microsoft', 'true', 'false')
    3. =if(Provider=='Microsoft', 'true', 'false')
The same tests are performed by replacing '==' by '=' and by removing the simple quote around true & false
  • This formula is valid but does not work
    1. =if(@Provider=='Microsoft', 'true', 'false')

The conditional formula is not functional currently or something is wrong?

9 Replies
best response confirmed by lsittler (Brass Contributor)
Solution

@lsittler As far I have tested this function only works in the display form not in Edit or New Form. Even they don't allow to save the formula as real time evaluation of fields are not happening.

See the below screen shots: 1. New Form:

Vikram_Samal_0-1591045077007.png

2. In Display form It works:

Vikram_Samal_1-1591045158607.png

3.Finally Display Form formula:

Vikram_Samal_2-1591045249036.png

But you can use power-apps that will give you this feature.  If I could help to find the solution, please like or mark the answer as solution.

 

Thanks

Vik

 

Hi @lsittler , @Vikram_Samal has a good idea on the Power Apps form to show/hide. Here's a great article from Nate Chamberlain on how to accomplish this: https://natechamberlain.com/2019/07/18/show-hide-fields-conditionally-in-powerapps-forms-based-on-dr...

@lsittler@Vikram_Samal : The formula works, This is not work on click event you need to save the form completed in order to work this formula.

For example, Region selection, I want to show/hide Finished Goods Notification column

1) Condition: if Region = US, hide Finished Goods Notification else show

Ashish_Kohale_0-1591109433170.png

2) Click on edit item, change the region to US.

3) Then click save in save form.

4) Open the form and Display mode, see below screenshot Finished Goods gets hidden.

Ashish_Kohale_1-1591109772372.png

5) then open the form in Edit mode, here also Finished Goods Notification column is hidden.

Ashish_Kohale_2-1591109856270.png

6) I wrote the formula on Finished Goods Notification column as below:

Ashish_Kohale_3-1591110010477.png

 

@lsittler : Of course PowerApps is the ultimate solution to design form and apply formulas. 

@Ashis when I was referring that you can’t use it in new form and edit form, I am referring to click event. As hide and show solution does not suffice all the aspects of a solution rather a partial one so that’s the challenge. On the other hand power apps being the better complete solution. Finally when you use the formula while you are in edit form and new form also it do not allow you to save giving me the error where as in display form it allows. Do you experience it differently.

Thanks
Vik

@Vikram_Samal : Its working for me on Edit and Display form as per the steps mentioned by me in earlier screenshots.

 

As per the microsoft standard step mentioned in the link also given by the @lsittler ----> https://docs.microsoft.com/en-us/sharepoint/dev/declarative-customization/list-form-conditional-show...

 

Note: Check the second step, it says Open an item to view the item details in the display form.

So in order to imbibe the formula you have to follow as per given standard steps.

 

To show or hide a column in a list or library form:

  1. Go to the list or library for which you want to show or hide columns in the form.

  2. If you are in a list:

    • Open an item to view the item details in the display form.
  3. If you are in a document library:

    • Select a file.
    • In the Information Pane:
      • Locate the Properties section.
      • Click Edit all.
  4. At the top of the form, select Edit Form > Edit columns.

  5. In the Edit columns pane, check (to show) or uncheck (to hide) the box for the column or columns as needed.

 

Note: PowerApps is the best solution to implement this functionality, this way you can show/hide fields on click/change of dropdown values.

 

@Ashish_Kohale I hope this is the last conversation :) for this.

 

Are you able to hide and show columns on the basis of selection/update of values in New or Edit Form (intent to do a real time evaluation of parent column and then show and hide of child column ). If your answer is "yes" then that is not happening for me and for me that is a show stopper for me.

 

Thanks

Vik

 

 

@Vikram_Samal : Yes I understood yours query totally. All I wanted to say the formula is working but not on real time value changes(which I have explained pretty in my earlier post with screenshots), it takes effect only after saving the value. 

 

The real time evaluation needs to have page load event or ready() function like as in JavaScript/JQuery. I think the conditional formula intended to work only after value gets saved in database.

 

Once you apply formula on specific column to which you want to show/hide based on value of another column. And then create New item,select column value based on show and hide of another column and then save the item and open the same item again, the formula working on both display/edit form.

 

In order to work this in real time we need to customize the form with PowerApps, where we can get more controls to apply such condition.

 

Its really awesome such tech community where we get to know various people and discuss with them. It gives us opportunity to Share and Learn. 

 

Thank You.

Hi @Vikram_Samal, thank you for your answer.
I understand that Power Apps is the solution to create custom form but I had hope that SharePoint could have a simple feature like this because the formula is available for the edit mode too.

It is complicate to explain to the final users that, yes you have a conditional formula but no it does not work like that.

Create a Power Apps for a simple use case like this one is pretty huge (potentially with authorizations, licences and external sharing).
Anyway, it is noted. That you for your time :)

1 best response

Accepted Solutions
best response confirmed by lsittler (Brass Contributor)
Solution

@lsittler As far I have tested this function only works in the display form not in Edit or New Form. Even they don't allow to save the formula as real time evaluation of fields are not happening.

See the below screen shots: 1. New Form:

Vikram_Samal_0-1591045077007.png

2. In Display form It works:

Vikram_Samal_1-1591045158607.png

3.Finally Display Form formula:

Vikram_Samal_2-1591045249036.png

But you can use power-apps that will give you this feature.  If I could help to find the solution, please like or mark the answer as solution.

 

Thanks

Vik

 

View solution in original post