/
Working with Frame Settings

Information Classification: External Restricted.
See https://www.chili-publish.com/security

Working with Frame Settings

Once you have access to a frame, you can manipulate most of its settings through the properties you can find in the DOM documentation.

You can apply this based on your choice of logic:

  • Registering to SelectedFrameChanged, and working on "document.selectedFrame"
  • Looping through all frames based on a type (Editor Enumerations - FrameType)
  • Finding frames in the document based on a tag
  • ...

Frame Properties

All frames inherit the properties from the base frame object: Document Object Model - Frame

Individual frame types have their own classes (eg: Document Object Model - TextFrame)

Frame Constraints

Frame constraints can be configured on a variety of levels (document, page, layer, frame), and all are accessible through JavaScript.You can find the available constraint settings in ?Document Object Model - FrameConstraints

The following sample loops through all image frames in the document, and locks them for the end user:

function defaultLock()
{
    var totalFrames = 0; ;
    var numPages = editor.GetObject("document.pages").length;
    for (var i = 0; i < numPages; i++)
    {
        var numFrames = editor.GetObject("document.pages[" + i + "].frames").length;
        totalFrames = totalFrames + numFrames;
        for (var j = 0; j < numFrames; j++)
        {
            var type = editor.GetObject("document.pages[" + i + "].frames[" + j + "].type");
            if (type == "image")
            {
                editor.SetProperty("document.pages[" + i + "].frames[" + j + "].frameConstraints", "lockContent", "no");
                editor.SetProperty("document.pages[" + i + "].frames[" + j + "].frameConstraints", "lockDelete", "yes_users");
                editor.SetProperty("document.pages[" + i + "].frames[" + j + "].frameConstraints", "lockFrameSettings", "yes_users");
                editor.SetProperty("document.pages[" + i + "].frames[" + j + "].frameConstraints", "lockMoveHorizontal", "yes_users");
                editor.SetProperty("document.pages[" + i + "].frames[" + j + "].frameConstraints", "lockMoveVertical", "yes_users");
                editor.SetProperty("document.pages[" + i + "].frames[" + j + "].frameConstraints", "lockResizeHorizontal", "yes_users");
                editor.SetProperty("document.pages[" + i + "].frames[" + j + "].frameConstraints", "lockResizeVertical", "yes_users");
                editor.SetProperty("document.pages[" + i + "].frames[" + j + "].frameConstraints", "lockRotate", "yes_users");
            }
        }
    }
}

Assigning Shapes to a Frame

A shape has to exist within the workspace, in order to use JS to assign a shape to a frame.

// Get the shape object from the workspace
var shapePath = editor.GetObject('document.workSpace.defaultShapes[2]');
// Assign shape to the selected frame
editor.ExecuteFunction("document.selectedFrame", "SetPaths", shapePath.paths);

 
//unassign a shape to the frame
editor.ExecuteFunction("document.selectedFrame","SetPaths",null);

Frame Index Setting

You can change the frame's index by using the following JS, The high index 5000 indicates to put the frame on top, the low index 0 indicates to put the frame at the bottom

editor.SetProperty('document.allFrames[0]','index','5000');
editor.SetProperty('document.selectedFrame','index','0');

Related pages

All information on this page must be treated as External Restricted, or more strict. https://www.chili-publish.com/security