Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How do I unlock a content control using the OpenXML SDK in a Word 2010 document?

I am manipulating a Word 2010 document on the server-side and some of the content controls in the document have the following Locking properties checked

  • Content control cannot be deleted
  • Contents cannot be edited

Can anyone advise set these Locking options to false or remove then altogether using the OpenXML SDK?

like image 880
Ryan Spears Avatar asked May 23 '12 21:05

Ryan Spears


People also ask

How do you unlock Microsoft Word 2010?

Quick guide: unlocking a Word document You'll need the password to unprotect your documents as well: In Word versions 2019 to 2010 and Microsoft 365, enter the password to unlock Word under "File" > "Protect Document" > "Restrict Editing" and then click "Stop Protection".

How do I remove content control from an entire document in Word?

Press Ctrl+A to select the entire document. Right-click a visible content control. In the context menu, click Remove Content Control.

How do I unlock a reference in Word?

Select the field you want to unlock. Press Ctrl+Shift+F11.


2 Answers

The openxml SDK provides the Lock class and the LockingValues enumeration for programmatically setting the options:

  • Content control cannot be deleted and
  • Contents cannot be edited

So, to set those two options to "false" (LockingValues.Unlocked), search for all SdtElement elements in the document and set the Val property to LockingValues.Unlocked.

The code below shows an example:

static void UnlockAllSdtContentElements()
{
  using (WordprocessingDocument wordDoc =
    WordprocessingDocument.Open(@"c:\temp\myword.docx", true))
  {        
    IEnumerable<SdtElement> elements = 
      wordDoc.MainDocumentPart.Document.Descendants<SdtElement>();

    foreach (SdtElement elem in elements)
    {
      if (elem.SdtProperties != null)
      {
        Lock l = elem.SdtProperties.ChildElements.First<Lock>();

        if (l == null)
        {              
          continue;
        }

        if (l.Val == LockingValues.SdtContentLocked)
        {
          Console.Out.WriteLine("Unlock content element...");
          l.Val = LockingValues.Unlocked;
        }
      }
    }
  }
}

static void Main(string[] args)
{
  UnlockAllSdtContentElements();
}
like image 53
Hans Avatar answered Oct 23 '22 03:10

Hans


Just for the ones who copy this code, keep in mind that if there is no Locks associated to the content control, then there won't be a Lock property associated to it, so when the code executes the following instruction, it will return a exception since there is no element found:

Lock l = elem.SdtProperties.ChildElements.First<Lock>();

The way to fix this is do the FirstOrDefault instead of First.

like image 44
Hugo Barona Avatar answered Oct 23 '22 05:10

Hugo Barona