MiniExcel icon indicating copy to clipboard operation
MiniExcel copied to clipboard

Hide sheets if Data is empty - using template (SaveAsByTemplateAsync)

Open Gilcemir opened this issue 1 year ago • 0 comments

Excel Type

  • [X] XLSX
  • [ ] XLSM
  • [ ] CSV
  • [ ] OTHER

Upload Excel File

Template.xlsx

MiniExcel Version

1.32.1

Description

Please attach your issue file by dragging or droppng, selecting or pasting them.

Hi, Im trying to hide sheets if the data is empty. For example, for the sheet "Mensalidades", if there's nothing to fill the template sheet, I want to hide it.

I did something like this:

        var configuration = new OpenXmlConfiguration()
        {
            IgnoreTemplateParameterMissing = true
        };
        var sheets = HideSheetsIfEmpty(eventData);
        if(sheets.Any())
        {
            configuration.DynamicSheets = sheets;
        }
                await using var memoryStream = new MemoryStream();
        await memoryStream.SaveAsByTemplateAsync(template, value, configuration);
        memoryStream.Seek(0, SeekOrigin.Begin);

        return memoryStream.ToArray();

where:

    private DynamicExcelSheet[] HideSheetsIfEmpty(TransferReportCreatedArgs eventData)
    {
        var sheets = new List<DynamicExcelSheet>();
        if (!eventData.Adjusts.Any())
        {
            sheets.Add(new DynamicExcelSheet(sheetNames["adjust"]) { Name = sheetNames["adjust"], State = SheetState.Hidden });
        }
        if (!eventData.Mensals.Any())
        {
            sheets.Add(new DynamicExcelSheet(sheetNames["mensal"]) { Name = sheetNames["mensal"], State = SheetState.Hidden });
        }
        if (!eventData.Retentions.Any())
        {
            sheets.Add(new DynamicExcelSheet(sheetNames["retention"]) { Name = sheetNames["retention"], State = SheetState.Hidden });
        }
        if (!eventData.OtherProducts.Any())
        {
            sheets.Add(new DynamicExcelSheet(sheetNames["other"]) { Name = sheetNames["other"], State = SheetState.Hidden });
        }
        if (!eventData.Gateways.Any())
        {
            sheets.Add(new DynamicExcelSheet(sheetNames["educbankgateway"]) { Name = sheetNames["educbankgateway"], State = SheetState.Hidden });
        }
        return sheets.ToArray();
    }

Is it possible in any way? Or this configuration is only available for non-template methods?

Gilcemir avatar Aug 21 '24 14:08 Gilcemir