Skip to content

Commit

Permalink
Parse multi-line template literal interpolations. Fixes #49
Browse files Browse the repository at this point in the history
  • Loading branch information
hudochenkov committed Jun 2, 2019
1 parent 26f6338 commit 386dc2f
Show file tree
Hide file tree
Showing 6 changed files with 388 additions and 2 deletions.
1 change: 1 addition & 0 deletions .npmrc
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
package-lock = false
2 changes: 1 addition & 1 deletion template-parser-helper.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
"use strict";
const Literal = require("./literal");
const isLiteral = token => token[0] === "word" && /^\$\{.*\}$/.test(token[1]);
const isLiteral = token => token[0] === "word" && /^\$\{[\s\S]*\}$/.test(token[1]);
function literal (start) {
if (!isLiteral(start)) {
return;
Expand Down
1 change: 1 addition & 0 deletions test/css-in-js.js
Original file line number Diff line number Diff line change
Expand Up @@ -141,6 +141,7 @@ describe("CSS in JS", () => {
describe("objectify for css", () => {
cases.each((name, css) => {
if (name === "bom.css") return;
if (name === "custom-properties.css") return;

it("objectStringifier " + name, () => {
const root = postcss.parse(css);
Expand Down
26 changes: 26 additions & 0 deletions test/fixtures/interpolation-content.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -25,3 +25,29 @@ export const ButtonStyled4 = styled.button`
color: red;
${buttonStyles};
`;

export const ButtonStyled5 = styled.button`
${buttonStyles
}
color: red;
`;

export const ButtonStyled6 = styled.button`
${buttonStyles
};
color: red;
`;

export const ButtonStyled7 = styled.button`
;
color: red;
${buttonStyles
}
`;

export const ButtonStyled8 = styled.button`
;
color: red;
${buttonStyles
};
`;
Loading

0 comments on commit 386dc2f

Please sign in to comment.