console-gui-tools
Advanced tools
Comparing version 1.1.21 to 1.1.28
@@ -6,11 +6,11 @@ import { ForegroundColor } from "chalk"; | ||
* @typedef {Object} DoubleLayoutOptions | ||
* @property {boolean} [showTitle] - If the title should be shown. | ||
* @property {boolean} [boxed] - If the layout should be boxed. | ||
* @property {ForegroundColor | ""} [boxColor] - The color of the box taken from the chalk library. | ||
* @property {"bold"} [boxStyle] - If the border of the box should be bold. | ||
* @property {string} [changeFocusKey] - The key that should be pressed to change the focus. | ||
* @property {"horizontal" | "vertical"} [direction] - The direction of the layout. | ||
* @property {string} [page1Title] - The title of the first page. | ||
* @property {string} [page2Title] - The title of the second page. | ||
* @property {[number, number]} [pageRatio] - The ratio of the pages. (in horizontal direction) | ||
* @prop {boolean} [showTitle] - If the title should be shown. | ||
* @prop {boolean} [boxed] - If the layout should be boxed. | ||
* @prop {ForegroundColor | ""} [boxColor] - The color of the box taken from the chalk library. | ||
* @prop {"bold"} [boxStyle] - If the border of the box should be bold. | ||
* @prop {string} [changeFocusKey] - The key that should be pressed to change the focus. | ||
* @prop {"horizontal" | "vertical"} [direction] - The direction of the layout. | ||
* @prop {string} [page1Title] - The title of the first page. | ||
* @prop {string} [page2Title] - The title of the second page. | ||
* @prop {[number, number]} [pageRatio] - The ratio of the pages. (in horizontal direction) | ||
* | ||
@@ -106,1 +106,2 @@ * @export | ||
export default DoubleLayout; | ||
//# sourceMappingURL=DoubleLayout.d.ts.map |
@@ -12,14 +12,4 @@ import { ConsoleManager } from "../../ConsoleGui.js"; | ||
export class DoubleLayout { | ||
CM; | ||
options; | ||
selected; | ||
page1; | ||
page2; | ||
boxBold; | ||
proportions; | ||
page2Title; | ||
page1Title; | ||
realWidth = 0; | ||
isOdd; | ||
constructor(page1, page2, options, selected = 0) { | ||
this.realWidth = 0; | ||
/** @const {ConsoleManager} CM the instance of ConsoleManager (singleton) */ | ||
@@ -250,2 +240,2 @@ this.CM = new ConsoleManager(); | ||
export default DoubleLayout; | ||
//# sourceMappingURL=DoubleLayout.js.map | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"DoubleLayout.js","sourceRoot":"","sources":["../../../src/components/layout/DoubleLayout.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAe,MAAM,qBAAqB,CAAA;AA+BjE;;;;;;;;GAQG;AACH,MAAM,OAAO,YAAY;IAarB,YAAmB,KAAmB,EAAE,KAAkB,EAAE,OAA4B,EAAE,WAAkB,CAAC;QAH7G,cAAS,GAA8B,CAAC,CAAA;QAIpC,4EAA4E;QAC5E,IAAI,CAAC,EAAE,GAAG,IAAI,cAAc,EAAE,CAAA;QAE9B,IAAI,CAAC,OAAO,GAAG,OAAO,CAAA;QACtB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAA;QACxB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAA;QAClB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAA;QAElB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,KAAK,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAA;QAC9D,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,IAAI,CAAC,GAAG,EAAE,GAAG,CAAC,CAAA;QAEvD,qDAAqD;QACrD,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,UAAU,IAAI,IAAI,CAAC,EAAE,CAAC,YAAY,CAAA;QAEjE,wDAAwD;QACxD,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,UAAU,IAAI,IAAI,CAAC,EAAE,CAAC,gBAAgB,CAAA;IACzE,CAAC;IAED;;;;OAIG;IACI,QAAQ,CAAC,IAAiB,IAAU,IAAI,CAAC,KAAK,GAAG,IAAI,CAAA,CAAC,CAAC;IAE9D;;;;OAIG;IACI,QAAQ,CAAC,IAAiB,IAAU,IAAI,CAAC,KAAK,GAAG,IAAI,CAAA,CAAC,CAAC;IAE9D;;;;OAIG;IACI,SAAS,CAAC,MAAe,IAAU,IAAI,CAAC,OAAO,CAAC,KAAK,GAAG,MAAM,CAAA,CAAC,CAAC;IAEvE;;;;OAIG;IACI,WAAW,CAAC,QAAe,IAAU,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAA,CAAC,CAAC;IAEtE;;;;OAIG;IACI,WAAW;QACd,OAAO,IAAI,CAAC,QAAQ,CAAA;IACxB,CAAC;IAED;;;;OAIG;IACI,YAAY;QACf,IAAI,IAAI,CAAC,QAAQ,IAAI,CAAC,EAAE;YACpB,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAA;SACpB;aAAM;YACH,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAA;SACpB;IACL,CAAC;IAED;;;;;;OAMG;IACK,QAAQ,CAAC,IAA4B,EAAE,UAAkC,EAAE,KAAK,GAAG,CAAC;QACxF,MAAM,GAAG,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,KAAK,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,YAAY,CAAA;QACxG,MAAM,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,KAAK,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;QACjE,IAAI,eAAe,GAAG,CAAC,EAAE,CAAC,CAAA;QAC1B,IAAI,OAAO,GAAG;YACV,CAAC,GAAG,IAAI,CAAC;SACZ,CAAA;QACD,IAAI,GAAG,KAAK,UAAU,EAAE;YACpB,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;gBACnB,eAAe,CAAC,CAAC,CAAC,IAAI,OAAO,CAAC,IAAI,CAAA;YACtC,CAAC,CAAC,CAAA;SACL;aAAM;YACH,OAAO,GAAG;gBACN,CAAC,GAAG,IAAI,CAAC;gBACT,CAAC,GAAG,UAAU,CAAA,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC;aACrC,CAAA;YACD,eAAe,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;YACxB,IAAI,CAAC,OAAO,CAAC,CAAC,OAAuB,EAAE,EAAE;gBACrC,eAAe,CAAC,CAAC,CAAC,IAAI,OAAO,CAAC,IAAI,CAAA;YACtC,CAAC,CAAC,CAAA;YACF,UAAU,EAAE,OAAO,CAAC,CAAC,OAAuB,EAAE,EAAE;gBAC5C,eAAe,CAAC,CAAC,CAAC,IAAI,OAAO,CAAC,IAAI,CAAA;YACtC,CAAC,CAAC,CAAA;SACL;QACD,IAAI,eAAe,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE;YACnF,eAAe,GAAG,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;gBAC3C,IAAI,CAAC,CAAC,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,KAAK,EAAE,EAAE,mBAAmB;oBAC3D,MAAM,MAAM,GAAG,CAAC,CAAA;oBAChB,IAAI,GAAG,KAAK,UAAU,EAAE;wBACpB,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA,CAAC,6EAA6E;qBACnI;yBAAM;wBACH,OAAO,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,CAAA;qBACtD;oBACD,IAAI,IAAI,GAAG,CAAC,CAAC,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,CAAA;oBAE3C,wBAAwB;oBACxB,KAAK,IAAI,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE;wBAC7C,IAAI,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,GAAG,IAAI,GAAG,MAAM,EAAE;4BAC3C,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,GAAG,MAAM,EAAE,IAAI,CAAC,CAAA;4BAC5G,MAAK;yBACR;6BAAM;4BACH,IAAI,IAAI,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAA;4BACjC,OAAO,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAA;yBAC1B;qBACJ;oBACD,0BAA0B;oBAC1B,OAAO,OAAO,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;iBAC1D;gBACD,OAAO,CAAC,CAAA;YACZ,CAAC,CAAC,CAAA;SACL;QACD,IAAI,GAAG,KAAK,UAAU,EAAE;YACpB,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK;gBAAE,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,QAAQ,KAAK,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,CAAA;YAC1J,IAAI,eAAe,CAAC,CAAC,CAAC,CAAC,MAAM,IAAI,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,GAAG,KAAK,EAAE;gBAC3D,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,GAAG,GAAG,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,GAAG,eAAe,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,KAAK,CAAC,EAAE,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,EAAE,CAAC,CAAA;aAC/H;YACD,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK;gBAAE,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,QAAQ,KAAK,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,CAAA;YACvJ,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC,CAAA;SACtC;aAAM;YACH,MAAM,GAAG,GAAoB,EAAE,CAAA;YAC/B,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK;gBAAE,GAAG,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,QAAQ,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,CAAA;YAC5I,GAAG,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC,CAAA;YACvB,IAAI,eAAe,CAAC,CAAC,CAAC,CAAC,MAAM,IAAI,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,KAAK,EAAE;gBACxD,GAAG,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,GAAG,GAAG,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,eAAe,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,EAAE,CAAC,CAAA;aACnI;YACD,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK;gBAAE,GAAG,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,CAAA;YAC5G,GAAG,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC,CAAA;YACvB,IAAI,eAAe,CAAC,CAAC,CAAC,CAAC,MAAM,IAAI,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,KAAK,EAAE;gBACxD,GAAG,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,GAAG,GAAG,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,eAAe,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,EAAE,CAAC,CAAA;aACnI;YACD,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK;gBAAE,GAAG,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,QAAQ,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,CAAA;YAC5I,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,GAAG,CAAC,CAAA;SAC/B;IACL,CAAC;IAED;;;;;OAKG;IACI,IAAI;QACP,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,GAAG,CAAC,KAAK,CAAC,CAAA;QAC3C,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,KAAK,UAAU,EAAE;YAClE,IAAI,CAAC,SAAS,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,CAAA;YAC7F,MAAM,YAAY,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,KAAK,CAAC,EAAE,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,KAAK,CAAC,CAAC,CAAA;YACvJ,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,0BAA0B;gBAChD,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE;oBACxB,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,IAAI,EAAE,KAAK,YAAY,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,QAAQ,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,CAAA;iBACvN;qBAAM;oBACH,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,IAAI,EAAE,KAAK,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,QAAQ,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,CAAA;iBAC5K;gBACD,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE,CAAC,OAAO,CAAC,CAAC,IAAqB,EAAE,EAAE;oBACtD,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,SAAS,EAAE,CAAC,CAAC,CAAA;gBACrC,CAAC,CAAC,CAAA;gBACF,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE;oBACxB,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,IAAI,EAAE,KAAK,YAAY,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,CAAA;iBACvL;qBAAM;oBACH,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,IAAI,EAAE,IAAI,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,CAAA;iBAC3I;gBACD,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE,CAAC,OAAO,CAAC,CAAC,IAAqB,EAAE,EAAE;oBACtD,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,SAAS,EAAE,CAAC,CAAC,CAAA;gBACrC,CAAC,CAAC,CAAA;gBACF,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,IAAI,EAAE,IAAI,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,QAAQ,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,CAAA;aAC3K;iBAAM,EAAE,6BAA6B;gBAClC,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE;oBACxB,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,IAAI,EAAE,GAAG,YAAY,CAAC,CAAC,CAAC,EAAE,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,QAAQ,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,CAAA;iBACpJ;gBACD,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE,CAAC,OAAO,CAAC,CAAC,IAAqB,EAAE,EAAE;oBACtD,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,SAAS,EAAE,CAAC,CAAC,CAAA;gBACrC,CAAC,CAAC,CAAA;gBACF,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE;oBACxB,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,IAAI,EAAE,GAAG,YAAY,CAAC,CAAC,CAAC,EAAE,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,QAAQ,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,CAAA;iBACpJ;gBACD,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE,CAAC,OAAO,CAAC,CAAC,IAAqB,EAAE,EAAE;oBACtD,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,SAAS,EAAE,CAAC,CAAC,CAAA;gBACrC,CAAC,CAAC,CAAA;aACL;SACJ;aAAM,EAAE,sBAAsB;YAC3B,IAAI,CAAC,SAAS,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;YACjI,MAAM,YAAY,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,KAAK,CAAC,EAAE,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,KAAK,CAAC,CAAC,CAAA;YACvJ,MAAM,aAAa,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,mBAAmB,EAAE,EAAE,IAAI,CAAC,KAAK,CAAC,mBAAmB,EAAE,CAAC,CAAA;YAClG,MAAM,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE,CAAA;YAClC,MAAM,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE,CAAA;YAClC,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,0BAA0B;gBAChD,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE;oBACxB,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,IAAI,EAAE,KAAK,YAAY,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,QAAQ,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE,EAAE,EAAE,IAAI,EAAE,IAAI,YAAY,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,QAAQ,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,CAAA;iBAChZ;qBAAM;oBACH,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,IAAI,EAAE,KAAK,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,QAAQ,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE,EAAE,EAAE,IAAI,EAAE,IAAI,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,QAAQ,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,CAAA;iBAC1T;gBACD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,aAAa,EAAE,CAAC,EAAE,EAAE;oBACpC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAA;iBAC9G;gBACD,yBAAyB;gBACzB,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,IAAI,EAAE,IAAI,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,QAAQ,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE,EAAE,EAAE,IAAI,EAAE,GAAG,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,QAAQ,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,CAAA;aACxT;iBAAM,EAAE,6BAA6B;gBAClC,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE;oBACxB,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,IAAI,EAAE,GAAG,YAAY,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,YAAY,CAAC,CAAC,CAAC,EAAE,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,QAAQ,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,CAAA;iBAC/N;gBACD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,aAAa,EAAE,CAAC,EAAE,EAAE;oBACpC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAA;iBAC9G;aACJ;SACJ;IACL,CAAC;CACJ;AAED,eAAe,YAAY,CAAA","sourcesContent":["import { ForegroundColor } from \"chalk\"\nimport { ConsoleManager, PageBuilder } from \"../../ConsoleGui.js\"\nimport { StyledElement } from \"../PageBuilder.js\"\n\n/**\n * @description The type containing all the possible options for the DoubleLayout.\n * @typedef {Object} DoubleLayoutOptions\n * @prop {boolean} [showTitle] - If the title should be shown.\n * @prop {boolean} [boxed] - If the layout should be boxed.\n * @prop {ForegroundColor | \"\"} [boxColor] - The color of the box taken from the chalk library.\n * @prop {\"bold\"} [boxStyle] - If the border of the box should be bold.\n * @prop {string} [changeFocusKey] - The key that should be pressed to change the focus.\n * @prop {\"horizontal\" | \"vertical\"} [direction] - The direction of the layout.\n * @prop {string} [page1Title] - The title of the first page.\n * @prop {string} [page2Title] - The title of the second page.\n * @prop {[number, number]} [pageRatio] - The ratio of the pages. (in horizontal direction)\n *\n * @export\n * @interface DoubleLayoutOptions\n */\nexport interface DoubleLayoutOptions {\n    showTitle?: boolean;\n    boxed?: boolean;\n    boxColor?: ForegroundColor | \"\"; // add color list from chalk\n    boxStyle?: \"bold\";\n    changeFocusKey: string;\n    direction?: \"horizontal\" | \"vertical\";\n    page1Title?: string;\n    page2Title?: string;\n    pageRatio?: [number, number];\n}\n\n/**\n * @class DoubleLayout\n * @description This class is a layout that has two pages.\n * @param {PageBuilder} page1 The first page.\n * @param {PageBuilder} page2 The second page.\n * @param {boolean} options Layout options.\n * @param {number} selected The selected page.\n * @example const layout = new DoubleLayout(page1, page2, true, 0)\n */\nexport class DoubleLayout {\n    CM: ConsoleManager\n    options: DoubleLayoutOptions\n    selected: 0 | 1\n    page1: PageBuilder\n    page2: PageBuilder\n    boxBold: boolean\n    proportions: [number, number]\n    page2Title: string\n    page1Title: string\n    realWidth: number | [number, number] = 0\n    isOdd: boolean | undefined\n\n    public constructor(page1 : PageBuilder, page2: PageBuilder, options: DoubleLayoutOptions, selected: 0 | 1 = 0) {\n        /** @const {ConsoleManager} CM the instance of ConsoleManager (singleton) */\n        this.CM = new ConsoleManager()\n\n        this.options = options\n        this.selected = selected\n        this.page1 = page1\n        this.page2 = page2\n\n        this.boxBold = this.options.boxStyle === \"bold\" ? true : false\n        this.proportions = this.options.pageRatio || [0.7, 0.3]\n\n        /** @const {string} page2Title The title of page2. */\n        this.page2Title = this.options.page2Title || this.CM.logPageTitle\n\n        /** @const {string} page1Title The application title. */\n        this.page1Title = this.options.page1Title || this.CM.applicationTitle\n    }\n\n    /**\n     * @description This function is used to overwrite the page content.\n     * @param {PageBuilder} page the page to be added\n     * @memberof DoubleLayout\n     */\n    public setPage1(page: PageBuilder): void { this.page1 = page }\n\n    /**\n     * @description This function is used to overwrite the page content.\n     * @param {PageBuilder} page the page to be added\n     * @memberof DoubleLayout\n     */\n    public setPage2(page: PageBuilder): void { this.page2 = page }\n\n    /**\n     * @description This function is used to enable or disable the layout border.\n     * @param {boolean} border enable or disable the border\n     * @memberof DoubleLayout\n     */\n    public setBorder(border: boolean): void { this.options.boxed = border }\n\n    /**\n     * @description This function is used to choose the page to be highlighted.\n     * @param {number} selected 0 for page1, 1 for page2\n     * @memberof DoubleLayout\n     */\n    public setSelected(selected: 0 | 1): void { this.selected = selected }\n\n    /**\n     * @description This function is used to get the selected page.\n     * @returns {number} 0 for page1, 1 for page2\n     * @memberof DoubleLayout\n     */\n    public getSelected(): number {\n        return this.selected\n    }\n\n    /**\n     * @description This function is used to get switch the selected page.\n     * @returns {void}\n     * @memberof DoubleLayout\n     */\n    public changeLayout(): void {\n        if (this.selected == 0) {\n            this.selected = 1\n        } else {\n            this.selected = 0\n        }\n    }\n\n    /**\n     * @description This function is used to draw a single line of the layout to the screen. It also trim the line if it is too long.\n     * @param {Array<object>} line the line to be drawn\n     * @param {number} lineIndex the index of the selected line\n     * @memberof DoubleLayout\n     * @returns {void}\n     */\n    private drawLine(line :  Array<StyledElement>, secondLine? : Array<StyledElement>, index = 0): void {\n        const dir = !this.options.direction || this.options.direction === \"vertical\" ? \"vertical\" : \"horizontal\"\n        const bsize = this.options.boxed ? dir === \"vertical\" ? 2 : 3 : 0\n        let unformattedLine = [\"\"]\n        let newLine = [\n            [...line]\n        ]\n        if (dir === \"vertical\") {\n            line.forEach(element => {\n                unformattedLine[0] += element.text\n            })\n        } else {\n            newLine = [\n                [...line],\n                [...secondLine? secondLine : line]\n            ]\n            unformattedLine.push(\"\")\n            line.forEach((element : StyledElement) => {\n                unformattedLine[0] += element.text\n            })\n            secondLine?.forEach((element : StyledElement) => {\n                unformattedLine[1] += element.text\n            })\n        }\n        if (unformattedLine.filter((e, i) => e.length > this.realWidth[i] - bsize).length > 0) {\n            unformattedLine = unformattedLine.map((e, i) => {\n                if (e.length > this.realWidth[i] - bsize) { // Need to truncate\n                    const offset = 2\n                    if (dir === \"vertical\") {\n                        newLine[i] = [...JSON.parse(JSON.stringify(line))] // Shallow copy because I just want to modify the values but not the original\n                    } else {\n                        newLine[i] = JSON.parse(JSON.stringify(secondLine))\n                    }\n                    let diff = e.length - this.realWidth[i] + 1\n\n                    // remove truncated text\n                    for (let j = newLine[i].length - 1; j >= 0; j--) {\n                        if (newLine[i][j].text.length > diff + offset) {\n                            newLine[i][j].text = this.CM.truncate(newLine[i][j].text, (newLine[i][j].text.length - diff) - offset, true)\n                            break\n                        } else {\n                            diff -= newLine[i][j].text.length\n                            newLine[i].splice(j, 1)\n                        }\n                    }\n                    // Update unformatted line\n                    return newLine[i].map(element => element.text).join(\"\")\n                }\n                return e\n            })\n        }\n        if (dir === \"vertical\") {\n            if (this.options.boxed) newLine[0].unshift({ text: \"│\", style: { color: this.selected === index ? this.options.boxColor : \"white\", bold: this.boxBold } })\n            if (unformattedLine[0].length <= this.CM.Screen.width - bsize) {\n                newLine[0].push({ text: `${\" \".repeat((this.CM.Screen.width - unformattedLine[0].length) - bsize)}`, style: { color: \"\" } })\n            }\n            if (this.options.boxed) newLine[0].push({ text: \"│\", style: { color: this.selected === index ? this.options.boxColor : \"white\", bold: this.boxBold } })\n            this.CM.Screen.write(...newLine[0])\n        } else {\n            const ret: StyledElement[] = []\n            if (this.options.boxed) ret.push({ text: \"│\", style: { color: this.selected === 0 ? this.options.boxColor : \"white\", bold: this.boxBold } })\n            ret.push(...newLine[0])\n            if (unformattedLine[0].length <= this.realWidth[0] - bsize) {\n                ret.push({ text: `${\" \".repeat((this.realWidth[0] - unformattedLine[0].length) - (bsize > 0 ? 2 : 0))}`, style: { color: \"\" } })\n            }\n            if (this.options.boxed) ret.push({ text: \"│\", style: { color: this.options.boxColor, bold: this.boxBold } })\n            ret.push(...newLine[1])\n            if (unformattedLine[1].length <= this.realWidth[1] - bsize) {\n                ret.push({ text: `${\" \".repeat((this.realWidth[1] - unformattedLine[1].length) - (bsize > 0 ? 1 : 0))}`, style: { color: \"\" } })\n            }\n            if (this.options.boxed) ret.push({ text: \"│\", style: { color: this.selected === 1 ? this.options.boxColor : \"white\", bold: this.boxBold } })\n            this.CM.Screen.write(...ret)\n        }\n    }\n\n    /**\n     * @description This function is used to draw the layout to the screen.\n     * @memberof DoubleLayout\n     * @returns {void}\n     * @example layout.draw()\n     */\n    public draw(): void {\n        this.isOdd = this.CM.Screen.width % 2 === 1\n        if (!this.options.direction || this.options.direction === \"vertical\") {\n            this.realWidth = [Math.round(this.CM.Screen.width * 1), Math.round(this.CM.Screen.width * 1)]\n            const trimmedTitle = [this.CM.truncate(this.page1Title, this.realWidth[0] - 4, false), this.CM.truncate(this.page2Title, this.realWidth[1] - 4, false)]\n            if (this.options.boxed) { // Draw pages with borders\n                if (this.options.showTitle) {\n                    this.CM.Screen.write({ text: `┌─${trimmedTitle[0]}${\"─\".repeat(this.CM.Screen.width - trimmedTitle[0].length - 3)}┐`, style: { color: this.selected === 0 ? this.options.boxColor : \"white\", bold: this.boxBold } })\n                } else {\n                    this.CM.Screen.write({ text: `┌─${\"─\".repeat(this.CM.Screen.width - 3)}┐`, style: { color: this.selected === 0 ? this.options.boxColor : \"white\", bold: this.boxBold } })\n                }\n                this.page1.getContent().forEach((line: StyledElement[]) => {\n                    this.drawLine(line, undefined, 0)\n                })\n                if (this.options.showTitle) {\n                    this.CM.Screen.write({ text: `├─${trimmedTitle[1]}${\"─\".repeat(this.CM.Screen.width - trimmedTitle[1].length - 3)}┤`, style: { color: this.options.boxColor, bold: this.boxBold } })\n                } else {\n                    this.CM.Screen.write({ text: `├${\"─\".repeat(this.CM.Screen.width - 2)}┤`, style: { color: this.options.boxColor, bold: this.boxBold } })\n                }\n                this.page2.getContent().forEach((line: StyledElement[]) => {\n                    this.drawLine(line, undefined, 1)\n                })\n                this.CM.Screen.write({ text: `└${\"─\".repeat(this.CM.Screen.width - 2)}┘`, style: { color: this.selected === 1 ? this.options.boxColor : \"white\", bold: this.boxBold } })\n            } else { // Draw pages without borders\n                if (this.options.showTitle) {\n                    this.CM.Screen.write({ text: `${trimmedTitle[0]}`, style: { color: this.selected === 0 ? this.options.boxColor : \"white\", bold: this.boxBold } })\n                }\n                this.page1.getContent().forEach((line: StyledElement[]) => {\n                    this.drawLine(line, undefined, 0)\n                })\n                if (this.options.showTitle) {\n                    this.CM.Screen.write({ text: `${trimmedTitle[1]}`, style: { color: this.selected === 1 ? this.options.boxColor : \"white\", bold: this.boxBold } })\n                }\n                this.page2.getContent().forEach((line: StyledElement[]) => {\n                    this.drawLine(line, undefined, 1)\n                })\n            }\n        } else { // Draw horizontally  \n            this.realWidth = [Math.round(this.CM.Screen.width * this.proportions[0]), Math.round(this.CM.Screen.width * this.proportions[1])]\n            const trimmedTitle = [this.CM.truncate(this.page1Title, this.realWidth[0] - 4, false), this.CM.truncate(this.page2Title, this.realWidth[1] - 3, false)]\n            const maxPageHeight = Math.max(this.page1.getViewedPageHeight(), this.page2.getViewedPageHeight())\n            const p1 = this.page1.getContent()\n            const p2 = this.page2.getContent()\n            if (this.options.boxed) { // Draw pages with borders\n                if (this.options.showTitle) {\n                    this.CM.Screen.write({ text: `┌─${trimmedTitle[0]}${\"─\".repeat(this.realWidth[0] - trimmedTitle[0].length - 3)}┬`, style: { color: this.selected === 0 ? this.options.boxColor : \"white\", bold: this.boxBold } }, { text: `─${trimmedTitle[1]}${\"─\".repeat(this.realWidth[1] - trimmedTitle[1].length - 2)}┐`, style: { color: this.selected === 1 ? this.options.boxColor : \"white\", bold: this.boxBold } })\n                } else {\n                    this.CM.Screen.write({ text: `┌─${\"─\".repeat(this.realWidth[0] - 3)}┬`, style: { color: this.selected === 0 ? this.options.boxColor : \"white\", bold: this.boxBold } }, { text: `─${\"─\".repeat(this.realWidth[1] - 2)}┐`, style: { color: this.selected === 1 ? this.options.boxColor : \"white\", bold: this.boxBold } })\n                }\n                for (let i = 0; i < maxPageHeight; i++) {\n                    this.drawLine(p1[i] || [{ text: \"\", style: { color: \"\" } }], p2[i] || [{ text: \"\", style: { color: \"\" } }])\n                }\n                // Draw the bottom border\n                this.CM.Screen.write({ text: `└${\"─\".repeat(this.realWidth[0] - 2)}┴`, style: { color: this.selected === 0 ? this.options.boxColor : \"white\", bold: this.boxBold } }, { text: `${\"─\".repeat(this.realWidth[1] - 1)}┘`, style: { color: this.selected === 1 ? this.options.boxColor : \"white\", bold: this.boxBold } })\n            } else { // Draw pages without borders\n                if (this.options.showTitle) {\n                    this.CM.Screen.write({ text: `${trimmedTitle[0]}${\" \".repeat(this.realWidth[0] - trimmedTitle[0].length)}${trimmedTitle[1]}`, style: { color: this.selected === 0 ? this.options.boxColor : \"white\", bold: this.boxBold } })\n                }\n                for (let i = 0; i < maxPageHeight; i++) {\n                    this.drawLine(p1[i] || [{ text: \"\", style: { color: \"\" } }], p2[i] || [{ text: \"\", style: { color: \"\" } }])\n                }\n            }\n        }\n    }\n}\n\nexport default DoubleLayout"]} |
@@ -6,12 +6,12 @@ import { BackgroundColor, ForegroundColor } from "chalk"; | ||
* @typedef {Object} StyleObject | ||
* @property {chalk.ForegroundColor | ""} [color] - The color of the text taken from the chalk library. | ||
* @property {chalk.BackgroundColor | ""} [backgroundColor] - The background color of the text taken from the chalk library. | ||
* @property {boolean} [italic] - If the text is italic. | ||
* @property {boolean} [bold] - If the text is bold. | ||
* @property {boolean} [dim] - If the text is dim. | ||
* @property {boolean} [underline] - If the text is underlined. | ||
* @property {boolean} [inverse] - If the text is inverse. | ||
* @property {boolean} [hidden] - If the text is hidden. | ||
* @property {boolean} [strikethrough] - If the text is strikethrough. | ||
* @property {boolean} [overline] - If the text is overlined. | ||
* @prop {chalk.ForegroundColor | ""} [color] - The color of the text taken from the chalk library. | ||
* @prop {chalk.BackgroundColor | ""} [backgroundColor] - The background color of the text taken from the chalk library. | ||
* @prop {boolean} [italic] - If the text is italic. | ||
* @prop {boolean} [bold] - If the text is bold. | ||
* @prop {boolean} [dim] - If the text is dim. | ||
* @prop {boolean} [underline] - If the text is underlined. | ||
* @prop {boolean} [inverse] - If the text is inverse. | ||
* @prop {boolean} [hidden] - If the text is hidden. | ||
* @prop {boolean} [strikethrough] - If the text is strikethrough. | ||
* @prop {boolean} [overline] - If the text is overlined. | ||
* | ||
@@ -39,4 +39,4 @@ * @example const textStyle = { color: "red", backgroundColor: "blue", bold: true, italic: true } | ||
* @typedef {Object} StyledElement | ||
* @property {string} text - The text of the styled text. | ||
* @property {StyleObject} style - The style of the styled text. | ||
* @prop {string} text - The text of the styled text. | ||
* @prop {StyleObject} style - The style of the styled text. | ||
* | ||
@@ -56,13 +56,13 @@ * @example const styledText = { text: "Hello", style: { color: "red", backgroundColor: "blue", bold: true, italic: true } } | ||
* @typedef {Object} SimplifiedStyledElement | ||
* @property {string} text - The text of the styled text. | ||
* @property {chalk.ForegroundColor | ""} [color] - The color of the text taken from the chalk library. | ||
* @property {chalk.BackgroundColor | ""} [backgroundColor] - The background color of the text taken from the chalk library. | ||
* @property {boolean} [italic] - If the text is italic. | ||
* @property {boolean} [bold] - If the text is bold. | ||
* @property {boolean} [dim] - If the text is dim. | ||
* @property {boolean} [underline] - If the text is underlined. | ||
* @property {boolean} [inverse] - If the text is inverse. | ||
* @property {boolean} [hidden] - If the text is hidden. | ||
* @property {boolean} [strikethrough] - If the text is strikethrough. | ||
* @property {boolean} [overline] - If the text is overlined. | ||
* @prop {string} text - The text of the styled text. | ||
* @prop {chalk.ForegroundColor | ""} [color] - The color of the text taken from the chalk library. | ||
* @prop {chalk.BackgroundColor | ""} [backgroundColor] - The background color of the text taken from the chalk library. | ||
* @prop {boolean} [italic] - If the text is italic. | ||
* @prop {boolean} [bold] - If the text is bold. | ||
* @prop {boolean} [dim] - If the text is dim. | ||
* @prop {boolean} [underline] - If the text is underlined. | ||
* @prop {boolean} [inverse] - If the text is inverse. | ||
* @prop {boolean} [hidden] - If the text is hidden. | ||
* @prop {boolean} [strikethrough] - If the text is strikethrough. | ||
* @prop {boolean} [overline] - If the text is overlined. | ||
* | ||
@@ -173,1 +173,2 @@ * @example const textStyle = { color: "red", backgroundColor: "blue", bold: true, italic: true } | ||
export default PageBuilder; | ||
//# sourceMappingURL=PageBuilder.d.ts.map |
@@ -11,5 +11,2 @@ /** | ||
export class PageBuilder { | ||
rowsPerPage; | ||
scrollIndex; | ||
content; | ||
constructor(rowsPerPage = 100) { | ||
@@ -151,2 +148,2 @@ this.rowsPerPage = rowsPerPage; | ||
export default PageBuilder; | ||
//# sourceMappingURL=PageBuilder.js.map | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"PageBuilder.js","sourceRoot":"","sources":["../../src/components/PageBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { BackgroundColor, ForegroundColor } from \"chalk\"\n\n\n/**\n * @description The type containing all the possible styles for the text.\n * \n * @typedef {Object} StyleObject\n * @prop {chalk.ForegroundColor | \"\"} [color] - The color of the text taken from the chalk library.\n * @prop {chalk.BackgroundColor | \"\"} [backgroundColor] - The background color of the text taken from the chalk library.\n * @prop {boolean} [italic] - If the text is italic.\n * @prop {boolean} [bold] - If the text is bold.\n * @prop {boolean} [dim] - If the text is dim.\n * @prop {boolean} [underline] - If the text is underlined.\n * @prop {boolean} [inverse] - If the text is inverse.\n * @prop {boolean} [hidden] - If the text is hidden.\n * @prop {boolean} [strikethrough] - If the text is strikethrough.\n * @prop {boolean} [overline] - If the text is overlined.\n * \n * @example const textStyle = { color: \"red\", backgroundColor: \"blue\", bold: true, italic: true }\n *\n * @export\n * @interface StyleObject\n */\nexport interface StyleObject {\n    color?: ForegroundColor | \"\";\n    bg?: BackgroundColor | \"\";\n    italic?: boolean;\n    bold?: boolean;\n    dim?: boolean;\n    underline?: boolean;\n    inverse?: boolean;\n    hidden?: boolean;\n    strikethrough?: boolean;\n    overline?: boolean;\n}\n\n/**\n * @description The type of the single styled text, stored in a line of the PageBuilder.\n * \n * @typedef {Object} StyledElement\n * @prop {string} text - The text of the styled text.\n * @prop {StyleObject} style - The style of the styled text.\n * \n * @example const styledText = { text: \"Hello\", style: { color: \"red\", backgroundColor: \"blue\", bold: true, italic: true } }\n *\n * @export\n * @interface StyledElement\n */\nexport interface StyledElement {\n    text: string;\n    style: StyleObject;\n}\n\n/**\n * @description The type containing all the possible styles for the text and the text on the same level. It's used on the higher level.\n * \n * @typedef {Object} SimplifiedStyledElement\n * @prop {string} text - The text of the styled text.\n * @prop {chalk.ForegroundColor | \"\"} [color] - The color of the text taken from the chalk library.\n * @prop {chalk.BackgroundColor | \"\"} [backgroundColor] - The background color of the text taken from the chalk library.\n * @prop {boolean} [italic] - If the text is italic.\n * @prop {boolean} [bold] - If the text is bold.\n * @prop {boolean} [dim] - If the text is dim.\n * @prop {boolean} [underline] - If the text is underlined.\n * @prop {boolean} [inverse] - If the text is inverse.\n * @prop {boolean} [hidden] - If the text is hidden.\n * @prop {boolean} [strikethrough] - If the text is strikethrough.\n * @prop {boolean} [overline] - If the text is overlined.\n * \n * @example const textStyle = { color: \"red\", backgroundColor: \"blue\", bold: true, italic: true }\n *\n * @export\n * @interface SimplifiedStyledElement\n */\nexport interface SimplifiedStyledElement {\n    text: string;\n    color?: ForegroundColor | \"\";\n    bg?: BackgroundColor | \"\";\n    italic?: boolean;\n    bold?: boolean;\n    dim?: boolean;\n    underline?: boolean;\n    inverse?: boolean;\n    hidden?: boolean;\n    strikethrough?: boolean;\n    overline?: boolean;\n}\n\n/**\n * @class PageBuilder\n * @description Defines a new page:\n * It's a sort of collection of styled rows.\n * @param {number} rowsPerPage - The number of rows per page. Default is 100. Useful for scrolling.\n *\n * @export\n * @class PageBuilder\n */\nexport class PageBuilder {\n    rowsPerPage: number\n    scrollIndex: number\n    content: StyledElement[][]\n\n    public constructor(rowsPerPage = 100) {\n        this.rowsPerPage = rowsPerPage\n\n        /**\n         * @const {number} scrollIndex - The index of the scroll bar.\n         * @memberOf PageBuilder \n         */\n        this.scrollIndex = 0\n\n        /**\n         * @const {Array<Array<object>>} content The content of the page.\n         * @memberOf PageBuilder\n         */\n        this.content = []\n    }\n\n    /**\n     * @description Add a new styled row to the page.\n     * @param {parameters<object>} row - The styled row to add.\n     * @returns {void}\n     * @memberOf PageBuilder\n     * @example\n     * page.addRow({ text: 'Hello World', color: 'white' })\n     * page.addRow({ text: 'Hello World', color: 'white' }, { text: 'Hello World', color: 'white' })\n     */\n    public addRow(...args: SimplifiedStyledElement[]): void {\n        // each argument is an object like {text: string, color: string}\n        const _row: StyledElement[] = []\n        for (let i = 0; i < args.length; i++) {\n            const arg: SimplifiedStyledElement = args[i]\n            _row.push({\n                text: arg.text,\n                style: {\n                    color: arg.color ? arg.color : undefined,\n                    bg: arg.bg ? arg.bg : undefined,\n                    italic: arg.italic ? arg.italic : undefined,\n                    bold: arg.bold ? arg.bold : undefined,\n                    dim: arg.dim ? arg.dim : undefined,\n                    underline: arg.underline ? arg.underline : undefined,\n                    inverse: arg.inverse ? arg.inverse : undefined,\n                    hidden: arg.hidden ? arg.hidden : undefined,\n                    strikethrough: arg.strikethrough ? arg.strikethrough : undefined,\n                    overline: arg.overline ? arg.overline : undefined,\n                }\n            })\n        }\n        this.content.push(_row)\n    }\n\n    /**\n     * @description Add an empty row to the page. (like <br /> in HTML)\n     * @param {number} [count=1] - The number of empty rows to add.\n     * @returns {void}\n     * @memberOf PageBuilder\n     * @example page.addEmptyRow()\n     * page.addEmptyRow(2)\n     */\n    public addSpacer(height = 1): void {\n        if (height > 0) {\n            for (let i = 0; i < height; i++) {\n                this.addRow({ text: \"\", color: \"\" })\n            }\n        }\n    }\n\n    /**\n     * @description Returns the content of the page.\n     * @returns {Array<Array<object>>}\n     * @memberOf PageBuilder\n     * @example page.getContent()\n     */\n    public getContent(): StyledElement[][] {\n        if (this.getPageHeight() > this.rowsPerPage) {\n            return this.content.slice(this.getPageHeight() - this.scrollIndex - this.rowsPerPage, this.getPageHeight() - this.scrollIndex)\n        } else {\n            return this.content\n        }\n    }\n\n    /**\n     * @description Returns the height of the page.\n     * @returns {number}\n     * @memberOf PageBuilder\n     * @example page.getPageHeight()\n     */\n    public getPageHeight(): number {\n        return this.content.length\n    }\n\n    /**\n     * @description Returns the height of the viewed page. It excludes the rows that are not visible.\n     * @returns {number}\n     * @memberOf PageBuilder\n     * @example page.getViewedPageHeight() // returns the height of the page that is visible\n     */\n    public getViewedPageHeight(): number {\n        return this.getContent().length\n    }\n\n    /**\n     * @description Changes the index of the scroll bar.\n     * @param {number} index - The index of the scroll bar.\n     * @returns {void}\n     * @memberOf PageBuilder\n     * @example page.setScrollIndex(10)\n     */\n    public setScrollIndex(index: number): void {\n        this.scrollIndex = index\n    }\n\n    /**\n     * @description Changes the number of rows per page.\n     * @param {number} rowsPerPage - The number of rows per page.\n     * @returns {void}\n     * @memberOf PageBuilder\n     * @example page.setRowsPerPage(10)\n     */\n    public setRowsPerPage(rpp: number): void {\n        this.rowsPerPage = rpp\n    }\n\n    /**\n     * @description Increases the index of the scroll bar.\n     * @returns {void}\n     * @memberOf PageBuilder\n     * @example page.increaseScrollIndex()\n     */\n    public increaseScrollIndex(): void {\n        if (this.scrollIndex < this.getPageHeight() - this.rowsPerPage) {\n            this.scrollIndex++\n        }\n    }\n\n    /**\n     * @description Decreases the index of the scroll bar.\n     * @returns {void}\n     * @memberOf PageBuilder\n     * @example page.increaseScrollIndex()\n     */\n    public decreaseScrollIndex(): void {\n        if (this.scrollIndex > 0) {\n            this.scrollIndex--\n        }\n    }\n}\n\nexport default PageBuilder"]} |
@@ -7,3 +7,3 @@ /// <reference types="node" /> | ||
* @typedef {Object} StyleIndexObject | ||
* @property {[number, number]} [index] - The index of the style in the style array. | ||
* @prop {Array<number>} index - The index of the style in the style array. | ||
* | ||
@@ -19,4 +19,4 @@ * @interface StyleIndexObject | ||
* @typedef {Object} StyledElementWithIndex | ||
* @property {string} text - The text of the styled element. | ||
* @property {StyleIndexObject[]} [styleIndex] - The styles array with index. | ||
* @prop {string} text - The text of the styled element. | ||
* @prop {StyleIndexObject[]} styleIndex - The styles array with index. | ||
* | ||
@@ -121,1 +121,2 @@ * @interface StyledElementWithIndex | ||
export default Screen; | ||
//# sourceMappingURL=Screen.d.ts.map |
@@ -12,10 +12,5 @@ import { EventEmitter } from "events"; | ||
export class Screen extends EventEmitter { | ||
Terminal; | ||
width; | ||
height; | ||
buffer; | ||
cursor; | ||
currentY = 0; | ||
constructor(_Terminal) { | ||
super(); | ||
this.currentY = 0; | ||
this.Terminal = _Terminal; | ||
@@ -214,2 +209,2 @@ /** @const {number} width - The width of the screen. */ | ||
export default Screen; | ||
//# sourceMappingURL=Screen.js.map | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Screen.js","sourceRoot":"","sources":["../../src/components/Screen.ts"],"names":[],"mappings":"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","sourcesContent":["import { EventEmitter } from \"events\"\nimport chalk from \"chalk\"\nimport { StyledElement, StyleObject } from \"./PageBuilder.js\"\nchalk.level = 1\n\n/**\n * @description The type containing all the possible styles for the text and the index array.\n * @typedef {Object} StyleIndexObject\n * @prop {Array<number>} index - The index of the style in the style array.\n * \n * @interface StyleIndexObject\n * @extends {StyleObject}\n */\ninterface StyleIndexObject extends StyleObject {\n    index: [number, number];\n}\n\n/**\n * @description The type containing all the possible styles for the text and the index array and the text.\n * @typedef {Object} StyledElementWithIndex\n * @prop {string} text - The text of the styled element.\n * @prop {StyleIndexObject[]} styleIndex - The styles array with index.\n * \n * @interface StyledElementWithIndex\n */\ninterface StyledElementWithIndex {\n    text: string;\n    styleIndex: StyleIndexObject[];\n}\n\n/**\n * @class Screen\n * @description This class is used to manage the screen buffer.\n * @param {object} Terminal - The terminal object (process.stdout).\n * @extends EventEmitter\n * @example const screen = new Screen(process.stdout)\n */\nexport class Screen extends EventEmitter {\n    Terminal: NodeJS.WriteStream\n    width: number\n    height: number\n    buffer: StyledElementWithIndex[]\n    cursor: { x: number; y: number }\n    currentY = 0\n\n    constructor(_Terminal: NodeJS.WriteStream) {\n        super()\n        this.Terminal = _Terminal\n\n        /** @const {number} width - The width of the screen. */\n        this.width = this.Terminal.columns\n\n        /** @const {number} height - The height of the screen. */\n        this.height = this.Terminal.rows\n\n        /** @const {Array} buffer - The screen buffer object. */\n        this.buffer = []\n\n        /** @const {object} cursor - The cursor object. */\n        this.cursor = { x: 0, y: 0 }\n    }\n\n    /**\n     * @description This method is used to write or overwrite a row in the screen buffer at a specific position.\n     * @param {arguments<object>} args - The row to write.\n     * @returns {void}\n     * @memberOf Screen\n     * @example screen.write({ text: 'Hello World', color: 'white' })\n    screen.write({ text: 'Hello World', color: 'white' }, { text: 'Hello World', color: 'white' })\n     */\n    write(...args: StyledElement[]): void {\n        this.currentY++\n\n        let row = \"\"\n        const newStyleIndex = []\n        for (let i = 0; i < args.length; i++) {\n            const arg = args[i]\n            if (arg.text !== undefined) {\n                const txt = arg.text.toString()\n                const style: StyleIndexObject = { ...arg.style, index: [row.length, row.length + txt.length] }\n                newStyleIndex.push(style)\n                row += txt\n            }\n        }\n        const currentStyleIndex = this.buffer[this.cursor.y].styleIndex\n\n        // Now recalculate the styleIndex for the current row mixing the old one with the new one\n        // Create a new styleIndex merging the old one with the new one\n        const mergedStyleIndex = this.mergeStyles(newStyleIndex, currentStyleIndex, this.cursor.x, row.length)\n\n        if (this.cursor.y < this.buffer.length - 1) {\n            this.buffer[this.cursor.y].styleIndex = mergedStyleIndex\n            this.buffer[this.cursor.y].text = this.replaceAt(this.buffer[this.cursor.y].text, this.cursor.x, row)\n            this.cursorTo(0, this.cursor.y + 1)\n        }\n    }\n\n    /**\n     * @description This method is used to change the cursor position.\n     * @param {number} x - The x position.\n     * @param {number} y - The y position.\n     * @returns {void}\n     * @memberOf Screen\n     * @example screen.cursorTo(0, 0)\n     */\n    cursorTo(x: number, y: number): void {\n        this.cursor.x = x\n        this.cursor.y = y\n    }\n\n    /**\n     * @description This method is used to change the Terminal cursor position.\n     * @param {number} x - The x position.\n     * @param {number} y - The y position.\n     * @returns {void}\n     * @memberOf Screen\n     * @example screen.moveCursor(0, 0)\n     */\n    moveCursor(x: number, y: number): void {\n        this.Terminal.cursorTo(x, y)\n    }\n\n    /**\n     * @description This method is used to clear the screen. It fills the screen buffer with empty rows with the size of the screen.\n     * @returns {void}\n     * @memberOf Screen\n     * @example screen.clear()\n     */\n    update(): void {\n        this.cursorTo(0, 0)\n        this.width = this.Terminal.columns\n        this.height = this.Terminal.rows\n        this.buffer = []\n        for (let i = 0; i < this.Terminal.rows; i++) {\n            this.buffer[i] = { text: \" \".repeat(this.Terminal.columns), styleIndex: [{ color: \"gray\", bg: \"\", italic: false, bold: false, index: [0, this.Terminal.columns] }] }\n        }\n    }\n\n    /**\n     * @description This method is used to print the screen buffer to the terminal. It also converts the styles to the terminal format using Chalk.\n     * @returns {void}\n     * @memberOf Screen\n     * @example screen.print()\n     */\n    print(): void {\n        this.buffer.forEach((row, i) => {\n            this.Terminal.cursorTo(0, i)\n            let outString = \"\"\n\n            // convert styleIndex to chalk functions and apply them to the row text\n            row.styleIndex.forEach(style => {\n                const color = style.color ? chalk[style.color] : (_in: string): string => _in\n                const bg = style.bg ? chalk[style.bg] : (_in: string): string => _in\n                const italic = style.italic ? chalk.italic : (_in: string): string => _in\n                const bold = style.bold ? chalk.bold : (_in: string): string => _in\n                const dim = style.dim ? chalk.dim : (_in: string): string => _in\n                const underline = style.underline ? chalk.underline : (_in: string): string => _in\n                const overline = style.overline ? chalk.overline : (_in: string): string => _in\n                const inverse = style.inverse ? chalk.inverse : (_in: string): string => _in\n                const hidden = style.hidden ? chalk.hidden : (_in: string): string => _in\n                const strikethrough = style.strikethrough ? chalk.strikethrough : (_in: string): string => _in\n                outString += color(bg(italic(bold(dim(underline(overline(inverse(hidden(strikethrough(row.text.substring(style.index[0], style.index[1])))))))))))\n            })\n            this.Terminal.write(outString)\n        })\n        this.Terminal.clearScreenDown()\n    }\n\n    /**\n     * @description This method is used to insert a substring into a string at a specific position.\n     * @param {string} str - The string to insert into.\n     * @param {number} index - The position to insert the substring.\n     * @param {string} replacement - The substring to insert.\n     * @returns {string}\n     * @memberOf Screen\n     * @example screen.replaceAt('Hello Luca', 6, 'Elia') // returns 'Hello Elia'\n     */\n    replaceAt(str: string, index: number, replacement: string): string {\n        return str.substring(0, index) + replacement + str.substring(index + replacement.length)\n    }\n\n    /**\n     * @description This method is used to merge two styleIndex arrays into one. It also recalculates the indexes for the new row.\n     * @param {Array<StyleIndexObject>} newStyleIndex - The new styleIndex array.\n     * @param {Array<StyleIndexObject>} currentStyleIndex - The current styleIndex array.\n     * @param {number} startIndex - The start index of the new styleIndex array (Usually the cursor.x).\n     * @param {number} newSize - The new size of the string.\n     * @returns {Array<StyleIndexObject>}\n     * @memberOf Screen\n     * @example screen.mergeStyles([{ color: 'red', bg: 'black', italic: false, bold: false, index: [0, 5] }, { color: 'white', bg: 'black', italic: false, bold: false, index: [6, 10] }], [{ color: 'magenta', bg: 'black', italic: false, bold: false, index: [0, 30] }], 5, 15)\n     * returns [{ color: 'magenta', bg: 'black', italic: false, bold: false, index: [0, 4] }, { color: 'red', bg: 'black', italic: false, bold: false, index: [5, 10] }, { color: 'white', bg: 'black', italic: false, bold: false, index: [11, 15] }, { color: 'magenta', bg: 'black', italic: false, bold: false, index: [16, 30] }]\n     */\n    mergeStyles(newStyleIndex: Array<StyleIndexObject>, currentStyleIndex: Array<StyleIndexObject>, startIndex: number, newSize: number): Array<StyleIndexObject> {\n        const new_ = [...newStyleIndex]\n        const current = [...currentStyleIndex]\n        const offset = startIndex\n        const _newSize = newSize\n        const merged: StyleIndexObject[] = []\n        current.forEach(style => {\n            if (style.index[0] < offset && style.index[1] < offset) {\n                merged.push(style)\n                return\n            } else if (style.index[0] < offset && style.index[1] >= offset && style.index[1] <= offset + _newSize) {\n                merged.push({ ...style, index: [style.index[0], offset] })\n                return\n            } else if (style.index[0] < offset && style.index[1] > offset + _newSize) {\n                merged.push({ ...style, index: [style.index[0], offset] })\n                merged.push({ ...style, index: [offset + _newSize, style.index[1]] })\n                return\n            } else if (style.index[0] >= offset && style.index[1] <= offset + _newSize) {\n                // Do nothing\n                return\n            } else if (style.index[0] >= offset && style.index[0] <= offset + _newSize && style.index[1] > offset + _newSize) {\n                merged.push({ ...style, index: [offset + _newSize, style.index[1]] })\n                return\n            } else if (style.index[0] > offset + _newSize && style.index[1] > offset + _newSize) {\n                merged.push(style)\n                return\n            }\n            this.emit(\"error\", new Error(\"mergeStyles: This should never happen\"))\n        })\n\n        // Then add the new style to the merged array\n        new_.forEach(newStyle => {\n            merged.push({ ...newStyle, index: [newStyle.index[0] + offset, newStyle.index[1] + offset] })\n        })\n\n        // Sort the merged array by index[0]\n        merged.sort(this.sortByIndex)\n        return merged\n    }\n\n    /**\n     * @description This method is used to sort an array of styleIndex objects by child index[0].\n     * @param {StyleIndexObject} a - The first object to compare.\n     * @param {StyleIndexObject} b - The second object to compare.\n     * @returns {number}\n     * @memberOf Screen\n     * @example merged.sort(this.sortByIndex)\n     */\n    sortByIndex(a: StyleIndexObject, b: StyleIndexObject): number {\n        if (a.index[0] < b.index[0]) {\n            return -1\n        } else if (a.index[0] > b.index[0]) {\n            return 1\n        } else {\n            return 0\n        }\n    }\n}\n\nexport default Screen"]} |
@@ -98,1 +98,2 @@ /// <reference types="node" /> | ||
export default ButtonPopup; | ||
//# sourceMappingURL=ButtonPopup.d.ts.map |
@@ -23,13 +23,22 @@ import { EventEmitter } from "events"; | ||
export class ButtonPopup extends EventEmitter { | ||
CM; | ||
id; | ||
title; | ||
message; | ||
buttons; | ||
selected; | ||
visible; | ||
marginTop; | ||
startIndex; | ||
constructor(id, title = "Confirm?", message = "", buttons = ["Ok", "Cancel", "?"], visible = false) { | ||
super(); | ||
this.boxChars = { | ||
normal: { | ||
topLeft: "┌", | ||
topRight: "┐", | ||
bottomLeft: "└", | ||
bottomRight: "┘", | ||
horizontal: "─", | ||
vertical: "│" | ||
}, | ||
selected: { | ||
topLeft: "╔", | ||
topRight: "╗", | ||
bottomLeft: "╚", | ||
bottomRight: "╝", | ||
horizontal: "═", | ||
vertical: "║" | ||
} | ||
}; | ||
/** @const {ConsoleManager} CM the instance of ConsoleManager (singleton) */ | ||
@@ -53,20 +62,2 @@ this.CM = new ConsoleManager(); | ||
} | ||
boxChars = { | ||
normal: { | ||
topLeft: "┌", | ||
topRight: "┐", | ||
bottomLeft: "└", | ||
bottomRight: "┘", | ||
horizontal: "─", | ||
vertical: "│" | ||
}, | ||
selected: { | ||
topLeft: "╔", | ||
topRight: "╗", | ||
bottomLeft: "╚", | ||
bottomRight: "╝", | ||
horizontal: "═", | ||
vertical: "║" | ||
} | ||
}; | ||
/** | ||
@@ -300,2 +291,2 @@ * @description This function is used to make the ConsoleManager handle the key events when the popup is showed. | ||
export default ButtonPopup; | ||
//# sourceMappingURL=ButtonPopup.js.map | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ButtonPopup.js","sourceRoot":"","sources":["../../../src/components/widgets/ButtonPopup.ts"],"names":[],"mappings":"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","sourcesContent":["import { EventEmitter } from \"events\"\nimport { ConsoleManager, KeyListenerArgs } from \"../../ConsoleGui.js\"\n\n/**\n * @class ButtonPopup\n * @extends EventEmitter\n * @description This class is used to create a popup with That asks for a confirm. \n * \n * ![ButtonPopup](https://user-images.githubusercontent.com/14907987/165752116-b796f41a-e4fe-45db-8c90-5d97318bd17a.gif)\n * \n * Emits the following events: \n * - \"confirm\" when the user confirm\n * - \"cancel\" when the user cancel\n * - \"exit\" when the user exit\n * @param {string} id - The id of the popup.\n * @param {string} title - The title of the popup.\n * @param {string} message - The message of the popup.\n * @param {Array<string>} buttons - The buttons of the popup (default is [\"Yes\", \"No\"]).\n * @param {boolean} visible - If the popup is visible. Default is false (make it appears using show()).\n * \n * @example const popup = new ButtonPopup(\"popup1\", \"Choose the option\", [\"YES\", \"NO\", \"?\"]).show().on(\"confirm\", (answer) => { console.log(answer) }) // show the popup and wait for the user to confirm\n */\nexport class ButtonPopup extends EventEmitter {\n    CM: ConsoleManager\n    id: string\n    title: string\n    message: string\n    buttons: string[]\n    selected: number\n    visible: boolean\n    marginTop: number\n    startIndex: number\n\n    public constructor(id: string, title = \"Confirm?\", message = \"\", buttons = [\"Ok\", \"Cancel\", \"?\"], visible = false) {\n        super()\n        /** @const {ConsoleManager} CM the instance of ConsoleManager (singleton) */\n        this.CM = new ConsoleManager()\n        this.id = id\n        this.title = title\n        this.message = message\n        this.buttons = buttons\n        this.selected = 0 // The selected option\n        this.visible = visible\n        this.marginTop = 4\n        this.startIndex = 0\n        if (this.CM.widgetsCollection[this.id]) {\n            this.CM.unRegisterWidget(this)\n            const message = `ButtonPopup ${this.id} already exists.`\n            this.CM.error(message)\n            throw new Error(message)\n        }\n        this.CM.registerWiget(this)\n    }\n\n    boxChars = {\n        normal: {\n            topLeft: \"┌\",\n            topRight: \"┐\",\n            bottomLeft: \"└\",\n            bottomRight: \"┘\",\n            horizontal: \"─\",\n            vertical: \"│\"\n        },\n        selected: {\n            topLeft: \"╔\",\n            topRight: \"╗\",\n            bottomLeft: \"╚\",\n            bottomRight: \"╝\",\n            horizontal: \"═\",\n            vertical: \"║\"\n        }\n    }\n\n    /**\n     * @description This function is used to make the ConsoleManager handle the key events when the popup is showed.\n     * Inside this function are defined all the keys that can be pressed and the actions to do when they are pressed.\n     * @param {string} _str - The string of the input.\n     * @param {any} key - The key object.\n     * @memberof ButtonPopup\n     */\n    public keyListner(_str: string, key : KeyListenerArgs): void {\n        switch (key.name) {\n        case \"left\":\n            if (this.selected > 0 && this.selected <= this.buttons.length) {\n                this.selected--\n            } else {\n                return\n            }\n            break\n        case \"right\":\n            if (this.selected >= 0 && this.selected < this.buttons.length - 1) {\n                this.selected++\n            } else {\n                return\n            }\n            break\n        case \"return\":\n            {\n                this.emit(\"confirm\", this.buttons[this.selected])\n                this.CM.unRegisterWidget(this)\n                this.hide()\n                //delete this\n            }\n            break\n        case \"escape\":\n            {\n                this.emit(\"cancel\")\n                this.CM.unRegisterWidget(this)\n                this.hide()\n                //delete this\n            }\n            break\n        case \"q\":\n            {\n                this.CM.emit(\"exit\")\n                this.CM.unRegisterWidget(this)\n                this.hide()\n                //delete this\n            }\n            break\n        default:\n            break\n        }\n        this.CM.refresh()\n    }\n\n    /**\n     * @description This function is used to show the popup. It also register the key events and refresh the ConsoleManager.\n     * @returns {ButtonPopup} The instance of the ButtonPopup.\n     * @memberof ButtonPopup\n     */\n    public show(): ButtonPopup {\n        if (!this.visible) {\n            this.manageInput()\n            this.visible = true\n            this.CM.refresh()\n        }\n        return this\n    }\n\n    /**\n     * @description This function is used to hide the popup. It also unregister the key events and refresh the ConsoleManager.\n     * @returns {ButtonPopup} The instance of the ButtonPopup.\n     * @memberof ButtonPopup\n     */\n    public hide(): ButtonPopup {\n        if (this.visible) {\n            this.unManageInput()\n            this.visible = false\n            this.CM.refresh()\n        }\n        return this\n    }\n\n    /**\n     * @description This function is used to get the visibility of the popup.\n     * @returns {boolean} The visibility of the popup.\n     * @memberof ButtonPopup\n     */\n    public isVisible(): boolean {\n        return this.visible\n    }\n\n    /**\n     * @description This function is used to add the ButtonPopup key listener callback to te ConsoleManager.\n     * @returns {ButtonPopup} The instance of the ButtonPopup.\n     * @memberof ButtonPopup\n     */\n    private manageInput(): ButtonPopup {\n        // Add a command input listener to change mode\n        this.CM.setKeyListener(this.id, this.keyListner.bind(this))\n        return this\n    }\n\n    /**\n     * @description This function is used to remove the ButtonPopup key listener callback to te ConsoleManager.\n     * @returns {ButtonPopup} The instance of the ButtonPopup.\n     * @memberof ButtonPopup\n     */\n    private unManageInput(): ButtonPopup {\n        // Add a command input listener to change mode\n        this.CM.removeKeyListener(this.id)\n        return this\n    }\n\n    /**\n     * @description This function is used to draw the ButtonPopup to the screen in the middle.\n     * @returns {ButtonPopup} The instance of the ButtonPopup.\n     * @memberof ButtonPopup\n     */\n    public draw(): ButtonPopup {\n        const offset = 1\n        const borderSize = 2\n        const spaceBetweenButtons = 1\n        let maxRowLength = 0\n        const buttonGrid: string[][] = []\n        let rowLength = 0\n        let rows = 0\n\n        this.buttons.forEach((button) => {\n            const newButtonLength = button.length + (2 * borderSize) + spaceBetweenButtons\n            // Divide into rows and columns the buttons (balance the buttons number between rows and columns)\n            if (rowLength + newButtonLength > this.CM.Screen.width - (2 * offset)) {\n                rows++\n                if (buttonGrid[rows]) {\n                    buttonGrid[rows].push(button)\n                } else {\n                    buttonGrid[rows] = [button]\n                }\n                rowLength = newButtonLength\n                if (rowLength > maxRowLength) {\n                    maxRowLength = rowLength - spaceBetweenButtons\n                }\n            } else {\n                if (buttonGrid[rows]) {\n                    buttonGrid[rows].push(button)\n                } else {\n                    buttonGrid[rows] = [button]\n                }\n                rowLength += newButtonLength\n                if (rowLength > maxRowLength) {\n                    maxRowLength = rowLength - spaceBetweenButtons\n                }\n            }\n        })\n        let title = `${this.title}`\n        if (title.length > this.CM.Screen.width - (2 * offset)) {\n            title = this.CM.truncate(title, this.CM.Screen.width - (2 * offset), true)\n        }\n        let msg = this.message ? `${this.message}` : \"\"\n        if (msg.length > this.CM.Screen.width - (2 * offset)) {\n            msg = this.CM.truncate(msg, this.CM.Screen.width - (2 * offset), true)\n        }\n        let windowWidth = title.length + (2 * offset)\n        if (windowWidth < msg.length) {\n            windowWidth = msg.length + (2 * offset)\n        }\n        if (windowWidth < maxRowLength) {\n            windowWidth = maxRowLength + (2 * offset)\n        }\n        const halfWidthTitle = Math.round((windowWidth - title.length) / 2)\n        const halfWidthMessage = Math.round((windowWidth - msg.length) / 2)\n\n        let header = \"┌\"\n        for (let i = 0; i < windowWidth; i++) {\n            header += \"─\"\n        }\n        header += \"┐\\n\"\n        header += `│${\" \".repeat(halfWidthTitle)}${title}${\" \".repeat(windowWidth - halfWidthTitle - title.length)}│\\n`\n        header += \"├\" + \"─\".repeat(windowWidth) + \"┤\\n\"\n\n        let footer = \"└\"\n        for (let i = 0; i < windowWidth; i++) {\n            footer += \"─\"\n        }\n        footer += \"┘\\n\"\n\n        let content = \"\"\n        if (msg !== \"\") {\n            content += `│${\" \".repeat(halfWidthMessage)}${msg}${\" \".repeat(windowWidth - halfWidthMessage - msg.length)}│\\n`\n        }\n        buttonGrid.forEach((row) => {\n            for (let k = 0; k < 3; k++) {\n                const buttonLength = row.map(button => button.length + (2 * borderSize) + spaceBetweenButtons)\n                const sumRowLength = buttonLength.reduce((a, b) => a + b, 0) - spaceBetweenButtons\n                const emptySpace = windowWidth - sumRowLength >= 0 ? windowWidth - sumRowLength : 0\n                row.forEach((button, colIndex) => {\n                    const btnBoxType = this.selected === this.buttons.indexOf(button) ? \"selected\" : \"normal\"\n                    if (colIndex < row.length) {\n                        if (colIndex === 0) {\n                            content += `│${\" \".repeat(emptySpace / 2)}`\n                        }\n                        if (k === 0) {\n                            content += `${this.boxChars[btnBoxType].topLeft}${this.boxChars[btnBoxType].horizontal.repeat(borderSize > 1 ? 2 * (borderSize - 1) + button.length : button.length)}${this.boxChars[btnBoxType].topRight}`\n                        } else if (k === 1) {\n                            content += `${this.boxChars[btnBoxType].vertical}${borderSize > 1 ? \" \".repeat(borderSize-1):\"\"}${button}${borderSize > 1 ? \" \".repeat(borderSize-1):\"\"}${this.boxChars[btnBoxType].vertical}`\n                        } else if (k === 2) {\n                            content += `${this.boxChars[btnBoxType].bottomLeft}${this.boxChars[btnBoxType].horizontal.repeat(borderSize > 1 ? 2 * (borderSize - 1) + button.length : button.length)}${this.boxChars[btnBoxType].bottomRight}`\n                        } else {\n                            this.CM.error(\"Error in ButtonPopup draw function\")\n                        }\n                        if (colIndex === row.length - 1) {\n                            content += \" \".repeat(!(emptySpace % 2) ? emptySpace / 2 : Math.round(emptySpace / 2)) + \"│\\n\"\n                        } else {\n                            content += \" \".repeat(spaceBetweenButtons)\n                        }\n                    } else if (colIndex === row.length) {\n                        content += \" \".repeat(!(emptySpace % 2) ? emptySpace / 2 : Math.round(emptySpace / 2)) + \"│\\n\"\n                    }\n                })\n            }\n        })\n\n\n\n        const windowDesign = `${header}${content}${footer}`\n        windowDesign.split(\"\\n\").forEach((line, index) => {\n            this.CM.Screen.cursorTo(Math.round((this.CM.Screen.width / 2) - (windowWidth / 2)), this.marginTop + index)\n            this.CM.Screen.write({ text: line, style: { color: \"white\" } })\n        })\n        return this\n    }\n}\n\nexport default ButtonPopup"]} |
@@ -24,1 +24,2 @@ import ButtonPopup from "./ButtonPopup.js"; | ||
export default ConfirmPopup; | ||
//# sourceMappingURL=ConfirmPopup.d.ts.map |
@@ -78,2 +78,2 @@ import ButtonPopup from "./ButtonPopup.js"; | ||
export default ConfirmPopup; | ||
//# sourceMappingURL=ConfirmPopup.js.map | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ29uZmlybVBvcHVwLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvd2lkZ2V0cy9Db25maXJtUG9wdXAudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxXQUFXLE1BQU0sa0JBQWtCLENBQUE7QUFFMUM7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBaUJHO0FBQ0gsTUFBTSxPQUFPLFlBQWEsU0FBUSxXQUFXO0lBQ3pDLFlBQW1CLEVBQVUsRUFBRSxLQUF5QixFQUFFLE9BQTJCO1FBQ2pGLEtBQUssQ0FBQyxFQUFFLEVBQUUsS0FBSyxFQUFFLE9BQU8sRUFBRSxDQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsQ0FBQyxDQUFBO1FBRXhDLEtBQUssQ0FBQyxVQUFVLEdBQUcsQ0FBQyxJQUFZLEVBQUUsR0FBcUIsRUFBRSxFQUFFO1lBQ3ZELFFBQVEsR0FBRyxDQUFDLElBQUksRUFBRTtnQkFDbEIsS0FBSyxNQUFNO29CQUNQLElBQUksSUFBSSxDQUFDLFFBQVEsR0FBRyxDQUFDLElBQUksSUFBSSxDQUFDLFFBQVEsSUFBSSxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sRUFBRTt3QkFDM0QsSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFBO3FCQUNsQjt5QkFBTTt3QkFDSCxPQUFNO3FCQUNUO29CQUNELE1BQUs7Z0JBQ1QsS0FBSyxPQUFPO29CQUNSLElBQUksSUFBSSxDQUFDLFFBQVEsSUFBSSxDQUFDLElBQUksSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUU7d0JBQy9ELElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQTtxQkFDbEI7eUJBQU07d0JBQ0gsT0FBTTtxQkFDVDtvQkFDRCxNQUFLO2dCQUNULEtBQUssUUFBUTtvQkFDVDt3QkFDSSxJQUFJLElBQUksQ0FBQyxRQUFRLEtBQUssQ0FBQyxFQUFFOzRCQUNyQixJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFBO3lCQUN2Qjs2QkFBTTs0QkFDSCxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFBO3lCQUN0Qjt3QkFDRCxJQUFJLENBQUMsRUFBRSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxDQUFBO3dCQUM5QixJQUFJLENBQUMsSUFBSSxFQUFFLENBQUE7d0JBQ1gsYUFBYTtxQkFDaEI7b0JBQ0QsTUFBSztnQkFDVCxLQUFLLFFBQVE7b0JBQ1Q7d0JBQ0ksSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQTt3QkFDbkIsSUFBSSxDQUFDLEVBQUUsQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsQ0FBQTt3QkFDOUIsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFBO3dCQUNYLGFBQWE7cUJBQ2hCO29CQUNELE1BQUs7Z0JBQ1QsS0FBSyxHQUFHO29CQUNKO3dCQUNJLElBQUksQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFBO3dCQUNwQixJQUFJLENBQUMsRUFBRSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxDQUFBO3dCQUM5QixJQUFJLENBQUMsSUFBSSxFQUFFLENBQUE7d0JBQ1gsYUFBYTtxQkFDaEI7b0JBQ0QsTUFBSztnQkFDVDtvQkFDSSxNQUFLO2FBQ1I7WUFDRCxJQUFJLENBQUMsRUFBRSxDQUFDLE9BQU8sRUFBRSxDQUFBO1FBQ3JCLENBQUMsQ0FBQTtJQUNMLENBQUM7Q0FDSjtBQUVELGVBQWUsWUFBWSxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgS2V5TGlzdGVuZXJBcmdzIH0gZnJvbSBcIi4uLy4uL0NvbnNvbGVHdWkuanNcIlxuaW1wb3J0IEJ1dHRvblBvcHVwIGZyb20gXCIuL0J1dHRvblBvcHVwLmpzXCJcblxuLyoqXG4gKiBAY2xhc3MgQ29uZmlybVBvcHVwXG4gKiBAZXh0ZW5kcyBCdXR0b25Qb3B1cFxuICogQGRlc2NyaXB0aW9uIFRoaXMgY2xhc3MgaXMgYW4gb3ZlcmxvYWQgb2YgQnV0dG9uUG9wdXAgdGhhdCBpcyB1c2VkIHRvIGNyZWF0ZSBhIHBvcHVwIHdpdGggVGhhdCBhc2tzIGZvciBhIGNvbmZpcm0gW1llcywgTm9dLiBcbiAqIFxuICogIVtDb25maXJtUG9wdXBdKGh0dHBzOi8vdXNlci1pbWFnZXMuZ2l0aHVidXNlcmNvbnRlbnQuY29tLzE0OTA3OTg3LzE2NTc1MjIyNi1iNzZiMTU3Zi00OTM1LTQyNDgtYTVjYy0zYjIxZDA4N2NiMDQuZ2lmKVxuICogXG4gKiBFbWl0cyB0aGUgZm9sbG93aW5nIGV2ZW50czogXG4gKiAtIFwiY29uZmlybVwiIHdoZW4gdGhlIHVzZXIgY29uZmlybVxuICogLSBcImNhbmNlbFwiIHdoZW4gdGhlIHVzZXIgY2FuY2VsXG4gKiAtIFwiZXhpdFwiIHdoZW4gdGhlIHVzZXIgZXhpdFxuICogQHBhcmFtIHtzdHJpbmd9IGlkIC0gVGhlIGlkIG9mIHRoZSBwb3B1cC5cbiAqIEBwYXJhbSB7c3RyaW5nfSB0aXRsZSAtIFRoZSB0aXRsZSBvZiB0aGUgcG9wdXAuXG4gKiBAcGFyYW0ge3N0cmluZ30gbWVzc2FnZSAtIFRoZSBtZXNzYWdlIG9mIHRoZSBwb3B1cC5cbiAqIEBwYXJhbSB7Ym9vbGVhbn0gdmlzaWJsZSAtIElmIHRoZSBwb3B1cCBpcyB2aXNpYmxlLiBEZWZhdWx0IGlzIGZhbHNlIChtYWtlIGl0IGFwcGVhcnMgdXNpbmcgc2hvdygpKS5cbiAqIFxuICogQGV4YW1wbGUgY29uc3QgcG9wdXAgPSBuZXcgQ29uZmlybVBvcHVwKFwicG9wdXAxXCIsIFwiQXJlIHlvdSBzaHVyZVwiKS5zaG93KCkub24oXCJjb25maXJtXCIsIChhbnN3ZXIpID0+IHsgY29uc29sZS5sb2coYW5zd2VyKSB9KSAvLyBzaG93IHRoZSBwb3B1cCBhbmQgd2FpdCBmb3IgdGhlIHVzZXIgdG8gY29uZmlybVxuICovXG5leHBvcnQgY2xhc3MgQ29uZmlybVBvcHVwIGV4dGVuZHMgQnV0dG9uUG9wdXAge1xuICAgIHB1YmxpYyBjb25zdHJ1Y3RvcihpZDogc3RyaW5nLCB0aXRsZTogc3RyaW5nIHwgdW5kZWZpbmVkLCBtZXNzYWdlOiBzdHJpbmcgfCB1bmRlZmluZWQpIHtcbiAgICAgICAgc3VwZXIoaWQsIHRpdGxlLCBtZXNzYWdlLCBbXCJZZXNcIiwgXCJOb1wiXSlcblxuICAgICAgICBzdXBlci5rZXlMaXN0bmVyID0gKF9zdHI6IHN0cmluZywga2V5IDogS2V5TGlzdGVuZXJBcmdzKSA9PiB7XG4gICAgICAgICAgICBzd2l0Y2ggKGtleS5uYW1lKSB7XG4gICAgICAgICAgICBjYXNlIFwibGVmdFwiOlxuICAgICAgICAgICAgICAgIGlmICh0aGlzLnNlbGVjdGVkID4gMCAmJiB0aGlzLnNlbGVjdGVkIDw9IHRoaXMuYnV0dG9ucy5sZW5ndGgpIHtcbiAgICAgICAgICAgICAgICAgICAgdGhpcy5zZWxlY3RlZC0tXG4gICAgICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICAgICAgcmV0dXJuXG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIGJyZWFrXG4gICAgICAgICAgICBjYXNlIFwicmlnaHRcIjpcbiAgICAgICAgICAgICAgICBpZiAodGhpcy5zZWxlY3RlZCA+PSAwICYmIHRoaXMuc2VsZWN0ZWQgPCB0aGlzLmJ1dHRvbnMubGVuZ3RoIC0gMSkge1xuICAgICAgICAgICAgICAgICAgICB0aGlzLnNlbGVjdGVkKytcbiAgICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgICAgICByZXR1cm5cbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgYnJlYWtcbiAgICAgICAgICAgIGNhc2UgXCJyZXR1cm5cIjpcbiAgICAgICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgICAgIGlmICh0aGlzLnNlbGVjdGVkID09PSAwKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICB0aGlzLmVtaXQoXCJjb25maXJtXCIpXG4gICAgICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgICAgICB0aGlzLmVtaXQoXCJjYW5jZWxcIilcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgICB0aGlzLkNNLnVuUmVnaXN0ZXJXaWRnZXQodGhpcylcbiAgICAgICAgICAgICAgICAgICAgdGhpcy5oaWRlKClcbiAgICAgICAgICAgICAgICAgICAgLy9kZWxldGUgdGhpc1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICBicmVha1xuICAgICAgICAgICAgY2FzZSBcImVzY2FwZVwiOlxuICAgICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICAgICAgdGhpcy5lbWl0KFwiY2FuY2VsXCIpXG4gICAgICAgICAgICAgICAgICAgIHRoaXMuQ00udW5SZWdpc3RlcldpZGdldCh0aGlzKVxuICAgICAgICAgICAgICAgICAgICB0aGlzLmhpZGUoKVxuICAgICAgICAgICAgICAgICAgICAvL2RlbGV0ZSB0aGlzXG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIGJyZWFrXG4gICAgICAgICAgICBjYXNlIFwicVwiOlxuICAgICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICAgICAgdGhpcy5DTS5lbWl0KFwiZXhpdFwiKVxuICAgICAgICAgICAgICAgICAgICB0aGlzLkNNLnVuUmVnaXN0ZXJXaWRnZXQodGhpcylcbiAgICAgICAgICAgICAgICAgICAgdGhpcy5oaWRlKClcbiAgICAgICAgICAgICAgICAgICAgLy9kZWxldGUgdGhpc1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICBicmVha1xuICAgICAgICAgICAgZGVmYXVsdDpcbiAgICAgICAgICAgICAgICBicmVha1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgdGhpcy5DTS5yZWZyZXNoKClcbiAgICAgICAgfVxuICAgIH1cbn1cblxuZXhwb3J0IGRlZmF1bHQgQ29uZmlybVBvcHVwIl19 |
@@ -107,1 +107,2 @@ /// <reference types="node" /> | ||
export default CustomPopup; | ||
//# sourceMappingURL=CustomPopup.d.ts.map |
@@ -24,9 +24,2 @@ import { EventEmitter } from "events"; | ||
export class CustomPopup extends EventEmitter { | ||
CM; | ||
id; | ||
title; | ||
content; | ||
width; | ||
visible; | ||
marginTop; | ||
constructor(id, title, content, width, visible = false) { | ||
@@ -252,2 +245,2 @@ super(); | ||
export default CustomPopup; | ||
//# sourceMappingURL=CustomPopup.js.map | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"CustomPopup.js","sourceRoot":"","sources":["../../../src/components/widgets/CustomPopup.ts"],"names":[],"mappings":"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","sourcesContent":["import { EventEmitter } from \"events\"\nimport { ConsoleManager, KeyListenerArgs } from \"../../ConsoleGui.js\"\nimport PageBuilder, { StyledElement } from \"../PageBuilder.js\"\n\n/**\n * @class CustomPopup\n * @extends EventEmitter\n * @description This class is used to create a popup with a free content built with PageBuilder class. \n * \n * ![Animation](https://user-images.githubusercontent.com/14907987/165736767-d60f857f-3945-4b95-aa4f-292b6a41f789.gif)\n * \n * Emits the following events: \n * - \"confirm\" when the user confirm\n * - \"cancel\" when the user cancel\n * - \"exit\" when the user exit\n * - \"data\" when the user send custom event - the data is an object with the data and the event name\n * @param {string} id - The id of the popup.\n * @param {string} title - The title of the popup.\n * @param {PageBuilder} content - The content of the popup.\n * @param {number} width - The width of the popup.\n * @param {boolean} visible - If the popup is visible. Default is false (make it appears using show()).\n * \n * @example const popup = new CustomPopup(\"popup1\", \"See that values\", new PageBuilder()).show()\n */\nexport class CustomPopup extends EventEmitter {\n    CM: ConsoleManager\n    id: string\n    title: string\n    content: PageBuilder\n    width: number\n    visible: boolean\n    marginTop: number\n\n    public constructor(id: string, title: string, content: PageBuilder, width: number, visible = false) {\n        super()\n        /** @const {ConsoleManager} CM the instance of ConsoleManager (singleton) */\n        this.CM = new ConsoleManager()\n        this.id = id\n        this.title = title\n        this.content = content\n        this.width = width\n        this.visible = visible\n        this.marginTop = 4\n        if (this.CM.widgetsCollection[this.id]) {\n            this.CM.unRegisterWidget(this)\n            const message = `CustomPopup ${this.id} already exists.`\n            this.CM.error(message)\n            throw new Error(message)\n        }\n        this.CM.registerWiget(this)\n    }\n\n    /**\n     * @description This function is used to make the ConsoleManager handle the key events when the input is text and it is showed.\n     * Inside this function are defined all the keys that can be pressed and the actions to do when they are pressed.\n     * @param {string} str - The string of the input.\n     * @param {Object} key - The key object.\n     * @memberof CustomPopup\n     */\n    public keyListner(_str: string, key : KeyListenerArgs): void {\n        switch (key.name) {\n        case \"up\":\n            this.content.increaseScrollIndex()\n            break\n        case \"down\":\n            this.content.decreaseScrollIndex()\n            break\n        case \"return\":\n            {\n                this.emit(\"confirm\")\n                this.CM.unRegisterWidget(this)\n                this.hide()\n                //delete this\n            }\n            break\n        case \"escape\":\n            {\n                this.emit(\"cancel\")\n                this.CM.unRegisterWidget(this)\n                this.hide()\n                //delete this\n            }\n            break\n        case \"q\":\n            {\n                this.CM.emit(\"exit\")\n                this.CM.unRegisterWidget(this)\n                this.hide()\n                //delete this\n            }\n            break\n        default:\n            break\n        }\n        this.CM.refresh()\n    }\n\n    /**\n     * @description This function is used to get the content of the popup.\n     * @returns {PageBuilder} The content of the popup.\n     * @memberof CustomPopup\n     */\n    public getContent(): PageBuilder {\n        return this.content\n    }\n\n    /**\n     * @description This function is used to change the content of the popup. It also refresh the ConsoleManager.\n     * @param {PageBuilder} newContent - The new content of the popup.\n     * @memberof CustomPopup\n     * @returns {CustomPopup} The instance of the CustomPopup.\n     */\n    public setContent(newContent: PageBuilder): CustomPopup {\n        this.content = newContent\n        this.CM.refresh()\n        return this\n    }\n\n    /**\n     * @description This function is used to change the popup width. It also refresh the ConsoleManager.\n     * @param {number} newWidth - The new width of the popup.\n     * @memberof CustomPopup\n     * @returns {CustomPopup} The instance of the CustomPopup.\n     */\n    public setWidth(newWidth: number): this {\n        this.width = newWidth\n        this.CM.refresh()\n        return this\n    }\n\n    /**\n     * @description This function is used to show the popup. It also register the key events and refresh the ConsoleManager.\n     * @returns {CustomPopup} The instance of the CustomPopup.\n     * @memberof CustomPopup\n     */\n    public show(): this {\n        if (!this.visible) {\n            this.manageInput()\n            this.visible = true\n            this.CM.refresh()\n        }\n        return this\n    }\n\n    /**\n     * @description This function is used to hide the popup. It also unregister the key events and refresh the ConsoleManager.\n     * @returns {CustomPopup} The instance of the CustomPopup.\n     * @memberof CustomPopup\n     */\n    public hide(): this {\n        if (this.visible) {\n            this.unManageInput()\n            this.visible = false\n            this.CM.refresh()\n        }\n        return this\n    }\n\n    /**\n     * @description This function is used to get the visibility of the popup.\n     * @returns {boolean} The visibility of the popup.\n     * @memberof CustomPopup\n     */\n    public isVisible(): boolean {\n        return this.visible\n    }\n\n    /**\n     * @description This function is used to add the CustomPopup key listener callback to te ConsoleManager.\n     * @returns {CustomPopup} The instance of the CustomPopup.\n     * @memberof CustomPopup\n     */\n    private manageInput(): CustomPopup {\n        // Add a command input listener to change mode\n        this.CM.setKeyListener(this.id, this.keyListner.bind(this))\n        return this\n    }\n\n    /**\n     * @description This function is used to remove the CustomPopup key listener callback to te ConsoleManager.\n     * @returns {CustomPopup} The instance of the CustomPopup.\n     * @memberof CustomPopup\n     */\n    private unManageInput(): CustomPopup {\n        // Add a command input listener to change mode\n        this.CM.removeKeyListener(this.id/*, this.keyListner.bind(this)*/)\n        return this\n    }\n\n    /**\n     * @description This function is used to draw a single line of the layout to the screen. It also trim the line if it is too long.\n     * @param {Array<object>} line the line to be drawn\n     * @memberof CustomPopup\n     * @returns {void}\n     */\n    private drawLine(line: StyledElement[], width: number): void {\n        let unformattedLine = \"\"\n        let newLine = [...line]\n        line.forEach((element: { text: string }) => {\n            unformattedLine += element.text\n        })\n        if (unformattedLine.length > width - 2) { // Need to truncate\n            const offset = 2\n            newLine = JSON.parse(JSON.stringify(line)) // Shallow copy because I don't want to modify the values but not the original\n            let diff = unformattedLine.length - width\n            // remove truncated text\n            for (let i = newLine.length - 1; i >= 0; i--) {\n                if (newLine[i].text.length > diff + offset) {\n                    newLine[i].text = this.CM.truncate(newLine[i].text, (newLine[i].text.length - diff) - offset, true)\n                    break\n                } else {\n                    diff -= newLine[i].text.length\n                    newLine.splice(i, 1)\n                }\n            }\n            // Update unformatted line\n            unformattedLine = \"\"\n            newLine.forEach(element => {\n                unformattedLine += element.text\n            })\n        }\n        newLine.unshift({ text: \"│\", style: { color: \"white\" } })\n        if (unformattedLine.length <= width) {\n            newLine.push({ text: `${\" \".repeat((width - unformattedLine.length))}`, style: { color: \"\" } })\n        }\n        newLine.push({ text: \"│\", style: { color: \"white\" } })\n        this.CM.Screen.write(...newLine)\n    }\n\n    /**\n     * @description This function is used to draw the CustomPopup to the screen in the middle.\n     * @returns {CustomPopup} The instance of the CustomPopup.\n     * @memberof CustomPopup\n     */\n    public draw(): CustomPopup {\n        const offset = 2\n        const windowWidth = this.title.length > this.width ? this.title.length + (2 * offset) : this.width + (2 * offset) + 1\n        const halfWidth = Math.round((windowWidth - this.title.length) / 2)\n        const x = Math.round((this.CM.Screen.width / 2) - (windowWidth / 2))\n        let header = \"┌\"\n        for (let i = 0; i < windowWidth; i++) {\n            header += \"─\"\n        }\n        header += \"┐\\n\"\n        header += `│${\" \".repeat(halfWidth)}${this.title}${\" \".repeat(windowWidth - halfWidth - this.title.length)}│\\n`\n        header += \"├\" + \"─\".repeat(windowWidth) + \"┤\\n\"\n\n        const windowDesign = `${header}`\n        const arrWindowDesign = windowDesign.split(\"\\n\")\n        arrWindowDesign.forEach((line, index) => {\n            this.CM.Screen.cursorTo(x, this.marginTop + index)\n            this.CM.Screen.write({ text: line, style: { color: \"white\" } })\n        })\n        const _content = this.content.getContent()\n        _content.forEach((line: StyledElement[], index: number) => {\n            this.CM.Screen.cursorTo(x, this.marginTop + index + arrWindowDesign.length - 1)\n            this.drawLine(line, windowWidth)\n        })\n        this.CM.Screen.cursorTo(x, this.marginTop + _content.length + arrWindowDesign.length - 1)\n        this.CM.Screen.write({ text: `└${\"─\".repeat(windowWidth)}┘`, style: { color: \"white\" } })\n        return this\n    }\n}\n\nexport default CustomPopup"]} |
@@ -7,6 +7,6 @@ /// <reference types="node" /> | ||
* @typedef {Object} FileItemObject | ||
* @property {string} name - The name of the file. | ||
* @property {string} path - The path to the file. | ||
* @property {"dir" | "file"} type - The type of the file. | ||
* @property {string} text - The display text of the file. | ||
* @prop {string} name - The name of the file. | ||
* @prop {string} path - The path to the file. | ||
* @prop {"dir" | "file"} type - The type of the file. | ||
* @prop {string} text - The display text of the file. | ||
* | ||
@@ -134,1 +134,2 @@ * @interface FileItemObject | ||
export default FileSelectorPopup; | ||
//# sourceMappingURL=FileSelectorPopup.d.ts.map |
@@ -29,15 +29,2 @@ import { EventEmitter } from "events"; | ||
export class FileSelectorPopup extends EventEmitter { | ||
CM; | ||
id; | ||
title; | ||
basePath; | ||
currentPath; | ||
selectDirectory; | ||
allowedExtensions; | ||
limitToPath; | ||
visible; | ||
marginTop; | ||
startIndex; | ||
selected; | ||
options; | ||
constructor(id, title, basePath, selectDirectory = false, allowedExtensions = [], limitToPath = false, visible = false) { | ||
@@ -344,2 +331,2 @@ super(); | ||
export default FileSelectorPopup; | ||
//# sourceMappingURL=FileSelectorPopup.js.map | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"FileSelectorPopup.js","sourceRoot":"","sources":["../../../src/components/widgets/FileSelectorPopup.ts"],"names":[],"mappings":"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","sourcesContent":["import { EventEmitter } from \"events\"\nimport { ConsoleManager, KeyListenerArgs } from \"../../ConsoleGui.js\"\nimport fs from \"fs\"\nimport path from \"path\"\n\n/**\n * @description The file descriptions for the file selector popup.\n * @typedef {Object} FileItemObject\n * @prop {string} name - The name of the file.\n * @prop {string} path - The path to the file.\n * @prop {\"dir\" | \"file\"} type - The type of the file.\n * @prop {string} text - The display text of the file.\n *\n * @interface FileItemObject\n */\ninterface FileItemObject { \n    text: string; \n    name: string; \n    type: \"dir\" | \"file\"; \n    path: string;\n}\n\n/**\n * @class FileSelectorPopup\n * @extends EventEmitter\n * @description This class is used to create a popup with a file input to select a file or a directory.\n * It will run a promise with fs.readdir to get the list of files and directories.\n * The user can select a file or a directory and the popup will be closed. \n * \n * ![FileSelectorPopup](https://user-images.githubusercontent.com/14907987/165938464-c1426102-b598-42bb-8597-6337f0bcb009.gif)\n * \n * Emits the following events: \n * - \"confirm\" when the user confirm the file or directory selection. The file or directory path is passed as parameter like this: {path: \"path/to/file\", name: \"file.ext\"}\n * - \"cancel\" when the user cancel the file or directory selection.\n * - \"exit\" when the user exit\n * @param {string} id - The id of the popup.\n * @param {string} title - The title of the popup.\n * @param {string} basePath - The main path of the popup.\nre case sensitive.\n * @param {boolean} [limitToPath=false] - If true, the user can select a directory. Otherwise, only files are selectable. When true, to enter a directory, the user must press the space key instead of the enter key.\n * @param {Array<string>} [allowedExtensions=[]] - The allowed extensions. If not set, all extensions are allowed. The extensions a can only select files in the path. If false, the user can select files in the path and parent directories.\n * @param {boolean} visible - If the popup is visible. Default is false (make it appears using show()).\n * \n * @example const popup = new FileSelectorPopup(\"popup1\", \"Choose the file\", \"./examples\").show().on(\"confirm\", (selected) => { console.log(selected) }) // show the popup and wait for the user to confirm\n */\nexport class FileSelectorPopup extends EventEmitter {\n    CM: ConsoleManager\n    id: string\n    title: string\n    basePath: string\n    currentPath: string\n    selectDirectory: boolean\n    allowedExtensions: string[]\n    limitToPath: boolean\n    visible: boolean\n    marginTop: number\n    startIndex: number\n    selected: FileItemObject\n    options: FileItemObject[]\n\n    public constructor(id: string, title: string, basePath: string, selectDirectory = false, allowedExtensions = [], limitToPath = false, visible = false) {\n        super()\n        /** @const {ConsoleManager} CM the instance of ConsoleManager (singleton) */\n        this.CM = new ConsoleManager()\n        this.id = id\n        this.title = title\n        this.basePath = basePath\n        this.currentPath = basePath\n        this.selectDirectory = selectDirectory\n        this.allowedExtensions = allowedExtensions\n        this.limitToPath = limitToPath\n        this.visible = visible\n        this.marginTop = 4\n        this.startIndex = 0\n        this.selected = { text: \"../\", name: \"../\", type: \"dir\", path: path.join(basePath, \"../\") }\n        if (this.CM.widgetsCollection[this.id]) {\n            this.CM.unRegisterWidget(this)\n            const message = `FileSelectorPopup ${this.id} already exists.`\n            this.CM.error(message)\n            throw new Error(message)\n        }\n        this.CM.registerWiget(this)\n        this.options = [{ text: \"../\", name: \"../\", type: \"dir\", path: path.join(basePath, \"../\") }]\n        this.updateList(this.basePath)\n    }\n\n    /**\n     * @description This function is used to load the list of files and directories in the current path.\n    it return a promise with the list of files and directories. The list is an array of objects like this:\n    [{text: \"📄 file.ext\", name: \"file.ext\", type: \"file\", path: \"path/to/file.ext\"}, {text: \"📁 dir/\", name: \"dir\", type: \"dir\", path: \"path/to/dir\"}]\n     * @param {string} dir - The path to load the list.\n     * @returns {Promise<Array<object>>} The list of files and directories.\n     * @memberof FileSelectorPopup\n     */\n    private listDir(dir: string): Promise<Array<FileItemObject>> {\n        return new Promise((resolve, reject) => {\n            fs.readdir(dir, (err, files) => {\n                if (err) {\n                    reject(err)\n                } else {\n                    resolve(files.map(file => {\n                        const filePath = path.join(dir, file)\n                        const stats = fs.statSync(filePath)\n                        const isDirectory = stats.isDirectory()\n                        //const isFile = stats.isFile()\n                        if (isDirectory) {\n                            return { text: `📁 ${file}/`, name: file, type: \"dir\", path: filePath }\n                        } else {\n                            return { text: `📄 ${file}`, name: file, type: \"file\", path: filePath }\n                        }\n                    }).filter(file => {\n                        const isAllowed = this.allowedExtensions.length === 0 || this.allowedExtensions.includes(path.extname(file.name))\n                        if (this.selectDirectory && file.type === \"file\") {\n                            return false\n                        }\n                        return isAllowed || file.type === \"dir\"\n                    }) as Array<FileItemObject>)\n                }\n            })\n        })\n    }\n\n    /**\n     * @description This function calls the updateList function and store the result to this.options, it also refresh the list of files and directories.\n     * @param {string} _path - The path to load the list.\n     * @memberof FileSelectorPopup\n     */\n    private updateList(_path: string) {\n        if (this.limitToPath) {\n            if (!path.resolve(_path).includes(path.resolve(this.basePath))) {\n                return\n            }\n        }\n        this.currentPath = _path\n        this.listDir(this.currentPath).then((files) => {\n            this.options = [{ text: \"../\", name: \"../\", type: \"dir\", path: path.join(this.currentPath, \"../\")} as FileItemObject].concat(files)\n            this.setSelected(this.options[0])\n            this.CM.refresh()\n        })\n    }\n\n    private adaptOptions() {\n        return this.options.slice(this.startIndex, this.startIndex + this.CM.Screen.height - this.marginTop - 6)\n    }\n\n    /**\n     * @description This function is used to make the ConsoleManager handle the key events when the popup is showed.\n     * Inside this function are defined all the keys that can be pressed and the actions to do when they are pressed.\n     * @param {string} str - The string of the input.\n     * @param {Object} key - The key object.\n     * @memberof FileSelectorPopup\n     */\n    public keyListner(_str: string, key: KeyListenerArgs) {\n        const ind = this.options.indexOf(this.selected)\n        switch (key.name) {\n        case \"down\":\n            this.setSelected(this.options[(ind + 1) % this.options.length])\n            if (this.CM.Screen.height - this.marginTop - 4 < this.options.length) {\n                if (this.selected === this.options[this.adaptOptions().length + this.startIndex]) {\n                    this.startIndex++\n                }\n            } else {\n                this.startIndex = 0\n            }\n            break\n        case \"up\":\n            this.setSelected(this.options[(ind - 1 + this.options.length) % this.options.length])\n            if (this.startIndex > 0 && this.selected === this.adaptOptions()[0]) {\n                this.startIndex--\n            }\n            break\n        case \"pagedown\":\n            if (this.CM.Screen.height - this.marginTop - 4 < this.options.length) {\n                this.setSelected(this.options[(ind + this.adaptOptions().length) % this.options.length])\n                if (this.startIndex + this.adaptOptions().length < this.options.length) {\n                    this.startIndex += this.adaptOptions().length\n                } else {\n                    this.startIndex = 0\n                }\n            } else {\n                return\n            }\n            break\n        case \"pageup\":\n            if (this.CM.Screen.height - this.marginTop - 4 < this.options.length) {\n                this.setSelected(this.options[(ind - this.adaptOptions().length + this.options.length) % this.options.length])\n                if (this.startIndex > this.adaptOptions().length) {\n                    this.startIndex -= this.adaptOptions().length\n                } else {\n                    this.startIndex = 0\n                }\n            } else {\n                return\n            }\n            break\n        case \"return\":\n            {\n                if (this.selectDirectory) {\n                    if (this.selected.type === \"dir\") {\n                        this.emit(\"confirm\", { path: this.selected.path, name: this.selected.name })\n                        this.CM.unRegisterWidget(this)\n                        this.hide()\n                        //delete this\n                    }\n                } else {\n                    if (this.selected.type === \"dir\") {\n                        this.updateList(this.selected.path)\n                    } else {\n                        this.emit(\"confirm\", { path: this.selected.path, name: this.selected.name })\n                        this.CM.unRegisterWidget(this)\n                        this.hide()\n                        //delete this\n                    }\n                }\n            }\n            break\n        case \"space\":\n            if (this.selected.type === \"dir\") {\n                this.updateList(this.selected.path)\n            }\n            break\n        case \"escape\":\n            {\n                this.emit(\"cancel\")\n                this.CM.unRegisterWidget(this)\n                this.hide()\n                //delete this\n            }\n            break\n        case \"q\":\n            {\n                this.CM.emit(\"exit\")\n                this.CM.unRegisterWidget(this)\n                this.hide()\n                //delete this\n            }\n            break\n        default:\n            break\n        }\n        this.CM.refresh()\n    }\n\n    /**\n     * @description This function is used to get the selected option.\n     * @returns {FileItemObject} The selected value of the popup.\n     * @memberof FileSelectorPopup\n     */\n    public getSelected(): FileItemObject {\n        return this.selected\n    }\n\n    /**\n     * @description This function is used to change the selection of the popup. It also refresh the ConsoleManager.\n     * @param {FileItemObject} selected - The new value of the selection.\n     * @memberof FileSelectorPopup\n     * @returns {FileSelectorPopup} The instance of the FileSelectorPopup.\n     */\n    private setSelected(selected : FileItemObject): FileSelectorPopup {\n        this.selected = selected\n        this.CM.refresh()\n        return this\n    }\n\n    /**\n     * @description This function is used to show the popup. It also register the key events and refresh the ConsoleManager.\n     * @returns {FileSelectorPopup} The instance of the FileSelectorPopup.\n     * @memberof FileSelectorPopup\n     */\n    public show(): FileSelectorPopup {\n        if (!this.visible) {\n            this.manageInput()\n            this.visible = true\n            this.CM.refresh()\n        }\n        return this\n    }\n\n    /**\n     * @description This function is used to hide the popup. It also unregister the key events and refresh the ConsoleManager.\n     * @returns {FileSelectorPopup} The instance of the FileSelectorPopup.\n     * @memberof FileSelectorPopup\n     */\n    public hide(): FileSelectorPopup {\n        if (this.visible) {\n            this.unManageInput()\n            this.visible = false\n            this.CM.refresh()\n        }\n        return this\n    }\n\n    /**\n     * @description This function is used to get the visibility of the popup.\n     * @returns {boolean} The visibility of the popup.\n     * @memberof FileSelectorPopup\n     */\n    public isVisible(): boolean {\n        return this.visible\n    }\n\n    /**\n     * @description This function is used to add the FileSelectorPopup key listener callback to te ConsoleManager.\n     * @returns {FileSelectorPopup} The instance of the FileSelectorPopup.\n     * @memberof FileSelectorPopup\n     */\n    private manageInput(): FileSelectorPopup {\n        // Add a command input listener to change mode\n        this.CM.setKeyListener(this.id, this.keyListner.bind(this))\n        return this\n    }\n\n    /**\n     * @description This function is used to remove the FileSelectorPopup key listener callback to te ConsoleManager.\n     * @returns {FileSelectorPopup} The instance of the FileSelectorPopup.\n     * @memberof FileSelectorPopup\n     */\n    private unManageInput(): FileSelectorPopup {\n        // Add a command input listener to change mode\n        this.CM.removeKeyListener(this.id)\n        return this\n    }\n\n    /**\n     * @description This function is used to draw the FileSelectorPopup to the screen in the middle.\n     * @returns {FileSelectorPopup} The instance of the FileSelectorPopup.\n     * @memberof FileSelectorPopup\n     */\n    public draw(): FileSelectorPopup {\n        // Change start index if selected is not in the adaptOptions return array\n        const ind = this.adaptOptions().indexOf(this.selected)\n        const ind1 = this.options.indexOf(this.selected)\n        if (ind === -1) {\n            this.startIndex = ind1 - this.adaptOptions().length + 1 > 0 ? ind1 - this.adaptOptions().length + 1 : 0\n        }\n        const offset = 2\n        const maxOptionsLength = this.options.map((o) => o.text).reduce((max, option) => Math.max(max, option.length), 0)\n        const windowWidth = maxOptionsLength > this.title.length ? maxOptionsLength + (2 * offset) : this.title.length + (2 * offset)\n        const halfWidth = Math.round((windowWidth - this.title.length) / 2)\n\n        let header = \"┌\"\n        for (let i = 0; i < windowWidth; i++) {\n            header += \"─\"\n        }\n        header += \"┐\\n\"\n        header += `│${\" \".repeat(halfWidth)}${this.title}${\" \".repeat(windowWidth - halfWidth - this.title.length)}│\\n`\n        header += \"├\" + \"─\".repeat(windowWidth) + \"┤\\n\"\n\n        let footer = \"└\"\n        for (let i = 0; i < windowWidth; i++) {\n            footer += \"─\"\n        }\n        footer += \"┘\\n\"\n\n        let content = \"\"\n        this.adaptOptions().forEach((option) => {\n            content += `│${option.name === this.selected.name ? \"<\" : \" \"} ${option.text}${option.name === this.selected.name ? \" >\" : \"  \"}${\" \".repeat(windowWidth - option.text.toString().length - 4)}│\\n`\n        })\n\n        const windowDesign = `${header}${content}${footer}`\n        windowDesign.split(\"\\n\").forEach((line, index) => {\n            this.CM.Screen.cursorTo(Math.round((this.CM.Screen.width / 2) - (windowWidth / 2)), this.marginTop + index)\n            this.CM.Screen.write({ text: line, style: { color: \"white\" } })\n        })\n        return this\n    }\n}\n\nexport default FileSelectorPopup"]} |
@@ -99,1 +99,2 @@ /// <reference types="node" /> | ||
export default InputPopup; | ||
//# sourceMappingURL=InputPopup.d.ts.map |
@@ -23,9 +23,2 @@ import { EventEmitter } from "events"; | ||
export class InputPopup extends EventEmitter { | ||
CM; | ||
id; | ||
title; | ||
value; | ||
numeric; | ||
visible; | ||
marginTop; | ||
constructor(id, title, value, numeric, visible = false) { | ||
@@ -292,2 +285,2 @@ super(); | ||
export default InputPopup; | ||
//# sourceMappingURL=InputPopup.js.map | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"InputPopup.js","sourceRoot":"","sources":["../../../src/components/widgets/InputPopup.ts"],"names":[],"mappings":"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","sourcesContent":["import { EventEmitter } from \"events\"\nimport { ConsoleManager, KeyListenerArgs } from \"../../ConsoleGui.js\"\n\n/**\n * @class InputPopup\n * @extends EventEmitter\n * @description This class is used to create a popup with a text or numeric input. \n * \n * ![InputPopup](https://user-images.githubusercontent.com/14907987/165752281-e836b862-a54a-48d5-b4e7-954374d6509f.gif)\n * \n * Emits the following events: \n * - \"confirm\" when the user confirm the input\n * - \"cancel\" when the user cancel the input\n * - \"exit\" when the user exit the input\n * @param {string} id - The id of the popup.\n * @param {string} title - The title of the popup.\n * @param {string | number} value - The value of the input.\n * @param {boolean} numeric - If the input is numeric.\n * @param {boolean} visible - If the popup is visible. Default is false (make it appears using show()).\n * \n * @example const popup = new InputPopup(\"popup1\", \"Choose the number\", selectedNumber, true).show().on(\"confirm\", (value) => { console.log(value) }) // show the popup and wait for the user to confirm\n */\nexport class InputPopup extends EventEmitter {\n    CM: ConsoleManager\n    id: string\n    title: string\n    value: string | number\n    numeric: boolean\n    visible: boolean\n    marginTop: number\n\n    public constructor(id: string, title: string, value: string | number, numeric: boolean, visible = false) {\n        super()\n        /** @const {ConsoleManager} CM the instance of ConsoleManager (singleton) */\n        this.CM = new ConsoleManager()\n        this.id = id\n        this.title = title\n        this.value = value\n        this.numeric = numeric\n        this.visible = visible\n        this.marginTop = 4\n        if (this.CM.widgetsCollection[this.id]) {\n            this.CM.unRegisterWidget(this)\n            const message = `InputPopup ${this.id} already exists.`\n            this.CM.error(message)\n            throw new Error(message)\n        }\n        this.CM.registerWiget(this)\n    }\n\n    /**\n     * @description This function is used to make the ConsoleManager handle the key events when the input is numeric and it is showed.\n     * Inside this function are defined all the keys that can be pressed and the actions to do when they are pressed.\n     * @param {string} _str - The string of the input.\n     * @param {Object} key - The key object.\n     * @memberof InputPopup\n     */\n    public keyListnerNumeric(_str: string, key: KeyListenerArgs): void {\n        let v = Number(this.value)\n        if (Number.isNaN(v)) {\n            v = 0\n        }\n        if (!Number.isNaN(Number(key.name))) {\n            if (v.toString().length < 20) {\n                let tmp = this.value.toString()\n                tmp += key.name\n                this.value = Number(tmp)\n            }\n            // To change the sign I check for the keys \"+\" and \"-\"\n        } else if (key.sequence === \"-\") {\n            this.value = v * -1\n        } else if (key.sequence === \"+\") {\n            this.value = Math.abs(v)\n        } else if (key.sequence === \".\" || key.sequence === \",\") {\n            if (this.value.toString().indexOf(\".\") === -1) {\n                this.value = v + \".\"\n            }\n        } else {\n            switch (key.name) {\n            case \"backspace\":\n                // If backspace is pressed I remove the last character from the typed value\n                if (this.value.toString().length > 0) {\n                    if (this.value.toString().indexOf(\".\") === this.value.toString().length - 1) {\n                        this.value = v.toString()\n                    } else if (this.value.toString().indexOf(\".\") === this.value.toString().length - 2) {\n                        this.value = this.value.toString().slice(0, this.value.toString().length - 1)\n                    } else {\n                        this.value = Number(v.toString().slice(0, v.toString().length - 1))\n                    }\n                }\n                break\n            case \"return\":\n                {\n                    this.emit(\"confirm\", Number(this.value))\n                    this.CM.unRegisterWidget(this)\n                    this.hide()\n                    //delete this\n                }\n                break\n            case \"escape\":\n                {\n                    this.emit(\"cancel\")\n                    this.CM.unRegisterWidget(this)\n                    this.hide()\n                    //delete this\n                }\n                break\n            case \"q\":\n                {\n                    this.CM.emit(\"exit\")\n                    this.CM.unRegisterWidget(this)\n                    this.hide()\n                    //delete this\n                }\n                break\n            default:\n                break\n            }\n        }\n        this.CM.refresh()\n    }\n\n    /**\n     * @description This function is used to make the ConsoleManager handle the key events when the input is text and it is showed.\n     * Inside this function are defined all the keys that can be pressed and the actions to do when they are pressed.\n     * @param {string} _str - The string of the input.\n     * @param {Object} key - The key object.\n     * @memberof InputPopup\n     */\n    public keyListnerText(_str: string, key: KeyListenerArgs): void {\n        const v = this.value\n        if (v.toString().length < 20) {\n            let tmp = v.toString()\n            tmp += key.name\n            this.value = tmp\n        }\n        switch (key.name) {\n        case \"backspace\":\n            // If backspace is pressed I remove the last character from the typed value\n            if (v.toString().length > 0) {\n                this.value = v.toString().slice(0, v.toString().length - 1)\n            }\n            break\n        case \"return\":\n            {\n                this.emit(\"confirm\", this.value)\n                this.CM.unRegisterWidget(this)\n                this.hide()\n                //delete this\n            }\n            break\n        case \"escape\":\n            {\n                this.emit(\"cancel\")\n                this.CM.unRegisterWidget(this)\n                this.hide()\n                //delete this\n            }\n            break\n        case \"q\":\n            {\n                this.CM.emit(\"exit\")\n                this.CM.unRegisterWidget(this)\n                this.hide()\n                //delete this\n            }\n            break\n        default:\n            break\n        }\n        this.CM.refresh()\n    }\n\n    /**\n     * @description This function is used to get the value of the input.\n     * @returns {string | number} The value of the input.\n     * @memberof InputPopup\n     */\n    public getValue(): string | number {\n        return this.value\n    }\n\n    /**\n     * @description This function is used to change the value of the input. It also refresh the ConsoleManager.\n     * @param {string | number} newValue - The new value of the input.\n     * @memberof InputPopup\n     * @returns {InputPopup} The instance of the InputPopup.\n     */\n    public setValue(newValue: string | number): this {\n        this.value = newValue\n        this.CM.refresh()\n        return this\n    }\n\n    /**\n     * @description This function is used to show the popup. It also register the key events and refresh the ConsoleManager.\n     * @returns {InputPopup} The instance of the InputPopup.\n     * @memberof InputPopup\n     */\n    public show(): InputPopup {\n        if (!this.visible) {\n            this.manageInput()\n            this.visible = true\n            this.CM.refresh()\n        }\n        return this\n    }\n\n    /**\n     * @description This function is used to hide the popup. It also unregister the key events and refresh the ConsoleManager.\n     * @returns {InputPopup} The instance of the InputPopup.\n     * @memberof InputPopup\n     */\n    public hide(): InputPopup {\n        if (this.visible) {\n            this.unManageInput()\n            this.visible = false\n            this.CM.refresh()\n        }\n        return this\n    }\n\n    /**\n     * @description This function is used to get the visibility of the popup.\n     * @returns {boolean} The visibility of the popup.\n     * @memberof InputPopup\n     */\n    public isVisible(): boolean {\n        return this.visible\n    }\n\n    /**\n     * @description This function is used to add the InputPopup key listener callback to te ConsoleManager.\n     * @returns {InputPopup} The instance of the InputPopup.\n     * @memberof InputPopup\n     */\n    private manageInput(): InputPopup {\n        // Add a command input listener to change mode\n        if (this.numeric) {\n            this.CM.setKeyListener(this.id, this.keyListnerNumeric.bind(this))\n        } else {\n            this.CM.setKeyListener(this.id, this.keyListnerText.bind(this))\n        }\n        return this\n    }\n\n    /**\n     * @description This function is used to remove the InputPopup key listener callback to te ConsoleManager.\n     * @returns {InputPopup} The instance of the InputPopup.\n     * @memberof InputPopup\n     */\n    private unManageInput(): InputPopup {\n        // Add a command input listener to change mode\n        if (this.numeric) {\n            this.CM.removeKeyListener(this.id/*, this.keyListnerNumeric.bind(this)*/)\n        } else {\n            this.CM.removeKeyListener(this.id/*, this.keyListnerText.bind(this)*/)\n        }\n        return this\n    }\n\n    /**\n     * @description This function is used to draw the InputPopup to the screen in the middle.\n     * @returns {InputPopup} The instance of the InputPopup.\n     * @memberof InputPopup\n     */\n    public draw(): InputPopup {\n        const offset = 2\n        const windowWidth = this.title.length > this.value.toString().length ? this.title.length + (2 * offset) : this.value.toString().length + (2 * offset) + 1\n        const halfWidth = Math.round((windowWidth - this.title.length) / 2)\n        let header = \"┌\"\n        for (let i = 0; i < windowWidth; i++) {\n            header += \"─\"\n        }\n        header += \"┐\\n\"\n        header += `│${\" \".repeat(halfWidth)}${this.title}${\" \".repeat(windowWidth - halfWidth - this.title.length)}│\\n`\n        header += \"├\" + \"─\".repeat(windowWidth) + \"┤\\n\"\n\n        let footer = \"└\"\n        for (let i = 0; i < windowWidth; i++) {\n            footer += \"─\"\n        }\n        footer += \"┘\\n\"\n\n        let content = \"\"\n        // Draw an input field\n        content += `│${\"> \"}${this.value}█${\" \".repeat(windowWidth - this.value.toString().length - 3)}│\\n`\n\n        const windowDesign = `${header}${content}${footer}`\n        windowDesign.split(\"\\n\").forEach((line, index) => {\n            this.CM.Screen.cursorTo(Math.round((this.CM.Screen.width / 2) - (windowWidth / 2)), this.marginTop + index)\n            this.CM.Screen.write({ text: line, style: { color: \"white\" } })\n        })\n        return this\n    }\n}\n\nexport default InputPopup"]} |
@@ -93,1 +93,2 @@ /// <reference types="node" /> | ||
export default OptionPopup; | ||
//# sourceMappingURL=OptionPopup.d.ts.map |
@@ -23,10 +23,2 @@ import { EventEmitter } from "events"; | ||
export class OptionPopup extends EventEmitter { | ||
CM; | ||
id; | ||
title; | ||
options; | ||
selected; | ||
visible; | ||
marginTop; | ||
startIndex; | ||
constructor(id, title, options, selected, visible = false) { | ||
@@ -249,2 +241,2 @@ super(); | ||
export default OptionPopup; | ||
//# sourceMappingURL=OptionPopup.js.map | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"OptionPopup.js","sourceRoot":"","sources":["../../../src/components/widgets/OptionPopup.ts"],"names":[],"mappings":"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","sourcesContent":["import { EventEmitter } from \"events\"\nimport { ConsoleManager, KeyListenerArgs } from \"../../ConsoleGui.js\"\n\n/**\n * @class OptionPopup\n * @extends EventEmitter\n * @description This class is used to create a popup with a list of selectable options. \n * \n * ![OptionPopup](https://user-images.githubusercontent.com/14907987/165752387-2eac4936-1b5d-462e-9353-562d04f1b4fe.gif)\n * \n * Emits the following events: \n * - \"confirm\" when the user confirm the option\n * - \"cancel\" when the user cancel the option\n * - \"exit\" when the user exit the option\n * @param {string} id - The id of the popup.\n * @param {string} title - The title of the popup.\n * @param {Array<string | number>} options - The options of the popup.\n * @param {string | number} selected - The selected option.\n * @param {boolean} visible - If the popup is visible. Default is false (make it appears using show()).\n * \n * @example const popup = new OptionPopup(\"popup1\", \"Choose the option\", options, selectedOption).show().on(\"confirm\", (option) => { console.log(option) }) // show the popup and wait for the user to confirm\n */\nexport class OptionPopup extends EventEmitter {\n    CM: ConsoleManager\n    id: string\n    title: string\n    options: Array<string | number>\n    selected: string | number\n    visible: boolean\n    marginTop: number\n    startIndex: number\n\n    public constructor(id: string, title: string, options: Array<string | number>, selected: string | number, visible = false) {\n        super()\n        /** @const {ConsoleManager} CM the instance of ConsoleManager (singleton) */\n        this.CM = new ConsoleManager()\n        this.id = id\n        this.title = title\n        this.options = options\n        this.selected = selected\n        this.visible = visible\n        this.marginTop = 4\n        this.startIndex = 0\n        if (this.CM.widgetsCollection[this.id]) {\n            this.CM.unRegisterWidget(this)\n            const message = `OptionPopup ${this.id} already exists.`\n            this.CM.error(message)\n            throw new Error(message)\n        }\n        this.CM.registerWiget(this)\n    }\n\n    private adaptOptions(): Array<string | number> {\n        return this.options.slice(this.startIndex, this.startIndex + this.CM.Screen.height - this.marginTop - 6)\n    }\n\n    /**\n     * @description This function is used to make the ConsoleManager handle the key events when the popup is showed.\n     * Inside this function are defined all the keys that can be pressed and the actions to do when they are pressed.\n     * @param {string} str - The string of the input.\n     * @param {Object} key - The key object.\n     * @memberof OptionPopup\n     */\n    keyListner(_str: string, key: KeyListenerArgs) {\n        switch (key.name) {\n        case \"down\":\n            this.setSelected(this.options[(this.options.indexOf(this.selected) + 1) % this.options.length])\n            if (this.CM.Screen.height - this.marginTop - 4 < this.options.length) {\n                if (this.selected === this.options[this.adaptOptions().length + this.startIndex]) {\n                    this.startIndex++\n                }\n            } else {\n                this.startIndex = 0\n            }\n            break\n        case \"up\":\n            this.setSelected(this.options[(this.options.indexOf(this.selected) - 1 + this.options.length) % this.options.length])\n            if (this.startIndex > 0 && this.selected === this.adaptOptions()[0]) {\n                this.startIndex--\n            }\n            break\n        case \"pagedown\":\n            if (this.CM.Screen.height - this.marginTop - 4 < this.options.length) {\n                this.setSelected(this.options[(this.options.indexOf(this.selected) + this.adaptOptions().length) % this.options.length])\n                if (this.startIndex + this.adaptOptions().length < this.options.length) {\n                    this.startIndex += this.adaptOptions().length\n                } else {\n                    this.startIndex = 0\n                }\n            } else {\n                return\n            }\n            break\n        case \"pageup\":\n            if (this.CM.Screen.height - this.marginTop - 4 < this.options.length) {\n                this.setSelected(this.options[(this.options.indexOf(this.selected) - this.adaptOptions().length + this.options.length) % this.options.length])\n                if (this.startIndex > this.adaptOptions().length) {\n                    this.startIndex -= this.adaptOptions().length\n                } else {\n                    this.startIndex = 0\n                }\n            } else {\n                return\n            }\n            break\n        case \"return\":\n            {\n                this.emit(\"confirm\", this.selected)\n                this.CM.unRegisterWidget(this)\n                this.hide()\n                //delete this\n            }\n            break\n        case \"escape\":\n            {\n                this.emit(\"cancel\")\n                this.CM.unRegisterWidget(this)\n                this.hide()\n                //delete this\n            }\n            break\n        case \"q\":\n            {\n                this.CM.emit(\"exit\")\n                this.CM.unRegisterWidget(this)\n                this.hide()\n                //delete this\n            }\n            break\n        default:\n            break\n        }\n        this.CM.refresh()\n    }\n\n    /**\n     * @description This function is used to get the selected option.\n     * @returns {string | number} The selected value of the popup.\n     * @memberof OptionPopup\n     */\n    public getSelected(): string | number {\n        return this.selected\n    }\n\n    /**\n     * @description This function is used to change the selection of the popup. It also refresh the ConsoleManager.\n     * @param {string | number} selected - The new value of the selection.\n     * @memberof OptionPopup\n     * @returns {OptionPopup} The instance of the OptionPopup.\n     */\n    public setSelected(selected: string | number): OptionPopup {\n        this.selected = selected\n        this.CM.refresh()\n        return this\n    }\n\n    /**\n     * @description This function is used to show the popup. It also register the key events and refresh the ConsoleManager.\n     * @returns {OptionPopup} The instance of the OptionPopup.\n     * @memberof OptionPopup\n     */\n    public show(): OptionPopup {\n        if (!this.visible) {\n            this.manageInput()\n            this.visible = true\n            this.CM.refresh()\n        }\n        return this\n    }\n\n    /**\n     * @description This function is used to hide the popup. It also unregister the key events and refresh the ConsoleManager.\n     * @returns {OptionPopup} The instance of the OptionPopup.\n     * @memberof OptionPopup\n     */\n    public hide(): OptionPopup {\n        if (this.visible) {\n            this.unManageInput()\n            this.visible = false\n            this.CM.refresh()\n        }\n        return this\n    }\n\n    /**\n     * @description This function is used to get the visibility of the popup.\n     * @returns {boolean} The visibility of the popup.\n     * @memberof OptionPopup\n     */\n    public isVisible(): boolean {\n        return this.visible\n    }\n\n    /**\n     * @description This function is used to add the OptionPopup key listener callback to te ConsoleManager.\n     * @returns {OptionPopup} The instance of the OptionPopup.\n     * @memberof OptionPopup\n     */\n    private manageInput(): OptionPopup {\n        // Add a command input listener to change mode\n        this.CM.setKeyListener(this.id, this.keyListner.bind(this))\n        return this\n    }\n\n    /**\n     * @description This function is used to remove the OptionPopup key listener callback to te ConsoleManager.\n     * @returns {OptionPopup} The instance of the OptionPopup.\n     * @memberof OptionPopup\n     */\n    private unManageInput(): OptionPopup {\n        // Add a command input listener to change mode\n        this.CM.removeKeyListener(this.id)\n        return this\n    }\n\n    /**\n     * @description This function is used to draw the OptionPopup to the screen in the middle.\n     * @returns {OptionPopup} The instance of the OptionPopup.\n     * @memberof OptionPopup\n     */\n    public draw(): OptionPopup {\n        // Change start index if selected is not in the adaptOptions return array\n        if (this.adaptOptions().indexOf(this.selected) === -1) {\n            this.startIndex = this.options.indexOf(this.selected) - this.adaptOptions().length + 1 > 0 ? this.options.indexOf(this.selected) - this.adaptOptions().length + 1 : 0\n        }\n        const offset = 2\n        const maxOptionsLength = this.options.map((o) => o.toString()).reduce((max, option) => Math.max(max, option.length), 0)\n        const windowWidth = maxOptionsLength > this.title.length ? maxOptionsLength + (2 * offset) : this.title.length + (2 * offset)\n        const halfWidth = Math.round((windowWidth - this.title.length) / 2)\n\n        let header = \"┌\"\n        for (let i = 0; i < windowWidth; i++) {\n            header += \"─\"\n        }\n        header += \"┐\\n\"\n        header += `│${\" \".repeat(halfWidth)}${this.title}${\" \".repeat(windowWidth - halfWidth - this.title.length)}│\\n`\n        header += \"├\" + \"─\".repeat(windowWidth) + \"┤\\n\"\n\n        let footer = \"└\"\n        for (let i = 0; i < windowWidth; i++) {\n            footer += \"─\"\n        }\n        footer += \"┘\\n\"\n\n        let content = \"\"\n        this.adaptOptions().forEach((option) => {\n            content += `│${option === this.selected ? \"<\" : \" \"} ${option}${option === this.selected ? \" >\" : \"  \"}${\" \".repeat(windowWidth - option.toString().length - 4)}│\\n`\n        })\n\n        const windowDesign = `${header}${content}${footer}`\n        windowDesign.split(\"\\n\").forEach((line, index) => {\n            this.CM.Screen.cursorTo(Math.round((this.CM.Screen.width / 2) - (windowWidth / 2)), this.marginTop + index)\n            this.CM.Screen.write({ text: line, style: { color: \"white\" } })\n        })\n        return this\n    }\n}\n\nexport default OptionPopup"]} |
@@ -15,8 +15,8 @@ /// <reference types="node" /> | ||
* @typedef {Object} KeyListenerArgs | ||
* @property {string} name - The name of the key pressed. | ||
* @property {boolean} ctrl - If the ctrl key is pressed. | ||
* @property {boolean} shift - If the shift key is pressed. | ||
* @property {boolean} alt - If the alt key is pressed. | ||
* @property {boolean} meta - If the meta key is pressed. | ||
* @property {boolean} sequence - If the sequence of keys is pressed. | ||
* @prop {string} name - The name of the key pressed. | ||
* @prop {boolean} ctrl - If the ctrl key is pressed. | ||
* @prop {boolean} shift - If the shift key is pressed. | ||
* @prop {boolean} alt - If the alt key is pressed. | ||
* @prop {boolean} meta - If the meta key is pressed. | ||
* @prop {boolean} sequence - If the sequence of keys is pressed. | ||
* | ||
@@ -37,7 +37,7 @@ * @export | ||
* @typedef {Object} ConsoleGuiOptions | ||
* @property {string} [title] - The title of the ConsoleGui. | ||
* @property {0 | 1 | "popup"} [logLocation] - The location of the logs. | ||
* @property {string} [showLogKey] - The key to show the log. | ||
* @property {number} [logPageSize] - The size of the log page. | ||
* @property {DoubleLayoutOptions} [layoutOptions] - The options of the layout. | ||
* @prop {string} [title] - The title of the ConsoleGui. | ||
* @prop {0 | 1 | "popup"} [logLocation] - The location of the logs. | ||
* @prop {string} [showLogKey] - The key to show the log. | ||
* @prop {number} [logPageSize] - The size of the log page. | ||
* @prop {DoubleLayoutOptions} [layoutOptions] - The options of the layout. | ||
* | ||
@@ -207,1 +207,2 @@ * @export | ||
export { PageBuilder, ConsoleManager, OptionPopup, InputPopup, ConfirmPopup, ButtonPopup, CustomPopup, FileSelectorPopup }; | ||
//# sourceMappingURL=ConsoleGui.d.ts.map |
@@ -24,22 +24,7 @@ import { EventEmitter } from "events"; | ||
class ConsoleManager extends EventEmitter { | ||
Terminal; | ||
Input; | ||
static instance; | ||
Screen; | ||
// eslint-disable-next-line @typescript-eslint/no-explicit-any | ||
widgetsCollection = []; | ||
eventListenersContainer = {}; | ||
logLocation; | ||
logPageSize; | ||
logPageTitle; | ||
pages; | ||
layoutOptions; | ||
changeLayoutKey; | ||
changeLayoutkeys; | ||
applicationTitle; | ||
showLogKey; | ||
stdOut; | ||
layout; | ||
constructor(options = undefined) { | ||
super(); | ||
// eslint-disable-next-line @typescript-eslint/no-explicit-any | ||
this.widgetsCollection = []; | ||
this.eventListenersContainer = {}; | ||
this.Terminal = process.stdout; | ||
@@ -68,3 +53,3 @@ this.Input = process.stdin; | ||
changeFocusKey: "ctrl+l", | ||
direction: "horizontal", | ||
direction: "vertical", | ||
}; | ||
@@ -438,2 +423,2 @@ /** @const {string} changeLayoutKey - The key or combination to switch the selected page */ | ||
export { PageBuilder, ConsoleManager, OptionPopup, InputPopup, ConfirmPopup, ButtonPopup, CustomPopup, FileSelectorPopup }; | ||
//# sourceMappingURL=ConsoleGui.js.map | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ConsoleGui.js","sourceRoot":"","sources":["../src/ConsoleGui.ts"],"names":[],"mappings":"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","sourcesContent":["import { EventEmitter } from \"events\"\nimport readline from \"readline\"\nimport DoubleLayout, { DoubleLayoutOptions } from \"./components/layout/DoubleLayout.js\"\nimport PageBuilder from \"./components/PageBuilder.js\"\nimport Screen from \"./components/Screen.js\"\nimport CustomPopup from \"./components/widgets/CustomPopup.js\"\nimport ButtonPopup from \"./components/widgets/ButtonPopup.js\"\nimport ConfirmPopup from \"./components/widgets/ConfirmPopup.js\"\nimport FileSelectorPopup from \"./components/widgets/FileSelectorPopup.js\"\nimport InputPopup from \"./components/widgets/InputPopup.js\"\nimport OptionPopup from \"./components/widgets/OptionPopup.js\"\n\n\n/**\n * @description This type is used to define the parameters of the KeyListener event (keypress).\n * @typedef {Object} KeyListenerArgs\n * @prop {string} name - The name of the key pressed.\n * @prop {boolean} ctrl - If the ctrl key is pressed.\n * @prop {boolean} shift - If the shift key is pressed.\n * @prop {boolean} alt - If the alt key is pressed.\n * @prop {boolean} meta - If the meta key is pressed.\n * @prop {boolean} sequence - If the sequence of keys is pressed.\n *\n * @export\n * @interface KeyListenerArgs\n */\nexport interface KeyListenerArgs {\n    name: string;\n    sequence: string;\n    ctrl: boolean;\n    alt: boolean;\n    shift: boolean;\n    meta: boolean;\n}\n\n/**\n * @description This type is used to define the ConsoleGui options.\n * @typedef {Object} ConsoleGuiOptions\n * @prop {string} [title] - The title of the ConsoleGui.\n * @prop {0 | 1 | \"popup\"} [logLocation] - The location of the logs.\n * @prop {string} [showLogKey] - The key to show the log.\n * @prop {number} [logPageSize] - The size of the log page.\n * @prop {DoubleLayoutOptions} [layoutOptions] - The options of the layout.\n *\n * @export\n * @interface ConsoleGuiOptions\n */\nexport interface ConsoleGuiOptions {\n    logLocation?: 0 | 1 | \"popup\";\n    showLogKey?: string;\n    logPageSize?: number;\n    layoutOptions?: DoubleLayoutOptions;\n    title?: string;\n}\n\n/**\n * @class ConsoleManager\n * @extends EventEmitter\n * @description This class is used to manage the console GUI and all the widgets.\n * This is a singleton class, so you can use it like this: const CM = new ConsoleManager()\n * Emits the following events: \n * - \"keypressed\" to propagate the key pressed event to the application\n * - \"exit\" when the user wants to exit the application\n * @param {object} options - The options of the ConsoleManager.\n * @example const CM = new ConsoleManager({ logPageSize: 10, layoutBorder: true, changeLayoutKey: 'ctrl+l', title: 'Console Application' })\n */\nclass ConsoleManager extends EventEmitter {\n    Terminal: NodeJS.WriteStream & { fd: 1 }\n    Input: NodeJS.ReadStream & { fd: 0 }\n    static instance: ConsoleManager\n    Screen!: Screen\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    widgetsCollection: any[] = []\n    eventListenersContainer: { [key: string]: (_str: string, key : KeyListenerArgs) => void } = {}\n    logLocation!: 0 | 1 | \"popup\"\n    logPageSize!: number\n    logPageTitle!: string\n    pages!: PageBuilder[]\n    layoutOptions!: DoubleLayoutOptions\n    changeLayoutKey!: string\n    changeLayoutkeys!: string[]\n    applicationTitle!: string\n    showLogKey!: string\n    stdOut!: PageBuilder\n    layout!: DoubleLayout\n\n    public constructor(options: ConsoleGuiOptions | undefined = undefined) {\n        super()\n        this.Terminal = process.stdout\n        this.Input = process.stdin\n        if (!ConsoleManager.instance) {\n            ConsoleManager.instance = this\n\n            /** @const {Screen} Screen - The screen instance */\n            this.Screen = new Screen(this.Terminal)\n            this.Screen.on(\"error\", (err) => {\n                this.error(err)\n            })\n\n            this.widgetsCollection = []\n            this.eventListenersContainer = {}\n\n            /** @const {number | 'popup'} logLocation - Choose where the logs are displayed: number (0,1) - to pot them on one of the two layouts, string (\"popup\") - to put them on a CustomPopup that can be displayed on the window. */\n            this.logLocation = 1\n            this.logPageSize = 10\n            this.logPageTitle = \"LOGS\"\n\n            /** @const {Array<PageBuilder>} homePage - The main application */\n            this.pages = [new PageBuilder(), new PageBuilder()]\n\n            this.layoutOptions = {\n                showTitle: true,\n                boxed: true,\n                boxColor: \"cyan\",\n                boxStyle: \"bold\",\n                changeFocusKey: \"ctrl+l\",\n                direction: \"vertical\",\n            }\n\n            /** @const {string} changeLayoutKey - The key or combination to switch the selected page */\n            this.changeLayoutKey = this.layoutOptions.changeFocusKey\n            this.changeLayoutkeys = this.changeLayoutKey.split(\"+\")\n            this.applicationTitle = \"\"\n\n            if (options) {\n                if (options.logLocation !== undefined) {\n                    if (typeof options.logLocation === \"number\") {\n                        this.logLocation = options.logLocation > 0 ? options.logLocation : 0\n                    } else {\n                        if (options.logLocation === \"popup\") {\n                            this.logLocation = \"popup\"\n                            this.showLogKey = options.showLogKey || \"o\"\n                        } else {\n                            this.logLocation = 1\n                        }\n                    }\n                }\n                if (options.logPageSize) {\n                    this.logPageSize = options.logPageSize\n                }\n                if (typeof options.layoutOptions !== \"undefined\") {\n                    this.layoutOptions = options.layoutOptions\n                    if (options.layoutOptions.changeFocusKey) {\n                        this.changeLayoutKey = options.layoutOptions.changeFocusKey\n                    }\n                }\n                if (options.title) {\n                    this.applicationTitle = options.title\n                }\n            }\n\n            /** @const {PageBuilder} stdOut - The logs page */\n            this.stdOut = new PageBuilder()\n            this.stdOut.setRowsPerPage(this.logPageSize)\n\n            /** @const {DoubleLayout} layout - The layout instance */\n            if (this.logLocation === \"popup\") {\n                this.layout = new DoubleLayout(this.pages[0], this.pages[1], this.layoutOptions)\n            } else if (typeof this.logLocation === \"number\") {\n                if (this.logLocation === 0) {\n                    this.layout = new DoubleLayout(this.stdOut, this.pages[0], this.layoutOptions)\n                    this.layout.page1Title = this.logPageTitle\n                    this.layout.page2Title = this.applicationTitle\n                } else {\n                    this.layout = new DoubleLayout(this.pages[0], this.stdOut, this.layoutOptions)\n                    this.layout.page1Title = this.applicationTitle\n                    this.layout.page2Title = this.logPageTitle\n                }\n            } else {\n                this.layout = new DoubleLayout(this.pages[0], this.stdOut, this.layoutOptions)\n                this.layout.page1Title = this.applicationTitle\n                this.layout.page2Title = this.logPageTitle\n            }\n            this.addGenericListeners()\n\n            // I use readline to manage the keypress event\n            readline.emitKeypressEvents(this.Input)\n            this.Input.setRawMode(true) // With this I only get the key value\n        }\n        return ConsoleManager.instance\n    }\n\n    public getLogPageSize(): number {\n        return this.logPageSize\n    }\n\n    public setLogPageSize(rows: number): void {\n        this.logPageSize = rows\n    }\n\n    /**\n     * @description This function is used to make the ConsoleManager handle the key events when no widgets are showed.\n     * Inside this function are defined all the keys that can be pressed and the actions to do when they are pressed.\n     * @memberof ConsoleManager\n     */\n    private addGenericListeners(): void {\n        this.Input.addListener(\"keypress\", (_str: string, key : KeyListenerArgs): void => {\n            let change = false\n            if (this.changeLayoutkeys.length > 1) {\n                if (this.changeLayoutkeys[0] == \"ctrl\") {\n                    if (key.ctrl && key.name === this.changeLayoutkeys[1])\n                        change = true\n                }\n                if (this.changeLayoutkeys[0] == \"meta\") {\n                    if (key.alt && key.name === this.changeLayoutkeys[1])\n                        change = true\n                }\n                if (this.changeLayoutkeys[0] == \"shift\") {\n                    if (key.shift && key.name === this.changeLayoutkeys[1])\n                        change = true\n                }\n            } else {\n                if (key.name === this.changeLayoutkeys[0])\n                    change = true\n            }\n\n            if (this.showLogKey && key.name === this.showLogKey) {\n                this.showLogPopup()\n            }\n\n            if (change) {\n                this.layout.changeLayout()\n                this.refresh()\n                return\n            }\n\n            if (key.ctrl && key.name === \"c\") {\n                this.emit(\"exit\")\n            } else {\n                if (Object.keys(this.widgetsCollection).length === 0) {\n                    if (key.name === \"down\") {\n                        if (this.layout.getSelected() === 0) {\n                            this.layout.page1.decreaseScrollIndex()\n                        } else {\n                            this.layout.page2.decreaseScrollIndex()\n                        }\n                        this.refresh()\n                        return\n                    } else if (key.name === \"up\") {\n                        if (this.layout.getSelected() === 0) {\n                            this.layout.page1.increaseScrollIndex()\n                        } else {\n                            this.layout.page2.increaseScrollIndex()\n                        }\n                        this.refresh()\n                        return\n                    }\n                    this.emit(\"keypressed\", key)\n                }\n            }\n        })\n    }\n\n    /**\n     * @description This function is used to set a key listener for a specific widget. The event listener is stored in the eventListenersContainer object.\n     * @param {string} id - The id of the widget.\n     * @param {function} manageFunction - The function to call when the key is pressed.\n     * @memberof ConsoleManager\n     * @example CM.setKeyListener('inputPopup', popup.keyListener)\n     */\n    public setKeyListener(id: string, manageFunction: (_str: string, key : KeyListenerArgs) => void): void {\n        this.eventListenersContainer[id] = manageFunction\n        this.Input.addListener(\"keypress\", this.eventListenersContainer[id])\n    }\n\n    /**\n     * @description This function is used to remove a key listener for a specific widget. The event listener is removed from the eventListenersContainer object.\n     * @param {string} id - The id of the widget.\n     * @memberof ConsoleManager\n     * @example CM.removeKeyListener('inputPopup')\n     */\n    public removeKeyListener(id: string): void {\n        this.Input.removeListener(\"keypress\", this.eventListenersContainer[id])\n        delete this.eventListenersContainer[id]\n    }\n\n    /**\n     * @description This function is used to register a widget. The widget is stored in the widgetsCollection object. That is called by the widgets in show().\n     * @param {Widget} widget - The widget to register.\n     * @memberof ConsoleManager\n     */\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    public registerWiget(widget: any): void {\n        this.widgetsCollection[widget.id] = widget\n    }\n\n    /**\n     * @description This function is used to unregister a widget. The widget is removed from the widgetsCollection object. That is called by the widgets in hide().\n     * @param {string} id - The id of the widget.\n     * @memberof ConsoleManager\n     */\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    public unRegisterWidget(widget: any): void {\n        if (this.widgetsCollection[widget.id]) {\n            delete this.widgetsCollection[widget.id]\n        }\n    }\n\n    /**\n     * @description This function is used to set the home page. It also refresh the screen.\n     * @param {PageBuilder} page - The page to set as home page.\n     * @memberof ConsoleManager\n     * @example CM.setHomePage(p)\n     * @deprecated since version 1.1.12 - Use setPage or setPages instead\n     */\n    public setHomePage(page: PageBuilder): void {\n        this.pages[0] = page\n        if (this.logLocation === \"popup\") {\n            this.layout.setPage1(page)\n        } else if (typeof this.logLocation === \"number\") {\n            if (this.logLocation === 0) {\n                this.layout.setPage2(page)\n            } else {\n                this.layout.setPage1(page)\n            }\n        } else {\n            this.layout.setPage1(page)\n        }\n        this.refresh()\n    }\n\n    /**\n     * @description This function is used to set a page of layout. It also refresh the screen.\n     * @param {PageBuilder} page - The page to set as home page.\n     * @param {number} [pageNumber] - The page number to set. 0 is the first page, 1 is the second page.\n     * @param {string} [title] - The title of the page to overwrite the default title. Default is null.\n     * @memberof ConsoleManager\n     * @example CM.setPage(p, 0)\n     */\n    public setPage(page: PageBuilder, pageNumber = 0, title: string | null = null): void {\n        this.pages[pageNumber] = page\n        if (this.logLocation === \"popup\") {\n            if (pageNumber === 0) {\n                this.layout.setPage1(this.pages[pageNumber])\n                if (title) this.layout.page1Title = title\n            } else {\n                this.layout.setPage2(this.pages[pageNumber])\n                if (title) this.layout.page2Title = title\n            }\n        } else if (typeof this.logLocation === \"number\") {\n            if (this.logLocation === 0) {\n                this.layout.setPage2(this.pages[pageNumber])\n                if (title) this.layout.page2Title = title\n            } else {\n                this.layout.setPage1(this.pages[pageNumber])\n                if (title) this.layout.page1Title = title\n            }\n        } else {\n            if (pageNumber === 0) {\n                this.layout.setPage1(this.pages[pageNumber])\n                if (title) this.layout.page1Title = title\n            } else {\n                this.layout.setPage2(this.pages[pageNumber])\n                if (title) this.layout.page2Title = title\n            }\n        }\n        this.refresh()\n    }\n\n    /**\n     * @description This function is used to set both pages of layout. It also refresh the screen.\n     * @param {Array<PageBuilder>} pages - The page to set as home page.\n     * @memberof ConsoleManager\n     * @example CM.setPages([p1, p2], 0)\n     */\n    public setPages(pages: Array<PageBuilder>): void {\n        this.pages = pages\n        if (this.logLocation === \"popup\") {\n            this.layout.setPage1(this.pages[0])\n            this.layout.setPage2(this.pages[1])\n        } else if (typeof this.logLocation === \"number\") {\n            if (this.logLocation === 0) {\n                this.layout.setPage2(this.pages[0])\n            } else {\n                this.layout.setPage1(this.pages[0])\n            }\n        } else {\n            this.layout.setPage1(this.pages[0])\n            this.layout.setPage2(this.pages[1])\n        }\n        this.refresh()\n    }\n\n    /**\n     * @description This function is used to refresh the screen. It do the following sequence: Clear the screen, draw layout, draw widgets and finally print the screen to the stdOut.\n     * @memberof ConsoleManager\n     * @example CM.refresh()\n     */\n    public refresh(): void {\n        this.Screen.update()\n        this.layout.draw()\n        for (const widget in this.widgetsCollection) {\n            if (this.widgetsCollection[widget].isVisible())\n                this.widgetsCollection[widget].draw()\n        }\n        this.Screen.print()\n    }\n\n    /**\n     * @description This function is used to show a popup containing all the stdOut of the console.\n     * @memberof ConsoleManager\n     * @returns the instance of the generated popup.\n     * @example CM.showLogPopup()\n     */\n    public showLogPopup(): CustomPopup {\n        return new CustomPopup(\"logPopup\", \"Application Logs\", this.stdOut, this.Screen.width - 12).show()\n    }\n\n    /**\n     * @description This function is used to log a message. It is used to log messages in the log page. Don't add colors to the message.\n     * @param {string} message - The message to log.\n     * @memberof ConsoleManager\n     * @example CM.log(\"Hello world\")\n     */\n    public log(message: string): void {\n        this.stdOut.addRow({ text: message, color: \"white\" })\n        this.updateLogsConsole(true)\n    }\n\n    /** \n     * @description This function is used to log an error message. It is used to log red messages in the log page. Don't add colors to the message.\n     * @param {string} message - The message to log.\n     * @memberof ConsoleManager\n     * @example CM.error(\"Anomaly detected\")\n     */\n    public error(message: string): void {\n        this.stdOut.addRow({ text: message, color: \"red\" })\n        this.updateLogsConsole(true)\n    }\n\n    /**\n     * @description This function is used to log a warning message. It is used to log yellow messages in the log page. Don't add colors to the message.\n     * @param {string} message - The message to log.\n     * @memberof ConsoleManager\n     * @example CM.warn(\"Anomaly detected\")\n     */\n    public warn(message: string): void {\n        this.stdOut.addRow({ text: message, color: \"yellow\" })\n        this.updateLogsConsole(true)\n    }\n\n    /**\n     * @description This function is used to log an info message. It is used to log blue messages in the log page. Don't add colors to the message.\n     * @param {string} message - The message to log.\n     * @memberof ConsoleManager\n     * @example CM.info(\"Anomaly detected\")\n     */\n    public info(message: string): void {\n        this.stdOut.addRow({ text: message, color: \"blue\" })\n        this.updateLogsConsole(true)\n    }\n\n    /**\n     * @description This function is used to update the logs console. It is called by the log functions.\n     * @param {boolean} resetCursor - If true, the log scroll index is resetted.\n     * @memberof ConsoleManager\n     */\n    private updateLogsConsole(resetCursor: boolean): void {\n        if (resetCursor) {\n            this.stdOut.setScrollIndex(0)\n        }\n        this.refresh()\n    }\n\n    // TODO: move to utils\n    /**\n     * @description This function is used to truncate a string adding ... at the end.\n     * @param {string} str - The string to truncate.\n     * @param {number} n - The number of characters to keep.\n     * @param {boolean} useWordBoundary - If true, the truncation will be done at the end of the word.\n     * @memberof ConsoleManager\n     * @example CM.truncate(\"Hello world\", 5, true) // \"Hello...\"\n     */\n    public truncate(str: string, n: number, useWordBoundary: boolean): string {\n        if (str.length <= n) { return str }\n        const subString = str.substring(0, n - 1) // the original check\n        return (useWordBoundary ?\n            subString.substring(0, subString.lastIndexOf(\" \")) :\n            subString) + \"…\"\n    }\n}\n\nexport {\n    PageBuilder,\n    ConsoleManager,\n    OptionPopup,\n    InputPopup,\n    ConfirmPopup,\n    ButtonPopup,\n    CustomPopup,\n    FileSelectorPopup\n}"]} |
{ | ||
"name": "console-gui-tools", | ||
"version": "1.1.21", | ||
"version": "1.1.28", | ||
"description": "A simple library to draw option menu, text popup or other widgets and layout on a Node.js console.", | ||
@@ -9,9 +9,12 @@ "main": "dist/ConsoleGui.js", | ||
"type": "module", | ||
"files": [ | ||
"dist/" | ||
], | ||
"scripts": { | ||
"lint": "eslint ./src/ --ext .ts", | ||
"build": "tsc", | ||
"build": "npx tsc", | ||
"prepare": "npm run build", | ||
"test": "npm run build && node ./examples/tcp_simulator.mjs", | ||
"start": "npm run build && node ./dist/ConsoqleGui.js", | ||
"docsgen": "node ./docgen.cjs" | ||
"docs": "node ./docgen.cjs" | ||
}, | ||
@@ -44,2 +47,8 @@ "repository": { | ||
"devDependencies": { | ||
"@babel/cli": "^7.17.10", | ||
"@babel/core": "^7.18.0", | ||
"@babel/plugin-proposal-class-properties": "^7.17.12", | ||
"@babel/plugin-proposal-object-rest-spread": "^7.18.0", | ||
"@babel/preset-env": "^7.18.0", | ||
"@babel/preset-typescript": "^7.17.12", | ||
"@types/node": "^17.0.35", | ||
@@ -49,2 +58,3 @@ "@typescript-eslint/eslint-plugin": "^5.25.0", | ||
"eslint": "^8.15.0", | ||
"jsdoc-babel": "^0.5.0", | ||
"jsdoc-to-markdown": "^7.1.1", | ||
@@ -51,0 +61,0 @@ "typescript": "^4.6.4" |
@@ -0,0 +0,0 @@ # console-gui-tools |
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Major refactor
Supply chain riskPackage has recently undergone a major refactor. It may be unstable or indicate significant internal changes. Use caution when updating to versions that include significant changes.
Found 1 instance in 1 package
Network access
Supply chain riskThis module accesses the network.
Found 1 instance in 1 package
1
0
446036
13
33
3618