data:image/s3,"s3://crabby-images/7e228/7e2287ba60e21dee87416ea9983ec241b5307ec2" alt="vlt Launches "reproduce": A New Tool Challenging the Limits of Package Provenance"
Security News
vlt Launches "reproduce": A New Tool Challenging the Limits of Package Provenance
vlt's new "reproduce" tool verifies npm packages against their source code, outperforming traditional provenance adoption in the JavaScript ecosystem.
babel-plugin-prejss
Advanced tools
This plugin allows to use PostCss features (plugins, parsers etc.) for compiling to JSS object, so you can take benefits from both.
npm i babel-plugin-prejss -D
This plugin uses postcss-load-config, so you need to set PostCSS options in package.json/.postcssrc/postcss.config.js/.postcssrc.js
extensionsRe
- RegExp for extensions. By default (c|(s[ac]?))ss
- for css, sass, scss, sssnamespace
- Set your custom namespace for tagged literals. By default its prejss
.babelrc example:
plugins: [
[
'prejss', {
extensionsRe: 's[ac]?ss',
namespace: 'customPreJssNamespace'
}
]
]
Please check a counter example
This plugin transforms tagged literal into the JSS-object by PostCSS, like:
const styles = prejss`
.${selector}
left: ${() => 0}
margin-${marginType}: 10px
transition: ${'opacity'} 1s
color: ${color}
`
After transpile it would look like:
const styles = {
[selector]: {
left: () => 0,
[`margin-${marginType}`]: '10px',
transition: 'opacity 1s',
color: color
}
}
You are free to use all PostCSS feature and custom prejss syntax
(see bellow)
Notice that if you are using
stylelint
andproperty-no-unknown
rule, you need to set an option like this (it's required for current prejss parser implementation):property-no-unknown: [true, { ignoreProperties: ['/\$\^var__/'] }]
After transpiling imported styles inlined into variable (import name) as a function expression, that accepts an object with arguments and returns a JSS object with styles with arguments usage. Notice that arguments name has uniq scope, so you need not worry about names conflict.
Say you have this styles.sss (with SugarSS i.e.):
.langList
display: flex
margin: 0
padding: 0
list-style: none
.lang
margin-right: 10px
padding: 5px
&.current
border-bottom: 1px solid red
And a component using it:
import style from './style.sss'
After babel transpiling your component become as:
const styles = function (izexozk) {
izexozk = Object.assign({}, izexozk);
return {
".langList": {
"display": "flex",
"margin": "0",
"padding": "0",
"listStyle": "none"
},
".lang": {
"marginRight": "10px",
"padding": "5px",
"&.current": {
"borderBottom": "1px solid red"
}
}
};
}
And you can use this with JSS like:
injectSheet(style())
You can use specific syntax for some JSS-features in your CSS:
/JS Code/
- you can place JS-block wrapped by /
in every property value.app
display: /({ visible }) => visible ? 'block' : 'none'/
^variableName
- allows you to use variables passed as arguments to the style function.app
background-color: /^color || $color/
defaults
block for default values - it would be default for accepting argsdefaults:
prop: /^prop || 'test'/
selector: ''
--^propertyName
- for custom property/selector names.app
--^prop: 100vw
--^selector:
display: none
style.sss
@import 'vars.sss'
@import 'mixins.sss'
$color: 'green'
:root
--color: $color
defaults:
prop: /^prop || 'test'/
selector: ''
.app
position: absolute
top: 0
left: 0
display: /({ name }) => name + 1 + $color-from-import/
overflow-y: auto
flex-direction: column
width: 100vw
height: 100vh
color: var(--color)
background-color: /^value || $color/
--^prop: 100vw
--^selector:
display: none
.content
@mixin container
padding: 20px
.header
border-bottom: 1px solid #eee
component.jsx
const style = function (izezix) {
izezix = Object.assign({
"prop": izezix.prop || 'test',
"selector": "''"
}, izezix);
return {
".app": {
"position": "absolute",
"top": "0",
"left": "0",
"display": function ({
name
}) {
return name + 1 + 'black';
},
"overflowY": "auto",
"flexDirection": "column",
"width": "100vw",
"height": "100vh",
"color": "green",
"backgroundColor": izezix.value || 'green',
[izezix.prop]: "100vw"
},
[izezix.selector]: {
"display": "none"
},
".content": {
"position": "absolute",
"margin": "0 auto",
"&::before": {
"content": "''"
},
"padding": "20px"
},
".header": {
"borderBottom": "1px solid #eee"
}
};
}
MIT
FAQs
Plugin for preparing sources for JSS by PostCSS
The npm package babel-plugin-prejss receives a total of 0 weekly downloads. As such, babel-plugin-prejss popularity was classified as not popular.
We found that babel-plugin-prejss demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
vlt's new "reproduce" tool verifies npm packages against their source code, outperforming traditional provenance adoption in the JavaScript ecosystem.
Research
Security News
Socket researchers uncovered a malicious PyPI package exploiting Deezer’s API to enable coordinated music piracy through API abuse and C2 server control.
Research
The Socket Research Team discovered a malicious npm package, '@ton-wallet/create', stealing cryptocurrency wallet keys from developers and users in the TON ecosystem.