使用和扩展小组件(经典UI)

Adobe Experience Manager的基于web的界面使用AJAX和其他现代浏览器技术,使作者能够直接在网页上对内容进行WYSIWYG编辑和格式化。

Adobe Experience Manager(AEM)使用ExtJS小组件库,该库提供了经过高度优化的用户界面元素,这些元素可在所有最重要的浏览器中使用,并且允许创建桌面级UI体验。

这些小组件包含在AEM中,除了供AEM本身使用外,还可供使用AEM构建的任何网站使用。

有关AEM中所有可用小组件的完整引用,请参阅小组件API文档或现有xtypes🔗的列表。 此外,在框架所有者Sencha网站上提供了许多显示如何使用ExtJS框架的示例。

本页对如何使用和扩展小组件提供了一些分析。 它首先介绍了如何在页面中包含客户端代码。 然后,该文档描述了为说明一些基本用法和扩展而创建的一些示例组件。 这些组件位于​包共享​上的​使用ExtJS Widgets​包中。

该包包含以下示例:

  • 使 用现成小组件构建的基本对话框。
  • 使用 现成小组件和自定义Javascript逻辑构建的动态对话框。
  • 基于自定义小组件的对话框。
  • 树面板显示给定路径下的JCR树。
  • 以表格格式显示数据的网格面板
注意

Adobe Experience Manager的经典UI基于ExtJS 3.4.0构建。

注意

本页介绍了小组件在经典UI中的用法。 Adobe建议您基于Coral UIGranite UI使用现代化的触屏优化UI

在页面中包含客户端代码

客户端javascript和样式表代码应放置在客户端库中。

要创建客户端库,请执行以下操作:

  1. /apps/<project>下创建具有以下属性的节点:

        name="clientlib"
        jcr:mixinTypes="[mix:lockable]"
        jcr:primaryType="cq:ClientLibraryFolder" 
        sling:resourceType="widgets/clientlib" 
        categories="[<category-name>]" 
        dependencies="[cq.widgets]"
    
    注意

    注意:<category-name>是自定义库的名称(例如,“cq.extjstring”),用于在页面上包含库。

  2. clientlib下创建cssjs文件夹(nt:folder)。

  3. clientlib下创建css.txtjs.txt文件(nt:files)。 这些.txt文件会列出库中包含的文件。

  4. 编辑js.txt:它需要从“ #base=js”开始,然后是CQ客户端库服务要聚合的文件列表,例如:

    #base=js
     components.js
     exercises.js
     CustomWidget.js
     CustomBrowseField.js
     InsertTextPlugin.js
    
  5. 编辑css.txt:它需要从“ #base=css”开始,然后是CQ客户端库服务要聚合的文件列表,例如:

    #base=css
     components.css
    
  6. js文件夹下,放置属于库的javascript文件。

  7. css文件夹下,放置.css文件和css文件使用的资源(例如,my_icon.png)。

注意

对之前描述的样式表的处理是可选的。

要在页面组件jsp中包含客户端库,请执行以下操作:

  • 要同时包含javascript代码和样式表,请执行以下操作:

    <ui:includeClientLib categories="<category-name1>, <category-name2>, ..."/>

    其中, <category-nameX>是客户端库的名称。

  • 要仅包含javascript代码,请执行以下操作:

    <ui:includeClientLib js="<category-name>"/>

有关更多详细信息,请参阅<ui:includeClientLib>标记的描述。

在某些情况下,客户端库应仅在创作模式下可用,而应在发布模式下排除。 具体实现如下:

    if (WCMMode.fromRequest(request) != WCMMode.DISABLED) {
        %><ui:includeClientLib categories="cq.collab.blog"/><%
    }

示例快速入门

要遵循本页面上的教程,请在本地AEM实例中安装名为​Using ExtJS Widgets​的包,并创建一个示例页面,其中将包含这些组件。 为此,请执行以下操作:

  1. 在您的AEM实例中,从包共享中下载名为​Using ExtJS Widget(v01)​的包,并安装该包。 它会在存储库的/apps下创建项目extjstraining

  2. 将包含脚本(js)和样式表(css)的客户端库包含在geometrixx页jsp的head标记中,因为您将在​Geometrixx​分支的新页面中包含示例组件:

    在​CRXDE Lite​中,打开文件/apps/geometrixx/components/page/headlibs.jsp并将cq.extjstraining类别添加到现有的<ui:includeClientLib>标记中,如下所示:

    %><ui:includeClientLib categories="apps.geometrixx-main, cq.extjstraining"/><%

  3. /content/geometrixx/en/products下的​Geometrixx​分支中创建新页面,并将其调用为​使用ExtJS小组件

  4. 进入设计模式,并将名为​Using ExtJS Widgets​的组的所有组件添加到Geometrixx设计中

  5. 在编辑模式下返回:组​使用ExtJS小组件​的组件在Sidekick中可用。

注意

本页面上的示例基于Geometrixx示例内容,该内容不再随AEM一起提供,而已被We.Retail替换。 有关如何下载和安装Geometrixx,请参阅文档We.Retail参考实施

基本对话框

对话框通常用于编辑内容,但也只能显示信息。 查看完整对话框的一种简单方法是访问其json格式的表示形式。 为此,请将您的浏览器指向:

http://localhost:4502/<path-to-dialog>.-1.json

Sidekick中​使用ExtJS小组件​组的第一个组件称为​1。 对话框基础知识,包括四个基本对话框,这些对话框是使用现成小组件构建的,而不使用自定义的javascript逻辑。 对话框存储在/apps/extjstraining/components/dialogbasics下方。 基本对话框包括:

  • 完整对话框(full节点):它显示一个窗口,其中包含3个选项卡,每个选项卡具有2个文本字段。

  • 单面板对话框(singlepanel节点):它显示一个窗口,其中带有1个选项卡,其中具有2个文本字段。

  • 多面板对话框(multipanel节点):其显示方式与“完整”对话框相同,只是构建方式不同。

  • 设计对话框(design节点):此时将显示一个带有2个选项卡的窗口。 第一个选项卡具有文本字段、下拉菜单和可折叠的文本区域。 第二个选项卡具有一个字段集,其中包含4个文本字段,以及一个可折叠的字段集,其中包含2个文本字段。

包括​1。 对话框基础知识​组件(在示例页面中):

  1. 添加​1。 对话框基础知识​组件,指向​Sidekick​中的​使用ExtJS小组件​选项卡的示例页面。

  2. 该组件显示标题、一些文本和​PROPERTIES​链接:单击链接以显示存储库中所存储段落的属性。 再次单击链接以隐藏属性。

组件显示如下:

chlimage_1-133

示例1:完整对话框

Full​对话框显示一个窗口,其中包含三个选项卡,每个选项卡具有两个文本字段。 它是​Dialog Basics​组件的默认对话框。 其特点是:

  • 由节点定义:节点类型= cq:Dialog,xtype = dialog

  • 显示3个选项卡(节点类型= cq:Panel)。

  • 每个选项卡都有2个文本字段(节点类型= cq:Widget,xtype = textfield)。

  • 由节点定义:

    /apps/extjstraining/components/dialogbasics/full

  • 通过请求以下项以JSON格式呈现:

    http://localhost:4502/apps/extjstraining/components/dialogbasics/full.-1.json

该对话框显示如下:

screen_shot_2012-01-31at45411pm

示例2:单面板对话框

单个面板​对话框显示一个窗口,其中有一个选项卡,其中具有两个文本字段。 其特点是:

  • 显示1个选项卡(节点类型= cq:Dialog,xtype = panel

  • 选项卡具有2个文本字段(节点类型= cq:Widget, xtype = textfield

  • 由节点定义:

    /apps/extjstraining/components/dialogbasics/singlepanel

  • 通过请求以下项以json格式呈现:

    http://localhost:4502/apps/extjstraining/components/dialogbasics/singlepanel.-1.json

  • 与​完整对话框​相比,一个优势是需要较少的配置。

  • 建议使用:用于显示信息或仅具有几个字段的简单对话框。

要使用单个面板对话框,请执行以下操作:

  1. 将​Dialog Basics​组件的对话框替换为​Single Panel​对话框:

    1. 在​CRXDE Lite​中,删除节点:/apps/extjstraining/components/dialogbasics/dialog
    2. 单击​Save All​以保存更改。
    3. 复制节点:/apps/extjstraining/components/dialogbasics/singlepanel
    4. 将复制的节点粘贴到下面:/apps/extjstraining/components/dialogbasics
    5. 选择节点:/apps/extjstraining/components/dialogbasics/Copy of singlepanel并将其重命名为dialog
  2. 编辑组件:对话框显示如下:

screen_shot_2012-01-31at45952pm

示例3:多面板对话框

多面板​对话框与​完整​对话框具有相同的显示,但其构建方式不同。 其特点是:

  • 由节点定义(节点类型= cq:Dialog,xtype = tabpanel)。

  • 显示3个选项卡(节点类型= cq:Panel)。

  • 每个选项卡都有2个文本字段(节点类型= cq:Widget,xtype = textfield)。

  • 由节点定义:

    /apps/extjstraining/components/dialogbasics/multipanel

  • 通过请求以下项以json格式呈现:

    http://localhost:4502/apps/extjstraining/components/dialogbasics/multipanel.-1.json

  • 与​全对话框​相比,其优势在于它具有简化的结构。

  • 建议使用:的子菜单。

要使用多面板对话框,请执行以下操作:

  1. 将​对话框基础组件​的对话框替换为​多面板​对话框:

    按照示例2中描述的步骤操作:单面板对话框

  2. 编辑组件:对话框显示如下:

screen_shot_2012-01-31at50119pm

示例4:富对话框

​对话框显示一个带有两个选项卡的窗口。 第一个选项卡具有文本字段、下拉菜单和可折叠的文本区域。 第二个选项卡具有一个字段集,其中包含四个文本字段,而一个可折叠的字段集中包含两个文本字段。 其特点是:

  • 由节点定义(节点类型= cq:Dialog,xtype = dialog)。

  • 显示2个选项卡(节点类型= cq:Panel)。

  • 第一个选项卡具有:带有textfielddialogfieldset小组件和带有3个选项的selection小组件,以及带有textarea小组件的可折叠dialogfieldset

  • 第二个选项卡具有带有4个textfield小部件的dialogfieldset小部件,以及带有2个textfield小部件的可折叠dialogfieldset

  • 由节点定义:

    /apps/extjstraining/components/dialogbasics/rich

  • 通过请求以下项以json格式呈现:

    http://localhost:4502/apps/extjstraining/components/dialogbasics/rich.-1.json

要使用​Rich​对话框,请执行以下操作:

  1. 将​Dialog Basics​组件的对话框替换为​Rich​对话框:

    按照示例2中描述的步骤操作:单面板对话框

  2. 编辑组件:对话框显示如下:

screen_shot_2012-01-31at50429 pmscreen_shot_2012-01-31at50519pm

动态对话框

Sidekick中​使用ExtJS小组件​组的第二个组件称为​2。 动态对话框,包括三个动态对话框,它们是使用现成小组件构建的,是使用自定义的javascript逻辑​构建的。 对话框存储在/apps/extjstraining/components/dynamicdialogs下方。 动态对话框包括:

  • 交换机选项卡对话框(switchtabs节点):此时将显示一个带有两个选项卡的窗口。 第一个选项卡具有一个单选按钮选项,其中包含三个选项:选择某个选项后,会显示与该选项相关的选项卡。 第二个选项卡有两个文本字段。
  • 任意对话框(arbitrary节点):此时会显示一个带有一个选项卡的窗口。 选项卡中有一个用于放置或上传资产的字段,以及一个字段,用于显示有关容器页面以及资产(如果引用了)的一些信息。
  • 切换字段对话框(togglefield节点):此时会显示一个带有一个选项卡的窗口。 选项卡中有一个复选框:选中此选项后,将显示一个字段集,其中包含两个文本字段。

包含​2。 示例页面上的动态对话框​组件:

  1. 添加​2。 动态对话框​组件,位于​Sidekick​中的​使用ExtJS小组件​选项卡的示例页面。

  2. 该组件显示标题、一些文本和​PROPERTIES​链接:单击以显示存储库中所存储段落的属性。 再次单击可隐藏属性。

组件显示如下:

chlimage_1-136

示例1:交换机选项卡对话框

交换机选项卡​对话框显示一个带有两个选项卡的窗口。 第一个选项卡具有一个单选按钮选项,其中包含三个选项:选择某个选项后,会显示与该选项相关的选项卡。 第二个选项卡有两个文本字段。

其主要特点是:

  • 由节点定义(节点类型= cq:Dialog,xtype = dialog)。

  • 显示2个选项卡(节点类型= cq:Panel):1选项卡,则第2个选项卡取决于第1个选项卡(3个选项)中的选择。

  • 具有3个可选制表符(节点类型= cq:Panel),每个制表符具有2个文本字段(节点类型= cq:Widget, xtype = textfield)。 一次只显示一个可选选项卡。

  • switchtabs节点在以下位置定义:

    /apps/extjstraining/components/dynamicdialogs/switchtabs

  • 通过请求以下项以json格式呈现:

    http://localhost:4502/apps/extjstraining/components/dynamicdialogs/switchtabs.-1.json

该逻辑通过事件侦听器和Javascript代码实现,如下所示:

  • 对话框节点具有“ beforeshow”侦听器,该侦听器会在显示对话框之前隐藏所有可选选项卡:

    beforeshow="function(dialog){Ejst.x2.manageTabs(dialog.items.get(0));}"

    dialog.items.get(0) 获取包含选择面板和3个可选面板的表面板。

  • Ejst.x2对象在exercises.js文件中定义,地址为:

    /apps/extjstraining/clientlib/js/exercises.js

  • Ejst.x2.manageTabs()方法中,由于index的值为–1,因此隐藏了所有可选选项卡(i从1到3)。

  • “选择”选项卡具有2个侦听器:其中,在加载对话框时显示所选选项卡(" loadcontent"事件),在更改选择时显示所选选项卡(" selectionchanged"事件):

    loadcontent="function(field,rec,path){Ejst.x2.showTab(field);}"

    selectionchanged="function(field,value){Ejst.x2.showTab(field);}"

  • Ejst.x2.showTab()方法中:

    field.findParentByType('tabpanel') 获取包含所有选项卡的选项卡面板( field 表示选择小组件)

    field.getValue() 获取选择的值,例如:tab2

    Ejst.x2.manageTabs() 显示选定的选项卡。

  • 每个可选选项卡都有一个侦听器,用于隐藏“ render”事件上的选项卡:

    render="function(tab){Ejst.x2.hideTab(tab);}"

  • Ejst.x2.hideTab()方法中:

    tabPanel 是包含所有选项卡的选项卡面板

    index 是可选选项卡的索引

    tabPanel.hideTabStripItem(index) 隐藏选项卡

其显示如下:

screen_shot_2012-02-01at114745am

示例2:任意对话框

通常,对话框会显示基础组件中的内容。 此处描述的对话框(称为​Arbitary​对话框)从其他组件中提取内容。

任意​对话框显示一个带有一个选项卡的窗口。 选项卡包含两个字段:一个用于放置或上传资产,另一个用于显示有关容器页面以及资产(如果已引用)的一些信息。

其主要特点是:

  • 由节点定义(节点类型= cq:Dialog,xtype = dialog)。

  • 显示1个表面板小组件(节点类型= cq:Widget, xtype = tabpanel),其中显示1个面板(节点类型= cq:Panel

  • 该面板具有smartfile小组件(节点类型= cq:Widget, xtype = smartfile)和所有制小组件(节点类型= cq:Widget, xtype = ownerdraw

  • arbitrary节点在以下位置定义:

    /apps/extjstraining/components/dynamicdialogs/arbitrary

  • 通过请求以下项以json格式呈现:

    http://localhost:4502/apps/extjstraining/components/dynamicdialogs/arbitrary.-1.json

该逻辑通过事件侦听器和Javascript代码实现,如下所示:

  • ownerdraw小组件具有“ loadcontent”侦听器,用于显示内容加载时包含组件的页面和智能文件小组件引用的资产相关信息:

    loadcontent="function(field,rec,path){Ejst.x2.showInfo(field,rec,path);}"

    field 使用ownerdraw对象进行设置

    path 使用组件的内容路径进行设置(例如:/content/geometrixx/en/products/triangle/ui-tutorial/jcr:content/par/dynamicdialogs)

  • Ejst.x2对象在exercises.js文件中定义,地址为:

    /apps/extjstraining/clientlib/js/exercises.js

  • Ejst.x2.showInfo()方法中:

    pagePath 是包含组件的页面路径

    pageInfo 表示json格式的页面属性

    reference 是引用资产的路径

    metadata 以json格式表示资产的元数据

    ownerdraw.getEl().update(html); 在对话框中显示已创建的html

要使用​任意​对话框,请执行以下操作:

  1. 将​动态对话框​组件的对话框替换为​任意​对话框:

    按照示例2中描述的步骤操作:单面板对话框

  2. 编辑组件:对话框显示如下:

screen_shot_2012-02-01at115300am

示例3:切换字段对话框

切换字段​对话框显示一个带有一个选项卡的窗口。 选项卡中有一个复选框:选中此选项后,将显示一个字段集,其中包含两个文本字段。

其主要特点是:

  • 由节点定义(节点类型= cq:Dialog,xtype = dialog)。

  • 显示1个表面板小组件(节点类型= cq:Widget, xtype = tabpanel),其中显示1个面板(节点类型= cq:Panel)。

  • 该面板具有选择/复选框小组件(节点类型= cq:Widget、xtype = selection、类型= checkbox)和默认隐藏的可折叠对话框字段集小组件(节点类型= cq:Widget、xtype = dialogfieldset),其中包含2个文本字段小组件(节点类型= cq:Widget、xtype = textfield)。

  • togglefields节点在以下位置定义:

    /apps/extjstraining/components/dynamicdialogs/togglefields

  • 通过请求以下项以json格式呈现:

    http://localhost:4502/apps/extjstraining/components/dynamicdialogs/togglefields.-1.json

该逻辑通过事件侦听器和Javascript代码实现,如下所示:

  • “选择”选项卡有2个侦听器:一个用于在加载内容时显示对话框字段集(“ loadcontent”事件),另一个用于在更改选择时显示对话框字段集(“ selectionchanged”事件):

    loadcontent="function(field,rec,path){Ejst.x2.toggleFieldSet(field);}"

    selectionchanged="function(field,value){Ejst.x2.toggleFieldSet(field);}"

  • Ejst.x2对象在exercises.js文件中定义,地址为:

    /apps/extjstraining/clientlib/js/exercises.js

  • Ejst.x2.toggleFieldSet()方法中:

    • box 是选择对象
    • panel 是包含所选内容和对话框字段集小组件的面板
    • fieldSet 是dialogfieldset对象
    • show 是所选内容的值(true或false)
    • 根据“ show”显示或不显示对话框字段集

要使用​切换字段​对话框,请执行以下操作:

  1. 将​动态对话框​组件的对话框替换为​切换字段​对话框:

    按照示例2中描述的步骤操作:单面板对话框

  2. 编辑组件:对话框显示如下:

screen_shot_2012-02-01at115518am

自定义小组件

AEM附带的现成小组件应涵盖大多数用例。 但是,有时可能需要创建自定义小组件以满足特定于项目的要求。 可通过扩展现有小组件来创建自定义小组件。 为了帮助您开始进行此类自定义,使用ExtJS Widget​包中包含三个使用三个不同自定义小组件的对话框:

  • 多字段对话框(multifield节点)显示一个带有一个选项卡的窗口。 选项卡具有一个自定义的多字段小组件,该小组件具有两个字段:包含两个选项和一个文本字段的下拉菜单。 由于它基于现成的multifield小组件(仅包含文本字段),因此它具有multifield小组件的所有功能。

  • “树浏览”对话框(treebrowse节点)显示一个窗口,其中有一个选项卡包含路径浏览小组件:单击箭头时,将打开一个窗口,您可以在其中浏览层次结构并选择项目。 项目的路径随后会添加到路径字段,并在对话框关闭时持久保留该路径。

  • 基于富文本编辑器插件的对话框(rteplugin节点),可向富文本编辑器添加自定义按钮以将一些自定义文本插入主文本。 它包含richtext小组件(RTE)和通过RTE插件机制添加的自定义功能。

自定义小组件和插件包含在名为​3的组件中。​使用ExtJS Widgets 包的自定义小组件。 要将此组件包含到示例页面,请执行以下操作:

  1. 添加​3。 自定义小组件​组件,可从​Sidekick​的“使用ExtJS小组件​”选项卡的​中添加到示例页面。

  2. 该组件显示标题和一些文本,单击​PROPERTIES​链接时,将显示存储在存储库中的段落属性。 再次单击会隐藏属性。

    组件显示如下:

chlimage_1-137

示例1:自定义多字段小组件

基于​自定义多字段​小组件的对话框显示一个带有一个选项卡的窗口。 选项卡具有一个自定义的多字段小组件,该小组件与具有一个字段的标准小组件不同,具有两个字段:包含两个选项和一个文本字段的下拉菜单。

基于​自定义多字段​小组件的对话框:

  • 由节点定义(节点类型= cq:Dialog,xtype = dialog)。

  • 显示1个表面板小组件(节点类型= cq:Widget, xtype = tabpanel),其中包含一个面板(节点类型= cq:Widget, xtype = panel)。

  • 该面板具有multifield小组件(节点类型= cq:Widget, xtype = multifield)。

  • multifield小组件具有基于自定义xtype ' ejstcustom'的fieldconfig(node type = nt:unstructured, xtype = ejstcustom, optionsProvider = Ejst.x3.provideOptions):

    • fieldconfig”是CQ.form.MultiField对象的配置选项。

    • optionsProvider”是ejstcustom小组件的配置。 它使用Ejst.x3.provideOptions方法进行设置,该方法在exercises.js中定义,具体位置为:

      /apps/extjstraining/clientlib/js/exercises.js

      和返回2个选项。

  • multifield节点在以下位置定义:

    /apps/extjstraining/components/customwidgets/multifield

  • 通过请求以下项以json格式呈现:

    http://localhost:4502/apps/extjstraining/components/customwidgets/multifield.-1.json

自定义多字段小组件(xtype = ejstcustom):

  • 是名为Ejst.CustomWidget的Javascript对象。

  • CustomWidget.js javascript文件中定义:

    /apps/extjstraining/clientlib/js/CustomWidget.js

  • 扩展CQ.form.CompositeField小组件。

  • 具有3个字段:hiddenField(文本字段)、allowField(组合框)和otherField(文本字段)

  • 覆盖CQ.Ext.Component#initComponent以添加3个字段:

    • allowField 是CQ. form. “select”类型的Selectionobject。optionsProvider是Selection对象的配置,该对象是使用对话框中定义的CustomWidget的optionsProvider配置进行实例化的
    • otherFieldCQ.Ext.form. TextFieldobject
  • 覆盖CQ.form.CompositeFieldsetValuegetValuegetRawValue方法,以便设置和检索格式为:

    <allowField value>/<otherField value>, e.g.: 'Bla1/hello'

  • 将自身注册为“ ejstcustom” xtype:

    CQ.Ext.reg('ejstcustom', Ejst.CustomWidget);

基于​自定义多字段​小组件的对话框如下所示:

screen_shot_2012-02-01at115840am

示例2:自定义树状浏览小组件

基于自定义​树状浏览​小组件的对话框显示一个窗口,其中有一个选项卡包含一个自定义路径浏览小组件:单击箭头时,将打开一个窗口,您可以在其中浏览层次结构并选择项目。 项目的路径随后会添加到路径字段,并在对话框关闭时持久保留该路径。

自定义树状浏览对话框:

  • 由节点定义(节点类型= cq:Dialog,xtype = dialog)。

  • 显示1个表面板小组件(节点类型= cq:Widget, xtype = tabpanel),其中包含一个面板(节点类型= cq:Widget, xtype = panel)。

  • 该面板具有一个自定义小组件(节点类型= cq:Widget,xtype = ejstbrowse

  • treebrowse节点在以下位置定义:

    /apps/extjstraining/components/customwidgets/treebrowse

  • 通过请求以下项以json格式呈现:

    http://localhost:4502/apps/extjstraining/components/customwidgets/treebrowse.-1.json

自定义树状浏览小组件(xtype = ejstbrowse):

  • 是名为Ejst.CustomWidget的Javascript对象。

  • CustomBrowseField.js javascript文件中定义:

    /apps/extjstraining/clientlib/js/CustomBrowseField.js

  • 扩展CQ.Ext.form.TriggerField

  • 定义一个名为browseWindow的浏览窗口。

  • 覆盖CQ.Ext.form.TriggerField以在单击箭头时显示浏览窗口。

  • 定义CQ.Ext.tree.TreePanel对象:

    • 它通过调用在/bin/wcm/siteadmin/tree.json注册的Servlet来获取其数据。
    • 其根为“ apps/extjstraining”。
  • 定义window对象(CQ.Ext.Window):

    • 基于预定义的面板。
    • 具有​OK​按钮,用于设置所选路径的值并隐藏面板。
  • 窗口锚定在​Path​字段的下方。

  • 选定的路径将从浏览字段传递到show事件上的窗口。

  • 将自身注册为“ ejstbrowse” xtype:

    CQ.Ext.reg('ejstbrowse', Ejst.CustomBrowseField);

要使用基于​自定义树状浏览器​小组件的对话框,请执行以下操作:

  1. 将​自定义小组件​组件的对话框替换为​自定义树状浏览​对话框:

    按照示例2中描述的步骤操作:单面板对话框

  2. 编辑组件:对话框显示如下:

screen_shot_2012-02-01at120104pm

示例3:富文本编辑器(RTE)插件

基于​富文本编辑器(RTE)插件​的对话框是基于富文本编辑器的对话框,其中具有一个自定义按钮,用于在方括号中插入一些自定义文本。 自定义文本可以由某些服务器端逻辑解析(本示例中未实现),例如,添加在给定路径中定义的一些文本:

基于​RTE插件​的对话框:

  • 由rtplugin节点在以下位置定义:

    /apps/extjstraining/components/customwidgets/rteplugin

  • 通过请求以下项以json格式呈现:

    http://localhost:4502/apps/extjstraining/components/customwidgets/rteplugin.-1.json

  • rtePlugins节点具有以插件命名的子节点inserttext(节点类型= nt:unstructured)。 该插件具有一个名为features的属性,用于定义RTE可使用的插件功能。

RTE插件:

  • 是名为Ejst.InsertTextPlugin的Javascript对象。

  • InsertTextPlugin.js javascript文件中定义:

    /apps/extjstraining/clientlib/js/InsertTextPlugin.js

  • 扩展CQ.form.rte.plugins.Plugin对象。

  • 以下方法定义了CQ.form.rte.plugins.Plugin对象,并在实施插件中被覆盖:

    • getFeatures() 返回该插件可用的所有功能的数组。
    • initializeUI() 将新按钮添加到RTE工具栏。
    • notifyPluginConfig() 在按钮悬停时显示标题和文本。
    • execute() 单击按钮并执行插件操作时,将调用:它会显示一个窗口,用于定义要包含的文本。
  • insertText() 使用相应的对话框对象插入文 Ejst.InsertTextPlugin.Dialog 本(请参阅之后)。

  • executeInsertText() 由对话框的 apply() 方法调用,该方法在单击OK按钮 ​时触发。

  • 将自身注册为“ inserttext”插件:

    CQ.form.rte.plugins.PluginRegistry.register("inserttext", Ejst.InsertTextPlugin);

  • Ejst.InsertTextPlugin.Dialog对象定义在单击插件按钮时打开的对话框。 该对话框由面板、窗体、文本字段和2个按钮(OK​和​Cancel)组成。

要使用基于​富文本编辑器(RTE)插件​的对话框,请执行以下操作:

  1. 将​自定义小组件​的对话框替换为基于​富文本编辑器(RTE)插件​的对话框:

    按照示例2中描述的步骤操作:单面板对话框

  2. 编辑组件。

  3. 单击右侧的最后一个图标(带四个箭头的图标)。 输入路径并单击​OK:

    路径显示在括号([])内。

  4. 单击​确定​以关闭富文本编辑器。

基于​富文本编辑器(RTE)插件​的对话框显示如下:

screen_shot_2012-02-01at120254pm

注意

此示例仅显示如何实施逻辑的客户端部分:占位符([text])随后必须在服务器端显式解析(例如,在组件JSP中)。

树概述

现成的CQ.Ext.tree.TreePanel对象提供树结构化数据的树结构化UI表示形式。 使用ExtJS Widgets​包中包含的树概述组件显示了如何使用TreePanel对象在给定路径下显示JCR树。 窗口本身可以停靠/取消停靠。 在此示例中,窗口逻辑嵌入到组件jsp中<script></script>标记之间。

要将​树概述​组件包含到示例页面中:

  1. 添加​4。 将树概述​组件添加到​Sidekick​中的​使用ExtJS Widgets​选项卡的示例页面。

  2. 组件会显示:

    • 带有文本的标题
    • a 属性​链接:单击以显示存储库中所存储段落的属性。 再次单击可隐藏属性。
    • 可展开的具有存储库树表示的浮动窗口。

组件显示如下:

screen_shot_2012-02-01at120639pm

树概述组件:

  • 定义于:

    /apps/extjstraining/components/treeoverview

  • 其对话框允许设置窗口大小和停靠/取消停靠窗口(请参阅下面的详细信息)。

组件jsp:

  • 从存储库中检索宽度、高度和停靠属性。

  • 显示有关树概述数据格式的一些文本。

  • 在javascript标记之间的组件jsp中嵌入窗口逻辑。

  • 定义于:

    apps/extjstraining/components/treeoverview/content.jsp

组件jsp中嵌入的Javascript代码:

  • 通过尝试从页面中检索树窗口来定义tree对象。

  • 如果显示树的窗口不存在,则会创建treePanel(CQ.Ext.tree.TreePanel):

    • treePanel 包含用于创建窗口的数据。

    • 通过调用在以下位置注册的Servlet来检索数据:

      /bin/wcm/siteadmin/tree.json

  • beforeload侦听器确保加载了点击的节点。

  • root对象将路径apps/extjstraining设置为树根。

  • tree (CQ.Ext.Window)基于预定义的变量进行设置, treePanel并显示为:

    tree.show();

  • 如果窗口已存在,则会根据从存储库检索的宽度、高度和停靠属性来显示该窗口。

组件对话框:

  • 显示1个选项卡,其中包含2个字段用于设置树概述窗口的大小(宽度和高度),1个字段用于停放/取消停放窗口

  • 由节点定义(节点类型= cq:Dialog,xtype = panel)。

  • 该面板具有一个大小字段小组件(节点类型= cq:Widget, xtype = sizefield)和一个选择小组件(节点类型= cq:Widget, xtype = selection,类型= radio),其中包含2个选项(true/false)

  • 由对话框节点在以下位置定义:

    /apps/extjstraining/components/treeoverview/dialog

  • 通过请求以下项以json格式呈现:

    http://localhost:4502/apps/extjstraining/components/treeoverview/dialog.-1.json

  • 显示如下:

screen_shot_2012-02-01at120745pm

网格概述

网格面板以行和列的表格格式表示数据。 它由以下内容组成:

  • 存储:保存数据记录(行)的模型。
  • 列模型:专栏的构成。
  • 查看:封装用户界面。
  • 选择模型:选择行为。

使用ExtJS Widgets​包中包含的网格概述组件显示了如何以表格格式显示数据:

  • 示例1使用静态数据。
  • 示例2使用从存储库检索到的数据。

要将网格概述组件包含到示例页面,请执行以下操作:

  1. 添加​5。 网格概述​组件,显示在​Sidekick​中的​使用ExtJS Widgets​选项卡的示例页面中。

  2. 组件会显示:

    • 带有文本的标题
    • a 属性​链接:单击以显示存储库中所存储段落的属性。 再次单击可隐藏属性。
    • 包含表格格式的数据的浮动窗口。

组件显示如下:

screen_shot_2012-02-01at121109pm

示例1:默认网格

在开箱即用的版本中,网格概述​组件以表格格式显示一个包含静态数据的窗口。 在本例中,逻辑以两种方式嵌入到组件jsp中:

  • 在<script></script>标记之间定义通用逻辑
  • 特定逻辑在单独的.js文件中可用,并在jsp中链接到。 通过此设置,可以通过注释所需的<script>标记,轻松地在两个逻辑(静态/动态)之间切换。

网格概述组件:

  • 定义于:

    /apps/extjstraining/components/gridoverview

  • 其对话框用于设置窗口的大小和停靠/取消停靠窗口。

组件jsp:

  • 从存储库中检索宽度、高度和停靠属性。

  • 显示一些文本作为网格概述数据格式的简介。

  • 引用定义GridPanel对象的Javascript代码:

    <script type="text/javascript" src="/apps/extjstraining/components/gridoverview/defaultgrid.js"></script>

    defaultgrid.js 将一些静态数据定义为GridPanel对象的基。

  • 在可定义使用GridPanel对象的Window对象的Javascript标记之间嵌入Javascript代码。

  • 定义于:

    apps/extjstraining/components/gridoverview/content.jsp

组件jsp中嵌入的Javascript代码:

  • 通过尝试从页面中检索窗口组件来定义grid对象:

    var grid = CQ.Ext.getCmp("<%= node.getName() %>-grid");

  • 如果grid不存在,则通过调用getGridPanel()方法(请参阅下文)来定义CQ.Ext.grid.GridPanel对象(gridPanel)。 此方法在defaultgrid.js中定义。

  • grid 是基 CQ.Ext.Window于预定义GridPanel的对象,显示如下: grid.show();

  • 如果grid已存在,则会根据从存储库检索到的宽度、高度和停靠属性来显示该属性。

组件jsp中引用的javascript文件(defaultgrid.js)定义了getGridPanel()方法,该方法由嵌入在JSP中的脚本调用,并基于静态数据返回CQ.Ext.grid.GridPanel对象。 逻辑如下:

  • myData 是静态数据数组,格式为包含5列和4行的表。

  • store 是使 CQ.Ext.data.Store 用的对 myData象。

  • store 在内存中加载:

    store.load();

  • gridPanel 是使用 CQ.Ext.grid.GridPanel 的对象 store:

    • 列宽随时会进行重新比例:

      forceFit: true

    • 一次只能选择一行:

      singleSelect:true

示例2:引用搜索网格

安装包时,网格概述​组件的content.jsp将显示一个基于静态数据的网格。 可以修改组件以显示具有以下特征的网格:

  • 有三列。
  • 基于通过调用Servlet从存储库检索到的数据。
  • 可以编辑最后一列的单元格。 该值将保留在test属性中,该属性位于由第一列中显示的路径定义的节点下方。

如前面部分所述,窗口对象通过调用defaultgrid.js文件中/apps/extjstraining/components/gridoverview/defaultgrid.js中定义的getGridPanel()方法来获取其CQ.Ext.grid.GridPanel对象。 网格概述​组件为getGridPanel()方法提供了不同的实现,该实现在/apps/extjstraining/components/gridoverview/referencesearch.jsreferencesearch.js文件中定义。 通过切换组件jsp中引用的.js文件,网格将基于从存储库检索到的数据。

切换组件jsp中引用的.js文件:

  1. 在​CRXDE Lite​的组件content.jsp文件中,对包含defaultgrid.js文件的行进行注释,使其如下所示:

    <!-- script type="text/javascript" src="/apps/extjstraining/components/gridoverview/defaultgrid.js"></script-->

  2. 从包含referencesearch.js文件的行中删除注释,使其如下所示:

    <script type="text/javascript" src="/apps/extjstraining/components/gridoverview/referencesearch.js"></script>

  3. 保存更改。

  4. 刷新示例页面。

组件显示如下:

screen_shot_2012-02-01at121429pm

组件jsp(referencesearch.js)中引用的javascript代码定义从组件jsp调用的getGridPanel()方法,并根据从存储库动态检索的数据返回CQ.Ext.grid.GridPanel对象。 referencesearch.js中的逻辑将一些动态数据定义为GridPanel的基础:

  • reader 是一个 CQ.Ext.data.JsonReader 对象,用于为3列读取json格式的servlet响应。

  • cm 是3 CQ.Ext.grid.ColumnModel 列的对象。

    可以编辑“测试”列单元格,因为这些单元格是通过编辑器定义的:

    editor: new CQ.Ext.form.TextField({})

  • 可对列进行排序:

    cm.defaultSortable = true;

  • store 是对 CQ.Ext.data.GroupingStore 象:

    • 它通过调用在“ /bin/querybuilder.json”注册的servlet来获取其数据,其中包含一些用于筛选查询的参数
    • 它基于预先定义的reader
    • 表按照“jcr:path”列的升序排序
  • gridPanel 是可 CQ.Ext.grid.EditorGridPanel 以编辑的对象:

    • 它基于预定义的store和列模型cm

    • 一次只能选择一行:

      sm: new CQ.Ext.grid.RowSelectionModel({singleSelect:true})

    • afteredit侦听器确保在“测试”列中的单元格被编辑之后:

      • 在存储库中使用单元格的值设置“jcr:path”列所定义路径处节点的属性“ test
      • 如果POST成功,则会将值添加到store对象,否则将拒绝该值

在此页面上