MapComplete/Logic/Osm/Actions/CreateMultiPolygonWithPointReuseAction.ts

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

109 lines
3.9 KiB
TypeScript
Raw Normal View History

2022-09-08 21:40:48 +02:00
import { OsmCreateAction } from "./OsmChangeAction"
import { Tag } from "../../Tags/Tag"
import { Changes } from "../Changes"
import { ChangeDescription } from "./ChangeDescription"
import FeaturePipelineState from "../../State/FeaturePipelineState"
import FeatureSource from "../../FeatureSource/FeatureSource"
import CreateNewWayAction from "./CreateNewWayAction"
import CreateWayWithPointReuseAction, { MergePointConfig } from "./CreateWayWithPointReuseAction"
import { And } from "../../Tags/And"
import { TagUtils } from "../../Tags/TagUtils"
/**
* More or less the same as 'CreateNewWay', except that it'll try to reuse already existing points
*/
export default class CreateMultiPolygonWithPointReuseAction extends OsmCreateAction {
2022-09-08 21:40:48 +02:00
public newElementId: string = undefined
public newElementIdNumber: number = undefined
private readonly _tags: Tag[]
private readonly createOuterWay: CreateWayWithPointReuseAction
2022-01-26 21:40:38 +01:00
private readonly createInnerWays: CreateNewWayAction[]
2022-09-08 21:40:48 +02:00
private readonly geojsonPreview: any
private readonly theme: string
private readonly changeType: "import" | "create" | string
2022-01-26 21:40:38 +01:00
2022-09-08 21:40:48 +02:00
constructor(
tags: Tag[],
outerRingCoordinates: [number, number][],
innerRingsCoordinates: [number, number][][],
state: FeaturePipelineState,
config: MergePointConfig[],
changeType: "import" | "create" | string
) {
2022-09-08 21:40:48 +02:00
super(null, true)
this._tags = [...tags, new Tag("type", "multipolygon")]
this.changeType = changeType
2022-02-22 14:13:41 +01:00
this.theme = state?.layoutToUse?.id ?? ""
2022-09-08 21:40:48 +02:00
this.createOuterWay = new CreateWayWithPointReuseAction(
[],
outerRingCoordinates,
state,
config
)
this.createInnerWays = innerRingsCoordinates.map(
(ringCoordinates) =>
new CreateNewWayAction(
[],
ringCoordinates.map(([lon, lat]) => ({ lat, lon })),
{ theme: state?.layoutToUse?.id }
)
)
2022-01-26 21:40:38 +01:00
this.geojsonPreview = {
type: "Feature",
properties: TagUtils.changeAsProperties(new And(this._tags).asChange({})),
2022-01-26 21:40:38 +01:00
geometry: {
type: "Polygon",
2022-09-08 21:40:48 +02:00
coordinates: [outerRingCoordinates, ...innerRingsCoordinates],
},
}
}
public async getPreview(): Promise<FeatureSource> {
const outerPreview = await this.createOuterWay.getPreview()
outerPreview.features.data.push({
freshness: new Date(),
2022-09-08 21:40:48 +02:00
feature: this.geojsonPreview,
})
2022-01-26 21:40:38 +01:00
return outerPreview
}
protected async CreateChangeDescriptions(changes: Changes): Promise<ChangeDescription[]> {
console.log("Running CMPWPRA")
const descriptions: ChangeDescription[] = []
2022-09-08 21:40:48 +02:00
descriptions.push(...(await this.createOuterWay.CreateChangeDescriptions(changes)))
for (const innerWay of this.createInnerWays) {
2022-09-08 21:40:48 +02:00
descriptions.push(...(await innerWay.CreateChangeDescriptions(changes)))
}
2022-09-08 21:40:48 +02:00
this.newElementIdNumber = changes.getNewID()
2022-01-26 21:40:38 +01:00
this.newElementId = "relation/" + this.newElementIdNumber
descriptions.push({
2022-01-26 21:40:38 +01:00
type: "relation",
id: this.newElementIdNumber,
tags: new And(this._tags).asChange({}),
meta: {
theme: this.theme,
2022-09-08 21:40:48 +02:00
changeType: this.changeType,
},
changes: {
members: [
{
type: "way",
ref: this.createOuterWay.newElementIdNumber,
2022-09-08 21:40:48 +02:00
role: "outer",
},
// @ts-ignore
2022-09-08 21:40:48 +02:00
...this.createInnerWays.map((a) => ({
type: "way",
ref: a.newElementIdNumber,
role: "inner",
})),
],
},
})
2022-01-26 21:40:38 +01:00
return descriptions
}
2022-09-08 21:40:48 +02:00
}