| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241 | "use strict";function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }// Generated by CoffeeScript 2.5.1var AnsiPainter, Layout, RenderKid, Styles, blockStyleApplier, cloneAndMergeDeep, inlineStyleApplier, isPlainObject, stripAnsi, terminalWidth, tools;inlineStyleApplier = require('./renderKid/styleApplier/inline');blockStyleApplier = require('./renderKid/styleApplier/block');isPlainObject = require('lodash/isPlainObject');var _require = require('./tools');cloneAndMergeDeep = _require.cloneAndMergeDeep;AnsiPainter = require('./AnsiPainter');Styles = require('./renderKid/Styles');Layout = require('./Layout');tools = require('./tools');stripAnsi = require('strip-ansi');terminalWidth = require('./tools').getCols();module.exports = RenderKid = function () {  var self;  var RenderKid = /*#__PURE__*/function () {    function RenderKid() {      var config = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};      _classCallCheck(this, RenderKid);      this.tools = self.tools;      this._config = cloneAndMergeDeep(self._defaultConfig, config);      this._initStyles();    }    _createClass(RenderKid, [{      key: "_initStyles",      value: function _initStyles() {        return this._styles = new Styles();      }    }, {      key: "style",      value: function style() {        return this._styles.setRule.apply(this._styles, arguments);      }    }, {      key: "_getStyleFor",      value: function _getStyleFor(el) {        return this._styles.getStyleFor(el);      }    }, {      key: "render",      value: function render(input) {        var withColors = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;        return this._paint(this._renderDom(this._toDom(input)), withColors);      }    }, {      key: "_toDom",      value: function _toDom(input) {        if (typeof input === 'string') {          return this._parse(input);        } else if (isPlainObject(input) || Array.isArray(input)) {          return this._objToDom(input);        } else {          throw Error("Invalid input type. Only strings, arrays and objects are accepted");        }      }    }, {      key: "_objToDom",      value: function _objToDom(o) {        var injectFakeRoot = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;        if (injectFakeRoot) {          o = {            body: o          };        }        return tools.objectToDom(o);      }    }, {      key: "_paint",      value: function _paint(text, withColors) {        var painted;        painted = AnsiPainter.paint(text);        if (withColors) {          return painted;        } else {          return stripAnsi(painted);        }      }    }, {      key: "_parse",      value: function _parse(string) {        var injectFakeRoot = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;        if (injectFakeRoot) {          string = '<body>' + string + '</body>';        }        return tools.stringToDom(string);      }    }, {      key: "_renderDom",      value: function _renderDom(dom) {        var bodyTag, layout, rootBlock;        bodyTag = dom[0];        layout = new Layout(this._config.layout);        rootBlock = layout.getRootBlock();        this._renderBlockNode(bodyTag, null, rootBlock);        return layout.get();      }    }, {      key: "_renderChildrenOf",      value: function _renderChildrenOf(parentNode, parentBlock) {        var i, len, node, nodes;        nodes = parentNode.children;        for (i = 0, len = nodes.length; i < len; i++) {          node = nodes[i];          this._renderNode(node, parentNode, parentBlock);        }      }    }, {      key: "_renderNode",      value: function _renderNode(node, parentNode, parentBlock) {        if (node.type === 'text') {          this._renderText(node, parentNode, parentBlock);        } else if (node.name === 'br') {          this._renderBr(node, parentNode, parentBlock);        } else if (this._isBlock(node)) {          this._renderBlockNode(node, parentNode, parentBlock);        } else if (this._isNone(node)) {          return;        } else {          this._renderInlineNode(node, parentNode, parentBlock);        }      }    }, {      key: "_renderText",      value: function _renderText(node, parentNode, parentBlock) {        var ref, text;        text = node.data;        text = text.replace(/\s+/g, ' '); // let's only trim if the parent is an inline element        if ((parentNode != null ? (ref = parentNode.styles) != null ? ref.display : void 0 : void 0) !== 'inline') {          text = text.trim();        }        if (text.length === 0) {          return;        }        text = text.replace(/&nl;/g, "\n");        return parentBlock.write(text);      }    }, {      key: "_renderBlockNode",      value: function _renderBlockNode(node, parentNode, parentBlock) {        var after, before, block, blockConfig;        var _blockStyleApplier$ap = blockStyleApplier.applyTo(node, this._getStyleFor(node));        before = _blockStyleApplier$ap.before;        after = _blockStyleApplier$ap.after;        blockConfig = _blockStyleApplier$ap.blockConfig;        block = parentBlock.openBlock(blockConfig);        if (before !== '') {          block.write(before);        }        this._renderChildrenOf(node, block);        if (after !== '') {          block.write(after);        }        return block.close();      }    }, {      key: "_renderInlineNode",      value: function _renderInlineNode(node, parentNode, parentBlock) {        var after, before;        var _inlineStyleApplier$a = inlineStyleApplier.applyTo(node, this._getStyleFor(node));        before = _inlineStyleApplier$a.before;        after = _inlineStyleApplier$a.after;        if (before !== '') {          parentBlock.write(before);        }        this._renderChildrenOf(node, parentBlock);        if (after !== '') {          return parentBlock.write(after);        }      }    }, {      key: "_renderBr",      value: function _renderBr(node, parentNode, parentBlock) {        return parentBlock.write("\n");      }    }, {      key: "_isBlock",      value: function _isBlock(node) {        return !(node.type === 'text' || node.name === 'br' || this._getStyleFor(node).display !== 'block');      }    }, {      key: "_isNone",      value: function _isNone(node) {        return !(node.type === 'text' || node.name === 'br' || this._getStyleFor(node).display !== 'none');      }    }]);    return RenderKid;  }();  ;  self = RenderKid;  RenderKid.AnsiPainter = AnsiPainter;  RenderKid.Layout = Layout;  RenderKid.quote = tools.quote;  RenderKid.tools = tools;  RenderKid._defaultConfig = {    layout: {      terminalWidth: terminalWidth    }  };  return RenderKid;}.call(void 0);
 |