{"id":13496379,"url":"https://github.com/epicweb-dev/advanced-react-patterns","last_synced_at":"2025-05-13T19:13:44.447Z","repository":{"id":37444875,"uuid":"170207515","full_name":"epicweb-dev/advanced-react-patterns","owner":"epicweb-dev","description":"This is the latest advanced react patterns workshop","archived":false,"fork":false,"pushed_at":"2025-05-13T17:07:34.000Z","size":32616,"stargazers_count":3469,"open_issues_count":0,"forks_count":1091,"subscribers_count":39,"default_branch":"main","last_synced_at":"2025-05-13T18:24:44.474Z","etag":null,"topics":["epicreact-dev","epicweb-dev","kcd-edu","react","react-components","react-patterns","workshop"],"latest_commit_sha":null,"homepage":"https://advanced-patterns.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,"zenodo":null}},"created_at":"2019-02-11T21:46:26.000Z","updated_at":"2025-05-13T17:07:40.000Z","dependencies_parsed_at":"2024-01-27T14:26:35.500Z","dependency_job_id":"9d30f702-090f-424d-81a9-108359a82ce6","html_url":"https://github.com/epicweb-dev/advanced-react-patterns","commit_stats":null,"previous_names":["epicweb-dev/advanced-react-patterns"],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/epicweb-dev%2Fadvanced-react-patterns","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/epicweb-dev%2Fadvanced-react-patterns/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/epicweb-dev%2Fadvanced-react-patterns/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/epicweb-dev%2Fadvanced-react-patterns/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/epicweb-dev","download_url":"https://codeload.github.com/epicweb-dev/advanced-react-patterns/tar.gz/refs/heads/main","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":254010813,"owners_count":21998995,"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","kcd-edu","react","react-components","react-patterns","workshop"],"created_at":"2024-07-31T19:01:47.073Z","updated_at":"2025-05-13T19:13:44.397Z","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\"\u003e🤯 Advanced React Patterns\u003c/a\u003e\u003c/h1\u003e\n  \u003cstrong\u003e\n    Learn how to build simple and flexible React Components and Hooks using\n    modern patterns\n  \u003c/strong\u003e\n  \u003cp\u003e\n    Not only learn great patterns you can use but also the strengths and\n    weaknesses of each, so you know which to reach for to provide your custom\n    hooks and components the flexibility and power you need.\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://advanced-patterns.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- The more experience you have with building React abstractions, the more\n  helpful this workshop will be for you.\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- [Inversion of Control](https://kentcdodds.com/blog/inversion-of-control)\n- [Implement Inversion of Control](https://egghead.io/lessons/egghead-implement-inversion-of-control?pl=kent-s-blog-posts-as-screencasts-eefa540c\u0026af=5236ad)\n\n## System Requirements\n\n- [git][git] v2.18 or greater\n- [NodeJS][node] v20 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\nFollow these steps to get this set up:\n\n```sh nonumber\ngit clone --depth 1 https://github.com/epicweb-dev/advanced-react-patterns.git\ncd advanced-react-patterns\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/advanced-react-patterns/validate.yml?branch=main\u0026logo=github\u0026style=flat-square\n[build]: https://github.com/epicweb-dev/advanced-react-patterns/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/advanced-react-patterns/blob/main/LICENSE.md\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/advanced-react-patterns/issues/new\n\u003c!-- prettier-ignore-end --\u003e\n","funding_links":[],"categories":["TypeScript"],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fepicweb-dev%2Fadvanced-react-patterns","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fepicweb-dev%2Fadvanced-react-patterns","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fepicweb-dev%2Fadvanced-react-patterns/lists"}