feat: jsx-explorer support options

This commit is contained in:
Amour1688 2021-03-03 23:58:09 +08:00
parent 98b4f92f48
commit 17c2894067
2 changed files with 99 additions and 17 deletions

View File

@ -1,9 +1,10 @@
/* eslint-disable no-console */ /* eslint-disable no-console */
// eslint-disable-next-line import/no-unresolved // eslint-disable-next-line import/no-unresolved
import * as m from 'monaco-editor'; import * as m from 'monaco-editor';
import { h, createApp } from 'vue'; import { watchEffect } from 'vue';
import { transform } from '@babel/core'; import { transform } from '@babel/core';
import babelPluginJsx from '../../babel-plugin-jsx/src'; import babelPluginJsx from '../../babel-plugin-jsx/src';
import { initOptions, compilerOptions } from './options';
import './index.css'; import './index.css';
declare global { declare global {
@ -15,17 +16,6 @@ declare global {
window.init = () => { window.init = () => {
const { monaco } = window; const { monaco } = window;
createApp(
() => h('h1', null, 'Vue JSX Explorer'),
).mount('#header');
// @ts-ignore
if (module.hot) {
// @ts-ignore
module.hot.accept('../../babel-plugin-jsx/src', () => {
compile();
});
}
const sharedEditorOptions: m.editor.IStandaloneEditorConstructionOptions = { const sharedEditorOptions: m.editor.IStandaloneEditorConstructionOptions = {
theme: 'vs-dark', theme: 'vs-dark',
@ -61,14 +51,15 @@ window.init = () => {
...sharedEditorOptions, ...sharedEditorOptions,
}); });
const compile = () => { const reCompile = () => {
const src = editor.getValue(); const src = editor.getValue();
localStorage.setItem('state', src); const state = JSON.stringify(compilerOptions);
localStorage.setItem('state', state);
window.location.hash = encodeURIComponent(src); window.location.hash = encodeURIComponent(src);
console.clear(); console.clear();
transform(src, { transform(src, {
babelrc: false, babelrc: false,
plugins: [[babelPluginJsx, { transformOn: true, optimize: true }]], plugins: [[babelPluginJsx, compilerOptions]],
ast: true, ast: true,
}, (err, result = {}) => { }, (err, result = {}) => {
const res = result!; const res = result!;
@ -87,10 +78,11 @@ window.init = () => {
output.layout(); output.layout();
}); });
compile(); initOptions();
watchEffect(reCompile);
// update compile output when input changes // update compile output when input changes
editor.onDidChangeModelContent(debounce(compile)); editor.onDidChangeModelContent(debounce(reCompile));
}; };
function debounce<T extends(...args: any[]) => any>( function debounce<T extends(...args: any[]) => any>(

View File

@ -0,0 +1,90 @@
import {
h, reactive, createApp,
} from 'vue';
import { VueJSXPluginOptions } from '../../babel-plugin-jsx/src';
export const compilerOptions: VueJSXPluginOptions = reactive({
mergeProps: true,
optimize: false,
transformOn: false,
enableObjectSlots: true,
});
const App = {
setup() {
return () => [
h('h1', 'Vue 3 JSX Explorer'),
h(
'a',
{
href: 'https://app.netlify.com/sites/vue-next-jsx-explorer/deploys',
target: '_blank',
},
'History',
),
h('div', { id: 'options-wrapper' }, [
h('div', { id: 'options-label' }, 'Options ↘'),
h('ul', { id: 'options' }, [
// mergeProps
h('li', [
h('input', {
type: 'checkbox',
id: 'mergeProps',
name: 'mergeProps',
checked: compilerOptions.mergeProps,
onChange(e: Event) {
compilerOptions.mergeProps = (e.target as HTMLInputElement).checked;
},
}),
h('label', { for: 'mergeProps' }, 'mergeProps'),
]),
// optimize
h('li', [
h('input', {
type: 'checkbox',
id: 'optimize',
checked: compilerOptions.optimize,
onChange(e: Event) {
compilerOptions.optimize = (e.target as HTMLInputElement).checked;
},
}),
h('label', { for: 'optimize' }, 'optimize'),
]),
// transformOn
h('li', [
h('input', {
type: 'checkbox',
id: 'transformOn',
checked: compilerOptions.transformOn,
onChange(e: Event) {
compilerOptions.transformOn = (e.target as HTMLInputElement).checked;
},
}),
h('label', { for: 'transformOn' }, 'transformOn'),
]),
// enableObjectSlots
h('li', [
h('input', {
type: 'checkbox',
id: 'transformOn',
checked: compilerOptions.enableObjectSlots,
onChange(e: Event) {
compilerOptions.enableObjectSlots = (e.target as HTMLInputElement).checked;
},
}),
h('label', { for: 'enableObjectSlots' }, 'enableObjectSlots'),
]),
]),
]),
];
},
};
export function initOptions() {
createApp(App).mount(document.getElementById('header')!);
}