'use strict'; const parseAttr = require('md-attr-parser'); const START = '[__'; const END = '__]'; /* Function used to locate the start of a line input filed * Used by remark */ function locator(value, fromIndex) { const index = value.indexOf(START, fromIndex); return index; } /* Funtion which is exported */ function plugin() { /* Verifie if it's the syntax of a line input and return a line input node */ function inlineTokenizer(eat, value, silent) { if (!this.options.gfm || !value.startsWith(START)) { return; } let subvalue = ''; let index = START.length; const length = value.length; while (!value.startsWith(END, index) && index < length) { subvalue += value.charAt(index); if (value.charAt(index) === '\n') { return true; } index++; } let letsEat = ''; let prop = { /* key: undefined {} class: undefined [] id: undefined */}; /* Parse the attributes if any */ if (value.charAt(index + END.length) === '{') { const res = parseAttr(value, index + END.length); letsEat = res.eaten; prop = res.prop; } /* istanbul ignore if - never used (yet) */ if (silent) { return true; } /* Allow some other kind of input */ if (prop.type !== 'password') { prop.type = 'text'; } prop.placeholder = subvalue.replace(/^_*/g, '').replace(/_*$/g, '') || undefined; if (index < length) { return eat(START + subvalue + END + letsEat)({ type: 'line-input', children: [], data: { hName: 'input', hProperties: prop, }, }); } return true; } inlineTokenizer.locator = locator; const Parser = this.Parser; // Inject inlineTokenizer const inlineTokenizers = Parser.prototype.inlineTokenizers; const inlineMethods = Parser.prototype.inlineMethods; inlineTokenizers.input = inlineTokenizer; inlineMethods.splice(inlineMethods.indexOf('url'), 0, 'input'); const Compiler = this.Compiler; // Stringify if (Compiler) { const visitors = Compiler.prototype.visitors; visitors.lineinput = function (node) { return `[__${this.all(node).join('')}__]`; }; } } module.exports = plugin;