A function to extract information about the props, actions, slots and css variables from a Svelte file. Designed to simplify the creation of documentation
NPM link: @el3um4s/svelte-get-component-info
I recommend using it with el3um4s/svelte-component-info (npm: @el3um4s/svelte-component-info)
To use the package in a project:
npm i @el3um4s/svelte-get-component-info
and then in a file:
import type { SvelteInformations } from "@el3um4s/svelte-get-component-info";
import { getInfo } from "@el3um4s/svelte-get-component-info";
const info: SvelteInformations = getInfo("./src/lib/hello.svelte");
console.log(info.props); // [{ name: "message", type: "string", defaultValue: "Hello World" }]
console.log(info.actions); /// [ { name: "notify" }]
info
looks like this:
{
"props": [
{ "name": "color", "type":"string", "defaultValue":"red" },
{ "name": "steps", "type":"number", "defaultValue":"8" }
{ "name": "title", "type":"string" },
{ "name": "description"}
],
"actions": [
{ "name": "click" },
{ "name": "hover" },
{ "name": "customAction" }
],
"slots": [
{ "anonymous": true },
{ "name": "header", "anonymous": false },
{ "name": "footer", "anonymous": false }
],
"css": [
{ "name": "--color-primary" },
{ "name": "--color-secondary" }
]
}