forked from MapComplete/MapComplete
		
	
		
			
				
	
	
		
			70 lines
		
	
	
	
		
			2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			70 lines
		
	
	
	
		
			2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import Script from "../Script"
 | |
| import { readFileSync, writeFileSync } from "fs"
 | |
| import { OsmId } from "../../src/Models/OsmFeature"
 | |
| import { Utils } from "../../src/Utils"
 | |
| 
 | |
| interface DiffItem {
 | |
|     /**
 | |
|      * Velopark-id
 | |
|      */
 | |
|     ref: string
 | |
|     osmid: OsmId
 | |
|     distance: number
 | |
|     diffs: {
 | |
|         key: string
 | |
|         /**
 | |
|          * The value in OpenStreetMap
 | |
|          * Might be undefined if OSM doesn't have an appropriate value
 | |
|          */
 | |
|         osm?: string
 | |
|         velopark: string | number
 | |
|     }[]
 | |
| }
 | |
| 
 | |
| export class DiffToCsv extends Script {
 | |
|     constructor() {
 | |
|         super(
 | |
|             "Converts a 'report.diff' to a CSV file for people who prefer LibreOffice Calc (or other Spreadsheet Software)"
 | |
|         )
 | |
|     }
 | |
| 
 | |
|     async main(args: string[]): Promise<void> {
 | |
|         const file = args[0] ?? "report_diff.json"
 | |
|         const json = <{ diffs: DiffItem[]; distanceBinds: number[] }>(
 | |
|             JSON.parse(readFileSync(file, "utf8"))
 | |
|         )
 | |
|         const diffs = json.diffs
 | |
|         const allKeys = Utils.Dedup(diffs.flatMap((item) => item.diffs.map((d) => d.key)))
 | |
|         allKeys.sort()
 | |
| 
 | |
|         const header = [
 | |
|             "osm_id",
 | |
|             "velopark_id",
 | |
|             "distance",
 | |
|             ...allKeys.flatMap((k) => ["osm:" + k, "velopark:" + k]),
 | |
|         ]
 | |
|         const lines = [header]
 | |
|         for (const diffItem of diffs) {
 | |
|             const line = []
 | |
|             lines.push(line)
 | |
|             line.push(diffItem.osmid)
 | |
|             line.push(diffItem.ref)
 | |
|             line.push(diffItem.distance)
 | |
| 
 | |
|             const d = diffItem.diffs
 | |
|             for (const k of allKeys) {
 | |
|                 const found = d.find((i) => i.key === k)
 | |
|                 if (!found) {
 | |
|                     line.push("", "")
 | |
|                     continue
 | |
|                 }
 | |
|                 line.push(found.osm, found.velopark)
 | |
|             }
 | |
|         }
 | |
|         const path = "report_diff.csv"
 | |
|         writeFileSync(path, lines.map((l) => l.join(",")).join("\n"), "utf8")
 | |
|         console.log("Written", path)
 | |
|     }
 | |
| }
 | |
| 
 | |
| new DiffToCsv().run()
 |