func renderCosts()

in internal/renderers/excel/cost.go [14:43]


func renderCosts(f *excelize.File, data *renderers.ReportData) {
	_, err := f.NewSheet("Costs")
	if err != nil {
		log.Fatal().Err(err).Msg("Failed to create Costs sheet")
	}

	records := data.CostTable()
	headers := records[0]
	createFirstRow(f, "Costs", headers)

	if data.Cost != nil && len(data.Cost.Items) > 0 {
		records = records[1:]
		currentRow := 4
		for _, row := range records {
			currentRow += 1
			cell, err := excelize.CoordinatesToCellName(1, currentRow)
			if err != nil {
				log.Fatal().Err(err).Msg("Failed to get cell")
			}
			err = f.SetSheetRow("Costs", cell, &row)
			if err != nil {
				log.Fatal().Err(err).Msg("Failed to set row")
			}
		}

		configureSheet(f, "Costs", headers, currentRow)
	} else {
		log.Info().Msg("Skipping Costs. No data to render")
	}
}