'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; 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); } /* 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; // Inject inlineTokenizer const {inlineTokenizers} = Parser.prototype; const {inlineMethods} = Parser.prototype; inlineTokenizers.input = inlineTokenizer; inlineMethods.splice(inlineMethods.indexOf('url'), 0, 'input'); const {Compiler} = this; // Stringify if (Compiler) { const {visitors} = Compiler.prototype; visitors.lineinput = function (node) { return `[__${this.all(node).join('')}__]`; }; } } module.exports = plugin;