0.2.0 • Published 9 months ago

@letele/hook-me-up v0.2.0

Weekly downloads
-
License
MIT
Repository
github
Last release
9 months ago

hook-me-up

A collection of custom React hooks.

// Used to fetch data from an API
import { useAPI } from "@letele/hook-me-up"

const url = "https://jsonplaceholder.typicode.com/todos/1"

const content = useAPI(url)

content && console.log(content)

// output
{
	"userId": 1,
	"id": 1,
	"title": "delectus aut autem",
	"completed": false
}
// Used to return a reference element to draw canvas drawings
import { useCanvas } from "@letele/hook-me-up"

function drawing(ctx){
    ctx.save()
    // draw here.
    ctx.restore()
}

const canvasRef = useCanvas(drawing)
    
return (
    <canvas 
        height={"200px"} 
        width={"200px"} 
        ref={canvasRef} 
    />
);
// Checks whether a component mounted
import { useDidMount } from "@letele/hook-me-up"

const isMounted = useDidMount()

if(isMounted){
    // do something
}
// Handles input form event values and submit events.
import { useInput } from "@letele/hook-me-up"

const { 
    onChangeI, onChangeII,
    validI, validII,
    valueI, valueII,
    onSubmit,
} = useInput('')

const valid = validI && validII 

const submit = () => {
    // Do something 
}

const SelectForm = (
    <form 
        onSubmit={e => onSubmit(e, submit)}
    >   
        <label>Label 1</label>
        <select value={valueI} onChange={onChangeI}>
            <option hidden disabled value=""></option>
            <option value="option11">option11</option>
            <option value="option12">option12</option>
        </select>
        
        <label>Label 2</label>
        <select value={valueII} onChange={onChangeII}>
            <option hidden disabled value=""></option>
            <option value="option21">option21</option>
            <option value="option22">option22</option>
            <option value="option23">option22</option>
        </select>

        <input disabled={valid} type="submit" value="Submit"></input>
    </form>
)
// Creates a timer between two different integers.
import { useInterval } from "@letele/hook-me-up"

const interval = useInterval(-5,5,50)

return (
    // A countup timer between -5 and 5 in 50 milliseconds
    <div>{interval}</div>
) 
// Used to detect viewport of client
import { useWindowDimensions } from "@letele/hook-me-up"

const {height, width} = useWindowDimensions()

console.log(`Window height is ${height}`)

console.log(`Window width is ${width}`)
// Toggles a 
import { VscChevronRight, VscChevronDown} from "react-icons/vsc";
import { useToggle } from "@letele/hook-me-up"

const  {mouseOver, ref, setToggle, toggle } = useToggle()

const Chevron = ({val}) => toggle === val?
<VscChevronDown onClick={()=> setToggled(false)} /> :
<VscChevronRight 
    onClick={()=> setToggle(val)} 
    onMouseOver={()=> mouseOver(val)}
/> 

const List = ({val}) => toggle==val &&
<ul>
    <li>list 1</li>
    <li>list 2</li>
    <li>list 3</li>
</ul>

return (
    <> 
        <Chevron val={parent} />
        <List val={parent} />
    </>
)
// Used to detect keys pressed by user
import { useKeyPress } from "@letele/hook-me-up"
const keysToUse = ['1','2','r','9']
useKeyPress( keysToUse,key => console.log(key))
0.2.0

9 months ago

0.1.4

1 year ago

0.1.3

1 year ago

0.1.2

2 years ago

0.1.1

2 years ago

0.1.0

2 years ago