PopupControlExtender внутри Gridview не закрывается
GridView будет перечислять строки, которые должны быть одобрены / отклонены. Первый столбец называется "Действие", при нажатии на который отображается панель ajax popupcontrolextender с двумя ссылками (Утвердить / Отклонить). После нажатия на ссылку мне нужно обновить статус в БД и обновить GridView. ObjectDataSource используется для привязки GridView. Я использовал приведенный ниже код внутри события RowCommand:
Dim index As Integer = Convert.ToInt32(e.CommandArgument)
Dim gvRow As GridViewRow = GridView1.Rows(index)
If e.CommandName = "Approve" Then
BusinessLogicLayer.UpdateFileStatus(sID, Approve)
ElseIf e.CommandName = "Reject" Then
BusinessLogicLayer.UpdateFileStatus(sID, Reject)
End If
GridView1.DataBind()
DirectCast(gvRow.FindControl("pceMenu"), AjaxControlToolkit.PopupControlExtender).Cancel()
HTML-код TemplateField 'Action':
<asp:TemplateField HeaderText="Action" >
<ItemTemplate>
<ajax:PopupControlExtender ID="pceMenu" runat="server" TargetControlID="imgMenu" PopupControlID="pnlMenu" Position="Right" >
</ajax:PopupControlExtender>
<asp:Image ID="imgMenu" runat="server" ImageUrl="~/Images/gear.png" CssClass="popupImage" />
<asp:Panel ID="pnlMenu" runat="server" CssClass="popupControl" Width="85px" Height="50px" style="display:none;">
<div class="menu-row" style="border-top: none;">
<asp:Image ID="imgApprove" runat="server" ImageUrl="~/Images/tick.png" style="float:left;"/>
<asp:LinkButton ID="lnkApprove" runat="server" Text="Approve" ToolTip="Approve" style="margin-left:10px;" CommandName="Approve" />
</div>
<div class="menu-row">
<asp:Image ID="imgReject" runat="server" ImageUrl="~/Images/delete16.png" style="float:left;"/>
<asp:LinkButton ID="lnkReject" runat="server" Text="Reject" ToolTip="Reject" style="margin-left:10px;" CommandName="Reject" />
</div>
</asp:Panel>
</ItemTemplate>
<HeaderStyle HorizontalAlign="Left"/>
<ItemStyle HorizontalAlign="Center" Width="5%"/>
</asp:TemplateField>
Попробовал следующие методы, но безуспешно:
- Подавить видимость панели с помощью style="display:'';"
- Вызывается метод Cancel() объекта PopupControlExtender.
Примечание. Всплывающее окно исчезает, если я не связываю GridView внутри события RowCommand. Но мне нужно обновить результаты, отображаемые после утверждения / отклонения.
Ценю любую помощь. Спасибо!
1 ответ
Привет, вы можете скрыть модальный всплывающий расширитель набора инструментов управления ajax от кода, попробуйте этот код:
IdOfYourModelPopup.Hide();