Skip to content
This repository was archived by the owner on Jul 6, 2025. It is now read-only.

Commit 1220aa4

Browse files
author
alfredo.salzillo
committed
feat: add withUseDeno HOC
1 parent 364bad1 commit 1220aa4

File tree

1 file changed

+13
-1
lines changed

1 file changed

+13
-1
lines changed

hooks.ts

Lines changed: 13 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
import { useContext, useEffect, useState } from 'https://esm.sh/react'
1+
import React, { useContext, useEffect, useState } from 'https://esm.sh/react'
22
import { RouterContext } from './context.ts'
33
import { AsyncUseDenoError } from './error.ts'
44
import events from './events.ts'
@@ -52,3 +52,15 @@ export function useDeno<T = any>(callback: () => (T | Promise<T>), browser?: boo
5252

5353
return data
5454
}
55+
56+
export function withUseDeno<T>(callback: () => (T | Promise<T>), browser?: boolean, deps?: ReadonlyArray<any>) {
57+
return function <P extends T, >(Component: React.ComponentType<P>): React.ComponentType<Exclude<P, keyof T>> {
58+
return function (props: Exclude<P, keyof T>) {
59+
const denoProps = useDeno(callback, browser, deps);
60+
if (typeof denoProps === 'object') {
61+
return React.createElement(Component, { ...props, ...denoProps });
62+
}
63+
return React.createElement(Component);
64+
}
65+
};
66+
}

0 commit comments

Comments
 (0)