UNPKG

exceljs

Version:

Excel Workbook Manager - Read and Write xlsx and csv Files.

102 lines (87 loc) 2.16 kB
const TextXform = require('./text-xform'); const FontXform = require('../style/font-xform'); const BaseXform = require('../base-xform'); // <r> // <rPr> // <sz val="11"/> // <color theme="1" tint="5"/> // <rFont val="Calibri"/> // <family val="2"/> // <scheme val="minor"/> // </rPr> // <t xml:space="preserve"> is </t> // </r> class RichTextXform extends BaseXform { constructor(model) { super(); this.model = model; } get tag() { return 'r'; } get textXform() { return this._textXform || (this._textXform = new TextXform()); } get fontXform() { return this._fontXform || (this._fontXform = new FontXform(RichTextXform.FONT_OPTIONS)); } render(xmlStream, model) { model = model || this.model; xmlStream.openNode('r'); if (model.font) { this.fontXform.render(xmlStream, model.font); } this.textXform.render(xmlStream, model.text); xmlStream.closeNode(); } parseOpen(node) { if (this.parser) { this.parser.parseOpen(node); return true; } switch (node.name) { case 'r': this.model = {}; return true; case 't': this.parser = this.textXform; this.parser.parseOpen(node); return true; case 'rPr': this.parser = this.fontXform; this.parser.parseOpen(node); return true; default: return false; } } parseText(text) { if (this.parser) { this.parser.parseText(text); } } parseClose(name) { switch (name) { case 'r': return false; case 't': this.model.text = this.parser.model; this.parser = undefined; return true; case 'rPr': this.model.font = this.parser.model; this.parser = undefined; return true; default: if (this.parser) { this.parser.parseClose(name); } return true; } } } RichTextXform.FONT_OPTIONS = { tagName: 'rPr', fontNameTag: 'rFont', }; module.exports = RichTextXform;