func renderImpactedResources()

in internal/renderers/excel/impacted.go [14:45]


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

	records := data.ImpactedTable()
	headers := records[0]
	createFirstRow(f, sheetName, headers)

	if len(records) > 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(sheetName, cell, &row)
			if err != nil {
				log.Fatal().Err(err).Msg("Failed to set row")
			}
			setHyperLink(f, sheetName, 18, currentRow)
		}

		configureSheet(f, sheetName, headers, currentRow)
	} else {
		log.Info().Msgf("Skipping %s. No data to render", sheetName)
	}
}