@powerlines/plugin-satori 0.1.337 → 0.1.339

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,21 @@
1
+ import { SatoriPluginContext, SatoriPluginOptions, SatoriPluginResolvedConfig, SatoriPluginUserConfig, __ΩSatoriPluginContext, __ΩSatoriPluginOptions, __ΩSatoriPluginResolvedConfig, __ΩSatoriPluginUserConfig } from "./types/plugin.cjs";
2
+ import { SatoriComponentModule, __ΩSatoriComponentModule } from "./types/module.cjs";
3
+ import "./types/index.cjs";
4
+ import { Plugin } from "powerlines";
5
+
6
+ //#region src/index.d.ts
7
+ declare module "powerlines" {
8
+ interface Config {
9
+ satori?: SatoriPluginOptions;
10
+ }
11
+ }
12
+ /**
13
+ * A Powerlines plugin to use Untyped for code generation based on user-defined schemas.
14
+ *
15
+ * @param options - The plugin options.
16
+ * @returns A Powerlines plugin instance.
17
+ */
18
+ declare const plugin: <TContext extends SatoriPluginContext = SatoriPluginContext>(options: SatoriPluginOptions) => Plugin<TContext>;
19
+ //#endregion
20
+ export { SatoriComponentModule, SatoriPluginContext, SatoriPluginOptions, SatoriPluginResolvedConfig, SatoriPluginUserConfig, __ΩSatoriComponentModule, __ΩSatoriPluginContext, __ΩSatoriPluginOptions, __ΩSatoriPluginResolvedConfig, __ΩSatoriPluginUserConfig, plugin as default, plugin };
21
+ //# sourceMappingURL=index.d.cts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.cts","names":[],"sources":["../src/index.ts"],"sourcesContent":[],"mappings":";;;;;;;;aAuCa;EAJW;;;;;AAcxB;;;AAGW,cAHE,MAGF,EAAA,CAAA,iBAFQ,mBAER,GAF8B,mBAE9B,CAAA,CAAA,OAAA,EAAA,mBAAA,EAAA,GACR,MADQ,CACD,QADC,CAAA"}
@@ -0,0 +1,21 @@
1
+ import { SatoriPluginContext, SatoriPluginOptions, SatoriPluginResolvedConfig, SatoriPluginUserConfig, __ΩSatoriPluginContext, __ΩSatoriPluginOptions, __ΩSatoriPluginResolvedConfig, __ΩSatoriPluginUserConfig } from "./types/plugin.mjs";
2
+ import { SatoriComponentModule, __ΩSatoriComponentModule } from "./types/module.mjs";
3
+ import "./types/index.mjs";
4
+ import { Plugin } from "powerlines";
5
+
6
+ //#region src/index.d.ts
7
+ declare module "powerlines" {
8
+ interface Config {
9
+ satori?: SatoriPluginOptions;
10
+ }
11
+ }
12
+ /**
13
+ * A Powerlines plugin to use Untyped for code generation based on user-defined schemas.
14
+ *
15
+ * @param options - The plugin options.
16
+ * @returns A Powerlines plugin instance.
17
+ */
18
+ declare const plugin: <TContext extends SatoriPluginContext = SatoriPluginContext>(options: SatoriPluginOptions) => Plugin<TContext>;
19
+ //#endregion
20
+ export { SatoriComponentModule, SatoriPluginContext, SatoriPluginOptions, SatoriPluginResolvedConfig, SatoriPluginUserConfig, __ΩSatoriComponentModule, __ΩSatoriPluginContext, __ΩSatoriPluginOptions, __ΩSatoriPluginResolvedConfig, __ΩSatoriPluginUserConfig, plugin as default, plugin };
21
+ //# sourceMappingURL=index.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.mts","names":[],"sources":["../src/index.ts"],"sourcesContent":[],"mappings":";;;;;;;;aAuCa;EAJW;;;;;AAcxB;;;AAGW,cAHE,MAGF,EAAA,CAAA,iBAFQ,mBAER,GAF8B,mBAE9B,CAAA,CAAA,OAAA,EAAA,mBAAA,EAAA,GACR,MADQ,CACD,QADC,CAAA"}
package/dist/index.mjs CHANGED
@@ -52,4 +52,5 @@ const plugin = (options) => {
52
52
  var src_default = plugin;
53
53
 
54
54
  //#endregion
55
- export { src_default as default, plugin };
55
+ export { src_default as default, plugin };
56
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.mjs","names":[],"sources":["../src/index.ts"],"sourcesContent":["/* -------------------------------------------------------------------\n\n ⚡ Storm Software - Powerlines\n\n This code was released as part of the Powerlines project. Powerlines\n is maintained by Storm Software under the Apache-2.0 license, and is\n free for commercial and private use. For more information, please visit\n our licensing page at https://stormsoftware.com/licenses/projects/powerlines.\n\n Website: https://stormsoftware.com\n Repository: https://github.com/storm-software/powerlines\n Documentation: https://docs.stormsoftware.com/projects/powerlines\n Contact: https://stormsoftware.com/contact\n\n SPDX-License-Identifier: Apache-2.0\n\n ------------------------------------------------------------------- */\n\nimport { toArray } from \"@stryke/convert/to-array\";\nimport { existsSync } from \"@stryke/fs/exists\";\nimport { listFiles } from \"@stryke/fs/list-files\";\nimport { findFileExtensionSafe } from \"@stryke/path/file-path-fns\";\nimport { joinPaths } from \"@stryke/path/join-paths\";\nimport { replacePath } from \"@stryke/path/replace\";\nimport defu from \"defu\";\nimport type { Plugin } from \"powerlines\";\nimport { replacePathTokens } from \"powerlines/plugin-utils\";\nimport satori from \"satori\";\nimport { SatoriComponentModule } from \"./types/module\";\nimport {\n SatoriPluginContext,\n SatoriPluginOptions,\n SatoriPluginUserConfig\n} from \"./types/plugin\";\n\nexport * from \"./types\";\n\ndeclare module \"powerlines\" {\n interface Config {\n satori?: SatoriPluginOptions;\n }\n}\n\n/**\n * A Powerlines plugin to use Untyped for code generation based on user-defined schemas.\n *\n * @param options - The plugin options.\n * @returns A Powerlines plugin instance.\n */\nexport const plugin = <\n TContext extends SatoriPluginContext = SatoriPluginContext\n>(\n options: SatoriPluginOptions\n): Plugin<TContext> => {\n return {\n name: \"satori\",\n config() {\n return {\n satori: {\n defaultOptions: {},\n width: 1200,\n height: 630,\n fonts: [],\n ...options\n }\n } as Partial<SatoriPluginUserConfig>;\n },\n async configResolved() {\n if (!this.config.satori.path) {\n throw new Error(\n \"The Powerlines Satori plugin requires a \\`path\\` option to be specified.\"\n );\n }\n\n this.config.satori.inputs = (\n await Promise.all(\n toArray(this.config.satori.path).map(async path => {\n if (path.includes(\"*\")) {\n return listFiles(replacePathTokens(this, path));\n }\n\n return replacePathTokens(this, path);\n })\n )\n )\n .flat()\n .filter(\n path =>\n path &&\n [\"jsx\", \"tsx\"].includes(findFileExtensionSafe(path)) &&\n existsSync(path)\n );\n },\n async prepare() {\n await Promise.all(\n this.config.satori.inputs.map(async input => {\n try {\n const mod =\n await this.resolver.import<SatoriComponentModule>(input);\n if (mod && mod.default) {\n const result = await satori(\n mod.default,\n defu(mod.options ?? {}, this.config.satori.defaultOptions)\n );\n if (result) {\n await this.fs.write(\n this.config.satori.outputPath\n ? joinPaths(\n this.config.satori.outputPath,\n replacePath(\n input,\n joinPaths(\n this.workspaceConfig.workspaceRoot,\n this.config.root\n )\n )\n )\n : input.replace(findFileExtensionSafe(input), \"svg\"),\n result\n );\n }\n }\n } catch (error) {\n this.debug(\n `Failed to load Satori schema from ${input}: ${(error as Error).message}`\n );\n }\n })\n );\n }\n };\n};\n\nexport default plugin;\n"],"mappings":";;;;;;;;;;;;;;;;;AAiDA,MAAa,UAGX,YACqB;AACrB,QAAO;EACL,MAAM;EACN,SAAS;AACP,UAAO,EACL,QAAQ;IACN,gBAAgB,EAAE;IAClB,OAAO;IACP,QAAQ;IACR,OAAO,EAAE;IACT,GAAG;IACJ,EACF;;EAEH,MAAM,iBAAiB;AACrB,OAAI,CAAC,KAAK,OAAO,OAAO,KACtB,OAAM,IAAI,MACR,yEACD;AAGH,QAAK,OAAO,OAAO,UACjB,MAAM,QAAQ,IACZ,QAAQ,KAAK,OAAO,OAAO,KAAK,CAAC,IAAI,OAAM,SAAQ;AACjD,QAAI,KAAK,SAAS,IAAI,CACpB,QAAO,UAAU,kBAAkB,MAAM,KAAK,CAAC;AAGjD,WAAO,kBAAkB,MAAM,KAAK;KACpC,CACH,EAEA,MAAM,CACN,QACC,SACE,QACA,CAAC,OAAO,MAAM,CAAC,SAAS,sBAAsB,KAAK,CAAC,IACpD,WAAW,KAAK,CACnB;;EAEL,MAAM,UAAU;AACd,SAAM,QAAQ,IACZ,KAAK,OAAO,OAAO,OAAO,IAAI,OAAM,UAAS;AAC3C,QAAI;KACF,MAAM,MACJ,MAAM,KAAK,SAAS,OAA8B,MAAM;AAC1D,SAAI,OAAO,IAAI,SAAS;MACtB,MAAM,SAAS,MAAM,OACnB,IAAI,SACJ,KAAK,IAAI,WAAW,EAAE,EAAE,KAAK,OAAO,OAAO,eAAe,CAC3D;AACD,UAAI,OACF,OAAM,KAAK,GAAG,MACZ,KAAK,OAAO,OAAO,aACf,UACE,KAAK,OAAO,OAAO,YACnB,YACE,OACA,UACE,KAAK,gBAAgB,eACrB,KAAK,OAAO,KACb,CACF,CACF,GACD,MAAM,QAAQ,sBAAsB,MAAM,EAAE,MAAM,EACtD,OACD;;aAGE,OAAO;AACd,UAAK,MACH,qCAAqC,MAAM,IAAK,MAAgB,UACjE;;KAEH,CACH;;EAEJ;;AAGH,kBAAe"}
@@ -0,0 +1,3 @@
1
+ import { SatoriPluginContext, SatoriPluginOptions, SatoriPluginResolvedConfig, SatoriPluginUserConfig, __ΩSatoriPluginContext, __ΩSatoriPluginOptions, __ΩSatoriPluginResolvedConfig, __ΩSatoriPluginUserConfig } from "./plugin.cjs";
2
+ import { SatoriComponentModule, __ΩSatoriComponentModule } from "./module.cjs";
3
+ export { SatoriComponentModule, SatoriPluginContext, SatoriPluginOptions, SatoriPluginResolvedConfig, SatoriPluginUserConfig, __ΩSatoriComponentModule, __ΩSatoriPluginContext, __ΩSatoriPluginOptions, __ΩSatoriPluginResolvedConfig, __ΩSatoriPluginUserConfig };
@@ -0,0 +1,3 @@
1
+ import { SatoriPluginContext, SatoriPluginOptions, SatoriPluginResolvedConfig, SatoriPluginUserConfig, __ΩSatoriPluginContext, __ΩSatoriPluginOptions, __ΩSatoriPluginResolvedConfig, __ΩSatoriPluginUserConfig } from "./plugin.mjs";
2
+ import { SatoriComponentModule, __ΩSatoriComponentModule } from "./module.mjs";
3
+ export { SatoriComponentModule, SatoriPluginContext, SatoriPluginOptions, SatoriPluginResolvedConfig, SatoriPluginUserConfig, __ΩSatoriComponentModule, __ΩSatoriPluginContext, __ΩSatoriPluginOptions, __ΩSatoriPluginResolvedConfig, __ΩSatoriPluginUserConfig };
@@ -0,0 +1,12 @@
1
+ import { SatoriOptions } from "satori";
2
+ import { ReactNode } from "react";
3
+
4
+ //#region src/types/module.d.ts
5
+ interface SatoriComponentModule {
6
+ default: ReactNode;
7
+ options?: SatoriOptions;
8
+ }
9
+ declare type __ΩSatoriComponentModule = any[];
10
+ //#endregion
11
+ export { SatoriComponentModule, __ΩSatoriComponentModule };
12
+ //# sourceMappingURL=module.d.cts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"module.d.cts","names":[],"sources":["../../src/types/module.ts"],"sourcesContent":[],"mappings":";;;;UAqBiB,qBAAA;WACN;EADM,OAAA,CAAA,EAEL,aAFK"}
@@ -0,0 +1,12 @@
1
+ import { SatoriOptions } from "satori";
2
+ import { ReactNode } from "react";
3
+
4
+ //#region src/types/module.d.ts
5
+ interface SatoriComponentModule {
6
+ default: ReactNode;
7
+ options?: SatoriOptions;
8
+ }
9
+ declare type __ΩSatoriComponentModule = any[];
10
+ //#endregion
11
+ export { SatoriComponentModule, __ΩSatoriComponentModule };
12
+ //# sourceMappingURL=module.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"module.d.mts","names":[],"sources":["../../src/types/module.ts"],"sourcesContent":[],"mappings":";;;;UAqBiB,qBAAA;WACN;EADM,OAAA,CAAA,EAEL,aAFK"}
@@ -0,0 +1,46 @@
1
+ import { PluginContext, ResolvedConfig, UserConfig } from "powerlines";
2
+ import { SatoriOptions } from "satori";
3
+
4
+ //#region src/types/plugin.d.ts
5
+ interface SatoriPluginOptions {
6
+ /**
7
+ * A path or glob pattern (or an array of paths and glob patterns) to files that have a Satori component default export.
8
+ */
9
+ path: string | string[];
10
+ /**
11
+ * The path for the generated Satori output images
12
+ *
13
+ * @remarks
14
+ * By default, it will generate the output files alongside each satori component file.
15
+ */
16
+ outputPath?: string;
17
+ /**
18
+ * Default Satori options to apply to all components.
19
+ *
20
+ * @remarks
21
+ * These options can be overridden by individual component modules that export their own options.
22
+ */
23
+ defaultOptions?: Partial<SatoriOptions>;
24
+ }
25
+ interface SatoriPluginUserConfig extends UserConfig {
26
+ satori?: Omit<SatoriPluginOptions, "defaultOptions"> & Required<Pick<SatoriPluginOptions, "defaultOptions">>;
27
+ }
28
+ interface SatoriPluginResolvedConfig extends ResolvedConfig {
29
+ satori: Omit<SatoriPluginOptions, "defaultOptions"> & Required<Pick<SatoriPluginOptions, "defaultOptions">> & {
30
+ /**
31
+ * An array of resolved input file paths containing Satori components.
32
+ *
33
+ * @remarks
34
+ * These paths are determined based on the {@link SatoriPluginOptions.path} option provided in the plugin configuration. These are **not** glob patterns, but the actual resolved file paths.
35
+ */
36
+ inputs: string[];
37
+ };
38
+ }
39
+ type SatoriPluginContext<TResolvedConfig extends SatoriPluginResolvedConfig = SatoriPluginResolvedConfig> = PluginContext<TResolvedConfig>;
40
+ declare type __ΩSatoriPluginOptions = any[];
41
+ declare type __ΩSatoriPluginUserConfig = any[];
42
+ declare type __ΩSatoriPluginResolvedConfig = any[];
43
+ declare type __ΩSatoriPluginContext = any[];
44
+ //#endregion
45
+ export { SatoriPluginContext, SatoriPluginOptions, SatoriPluginResolvedConfig, SatoriPluginUserConfig, __ΩSatoriPluginContext, __ΩSatoriPluginOptions, __ΩSatoriPluginResolvedConfig, __ΩSatoriPluginUserConfig };
46
+ //# sourceMappingURL=plugin.d.cts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"plugin.d.cts","names":[],"sources":["../../src/types/plugin.ts"],"sourcesContent":[],"mappings":";;;;UAqBiB,mBAAA;;AAAjB;AAuBA;EACgB,IAAA,EAAA,MAAA,GAAA,MAAA,EAAA;EAAL;;;;;;EAIM,UAAA,CAAA,EAAA,MAAA;EACF;;;;;;EADmD,cAAA,CAAA,EAR/C,OAQ+C,CARvC,aAQuC,CAAA;AAalE;AAC0B,UAnBT,sBAAA,SAA+B,UAmBtB,CAAA;EACtB,MAAA,CAAA,EAnBO,IAmBP,CAnBY,mBAmBZ,EAAA,gBAAA,CAAA,GAlBA,QAkBA,CAlBS,IAkBT,CAlBc,mBAkBd,EAAA,gBAAA,CAAA,CAAA;;AACA,UAhBa,0BAAA,SAAmC,cAgBhD,CAAA;EAAa,MAAA,EAfP,IAeO,CAfF,mBAeE,EAAA,gBAAA,CAAA,GAdb,QAca,CAdJ,IAcI,CAdC,mBAcD,EAAA,gBAAA,CAAA,CAAA,GAAA;;;;;;;;;;KAHL,4CACc,6BACtB,8BACA,cAAc"}
@@ -0,0 +1,46 @@
1
+ import { SatoriOptions } from "satori";
2
+ import { PluginContext, ResolvedConfig, UserConfig } from "powerlines";
3
+
4
+ //#region src/types/plugin.d.ts
5
+ interface SatoriPluginOptions {
6
+ /**
7
+ * A path or glob pattern (or an array of paths and glob patterns) to files that have a Satori component default export.
8
+ */
9
+ path: string | string[];
10
+ /**
11
+ * The path for the generated Satori output images
12
+ *
13
+ * @remarks
14
+ * By default, it will generate the output files alongside each satori component file.
15
+ */
16
+ outputPath?: string;
17
+ /**
18
+ * Default Satori options to apply to all components.
19
+ *
20
+ * @remarks
21
+ * These options can be overridden by individual component modules that export their own options.
22
+ */
23
+ defaultOptions?: Partial<SatoriOptions>;
24
+ }
25
+ interface SatoriPluginUserConfig extends UserConfig {
26
+ satori?: Omit<SatoriPluginOptions, "defaultOptions"> & Required<Pick<SatoriPluginOptions, "defaultOptions">>;
27
+ }
28
+ interface SatoriPluginResolvedConfig extends ResolvedConfig {
29
+ satori: Omit<SatoriPluginOptions, "defaultOptions"> & Required<Pick<SatoriPluginOptions, "defaultOptions">> & {
30
+ /**
31
+ * An array of resolved input file paths containing Satori components.
32
+ *
33
+ * @remarks
34
+ * These paths are determined based on the {@link SatoriPluginOptions.path} option provided in the plugin configuration. These are **not** glob patterns, but the actual resolved file paths.
35
+ */
36
+ inputs: string[];
37
+ };
38
+ }
39
+ type SatoriPluginContext<TResolvedConfig extends SatoriPluginResolvedConfig = SatoriPluginResolvedConfig> = PluginContext<TResolvedConfig>;
40
+ declare type __ΩSatoriPluginOptions = any[];
41
+ declare type __ΩSatoriPluginUserConfig = any[];
42
+ declare type __ΩSatoriPluginResolvedConfig = any[];
43
+ declare type __ΩSatoriPluginContext = any[];
44
+ //#endregion
45
+ export { SatoriPluginContext, SatoriPluginOptions, SatoriPluginResolvedConfig, SatoriPluginUserConfig, __ΩSatoriPluginContext, __ΩSatoriPluginOptions, __ΩSatoriPluginResolvedConfig, __ΩSatoriPluginUserConfig };
46
+ //# sourceMappingURL=plugin.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"plugin.d.mts","names":[],"sources":["../../src/types/plugin.ts"],"sourcesContent":[],"mappings":";;;;UAqBiB,mBAAA;;AAAjB;AAuBA;EACgB,IAAA,EAAA,MAAA,GAAA,MAAA,EAAA;EAAL;;;;;;EAIM,UAAA,CAAA,EAAA,MAAA;EACF;;;;;;EADmD,cAAA,CAAA,EAR/C,OAQ+C,CARvC,aAQuC,CAAA;AAalE;AAC0B,UAnBT,sBAAA,SAA+B,UAmBtB,CAAA;EACtB,MAAA,CAAA,EAnBO,IAmBP,CAnBY,mBAmBZ,EAAA,gBAAA,CAAA,GAlBA,QAkBA,CAlBS,IAkBT,CAlBc,mBAkBd,EAAA,gBAAA,CAAA,CAAA;;AACA,UAhBa,0BAAA,SAAmC,cAgBhD,CAAA;EAAa,MAAA,EAfP,IAeO,CAfF,mBAeE,EAAA,gBAAA,CAAA,GAdb,QAca,CAdJ,IAcI,CAdC,mBAcD,EAAA,gBAAA,CAAA,CAAA,GAAA;;;;;;;;;;KAHL,4CACc,6BACtB,8BACA,cAAc"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@powerlines/plugin-satori",
3
- "version": "0.1.337",
3
+ "version": "0.1.339",
4
4
  "type": "module",
5
5
  "description": "A Powerlines plugin to use Satori to generate SVG files from jsx/tsx components.",
6
6
  "repository": {
@@ -117,11 +117,11 @@
117
117
  "@stryke/types": "^0.10.52",
118
118
  "defu": "^6.1.4",
119
119
  "jiti": "^2.6.1",
120
- "powerlines": "^0.41.3",
120
+ "powerlines": "^0.41.5",
121
121
  "satori": "^0.18.4"
122
122
  },
123
123
  "devDependencies": {
124
- "@powerlines/plugin-plugin": "^0.12.289",
124
+ "@powerlines/plugin-plugin": "^0.12.291",
125
125
  "@storm-software/config": "^1.135.29",
126
126
  "@types/node": "^25.4.0",
127
127
  "@types/react": "^19.2.14",
@@ -129,5 +129,5 @@
129
129
  },
130
130
  "publishConfig": { "access": "public" },
131
131
  "types": "./dist/index.d.cts",
132
- "gitHead": "df3c5d736cd0fce20967864a4920af034e9434e3"
132
+ "gitHead": "0ed0ad0cd6f440d1584ac705987ef985931161db"
133
133
  }