DNN 7以模式打开页面/模块

时间:2015-02-10 08:37:33

标签: dotnetnuke

在DNN 7上工作,我有一个网格,我在其中显示一些用户信息。 我想设置一个"编辑操作",以编辑用户,就像进入管理面板一样。

所以我选择在同一页面上创建一个模式。

<rad:GridTemplateColumn HeaderStyle-Width="0" ItemStyle-HorizontalAlign="Center" AllowFiltering="False">
    <ItemTemplate>
        <a href="#" data-id="<%#((CustomerViewModel)Container.DataItem).UserID%>" class="e">
            <img src='<%=ResolveUrl("~/Icons/Sigma/Edit_16x16_Standard.png")%>' title='Edit user' />
        </a>
    </ItemTemplate>
</rad:GridTemplateColumn>

// edit user infos
$('.e').click(function () {
    var url = "<%= GetEditUrlUser() %>".replace(new RegExp("KEYFIELD", "g"), $(this).attr("data-id"));
    //alert(url);
    dnnModal.show(url, true, 550, 950, false, '');
    return false;
});

这里我的cs功能

public string GetEditUrlUser()
    {
        // I need to show "dnndev.me/en-us/Admin/User-Accounts/ctl/Edit/mid/"+ModuleId+"/UserId/KEYFIELD/filter/All/pagesize/10/currentpage/0?popUp=true ";
        var url = Globals.NavigateURL("393", "Edit", "mid=" + ModuleId, "UserID=KEYFIELD", "filter/All/pagesize/10/currentpage/0", "popUp=true");
        return url;
    }

但这并不好,因为Globals.NavigateURL()会将我的页面返回给我。

我还看了ResolveUrl()函数,但没有成功做好事。

因此,如果有人可以帮助我,或者给我一个示例/提示,那就太棒了。

感谢名单

编辑:它使用此代码,但它似乎没有优化,非常好

public string GetEditUrlUser()
    {
        var url = Globals.NavigateURL("Edit", "mid","393","UserID","KEYFIELD", "filter/All/pagesize/10/currentpage/0", "popUp=true");
        return url;
    }

编辑2:为了提高效率,我实际上得到了这个。但这不起作用,我得到了一个空白的模式。

但这种方式看起来更好,因为它会搜索自己的管理模块

public string GetEditUrlUser()
    {
        // dnndev.me/en-us/Admin/User-Accounts/ctl/Edit/mid/"+ModuleId+"/UserId/KEYFIELD/filter/All/pagesize/10/currentpage/0?popUp=true

        var moduleController = new ModuleController();
        var adminUserModule = moduleController.GetModuleByDefinition(PortalId, "User Accounts");
        var url = EditUrl(adminUserModule.TabID, "Edit", false, "mid="+adminUserModule.ModuleID, "userId=KEYFIELD");
        return url;
    }

1 个答案:

答案 0 :(得分:0)

好吧,我想,最后,我明白了。

ASCX代码

<rad:GridTemplateColumn HeaderStyle-Width="0" ItemStyle-HorizontalAlign="Center" AllowFiltering="False">
    <ItemTemplate>
        <a href="#" data-id="<%#((CustomerViewModel)Container.DataItem).UserID%>" class="e">
            <img src='<%=ResolveUrl("~/Icons/Sigma/Edit_16x16_Standard.png")%>' title='Edit user' />
        </a>
    </ItemTemplate>
</rad:GridTemplateColumn>

使用某些Javascript函数进行自我更新而无需重新加载页面。

function refreshGrid() {
    // grdCustomers should be the ID of your grid
    $find("<%= grdCustomers.ClientID %>").get_masterTableView().rebind();
}

// edit user infos
$('.e').click(function () {
    var url = "<%= GetEditUrlUser() %>".replace(new RegExp("KEYFIELD", "g"), $(this).attr("data-id"));
    dnnModal.show(url,/*showReturn*/true, 550, 950, true, 'javascript:parent.window.refreshGrid()');
    return false;
});

进入CS文件,它应该是。

public string GetEditUrlUser()
{
    var moduleController = new ModuleController();
    var adminUserModule = moduleController.GetModuleByDefinition(PortalId, "User Accounts");
        var url = Globals.NavigateURL(adminUserModule.TabID, "Edit", "mid=" + adminUserModule.ModuleID, "userId=KEYFIELD", "popUp=true");
    return url;
}

它工作正常。

我希望它可以帮助别人。