配置Campaign Explorer导航树

作为专家用户,您可以在资源管理器树中添加文件夹并对其进行自定义。

在此部分🔗中了解有关Campaign资源管理器和导航层次结构的更多信息。

导航列表使用的文件夹类型在遵循​xtk:navtree​模式语法的XML文档中进行描述。

XML文档的结构如下:

<navtree name="name" namespace="name_space">
  <!-- Global commands -->
  <commands>
      ...
  </commands>
  
  <!-- Structured space for adding a folder -->
  <model name="<name>" label="<Label>">
    <!-- Folder type -->
    <nodeModel>
      ...
    </nodeModel>
<model name="<name>" label="<Sub model>">
      ...
    </model>
  </model> 
</navtree>

XML文档包含具有​name​和​namespace​属性的​<navtree>​根元素,用于指定文档名称和命名空间。 名称和命名空间构成了文档标识键。

应用程序的全局命令在文档中从​<commands>​元素声明。

在文档中,文件类型声明的结构具有以下元素:<model>​和​<nodemodel>

全局命令

全局命令允许您启动操作。 此操作可以是输入表单或SOAP调用。

可从主​Tools​菜单访问全局命令。

命令配置结构如下所示:

<commands>
  <!-- Description of a command -->
  <command name="<name>" label="<label>" desc="<Description>" form="<form>" rights="<rights>">
    <soapCall name="<name>" service="<schema>">
      <param type="<type>" exprIn="<xpath>"/>  
        ...
    </soapCall>
    <enter>
      ...
    </enter>
  </command>
  <!-- Separator -->
  <command label="-" name="<name>"/>
  <!-- Command structure -->
  <command name="<name>" label="<Label>">
    <command...
  </command>
</commands>

全局命令的描述将在​<command>​元素中输入,并具有以下属性:

  • 名称:命令的内部名称:必须输入名称且名称唯一
  • 标签:命令的标签。
  • desc:描述从主屏幕的状态栏中可见。
  • 表单:要启动的表单:要输入的值是输入表单的标识键(例如,"cus:recipient")
  • 权限:允许访问此命令的命名权限列表(以逗号分隔)。可从​Administration > Access management > Named rights​文件夹访问可用权限列表。
  • promptLabel:在执行命令之前显示确认框。

<command>​元素可以包含​<command>​子元素。 在这种情况下,父元素允许您显示由这些子元素组成的子菜单。

命令以与在XML文档中声明的顺序相同的顺序显示。

使用命令分隔符可显示命令之间的分隔条。 它由命令标签中包含的​'-'​值标识。

<soapcall>​标记的可选存在及其输入参数定义了要执行的SOAP方法的调用。 有关SOAP API的更多信息,请参阅Campaign JSAPI文档

可以从​<enter>​标记初始化时更新表单上下文。 有关此标记的更多信息,请参阅有关输入表单的文档。

示例:

  • 声明全局命令以启动“xtk:import”表单:

    <command desc="Start the data import wizard" form="xtk:import" label="&amp;Data import..." name="import" rights="import,recipientImport"/>
    

    在命令标签中存在​&​时,会在“I”字符上声明键盘快捷键。

  • 带分隔符的子菜单示例:

    <command label="Administration" name="admin">
      <command name="cmd1" label="Example 1" form="cus:example1"/>
      <command name="sep" label="-"/>
      <command name="cmd1" label="Example 2" form="cus:example2">
        <enter>
          <set xpath="@type" expr="1"/>
        </enter>
      </command>
    </command>
    
  • 执行SOAP方法:

    <command name="cmd3" label="Example 3" promptLabel="Do you really want to execute the command?">
      <soapCall name="Execute" service="xtk:sql"/>
    </command>
    

文件夹类型

利用文件夹类型,可访问架构的数据。 与文件夹关联的视图由列表和输入表单组成。

文件夹类型配置结构如下所示:

<!-- Structured location to add the folder -->
<model name="name" label="Labelled">
  <!-- Type of folder -->
  <nodeModel name="<name>" label="<Labelled>" img="<image>">
    <view name="<name>" schema="<schema>" type="<listdet|list|form|editForm>">
      <columns>
        <node xpath="<field1>"/>
        ...
    </columns>
    </view> 
  </nodeModel>
  <model name="<name>" label="<Sous modèle>">
    ...
  </model>
</model>

必须在​<model>​元素下输入文件夹类型声明。 利用此元素,可定义从​Add new folder​菜单中可见的分层组织。 <model>​元素必须包含​<nodemodel>​元素和其他​<model>​元素。

name​和​label​属性填充元素的内部名称和​Add new folder​菜单中显示的标签。

<nodemodel>​元素包含文件夹类型的描述,其属性如下:

  • 名称:内部名称
  • 标签:在菜单中使用 Add new folder 的标签,在插入文件夹时用作默认标签。
  • img:文件夹插入时的默认图像。
  • hiddenCommands:要屏蔽的命令列表(以逗号分隔)。可能值:"adbnew"、"adbsave"、"adbcancel"和"adbdup"。
  • newFolderShortCuts:文件夹创建中模型(<nodemodel> 以逗号分隔)上的快捷键列表。
  • insertRighteditRightdeleteRight:用于插入、编辑和删除文件夹的权限。

<nodemodel>​元素下方的​<view>​元素包含与视图关联的列表的配置。 列表的架构在​<view>​元素的​schema​属性中输入。

要编辑列表的记录,将隐式使用与列表架构同名的输入表单。 <view>​元素中的​type​属性会影响表单的显示。 可能的值包括:

  • listdet:在列表底部显示表单。
  • 列表:仅显示列表。通过双击或通过选择列表的菜单中的“打开”启动表单。
  • 表单:显示只读表单。
  • editForm:在编辑模式下显示表单。
注意

通过在​**<view>​元素中输入​form**​属性,可以重载输入表单的名称。

列表列的默认配置通过​<columns>​元素输入。 在包含​xpath​属性的​<node>​元素上声明列,其模式中要引用的字段作为其值。

示例:“nms:recipient”模式上文件夹类型的声明。

<model label="Profiles and targets" name="nmsProfiles">
  <nodeModel deleteRight="folderDelete" editRight="folderEdit" folderLink="folder"
             img="nms:folder.png" insertRight="folderInsert" label="Recipients"
             name="nmsFolder">
    <view name="listdet" schema="nms:recipient" type="listdet">
      <columns>
        <node xpath="@firstName"/>
        <node xpath="@lastName"/>
        <node xpath="@email"/>
        <node xpath="@account"/>
      </columns>
    </view>
  </nodeModel>
  <nodeModel name="nmsGroup" label="Groups"...
</model>

相应的文件夹插入菜单:

在加载列表时,可以应用过滤和排序:

<view name="listdet" schema="nms:recipient" type="listdet">
  <columns>
    ...
  </columns>

  <orderBy>
    <node expr="@lastName" desc="true"/>
</orderBy>
  <sysFilter>
    <condition expr="@type = 1"/>
  </sysFilter>
</view>  

快捷键命令

快捷键命令允许您在选择列表时启动一项操作。 操作可以是输入表单或SOAP调用。

可从列表的​Action​菜单或相关菜单按钮访问命令。

命令配置结构如下所示:

<nodeModel...
  ...
  <command name="<name>" label="<label>" desc="<Description>" form="<form>" rights="<rights>">
    <soapCall name="<name>" service="<schema>">
      <param type="<type>" exprIn="<xpath>"/>  
        ...
    </soapCall>
    <enter>
      ...
    </enter>
  </command>
</nodeModel>

在​<command>​元素中输入命令的说明,该说明具有以下属性:

  • 名称:命令的内部名称:必须输入名称且名称唯一。
  • 标签:命令的标签。
  • desc:描述从主屏幕的状态栏中可见。
  • 表单:要启动的表单:要输入的值是输入表单的标识键(例如,"cus:recipient")。
  • 权限:允许访问此命令的命名权限列表(以逗号分隔)。可从​Administration > Access management > Named rights​文件夹访问可用权限列表。
  • promptLabel:在执行命令之前显示确认框
  • monoSelection:强制单选(默认情况下为多选)。
  • refreshView:执行命令后强制重新加载列表。
  • enabledIf:根据输入的表达式激活命令。
  • img:输入允许从列表工具栏访问命令的图像。

<command>​元素可以包含​<command>​子元素。 在这种情况下,父元素允许您显示由这些子元素组成的子菜单。

命令以与在XML文档中声明的顺序相同的顺序显示。

使用命令分隔符可显示命令之间的分隔条。 它由命令标签中包含的​'-'​值标识。

<soapcall>​标记的可选存在及其输入参数定义了要执行的SOAP方法的调用。 有关SOAP API的更多信息,请参阅Campaign JSAPI文档

可以通过​<enter>​标记在初始化时更新表单上下文。 有关此标记的更多信息,请参阅输入表单文档。

示例:

<command desc="Cancel execution of the job" enabledIf="EV(@status, 'running')"
         img="nms:difstop.bmp" label="Cancel..." name="cancelJob" 
         promptLabel="Do you really want to cancel this job?" refreshView="true">
  <soapCall name="Cancel" service="xtk:jobInterface"/>
</command>
<command label="-" name="sep1"/>
<command desc="Execute selected template" form="cus:form" lmonoSelection="true" name="executeModel"
         rights="import,export,aggregate">
  <enter>
    <set expr="0" xpath="@status"/>
  </enter>
</command>

链接的文件夹

文件夹管理操作有两种类型:

  1. 文件夹是一个视图:该列表显示与架构关联的所有记录,并可能在文件夹属性中输入系统筛选。
  2. 文件夹已链接:列表中的记录会在文件夹链接上隐式过滤。

对于链接的文件夹,必须填充​<nodemodel>​元素上的​folderLink​属性。 此属性包含在数据架构中配置的文件夹中的链接名称。

数据架构中链接文件夹的声明示例:

<element default="DefaultFolder('nmsFolder', [@_folder-id])" label="Folder" name="folder" revDesc="Recipients in the folder" revIntegrity="define" revLabel="Recipients" target="xtk:folder" type="link"/>

名为“folder”的文件夹链接上的​<nodemodel>​的配置如下:

<nodeModel deleteRight="folderDelete" editRight="folderEdit" folderLink="folder"
  img="nms:folder.png" insertRight="folderInsert" label="Recipients" name="nmsFolder">
...
</nodeModel>

在此页面上