svelte2tsx
TypeScript icon, indicating that this package has built-in type declarations

0.7.36 • Public • Published

svelte2tsx

Converts Svelte component source into TSX. The TSX can be type checked using the included svelte-jsx.d.ts and svelte-shims.d.ts.

This project only converts svelte to tsx, type checking is left to consumers of this plugin such as language services

type SvelteCompiledToTsx = {
    code: string;
    map: import('magic-string').SourceMap;
};

export default function svelte2tsx(svelte: string): SvelteCompiledToTsx;

For example

Input.svelte

<script>
    export let world = 'name';
</script>

<h1>hello {world}</h1>

will produce this ugly but type checkable TSX

<></>;
function render() {
    let world = 'name';
    <>
        <h1>hello {world}</h1>
    </>;
    return { props: { world }, slots: {}, events: {} };
}

export default class _World_ extends __sveltets_2_createSvelte2TsxComponent(
    __sveltets_2_partial(__sveltets_2_with_any_event(render))
) {}

with a v3 SourceMap back to the original source.

For more examples of the transformations, see the test/**/samples folders

Credits

  • halfnelson for creating svelte2tsx
  • pushkine for creating the source mapping test infrastructure

/svelte2tsx/

    Package Sidebar

    Install

    npm i svelte2tsx

    Weekly Downloads

    224,560

    Version

    0.7.36

    License

    MIT

    Unpacked Size

    767 kB

    Total Files

    11

    Last publish

    Collaborators

    • orta
    • svelte-language-tools-deploy
    • dummdidumm
    • halfnelson