Я новичок в asp net и немного застрял в этом вопросе.
Я использую вложенную таблицу Gridview. Родительская таблица суммирует общую сумму счетов-фактур, в которой есть столбец «Сумма сбора», «Дочерняя таблица» отображает отдельные данные счета-фактуры и столбец «Сумма счета». Сумма инкассо является суммой суммы инвойса.
В дочерней сетке у меня есть флажок, если пользователь проверяет отдельные строки счета, мне нужно обновить Сумму сбора в родительской сетке.
Я искал онлайн решение, но не смог его найти.
Настройка Parent и ChildGrid
<asp:GridView ID="NotaDebitoInvoicesGrid" runat="server" AutoGenerateColumns="false"
OnRowDataBound="NotaDebitoInvoicesGrid_RowDataBound"
Width="98%" ShowFooter="true" Style="margin-left: 4px; margin-right: 4px;" DataKeyNames="HoId">
<Columns>
<asp:TemplateField ItemStyle-Width="20px">
<ItemTemplate>
<a href="JavaScript:divexpandcollapse('div<%# Eval("HoId") %>');">
<img id="imgdiv<%# Eval("HoId") %>" width="9px" border="0" src="../images/expand_blue.jpg"
alt="" /></a>
</ItemTemplate>
</asp:TemplateField>
<asp:TemplateField>
<HeaderTemplate>
Head Office Name
</HeaderTemplate>
<ItemTemplate>
<asp:HiddenField ID="adminFeeHoID" runat="server" Value='<%#Eval("HoId") %>' />
</ItemTemplate>
<ItemTemplate>
<asp:Label ID="adminFeeHeadOfficeID" runat="server">
<%# string.Format("{0}", Eval("HeadOfficeName"))%></asp:Label>
</ItemTemplate>
</asp:TemplateField>
<asp:TemplateField>
<HeaderTemplate>
Collection Amount
</HeaderTemplate>
<ItemTemplate>
<asp:Label ID="adminFeeInvoiceAmount" runat="server"><%# string.Format("{0} {1:0.00}", CurrencySymbol, Eval("TotalAmount"))%></asp:Label>
</ItemTemplate>
<FooterTemplate>
<asp:Label ID="adminFeeSelectedInvoiceAmount" runat="server">0.0</asp:Label>
</FooterTemplate>
<FooterStyle CssClass="pflabelright" HorizontalAlign="Right" />
<ItemStyle CssClass="pflabelright" HorizontalAlign="Right" />
</asp:TemplateField>
<asp:TemplateField>
<HeaderTemplate>
Number of Invoices
</HeaderTemplate>
<ItemTemplate>
<asp:Label ID="adminInvoiceCount" runat="server">
<%# string.Format("{0}", Eval("InvoiceCount"))%></asp:Label>
</ItemTemplate>
<ItemStyle HorizontalAlign="Center" />
</asp:TemplateField>
<asp:TemplateField HeaderText="Select all">
<HeaderTemplate>
<asp:Label ID="HeaderSelectAll" runat="server" Text="Select All"></asp:Label>
<asp:CheckBox ID="CheckBoxAll" AutoPostBack="true" runat="server" OnCheckedChanged="CheckBoxAll_OnCheckedChanged" />
</HeaderTemplate>
<ItemTemplate>
<asp:CheckBox ID="checkBoxInvoice" runat="server" AutoPostBack="true" OnCheckedChanged="CheckBoxInvoice_OnCheckedChanged" />
</ItemTemplate>
<ItemStyle CssClass="pflabelright" HorizontalAlign="Center" />
</asp:TemplateField>
<asp:TemplateField>
<ItemTemplate>
<tr>
<td colspan="100%">
<div id="div<%# Eval("HoId") %>" style="overflow:auto; display:none; position: relative; left: 15px; overflow: auto">
<asp:GridView ID="gvDebitsGredits" runat="server" AutoGenerateColumns="false">
<Columns>
<asp:TemplateField>
<HeaderTemplate>
Invoice No.
</HeaderTemplate>
<ItemTemplate>
<asp:HiddenField ID="adminFeeInvoiceKey" runat="server" Value='<%#Eval("Key") %>' />
<asp:HiddenField ID="adminFeeHoID" runat="server" Value='<%#Eval("HoId") %>' />
<asp:HiddenField ID="adminFeeMsgID" runat="server" Value='<%#Eval("SepaMsgId") %>' />
<asp:HiddenField ID="UniqueMandateRef" runat="server" Value='<%#Eval("UniqueMandateRef") %>' />
<asp:Label ID="adminFeeInvoiceNumber" runat="server"><%# string.Format("{0}", Eval("Number")) %></asp:Label>
</ItemTemplate>
</asp:TemplateField>
<asp:TemplateField>
<HeaderTemplate>
Period
</HeaderTemplate>
<ItemTemplate>
<asp:Label ID="adminFeeHeadOfficeName" runat="server"><%# string.Format("{0}", Eval("Period") ?? "NA")%></asp:Label>
</ItemTemplate>
</asp:TemplateField>
<asp:TemplateField>
<HeaderTemplate>
Invoice Date
</HeaderTemplate>
<ItemTemplate>
<asp:Label ID="adminFeeHeadOfficeDate" runat="server"><%# string.Format("{0: dd-MM-yyyy}", Eval("Date"))%></asp:Label>
</ItemTemplate>
<ItemStyle HorizontalAlign="Center" />
</asp:TemplateField>
<asp:TemplateField>
<HeaderTemplate>
Invoice type
</HeaderTemplate>
<ItemTemplate>
<asp:Label ID="adminFeeHeadOfficeType" runat="server"><%# Convert.ToString(Eval("Type"))%></asp:Label>
</ItemTemplate>
<ItemStyle HorizontalAlign="Center" />
</asp:TemplateField>
<asp:TemplateField>
<HeaderTemplate>
Invoice Amount
</HeaderTemplate>
<ItemTemplate>
<asp:Label ID="adminFeeInvoiceAmount" runat="server"><%# string.Format("{0} {1:0.00}", CurrencySymbol, Eval("PpInclVat"))%></asp:Label>
</ItemTemplate>
<FooterTemplate>
<asp:Label ID="adminFeeSelectedInvoiceAmount" runat="server">0.0</asp:Label>
</FooterTemplate>
<FooterStyle CssClass="pflabelright" HorizontalAlign="Right" />
<ItemStyle CssClass="pflabelright" HorizontalAlign="Right" />
</asp:TemplateField>
<asp:TemplateField HeaderText="Select all">
<HeaderTemplate>
<asp:Label ID="HeaderSelectAllSubInvoice" runat="server" Text="Select All"></asp:Label>
<asp:CheckBox ID="CheckBoxAllInvoice" AutoPostBack="false" runat="server" OnCheckedChanged="CheckBoxAllInvoice_CheckedChanged" />
</HeaderTemplate>
<ItemTemplate>
<asp:CheckBox ID="checkBoxSubInvoice" runat="server" AutoPostBack="false" OnCheckedChanged="checkBoxSubInvoice_CheckedChanged" />
</ItemTemplate>
<ItemStyle CssClass="pflabelright" HorizontalAlign="Center" /><%--<asp:CheckBoxField ID="checkBoxDebitCredit" runat="server" AutoPostBack="true" OnCheckedChanged="checkBoxDebitCredit_OnCheckedChanged"/>--%>
</asp:TemplateField>
</Columns>
</asp:GridView>
</td>
</tr>
</ItemTemplate>
</asp:TemplateField>
</Columns>
</asp:GridView>
Получает все неоплаченные счета, создает сводку и привязывается к родительской сетке.
UnpaidInvoicesList = NotaDebitoManagement.SelectAllNotPaidNotaDebitoInvoices(Page.CountryId, option,
Convert.ToDateTime(NotaDebitoInvoiceDates.SelectedValue),
Convert.ToDateTime(NotaDebitoInvoiceDatesTo.SelectedValue));
List<NotaDebitoManagement.InvoiceGrouping> InvoiceGroup = UnpaidInvoicesList
.GroupBy(ho => ho.HeadOffice)
.Select(ig => new NotaDebitoManagement.InvoiceGrouping
{
HoId = ig.First().HoId,
HeadOfficeName = ig.First().HeadOffice,
TotalAmount = ig.Sum(c => c.PpInclVat),
InvoiceCount = ig.Count(),
}).ToList();
NotaDebitoInvoicesGrid.DataSource = InvoiceGroup;
NotaDebitoInvoicesGrid.DataBind();
Для каждого продавца добавить неоплаченный счет в дочернюю сетку
protected void NotaDebitoInvoicesGrid_RowDataBound(object sender, GridViewRowEventArgs e)
{
if (e.Row.RowType == DataControlRowType.DataRow)
{
int HeadOfficeID = (int)NotaDebitoInvoicesGrid.DataKeys[e.Row.RowIndex].Values["HoId"];
var gvDebitsGredits = (GridView)e.Row.FindControl("gvDebitsGredits");
var DebitCredits = UnpaidInvoicesList
.Where(o => o.HoId == HeadOfficeID)
.OrderByDescending(ob =>ob.PpInclVat);
if (DebitCredits.Count() > 0)
{
gvDebitsGredits.DataSource = DebitCredits;
gvDebitsGredits.DataBind();
}
}
}
Заранее спасибо.
Даррен
Пример вложенной сетки