@solidjs/universal 2.0.0-experimental.1 → 2.0.0-experimental.10

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.
package/LICENSE CHANGED
@@ -1,6 +1,6 @@
1
1
  MIT License
2
2
 
3
- Copyright (c) 2016-2023 Ryan Carniato
3
+ Copyright (c) 2016-2025 Ryan Carniato
4
4
 
5
5
  Permission is hereby granted, free of charge, to any person obtaining a copy
6
6
  of this software and associated documentation files (the "Software"), to deal
package/dist/dev.cjs CHANGED
@@ -2,6 +2,8 @@
2
2
 
3
3
  var solidJs = require('solid-js');
4
4
 
5
+ const memo = fn => solidJs.createMemo(() => fn());
6
+
5
7
  function createRenderer({
6
8
  createElement,
7
9
  createTextNode,
@@ -64,7 +66,7 @@ function createRenderer({
64
66
  doNotUnwrap
65
67
  });
66
68
  if (doNotUnwrap && typeof value === "function") return value;
67
- if (multi && value != null && !Array.isArray(value)) value = [value];
69
+ if (multi && !Array.isArray(value)) value = [value != null ? value : ""];
68
70
  if (Array.isArray(value)) {
69
71
  for (let i = 0, len = value.length; i < len; i++) {
70
72
  const item = value[i],
@@ -164,7 +166,7 @@ function createRenderer({
164
166
  prevProps.children = value;
165
167
  });
166
168
  }
167
- solidJs.createRenderEffect(() => props.ref && props.ref(node), () => ({}));
169
+ solidJs.createRenderEffect(() => props.ref && props.ref(node), () => {});
168
170
  solidJs.createRenderEffect(() => {
169
171
  const newProps = {};
170
172
  for (const prop in props) {
@@ -203,7 +205,7 @@ function createRenderer({
203
205
  },
204
206
  mergeProps: solidJs.merge,
205
207
  effect: solidJs.createRenderEffect,
206
- memo: solidJs.createMemo,
208
+ memo,
207
209
  createComponent: solidJs.createComponent,
208
210
  use(fn, element, arg) {
209
211
  return solidJs.untrack(() => fn(element, arg));
package/dist/dev.js CHANGED
@@ -1,4 +1,6 @@
1
- import { createRoot, merge, createRenderEffect, createMemo, createComponent, untrack, flatten } from 'solid-js';
1
+ import { createMemo, createRoot, merge, createRenderEffect, createComponent, untrack, flatten } from 'solid-js';
2
+
3
+ const memo = fn => createMemo(() => fn());
2
4
 
3
5
  function createRenderer({
4
6
  createElement,
@@ -62,7 +64,7 @@ function createRenderer({
62
64
  doNotUnwrap
63
65
  });
64
66
  if (doNotUnwrap && typeof value === "function") return value;
65
- if (multi && value != null && !Array.isArray(value)) value = [value];
67
+ if (multi && !Array.isArray(value)) value = [value != null ? value : ""];
66
68
  if (Array.isArray(value)) {
67
69
  for (let i = 0, len = value.length; i < len; i++) {
68
70
  const item = value[i],
@@ -162,7 +164,7 @@ function createRenderer({
162
164
  prevProps.children = value;
163
165
  });
164
166
  }
165
- createRenderEffect(() => props.ref && props.ref(node), () => ({}));
167
+ createRenderEffect(() => props.ref && props.ref(node), () => {});
166
168
  createRenderEffect(() => {
167
169
  const newProps = {};
168
170
  for (const prop in props) {
@@ -201,7 +203,7 @@ function createRenderer({
201
203
  },
202
204
  mergeProps: merge,
203
205
  effect: createRenderEffect,
204
- memo: createMemo,
206
+ memo,
205
207
  createComponent,
206
208
  use(fn, element, arg) {
207
209
  return untrack(() => fn(element, arg));
@@ -2,6 +2,8 @@
2
2
 
3
3
  var solidJs = require('solid-js');
4
4
 
5
+ const memo = fn => solidJs.createMemo(() => fn());
6
+
5
7
  function createRenderer({
6
8
  createElement,
7
9
  createTextNode,
@@ -64,7 +66,7 @@ function createRenderer({
64
66
  doNotUnwrap
65
67
  });
66
68
  if (doNotUnwrap && typeof value === "function") return value;
67
- if (multi && value != null && !Array.isArray(value)) value = [value];
69
+ if (multi && !Array.isArray(value)) value = [value != null ? value : ""];
68
70
  if (Array.isArray(value)) {
69
71
  for (let i = 0, len = value.length; i < len; i++) {
70
72
  const item = value[i],
@@ -164,7 +166,7 @@ function createRenderer({
164
166
  prevProps.children = value;
165
167
  });
166
168
  }
167
- solidJs.createRenderEffect(() => props.ref && props.ref(node), () => ({}));
169
+ solidJs.createRenderEffect(() => props.ref && props.ref(node), () => {});
168
170
  solidJs.createRenderEffect(() => {
169
171
  const newProps = {};
170
172
  for (const prop in props) {
@@ -203,7 +205,7 @@ function createRenderer({
203
205
  },
204
206
  mergeProps: solidJs.merge,
205
207
  effect: solidJs.createRenderEffect,
206
- memo: solidJs.createMemo,
208
+ memo,
207
209
  createComponent: solidJs.createComponent,
208
210
  use(fn, element, arg) {
209
211
  return solidJs.untrack(() => fn(element, arg));
package/dist/universal.js CHANGED
@@ -1,4 +1,6 @@
1
- import { createRoot, merge, createRenderEffect, createMemo, createComponent, untrack, flatten } from 'solid-js';
1
+ import { createMemo, createRoot, merge, createRenderEffect, createComponent, untrack, flatten } from 'solid-js';
2
+
3
+ const memo = fn => createMemo(() => fn());
2
4
 
3
5
  function createRenderer({
4
6
  createElement,
@@ -62,7 +64,7 @@ function createRenderer({
62
64
  doNotUnwrap
63
65
  });
64
66
  if (doNotUnwrap && typeof value === "function") return value;
65
- if (multi && value != null && !Array.isArray(value)) value = [value];
67
+ if (multi && !Array.isArray(value)) value = [value != null ? value : ""];
66
68
  if (Array.isArray(value)) {
67
69
  for (let i = 0, len = value.length; i < len; i++) {
68
70
  const item = value[i],
@@ -162,7 +164,7 @@ function createRenderer({
162
164
  prevProps.children = value;
163
165
  });
164
166
  }
165
- createRenderEffect(() => props.ref && props.ref(node), () => ({}));
167
+ createRenderEffect(() => props.ref && props.ref(node), () => {});
166
168
  createRenderEffect(() => {
167
169
  const newProps = {};
168
170
  for (const prop in props) {
@@ -201,7 +203,7 @@ function createRenderer({
201
203
  },
202
204
  mergeProps: merge,
203
205
  effect: createRenderEffect,
204
- memo: createMemo,
206
+ memo,
205
207
  createComponent,
206
208
  use(fn, element, arg) {
207
209
  return untrack(() => fn(element, arg));
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@solidjs/universal",
3
3
  "description": "Solid's universal runtime for creating custom renderers",
4
- "version": "2.0.0-experimental.1",
4
+ "version": "2.0.0-experimental.10",
5
5
  "author": "Ryan Carniato",
6
6
  "license": "MIT",
7
7
  "homepage": "https://solidjs.com",
@@ -37,10 +37,10 @@
37
37
  "./types/*": "./types/*"
38
38
  },
39
39
  "peerDependencies": {
40
- "solid-js": "^2.0.0-experimental.1"
40
+ "solid-js": "^2.0.0-experimental.10"
41
41
  },
42
42
  "devDependencies": {
43
- "solid-js": "2.0.0-experimental.1"
43
+ "solid-js": "2.0.0-experimental.10"
44
44
  },
45
45
  "scripts": {
46
46
  "build": "npm-run-all -nl build:*",
package/types/index.d.ts DELETED
@@ -1,29 +0,0 @@
1
- export interface RendererOptions<NodeType> {
2
- createElement(tag: string): NodeType;
3
- createTextNode(value: string): NodeType;
4
- replaceText(textNode: NodeType, value: string): void;
5
- isTextNode(node: NodeType): boolean;
6
- setProperty<T>(node: NodeType, name: string, value: T, prev?: T): void;
7
- insertNode(parent: NodeType, node: NodeType, anchor?: NodeType): void;
8
- removeNode(parent: NodeType, node: NodeType): void;
9
- getParentNode(node: NodeType): NodeType | undefined;
10
- getFirstChild(node: NodeType): NodeType | undefined;
11
- getNextSibling(node: NodeType): NodeType | undefined;
12
- }
13
-
14
- export interface Renderer<NodeType> {
15
- render(code: () => NodeType, node: NodeType): () => void;
16
- effect<T>(fn: (prev?: T) => T, effect: (value: T, prev?: T) => void, init?: T): void;
17
- memo<T>(fn: () => T, equal: boolean): () => T;
18
- createComponent<T>(Comp: (props: T) => NodeType, props: T): NodeType;
19
- createElement(tag: string): NodeType;
20
- createTextNode(value: string): NodeType;
21
- insertNode(parent: NodeType, node: NodeType, anchor?: NodeType): void;
22
- insert<T>(parent: any, accessor: (() => T) | T, marker?: any | null): NodeType;
23
- spread<T>(node: any, accessor: (() => T) | T, skipChildren?: Boolean): void;
24
- setProp<T>(node: NodeType, name: string, value: T, prev?: T): T;
25
- mergeProps(...sources: unknown[]): unknown;
26
- use<A, T>(fn: (element: NodeType, arg: A) => T, element: NodeType, arg: A): T;
27
- }
28
-
29
- export function createRenderer<NodeType>(options: RendererOptions<NodeType>): Renderer<NodeType>;