Awesome
@dojo/interfaces
<!-- [![codecov](https://codecov.io/gh/dojo/interfaces/branch/master/graph/badge.svg)](https://codecov.io/gh/dojo/interfaces) [![npm version](https://badge.fury.io/js/@dojo/interfaces.svg)](http://badge.fury.io/js/@dojo/interfaces) -->This package contain TypeScript interfaces and types that are widely used across Dojo 2 packages. It is designed to make it easier to maintain these interfaces as well as build code that integrates well with the rest of the Dojo 2 packages without requiring a hard dependency on those other packages.
WARNING This package is deprecated in favor of functionality found elsewhere in Dojo 2.
Usage
To use @dojo/interfaces
install the package:
npm install @dojo/interfaces
Features
bases
Evented
and Destroyable
interfaces, which are used throughout many packages, specifically@dojo/core
and @dojo/widget-core
.
Evented
defines an interface for objects that emit events, while Destroyable
defines an interface for objects that have own
and destroy
methods.
core
Common, foundational interfaces used widely throughout most Dojo 2 packages. Includes Handle
and event related interfaces EventObject
, and EventTargettedObject
.
loader
Interfaces for working with @dojo/loader
. If the loader is included on the page, you can reference the loader with:
import { DojoRequire } from '@dojo/interfaces/loader';
declare const require: DojoRequire;
require(['some-module'], (someModule) => {
});
shim
Thenable
and ArrayLike
interfaces. Thenable
will allow you to use promise-like objects without pulling in @dojo/shim
.
vdom
A set of interfaces for working with widgets and the virtual DOM. To work with a VNode
:
import { VNode } from '@dojo/interfaces/vdom';
let node: VNode;
node = someFlag ? v('div') : v('p');
How do I contribute?
We appreciate your interest! Please see the Dojo 2 Meta Repository for the Contributing Guidelines.
Code Style
This repository uses prettier
for code styling rules and formatting. A pre-commit hook is installed automatically and configured to run prettier
against all staged files as per the configuration in the projects package.json
.
An additional npm script to run prettier
(with write set to true
) against all src
and test
project files is available by running:
npm run prettier
Installation
To start working with this package, clone the repository and run npm install
.
In order to build the project run grunt dev
or grunt dist
.
Testing
Since this is a type only package, we are currently working on the best way to test this package.
Licensing information
© 2018 JS Foundation. New BSD license.