Как мне суммировать столбец суммы и обновлять родительскую сетку - PullRequest
0 голосов
/ 09 июля 2019

Я новичок в 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();
                }
            }
        }

Заранее спасибо. Даррен

Пример вложенной сетки

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...