forked from MapComplete/MapComplete
44 lines
1.5 KiB
TypeScript
44 lines
1.5 KiB
TypeScript
import DynamicTileSource from "./DynamicTileSource"
|
|
import { Store } from "../../UIEventSource"
|
|
import { BBox } from "../../BBox"
|
|
import TileLocalStorage from "../Actors/TileLocalStorage"
|
|
import { Feature } from "geojson"
|
|
import StaticFeatureSource from "../Sources/StaticFeatureSource"
|
|
|
|
export default class LocalStorageFeatureSource extends DynamicTileSource {
|
|
constructor(
|
|
backend: string,
|
|
layername: string,
|
|
zoomlevel: number,
|
|
mapProperties: {
|
|
bounds: Store<BBox>
|
|
zoom: Store<number>
|
|
},
|
|
options?: {
|
|
isActive?: Store<boolean>
|
|
maxAge?: number // In seconds
|
|
}
|
|
) {
|
|
const storage = TileLocalStorage.construct<Feature[]>(
|
|
backend,
|
|
layername,
|
|
options?.maxAge ?? 24 * 60 * 60
|
|
)
|
|
super(
|
|
zoomlevel,
|
|
(tileIndex) =>
|
|
new StaticFeatureSource(
|
|
storage.getTileSource(tileIndex).mapD((features) => {
|
|
if (features.length === undefined) {
|
|
console.trace("These are not features:", features)
|
|
storage.invalidate(zoomlevel, tileIndex)
|
|
return []
|
|
}
|
|
return features.filter((f) => !f.properties.id.match(/(node|way)\/-[0-9]+/))
|
|
})
|
|
),
|
|
mapProperties,
|
|
options
|
|
)
|
|
}
|
|
}
|