1.8.0 â€ĸ Published 4 months ago

s2json-spec v1.8.0

Weekly downloads
-
License
MIT
Repository
github
Last release
4 months ago

About

S2JSON is a format for encoding a variety of geographic data structures that simplifies the GeoJSON spec and builds ontop of it to include S2 Geometry.

Notable features of S2JSON are:

  • Properties data is clearly defined on how it can be shaped.
  • 🧊 Support for 3D geometries.
  • đŸˇī¸ Support for metadata.
  • ♏ Support for M-Values for each geometry point.
  • đŸ“Ļ Support for bounding boxes
  • đŸĢĨ Updated spec to handle vector structures.
  • 🔨 Tools for converting between GeoJSON, S2JSON, and quad-tree Tile structures
  • đŸĒŠ Support for S2Feature and S2FeatureCollection types based upon the S2 Geometry spherical projection.
  • â™ģī¸ Feature Properties & M-Values are defined in scope to ensure they can be easily processed by lower level languages as structures, but also adds value to other projects down the line.
  • 🛑 GeoJSON no longer supports GeometryCollection.
  • 📝 Attribution can be added to either a FeatureCollection or S2FeatureCollection
// GeoJSON example
{
  "type": "Feature",
  "geometry": {
    "type": "Point",
    "coordinates": [125.6, 10.1]
  },
  "properties": {
    "name": "Dinagat Islands"
  }
}
// GeoJSON Vector example
{
  "type": "VectorFeature",
  "geometry": {
    "type": "Point",
    "coordinates": { x: 125.6, y: 10.1 }
  },
  "properties": {
    "name": "Dinagat Islands"
  }
}
// S2JSON example
{
  "type": "S2Feature",
  "face": 0,
  "geometry": {
    "type": "Point",
    "coordinates": { x: 0.5, y: 0.5 }
  },
  "properties": {
    "name": "Null Island"
  }
}

Read The Spec

s2json-spec

Implementations

Install

# bun
bun add -D s2json-spec
# pnpm
pnpm add -D s2json-spec
# yarn
yarn add -D s2json-spec
# npm
npm install -D s2json-spec

# cargo
cargo install s2json --dev

grammars/highlighting for VSCode are available for install.


Development

Requirements

You need the tool tarpaulin to generate the coverage report. Install it using the following command:

cargo install cargo-tarpaulin

The bacon coverage tool is used to generate the coverage report. To utilize the pycobertura package for a prettier coverage report, install it using the following command:

pip install pycobertura

Validated Your Data

Note: Be sure to set resolveJsonModule: true in your tsconfig.json to ensure json may be loaded as a module.

import Ajv from 'ajv';
import * as schema from 's2json-spec/s2json.schema.json'; // Path to the schema

import type { Feature } from 's2json-spec';

const ajv = new Ajv();
const validate = ajv.compile(schema);

const feature: Feature = {
  type: 'Feature',
  geometry: {
    type: 'Point',
    coordinates: [125.6, 10.1]
  },
  properties: {
    name: 'Dinagat Islands'
  },
};

validate(feature); // true

Running Tests

To run the tests, use the following command:

# TYPESCRIPT
## basic test
bun run test
## live testing
bun run test:dev

# RUST
## basic test
cargo test
# live testing
bacon test

Generating Coverage Report

To generate the coverage report, use the following command:

cargo tarpaulin
# bacon
bacon coverage # or type `l` inside the tool
1.7.3

6 months ago

1.7.2

6 months ago

1.8.0

4 months ago

1.7.1

6 months ago

1.6.2

6 months ago

1.7.0

6 months ago

1.6.1

6 months ago

1.7.5

5 months ago

1.7.4

5 months ago

1.5.5

10 months ago

1.5.4

10 months ago

1.5.3

10 months ago

1.5.2

10 months ago

1.6.0

9 months ago

1.5.1

10 months ago

1.5.0

10 months ago

1.4.1

10 months ago

1.4.0

10 months ago

1.3.1

11 months ago

1.3.0

11 months ago

1.2.0

11 months ago

1.1.0

1 year ago

1.0.2

1 year ago

1.0.1

1 year ago

1.0.0

1 year ago