delegates

WebJar for delegates

License

License

MIT
GroupId

GroupId

org.webjars.npm
ArtifactId

ArtifactId

delegates
Last Version

Last Version

1.0.0
Release Date

Release Date

Type

Type

jar
Description

Description

delegates
WebJar for delegates
Project URL

Project URL

http://webjars.org

Download delegates

How to add to project

<!-- https://jarcasting.com/artifacts/org.webjars.npm/delegates/ -->
<dependency>
    <groupId>org.webjars.npm</groupId>
    <artifactId>delegates</artifactId>
    <version>1.0.0</version>
</dependency>
// https://jarcasting.com/artifacts/org.webjars.npm/delegates/
implementation 'org.webjars.npm:delegates:1.0.0'
// https://jarcasting.com/artifacts/org.webjars.npm/delegates/
implementation ("org.webjars.npm:delegates:1.0.0")
'org.webjars.npm:delegates:jar:1.0.0'
<dependency org="org.webjars.npm" name="delegates" rev="1.0.0">
  <artifact name="delegates" type="jar" />
</dependency>
@Grapes(
@Grab(group='org.webjars.npm', module='delegates', version='1.0.0')
)
libraryDependencies += "org.webjars.npm" % "delegates" % "1.0.0"
[org.webjars.npm/delegates "1.0.0"]

Dependencies

There are no dependencies for this project. It is a standalone project that does not depend on any other jars.

Project Modules

There are no modules declared in this project.

delegates

Node method and accessor delegation utilty.

Installation

$ npm install delegates

Example

var delegate = require('delegates');

...

delegate(proto, 'request')
  .method('acceptsLanguages')
  .method('acceptsEncodings')
  .method('acceptsCharsets')
  .method('accepts')
  .method('is')
  .access('querystring')
  .access('idempotent')
  .access('socket')
  .access('length')
  .access('query')
  .access('search')
  .access('status')
  .access('method')
  .access('path')
  .access('body')
  .access('host')
  .access('url')
  .getter('subdomains')
  .getter('protocol')
  .getter('header')
  .getter('stale')
  .getter('fresh')
  .getter('secure')
  .getter('ips')
  .getter('ip')

API

Delegate(proto, prop)

Creates a delegator instance used to configure using the prop on the given proto object. (which is usually a prototype)

Delegate.auto(proto, targetProto, targetProp)

Delegates getters, setters, values, and methods from targetProto to proto. Assumes that targetProto objects will exist under proto objects with the key targetProp.

Delegate#method(name)

Allows the given method name to be accessed on the host.

Delegate#getter(name)

Creates a "getter" for the property with the given name on the delegated object.

Delegate#setter(name)

Creates a "setter" for the property with the given name on the delegated object.

Delegate#access(name)

Creates an "accessor" (ie: both getter and setter) for the property with the given name on the delegated object.

Delegate#fluent(name)

A unique type of "accessor" that works for a "fluent" API. When called as a getter, the method returns the expected value. However, if the method is called with a value, it will return itself so it can be chained. For example:

delegate(proto, 'request')
  .fluent('query')

// getter
var q = request.query();

// setter (chainable)
request
  .query({ a: 1 })
  .query({ b: 2 });

License

MIT

Versions

Version
1.0.0