Giter Club home page Giter Club logo

scribesass-parser's Introduction

ScribeSass

Parse SCSS comments and return a JSON object.

Usage

Require scribesass-parser and provide it a path to a .scss file.

var scribeSass = require('scribesass-parser');

// Provide path to a file and receive an array of files containing `path` and `ast` properties.
scribeSass.create('main.scss', function(err, files) {
  // Get an object of group objects containing file objects.
  var groups = scribeSass.getGroups(files);

  // Loop through the files.
  for (var i = 0; i < files.length; i++) {
    // Path to the file.
    var path = files[i].path;

    // Get SCSS from an AST.
    var scss = scribeSass.getScss(files[i].ast);

    // Get object of file properties from AST.
    var fileProperties = scribeSass.getFileProperties(files[i].ast);

    // Get array of parsed comment objects and ASTs from AST.
    // ```js
    // comments = [{
    //   properties = {...},
    //   ast = {...},
    // }]
    // ```
    var comments = scribeSass.getComments(files[i].ast);
  }
});

scribesass-parser's People

Contributors

danoc avatar quarklemotion avatar

Stargazers

jennie § yip  avatar Sawyer Hollenshead avatar Dave Rau avatar

Watchers

Jessica Ross McKinnie avatar Pete Koomen avatar Vickrum Loi avatar Brian Taylor avatar Jennifer Adventure Lin avatar Rama Ranganath avatar Vladimir Mazheru avatar Jordan Garcia avatar Yeeland Chen avatar Jeremy Knight avatar Brian Petrowicz avatar Kyle Randolph avatar Matt Carroll avatar Nick DiRienzo avatar Zsolt Pocsaji avatar Daniel Gómez Didier avatar James Cloos avatar Dano Alexander avatar Christopher Banner avatar  avatar Natarajan Chakrapani avatar Sonesh Surana avatar Paul V Craven avatar Matt Auerbach avatar Adam Panzer avatar Joe avatar Trent Robbins avatar Jon Noronha avatar Byron Jones avatar Ejede avatar Jamie Connolly avatar Mirza Sohail Hussain avatar Ben Schaefer avatar Stathis Charitos avatar Serge Mengaptche avatar  avatar Akis avatar HASIBA CHOUDHURY avatar Adrian Gregory avatar Ian Fisher avatar Bryce avatar Lucas Swartsenburg avatar Waliur Rahman avatar Cyrus Dorosti avatar Becca Bruggman avatar Ben McKown avatar Rebecca R. Carter avatar Esha Verma avatar Ayesha Mazrana avatar Quinton Dang avatar Leo Pekelis avatar Kody avatar Darcey Lachtman avatar Pamela Ongchin avatar Ajith Mascarenhas avatar John Provine avatar Aniel Sud avatar Michael Faller avatar Whelan Boyd avatar  avatar Kunal Shetye avatar Neha Saigal avatar Jennifer J. Black avatar David Walsh avatar Po-Lin Yeh avatar Michael Sample avatar  avatar Karen Loughrey avatar Robin Jacobsson avatar Eduardo Rivera avatar Benjamin Mosier avatar Jimmy Jin avatar Ramyaa Krishnamani avatar Amy Chiu avatar Takeshi Young avatar Hoan Le avatar Naseef M Abdus Sattar avatar Bill Caplan avatar James Chen avatar  avatar Dave Primicias avatar Andreas Bloomquist avatar Juan Diego Arias avatar Shashank Paliwal avatar Johanna avatar Zach Power avatar Yelena Chamanova avatar  avatar Alda Luong avatar Ifi Akpandak avatar Aamir Farooq avatar Aamir Farooq avatar Allison Rodriguez avatar Will K avatar Yeesheen avatar Jeffrey Chan avatar  avatar Tung Nguyen avatar Vignesh Sukumar avatar  avatar

Forkers

isabella232

scribesass-parser's Issues

Parse code example annotations

The format is:

/// @example html - Image that has a standard border around it. 
/// <img src="http://fillmurray.com/100/100" class="img--border">

The JS should separate the language, description, and source.

Provide function to get an array of groups and the corresponding files.

Files can be grouped with the @group annotation, so it would be helpful to provide a function that returns an array groups and the corresponding file objects.

Proposal:

var scribeSass = require('scribesass-parser');

scribeSass.create('main.scss', function(files) {
  // Get an array of group objects containing files.
  var groups = scribeSass.getGroups(files);
});

groups would contain:

[
  {
    name: 'Objects',
    files: [
      {...},
      {...}
    ]
  }
]

File properties (name, for example) can be accessed by looping through the groups:

// Loop through the groups.
for (var i = 0; i < groups.length; i++) {
  var group = groups[i];

  for (var j = 0; j < group.files.length; j++) {
    var file = group.files[j];

    // Path to the file.
    var path = file.path;

    // Get object of file properties from AST.
    var fileProperties = scribeSass.getFileProperties(file.ast);
  }
}

Show value of color and text variables

Compile the Sass and display the outputted color next to it.

$color: (

  ui: (
    white                    : $base-white,
    faint                    : map-fetch($root-color, grey-03),
    light                    : map-fetch($root-color, grey-06),
    base                     : map-fetch($root-color, grey-12),
    medium                   : map-fetch($root-color, grey-40),
    dark                     : map-fetch($root-color, grey-85),
    brand                    : map-fetch($root-color, brand),
    brand-light              : map-fetch($root-color, brand-light),
    brand-dark               : map-fetch($root-color, brand-dark),
    warning                  : map-fetch($root-color, warning),
    bad-news                 : map-fetch($root-color, bad-news),
    good-news                : map-fetch($root-color, good-news)
  ),

  link: (
    base                     : map-fetch($root-color, brand),
    brand-light              : map-fetch($root-color, brand-light),
    bad-news                 : map-fetch($root-color, bad-news),
    white                    : $base-white
  ),

  background: (
    base                     : $base-white,
    white                    : $base-white,
    faint                    : map-fetch($root-color, grey-03),
    light                    : map-fetch($root-color, grey-06),
    muted                    : map-fetch($root-color, grey-35),
    medium                   : map-fetch($root-color, grey-50),
    black                    : $base-black,
    brand                    : map-fetch($root-color, brand),
    brand-dark               : map-fetch($root-color, brand-dark),
    brand-light              : #F2F7FC,
    warning                  : #FCF8E3,
    bad-news                 : #F9E3E4,
    good-news                : #E9F6C3
  ),

  text: (
    base                     : map-fetch($root-color, grey-85),
    white                    : $base-white,
    faint                    : map-fetch($root-color, grey-12),
    light                    : map-fetch($root-color, grey-25),
    muted                    : map-fetch($root-color, grey-35),
    medium                   : map-fetch($root-color, grey-50),
    dark                     : map-fetch($root-color, grey-85),
    brand                    : map-fetch($root-color, brand),
    brand-dark               : map-fetch($root-color, brand-dark),
    warning                  : map-fetch($root-color, warning),
    bad-news                 : map-fetch($root-color, bad-news),
    good-news                : map-fetch($root-color, good-news)
  )

);

Support one comment for multiple items

This comment relates to all the classes below it. There should be a way to indicate this.

/// Flex classes

.flex {
  @include display(flex);
}

.flex-1 {
  @include flex(1);
}

.flex-none {
  @include flex(none);
}

.flex-wrap--wrap {
  @include flex-wrap(wrap);
}

Support @alias annotation

This would be used for searching through the output for keywords. For example, an "attention" bar object could be aliased to alert.

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.