Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@globalfishingwatch/layer-composer

Package Overview
Dependencies
Maintainers
3
Versions
211
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@globalfishingwatch/layer-composer

The LayerManager orchestrates various **Layer Generators** in order to generate an entire Mapbox GL Style document that can be used with Mapbox GL and/or react-map-gl.

  • 9.2.3
  • npm
  • Socket score

Version published
Weekly downloads
105
decreased by-0.94%
Maintainers
3
Weekly downloads
 
Created
Source

LayerManager initial proposal

The LayerManager orchestrates various Layer Generators in order to generate an entire Mapbox GL Style document that can be used with Mapbox GL and/or react-map-gl.

API

LayerManager.constructor

new LayerManager(config?)

LayerManager.config

{
    generators: Generator[],
    glyphs: string,
    sprites: string
}

Instanciates a new Layer Manager that will use the provided Layer Generators.

LayerManager.getEvent (to be implemented)

Draft

`layerManager.getEvent(event: GLEvent): GFWEvent`.

Converts a native Mapbox GL event into a GFW event to be used in clients (takes into account popup info, variable formatting, priority, etc).

LayerManager.setZIndices (To be implemented)

LayerManager.getGLStyle

Converts provided LayerDefinitions, using Generators, to a usable Mapbox GL JSON style object.

layerManager.getGLStyle(layers: LayerDefinition[]): { GLStyle, [promises] }

Returns the sync glStyle and an array of promises when async layers are loaded which will pass the updated GLStyle and the layer as params when layer is ready

LayerDefinition.type

String. Mandatory. Use constants stored in the generator.

import { Generators } from '@globalfishingwatch/layer-composer'

Generators.Types

LayerDefinition.id

String. Must be specified if several layers from the same generator are to be used, otherwise the type will be used as id.

Generator.constructor

new Generator(config?): void

Generators define, for a varying set of any inputs, a way to generate both GL source(s) and layer(s) for a given type of layer.

Generators each contain the styling information they need, which can take the form of a customizable bit of GL style json, or something entirely dynamic.

See Generators section below.

Generator.type

String. Mandatory. Defines uniquely the type of each generator, required in layer types

Generator.getStyle

generator.getStyle(layer: LayerDefinition): { id: string, layers: GLLayer[], sources: GLSource[] }

Returns an object with the unique identifier and an array of sources and layers needed by the layers.

React Component

The Layer Manager Component is a React component that takes a ReactMapGL component as a child and pass its props using the render props pattern.

Parameters availables:

  • mapStyle
  • loading

import LayerManager, { Generators } from '@globalfishingwatch/layer-composer'
import defaultGenerators from '@globalfishingwatch/layer-composer/generators'

// optional step as common generators will be used by default
const generators = { ...defaultGenerators, { custom: new CustomGenerator()} }

<LayerManager
  config={{
      generators
  }}
  layers={[
    {
      type: Generators.Types.BACKGROUND,
      color: '#00265c',
    },
    {
      type: Generators.Types.BASEMAP,
      id: 'satellite',
    },
    {
      type: Generators.Types.CARTO_POLYGONS,
      id: 'RFMO',
      color: '#ff00ff',
    },
  ]}
  onClick={(event) => {
    setState...
  }}
>
{(mapStyle, loading, onClick, onHover, cursor) => {
    return <ReactMapGL
      mapStyle={mapStyle}
      onClick={onClick}
      onHover={onHover}
      cursor={cursor}
      ...

    />
  }}
</LayerManager>

React Hooks

There is a React hook to consume this library to get the mapStyles definition easily in react applications:

import { useLayerComposer } } from '@globalfishingwatch/react-hooks'

const { style, loading} = useLayerManager(layers, config)

Generators

To be defined

Background

Basemap

CartoPolygons

WMS

FishingActivity

VesselTracks

Events

Ruler

FAQs

Package last updated on 17 Sep 2021

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc