Compare commits

...

20 Commits

Author SHA1 Message Date
a9270cda03 5.4.31 2016-09-14 13:16:40 +02:00
2a0a5cea8c update tsn dependency and by that support Decorators and runtime type checking through reflect metadata API 2016-09-14 13:16:36 +02:00
b2d8cb53f3 5.4.30 2016-09-06 17:33:31 +02:00
875efe413a some more standard js 2016-09-06 17:33:28 +02:00
8fd24c6e31 5.4.29 2016-09-06 17:22:30 +02:00
18a1087478 copile docs 2016-09-06 17:22:26 +02:00
cd2f401180 now adhering to standard js code style 2016-09-06 17:21:25 +02:00
41b1fe85d6 5.4.27 2016-09-03 18:50:12 +02:00
8372c1437c fixes #8 2016-09-03 18:50:09 +02:00
aedf9f3115 5.4.26 2016-09-02 17:42:45 +02:00
25320bdf5c fix checks 2016-09-02 17:42:41 +02:00
33c83de1fb 5.4.25 2016-09-02 17:12:38 +02:00
07a56fcaca fix @types/node 2016-09-02 17:12:35 +02:00
7bc986251f 5.4.24 2016-09-02 14:11:44 +02:00
cdde7da5f9 remove travis and appveyor 2016-09-02 14:11:27 +02:00
82c00fe444 fix typedoc integration 2016-09-02 14:10:09 +02:00
93682e9ec4 5.4.23 2016-09-01 15:50:01 +02:00
d339da7e11 compile 2016-09-01 15:49:57 +02:00
8b51992959 5.4.22 2016-09-01 15:47:10 +02:00
cb3bfaf438 updated README 2016-09-01 15:46:31 +02:00
44 changed files with 582 additions and 577 deletions

View File

@ -1,15 +0,0 @@
language: node_js
node_js:
- 4.3.1
- stable
deploy:
provider: npm
email: npm@lossless.digital
api_key:
secure: k075QdAcmEdmAoVaP5vclLnZmhbZB39v85VIUMWAKXbIAU+liHrYZRlIEYfAaIUrf6sha+zAo/U/vjAN7c5ArB7J/HjCLJ3lsi2fWtaSRlYQrYX9/EhU0S+YZjRE8Jrn4hGTcce6I2mANBnEzvzlXrlKaqVvSqOqTO9nJ5aDBCGa5XT3EwlHKkRlAlL3ZOLrRg38R343E8ifZBsbn9G0e+RgDt0sic3WD8NME9lpsQ/99UZKH00duHbhF9nme5Sjdh86y01hvsaBf+CLR4gfS2IntnrCSrZbETFrsOBUyMnJZDQ3qlrjcEaiTkpJ4iSIqr+ftwGMMD6S1MxCTPqkp64UIeMz2Tg41HqoaeIg7z8cF0APv6M9ZAdWhsU43GqsMe70dK900JZpQAkQxMf/6NpPpGfZug6TwqLYSIRzvjvNrhYfuyoGfXdAxrM3SJMkIq6rwE+T/y36kZaC3CrQRyNZypNz0vW1M9HLjJUi2vO0U/CDn8tvi1p6ChrDXDfV3H2UIAMHFlAF+GrT7dMWwD+p+d8mc9gpAFEF9zMqAIJamPhwboJxoHjKQrqrq5czNm75ETL77AzfnU6CfQlG5dTIFnGId8y0ZxXvtpBruDoyC1+ZF23MYZmb+ipxQZM2oLCjNLeL3aEePc/JlSm6Gn8w3sIkZTG261F0XZxdApw=
on:
tags: true
repo: pushrocks/npmts
env:
global:
secure: kPKBMnEKoC+K5dXpl11NhuK3LSp0c0fRO60Akj3QeQBjUWnVAcF0Ht30c31y0lnJaMEzXhmUIKdR7RQnlmw5be4TYGINzY7FD3Dcv7o+HO1ZQrkpMWSu46jF6ZJer9moGjZ8e0rX8wZyB9SqsXYlwWRzqvxfOVxQfTvU3BEnJKHbhq+R5JMJ8dwLBPNTJKMWKq85KNsjo3ap0BjxdBUoRLzvrn31VOPH30BkvmLGc5YiIz5QmITll/T2wmQKYTNT2qDlEJ729B8pYa3eNlCNi89AxsLDGCmEoJAVrPsyw5g+gAyBqZ1GRULy83UJbELUq7cse3MRLMSwCAm4f0INRAuqcyiKYJ4+LHd0NwKrFQ/dQ0pvyBTbbEjNemXaakkWH7S6F03UvF+u+tiQ7C97XH0CRsseGlm36zCkAClEhtWVWA4U0Q5c6zqRAAOYOI0xquXalRKPTJe7fCYewp2eqmlp8drt8MxancyKI/ynXNoR5vGFzDTSRoPjTlaYQPmbiH4+Nd5+6Qoj94PEIqghebIPDQo3C7vWts4WGccux5b2q524UgB63hjJQA6+GQOo1q4RibouS6WScn8/tW/ZOEP+sNhDfkeiZUIjye+Q3PyzonGHefgSQ8wBbsc8LOX0cKUcEFWr14nhdQ9ZeW+hrSSF04TbM4zGJPGcKhmT2UU=

View File

@ -1,8 +1,6 @@
# npmts # npmts
Write npm modules with TypeScript without hassle. TypeScript ready. Fully ES6. Write npm modules with TypeScript without hassle. TypeScript ready. Fully ES6.
[![npm](https://push.rocks/assets/repo-header.svg)](https://push.rocks)
## Availabililty ## Availabililty
[![npm](https://push.rocks/assets/repo-button-npm.svg)](https://www.npmjs.com/package/npmts) [![npm](https://push.rocks/assets/repo-button-npm.svg)](https://www.npmjs.com/package/npmts)
[![git](https://push.rocks/assets/repo-button-git.svg)](https://gitlab.com/pushrocks/npmts) [![git](https://push.rocks/assets/repo-button-git.svg)](https://gitlab.com/pushrocks/npmts)
@ -17,12 +15,22 @@ Write npm modules with TypeScript without hassle. TypeScript ready. Fully ES6.
[![bitHound Code](https://www.bithound.io/github/pushrocks/npmts/badges/code.svg)](https://www.bithound.io/github/pushrocks/npmts) [![bitHound Code](https://www.bithound.io/github/pushrocks/npmts/badges/code.svg)](https://www.bithound.io/github/pushrocks/npmts)
[![TypeScript](https://img.shields.io/badge/TypeScript-2.x-blue.svg)](https://nodejs.org/dist/latest-v6.x/docs/api/) [![TypeScript](https://img.shields.io/badge/TypeScript-2.x-blue.svg)](https://nodejs.org/dist/latest-v6.x/docs/api/)
[![node](https://img.shields.io/badge/node->=%206.x.x-blue.svg)](https://nodejs.org/dist/latest-v6.x/docs/api/) [![node](https://img.shields.io/badge/node->=%206.x.x-blue.svg)](https://nodejs.org/dist/latest-v6.x/docs/api/)
[![JavaScript Style Guide](https://img.shields.io/badge/code%20style-standard-brightgreen.svg)](http://standardjs.com/)
## Introduction ## Introduction
NPMTS is your friend when it comes to write, test, publish and document NPM modules written in TypeScript. NPMTS is your friend when writing, testing, publishing and documenting npm modules written in TypeScript.
By default NPMTS will **bundle declaration files**. As a result npm module **code completion in editors like Visual Studio Code** works.
There is a docker image available that includes npmts to make CI a breeze: npmts will
1. check your dependencies and package.json
1. transpile your code with tsc,
1. document your code with typedoc,
1. test your code with mocha
1. create coverage with istanbul
This works on your machine and in CI. There is a prebuild docker image available that includes npmts to make CI a breeze:
[hosttoday/ht-docker-node:npmts on Dockerhub](https://hub.docker.com/r/hosttoday/ht-docker-node/) [hosttoday/ht-docker-node:npmts on Dockerhub](https://hub.docker.com/r/hosttoday/ht-docker-node/)
For further information read the docs. For further information read the docs.
[![npm](https://push.rocks/assets/repo-header.svg)](https://push.rocks)

View File

@ -1,10 +0,0 @@
environment:
nodejs_version: "4"
install:
- ps: Install-Product node $env:nodejs_version
- npm install
test_script:
- node --version
- npm --version
- npm test
build: off

2
dist/index.d.ts vendored
View File

@ -1 +1 @@
import "typings-global"; import 'typings-global';

6
dist/index.js vendored
View File

@ -4,7 +4,7 @@ require("typings-global");
Starting NPMTS main process. Starting NPMTS main process.
* ================================================== */ * ================================================== */
var early = require("early"); var early = require("early");
early.start("NPMTS"); early.start('NPMTS');
var plugins = require("./npmts.plugins"); var plugins = require("./npmts.plugins");
var paths = require("./npmts.paths"); var paths = require("./npmts.paths");
var npmts_promisechain_1 = require("./npmts.promisechain"); var npmts_promisechain_1 = require("./npmts.promisechain");
@ -14,8 +14,8 @@ early.stop()
var npmtsCli = new plugins.smartcli.Smartcli(); var npmtsCli = new plugins.smartcli.Smartcli();
npmtsCli.standardTask() npmtsCli.standardTask()
.then(function (argvArg) { .then(function (argvArg) {
plugins.beautylog.figletSync("NPMTS"); plugins.beautylog.figletSync('NPMTS');
plugins.beautylog.info("npmts version: " + npmtsProjectInfo.version); plugins.beautylog.info('npmts version: ' + npmtsProjectInfo.version);
try { try {
npmts_promisechain_1.promisechain(argvArg); npmts_promisechain_1.promisechain(argvArg);
} }

View File

@ -1,4 +1,4 @@
/// <reference types="q" /> /// <reference types="q" />
import "typings-global"; import 'typings-global';
import plugins = require("./npmts.plugins"); import plugins = require('./npmts.plugins');
export declare var run: (configArg: any) => plugins.Q.Promise<{}>; export declare var run: (configArg: any) => plugins.Q.Promise<{}>;

10
dist/npmts.assets.js vendored
View File

@ -6,14 +6,14 @@ var npmts_promisechain_1 = require("./npmts.promisechain");
exports.run = function (configArg) { exports.run = function (configArg) {
var done = plugins.Q.defer(); var done = plugins.Q.defer();
var config = configArg; var config = configArg;
npmts_promisechain_1.npmtsOra.text("now looking at " + "required assets".yellow); npmts_promisechain_1.npmtsOra.text('now looking at ' + 'required assets'.yellow);
if (config.cli == true) { if (config.cli === true) {
plugins.smartfile.fs.copySync(plugins.path.join(paths.npmtsAssetsDir, "cli.js"), plugins.path.join(paths.distDir, "cli.js")); plugins.smartfile.fs.copySync(plugins.path.join(paths.npmtsAssetsDir, 'cli.js'), plugins.path.join(paths.distDir, 'cli.js'));
plugins.beautylog.ok("installed CLI assets!"); plugins.beautylog.ok('installed CLI assets!');
done.resolve(config); done.resolve(config);
} }
else { else {
plugins.beautylog.ok("No additional assets required!"); plugins.beautylog.ok('No additional assets required!');
done.resolve(config); done.resolve(config);
} }
return done.promise; return done.promise;

View File

@ -1,3 +1,5 @@
/// <reference types="q" /> /// <reference types="q" />
import * as plugins from "./npmts.plugins"; import * as plugins from './npmts.plugins';
import { ProjectinfoNpm } from 'projectinfo';
export declare let projectInfo: ProjectinfoNpm;
export declare let run: (configArg: any) => plugins.Q.Promise<{}>; export declare let run: (configArg: any) => plugins.Q.Promise<{}>;

25
dist/npmts.check.js vendored
View File

@ -2,10 +2,11 @@
var plugins = require("./npmts.plugins"); var plugins = require("./npmts.plugins");
var paths = require("./npmts.paths"); var paths = require("./npmts.paths");
var npmts_promisechain_1 = require("./npmts.promisechain"); var npmts_promisechain_1 = require("./npmts.promisechain");
var projectinfo_1 = require("projectinfo");
var checkProjectTypings = function (configArg) { var checkProjectTypings = function (configArg) {
var done = plugins.Q.defer(); var done = plugins.Q.defer();
var cwdProjectInfo = new plugins.projectinfo.ProjectinfoNpm(paths.cwd); exports.projectInfo = new projectinfo_1.ProjectinfoNpm(paths.cwd);
if (typeof cwdProjectInfo.packageJson.typings == "undefined") { if (typeof exports.projectInfo.packageJson.typings === 'undefined') {
plugins.beautylog.error("please add typings field to package.json"); plugins.beautylog.error("please add typings field to package.json");
process.exit(1); process.exit(1);
} }
@ -16,7 +17,7 @@ var checkProjectTypings = function (configArg) {
var depcheckOptions = { var depcheckOptions = {
ignoreBinPackage: false, ignoreBinPackage: false,
parsers: { parsers: {
'*.ts': plugins.depcheck.parser.typescript, '*.ts': plugins.depcheck.parser.typescript
}, },
detectors: [ detectors: [
plugins.depcheck.detector.requireCallExpression, plugins.depcheck.detector.requireCallExpression,
@ -25,7 +26,7 @@ var depcheckOptions = {
specials: [ specials: [
plugins.depcheck.special.eslint, plugins.depcheck.special.eslint,
plugins.depcheck.special.webpack plugins.depcheck.special.webpack
], ]
}; };
var checkDependencies = function (configArg) { var checkDependencies = function (configArg) {
var done = plugins.Q.defer(); var done = plugins.Q.defer();
@ -36,8 +37,8 @@ var checkDependencies = function (configArg) {
'bower_components' 'bower_components'
], ],
ignoreMatches: [ ignoreMatches: [
"@types/*", '@types/*',
"babel-preset-*" 'babel-preset-*'
] ]
}); });
plugins.depcheck(paths.cwd, depcheckOptionsMerged, function (unused) { plugins.depcheck(paths.cwd, depcheckOptionsMerged, function (unused) {
@ -52,7 +53,7 @@ var checkDependencies = function (configArg) {
} }
; ;
if (unused.missing.length > 0) { if (unused.missing.length > 0) {
plugins.beautylog.info("exiting due to missing dependencies in package.json"); plugins.beautylog.info('exiting due to missing dependencies in package.json');
process.exit(1); process.exit(1);
} }
for (var _d = 0, _e = unused.invalidFiles; _d < _e.length; _d++) { for (var _d = 0, _e = unused.invalidFiles; _d < _e.length; _d++) {
@ -78,8 +79,8 @@ var checkDevDependencies = function (configArg) {
'bower_components' 'bower_components'
], ],
ignoreMatches: [ ignoreMatches: [
"@types/*", '@types/*',
"babel-preset-*" 'babel-preset-*'
] ]
}); });
plugins.depcheck(paths.cwd, depcheckOptionsMerged, function (unused) { plugins.depcheck(paths.cwd, depcheckOptionsMerged, function (unused) {
@ -94,19 +95,17 @@ var checkDevDependencies = function (configArg) {
} }
; ;
if (unused.missing.length > 0) { if (unused.missing.length > 0) {
plugins.beautylog.info("exiting due to missing dependencies in package.json"); plugins.beautylog.info('exiting due to missing dependencies in package.json');
process.exit(1); process.exit(1);
} }
for (var _d = 0, _e = unused.invalidFiles; _d < _e.length; _d++) { for (var _d = 0, _e = unused.invalidFiles; _d < _e.length; _d++) {
var item = _e[_d]; var item = _e[_d];
plugins.beautylog.warn("Watch out: could not parse file " + item.red); plugins.beautylog.warn("Watch out: could not parse file " + item.red);
} }
;
for (var _f = 0, _g = unused.invalidDirs; _f < _g.length; _f++) { for (var _f = 0, _g = unused.invalidDirs; _f < _g.length; _f++) {
var item = _g[_f]; var item = _g[_f];
plugins.beautylog.warn("Watch out: could not parse directory " + item.red); plugins.beautylog.warn("Watch out: could not parse directory " + item.red);
} }
;
done.resolve(configArg); done.resolve(configArg);
}); });
return done.promise; return done.promise;
@ -118,7 +117,7 @@ var checkNodeVersion = function (configArg) {
}; };
exports.run = function (configArg) { exports.run = function (configArg) {
var done = plugins.Q.defer(); var done = plugins.Q.defer();
npmts_promisechain_1.npmtsOra.text("running project checks..."), npmts_promisechain_1.npmtsOra.text('running project checks...');
checkProjectTypings(configArg) checkProjectTypings(configArg)
.then(checkDependencies) .then(checkDependencies)
.then(checkDevDependencies) .then(checkDevDependencies)

View File

@ -1,4 +1,4 @@
/// <reference types="q" /> /// <reference types="q" />
import "typings-global"; import 'typings-global';
import plugins = require("./npmts.plugins"); import plugins = require('./npmts.plugins');
export declare let run: (configArg: any) => plugins.Q.Promise<{}>; export declare let run: (configArg: any) => plugins.Q.Promise<{}>;

8
dist/npmts.clean.js vendored
View File

@ -4,20 +4,20 @@ var plugins = require("./npmts.plugins");
var paths = require("./npmts.paths"); var paths = require("./npmts.paths");
var npmts_promisechain_1 = require("./npmts.promisechain"); var npmts_promisechain_1 = require("./npmts.promisechain");
var removeDist = function () { var removeDist = function () {
npmts_promisechain_1.npmtsOra.text("cleaning dist folder"); npmts_promisechain_1.npmtsOra.text('cleaning dist folder');
return plugins.smartfile.fs.remove(paths.distDir); return plugins.smartfile.fs.remove(paths.distDir);
}; };
var removePages = function () { var removePages = function () {
npmts_promisechain_1.npmtsOra.text("cleaning pages folder"); npmts_promisechain_1.npmtsOra.text('cleaning pages folder');
return plugins.smartfile.fs.remove(paths.pagesDir); return plugins.smartfile.fs.remove(paths.pagesDir);
}; };
exports.run = function (configArg) { exports.run = function (configArg) {
npmts_promisechain_1.npmtsOra.text("cleaning up from previous builds..."); npmts_promisechain_1.npmtsOra.text('cleaning up from previous builds...');
var done = plugins.Q.defer(); var done = plugins.Q.defer();
removeDist() removeDist()
.then(removePages) .then(removePages)
.then(function () { .then(function () {
plugins.beautylog.ok("Cleaned up from previous builds!"); plugins.beautylog.ok('Cleaned up from previous builds!');
done.resolve(configArg); done.resolve(configArg);
}); });
return done.promise; return done.promise;

View File

@ -1,4 +1,4 @@
/// <reference types="q" /> /// <reference types="q" />
import "typings-global"; import 'typings-global';
import plugins = require("./npmts.plugins"); import plugins = require('./npmts.plugins');
export declare let run: (configArg: any) => plugins.Q.Promise<{}>; export declare let run: (configArg: any) => plugins.Q.Promise<{}>;

View File

@ -6,7 +6,7 @@ var outputPathIsDir = function (tsArrayArg, keyArg) {
}; };
exports.checkOutputPath = function (tsArrayArg, keyArg) { exports.checkOutputPath = function (tsArrayArg, keyArg) {
if (!outputPathIsDir(tsArrayArg, keyArg)) { if (!outputPathIsDir(tsArrayArg, keyArg)) {
plugins.beautylog.warn("Skipping " + keyArg + " because " + tsArrayArg[keyArg] + " it is no directory!"); plugins.beautylog.warn('Skipping ' + keyArg + ' because ' + tsArrayArg[keyArg] + ' it is no directory!');
return false; return false;
} }
else { else {

15
dist/npmts.compile.js vendored
View File

@ -9,8 +9,8 @@ var compileTs = function (tsFileArrayArg, tsOptionsArg) {
var done = plugins.Q.defer(); var done = plugins.Q.defer();
var compilerOptionsDefault = { var compilerOptionsDefault = {
declaration: true, declaration: true,
module: "CommonJS", module: 'CommonJS',
target: "ES6" target: 'ES6'
}; };
/** /**
* merges default ts options with those found in npmts.json * merges default ts options with those found in npmts.json
@ -20,7 +20,8 @@ var compileTs = function (tsFileArrayArg, tsOptionsArg) {
var compilerOptions = { var compilerOptions = {
declaration: tsOptionsCombined.declaration, declaration: tsOptionsCombined.declaration,
module: plugins.tsn.ModuleKind[tsOptionsCombined.module], module: plugins.tsn.ModuleKind[tsOptionsCombined.module],
target: plugins.tsn.ScriptTarget[tsOptionsCombined.target] target: plugins.tsn.ScriptTarget[tsOptionsCombined.target],
exclude: 'node_modules/**/*'
}; };
return compilerOptions; return compilerOptions;
}; };
@ -48,15 +49,15 @@ var compileTs = function (tsFileArrayArg, tsOptionsArg) {
exports.run = function (configArg) { exports.run = function (configArg) {
var done = plugins.Q.defer(); var done = plugins.Q.defer();
var config = configArg; var config = configArg;
npmts_promisechain_1.npmtsOra.text("now compiling " + "TypeScript".yellow); npmts_promisechain_1.npmtsOra.text('now compiling ' + 'TypeScript'.yellow);
compileTs(config.ts, config.tsOptions) compileTs(config.ts, config.tsOptions)
.then(function () { .then(function () {
plugins.beautylog.ok("compiled main TypeScript!"); plugins.beautylog.ok('compiled main TypeScript!');
plugins.beautylog.log("now compiling tests!"); plugins.beautylog.log('now compiling tests!');
return compileTs(config.testTs); return compileTs(config.testTs);
}) })
.then(function () { .then(function () {
plugins.beautylog.ok("compiled all TypeScript!"); plugins.beautylog.ok('compiled all TypeScript!');
done.resolve(config); done.resolve(config);
}); });
return done.promise; return done.promise;

View File

@ -1,8 +1,8 @@
/// <reference types="q" /> /// <reference types="q" />
import "typings-global"; import 'typings-global';
import plugins = require("./npmts.plugins"); import plugins = require('./npmts.plugins');
export declare type npmtsMode = "default" | "custom"; export declare type npmtsMode = 'default' | 'custom';
export interface npmtsConfig { export interface INpmtsConfig {
argv: any; argv: any;
coverageTreshold: number; coverageTreshold: number;
docs: boolean; docs: boolean;

26
dist/npmts.options.js vendored
View File

@ -10,16 +10,16 @@ exports.run = function (argvArg) {
argv: undefined, argv: undefined,
coverageTreshold: 70, coverageTreshold: 70,
docs: true, docs: true,
mode: "default", mode: 'default',
test: true, test: true,
testTs: {}, testTs: {},
ts: {}, ts: {},
tsOptions: {} tsOptions: {}
}; };
// mix with configfile // mix with configfile
npmts_promisechain_1.npmtsOra.text("looking for npmextra.json"); npmts_promisechain_1.npmtsOra.text('looking for npmextra.json');
var config = plugins.npmextra.dataFor({ var config = plugins.npmextra.dataFor({
toolName: "npmts", toolName: 'npmts',
defaultSettings: defaultConfig, defaultSettings: defaultConfig,
cwd: paths.cwd cwd: paths.cwd
}); });
@ -27,9 +27,9 @@ exports.run = function (argvArg) {
config.argv = argvArg; config.argv = argvArg;
// check mode // check mode
switch (config.mode) { switch (config.mode) {
case "default": case 'default':
case "custom": case 'custom':
plugins.beautylog.ok("mode is " + config.mode); plugins.beautylog.ok('mode is ' + config.mode);
done.resolve(config); done.resolve(config);
break; break;
default: default:
@ -38,15 +38,13 @@ exports.run = function (argvArg) {
} }
; ;
// handle default mode // handle default mode
if (config.mode == "default") { if (config.mode === 'default') {
config.ts = (_a = {}, config.ts = (_a = {},
_a["./ts/**/*.ts"] = "./dist/", _a['./ts/**/*.ts'] = './dist/',
_a _a);
);
config.testTs = (_b = {}, config.testTs = (_b = {},
_b["./test/test.ts"] = "./test/", _b['./test/test.ts'] = './test/',
_b _b);
);
} }
; ;
// mix with commandline // mix with commandline
@ -58,7 +56,7 @@ exports.run = function (argvArg) {
config.docs = false; config.docs = false;
} }
; ;
plugins.beautylog.ok("build options are ready!"); plugins.beautylog.ok('build options are ready!');
done.resolve(config); done.resolve(config);
return done.promise; return done.promise;
var _a, _b; var _a, _b;

View File

@ -1,4 +1,4 @@
import "typings-global"; import 'typings-global';
export declare let npmtsPackageRoot: string; export declare let npmtsPackageRoot: string;
export declare let cwd: string; export declare let cwd: string;
export declare let tsDir: string; export declare let tsDir: string;

22
dist/npmts.paths.js vendored
View File

@ -2,19 +2,19 @@
require("typings-global"); require("typings-global");
var plugins = require("./npmts.plugins"); var plugins = require("./npmts.plugins");
// NPMTS Paths // NPMTS Paths
exports.npmtsPackageRoot = plugins.path.join(__dirname, "../"); exports.npmtsPackageRoot = plugins.path.join(__dirname, '../');
// Project paths // Project paths
exports.cwd = process.cwd(); exports.cwd = process.cwd();
// Directories // Directories
exports.tsDir = plugins.path.join(exports.cwd, "ts/"); exports.tsDir = plugins.path.join(exports.cwd, 'ts/');
exports.distDir = plugins.path.join(exports.cwd, "dist/"); exports.distDir = plugins.path.join(exports.cwd, 'dist/');
exports.testDir = plugins.path.join(exports.cwd, "test/"); exports.testDir = plugins.path.join(exports.cwd, 'test/');
exports.typingsDir = plugins.path.join(exports.cwd, "ts/typings/"); exports.typingsDir = plugins.path.join(exports.cwd, 'ts/typings/');
exports.coverageDir = plugins.path.join(exports.cwd, "coverage/"); exports.coverageDir = plugins.path.join(exports.cwd, 'coverage/');
// Pages // Pages
exports.pagesDir = plugins.path.join(exports.cwd, "pages/"); exports.pagesDir = plugins.path.join(exports.cwd, 'pages/');
exports.pagesApiDir = plugins.path.join(exports.pagesDir, "/api"); exports.pagesApiDir = plugins.path.join(exports.pagesDir, '/api');
exports.npmtsAssetsDir = plugins.path.join(__dirname, "../assets/"); exports.npmtsAssetsDir = plugins.path.join(__dirname, '../assets/');
// Files // Files
exports.indexTS = plugins.path.join(exports.cwd, "ts/index.ts"); exports.indexTS = plugins.path.join(exports.cwd, 'ts/index.ts');
exports.testTS = plugins.path.join(exports.cwd, "ts/test.ts"); exports.testTS = plugins.path.join(exports.cwd, 'ts/test.ts');

View File

@ -1,7 +1,7 @@
import "typings-global"; import 'typings-global';
export import beautylog = require("beautylog"); export import beautylog = require('beautylog');
export declare let depcheck: any; export declare let depcheck: any;
export import gulp = require("gulp"); export import gulp = require('gulp');
export declare let g: { export declare let g: {
babel: any; babel: any;
istanbul: any; istanbul: any;
@ -12,16 +12,16 @@ export declare let g: {
typedoc: any; typedoc: any;
}; };
export import lodashObject = require('lodash'); export import lodashObject = require('lodash');
export import npmextra = require("npmextra"); export import npmextra = require('npmextra');
export import projectinfo = require("projectinfo"); export import projectinfo = require('projectinfo');
export import path = require("path"); export import path = require('path');
export import Q = require("q"); export import Q = require('q');
export import shelljs = require("shelljs"); export import shelljs = require('shelljs');
export import smartcli = require("smartcli"); export import smartcli = require('smartcli');
export import smartcov = require("smartcov"); export import smartcov = require('smartcov');
export import smartenv = require("smartenv"); export import smartenv = require('smartenv');
export import smartfile = require("smartfile"); export import smartfile = require('smartfile');
export import smartpath = require("smartpath"); export import smartpath = require('smartpath');
export import smartstring = require("smartstring"); export import smartstring = require('smartstring');
export declare let sourceMapSupport: any; export declare let sourceMapSupport: any;
export import tsn = require("tsn"); export import tsn = require('tsn');

20
dist/npmts.plugins.js vendored
View File

@ -1,18 +1,18 @@
"use strict"; "use strict";
require("typings-global"); require("typings-global");
exports.beautylog = require("beautylog"); exports.beautylog = require("beautylog");
exports.depcheck = require("depcheck"); exports.depcheck = require('depcheck');
exports.gulp = require("gulp"); exports.gulp = require("gulp");
exports.g = { exports.g = {
babel: require("gulp-babel"), babel: require('gulp-babel'),
istanbul: require("gulp-istanbul"), istanbul: require('gulp-istanbul'),
gFunction: require("gulp-function"), gFunction: require('gulp-function'),
injectModules: require("gulp-inject-modules"), injectModules: require('gulp-inject-modules'),
mocha: require("gulp-mocha"), mocha: require('gulp-mocha'),
sourcemaps: require("gulp-sourcemaps"), sourcemaps: require('gulp-sourcemaps'),
typedoc: require("gulp-typedoc") typedoc: require('gulp-typedoc')
}; };
exports.lodashObject = require('lodash'); exports.lodashObject = require("lodash");
exports.npmextra = require("npmextra"); exports.npmextra = require("npmextra");
exports.projectinfo = require("projectinfo"); exports.projectinfo = require("projectinfo");
exports.path = require("path"); exports.path = require("path");
@ -24,5 +24,5 @@ exports.smartenv = require("smartenv");
exports.smartfile = require("smartfile"); exports.smartfile = require("smartfile");
exports.smartpath = require("smartpath"); exports.smartpath = require("smartpath");
exports.smartstring = require("smartstring"); exports.smartstring = require("smartstring");
exports.sourceMapSupport = require("source-map-support").install(); // this is required to display errors correctly during testing exports.sourceMapSupport = require('source-map-support').install(); // display errors correctly during testing
exports.tsn = require("tsn"); exports.tsn = require("tsn");

View File

@ -1,6 +1,6 @@
/// <reference types="q" /> /// <reference types="q" />
import "typings-global"; import 'typings-global';
import plugins = require("./npmts.plugins"); import plugins = require('./npmts.plugins');
import { Ora } from "beautylog"; import { Ora } from 'beautylog';
export declare let npmtsOra: Ora; export declare let npmtsOra: Ora;
export declare let promisechain: (argvArg: any) => plugins.Q.Promise<{}>; export declare let promisechain: (argvArg: any) => plugins.Q.Promise<{}>;

View File

@ -1,7 +1,8 @@
"use strict"; "use strict";
require("typings-global"); require("typings-global");
var plugins = require("./npmts.plugins"); var plugins = require("./npmts.plugins");
exports.npmtsOra = new plugins.beautylog.Ora("setting up TaskChain", "cyan"); var beautylog_1 = require("beautylog");
exports.npmtsOra = new beautylog_1.Ora('setting up TaskChain', 'cyan');
var NpmtsAssets = require("./npmts.assets"); var NpmtsAssets = require("./npmts.assets");
var NpmtsCheck = require("./npmts.check"); var NpmtsCheck = require("./npmts.check");
var NpmtsClean = require("./npmts.clean"); var NpmtsClean = require("./npmts.clean");
@ -20,26 +21,26 @@ exports.promisechain = function (argvArg) {
.then(NpmtsTypeDoc.run) .then(NpmtsTypeDoc.run)
.then(NpmtsTests.run) .then(NpmtsTests.run)
.then(function (configArg) { .then(function (configArg) {
var shipString = "" + var shipString = '' +
"\n" + '\n' +
"\n" + '\n' +
" # # ( )\n" + ' # # ( )\n' +
" ___#_#___|__\n" + ' ___#_#___|__\n' +
" _ |____________| _\n" + ' _ |____________| _\n' +
" _=====| | | | | |==== _\n" + ' _=====| | | | | |==== _\n' +
" =====| |.---------------------------. | |====\n" + ' =====| |.---------------------------. | |====\n' +
" <--------------------' . . . . . . . . '--------------/\n" + " <--------------------' . . . . . . . . '--------------/\n" +
" \\ /\n" + ' \\ /\n' +
" \\___________________________________________________________/\n" + ' \\___________________________________________________________/\n' +
" wwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwww\n" + ' wwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwww\n' +
" wwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwww\n" + ' wwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwww\n' +
" wwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwww\n"; ' wwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwww\n';
if (process.env.CI) { if (process.env.CI) {
console.log(shipString); console.log(shipString);
plugins.beautylog.success("READY TO SHIP!"); plugins.beautylog.success('READY TO SHIP!');
} }
else { else {
plugins.beautylog.success("Done!"); plugins.beautylog.success('Done!');
} }
done.resolve(); done.resolve();
}); });

View File

@ -1,4 +1,4 @@
/// <reference types="q" /> /// <reference types="q" />
import "typings-global"; import 'typings-global';
import plugins = require("./npmts.plugins"); import plugins = require('./npmts.plugins');
export declare let run: (configArg: any) => plugins.Q.Promise<{}>; export declare let run: (configArg: any) => plugins.Q.Promise<{}>;

38
dist/npmts.tests.js vendored
View File

@ -8,49 +8,53 @@ var npmts_promisechain_1 = require("./npmts.promisechain");
* @returns {*} * @returns {*}
*/ */
var mocha = function (configArg) { var mocha = function (configArg) {
npmts_promisechain_1.npmtsOra.text("Instrumentalizing and testing transpiled JS"); npmts_promisechain_1.npmtsOra.text('Instrumentalizing and testing transpiled JS');
npmts_promisechain_1.npmtsOra.end(); // end npmtsOra for tests. npmts_promisechain_1.npmtsOra.end(); // end npmtsOra for tests.
var done = plugins.Q.defer(); var done = plugins.Q.defer();
var stream = plugins.gulp.src([plugins.path.join(paths.cwd, "dist/*.js")]) plugins.gulp.src([plugins.path.join(paths.cwd, 'dist/*.js')])
.pipe(plugins.g.sourcemaps.init()) .pipe(plugins.g.sourcemaps.init())
.pipe(plugins.g.babel({ .pipe(plugins.g.babel({
presets: [ presets: [
require.resolve("babel-preset-es2015") require.resolve('babel-preset-es2015')
] ]
})) }))
.pipe(plugins.g.istanbul({})) .pipe(plugins.g.istanbul({}))
.pipe(plugins.g.sourcemaps.write()) .pipe(plugins.g.sourcemaps.write())
.pipe(plugins.g.injectModules()) .pipe(plugins.g.injectModules())
.on("finish", function () { .on('finish', function () {
plugins.gulp.src([plugins.path.join(paths.cwd, "test/test.js")]) plugins.gulp.src([plugins.path.join(paths.cwd, 'test/test.js')])
.pipe(plugins.g.babel({ .pipe(plugins.g.babel({
presets: [ presets: [
require.resolve("babel-preset-es2015") require.resolve('babel-preset-es2015')
] ]
})) }))
.pipe(plugins.g.injectModules()) .pipe(plugins.g.injectModules())
.pipe(plugins.g.mocha()) .pipe(plugins.g.mocha())
.pipe(plugins.g.istanbul.writeReports({ .pipe(plugins.g.istanbul.writeReports({
dir: plugins.path.join(paths.cwd, "./coverage"), dir: plugins.path.join(paths.cwd, './coverage'),
reporters: ['lcovonly', 'json', 'text', 'text-summary'] reporters: ['lcovonly', 'json', 'text', 'text-summary']
})) }))
.pipe(plugins.g.gFunction(function () { .pipe(plugins.g.gFunction(function () {
plugins.beautylog.ok("Tested!"); plugins.beautylog.ok('Tested!');
done.resolve(configArg); done.resolve(configArg);
}, "atEnd")); }, 'atEnd'));
}); });
return done.promise; return done.promise;
}; };
var coverage = function (configArg) { var coverage = function (configArg) {
var done = plugins.Q.defer(); var done = plugins.Q.defer();
plugins.smartcov.get.percentage(plugins.path.join(paths.coverageDir, "lcov.info"), 2) plugins.smartcov.get.percentage(plugins.path.join(paths.coverageDir, 'lcov.info'), 2)
.then(function (percentageArg) { .then(function (percentageArg) {
if (percentageArg >= configArg.coverageTreshold) { if (percentageArg >= configArg.coverageTreshold) {
plugins.beautylog.ok(percentageArg.toString() + "% coverage exceeds your treshold of " + configArg.coverageTreshold.toString() + "%"); plugins.beautylog.ok(percentageArg.toString() + "% "
+ "coverage exceeds your treshold of "
+ (configArg.coverageTreshold.toString() + "%"));
} }
else { else {
plugins.beautylog.warn(percentageArg.toString() + "% coverage fails your treshold of " + configArg.coverageTreshold.toString() + "%"); plugins.beautylog.warn(percentageArg.toString() + "% "
plugins.beautylog.error("exiting due to coverage failure"); + "coverage fails your treshold of "
+ (configArg.coverageTreshold.toString() + "%"));
plugins.beautylog.error('exiting due to coverage failure');
process.exit(1); process.exit(1);
} }
done.resolve(configArg); done.resolve(configArg);
@ -61,10 +65,10 @@ exports.run = function (configArg) {
var done = plugins.Q.defer(); var done = plugins.Q.defer();
var config = configArg; var config = configArg;
if (config.test === true) { if (config.test === true) {
npmts_promisechain_1.npmtsOra.text("now starting tests"); npmts_promisechain_1.npmtsOra.text('now starting tests');
plugins.beautylog.log("-------------------------------------------------------\n" + plugins.beautylog.log('-------------------------------------------------------\n' +
"*************************** TESTS: ***************************\n" + '*************************** TESTS: ***************************\n' +
"--------------------------------------------------------------"); '--------------------------------------------------------------');
mocha(config) mocha(config)
.then(coverage) .then(coverage)
.then(function () { .then(function () {

View File

@ -1,4 +1,4 @@
/// <reference types="q" /> /// <reference types="q" />
import "typings-global"; import 'typings-global';
import plugins = require("./npmts.plugins"); import plugins = require('./npmts.plugins');
export declare let run: (configArg: any) => plugins.Q.Promise<{}>; export declare let run: (configArg: any) => plugins.Q.Promise<{}>;

20
dist/npmts.typedoc.js vendored
View File

@ -3,26 +3,28 @@ require("typings-global");
var plugins = require("./npmts.plugins"); var plugins = require("./npmts.plugins");
var paths = require("./npmts.paths"); var paths = require("./npmts.paths");
var npmts_promisechain_1 = require("./npmts.promisechain"); var npmts_promisechain_1 = require("./npmts.promisechain");
var npmts_check_1 = require("./npmts.check");
var genTypeDoc = function (configArg) { var genTypeDoc = function (configArg) {
var done = plugins.Q.defer(); var done = plugins.Q.defer();
npmts_promisechain_1.npmtsOra.text("now generating " + "TypeDoc documentation".yellow); npmts_promisechain_1.npmtsOra.text('now generating ' + 'TypeDoc documentation'.yellow);
plugins.beautylog.log("TypeDoc Output:"); plugins.beautylog.log('TypeDoc Output:');
plugins.gulp.src(plugins.path.join(paths.tsDir, "**/*.ts")) plugins.gulp.src(plugins.path.join(paths.tsDir, '**/*.ts'))
.pipe(plugins.g.typedoc({ .pipe(plugins.g.typedoc({
// TypeScript options (see typescript docs) // TypeScript options (see typescript docs)
module: "commonjs", module: 'commonjs',
target: "es6", target: 'es6',
includeDeclarations: true, includeDeclarations: true,
// Output options (see typedoc docs) // Output options (see typedoc docs)
out: paths.pagesApiDir, out: paths.pagesApiDir,
json: plugins.path.join(paths.pagesApiDir, "file.json"), json: plugins.path.join(paths.pagesApiDir, 'file.json'),
// TypeDoc options (see typedoc docs) // TypeDoc options (see typedoc docs)
name: "my-project", name: npmts_check_1.projectInfo.name,
readme: plugins.path.join(paths.cwd, 'README.md'),
// theme: "default", // theme: "default",
ignoreCompilerErrors: true, ignoreCompilerErrors: true,
version: true, version: true
})) }))
.pipe(plugins.g.gFunction(done.resolve, "atEnd")); .pipe(plugins.g.gFunction(done.resolve, 'atEnd'));
return done.promise; return done.promise;
}; };
exports.run = function (configArg) { exports.run = function (configArg) {

View File

@ -1,4 +1,4 @@
# Default task execution order # Default task execution of npmts
1. **Config:** Check config in ./npmextra.json (Check out [npmextra](https://www.npmjs.com/package/npmextra)) 1. **Config:** Check config in ./npmextra.json (Check out [npmextra](https://www.npmjs.com/package/npmextra))
1. **Clean:** Clean up from any previous builds (old js files) 1. **Clean:** Clean up from any previous builds (old js files)

View File

@ -1,4 +1,4 @@
# Examples for NPMTS # Examples for npmts
## Example Usage in modules: ## Example Usage in modules:
* [gulp-browser](https://www.npmjs.com/package/gulp-browser) * [gulp-browser](https://www.npmjs.com/package/gulp-browser)

View File

@ -1,8 +1,6 @@
# npmts # npmts
Write npm modules with TypeScript without hassle. TypeScript ready. Fully ES6. Write npm modules with TypeScript without hassle. TypeScript ready. Fully ES6.
[![npm](https://push.rocks/assets/repo-header.svg)](https://push.rocks)
## Availabililty ## Availabililty
[![npm](https://push.rocks/assets/repo-button-npm.svg)](https://www.npmjs.com/package/npmts) [![npm](https://push.rocks/assets/repo-button-npm.svg)](https://www.npmjs.com/package/npmts)
[![git](https://push.rocks/assets/repo-button-git.svg)](https://gitlab.com/pushrocks/npmts) [![git](https://push.rocks/assets/repo-button-git.svg)](https://gitlab.com/pushrocks/npmts)
@ -17,12 +15,22 @@ Write npm modules with TypeScript without hassle. TypeScript ready. Fully ES6.
[![bitHound Code](https://www.bithound.io/github/pushrocks/npmts/badges/code.svg)](https://www.bithound.io/github/pushrocks/npmts) [![bitHound Code](https://www.bithound.io/github/pushrocks/npmts/badges/code.svg)](https://www.bithound.io/github/pushrocks/npmts)
[![TypeScript](https://img.shields.io/badge/TypeScript-2.x-blue.svg)](https://nodejs.org/dist/latest-v6.x/docs/api/) [![TypeScript](https://img.shields.io/badge/TypeScript-2.x-blue.svg)](https://nodejs.org/dist/latest-v6.x/docs/api/)
[![node](https://img.shields.io/badge/node->=%206.x.x-blue.svg)](https://nodejs.org/dist/latest-v6.x/docs/api/) [![node](https://img.shields.io/badge/node->=%206.x.x-blue.svg)](https://nodejs.org/dist/latest-v6.x/docs/api/)
[![JavaScript Style Guide](https://img.shields.io/badge/code%20style-standard-brightgreen.svg)](http://standardjs.com/)
## Introduction ## Introduction
NPMTS is your friend when it comes to write, test, publish and document NPM modules written in TypeScript. NPMTS is your friend when writing, testing, publishing and documenting npm modules written in TypeScript.
By default NPMTS will **bundle declaration files**. As a result npm module **code completion in editors like Visual Studio Code** works.
There is a docker image available that includes npmts to make CI a breeze: npmts will
1. check your dependencies and package.json
1. transpile your code with tsc,
1. document your code with typedoc,
1. test your code with mocha
1. create coverage with istanbul
This works on your machine and in CI. There is a prebuild docker image available that includes npmts to make CI a breeze:
[hosttoday/ht-docker-node:npmts on Dockerhub](https://hub.docker.com/r/hosttoday/ht-docker-node/) [hosttoday/ht-docker-node:npmts on Dockerhub](https://hub.docker.com/r/hosttoday/ht-docker-node/)
For further information read the docs. For further information read the docs.
[![npm](https://push.rocks/assets/repo-header.svg)](https://push.rocks)

View File

@ -1,4 +1,4 @@
# Install NPMTS # Install npmts
First install npmts globally, then install the npmts-g locally. First install npmts globally, then install the npmts-g locally.
> **npmts-g* checks if the global version of npmts suffices the modules requirements. > **npmts-g* checks if the global version of npmts suffices the modules requirements.

View File

@ -1,6 +1,6 @@
{ {
"name": "npmts", "name": "npmts",
"version": "5.4.21", "version": "5.4.31",
"description": "Write npm modules with TypeScript without hassle. TypeScript ready. Fully ES6.", "description": "Write npm modules with TypeScript without hassle. TypeScript ready. Fully ES6.",
"main": "dist/index.js", "main": "dist/index.js",
"bin": { "bin": {
@ -32,19 +32,19 @@
}, },
"homepage": "https://gitlab.com/pushrocks/npmts#readme", "homepage": "https://gitlab.com/pushrocks/npmts#readme",
"dependencies": { "dependencies": {
"@types/gulp": "^3.8.30", "@types/gulp": "^3.8.31",
"@types/minimatch": "^2.0.28", "@types/minimatch": "^2.0.28",
"@types/q": "^0.x.x", "@types/q": "^0.x.x",
"@types/shelljs": "^0.3.29", "@types/shelljs": "^0.3.30",
"babel-preset-es2015": "^6.13.2", "babel-preset-es2015": "^6.14.0",
"beautylog": "5.0.20", "beautylog": "5.0.23",
"depcheck": "^0.6.4", "depcheck": "^0.6.4",
"early": "^2.0.25", "early": "^2.0.26",
"gulp": "3.9.1", "gulp": "3.9.1",
"gulp-babel": "^6.1.2", "gulp-babel": "^6.1.2",
"gulp-function": "^1.3.6", "gulp-function": "^1.3.6",
"gulp-inject-modules": "^1.0.0", "gulp-inject-modules": "^1.0.0",
"gulp-istanbul": "^1.1.0", "gulp-istanbul": "^1.1.1",
"gulp-mocha": "^3.0.1", "gulp-mocha": "^3.0.1",
"gulp-sourcemaps": "^1.6.0", "gulp-sourcemaps": "^1.6.0",
"gulp-typedoc": "^2.0.0", "gulp-typedoc": "^2.0.0",
@ -52,18 +52,18 @@
"npmextra": "^1.0.9", "npmextra": "^1.0.9",
"projectinfo": "1.0.3", "projectinfo": "1.0.3",
"q": "^1.4.1", "q": "^1.4.1",
"shelljs": "^0.7.3", "shelljs": "^0.7.4",
"smartcli": "1.0.4", "smartcli": "1.0.9",
"smartcov": "1.0.0", "smartcov": "1.0.0",
"smartenv": "1.2.5", "smartenv": "1.2.5",
"smartfile": "4.0.13", "smartfile": "4.0.15",
"smartpath": "3.2.2", "smartpath": "3.2.2",
"smartstring": "^2.0.17", "smartstring": "^2.0.17",
"source-map-support": "^0.4.2", "source-map-support": "^0.4.2",
"tsn": "^1.0.12", "tsn": "^1.0.13",
"typedoc": "^0.4.5", "typedoc": "^0.4.5",
"typescript": "next", "typescript": "next",
"typings-global": "*" "typings-global": "^1.0.14"
}, },
"devDependencies": {} "devDependencies": {}
} }

View File

@ -1,30 +1,28 @@
import "typings-global"; import 'typings-global'
/* ================================================== * /* ================================================== *
Starting NPMTS main process. Starting NPMTS main process.
* ================================================== */ * ================================================== */
import * as early from "early"; import * as early from 'early'
early.start("NPMTS"); early.start('NPMTS')
import * as plugins from "./npmts.plugins" import * as plugins from './npmts.plugins'
import * as paths from "./npmts.paths"; import * as paths from './npmts.paths'
import {promisechain} from "./npmts.promisechain"; import {promisechain} from './npmts.promisechain'
early.stop() early.stop()
.then(() => { .then(() => {
let npmtsProjectInfo = new plugins.projectinfo.ProjectinfoNpm(paths.npmtsPackageRoot); let npmtsProjectInfo = new plugins.projectinfo.ProjectinfoNpm(paths.npmtsPackageRoot)
let npmtsCli = new plugins.smartcli.Smartcli()
let npmtsCli = new plugins.smartcli.Smartcli();
npmtsCli.standardTask() npmtsCli.standardTask()
.then((argvArg) => { .then((argvArg) => {
plugins.beautylog.figletSync("NPMTS"); plugins.beautylog.figletSync('NPMTS')
plugins.beautylog.info("npmts version: " + npmtsProjectInfo.version); plugins.beautylog.info('npmts version: ' + npmtsProjectInfo.version)
try { try {
promisechain(argvArg); promisechain(argvArg)
} catch (err) {
console.log(err)
} }
catch(err){ })
console.log(err);
}
});
npmtsCli.addVersion(npmtsProjectInfo.version); npmtsCli.addVersion(npmtsProjectInfo.version)
npmtsCli.startParse(); npmtsCli.startParse()
}); })

View File

@ -1,22 +1,22 @@
import "typings-global"; import 'typings-global'
import plugins = require("./npmts.plugins"); import plugins = require('./npmts.plugins')
import paths = require("./npmts.paths"); import paths = require('./npmts.paths')
import {npmtsOra} from "./npmts.promisechain"; import {npmtsOra} from './npmts.promisechain'
export var run = function(configArg){ export var run = function(configArg){
let done = plugins.Q.defer(); let done = plugins.Q.defer()
let config = configArg; let config = configArg
npmtsOra.text("now looking at " + "required assets".yellow); npmtsOra.text('now looking at ' + 'required assets'.yellow)
if(config.cli == true){ if (config.cli === true) {
plugins.smartfile.fs.copySync( plugins.smartfile.fs.copySync(
plugins.path.join(paths.npmtsAssetsDir,"cli.js"), plugins.path.join(paths.npmtsAssetsDir,'cli.js'),
plugins.path.join(paths.distDir,"cli.js") plugins.path.join(paths.distDir,'cli.js')
); )
plugins.beautylog.ok("installed CLI assets!"); plugins.beautylog.ok('installed CLI assets!')
done.resolve(config); done.resolve(config)
} else { } else {
plugins.beautylog.ok("No additional assets required!") plugins.beautylog.ok('No additional assets required!')
done.resolve(config); done.resolve(config)
}
return done.promise
} }
return done.promise;
};

View File

@ -1,22 +1,26 @@
import * as plugins from "./npmts.plugins"; import * as plugins from './npmts.plugins'
import * as paths from "./npmts.paths"; import * as paths from './npmts.paths'
import { npmtsOra } from "./npmts.promisechain"; import { npmtsOra } from './npmts.promisechain'
import {ProjectinfoNpm} from 'projectinfo'
export let projectInfo: ProjectinfoNpm
let checkProjectTypings = (configArg) => { let checkProjectTypings = (configArg) => {
let done = plugins.Q.defer(); let done = plugins.Q.defer()
let cwdProjectInfo = new plugins.projectinfo.ProjectinfoNpm(paths.cwd); projectInfo = new ProjectinfoNpm(paths.cwd)
if(typeof cwdProjectInfo.packageJson.typings == "undefined"){ if (typeof projectInfo.packageJson.typings === 'undefined') {
plugins.beautylog.error(`please add typings field to package.json`); plugins.beautylog.error(`please add typings field to package.json`)
process.exit(1); process.exit(1)
};
done.resolve(configArg);
return done.promise;
}; };
done.resolve(configArg)
return done.promise
}
const depcheckOptions = { const depcheckOptions = {
ignoreBinPackage: false, // ignore the packages with bin entry ignoreBinPackage: false, // ignore the packages with bin entry
parsers: { // the target parsers parsers: { // the target parsers
'*.ts': plugins.depcheck.parser.typescript, '*.ts': plugins.depcheck.parser.typescript
}, },
detectors: [ // the target detectors detectors: [ // the target detectors
plugins.depcheck.detector.requireCallExpression, plugins.depcheck.detector.requireCallExpression,
@ -25,11 +29,11 @@ const depcheckOptions = {
specials: [ // the target special parsers specials: [ // the target special parsers
plugins.depcheck.special.eslint, plugins.depcheck.special.eslint,
plugins.depcheck.special.webpack plugins.depcheck.special.webpack
], ]
}; }
let checkDependencies = (configArg) => { let checkDependencies = (configArg) => {
let done = plugins.Q.defer(); let done = plugins.Q.defer()
let depcheckOptionsMerged = plugins.lodashObject.merge(depcheckOptions, { let depcheckOptionsMerged = plugins.lodashObject.merge(depcheckOptions, {
ignoreDirs: [ // folder with these names will be ignored ignoreDirs: [ // folder with these names will be ignored
'test', 'test',
@ -37,34 +41,34 @@ let checkDependencies = (configArg) => {
'bower_components' 'bower_components'
], ],
ignoreMatches: [ // ignore dependencies that matches these globs ignoreMatches: [ // ignore dependencies that matches these globs
"@types/*", '@types/*',
"babel-preset-*" 'babel-preset-*'
] ]
}) })
plugins.depcheck(paths.cwd, depcheckOptionsMerged, (unused) => { plugins.depcheck(paths.cwd, depcheckOptionsMerged, (unused) => {
for (let item of unused.dependencies) { for (let item of unused.dependencies) {
plugins.beautylog.warn(`Watch out: unused dependency ${item.red}`); plugins.beautylog.warn(`Watch out: unused dependency ${item.red}`)
}; };
for (let item of unused.missing) { for (let item of unused.missing) {
plugins.beautylog.error(`unused devDependency ${item.red}`); plugins.beautylog.error(`unused devDependency ${item.red}`)
}; };
if (unused.missing.length > 0) { if (unused.missing.length > 0) {
plugins.beautylog.info("exiting due to missing dependencies in package.json"); plugins.beautylog.info('exiting due to missing dependencies in package.json')
process.exit(1); process.exit(1)
} }
for (let item of unused.invalidFiles) { for (let item of unused.invalidFiles) {
plugins.beautylog.warn(`Watch out: could not parse file ${item.red}`); plugins.beautylog.warn(`Watch out: could not parse file ${item.red}`)
}; };
for (let item of unused.invalidDirs) { for (let item of unused.invalidDirs) {
plugins.beautylog.warn(`Watch out: could not parse directory ${item.red}`); plugins.beautylog.warn(`Watch out: could not parse directory ${item.red}`)
};
done.resolve(configArg);
});
return done.promise;
}; };
done.resolve(configArg)
})
return done.promise
}
let checkDevDependencies = (configArg) => { let checkDevDependencies = (configArg) => {
let done = plugins.Q.defer(); let done = plugins.Q.defer()
let depcheckOptionsMerged = plugins.lodashObject.merge(depcheckOptions, { let depcheckOptionsMerged = plugins.lodashObject.merge(depcheckOptions, {
ignoreDirs: [ // folder with these names will be ignored ignoreDirs: [ // folder with these names will be ignored
'ts', 'ts',
@ -72,46 +76,45 @@ let checkDevDependencies = (configArg) => {
'bower_components' 'bower_components'
], ],
ignoreMatches: [ // ignore dependencies that matches these globs ignoreMatches: [ // ignore dependencies that matches these globs
"@types/*", '@types/*',
"babel-preset-*" 'babel-preset-*'
] ]
}) })
plugins.depcheck(paths.cwd, depcheckOptionsMerged, (unused) => { plugins.depcheck(paths.cwd, depcheckOptionsMerged, (unused) => {
for (let item of unused.devDependencies) { for (let item of unused.devDependencies) {
plugins.beautylog.log(`unused devDependency ${item.red}`); plugins.beautylog.log(`unused devDependency ${item.red}`)
}; };
for (let item of unused.missing) { for (let item of unused.missing) {
plugins.beautylog.error(`unused devDependency ${item.red}`); plugins.beautylog.error(`unused devDependency ${item.red}`)
}; };
if (unused.missing.length > 0) { if (unused.missing.length > 0) {
plugins.beautylog.info("exiting due to missing dependencies in package.json"); plugins.beautylog.info('exiting due to missing dependencies in package.json')
process.exit(1); process.exit(1)
} }
for (let item of unused.invalidFiles) { for (let item of unused.invalidFiles) {
plugins.beautylog.warn(`Watch out: could not parse file ${item.red}`); plugins.beautylog.warn(`Watch out: could not parse file ${item.red}`)
}; }
for (let item of unused.invalidDirs) { for (let item of unused.invalidDirs) {
plugins.beautylog.warn(`Watch out: could not parse directory ${item.red}`); plugins.beautylog.warn(`Watch out: could not parse directory ${item.red}`)
}; }
done.resolve(configArg); done.resolve(configArg)
}); })
return done.promise; return done.promise
}; }
let checkNodeVersion = (configArg) => { let checkNodeVersion = (configArg) => {
let done = plugins.Q.defer(); let done = plugins.Q.defer()
done.resolve(configArg)
done.resolve(configArg); return done.promise
return done.promise;
} }
export let run = (configArg) => { export let run = (configArg) => {
let done = plugins.Q.defer(); let done = plugins.Q.defer()
npmtsOra.text("running project checks..."), npmtsOra.text('running project checks...')
checkProjectTypings(configArg) checkProjectTypings(configArg)
.then(checkDependencies) .then(checkDependencies)
.then(checkDevDependencies) .then(checkDevDependencies)
.then(checkNodeVersion) .then(checkNodeVersion)
.then(done.resolve); .then(done.resolve)
return done.promise; return done.promise
} }

View File

@ -1,26 +1,26 @@
import "typings-global"; import 'typings-global'
import plugins = require("./npmts.plugins"); import plugins = require('./npmts.plugins')
import paths = require("./npmts.paths"); import paths = require('./npmts.paths')
import {npmtsOra} from "./npmts.promisechain"; import {npmtsOra} from './npmts.promisechain'
let removeDist = function(){ let removeDist = function(){
npmtsOra.text("cleaning dist folder"); npmtsOra.text('cleaning dist folder')
return plugins.smartfile.fs.remove(paths.distDir); return plugins.smartfile.fs.remove(paths.distDir)
}; }
let removePages = function(){ let removePages = function(){
npmtsOra.text("cleaning pages folder"); npmtsOra.text('cleaning pages folder')
return plugins.smartfile.fs.remove(paths.pagesDir); return plugins.smartfile.fs.remove(paths.pagesDir)
}; }
export let run = function(configArg){ export let run = function(configArg){
npmtsOra.text("cleaning up from previous builds..."); npmtsOra.text('cleaning up from previous builds...')
let done = plugins.Q.defer(); let done = plugins.Q.defer()
removeDist() removeDist()
.then(removePages) .then(removePages)
.then(function(){ .then(function(){
plugins.beautylog.ok("Cleaned up from previous builds!"); plugins.beautylog.ok('Cleaned up from previous builds!')
done.resolve(configArg); done.resolve(configArg)
}); })
return done.promise; return done.promise
}; }

View File

@ -1,15 +1,15 @@
import plugins = require("./npmts.plugins"); import plugins = require('./npmts.plugins')
import paths = require("./npmts.paths"); import paths = require('./npmts.paths')
let outputPathIsDir = function (tsArrayArg,keyArg) { let outputPathIsDir = function (tsArrayArg,keyArg) {
return plugins.smartpath.check.isDir(plugins.path.join(paths.cwd, tsArrayArg[keyArg])); return plugins.smartpath.check.isDir(plugins.path.join(paths.cwd, tsArrayArg[keyArg]))
}; }
export let checkOutputPath = function(tsArrayArg,keyArg){ export let checkOutputPath = function(tsArrayArg,keyArg){
if (!outputPathIsDir(tsArrayArg,keyArg)) { if (!outputPathIsDir(tsArrayArg,keyArg)) {
plugins.beautylog.warn("Skipping " + keyArg + " because " + tsArrayArg[keyArg] + " it is no directory!") plugins.beautylog.warn('Skipping ' + keyArg + ' because ' + tsArrayArg[keyArg] + ' it is no directory!')
return false return false
} else { } else {
return true; return true
}; };
} }

View File

@ -1,68 +1,68 @@
import "typings-global"; import 'typings-global'
import plugins = require("./npmts.plugins"); import plugins = require('./npmts.plugins')
import paths = require("./npmts.paths"); import paths = require('./npmts.paths')
import helpers = require("./npmts.compile.helpers"); import helpers = require('./npmts.compile.helpers')
import {npmtsOra} from "./npmts.promisechain"; import {npmtsOra} from './npmts.promisechain'
let promiseArray = []; let promiseArray = []
let compileTs = (tsFileArrayArg: string[],tsOptionsArg = {}) => { let compileTs = (tsFileArrayArg: string[],tsOptionsArg = {}) => {
let done = plugins.Q.defer(); let done = plugins.Q.defer()
let compilerOptionsDefault = { let compilerOptionsDefault = {
declaration: true, declaration: true,
module: "CommonJS", module: 'CommonJS',
target: "ES6" target: 'ES6'
}; }
/** /**
* merges default ts options with those found in npmts.json * merges default ts options with those found in npmts.json
*/ */
let compilerOptions = function (keyArg: string) { let compilerOptions = function (keyArg: string) {
let tsOptionsCombined = plugins.lodashObject.merge(compilerOptionsDefault, tsOptionsArg); let tsOptionsCombined = plugins.lodashObject.merge(compilerOptionsDefault, tsOptionsArg)
let compilerOptions: plugins.tsn.CompilerOptions = { let compilerOptions: plugins.tsn.CompilerOptions = {
declaration: tsOptionsCombined.declaration, declaration: tsOptionsCombined.declaration,
module: plugins.tsn.ModuleKind[tsOptionsCombined.module], module: plugins.tsn.ModuleKind[tsOptionsCombined.module],
target: plugins.tsn.ScriptTarget[tsOptionsCombined.target] target: plugins.tsn.ScriptTarget[tsOptionsCombined.target],
}; exclude: 'node_modules/**/*'
return compilerOptions; }
}; return compilerOptions
}
for (let keyArg in tsFileArrayArg) { for (let keyArg in tsFileArrayArg) {
plugins.beautylog.info(`TypeScript assignment: transpile from ${keyArg.blue} to ${tsFileArrayArg[keyArg].blue}`); plugins.beautylog.info(`TypeScript assignment: transpile from ${keyArg.blue} to ${tsFileArrayArg[keyArg].blue}`)
if (helpers.checkOutputPath(tsFileArrayArg,keyArg)) { if (helpers.checkOutputPath(tsFileArrayArg,keyArg)) {
let filesReadPromise = plugins.smartfile.fs.listFileTree(process.cwd(),keyArg) let filesReadPromise = plugins.smartfile.fs.listFileTree(process.cwd(),keyArg)
.then((filesToConvertArg) => { .then((filesToConvertArg) => {
let filesToConvertAbsolute = plugins.smartpath.transform.toAbsolute(filesToConvertArg,process.cwd()); let filesToConvertAbsolute = plugins.smartpath.transform.toAbsolute(filesToConvertArg,process.cwd())
let destDir = plugins.smartpath.transform.toAbsolute(tsFileArrayArg[keyArg],process.cwd()); let destDir = plugins.smartpath.transform.toAbsolute(tsFileArrayArg[keyArg],process.cwd())
let filesCompiledPromise = plugins.tsn.compile( let filesCompiledPromise = plugins.tsn.compile(
filesToConvertAbsolute, filesToConvertAbsolute,
destDir, destDir,
compilerOptions(keyArg) compilerOptions(keyArg)
); )
promiseArray.push(filesCompiledPromise); promiseArray.push(filesCompiledPromise)
}); })
promiseArray.push(filesReadPromise); promiseArray.push(filesReadPromise)
} }
}; };
plugins.Q.all(promiseArray) plugins.Q.all(promiseArray)
.then(done.resolve); .then(done.resolve)
return done.promise; return done.promise
} }
export let run = function (configArg) { export let run = function (configArg) {
let done = plugins.Q.defer(); let done = plugins.Q.defer()
let config = configArg; let config = configArg
npmtsOra.text("now compiling " + "TypeScript".yellow); npmtsOra.text('now compiling ' + 'TypeScript'.yellow)
compileTs(config.ts,config.tsOptions) compileTs(config.ts,config.tsOptions)
.then(() => { .then(() => {
plugins.beautylog.ok("compiled main TypeScript!"); plugins.beautylog.ok('compiled main TypeScript!')
plugins.beautylog.log("now compiling tests!"); plugins.beautylog.log('now compiling tests!')
return compileTs(config.testTs); return compileTs(config.testTs)
}) })
.then(function () { .then(function () {
plugins.beautylog.ok("compiled all TypeScript!"); plugins.beautylog.ok('compiled all TypeScript!')
done.resolve(config); done.resolve(config)
}); })
return done.promise; return done.promise
}; }

View File

@ -1,11 +1,11 @@
import "typings-global"; import 'typings-global'
import plugins = require("./npmts.plugins"); import plugins = require('./npmts.plugins')
import paths = require("./npmts.paths"); import paths = require('./npmts.paths')
import {npmtsOra} from "./npmts.promisechain"; import { npmtsOra } from './npmts.promisechain'
export type npmtsMode = "default" | "custom" export type npmtsMode = 'default' | 'custom'
export interface npmtsConfig { export interface INpmtsConfig {
argv: any, argv: any,
coverageTreshold: number, coverageTreshold: number,
docs: boolean, docs: boolean,
@ -17,65 +17,61 @@ export interface npmtsConfig {
}; };
export var run = function (argvArg) { export var run = function (argvArg) {
let done = plugins.Q.defer(); let done = plugins.Q.defer()
let defaultConfig:npmtsConfig = { let defaultConfig: INpmtsConfig = {
argv: undefined, argv: undefined,
coverageTreshold: 70, coverageTreshold: 70,
docs: true, docs: true,
mode:"default", mode: 'default',
test: true, test: true,
testTs: {}, testTs: {},
ts: {}, ts: {},
tsOptions: {} tsOptions: {}
}; }
// mix with configfile // mix with configfile
npmtsOra.text("looking for npmextra.json"); npmtsOra.text('looking for npmextra.json')
let config:npmtsConfig = plugins.npmextra.dataFor({ let config: INpmtsConfig = plugins.npmextra.dataFor({
toolName:"npmts", toolName: 'npmts',
defaultSettings: defaultConfig, defaultSettings: defaultConfig,
cwd: paths.cwd cwd: paths.cwd
}); })
// add argv // add argv
config.argv = argvArg; config.argv = argvArg
// check mode // check mode
switch (config.mode) { switch (config.mode) {
case "default": case 'default':
case "custom": case 'custom':
plugins.beautylog.ok("mode is " + config.mode); plugins.beautylog.ok('mode is ' + config.mode)
done.resolve(config); done.resolve(config)
break; break
default: default:
plugins.beautylog.error(`mode not recognised!`); plugins.beautylog.error(`mode not recognised!`)
process.exit(1); process.exit(1)
}; };
// handle default mode // handle default mode
if (config.mode == "default"){ if (config.mode === 'default') {
config.ts = { config.ts = {
["./ts/**/*.ts"]: "./dist/" ['./ts/**/*.ts']: './dist/'
}; }
config.testTs = { config.testTs = {
["./test/test.ts"]: "./test/" ['./test/test.ts']: './test/'
}
}; };
};
// mix with commandline // mix with commandline
if (config.argv.notest) { if (config.argv.notest) {
config.test = false; config.test = false
}; };
if (config.argv.nodocs) { if (config.argv.nodocs) {
config.docs = false; config.docs = false
}; };
plugins.beautylog.ok('build options are ready!')
plugins.beautylog.ok("build options are ready!"); done.resolve(config)
done.resolve(config); return done.promise
return done.promise; }
};

View File

@ -1,26 +1,25 @@
import "typings-global"; import 'typings-global'
import plugins = require("./npmts.plugins"); import plugins = require('./npmts.plugins')
// NPMTS Paths // NPMTS Paths
export let npmtsPackageRoot = plugins.path.join(__dirname,"../"); export let npmtsPackageRoot = plugins.path.join(__dirname,'../')
// Project paths // Project paths
export let cwd = process.cwd(); export let cwd = process.cwd()
// Directories // Directories
export let tsDir = plugins.path.join(cwd,"ts/"); export let tsDir = plugins.path.join(cwd,'ts/')
export let distDir = plugins.path.join(cwd,"dist/"); export let distDir = plugins.path.join(cwd,'dist/')
export let testDir = plugins.path.join(cwd,"test/"); export let testDir = plugins.path.join(cwd,'test/')
export let typingsDir = plugins.path.join(cwd,"ts/typings/"); export let typingsDir = plugins.path.join(cwd,'ts/typings/')
export let coverageDir = plugins.path.join(cwd,"coverage/"); export let coverageDir = plugins.path.join(cwd,'coverage/')
// Pages // Pages
export let pagesDir = plugins.path.join(cwd,"pages/"); export let pagesDir = plugins.path.join(cwd,'pages/')
export let pagesApiDir = plugins.path.join(pagesDir,"/api"); export let pagesApiDir = plugins.path.join(pagesDir,'/api')
export let npmtsAssetsDir = plugins.path.join(__dirname,"../assets/"); export let npmtsAssetsDir = plugins.path.join(__dirname,'../assets/')
// Files // Files
export let indexTS = plugins.path.join(cwd,"ts/index.ts"); export let indexTS = plugins.path.join(cwd,'ts/index.ts')
export let testTS = plugins.path.join(cwd,"ts/test.ts"); export let testTS = plugins.path.join(cwd,'ts/test.ts')

View File

@ -1,27 +1,27 @@
import "typings-global"; import 'typings-global'
export import beautylog = require("beautylog"); export import beautylog = require('beautylog')
export let depcheck = require("depcheck"); export let depcheck = require('depcheck')
export import gulp = require("gulp"); export import gulp = require('gulp')
export let g = { export let g = {
babel: require("gulp-babel"), babel: require('gulp-babel'),
istanbul: require("gulp-istanbul"), istanbul: require('gulp-istanbul'),
gFunction: require("gulp-function"), gFunction: require('gulp-function'),
injectModules: require("gulp-inject-modules"), injectModules: require('gulp-inject-modules'),
mocha: require("gulp-mocha"), mocha: require('gulp-mocha'),
sourcemaps: require("gulp-sourcemaps"), sourcemaps: require('gulp-sourcemaps'),
typedoc: require("gulp-typedoc") typedoc: require('gulp-typedoc')
}; }
export import lodashObject = require('lodash'); export import lodashObject = require('lodash')
export import npmextra = require("npmextra"); export import npmextra = require('npmextra')
export import projectinfo = require("projectinfo"); export import projectinfo = require('projectinfo')
export import path = require("path"); export import path = require('path')
export import Q = require("q"); export import Q = require('q')
export import shelljs = require("shelljs"); export import shelljs = require('shelljs')
export import smartcli = require("smartcli"); export import smartcli = require('smartcli')
export import smartcov = require("smartcov"); export import smartcov = require('smartcov')
export import smartenv = require("smartenv"); export import smartenv = require('smartenv')
export import smartfile = require("smartfile"); export import smartfile = require('smartfile')
export import smartpath = require("smartpath"); export import smartpath = require('smartpath')
export import smartstring = require("smartstring"); export import smartstring = require('smartstring')
export let sourceMapSupport = require("source-map-support").install(); // this is required to display errors correctly during testing export let sourceMapSupport = require('source-map-support').install() // display errors correctly during testing
export import tsn = require("tsn"); export import tsn = require('tsn')

View File

@ -1,20 +1,20 @@
import "typings-global"; import 'typings-global'
import plugins = require("./npmts.plugins"); import plugins = require('./npmts.plugins')
import {Ora} from "beautylog" import {Ora} from 'beautylog'
export let npmtsOra = new plugins.beautylog.Ora("setting up TaskChain","cyan"); export let npmtsOra = new Ora('setting up TaskChain','cyan')
import NpmtsAssets = require("./npmts.assets"); import NpmtsAssets = require('./npmts.assets')
import NpmtsCheck = require("./npmts.check"); import NpmtsCheck = require('./npmts.check')
import NpmtsClean = require("./npmts.clean"); import NpmtsClean = require('./npmts.clean')
import NpmtsCompile = require("./npmts.compile"); import NpmtsCompile = require('./npmts.compile')
import NpmtsTypeDoc = require("./npmts.typedoc"); import NpmtsTypeDoc = require('./npmts.typedoc')
import NpmtsOptions = require("./npmts.options"); import NpmtsOptions = require('./npmts.options')
import NpmtsTests = require("./npmts.tests"); import NpmtsTests = require('./npmts.tests')
export let promisechain = function(argvArg){ export let promisechain = function(argvArg){
let done = plugins.Q.defer(); let done = plugins.Q.defer()
npmtsOra.start(); npmtsOra.start()
NpmtsOptions.run(argvArg) NpmtsOptions.run(argvArg)
.then(NpmtsClean.run) .then(NpmtsClean.run)
.then(NpmtsCheck.run) .then(NpmtsCheck.run)
@ -23,27 +23,27 @@ export let promisechain = function(argvArg){
.then(NpmtsTypeDoc.run) .then(NpmtsTypeDoc.run)
.then(NpmtsTests.run) .then(NpmtsTests.run)
.then(function(configArg){ .then(function(configArg){
let shipString = "" + let shipString = '' +
"\n" + '\n' +
"\n" + '\n' +
" # # ( )\n" + ' # # ( )\n' +
" ___#_#___|__\n" + ' ___#_#___|__\n' +
" _ |____________| _\n" + ' _ |____________| _\n' +
" _=====| | | | | |==== _\n" + ' _=====| | | | | |==== _\n' +
" =====| |.---------------------------. | |====\n" + ' =====| |.---------------------------. | |====\n' +
" <--------------------' . . . . . . . . '--------------/\n" + " <--------------------' . . . . . . . . '--------------/\n" +
" \\ /\n" + ' \\ /\n' +
" \\___________________________________________________________/\n" + ' \\___________________________________________________________/\n' +
" wwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwww\n" + ' wwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwww\n' +
" wwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwww\n" + ' wwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwww\n' +
" wwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwww\n" ' wwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwww\n'
if (process.env.CI) { if (process.env.CI) {
console.log(shipString); console.log(shipString)
plugins.beautylog.success("READY TO SHIP!"); plugins.beautylog.success('READY TO SHIP!')
} else { } else {
plugins.beautylog.success("Done!"); plugins.beautylog.success('Done!')
}
done.resolve()
})
return done.promise
} }
done.resolve();
});
return done.promise;
};

View File

@ -1,87 +1,94 @@
import "typings-global"; import 'typings-global'
import plugins = require("./npmts.plugins"); import plugins = require('./npmts.plugins')
import paths = require("./npmts.paths"); import paths = require('./npmts.paths')
import {npmtsOra} from "./npmts.promisechain"; import { npmtsOra } from './npmts.promisechain'
/** /**
* *
* @returns {*} * @returns {*}
*/ */
let mocha = function (configArg) { let mocha = function (configArg) {
npmtsOra.text("Instrumentalizing and testing transpiled JS"); npmtsOra.text('Instrumentalizing and testing transpiled JS')
npmtsOra.end(); // end npmtsOra for tests. npmtsOra.end() // end npmtsOra for tests.
let done = plugins.Q.defer(); let done = plugins.Q.defer()
var stream = plugins.gulp.src([plugins.path.join(paths.cwd,"dist/*.js")]) plugins.gulp.src([plugins.path.join(paths.cwd, 'dist/*.js')])
.pipe(plugins.g.sourcemaps.init()) .pipe(plugins.g.sourcemaps.init())
.pipe(plugins.g.babel({ .pipe(plugins.g.babel({
presets: [ presets: [
require.resolve("babel-preset-es2015") require.resolve('babel-preset-es2015')
] ]
})) }))
.pipe(plugins.g.istanbul({ .pipe(plugins.g.istanbul({
})) }))
.pipe(plugins.g.sourcemaps.write()) .pipe(plugins.g.sourcemaps.write())
.pipe(plugins.g.injectModules()) .pipe(plugins.g.injectModules())
.on("finish",function(){ .on('finish', function () {
plugins.gulp.src([plugins.path.join(paths.cwd,"test/test.js")]) plugins.gulp.src([plugins.path.join(paths.cwd, 'test/test.js')])
.pipe(plugins.g.babel({ .pipe(plugins.g.babel({
presets: [ presets: [
require.resolve("babel-preset-es2015") require.resolve('babel-preset-es2015')
] ]
})) }))
.pipe(plugins.g.injectModules()) .pipe(plugins.g.injectModules())
.pipe(plugins.g.mocha()) .pipe(plugins.g.mocha())
.pipe(plugins.g.istanbul.writeReports({ .pipe(plugins.g.istanbul.writeReports({
dir: plugins.path.join(paths.cwd,"./coverage"), dir: plugins.path.join(paths.cwd, './coverage'),
reporters: ['lcovonly', 'json', 'text', 'text-summary'] reporters: ['lcovonly', 'json', 'text', 'text-summary']
})) }))
.pipe(plugins.g.gFunction(function(){ .pipe(plugins.g.gFunction(
plugins.beautylog.ok("Tested!"); function () {
done.resolve(configArg); plugins.beautylog.ok('Tested!')
},"atEnd")); done.resolve(configArg)
}); },
return done.promise; 'atEnd'
}; ))
})
return done.promise
}
let coverage = function (configArg) { let coverage = function (configArg) {
let done = plugins.Q.defer(); let done = plugins.Q.defer()
plugins.smartcov.get.percentage(plugins.path.join(paths.coverageDir,"lcov.info"),2) plugins.smartcov.get.percentage(plugins.path.join(paths.coverageDir, 'lcov.info'), 2)
.then(function (percentageArg) { .then(function (percentageArg) {
if (percentageArg >= configArg.coverageTreshold) { if (percentageArg >= configArg.coverageTreshold) {
plugins.beautylog.ok( plugins.beautylog.ok(
`${percentageArg.toString()}% coverage exceeds your treshold of ${configArg.coverageTreshold.toString()}%` `${percentageArg.toString()}% `
); + `coverage exceeds your treshold of `
+ `${configArg.coverageTreshold.toString()}%`
)
} else { } else {
plugins.beautylog.warn( plugins.beautylog.warn(
`${percentageArg.toString()}% coverage fails your treshold of ${configArg.coverageTreshold.toString()}%` `${percentageArg.toString()}% `
); + `coverage fails your treshold of `
plugins.beautylog.error("exiting due to coverage failure"); + `${configArg.coverageTreshold.toString()}%`
process.exit(1); )
plugins.beautylog.error('exiting due to coverage failure')
process.exit(1)
}
done.resolve(configArg)
})
return done.promise
} }
done.resolve(configArg);
});
return done.promise;
};
export let run = function (configArg) { export let run = function (configArg) {
let done = plugins.Q.defer(); let done = plugins.Q.defer()
let config = configArg; let config = configArg
if (config.test === true) { if (config.test === true) {
npmtsOra.text("now starting tests"); npmtsOra.text('now starting tests')
plugins.beautylog.log( plugins.beautylog.log(
"-------------------------------------------------------\n" + '-------------------------------------------------------\n' +
"*************************** TESTS: ***************************\n" + '*************************** TESTS: ***************************\n' +
"--------------------------------------------------------------" '--------------------------------------------------------------'
); )
mocha(config) mocha(config)
.then(coverage) .then(coverage)
.then(() => { .then(() => {
done.resolve(config); done.resolve(config)
}); })
} else { } else {
npmtsOra.end(); npmtsOra.end()
done.resolve(config); done.resolve(config)
}
return done.promise
} }
return done.promise;
};

View File

@ -1,44 +1,45 @@
import "typings-global"; import 'typings-global'
import plugins = require("./npmts.plugins"); import plugins = require('./npmts.plugins')
import paths = require("./npmts.paths"); import paths = require('./npmts.paths')
import { npmtsOra } from "./npmts.promisechain"; import { npmtsOra } from './npmts.promisechain'
import { projectInfo } from './npmts.check'
let genTypeDoc = function (configArg) { let genTypeDoc = function (configArg) {
let done = plugins.Q.defer(); let done = plugins.Q.defer()
npmtsOra.text("now generating " + "TypeDoc documentation".yellow); npmtsOra.text('now generating ' + 'TypeDoc documentation'.yellow)
plugins.beautylog.log("TypeDoc Output:"); plugins.beautylog.log('TypeDoc Output:')
plugins.gulp.src(plugins.path.join(paths.tsDir, "**/*.ts")) plugins.gulp.src(plugins.path.join(paths.tsDir, '**/*.ts'))
.pipe(plugins.g.typedoc({ .pipe(plugins.g.typedoc({
// TypeScript options (see typescript docs) // TypeScript options (see typescript docs)
module: "commonjs", module: 'commonjs',
target: "es6", target: 'es6',
includeDeclarations: true, includeDeclarations: true,
// Output options (see typedoc docs) // Output options (see typedoc docs)
out: paths.pagesApiDir, out: paths.pagesApiDir,
json: plugins.path.join(paths.pagesApiDir, "file.json"), json: plugins.path.join(paths.pagesApiDir, 'file.json'),
// TypeDoc options (see typedoc docs) // TypeDoc options (see typedoc docs)
name: "my-project", name: projectInfo.name,
readme: plugins.path.join(paths.cwd, 'README.md'),
// theme: "default", // theme: "default",
ignoreCompilerErrors: true, ignoreCompilerErrors: true,
version: true, version: true
})) }))
.pipe(plugins.g.gFunction(done.resolve, "atEnd")); .pipe(plugins.g.gFunction(done.resolve, 'atEnd'))
return done.promise; return done.promise
}; }
export let run = function (configArg) { export let run = function (configArg) {
let done = plugins.Q.defer(); let done = plugins.Q.defer()
if (configArg.docs) { if (configArg.docs) {
genTypeDoc(configArg) genTypeDoc(configArg)
.then(() => { .then(() => {
done.resolve(configArg); done.resolve(configArg)
}); })
} else { } else {
done.resolve(configArg); done.resolve(configArg)
};
return done.promise;
}; };
return done.promise
}

3
tslint.json Normal file
View File

@ -0,0 +1,3 @@
{
"extends": "tslint-config-standard"
}