There are times when you set a field to visible (optional or required) in the GUI, yet it refuses to show up on the list\library.  This seems to occur if your content type inherits from a parent that has the field hidden.  If you attempt to make the child content type field visible again it doesn’t seem to cascade down into the list instance of the content type and thus your field never shows up on the list.

So you think, “ok, I’ll just use PowerShell”.  You’re on the right track, but there is more to it than meets the eye.

if you run the following code:

You are going to get the following error message:

Exception setting “Hidden”: “Cannot change Hidden attribute for this field”

ErrorMessage

What you don’t realize is that when this particular problem occurs, there is an internal field that you can see in the field xml, but is not part of the regular properties called CanToggleHidden.  As it sounds, the purpose of this field is to ensure the field can’t be enabled.

But wait!!  There’s hope.

There’s a method that can be used called SetFieldBoolValue.  It allows us to modify that value.  If you do a little research on it, the method is listed in technet.  But it’s one of those: “It’s there but you shouldn’t use it” kind of methods.  Well in this case we have to use it.  The only way to get to it is via the Reflection namespace as follows:

Once you have completed the script you will find your field is visible again.

Thanks for reading!