npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

@mxtommy/kip

v4.8.0

Published

An advanced and versatile marine instrumentation package to display Signal K data.

Readme

KIP – Signal K Multi-Function Display (MFD) and Marine Instrument Panel

Help Docs Community Videos Contact

KIP is the most popular Signal K MFD and marine instrument panel: plug-and-play, touch-optimized, pre-installed, and ready-to-use across all devices.

Unlike many instrument panels, KIP offers full MFD functionality and is automatically included with Signal K distributions, so there’s nothing extra to install or configure. Simply start your Signal K server, open KIP in a browser, and it’s ready to go. A single instance works everywhere — no per‑device deployment is needed.

KIP is designed for sailors and boaters who want:

  • A ready-to-use, classic marine app experience with minimal setup.
  • A modern, polished interface optimized for marine displays.
  • Touch-optimized design: touch-first, intuitive design for tablets, phones, and other touch-enabled devices.
  • Cross-platform support: runs on phones, tablets, laptops, Raspberry Pi, Web Enabled TV or other fixed displays - anywhere you can run a web browser.
  • Instant access to all Signal K data: displays gauges, charts, switches, and other widgets right out of the box.
  • Flexible dashboards: customize layouts, drag-and-drop widgets, night/day mode, kiosk/fullscreen and remote control support.

With KIP, you get the familiar feel of professional Multi-Function Displays combined with the flexibility of Signal K. It’s simple, reliable, and highly usable — the ultimate ready-to-go, modern, touch-first, Multi-Function Display for Signal K vessels.

KIP

Table of Content

Installations Showcase

Form factor support In addition to the obvious navstation, wall mounted instrument panel and autopilot remote control usecases using PCs, tablets and phones, users have taken KIP into the elements using Raspberry Pi, Pi Zero, rugged tablets and all kinds of low cost AliExpress screens and industry leading, high quality, sunlight readable marine touch screens. KIP's native remote control feature opens up all kinds of possibilities.

Read the Help Introduction How-To

You just installed KIP and you're stuck; read the Introduction help file.

Design Goal

The goal is to replicate and enhance the functionality of modern marine instrumentation displays while providing unmatched customization and flexibility. The design principles include:

  • Full-Screen Utilization: Ensure the display uses the entire screen without requiring scrolling, maximizing visibility, usability reducing onscreen control clutter.
  • Optimized for Readability: Present data in a large, clear, and easily interpretable format to ensure quick comprehension. Utilize high-contrast color schemes to enhance visibility, especially in bright daylight conditions.
  • Touchscreen Excellence: Deliver an intuitive and seamless experience for touchscreen users, with support for gestures like swiping and tapping.
  • Cross-Device Compatibility: Guarantee a consistent and responsive experience across phones, tablets, computers, and other devices.
  • Modern Browser Support: Include support for the latest versions of Chromium and other modern web browsers to ensure optimal performance and compatibility.

Form factor support

User Experience

Interactions

  • Swipe up and down to navigate through your dashboards effortlessly.
  • Swipe left and right to access notifications and other system features quickly.
  • Use keyboard shortcuts for essential features, ensuring fast and efficient navigation across devices types.

Customize

  • Effortlessly create and customize dashboards using an intuitive grid layout system.
  • Add, resize, and align widgets to design tailored displays for your specific needs.
  • Duplicate widgets or entire dashboards, including their configurations, with a single click.
  • Simply drag dashboards to reorganize them. Double-click any dashboard to open the icon gallery and give each page a unique visual identity.
  • Easily switch between multiple user and device configurations profiles for different roles, formfactors or use cases.

Sidenav for quick access to all important features. Sidenav Dashboard Access

Chartplotter Mode with dashboards Chartplotter Mode

Dashboards and Configuration

Customizable and Easy

Meant to build purposeful dashboards with however many widgets you want, wherever you want them.

Add, resize, and position the widgets of your choosing. Need more? Add as many additional dashboards as you wish to keep your display purposeful. Simply swipe up and down to quickly cycle through dashboards or effortlessly jump between dashboards with a single tap in the action sidenav, always knowing exactly where you are thanks to clear highlighting of your current dashboard.

Widget lists are sorted by category. Layouts Configuration Image

Intuitive widget configuration. Gauges Configuration Image

See what Signal K has to offer that you can leverage with widgets. Select it and tweak the display options to suit your purpose. Paths Configuration Image

Many units are supported. Choose your preferred app defaults, then tweak them widget-by-widget as necessary. KIP will automatically convert the units for you. Units Configuration Image

Organize your dashboards and access tools. Options and Dashboards

Widget Library

All KIP widgets are visual presentation controls that are very versatile, with multiple advanced configuration options available to suit your needs:

  • Compact Linear – Simple horizontal linear gauge with a large value label and modern look.
  • Linear – Horizontal or vertical linear gauge with zone highlighting.
  • Radial – Radial gauge with configurable dials and zone highlighting.
  • Compass – Rotating compass gauge with multiple cardinal indicator options.
  • Level Gauge – Dual-scale heel angle indicator for trim tuning and sea-state monitoring.
  • Pitch & Roll – Horizon-style attitude indicator showing live pitch and roll degrees.
  • Classic Steel – Traditional steel-look linear & radial gauges with range sizes and zone highlights.
  • Windsteer – Combines wind, wind sectors, heading, COG, and waypoint info for wind steering.
  • Wind Trends – Real-time True Wind trends with dual axes for direction and speed, live values, and averages.
  • Battery Monitor - Display batteries or whole banks state State of Charge, remaining capacity, remaining time, voltage, current, power flow, and temperature.
  • Solar Charger- Track solar generation and charging performance at a glance with live panel output, battery-side metrics, and clear charger and relay status indicators.
  • AC/DC Charger- Monitor charging performance at a glance with a compact AC/DC Charger Widget. View single or multiple chargers with charge mode, voltage, current, power and temperature. Chargers are discovered automatically.
  • Freeboard-SK – Adds the Freeboard-SK chart plotter as a widget with automatic sign-in.
  • Autopilot Head – Typical autopilot controls for compatible Signal K Autopilot devices.
  • Realtime Data Chart – Visualizes data on a real-time chart with actuals, averages, and min/max.
  • AIS Radar: Display AIS targets with range rings, interactive target details, and quick zoom and filtering controls.
  • Embed Webpage Viewer – Embeds external web apps (Grafana, Node-RED, etc.) into your dashboard.
  • Racesteer – Race steering display fusing polar performance data with live conditions for optimal tactics.
  • Racer - Start Line Insight – Set and adjust start line ends, see distance, favored end, and line bias; integrates with Freeboard SK.
  • Racer - Start Timer – Advanced racing countdown timer with OCS status and auto dashboard switching.
  • Countdown Timer – Simple race start countdown timer with start, pause, sync, and reset options.

Get the latest version of KIP to see what's new!

Widget Samples

Gauges sample Sample Gauges Image

Various other types of widgets Electrical Concept Image

Freeboard-SK Chartplotter integration with Autopilot widget Freeboard-SK Image

Grafana integration with other widgets Embedded Webpage Concept Image

Historical Data

Experience effortless insight into your vessel’s past with KIP’s Widget Historical Charts—automatically track, store, and visualize key data, unlocking instant access charts showing up to the last full day of performance. Whether you’re sailing or docked, simply two-finger tap or right-click widgets to reveal a seamless history dialog—no setup, no clutter, just the trends you need. When combining data visualisation using Data Driven widgets, live-to-history transitions, KIP puts your boat’s story at your fingertips—so you can make smarter decisions, spot patterns, and sail with confidence.

Night Modes

Keep your night vision with automatic or manual day and night switching to a color preserving dim mode or an all Red theme. The images below look very dark, but at night... they are perfect!

Night mode - All Red

Night mode - Brightness

Chartplotter Mode

Keep a live Freeboard‑SK chart visible while switching dashboards for an MFD‑style workflow. The chart persists (no reload or flicker), you can choose its side, collapse it per‑dashboard for full data pages, and drag resize the split. Layout auto‑stacks in portrait / narrow screens. See the dedicated Chartplotter Mode help page for setup, performance tips, and troubleshooting.

Remote Control Other KIP Displays

Control which dashboard is shown on another KIP instance (e.g., a mast display, hard-to-reach screen, or a non‑touch device) from any KIP, including your phone.

Use cases

  • Mast display: change dashboards from the cockpit.
  • Wall/helm screens: toggle dashboards without standing up or reaching for controls.
  • Non‑touch/no input: select dashboards when no keyboard/mouse is connected or touch is not supported/disabled.

Dedicated Fullscreen instrument display (Kiosk Mode)

Runs KIP on Raspberry Pi as a single full-screen application, suppresses the desktop UI and stays on screen like a dedicated chartplotter or marine instrument panel at a fraction of the cost. Read the Kiosk Mode help file.

Progressive Web App PWA

Run KIP without browser controls, just like a native computer, tablet or phone app. This feature is supported on most mobile operating systems and desktop browser. It freezes up screen real estate and offers a native Android and iOS app experience with single icon launch. Follow your browser's instructions to install Progressiver Web Apps. It's usually just a few clicks, such as "Add to Home Screen".

Multiple User Configurations

If you have different roles on board: captain, skipper, tactician, navigator, engineer—or simply different people with different needs, each can tailor KIP as they wish. The use of profiles also allows you to tie specific configuration arrangements to use cases or device form factors.

Complementary Components

Typical complementary components you may install (most are often bundled with Signal K distributions):

Navigation & Charting

  • Freeboard‑SK (pre-installed) – Multi‑station, web chart plotter dedicated to Signal K: routes, waypoints, charts, alarms, weather layers, and instrument overlays.

Visual Flow / Automation

  • Node‑RED – Low‑code, flow‑based wiring of devices, APIs, online services, and custom logic (alert escalation, device control automation, data enrichment, protocol bridging).

Data Storage & Analytics

  • InfluxDB / other TSDB – High‑resolution historical storage of sensor & performance metrics beyond what lightweight widget charts should retain.
  • Grafana – Rich exploratory / comparative dashboards, ad‑hoc queries, alert rules on stored metrics, correlation across heterogeneous data sources.

Harness the Power of Data State Notifications

Stay informed with notifications about the state of the data you are interested in. For example, Signal K will notify KIP when a water depth or temperature sensor reaches certain levels. In addition to KIP's centralized notification menu, individual widgets offer tailored visual representations appropriate to their design objectives, providing an optimal user experience.

How To Contribute

KIP is under the MIT license and is built with Node and Angular using various open-source assets. All free!

Project Scope

What KIP IS about:

  • Real‑time presentation of vessel & environment data (navigation, performance, systems) pulled from Signal K.
  • Fast, legible, touchscreen‑friendly dashboards for underway decision making.
  • Configurable widgets (gauges, charts, timers, controls) tuned for sailing operations.

What KIP deliberately IS NOT trying to become:

  • A full data lake / long‑term time‑series historian.
  • A general purpose automation / rules / orchestration engine.
  • A universal external web‑app embedding or mash‑up framework.
  • A low‑code integration hub for arbitrarily wiring protocols and services.

Those domains already have excellent, specialized open‑source tools. Instead of re‑implementing them, KIP plays nicely alongside them within a Signal K based onboard stack.

Processing, Extensions and Widgets

Signal K Plugins

Domain‑specific enrichment (polars, performance calculations, derived environmental data, routing aids) published directly into the Signal K data model that KIP can then display.

KIP Widgets

Visual data representation component that use Signal K path data and API V2 features. Scaffolding a new widgets only takes a few moments and is backed by KIP AI agent instructions providing willed creative minds a personal assistant programmer.

Run one simple command (example):

npm run generate:widget

or ask your AI to create a widget using the KIP project AI instructions.

For deeper details you can still look at COPILOT.md, but you don’t need to in order to get started.

Why this separation matters

Keeping KIP focused preserves responsiveness (lower CPU / memory), reduces UI clutter, and accelerates core sailing user experience development. Heavy analytics, complex workflow logic, and broad third‑party embedding stay where they are strongest—outside—but still feed KIP through the common Signal K data fabric.

In short: use KIP to see & act on live sailing information; use the complementary tools to store it long‑term, analyze it deeply, automate decisions, or build advanced integrations.

Getting Started

Linux, Mac, RPi, or Windows dev platform supported

  1. Download your favorite coding IDE (we use the free Visual Studio Code)
  2. Create your own GitHub KIP fork.
  3. Configure your IDE's source control to point it to your forked KIP instance (Visual Studio Code, GitHub support is built-in) and get the fork's master branch locally.
  4. Install npm and node. On macOS, you can use brew install node if you have Homebrew. See https://nodejs.org/en/download for more options.
  5. Install the Angular CLI using npm install -g @angular/cli

Project Setup

  1. From your fork's master branch, create a working branch with a name such as: new-widget-abc or fix-issue-abc, etc.
  2. Check out this new branch.
  3. In a command shell (or in the Visual Studio Code Terminal window), go to the root of your local project folder, if not done automatically by your IDE.
  4. Install project dependencies using the NPM package and dependency manager: run npm install. NPM will read the KIP project dependencies, download, and install everything automatically for you.
  5. Build the app locally using Angular CLI: from that same project root folder, run npm run build:all. The CLI tool will build KIP.

Code and Test

  1. Fire up your local KIP development instance with npm run dev.
  2. Hit Run/Start Debugging in Visual Studio Code or manually point your favorite browser to http://localhost:4200/@mxtommy/kip. Alternatively, to start the development server and allow remote devices connections, such as with your phone or RPi (blocked for security reasons by default):
    ng serve --configuration=dev --serve-path=/@mxtommy/kip/ --host=<your computer's IP> --port=4200
  3. Voila!

As you work on source code and save files, the app will automatically reload in the browser with your latest changes.
You will also need a running Signal K server for KIP to connect to and receive data. You could also use https://demo.signalk.org but without authentication enabled, your actions, features and test coverage will be limited.

Apple PWA Icon Generation

Use the following tool and command line:
npx pwa-asset-generator ./src/assets/favicon.svg ./src/assets/ -i ./src/index.html -m ./src manifest.json -b "linear-gradient(to bottom, rgba(255,255,255,0.15) 0%, rgba(0,0,0,0.15) 100%), radial-gradient(at top center, rgba(255,255,255,0.40) 0%, rgba(0,0,0,0.40) 120%) #989898" -p 5%

Share

Once done with your work, from your fork's working branch, make a GitHub pull request to have your code reviewed, merged, and included in the next release. It's always optimal to sync with us prior to engaging in extensive new development work.

Development Instructions & Guidelines Documentation

For comprehensive development guidance, please refer to these instruction files:

Primary Instructions

  • Project Instructions: KIP policy owner for architecture/domain rules, including widget creation and Host2 contracts.
  • COPILOT.md: Architecture context, rationale, and evolution notes (non-policy).
  • Angular Instructions: Modern Angular v21+ coding standards, component patterns, and framework best practices.
  • Copilot Agent Instructions: Architecture details and coding-agent guardrails for this repository.

Development Workflow

  1. Start Here: Read .github/instructions/project.instructions.md for KIP policy contracts.
  2. Angular Standards: Follow .github/instructions/angular.instructions.md for modern Angular development.
  3. Architecture Context: Use COPILOT.md for rationale and dated architecture notes.
  4. Setup & Build: Use this README for project setup and build commands.

Widget Creation Workflow

  1. Scaffold with npm run generate:widget (Host2 schematic-first path).
  2. Use docs/widget-schematic.md for CLI flags, prompting behavior, and troubleshooting.
  3. Follow Host2 runtime/stream patterns in .agents/skills/kip-host2-widget/SKILL.md.
  4. Apply widget creation implementation checklist from .agents/skills/kip-widget-creation/SKILL.md.
  5. Keep enforceable behavior aligned with .github/instructions/project.instructions.md (Widget Creation Domain Rules).

Key Priorities

  • Widget Development: Use Host2 patterns and scaffold with the create-host2-widget schematic (see docs/widget-schematic.md).
  • Angular Patterns: Use signals, standalone components, and modern control flow.
  • Theming: Follow KIP's theme system for consistent UI.
  • Code Quality: Run npm run lint before commits.

KIP is open-source under the MIT license, built by the community and 100% free. Join the community on Discord or contribute to the project on GitHub!

Connect, Share, and Support

KIP has its own Discord Signal K channel for getting in touch. Join us at https://discord.gg/AMDYT2DQga

Features, Ideas, Bugs

See KIP's GitHub project for the latest feature requests: https://github.com/mxtommy/Kip/issues

This repository may not be used to train machine learning or AI models without explicit permission from the author.