@emmetio/field-parser

0.3.1 • Public • Published

Fields (tab-stops) parser

Parses snippet fields (aka tab-stops) like ${1:foo} in given string and produces a model that contains clean string without fields and list of fields locations.

Usage example

import parse from '@emmetio/field-parser';

const fieldModel = parse('foo $0 ${1:bar} ${2}${1}');

console.log(fieldModel.string);
// outputs "foo  bar "

// `.fields` is array of `{index, location, length}` fields
console.log(fieldModel.fields);
// outputs:
// {index: 0, location: 4, length: 0}
// {index: 1, location: 5, length: 3}
// {index: 2, location: 9, length: 0}
// {index: 1, location: 9, length: 0}

You can also mark string with fields:

import { mark } from '@emmetio/field-parser';

const marked = mark('foo bar', [
    {index: 1, location: 0, length: 3},
    {index: 5, location: 4, length: 3},
]);

console.log(marked); // ${1:foo} ${5:bar}

...or parse string and then use built-it mark method:

import parse from '@emmetio/field-parser';

const fieldModel = parse('foo $0 ${1:bar} ${2}${1}');
fieldModel.forEach(field => field.index += 100);

console.log(fieldModel.mark()); // foo $100 ${101:bar} ${102}${101}

Readme

Keywords

Package Sidebar

Install

npm i @emmetio/field-parser

Weekly Downloads

8,668

Version

0.3.1

License

MIT

Unpacked Size

40.4 kB

Total Files

12

Last publish

Collaborators

  • serge.che
  • emmetio-user