3

我正在尝试显示另一个 portlet(我之前创建的),但弹出窗口是空的。首先,我创建了 renderURL:

<liferay-portlet:renderURL var="testPopupURL" portletName="<%=rule.getBannerPortletId() %>" windowState="<%=LiferayWindowState.POP_UP.toString() %>"></liferay-portlet:renderURL>

我做链接:

<aui:a href="#" onClick="showPopup('${testPopupURL}')">View</aui:a> 

这是函数 showPopup:

    function showPopup(url){
    console.log("En el showPopup ");
    AUI().ready('aui-dialog', 'aui-io', 'event', 'event-custom', function(A) {
        window.myDialog  = new A.Dialog({
            title: 'Banner',
            width: 640,
            centered: true
        }).plug(A.Plugin.DialogIframe, {
                uri: url.toString(),
                iframeCssClass: 'dialog-iframe'
        }).render();
    });
}

我输入了 liferay-portlet.xml(我想在弹出窗口中打开的 portlet):

<add-default-resource>true</add-default-resource>

portlet 是可实例化的,bannerPortletId 是 portletId。

任何想法?

谢谢

4

1 回答 1

3

最后我得到了显示portlet。我用javascript创建了网址:

    var url;
    function createRenderURL(portletId) {
    AUI().ready('liferay-portlet-url', function(A) {
        var renderURL = Liferay.PortletURL.createRenderURL();
        renderURL.setName("Banner");
        renderURL .setPortletMode("edit");
        renderURL .setWindowState("pop_up"); 
        renderURL.setPortletId(portletId);
    url = renderURL.toString();
    });
}

显示弹出窗口的代码是相同的,但我将 portletId 作为参数传递并调用函数 createRenderURL。

    var url;

function createRenderURL(portletId) {
    console.log("en el createRender");
    AUI().ready('liferay-portlet-url', function(A) {
        var renderURL = Liferay.PortletURL.createRenderURL();
        renderURL.setName("Banner");
        renderURL .setPortletMode("edit");
        renderURL .setWindowState("pop_up"); 
        renderURL.setPortletId(portletId);
        console.log(renderURL);
        url = renderURL.toString();
    });
}

我希望这对某人有用。

于 2013-11-11T09:32:42.557 回答