solidstep 0.3.2 → 0.3.4
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/package.json +3 -1
- package/server.d.ts.map +1 -1
- package/server.js +8 -1
- package/utils/client-only.d.ts +6 -0
- package/utils/client-only.d.ts.map +1 -0
- package/utils/client-only.js +23 -0
- package/utils/options.d.ts +15 -0
- package/utils/options.d.ts.map +1 -0
- package/utils/options.js +1 -0
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "solidstep",
|
|
3
|
-
"version": "0.3.
|
|
3
|
+
"version": "0.3.4",
|
|
4
4
|
"description": "Next Step SolidJS Framework for building web applications.",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"author": "HamzaKV <hamzakv333@gmail.com>",
|
|
@@ -13,6 +13,7 @@
|
|
|
13
13
|
".": "./index.js",
|
|
14
14
|
"./hooks/action-state": "./utils/hooks/action-state.js",
|
|
15
15
|
"./utils/cache": "./utils/cache.js",
|
|
16
|
+
"./utils/client-only": "./utils/client-only.js",
|
|
16
17
|
"./utils/cookies": "./utils/cookies.js",
|
|
17
18
|
"./utils/cors": "./utils/cors.js",
|
|
18
19
|
"./utils/csp": "./utils/csp.js",
|
|
@@ -23,6 +24,7 @@
|
|
|
23
24
|
"./utils/loader": "./utils/loader.js",
|
|
24
25
|
"./utils/logger": "./utils/logger.js",
|
|
25
26
|
"./utils/meta": "./utils/meta.js",
|
|
27
|
+
"./utils/options": "./utils/options.js",
|
|
26
28
|
"./utils/redirect": "./utils/redirect.js",
|
|
27
29
|
"./utils/server-only": "./utils/server-only.js"
|
|
28
30
|
},
|
package/server.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"server.d.ts","sourceRoot":"","sources":["../server.ts"],"names":[],"mappings":"AAkfA,QAAA,MAAM,OAAO,
|
|
1
|
+
{"version":3,"file":"server.d.ts","sourceRoot":"","sources":["../server.ts"],"names":[],"mappings":"AAkfA,QAAA,MAAM,OAAO,2FA+XX,CAAC;AAEH,eAAe,OAAO,CAAC"}
|
package/server.js
CHANGED
|
@@ -369,6 +369,10 @@ onStart();
|
|
|
369
369
|
const handler = eventHandler(async (event) => {
|
|
370
370
|
const req = toWebRequest(event);
|
|
371
371
|
try {
|
|
372
|
+
if (req.url.includes('/.well-known/appspecific/com.chrome.devtools.json')) {
|
|
373
|
+
setResponseStatus(204);
|
|
374
|
+
return;
|
|
375
|
+
}
|
|
372
376
|
if (req.url?.includes('_server')) {
|
|
373
377
|
return handleServerFunction(event);
|
|
374
378
|
}
|
|
@@ -635,6 +639,7 @@ const handler = eventHandler(async (event) => {
|
|
|
635
639
|
return '';
|
|
636
640
|
})
|
|
637
641
|
.join('\n');
|
|
642
|
+
push(`<template id="__page_html__">${html}</template>`);
|
|
638
643
|
push(`
|
|
639
644
|
<script ${cspNonce ? `nonce="${cspNonce}"` : ''}>
|
|
640
645
|
const head = document.querySelector('head');
|
|
@@ -645,7 +650,9 @@ const handler = eventHandler(async (event) => {
|
|
|
645
650
|
});
|
|
646
651
|
document.querySelector('script[data-hydration="loading"]')?.remove();
|
|
647
652
|
const loading = document.querySelector('body');
|
|
648
|
-
|
|
653
|
+
const template = document.getElementById('__page_html__');
|
|
654
|
+
loading.innerHTML = template.innerHTML;
|
|
655
|
+
template.remove();
|
|
649
656
|
</script>
|
|
650
657
|
`);
|
|
651
658
|
push(manifestHtml);
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { Component, ComponentProps, JSX } from 'solid-js';
|
|
2
|
+
declare const clientOnly: <T extends Component<any>>(component: T, options?: {
|
|
3
|
+
fallback?: JSX.Element;
|
|
4
|
+
}) => (props: ComponentProps<T>) => JSX.Element;
|
|
5
|
+
export default clientOnly;
|
|
6
|
+
//# sourceMappingURL=client-only.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"client-only.d.ts","sourceRoot":"","sources":["../../utils/client-only.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,cAAc,EAAE,GAAG,EAAU,MAAM,UAAU,CAAC;AAavE,QAAA,MAAM,UAAU,GAAI,CAAC,SAAS,SAAS,CAAC,GAAG,CAAC,EACxC,WAAW,CAAC,EACZ,UAAU;IAAE,QAAQ,CAAC,EAAE,GAAG,CAAC,OAAO,CAAC;CAAE,aAMtB,cAAc,CAAC,CAAC,CAAC,gBAanC,CAAC;AAEF,eAAe,UAAU,CAAC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { createMemo, createSignal, onMount, sharedConfig, untrack } from 'solid-js';
|
|
2
|
+
import { isServer } from 'solid-js/web';
|
|
3
|
+
const load = (fn, setComp) => {
|
|
4
|
+
fn().then(m => setComp(() => m.default));
|
|
5
|
+
};
|
|
6
|
+
const clientOnly = (component, options) => {
|
|
7
|
+
if (isServer)
|
|
8
|
+
return () => (options?.fallback) ?? null;
|
|
9
|
+
const [comp, setComp] = createSignal();
|
|
10
|
+
load(async () => ({ default: component }), setComp);
|
|
11
|
+
return (props) => {
|
|
12
|
+
let Comp;
|
|
13
|
+
let m;
|
|
14
|
+
if ((Comp = comp()) && !sharedConfig.context)
|
|
15
|
+
return Comp(props);
|
|
16
|
+
const [mounted, setMounted] = createSignal(!sharedConfig.context);
|
|
17
|
+
onMount(() => setMounted(true));
|
|
18
|
+
return createMemo(() => (
|
|
19
|
+
// biome-ignore lint/style/noCommaOperator: <explanation>
|
|
20
|
+
(Comp = comp()), (m = mounted()), untrack(() => (Comp && m ? Comp(props) : options?.fallback))));
|
|
21
|
+
};
|
|
22
|
+
};
|
|
23
|
+
export default clientOnly;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
export type Options = {
|
|
2
|
+
cache?: {
|
|
3
|
+
ttl?: number;
|
|
4
|
+
};
|
|
5
|
+
responseHeaders?: {
|
|
6
|
+
[key: string]: string;
|
|
7
|
+
};
|
|
8
|
+
hydration?: {
|
|
9
|
+
disable?: boolean;
|
|
10
|
+
blockRender?: boolean;
|
|
11
|
+
fetchPriority?: 'high' | 'low' | 'auto';
|
|
12
|
+
};
|
|
13
|
+
};
|
|
14
|
+
export declare const options: (options: Options) => Options;
|
|
15
|
+
//# sourceMappingURL=options.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"options.d.ts","sourceRoot":"","sources":["../../utils/options.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,OAAO,GAAG;IAClB,KAAK,CAAC,EAAE;QACJ,GAAG,CAAC,EAAE,MAAM,CAAC;KAChB,CAAC;IACF,eAAe,CAAC,EAAE;QACd,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAAC;KACzB,CAAC;IACF,SAAS,CAAC,EAAE;QACR,OAAO,CAAC,EAAE,OAAO,CAAC;QAClB,WAAW,CAAC,EAAE,OAAO,CAAC;QACtB,aAAa,CAAC,EAAE,MAAM,GAAG,KAAK,GAAG,MAAM,CAAC;KAC3C,CAAC;CACL,CAAC;AAEF,eAAO,MAAM,OAAO,GAAI,SAAS,OAAO,YAAY,CAAC"}
|
package/utils/options.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export const options = (options) => options;
|