241 lines
		
	
	
		
			7.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			241 lines
		
	
	
		
			7.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| "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.1
 | |
| var 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); |