@cdp/promise
v2.1.0
Published
CDP promise utility module
Downloads
9
Readme
cdp-promise
What is this module
- This module provides the
cancelable
promise object and utilities based on jQuery.Deferred.
- example1:
// pipe line operation
function procPipeline(): IPromise<SomeData> {
const df = $.Deferred(); // create jQueryDeferred instance.
const promise = makePromise(df); // create IPromise instance.
// async1(), async2(), async3() are async function and returned IPromise instance.
promsie.dependOn(async1())
.then(() => {
return promsie.dependOn(async2());
})
.then(() => {
return promsie.dependOn(async3());
})
.done(() => {
df.resolve({ somedata: "hoge" });
})
.fail((error) => {
df.reject(error);
});
return promise;
}
// client of pipe line operation
function procCaller(): void {
const promise = procPipeline();
setTimeout(() => {
promise.abort(); // The whole cancellation is possible by optional timing.
// In whichever processing of async1(), async2() or async3(),
// it can be canceled appropriately.
});
}
- example2:
// override global "Promise" for using Cancelable Promise in this module scope.
import { Promise } from "cdp";
function (): IPromise<SomeData> => {
return new Promise((resolve, reject, dependOn) => {
// async1(), async2() are async function and returned IPromise instance.
dependOn(async1())
.then(() => {
return dependOn(async2());
})
.then(() => {
resolve({ somedata: "hoge" });
})
.catch((error) => {
reject(error);
});
});
};
}
Repository structure
Folder and file structure of this repository is the following list.
root/
docs/ // specification documents for this libraries
external/ // 3rd party library modules
src/ // development sources for this libraries
tests/ // test scripts for this libraries
How to install
npm
$ npm install @cdp/promise
How to build the module
If you want to use newest version, you can build the modules yourself as follow steps.
build the modules
$ npm install $ npm run package
pick up from the
dist
directory.root/ dist/ cdp.promise.js js modules for dev. cdp.promise.min.js js modules for production. cdp.promise.min.js.map js map file. @types/ cdp.promise.d.ts d.ts file for this module.
How to test the module
CI command as following.
$ npm install -g testem
$ npm install
$ npm run ci
LINT command as following.
$ npm install
$ npm run lint
How to use
Please see the following documentation.
Release Notes
Please see the following link.
License
Copyright 2015, 2016 Sony Corporation
Copyright 2017 Sony Network Communications Inc.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.