Skip to content

Commit

Permalink
feat: add transpileOptions prop to LiveProvider
Browse files Browse the repository at this point in the history
Closes #252
  • Loading branch information
maksnester committed Jun 28, 2021
1 parent c09b4bc commit 08b945d
Show file tree
Hide file tree
Showing 7 changed files with 59 additions and 16 deletions.
1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@
"lint": "eslint --config .eslintrc \"./**/*.js\""
},
"dependencies": {
"@types/buble": "^0.20.0",
"buble": "0.19.6",
"core-js": "^3.14.0",
"dom-iterator": "^1.0.0",
Expand Down
9 changes: 6 additions & 3 deletions src/components/Live/LiveProvider.js
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ function LiveProvider({
disabled,
scope,
transformCode,
transpileOptions,
noInline = false
}) {
const [state, setState] = useState({
Expand All @@ -23,7 +24,8 @@ function LiveProvider({
// Transpilation arguments
const input = {
code: transformCode ? transformCode(newCode) : newCode,
scope
scope,
transpileOptions
};

const errorCallback = error =>
Expand All @@ -45,7 +47,7 @@ function LiveProvider({

useEffect(() => {
transpile(code);
}, [code, scope, noInline, transformCode]);
}, [code, scope, noInline, transformCode, transpileOptions]);

const onChange = newCode => transpile(newCode);

Expand Down Expand Up @@ -76,7 +78,8 @@ LiveProvider.propTypes = {
noInline: PropTypes.bool,
scope: PropTypes.object,
theme: PropTypes.object,
transformCode: PropTypes.func
transformCode: PropTypes.node,
transpileOptions: PropTypes.object
};

LiveProvider.defaultProps = {
Expand Down
17 changes: 17 additions & 0 deletions src/utils/test/transpile.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -59,6 +59,23 @@ describe('transpile', () => {

expect(wrapper.text()).toBe('Hello World!');
});

it('adopts code generation based on transpileOptions', () => {
const code = `(() => {
class Foo { async bar() { await Promise.resolve(1); } }
})();`;

expect(() => generateElement({ code })).toThrow();

expect(() =>
generateElement({
code,
transpileOptions: {
transforms: { classes: false, asyncAwait: false }
}
})
).not.toThrow();
});
});

describe('renderElementAsync', () => {
Expand Down
15 changes: 11 additions & 4 deletions src/utils/transpile/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,17 +2,24 @@ import transform from './transform';
import errorBoundary from './errorBoundary';
import evalCode from './evalCode';

export const generateElement = ({ code = '', scope = {} }, errorCallback) => {
export const generateElement = (
{ code = '', scope = {}, transpileOptions },
errorCallback
) => {
// NOTE: Remove trailing semicolon to get an actual expression.
const codeTrimmed = code.trim().replace(/;$/, '');

// NOTE: Workaround for classes and arrow functions.
const transformed = transform(`return (${codeTrimmed})`).trim();
const transformed = transform(
`return (${codeTrimmed})`,
transpileOptions
).trim();

return errorBoundary(evalCode(transformed, scope), errorCallback);
};

export const renderElementAsync = (
{ code = '', scope = {} },
{ code = '', scope = {}, transpileOptions },
resultCallback,
errorCallback
// eslint-disable-next-line consistent-return
Expand All @@ -31,5 +38,5 @@ export const renderElementAsync = (
);
}

evalCode(transform(code), { ...scope, render });
evalCode(transform(code, transpileOptions), { ...scope, render });
};
20 changes: 12 additions & 8 deletions src/utils/transpile/transform.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,12 +3,16 @@ import assign from 'core-js/features/object/assign';

export const _poly = { assign };

const opts = {
objectAssign: '_poly.assign',
transforms: {
dangerousForOf: true,
dangerousTaggedTemplateString: true
}
};
export default (code, transpileOptions = {}) => {
const opts = {
...transpileOptions,
objectAssign: '_poly.assign',
transforms: {
dangerousForOf: true,
dangerousTaggedTemplateString: true,
...transpileOptions.transforms
}
};

export default code => _transform(code, opts).code;
return _transform(code, opts).code;
};
6 changes: 5 additions & 1 deletion typings/react-live.d.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,8 @@
import { ComponentClass, StatelessComponent, HTMLProps, ComponentType, Context } from 'react'
import { ComponentClass, HTMLProps, ComponentType, Context } from 'react'
import { PrismTheme, Language } from 'prism-react-renderer';
import { TransformOptions } from 'buble';

type TranspileOptions = TransformOptions & { transforms: {asyncAwait?: boolean}}

// Helper types
type Omit<T, K extends keyof T> = Pick<T, Exclude<keyof T, K>>
Expand All @@ -14,6 +17,7 @@ export type LiveProviderProps = Omit<DivProps, 'scope'> & {
code?: string;
noInline?: boolean;
transformCode?: (code: string) => string;
transpileOptions?: TranspileOptions;
language?: Language;
disabled?: boolean;
theme?: PrismTheme;
Expand Down
7 changes: 7 additions & 0 deletions yarn.lock
Original file line number Diff line number Diff line change
Expand Up @@ -383,6 +383,13 @@
react-split-pane "^0.1.77"
react-treebeard "^2.1.0"

"@types/buble@^0.20.0":
version "0.20.0"
resolved "https://registry.yarnpkg.com/@types/buble/-/buble-0.20.0.tgz#8c076a500bb297a3955bd832ae4a1ec5ccf25753"
integrity sha512-tS+DwolzYtDuayJspUABudwjeF8t0mGzchixMDcxN9Vn96IL23AFCsZVoX3gbPkYbZnvD3W+nWCtB/HyxUaeXg==
dependencies:
magic-string "^0.25.0"

"@types/node@*":
version "12.7.2"
resolved "https://registry.yarnpkg.com/@types/node/-/node-12.7.2.tgz#c4e63af5e8823ce9cc3f0b34f7b998c2171f0c44"
Expand Down

0 comments on commit 08b945d

Please sign in to comment.