{"id":13450589,"url":"https://github.com/regionjs/region-core","last_synced_at":"2025-03-23T16:31:43.621Z","repository":{"id":33965401,"uuid":"164082761","full_name":"regionjs/region-core","owner":"regionjs","description":"Progressive View Model Management Library","archived":false,"fork":false,"pushed_at":"2024-12-05T03:24:52.000Z","size":32971,"stargazers_count":116,"open_issues_count":18,"forks_count":5,"subscribers_count":3,"default_branch":"master","last_synced_at":"2025-03-05T16:42:36.697Z","etag":null,"topics":["react","redux","swr","typescript"],"latest_commit_sha":null,"homepage":"https://regionjs.github.io/region-core","language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/regionjs.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":"docs/CONTRIBUTING.md","funding":null,"license":"LICENSE","code_of_conduct":"docs/CODE_OF_CONDUCT.md","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":"2019-01-04T08:52:04.000Z","updated_at":"2025-01-14T05:22:06.000Z","dependencies_parsed_at":"2024-04-11T21:48:49.696Z","dependency_job_id":"c7b9d191-85f5-4898-8740-a75f006a87b1","html_url":"https://github.com/regionjs/region-core","commit_stats":{"total_commits":494,"total_committers":2,"mean_commits":247.0,"dds":0.002024291497975672,"last_synced_commit":"59b8a6192564f0f1e395593f716593394fea34e3"},"previous_names":[],"tags_count":131,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/regionjs%2Fregion-core","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/regionjs%2Fregion-core/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/regionjs%2Fregion-core/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/regionjs%2Fregion-core/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/regionjs","download_url":"https://codeload.github.com/regionjs/region-core/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":245130833,"owners_count":20565729,"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":["react","redux","swr","typescript"],"created_at":"2024-07-31T07:00:36.438Z","updated_at":"2025-03-23T16:31:43.296Z","avatar_url":"https://github.com/regionjs.png","language":"TypeScript","funding_links":[],"categories":["Packages"],"sub_categories":[],"readme":"# region-core\n\n[![version](https://img.shields.io/npm/v/region-core.svg?style=flat-square)](http://npm.im/region-core)\n[![npm downloads](https://img.shields.io/npm/dm/region-core.svg?style=flat-square)](https://www.npmjs.com/package/region-core)\n[![codecov](https://img.shields.io/codecov/c/gh/regionjs/region-core)](https://codecov.io/gh/regionjs/region-core)\n[![MIT License](https://img.shields.io/npm/l/region-core.svg?style=flat-square)](http://opensource.org/licenses/MIT)\n\nregion-core is a progressive View Model Management Framework. You can use it while using react state, redux, and benefit from it.\n\nEnglish | [中文](https://github.com/regionjs/region-core/blob/master/docs/README-zh_CN.md)\n\n## Get Started\n\n- install\n\n```bash\nnpm i region-core\n```\n\n- Build your Component above region\n\n```typescript jsx\nimport {createRegion} from 'region-core';\n\nconst region = createRegion\u003cstring\u003e('initialValue');\n\nconst handleChange = e =\u003e region.set(e.target.value);\n\nconst Component = () =\u003e {\n    const value = region.useValue();\n    return \u003cinput value={value} onChange={handleChange} /\u003e;\n};\n```\n\n- Fetching data with region\n\n```typescript jsx\nimport {createRegion} from 'region-core';\n\nconst region = createRegion\u003cUser\u003e();\n\nconst loadUser = region.loadBy(asyncFuncion);\n\n// call loadUser in application lifecycle\nloadUser({userId: 1});\n\nconst Component = () =\u003e {\n    const value = region.useValue();\n    const loading = region.useLoading();\n    const error = region.useError();\n\n    // ...\n    return \u003cdiv\u003e{value}\u003c/div\u003e;\n}\n```\n\n## Docs\n\n[Document And Best Practices](https://github.com/regionjs/region-core/blob/master/docs/Document.md)\n\n[Migrate Guide](https://github.com/regionjs/region-core/blob/master/docs/Migrate.md)\n\n[ChangeLog](https://github.com/regionjs/region-core/blob/master/docs/CHANGELOG.md)\n\n[Request for Comments](https://github.com/regionjs/rfcs/issues)\n\n## Example\n\n[Online Example](https://regionjs.github.io/region-core/)\n\n```bash\ngit clone https://github.com/regionjs/region-core.git\ncd example\nnpm i\nnpm start\n```\n\n[SSR: NextJs with Region](https://codesandbox.io/s/region-ssr-6xprd)\n\n## Contribute\n\nFeel free to raise issues and PR.\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fregionjs%2Fregion-core","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fregionjs%2Fregion-core","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fregionjs%2Fregion-core/lists"}