Compare commits
78 Commits
Author | SHA1 | Date | |
---|---|---|---|
d2182a6d0f | |||
b7e48313e1 | |||
9f8e30526f | |||
8dd5c97f3b | |||
58b6a9a328 | |||
1c4020824d | |||
521e5740e5 | |||
ce76702d53 | |||
4590c8f64e | |||
ab7155f198 | |||
feba451f90 | |||
1ba1b0447b | |||
e4db3ba7ee | |||
da209ecc06 | |||
e010b01c42 | |||
225c46a788 | |||
7883f1cb7d | |||
394dd88a1d | |||
1d8fee1506 | |||
88d5409c40 | |||
b8c9508d21 | |||
59f97c3254 | |||
0491493b2e | |||
aca45165f8 | |||
569c597f8b | |||
5f17ea48ed | |||
6a9cdd297a | |||
0a363b441c | |||
3af6edd5e6 | |||
9a26f1367d | |||
15dd17e7a7 | |||
3b704dbde5 | |||
48aeb16dfd | |||
b40d8452ec | |||
d8281f098a | |||
3ffee9d0d6 | |||
03dfdda812 | |||
24cce5d9b2 | |||
295e568097 | |||
846bcf66db | |||
fc7d7fd27f | |||
9829c7bb1e | |||
6827999cf8 | |||
b318fa2076 | |||
0c751e1bca | |||
cb489552f2 | |||
addd66091f | |||
c2f8199f0b | |||
5e5696cce1 | |||
44d9782487 | |||
41592a4d2f | |||
23367249ec | |||
b415bf4ee7 | |||
86b6a6c3c4 | |||
ffbfc29628 | |||
9c6e452801 | |||
96c421e96e | |||
84af99ba80 | |||
6bb20dbc7b | |||
66a7fc2afe | |||
a42faf36d2 | |||
6db7cc0e14 | |||
102d384de5 | |||
1ceae01a49 | |||
7f4adbfe9f | |||
eb72e2dccc | |||
839c80f5dd | |||
e7e96972ad | |||
799c2a58ca | |||
1955dadba3 | |||
c14fadadf7 | |||
3f1a05d3e0 | |||
5908dc8b6f | |||
d7ecf8e320 | |||
8b73f7a6bb | |||
00d9ad0af1 | |||
ef20c00999 | |||
4dab0f250a |
4
.gitignore
vendored
Normal file
4
.gitignore
vendored
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
node_modules/
|
||||||
|
docs/
|
||||||
|
coverage/
|
||||||
|
ts/typings/
|
35
.gitlab-ci.yml
Normal file
35
.gitlab-ci.yml
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
image: hosttoday/ht-docker-node:npmts
|
||||||
|
|
||||||
|
stages:
|
||||||
|
- test
|
||||||
|
- release
|
||||||
|
|
||||||
|
testLEGACY:
|
||||||
|
stage: test
|
||||||
|
script:
|
||||||
|
- npmci test legacy
|
||||||
|
tags:
|
||||||
|
- docker
|
||||||
|
|
||||||
|
testLTS:
|
||||||
|
stage: test
|
||||||
|
script:
|
||||||
|
- npmci test lts
|
||||||
|
tags:
|
||||||
|
- docker
|
||||||
|
|
||||||
|
testSTABLE:
|
||||||
|
stage: test
|
||||||
|
script:
|
||||||
|
- npmci test stable
|
||||||
|
tags:
|
||||||
|
- docker
|
||||||
|
|
||||||
|
release:
|
||||||
|
stage: release
|
||||||
|
script:
|
||||||
|
- npmci publish
|
||||||
|
only:
|
||||||
|
- tags
|
||||||
|
tags:
|
||||||
|
- docker
|
2
.npmignore
Normal file
2
.npmignore
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
docs/
|
||||||
|
coverage/
|
12
.travis.yml
Normal file
12
.travis.yml
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
language: node_js
|
||||||
|
node_js:
|
||||||
|
- '4'
|
||||||
|
- stable
|
||||||
|
deploy:
|
||||||
|
provider: npm
|
||||||
|
email: npm@lossless.digital
|
||||||
|
api_key:
|
||||||
|
secure: WmJJw1aJ1kbTOtArdBvgtYEcEk2899hiPc/XnCoUrHz45DAgnAES4eVUbhI5AC78tjnKc+iqbB9e5+vziSW4G5P4KAuP0CYLd5v4G5ZC4IYigFPxroIib7wFtGoOlhe8AItLDMdYO2KcPYXVpZzaITj2FlfNjoqg5UiKnSVShKwUALQk6JdZ345d0iwyr2nmNA6m0FJhcO2weY3BEDRyPWuody/FEoVZ3I2Q1f3R50v3Kb7Nzfn0uob5ABjux4YZ4xJ6tNeJkU021tSgJhjqfwbVMoIVJohwa5jlaqXdMQvWWKvhOAFyDj6zOJ1BnIuVYltDoWczuPi3+YVtFoc2+rYdSXYUcK1aCfVQZ8DDYYzlZ9Sp1vxiy8D3RZuNkLzUImranCDl6r6EYTxEw2L2bAowo9wLZtnht/mlRvOOLM9ZYVi0yr7Cd9FhVfiLZO97OGybfTFvih+nbMZGk5/RVeQzYzsycgeNT96ii5+de0yerbD690Qf+Kap5IlS5Fyvo2Y/SVQ3nxgQt7Pa4bTLbMwzSmXoBgUO6j6d8Qv7fPGQvbOQJEGJaZDaqpgxxS7WIc2YtwLXXob757BxKNW6Y6xPCcTqX7lMqfyQa194EjPTNTK+O0YnGAFFnXps/uCc8ccH3z3x6IrAAQpPx68gPERiWMf2WiPsMoh+kH4UzLc=
|
||||||
|
on:
|
||||||
|
tags: true
|
||||||
|
repo: pushrocks/early
|
16
README.md
16
README.md
@ -1,12 +1,16 @@
|
|||||||
# early
|
# early
|
||||||
nice module loading animation for modules that need a little starting time.
|
minimal and fast loading animation for modules that need a little starting time.
|
||||||
|
|
||||||
> **note: this package is NOT READY YET**
|
## Usage
|
||||||
|
|
||||||
```typscript
|
```typescript
|
||||||
|
// Put the following at the start of your module
|
||||||
import * as early from "early";
|
import * as early from "early";
|
||||||
early.start();
|
early.start("myModuleName");
|
||||||
// do your loading stuff
|
/*
|
||||||
early.stop();
|
do your loading stuff
|
||||||
|
*/
|
||||||
|
early.stop(); // stop "early" when your module is ready
|
||||||
```
|
```
|
||||||
|
|
||||||
|
early runs in its own process: The loader animation runs smoothly even when your event queue of your currently loading module is working heavily.
|
||||||
|
1
dist/early.child.d.ts
vendored
Normal file
1
dist/early.child.d.ts
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
import "typings-global";
|
43
dist/early.child.js
vendored
Normal file
43
dist/early.child.js
vendored
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
"use strict";
|
||||||
|
require("typings-global");
|
||||||
|
const chalk = require("chalk");
|
||||||
|
const readline = require("readline");
|
||||||
|
let rl = readline.createInterface({
|
||||||
|
input: process.stdin,
|
||||||
|
output: process.stdout
|
||||||
|
});
|
||||||
|
let moduleName;
|
||||||
|
let loaderLength;
|
||||||
|
let frameCounter = 0;
|
||||||
|
let makeFrame = () => {
|
||||||
|
let resultString = `[${chalk.green("/".repeat(frameCounter))}${" ".repeat(loaderLength - frameCounter)}] starting ${moduleName}`;
|
||||||
|
if (frameCounter == loaderLength) {
|
||||||
|
frameCounter = 0;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
frameCounter++;
|
||||||
|
}
|
||||||
|
return resultString;
|
||||||
|
};
|
||||||
|
let logEarlyAbort = false;
|
||||||
|
let logEarly = () => {
|
||||||
|
if (!logEarlyAbort) {
|
||||||
|
rl.write(null, { ctrl: true, name: 'u' });
|
||||||
|
rl.write(makeFrame());
|
||||||
|
setTimeout(function () {
|
||||||
|
logEarly();
|
||||||
|
}, 80);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
let start = function (moduleNameArg = "", loaderLengthArg = "10") {
|
||||||
|
moduleName = moduleNameArg;
|
||||||
|
loaderLength = parseInt(loaderLengthArg);
|
||||||
|
logEarly();
|
||||||
|
};
|
||||||
|
start(process.env.moduleNameArg, process.env.loaderLengthArg);
|
||||||
|
process.on('SIGINT', () => {
|
||||||
|
logEarlyAbort = true;
|
||||||
|
rl.write(null, { ctrl: true, name: 'u' });
|
||||||
|
process.exit(0);
|
||||||
|
});
|
||||||
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWFybHkuY2hpbGQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90cy9lYXJseS5jaGlsZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsUUFBTyxnQkFBZ0IsQ0FBQyxDQUFBO0FBQ3hCLE1BQU8sS0FBSyxXQUFXLE9BQU8sQ0FBQyxDQUFDO0FBQ2hDLE1BQU8sUUFBUSxXQUFXLFVBQVUsQ0FBQyxDQUFDO0FBQ3RDLElBQUksRUFBRSxHQUFHLFFBQVEsQ0FBQyxlQUFlLENBQUM7SUFDOUIsS0FBSyxFQUFFLE9BQU8sQ0FBQyxLQUFLO0lBQ3BCLE1BQU0sRUFBRSxPQUFPLENBQUMsTUFBTTtDQUN6QixDQUFDLENBQUM7QUFFSCxJQUFJLFVBQWtCLENBQUM7QUFDdkIsSUFBSSxZQUFvQixDQUFDO0FBQ3pCLElBQUksWUFBWSxHQUFXLENBQUMsQ0FBQztBQUU3QixJQUFJLFNBQVMsR0FBRztJQUNaLElBQUksWUFBWSxHQUFXLElBQUksS0FBSyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLFlBQVksQ0FBQyxDQUFDLEdBQUcsR0FBRyxDQUFDLE1BQU0sQ0FBQyxZQUFZLEdBQUcsWUFBWSxDQUFDLGNBQWMsVUFBVSxFQUFFLENBQUM7SUFDekksRUFBRSxDQUFDLENBQUMsWUFBWSxJQUFJLFlBQVksQ0FBQyxDQUFDLENBQUM7UUFDL0IsWUFBWSxHQUFHLENBQUMsQ0FBQztJQUNyQixDQUFDO0lBQUMsSUFBSSxDQUFDLENBQUM7UUFDSixZQUFZLEVBQUUsQ0FBQztJQUNuQixDQUFDO0lBQ0QsTUFBTSxDQUFDLFlBQVksQ0FBQztBQUN4QixDQUFDLENBQUM7QUFFRixJQUFJLGFBQWEsR0FBRyxLQUFLLENBQUM7QUFDMUIsSUFBSSxRQUFRLEdBQUc7SUFDWCxFQUFFLENBQUMsQ0FBQyxDQUFDLGFBQWEsQ0FBQyxDQUFDLENBQUM7UUFDakIsRUFBRSxDQUFDLEtBQUssQ0FBQyxJQUFJLEVBQUUsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDO1FBQzFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsU0FBUyxFQUFFLENBQUMsQ0FBQztRQUN0QixVQUFVLENBQUM7WUFDUCxRQUFRLEVBQUUsQ0FBQztRQUNmLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztJQUNYLENBQUM7QUFDTCxDQUFDLENBQUM7QUFFRixJQUFJLEtBQUssR0FBRyxVQUFVLGFBQWEsR0FBVyxFQUFFLEVBQUUsZUFBZSxHQUFXLElBQUk7SUFDNUUsVUFBVSxHQUFHLGFBQWEsQ0FBQztJQUMzQixZQUFZLEdBQUcsUUFBUSxDQUFDLGVBQWUsQ0FBQyxDQUFDO0lBQ3pDLFFBQVEsRUFBRSxDQUFDO0FBQ2YsQ0FBQyxDQUFDO0FBRUYsS0FBSyxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsYUFBYSxFQUFFLE9BQU8sQ0FBQyxHQUFHLENBQUMsZUFBZSxDQUFDLENBQUM7QUFFOUQsT0FBTyxDQUFDLEVBQUUsQ0FBQyxRQUFRLEVBQUU7SUFDakIsYUFBYSxHQUFHLElBQUksQ0FBQztJQUNyQixFQUFFLENBQUMsS0FBSyxDQUFDLElBQUksRUFBRSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUM7SUFDMUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUNwQixDQUFDLENBQUMsQ0FBQyJ9
|
5
dist/index.d.ts
vendored
Normal file
5
dist/index.d.ts
vendored
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
/// <reference types="q" />
|
||||||
|
import "typings-global";
|
||||||
|
import q = require("q");
|
||||||
|
export declare let start: (moduleNameArg?: string, loaderLengthArg?: string) => void;
|
||||||
|
export declare let stop: () => q.Promise<{}>;
|
52
dist/index.js
vendored
Normal file
52
dist/index.js
vendored
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
"use strict";
|
||||||
|
require("typings-global");
|
||||||
|
const path = require("path");
|
||||||
|
const chalk = require("chalk");
|
||||||
|
const q = require("q");
|
||||||
|
const childProcess = require("child_process");
|
||||||
|
let earlyChild;
|
||||||
|
let doAnimation = true;
|
||||||
|
let doText = false;
|
||||||
|
let moduleName = "undefined module name";
|
||||||
|
let startTime;
|
||||||
|
if (process.argv.indexOf("-v") != -1 || process.env.CI) {
|
||||||
|
doAnimation = false;
|
||||||
|
}
|
||||||
|
if (process.argv.indexOf("-v") == -1 && process.env.CI) {
|
||||||
|
doText = true;
|
||||||
|
}
|
||||||
|
// exports
|
||||||
|
exports.start = function (moduleNameArg = "", loaderLengthArg = "10") {
|
||||||
|
startTime = Date.now();
|
||||||
|
moduleName = moduleNameArg;
|
||||||
|
if (doAnimation) {
|
||||||
|
earlyChild = childProcess.fork(path.join(__dirname, "early.child.js"), [], {
|
||||||
|
env: {
|
||||||
|
moduleNameArg: moduleNameArg,
|
||||||
|
loaderLengthArg: loaderLengthArg,
|
||||||
|
CI: process.env.CI
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
else if (doText) {
|
||||||
|
console.log(`**** starting ${chalk.green(moduleNameArg)} ****`);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
exports.stop = function () {
|
||||||
|
let done = q.defer();
|
||||||
|
let endTime = Date.now();
|
||||||
|
let executionTime = ((endTime - startTime) / 1000).toString();
|
||||||
|
if (doAnimation) {
|
||||||
|
earlyChild.kill("SIGINT");
|
||||||
|
earlyChild.on("close", function () {
|
||||||
|
console.log(`loaded ${chalk.green(moduleName)} in ${executionTime} seconds!`);
|
||||||
|
done.resolve();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
console.log(`... finished loading ${moduleName} in ${executionTime}`);
|
||||||
|
done.resolve();
|
||||||
|
}
|
||||||
|
return done.promise;
|
||||||
|
};
|
||||||
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsUUFBTyxnQkFDUCxDQUFDLENBRHNCO0FBQ3ZCLE1BQU8sSUFBSSxXQUFXLE1BQU0sQ0FBQyxDQUFDO0FBQzlCLE1BQU8sS0FBSyxXQUFXLE9BQU8sQ0FBQyxDQUFDO0FBQ2hDLE1BQU8sQ0FBQyxXQUFXLEdBQUcsQ0FBQyxDQUFDO0FBRXhCLE1BQU8sWUFBWSxXQUFXLGVBQWUsQ0FBQyxDQUFDO0FBQy9DLElBQUksVUFBVSxDQUFDO0FBRWYsSUFBSSxXQUFXLEdBQVksSUFBSSxDQUFDO0FBQ2hDLElBQUksTUFBTSxHQUFZLEtBQUssQ0FBQztBQUM1QixJQUFJLFVBQVUsR0FBVyx1QkFBdUIsQ0FBQztBQUNqRCxJQUFJLFNBQVMsQ0FBQztBQUVkLEVBQUUsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJLE9BQU8sQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztJQUNyRCxXQUFXLEdBQUcsS0FBSyxDQUFDO0FBQ3hCLENBQUM7QUFDRCxFQUFFLENBQUMsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsSUFBSSxPQUFPLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFDckQsTUFBTSxHQUFHLElBQUksQ0FBQztBQUNsQixDQUFDO0FBRUQsVUFBVTtBQUNDLGFBQUssR0FBRyxVQUFVLGFBQWEsR0FBVyxFQUFFLEVBQUUsZUFBZSxHQUFXLElBQUk7SUFFbkYsU0FBUyxHQUFHLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQztJQUV2QixVQUFVLEdBQUcsYUFBYSxDQUFDO0lBQzNCLEVBQUUsQ0FBQyxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUM7UUFDZCxVQUFVLEdBQUcsWUFBWSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxnQkFBZ0IsQ0FBQyxFQUFFLEVBQUUsRUFBRTtZQUN2RSxHQUFHLEVBQUU7Z0JBQ0QsYUFBYSxFQUFFLGFBQWE7Z0JBQzVCLGVBQWUsRUFBRSxlQUFlO2dCQUNoQyxFQUFFLEVBQUUsT0FBTyxDQUFDLEdBQUcsQ0FBQyxFQUFFO2FBQ3JCO1NBQ0osQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO1FBQ2hCLE9BQU8sQ0FBQyxHQUFHLENBQUMsaUJBQWlCLEtBQUssQ0FBQyxLQUFLLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ3BFLENBQUM7QUFDTCxDQUFDLENBQUM7QUFFUyxZQUFJLEdBQUc7SUFDZCxJQUFJLElBQUksR0FBRyxDQUFDLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDckIsSUFBSSxPQUFPLEdBQUcsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDO0lBQ3pCLElBQUksYUFBYSxHQUFVLENBQUMsQ0FBQyxPQUFPLEdBQUcsU0FBUyxDQUFDLEdBQUcsSUFBSSxDQUFDLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDckUsRUFBRSxDQUFDLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQztRQUNkLFVBQVUsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDMUIsVUFBVSxDQUFDLEVBQUUsQ0FBQyxPQUFPLEVBQUU7WUFDbkIsT0FBTyxDQUFDLEdBQUcsQ0FBQyxVQUFVLEtBQUssQ0FBQyxLQUFLLENBQUMsVUFBVSxDQUFDLE9BQU8sYUFBYSxXQUFXLENBQUMsQ0FBQztZQUM5RSxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7UUFDbkIsQ0FBQyxDQUFDLENBQUE7SUFDTixDQUFDO0lBQUMsSUFBSSxDQUFDLENBQUM7UUFDSixPQUFPLENBQUMsR0FBRyxDQUFDLHdCQUF3QixVQUFVLE9BQU8sYUFBYSxFQUFFLENBQUMsQ0FBQztRQUN0RSxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDbkIsQ0FBQztJQUNELE1BQU0sQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDO0FBQ3hCLENBQUMsQ0FBQyJ9
|
5
npmextra.json
Normal file
5
npmextra.json
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
{
|
||||||
|
"npmts":{
|
||||||
|
"coverageTreshold":50
|
||||||
|
}
|
||||||
|
}
|
4
npmts.json
Normal file
4
npmts.json
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
{
|
||||||
|
"mode":"default",
|
||||||
|
"coverageTreshold":30
|
||||||
|
}
|
20
package.json
20
package.json
@ -1,14 +1,15 @@
|
|||||||
{
|
{
|
||||||
"name": "early",
|
"name": "early",
|
||||||
"version": "1.0.1",
|
"version": "2.0.26",
|
||||||
"description": "nice module loading animation for modules that need a little starting time.",
|
"description": "nice module loading animation for modules that need a little starting time.",
|
||||||
"main": "dist/index.js",
|
"main": "dist/index.js",
|
||||||
|
"typings": "dist/index.d.ts",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"test": "(npmts)"
|
"test": "(npmts)"
|
||||||
},
|
},
|
||||||
"repository": {
|
"repository": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "git+https://github.com/pushrocks/early.git"
|
"url": "git+https://gitlab.com/pushrocks/early.git"
|
||||||
},
|
},
|
||||||
"keywords": [
|
"keywords": [
|
||||||
"preloader"
|
"preloader"
|
||||||
@ -16,7 +17,18 @@
|
|||||||
"author": "Lossless GmbH",
|
"author": "Lossless GmbH",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"bugs": {
|
"bugs": {
|
||||||
"url": "https://github.com/pushrocks/early/issues"
|
"url": "https://gitlab.com/pushrocks/early/issues"
|
||||||
},
|
},
|
||||||
"homepage": "https://github.com/pushrocks/early#readme"
|
"homepage": "https://gitlab.com/pushrocks/early#readme",
|
||||||
|
"devDependencies": {
|
||||||
|
"npmts-g": "^5.2.8",
|
||||||
|
"typings-test": "^1.0.1"
|
||||||
|
},
|
||||||
|
"dependencies": {
|
||||||
|
"@types/chalk": "^0.4.28",
|
||||||
|
"@types/q": "0.x.x",
|
||||||
|
"chalk": "^1.1.3",
|
||||||
|
"q": "^1.4.1",
|
||||||
|
"typings-global": "^1.0.6"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
1
test/test.d.ts
vendored
Normal file
1
test/test.d.ts
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
import "typings-test";
|
15
test/test.js
Normal file
15
test/test.js
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
"use strict";
|
||||||
|
require("typings-test");
|
||||||
|
const early = require("../dist/index");
|
||||||
|
describe("early", function () {
|
||||||
|
it(".start()", function (done) {
|
||||||
|
this.timeout(10000);
|
||||||
|
early.start("early");
|
||||||
|
setTimeout(done, 5000);
|
||||||
|
});
|
||||||
|
it(".stop()", function (done) {
|
||||||
|
early.stop()
|
||||||
|
.then(done);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInRlc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLFFBQU8sY0FBYyxDQUFDLENBQUE7QUFDdEIsTUFBTyxLQUFLLFdBQVcsZUFBZSxDQUFDLENBQUM7QUFFeEMsUUFBUSxDQUFDLE9BQU8sRUFBQztJQUNiLEVBQUUsQ0FBQyxVQUFVLEVBQUMsVUFBUyxJQUFJO1FBQ3ZCLElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDcEIsS0FBSyxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUNyQixVQUFVLENBQUMsSUFBSSxFQUFDLElBQUksQ0FBQyxDQUFDO0lBQzFCLENBQUMsQ0FBQyxDQUFDO0lBQ0gsRUFBRSxDQUFDLFNBQVMsRUFBQyxVQUFTLElBQUk7UUFDdEIsS0FBSyxDQUFDLElBQUksRUFBRTthQUNQLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNwQixDQUFDLENBQUMsQ0FBQTtBQUNOLENBQUMsQ0FBQyxDQUFBIn0=
|
14
test/test.ts
Normal file
14
test/test.ts
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
import "typings-test";
|
||||||
|
import early = require("../dist/index");
|
||||||
|
|
||||||
|
describe("early",function(){
|
||||||
|
it(".start()",function(done){
|
||||||
|
this.timeout(10000);
|
||||||
|
early.start("early");
|
||||||
|
setTimeout(done,5000);
|
||||||
|
});
|
||||||
|
it(".stop()",function(done){
|
||||||
|
early.stop()
|
||||||
|
.then(done);
|
||||||
|
})
|
||||||
|
})
|
46
ts/early.child.ts
Normal file
46
ts/early.child.ts
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
import "typings-global";
|
||||||
|
import chalk = require("chalk");
|
||||||
|
import readline = require("readline");
|
||||||
|
let rl = readline.createInterface({
|
||||||
|
input: process.stdin,
|
||||||
|
output: process.stdout
|
||||||
|
});
|
||||||
|
|
||||||
|
let moduleName: string;
|
||||||
|
let loaderLength: number;
|
||||||
|
let frameCounter: number = 0;
|
||||||
|
|
||||||
|
let makeFrame = (): string => {
|
||||||
|
let resultString: string = `[${chalk.green("/".repeat(frameCounter))}${" ".repeat(loaderLength - frameCounter)}] starting ${moduleName}`;
|
||||||
|
if (frameCounter == loaderLength) {
|
||||||
|
frameCounter = 0;
|
||||||
|
} else {
|
||||||
|
frameCounter++;
|
||||||
|
}
|
||||||
|
return resultString;
|
||||||
|
};
|
||||||
|
|
||||||
|
let logEarlyAbort = false;
|
||||||
|
let logEarly = () => {
|
||||||
|
if (!logEarlyAbort) {
|
||||||
|
rl.write(null, { ctrl: true, name: 'u' });
|
||||||
|
rl.write(makeFrame());
|
||||||
|
setTimeout(function () {
|
||||||
|
logEarly();
|
||||||
|
}, 80);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
let start = function (moduleNameArg: string = "", loaderLengthArg: string = "10") {
|
||||||
|
moduleName = moduleNameArg;
|
||||||
|
loaderLength = parseInt(loaderLengthArg);
|
||||||
|
logEarly();
|
||||||
|
};
|
||||||
|
|
||||||
|
start(process.env.moduleNameArg, process.env.loaderLengthArg);
|
||||||
|
|
||||||
|
process.on('SIGINT', () => {
|
||||||
|
logEarlyAbort = true;
|
||||||
|
rl.write(null, { ctrl: true, name: 'u' });
|
||||||
|
process.exit(0);
|
||||||
|
});
|
56
ts/index.ts
Normal file
56
ts/index.ts
Normal file
@ -0,0 +1,56 @@
|
|||||||
|
import "typings-global"
|
||||||
|
import path = require("path");
|
||||||
|
import chalk = require("chalk");
|
||||||
|
import q = require("q");
|
||||||
|
import readline = require("readline");
|
||||||
|
import childProcess = require("child_process");
|
||||||
|
let earlyChild;
|
||||||
|
|
||||||
|
let doAnimation: boolean = true;
|
||||||
|
let doText: boolean = false;
|
||||||
|
let moduleName: string = "undefined module name";
|
||||||
|
let startTime;
|
||||||
|
|
||||||
|
if (process.argv.indexOf("-v") != -1 || process.env.CI) {
|
||||||
|
doAnimation = false;
|
||||||
|
}
|
||||||
|
if (process.argv.indexOf("-v") == -1 && process.env.CI) {
|
||||||
|
doText = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
// exports
|
||||||
|
export let start = function (moduleNameArg: string = "", loaderLengthArg: string = "10") {
|
||||||
|
|
||||||
|
startTime = Date.now();
|
||||||
|
|
||||||
|
moduleName = moduleNameArg;
|
||||||
|
if (doAnimation) {
|
||||||
|
earlyChild = childProcess.fork(path.join(__dirname, "early.child.js"), [], {
|
||||||
|
env: {
|
||||||
|
moduleNameArg: moduleNameArg,
|
||||||
|
loaderLengthArg: loaderLengthArg,
|
||||||
|
CI: process.env.CI
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} else if (doText) {
|
||||||
|
console.log(`**** starting ${chalk.green(moduleNameArg)} ****`);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
export let stop = function () {
|
||||||
|
let done = q.defer();
|
||||||
|
let endTime = Date.now();
|
||||||
|
let executionTime:string = ((endTime - startTime) / 1000).toString();
|
||||||
|
if (doAnimation) {
|
||||||
|
earlyChild.kill("SIGINT");
|
||||||
|
earlyChild.on("close", function () {
|
||||||
|
console.log(`loaded ${chalk.green(moduleName)} in ${executionTime} seconds!`);
|
||||||
|
done.resolve();
|
||||||
|
})
|
||||||
|
} else {
|
||||||
|
console.log(`... finished loading ${moduleName} in ${executionTime}`);
|
||||||
|
done.resolve();
|
||||||
|
}
|
||||||
|
return done.promise;
|
||||||
|
};
|
||||||
|
|
Reference in New Issue
Block a user