26 Commits

Author SHA1 Message Date
e2b1e1a735 2.0.6 2020-01-13 19:07:15 +00:00
eeb042c3a9 fix(core): update 2020-01-13 19:07:14 +00:00
7a4372f104 2.0.5 2020-01-13 18:58:12 +00:00
caa194dee6 fix(core): update 2020-01-13 18:58:12 +00:00
5913245604 2.0.4 2019-10-14 14:35:26 +02:00
ad753b3a9a fix(core): update 2019-10-14 14:35:26 +02:00
9fc47fcca1 2.0.3 2018-11-28 11:04:26 +01:00
cfcff789a2 fix(format): run gitzone format 2018-11-28 11:04:26 +01:00
134618cb3a 2.0.2 2018-11-28 11:03:50 +01:00
9bbbf82b20 fix(dependencies): make it work with node 11 2018-11-28 11:03:50 +01:00
23aa8efef2 2.0.1 2018-09-20 23:06:26 +02:00
d09b5773ca fix(core): update smartsass 2018-09-20 23:06:26 +02:00
b1165827a1 2.0.0 2018-09-20 00:47:15 +02:00
581bae156e BREAKING CHANGE(scope): update scope to @pushrocks 2018-09-20 00:47:15 +02:00
42573648b9 update gitlab yml 2017-03-12 20:08:52 +01:00
b9266d0a9a fix README 2017-03-12 18:59:57 +01:00
3cf679365f improve README 2017-03-12 12:13:29 +01:00
5c13a1d568 improve README 2017-03-12 12:09:08 +01:00
2fb3a039f4 update README 2017-03-12 11:28:12 +01:00
cc91855a48 1.0.5 2017-03-12 10:59:26 +01:00
ef4ee3ee0b add inlude paths later on 2017-03-12 10:59:21 +01:00
975f27d241 update 2017-03-12 00:56:31 +01:00
33cb6ac697 1.0.4 2017-03-12 00:55:47 +01:00
df11f7fe64 add includePaths 2017-03-12 00:55:34 +01:00
42faa6a389 1.0.3 2017-03-05 20:03:25 +01:00
733a67b597 add npmextra.json 2017-03-05 20:03:21 +01:00
18 changed files with 3026 additions and 1400 deletions

20
.gitignore vendored
View File

@ -1,4 +1,22 @@
.nogit/
# artifacts
coverage/ coverage/
node_modules/
public/ public/
pages/ pages/
# installs
node_modules/
# caches
.yarn/
.cache/
.rpt2_cache
# builds
dist/
dist_web/
dist_serve/
dist_ts_web/
# custom

View File

@ -1,60 +1,118 @@
# gitzone standard # gitzone ci_default
image: hosttoday/ht-docker-node:npmts image: registry.gitlab.com/hosttoday/ht-docker-node:npmci
cache:
paths:
- .npmci_cache/
key: "$CI_BUILD_STAGE"
stages: stages:
- security
- test - test
- release - release
- trigger - metadata
- pages
testLEGACY: # ====================
stage: test # security stage
# ====================
mirror:
stage: security
script: script:
- npmci test legacy - npmci git mirror
tags: tags:
- docker - docker
allow_failure: true - notpriv
testLTS: snyk:
stage: security
script:
- npmci npm prepare
- npmci command npm install -g snyk
- npmci command npm install --ignore-scripts
- npmci command snyk test
tags:
- docker
- notpriv
# ====================
# test stage
# ====================
testStable:
stage: test stage: test
script: script:
- npmci test lts - npmci npm prepare
- npmci node install stable
- npmci npm install
- npmci npm test
coverage: /\d+.?\d+?\%\s*coverage/
tags: tags:
- docker - docker
- priv
testSTABLE:
testBuild:
stage: test stage: test
script: script:
- npmci test stable - npmci npm prepare
- npmci node install stable
- npmci npm install
- npmci command npm run build
coverage: /\d+.?\d+?\%\s*coverage/
tags: tags:
- docker - docker
- notpriv
release: release:
stage: release stage: release
script: script:
- npmci publish - npmci node install stable
- npmci npm publish
only: only:
- tags - tags
tags: tags:
- docker - docker
- notpriv
# ====================
# metadata stage
# ====================
codequality:
stage: metadata
allow_failure: true
script:
- npmci command npm install -g tslint typescript
- npmci npm prepare
- npmci npm install
- npmci command "tslint -c tslint.json ./ts/**/*.ts"
tags:
- docker
- priv
trigger: trigger:
stage: trigger stage: metadata
script: script:
- npmci trigger - npmci trigger
only: only:
- tags - tags
tags: tags:
- docker - docker
- notpriv
pages: pages:
image: hosttoday/ht-docker-node:npmpage stage: metadata
stage: pages
script: script:
- npmci command npmpage --publish gitlab - npmci node install lts
- npmci command npm install -g @gitzone/tsdoc
- npmci npm prepare
- npmci npm install
- npmci command tsdoc
tags:
- docker
- notpriv
only: only:
- tags - tags
artifacts: artifacts:
expire_in: 1 week expire_in: 1 week
paths: paths:
- public - public
allow_failure: true

69
.snyk Normal file
View File

@ -0,0 +1,69 @@
# Snyk (https://snyk.io) policy file, patches or ignores known vulnerabilities.
version: v1.13.5
# ignores vulnerabilities until expiry date; change duration by modifying expiry date
ignore:
SNYK-JS-NODESASS-535497:
- node-sass:
reason: None given
expires: '2020-02-12T19:06:41.940Z'
SNYK-JS-NODESASS-535498:
- node-sass:
reason: None given
expires: '2020-02-12T19:06:41.940Z'
SNYK-JS-NODESASS-535502:
- node-sass:
reason: None given
expires: '2020-02-12T19:06:41.940Z'
SNYK-JS-NODESASS-540956:
- node-sass:
reason: None given
expires: '2020-02-12T19:06:41.940Z'
SNYK-JS-NODESASS-540958:
- node-sass:
reason: None given
expires: '2020-02-12T19:06:41.940Z'
SNYK-JS-NODESASS-540964:
- node-sass:
reason: None given
expires: '2020-02-12T19:06:41.940Z'
SNYK-JS-NODESASS-540974:
- node-sass:
reason: None given
expires: '2020-02-12T19:06:41.940Z'
SNYK-JS-NODESASS-540978:
- node-sass:
reason: None given
expires: '2020-02-12T19:06:41.940Z'
SNYK-JS-NODESASS-540980:
- node-sass:
reason: None given
expires: '2020-02-12T19:06:41.940Z'
SNYK-JS-NODESASS-540990:
- node-sass:
reason: None given
expires: '2020-02-12T19:06:41.940Z'
SNYK-JS-NODESASS-540992:
- node-sass:
reason: None given
expires: '2020-02-12T19:06:41.940Z'
SNYK-JS-NODESASS-540994:
- node-sass:
reason: None given
expires: '2020-02-12T19:06:41.940Z'
SNYK-JS-NODESASS-540996:
- node-sass:
reason: None given
expires: '2020-02-12T19:06:41.940Z'
SNYK-JS-NODESASS-540998:
- node-sass:
reason: None given
expires: '2020-02-12T19:06:41.940Z'
SNYK-JS-NODESASS-541000:
- node-sass:
reason: None given
expires: '2020-02-12T19:06:41.940Z'
SNYK-JS-NODESASS-541002:
- node-sass:
reason: None given
expires: '2020-02-12T19:06:41.941Z'
patch: {}

View File

@ -1,29 +1,50 @@
# smartsass # @pushrocks/smartsass
smart wrapper for sass smart wrapper for sass
## Availabililty ## Availabililty and Links
[![npm](https://pushrocks.gitlab.io/assets/repo-button-npm.svg)](https://www.npmjs.com/package/smartsass) * [npmjs.org (npm package)](https://www.npmjs.com/package/@pushrocks/smartsass)
[![git](https://pushrocks.gitlab.io/assets/repo-button-git.svg)](https://GitLab.com/pushrocks/smartsass) * [gitlab.com (source)](https://gitlab.com/pushrocks/smartsass)
[![git](https://pushrocks.gitlab.io/assets/repo-button-mirror.svg)](https://github.com/pushrocks/smartsass) * [github.com (source mirror)](https://github.com/pushrocks/smartsass)
[![docs](https://pushrocks.gitlab.io/assets/repo-button-docs.svg)](https://pushrocks.gitlab.io/smartsass/) * [docs (typedoc)](https://pushrocks.gitlab.io/smartsass/)
## Status for master ## Status for master
[![build status](https://GitLab.com/pushrocks/smartsass/badges/master/build.svg)](https://GitLab.com/pushrocks/smartsass/commits/master) [![build status](https://gitlab.com/pushrocks/smartsass/badges/master/build.svg)](https://gitlab.com/pushrocks/smartsass/commits/master)
[![coverage report](https://GitLab.com/pushrocks/smartsass/badges/master/coverage.svg)](https://GitLab.com/pushrocks/smartsass/commits/master) [![coverage report](https://gitlab.com/pushrocks/smartsass/badges/master/coverage.svg)](https://gitlab.com/pushrocks/smartsass/commits/master)
[![npm downloads per month](https://img.shields.io/npm/dm/smartsass.svg)](https://www.npmjs.com/package/smartsass) [![npm downloads per month](https://img.shields.io/npm/dm/@pushrocks/smartsass.svg)](https://www.npmjs.com/package/@pushrocks/smartsass)
[![Dependency Status](https://david-dm.org/pushrocks/smartsass.svg)](https://david-dm.org/pushrocks/smartsass) [![Known Vulnerabilities](https://snyk.io/test/npm/@pushrocks/smartsass/badge.svg)](https://snyk.io/test/npm/@pushrocks/smartsass)
[![bitHound Dependencies](https://www.bithound.io/github/pushrocks/smartsass/badges/dependencies.svg)](https://www.bithound.io/github/pushrocks/smartsass/master/dependencies/npm) [![TypeScript](https://img.shields.io/badge/TypeScript->=%203.x-blue.svg)](https://nodejs.org/dist/latest-v10.x/docs/api/)
[![bitHound Code](https://www.bithound.io/github/pushrocks/smartsass/badges/code.svg)](https://www.bithound.io/github/pushrocks/smartsass) [![node](https://img.shields.io/badge/node->=%2010.x.x-blue.svg)](https://nodejs.org/dist/latest-v10.x/docs/api/)
[![TypeScript](https://img.shields.io/badge/TypeScript-2.x-blue.svg)](https://nodejs.org/dist/latest-v6.x/docs/api/) [![JavaScript Style Guide](https://img.shields.io/badge/code%20style-prettier-ff69b4.svg)](https://prettier.io/)
[![node](https://img.shields.io/badge/node->=%206.x.x-blue.svg)](https://nodejs.org/dist/latest-v6.x/docs/api/)
[![JavaScript Style Guide](https://img.shields.io/badge/code%20style-standard-brightgreen.svg)](http://standardjs.com/)
## Usage ## Usage
Use TypeScript for best in class instellisense. Use TypeScript for best in class instellisense.
```javascript
import * as smartsass from 'smartsass'
import * as bourbon from 'bourbon
import * as neat from 'neat'
let mySmartsass = new smartsass.Smartsass({
filePath: './some.css',
includePaths: bourbon.includePaths
})
mySmartsass.addIncludePaths(neat.includePaths)
let renderedString = mySmartsass.render()
```
For further information read the linked docs at the top of this README. For further information read the linked docs at the top of this README.
> MIT licensed | **©** [Lossless GmbH](https://lossless.gmbh) > MIT licensed | **©** [Lossless GmbH](https://lossless.gmbh)
| By using this npm module you agree to our [privacy policy](https://lossless.gmbH/privacy.html) > | By using this npm module you agree to our [privacy policy](https://lossless.gmbH/privacy.html)
[![repo-footer](https://pushrocks.gitlab.io/assets/repo-footer.svg)](https://push.rocks) [![repo-footer](https://pushrocks.gitlab.io/assets/repo-footer.svg)](https://push.rocks)
For further information read the linked docs at the top of this readme.
> MIT licensed | **©** [Lossless GmbH](https://lossless.gmbh)
| By using this npm module you agree to our [privacy policy](https://lossless.gmbH/privacy)
[![repo-footer](https://lossless.gitlab.io/publicrelations/repofooter.svg)](https://maintainedby.lossless.com)

16
dist/index.d.ts vendored
View File

@ -1,16 +0,0 @@
import { Result } from 'node-sass';
export interface ISmartsassConstructorOptions {
entryFilePath: string;
}
export declare class Smartsass {
entryFilePath: string;
constructor(optionsArg: ISmartsassConstructorOptions);
/**
* renders the Smartsass classes' entryfile and returns result as string
*/
render(): Promise<Result>;
/**
* renders and stores
*/
renderAndStore(outputFilePath: string): Promise<void>;
}

43
dist/index.js vendored
View File

@ -1,43 +0,0 @@
"use strict";
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
Object.defineProperty(exports, "__esModule", { value: true });
const plugins = require("./smartsass.plugins");
class Smartsass {
constructor(optionsArg) {
this.entryFilePath = optionsArg.entryFilePath;
}
/**
* renders the Smartsass classes' entryfile and returns result as string
*/
render() {
let done = plugins.smartq.defer();
plugins.sass.render({
file: this.entryFilePath
}, function (err, result) {
if (err) {
console.log(err);
done.reject(err);
}
done.resolve(result);
});
return done.promise;
}
/**
* renders and stores
*/
renderAndStore(outputFilePath) {
return __awaiter(this, void 0, void 0, function* () {
let result = yield this.render();
yield plugins.smartfile.memory.toFs(result.css.toString(), outputFilePath);
});
}
}
exports.Smartsass = Smartsass;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7O0FBQUEsK0NBQThDO0FBUzlDO0lBRUUsWUFBWSxVQUF3QztRQUNsRCxJQUFJLENBQUMsYUFBYSxHQUFHLFVBQVUsQ0FBQyxhQUFhLENBQUE7SUFDL0MsQ0FBQztJQUVEOztPQUVHO0lBQ0gsTUFBTTtRQUNKLElBQUksSUFBSSxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsS0FBSyxFQUF1QixDQUFBO1FBQ3RELE9BQU8sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDO1lBQ2xCLElBQUksRUFBRSxJQUFJLENBQUMsYUFBYTtTQUN6QixFQUFFLFVBQVUsR0FBRyxFQUFFLE1BQU07WUFDdEIsRUFBRSxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztnQkFDUixPQUFPLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFBO2dCQUNoQixJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFBO1lBQ2xCLENBQUM7WUFDRCxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFBO1FBQ3RCLENBQUMsQ0FBQyxDQUFBO1FBQ0YsTUFBTSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUE7SUFDckIsQ0FBQztJQUVEOztPQUVHO0lBQ0csY0FBYyxDQUFFLGNBQXNCOztZQUMxQyxJQUFJLE1BQU0sR0FBRyxNQUFNLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQTtZQUNoQyxNQUFNLE9BQU8sQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLFFBQVEsRUFBRSxFQUFFLGNBQWMsQ0FBQyxDQUFBO1FBQzVFLENBQUM7S0FBQTtDQUNGO0FBOUJELDhCQThCQyJ9

View File

@ -1,5 +0,0 @@
import 'typings-global';
import * as sass from 'node-sass';
import * as smartfile from 'smartfile';
import * as smartq from 'smartq';
export { sass, smartfile, smartq };

View File

@ -1,10 +0,0 @@
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
require("typings-global");
const sass = require("node-sass");
exports.sass = sass;
const smartfile = require("smartfile");
exports.smartfile = smartfile;
const smartq = require("smartq");
exports.smartq = smartq;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRzYXNzLnBsdWdpbnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90cy9zbWFydHNhc3MucGx1Z2lucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLDBCQUF1QjtBQUN2QixrQ0FBaUM7QUFLL0Isb0JBQUk7QUFKTix1Q0FBc0M7QUFLcEMsOEJBQVM7QUFKWCxpQ0FBZ0M7QUFLOUIsd0JBQU0ifQ==

16
npmextra.json Normal file
View File

@ -0,0 +1,16 @@
{
"npmci": {
"npmGlobalTools": [],
"npmAccessLevel": "public"
},
"gitzone": {
"module": {
"githost": "gitlab.com",
"gitscope": "pushrocks",
"gitrepo": "smartsass",
"shortDescription": "smart wrapper for sass",
"npmPackagename": "@pushrocks/smartsass",
"license": "MIT"
}
}
}

2697
package-lock.json generated Normal file

File diff suppressed because it is too large Load Diff

View File

@ -1,11 +1,13 @@
{ {
"name": "smartsass", "name": "@pushrocks/smartsass",
"version": "1.0.2", "version": "2.0.6",
"private": false,
"description": "smart wrapper for sass", "description": "smart wrapper for sass",
"main": "dist/index.js", "main": "dist/index.js",
"typings": "dist/index.d.ts", "typings": "dist/index.d.ts",
"scripts": { "scripts": {
"test": "(npmts)" "test": "(tstest test/)",
"build": "(tsbuild)"
}, },
"repository": { "repository": {
"type": "git", "type": "git",
@ -23,10 +25,29 @@
}, },
"homepage": "https://gitlab.com/pushrocks/smartsass#README", "homepage": "https://gitlab.com/pushrocks/smartsass#README",
"dependencies": { "dependencies": {
"@types/node-sass": "^3.10.32", "@pushrocks/smartfile": "^7.0.6",
"node-sass": "^4.5.0", "@pushrocks/smartpromise": "^3.0.6",
"smartfile": "^4.1.7", "@types/node-sass": "^4.11.0",
"smartq": "^1.1.1", "node-sass": "^4.13.0"
"typings-global": "^1.0.14" },
} "devDependencies": {
"@gitzone/tsbuild": "^2.1.17",
"@gitzone/tsrun": "^1.2.8",
"@gitzone/tstest": "^1.0.28",
"@pushrocks/tapbundle": "^3.2.0",
"@types/node": "^13.1.6",
"tslint": "^5.20.1",
"tslint-config-prettier": "^1.18.0"
},
"files": [
"ts/**/*",
"ts_web/**/*",
"dist/**/*",
"dist_web/**/*",
"dist_ts_web/**/*",
"assets/**/*",
"cli.js",
"npmextra.json",
"readme.md"
]
} }

0
test/test.scss Normal file
View File

12
test/test.ts Normal file
View File

@ -0,0 +1,12 @@
import { tap, expect } from '@pushrocks/tapbundle';
import * as smartsass from '../ts/index';
tap.test('should create a valid instance of smartsass', async () => {
const testsmartSass = new smartsass.Smartsass({
data: 'hello'
});
expect(testsmartSass).to.be.instanceof(smartsass.Smartsass);
});
tap.start();

View File

@ -1,40 +1,64 @@
import * as plugins from './smartsass.plugins' import * as plugins from './smartsass.plugins';
// interfaces // interfaces
import { Result } from 'node-sass' import { Result } from 'node-sass';
export interface ISmartsassConstructorOptions { export interface ISmartsassConstructorOptions {
entryFilePath: string data?: string;
entryFilePath?: string;
includePaths?: string[];
} }
export class Smartsass { export class Smartsass {
entryFilePath: string includePaths = [];
entryFilePath: string;
data: string;
constructor(optionsArg: ISmartsassConstructorOptions) { constructor(optionsArg: ISmartsassConstructorOptions) {
this.entryFilePath = optionsArg.entryFilePath this.entryFilePath = optionsArg.entryFilePath;
this.data = optionsArg.data;
if (optionsArg.includePaths) {
for (let includePath of optionsArg.includePaths) {
this.includePaths.push(includePath);
}
}
}
/**
* add further include paths
*/
addIncludePaths(includePathsArray: string[]) {
for (let includePath of includePathsArray) {
this.includePaths.push(includePath);
}
} }
/** /**
* renders the Smartsass classes' entryfile and returns result as string * renders the Smartsass classes' entryfile and returns result as string
*/ */
render() { render() {
let done = plugins.smartq.defer<plugins.sass.Result>() let done = plugins.smartpromise.defer<plugins.sass.Result>();
plugins.sass.render({ plugins.sass.render(
file: this.entryFilePath {
}, function (err, result) { data: this.data,
if (err) { file: this.entryFilePath,
console.log(err) includePaths: this.includePaths
done.reject(err) },
function(err, result) {
if (err) {
console.log(err);
done.reject(err);
}
done.resolve(result);
} }
done.resolve(result) );
}) return done.promise;
return done.promise
} }
/** /**
* renders and stores * renders and stores
*/ */
async renderAndStore (outputFilePath: string) { async renderAndStore(outputFilePath: string) {
let result = await this.render() let result = await this.render();
await plugins.smartfile.memory.toFs(result.css.toString(), outputFilePath) await plugins.smartfile.memory.toFs(result.css.toString(), outputFilePath);
} }
} }

1
ts/smartsass.includes.ts Normal file
View File

@ -0,0 +1 @@
import * as plugins from './smartsass.plugins';

View File

@ -1,10 +1,5 @@
import 'typings-global' import * as sass from 'node-sass';
import * as sass from 'node-sass' import * as smartfile from '@pushrocks/smartfile';
import * as smartfile from 'smartfile' import * as smartpromise from '@pushrocks/smartpromise';
import * as smartq from 'smartq'
export { export { sass, smartfile, smartpromise };
sass,
smartfile,
smartq
}

View File

@ -1,3 +1,17 @@
{ {
"extends": "tslint-config-standard" "extends": ["tslint:latest", "tslint-config-prettier"],
"rules": {
"semicolon": [true, "always"],
"no-console": false,
"ordered-imports": false,
"object-literal-sort-keys": false,
"member-ordering": {
"options":{
"order": [
"static-method"
]
}
}
},
"defaultSeverity": "warning"
} }

1246
yarn.lock

File diff suppressed because it is too large Load Diff