Skip to content

workletjs/workletjs

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

Workletjs - Angular Map Component Library

Workletjs is an Angular map component library that provides seamless integration with OpenLayers, enabling developers to create interactive and customizable maps with ease.

This library developed under the Nx monorepo architecture and documented using NgDoc.


πŸš€ Features

  • πŸ“Œ Built on OpenLayers - high-performance mapping engine
  • 🧱 Componentized architecture for interactive map development
  • 🧩 Built with Nx for scalable multi-project workspace
  • πŸ“˜ Component documentation powered by NgDoc
  • πŸ§ͺ Testable and maintainable design
  • 🌐 Ideal for multi-layer visualization, spatial analysis, and geospatial applications

πŸ›  Prerequisites

This library depends on the following peer dependencies:

Make sure these dependencies are installed in your project.

πŸ“¦ Installation

Install the peerDependencies.

npm install ol @angular/cdk --save  
// or
yarn add ol @angular/cdk
// or
pnpm add ol @angular/cdk

Install this library.

npm install @workletjs/ngx-openlayers --save
// or
yarn add @workletjs/ngx-openlayers
// or 
pnpm add @workletjs/ngx-openlayers

πŸ”¨ Usage

Import the component modules you want to use into your component.

import { WolMapModule } from '@workletjs/ngx-openlayers/map';
import { WolViewModule } from '@workletjs/ngx-openlayers/view';

@Component({
  imports: [WolMapModule, WolViewModule]
})
export class AppComponent {}

And import style file link in angular.json.

{
  "styles": [
+    "node_modules/ol/ol.css"
  ]
}

✨ Example

Here is a simple map with an OSM source.

import { Component } from '@angular/core';
import { WolTileLayerModule } from '@workletjs/ngx-openlayers/layer/tile';
import { WolMapModule } from '@workletjs/ngx-openlayers/map';
import { WolOSMSourceModule } from '@workletjs/ngx-openlayers/source/osm';
import { WolViewModule } from '@workletjs/ngx-openlayers/view';

@Component({
  selector: 'app-root',
  imports: [WolMapModule, WolViewModule, WolTileLayerModule, WolOSMSourceModule],
  template: `
    <wol-map>
      <wol-view [wolCenter]="[0, 0]" [wolZoom]="2" />
      <wol-tile-layer>
        <wol-osm-source />
      </wol-tile-layer>
    </wol-map>
  `,
  styles: `
    :host > wol-map {
      height: 400px;
    }
  `,
})
export class AppComponent {}

πŸ“– Naming Conventions

  • Component selector prefix: wol-*

  • Input property prefix: wol* (e.g. wolControls, wolLayers)

  • Output event prefix: wol* (e.g. wolClick, wolViewChange)

β˜€οΈ License

GitHub license

About

πŸ“¦ A modern map component library built with Angular and OpenLayers

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages