{"id":19237152,"url":"https://github.com/epicweb-dev/build-react-hooks","last_synced_at":"2025-04-06T01:07:24.737Z","repository":{"id":246551526,"uuid":"821459158","full_name":"epicweb-dev/build-react-hooks","owner":"epicweb-dev","description":"Understand how React hooks work by building them from scratch","archived":false,"fork":false,"pushed_at":"2025-03-06T22:04:25.000Z","size":8043,"stargazers_count":102,"open_issues_count":0,"forks_count":14,"subscribers_count":3,"default_branch":"main","last_synced_at":"2025-03-30T00:06:27.681Z","etag":null,"topics":["epicreact-dev","epicweb-dev","react","workshop"],"latest_commit_sha":null,"homepage":"https://build-hooks.epicreact.dev","language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"other","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/epicweb-dev.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE.md","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2024-06-28T15:30:39.000Z","updated_at":"2025-03-18T21:45:19.000Z","dependencies_parsed_at":"2024-06-28T16:59:12.232Z","dependency_job_id":"1c981ab0-f75e-4984-93c0-5aaf2ae6b54e","html_url":"https://github.com/epicweb-dev/build-react-hooks","commit_stats":{"total_commits":99,"total_committers":4,"mean_commits":24.75,"dds":0.04040404040404044,"last_synced_commit":"0313a981483a87a39d37d3af30ba340dd419e7f8"},"previous_names":["epicweb-dev/build-react-hooks"],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/epicweb-dev%2Fbuild-react-hooks","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/epicweb-dev%2Fbuild-react-hooks/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/epicweb-dev%2Fbuild-react-hooks/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/epicweb-dev%2Fbuild-react-hooks/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/epicweb-dev","download_url":"https://codeload.github.com/epicweb-dev/build-react-hooks/tar.gz/refs/heads/main","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":247419860,"owners_count":20936012,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["epicreact-dev","epicweb-dev","react","workshop"],"created_at":"2024-11-09T16:25:02.027Z","updated_at":"2025-04-06T01:07:24.721Z","avatar_url":"https://github.com/epicweb-dev.png","language":"TypeScript","readme":"\u003cdiv\u003e\n  \u003ch1 align=\"center\"\u003e\u003ca href=\"https://www.epicweb.dev/workshops\"\u003eBuild React Hooks 🪝\u003c/a\u003e\u003c/h1\u003e\n  \u003cstrong\u003e\n    Understand how React hooks work by building them from scratch\n  \u003c/strong\u003e\n  \u003cp\u003e\n    React hooks are a core building block upon which we build our React apps. Understanding them at a fundamental level will help you use them more efficiently. You'll go from \"it doesn't work and I don't know why\" to \"it works and I understand why.\"\n  \u003c/p\u003e\n\u003c/div\u003e\n\n\u003chr /\u003e\n\n\u003cdiv align=\"center\"\u003e\n  \u003ca\n    alt=\"Epic Web logo with the words Deployed Version\"\n    href=\"https://build-hooks.epicreact.dev\"\n  \u003e\n    \u003cimg\n      width=\"300px\"\n      src=\"https://github-production-user-asset-6210df.s3.amazonaws.com/1500684/254000390-447a3559-e7b9-4918-947a-1b326d239771.png\"\n    /\u003e\n  \u003c/a\u003e\n\u003c/div\u003e\n\n\u003chr /\u003e\n\n\u003c!-- prettier-ignore-start --\u003e\n[![Build Status][build-badge]][build]\n[![GPL 3.0 License][license-badge]][license]\n[![Code of Conduct][coc-badge]][coc]\n\u003c!-- prettier-ignore-end --\u003e\n\n## Prerequisites\n\n- [Experience with React hooks](https://www.epicreact.dev/hooks)\n\n## Pre-workshop Resources\n\nHere are some resources you can read before taking the workshop to get you up to\nspeed on some of the tools and concepts we'll be covering:\n\n- [Getting Closure on React Hooks](https://www.swyx.io/hooks)\n\n## System Requirements\n\n- [git][git] v2.18 or greater\n- [NodeJS][node] v18 or greater\n- [npm][npm] v8 or greater\n\nAll of these must be available in your `PATH`. To verify things are set up\nproperly, you can run this:\n\n```shell\ngit --version\nnode --version\nnpm --version\n```\n\nIf you have trouble with any of these, learn more about the PATH environment\nvariable and how to fix it here for [windows][win-path] or\n[mac/linux][mac-path].\n\n## Setup\n\nThis is a pretty large project (it's actually many apps in one) so it can take\nseveral minutes to get everything set up the first time. Please have a strong\nnetwork connection before running the setup and grab a snack.\n\n\u003e **Warning**: This repo is _very_ large. Make sure you have a good internet\n\u003e connection before you start the setup process. The instructions below use\n\u003e `--depth` to limit the amount you download, but if you have a slow connection,\n\u003e or you pay for bandwidth, you may want to find a place with a better\n\u003e connection.\n\nFollow these steps to get this set up:\n\n```sh nonumber\ngit clone --depth 1 https://github.com/epicweb-dev/build-react-hooks.git\ncd build-react-hooks\nnpm run setup\n```\n\nIf you experience errors here, please open [an issue][issue] with as many\ndetails as you can offer.\n\n## Starting the app\n\nOnce you have the setup finished, you can start the app with:\n\n```\nnpm start\n```\n\n## The Workshop App\n\nLearn all about the workshop app on the\n[Epic Web Getting Started Guide](https://www.epicweb.dev/get-started).\n\n[![Kent with the workshop app in the background](https://github-production-user-asset-6210df.s3.amazonaws.com/1500684/280407082-0e012138-e01d-45d5-abf2-86ffe5d03c69.png)](https://www.epicweb.dev/get-started)\n\n\u003c!-- prettier-ignore-start --\u003e\n[npm]: https://www.npmjs.com/\n[node]: https://nodejs.org\n[git]: https://git-scm.com/\n[build-badge]: https://img.shields.io/github/actions/workflow/status/epicweb-dev/build-react-hooks/validate.yml?branch=main\u0026logo=github\u0026style=flat-square\n[build]: https://github.com/epicweb-dev/build-react-hooks/actions?query=workflow%3Avalidate\n[license-badge]: https://img.shields.io/badge/license-GPL%203.0%20License-blue.svg?style=flat-square\n[license]: https://github.com/epicweb-dev/build-react-hooks/blob/main/LICENSE\n[coc-badge]: https://img.shields.io/badge/code%20of-conduct-ff69b4.svg?style=flat-square\n[coc]: https://kentcdodds.com/conduct\n[win-path]: https://www.howtogeek.com/118594/how-to-edit-your-system-path-for-easy-command-line-access/\n[mac-path]: http://stackoverflow.com/a/24322978/971592\n[issue]: https://github.com/epicweb-dev/build-react-hooks/issues/new\n\u003c!-- prettier-ignore-end --\u003e\n","funding_links":[],"categories":[],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fepicweb-dev%2Fbuild-react-hooks","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fepicweb-dev%2Fbuild-react-hooks","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fepicweb-dev%2Fbuild-react-hooks/lists"}