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

webxdc-types

Package Overview
Dependencies
Maintainers
3
Versions
4
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

webxdc-types

TypeScript type definitions for webxdc

  • 1.0.1
  • latest
  • npm
  • Socket score

Version published
Weekly downloads
475
increased by85.55%
Maintainers
3
Weekly downloads
 
Created
Source

Types for webxdc

When you develop a webxdc app, you use the webxdc API to communicate with other instances of the same webxdc application.

The API is available on window.webxdc.

When you develop your webxdc app in TypeScript, it's handy to have proper types for this API. This library provides those types for you.

Why use this?

  • you want better autocomplete in your IDE (js and ts)
  • you want to see docuemntation on hover in your IDE (js and ts)
  • you need types for typescript typechecking

Usage

You can install this using:

npm install -D webxdc-types
Usage in Typescript with typed payload (Recommended)

You should have a type that describes your webxdc payload structure in use by your application:

type Payload = {
  label: string;
  value: number;
};

Once you have a Payload type, you can declare the type of window.webxdc in your application:

import { WebXdc } from "webxdc-types";

declare global {
  interface Window {
    webxdc: WebXdc<Payload>;
  }
}

(write this in a file that is picked up by the typescript compiler, paths like src/types.d.ts or src/global.d.ts should work)

Now window.webxdc should be fully typed.

Usage in Typescript without payload typing

Use this if you just want completions for the api, but not for the status update payloads, they will get the any type with this method.

import "webxdc-types/global";
// or
/// <reference types="webxdc-types/global" />

Now window.webxdc should be typed.

usage in plain javascript files (jsdoc)

If your IDE supports it (vscode and it's forks do), you can add //@ts-check to the top of your javascript file to enable typescript type checking for it.

you can then type variables like this

//@ts-check

/** @type {number} documentation of the value */
const my_var = 8;

You can use this to import the webxdc types when you need them to type your functions:

/**
 * @typedef {any} MyPayload
 * @typedef {import('webxdc-types').XDCFile} XDCFile
 * @typedef {import('webxdc-types').ReceivedStatusUpdate<MyPayload>} ReceivedStatusUpdate
 * @typedef {import('webxdc-types').SendingStatusUpdate<MyPayload>} SendingStatusUpdate
 * @typedef {import('webxdc-types').Webxdc<MyPayload>} Webxdc
 */
// note that this does not set `window.webxdc` for you follow the steps below for that.

Without typed payloads

If you just want the api and not want to type your payloads you can import the types for window.webxdc like this:

/** @typedef {import('webxdc-types/global')} */

With typed payloads

For this you need to create a mytypes.d.ts file declaring your payload type:

import { WebXdc } from "webxdc-types";

// do your own payload type here
type Payload = {
  label: string;
  value: number;
};

declare global {
  interface Window {
    webxdc: WebXdc<Payload>;
  }
}

Then import this file like this:

/** @typedef {import('./my_types')} */
usage without package manager (npm, yarn, pnpm and so on.)

Copy global.d.ts and webxdc.d.ts files into your project and use one of the methods above, adjusting the import path acordingly.

/** @typedef {import('./global')} */
/** @typedef {import('./webxdc')} */

You can also combine the two files if you have basic knowledge of typescript.

Keywords

FAQs

Package last updated on 19 Oct 2023

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